@seniorsistemas/angular-components 19.0.2 → 19.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dynamic-form/dynamic-form/components/grid/row/row.component.d.ts +1 -0
- package/dynamic-form/dynamic-form/components/lookup/lookup.component.d.ts +4 -1
- package/esm2022/dynamic-form/dynamic-form/components/grid/row/row.component.mjs +12 -3
- package/esm2022/dynamic-form/dynamic-form/components/lookup/lookup.component.mjs +26 -17
- package/esm2022/dynamic-form/dynamic-form/dynamic-form.mjs +5 -3
- package/fesm2022/seniorsistemas-angular-components-dynamic-form.mjs +40 -20
- package/fesm2022/seniorsistemas-angular-components-dynamic-form.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -14,6 +14,7 @@ export declare class RowComponent implements BaseStructureComponentConfig {
|
|
|
14
14
|
protected isFunction(value: any): boolean;
|
|
15
15
|
protected fieldIsExpandedDynamicType(field: ExpandedDynamicType | ExpandedDynamicStructure | DynamicType): field is ExpandedDynamicType;
|
|
16
16
|
protected fieldGridClass(field: RowType): string;
|
|
17
|
+
protected getName(field: RowType): string;
|
|
17
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<RowComponent, never>;
|
|
18
19
|
static ɵcmp: i0.ɵɵComponentDeclaration<RowComponent, "s-row", never, { "id": { "alias": "id"; "required": false; "isSignal": true; }; "config": { "alias": "config"; "required": true; "isSignal": true; }; "group": { "alias": "group"; "required": true; "isSignal": true; }; "errorMessages": { "alias": "errorMessages"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
19
20
|
}
|
|
@@ -21,6 +21,7 @@ export declare class LookupComponent implements ControlValueAccessor, OnChanges,
|
|
|
21
21
|
private readonly hotkeysService;
|
|
22
22
|
protected readonly translateService: TranslateService;
|
|
23
23
|
protected readonly changeDetectorRef: ChangeDetectorRef;
|
|
24
|
+
private readonly MAP_FORM_DIALOG_CONTROLS;
|
|
24
25
|
private readonly lookupDialogContainer;
|
|
25
26
|
protected rowType: string;
|
|
26
27
|
indicatorLogo: LoadingStateIndicators;
|
|
@@ -40,7 +41,9 @@ export declare class LookupComponent implements ControlValueAccessor, OnChanges,
|
|
|
40
41
|
searchEmptyDescription?: string;
|
|
41
42
|
searchGridData: any[];
|
|
42
43
|
searchTotalRecords: number;
|
|
43
|
-
searchFields: DynamicType
|
|
44
|
+
searchFields: (DynamicType & {
|
|
45
|
+
customName?: string;
|
|
46
|
+
})[];
|
|
44
47
|
searchGridFields: DynamicType[];
|
|
45
48
|
multiSortMeta: SortMeta[];
|
|
46
49
|
placeholder?: string;
|
|
@@ -31,11 +31,20 @@ export class RowComponent {
|
|
|
31
31
|
const fieldSize = new FieldSize(field.size ?? {});
|
|
32
32
|
return fieldSize.getGridClass();
|
|
33
33
|
}
|
|
34
|
+
getName(field) {
|
|
35
|
+
if ('customName' in field && field.customName) {
|
|
36
|
+
return field.customName;
|
|
37
|
+
}
|
|
38
|
+
else if ('name' in field) {
|
|
39
|
+
return field.name;
|
|
40
|
+
}
|
|
41
|
+
return '';
|
|
42
|
+
}
|
|
34
43
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
35
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: RowComponent, isStandalone: true, selector: "s-row", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, group: { classPropertyName: "group", publicName: "group", isSignal: true, isRequired: true, transformFunction: null }, errorMessages: { classPropertyName: "errorMessages", publicName: "errorMessages", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div\n class=\"w-full\"\n [formGroup]=\"group()\"\n>\n @let rowConfig = config();\n @let rowIsVisible = formUtils.getFieldProperty(rowConfig.visible, true);\n @if (rowIsVisible) {\n <div class=\"grid w-screen max-w-full grid-cols-12 gap-4\">\n @for (field of config().fields; let i = $index; track i) {\n @if (fieldIsExpandedDynamicType(field)) {\n @let fieldVisible = formUtils.getFieldProperty(field.visible, true);\n @if (fieldVisible) {\n <div\n class=\"p-1\"\n [ngClass]=\"fieldGridClass(field)\"\n >\n <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n\n @if (
|
|
44
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: RowComponent, isStandalone: true, selector: "s-row", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, group: { classPropertyName: "group", publicName: "group", isSignal: true, isRequired: true, transformFunction: null }, errorMessages: { classPropertyName: "errorMessages", publicName: "errorMessages", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div\n class=\"w-full\"\n [formGroup]=\"group()\"\n>\n @let rowConfig = config();\n @let rowIsVisible = formUtils.getFieldProperty(rowConfig.visible, true);\n @if (rowIsVisible) {\n <div class=\"grid w-screen max-w-full grid-cols-12 gap-4\">\n @for (field of config().fields; let i = $index; track i) {\n @let fieldName = getName(field);\n @if (fieldIsExpandedDynamicType(field)) {\n @let fieldVisible = formUtils.getFieldProperty(field.visible, true);\n @if (fieldVisible) {\n <div\n class=\"p-1\"\n [ngClass]=\"fieldGridClass(field)\"\n >\n <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n\n @if (fieldName) {\n <s-control-errors\n [form]=\"group\"\n [control]=\"group().controls[fieldName]\"\n [errorMessages]=\"getErrorMessages(field.errorMessages)\"\n ></s-control-errors>\n }\n\n @if (field.footer) {\n @if (field.footer.help) {\n @let footerHelpVisible =\n field.footer.help.visible?.({\n abstractControl: group().controls[fieldName],\n formField: field,\n });\n @if (fieldName && field.footer.help.visible ? footerHelpVisible : true) {\n <span style=\"color: #888b99\">\n {{ field.footer.help.text }}\n </span>\n }\n }\n }\n\n @if (field.footer) {\n @let footerLinkVisible =\n field.footer.link?.visible?.({\n abstractControl: group().controls[fieldName],\n formField: field,\n });\n @if (fieldName && field.footer.link?.visible ? footerLinkVisible : true) {\n <div style=\"margin-left: -17px\">\n <s-button\n [label]=\"field.footer.link?.label\"\n priority=\"link\"\n (clicked)=\"\n field.footer.link?.onClick({\n abstractControl: group().controls[fieldName],\n formField: field,\n })\n \"\n [auxiliary]=\"true\"\n ></s-button>\n </div>\n }\n }\n @if (field.bottomTemplate) {\n <ng-template [ngTemplateOutlet]=\"field.bottomTemplate\"></ng-template>\n }\n </div>\n }\n } @else {\n @let gridClass = fieldGridClass(field);\n <div [ngClass]=\"gridClass\">\n <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n </div>\n }\n }\n </div>\n }\n</div>\n\n", dependencies: [{ kind: "ngmodule", type: ControlErrorsModule }, { kind: "component", type: i1.ControlErrorsComponent, selector: "s-control-errors", inputs: ["id", "control", "errorMessages", "form"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ButtonComponent, selector: "s-button", inputs: ["id", "label", "tooltip", "tooltipPosition", "iconClass", "rightIconClass", "caret", "styleClass", "baseZIndex", "disabled", "auxiliary", "type", "priority", "menuOptions", "size", "slide", "animation", "badge", "iconColor"], outputs: ["clicked"] }, { kind: "directive", type: DynamicFormDirective, selector: "[sDynamicForm]", inputs: ["sDynamicForm"] }] });
|
|
36
45
|
}
|
|
37
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RowComponent, decorators: [{
|
|
38
47
|
type: Component,
|
|
39
|
-
args: [{ selector: 's-row', standalone: true, imports: [ControlErrorsModule, ReactiveFormsModule, NgClass, ButtonComponent, DynamicFormDirective], template: "<div\n class=\"w-full\"\n [formGroup]=\"group()\"\n>\n @let rowConfig = config();\n @let rowIsVisible = formUtils.getFieldProperty(rowConfig.visible, true);\n @if (rowIsVisible) {\n <div class=\"grid w-screen max-w-full grid-cols-12 gap-4\">\n @for (field of config().fields; let i = $index; track i) {\n @if (fieldIsExpandedDynamicType(field)) {\n @let fieldVisible = formUtils.getFieldProperty(field.visible, true);\n @if (fieldVisible) {\n <div\n class=\"p-1\"\n [ngClass]=\"fieldGridClass(field)\"\n >\n <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n\n @if (
|
|
48
|
+
args: [{ selector: 's-row', standalone: true, imports: [ControlErrorsModule, ReactiveFormsModule, NgClass, ButtonComponent, DynamicFormDirective], template: "<div\n class=\"w-full\"\n [formGroup]=\"group()\"\n>\n @let rowConfig = config();\n @let rowIsVisible = formUtils.getFieldProperty(rowConfig.visible, true);\n @if (rowIsVisible) {\n <div class=\"grid w-screen max-w-full grid-cols-12 gap-4\">\n @for (field of config().fields; let i = $index; track i) {\n @let fieldName = getName(field);\n @if (fieldIsExpandedDynamicType(field)) {\n @let fieldVisible = formUtils.getFieldProperty(field.visible, true);\n @if (fieldVisible) {\n <div\n class=\"p-1\"\n [ngClass]=\"fieldGridClass(field)\"\n >\n <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n\n @if (fieldName) {\n <s-control-errors\n [form]=\"group\"\n [control]=\"group().controls[fieldName]\"\n [errorMessages]=\"getErrorMessages(field.errorMessages)\"\n ></s-control-errors>\n }\n\n @if (field.footer) {\n @if (field.footer.help) {\n @let footerHelpVisible =\n field.footer.help.visible?.({\n abstractControl: group().controls[fieldName],\n formField: field,\n });\n @if (fieldName && field.footer.help.visible ? footerHelpVisible : true) {\n <span style=\"color: #888b99\">\n {{ field.footer.help.text }}\n </span>\n }\n }\n }\n\n @if (field.footer) {\n @let footerLinkVisible =\n field.footer.link?.visible?.({\n abstractControl: group().controls[fieldName],\n formField: field,\n });\n @if (fieldName && field.footer.link?.visible ? footerLinkVisible : true) {\n <div style=\"margin-left: -17px\">\n <s-button\n [label]=\"field.footer.link?.label\"\n priority=\"link\"\n (clicked)=\"\n field.footer.link?.onClick({\n abstractControl: group().controls[fieldName],\n formField: field,\n })\n \"\n [auxiliary]=\"true\"\n ></s-button>\n </div>\n }\n }\n @if (field.bottomTemplate) {\n <ng-template [ngTemplateOutlet]=\"field.bottomTemplate\"></ng-template>\n }\n </div>\n }\n } @else {\n @let gridClass = fieldGridClass(field);\n <div [ngClass]=\"gridClass\">\n <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n </div>\n }\n }\n </div>\n }\n</div>\n\n" }]
|
|
40
49
|
}] });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-components/dynamic-form/src/lib/dynamic-form/components/grid/row/row.component.ts","../../../../../../../projects/angular-components/dynamic-form/src/lib/dynamic-form/components/grid/row/row.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACzD,OAAO,EAAa,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAEhE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AAC5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,mDAAmD,CAAC;AAOxF,OAAO,EAAE,oBAAoB,EAAiB,MAAM,6CAA6C,CAAC;AAClG,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,MAAM,+CAA+C,CAAC;AAE1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;;;;AASnF,MAAM,OAAO,YAAY;IACrB,EAAE,GAAG,KAAK,EAAU,CAAC;IACrB,MAAM,GAAG,KAAK,CAAC,QAAQ,EAAa,CAAC;IAErC,KAAK,GAAG,KAAK,CAAC,QAAQ,EAAa,CAAC;IACpC,aAAa,GAAG,KAAK,EAAO,CAAC;IAEV,SAAS,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;IAEnD,gBAAgB,CAAC,aAAkB;QACzC,IAAI,aAAa;YAAE,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC;QAC3F,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAChC,CAAC;IAES,UAAU,CAAC,KAAU;QAC3B,OAAO,KAAK,YAAY,QAAQ,CAAC;IACrC,CAAC;IAES,0BAA0B,CAChC,KAAmE;QAEnE,OAAO,CAAC,oBAAoB,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAqB,CAAC,CAAC;IACvE,CAAC;IAES,cAAc,CAAC,KAAc;QACnC,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAClD,OAAO,SAAS,CAAC,YAAY,EAAE,CAAC;IACpC,CAAC;wGA3BQ,YAAY;4FAAZ,YAAY,6jBCzBzB,o+HA+EA,2CDxDc,mBAAmB,wKAAE,mBAAmB,4UAAE,OAAO,oFAAE,eAAe,sTAAE,oBAAoB;;4FAEzF,YAAY;kBANxB,SAAS;+BAEI,OAAO,cACL,IAAI,WACP,CAAC,mBAAmB,EAAE,mBAAmB,EAAE,OAAO,EAAE,eAAe,EAAE,oBAAoB,CAAC","sourcesContent":["import { Component, inject, input } from '@angular/core';\nimport { FormGroup, ReactiveFormsModule } from '@angular/forms';\n\nimport { NgClass } from '@angular/common';\nimport { ButtonComponent } from '@seniorsistemas/angular-components/button';\nimport { ControlErrorsModule } from '@seniorsistemas/angular-components/control-errors';\nimport {\n    ExpandedDynamicStructure,\n    ExpandedDynamicType,\n    RowConfig,\n    RowType,\n} from '../../../configurations/structure/row';\nimport { STRUCTURE_TYPES_LIST, StructureType } from '../../../configurations/structure/structure';\nimport { DynamicFormDirective } from '../../../dynamic-form.directive';\nimport { FieldSize } from '../../../form-field/configurations/field-size';\nimport { DynamicType } from '../../../form-field/configurations/fields/field';\nimport { FormFieldUtilsService } from '../../../services/form-field-utils.service';\nimport { BaseStructureComponentConfig } from '../../structure/base-structure-component';\n\n@Component({\n    templateUrl: './row.component.html',\n    selector: 's-row',\n    standalone: true,\n    imports: [ControlErrorsModule, ReactiveFormsModule, NgClass, ButtonComponent, DynamicFormDirective],\n})\nexport class RowComponent implements BaseStructureComponentConfig {\n    id = input<string>();\n    config = input.required<RowConfig>();\n\n    group = input.required<FormGroup>();\n    errorMessages = input<any>();\n\n    protected readonly formUtils = inject(FormFieldUtilsService);\n\n    protected getErrorMessages(errorMessages: any) {\n        if (errorMessages) return this.isFunction(errorMessages) ? errorMessages() : errorMessages;\n        return this.errorMessages();\n    }\n\n    protected isFunction(value: any): boolean {\n        return value instanceof Function;\n    }\n\n    protected fieldIsExpandedDynamicType(\n        field: ExpandedDynamicType | ExpandedDynamicStructure | DynamicType,\n    ): field is ExpandedDynamicType {\n        return !STRUCTURE_TYPES_LIST.includes(field.type as StructureType);\n    }\n\n    protected fieldGridClass(field: RowType) {\n        const fieldSize = new FieldSize(field.size ?? {});\n        return fieldSize.getGridClass();\n    }\n}\n\n","<div\n    class=\"w-full\"\n    [formGroup]=\"group()\"\n>\n    @let rowConfig = config();\n    @let rowIsVisible = formUtils.getFieldProperty(rowConfig.visible, true);\n    @if (rowIsVisible) {\n        <div class=\"grid w-screen max-w-full grid-cols-12 gap-4\">\n            @for (field of config().fields; let i = $index; track i) {\n                @if (fieldIsExpandedDynamicType(field)) {\n                    @let fieldVisible = formUtils.getFieldProperty(field.visible, true);\n                    @if (fieldVisible) {\n                        <div\n                            class=\"p-1\"\n                            [ngClass]=\"fieldGridClass(field)\"\n                        >\n                            <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n\n                            @if (field.name) {\n                                <s-control-errors\n                                    [form]=\"group\"\n                                    [control]=\"group().controls[field.name]\"\n                                    [errorMessages]=\"getErrorMessages(field.errorMessages)\"\n                                ></s-control-errors>\n                            }\n\n                            @if (field.footer) {\n                                @if (field.footer.help) {\n                                    @let footerHelpVisible =\n                                        field.footer.help.visible?.({\n                                            abstractControl: group().controls[field.name],\n                                            formField: field,\n                                        });\n                                    @if (field.name && field.footer.help.visible ? footerHelpVisible : true) {\n                                        <span style=\"color: #888b99\">\n                                            {{ field.footer.help.text }}\n                                        </span>\n                                    }\n                                }\n                            }\n\n                            @if (field.footer) {\n                                @let footerLinkVisible =\n                                    field.footer.link?.visible?.({\n                                        abstractControl: group().controls[field.name],\n                                        formField: field,\n                                    });\n                                @if (field.name && field.footer.link?.visible ? footerLinkVisible : true) {\n                                    <div style=\"margin-left: -17px\">\n                                        <s-button\n                                            [label]=\"field.footer.link?.label\"\n                                            priority=\"link\"\n                                            (clicked)=\"\n                                                field.footer.link?.onClick({\n                                                    abstractControl: group().controls[field.name],\n                                                    formField: field,\n                                                })\n                                            \"\n                                            [auxiliary]=\"true\"\n                                        ></s-button>\n                                    </div>\n                                }\n                            }\n                            @if (field.bottomTemplate) {\n                                <ng-template [ngTemplateOutlet]=\"field.bottomTemplate\"></ng-template>\n                            }\n                        </div>\n                    }\n                } @else {\n                    @let gridClass = fieldGridClass(field);\n                    <div [ngClass]=\"gridClass\">\n                        <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n                    </div>\n                }\n            }\n        </div>\n    }\n</div>\n\n"]}
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-components/dynamic-form/src/lib/dynamic-form/components/grid/row/row.component.ts","../../../../../../../projects/angular-components/dynamic-form/src/lib/dynamic-form/components/grid/row/row.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACzD,OAAO,EAAa,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAEhE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AAC5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,mDAAmD,CAAC;AAOxF,OAAO,EAAE,oBAAoB,EAAiB,MAAM,6CAA6C,CAAC;AAClG,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,MAAM,+CAA+C,CAAC;AAE1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;;;;AASnF,MAAM,OAAO,YAAY;IACrB,EAAE,GAAG,KAAK,EAAU,CAAC;IACrB,MAAM,GAAG,KAAK,CAAC,QAAQ,EAAa,CAAC;IAErC,KAAK,GAAG,KAAK,CAAC,QAAQ,EAAa,CAAC;IACpC,aAAa,GAAG,KAAK,EAAO,CAAC;IAEV,SAAS,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;IAEnD,gBAAgB,CAAC,aAAkB;QACzC,IAAI,aAAa;YAAE,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC;QAC3F,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAChC,CAAC;IAES,UAAU,CAAC,KAAU;QAC3B,OAAO,KAAK,YAAY,QAAQ,CAAC;IACrC,CAAC;IAES,0BAA0B,CAChC,KAAmE;QAEnE,OAAO,CAAC,oBAAoB,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAqB,CAAC,CAAC;IACvE,CAAC;IAES,cAAc,CAAC,KAAc;QACnC,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAClD,OAAO,SAAS,CAAC,YAAY,EAAE,CAAC;IACpC,CAAC;IAES,OAAO,CAAC,KAAc;QAC5B,IAAI,YAAY,IAAI,KAAK,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;YAC5C,OAAO,KAAK,CAAC,UAAoB,CAAC;QACtC,CAAC;aAAM,IAAI,MAAM,IAAI,KAAK,EAAE,CAAC;YACzB,OAAO,KAAK,CAAC,IAAI,CAAC;QACtB,CAAC;QAED,OAAO,EAAE,CAAC;IACd,CAAC;wGArCQ,YAAY;4FAAZ,YAAY,6jBCzBzB,+gIAgFA,2CDzDc,mBAAmB,wKAAE,mBAAmB,4UAAE,OAAO,oFAAE,eAAe,sTAAE,oBAAoB;;4FAEzF,YAAY;kBANxB,SAAS;+BAEI,OAAO,cACL,IAAI,WACP,CAAC,mBAAmB,EAAE,mBAAmB,EAAE,OAAO,EAAE,eAAe,EAAE,oBAAoB,CAAC","sourcesContent":["import { Component, inject, input } from '@angular/core';\nimport { FormGroup, ReactiveFormsModule } from '@angular/forms';\n\nimport { NgClass } from '@angular/common';\nimport { ButtonComponent } from '@seniorsistemas/angular-components/button';\nimport { ControlErrorsModule } from '@seniorsistemas/angular-components/control-errors';\nimport {\n    ExpandedDynamicStructure,\n    ExpandedDynamicType,\n    RowConfig,\n    RowType,\n} from '../../../configurations/structure/row';\nimport { STRUCTURE_TYPES_LIST, StructureType } from '../../../configurations/structure/structure';\nimport { DynamicFormDirective } from '../../../dynamic-form.directive';\nimport { FieldSize } from '../../../form-field/configurations/field-size';\nimport { DynamicType } from '../../../form-field/configurations/fields/field';\nimport { FormFieldUtilsService } from '../../../services/form-field-utils.service';\nimport { BaseStructureComponentConfig } from '../../structure/base-structure-component';\n\n@Component({\n    templateUrl: './row.component.html',\n    selector: 's-row',\n    standalone: true,\n    imports: [ControlErrorsModule, ReactiveFormsModule, NgClass, ButtonComponent, DynamicFormDirective],\n})\nexport class RowComponent implements BaseStructureComponentConfig {\n    id = input<string>();\n    config = input.required<RowConfig>();\n\n    group = input.required<FormGroup>();\n    errorMessages = input<any>();\n\n    protected readonly formUtils = inject(FormFieldUtilsService);\n\n    protected getErrorMessages(errorMessages: any) {\n        if (errorMessages) return this.isFunction(errorMessages) ? errorMessages() : errorMessages;\n        return this.errorMessages();\n    }\n\n    protected isFunction(value: any): boolean {\n        return value instanceof Function;\n    }\n\n    protected fieldIsExpandedDynamicType(\n        field: ExpandedDynamicType | ExpandedDynamicStructure | DynamicType,\n    ): field is ExpandedDynamicType {\n        return !STRUCTURE_TYPES_LIST.includes(field.type as StructureType);\n    }\n\n    protected fieldGridClass(field: RowType) {\n        const fieldSize = new FieldSize(field.size ?? {});\n        return fieldSize.getGridClass();\n    }\n\n    protected getName(field: RowType) {\n        if ('customName' in field && field.customName) {\n            return field.customName as string;\n        } else if ('name' in field) {\n            return field.name;\n        }\n\n        return '';\n    }\n}\n\n","<div\n    class=\"w-full\"\n    [formGroup]=\"group()\"\n>\n    @let rowConfig = config();\n    @let rowIsVisible = formUtils.getFieldProperty(rowConfig.visible, true);\n    @if (rowIsVisible) {\n        <div class=\"grid w-screen max-w-full grid-cols-12 gap-4\">\n            @for (field of config().fields; let i = $index; track i) {\n                @let fieldName = getName(field);\n                @if (fieldIsExpandedDynamicType(field)) {\n                    @let fieldVisible = formUtils.getFieldProperty(field.visible, true);\n                    @if (fieldVisible) {\n                        <div\n                            class=\"p-1\"\n                            [ngClass]=\"fieldGridClass(field)\"\n                        >\n                            <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n\n                            @if (fieldName) {\n                                <s-control-errors\n                                    [form]=\"group\"\n                                    [control]=\"group().controls[fieldName]\"\n                                    [errorMessages]=\"getErrorMessages(field.errorMessages)\"\n                                ></s-control-errors>\n                            }\n\n                            @if (field.footer) {\n                                @if (field.footer.help) {\n                                    @let footerHelpVisible =\n                                        field.footer.help.visible?.({\n                                            abstractControl: group().controls[fieldName],\n                                            formField: field,\n                                        });\n                                    @if (fieldName && field.footer.help.visible ? footerHelpVisible : true) {\n                                        <span style=\"color: #888b99\">\n                                            {{ field.footer.help.text }}\n                                        </span>\n                                    }\n                                }\n                            }\n\n                            @if (field.footer) {\n                                @let footerLinkVisible =\n                                    field.footer.link?.visible?.({\n                                        abstractControl: group().controls[fieldName],\n                                        formField: field,\n                                    });\n                                @if (fieldName && field.footer.link?.visible ? footerLinkVisible : true) {\n                                    <div style=\"margin-left: -17px\">\n                                        <s-button\n                                            [label]=\"field.footer.link?.label\"\n                                            priority=\"link\"\n                                            (clicked)=\"\n                                                field.footer.link?.onClick({\n                                                    abstractControl: group().controls[fieldName],\n                                                    formField: field,\n                                                })\n                                            \"\n                                            [auxiliary]=\"true\"\n                                        ></s-button>\n                                    </div>\n                                }\n                            }\n                            @if (field.bottomTemplate) {\n                                <ng-template [ngTemplateOutlet]=\"field.bottomTemplate\"></ng-template>\n                            }\n                        </div>\n                    }\n                } @else {\n                    @let gridClass = fieldGridClass(field);\n                    <div [ngClass]=\"gridClass\">\n                        <ng-container *sDynamicForm=\"{ id: id(), config: field, group: group() }\"></ng-container>\n                    </div>\n                }\n            }\n        </div>\n    }\n</div>\n\n"]}
|