@3kles/kles-material-dynamicforms 1.1.23 → 1.2.1

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.
@@ -1,5 +1,5 @@
1
1
  import { __decorate } from "tslib";
2
- import { Directive, Input, OnInit, ComponentFactoryResolver, ViewContainerRef, ComponentRef, Type, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';
2
+ import { Directive, Input, OnInit, ComponentFactoryResolver, ViewContainerRef, ComponentRef, Type, OnChanges, SimpleChanges, OnDestroy, Injector } from '@angular/core';
3
3
  import { KlesFormLabelComponent } from '../fields/label.component';
4
4
  import { KlesFormInputComponent } from '../fields/input.component';
5
5
  import { KlesFormSubmitButtonComponent } from '../fields/button-submit.component';
@@ -18,6 +18,7 @@ import { KlesFormLinkComponent } from '../fields/link.component';
18
18
  import { KlesFormSelectionListComponent } from '../fields/selection-list.component';
19
19
  import { KlesFormButtonToogleGroupComponent } from '../fields/button-toogle-group.component';
20
20
  import { KlesFormArrayComponent } from '../fields/array.component';
21
+ import { MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';
21
22
  const componentMapper = {
22
23
  label: KlesFormLabelComponent,
23
24
  input: KlesFormInputComponent,
@@ -39,9 +40,10 @@ const componentMapper = {
39
40
  buttonToogleGroup: KlesFormButtonToogleGroupComponent
40
41
  };
41
42
  let KlesDynamicFieldDirective = class KlesDynamicFieldDirective {
42
- constructor(resolver, container) {
43
+ constructor(resolver, container, injector) {
43
44
  this.resolver = resolver;
44
45
  this.container = container;
46
+ this.injector = injector;
45
47
  }
46
48
  ngOnDestroy() {
47
49
  if (this.componentRef)
@@ -67,7 +69,19 @@ let KlesDynamicFieldDirective = class KlesDynamicFieldDirective {
67
69
  const factory = this.resolver.resolveComponentFactory(this.field.component || componentMapper[this.field.type]);
68
70
  if (this.componentRef)
69
71
  this.componentRef.destroy();
70
- this.componentRef = this.container.createComponent(factory);
72
+ if (this.field.dateOptions) {
73
+ const options = {
74
+ providers: [
75
+ { provide: MAT_DATE_LOCALE, useValue: this.field.dateOptions.language },
76
+ { provide: MAT_DATE_FORMATS, useValue: this.field.dateOptions.dateFormat },
77
+ ]
78
+ };
79
+ const injector = Injector.create(options.providers, this.injector);
80
+ this.componentRef = this.container.createComponent(factory, 0, injector);
81
+ }
82
+ else {
83
+ this.componentRef = this.container.createComponent(factory);
84
+ }
71
85
  this.componentRef.instance.field = this.field;
72
86
  this.componentRef.instance.group = this.group;
73
87
  this.componentRef.instance.siblingFields = this.siblingFields;
@@ -75,7 +89,8 @@ let KlesDynamicFieldDirective = class KlesDynamicFieldDirective {
75
89
  };
76
90
  KlesDynamicFieldDirective.ctorParameters = () => [
77
91
  { type: ComponentFactoryResolver },
78
- { type: ViewContainerRef }
92
+ { type: ViewContainerRef },
93
+ { type: Injector }
79
94
  ];
80
95
  __decorate([
81
96
  Input()
@@ -92,4 +107,4 @@ KlesDynamicFieldDirective = __decorate([
92
107
  })
93
108
  ], KlesDynamicFieldDirective);
94
109
  export { KlesDynamicFieldDirective };
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field.directive.js","sourceRoot":"ng://@3kles/kles-material-dynamicforms/","sources":["lib/directive/dynamic-field.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnInit, ComponentFactoryResolver, ViewContainerRef, ComponentRef, Type, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';\n\nimport { FormGroup } from '@angular/forms';\nimport { IKlesFieldConfig } from '../interfaces/field.config.interface';\nimport { KlesFormLabelComponent } from '../fields/label.component';\nimport { KlesFormInputComponent } from '../fields/input.component';\nimport { KlesFormSubmitButtonComponent } from '../fields/button-submit.component';\nimport { KlesFormSelectComponent } from '../fields/select.component';\nimport { KlesFormDateComponent } from '../fields/date.component';\nimport { KlesFormRadioComponent } from '../fields/radio.component';\nimport { KlesFormCheckboxComponent } from '../fields/checkbox.component';\nimport { KlesFormListFieldComponent } from '../fields/list-field.component';\nimport { KlesFormColorComponent } from '../fields/color.component';\nimport { KlesFormChipComponent } from '../fields/chip.component';\nimport { KlesFormGroupComponent } from '../fields/group.component';\nimport { KlesFormIconComponent } from '../fields/icon.component';\nimport { KlesFormSelectSearchComponent } from '../fields/select.search.component';\nimport { KlesFormLineBreakComponent } from '../fields/line-break.component';\nimport { KlesFormLinkComponent } from '../fields/link.component';\nimport { KlesFormSelectionListComponent } from '../fields/selection-list.component';\nimport { KlesFormButtonToogleGroupComponent } from '../fields/button-toogle-group.component';\nimport { KlesFormArrayComponent } from '../fields/array.component';\n\nconst componentMapper = {\n    label: KlesFormLabelComponent,\n    input: KlesFormInputComponent,\n    button: KlesFormSubmitButtonComponent,\n    select: KlesFormSelectComponent,\n    date: KlesFormDateComponent,\n    radio: KlesFormRadioComponent,\n    checkbox: KlesFormCheckboxComponent,\n    listField: KlesFormListFieldComponent,\n    array: KlesFormArrayComponent,\n    color: KlesFormColorComponent,\n    chip: KlesFormChipComponent,\n    group: KlesFormGroupComponent,\n    icon: KlesFormIconComponent,\n    selectSearch: KlesFormSelectSearchComponent,\n    lineBreak: KlesFormLineBreakComponent,\n    link: KlesFormLinkComponent,\n    selectionList: KlesFormSelectionListComponent,\n    buttonToogleGroup: KlesFormButtonToogleGroupComponent\n};\n\n@Directive({\n    selector: '[klesDynamicField]'\n})\nexport class KlesDynamicFieldDirective implements OnInit, OnChanges, OnDestroy {\n    @Input() field: IKlesFieldConfig;\n    @Input() group: FormGroup;\n    @Input() siblingFields: IKlesFieldConfig[];\n\n    componentRef: ComponentRef<any>;\n\n    constructor(protected resolver: ComponentFactoryResolver,\n        protected container: ViewContainerRef) { }\n\n    ngOnDestroy(): void {\n        if (this.componentRef) this.componentRef.destroy();\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            // if (changes.field.previousValue && changes.field.currentValue.component !== changes.field.previousValue.component) {\n                this.field = changes.field.currentValue;\n                this.buildComponent();\n            // } else {\n            //     this.field = changes.field.currentValue;\n            // }\n        }\n    }\n\n    buildComponent() {\n        const factory = this.resolver.resolveComponentFactory(\n            this.field.component || componentMapper[this.field.type]\n        );\n        if (this.componentRef) this.componentRef.destroy();\n        this.componentRef = this.container.createComponent(factory);\n        this.componentRef.instance.field = this.field;\n        this.componentRef.instance.group = this.group;\n        this.componentRef.instance.siblingFields = this.siblingFields;\n    }\n}\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field.directive.js","sourceRoot":"ng://@3kles/kles-material-dynamicforms/","sources":["lib/directive/dynamic-field.directive.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,wBAAwB,EAAE,gBAAgB,EAAE,YAAY,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAIxK,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,yBAAyB,EAAE,MAAM,8BAA8B,CAAC;AACzE,OAAO,EAAE,0BAA0B,EAAE,MAAM,gCAAgC,CAAC;AAC5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,EAAE,0BAA0B,EAAE,MAAM,gCAAgC,CAAC;AAC5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AACpF,OAAO,EAAE,kCAAkC,EAAE,MAAM,yCAAyC,CAAC;AAC7F,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAe,gBAAgB,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAGxF,MAAM,eAAe,GAAG;IACpB,KAAK,EAAE,sBAAsB;IAC7B,KAAK,EAAE,sBAAsB;IAC7B,MAAM,EAAE,6BAA6B;IACrC,MAAM,EAAE,uBAAuB;IAC/B,IAAI,EAAE,qBAAqB;IAC3B,KAAK,EAAE,sBAAsB;IAC7B,QAAQ,EAAE,yBAAyB;IACnC,SAAS,EAAE,0BAA0B;IACrC,KAAK,EAAE,sBAAsB;IAC7B,KAAK,EAAE,sBAAsB;IAC7B,IAAI,EAAE,qBAAqB;IAC3B,KAAK,EAAE,sBAAsB;IAC7B,IAAI,EAAE,qBAAqB;IAC3B,YAAY,EAAE,6BAA6B;IAC3C,SAAS,EAAE,0BAA0B;IACrC,IAAI,EAAE,qBAAqB;IAC3B,aAAa,EAAE,8BAA8B;IAC7C,iBAAiB,EAAE,kCAAkC;CACxD,CAAC;AAKF,IAAa,yBAAyB,GAAtC,MAAa,yBAAyB;IAOlC,YAAsB,QAAkC,EAC1C,SAA2B,EAAU,QAAkB;QAD/C,aAAQ,GAAR,QAAQ,CAA0B;QAC1C,cAAS,GAAT,SAAS,CAAkB;QAAU,aAAQ,GAAR,QAAQ,CAAU;IAAI,CAAC;IAE1E,WAAW;QACP,IAAI,IAAI,CAAC,YAAY;YAAE,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC;SAC3C;QACD,IAAI,OAAO,CAAC,KAAK,EAAE;YACf,uHAAuH;YACvH,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC;YACxC,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,WAAW;YACX,+CAA+C;YAC/C,IAAI;SACP;IACL,CAAC;IAED,cAAc;QACV,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,uBAAuB,CACjD,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAC3D,CAAC;QACF,IAAI,IAAI,CAAC,YAAY;YAAE,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QACnD,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;YACxB,MAAM,OAAO,GAAG;gBACZ,SAAS,EAAE;oBACP,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,QAAQ,EAAE;oBACvE,EAAE,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,UAAU,EAAE;iBAC7E;aACJ,CAAC;YACF,MAAM,QAAQ,GAAa,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC7E,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;SAC5E;aAAM;YACH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;SAC/D;QACD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;IAClE,CAAC;CACJ,CAAA;;YA9CmC,wBAAwB;YAC/B,gBAAgB;YAAoB,QAAQ;;AAP5D;IAAR,KAAK,EAAE;wDAAyB;AACxB;IAAR,KAAK,EAAE;wDAAkB;AACjB;IAAR,KAAK,EAAE;gEAAmC;AAHlC,yBAAyB;IAHrC,SAAS,CAAC;QACP,QAAQ,EAAE,oBAAoB;KACjC,CAAC;GACW,yBAAyB,CAqDrC;SArDY,yBAAyB","sourcesContent":["import { Directive, Input, OnInit, ComponentFactoryResolver, ViewContainerRef, ComponentRef, Type, OnChanges, SimpleChanges, OnDestroy, Injector } from '@angular/core';\n\nimport { FormGroup } from '@angular/forms';\nimport { IKlesFieldConfig } from '../interfaces/field.config.interface';\nimport { KlesFormLabelComponent } from '../fields/label.component';\nimport { KlesFormInputComponent } from '../fields/input.component';\nimport { KlesFormSubmitButtonComponent } from '../fields/button-submit.component';\nimport { KlesFormSelectComponent } from '../fields/select.component';\nimport { KlesFormDateComponent } from '../fields/date.component';\nimport { KlesFormRadioComponent } from '../fields/radio.component';\nimport { KlesFormCheckboxComponent } from '../fields/checkbox.component';\nimport { KlesFormListFieldComponent } from '../fields/list-field.component';\nimport { KlesFormColorComponent } from '../fields/color.component';\nimport { KlesFormChipComponent } from '../fields/chip.component';\nimport { KlesFormGroupComponent } from '../fields/group.component';\nimport { KlesFormIconComponent } from '../fields/icon.component';\nimport { KlesFormSelectSearchComponent } from '../fields/select.search.component';\nimport { KlesFormLineBreakComponent } from '../fields/line-break.component';\nimport { KlesFormLinkComponent } from '../fields/link.component';\nimport { KlesFormSelectionListComponent } from '../fields/selection-list.component';\nimport { KlesFormButtonToogleGroupComponent } from '../fields/button-toogle-group.component';\nimport { KlesFormArrayComponent } from '../fields/array.component';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport { MAT_MOMENT_DATE_ADAPTER_OPTIONS } from '@angular/material-moment-adapter';\n\nconst componentMapper = {\n    label: KlesFormLabelComponent,\n    input: KlesFormInputComponent,\n    button: KlesFormSubmitButtonComponent,\n    select: KlesFormSelectComponent,\n    date: KlesFormDateComponent,\n    radio: KlesFormRadioComponent,\n    checkbox: KlesFormCheckboxComponent,\n    listField: KlesFormListFieldComponent,\n    array: KlesFormArrayComponent,\n    color: KlesFormColorComponent,\n    chip: KlesFormChipComponent,\n    group: KlesFormGroupComponent,\n    icon: KlesFormIconComponent,\n    selectSearch: KlesFormSelectSearchComponent,\n    lineBreak: KlesFormLineBreakComponent,\n    link: KlesFormLinkComponent,\n    selectionList: KlesFormSelectionListComponent,\n    buttonToogleGroup: KlesFormButtonToogleGroupComponent\n};\n\n@Directive({\n    selector: '[klesDynamicField]'\n})\nexport class KlesDynamicFieldDirective implements OnInit, OnChanges, OnDestroy {\n    @Input() field: IKlesFieldConfig;\n    @Input() group: FormGroup;\n    @Input() siblingFields: IKlesFieldConfig[];\n\n    componentRef: ComponentRef<any>;\n\n    constructor(protected resolver: ComponentFactoryResolver,\n        protected container: ViewContainerRef, private injector: Injector) { }\n\n    ngOnDestroy(): void {\n        if (this.componentRef) this.componentRef.destroy();\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            // if (changes.field.previousValue && changes.field.currentValue.component !== changes.field.previousValue.component) {\n            this.field = changes.field.currentValue;\n            this.buildComponent();\n            // } else {\n            //     this.field = changes.field.currentValue;\n            // }\n        }\n    }\n\n    buildComponent() {\n        const factory = this.resolver.resolveComponentFactory(\n            this.field.component || componentMapper[this.field.type]\n        );\n        if (this.componentRef) this.componentRef.destroy();\n        if (this.field.dateOptions) {\n            const options = {\n                providers: [\n                    { provide: MAT_DATE_LOCALE, useValue: this.field.dateOptions.language },\n                    { provide: MAT_DATE_FORMATS, useValue: this.field.dateOptions.dateFormat },\n                ]\n            };\n            const injector: Injector = Injector.create(options.providers, this.injector);\n            this.componentRef = this.container.createComponent(factory, 0, injector);\n        } else {\n            this.componentRef = this.container.createComponent(factory);\n        }\n        this.componentRef.instance.field = this.field;\n        this.componentRef.instance.group = this.group;\n        this.componentRef.instance.siblingFields = this.siblingFields;\n    }\n}\n"]}
@@ -1 +1 @@
1
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuY29uZmlnLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Aza2xlcy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2VzL2ZpZWxkLmNvbmZpZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElLbGVzVmFsaWRhdG9yIH0gZnJvbSAnLi92YWxpZGF0b3IuaW50ZXJmYWNlJztcbmltcG9ydCB7IFZhbGlkYXRvckZuLCBBc3luY1ZhbGlkYXRvckZuLCBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBUeXBlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBFbnVtVHlwZSB9IGZyb20gJy4uL2VudW1zL3R5cGUuZW51bSc7XG5pbXBvcnQgeyBJS2xlc0ZpZWxkIH0gZnJvbSAnLi9maWVsZC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUtsZXNEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZS5pbnRlcmZhY2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElLbGVzRmllbGRDb25maWcge1xuICAgIHR5cGU/OiBFbnVtVHlwZTsvLyBNYXBwZXIgdHlwZSBpZih0eXBlICYmICFjb21wb25lbnQpPT50eXBlXG4gICAgbmFtZTogc3RyaW5nOy8vIE5hbWUgRmllbGQgKGtleSBmb3IgRm9ybUNvbnRyb2xOYW1lKVxuICAgIGNvbXBvbmVudD86IFR5cGU8YW55PjtcbiAgICBpZD86IHN0cmluZzsvLyBBdHRyaWJ1dCBodG1sIGlkXG4gICAgbGFiZWw/OiBzdHJpbmc7Ly8gTGFiZWwgZmllbGRcbiAgICBwbGFjZWhvbGRlcj86IHN0cmluZzsvLyBQbGFjZWhvbGRlciBmaWVsZFxuICAgIHRvb2x0aXA/OiBzdHJpbmc7Ly8gVG9vbHRpcCBmaWVsZFxuICAgIGlucHV0VHlwZT86IHN0cmluZzsvLyBUeXBlIFxuICAgIG1pbj86IG51bWJlcjtcbiAgICBtYXg/OiBudW1iZXI7XG4gICAgbWF4TGVuZ3RoPzogbnVtYmVyO1xuICAgIHN0ZXA/OiBudW1iZXI7XG4gICAgb3B0aW9ucz86IGFueVtdIHwgU3ViamVjdDxhbnlbXT47Ly8gTGlzdCBvcHRpb25zIGZvciBsaXN0IGNvbXBvbmVudFxuICAgIG5nQ2xhc3M/OiBhbnk7Ly8gbmdjbGFzcyBmb3IgZmllbGRcbiAgICBuZ1N0eWxlPzogYW55Oy8vIG5nU3R5bGUgZm9yIGZpZWxkXG4gICAgcHJvcGVydHk/OiBzdHJpbmc7Ly8gUHJvcGVydHkgZm9yIGZpZWxkXG4gICAgY29sbGVjdGlvbnM/OiBhbnk7Ly8gQ29sbGVjdGlvbnMgZm9yIHN1YmZpZWxkXG4gICAgdmFsdWU/OiBhbnk7Ly8gVmFsdWUgZmllbGRcbiAgICBtdWx0aXBsZT86IGJvb2xlYW47Ly8gTXVsdGlwbGUgc2VsZWN0aW9uIGZpZWxkXG4gICAgZGlzYWJsZWQ/OiBib29sZWFuOy8vIERpc2FibGVkIGZpZWxkXG4gICAgYXV0b2NvbXBsZXRlPzogYm9vbGVhbjsvLyBBdXRvY29tcGxldGUgaW5wdXQgZmllbGRcbiAgICBhdXRvY29tcGxldGVDb21wb25lbnQ/OiBUeXBlPGFueT47Ly9BdXRvY29tcGxldGUgY29tcG9uZW50IHRvIGRpc3BsYXkgaW4gbGlzdCBvcHRpb25cbiAgICBkaXNwbGF5V2l0aD86ICgodmFsdWU6IGFueSkgPT4gc3RyaW5nKSB8IG51bGw7IC8vIEF1dG9jb21wbGV0ZSBkaXNwbGF5IGZvcm1hdFxuICAgIHBhbmVsV2lkdGg/OiBzdHJpbmcgfCBudW1iZXI7Ly9XaXRoIGZvciBwYW5lbCBsaXN0IG9wdGlvblxuICAgIGluZGV0ZXJtaW5hdGU/OiBib29sZWFuOy8vIEluZGV0ZXJtaW5hdGUgY2hlY2thYmxlIGNvbXBvbmVudFxuICAgIGNvbG9yPzogc3RyaW5nOyAvL01hdGVyaWFsIGNvbG9yXG4gICAgaWNvbj86IHN0cmluZzsvL01hdGVyaWFsIGljb25cbiAgICBpY29uU3ZnPzogc3RyaW5nOy8vU3ZnIEljb25cbiAgICB0ZXh0YXJlYUF1dG9TaXplPzogeyBtaW5Sb3dzPzogbnVtYmVyOyBtYXhSb3dzPzogbnVtYmVyIH1cbiAgICB2YWxpZGF0aW9ucz86IElLbGVzVmFsaWRhdG9yPFZhbGlkYXRvckZuPltdO1xuICAgIGFzeW5jVmFsaWRhdGlvbnM/OiBJS2xlc1ZhbGlkYXRvcjxBc3luY1ZhbGlkYXRvckZuPltdO1xuICAgIHBpcGVUcmFuc2Zvcm0/OiB7XG4gICAgICAgIHBpcGU6IFBpcGVUcmFuc2Zvcm0sXG4gICAgICAgIG9wdGlvbnM/OiBhbnlbXVxuICAgIH1bXTtcbiAgICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nO1xuICAgIHZhbHVlQ2hhbmdlcz86ICgoZmllbGQ6IElLbGVzRmllbGRDb25maWcsIGdyb3VwOiBGb3JtR3JvdXAsIHNpYmxpbmdGaWVsZD86IElLbGVzRmllbGRDb25maWdbXSwgdmFsdWVDaGFuZ2VkPzogYW55KSA9PiB2b2lkKTtcbiAgICB0cmlnZ2VyQ29tcG9uZW50PzogVHlwZTxhbnk+OyAvL3RyaWdnZXIgY29tcG9uZW50IHRvIGN1c3RvbWl6ZSB0cmlnZ2VyIGxhYmVsIGluIHNlbGVjdFxuICAgIHZpcnR1YWxTY3JvbGw/OiBib29sZWFuOyAvL1RvIGFjdGl2YXRlIHZpcnR1YWwgc2Nyb2xsXG4gICAgaXRlbVNpemU/OiBudW1iZXI7IC8vIGl0ZW1TaXplIGZvciB2aXJ0dWFsIHNjcm9sbCB2aWV3cG9ydFxuICAgIHBlbmRpbmc/OiBib29sZWFuO1xuICAgIHNlYXJjaEtleXM/OiBzdHJpbmdbXTsgLy9saXN0IG9mIGtleXMgZm9yIG11bHRpcGxlIHNlYXJjaGVzXG4gICAgdXBkYXRlT24/OiAnY2hhbmdlJyB8ICdibHVyJyB8ICdzdWJtaXQnO1xuICAgIGRlYm91bmNlVGltZT86IG51bWJlcjtcbiAgICBkaXJlY3RpdmU/OiAobmV3IChyZWY6IFZpZXdDb250YWluZXJSZWYsIGZpZWxkOiBJS2xlc0ZpZWxkKSA9PiBJS2xlc0RpcmVjdGl2ZSk7XG4gICAgYnV0dG9uVHlwZT86ICdzdWJtaXQnIHwgJ2J1dHRvbicgfCAncmVzZXQnO1xufVxuIl19
1
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuY29uZmlnLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Aza2xlcy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2VzL2ZpZWxkLmNvbmZpZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElLbGVzVmFsaWRhdG9yIH0gZnJvbSAnLi92YWxpZGF0b3IuaW50ZXJmYWNlJztcbmltcG9ydCB7IFZhbGlkYXRvckZuLCBBc3luY1ZhbGlkYXRvckZuLCBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBUeXBlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBFbnVtVHlwZSB9IGZyb20gJy4uL2VudW1zL3R5cGUuZW51bSc7XG5pbXBvcnQgeyBJS2xlc0ZpZWxkIH0gZnJvbSAnLi9maWVsZC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUtsZXNEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgRGF0ZUFkYXB0ZXIsIE1hdERhdGVGb3JtYXRzIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUtsZXNGaWVsZENvbmZpZyB7XG4gICAgdHlwZT86IEVudW1UeXBlOy8vIE1hcHBlciB0eXBlIGlmKHR5cGUgJiYgIWNvbXBvbmVudCk9PnR5cGVcbiAgICBuYW1lOiBzdHJpbmc7Ly8gTmFtZSBGaWVsZCAoa2V5IGZvciBGb3JtQ29udHJvbE5hbWUpXG4gICAgY29tcG9uZW50PzogVHlwZTxhbnk+O1xuICAgIGlkPzogc3RyaW5nOy8vIEF0dHJpYnV0IGh0bWwgaWRcbiAgICBsYWJlbD86IHN0cmluZzsvLyBMYWJlbCBmaWVsZFxuICAgIHBsYWNlaG9sZGVyPzogc3RyaW5nOy8vIFBsYWNlaG9sZGVyIGZpZWxkXG4gICAgdG9vbHRpcD86IHN0cmluZzsvLyBUb29sdGlwIGZpZWxkXG4gICAgaW5wdXRUeXBlPzogc3RyaW5nOy8vIFR5cGUgXG4gICAgbWluPzogbnVtYmVyO1xuICAgIG1heD86IG51bWJlcjtcbiAgICBtYXhMZW5ndGg/OiBudW1iZXI7XG4gICAgc3RlcD86IG51bWJlcjtcbiAgICBvcHRpb25zPzogYW55W10gfCBTdWJqZWN0PGFueVtdPjsvLyBMaXN0IG9wdGlvbnMgZm9yIGxpc3QgY29tcG9uZW50XG4gICAgbmdDbGFzcz86IGFueTsvLyBuZ2NsYXNzIGZvciBmaWVsZFxuICAgIG5nU3R5bGU/OiBhbnk7Ly8gbmdTdHlsZSBmb3IgZmllbGRcbiAgICBwcm9wZXJ0eT86IHN0cmluZzsvLyBQcm9wZXJ0eSBmb3IgZmllbGRcbiAgICBjb2xsZWN0aW9ucz86IGFueTsvLyBDb2xsZWN0aW9ucyBmb3Igc3ViZmllbGRcbiAgICB2YWx1ZT86IGFueTsvLyBWYWx1ZSBmaWVsZFxuICAgIG11bHRpcGxlPzogYm9vbGVhbjsvLyBNdWx0aXBsZSBzZWxlY3Rpb24gZmllbGRcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47Ly8gRGlzYWJsZWQgZmllbGRcbiAgICBhdXRvY29tcGxldGU/OiBib29sZWFuOy8vIEF1dG9jb21wbGV0ZSBpbnB1dCBmaWVsZFxuICAgIGF1dG9jb21wbGV0ZUNvbXBvbmVudD86IFR5cGU8YW55PjsvL0F1dG9jb21wbGV0ZSBjb21wb25lbnQgdG8gZGlzcGxheSBpbiBsaXN0IG9wdGlvblxuICAgIGRpc3BsYXlXaXRoPzogKCh2YWx1ZTogYW55KSA9PiBzdHJpbmcpIHwgbnVsbDsgLy8gQXV0b2NvbXBsZXRlIGRpc3BsYXkgZm9ybWF0XG4gICAgcGFuZWxXaWR0aD86IHN0cmluZyB8IG51bWJlcjsvL1dpdGggZm9yIHBhbmVsIGxpc3Qgb3B0aW9uXG4gICAgaW5kZXRlcm1pbmF0ZT86IGJvb2xlYW47Ly8gSW5kZXRlcm1pbmF0ZSBjaGVja2FibGUgY29tcG9uZW50XG4gICAgY29sb3I/OiBzdHJpbmc7IC8vTWF0ZXJpYWwgY29sb3JcbiAgICBpY29uPzogc3RyaW5nOy8vTWF0ZXJpYWwgaWNvblxuICAgIGljb25Tdmc/OiBzdHJpbmc7Ly9TdmcgSWNvblxuICAgIHRleHRhcmVhQXV0b1NpemU/OiB7IG1pblJvd3M/OiBudW1iZXI7IG1heFJvd3M/OiBudW1iZXIgfVxuICAgIHZhbGlkYXRpb25zPzogSUtsZXNWYWxpZGF0b3I8VmFsaWRhdG9yRm4+W107XG4gICAgYXN5bmNWYWxpZGF0aW9ucz86IElLbGVzVmFsaWRhdG9yPEFzeW5jVmFsaWRhdG9yRm4+W107XG4gICAgcGlwZVRyYW5zZm9ybT86IHtcbiAgICAgICAgcGlwZTogUGlwZVRyYW5zZm9ybSxcbiAgICAgICAgb3B0aW9ucz86IGFueVtdXG4gICAgfVtdO1xuICAgIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbic7XG4gICAgdmFsdWVDaGFuZ2VzPzogKChmaWVsZDogSUtsZXNGaWVsZENvbmZpZywgZ3JvdXA6IEZvcm1Hcm91cCwgc2libGluZ0ZpZWxkPzogSUtsZXNGaWVsZENvbmZpZ1tdLCB2YWx1ZUNoYW5nZWQ/OiBhbnkpID0+IHZvaWQpO1xuICAgIHRyaWdnZXJDb21wb25lbnQ/OiBUeXBlPGFueT47IC8vdHJpZ2dlciBjb21wb25lbnQgdG8gY3VzdG9taXplIHRyaWdnZXIgbGFiZWwgaW4gc2VsZWN0XG4gICAgdmlydHVhbFNjcm9sbD86IGJvb2xlYW47IC8vVG8gYWN0aXZhdGUgdmlydHVhbCBzY3JvbGxcbiAgICBpdGVtU2l6ZT86IG51bWJlcjsgLy8gaXRlbVNpemUgZm9yIHZpcnR1YWwgc2Nyb2xsIHZpZXdwb3J0XG4gICAgcGVuZGluZz86IGJvb2xlYW47XG4gICAgc2VhcmNoS2V5cz86IHN0cmluZ1tdOyAvL2xpc3Qgb2Yga2V5cyBmb3IgbXVsdGlwbGUgc2VhcmNoZXNcbiAgICB1cGRhdGVPbj86ICdjaGFuZ2UnIHwgJ2JsdXInIHwgJ3N1Ym1pdCc7XG4gICAgZGVib3VuY2VUaW1lPzogbnVtYmVyO1xuICAgIGRpcmVjdGl2ZT86IChuZXcgKHJlZjogVmlld0NvbnRhaW5lclJlZiwgZmllbGQ6IElLbGVzRmllbGQpID0+IElLbGVzRGlyZWN0aXZlKTtcbiAgICBidXR0b25UeXBlPzogJ3N1Ym1pdCcgfCAnYnV0dG9uJyB8ICdyZXNldCc7XG4gICAgZGF0ZU9wdGlvbnM/OiB7XG4gICAgICAgIGxhbmd1YWdlOiBzdHJpbmcsXG4gICAgICAgIC8vIGRhdGVBZGFwdGVyOiBhbnksXG4gICAgICAgIC8vIGRhdGVBZGFwdGVyT3B0aW9uczogYW55O1xuICAgICAgICBkYXRlRm9ybWF0OiBNYXREYXRlRm9ybWF0c1xuICAgIH1cbn1cbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  import { __decorate } from "tslib";
2
- import { Directive, Input, OnInit, ComponentFactoryResolver, ViewContainerRef, ComponentRef, Type, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';
2
+ import { Directive, Input, OnInit, ComponentFactoryResolver, ViewContainerRef, ComponentRef, Type, OnChanges, SimpleChanges, OnDestroy, Injector } from '@angular/core';
3
3
  import { KlesFormLabelComponent } from '../fields/label.component';
4
4
  import { KlesFormInputComponent } from '../fields/input.component';
5
5
  import { KlesFormSubmitButtonComponent } from '../fields/button-submit.component';
@@ -18,6 +18,7 @@ import { KlesFormLinkComponent } from '../fields/link.component';
18
18
  import { KlesFormSelectionListComponent } from '../fields/selection-list.component';
19
19
  import { KlesFormButtonToogleGroupComponent } from '../fields/button-toogle-group.component';
20
20
  import { KlesFormArrayComponent } from '../fields/array.component';
21
+ import { MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';
21
22
  var componentMapper = {
22
23
  label: KlesFormLabelComponent,
23
24
  input: KlesFormInputComponent,
@@ -39,9 +40,10 @@ var componentMapper = {
39
40
  buttonToogleGroup: KlesFormButtonToogleGroupComponent
40
41
  };
41
42
  var KlesDynamicFieldDirective = /** @class */ (function () {
42
- function KlesDynamicFieldDirective(resolver, container) {
43
+ function KlesDynamicFieldDirective(resolver, container, injector) {
43
44
  this.resolver = resolver;
44
45
  this.container = container;
46
+ this.injector = injector;
45
47
  }
46
48
  KlesDynamicFieldDirective.prototype.ngOnDestroy = function () {
47
49
  if (this.componentRef)
@@ -67,14 +69,27 @@ var KlesDynamicFieldDirective = /** @class */ (function () {
67
69
  var factory = this.resolver.resolveComponentFactory(this.field.component || componentMapper[this.field.type]);
68
70
  if (this.componentRef)
69
71
  this.componentRef.destroy();
70
- this.componentRef = this.container.createComponent(factory);
72
+ if (this.field.dateOptions) {
73
+ var options = {
74
+ providers: [
75
+ { provide: MAT_DATE_LOCALE, useValue: this.field.dateOptions.language },
76
+ { provide: MAT_DATE_FORMATS, useValue: this.field.dateOptions.dateFormat },
77
+ ]
78
+ };
79
+ var injector = Injector.create(options.providers, this.injector);
80
+ this.componentRef = this.container.createComponent(factory, 0, injector);
81
+ }
82
+ else {
83
+ this.componentRef = this.container.createComponent(factory);
84
+ }
71
85
  this.componentRef.instance.field = this.field;
72
86
  this.componentRef.instance.group = this.group;
73
87
  this.componentRef.instance.siblingFields = this.siblingFields;
74
88
  };
75
89
  KlesDynamicFieldDirective.ctorParameters = function () { return [
76
90
  { type: ComponentFactoryResolver },
77
- { type: ViewContainerRef }
91
+ { type: ViewContainerRef },
92
+ { type: Injector }
78
93
  ]; };
79
94
  __decorate([
80
95
  Input()
@@ -93,4 +108,4 @@ var KlesDynamicFieldDirective = /** @class */ (function () {
93
108
  return KlesDynamicFieldDirective;
94
109
  }());
95
110
  export { KlesDynamicFieldDirective };
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field.directive.js","sourceRoot":"ng://@3kles/kles-material-dynamicforms/","sources":["lib/directive/dynamic-field.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnInit, ComponentFactoryResolver, ViewContainerRef, ComponentRef, Type, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';\n\nimport { FormGroup } from '@angular/forms';\nimport { IKlesFieldConfig } from '../interfaces/field.config.interface';\nimport { KlesFormLabelComponent } from '../fields/label.component';\nimport { KlesFormInputComponent } from '../fields/input.component';\nimport { KlesFormSubmitButtonComponent } from '../fields/button-submit.component';\nimport { KlesFormSelectComponent } from '../fields/select.component';\nimport { KlesFormDateComponent } from '../fields/date.component';\nimport { KlesFormRadioComponent } from '../fields/radio.component';\nimport { KlesFormCheckboxComponent } from '../fields/checkbox.component';\nimport { KlesFormListFieldComponent } from '../fields/list-field.component';\nimport { KlesFormColorComponent } from '../fields/color.component';\nimport { KlesFormChipComponent } from '../fields/chip.component';\nimport { KlesFormGroupComponent } from '../fields/group.component';\nimport { KlesFormIconComponent } from '../fields/icon.component';\nimport { KlesFormSelectSearchComponent } from '../fields/select.search.component';\nimport { KlesFormLineBreakComponent } from '../fields/line-break.component';\nimport { KlesFormLinkComponent } from '../fields/link.component';\nimport { KlesFormSelectionListComponent } from '../fields/selection-list.component';\nimport { KlesFormButtonToogleGroupComponent } from '../fields/button-toogle-group.component';\nimport { KlesFormArrayComponent } from '../fields/array.component';\n\nconst componentMapper = {\n    label: KlesFormLabelComponent,\n    input: KlesFormInputComponent,\n    button: KlesFormSubmitButtonComponent,\n    select: KlesFormSelectComponent,\n    date: KlesFormDateComponent,\n    radio: KlesFormRadioComponent,\n    checkbox: KlesFormCheckboxComponent,\n    listField: KlesFormListFieldComponent,\n    array: KlesFormArrayComponent,\n    color: KlesFormColorComponent,\n    chip: KlesFormChipComponent,\n    group: KlesFormGroupComponent,\n    icon: KlesFormIconComponent,\n    selectSearch: KlesFormSelectSearchComponent,\n    lineBreak: KlesFormLineBreakComponent,\n    link: KlesFormLinkComponent,\n    selectionList: KlesFormSelectionListComponent,\n    buttonToogleGroup: KlesFormButtonToogleGroupComponent\n};\n\n@Directive({\n    selector: '[klesDynamicField]'\n})\nexport class KlesDynamicFieldDirective implements OnInit, OnChanges, OnDestroy {\n    @Input() field: IKlesFieldConfig;\n    @Input() group: FormGroup;\n    @Input() siblingFields: IKlesFieldConfig[];\n\n    componentRef: ComponentRef<any>;\n\n    constructor(protected resolver: ComponentFactoryResolver,\n        protected container: ViewContainerRef) { }\n\n    ngOnDestroy(): void {\n        if (this.componentRef) this.componentRef.destroy();\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            // if (changes.field.previousValue && changes.field.currentValue.component !== changes.field.previousValue.component) {\n                this.field = changes.field.currentValue;\n                this.buildComponent();\n            // } else {\n            //     this.field = changes.field.currentValue;\n            // }\n        }\n    }\n\n    buildComponent() {\n        const factory = this.resolver.resolveComponentFactory(\n            this.field.component || componentMapper[this.field.type]\n        );\n        if (this.componentRef) this.componentRef.destroy();\n        this.componentRef = this.container.createComponent(factory);\n        this.componentRef.instance.field = this.field;\n        this.componentRef.instance.group = this.group;\n        this.componentRef.instance.siblingFields = this.siblingFields;\n    }\n}\n"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field.directive.js","sourceRoot":"ng://@3kles/kles-material-dynamicforms/","sources":["lib/directive/dynamic-field.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnInit, ComponentFactoryResolver, ViewContainerRef, ComponentRef, Type, OnChanges, SimpleChanges, OnDestroy, Injector } from '@angular/core';\n\nimport { FormGroup } from '@angular/forms';\nimport { IKlesFieldConfig } from '../interfaces/field.config.interface';\nimport { KlesFormLabelComponent } from '../fields/label.component';\nimport { KlesFormInputComponent } from '../fields/input.component';\nimport { KlesFormSubmitButtonComponent } from '../fields/button-submit.component';\nimport { KlesFormSelectComponent } from '../fields/select.component';\nimport { KlesFormDateComponent } from '../fields/date.component';\nimport { KlesFormRadioComponent } from '../fields/radio.component';\nimport { KlesFormCheckboxComponent } from '../fields/checkbox.component';\nimport { KlesFormListFieldComponent } from '../fields/list-field.component';\nimport { KlesFormColorComponent } from '../fields/color.component';\nimport { KlesFormChipComponent } from '../fields/chip.component';\nimport { KlesFormGroupComponent } from '../fields/group.component';\nimport { KlesFormIconComponent } from '../fields/icon.component';\nimport { KlesFormSelectSearchComponent } from '../fields/select.search.component';\nimport { KlesFormLineBreakComponent } from '../fields/line-break.component';\nimport { KlesFormLinkComponent } from '../fields/link.component';\nimport { KlesFormSelectionListComponent } from '../fields/selection-list.component';\nimport { KlesFormButtonToogleGroupComponent } from '../fields/button-toogle-group.component';\nimport { KlesFormArrayComponent } from '../fields/array.component';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport { MAT_MOMENT_DATE_ADAPTER_OPTIONS } from '@angular/material-moment-adapter';\n\nconst componentMapper = {\n    label: KlesFormLabelComponent,\n    input: KlesFormInputComponent,\n    button: KlesFormSubmitButtonComponent,\n    select: KlesFormSelectComponent,\n    date: KlesFormDateComponent,\n    radio: KlesFormRadioComponent,\n    checkbox: KlesFormCheckboxComponent,\n    listField: KlesFormListFieldComponent,\n    array: KlesFormArrayComponent,\n    color: KlesFormColorComponent,\n    chip: KlesFormChipComponent,\n    group: KlesFormGroupComponent,\n    icon: KlesFormIconComponent,\n    selectSearch: KlesFormSelectSearchComponent,\n    lineBreak: KlesFormLineBreakComponent,\n    link: KlesFormLinkComponent,\n    selectionList: KlesFormSelectionListComponent,\n    buttonToogleGroup: KlesFormButtonToogleGroupComponent\n};\n\n@Directive({\n    selector: '[klesDynamicField]'\n})\nexport class KlesDynamicFieldDirective implements OnInit, OnChanges, OnDestroy {\n    @Input() field: IKlesFieldConfig;\n    @Input() group: FormGroup;\n    @Input() siblingFields: IKlesFieldConfig[];\n\n    componentRef: ComponentRef<any>;\n\n    constructor(protected resolver: ComponentFactoryResolver,\n        protected container: ViewContainerRef, private injector: Injector) { }\n\n    ngOnDestroy(): void {\n        if (this.componentRef) this.componentRef.destroy();\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            // if (changes.field.previousValue && changes.field.currentValue.component !== changes.field.previousValue.component) {\n            this.field = changes.field.currentValue;\n            this.buildComponent();\n            // } else {\n            //     this.field = changes.field.currentValue;\n            // }\n        }\n    }\n\n    buildComponent() {\n        const factory = this.resolver.resolveComponentFactory(\n            this.field.component || componentMapper[this.field.type]\n        );\n        if (this.componentRef) this.componentRef.destroy();\n        if (this.field.dateOptions) {\n            const options = {\n                providers: [\n                    { provide: MAT_DATE_LOCALE, useValue: this.field.dateOptions.language },\n                    { provide: MAT_DATE_FORMATS, useValue: this.field.dateOptions.dateFormat },\n                ]\n            };\n            const injector: Injector = Injector.create(options.providers, this.injector);\n            this.componentRef = this.container.createComponent(factory, 0, injector);\n        } else {\n            this.componentRef = this.container.createComponent(factory);\n        }\n        this.componentRef.instance.field = this.field;\n        this.componentRef.instance.group = this.group;\n        this.componentRef.instance.siblingFields = this.siblingFields;\n    }\n}\n"]}
@@ -1 +1 @@
1
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuY29uZmlnLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Aza2xlcy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2VzL2ZpZWxkLmNvbmZpZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElLbGVzVmFsaWRhdG9yIH0gZnJvbSAnLi92YWxpZGF0b3IuaW50ZXJmYWNlJztcbmltcG9ydCB7IFZhbGlkYXRvckZuLCBBc3luY1ZhbGlkYXRvckZuLCBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBUeXBlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBFbnVtVHlwZSB9IGZyb20gJy4uL2VudW1zL3R5cGUuZW51bSc7XG5pbXBvcnQgeyBJS2xlc0ZpZWxkIH0gZnJvbSAnLi9maWVsZC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUtsZXNEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZS5pbnRlcmZhY2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElLbGVzRmllbGRDb25maWcge1xuICAgIHR5cGU/OiBFbnVtVHlwZTsvLyBNYXBwZXIgdHlwZSBpZih0eXBlICYmICFjb21wb25lbnQpPT50eXBlXG4gICAgbmFtZTogc3RyaW5nOy8vIE5hbWUgRmllbGQgKGtleSBmb3IgRm9ybUNvbnRyb2xOYW1lKVxuICAgIGNvbXBvbmVudD86IFR5cGU8YW55PjtcbiAgICBpZD86IHN0cmluZzsvLyBBdHRyaWJ1dCBodG1sIGlkXG4gICAgbGFiZWw/OiBzdHJpbmc7Ly8gTGFiZWwgZmllbGRcbiAgICBwbGFjZWhvbGRlcj86IHN0cmluZzsvLyBQbGFjZWhvbGRlciBmaWVsZFxuICAgIHRvb2x0aXA/OiBzdHJpbmc7Ly8gVG9vbHRpcCBmaWVsZFxuICAgIGlucHV0VHlwZT86IHN0cmluZzsvLyBUeXBlIFxuICAgIG1pbj86IG51bWJlcjtcbiAgICBtYXg/OiBudW1iZXI7XG4gICAgbWF4TGVuZ3RoPzogbnVtYmVyO1xuICAgIHN0ZXA/OiBudW1iZXI7XG4gICAgb3B0aW9ucz86IGFueVtdIHwgU3ViamVjdDxhbnlbXT47Ly8gTGlzdCBvcHRpb25zIGZvciBsaXN0IGNvbXBvbmVudFxuICAgIG5nQ2xhc3M/OiBhbnk7Ly8gbmdjbGFzcyBmb3IgZmllbGRcbiAgICBuZ1N0eWxlPzogYW55Oy8vIG5nU3R5bGUgZm9yIGZpZWxkXG4gICAgcHJvcGVydHk/OiBzdHJpbmc7Ly8gUHJvcGVydHkgZm9yIGZpZWxkXG4gICAgY29sbGVjdGlvbnM/OiBhbnk7Ly8gQ29sbGVjdGlvbnMgZm9yIHN1YmZpZWxkXG4gICAgdmFsdWU/OiBhbnk7Ly8gVmFsdWUgZmllbGRcbiAgICBtdWx0aXBsZT86IGJvb2xlYW47Ly8gTXVsdGlwbGUgc2VsZWN0aW9uIGZpZWxkXG4gICAgZGlzYWJsZWQ/OiBib29sZWFuOy8vIERpc2FibGVkIGZpZWxkXG4gICAgYXV0b2NvbXBsZXRlPzogYm9vbGVhbjsvLyBBdXRvY29tcGxldGUgaW5wdXQgZmllbGRcbiAgICBhdXRvY29tcGxldGVDb21wb25lbnQ/OiBUeXBlPGFueT47Ly9BdXRvY29tcGxldGUgY29tcG9uZW50IHRvIGRpc3BsYXkgaW4gbGlzdCBvcHRpb25cbiAgICBkaXNwbGF5V2l0aD86ICgodmFsdWU6IGFueSkgPT4gc3RyaW5nKSB8IG51bGw7IC8vIEF1dG9jb21wbGV0ZSBkaXNwbGF5IGZvcm1hdFxuICAgIHBhbmVsV2lkdGg/OiBzdHJpbmcgfCBudW1iZXI7Ly9XaXRoIGZvciBwYW5lbCBsaXN0IG9wdGlvblxuICAgIGluZGV0ZXJtaW5hdGU/OiBib29sZWFuOy8vIEluZGV0ZXJtaW5hdGUgY2hlY2thYmxlIGNvbXBvbmVudFxuICAgIGNvbG9yPzogc3RyaW5nOyAvL01hdGVyaWFsIGNvbG9yXG4gICAgaWNvbj86IHN0cmluZzsvL01hdGVyaWFsIGljb25cbiAgICBpY29uU3ZnPzogc3RyaW5nOy8vU3ZnIEljb25cbiAgICB0ZXh0YXJlYUF1dG9TaXplPzogeyBtaW5Sb3dzPzogbnVtYmVyOyBtYXhSb3dzPzogbnVtYmVyIH1cbiAgICB2YWxpZGF0aW9ucz86IElLbGVzVmFsaWRhdG9yPFZhbGlkYXRvckZuPltdO1xuICAgIGFzeW5jVmFsaWRhdGlvbnM/OiBJS2xlc1ZhbGlkYXRvcjxBc3luY1ZhbGlkYXRvckZuPltdO1xuICAgIHBpcGVUcmFuc2Zvcm0/OiB7XG4gICAgICAgIHBpcGU6IFBpcGVUcmFuc2Zvcm0sXG4gICAgICAgIG9wdGlvbnM/OiBhbnlbXVxuICAgIH1bXTtcbiAgICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nO1xuICAgIHZhbHVlQ2hhbmdlcz86ICgoZmllbGQ6IElLbGVzRmllbGRDb25maWcsIGdyb3VwOiBGb3JtR3JvdXAsIHNpYmxpbmdGaWVsZD86IElLbGVzRmllbGRDb25maWdbXSwgdmFsdWVDaGFuZ2VkPzogYW55KSA9PiB2b2lkKTtcbiAgICB0cmlnZ2VyQ29tcG9uZW50PzogVHlwZTxhbnk+OyAvL3RyaWdnZXIgY29tcG9uZW50IHRvIGN1c3RvbWl6ZSB0cmlnZ2VyIGxhYmVsIGluIHNlbGVjdFxuICAgIHZpcnR1YWxTY3JvbGw/OiBib29sZWFuOyAvL1RvIGFjdGl2YXRlIHZpcnR1YWwgc2Nyb2xsXG4gICAgaXRlbVNpemU/OiBudW1iZXI7IC8vIGl0ZW1TaXplIGZvciB2aXJ0dWFsIHNjcm9sbCB2aWV3cG9ydFxuICAgIHBlbmRpbmc/OiBib29sZWFuO1xuICAgIHNlYXJjaEtleXM/OiBzdHJpbmdbXTsgLy9saXN0IG9mIGtleXMgZm9yIG11bHRpcGxlIHNlYXJjaGVzXG4gICAgdXBkYXRlT24/OiAnY2hhbmdlJyB8ICdibHVyJyB8ICdzdWJtaXQnO1xuICAgIGRlYm91bmNlVGltZT86IG51bWJlcjtcbiAgICBkaXJlY3RpdmU/OiAobmV3IChyZWY6IFZpZXdDb250YWluZXJSZWYsIGZpZWxkOiBJS2xlc0ZpZWxkKSA9PiBJS2xlc0RpcmVjdGl2ZSk7XG4gICAgYnV0dG9uVHlwZT86ICdzdWJtaXQnIHwgJ2J1dHRvbicgfCAncmVzZXQnO1xufVxuIl19
1
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuY29uZmlnLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Aza2xlcy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2VzL2ZpZWxkLmNvbmZpZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElLbGVzVmFsaWRhdG9yIH0gZnJvbSAnLi92YWxpZGF0b3IuaW50ZXJmYWNlJztcbmltcG9ydCB7IFZhbGlkYXRvckZuLCBBc3luY1ZhbGlkYXRvckZuLCBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBUeXBlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBFbnVtVHlwZSB9IGZyb20gJy4uL2VudW1zL3R5cGUuZW51bSc7XG5pbXBvcnQgeyBJS2xlc0ZpZWxkIH0gZnJvbSAnLi9maWVsZC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUtsZXNEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgRGF0ZUFkYXB0ZXIsIE1hdERhdGVGb3JtYXRzIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUtsZXNGaWVsZENvbmZpZyB7XG4gICAgdHlwZT86IEVudW1UeXBlOy8vIE1hcHBlciB0eXBlIGlmKHR5cGUgJiYgIWNvbXBvbmVudCk9PnR5cGVcbiAgICBuYW1lOiBzdHJpbmc7Ly8gTmFtZSBGaWVsZCAoa2V5IGZvciBGb3JtQ29udHJvbE5hbWUpXG4gICAgY29tcG9uZW50PzogVHlwZTxhbnk+O1xuICAgIGlkPzogc3RyaW5nOy8vIEF0dHJpYnV0IGh0bWwgaWRcbiAgICBsYWJlbD86IHN0cmluZzsvLyBMYWJlbCBmaWVsZFxuICAgIHBsYWNlaG9sZGVyPzogc3RyaW5nOy8vIFBsYWNlaG9sZGVyIGZpZWxkXG4gICAgdG9vbHRpcD86IHN0cmluZzsvLyBUb29sdGlwIGZpZWxkXG4gICAgaW5wdXRUeXBlPzogc3RyaW5nOy8vIFR5cGUgXG4gICAgbWluPzogbnVtYmVyO1xuICAgIG1heD86IG51bWJlcjtcbiAgICBtYXhMZW5ndGg/OiBudW1iZXI7XG4gICAgc3RlcD86IG51bWJlcjtcbiAgICBvcHRpb25zPzogYW55W10gfCBTdWJqZWN0PGFueVtdPjsvLyBMaXN0IG9wdGlvbnMgZm9yIGxpc3QgY29tcG9uZW50XG4gICAgbmdDbGFzcz86IGFueTsvLyBuZ2NsYXNzIGZvciBmaWVsZFxuICAgIG5nU3R5bGU/OiBhbnk7Ly8gbmdTdHlsZSBmb3IgZmllbGRcbiAgICBwcm9wZXJ0eT86IHN0cmluZzsvLyBQcm9wZXJ0eSBmb3IgZmllbGRcbiAgICBjb2xsZWN0aW9ucz86IGFueTsvLyBDb2xsZWN0aW9ucyBmb3Igc3ViZmllbGRcbiAgICB2YWx1ZT86IGFueTsvLyBWYWx1ZSBmaWVsZFxuICAgIG11bHRpcGxlPzogYm9vbGVhbjsvLyBNdWx0aXBsZSBzZWxlY3Rpb24gZmllbGRcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47Ly8gRGlzYWJsZWQgZmllbGRcbiAgICBhdXRvY29tcGxldGU/OiBib29sZWFuOy8vIEF1dG9jb21wbGV0ZSBpbnB1dCBmaWVsZFxuICAgIGF1dG9jb21wbGV0ZUNvbXBvbmVudD86IFR5cGU8YW55PjsvL0F1dG9jb21wbGV0ZSBjb21wb25lbnQgdG8gZGlzcGxheSBpbiBsaXN0IG9wdGlvblxuICAgIGRpc3BsYXlXaXRoPzogKCh2YWx1ZTogYW55KSA9PiBzdHJpbmcpIHwgbnVsbDsgLy8gQXV0b2NvbXBsZXRlIGRpc3BsYXkgZm9ybWF0XG4gICAgcGFuZWxXaWR0aD86IHN0cmluZyB8IG51bWJlcjsvL1dpdGggZm9yIHBhbmVsIGxpc3Qgb3B0aW9uXG4gICAgaW5kZXRlcm1pbmF0ZT86IGJvb2xlYW47Ly8gSW5kZXRlcm1pbmF0ZSBjaGVja2FibGUgY29tcG9uZW50XG4gICAgY29sb3I/OiBzdHJpbmc7IC8vTWF0ZXJpYWwgY29sb3JcbiAgICBpY29uPzogc3RyaW5nOy8vTWF0ZXJpYWwgaWNvblxuICAgIGljb25Tdmc/OiBzdHJpbmc7Ly9TdmcgSWNvblxuICAgIHRleHRhcmVhQXV0b1NpemU/OiB7IG1pblJvd3M/OiBudW1iZXI7IG1heFJvd3M/OiBudW1iZXIgfVxuICAgIHZhbGlkYXRpb25zPzogSUtsZXNWYWxpZGF0b3I8VmFsaWRhdG9yRm4+W107XG4gICAgYXN5bmNWYWxpZGF0aW9ucz86IElLbGVzVmFsaWRhdG9yPEFzeW5jVmFsaWRhdG9yRm4+W107XG4gICAgcGlwZVRyYW5zZm9ybT86IHtcbiAgICAgICAgcGlwZTogUGlwZVRyYW5zZm9ybSxcbiAgICAgICAgb3B0aW9ucz86IGFueVtdXG4gICAgfVtdO1xuICAgIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbic7XG4gICAgdmFsdWVDaGFuZ2VzPzogKChmaWVsZDogSUtsZXNGaWVsZENvbmZpZywgZ3JvdXA6IEZvcm1Hcm91cCwgc2libGluZ0ZpZWxkPzogSUtsZXNGaWVsZENvbmZpZ1tdLCB2YWx1ZUNoYW5nZWQ/OiBhbnkpID0+IHZvaWQpO1xuICAgIHRyaWdnZXJDb21wb25lbnQ/OiBUeXBlPGFueT47IC8vdHJpZ2dlciBjb21wb25lbnQgdG8gY3VzdG9taXplIHRyaWdnZXIgbGFiZWwgaW4gc2VsZWN0XG4gICAgdmlydHVhbFNjcm9sbD86IGJvb2xlYW47IC8vVG8gYWN0aXZhdGUgdmlydHVhbCBzY3JvbGxcbiAgICBpdGVtU2l6ZT86IG51bWJlcjsgLy8gaXRlbVNpemUgZm9yIHZpcnR1YWwgc2Nyb2xsIHZpZXdwb3J0XG4gICAgcGVuZGluZz86IGJvb2xlYW47XG4gICAgc2VhcmNoS2V5cz86IHN0cmluZ1tdOyAvL2xpc3Qgb2Yga2V5cyBmb3IgbXVsdGlwbGUgc2VhcmNoZXNcbiAgICB1cGRhdGVPbj86ICdjaGFuZ2UnIHwgJ2JsdXInIHwgJ3N1Ym1pdCc7XG4gICAgZGVib3VuY2VUaW1lPzogbnVtYmVyO1xuICAgIGRpcmVjdGl2ZT86IChuZXcgKHJlZjogVmlld0NvbnRhaW5lclJlZiwgZmllbGQ6IElLbGVzRmllbGQpID0+IElLbGVzRGlyZWN0aXZlKTtcbiAgICBidXR0b25UeXBlPzogJ3N1Ym1pdCcgfCAnYnV0dG9uJyB8ICdyZXNldCc7XG4gICAgZGF0ZU9wdGlvbnM/OiB7XG4gICAgICAgIGxhbmd1YWdlOiBzdHJpbmcsXG4gICAgICAgIC8vIGRhdGVBZGFwdGVyOiBhbnksXG4gICAgICAgIC8vIGRhdGVBZGFwdGVyT3B0aW9uczogYW55O1xuICAgICAgICBkYXRlRm9ybWF0OiBNYXREYXRlRm9ybWF0c1xuICAgIH1cbn1cbiJdfQ==
@@ -1,11 +1,11 @@
1
1
  import { __decorate, __awaiter } from 'tslib';
2
- import { EventEmitter, Input, Output, Component, ComponentFactoryResolver, ViewContainerRef, Directive, HostBinding, ViewChild, ViewChildren, NgModule, forwardRef, Pipe, CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA } from '@angular/core';
2
+ import { EventEmitter, Input, Output, Component, ComponentFactoryResolver, ViewContainerRef, Directive, HostBinding, ViewChild, ViewChildren, Injector, NgModule, forwardRef, Pipe, CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA } from '@angular/core';
3
3
  import { CommonModule } from '@angular/common';
4
4
  import { Validators, FormBuilder, FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule, FormsModule } from '@angular/forms';
5
5
  import { Subject, Observable, of, ReplaySubject } from 'rxjs';
6
6
  import { takeUntil, startWith, switchMap, map, take } from 'rxjs/operators';
7
7
  import { CdkVirtualScrollViewport, ScrollingModule, CdkScrollable } from '@angular/cdk/scrolling';
8
- import { MatOption, MatNativeDateModule, ErrorStateMatcher } from '@angular/material/core';
8
+ import { MatOption, MAT_DATE_LOCALE, MAT_DATE_FORMATS, MatNativeDateModule, ErrorStateMatcher } from '@angular/material/core';
9
9
  import { MatSliderModule } from '@angular/material/slider';
10
10
  import { MatButtonModule } from '@angular/material/button';
11
11
  import { MatToolbarModule } from '@angular/material/toolbar';
@@ -1357,9 +1357,10 @@ const componentMapper = {
1357
1357
  buttonToogleGroup: KlesFormButtonToogleGroupComponent
1358
1358
  };
1359
1359
  let KlesDynamicFieldDirective = class KlesDynamicFieldDirective {
1360
- constructor(resolver, container) {
1360
+ constructor(resolver, container, injector) {
1361
1361
  this.resolver = resolver;
1362
1362
  this.container = container;
1363
+ this.injector = injector;
1363
1364
  }
1364
1365
  ngOnDestroy() {
1365
1366
  if (this.componentRef)
@@ -1385,7 +1386,19 @@ let KlesDynamicFieldDirective = class KlesDynamicFieldDirective {
1385
1386
  const factory = this.resolver.resolveComponentFactory(this.field.component || componentMapper[this.field.type]);
1386
1387
  if (this.componentRef)
1387
1388
  this.componentRef.destroy();
1388
- this.componentRef = this.container.createComponent(factory);
1389
+ if (this.field.dateOptions) {
1390
+ const options = {
1391
+ providers: [
1392
+ { provide: MAT_DATE_LOCALE, useValue: this.field.dateOptions.language },
1393
+ { provide: MAT_DATE_FORMATS, useValue: this.field.dateOptions.dateFormat },
1394
+ ]
1395
+ };
1396
+ const injector = Injector.create(options.providers, this.injector);
1397
+ this.componentRef = this.container.createComponent(factory, 0, injector);
1398
+ }
1399
+ else {
1400
+ this.componentRef = this.container.createComponent(factory);
1401
+ }
1389
1402
  this.componentRef.instance.field = this.field;
1390
1403
  this.componentRef.instance.group = this.group;
1391
1404
  this.componentRef.instance.siblingFields = this.siblingFields;
@@ -1393,7 +1406,8 @@ let KlesDynamicFieldDirective = class KlesDynamicFieldDirective {
1393
1406
  };
1394
1407
  KlesDynamicFieldDirective.ctorParameters = () => [
1395
1408
  { type: ComponentFactoryResolver },
1396
- { type: ViewContainerRef }
1409
+ { type: ViewContainerRef },
1410
+ { type: Injector }
1397
1411
  ];
1398
1412
  __decorate([
1399
1413
  Input()