From 1a06a9a7c0de519b0a02e2786d61ef473791da23 Mon Sep 17 00:00:00 2001 From: stevewang Date: Thu, 20 Dec 2018 12:06:24 +0800 Subject: [PATCH] fix(upgrade): Fix "no provider" error while injecting a falsy ng1 provider --- src/angular-hybrid.ts | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/src/angular-hybrid.ts b/src/angular-hybrid.ts index f0e6bb9e..5b2ec3e0 100644 --- a/src/angular-hybrid.ts +++ b/src/angular-hybrid.ts @@ -122,7 +122,8 @@ export function objectFactory() { }) export class UIViewNgUpgrade { // The ui-view's name (or '$default') - @Input() name: string; + @Input() + name: string; constructor( ref: ElementRef, @@ -238,7 +239,10 @@ upgradeModule.run([ const mergedInjector = { get: function(token: any, ng2NotFoundValue?: any) { const ng2Injector = ng1Injector.get('$$angularInjector'); - return (ng1Injector.has(token) && ng1Injector.get(token)) || ng2Injector.get(token, ng2NotFoundValue); + if (ng1Injector.has(token)) { + return ng1Injector.get(token); + } + return ng2Injector.get(token, ng2NotFoundValue); }, }; @@ -300,14 +304,11 @@ upgradeModule.run([ // Register a ViewConfig factory for views of type `ng1-to-ng2`. // Returns both an ng1 config and an ng2 config allowing either ng1 or ng2 ui-view components to be targeted. $view._pluginapi._viewConfigFactory('ng1-to-ng2', (path: PathNode[], config: Ng2ViewDeclaration) => { - const ng1ViewConfig: ViewConfig = new Ng1ViewConfig( - path, - Object.assign({}, config, { $type: 'ng1' }), - $templateFactory + const ng1ViewConfig: ViewConfig = ( + new Ng1ViewConfig(path, Object.assign({}, config, { $type: 'ng1' }), $templateFactory) ); - const ng2ViewConfig: ViewConfig = new Ng2ViewConfig( - path, - Object.assign({}, config, { $type: 'ng2' }) + const ng2ViewConfig: ViewConfig = ( + new Ng2ViewConfig(path, Object.assign({}, config, { $type: 'ng2' })) ); return [ng2ViewConfig, ng1ViewConfig];