@3kles/kles-material-dynamicforms 1.1.5 → 1.1.8

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.
Files changed (28) hide show
  1. package/3kles-kles-material-dynamicforms.metadata.json +1 -1
  2. package/bundles/3kles-kles-material-dynamicforms.umd.js +75 -11
  3. package/bundles/3kles-kles-material-dynamicforms.umd.js.map +1 -1
  4. package/bundles/3kles-kles-material-dynamicforms.umd.min.js +2 -2
  5. package/bundles/3kles-kles-material-dynamicforms.umd.min.js.map +1 -1
  6. package/esm2015/lib/directive/dynamic-field.directive.js +3 -1
  7. package/esm2015/lib/dynamic-form.component.js +34 -12
  8. package/esm2015/lib/enums/type.enum.js +14 -0
  9. package/esm2015/lib/fields/array.component.js +37 -0
  10. package/esm2015/lib/interfaces/field.config.interface.js +1 -1
  11. package/esm2015/lib/kles-material-dynamicforms.module.js +4 -2
  12. package/esm2015/public-api.js +4 -1
  13. package/esm5/lib/directive/dynamic-field.directive.js +3 -1
  14. package/esm5/lib/dynamic-form.component.js +35 -13
  15. package/esm5/lib/enums/type.enum.js +14 -0
  16. package/esm5/lib/fields/array.component.js +31 -0
  17. package/esm5/lib/interfaces/field.config.interface.js +1 -1
  18. package/esm5/lib/kles-material-dynamicforms.module.js +4 -2
  19. package/esm5/public-api.js +4 -1
  20. package/fesm2015/3kles-kles-material-dynamicforms.js +82 -12
  21. package/fesm2015/3kles-kles-material-dynamicforms.js.map +1 -1
  22. package/fesm5/3kles-kles-material-dynamicforms.js +77 -13
  23. package/fesm5/3kles-kles-material-dynamicforms.js.map +1 -1
  24. package/lib/enums/type.enum.d.ts +12 -0
  25. package/lib/fields/array.component.d.ts +7 -0
  26. package/lib/interfaces/field.config.interface.d.ts +2 -1
  27. package/package.json +1 -1
  28. package/public-api.d.ts +3 -0
@@ -1,6 +1,7 @@
1
- import { __decorate } from "tslib";
1
+ import { __assign, __decorate } from "tslib";
2
2
  import { Component, Input, Output, EventEmitter } from '@angular/core';
3
- import { FormGroup, FormBuilder, Validators, ValidatorFn, AsyncValidatorFn, ValidationErrors, AsyncValidator, AbstractControl } from '@angular/forms';
3
+ import { FormGroup, FormBuilder, Validators, ValidatorFn, AsyncValidatorFn, AbstractControl } from '@angular/forms';
4
+ import { EnumType } from './enums/type.enum';
4
5
  var KlesDynamicFormComponent = /** @class */ (function () {
5
6
  function KlesDynamicFormComponent(fb) {
6
7
  this.fb = fb;
@@ -69,7 +70,7 @@ var KlesDynamicFormComponent = /** @class */ (function () {
69
70
  this.fields
70
71
  .filter(function (field) { return !_this.form.controls[field.name]; })
71
72
  .forEach(function (field) {
72
- if (field.type === 'lineBreak') {
73
+ if (field.type === EnumType.lineBreak) {
73
74
  return;
74
75
  }
75
76
  var control = _this.createControl(field);
@@ -78,19 +79,40 @@ var KlesDynamicFormComponent = /** @class */ (function () {
78
79
  };
79
80
  KlesDynamicFormComponent.prototype.createControl = function (field) {
80
81
  var _this = this;
81
- if (field.type === 'listField') {
82
+ if (field.type === EnumType.array) {
82
83
  var array_1 = this.fb.array([]);
83
- field.value.forEach(function (data) {
84
- var subGroup = _this.fb.group({});
84
+ if (field.value && Array.isArray(field.value)) {
85
+ if (field.collections && Array.isArray(field.collections)) {
86
+ field.value.forEach(function (val) {
87
+ var group = _this.fb.group({});
88
+ field.collections.forEach(function (subfield) {
89
+ var data = val[subfield.name] || null;
90
+ var control = _this.createControl(__assign(__assign({}, subfield), (data && { value: data })));
91
+ group.addControl(subfield.name, control);
92
+ });
93
+ array_1.push(group);
94
+ });
95
+ }
96
+ }
97
+ else {
98
+ var group_1 = this.fb.group({});
85
99
  field.collections.forEach(function (subfield) {
86
- var control = _this.createControl(subfield);
87
- subGroup.addControl(subfield.name, control);
100
+ var control = _this.createControl(__assign({}, subfield));
101
+ group_1.addControl(subfield.name, control);
88
102
  });
89
- array_1.push(subGroup);
90
- });
103
+ array_1.push(group_1);
104
+ }
105
+ // field.value.forEach((data: any) => {
106
+ // const subGroup = this.fb.group({});
107
+ // field.collections.forEach(subfield => {
108
+ // const control = this.createControl(subfield);
109
+ // subGroup.addControl(subfield.name, control);
110
+ // });
111
+ // array.push(subGroup);
112
+ // });
91
113
  return array_1;
92
114
  }
93
- else if (field.type === 'group') {
115
+ else if (field.type === EnumType.group) {
94
116
  var subGroup_1 = this.fb.group({});
95
117
  if (field.collections && Array.isArray(field.collections)) {
96
118
  field.collections.forEach(function (subfield) {
@@ -160,7 +182,7 @@ var KlesDynamicFormComponent = /** @class */ (function () {
160
182
  var _this = this;
161
183
  var group = this.fb.group({});
162
184
  this.fields.forEach(function (field) {
163
- if (field.type === 'lineBreak') {
185
+ if (field.type === EnumType.lineBreak) {
164
186
  return;
165
187
  }
166
188
  var control = _this.createControl(field);
@@ -237,4 +259,4 @@ var KlesDynamicFormComponent = /** @class */ (function () {
237
259
  return KlesDynamicFormComponent;
238
260
  }());
239
261
  export { KlesDynamicFormComponent };
240
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"ng://@3kles/kles-material-dynamicforms/","sources":["lib/dynamic-form.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAU,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAA8C,MAAM,eAAe,CAAC;AAC3H,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AA6BtJ;IAkBI,kCAAoB,EAAe;QAAf,OAAE,GAAF,EAAE,CAAa;QAjB1B,WAAM,GAAuB,EAAE,CAAC;QAChC,eAAU,GAAkC,EAAE,CAAC;QAC/C,oBAAe,GAAuC,EAAE,CAAC;QAClE,6CAA6C;QACnC,WAAM,GAAsB,IAAI,YAAY,EAAO,CAAC;QACpD,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAEhC,cAAS,GAAqB,QAAQ,CAAC;QAGhD,qBAAgB,GAA+C,qBAAqB,CAAC;QACrF,yBAAoB,GAAyD,0BAA0B,CAAC;IAMjE,CAAC;IAJxC,sBAAI,2CAAK;aAAT;YACI,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QAC3B,CAAC;;;OAAA;IAKD,2CAAQ,GAAR;QACI,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAC9B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,qBAAqB,CAAC;QAC9F,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,0BAA0B,CAAC;QAC5G,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;IAED,8CAAW,GAAX,UAAY,OAAsB;;QAC9B,IAAI,QAAC,OAAO,CAAC,MAAM,0CAAE,WAAW,CAAA,EAAE;YAC9B,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,oCAAoC;YACpC,2BAA2B;YAC3B,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;SACzB;QAED,IAAI,QAAC,OAAO,CAAC,UAAU,0CAAE,WAAW,CAAA,IAAI,IAAI,CAAC,IAAI,EAAE;YAC/C,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,SAAS,EAAX,CAAW,CAAC,CAAC,CAAC;SAClE;QAED,IAAI,QAAC,OAAO,CAAC,eAAe,0CAAE,WAAW,CAAA,IAAI,IAAI,CAAC,IAAI,EAAE;YACpD,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,SAAS,EAAX,CAAW,CAAC,CAAC,CAAC;SAC5E;QAED,IAAI,QAAC,OAAO,CAAC,SAAS,0CAAE,WAAW,CAAA,EAAE;YACjC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,qBAAqB,CAAC;YAC9F,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,0BAA0B,CAAC;SAC/G;IAEL,CAAC;IAED,2CAAQ,GAAR,UAAS,KAAY;QACjB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACrC;aAAM;YACH,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACzC;IACL,CAAC;IAED,wCAAK,GAAL;QACI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;IACtB,CAAC;IAGO,6CAAU,GAAlB;QAAA,iBAiBC;QAhBG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,UAAA,GAAG;YACtC,OAAO,CAAC,KAAI,CAAC,MAAM,CAAC,GAAG,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,CAAC,IAAI,EAAV,CAAU,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAC/D,CAAC,CAAC,CAAC,OAAO,CAAC,UAAA,GAAG;YACV,KAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QAGH,IAAI,CAAC,MAAM;aACN,MAAM,CAAC,UAAA,KAAK,IAAI,OAAA,CAAC,KAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,EAA/B,CAA+B,CAAC;aAChD,OAAO,CAAC,UAAA,KAAK;YACV,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,EAAE;gBAC5B,OAAO;aACV;YACD,IAAM,OAAO,GAAG,KAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC1C,KAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;IACX,CAAC;IAEO,gDAAa,GAArB,UAAsB,KAAuB;QAA7C,iBAsCC;QApCG,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,EAAE;YAC5B,IAAM,OAAK,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAEhC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,UAAC,IAAS;gBAC1B,IAAM,QAAQ,GAAG,KAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBACnC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,UAAA,QAAQ;oBAC9B,IAAM,OAAO,GAAG,KAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;oBAC7C,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;gBAChD,CAAC,CAAC,CAAC;gBACH,OAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;YACH,OAAO,OAAK,CAAC;SAChB;aAAM,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YAC/B,IAAM,UAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACnC,IAAI,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE;gBACvD,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,UAAA,QAAQ;oBAC9B,IAAM,OAAO,GAAG,KAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;oBAC7C,UAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;gBAChD,CAAC,CAAC,CAAC;aACN;YACD,OAAO,UAAQ,CAAC;SAEnB;aAAM;YACH,IAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAC3B,KAAK,CAAC,KAAK,EACX;gBACI,UAAU,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,WAAW,IAAI,EAAE,CAAC;gBACzD,eAAe,EAAE,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,gBAAgB,IAAI,EAAE,CAAC;gBACxE,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,QAAQ;aACvC,CACJ,CAAC;YACF,IAAI,KAAK,CAAC,QAAQ,EAAE;gBAChB,OAAO,CAAC,OAAO,EAAE,CAAC;aACrB;YACD,OAAO,OAAO,CAAC;SAClB;IACL,CAAC;IAID,oEAAoE;IAEpE,wCAAwC;IACxC,2CAA2C;IAE3C,+CAA+C;IAC/C,kDAAkD;IAClD,sDAAsD;IACtD,mDAAmD;IACnD,wEAAwE;IACxE,wEAAwE;IACxE,iFAAiF;IACjF,qBAAqB;IACrB,+DAA+D;IAC/D,kBAAkB;IAClB,oCAAoC;IACpC,cAAc;IACd,wBAAwB;IACxB,2CAA2C;IAC3C,8CAA8C;IAC9C,uEAAuE;IACvE,sDAAsD;IACtD,mDAAmD;IACnD,sCAAsC;IACtC,wEAAwE;IACxE,iFAAiF;IACjF,qBAAqB;IACrB,2CAA2C;IAC3C,yCAAyC;IACzC,oBAAoB;IACpB,+DAA+D;IAC/D,kBAAkB;IAClB,YAAY;IACZ,2BAA2B;IAE3B,eAAe;IACf,2CAA2C;IAC3C,2BAA2B;IAC3B,6DAA6D;IAC7D,sEAAsE;IACtE,aAAa;IACb,gCAAgC;IAChC,iCAAiC;IACjC,YAAY;IACZ,0BAA0B;IAC1B,QAAQ;IACR,IAAI;IAII,6CAAU,GAAlB;QAAA,iBAiBC;QAhBG,IAAM,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAEhC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAA,KAAK;YAErB,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,EAAE;gBAC5B,OAAO;aACV;YACD,IAAM,OAAO,GAAG,KAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAE1C,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,SAAS,EAAX,CAAW,CAAC,CAAC,CAAC;QAC3D,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,SAAS,EAAX,CAAW,CAAC,CAAC,CAAC;QAErE,OAAO,KAAK,CAAC;IACjB,CAAC;IAGO,kDAAe,GAAvB,UAAwB,WAA0C;QAC9D,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;YACxB,IAAM,WAAS,GAAG,EAAE,CAAC;YACrB,WAAW,CAAC,OAAO,CAAC,UAAA,KAAK;gBACrB,WAAS,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YACpC,CAAC,CAAC,CAAC;YACH,OAAO,UAAU,CAAC,OAAO,CAAC,WAAS,CAAC,CAAC;SAExC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAGO,uDAAoB,GAA5B,UAA6B,WAA+C;QACxE,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;YACxB,IAAM,WAAS,GAAG,EAAE,CAAC;YACrB,WAAW,CAAC,OAAO,CAAC,UAAA,KAAK;gBACrB,WAAS,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YACpC,CAAC,CAAC,CAAC;YACH,OAAO,UAAU,CAAC,YAAY,CAAC,WAAS,CAAC,CAAC;SAE7C;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,wDAAqB,GAA7B,UAA8B,SAAoB;QAC9C,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,UAAA,KAAK;YACzC,IAAM,OAAO,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACrC,OAAO,CAAC,aAAa,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;IACP,CAAC;;gBAjNuB,WAAW;;IAjB1B;QAAR,KAAK,EAAE;4DAAiC;IAChC;QAAR,KAAK,EAAE;gEAAgD;IAC/C;QAAR,KAAK,EAAE;qEAA0D;IAExD;QAAT,MAAM,EAAE;4DAAqD;IACpD;QAAT,MAAM,EAAE;+DAAgC;IAEhC;QAAR,KAAK,EAAE;+DAAwC;IARvC,wBAAwB;QAvBpC,SAAS,CAAC;YACP,QAAQ,EAAE,iBAAiB;YAC3B,QAAQ,EAAE,uBAAuB;YACjC,QAAQ,EAAE,qZAMT;;gBAEG,4DAA4D;gBAC5D,mCAAmC;gBACnC,mCAAmC;gBACnC,gEAAgE;gBAChE,2CAA2C;gBAC3C,oEAAoE;gBACpE,wCAAwC;gBACxC,gDAAgD;gBAChD,oDAAoD;SAG3D,CAAC;OACW,wBAAwB,CAoOpC;IAAD,+BAAC;CAAA,AApOD,IAoOC;SApOY,wBAAwB","sourcesContent":["import { OnInit, Component, Input, Output, EventEmitter, AfterContentInit, OnChanges, SimpleChanges } from '@angular/core';\nimport { FormGroup, FormBuilder, Validators, ValidatorFn, AsyncValidatorFn, ValidationErrors, AsyncValidator, AbstractControl } from '@angular/forms';\nimport { KlesFormGroupComponent } from './fields/group.component';\nimport { KlesFormListFieldComponent } from './fields/list-field.component';\nimport { IKlesFieldConfig } from './interfaces/field.config.interface';\nimport { IKlesValidator } from './interfaces/validator.interface';\n\n@Component({\n    exportAs: 'klesDynamicForm',\n    selector: 'app-kles-dynamic-form',\n    template: `\n    <form class=\"{{orientationClass}}\" [formGroup]=\"form\" (submit)=\"onSubmit($event)\">\n        <ng-container *ngFor=\"let field of fields;\" class=\"{{orientationItemClass}}\" klesDynamicField [field]=\"field\" [group]=\"form\" [siblingFields]=\"fields\">\n        </ng-container>\n        <!--<button (click)=\"reset()\" mat-raised-button color=\"primary\">RESET</button>-->\n    </form>\n    `,\n    styles: [\n        // '.dynamic-form {display: flex; flex-direction: column;}',\n        //'.dynamic-form {display: flex;}',\n        //'.dynamic-form { width: 100%; }',\n        '.dynamic-form-column { display: flex;flex-direction: column; }',\n        '.dynamic-form-column > * { width: 100%; }',\n        '.dynamic-form-row { display: inline-flex;flex-wrap:wrap;gap:10px }',\n        '.dynamic-form-row > * { width: 100%; }',\n        '.dynamic-form-row-item { margin-right: 10px; }',\n        '.dynamic-form-column-item { margin-bottom: 10px; }',\n    ]\n\n})\nexport class KlesDynamicFormComponent implements OnInit, OnChanges {\n    @Input() fields: IKlesFieldConfig[] = [];\n    @Input() validators: IKlesValidator<ValidatorFn>[] = [];\n    @Input() asyncValidators: IKlesValidator<AsyncValidatorFn>[] = [];\n    // tslint:disable-next-line: no-output-native\n    @Output() submit: EventEmitter<any> = new EventEmitter<any>();\n    @Output() _onLoaded = new EventEmitter();\n\n    @Input() direction: 'column' | 'row' = 'column';\n\n    form: FormGroup;\n    orientationClass: 'dynamic-form-column' | 'dynamic-form-row' = 'dynamic-form-column';\n    orientationItemClass: 'dynamic-form-column-item' | 'dynamic-form-row-item' = 'dynamic-form-column-item';\n\n    get value() {\n        return this.form.value;\n    }\n\n    constructor(private fb: FormBuilder) { }\n\n\n    ngOnInit() {\n        this.form = this.createForm();\n        this.orientationClass = this.direction === 'row' ? 'dynamic-form-row' : 'dynamic-form-column';\n        this.orientationItemClass = this.direction === 'row' ? 'dynamic-form-row-item' : 'dynamic-form-column-item';\n        this._onLoaded.emit();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!changes.fields?.firstChange) {\n            this.updateForm();\n            // this.form = this.createControl();\n            // this.form.controls = {};\n            this._onLoaded.emit();\n        }\n\n        if (!changes.validators?.firstChange && this.form) {\n            this.form.setValidators(this.validators.map(v => v.validator));\n        }\n\n        if (!changes.asyncValidators?.firstChange && this.form) {\n            this.form.setAsyncValidators(this.asyncValidators.map(v => v.validator));\n        }\n\n        if (!changes.direction?.firstChange) {\n            this.orientationClass = this.direction === 'row' ? 'dynamic-form-row' : 'dynamic-form-column';\n            this.orientationItemClass = this.direction === 'row' ? 'dynamic-form-row-item' : 'dynamic-form-column-item';\n        }\n\n    }\n\n    onSubmit(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.form.valid) {\n            this.submit.emit(this.form.value);\n        } else {\n            this.validateAllFormFields(this.form);\n        }\n    }\n\n    reset() {\n        this.form.reset();\n    }\n\n\n    private updateForm() {\n        Object.keys(this.form.controls).filter(key => {\n            return !this.fields.map(field => field.name).includes(key);\n        }).forEach(key => {\n            this.form.removeControl(key);\n        });\n\n\n        this.fields\n            .filter(field => !this.form.controls[field.name])\n            .forEach(field => {\n                if (field.type === 'lineBreak') {\n                    return;\n                }\n                const control = this.createControl(field);\n                this.form.addControl(field.name, control);\n            });\n    }\n\n    private createControl(field: IKlesFieldConfig): AbstractControl {\n\n        if (field.type === 'listField') {\n            const array = this.fb.array([]);\n\n            field.value.forEach((data: any) => {\n                const subGroup = this.fb.group({});\n                field.collections.forEach(subfield => {\n                    const control = this.createControl(subfield);\n                    subGroup.addControl(subfield.name, control);\n                });\n                array.push(subGroup);\n            });\n            return array;\n        } else if (field.type === 'group') {\n            const subGroup = this.fb.group({});\n            if (field.collections && Array.isArray(field.collections)) {\n                field.collections.forEach(subfield => {\n                    const control = this.createControl(subfield);\n                    subGroup.addControl(subfield.name, control);\n                });\n            }\n            return subGroup;\n\n        } else {\n            const control = this.fb.control(\n                field.value,\n                {\n                    validators: this.bindValidations(field.validations || []),\n                    asyncValidators: this.bindAsyncValidations(field.asyncValidations || []),\n                    updateOn: field.updateOn || 'change'\n                }\n            );\n            if (field.disabled) {\n                control.disable();\n            }\n            return control;\n        }\n    }\n\n\n\n    // private createControl(field: IKlesFieldConfig): AbstractControl {\n\n    //     if (field.type === 'listField') {\n    //         const array = this.fb.array([]);\n\n    //         field.value.forEach((data: any) => {\n    //             const subGroup = this.fb.group({});\n    //             field.collections.forEach(subfield => {\n    //                 const control = this.fb.control(\n    //                     data[subfield.name] ? data[subfield.name] : null,\n    //                     this.bindValidations(subfield.validations || []),\n    //                     this.bindAsyncValidations(subfield.asyncValidations || [])\n    //                 );\n    //                 subGroup.addControl(subfield.name, control);\n    //             });\n    //             array.push(subGroup);\n    //         });\n    //         return array;\n    //     } else if (field.type === 'group') {\n    //         const subGroup = this.fb.group({});\n    //         if (field.collections && Array.isArray(field.collections)) {\n    //             field.collections.forEach(subfield => {\n    //                 const control = this.fb.control(\n    //                     subfield.value,\n    //                     this.bindValidations(subfield.validations || []),\n    //                     this.bindAsyncValidations(subfield.asyncValidations || [])\n    //                 );\n    //                 if (subfield.disabled) {\n    //                     control.disable();\n    //                 }\n    //                 subGroup.addControl(subfield.name, control);\n    //             });\n    //         }\n    //         return subGroup;\n\n    //     } else {\n    //         const control = this.fb.control(\n    //             field.value,\n    //             this.bindValidations(field.validations || []),\n    //             this.bindAsyncValidations(field.asyncValidations || [])\n    //         );\n    //         if (field.disabled) {\n    //             control.disable();\n    //         }\n    //         return control;\n    //     }\n    // }\n\n\n\n    private createForm() {\n        const group = this.fb.group({});\n\n        this.fields.forEach(field => {\n\n            if (field.type === 'lineBreak') {\n                return;\n            }\n            const control = this.createControl(field);\n\n            group.addControl(field.name, control);\n        });\n\n        group.setValidators(this.validators.map(v => v.validator));\n        group.setAsyncValidators(this.asyncValidators.map(v => v.validator));\n\n        return group;\n    }\n\n\n    private bindValidations(validations: IKlesValidator<ValidatorFn>[]): ValidatorFn {\n        if (validations.length > 0) {\n            const validList = [];\n            validations.forEach(valid => {\n                validList.push(valid.validator);\n            });\n            return Validators.compose(validList);\n\n        }\n        return null;\n    }\n\n\n    private bindAsyncValidations(validations: IKlesValidator<AsyncValidatorFn>[]): AsyncValidatorFn {\n        if (validations.length > 0) {\n            const validList = [];\n            validations.forEach(valid => {\n                validList.push(valid.validator);\n            });\n            return Validators.composeAsync(validList);\n\n        }\n        return null;\n    }\n\n    private validateAllFormFields(formGroup: FormGroup) {\n        Object.keys(formGroup.controls).forEach(field => {\n            const control = formGroup.get(field);\n            control.markAsTouched({ onlySelf: true });\n        });\n    }\n}\n"]}
262
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"ng://@3kles/kles-material-dynamicforms/","sources":["lib/dynamic-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, Component, Input, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';\nimport { FormGroup, FormBuilder, Validators, ValidatorFn, AsyncValidatorFn, AbstractControl } from '@angular/forms';\nimport { EnumType } from './enums/type.enum';\nimport { IKlesFieldConfig } from './interfaces/field.config.interface';\nimport { IKlesValidator } from './interfaces/validator.interface';\n\n@Component({\n    exportAs: 'klesDynamicForm',\n    selector: 'app-kles-dynamic-form',\n    template: `\n    <form class=\"{{orientationClass}}\" [formGroup]=\"form\" (submit)=\"onSubmit($event)\">\n        <ng-container *ngFor=\"let field of fields;\" class=\"{{orientationItemClass}}\" klesDynamicField [field]=\"field\" [group]=\"form\" [siblingFields]=\"fields\">\n        </ng-container>\n        <!--<button (click)=\"reset()\" mat-raised-button color=\"primary\">RESET</button>-->\n    </form>\n    `,\n    styles: [\n        // '.dynamic-form {display: flex; flex-direction: column;}',\n        //'.dynamic-form {display: flex;}',\n        //'.dynamic-form { width: 100%; }',\n        '.dynamic-form-column { display: flex;flex-direction: column; }',\n        '.dynamic-form-column > * { width: 100%; }',\n        '.dynamic-form-row { display: inline-flex;flex-wrap:wrap;gap:10px }',\n        '.dynamic-form-row > * { width: 100%; }',\n        '.dynamic-form-row-item { margin-right: 10px; }',\n        '.dynamic-form-column-item { margin-bottom: 10px; }',\n    ]\n\n})\nexport class KlesDynamicFormComponent implements OnInit, OnChanges {\n    @Input() fields: IKlesFieldConfig[] = [];\n    @Input() validators: IKlesValidator<ValidatorFn>[] = [];\n    @Input() asyncValidators: IKlesValidator<AsyncValidatorFn>[] = [];\n    // tslint:disable-next-line: no-output-native\n    @Output() submit: EventEmitter<any> = new EventEmitter<any>();\n    @Output() _onLoaded = new EventEmitter();\n\n    @Input() direction: 'column' | 'row' = 'column';\n\n    form: FormGroup;\n    orientationClass: 'dynamic-form-column' | 'dynamic-form-row' = 'dynamic-form-column';\n    orientationItemClass: 'dynamic-form-column-item' | 'dynamic-form-row-item' = 'dynamic-form-column-item';\n\n    get value() {\n        return this.form.value;\n    }\n\n    constructor(private fb: FormBuilder) { }\n\n\n    ngOnInit() {\n        this.form = this.createForm();\n        this.orientationClass = this.direction === 'row' ? 'dynamic-form-row' : 'dynamic-form-column';\n        this.orientationItemClass = this.direction === 'row' ? 'dynamic-form-row-item' : 'dynamic-form-column-item';\n        this._onLoaded.emit();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!changes.fields?.firstChange) {\n            this.updateForm();\n            // this.form = this.createControl();\n            // this.form.controls = {};\n            this._onLoaded.emit();\n        }\n\n        if (!changes.validators?.firstChange && this.form) {\n            this.form.setValidators(this.validators.map(v => v.validator));\n        }\n\n        if (!changes.asyncValidators?.firstChange && this.form) {\n            this.form.setAsyncValidators(this.asyncValidators.map(v => v.validator));\n        }\n\n        if (!changes.direction?.firstChange) {\n            this.orientationClass = this.direction === 'row' ? 'dynamic-form-row' : 'dynamic-form-column';\n            this.orientationItemClass = this.direction === 'row' ? 'dynamic-form-row-item' : 'dynamic-form-column-item';\n        }\n\n    }\n\n    onSubmit(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.form.valid) {\n            this.submit.emit(this.form.value);\n        } else {\n            this.validateAllFormFields(this.form);\n        }\n    }\n\n    reset() {\n        this.form.reset();\n    }\n\n\n    private updateForm() {\n        Object.keys(this.form.controls).filter(key => {\n            return !this.fields.map(field => field.name).includes(key);\n        }).forEach(key => {\n            this.form.removeControl(key);\n        });\n\n\n        this.fields\n            .filter(field => !this.form.controls[field.name])\n            .forEach(field => {\n                if (field.type === EnumType.lineBreak) {\n                    return;\n                }\n                const control = this.createControl(field);\n                this.form.addControl(field.name, control);\n            });\n    }\n\n    private createControl(field: IKlesFieldConfig): AbstractControl {\n\n        if (field.type === EnumType.array) {\n            const array = this.fb.array([]);\n\n            if (field.value && Array.isArray(field.value)) {\n                if (field.collections && Array.isArray(field.collections)) {\n                    field.value.forEach(val => {\n                        const group = this.fb.group({});\n                        field.collections.forEach(subfield => {\n                            const data = val[subfield.name] || null;\n                            const control = this.createControl({ ...subfield, ...(data && { value: data }) });\n                            group.addControl(subfield.name, control);\n                        });\n                        array.push(group);\n                    });\n                }\n            } else {\n                const group = this.fb.group({});\n                field.collections.forEach(subfield => {\n                    const control = this.createControl({ ...subfield });\n                    group.addControl(subfield.name, control);\n                });\n                array.push(group);\n            }\n\n            // field.value.forEach((data: any) => {\n            //     const subGroup = this.fb.group({});\n            //     field.collections.forEach(subfield => {\n            //         const control = this.createControl(subfield);\n            //         subGroup.addControl(subfield.name, control);\n            //     });\n            //     array.push(subGroup);\n            // });\n            return array;\n        } else if (field.type === EnumType.group) {\n            const subGroup = this.fb.group({});\n            if (field.collections && Array.isArray(field.collections)) {\n                field.collections.forEach(subfield => {\n                    const control = this.createControl(subfield);\n                    subGroup.addControl(subfield.name, control);\n                });\n            }\n            return subGroup;\n\n        } else {\n            const control = this.fb.control(\n                field.value,\n                {\n                    validators: this.bindValidations(field.validations || []),\n                    asyncValidators: this.bindAsyncValidations(field.asyncValidations || []),\n                    updateOn: field.updateOn || 'change'\n                }\n            );\n            if (field.disabled) {\n                control.disable();\n            }\n            return control;\n        }\n    }\n\n\n\n    // private createControl(field: IKlesFieldConfig): AbstractControl {\n\n    //     if (field.type === 'listField') {\n    //         const array = this.fb.array([]);\n\n    //         field.value.forEach((data: any) => {\n    //             const subGroup = this.fb.group({});\n    //             field.collections.forEach(subfield => {\n    //                 const control = this.fb.control(\n    //                     data[subfield.name] ? data[subfield.name] : null,\n    //                     this.bindValidations(subfield.validations || []),\n    //                     this.bindAsyncValidations(subfield.asyncValidations || [])\n    //                 );\n    //                 subGroup.addControl(subfield.name, control);\n    //             });\n    //             array.push(subGroup);\n    //         });\n    //         return array;\n    //     } else if (field.type === 'group') {\n    //         const subGroup = this.fb.group({});\n    //         if (field.collections && Array.isArray(field.collections)) {\n    //             field.collections.forEach(subfield => {\n    //                 const control = this.fb.control(\n    //                     subfield.value,\n    //                     this.bindValidations(subfield.validations || []),\n    //                     this.bindAsyncValidations(subfield.asyncValidations || [])\n    //                 );\n    //                 if (subfield.disabled) {\n    //                     control.disable();\n    //                 }\n    //                 subGroup.addControl(subfield.name, control);\n    //             });\n    //         }\n    //         return subGroup;\n\n    //     } else {\n    //         const control = this.fb.control(\n    //             field.value,\n    //             this.bindValidations(field.validations || []),\n    //             this.bindAsyncValidations(field.asyncValidations || [])\n    //         );\n    //         if (field.disabled) {\n    //             control.disable();\n    //         }\n    //         return control;\n    //     }\n    // }\n\n\n\n    private createForm() {\n        const group = this.fb.group({});\n\n        this.fields.forEach(field => {\n\n            if (field.type === EnumType.lineBreak) {\n                return;\n            }\n            const control = this.createControl(field);\n\n            group.addControl(field.name, control);\n        });\n\n        group.setValidators(this.validators.map(v => v.validator));\n        group.setAsyncValidators(this.asyncValidators.map(v => v.validator));\n\n        return group;\n    }\n\n\n    private bindValidations(validations: IKlesValidator<ValidatorFn>[]): ValidatorFn {\n        if (validations.length > 0) {\n            const validList = [];\n            validations.forEach(valid => {\n                validList.push(valid.validator);\n            });\n            return Validators.compose(validList);\n\n        }\n        return null;\n    }\n\n\n    private bindAsyncValidations(validations: IKlesValidator<AsyncValidatorFn>[]): AsyncValidatorFn {\n        if (validations.length > 0) {\n            const validList = [];\n            validations.forEach(valid => {\n                validList.push(valid.validator);\n            });\n            return Validators.composeAsync(validList);\n\n        }\n        return null;\n    }\n\n    private validateAllFormFields(formGroup: FormGroup) {\n        Object.keys(formGroup.controls).forEach(field => {\n            const control = formGroup.get(field);\n            control.markAsTouched({ onlySelf: true });\n        });\n    }\n}\n"]}
@@ -0,0 +1,14 @@
1
+ export var EnumType;
2
+ (function (EnumType) {
3
+ EnumType["text"] = "text";
4
+ EnumType["number"] = "number";
5
+ EnumType["time"] = "time";
6
+ EnumType["date"] = "date";
7
+ EnumType["color"] = "color";
8
+ EnumType["list"] = "list";
9
+ EnumType["multi"] = "multi";
10
+ EnumType["array"] = "array";
11
+ EnumType["group"] = "group";
12
+ EnumType["lineBreak"] = "lineBreak";
13
+ })(EnumType || (EnumType = {}));
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS5lbnVtLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQDNrbGVzL2tsZXMtbWF0ZXJpYWwtZHluYW1pY2Zvcm1zLyIsInNvdXJjZXMiOlsibGliL2VudW1zL3R5cGUuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxRQVdYO0FBWEQsV0FBWSxRQUFRO0lBQ2hCLHlCQUFhLENBQUE7SUFDYiw2QkFBaUIsQ0FBQTtJQUNqQix5QkFBYSxDQUFBO0lBQ2IseUJBQWEsQ0FBQTtJQUNiLDJCQUFlLENBQUE7SUFDZix5QkFBYSxDQUFBO0lBQ2IsMkJBQWUsQ0FBQTtJQUNmLDJCQUFlLENBQUE7SUFDZiwyQkFBZSxDQUFBO0lBQ2YsbUNBQXVCLENBQUE7QUFDM0IsQ0FBQyxFQVhXLFFBQVEsS0FBUixRQUFRLFFBV25CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gRW51bVR5cGUge1xuICAgIHRleHQgPSAndGV4dCcsXG4gICAgbnVtYmVyID0gJ251bWJlcicsXG4gICAgdGltZSA9ICd0aW1lJyxcbiAgICBkYXRlID0gJ2RhdGUnLFxuICAgIGNvbG9yID0gJ2NvbG9yJyxcbiAgICBsaXN0ID0gJ2xpc3QnLFxuICAgIG11bHRpID0gJ211bHRpJyxcbiAgICBhcnJheSA9ICdhcnJheScsXG4gICAgZ3JvdXAgPSAnZ3JvdXAnLFxuICAgIGxpbmVCcmVhayA9ICdsaW5lQnJlYWsnLFxufSJdfQ==
@@ -0,0 +1,31 @@
1
+ import { __decorate, __extends } from "tslib";
2
+ import { Component } from '@angular/core';
3
+ import { KlesFieldAbstract } from './field.abstract';
4
+ var KlesFormArrayComponent = /** @class */ (function (_super) {
5
+ __extends(KlesFormArrayComponent, _super);
6
+ function KlesFormArrayComponent() {
7
+ return _super !== null && _super.apply(this, arguments) || this;
8
+ }
9
+ KlesFormArrayComponent.prototype.ngOnInit = function () {
10
+ // this.subGroup = this.group.controls[this.field.name] as FormGroup;
11
+ _super.prototype.ngOnInit.call(this);
12
+ this.formArray = this.group.controls[this.field.name];
13
+ console.log('on arrive ici');
14
+ console.log(this.field);
15
+ console.log(this.formArray);
16
+ };
17
+ KlesFormArrayComponent = __decorate([
18
+ Component({
19
+ selector: 'kles-array',
20
+ template: "\n <div [formGroup]=\"group\">\n <ng-container [formArrayName]=\"field.name\">\n <div class=\"group-container\" *ngFor=\"let subGroup of formArray.controls let index = index;\"\n [ngClass]=\"field.direction === 'column' ? 'column': 'row'\">\n <ng-container *ngFor=\"let subfield of field.collections;\"\n klesDynamicField [field]=\"subfield\" [group]=\"subGroup\" [siblingFields]=\"field.collections\">\n </ng-container>\n </div>\n </ng-container>\n </div>\n",
21
+ styles: ['mat-form-field {width: calc(100%)}',
22
+ ':host { display:flex; flex-direction: inherit}',
23
+ '.group-container {display:flex; flex-direction: inherit}',
24
+ '.row { gap:10px; flex-direction: row }',
25
+ '.column { flex-direction: column, gap:0px}']
26
+ })
27
+ ], KlesFormArrayComponent);
28
+ return KlesFormArrayComponent;
29
+ }(KlesFieldAbstract));
30
+ export { KlesFormArrayComponent };
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyYXkuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQDNrbGVzL2tsZXMtbWF0ZXJpYWwtZHluYW1pY2Zvcm1zLyIsInNvdXJjZXMiOlsibGliL2ZpZWxkcy9hcnJheS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFFbEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFzQnJEO0lBQTRDLDBDQUFpQjtJQUE3RDs7SUFjQSxDQUFDO0lBUkcseUNBQVEsR0FBUjtRQUNJLHFFQUFxRTtRQUNyRSxpQkFBTSxRQUFRLFdBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFjLENBQUM7UUFDbkUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQTtRQUM1QixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUN2QixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQTtJQUMvQixDQUFDO0lBYlEsc0JBQXNCO1FBckJsQyxTQUFTLENBQUM7WUFDUCxRQUFRLEVBQUUsWUFBWTtZQUN0QixRQUFRLEVBQUUsa2pCQVdiO3FCQUNZLG9DQUFvQztnQkFDekMsZ0RBQWdEO2dCQUNoRCwwREFBMEQ7Z0JBQzFELHdDQUF3QztnQkFDeEMsNENBQTRDO1NBRW5ELENBQUM7T0FDVyxzQkFBc0IsQ0FjbEM7SUFBRCw2QkFBQztDQUFBLEFBZEQsQ0FBNEMsaUJBQWlCLEdBYzVEO1NBZFksc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1BcnJheSwgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgS2xlc0ZpZWxkQWJzdHJhY3QgfSBmcm9tICcuL2ZpZWxkLmFic3RyYWN0JztcbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAna2xlcy1hcnJheScsXG4gICAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IFtmb3JtR3JvdXBdPVwiZ3JvdXBcIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciBbZm9ybUFycmF5TmFtZV09XCJmaWVsZC5uYW1lXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZ3JvdXAtY29udGFpbmVyXCIgKm5nRm9yPVwibGV0IHN1Ykdyb3VwIG9mIGZvcm1BcnJheS5jb250cm9scyBsZXQgaW5kZXggPSBpbmRleDtcIlxuICAgICAgICAgICAgW25nQ2xhc3NdPVwiZmllbGQuZGlyZWN0aW9uID09PSAnY29sdW1uJyA/ICdjb2x1bW4nOiAncm93J1wiPlxuICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IHN1YmZpZWxkIG9mIGZpZWxkLmNvbGxlY3Rpb25zO1wiXG4gICAgICAgICAgICAgICAgICAgIGtsZXNEeW5hbWljRmllbGQgW2ZpZWxkXT1cInN1YmZpZWxkXCIgW2dyb3VwXT1cInN1Ykdyb3VwXCIgW3NpYmxpbmdGaWVsZHNdPVwiZmllbGQuY29sbGVjdGlvbnNcIj5cbiAgICAgICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbmAsXG4gICAgc3R5bGVzOiBbJ21hdC1mb3JtLWZpZWxkIHt3aWR0aDogY2FsYygxMDAlKX0nLFxuICAgICAgICAnOmhvc3QgeyBkaXNwbGF5OmZsZXg7IGZsZXgtZGlyZWN0aW9uOiBpbmhlcml0fScsXG4gICAgICAgICcuZ3JvdXAtY29udGFpbmVyIHtkaXNwbGF5OmZsZXg7IGZsZXgtZGlyZWN0aW9uOiBpbmhlcml0fScsXG4gICAgICAgICcucm93IHsgZ2FwOjEwcHg7IGZsZXgtZGlyZWN0aW9uOiByb3cgfScsXG4gICAgICAgICcuY29sdW1uIHsgZmxleC1kaXJlY3Rpb246IGNvbHVtbiwgZ2FwOjBweH0nXG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBLbGVzRm9ybUFycmF5Q29tcG9uZW50IGV4dGVuZHMgS2xlc0ZpZWxkQWJzdHJhY3QgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gICAgLy8gc3ViR3JvdXA6IEZvcm1Hcm91cFxuXG4gICAgZm9ybUFycmF5OiBGb3JtQXJyYXk7XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgLy8gdGhpcy5zdWJHcm91cCA9IHRoaXMuZ3JvdXAuY29udHJvbHNbdGhpcy5maWVsZC5uYW1lXSBhcyBGb3JtR3JvdXA7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMuZm9ybUFycmF5ID0gdGhpcy5ncm91cC5jb250cm9sc1t0aGlzLmZpZWxkLm5hbWVdIGFzIEZvcm1BcnJheTtcbiAgICAgICAgY29uc29sZS5sb2coJ29uIGFycml2ZSBpY2knKVxuICAgICAgICBjb25zb2xlLmxvZyh0aGlzLmZpZWxkKVxuICAgICAgICBjb25zb2xlLmxvZyh0aGlzLmZvcm1BcnJheSlcbiAgICB9XG59XG4iXX0=
@@ -1 +1 @@
1
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuY29uZmlnLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Aza2xlcy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2VzL2ZpZWxkLmNvbmZpZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElLbGVzVmFsaWRhdG9yIH0gZnJvbSAnLi92YWxpZGF0b3IuaW50ZXJmYWNlJztcbmltcG9ydCB7IFZhbGlkYXRvckZuLCBBc3luY1ZhbGlkYXRvckZuLCBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUtsZXNGaWVsZENvbmZpZyB7XG4gICAgdHlwZT86IHN0cmluZzsvLyBNYXBwZXIgdHlwZSBpZih0eXBlICYmICFjb21wb25lbnQpPT50eXBlXG4gICAgbmFtZTogc3RyaW5nOy8vIE5hbWUgRmllbGQgKGtleSBmb3IgRm9ybUNvbnRyb2xOYW1lKVxuICAgIGNvbXBvbmVudD86IFR5cGU8YW55PjtcbiAgICBpZD86IHN0cmluZzsvLyBBdHRyaWJ1dCBodG1sIGlkXG4gICAgbGFiZWw/OiBzdHJpbmc7Ly8gTGFiZWwgZmllbGRcbiAgICBwbGFjZWhvbGRlcj86IHN0cmluZzsvLyBQbGFjZWhvbGRlciBmaWVsZFxuICAgIHRvb2x0aXA/OiBzdHJpbmc7Ly8gVG9vbHRpcCBmaWVsZFxuICAgIGlucHV0VHlwZT86IHN0cmluZzsvLyBUeXBlIFxuICAgIG1pbj86IG51bWJlcjtcbiAgICBtYXg/OiBudW1iZXI7XG4gICAgbWF4TGVuZ3RoPzogbnVtYmVyO1xuICAgIHN0ZXA/OiBudW1iZXI7XG4gICAgb3B0aW9ucz86IGFueVtdIHwgU3ViamVjdDxhbnlbXT47Ly8gTGlzdCBvcHRpb25zIGZvciBsaXN0IGNvbXBvbmVudFxuICAgIG5nQ2xhc3M/OiBhbnk7Ly8gbmdjbGFzcyBmb3IgZmllbGRcbiAgICBuZ1N0eWxlPzogYW55Oy8vIG5nU3R5bGUgZm9yIGZpZWxkXG4gICAgcHJvcGVydHk/OiBzdHJpbmc7Ly8gUHJvcGVydHkgZm9yIGZpZWxkXG4gICAgY29sbGVjdGlvbnM/OiBhbnk7Ly8gQ29sbGVjdGlvbnMgZm9yIHN1YmZpZWxkXG4gICAgdmFsdWU/OiBhbnk7Ly8gVmFsdWUgZmllbGRcbiAgICBtdWx0aXBsZT86IGJvb2xlYW47Ly8gTXVsdGlwbGUgc2VsZWN0aW9uIGZpZWxkXG4gICAgZGlzYWJsZWQ/OiBib29sZWFuOy8vIERpc2FibGVkIGZpZWxkXG4gICAgYXV0b2NvbXBsZXRlPzogYm9vbGVhbjsvLyBBdXRvY29tcGxldGUgaW5wdXQgZmllbGRcbiAgICBhdXRvY29tcGxldGVDb21wb25lbnQ/OiBUeXBlPGFueT47Ly9BdXRvY29tcGxldGUgY29tcG9uZW50IHRvIGRpc3BsYXkgaW4gbGlzdCBvcHRpb25cbiAgICBkaXNwbGF5V2l0aD86ICgodmFsdWU6IGFueSkgPT4gc3RyaW5nKSB8IG51bGw7IC8vIEF1dG9jb21wbGV0ZSBkaXNwbGF5IGZvcm1hdFxuICAgIHBhbmVsV2lkdGg/OiBzdHJpbmcgfCBudW1iZXI7Ly9XaXRoIGZvciBwYW5lbCBsaXN0IG9wdGlvblxuICAgIGluZGV0ZXJtaW5hdGU/OiBib29sZWFuOy8vIEluZGV0ZXJtaW5hdGUgY2hlY2thYmxlIGNvbXBvbmVudFxuICAgIGNvbG9yPzogc3RyaW5nOyAvL01hdGVyaWFsIGNvbG9yXG4gICAgaWNvbj86IHN0cmluZzsvL01hdGVyaWFsIGljb25cbiAgICBpY29uU3ZnPzogc3RyaW5nOy8vU3ZnIEljb25cbiAgICB0ZXh0YXJlYUF1dG9TaXplPzogeyBtaW5Sb3dzPzogbnVtYmVyOyBtYXhSb3dzPzogbnVtYmVyIH1cbiAgICB2YWxpZGF0aW9ucz86IElLbGVzVmFsaWRhdG9yPFZhbGlkYXRvckZuPltdO1xuICAgIGFzeW5jVmFsaWRhdGlvbnM/OiBJS2xlc1ZhbGlkYXRvcjxBc3luY1ZhbGlkYXRvckZuPltdO1xuICAgIHBpcGVUcmFuc2Zvcm0/OiB7XG4gICAgICAgIHBpcGU6IFBpcGVUcmFuc2Zvcm0sXG4gICAgICAgIG9wdGlvbnM/OiBhbnlbXVxuICAgIH1bXTtcbiAgICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nO1xuICAgIHZhbHVlQ2hhbmdlcz86ICgoZmllbGQ6IElLbGVzRmllbGRDb25maWcsIGdyb3VwOiBGb3JtR3JvdXAsIHNpYmxpbmdGaWVsZD86IElLbGVzRmllbGRDb25maWdbXSwgdmFsdWVDaGFuZ2VkPzogYW55KSA9PiB2b2lkKTtcbiAgICB0cmlnZ2VyQ29tcG9uZW50PzogVHlwZTxhbnk+OyAvL3RyaWdnZXIgY29tcG9uZW50IHRvIGN1c3RvbWl6ZSB0cmlnZ2VyIGxhYmVsIGluIHNlbGVjdFxuICAgIHZpcnR1YWxTY3JvbGw/OiBib29sZWFuOyAvL1RvIGFjdGl2YXRlIHZpcnR1YWwgc2Nyb2xsXG4gICAgaXRlbVNpemU/OiBudW1iZXI7IC8vIGl0ZW1TaXplIGZvciB2aXJ0dWFsIHNjcm9sbCB2aWV3cG9ydFxuICAgIHBlbmRpbmc/OiBib29sZWFuO1xuICAgIHNlYXJjaEtleXM/OiBzdHJpbmdbXTsgLy9saXN0IG9mIGtleXMgZm9yIG11bHRpcGxlIHNlYXJjaGVzXG4gICAgdXBkYXRlT24/OiAnY2hhbmdlJyB8ICdibHVyJyB8ICdzdWJtaXQnO1xufVxuIl19
1
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuY29uZmlnLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Aza2xlcy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2VzL2ZpZWxkLmNvbmZpZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElLbGVzVmFsaWRhdG9yIH0gZnJvbSAnLi92YWxpZGF0b3IuaW50ZXJmYWNlJztcbmltcG9ydCB7IFZhbGlkYXRvckZuLCBBc3luY1ZhbGlkYXRvckZuLCBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQaXBlVHJhbnNmb3JtLCBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBFbnVtVHlwZSB9IGZyb20gJy4uL2VudW1zL3R5cGUuZW51bSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUtsZXNGaWVsZENvbmZpZyB7XG4gICAgdHlwZT86IEVudW1UeXBlOy8vIE1hcHBlciB0eXBlIGlmKHR5cGUgJiYgIWNvbXBvbmVudCk9PnR5cGVcbiAgICBuYW1lOiBzdHJpbmc7Ly8gTmFtZSBGaWVsZCAoa2V5IGZvciBGb3JtQ29udHJvbE5hbWUpXG4gICAgY29tcG9uZW50PzogVHlwZTxhbnk+O1xuICAgIGlkPzogc3RyaW5nOy8vIEF0dHJpYnV0IGh0bWwgaWRcbiAgICBsYWJlbD86IHN0cmluZzsvLyBMYWJlbCBmaWVsZFxuICAgIHBsYWNlaG9sZGVyPzogc3RyaW5nOy8vIFBsYWNlaG9sZGVyIGZpZWxkXG4gICAgdG9vbHRpcD86IHN0cmluZzsvLyBUb29sdGlwIGZpZWxkXG4gICAgaW5wdXRUeXBlPzogc3RyaW5nOy8vIFR5cGUgXG4gICAgbWluPzogbnVtYmVyO1xuICAgIG1heD86IG51bWJlcjtcbiAgICBtYXhMZW5ndGg/OiBudW1iZXI7XG4gICAgc3RlcD86IG51bWJlcjtcbiAgICBvcHRpb25zPzogYW55W10gfCBTdWJqZWN0PGFueVtdPjsvLyBMaXN0IG9wdGlvbnMgZm9yIGxpc3QgY29tcG9uZW50XG4gICAgbmdDbGFzcz86IGFueTsvLyBuZ2NsYXNzIGZvciBmaWVsZFxuICAgIG5nU3R5bGU/OiBhbnk7Ly8gbmdTdHlsZSBmb3IgZmllbGRcbiAgICBwcm9wZXJ0eT86IHN0cmluZzsvLyBQcm9wZXJ0eSBmb3IgZmllbGRcbiAgICBjb2xsZWN0aW9ucz86IGFueTsvLyBDb2xsZWN0aW9ucyBmb3Igc3ViZmllbGRcbiAgICB2YWx1ZT86IGFueTsvLyBWYWx1ZSBmaWVsZFxuICAgIG11bHRpcGxlPzogYm9vbGVhbjsvLyBNdWx0aXBsZSBzZWxlY3Rpb24gZmllbGRcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47Ly8gRGlzYWJsZWQgZmllbGRcbiAgICBhdXRvY29tcGxldGU/OiBib29sZWFuOy8vIEF1dG9jb21wbGV0ZSBpbnB1dCBmaWVsZFxuICAgIGF1dG9jb21wbGV0ZUNvbXBvbmVudD86IFR5cGU8YW55PjsvL0F1dG9jb21wbGV0ZSBjb21wb25lbnQgdG8gZGlzcGxheSBpbiBsaXN0IG9wdGlvblxuICAgIGRpc3BsYXlXaXRoPzogKCh2YWx1ZTogYW55KSA9PiBzdHJpbmcpIHwgbnVsbDsgLy8gQXV0b2NvbXBsZXRlIGRpc3BsYXkgZm9ybWF0XG4gICAgcGFuZWxXaWR0aD86IHN0cmluZyB8IG51bWJlcjsvL1dpdGggZm9yIHBhbmVsIGxpc3Qgb3B0aW9uXG4gICAgaW5kZXRlcm1pbmF0ZT86IGJvb2xlYW47Ly8gSW5kZXRlcm1pbmF0ZSBjaGVja2FibGUgY29tcG9uZW50XG4gICAgY29sb3I/OiBzdHJpbmc7IC8vTWF0ZXJpYWwgY29sb3JcbiAgICBpY29uPzogc3RyaW5nOy8vTWF0ZXJpYWwgaWNvblxuICAgIGljb25Tdmc/OiBzdHJpbmc7Ly9TdmcgSWNvblxuICAgIHRleHRhcmVhQXV0b1NpemU/OiB7IG1pblJvd3M/OiBudW1iZXI7IG1heFJvd3M/OiBudW1iZXIgfVxuICAgIHZhbGlkYXRpb25zPzogSUtsZXNWYWxpZGF0b3I8VmFsaWRhdG9yRm4+W107XG4gICAgYXN5bmNWYWxpZGF0aW9ucz86IElLbGVzVmFsaWRhdG9yPEFzeW5jVmFsaWRhdG9yRm4+W107XG4gICAgcGlwZVRyYW5zZm9ybT86IHtcbiAgICAgICAgcGlwZTogUGlwZVRyYW5zZm9ybSxcbiAgICAgICAgb3B0aW9ucz86IGFueVtdXG4gICAgfVtdO1xuICAgIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbic7XG4gICAgdmFsdWVDaGFuZ2VzPzogKChmaWVsZDogSUtsZXNGaWVsZENvbmZpZywgZ3JvdXA6IEZvcm1Hcm91cCwgc2libGluZ0ZpZWxkPzogSUtsZXNGaWVsZENvbmZpZ1tdLCB2YWx1ZUNoYW5nZWQ/OiBhbnkpID0+IHZvaWQpO1xuICAgIHRyaWdnZXJDb21wb25lbnQ/OiBUeXBlPGFueT47IC8vdHJpZ2dlciBjb21wb25lbnQgdG8gY3VzdG9taXplIHRyaWdnZXIgbGFiZWwgaW4gc2VsZWN0XG4gICAgdmlydHVhbFNjcm9sbD86IGJvb2xlYW47IC8vVG8gYWN0aXZhdGUgdmlydHVhbCBzY3JvbGxcbiAgICBpdGVtU2l6ZT86IG51bWJlcjsgLy8gaXRlbVNpemUgZm9yIHZpcnR1YWwgc2Nyb2xsIHZpZXdwb3J0XG4gICAgcGVuZGluZz86IGJvb2xlYW47XG4gICAgc2VhcmNoS2V5cz86IHN0cmluZ1tdOyAvL2xpc3Qgb2Yga2V5cyBmb3IgbXVsdGlwbGUgc2VhcmNoZXNcbiAgICB1cGRhdGVPbj86ICdjaGFuZ2UnIHwgJ2JsdXInIHwgJ3N1Ym1pdCc7XG59XG4iXX0=
@@ -42,6 +42,7 @@ import { KlesFormSlideToggleComponent } from './fields/slide-toggle.component';
42
42
  import { KlesFormSelectionListComponent } from './fields/selection-list.component';
43
43
  import { KlesFormBadgeComponent } from './fields/badge.component';
44
44
  import { KlesFormButtonToogleGroupComponent } from './fields/button-toogle-group.component';
45
+ import { KlesFormArrayComponent } from './fields/array.component';
45
46
  var components = [
46
47
  KlesDynamicFormComponent,
47
48
  KlesFormLabelComponent,
@@ -71,7 +72,8 @@ var components = [
71
72
  KlesFormLinkComponent,
72
73
  KlesFormSlideToggleComponent,
73
74
  KlesFormSelectionListComponent,
74
- KlesFormButtonToogleGroupComponent
75
+ KlesFormButtonToogleGroupComponent,
76
+ KlesFormArrayComponent
75
77
  ];
76
78
  var directives = [KlesDynamicFieldDirective, KlesComponentDirective];
77
79
  var pipes = [KlesTransformPipe, ArrayFormatPipe];
@@ -114,4 +116,4 @@ var KlesMaterialDynamicformsModule = /** @class */ (function () {
114
116
  return KlesMaterialDynamicformsModule;
115
117
  }());
116
118
  export { KlesMaterialDynamicformsModule };
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kles-material-dynamicforms.module.js","sourceRoot":"ng://@3kles/kles-material-dynamicforms/","sources":["lib/kles-material-dynamicforms.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CUSTOM_ELEMENTS_SCHEMA, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { KlesDynamicFormComponent } from './dynamic-form.component';\nimport { KlesComponentDirective } from './directive/dynamic-component.directive';\nimport { KlesDynamicFieldDirective } from './directive/dynamic-field.directive';\nimport { KlesFormErrorStateMatcher } from './matcher/form-error.matcher';\nimport { ErrorStateMatcher } from '@angular/material/core';\nimport { MaterialModule } from './modules/material.module';\nimport { FlexLayoutModule } from '@angular/flex-layout';\nimport { ColorPickerModule } from 'ngx-color-picker';\nimport { TranslateModule } from '@ngx-translate/core';\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 { KlesButtonComponent } from './forms/button-control.component';\nimport { KlesFormButtonComponent } from './fields/button-form.component';\nimport { KlesButtonCheckerComponent } from './forms/buttonchecker-control.component';\nimport { KlesFormButtonCheckerComponent } from './fields/buttonchecker-form.component';\nimport { KlesButtonFileComponent } from './forms/buttonfile-control.component';\nimport { KlesFormButtonFileComponent } from './fields/buttonfile-form.component';\nimport { KlesFormTextareaComponent } from './fields/textarea.component';\nimport { KlesFormTextComponent } from './fields/text.component';\nimport { KlesFormChipComponent } from './fields/chip.component';\nimport { KlesFormGroupComponent } from './fields/group.component';\nimport { KlesFormInputClearableComponent } from './fields/input.clearable.component';\nimport { KlesFormIconComponent } from './fields/icon.component';\nimport { KlesTransformPipe } from './pipe/transform.pipe';\nimport { NgxMatSelectSearchModule } from 'ngx-mat-select-search';\nimport { KlesFormSelectSearchComponent } from './fields/select.search.component';\nimport { KlesFormLineBreakComponent } from './fields/line-break.component';\nimport { ArrayFormatPipe } from './pipe/array.pipe';\nimport { KlesFormLinkComponent } from './fields/link.component';\nimport { KlesFormSlideToggleComponent } from './fields/slide-toggle.component';\nimport { KlesFormSelectionListComponent } from './fields/selection-list.component';\nimport { KlesFormBadgeComponent } from './fields/badge.component';\nimport { KlesFormButtonToogleGroupComponent } from './fields/button-toogle-group.component';\n\nconst components = [\n  KlesDynamicFormComponent,\n  KlesFormLabelComponent,\n  KlesFormInputComponent,\n  KlesFormInputClearableComponent,\n  KlesFormSubmitButtonComponent,\n  KlesFormBadgeComponent,\n  KlesButtonComponent,\n  KlesFormButtonComponent,\n  KlesButtonCheckerComponent,\n  KlesFormButtonCheckerComponent,\n  KlesButtonFileComponent,\n  KlesFormButtonFileComponent,\n  KlesFormSelectComponent,\n  KlesFormDateComponent,\n  KlesFormRadioComponent,\n  KlesFormCheckboxComponent,\n  KlesFormListFieldComponent,\n  KlesFormColorComponent,\n  KlesFormTextareaComponent,\n  KlesFormTextComponent,\n  KlesFormChipComponent,\n  KlesFormGroupComponent,\n  KlesFormIconComponent,\n  KlesFormSelectSearchComponent,\n  KlesFormLineBreakComponent,\n  KlesFormLinkComponent,\n  KlesFormSlideToggleComponent,\n  KlesFormSelectionListComponent,\n  KlesFormButtonToogleGroupComponent\n];\n\nconst directives = [KlesDynamicFieldDirective, KlesComponentDirective];\nconst pipes = [KlesTransformPipe, ArrayFormatPipe];\n@NgModule({\n  declarations: [\n    components,\n    directives,\n    pipes\n\n  ],\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    FlexLayoutModule,\n    FormsModule,\n    MaterialModule,\n    ColorPickerModule,\n    NgxMatSelectSearchModule\n  ],\n  providers: [\n    { provide: ErrorStateMatcher, useClass: KlesFormErrorStateMatcher },\n    pipes\n  ],\n  entryComponents: [\n    components\n  ],\n  exports: [\n    components,\n    pipes,\n    directives,\n    ColorPickerModule\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA]\n})\nexport class KlesMaterialDynamicformsModule { }\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kles-material-dynamicforms.module.js","sourceRoot":"ng://@3kles/kles-material-dynamicforms/","sources":["lib/kles-material-dynamicforms.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CUSTOM_ELEMENTS_SCHEMA, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { KlesDynamicFormComponent } from './dynamic-form.component';\nimport { KlesComponentDirective } from './directive/dynamic-component.directive';\nimport { KlesDynamicFieldDirective } from './directive/dynamic-field.directive';\nimport { KlesFormErrorStateMatcher } from './matcher/form-error.matcher';\nimport { ErrorStateMatcher } from '@angular/material/core';\nimport { MaterialModule } from './modules/material.module';\nimport { FlexLayoutModule } from '@angular/flex-layout';\nimport { ColorPickerModule } from 'ngx-color-picker';\nimport { TranslateModule } from '@ngx-translate/core';\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 { KlesButtonComponent } from './forms/button-control.component';\nimport { KlesFormButtonComponent } from './fields/button-form.component';\nimport { KlesButtonCheckerComponent } from './forms/buttonchecker-control.component';\nimport { KlesFormButtonCheckerComponent } from './fields/buttonchecker-form.component';\nimport { KlesButtonFileComponent } from './forms/buttonfile-control.component';\nimport { KlesFormButtonFileComponent } from './fields/buttonfile-form.component';\nimport { KlesFormTextareaComponent } from './fields/textarea.component';\nimport { KlesFormTextComponent } from './fields/text.component';\nimport { KlesFormChipComponent } from './fields/chip.component';\nimport { KlesFormGroupComponent } from './fields/group.component';\nimport { KlesFormInputClearableComponent } from './fields/input.clearable.component';\nimport { KlesFormIconComponent } from './fields/icon.component';\nimport { KlesTransformPipe } from './pipe/transform.pipe';\nimport { NgxMatSelectSearchModule } from 'ngx-mat-select-search';\nimport { KlesFormSelectSearchComponent } from './fields/select.search.component';\nimport { KlesFormLineBreakComponent } from './fields/line-break.component';\nimport { ArrayFormatPipe } from './pipe/array.pipe';\nimport { KlesFormLinkComponent } from './fields/link.component';\nimport { KlesFormSlideToggleComponent } from './fields/slide-toggle.component';\nimport { KlesFormSelectionListComponent } from './fields/selection-list.component';\nimport { KlesFormBadgeComponent } from './fields/badge.component';\nimport { KlesFormButtonToogleGroupComponent } from './fields/button-toogle-group.component';\nimport { KlesFormArrayComponent } from './fields/array.component';\n\nconst components = [\n  KlesDynamicFormComponent,\n  KlesFormLabelComponent,\n  KlesFormInputComponent,\n  KlesFormInputClearableComponent,\n  KlesFormSubmitButtonComponent,\n  KlesFormBadgeComponent,\n  KlesButtonComponent,\n  KlesFormButtonComponent,\n  KlesButtonCheckerComponent,\n  KlesFormButtonCheckerComponent,\n  KlesButtonFileComponent,\n  KlesFormButtonFileComponent,\n  KlesFormSelectComponent,\n  KlesFormDateComponent,\n  KlesFormRadioComponent,\n  KlesFormCheckboxComponent,\n  KlesFormListFieldComponent,\n  KlesFormColorComponent,\n  KlesFormTextareaComponent,\n  KlesFormTextComponent,\n  KlesFormChipComponent,\n  KlesFormGroupComponent,\n  KlesFormIconComponent,\n  KlesFormSelectSearchComponent,\n  KlesFormLineBreakComponent,\n  KlesFormLinkComponent,\n  KlesFormSlideToggleComponent,\n  KlesFormSelectionListComponent,\n  KlesFormButtonToogleGroupComponent,\n  KlesFormArrayComponent\n];\n\nconst directives = [KlesDynamicFieldDirective, KlesComponentDirective];\nconst pipes = [KlesTransformPipe, ArrayFormatPipe];\n@NgModule({\n  declarations: [\n    components,\n    directives,\n    pipes\n\n  ],\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    FlexLayoutModule,\n    FormsModule,\n    MaterialModule,\n    ColorPickerModule,\n    NgxMatSelectSearchModule\n  ],\n  providers: [\n    { provide: ErrorStateMatcher, useClass: KlesFormErrorStateMatcher },\n    pipes\n  ],\n  entryComponents: [\n    components\n  ],\n  exports: [\n    components,\n    pipes,\n    directives,\n    ColorPickerModule\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA]\n})\nexport class KlesMaterialDynamicformsModule { }\n"]}
@@ -36,6 +36,9 @@ export * from './lib/fields/link.component';
36
36
  export * from './lib/fields/slide-toggle.component';
37
37
  export * from './lib/fields/selection-list.component';
38
38
  export * from './lib/fields/button-toogle-group.component';
39
+ export * from './lib/fields/array.component';
40
+ /**ENUMS */
41
+ export * from './lib/enums/type.enum';
39
42
  /**MATCHER */
40
43
  export * from './lib/matcher/form-error.matcher';
41
44
  /**VALIDATORS */
@@ -45,4 +48,4 @@ export * from './lib/dynamic-form.component';
45
48
  /**PIPES */
46
49
  export * from './lib/pipe/array.pipe';
47
50
  export * from './lib/pipe/transform.pipe';
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Aza2xlcy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy8iLCJzb3VyY2VzIjpbInB1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBRXhELGVBQWU7QUFDZixjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsNkNBQTZDLENBQUM7QUFFNUQsU0FBUztBQUNULGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDBDQUEwQyxDQUFDO0FBRXpELFlBQVk7QUFDWixjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsNENBQTRDLENBQUM7QUFRM0QsYUFBYTtBQUNiLGNBQWMsa0NBQWtDLENBQUM7QUFFakQsZ0JBQWdCO0FBQ2hCLGNBQWMseUNBQXlDLENBQUM7QUFFeEQsVUFBVTtBQUNWLGNBQWMsOEJBQThCLENBQUM7QUFFN0MsV0FBVztBQUNYLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Yga2xlcy1tYXRlcmlhbC1keW5hbWljZm9ybXNcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy5tb2R1bGUnO1xuXG4vKipESVJFQ1RJVkUgKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZS9keW5hbWljLWZpZWxkLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmUvZHluYW1pYy1jb21wb25lbnQuZGlyZWN0aXZlJztcblxuLypGT1JNUyovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3Jtcy9idXR0b24tY29udHJvbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybXMvYnV0dG9uY2hlY2tlci1jb250cm9sLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3Jtcy9idXR0b25maWxlLWNvbnRyb2wuY29tcG9uZW50JztcblxuLyoqRklFTERTICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvYmFkZ2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9idXR0b24tZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2J1dHRvbmNoZWNrZXItZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2J1dHRvbmZpbGUtZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2J1dHRvbi1zdWJtaXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2NvbG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvZGF0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2ZpZWxkLmFic3RyYWN0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2lucHV0LmNsZWFyYWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2xhYmVsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvbGlzdC1maWVsZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL3JhZGlvLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvdGV4dGFyZWEuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy90ZXh0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvY2hpcC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2dyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvaWNvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL3NlbGVjdC5zZWFyY2guY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9saW5lLWJyZWFrLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvbGluay5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL3NsaWRlLXRvZ2dsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL3NlbGVjdGlvbi1saXN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvYnV0dG9uLXRvb2dsZS1ncm91cC5jb21wb25lbnQnO1xuXG4vKipJTlRFUkZBQ0VTICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnRlcmZhY2VzL2NvbXBvbmVudC5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW50ZXJmYWNlcy9maWVsZC5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW50ZXJmYWNlcy9maWVsZC5jb25maWcuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyZmFjZXMvdmFsaWRhdG9yLmludGVyZmFjZSc7XG5cbi8qKk1BVENIRVIgKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL21hdGNoZXIvZm9ybS1lcnJvci5tYXRjaGVyJztcblxuLyoqVkFMSURBVE9SUyAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmFsaWRhdG9ycy9hdXRvY29tcGxldGUudmFsaWRhdG9yJztcblxuLyoqRk9STSAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZHluYW1pYy1mb3JtLmNvbXBvbmVudCc7XG5cbi8qKlBJUEVTICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlL2FycmF5LnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZS90cmFuc2Zvcm0ucGlwZSc7XG4iXX0=
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Aza2xlcy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy8iLCJzb3VyY2VzIjpbInB1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBRXhELGVBQWU7QUFDZixjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsNkNBQTZDLENBQUM7QUFFNUQsU0FBUztBQUNULGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDBDQUEwQyxDQUFDO0FBRXpELFlBQVk7QUFDWixjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyw4QkFBOEIsQ0FBQztBQUU3QyxXQUFXO0FBQ1gsY0FBYyx1QkFBdUIsQ0FBQztBQVF0QyxhQUFhO0FBQ2IsY0FBYyxrQ0FBa0MsQ0FBQztBQUVqRCxnQkFBZ0I7QUFDaEIsY0FBYyx5Q0FBeUMsQ0FBQztBQUV4RCxVQUFVO0FBQ1YsY0FBYyw4QkFBOEIsQ0FBQztBQUU3QyxXQUFXO0FBQ1gsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBrbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtc1xuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2tsZXMtbWF0ZXJpYWwtZHluYW1pY2Zvcm1zLm1vZHVsZSc7XG5cbi8qKkRJUkVDVElWRSAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlL2R5bmFtaWMtZmllbGQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZS9keW5hbWljLWNvbXBvbmVudC5kaXJlY3RpdmUnO1xuXG4vKkZPUk1TKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm1zL2J1dHRvbi1jb250cm9sLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3Jtcy9idXR0b25jaGVja2VyLWNvbnRyb2wuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm1zL2J1dHRvbmZpbGUtY29udHJvbC5jb21wb25lbnQnO1xuXG4vKipGSUVMRFMgKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9iYWRnZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2J1dHRvbi1mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvYnV0dG9uY2hlY2tlci1mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvYnV0dG9uZmlsZS1mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvYnV0dG9uLXN1Ym1pdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2NoZWNrYm94LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvY29sb3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9kYXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvZmllbGQuYWJzdHJhY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2lucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvaW5wdXQuY2xlYXJhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvbGFiZWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9saXN0LWZpZWxkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvcmFkaW8uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy90ZXh0YXJlYS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL3RleHQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9jaGlwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvZ3JvdXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvc2VsZWN0LnNlYXJjaC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmllbGRzL2xpbmUtYnJlYWsuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9saW5rLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvc2xpZGUtdG9nZ2xlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvc2VsZWN0aW9uLWxpc3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkcy9idXR0b24tdG9vZ2xlLWdyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZHMvYXJyYXkuY29tcG9uZW50JztcblxuLyoqRU5VTVMgKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudW1zL3R5cGUuZW51bSc7XG5cbi8qKklOVEVSRkFDRVMgKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyZmFjZXMvY29tcG9uZW50LmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnRlcmZhY2VzL2ZpZWxkLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnRlcmZhY2VzL2ZpZWxkLmNvbmZpZy5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW50ZXJmYWNlcy92YWxpZGF0b3IuaW50ZXJmYWNlJztcblxuLyoqTUFUQ0hFUiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWF0Y2hlci9mb3JtLWVycm9yLm1hdGNoZXInO1xuXG4vKipWQUxJREFUT1JTICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi92YWxpZGF0b3JzL2F1dG9jb21wbGV0ZS52YWxpZGF0b3InO1xuXG4vKipGT1JNICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9keW5hbWljLWZvcm0uY29tcG9uZW50JztcblxuLyoqUElQRVMgKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGUvYXJyYXkucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlL3RyYW5zZm9ybS5waXBlJztcbiJdfQ==
@@ -43,6 +43,20 @@ import { FlexLayoutModule } from '@angular/flex-layout';
43
43
  import { TranslateModule } from '@ngx-translate/core';
44
44
  import { NgxMatSelectSearchModule } from 'ngx-mat-select-search';
45
45
 
46
+ var EnumType;
47
+ (function (EnumType) {
48
+ EnumType["text"] = "text";
49
+ EnumType["number"] = "number";
50
+ EnumType["time"] = "time";
51
+ EnumType["date"] = "date";
52
+ EnumType["color"] = "color";
53
+ EnumType["list"] = "list";
54
+ EnumType["multi"] = "multi";
55
+ EnumType["array"] = "array";
56
+ EnumType["group"] = "group";
57
+ EnumType["lineBreak"] = "lineBreak";
58
+ })(EnumType || (EnumType = {}));
59
+
46
60
  let KlesDynamicFormComponent = class KlesDynamicFormComponent {
47
61
  constructor(fb) {
48
62
  this.fb = fb;
@@ -106,7 +120,7 @@ let KlesDynamicFormComponent = class KlesDynamicFormComponent {
106
120
  this.fields
107
121
  .filter(field => !this.form.controls[field.name])
108
122
  .forEach(field => {
109
- if (field.type === 'lineBreak') {
123
+ if (field.type === EnumType.lineBreak) {
110
124
  return;
111
125
  }
112
126
  const control = this.createControl(field);
@@ -114,19 +128,40 @@ let KlesDynamicFormComponent = class KlesDynamicFormComponent {
114
128
  });
115
129
  }
116
130
  createControl(field) {
117
- if (field.type === 'listField') {
131
+ if (field.type === EnumType.array) {
118
132
  const array = this.fb.array([]);
119
- field.value.forEach((data) => {
120
- const subGroup = this.fb.group({});
133
+ if (field.value && Array.isArray(field.value)) {
134
+ if (field.collections && Array.isArray(field.collections)) {
135
+ field.value.forEach(val => {
136
+ const group = this.fb.group({});
137
+ field.collections.forEach(subfield => {
138
+ const data = val[subfield.name] || null;
139
+ const control = this.createControl(Object.assign(Object.assign({}, subfield), (data && { value: data })));
140
+ group.addControl(subfield.name, control);
141
+ });
142
+ array.push(group);
143
+ });
144
+ }
145
+ }
146
+ else {
147
+ const group = this.fb.group({});
121
148
  field.collections.forEach(subfield => {
122
- const control = this.createControl(subfield);
123
- subGroup.addControl(subfield.name, control);
149
+ const control = this.createControl(Object.assign({}, subfield));
150
+ group.addControl(subfield.name, control);
124
151
  });
125
- array.push(subGroup);
126
- });
152
+ array.push(group);
153
+ }
154
+ // field.value.forEach((data: any) => {
155
+ // const subGroup = this.fb.group({});
156
+ // field.collections.forEach(subfield => {
157
+ // const control = this.createControl(subfield);
158
+ // subGroup.addControl(subfield.name, control);
159
+ // });
160
+ // array.push(subGroup);
161
+ // });
127
162
  return array;
128
163
  }
129
- else if (field.type === 'group') {
164
+ else if (field.type === EnumType.group) {
130
165
  const subGroup = this.fb.group({});
131
166
  if (field.collections && Array.isArray(field.collections)) {
132
167
  field.collections.forEach(subfield => {
@@ -195,7 +230,7 @@ let KlesDynamicFormComponent = class KlesDynamicFormComponent {
195
230
  createForm() {
196
231
  const group = this.fb.group({});
197
232
  this.fields.forEach(field => {
198
- if (field.type === 'lineBreak') {
233
+ if (field.type === EnumType.lineBreak) {
199
234
  return;
200
235
  }
201
236
  const control = this.createControl(field);
@@ -1156,6 +1191,39 @@ KlesFormButtonToogleGroupComponent = __decorate([
1156
1191
  // <mat-button-toggle value="underline">Underline</mat-button-toggle>
1157
1192
  // </mat-button-toggle-group>
1158
1193
 
1194
+ let KlesFormArrayComponent = class KlesFormArrayComponent extends KlesFieldAbstract {
1195
+ ngOnInit() {
1196
+ // this.subGroup = this.group.controls[this.field.name] as FormGroup;
1197
+ super.ngOnInit();
1198
+ this.formArray = this.group.controls[this.field.name];
1199
+ console.log('on arrive ici');
1200
+ console.log(this.field);
1201
+ console.log(this.formArray);
1202
+ }
1203
+ };
1204
+ KlesFormArrayComponent = __decorate([
1205
+ Component({
1206
+ selector: 'kles-array',
1207
+ template: `
1208
+ <div [formGroup]="group">
1209
+ <ng-container [formArrayName]="field.name">
1210
+ <div class="group-container" *ngFor="let subGroup of formArray.controls let index = index;"
1211
+ [ngClass]="field.direction === 'column' ? 'column': 'row'">
1212
+ <ng-container *ngFor="let subfield of field.collections;"
1213
+ klesDynamicField [field]="subfield" [group]="subGroup" [siblingFields]="field.collections">
1214
+ </ng-container>
1215
+ </div>
1216
+ </ng-container>
1217
+ </div>
1218
+ `,
1219
+ styles: ['mat-form-field {width: calc(100%)}',
1220
+ ':host { display:flex; flex-direction: inherit}',
1221
+ '.group-container {display:flex; flex-direction: inherit}',
1222
+ '.row { gap:10px; flex-direction: row }',
1223
+ '.column { flex-direction: column, gap:0px}']
1224
+ })
1225
+ ], KlesFormArrayComponent);
1226
+
1159
1227
  const componentMapper = {
1160
1228
  label: KlesFormLabelComponent,
1161
1229
  input: KlesFormInputComponent,
@@ -1165,6 +1233,7 @@ const componentMapper = {
1165
1233
  radio: KlesFormRadioComponent,
1166
1234
  checkbox: KlesFormCheckboxComponent,
1167
1235
  listField: KlesFormListFieldComponent,
1236
+ array: KlesFormArrayComponent,
1168
1237
  color: KlesFormColorComponent,
1169
1238
  chip: KlesFormChipComponent,
1170
1239
  group: KlesFormGroupComponent,
@@ -1847,7 +1916,8 @@ const components = [
1847
1916
  KlesFormLinkComponent,
1848
1917
  KlesFormSlideToggleComponent,
1849
1918
  KlesFormSelectionListComponent,
1850
- KlesFormButtonToogleGroupComponent
1919
+ KlesFormButtonToogleGroupComponent,
1920
+ KlesFormArrayComponent
1851
1921
  ];
1852
1922
  const directives = [KlesDynamicFieldDirective, KlesComponentDirective];
1853
1923
  const pipes = [KlesTransformPipe, ArrayFormatPipe];
@@ -1918,5 +1988,5 @@ function autocompleteStringValidator(validOptions, optional) {
1918
1988
  * Generated bundle index. Do not edit.
1919
1989
  */
1920
1990
 
1921
- export { ArrayFormatPipe, KlesButtonCheckerComponent, KlesButtonComponent, KlesButtonFileComponent, KlesComponentDirective, KlesDynamicFieldDirective, KlesDynamicFormComponent, KlesFieldAbstract, KlesFormBadgeComponent, KlesFormButtonCheckerComponent, KlesFormButtonComponent, KlesFormButtonFileComponent, KlesFormButtonToogleGroupComponent, KlesFormCheckboxComponent, KlesFormChipComponent, KlesFormColorComponent, KlesFormDateComponent, KlesFormErrorStateMatcher, KlesFormGroupComponent, KlesFormIconComponent, KlesFormInputClearableComponent, KlesFormInputComponent, KlesFormLabelComponent, KlesFormLineBreakComponent, KlesFormLinkComponent, KlesFormListFieldComponent, KlesFormRadioComponent, KlesFormSelectComponent, KlesFormSelectSearchComponent, KlesFormSelectionListComponent, KlesFormSlideToggleComponent, KlesFormSubmitButtonComponent, KlesFormTextComponent, KlesFormTextareaComponent, KlesMaterialDynamicformsModule, KlesTransformPipe, autocompleteObjectValidator, autocompleteStringValidator, MaterialModule as ɵa };
1991
+ export { ArrayFormatPipe, EnumType, KlesButtonCheckerComponent, KlesButtonComponent, KlesButtonFileComponent, KlesComponentDirective, KlesDynamicFieldDirective, KlesDynamicFormComponent, KlesFieldAbstract, KlesFormArrayComponent, KlesFormBadgeComponent, KlesFormButtonCheckerComponent, KlesFormButtonComponent, KlesFormButtonFileComponent, KlesFormButtonToogleGroupComponent, KlesFormCheckboxComponent, KlesFormChipComponent, KlesFormColorComponent, KlesFormDateComponent, KlesFormErrorStateMatcher, KlesFormGroupComponent, KlesFormIconComponent, KlesFormInputClearableComponent, KlesFormInputComponent, KlesFormLabelComponent, KlesFormLineBreakComponent, KlesFormLinkComponent, KlesFormListFieldComponent, KlesFormRadioComponent, KlesFormSelectComponent, KlesFormSelectSearchComponent, KlesFormSelectionListComponent, KlesFormSlideToggleComponent, KlesFormSubmitButtonComponent, KlesFormTextComponent, KlesFormTextareaComponent, KlesMaterialDynamicformsModule, KlesTransformPipe, autocompleteObjectValidator, autocompleteStringValidator, MaterialModule as ɵa };
1922
1992
  //# sourceMappingURL=3kles-kles-material-dynamicforms.js.map