@3kles/kles-material-dynamicforms 17.12.2 → 17.12.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -50,11 +50,11 @@ export class KlesDynamicFieldDirective {
50
50
  };
51
51
  const injector = Injector.create(options);
52
52
  if (this.field.clearable) {
53
- const composant = this.createSubComponent(this.field.clearableComponent || KlesFormClearComponent);
53
+ const composant = this.createSubComponent(this.field.clearableComponent || KlesFormClearComponent, options);
54
54
  this.subComponents.push(composant);
55
55
  }
56
56
  if (this.field.subComponents) {
57
- this.subComponents.push(...this.field.subComponents.map((subComponent) => this.createSubComponent(subComponent)));
57
+ this.subComponents.push(...this.field.subComponents.map((subComponent) => this.createSubComponent(subComponent, options)));
58
58
  }
59
59
  this.componentRef = this.createComponentRef(injector);
60
60
  this.componentRef.instance.field = this.field;
@@ -78,11 +78,17 @@ export class KlesDynamicFieldDirective {
78
78
  }
79
79
  return componentRef;
80
80
  }
81
- createSubComponent(componentType) {
82
- const component = this.container.createComponent(componentType);
81
+ createSubComponent(componentType, options) {
82
+ const injector = Injector.create(options);
83
+ const component = this.container.createComponent(componentType, { injector });
83
84
  component.instance.field = this.field;
84
85
  component.instance.group = this.group;
85
86
  component.instance.siblingFields = this.siblingFields;
87
+ component.onDestroy(() => {
88
+ if (isDestroyable(injector)) {
89
+ injector.destroy();
90
+ }
91
+ });
86
92
  return component;
87
93
  }
88
94
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: KlesDynamicFieldDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
@@ -100,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
100
106
  }], siblingFields: [{
101
107
  type: Input
102
108
  }] } });
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field.directive.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/directive/dynamic-field.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive, Input, OnInit, ViewContainerRef, ComponentRef, OnChanges, SimpleChanges, OnDestroy, Type, Injector, StaticProvider,\n    Provider\n} from '@angular/core';\n\nimport { UntypedFormGroup } from '@angular/forms';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport { componentMapper } from '../decorators/component.decorator';\nimport { KlesFormClearComponent } from '../fields/clear.component';\nimport { IKlesFieldConfig } from '../interfaces/field.config.interface';\nimport { isDestroyable } from '../utils/destroyable.guard';\n\n@Directive({\n    selector: '[klesDynamicField]'\n})\nexport class KlesDynamicFieldDirective implements OnInit, OnChanges, OnDestroy {\n    @Input() field: IKlesFieldConfig;\n    @Input() group: UntypedFormGroup;\n    @Input() siblingFields: IKlesFieldConfig[];\n\n    componentRef: ComponentRef<any>;\n    subComponents: (ComponentRef<any>)[] = [];\n\n    constructor(protected container: ViewContainerRef, private injector: Injector) { }\n\n    ngOnDestroy(): void {\n        if (this.componentRef) {\n            this.componentRef.destroy();\n        }\n    }\n\n    ngOnInit() {\n        this.buildComponent();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.group) {\n            this.group = changes.group.currentValue;\n        }\n        if (changes.field) {\n            this.field = changes.field.currentValue;\n            this.buildComponent();\n        }\n    }\n\n    buildComponent() {\n        if (this.componentRef) {\n            this.subComponents.forEach(c => c.destroy());\n            this.subComponents = [];\n            this.componentRef.destroy();\n        }\n\n        const options: {\n            providers: Array<Provider | StaticProvider>;\n            parent?: Injector;\n            name?: string;\n        } = {\n            providers: [\n                ...(this.field.providers || []),\n                ...(this.field.dateOptions ? [\n                    ...(this.field.dateOptions.adapter ? [{\n                        provide: DateAdapter,\n                        useClass: this.field.dateOptions.adapter.class,\n                        deps: this.field.dateOptions.adapter.deps || [],\n                    }] : []),\n                    { provide: MAT_DATE_LOCALE, useValue: this.field.dateOptions.language },\n                    { provide: MAT_DATE_FORMATS, useValue: this.field.dateOptions.dateFormat },\n                ] : [])\n            ],\n            parent: this.injector\n        };\n\n        const injector: Injector = Injector.create(options);\n\n        if (this.field.clearable) {\n            const composant = this.createSubComponent(this.field.clearableComponent || KlesFormClearComponent);\n            this.subComponents.push(composant);\n        }\n        if (this.field.subComponents) {\n            this.subComponents.push(...this.field.subComponents.map((subComponent) => this.createSubComponent(subComponent)));\n        }\n\n        this.componentRef = this.createComponentRef(injector);\n\n        this.componentRef.instance.field = this.field;\n        this.componentRef.instance.group = this.group;\n        this.componentRef.instance.siblingFields = this.siblingFields;\n\n        this.componentRef.onDestroy(() => {\n            if (isDestroyable(injector)) {\n                injector.destroy();\n            }\n        });\n    }\n\n    protected createComponentRef(injector: Injector) {\n        const componentRef = this.container.createComponent(\n            componentMapper.find(element => element.type === this.field.type)?.component || this.field.component,\n            { injector, projectableNodes: [this.subComponents.map(sub => sub.location.nativeElement)] });\n\n        if (this.field.hostClass) {\n            if (Array.isArray(this.field.hostClass)) {\n                componentRef.location.nativeElement.classList.add(...this.field.hostClass);\n            } else {\n                componentRef.location.nativeElement.classList.add(this.field.hostClass);\n            }\n\n        }\n\n        return componentRef;\n    }\n\n    private createSubComponent(componentType: Type<any>): ComponentRef<any> {\n        const component = this.container.createComponent(componentType);\n        component.instance.field = this.field;\n        component.instance.group = this.group;\n        component.instance.siblingFields = this.siblingFields;\n        return component;\n    }\n}\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field.directive.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/directive/dynamic-field.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive, Input, OnInit, ViewContainerRef, ComponentRef, OnChanges, SimpleChanges, OnDestroy, Type, Injector, StaticProvider,\n    Provider\n} from '@angular/core';\n\nimport { UntypedFormGroup } from '@angular/forms';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport { componentMapper } from '../decorators/component.decorator';\nimport { KlesFormClearComponent } from '../fields/clear.component';\nimport { IKlesFieldConfig } from '../interfaces/field.config.interface';\nimport { isDestroyable } from '../utils/destroyable.guard';\n\n@Directive({\n    selector: '[klesDynamicField]'\n})\nexport class KlesDynamicFieldDirective implements OnInit, OnChanges, OnDestroy {\n    @Input() field: IKlesFieldConfig;\n    @Input() group: UntypedFormGroup;\n    @Input() siblingFields: IKlesFieldConfig[];\n\n    componentRef: ComponentRef<any>;\n    subComponents: (ComponentRef<any>)[] = [];\n\n    constructor(protected container: ViewContainerRef, private injector: Injector) { }\n\n    ngOnDestroy(): void {\n        if (this.componentRef) {\n            this.componentRef.destroy();\n        }\n    }\n\n    ngOnInit() {\n        this.buildComponent();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.group) {\n            this.group = changes.group.currentValue;\n        }\n        if (changes.field) {\n            this.field = changes.field.currentValue;\n            this.buildComponent();\n        }\n    }\n\n    buildComponent() {\n        if (this.componentRef) {\n            this.subComponents.forEach(c => c.destroy());\n            this.subComponents = [];\n            this.componentRef.destroy();\n        }\n\n        const options: {\n            providers: Array<Provider | StaticProvider>;\n            parent?: Injector;\n            name?: string;\n        } = {\n            providers: [\n                ...(this.field.providers || []),\n                ...(this.field.dateOptions ? [\n                    ...(this.field.dateOptions.adapter ? [{\n                        provide: DateAdapter,\n                        useClass: this.field.dateOptions.adapter.class,\n                        deps: this.field.dateOptions.adapter.deps || [],\n                    }] : []),\n                    { provide: MAT_DATE_LOCALE, useValue: this.field.dateOptions.language },\n                    { provide: MAT_DATE_FORMATS, useValue: this.field.dateOptions.dateFormat },\n                ] : [])\n            ],\n            parent: this.injector\n        };\n\n        const injector: Injector = Injector.create(options);\n\n        if (this.field.clearable) {\n            const composant = this.createSubComponent(this.field.clearableComponent || KlesFormClearComponent, options);\n            this.subComponents.push(composant);\n        }\n        if (this.field.subComponents) {\n            this.subComponents.push(...this.field.subComponents.map((subComponent) => this.createSubComponent(subComponent, options)));\n        }\n\n        this.componentRef = this.createComponentRef(injector);\n\n        this.componentRef.instance.field = this.field;\n        this.componentRef.instance.group = this.group;\n        this.componentRef.instance.siblingFields = this.siblingFields;\n\n        this.componentRef.onDestroy(() => {\n            if (isDestroyable(injector)) {\n                injector.destroy();\n            }\n        });\n    }\n\n    protected createComponentRef(injector: Injector) {\n        const componentRef = this.container.createComponent(\n            componentMapper.find(element => element.type === this.field.type)?.component || this.field.component,\n            { injector, projectableNodes: [this.subComponents.map(sub => sub.location.nativeElement)] });\n\n        if (this.field.hostClass) {\n            if (Array.isArray(this.field.hostClass)) {\n                componentRef.location.nativeElement.classList.add(...this.field.hostClass);\n            } else {\n                componentRef.location.nativeElement.classList.add(this.field.hostClass);\n            }\n\n        }\n\n        return componentRef;\n    }\n\n    private createSubComponent(componentType: Type<any>, options: {\n        providers: Array<Provider | StaticProvider>;\n        parent?: Injector;\n        name?: string;\n    }): ComponentRef<any> {\n        const injector: Injector = Injector.create(options);\n        const component = this.container.createComponent(componentType, { injector });\n        component.instance.field = this.field;\n        component.instance.group = this.group;\n        component.instance.siblingFields = this.siblingFields;\n\n        component.onDestroy(() => {\n            if (isDestroyable(injector)) {\n                injector.destroy();\n            }\n        });\n\n        return component;\n    }\n}\n"]}
@@ -250,11 +250,11 @@ class KlesDynamicFieldDirective {
250
250
  };
251
251
  const injector = Injector.create(options);
252
252
  if (this.field.clearable) {
253
- const composant = this.createSubComponent(this.field.clearableComponent || KlesFormClearComponent);
253
+ const composant = this.createSubComponent(this.field.clearableComponent || KlesFormClearComponent, options);
254
254
  this.subComponents.push(composant);
255
255
  }
256
256
  if (this.field.subComponents) {
257
- this.subComponents.push(...this.field.subComponents.map((subComponent) => this.createSubComponent(subComponent)));
257
+ this.subComponents.push(...this.field.subComponents.map((subComponent) => this.createSubComponent(subComponent, options)));
258
258
  }
259
259
  this.componentRef = this.createComponentRef(injector);
260
260
  this.componentRef.instance.field = this.field;
@@ -278,11 +278,17 @@ class KlesDynamicFieldDirective {
278
278
  }
279
279
  return componentRef;
280
280
  }
281
- createSubComponent(componentType) {
282
- const component = this.container.createComponent(componentType);
281
+ createSubComponent(componentType, options) {
282
+ const injector = Injector.create(options);
283
+ const component = this.container.createComponent(componentType, { injector });
283
284
  component.instance.field = this.field;
284
285
  component.instance.group = this.group;
285
286
  component.instance.siblingFields = this.siblingFields;
287
+ component.onDestroy(() => {
288
+ if (isDestroyable(injector)) {
289
+ injector.destroy();
290
+ }
291
+ });
286
292
  return component;
287
293
  }
288
294
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: KlesDynamicFieldDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }