@seniorsistemas/angular-components 17.19.0 → 17.19.2

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 (26) hide show
  1. package/bundles/seniorsistemas-angular-components.umd.js +23 -4
  2. package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
  3. package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
  4. package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
  5. package/components/checkbox/checkbox.component.d.ts +1 -0
  6. package/components/checkbox/models/checkbox-data.d.ts +1 -0
  7. package/components/dynamic-form/configurations/fields/field.d.ts +5 -0
  8. package/components/dynamic-form/configurations/form-field.d.ts +4 -0
  9. package/esm2015/components/checkbox/checkbox.component.js +6 -3
  10. package/esm2015/components/checkbox/models/checkbox-data.js +1 -1
  11. package/esm2015/components/custom-fields/custom-fields.component.js +4 -1
  12. package/esm2015/components/dynamic-form/components/dynamic-field/dynamic-field.component.js +2 -2
  13. package/esm2015/components/dynamic-form/configurations/fields/field.js +7 -2
  14. package/esm2015/components/dynamic-form/configurations/form-field.js +5 -1
  15. package/esm5/components/checkbox/checkbox.component.js +10 -3
  16. package/esm5/components/checkbox/models/checkbox-data.js +1 -1
  17. package/esm5/components/custom-fields/custom-fields.component.js +4 -1
  18. package/esm5/components/dynamic-form/components/dynamic-field/dynamic-field.component.js +2 -2
  19. package/esm5/components/dynamic-form/configurations/fields/field.js +7 -2
  20. package/esm5/components/dynamic-form/configurations/form-field.js +5 -1
  21. package/fesm2015/seniorsistemas-angular-components.js +19 -4
  22. package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
  23. package/fesm5/seniorsistemas-angular-components.js +23 -4
  24. package/fesm5/seniorsistemas-angular-components.js.map +1 -1
  25. package/package.json +1 -1
  26. package/seniorsistemas-angular-components.metadata.json +1 -1
@@ -3,7 +3,11 @@ import { FieldSize } from "../field-size";
3
3
  var Field = /** @class */ (function () {
4
4
  function Field(config) {
5
5
  var _this = this;
6
- var _a, _b, _c, _d, _e, _f;
6
+ var _a, _b, _c, _d, _e, _f, _g;
7
+ /**
8
+ * In some cases DynamicFormField use a custom field that alredy exists, this happen in CustomFields when convert 'Integer, Double & Money' types to 'Custom' this create two labels. activate this property hide the parent label.
9
+ */
10
+ this.ignoreLabel = false;
7
11
  if ((_a = config.footer) === null || _a === void 0 ? void 0 : _a.help) {
8
12
  config.footer.help = __assign({ visible: function () { return true; } }, (_b = config.footer) === null || _b === void 0 ? void 0 : _b.help);
9
13
  }
@@ -31,8 +35,9 @@ var Field = /** @class */ (function () {
31
35
  this.CustomFieldComponentClass = config.CustomFieldComponentClass;
32
36
  this.displayTimeInfoSign = (_e = config.displayTimeInfoSign) !== null && _e !== void 0 ? _e : 5000;
33
37
  this.useInfoSignFocusedInputRef = (_f = config.useInfoSignFocusedInputRef) !== null && _f !== void 0 ? _f : true;
38
+ this.ignoreLabel = (_g = config.ignoreLabel) !== null && _g !== void 0 ? _g : false;
34
39
  }
35
40
  return Field;
36
41
  }());
37
42
  export { Field };
38
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/dynamic-form/configurations/fields/field.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAuC1C;IAkCI,eAAY,MAAmB;QAA/B,iBAoCC;;QAnCG,UAAI,MAAM,CAAC,MAAM,0CAAE,IAAI,EAAE;YACrB,MAAM,CAAC,MAAM,CAAC,IAAI,cACd,OAAO,EAAE,cAAM,OAAA,IAAI,EAAJ,CAAI,UAChB,MAAM,CAAC,MAAM,0CAAE,IAAI,CACzB,CAAA;SACJ;QAED,UAAI,MAAM,CAAC,MAAM,0CAAE,IAAI,EAAE;YACrB,MAAM,CAAC,MAAM,CAAC,IAAI,cACd,OAAO,EAAE,cAAM,OAAA,IAAI,EAAJ,CAAI,UAChB,MAAM,CAAC,MAAM,0CAAE,IAAI,CACzB,CAAA;SACJ;QAED,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,CAAC,cAAM,OAAA,KAAK,EAAL,CAAK,CAAC,CAAC;QACjD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,CAAC,cAAM,OAAA,IAAI,EAAJ,CAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC;QACpB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACxB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,WAAW,IAAI,EAAE,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,KAAK,CAAC;QAC3C,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,IAAI,SAAS,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAC7C,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAC;QAC1C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,cAAc,CAAC;QAC5C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,QAAM,GAAG,SAAI,KAAI,CAAC,IAAI,CAAC,GAAG,CAAG,EAA7B,CAA6B,CAAC,CAAC;QAClF,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC;QACxC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAC;QAC1C,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC;QAChD,IAAI,CAAC,yBAAyB,GAAG,MAAM,CAAC,yBAAyB,CAAC;QAClE,IAAI,CAAC,mBAAmB,SAAG,MAAM,CAAC,mBAAmB,mCAAI,IAAI,CAAC;QAC9D,IAAI,CAAC,0BAA0B,SAAG,MAAM,CAAC,0BAA0B,mCAAI,IAAI,CAAC;IAChF,CAAC;IACL,YAAC;AAAD,CAAC,AAvED,IAuEC","sourcesContent":["import { TemplateRef } from \"@angular/core\";\nimport { FieldSize } from \"../field-size\";\nimport { FieldType } from \"../field-type\";\nimport { AbstractControl } from \"@angular/forms\";\nimport { FormField } from \"../form-field\";\n\nexport interface FieldConfig {\n    defaultValue?: any;\n    required?: () => boolean;\n    visible?: () => boolean;\n    id?: string;\n    name: string;\n    label: string;\n    infoSign?: string;\n    tooltip?: string;\n    placeholder?: string;\n    showClear?: boolean;\n    type?: FieldType;\n    size?: FieldSize;\n    representedBy?: \"radio\" | \"switch\";\n    errorMessages?: () => ({}) | {};\n    bottomTemplate?: TemplateRef<Element>;\n    footer?: {\n        help?: {\n            text: string;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n        link?: {\n            label: string;\n            onClick: (options: { abstractControl: AbstractControl, formField: FormField }) => void;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n    };\n    CustomFieldClass?: unknown;\n    CustomFieldComponentClass?: unknown;\n    displayTimeInfoSign?: number;\n    sortableColumnName?: string\n    useInfoSignFocusedInputRef?: boolean;\n}\n\nexport abstract class Field {\n    public required?: () => boolean;\n    public visible?: () => boolean;\n    public id?: string;\n    public name: string;\n    public label: string;\n    public infoSign?: string;\n    public tooltip?: string;\n    public placeholder?: string;\n    public showClear?: boolean;\n    public type: FieldType;\n    public size: FieldSize;\n    public gridClass: string[];\n    public defaultValue?: any;\n    public representedBy?: \"radio\" | \"switch\";\n    public errorMessages?: () => ({}) | {};\n    public bottomTemplate?: TemplateRef<Element>;\n    public CustomFieldClass?: unknown;\n    public CustomFieldComponentClass?: unknown;\n    public displayTimeInfoSign?: number;\n    public sortableColumnName?: string\n    public footer?: {\n        help?: {\n            text: string;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n        link?: {\n            label: string;\n            onClick: (options: { abstractControl: AbstractControl, formField: FormField }) => void;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n    };\n    public useInfoSignFocusedInputRef?: boolean;\n\n    constructor(config: FieldConfig) {\n        if (config.footer?.help) {\n            config.footer.help = {\n                visible: () => true,\n                ...config.footer?.help\n            }\n        }\n\n        if (config.footer?.link) {\n            config.footer.link = {\n                visible: () => true,\n                ...config.footer?.link\n            }\n        }\n\n        this.required = config.required || (() => false);\n        this.visible = config.visible || (() => true);\n        this.id = config.id;\n        this.name = config.name;\n        this.label = config.label;\n        this.infoSign = config.infoSign;\n        this.tooltip = config.tooltip;\n        this.placeholder = config.placeholder || \"\";\n        this.showClear = config.showClear || false;\n        this.type = config.type;\n        this.size = new FieldSize(config.size || {});\n        this.errorMessages = config.errorMessages;\n        this.bottomTemplate = config.bottomTemplate;\n        this.footer = config.footer;\n        this.gridClass = Object.keys(this.size).map(key => `ui-${key}-${this.size[key]}`);\n        this.defaultValue = config.defaultValue;\n        this.representedBy = config.representedBy;\n        this.CustomFieldClass = config.CustomFieldClass;\n        this.CustomFieldComponentClass = config.CustomFieldComponentClass;\n        this.displayTimeInfoSign = config.displayTimeInfoSign ?? 5000;\n        this.useInfoSignFocusedInputRef = config.useInfoSignFocusedInputRef ?? true;\n    }\n}\n"]}
43
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/dynamic-form/configurations/fields/field.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAwC1C;IAuCI,eAAY,MAAmB;QAA/B,iBAqCC;;QA1CD;;WAEG;QACH,gBAAW,GAAI,KAAK,CAAC;QAGjB,UAAI,MAAM,CAAC,MAAM,0CAAE,IAAI,EAAE;YACrB,MAAM,CAAC,MAAM,CAAC,IAAI,cACd,OAAO,EAAE,cAAM,OAAA,IAAI,EAAJ,CAAI,UAChB,MAAM,CAAC,MAAM,0CAAE,IAAI,CACzB,CAAA;SACJ;QAED,UAAI,MAAM,CAAC,MAAM,0CAAE,IAAI,EAAE;YACrB,MAAM,CAAC,MAAM,CAAC,IAAI,cACd,OAAO,EAAE,cAAM,OAAA,IAAI,EAAJ,CAAI,UAChB,MAAM,CAAC,MAAM,0CAAE,IAAI,CACzB,CAAA;SACJ;QAED,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,CAAC,cAAM,OAAA,KAAK,EAAL,CAAK,CAAC,CAAC;QACjD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,CAAC,cAAM,OAAA,IAAI,EAAJ,CAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC;QACpB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACxB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,WAAW,IAAI,EAAE,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,KAAK,CAAC;QAC3C,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,IAAI,SAAS,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAC7C,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAC;QAC1C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,cAAc,CAAC;QAC5C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,QAAM,GAAG,SAAI,KAAI,CAAC,IAAI,CAAC,GAAG,CAAG,EAA7B,CAA6B,CAAC,CAAC;QAClF,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC;QACxC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAC;QAC1C,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC;QAChD,IAAI,CAAC,yBAAyB,GAAG,MAAM,CAAC,yBAAyB,CAAC;QAClE,IAAI,CAAC,mBAAmB,SAAG,MAAM,CAAC,mBAAmB,mCAAI,IAAI,CAAC;QAC9D,IAAI,CAAC,0BAA0B,SAAG,MAAM,CAAC,0BAA0B,mCAAI,IAAI,CAAC;QAC5E,IAAI,CAAC,WAAW,SAAG,MAAM,CAAC,WAAW,mCAAI,KAAK,CAAC;IACnD,CAAC;IACL,YAAC;AAAD,CAAC,AA7ED,IA6EC","sourcesContent":["import { TemplateRef } from \"@angular/core\";\nimport { FieldSize } from \"../field-size\";\nimport { FieldType } from \"../field-type\";\nimport { AbstractControl } from \"@angular/forms\";\nimport { FormField } from \"../form-field\";\n\nexport interface FieldConfig {\n    defaultValue?: any;\n    required?: () => boolean;\n    visible?: () => boolean;\n    id?: string;\n    name: string;\n    label: string;\n    infoSign?: string;\n    tooltip?: string;\n    placeholder?: string;\n    showClear?: boolean;\n    type?: FieldType;\n    size?: FieldSize;\n    representedBy?: \"radio\" | \"switch\";\n    errorMessages?: () => ({}) | {};\n    bottomTemplate?: TemplateRef<Element>;\n    footer?: {\n        help?: {\n            text: string;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n        link?: {\n            label: string;\n            onClick: (options: { abstractControl: AbstractControl, formField: FormField }) => void;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n    };\n    CustomFieldClass?: unknown;\n    CustomFieldComponentClass?: unknown;\n    displayTimeInfoSign?: number;\n    sortableColumnName?: string\n    useInfoSignFocusedInputRef?: boolean;\n    ignoreLabel?: boolean\n}\n\nexport abstract class Field {\n    public required?: () => boolean;\n    public visible?: () => boolean;\n    public id?: string;\n    public name: string;\n    public label: string;\n    public infoSign?: string;\n    public tooltip?: string;\n    public placeholder?: string;\n    public showClear?: boolean;\n    public type: FieldType;\n    public size: FieldSize;\n    public gridClass: string[];\n    public defaultValue?: any;\n    public representedBy?: \"radio\" | \"switch\";\n    public errorMessages?: () => ({}) | {};\n    public bottomTemplate?: TemplateRef<Element>;\n    public CustomFieldClass?: unknown;\n    public CustomFieldComponentClass?: unknown;\n    public displayTimeInfoSign?: number;\n    public sortableColumnName?: string\n    public footer?: {\n        help?: {\n            text: string;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n        link?: {\n            label: string;\n            onClick: (options: { abstractControl: AbstractControl, formField: FormField }) => void;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n    };\n    public useInfoSignFocusedInputRef?: boolean;\n\n    /**\n     * In some cases DynamicFormField use a custom field that alredy exists, this happen in CustomFields when convert 'Integer, Double & Money' types to 'Custom' this create two labels. activate this property hide the parent label.\n     */\n    ignoreLabel? = false;\n\n    constructor(config: FieldConfig) {\n        if (config.footer?.help) {\n            config.footer.help = {\n                visible: () => true,\n                ...config.footer?.help\n            }\n        }\n\n        if (config.footer?.link) {\n            config.footer.link = {\n                visible: () => true,\n                ...config.footer?.link\n            }\n        }\n\n        this.required = config.required || (() => false);\n        this.visible = config.visible || (() => true);\n        this.id = config.id;\n        this.name = config.name;\n        this.label = config.label;\n        this.infoSign = config.infoSign;\n        this.tooltip = config.tooltip;\n        this.placeholder = config.placeholder || \"\";\n        this.showClear = config.showClear || false;\n        this.type = config.type;\n        this.size = new FieldSize(config.size || {});\n        this.errorMessages = config.errorMessages;\n        this.bottomTemplate = config.bottomTemplate;\n        this.footer = config.footer;\n        this.gridClass = Object.keys(this.size).map(key => `ui-${key}-${this.size[key]}`);\n        this.defaultValue = config.defaultValue;\n        this.representedBy = config.representedBy;\n        this.CustomFieldClass = config.CustomFieldClass;\n        this.CustomFieldComponentClass = config.CustomFieldComponentClass;\n        this.displayTimeInfoSign = config.displayTimeInfoSign ?? 5000;\n        this.useInfoSignFocusedInputRef = config.useInfoSignFocusedInputRef ?? true;\n        this.ignoreLabel = config.ignoreLabel ?? false;\n    }\n}\n"]}
@@ -23,6 +23,10 @@ import { TextAreaIAField } from "./fields/text-area-ia-field";
23
23
  import { TextField } from "./fields/text-field";
24
24
  var FormField = /** @class */ (function () {
25
25
  function FormField(config) {
26
+ /**
27
+ * In some cases DynamicFormField use a custom field that alredy exists, this happen in CustomFields when convert 'Integer, Double & Money' types to 'Custom' this create two labels. activate this property hide the parent label.
28
+ */
29
+ this.ignoreLabel = false;
26
30
  switch (config.type) {
27
31
  case FieldType.Enum:
28
32
  return new SelectField(config);
@@ -86,4 +90,4 @@ var Option = /** @class */ (function () {
86
90
  return Option;
87
91
  }());
88
92
  export { Option };
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/dynamic-form/configurations/form-field.ts"],"names":[],"mappings":";AAQA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,uBAAuB,EAAE,MAAM,UAAU,CAAC;AAClE,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAuB,MAAM,wBAAwB,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD;IAuKI,mBAAY,MAAW;QACnB,QAAQ,MAAM,CAAC,IAAI,EAAE;YACjB,KAAK,SAAS,CAAC,IAAI;gBACf,OAAO,IAAI,WAAW,CAAC,MAAM,CAAC,CAAC;YACnC,KAAK,SAAS,CAAC,YAAY;gBACvB,OAAO,IAAI,iBAAiB,CAAC,MAAM,CAAC,CAAC;YACzC,KAAK,SAAS,CAAC,KAAK;gBAChB,OAAO,IAAI,aAAa,CAAC,MAAM,CAAC,CAAC;YACrC,KAAK,SAAS,CAAC,OAAO;gBAClB,OAAO,IAAI,WAAW,CAAC,MAAM,CAAC,CAAC;YACnC,KAAK,SAAS,CAAC,MAAM;gBACjB,OAAO,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC;YACpC,KAAK,SAAS,CAAC,MAAM;gBACjB,OAAO,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;YACtC,KAAK,SAAS,CAAC,MAAM,CAAC;YACtB,KAAK,SAAS,CAAC,MAAM;gBACjB,OAAO,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC;YACjC,KAAK,SAAS,CAAC,QAAQ;gBACnB,OAAO,IAAI,aAAa,CAAC,MAAM,CAAC,CAAC;YACrC,KAAK,SAAS,CAAC,IAAI;gBACf,OAAO,IAAI,aAAa,CAAC,MAAM,CAAC,CAAC;YACrC,KAAK,SAAS,CAAC,MAAM;gBACjB,OAAO,IAAI,eAAe,CAAC,MAAM,CAAC,CAAC;YACvC,KAAK,SAAS,CAAC,OAAO;gBAClB,OAAO,MAAM,CAAC,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC;YACzG,KAAK,SAAS,CAAC,IAAI,CAAC;YACpB,KAAK,SAAS,CAAC,QAAQ,CAAC;YACxB,KAAK,SAAS,CAAC,aAAa,CAAC;YAC7B,KAAK,SAAS,CAAC,IAAI;gBACf,OAAO,IAAI,aAAa,CAAC,MAAM,CAAC,CAAC;YACrC,KAAK,SAAS,CAAC,MAAM;gBACjB,OAAO,IAAI,WAAW,CAAC,MAAM,CAAC,CAAC;YACnC,KAAK,SAAS,CAAC,KAAK;gBAChB,OAAO,IAAI,gBAAgB,CAAC,MAAM,CAAC,CAAC;YACxC,KAAK,SAAS,CAAC,QAAQ;gBACnB,OAAO,IAAI,aAAa,CAAC,MAAM,CAAC,CAAC;YACrC,KAAK,SAAS,CAAC,KAAK;gBAChB,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC,CAAC;YAClC,KAAK,SAAS,CAAC,kBAAkB;gBAC7B,OAAO,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAAC;YAC/C,KAAK,SAAS,CAAC,IAAI;gBACf,OAAO,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC;YACjC,KAAK,SAAS,CAAC,MAAM;gBACjB,OAAO,IAAI,WAAW,CAAC,MAAM,CAAC,CAAC;YACnC,KAAK,SAAS,CAAC,cAAc;gBACzB,OAAO,IAAI,mBAAmB,CAAC,MAAM,CAAC,CAAC;YAC3C,KAAK,SAAS,CAAC,MAAM;gBACjB,OAAO,IAAI,WAAW,CAAC,MAAM,CAAC,CAAC;YACnC,KAAK,SAAS,CAAC,MAAM;gBACT,IAAA,0CAAgB,EAAE,mDAAe,CAAY;gBACrD,OAAO,IAAI,gBAAgB,CAAC,YAAY,CAAC,CAAC;SACjD;IACL,CAAC;IACL,gBAAC;AAAD,CAAC,AA5ND,IA4NC;;AAED;IAII,gBAAY,KAAa,EAAE,KAAU;QACjC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IACL,aAAC;AAAD,CAAC,AARD,IAQC","sourcesContent":["import { TemplateRef } from \"@angular/core\";\nimport { AbstractControl } from \"@angular/forms\";\nimport { AlignmentOptions } from \"@seniorsistemas/ng2-currency-mask\";\nimport { FileDto } from \"../../file-upload/index\";\nimport { CalendarLocaleOptions, NumberLocaleOptions } from \"../../locale/index\";\nimport { NumberAlignmentOption } from \"../../number-input\";\nimport { AddonConfig } from \"./addon-config\";\nimport { FieldSize } from \"./field-size\";\nimport { FieldType } from \"./field-type\";\nimport { CheckboxField, CountryPhonePickerField } from \"./fields\";\nimport { AutocompleteField } from \"./fields/autocomplete-field\";\nimport { BignumberField } from \"./fields/bignumber-field\";\nimport { BlobField } from \"./fields/blob-field\";\nimport { BooleanField, BooleanOptionsLabel } from \"./fields/boolean-field\";\nimport { BooleanSwitchField } from \"./fields/boolean-switch-field\";\nimport { CalendarField } from \"./fields/calendar-field\";\nimport { ChipsField } from \"./fields/chips-field\";\nimport { CurrencyField } from \"./fields/currency-field\";\nimport { DecimalField } from \"./fields/decimal-field\";\nimport { EditorField } from \"./fields/editor-field\";\nimport { LookupField } from \"./fields/lookup-field\";\nimport { NumberField } from \"./fields/number-field\";\nimport { PasswordField } from \"./fields/password-field\";\nimport { ProfilePictureField } from \"./fields/profile-picture\";\nimport { RadioButtonField } from \"./fields/radio-button-field\";\nimport { SelectField } from \"./fields/select-field\";\nimport { SliderField } from \"./fields/slider-field\";\nimport { TextAreaField } from \"./fields/text-area-field\";\nimport { TextAreaIAField } from \"./fields/text-area-ia-field\";\nimport { TextField } from \"./fields/text-field\";\n\nexport class FormField {\n    id?: string;\n    /**\n     * Tells whether the field is required or not\n     */\n    required?: () => boolean;\n    name?: string;\n    sortableColumnName?: string;\n    type?: FieldType;\n    label?: string;\n    /**\n     * Labels of a Radio Button, only used to FieldType Boolean\n     */\n    optionsLabel?: BooleanOptionsLabel;\n    tooltip?: string;\n    /**\n     * Mask pattern.\n     */\n    mask?: () => string | string;\n    /**\n     * Message to display when there are no results for a query.\n     */\n    emptyMessage?: string;\n    cols?: number;\n    rows?: number;\n    placeholder?: string;\n    options?: any;\n    calendarLocaleOptions?: CalendarLocaleOptions;\n    numberLocaleOptions?: NumberLocaleOptions;\n    multiple?: boolean;\n    appendTo?: string;\n    browserAutocomplete?: boolean;\n    showClear?: boolean;\n    showOnFocus?: boolean;\n    style?: { [klass: string]: any };\n    representedBy?: \"radio\" | \"switch\";\n    /**\n     * Whether the `RadioButton` should be displayed on the vertical or not.\n     *\n     * @default false\n     */\n    verticalAlignment?: boolean;\n    /**\n     * Field max length\n     */\n    precision?: Function | number;\n    /**\n     * Number of decimal places\n     */\n    scale?: Function | number;\n    /**\n     * @deprecated Using FieldType.Number this attribute is unnecessary\n     */\n    alignTo?: NumberAlignmentOption | AlignmentOptions;\n    gridClass?:\n        | string\n        | string[]\n        | Set<string>\n        | {\n              [klass: string]: any;\n          };\n    size?: FieldSize;\n    multipleSelectedLabel?: string;\n    inputType?: string;\n    accept?: string;\n    files?: FileDto[];\n    autocompleteForceSelection?: boolean;\n    /**\n     * The minimum selectable date.\n     */\n    minDate?: Date;\n    /**\n     * The maximum selectable date.\n     */\n    maxDate?: Date;\n    /**\n     * Set the date to highlight on first opening if the field is blank.\n     */\n    defaultDate?: Date;\n    /**\n     * Text or icon to be grouped in the left of an input.\n     */\n    leftAddon?: AddonConfig;\n    /**\n     * Text or icon to be grouped in right of an input.\n     */\n    rightAddon?: AddonConfig;\n    /**\n     * InfoSign para a label do input.\n     */\n    infoSign?: string;\n    /**\n     * Expression to restricts user input\n     */\n    keyFilter?: RegExp;\n\n    /**\n     * Default value for field\n     */\n    defaultValue?: any;\n    /**\n     * Customized FormField error message\n     */\n    errorMessages?: () => ({}) | {};\n    visible?: () => boolean;\n    /**\n     * Callback to invoke when the field loses focus\n     */\n    onBlur?: (event: FocusEvent) => void;\n    /**\n     * Callback to invoke when the field receives focus\n     */\n    onFocus?: (event: FocusEvent) => void;\n    onComplete?: (event: any) => void;\n    onInput?: (event: any) => void;\n    onChange?: (event: boolean) => void;\n    onSelect?: (event: any) => void;\n    /**\n     * Callback to invoke on component click.\n     */\n    onClick?: (event: any) => void;\n    onClose?: (event: any) => void;\n    onTodayClick?: (event: any) => void;\n    onClearClick?: (event: any) => void;\n    onMonthChange?: (event: any) => void;\n    onYearChange?: (event: any) => void;\n    /**\n     * Callback to invoke when a value is added.\n     */\n    onAdd?: (event: any) => void;\n    /**\n     * Callback to invoke when a value is removed.\n     */\n    onRemove?: (event: any) => void;\n    /**\n     * Callback to invoke when a chip is clicked.\n     */\n    onChipClick?: (event: any) => void;\n\n    /**\n     * Callback to invoke when a slider is released\n     */\n    onSlideEnd?: (event: any) => void;\n\n    CustomFieldClass?: any;\n    CustomFieldComponentClass?: any;\n\n    /**\n     * @deprecated You should use footer attribute instead.\n     */\n    bottomTemplate?: TemplateRef<Element>;\n\n    autoClear?: boolean;\n    displayTimeInfoSign?: number;\n\n    footer?: {\n        help?: {\n            text: string;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n        link?: {\n            label: string;\n            onClick: (options: { abstractControl: AbstractControl, formField: FormField }) => void;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n    };\n\n    constructor(config: any) {\n        switch (config.type) {\n            case FieldType.Enum:\n                return new SelectField(config);\n            case FieldType.Autocomplete:\n                return new AutocompleteField(config);\n            case FieldType.Money:\n                return new CurrencyField(config);\n            case FieldType.Integer:\n                return new NumberField(config);\n            case FieldType.Double:\n                return new DecimalField(config);\n            case FieldType.Number:\n                return new BignumberField(config);\n            case FieldType.String:\n            case FieldType.Binary:\n                return new TextField(config);\n            case FieldType.Password:\n                return new PasswordField(config);\n            case FieldType.Text:\n                return new TextAreaField(config);\n            case FieldType.TextIA:\n                return new TextAreaIAField(config);\n            case FieldType.Boolean:\n                return config.representedBy === \"switch\" ? new BooleanSwitchField(config) : new BooleanField(config);\n            case FieldType.Date:\n            case FieldType.DateTime:\n            case FieldType.LocalDateTime:\n            case FieldType.Time:\n                return new CalendarField(config);\n            case FieldType.Lookup:\n                return new LookupField(config);\n            case FieldType.Radio:\n                return new RadioButtonField(config);\n            case FieldType.Checkbox:\n                return new CheckboxField(config);\n            case FieldType.Chips:\n                return new ChipsField(config);\n            case FieldType.CountryPhonePicker:\n                return new CountryPhonePickerField(config);\n            case FieldType.Blob:\n                return new BlobField(config);\n            case FieldType.Slider:\n                return new SliderField(config);\n            case FieldType.ProfilePicture:\n                return new ProfilePictureField(config);\n            case FieldType.Editor:\n                return new EditorField(config);\n            case FieldType.Custom:\n                const { CustomFieldClass, ...otherConfigs } = config;\n                return new CustomFieldClass(otherConfigs);\n        }\n    }\n}\n\nexport class Option {\n    label: string;\n    value?: any;\n\n    constructor(label: string, value: any) {\n        this.label = label;\n        this.value = value;\n    }\n}\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/dynamic-form/configurations/form-field.ts"],"names":[],"mappings":"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","sourcesContent":["import { TemplateRef } from \"@angular/core\";\nimport { AbstractControl } from \"@angular/forms\";\nimport { AlignmentOptions } from \"@seniorsistemas/ng2-currency-mask\";\nimport { FileDto } from \"../../file-upload/index\";\nimport { CalendarLocaleOptions, NumberLocaleOptions } from \"../../locale/index\";\nimport { NumberAlignmentOption } from \"../../number-input\";\nimport { AddonConfig } from \"./addon-config\";\nimport { FieldSize } from \"./field-size\";\nimport { FieldType } from \"./field-type\";\nimport { CheckboxField, CountryPhonePickerField } from \"./fields\";\nimport { AutocompleteField } from \"./fields/autocomplete-field\";\nimport { BignumberField } from \"./fields/bignumber-field\";\nimport { BlobField } from \"./fields/blob-field\";\nimport { BooleanField, BooleanOptionsLabel } from \"./fields/boolean-field\";\nimport { BooleanSwitchField } from \"./fields/boolean-switch-field\";\nimport { CalendarField } from \"./fields/calendar-field\";\nimport { ChipsField } from \"./fields/chips-field\";\nimport { CurrencyField } from \"./fields/currency-field\";\nimport { DecimalField } from \"./fields/decimal-field\";\nimport { EditorField } from \"./fields/editor-field\";\nimport { LookupField } from \"./fields/lookup-field\";\nimport { NumberField } from \"./fields/number-field\";\nimport { PasswordField } from \"./fields/password-field\";\nimport { ProfilePictureField } from \"./fields/profile-picture\";\nimport { RadioButtonField } from \"./fields/radio-button-field\";\nimport { SelectField } from \"./fields/select-field\";\nimport { SliderField } from \"./fields/slider-field\";\nimport { TextAreaField } from \"./fields/text-area-field\";\nimport { TextAreaIAField } from \"./fields/text-area-ia-field\";\nimport { TextField } from \"./fields/text-field\";\n\nexport class FormField {\n    id?: string;\n    /**\n     * Tells whether the field is required or not\n     */\n    required?: () => boolean;\n    name?: string;\n    sortableColumnName?: string;\n    type?: FieldType;\n    label?: string;\n    /**\n     * Labels of a Radio Button, only used to FieldType Boolean\n     */\n    optionsLabel?: BooleanOptionsLabel;\n    tooltip?: string;\n    /**\n     * Mask pattern.\n     */\n    mask?: () => string | string;\n    /**\n     * Message to display when there are no results for a query.\n     */\n    emptyMessage?: string;\n    cols?: number;\n    rows?: number;\n    placeholder?: string;\n    options?: any;\n    calendarLocaleOptions?: CalendarLocaleOptions;\n    numberLocaleOptions?: NumberLocaleOptions;\n    multiple?: boolean;\n    appendTo?: string;\n    browserAutocomplete?: boolean;\n    showClear?: boolean;\n    showOnFocus?: boolean;\n    style?: { [klass: string]: any };\n    representedBy?: \"radio\" | \"switch\";\n    /**\n     * Whether the `RadioButton` should be displayed on the vertical or not.\n     *\n     * @default false\n     */\n    verticalAlignment?: boolean;\n    /**\n     * Field max length\n     */\n    precision?: Function | number;\n    /**\n     * Number of decimal places\n     */\n    scale?: Function | number;\n    /**\n     * @deprecated Using FieldType.Number this attribute is unnecessary\n     */\n    alignTo?: NumberAlignmentOption | AlignmentOptions;\n    gridClass?:\n        | string\n        | string[]\n        | Set<string>\n        | {\n            [klass: string]: any;\n        };\n    size?: FieldSize;\n    multipleSelectedLabel?: string;\n    inputType?: string;\n    accept?: string;\n    files?: FileDto[];\n    autocompleteForceSelection?: boolean;\n    /**\n     * The minimum selectable date.\n     */\n    minDate?: Date;\n    /**\n     * The maximum selectable date.\n     */\n    maxDate?: Date;\n    /**\n     * Set the date to highlight on first opening if the field is blank.\n     */\n    defaultDate?: Date;\n    /**\n     * Text or icon to be grouped in the left of an input.\n     */\n    leftAddon?: AddonConfig;\n    /**\n     * Text or icon to be grouped in right of an input.\n     */\n    rightAddon?: AddonConfig;\n    /**\n     * InfoSign para a label do input.\n     */\n    infoSign?: string;\n    /**\n     * Expression to restricts user input\n     */\n    keyFilter?: RegExp;\n\n    /**\n     * Default value for field\n     */\n    defaultValue?: any;\n    /**\n     * Customized FormField error message\n     */\n    errorMessages?: () => ({}) | {};\n    visible?: () => boolean;\n    /**\n     * Callback to invoke when the field loses focus\n     */\n    onBlur?: (event: FocusEvent) => void;\n    /**\n     * Callback to invoke when the field receives focus\n     */\n    onFocus?: (event: FocusEvent) => void;\n    onComplete?: (event: any) => void;\n    onInput?: (event: any) => void;\n    onChange?: (event: boolean) => void;\n    onSelect?: (event: any) => void;\n    /**\n     * Callback to invoke on component click.\n     */\n    onClick?: (event: any) => void;\n    onClose?: (event: any) => void;\n    onTodayClick?: (event: any) => void;\n    onClearClick?: (event: any) => void;\n    onMonthChange?: (event: any) => void;\n    onYearChange?: (event: any) => void;\n    /**\n     * Callback to invoke when a value is added.\n     */\n    onAdd?: (event: any) => void;\n    /**\n     * Callback to invoke when a value is removed.\n     */\n    onRemove?: (event: any) => void;\n    /**\n     * Callback to invoke when a chip is clicked.\n     */\n    onChipClick?: (event: any) => void;\n\n    /**\n     * Callback to invoke when a slider is released\n     */\n    onSlideEnd?: (event: any) => void;\n\n    CustomFieldClass?: any;\n    CustomFieldComponentClass?: any;\n\n    /**\n     * @deprecated You should use footer attribute instead.\n     */\n    bottomTemplate?: TemplateRef<Element>;\n\n    autoClear?: boolean;\n    displayTimeInfoSign?: number;\n\n    footer?: {\n        help?: {\n            text: string;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n        link?: {\n            label: string;\n            onClick: (options: { abstractControl: AbstractControl, formField: FormField }) => void;\n            visible?: (options: { abstractControl: AbstractControl, formField: FormField }) => boolean;\n        };\n    };\n\n    /**\n     * In some cases DynamicFormField use a custom field that alredy exists, this happen in CustomFields when convert 'Integer, Double & Money' types to 'Custom' this create two labels. activate this property hide the parent label.\n     */\n    ignoreLabel? = false;\n\n    constructor(config: any) {\n        switch (config.type) {\n            case FieldType.Enum:\n                return new SelectField(config);\n            case FieldType.Autocomplete:\n                return new AutocompleteField(config);\n            case FieldType.Money:\n                return new CurrencyField(config);\n            case FieldType.Integer:\n                return new NumberField(config);\n            case FieldType.Double:\n                return new DecimalField(config);\n            case FieldType.Number:\n                return new BignumberField(config);\n            case FieldType.String:\n            case FieldType.Binary:\n                return new TextField(config);\n            case FieldType.Password:\n                return new PasswordField(config);\n            case FieldType.Text:\n                return new TextAreaField(config);\n            case FieldType.TextIA:\n                return new TextAreaIAField(config);\n            case FieldType.Boolean:\n                return config.representedBy === \"switch\" ? new BooleanSwitchField(config) : new BooleanField(config);\n            case FieldType.Date:\n            case FieldType.DateTime:\n            case FieldType.LocalDateTime:\n            case FieldType.Time:\n                return new CalendarField(config);\n            case FieldType.Lookup:\n                return new LookupField(config);\n            case FieldType.Radio:\n                return new RadioButtonField(config);\n            case FieldType.Checkbox:\n                return new CheckboxField(config);\n            case FieldType.Chips:\n                return new ChipsField(config);\n            case FieldType.CountryPhonePicker:\n                return new CountryPhonePickerField(config);\n            case FieldType.Blob:\n                return new BlobField(config);\n            case FieldType.Slider:\n                return new SliderField(config);\n            case FieldType.ProfilePicture:\n                return new ProfilePictureField(config);\n            case FieldType.Editor:\n                return new EditorField(config);\n            case FieldType.Custom:\n                const { CustomFieldClass, ...otherConfigs } = config;\n                return new CustomFieldClass(otherConfigs);\n        }\n    }\n}\n\nexport class Option {\n    label: string;\n    value?: any;\n\n    constructor(label: string, value: any) {\n        this.label = label;\n        this.value = value;\n    }\n}\n"]}
@@ -3574,6 +3574,9 @@ let CheckboxComponent = CheckboxComponent_1 = class CheckboxComponent {
3574
3574
  this._onChange(this.state);
3575
3575
  this._onTouched();
3576
3576
  }
3577
+ get renderType() {
3578
+ return this.data.renderType || "inline";
3579
+ }
3577
3580
  _toggleChildrenCheck(item, state, checked) {
3578
3581
  var _a;
3579
3582
  if ((_a = item.children) === null || _a === void 0 ? void 0 : _a.length) {
@@ -3600,7 +3603,7 @@ __decorate([
3600
3603
  CheckboxComponent = CheckboxComponent_1 = __decorate([
3601
3604
  Component({
3602
3605
  selector: "s-checkbox",
3603
- template: "<div class=\"checkbox\">\n <label>\n <div\n class=\"checkbox-wrapper\"\n [ngClass]=\"{ 'checkbox-wrapper--disabled': state.disabled }\">\n <input\n type=\"checkbox\"\n class=\"checkbox-input\"\n [disabled]=\"state.disabled\"\n [ngClass]=\"{\n 'checkbox-input--checked': state.checked,\n 'checkbox-input--indeterminate': state.indeterminate\n }\"\n (change)=\"onCheckboxChange()\"\n [attr.aria-checked]=\"state.indeterminate ? 'mixed' : state.checked\"\n [attr.aria-disabled]=\"state.disabled\"\n role=\"checkbox\" />\n {{ data.label }}\n </div>\n </label>\n <div *ngIf=\"data.children && data.children.length\" class=\"checkbox-children\">\n <s-checkbox\n *ngFor=\"let child of data.children\"\n [data]=\"child\"\n [ngModel]=\"state.children[child.label]\"\n (ngModelChange)=\"updateParent()\">\n </s-checkbox>\n </div>\n</div>\n",
3606
+ template: "<div class=\"checkbox\">\n <label>\n <div\n class=\"checkbox-wrapper\"\n [class.checkbox-wrapper-inline]=\"renderType === 'inline'\"\n [class.checkbox-wrapper-block]=\"renderType === 'block'\"\n [ngClass]=\"{ 'checkbox-wrapper--disabled': state.disabled }\">\n <input\n type=\"checkbox\"\n class=\"checkbox-input\"\n [disabled]=\"state.disabled\"\n [ngClass]=\"{\n 'checkbox-input--checked': state.checked,\n 'checkbox-input--indeterminate': state.indeterminate\n }\"\n (change)=\"onCheckboxChange()\"\n [attr.aria-checked]=\"state.indeterminate ? 'mixed' : state.checked\"\n [attr.aria-disabled]=\"state.disabled\"\n role=\"checkbox\" />\n {{ data.label }}\n </div>\n </label>\n <div *ngIf=\"data.children && data.children.length\" class=\"checkbox-children\">\n <s-checkbox\n *ngFor=\"let child of data.children\"\n [data]=\"child\"\n [ngModel]=\"state.children[child.label]\"\n (ngModelChange)=\"updateParent()\">\n </s-checkbox>\n </div>\n</div>\n",
3604
3607
  providers: [
3605
3608
  {
3606
3609
  provide: NG_VALUE_ACCESSOR,
@@ -3608,7 +3611,7 @@ CheckboxComponent = CheckboxComponent_1 = __decorate([
3608
3611
  multi: true,
3609
3612
  },
3610
3613
  ],
3611
- styles: [".checkbox{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;gap:10px;margin-bottom:10px}.checkbox .checkbox-wrapper{-ms-flex-align:center;align-items:center;color:#212533;display:-ms-flexbox;display:flex;font-family:\"Open Sans\" sans-serif;font-size:14px;gap:12px}.checkbox .checkbox-wrapper .checkbox-input{-webkit-appearance:none;appearance:none;background-color:#fff;border:1px solid #c1c1cc;border-radius:4px;cursor:pointer;-ms-flex-negative:0;flex-shrink:0;height:20px;width:20px;position:relative}.checkbox .checkbox-wrapper .checkbox-input--checked{background-color:#428bca;border-color:#428bca}.checkbox .checkbox-wrapper .checkbox-input--checked::after{border:solid #fff;border-width:0 2px 2px 0;content:\"\";height:12px;left:6px;position:absolute;top:2px;transform:rotate(45deg);width:6px}.checkbox .checkbox-wrapper .checkbox-input--indeterminate{background-color:#428bca;border-color:#428bca}.checkbox .checkbox-wrapper .checkbox-input--indeterminate::after{background-color:#fff;content:\"\";height:2px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:10px}.checkbox .checkbox-wrapper:not(.checkbox-wrapper--disabled) .checkbox-input:not(.checkbox-input--checked):hover{background-color:#e5eaea;border-color:#ccc}.checkbox .checkbox-wrapper--disabled{opacity:.5;cursor:auto}.checkbox .checkbox-children{margin-left:20px}"]
3614
+ styles: [".checkbox{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;gap:10px;margin-bottom:10px}.checkbox .checkbox-wrapper{color:#212533;display:-ms-flexbox;display:flex;font-family:\"Open Sans\" sans-serif;font-size:14px;gap:12px}.checkbox .checkbox-wrapper-inline{-ms-flex-align:center;align-items:center}.checkbox .checkbox-wrapper-block{-ms-flex-direction:column-reverse;flex-direction:column-reverse}.checkbox .checkbox-wrapper .checkbox-input{-webkit-appearance:none;appearance:none;background-color:#fff;border:1px solid #c1c1cc;border-radius:4px;cursor:pointer;-ms-flex-negative:0;flex-shrink:0;height:20px;width:20px;position:relative}.checkbox .checkbox-wrapper .checkbox-input--checked{background-color:#428bca;border-color:#428bca}.checkbox .checkbox-wrapper .checkbox-input--checked::after{border:solid #fff;border-width:0 2px 2px 0;content:\"\";height:12px;left:6px;position:absolute;top:2px;transform:rotate(45deg);width:6px}.checkbox .checkbox-wrapper .checkbox-input--indeterminate{background-color:#428bca;border-color:#428bca}.checkbox .checkbox-wrapper .checkbox-input--indeterminate::after{background-color:#fff;content:\"\";height:2px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:10px}.checkbox .checkbox-wrapper:not(.checkbox-wrapper--disabled) .checkbox-input:not(.checkbox-input--checked):hover{background-color:#e5eaea;border-color:#ccc}.checkbox .checkbox-wrapper--disabled{opacity:.5;cursor:auto}.checkbox .checkbox-children{margin-left:20px}"]
3612
3615
  })
3613
3616
  ], CheckboxComponent);
3614
3617
 
@@ -5914,7 +5917,11 @@ class FieldSize {
5914
5917
 
5915
5918
  class Field {
5916
5919
  constructor(config) {
5917
- var _a, _b, _c, _d, _e, _f;
5920
+ var _a, _b, _c, _d, _e, _f, _g;
5921
+ /**
5922
+ * In some cases DynamicFormField use a custom field that alredy exists, this happen in CustomFields when convert 'Integer, Double & Money' types to 'Custom' this create two labels. activate this property hide the parent label.
5923
+ */
5924
+ this.ignoreLabel = false;
5918
5925
  if ((_a = config.footer) === null || _a === void 0 ? void 0 : _a.help) {
5919
5926
  config.footer.help = Object.assign({ visible: () => true }, (_b = config.footer) === null || _b === void 0 ? void 0 : _b.help);
5920
5927
  }
@@ -5942,6 +5949,7 @@ class Field {
5942
5949
  this.CustomFieldComponentClass = config.CustomFieldComponentClass;
5943
5950
  this.displayTimeInfoSign = (_e = config.displayTimeInfoSign) !== null && _e !== void 0 ? _e : 5000;
5944
5951
  this.useInfoSignFocusedInputRef = (_f = config.useInfoSignFocusedInputRef) !== null && _f !== void 0 ? _f : true;
5952
+ this.ignoreLabel = (_g = config.ignoreLabel) !== null && _g !== void 0 ? _g : false;
5945
5953
  }
5946
5954
  }
5947
5955
 
@@ -6471,6 +6479,10 @@ class ProfilePictureField extends Field {
6471
6479
 
6472
6480
  class FormField {
6473
6481
  constructor(config) {
6482
+ /**
6483
+ * In some cases DynamicFormField use a custom field that alredy exists, this happen in CustomFields when convert 'Integer, Double & Money' types to 'Custom' this create two labels. activate this property hide the parent label.
6484
+ */
6485
+ this.ignoreLabel = false;
6474
6486
  switch (config.type) {
6475
6487
  case FieldType.Enum:
6476
6488
  return new SelectField(config);
@@ -10520,7 +10532,7 @@ __decorate([
10520
10532
  DynamicFieldComponent = __decorate([
10521
10533
  Component({
10522
10534
  selector: "s-dynamic-field",
10523
- template: "<div class=\"ui-fluid\" [formGroup]=\"form\">\n <div class=\"ui-g\">\n <ng-container *ngFor=\"let field of fields\">\n <div\n *ngIf=\"!field.visible || field.visible()\"\n [ngClass]=\"field.gridClass\">\n\n <ng-container *ngIf=\"field.label && field.type === FieldType.Custom\">\n <label\n *sInfoSign=\"field.infoSign; displayTime: field.displayTimeInfoSign; useFocusedInputRef: field.useInfoSignFocusedInputRef\"\n [for]=\"field.name\"\n [ngClass]=\"{ required: field.required() }\"\n >\n {{ field.label }}\n </label>\n </ng-container>\n\n <ng-container\n *sDynamicForm=\"{\n id: id,\n config: field,\n group: form\n }\"\n ></ng-container>\n\n <s-control-errors\n [form]=\"form\"\n [control]=\"form.controls[field.name]\"\n [errorMessages]=\"getErrorMessages(field.errorMessages)\"\n ></s-control-errors>\n\n <ng-container *ngIf=\"field.footer\">\n <ng-container *ngIf=\"field.footer.help\">\n <span\n *ngIf=\"\n field.footer.help.visible({\n abstractControl: form.controls[field.name],\n formField: field\n })\n \"\n style=\"color: #888b99\"\n >\n {{ field.footer.help.text }}\n </span>\n </ng-container>\n\n <ng-container *ngIf=\"field.footer.link\">\n <div\n *ngIf=\"\n field.footer.link.visible({\n abstractControl: form.controls[field.name],\n formField: field\n })\n \"\n class=\"ui-g\"\n style=\"margin-left: -10px\"\n >\n <s-button\n [label]=\"field.footer.link.label\"\n priority=\"link\"\n (onClick)=\"\n field.footer.link.onClick({\n abstractControl:\n form.controls[field.name],\n formField: field\n })\n \"\n [auxiliary]=\"true\"\n ></s-button>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-template\n *ngIf=\"field?.bottomTemplate\"\n [ngTemplateOutlet]=\"field.bottomTemplate\"\n ></ng-template>\n </div>\n </ng-container>\n </div>\n</div>\n"
10535
+ template: "<div class=\"ui-fluid\" [formGroup]=\"form\">\n <div class=\"ui-g\">\n <ng-container *ngFor=\"let field of fields\">\n <div\n *ngIf=\"!field.visible || field.visible()\"\n [ngClass]=\"field.gridClass\">\n <ng-container *ngIf=\"field.ignoreLabel ? false : field.label && field.type === FieldType.Custom\">\n <label\n *sInfoSign=\"field.infoSign; displayTime: field.displayTimeInfoSign; useFocusedInputRef: field.useInfoSignFocusedInputRef\"\n [for]=\"field.name\"\n [ngClass]=\"{ required: field.required() }\"\n >\n {{ field.label }}\n </label>\n </ng-container>\n\n <ng-container\n *sDynamicForm=\"{\n id: id,\n config: field,\n group: form\n }\"\n ></ng-container>\n\n <s-control-errors\n [form]=\"form\"\n [control]=\"form.controls[field.name]\"\n [errorMessages]=\"getErrorMessages(field.errorMessages)\"\n ></s-control-errors>\n\n <ng-container *ngIf=\"field.footer\">\n <ng-container *ngIf=\"field.footer.help\">\n <span\n *ngIf=\"\n field.footer.help.visible({\n abstractControl: form.controls[field.name],\n formField: field\n })\n \"\n style=\"color: #888b99\"\n >\n {{ field.footer.help.text }}\n </span>\n </ng-container>\n\n <ng-container *ngIf=\"field.footer.link\">\n <div\n *ngIf=\"\n field.footer.link.visible({\n abstractControl: form.controls[field.name],\n formField: field\n })\n \"\n class=\"ui-g\"\n style=\"margin-left: -10px\"\n >\n <s-button\n [label]=\"field.footer.link.label\"\n priority=\"link\"\n (onClick)=\"\n field.footer.link.onClick({\n abstractControl:\n form.controls[field.name],\n formField: field\n })\n \"\n [auxiliary]=\"true\"\n ></s-button>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-template\n *ngIf=\"field?.bottomTemplate\"\n [ngTemplateOutlet]=\"field.bottomTemplate\"\n ></ng-template>\n </div>\n </ng-container>\n </div>\n</div>\n"
10524
10536
  })
10525
10537
  ], DynamicFieldComponent);
10526
10538
 
@@ -12533,6 +12545,7 @@ let CustomFieldsComponent = CustomFieldsComponent_1 = class CustomFieldsComponen
12533
12545
  leftAddon: {
12534
12546
  label: (_b = (_a = localeOptions === null || localeOptions === void 0 ? void 0 : localeOptions.number) === null || _a === void 0 ? void 0 : _a.currencySymbol) !== null && _b !== void 0 ? _b : "R$",
12535
12547
  },
12548
+ ignoreLabel: true,
12536
12549
  };
12537
12550
  break;
12538
12551
  case CustomFieldType.Double:
@@ -12542,6 +12555,7 @@ let CustomFieldsComponent = CustomFieldsComponent_1 = class CustomFieldsComponen
12542
12555
  CustomFieldClass: NumberField,
12543
12556
  precision: 15,
12544
12557
  scale: 2,
12558
+ ignoreLabel: true,
12545
12559
  };
12546
12560
  break;
12547
12561
  case CustomFieldType.Integer:
@@ -12551,6 +12565,7 @@ let CustomFieldsComponent = CustomFieldsComponent_1 = class CustomFieldsComponen
12551
12565
  CustomFieldClass: NumberField,
12552
12566
  precision: 15,
12553
12567
  scale: 0,
12568
+ ignoreLabel: true,
12554
12569
  };
12555
12570
  break;
12556
12571
  case CustomFieldType.Any: