UNPKG

18.9 kBJavaScriptView Raw
1import { Injectable, InjectionToken, Injector, } from '@angular/core';
2import { LIFECYCLE_DID_ENTER, LIFECYCLE_DID_LEAVE, LIFECYCLE_WILL_ENTER, LIFECYCLE_WILL_LEAVE, LIFECYCLE_WILL_UNLOAD, } from '@ionic/core';
3import { NavParams } from '../directives/navigation/nav-params';
4import { isComponentFactoryResolver } from '../util/util';
5import * as i0 from "@angular/core";
6export class AngularDelegate {
7 constructor(zone, appRef) {
8 this.zone = zone;
9 this.appRef = appRef;
10 }
11 create(resolverOrInjector, injector, location) {
12 return new AngularFrameworkDelegate(resolverOrInjector, injector, location, this.appRef, this.zone);
13 }
14}
15/** @nocollapse */ AngularDelegate.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: AngularDelegate, deps: [{ token: i0.NgZone }, { token: i0.ApplicationRef }], target: i0.ɵɵFactoryTarget.Injectable });
16/** @nocollapse */ AngularDelegate.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: AngularDelegate });
17i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: AngularDelegate, decorators: [{
18 type: Injectable
19 }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ApplicationRef }]; } });
20export class AngularFrameworkDelegate {
21 constructor(resolverOrInjector, injector, location, appRef, zone) {
22 this.resolverOrInjector = resolverOrInjector;
23 this.injector = injector;
24 this.location = location;
25 this.appRef = appRef;
26 this.zone = zone;
27 this.elRefMap = new WeakMap();
28 this.elEventsMap = new WeakMap();
29 }
30 attachViewToDom(container, component, params, cssClasses) {
31 return this.zone.run(() => {
32 return new Promise((resolve) => {
33 const el = attachView(this.zone, this.resolverOrInjector, this.injector, this.location, this.appRef, this.elRefMap, this.elEventsMap, container, component, params, cssClasses);
34 resolve(el);
35 });
36 });
37 }
38 removeViewFromDom(_container, component) {
39 return this.zone.run(() => {
40 return new Promise((resolve) => {
41 const componentRef = this.elRefMap.get(component);
42 if (componentRef) {
43 componentRef.destroy();
44 this.elRefMap.delete(component);
45 const unbindEvents = this.elEventsMap.get(component);
46 if (unbindEvents) {
47 unbindEvents();
48 this.elEventsMap.delete(component);
49 }
50 }
51 resolve();
52 });
53 });
54 }
55}
56export const attachView = (zone, resolverOrInjector, injector, location, appRef, elRefMap, elEventsMap, container, component, params, cssClasses) => {
57 let componentRef;
58 const childInjector = Injector.create({
59 providers: getProviders(params),
60 parent: injector,
61 });
62 if (resolverOrInjector && isComponentFactoryResolver(resolverOrInjector)) {
63 // Angular 13 and lower
64 const factory = resolverOrInjector.resolveComponentFactory(component);
65 componentRef = location
66 ? location.createComponent(factory, location.length, childInjector)
67 : factory.create(childInjector);
68 }
69 else if (location) {
70 // Angular 14
71 const environmentInjector = resolverOrInjector;
72 componentRef = location.createComponent(component, {
73 index: location.indexOf,
74 injector: childInjector,
75 environmentInjector,
76 });
77 }
78 else {
79 return null;
80 }
81 const instance = componentRef.instance;
82 const hostElement = componentRef.location.nativeElement;
83 if (params) {
84 Object.assign(instance, params);
85 }
86 if (cssClasses) {
87 for (const clazz of cssClasses) {
88 hostElement.classList.add(clazz);
89 }
90 }
91 const unbindEvents = bindLifecycleEvents(zone, instance, hostElement);
92 container.appendChild(hostElement);
93 if (!location) {
94 appRef.attachView(componentRef.hostView);
95 }
96 componentRef.changeDetectorRef.reattach();
97 elRefMap.set(hostElement, componentRef);
98 elEventsMap.set(hostElement, unbindEvents);
99 return hostElement;
100};
101const LIFECYCLES = [
102 LIFECYCLE_WILL_ENTER,
103 LIFECYCLE_DID_ENTER,
104 LIFECYCLE_WILL_LEAVE,
105 LIFECYCLE_DID_LEAVE,
106 LIFECYCLE_WILL_UNLOAD,
107];
108export const bindLifecycleEvents = (zone, instance, element) => {
109 return zone.run(() => {
110 const unregisters = LIFECYCLES.filter((eventName) => typeof instance[eventName] === 'function').map((eventName) => {
111 const handler = (ev) => instance[eventName](ev.detail);
112 element.addEventListener(eventName, handler);
113 return () => element.removeEventListener(eventName, handler);
114 });
115 return () => unregisters.forEach((fn) => fn());
116 });
117};
118const NavParamsToken = new InjectionToken('NavParamsToken');
119const getProviders = (params) => {
120 return [
121 {
122 provide: NavParamsToken,
123 useValue: params,
124 },
125 {
126 provide: NavParams,
127 useFactory: provideNavParamsInjectable,
128 deps: [NavParamsToken],
129 },
130 ];
131};
132const provideNavParamsInjectable = (params) => {
133 return new NavParams(params);
134};
135//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-delegate.js","sourceRoot":"","sources":["../../../src/providers/angular-delegate.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  NgZone,\n  ViewContainerRef,\n  Injectable,\n  InjectionToken,\n  Injector,\n  ComponentRef,\n} from '@angular/core';\nimport {\n  FrameworkDelegate,\n  LIFECYCLE_DID_ENTER,\n  LIFECYCLE_DID_LEAVE,\n  LIFECYCLE_WILL_ENTER,\n  LIFECYCLE_WILL_LEAVE,\n  LIFECYCLE_WILL_UNLOAD,\n} from '@ionic/core';\n\nimport { EnvironmentInjector } from '../di/r3_injector';\nimport { NavParams } from '../directives/navigation/nav-params';\nimport { isComponentFactoryResolver } from '../util/util';\n\n@Injectable()\nexport class AngularDelegate {\n  constructor(private zone: NgZone, private appRef: ApplicationRef) {}\n\n  create(\n    resolverOrInjector: ComponentFactoryResolver,\n    injector: Injector,\n    location?: ViewContainerRef\n  ): AngularFrameworkDelegate {\n    return new AngularFrameworkDelegate(resolverOrInjector, injector, location, this.appRef, this.zone);\n  }\n}\n\nexport class AngularFrameworkDelegate implements FrameworkDelegate {\n  private elRefMap = new WeakMap<HTMLElement, any>();\n  private elEventsMap = new WeakMap<HTMLElement, () => void>();\n\n  constructor(\n    private resolverOrInjector: ComponentFactoryResolver | EnvironmentInjector,\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,\n          this.resolverOrInjector,\n          this.injector,\n          this.location,\n          this.appRef,\n          this.elRefMap,\n          this.elEventsMap,\n          container,\n          component,\n          params,\n          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  resolverOrInjector: ComponentFactoryResolver | EnvironmentInjector,\n  injector: Injector,\n  location: ViewContainerRef | undefined,\n  appRef: ApplicationRef,\n  elRefMap: WeakMap<HTMLElement, any>,\n  elEventsMap: WeakMap<HTMLElement, () => void>,\n  container: any,\n  component: any,\n  params: any,\n  cssClasses: string[] | undefined\n): any => {\n  let componentRef: ComponentRef<any>;\n  const childInjector = Injector.create({\n    providers: getProviders(params),\n    parent: injector,\n  });\n\n  if (resolverOrInjector && isComponentFactoryResolver(resolverOrInjector)) {\n    // Angular 13 and lower\n    const factory = resolverOrInjector.resolveComponentFactory(component);\n    componentRef = location\n      ? location.createComponent(factory, location.length, childInjector)\n      : factory.create(childInjector);\n  } else if (location) {\n    // Angular 14\n    const environmentInjector = resolverOrInjector;\n    componentRef = location.createComponent(component, {\n      index: location.indexOf,\n      injector: childInjector,\n      environmentInjector,\n    } as any);\n  } else {\n    return null;\n  }\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): (() => void) => {\n  return zone.run(() => {\n    const unregisters = LIFECYCLES.filter((eventName) => typeof instance[eventName] === 'function').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,\n      useValue: params,\n    },\n    {\n      provide: NavParams,\n      useFactory: provideNavParamsInjectable,\n      deps: [NavParamsToken],\n    },\n  ];\n};\n\nconst provideNavParamsInjectable = (params: { [key: string]: any }) => {\n  return new NavParams(params);\n};\n"]}
\No newline at end of file