refactor(upgrade): ensure compatibility with typescript strict flag (#30993)

As part of FW-1265, the `@angular/upgrade` package is made compatible
with the TypeScript `--strict` flag. Read more about the strict flag [here](https://www.typescriptlang.org/docs/handbook/compiler-options.html)

PR Close #30993
This commit is contained in:
Paul Gschwendtner 2019-06-13 20:12:43 +02:00 committed by Miško Hevery
parent 0139b11227
commit 5bd12c5aa1
3 changed files with 5 additions and 7 deletions

View File

@ -116,9 +116,7 @@ export interface ITranscludeFunction {
// If one argument is provided, then it's assumed to be the cloneAttachFn. // If one argument is provided, then it's assumed to be the cloneAttachFn.
(cloneAttachFn?: ICloneAttachFunction): IAugmentedJQuery; (cloneAttachFn?: ICloneAttachFunction): IAugmentedJQuery;
} }
export interface ICloneAttachFunction { export interface ICloneAttachFunction { (clonedElement: IAugmentedJQuery, scope: IScope): any; }
(clonedElement: IAugmentedJQuery, scope: IScope): any;
}
export type IAugmentedJQuery = Node[] & { export type IAugmentedJQuery = Node[] & {
on?: (name: string, fn: () => void) => void; on?: (name: string, fn: () => void) => void;
data?: (name: string, value?: any) => any; data?: (name: string, value?: any) => any;

View File

@ -124,7 +124,7 @@ export function createWithEachNg1VersionFn(setNg1: typeof setAngularJSGlobal) {
delete win.angular; delete win.angular;
}); });
methodsToPatch.forEach(method => win[method](function() { methodsToPatch.forEach(method => win[method](function(this: unknown) {
// Run the captured callbacks. (Async callbacks not supported.) // Run the captured callbacks. (Async callbacks not supported.)
methodCallbacks[method].forEach(cb => cb.call(this)); methodCallbacks[method].forEach(cb => cb.call(this));
})); }));

View File

@ -537,8 +537,8 @@ export class UpgradeAdapter {
function(testabilityDelegate: ITestabilityService) { function(testabilityDelegate: ITestabilityService) {
const originalWhenStable: Function = testabilityDelegate.whenStable; const originalWhenStable: Function = testabilityDelegate.whenStable;
// Cannot use arrow function below because we need the context // Cannot use arrow function below because we need the context
const newWhenStable = function(callback: Function) { const newWhenStable = function(this: unknown, callback: Function) {
originalWhenStable.call(this, function() { originalWhenStable.call(this, function(this: unknown) {
const ng2Testability: Testability = const ng2Testability: Testability =
upgradeAdapter.moduleRef !.injector.get(Testability); upgradeAdapter.moduleRef !.injector.get(Testability);
if (ng2Testability.isStable()) { if (ng2Testability.isStable()) {
@ -670,7 +670,7 @@ class ParentInjectorPromise {
*/ */
export class UpgradeAdapterRef { export class UpgradeAdapterRef {
/* @internal */ /* @internal */
private _readyFn: ((upgradeAdapterRef?: UpgradeAdapterRef) => void)|null = null; private _readyFn: ((upgradeAdapterRef: UpgradeAdapterRef) => void)|null = null;
public ng1RootScope: IRootScopeService = null !; public ng1RootScope: IRootScopeService = null !;
public ng1Injector: IInjectorService = null !; public ng1Injector: IInjectorService = null !;