139 lines
No EOL
17 KiB
JavaScript
Executable file
139 lines
No EOL
17 KiB
JavaScript
Executable file
import * as tslib_1 from "tslib";
|
|
import { ApplicationRef, ComponentFactoryResolver, Injectable, InjectionToken, Injector, NgZone, ViewContainerRef } from '@angular/core';
|
|
import { LIFECYCLE_DID_ENTER, LIFECYCLE_DID_LEAVE, LIFECYCLE_WILL_ENTER, LIFECYCLE_WILL_LEAVE, LIFECYCLE_WILL_UNLOAD } from '@ionic/core';
|
|
import { NavParams } from '../directives/navigation/nav-params';
|
|
var AngularDelegate = /** @class */ (function () {
|
|
function AngularDelegate(zone, appRef) {
|
|
this.zone = zone;
|
|
this.appRef = appRef;
|
|
}
|
|
AngularDelegate.prototype.create = function (resolver, injector, location) {
|
|
return new AngularFrameworkDelegate(resolver, injector, location, this.appRef, this.zone);
|
|
};
|
|
AngularDelegate.ctorParameters = function () { return [
|
|
{ type: NgZone },
|
|
{ type: ApplicationRef }
|
|
]; };
|
|
AngularDelegate = tslib_1.__decorate([
|
|
Injectable()
|
|
], AngularDelegate);
|
|
return AngularDelegate;
|
|
}());
|
|
export { AngularDelegate };
|
|
var AngularFrameworkDelegate = /** @class */ (function () {
|
|
function AngularFrameworkDelegate(resolver, injector, location, appRef, zone) {
|
|
this.resolver = resolver;
|
|
this.injector = injector;
|
|
this.location = location;
|
|
this.appRef = appRef;
|
|
this.zone = zone;
|
|
this.elRefMap = new WeakMap();
|
|
this.elEventsMap = new WeakMap();
|
|
}
|
|
AngularFrameworkDelegate.prototype.attachViewToDom = function (container, component, params, cssClasses) {
|
|
var _this = this;
|
|
return this.zone.run(function () {
|
|
return new Promise(function (resolve) {
|
|
var el = attachView(_this.zone, _this.resolver, _this.injector, _this.location, _this.appRef, _this.elRefMap, _this.elEventsMap, container, component, params, cssClasses);
|
|
resolve(el);
|
|
});
|
|
});
|
|
};
|
|
AngularFrameworkDelegate.prototype.removeViewFromDom = function (_container, component) {
|
|
var _this = this;
|
|
return this.zone.run(function () {
|
|
return new Promise(function (resolve) {
|
|
var componentRef = _this.elRefMap.get(component);
|
|
if (componentRef) {
|
|
componentRef.destroy();
|
|
_this.elRefMap.delete(component);
|
|
var unbindEvents = _this.elEventsMap.get(component);
|
|
if (unbindEvents) {
|
|
unbindEvents();
|
|
_this.elEventsMap.delete(component);
|
|
}
|
|
}
|
|
resolve();
|
|
});
|
|
});
|
|
};
|
|
return AngularFrameworkDelegate;
|
|
}());
|
|
export { AngularFrameworkDelegate };
|
|
export var attachView = function (zone, resolver, injector, location, appRef, elRefMap, elEventsMap, container, component, params, cssClasses) {
|
|
var e_1, _a;
|
|
var factory = resolver.resolveComponentFactory(component);
|
|
var childInjector = Injector.create({
|
|
providers: getProviders(params),
|
|
parent: injector
|
|
});
|
|
var componentRef = (location)
|
|
? location.createComponent(factory, location.length, childInjector)
|
|
: factory.create(childInjector);
|
|
var instance = componentRef.instance;
|
|
var hostElement = componentRef.location.nativeElement;
|
|
if (params) {
|
|
Object.assign(instance, params);
|
|
}
|
|
if (cssClasses) {
|
|
try {
|
|
for (var cssClasses_1 = tslib_1.__values(cssClasses), cssClasses_1_1 = cssClasses_1.next(); !cssClasses_1_1.done; cssClasses_1_1 = cssClasses_1.next()) {
|
|
var clazz = cssClasses_1_1.value;
|
|
hostElement.classList.add(clazz);
|
|
}
|
|
}
|
|
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
finally {
|
|
try {
|
|
if (cssClasses_1_1 && !cssClasses_1_1.done && (_a = cssClasses_1.return)) _a.call(cssClasses_1);
|
|
}
|
|
finally { if (e_1) throw e_1.error; }
|
|
}
|
|
}
|
|
var unbindEvents = bindLifecycleEvents(zone, instance, hostElement);
|
|
container.appendChild(hostElement);
|
|
if (!location) {
|
|
appRef.attachView(componentRef.hostView);
|
|
}
|
|
componentRef.changeDetectorRef.reattach();
|
|
elRefMap.set(hostElement, componentRef);
|
|
elEventsMap.set(hostElement, unbindEvents);
|
|
return hostElement;
|
|
};
|
|
var LIFECYCLES = [
|
|
LIFECYCLE_WILL_ENTER,
|
|
LIFECYCLE_DID_ENTER,
|
|
LIFECYCLE_WILL_LEAVE,
|
|
LIFECYCLE_DID_LEAVE,
|
|
LIFECYCLE_WILL_UNLOAD
|
|
];
|
|
export var bindLifecycleEvents = function (zone, instance, element) {
|
|
return zone.run(function () {
|
|
var unregisters = LIFECYCLES
|
|
.filter(function (eventName) { return typeof instance[eventName] === 'function'; })
|
|
.map(function (eventName) {
|
|
var handler = function (ev) { return instance[eventName](ev.detail); };
|
|
element.addEventListener(eventName, handler);
|
|
return function () { return element.removeEventListener(eventName, handler); };
|
|
});
|
|
return function () { return unregisters.forEach(function (fn) { return fn(); }); };
|
|
});
|
|
};
|
|
var NavParamsToken = new InjectionToken('NavParamsToken');
|
|
var getProviders = function (params) {
|
|
return [
|
|
{
|
|
provide: NavParamsToken, useValue: params
|
|
},
|
|
{
|
|
provide: NavParams, useFactory: provideNavParamsInjectable, deps: [NavParamsToken]
|
|
}
|
|
];
|
|
};
|
|
var ɵ0 = getProviders;
|
|
var provideNavParamsInjectable = function (params) {
|
|
return new NavParams(params);
|
|
};
|
|
var ɵ1 = provideNavParamsInjectable;
|
|
export { ɵ0, ɵ1 };
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-delegate.js","sourceRoot":"ng://@ionic/angular/","sources":["providers/angular-delegate.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, ComponentFactoryResolver, Injectable, InjectionToken, Injector, NgZone, ViewContainerRef } from '@angular/core';\nimport { FrameworkDelegate, LIFECYCLE_DID_ENTER, LIFECYCLE_DID_LEAVE, LIFECYCLE_WILL_ENTER, LIFECYCLE_WILL_LEAVE, LIFECYCLE_WILL_UNLOAD } from '@ionic/core';\n\nimport { NavParams } from '../directives/navigation/nav-params';\n\n@Injectable()\nexport class AngularDelegate {\n\n  constructor(\n    private zone: NgZone,\n    private appRef: ApplicationRef\n  ) {}\n\n  create(\n    resolver: ComponentFactoryResolver,\n    injector: Injector,\n    location?: ViewContainerRef,\n  ) {\n    return new AngularFrameworkDelegate(resolver, injector, location, this.appRef, this.zone);\n  }\n}\n\nexport class AngularFrameworkDelegate implements FrameworkDelegate {\n\n  private elRefMap = new WeakMap<HTMLElement, any>();\n  private elEventsMap = new WeakMap<HTMLElement, () => void>();\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    private injector: Injector,\n    private location: ViewContainerRef | undefined,\n    private appRef: ApplicationRef,\n    private zone: NgZone,\n  ) {}\n\n  attachViewToDom(container: any, component: any, params?: any, cssClasses?: string[]): Promise<any> {\n    return this.zone.run(() => {\n      return new Promise(resolve => {\n        const el = attachView(\n          this.zone, this.resolver, this.injector, this.location, this.appRef,\n          this.elRefMap, this.elEventsMap,\n          container, component, params, cssClasses\n        );\n        resolve(el);\n      });\n    });\n  }\n\n  removeViewFromDom(_container: any, component: any): Promise<void> {\n    return this.zone.run(() => {\n      return new Promise(resolve => {\n        const componentRef = this.elRefMap.get(component);\n        if (componentRef) {\n          componentRef.destroy();\n          this.elRefMap.delete(component);\n          const unbindEvents = this.elEventsMap.get(component);\n          if (unbindEvents) {\n            unbindEvents();\n            this.elEventsMap.delete(component);\n          }\n        }\n        resolve();\n      });\n    });\n  }\n}\n\nexport const attachView = (\n  zone: NgZone,\n  resolver: ComponentFactoryResolver,\n  injector: Injector,\n  location: ViewContainerRef | undefined,\n  appRef: ApplicationRef,\n  elRefMap: WeakMap<HTMLElement, any>,\n  elEventsMap: WeakMap<HTMLElement, () => void>,\n  container: any, component: any, params: any, cssClasses: string[] | undefined\n) => {\n  const factory = resolver.resolveComponentFactory(component);\n  const childInjector = Injector.create({\n    providers: getProviders(params),\n    parent: injector\n  });\n  const componentRef = (location)\n    ? location.createComponent(factory, location.length, childInjector)\n    : factory.create(childInjector);\n\n  const instance = componentRef.instance;\n  const hostElement = componentRef.location.nativeElement;\n  if (params) {\n    Object.assign(instance, params);\n  }\n  if (cssClasses) {\n    for (const clazz of cssClasses) {\n      hostElement.classList.add(clazz);\n    }\n  }\n  const unbindEvents = bindLifecycleEvents(zone, instance, hostElement);\n  container.appendChild(hostElement);\n\n  if (!location) {\n    appRef.attachView(componentRef.hostView);\n  }\n  componentRef.changeDetectorRef.reattach();\n  elRefMap.set(hostElement, componentRef);\n  elEventsMap.set(hostElement, unbindEvents);\n  return hostElement;\n};\n\nconst LIFECYCLES = [\n  LIFECYCLE_WILL_ENTER,\n  LIFECYCLE_DID_ENTER,\n  LIFECYCLE_WILL_LEAVE,\n  LIFECYCLE_DID_LEAVE,\n  LIFECYCLE_WILL_UNLOAD\n];\n\nexport const bindLifecycleEvents = (zone: NgZone, instance: any, element: HTMLElement) => {\n  return zone.run(() => {\n    const unregisters = LIFECYCLES\n      .filter(eventName => typeof instance[eventName] === 'function')\n      .map(eventName => {\n        const handler = (ev: any) => instance[eventName](ev.detail);\n        element.addEventListener(eventName, handler);\n        return () => element.removeEventListener(eventName, handler);\n      });\n    return () => unregisters.forEach(fn => fn());\n  });\n};\n\nconst NavParamsToken = new InjectionToken<any>('NavParamsToken');\n\nconst getProviders = (params: {[key: string]: any}) => {\n  return [\n    {\n      provide: NavParamsToken, useValue: params\n    },\n    {\n      provide: NavParams, useFactory: provideNavParamsInjectable, deps: [NavParamsToken]\n    }\n  ];\n};\n\nconst provideNavParamsInjectable = (params: {[key: string]: any}) => {\n  return new NavParams(params);\n};\n"]}
|