@koalarx/ui
Version:
Koala UI is a Design System developed in Angular whose objective is to facilitate and make your development faster and simpler, making this framework your greatest ally.
148 lines • 19.3 kB
JavaScript
import { DynamicFormTypeFieldEnum } from "../../enums/dynamic-form-type-field.enum";
import { koala } from "@koalarx/utils";
import { DynamicFormBuilder } from "../dynamic-form.builder";
export class FieldBase {
constructor(label, name, type, formConfig, fb, deviceService) {
this.formConfig = formConfig;
this.fb = fb;
this.deviceService = deviceService;
this.fieldConfig = {
label,
name,
type
};
this.appearance().grid();
}
hide(hide = true) {
this.fieldConfig.show = !hide;
return this;
}
focus() {
this.fieldConfig.focus = true;
return this;
}
syncValidator(validators) {
this.fieldConfig.syncValidators = validators;
return this;
}
asyncValidator(validators) {
this.fieldConfig.asyncValidators = validators;
return this;
}
disabled(disabled = true) {
this.fieldConfig.disabled = disabled;
return this;
}
required(required = true) {
this.fieldConfig.required = required;
return this;
}
textHint(hint) {
this.fieldConfig.textHint = hint;
return this;
}
min(min) {
this.fieldConfig.min = min;
return this;
}
max(max) {
this.fieldConfig.max = max;
return this;
}
minLength(min) {
this.fieldConfig.minLength = min;
return this;
}
maxLength(max) {
this.fieldConfig.maxLength = max;
return this;
}
multiple(multiple = true) {
this.fieldConfig.multiple = multiple;
return this;
}
valueChanges(fn) {
this.fieldConfig.valueChanges = fn;
return this;
}
setValue(value) {
this.fieldConfig.value = value;
return this;
}
appearance(type = "outline", floatLabel = "always") {
this.fieldConfig.appearance = type;
this.fieldConfig.floatLabel = floatLabel;
return this;
}
grid(size = 12, width = 100) {
if (this.deviceService.isMobile()) {
size = 12;
}
for (let colSize = 12; colSize >= 1; colSize--) {
this.fieldConfig.class = this.fieldConfig.class?.replace('col-' + colSize, '');
}
this.addClass('col-' + size);
this.addFieldClass('w-' + width);
return this;
}
setOptions(options) {
this.fieldConfig.opcoesSelect = options;
return this;
}
addClass(className) {
if (this.deviceService.isMobile() &&
className.indexOf('col-') >= 0 &&
className.indexOf('col-12') === 0) {
className = className.replace('col-1', 'col-12')
.replace('col-2', 'col-12')
.replace('col-3', 'col-12')
.replace('col-4', 'col-12')
.replace('col-5', 'col-12')
.replace('col-6', 'col-12')
.replace('col-7', 'col-12')
.replace('col-8', 'col-12')
.replace('col-9', 'col-12')
.replace('col-10', 'col-12')
.replace('col-11', 'col-12');
}
this.fieldConfig.class = koala(`${this.fieldConfig?.class ?? ''} ${className}`)
.string()
.split(' ')
.clearEmptyValues()
.toString(' ')
.getValue();
return this;
}
addFieldClass(className) {
this.fieldConfig.fieldClass = koala(`${this.fieldConfig?.fieldClass ?? ''} ${className}`)
.string()
.split(' ')
.clearEmptyValues()
.toString(' ')
.getValue();
return this;
}
setCustomMasc(mask, config) {
this.fieldConfig.customMasc = mask;
this.fieldConfig.customMascThousandSeparator = config?.thousandSeparator;
this.fieldConfig.customMascSuffix = config?.suffix;
this.fieldConfig.customMascPrefix = config?.prefix;
return this;
}
generate() {
let getLastConfig = (this.formConfig.formConfig.length > 0) ?
this.formConfig.formConfig[this.formConfig.formConfig.length - 1] :
null;
if (getLastConfig?.type === DynamicFormTypeFieldEnum.moreItems && getLastConfig?.name !== 'endMoreItems') {
this.formConfig.formConfig[this.formConfig.formConfig.length - 1].moreItemsConfig.formConfig.push(this.fieldConfig);
}
else {
if (getLastConfig?.name === 'endMoreItems') {
this.formConfig.formConfig.splice(this.formConfig.formConfig.length - 1, 1);
}
this.formConfig.formConfig.push(this.fieldConfig);
}
return new DynamicFormBuilder(this.fb, this.deviceService, this.formConfig.formConfig);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.base.js","sourceRoot":"","sources":["../../../../../../../projects/form/src/lib/dynamic-form/builder/fields/field.base.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,wBAAwB,EAAE,MAAM,0CAA0C,CAAC;AAIpF,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE7D,MAAM,OAAgB,SAAS;IAG7B,YACE,KAAa,EACb,IAAY,EACZ,IAA8B,EACtB,UAA2C,EACzC,EAAsB,EACtB,aAAoC;QAFtC,eAAU,GAAV,UAAU,CAAiC;QACzC,OAAE,GAAF,EAAE,CAAoB;QACtB,kBAAa,GAAb,aAAa,CAAuB;QAE9C,IAAI,CAAC,WAAW,GAAG;YACjB,KAAK;YACL,IAAI;YACJ,IAAI;SACL,CAAA;QACD,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAEM,IAAI,CAAC,OAAgB,IAAI;QAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK;QACV,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,aAAa,CAAC,UAAyB;QAC5C,IAAI,CAAC,WAAW,CAAC,cAAc,GAAG,UAAU,CAAC;QAC7C,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,cAAc,CAAC,UAAiD;QACrE,IAAI,CAAC,WAAW,CAAC,eAAe,GAAG,UAAU,CAAC;QAC9C,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,QAAQ,CAAC,WAAoB,IAAI;QACtC,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACrC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,QAAQ,CAAC,WAAoB,IAAI;QACtC,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACrC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,QAAQ,CAAC,IAAY;QAC1B,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,IAAI,CAAC;QACjC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,GAAG,CAAC,GAAW;QACpB,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,GAAG,CAAC;QAC3B,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,GAAG,CAAC,GAAW;QACpB,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,GAAG,CAAC;QAC3B,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,SAAS,CAAC,GAAW;QAC1B,IAAI,CAAC,WAAW,CAAC,SAAS,GAAG,GAAG,CAAC;QACjC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,SAAS,CAAC,GAAW;QAC1B,IAAI,CAAC,WAAW,CAAC,SAAS,GAAG,GAAG,CAAC;QACjC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,QAAQ,CAAC,QAAQ,GAAG,IAAI;QAC7B,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACrC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,YAAY,CAAI,EAAsB;QAC3C,IAAI,CAAC,WAAW,CAAC,YAAY,GAAG,EAAE,CAAC;QACnC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,QAAQ,CAAC,KAAU;QACxB,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,KAAK,CAAC;QAC/B,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,UAAU,CAAC,OAA+B,SAAS,EAAE,aAA6B,QAAQ;QAC/F,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,UAAU,CAAC;QACzC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,IAAI,CAAC,OAAyD,EAAE,EAAE,QAAgB,GAAG;QAC1F,IAAI,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,EAAE;YACjC,IAAI,GAAG,EAAE,CAAC;SACX;QAED,KAAK,IAAI,OAAO,GAAG,EAAE,EAAE,OAAO,IAAI,CAAC,EAAE,OAAO,EAAE,EAAE;YAC9C,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,OAAO,CAAC,MAAM,GAAG,OAAO,EAAE,EAAE,CAAC,CAAC;SAChF;QACD,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;QAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC;QAEjC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,UAAU,CAAC,OAAwC;QACxD,IAAI,CAAC,WAAW,CAAC,YAAY,GAAG,OAAO,CAAC;QACxC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,QAAQ,CAAC,SAAiB;QAC/B,IACE,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE;YAC7B,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC;YAC9B,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,EACjC;YACA,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;iBAC1B,OAAO,CAAC,QAAQ,EAAE,QAAQ,CAAC;iBAC3B,OAAO,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;SACnD;QAED,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,KAAK,IAAI,EAAE,IAAI,SAAS,EAAE,CAAC;aAC5E,MAAM,EAAE;aACR,KAAK,CAAC,GAAG,CAAC;aACV,gBAAgB,EAAE;aAClB,QAAQ,CAAC,GAAG,CAAC;aACb,QAAQ,EAAE,CAAC;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,aAAa,CAAC,SAAiB;QACpC,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,UAAU,IAAI,EAAE,IAAI,SAAS,EAAE,CAAC;aACtF,MAAM,EAAE;aACR,KAAK,CAAC,GAAG,CAAC;aACV,gBAAgB,EAAE;aAClB,QAAQ,CAAC,GAAG,CAAC;aACb,QAAQ,EAAE,CAAC;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,aAAa,CAAC,IAAY,EAAE,MAIlC;QACC,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,WAAW,CAAC,2BAA2B,GAAG,MAAM,EAAE,iBAAiB,CAAC;QACzE,IAAI,CAAC,WAAW,CAAC,gBAAgB,GAAG,MAAM,EAAE,MAAM,CAAC;QACnD,IAAI,CAAC,WAAW,CAAC,gBAAgB,GAAG,MAAM,EAAE,MAAM,CAAC;QACnD,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,QAAQ;QACb,IAAI,aAAa,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;YAC3D,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;YACnE,IAAI,CAAC;QAEP,IAAI,aAAa,EAAE,IAAI,KAAK,wBAAwB,CAAC,SAAS,IAAI,aAAa,EAAE,IAAI,KAAK,cAAc,EAAE;YACxG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,eAAe,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACrH;aAAM;YACL,IAAI,aAAa,EAAE,IAAI,KAAK,cAAc,EAAE;gBAC1C,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;aAC7E;YAED,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACnD;QACD,OAAO,IAAI,kBAAkB,CAC3B,IAAI,CAAC,EAAE,EACP,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,UAAU,CAAC,UAAU,CAC3B,CAAC;IACJ,CAAC;CACF","sourcesContent":["import { KoalaDynamicFormFieldInterface } from \"../../interfaces/koala.dynamic-form-field.interface\";\nimport { DynamicFormTypeFieldEnum } from \"../../enums/dynamic-form-type-field.enum\";\nimport { FloatLabelType, MatFormFieldAppearance } from \"@angular/material/form-field\";\nimport { AsyncValidatorFn, UntypedFormBuilder, ValidatorFn } from \"@angular/forms\";\nimport { KoalaDynamicFormConfigInterface } from \"../../interfaces/koala.dynamic-form-config.interface\";\nimport { koala } from \"@koalarx/utils\";\nimport { DeviceDetectorService } from \"ngx-device-detector\";\nimport { DynamicFormBuilder } from \"../dynamic-form.builder\";\n\nexport abstract class FieldBase {\n  protected readonly fieldConfig: KoalaDynamicFormFieldInterface;\n\n  protected constructor(\n    label: string,\n    name: string,\n    type: DynamicFormTypeFieldEnum,\n    private formConfig: KoalaDynamicFormConfigInterface,\n    protected fb: UntypedFormBuilder,\n    protected deviceService: DeviceDetectorService\n  ) {\n    this.fieldConfig = {\n      label,\n      name,\n      type\n    }\n    this.appearance().grid();\n  }\n\n  public hide(hide: boolean = true) {\n    this.fieldConfig.show = !hide;\n    return this;\n  }\n\n  public focus() {\n    this.fieldConfig.focus = true;\n    return this;\n  }\n\n  public syncValidator(validators: ValidatorFn[]) {\n    this.fieldConfig.syncValidators = validators;\n    return this;\n  }\n\n  public asyncValidator(validators: AsyncValidatorFn | AsyncValidatorFn[]) {\n    this.fieldConfig.asyncValidators = validators;\n    return this;\n  }\n\n  public disabled(disabled: boolean = true) {\n    this.fieldConfig.disabled = disabled;\n    return this;\n  }\n\n  public required(required: boolean = true) {\n    this.fieldConfig.required = required;\n    return this;\n  }\n\n  public textHint(hint: string) {\n    this.fieldConfig.textHint = hint;\n    return this;\n  }\n\n  public min(min: number) {\n    this.fieldConfig.min = min;\n    return this;\n  }\n\n  public max(max: number) {\n    this.fieldConfig.max = max;\n    return this;\n  }\n\n  public minLength(min: number) {\n    this.fieldConfig.minLength = min;\n    return this;\n  }\n\n  public maxLength(max: number) {\n    this.fieldConfig.maxLength = max;\n    return this;\n  }\n\n  public multiple(multiple = true) {\n    this.fieldConfig.multiple = multiple;\n    return this;\n  }\n\n  public valueChanges<T>(fn: (value: T) => void) {\n    this.fieldConfig.valueChanges = fn;\n    return this;\n  }\n\n  public setValue(value: any) {\n    this.fieldConfig.value = value;\n    return this;\n  }\n\n  public appearance(type: MatFormFieldAppearance = \"outline\", floatLabel: FloatLabelType = \"always\") {\n    this.fieldConfig.appearance = type;\n    this.fieldConfig.floatLabel = floatLabel;\n    return this;\n  }\n\n  public grid(size: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 = 12, width: number = 100) {\n    if (this.deviceService.isMobile()) {\n      size = 12;\n    }\n\n    for (let colSize = 12; colSize >= 1; colSize--) {\n      this.fieldConfig.class = this.fieldConfig.class?.replace('col-' + colSize, '');\n    }\n    this.addClass('col-' + size);\n    this.addFieldClass('w-' + width);\n\n    return this;\n  }\n\n  public setOptions(options: { value: any; name: string; }[]) {\n    this.fieldConfig.opcoesSelect = options;\n    return this;\n  }\n\n  public addClass(className: string) {\n    if (\n      this.deviceService.isMobile() &&\n      className.indexOf('col-') >= 0 &&\n      className.indexOf('col-12') === 0\n    ) {\n      className = className.replace('col-1', 'col-12')\n                           .replace('col-2', 'col-12')\n                           .replace('col-3', 'col-12')\n                           .replace('col-4', 'col-12')\n                           .replace('col-5', 'col-12')\n                           .replace('col-6', 'col-12')\n                           .replace('col-7', 'col-12')\n                           .replace('col-8', 'col-12')\n                           .replace('col-9', 'col-12')\n                           .replace('col-10', 'col-12')\n                           .replace('col-11', 'col-12');\n    }\n\n    this.fieldConfig.class = koala(`${this.fieldConfig?.class ?? ''} ${className}`)\n      .string()\n      .split(' ')\n      .clearEmptyValues()\n      .toString(' ')\n      .getValue();\n    return this;\n  }\n\n  public addFieldClass(className: string) {\n    this.fieldConfig.fieldClass = koala(`${this.fieldConfig?.fieldClass ?? ''} ${className}`)\n      .string()\n      .split(' ')\n      .clearEmptyValues()\n      .toString(' ')\n      .getValue();\n    return this;\n  }\n\n  public setCustomMasc(mask: string, config?: {\n    thousandSeparator?: string;\n    suffix?: string;\n    prefix?: string;\n  }) {\n    this.fieldConfig.customMasc = mask;\n    this.fieldConfig.customMascThousandSeparator = config?.thousandSeparator;\n    this.fieldConfig.customMascSuffix = config?.suffix;\n    this.fieldConfig.customMascPrefix = config?.prefix;\n    return this;\n  }\n\n  public generate() {\n    let getLastConfig = (this.formConfig.formConfig.length > 0) ?\n      this.formConfig.formConfig[this.formConfig.formConfig.length - 1] :\n      null;\n\n    if (getLastConfig?.type === DynamicFormTypeFieldEnum.moreItems && getLastConfig?.name !== 'endMoreItems') {\n      this.formConfig.formConfig[this.formConfig.formConfig.length - 1].moreItemsConfig.formConfig.push(this.fieldConfig);\n    } else {\n      if (getLastConfig?.name === 'endMoreItems') {\n        this.formConfig.formConfig.splice(this.formConfig.formConfig.length - 1, 1);\n      }\n\n      this.formConfig.formConfig.push(this.fieldConfig);\n    }\n    return new DynamicFormBuilder(\n      this.fb,\n      this.deviceService,\n      this.formConfig.formConfig\n    );\n  }\n}\n"]}