ets-fe-ng-sdk 17.0.396 → 17.0.398

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.
@@ -75,7 +75,7 @@ export class FieldsToDisplayComponent {
75
75
  e ? (item.type = 'number') : null;
76
76
  }
77
77
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: FieldsToDisplayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
78
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: FieldsToDisplayComponent, isStandalone: true, selector: "fields-to-display", inputs: { query1: { classPropertyName: "query1", publicName: "query1", isSignal: true, isRequired: false, transformFunction: null }, query2: { classPropertyName: "query2", publicName: "query2", isSignal: true, isRequired: false, transformFunction: null }, _fields: { classPropertyName: "_fields", publicName: "fields", isSignal: false, isRequired: false, transformFunction: null }, _currentColumns: { classPropertyName: "_currentColumns", publicName: "currentColumns", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { query1: "query1Change", query2: "query2Change", fieldsChanged: "fieldsChanged" }, providers: [FilterArrayByStringPipe], ngImport: i0, template: "<app-btn\n type=\"outline\"\n customIcon=\"fa fa-bars\"\n iconPosition=\"right\"\n text=\"Define Outputs\"\n (mclick)=\"acModal.open()\" />\n<modal-comp\n header=\"Arrange Columns\"\n [width]=\"{ XLarge: '70%', Large: '80%' } | responsiveVal\"\n height=\"80vh\"\n #acModal>\n <div *modalBody>\n @if (uS.isMobileSignal()) {\n <div class=\"mb-2\">\n <app-input-td-rf [noFormat]=\"true\" [(model)]=\"query1\" placeholder=\"Filter\" />\n </div>\n <div class=\"border rounded-10\">\n <table class=\"table\">\n <thead>\n <tr>\n <th>{{ 'Column' | appTranslate | async }}</th>\n <th>{{ 'Visible' | appTranslate | async }}</th>\n <th>{{ 'Sticky' | appTranslate | async }}</th>\n </tr>\n </thead>\n <tbody>\n @for (item of filteredAllFields(); track item) {\n <tr>\n <td scope=\"row\">\n {{ item.t | titlecase | appTranslate | async }}\n </td>\n <td>\n <mat-slide-toggle [(ngModel)]=\"item.active\"></mat-slide-toggle>\n </td>\n <td>\n @if (item.active) {\n <mat-slide-toggle [(ngModel)]=\"item.sticky\"></mat-slide-toggle>\n }\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n } @else {\n <!-- <div>query2 {{ query2() }}</div>\n <div class=\"\">\n searchRef.valueSignal {{ searchRef.valueSignal() }}\n </div> -->\n <div class=\"row row-cols-2\">\n <div>\n <div class=\"text-primary f-600 mb-2\">\n {{ 'Non-Selected Columns' | appTranslate | async }}\n </div>\n <!-- <div class=\"mb-2\">\n <app-input-td-rf [(model)]=\"query\" placeholder=\"Filter\" />\n </div> -->\n <div class=\"border rounded-10 p-2 bg-light cage overflow-auto\">\n <div class=\"row my-2 mx-0 justify-content-center\">\n <div class=\"col-sm-10\">\n <app-input-td-rf\n #searchRef\n [noFormat]=\"true\"\n [(model)]=\"query2\"\n placeholder=\"Search by name\"/>\n </div>\n </div>\n <div\n class=\"row row-cols-1 g-2\"\n cdkDropList\n #sourceList=\"cdkDropList\"\n [cdkDropListData]=\"nonActiveFields()\"\n cdkDropListSortingDisabled\n [cdkDropListConnectedTo]=\"[destinationList]\"\n (cdkDropListDropped)=\"drop($event)\">\n @for (item of nonActiveFields(); track item.f; let i = $index) {\n <div class=\"\" cdkDrag>\n <div class=\"example-custom-placeholder\" *cdkDragPlaceholder></div>\n <div class=\"border p-2 rounded-10 bg-white\">\n <div class=\"row row-cols-auto justify-content-between\">\n <div class=\"d-flex align-items-center\">\n <i\n cdkDragHandle\n matTooltip=\"Drag the icon to move the column to the selected columns group\"\n class=\"drag-cursor material-icons\">\n drag_handle\n </i>\n {{ item.t | titlecase | appTranslate | async }}\n </div>\n <div class=\"col-md-auto\">\n <div class=\"row\">\n <div class=\"col-md-auto\" *ngIf=\"!uS.environment.production\">\n {{ item.type }}\n </div>\n <!-- <div class=\"col-md-auto\">\n <app-input-td-rf [xsmall]=\"true\" [label]=\"'Is Number?'\"\n [stacked]=\"false\" type=\"checkbox\"\n (modelChange)=\"isNumType($event, item)\" />\n </div> -->\n <div class=\"col-md-auto\">\n <app-btn text=\"Select\" (mclick)=\"changeToActive(item)\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n <div>\n <div class=\"text-primary f-600 mb-2\">\n {{ 'Selected Columns' | appTranslate | async }}\n </div>\n <div class=\"border rounded-10 p-2 bg-light cage overflow-auto\">\n <div\n class=\"row row-cols-1 g-2\"\n cdkDropList\n #destinationList=\"cdkDropList\"\n [cdkDropListData]=\"activeFields()\"\n [cdkDropListConnectedTo]=\"[sourceList]\"\n (cdkDropListDropped)=\"drop($event)\">\n @for (item of activeFields(); track item.f; let i = $index) {\n <div class=\"\" cdkDrag>\n <div class=\"example-custom-placeholder\" *cdkDragPlaceholder></div>\n <div class=\"border p-2 rounded-10 bg-white\">\n <div class=\"row row-cols-auto justify-content-between\">\n <div class=\"d-flex align-items-center\">\n <i\n cdkDragHandle\n matTooltip=\"Drag the icon to move the column to the non-selected columns group or re-order\"\n class=\"drag-cursor material-icons\">\n drag_handle\n </i>\n {{ item.t | titlecase | appTranslate | async }}\n </div>\n <div>\n <mat-slide-toggle *ngIf=\"item.active\" [(ngModel)]=\"item.sticky\">\n {{ 'Sticky' | appTranslate | async }}\n </mat-slide-toggle>\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n <div class=\"w-100 pt-2 d-flex justify-content-end\" *modalFooter>\n <app-btn text=\"Update Columns\" (mclick)=\"emitFieldsChanged(); acModal.close()\" />\n </div>\n</modal-comp>\n", styles: [".example-custom-placeholder{background:#ccc;border:dotted 3px #999;border-radius:var(--border-radius);min-height:42px;transition:transform .25s cubic-bezier(0,0,.2,1)}.cage{height:calc(80vh - 215px)}\n"], dependencies: [{ kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: InputTD_RFComponent, selector: "app-input-td-rf", inputs: ["validators", "asyncValidators", "model"], outputs: ["modelChange"] }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: i1.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: CdkDragPlaceholder, selector: "ng-template[cdkDragPlaceholder]", inputs: ["data"] }, { kind: "directive", type: CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: TitleCasePipe, name: "titlecase" }, { kind: "component", type: i4.ModalComponent, selector: "modal-comp", inputs: ["header", "bodyTemplateRef", "footerTemplateRef", "showHeader", "loading", "isFullscreen", "showFooter", "width", "minWidth", "height", "maxHeight", "icon", "data", "disableClose", "hasBackdrop"], outputs: ["showHeaderChange", "loadingChange", "showFooterChange", "modalOpen", "modalClose"] }, { kind: "directive", type: i5.ModalBodyDirective, selector: "[modalBody]" }, { kind: "directive", type: i6.ModalFooterDirective, selector: "[modalFooter]" }, { kind: "pipe", type: ResponsiveValPipe, name: "responsiveVal" }, { kind: "pipe", type: TranslatePipe, name: "appTranslate" }] }); }
78
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: FieldsToDisplayComponent, isStandalone: true, selector: "fields-to-display", inputs: { query1: { classPropertyName: "query1", publicName: "query1", isSignal: true, isRequired: false, transformFunction: null }, query2: { classPropertyName: "query2", publicName: "query2", isSignal: true, isRequired: false, transformFunction: null }, _fields: { classPropertyName: "_fields", publicName: "fields", isSignal: false, isRequired: false, transformFunction: null }, _currentColumns: { classPropertyName: "_currentColumns", publicName: "currentColumns", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { query1: "query1Change", query2: "query2Change", fieldsChanged: "fieldsChanged" }, providers: [FilterArrayByStringPipe], ngImport: i0, template: "<app-btn\n type=\"outline\"\n customIcon=\"fa fa-bars\"\n iconPosition=\"right\"\n text=\"Define Outputs\"\n (mclick)=\"acModal.open()\" />\n<modal-comp\n header=\"Arrange Columns\"\n [width]=\"{ XLarge: '70%', Large: '80%' } | responsiveVal\"\n height=\"80vh\"\n #acModal>\n <div *modalBody>\n @if (uS.isMobileSignal()) {\n <div class=\"mb-2\">\n <app-input-td-rf [noFormat]=\"true\" [(model)]=\"query1\" placeholder=\"Filter\" />\n </div>\n <div class=\"border rounded-10\">\n <table class=\"table\">\n <thead>\n <tr>\n <th>{{ 'Column' | appTranslate | async }}</th>\n <th>{{ 'Visible' | appTranslate | async }}</th>\n <th>{{ 'Sticky' | appTranslate | async }}</th>\n </tr>\n </thead>\n <tbody>\n @for (item of filteredAllFields(); track item) {\n <tr>\n <td scope=\"row\">\n {{ item.t | titlecase | appTranslate | async }}\n </td>\n <td>\n <mat-slide-toggle [(ngModel)]=\"item.active\"></mat-slide-toggle>\n </td>\n <td>\n @if (item.active) {\n <mat-slide-toggle [(ngModel)]=\"item.sticky\"></mat-slide-toggle>\n }\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n } @else {\n <!-- <div>query2 {{ query2() }}</div>\n <div class=\"\">\n searchRef.valueSignal {{ searchRef.valueSignal() }}\n </div> -->\n <div class=\"row row-cols-2\">\n <div>\n <div class=\"text-primary f-600 mb-2\">\n {{ 'Non-Selected Columns' | appTranslate | async }}\n </div>\n <!-- <div class=\"mb-2\">\n <app-input-td-rf [(model)]=\"query\" placeholder=\"Filter\" />\n </div> -->\n <div class=\"border rounded-10 p-2 bg-light cage overflow-auto\">\n <div class=\"row my-2 mx-0 justify-content-center\">\n <div class=\"col-sm-10\">\n <app-input-td-rf\n #searchRef\n [noFormat]=\"true\"\n [(model)]=\"query2\"\n placeholder=\"Search by name\"/>\n </div>\n </div>\n <div\n class=\"row row-cols-1 g-2\"\n cdkDropList\n #sourceList=\"cdkDropList\"\n [cdkDropListData]=\"nonActiveFields()\"\n cdkDropListSortingDisabled\n [cdkDropListConnectedTo]=\"[destinationList]\"\n (cdkDropListDropped)=\"drop($event)\">\n @for (item of nonActiveFields(); track item.f; let i = $index) {\n <div class=\"\" cdkDrag>\n <div class=\"example-custom-placeholder\" *cdkDragPlaceholder></div>\n <div class=\"border p-2 rounded-10 bg-white\">\n <div class=\"row row-cols-auto justify-content-between\">\n <div class=\"d-flex align-items-center\">\n <i\n cdkDragHandle\n matTooltip=\"Drag the icon to move the column to the selected columns group\"\n class=\"drag-cursor material-icons\">\n drag_handle\n </i>\n {{ item.t | titlecase | appTranslate | async }}\n </div>\n <div class=\"col-md-auto\">\n <div class=\"row\">\n <div class=\"col-md-auto\" *ngIf=\"!uS.environment.production\">\n {{ item.type }}\n </div>\n <!-- <div class=\"col-md-auto\">\n <app-input-td-rf [xsmall]=\"true\" [label]=\"'Is Number?'\"\n [stacked]=\"false\" type=\"checkbox\"\n (modelChange)=\"isNumType($event, item)\" />\n </div> -->\n <div class=\"col-md-auto\">\n <app-btn text=\"Select\" (mclick)=\"changeToActive(item)\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n <div>\n <div class=\"text-primary f-600 mb-2\">\n {{ 'Selected Columns' | appTranslate | async }}\n </div>\n <div class=\"border rounded-10 p-2 bg-light cage overflow-auto\">\n <div\n class=\"row row-cols-1 g-2\"\n cdkDropList\n #destinationList=\"cdkDropList\"\n [cdkDropListData]=\"activeFields()\"\n [cdkDropListConnectedTo]=\"[sourceList]\"\n (cdkDropListDropped)=\"drop($event)\">\n @for (item of activeFields(); track item.f; let i = $index) {\n <div class=\"\" cdkDrag>\n <div class=\"example-custom-placeholder\" *cdkDragPlaceholder></div>\n <div class=\"border p-2 rounded-10 bg-white\">\n <div class=\"row row-cols-auto justify-content-between\">\n <div class=\"d-flex align-items-center\">\n <i\n cdkDragHandle\n matTooltip=\"Drag the icon to move the column to the non-selected columns group or re-order\"\n class=\"drag-cursor material-icons\">\n drag_handle\n </i>\n {{ item.t | titlecase | appTranslate | async }}\n </div>\n <div>\n <mat-slide-toggle *ngIf=\"item.active\" [(ngModel)]=\"item.sticky\">\n {{ 'Sticky' | appTranslate | async }}\n </mat-slide-toggle>\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n <div class=\"w-100 pt-2 d-flex justify-content-end\" *modalFooter>\n <app-btn text=\"Update Columns\" (mclick)=\"emitFieldsChanged(); acModal.close()\" />\n </div>\n</modal-comp>\n", styles: [".example-custom-placeholder{background:#ccc;border:dotted 3px #999;border-radius:var(--border-radius);min-height:42px;transition:transform .25s cubic-bezier(0,0,.2,1)}.cage{height:calc(80vh - 215px)}\n"], dependencies: [{ kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: InputTD_RFComponent, selector: "app-input-td-rf", inputs: ["validators", "asyncValidators", "model"], outputs: ["modelChange"] }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: i1.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: CdkDragPlaceholder, selector: "ng-template[cdkDragPlaceholder]", inputs: ["data"] }, { kind: "directive", type: CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: TitleCasePipe, name: "titlecase" }, { kind: "component", type: i4.ModalComponent, selector: "modal-comp", inputs: ["header", "bodyTemplateRef", "footerTemplateRef", "showHeader", "loading", "isFullscreen", "showFooter", "width", "minWidth", "height", "maxHeight", "icon", "data", "disableClose", "hasBackdrop"], outputs: ["headerChange", "showHeaderChange", "loadingChange", "showFooterChange", "modalOpen", "modalClose"] }, { kind: "directive", type: i5.ModalBodyDirective, selector: "[modalBody]" }, { kind: "directive", type: i6.ModalFooterDirective, selector: "[modalFooter]" }, { kind: "pipe", type: ResponsiveValPipe, name: "responsiveVal" }, { kind: "pipe", type: TranslatePipe, name: "appTranslate" }] }); }
79
79
  }
80
80
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: FieldsToDisplayComponent, decorators: [{
81
81
  type: Component,
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
107
107
  }], fieldsChanged: [{
108
108
  type: Output
109
109
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields-to-display.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/fields-to-display/fields-to-display.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/fields-to-display/fields-to-display.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  CdkDragDrop,\n  moveItemInArray,\n  transferArrayItem,\n  CdkDropList,\n  CdkDrag,\n  CdkDragPlaceholder,\n  CdkDragHandle,\n} from '@angular/cdk/drag-drop';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  computed,\n  inject,\n  model,\n  signal,\n} from '@angular/core';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { cloneDeep, uniqBy } from 'lodash-es';\nimport { FilterArrayByStringPipe, ResponsiveValPipe } from '../../pipes/utility.pipe';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { FormsModule } from '@angular/forms';\nimport { InputTD_RFComponent } from '../input/input-td-rf.component';\nimport { NgIf, NgFor, AsyncPipe, TitleCasePipe } from '@angular/common';\nimport { ModalComponents } from '../modal-components/modal.components';\nimport { BtnComponent } from '../btn/btn.component';\nimport { TableCol } from '../../models/index.model';\nimport { UtilityService } from '../../../Services/utility.service';\n\n@Component({\n  selector: 'fields-to-display',\n  templateUrl: './fields-to-display.component.html',\n  styleUrls: ['./fields-to-display.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    BtnComponent,\n    NgIf,\n    InputTD_RFComponent,\n    NgFor,\n    MatSlideToggleModule,\n    FormsModule,\n    CdkDropList,\n    CdkDrag,\n    CdkDragPlaceholder,\n    CdkDragHandle,\n    MatTooltipModule,\n    AsyncPipe,\n    TitleCasePipe,\n    FilterArrayByStringPipe,\n    ModalComponents,\n    ResponsiveValPipe,\n    TranslatePipe,\n  ],\n  providers: [FilterArrayByStringPipe],\n})\nexport class FieldsToDisplayComponent {\n  readonly query1 = model<string | undefined>(undefined);\n  readonly query2 = model<string | undefined>(undefined);\n\n  @Input('fields') set _fields(v: TableCol[]) {\n    this.allFields.set(\n      cloneDeep(v).map((x) => {\n        x['id'] = x.f?.toString();\n        return x;\n      }) || [],\n    );\n  }\n\n  @Input('currentColumns') set _currentColumns(v: TableCol[]) {\n    this.allFields.update((allFields) =>\n      uniqBy(\n        (\n          v.map((x) => {\n            x.active = true;\n            return x;\n          }) || []\n        ).concat(allFields),\n        'f',\n      ),\n    );\n  }\n\n  readonly allFields = signal<TableCol[]>([]);\n\n  readonly filteredAllFields = computed<TableCol[]>(() =>\n    this.filterArrayByStringPipe.transform(this.allFields(), this.query1()!, ['f', 't']),\n  );\n\n  readonly activeFields = computed<TableCol[]>(() => this.allFields().filter((x) => x.active));\n  // activeFields = signal<TableCol[]>([]);\n\n  readonly nonActiveFields = computed<TableCol[]>(() =>\n    this.filterArrayByStringPipe\n      .transform(\n        this.allFields().filter((x) => !x.active),\n        this.query2()!,\n        ['f', 't'],\n      )\n      .sort2('t', true),\n  );\n\n  @Output() fieldsChanged = new EventEmitter<{\n    nFields: TableCol[];\n    allFields: TableCol[];\n  }>();\n\n  public filterArrayByStringPipe = inject(FilterArrayByStringPipe);\n  public uS = inject(UtilityService);\n  constructor() {}\n\n  drop(event: CdkDragDrop<TableCol[]>) {\n    if (event.previousContainer === event.container) {\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\n    } else {\n      // debugger;\n      const item = event.previousContainer.data[event.previousIndex];\n      item.active = !item.active;\n      if (!item.active) item.sticky = false;\n      transferArrayItem(\n        event.previousContainer.data,\n        event.container.data,\n        event.previousIndex,\n        event.currentIndex,\n      );\n    }\n  }\n\n  changeToActive(nonActiveObj: TableCol) {\n    this.allFields.update((allFields) =>\n      allFields.map((x) => {\n        if (nonActiveObj.f == x.f) x.active = true;\n        return x;\n      }),\n    );\n  }\n\n  emitFieldsChanged() {\n    this.fieldsChanged.emit({\n      nFields: this.uS.isMobile ? this.allFields().filter((x) => x.active) : this.activeFields(),\n      allFields: this.allFields(),\n    });\n  }\n\n  isNumType(e: any, item: TableCol) {\n    e ? (item.type = 'number') : null;\n  }\n}\n","<app-btn\n  type=\"outline\"\n  customIcon=\"fa fa-bars\"\n  iconPosition=\"right\"\n  text=\"Define Outputs\"\n  (mclick)=\"acModal.open()\" />\n<modal-comp\n  header=\"Arrange Columns\"\n  [width]=\"{ XLarge: '70%', Large: '80%' } | responsiveVal\"\n  height=\"80vh\"\n  #acModal>\n  <div *modalBody>\n    @if (uS.isMobileSignal()) {\n      <div class=\"mb-2\">\n        <app-input-td-rf [noFormat]=\"true\" [(model)]=\"query1\" placeholder=\"Filter\" />\n      </div>\n      <div class=\"border rounded-10\">\n        <table class=\"table\">\n          <thead>\n            <tr>\n              <th>{{ 'Column' | appTranslate | async }}</th>\n              <th>{{ 'Visible' | appTranslate | async }}</th>\n              <th>{{ 'Sticky' | appTranslate | async }}</th>\n            </tr>\n          </thead>\n          <tbody>\n            @for (item of filteredAllFields(); track item) {\n              <tr>\n                <td scope=\"row\">\n                  {{ item.t | titlecase | appTranslate | async }}\n                </td>\n                <td>\n                  <mat-slide-toggle [(ngModel)]=\"item.active\"></mat-slide-toggle>\n                </td>\n                <td>\n                  @if (item.active) {\n                    <mat-slide-toggle [(ngModel)]=\"item.sticky\"></mat-slide-toggle>\n                  }\n                </td>\n              </tr>\n            }\n          </tbody>\n        </table>\n      </div>\n    } @else {\n      <!-- <div>query2 {{ query2() }}</div>\n      <div class=\"\">\n        searchRef.valueSignal    {{ searchRef.valueSignal() }}\n      </div> -->\n      <div class=\"row row-cols-2\">\n        <div>\n          <div class=\"text-primary f-600 mb-2\">\n            {{ 'Non-Selected Columns' | appTranslate | async }}\n          </div>\n          <!-- <div class=\"mb-2\">\n                        <app-input-td-rf [(model)]=\"query\" placeholder=\"Filter\" />\n                    </div> -->\n          <div class=\"border rounded-10 p-2 bg-light cage overflow-auto\">\n            <div class=\"row my-2 mx-0 justify-content-center\">\n              <div class=\"col-sm-10\">\n                <app-input-td-rf\n                  #searchRef\n                  [noFormat]=\"true\"\n                  [(model)]=\"query2\"\n                  placeholder=\"Search by name\"/>\n              </div>\n            </div>\n            <div\n              class=\"row row-cols-1 g-2\"\n              cdkDropList\n              #sourceList=\"cdkDropList\"\n              [cdkDropListData]=\"nonActiveFields()\"\n              cdkDropListSortingDisabled\n              [cdkDropListConnectedTo]=\"[destinationList]\"\n              (cdkDropListDropped)=\"drop($event)\">\n              @for (item of nonActiveFields(); track item.f; let i = $index) {\n                <div class=\"\" cdkDrag>\n                  <div class=\"example-custom-placeholder\" *cdkDragPlaceholder></div>\n                  <div class=\"border p-2 rounded-10 bg-white\">\n                    <div class=\"row row-cols-auto justify-content-between\">\n                      <div class=\"d-flex align-items-center\">\n                        <i\n                          cdkDragHandle\n                          matTooltip=\"Drag the icon to move the column to the selected columns group\"\n                          class=\"drag-cursor material-icons\">\n                          drag_handle\n                        </i>\n                        {{ item.t | titlecase | appTranslate | async }}\n                      </div>\n                      <div class=\"col-md-auto\">\n                        <div class=\"row\">\n                          <div class=\"col-md-auto\" *ngIf=\"!uS.environment.production\">\n                            {{ item.type }}\n                          </div>\n                          <!-- <div class=\"col-md-auto\">\n                                                    <app-input-td-rf [xsmall]=\"true\" [label]=\"'Is Number?'\"\n                                                        [stacked]=\"false\" type=\"checkbox\"\n                                                        (modelChange)=\"isNumType($event, item)\" />\n                                                </div> -->\n                          <div class=\"col-md-auto\">\n                            <app-btn text=\"Select\" (mclick)=\"changeToActive(item)\" />\n                          </div>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              }\n            </div>\n          </div>\n        </div>\n        <div>\n          <div class=\"text-primary f-600 mb-2\">\n            {{ 'Selected Columns' | appTranslate | async }}\n          </div>\n          <div class=\"border rounded-10 p-2 bg-light cage overflow-auto\">\n            <div\n              class=\"row row-cols-1 g-2\"\n              cdkDropList\n              #destinationList=\"cdkDropList\"\n              [cdkDropListData]=\"activeFields()\"\n              [cdkDropListConnectedTo]=\"[sourceList]\"\n              (cdkDropListDropped)=\"drop($event)\">\n              @for (item of activeFields(); track item.f; let i = $index) {\n                <div class=\"\" cdkDrag>\n                  <div class=\"example-custom-placeholder\" *cdkDragPlaceholder></div>\n                  <div class=\"border p-2 rounded-10 bg-white\">\n                    <div class=\"row row-cols-auto justify-content-between\">\n                      <div class=\"d-flex align-items-center\">\n                        <i\n                          cdkDragHandle\n                          matTooltip=\"Drag the icon to move the column to the non-selected columns group or re-order\"\n                          class=\"drag-cursor material-icons\">\n                          drag_handle\n                        </i>\n                        {{ item.t | titlecase | appTranslate | async }}\n                      </div>\n                      <div>\n                        <mat-slide-toggle *ngIf=\"item.active\" [(ngModel)]=\"item.sticky\">\n                          {{ 'Sticky' | appTranslate | async }}\n                        </mat-slide-toggle>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              }\n            </div>\n          </div>\n        </div>\n      </div>\n    }\n  </div>\n  <div class=\"w-100 pt-2 d-flex justify-content-end\" *modalFooter>\n    <app-btn text=\"Update Columns\" (mclick)=\"emitFieldsChanged(); acModal.close()\" />\n  </div>\n</modal-comp>\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields-to-display.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/fields-to-display/fields-to-display.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/fields-to-display/fields-to-display.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  CdkDragDrop,\n  moveItemInArray,\n  transferArrayItem,\n  CdkDropList,\n  CdkDrag,\n  CdkDragPlaceholder,\n  CdkDragHandle,\n} from '@angular/cdk/drag-drop';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  computed,\n  inject,\n  model,\n  signal,\n} from '@angular/core';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { cloneDeep, uniqBy } from 'lodash-es';\nimport { FilterArrayByStringPipe, ResponsiveValPipe } from '../../pipes/utility.pipe';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { FormsModule } from '@angular/forms';\nimport { InputTD_RFComponent } from '../input/input-td-rf.component';\nimport { NgIf, NgFor, AsyncPipe, TitleCasePipe } from '@angular/common';\nimport { ModalComponents } from '../modal-components/modal.components';\nimport { BtnComponent } from '../btn/btn.component';\nimport { TableCol } from '../../models/index.model';\nimport { UtilityService } from '../../../Services/utility.service';\n\n@Component({\n  selector: 'fields-to-display',\n  templateUrl: './fields-to-display.component.html',\n  styleUrls: ['./fields-to-display.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    BtnComponent,\n    NgIf,\n    InputTD_RFComponent,\n    NgFor,\n    MatSlideToggleModule,\n    FormsModule,\n    CdkDropList,\n    CdkDrag,\n    CdkDragPlaceholder,\n    CdkDragHandle,\n    MatTooltipModule,\n    AsyncPipe,\n    TitleCasePipe,\n    FilterArrayByStringPipe,\n    ModalComponents,\n    ResponsiveValPipe,\n    TranslatePipe,\n  ],\n  providers: [FilterArrayByStringPipe],\n})\nexport class FieldsToDisplayComponent {\n  readonly query1 = model<string | undefined>(undefined);\n  readonly query2 = model<string | undefined>(undefined);\n\n  @Input('fields') set _fields(v: TableCol[]) {\n    this.allFields.set(\n      cloneDeep(v).map((x) => {\n        x['id'] = x.f?.toString();\n        return x;\n      }) || [],\n    );\n  }\n\n  @Input('currentColumns') set _currentColumns(v: TableCol[]) {\n    this.allFields.update((allFields) =>\n      uniqBy(\n        (\n          v.map((x) => {\n            x.active = true;\n            return x;\n          }) || []\n        ).concat(allFields),\n        'f',\n      ),\n    );\n  }\n\n  readonly allFields = signal<TableCol[]>([]);\n\n  readonly filteredAllFields = computed<TableCol[]>(() =>\n    this.filterArrayByStringPipe.transform(this.allFields(), this.query1()!, ['f', 't']),\n  );\n\n  readonly activeFields = computed<TableCol[]>(() => this.allFields().filter((x) => x.active));\n  // activeFields = signal<TableCol[]>([]);\n\n  readonly nonActiveFields = computed<TableCol[]>(() =>\n    this.filterArrayByStringPipe\n      .transform(\n        this.allFields().filter((x) => !x.active),\n        this.query2()!,\n        ['f', 't'],\n      )\n      .sort2('t', true),\n  );\n\n  @Output() fieldsChanged = new EventEmitter<{\n    nFields: TableCol[];\n    allFields: TableCol[];\n  }>();\n\n  public filterArrayByStringPipe = inject(FilterArrayByStringPipe);\n  public uS = inject(UtilityService);\n  constructor() {}\n\n  drop(event: CdkDragDrop<TableCol[]>) {\n    if (event.previousContainer === event.container) {\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\n    } else {\n      // debugger;\n      const item = event.previousContainer.data[event.previousIndex];\n      item.active = !item.active;\n      if (!item.active) item.sticky = false;\n      transferArrayItem(\n        event.previousContainer.data,\n        event.container.data,\n        event.previousIndex,\n        event.currentIndex,\n      );\n    }\n  }\n\n  changeToActive(nonActiveObj: TableCol) {\n    this.allFields.update((allFields) =>\n      allFields.map((x) => {\n        if (nonActiveObj.f == x.f) x.active = true;\n        return x;\n      }),\n    );\n  }\n\n  emitFieldsChanged() {\n    this.fieldsChanged.emit({\n      nFields: this.uS.isMobile ? this.allFields().filter((x) => x.active) : this.activeFields(),\n      allFields: this.allFields(),\n    });\n  }\n\n  isNumType(e: any, item: TableCol) {\n    e ? (item.type = 'number') : null;\n  }\n}\n","<app-btn\n  type=\"outline\"\n  customIcon=\"fa fa-bars\"\n  iconPosition=\"right\"\n  text=\"Define Outputs\"\n  (mclick)=\"acModal.open()\" />\n<modal-comp\n  header=\"Arrange Columns\"\n  [width]=\"{ XLarge: '70%', Large: '80%' } | responsiveVal\"\n  height=\"80vh\"\n  #acModal>\n  <div *modalBody>\n    @if (uS.isMobileSignal()) {\n      <div class=\"mb-2\">\n        <app-input-td-rf [noFormat]=\"true\" [(model)]=\"query1\" placeholder=\"Filter\" />\n      </div>\n      <div class=\"border rounded-10\">\n        <table class=\"table\">\n          <thead>\n            <tr>\n              <th>{{ 'Column' | appTranslate | async }}</th>\n              <th>{{ 'Visible' | appTranslate | async }}</th>\n              <th>{{ 'Sticky' | appTranslate | async }}</th>\n            </tr>\n          </thead>\n          <tbody>\n            @for (item of filteredAllFields(); track item) {\n              <tr>\n                <td scope=\"row\">\n                  {{ item.t | titlecase | appTranslate | async }}\n                </td>\n                <td>\n                  <mat-slide-toggle [(ngModel)]=\"item.active\"></mat-slide-toggle>\n                </td>\n                <td>\n                  @if (item.active) {\n                    <mat-slide-toggle [(ngModel)]=\"item.sticky\"></mat-slide-toggle>\n                  }\n                </td>\n              </tr>\n            }\n          </tbody>\n        </table>\n      </div>\n    } @else {\n      <!-- <div>query2 {{ query2() }}</div>\n      <div class=\"\">\n        searchRef.valueSignal    {{ searchRef.valueSignal() }}\n      </div> -->\n      <div class=\"row row-cols-2\">\n        <div>\n          <div class=\"text-primary f-600 mb-2\">\n            {{ 'Non-Selected Columns' | appTranslate | async }}\n          </div>\n          <!-- <div class=\"mb-2\">\n                        <app-input-td-rf [(model)]=\"query\" placeholder=\"Filter\" />\n                    </div> -->\n          <div class=\"border rounded-10 p-2 bg-light cage overflow-auto\">\n            <div class=\"row my-2 mx-0 justify-content-center\">\n              <div class=\"col-sm-10\">\n                <app-input-td-rf\n                  #searchRef\n                  [noFormat]=\"true\"\n                  [(model)]=\"query2\"\n                  placeholder=\"Search by name\"/>\n              </div>\n            </div>\n            <div\n              class=\"row row-cols-1 g-2\"\n              cdkDropList\n              #sourceList=\"cdkDropList\"\n              [cdkDropListData]=\"nonActiveFields()\"\n              cdkDropListSortingDisabled\n              [cdkDropListConnectedTo]=\"[destinationList]\"\n              (cdkDropListDropped)=\"drop($event)\">\n              @for (item of nonActiveFields(); track item.f; let i = $index) {\n                <div class=\"\" cdkDrag>\n                  <div class=\"example-custom-placeholder\" *cdkDragPlaceholder></div>\n                  <div class=\"border p-2 rounded-10 bg-white\">\n                    <div class=\"row row-cols-auto justify-content-between\">\n                      <div class=\"d-flex align-items-center\">\n                        <i\n                          cdkDragHandle\n                          matTooltip=\"Drag the icon to move the column to the selected columns group\"\n                          class=\"drag-cursor material-icons\">\n                          drag_handle\n                        </i>\n                        {{ item.t | titlecase | appTranslate | async }}\n                      </div>\n                      <div class=\"col-md-auto\">\n                        <div class=\"row\">\n                          <div class=\"col-md-auto\" *ngIf=\"!uS.environment.production\">\n                            {{ item.type }}\n                          </div>\n                          <!-- <div class=\"col-md-auto\">\n                                                    <app-input-td-rf [xsmall]=\"true\" [label]=\"'Is Number?'\"\n                                                        [stacked]=\"false\" type=\"checkbox\"\n                                                        (modelChange)=\"isNumType($event, item)\" />\n                                                </div> -->\n                          <div class=\"col-md-auto\">\n                            <app-btn text=\"Select\" (mclick)=\"changeToActive(item)\" />\n                          </div>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              }\n            </div>\n          </div>\n        </div>\n        <div>\n          <div class=\"text-primary f-600 mb-2\">\n            {{ 'Selected Columns' | appTranslate | async }}\n          </div>\n          <div class=\"border rounded-10 p-2 bg-light cage overflow-auto\">\n            <div\n              class=\"row row-cols-1 g-2\"\n              cdkDropList\n              #destinationList=\"cdkDropList\"\n              [cdkDropListData]=\"activeFields()\"\n              [cdkDropListConnectedTo]=\"[sourceList]\"\n              (cdkDropListDropped)=\"drop($event)\">\n              @for (item of activeFields(); track item.f; let i = $index) {\n                <div class=\"\" cdkDrag>\n                  <div class=\"example-custom-placeholder\" *cdkDragPlaceholder></div>\n                  <div class=\"border p-2 rounded-10 bg-white\">\n                    <div class=\"row row-cols-auto justify-content-between\">\n                      <div class=\"d-flex align-items-center\">\n                        <i\n                          cdkDragHandle\n                          matTooltip=\"Drag the icon to move the column to the non-selected columns group or re-order\"\n                          class=\"drag-cursor material-icons\">\n                          drag_handle\n                        </i>\n                        {{ item.t | titlecase | appTranslate | async }}\n                      </div>\n                      <div>\n                        <mat-slide-toggle *ngIf=\"item.active\" [(ngModel)]=\"item.sticky\">\n                          {{ 'Sticky' | appTranslate | async }}\n                        </mat-slide-toggle>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              }\n            </div>\n          </div>\n        </div>\n      </div>\n    }\n  </div>\n  <div class=\"w-100 pt-2 d-flex justify-content-end\" *modalFooter>\n    <app-btn text=\"Update Columns\" (mclick)=\"emitFieldsChanged(); acModal.close()\" />\n  </div>\n</modal-comp>\n"]}
@@ -78,7 +78,7 @@ export class FileUploadComponent {
78
78
  inp.click();
79
79
  }
80
80
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: FileUploadComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
81
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: FileUploadComponent, isStandalone: true, selector: "app-file-upload", inputs: { help: { classPropertyName: "help", publicName: "help", isSignal: false, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: false, isRequired: false, transformFunction: null }, mediaWidth: { classPropertyName: "mediaWidth", publicName: "mediaWidth", isSignal: true, isRequired: false, transformFunction: null }, class: { classPropertyName: "class", publicName: "class", isSignal: true, isRequired: false, transformFunction: null }, useWebcam: { classPropertyName: "useWebcam", publicName: "useWebcam", isSignal: true, isRequired: false, transformFunction: null }, fileName: { classPropertyName: "fileName", publicName: "fileName", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: false, isRequired: false, transformFunction: null }, mini: { classPropertyName: "mini", publicName: "mini", isSignal: true, isRequired: false, transformFunction: null }, useDocumentModal: { classPropertyName: "useDocumentModal", publicName: "useDocumentModal", isSignal: false, isRequired: false, transformFunction: null }, listFiles: { classPropertyName: "listFiles", publicName: "listFiles", isSignal: true, isRequired: false, transformFunction: null }, _accept: { classPropertyName: "_accept", publicName: "accept", isSignal: false, isRequired: false, transformFunction: null }, file: { classPropertyName: "file", publicName: "file", isSignal: true, isRequired: false, transformFunction: null }, files: { classPropertyName: "files", publicName: "files", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { mediaWidth: "mediaWidthChange", file: "fileChange", fileChange: "fileChange", files: "filesChange", filesChange: "filesChange" }, ngImport: i0, template: "@if (listFiles()) {\n <div [ngClass]=\"{ meta: mini() }\" class=\"{{ class() }} form-label mb-2 hide-scroll\">\n @for (item of files(); track item) {\n <div class=\"row align-items-start mb-1\">\n <div class=\"col\">\n <div class=\"hide-scroll file-name\">\n {{ item?.name }}\n </div>\n </div>\n <div class=\"col-auto text-end\">\n <span class=\"text-danger pointer p-1 fa fa-close\" (click)=\"removeFile($index)\"></span>\n </div>\n </div>\n }\n </div>\n}\n<!-- <input type=\"file\" style=\"display: none;\" accept=\"{{accept}}\" (change)=\"onUpload($event)\" #uploadInput [multiple]=\"multiple\"> -->\n<app-btn\n icon=\"upload\"\n (mclick)=\"useWebcam() ? null : openDialog()\"\n [type]=\"file() ? 'primary' : 'secondary'\"\n [disabled]=\"disabled\"\n [help]=\"help\"\n [text]=\"label\"\n [matMenuTriggerFor]=\"useWebcam() ? menu : null\" />\n\n<mat-menu #menu=\"matMenu\">\n <button mat-menu-item (click)=\"openDialog()\">Upload</button>\n <button mat-menu-item (click)=\"webcamModal.open()\">Use Camera</button>\n</mat-menu>\n\n<modal-comp #webcamModal width=\"1080px\" [showFooter]=\"false\" header=\"Webcam\">\n <ng-template modalBody>\n <lib-webcam-media [fileName]=\"fileName()\" [width]=\"mediaWidth()\" (closed)=\"webcamModal.close(); $event ? acceptFiles($event?.latestFile) : null\" />\n </ng-template>\n</modal-comp>\n", styles: [".meta,.file-name{height:23px}.meta{overflow-y:auto}.file-name{overflow:auto}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "component", type: i1.ModalComponent, selector: "modal-comp", inputs: ["header", "bodyTemplateRef", "footerTemplateRef", "showHeader", "loading", "isFullscreen", "showFooter", "width", "minWidth", "height", "maxHeight", "icon", "data", "disableClose", "hasBackdrop"], outputs: ["showHeaderChange", "loadingChange", "showFooterChange", "modalOpen", "modalClose"] }, { kind: "directive", type: i2.ModalBodyDirective, selector: "[modalBody]" }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: WebcamMediaComponent, selector: "lib-webcam-media", inputs: ["controlTemplate", "isVideo", "useAudio", "fileName", "fileNameFactory", "fileType", "extraClass", "recordingNotificationInterval", "imageSnapshotInterval", "isBackground", "width"], outputs: ["closed", "recorderStopped", "recorderErrored", "recorderStarted", "recordingState", "recordingChanged", "newImageSnapshot", "webcamError", "widthChange"] }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
81
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: FileUploadComponent, isStandalone: true, selector: "app-file-upload", inputs: { help: { classPropertyName: "help", publicName: "help", isSignal: false, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: false, isRequired: false, transformFunction: null }, mediaWidth: { classPropertyName: "mediaWidth", publicName: "mediaWidth", isSignal: true, isRequired: false, transformFunction: null }, class: { classPropertyName: "class", publicName: "class", isSignal: true, isRequired: false, transformFunction: null }, useWebcam: { classPropertyName: "useWebcam", publicName: "useWebcam", isSignal: true, isRequired: false, transformFunction: null }, fileName: { classPropertyName: "fileName", publicName: "fileName", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: false, isRequired: false, transformFunction: null }, mini: { classPropertyName: "mini", publicName: "mini", isSignal: true, isRequired: false, transformFunction: null }, useDocumentModal: { classPropertyName: "useDocumentModal", publicName: "useDocumentModal", isSignal: false, isRequired: false, transformFunction: null }, listFiles: { classPropertyName: "listFiles", publicName: "listFiles", isSignal: true, isRequired: false, transformFunction: null }, _accept: { classPropertyName: "_accept", publicName: "accept", isSignal: false, isRequired: false, transformFunction: null }, file: { classPropertyName: "file", publicName: "file", isSignal: true, isRequired: false, transformFunction: null }, files: { classPropertyName: "files", publicName: "files", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { mediaWidth: "mediaWidthChange", file: "fileChange", fileChange: "fileChange", files: "filesChange", filesChange: "filesChange" }, ngImport: i0, template: "@if (listFiles()) {\n <div [ngClass]=\"{ meta: mini() }\" class=\"{{ class() }} form-label mb-2 hide-scroll\">\n @for (item of files(); track item) {\n <div class=\"row align-items-start mb-1\">\n <div class=\"col\">\n <div class=\"hide-scroll file-name\">\n {{ item?.name }}\n </div>\n </div>\n <div class=\"col-auto text-end\">\n <span class=\"text-danger pointer p-1 fa fa-close\" (click)=\"removeFile($index)\"></span>\n </div>\n </div>\n }\n </div>\n}\n<!-- <input type=\"file\" style=\"display: none;\" accept=\"{{accept}}\" (change)=\"onUpload($event)\" #uploadInput [multiple]=\"multiple\"> -->\n<app-btn\n icon=\"upload\"\n (mclick)=\"useWebcam() ? null : openDialog()\"\n [type]=\"file() ? 'primary' : 'secondary'\"\n [disabled]=\"disabled\"\n [help]=\"help\"\n [text]=\"label\"\n [matMenuTriggerFor]=\"useWebcam() ? menu : null\" />\n\n<mat-menu #menu=\"matMenu\">\n <button mat-menu-item (click)=\"openDialog()\">Upload</button>\n <button mat-menu-item (click)=\"webcamModal.open()\">Use Camera</button>\n</mat-menu>\n\n<modal-comp #webcamModal width=\"1080px\" [showFooter]=\"false\" header=\"Webcam\">\n <ng-template modalBody>\n <lib-webcam-media [fileName]=\"fileName()\" [width]=\"mediaWidth()\" (closed)=\"webcamModal.close(); $event ? acceptFiles($event?.latestFile) : null\" />\n </ng-template>\n</modal-comp>\n", styles: [".meta,.file-name{height:23px}.meta{overflow-y:auto}.file-name{overflow:auto}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "component", type: i1.ModalComponent, selector: "modal-comp", inputs: ["header", "bodyTemplateRef", "footerTemplateRef", "showHeader", "loading", "isFullscreen", "showFooter", "width", "minWidth", "height", "maxHeight", "icon", "data", "disableClose", "hasBackdrop"], outputs: ["headerChange", "showHeaderChange", "loadingChange", "showFooterChange", "modalOpen", "modalClose"] }, { kind: "directive", type: i2.ModalBodyDirective, selector: "[modalBody]" }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: WebcamMediaComponent, selector: "lib-webcam-media", inputs: ["controlTemplate", "isVideo", "useAudio", "fileName", "fileNameFactory", "fileType", "extraClass", "recordingNotificationInterval", "imageSnapshotInterval", "isBackground", "width"], outputs: ["closed", "recorderStopped", "recorderErrored", "recorderStarted", "recordingState", "recordingChanged", "newImageSnapshot", "webcamError", "widthChange"] }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
82
82
  }
83
83
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: FileUploadComponent, decorators: [{
84
84
  type: Component,
@@ -105,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
105
105
  type: Input,
106
106
  args: ['accept']
107
107
  }] } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/file-upload/file-upload.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/file-upload/file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  inject,\n  input,\n  model,\n  output,\n} from '@angular/core';\nimport { NgIf, NgClass, NgFor } from '@angular/common';\nimport { BtnComponent } from '../btn/btn.component';\nimport { UtilityService } from '../../../Services/utility.service';\nimport ModalComponents from '../modal-components/modal.components';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { WebcamMediaComponent } from '../webcam-media/webcam-media.component';\n\n@Component({\n  selector: 'app-file-upload',\n  templateUrl: './file-upload.component.html',\n  styleUrls: ['./file-upload.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.Default,\n  imports: [\n    NgIf,\n    NgClass,\n    NgFor,\n    BtnComponent,\n    ModalComponents,\n    MatMenuModule,\n    WebcamMediaComponent,\n  ],\n})\nexport class FileUploadComponent implements OnInit {\n  @Input() help: string;\n  @Input() label: string;\n  mediaWidth = model<number>(1080);\n  class = input<string>();\n  useWebcam = input<boolean>(false);\n  /**\n   * Only useful if using the webcam option\n   */\n  fileName = input<string>();\n  @Input() disabled: boolean;\n  @Input() multiple: boolean;\n  mini = input(true);\n  @Input() useDocumentModal: boolean;\n  listFiles = input(true);\n  accept: string;\n  @Input('accept') set _accept(v: string) {\n    switch (v) {\n      case 'image':\n        this.accept = '.png,.jpg,.jpeg,.bmp';\n        break;\n\n      default:\n        this.accept = v;\n        break;\n    }\n  }\n  // @ViewChild('uploadInput') uploadInputRef: ElementRef<HTMLInputElement>;\n  readonly file = model<File>();\n  readonly fileChange = output<File>();\n  readonly files = model<File[]>();\n  readonly filesChange = output<File[]>();\n\n  public uS = inject(UtilityService);\n\n  constructor() {}\n\n  ngOnInit(): void {}\n\n  get isSingle() {\n    return !this.multiple;\n  }\n  protected acceptFiles(...files: File[]) {\n    this.files.set(files);\n    this.file.set(files ? files[0] : null);\n    this.emitFiles();\n  }\n  protected emitFiles() {\n    if (this.multiple) this.filesChange.emit(this.files());\n    else this.fileChange.emit(this.file());\n  }\n\n  onUpload(event: any) {\n    const files = Array.from<File>(event.target.files);\n    this.acceptFiles(...files);\n  }\n\n  removeFile(index: number) {\n    this.files.update((files) => {\n      files.splice(index, 1);\n      return [...files];\n    });\n    this.file.set(this.files() ? this.files()?.[0] : null);\n\n    this.fileChange.emit(this.file());\n    this.filesChange.emit(this.files());\n  }\n  openDialog() {\n    const inp = document.createElement('input');\n    inp.type = 'file';\n    inp.accept = this.accept;\n    inp.multiple = this.multiple;\n    inp.onchange = (e) => {\n      this.onUpload(e);\n      inp.remove();\n    };\n    // document.body.appendChild(inp);\n    inp.click();\n  }\n}\n","@if (listFiles()) {\n  <div [ngClass]=\"{ meta: mini() }\" class=\"{{ class() }} form-label mb-2 hide-scroll\">\n    @for (item of files(); track item) {\n      <div class=\"row align-items-start mb-1\">\n        <div class=\"col\">\n          <div class=\"hide-scroll file-name\">\n            {{ item?.name }}\n          </div>\n        </div>\n        <div class=\"col-auto text-end\">\n          <span class=\"text-danger pointer p-1 fa fa-close\" (click)=\"removeFile($index)\"></span>\n        </div>\n      </div>\n    }\n  </div>\n}\n<!-- <input type=\"file\"  style=\"display: none;\" accept=\"{{accept}}\" (change)=\"onUpload($event)\" #uploadInput [multiple]=\"multiple\"> -->\n<app-btn\n  icon=\"upload\"\n  (mclick)=\"useWebcam() ? null : openDialog()\"\n  [type]=\"file() ? 'primary' : 'secondary'\"\n  [disabled]=\"disabled\"\n  [help]=\"help\"\n  [text]=\"label\"\n  [matMenuTriggerFor]=\"useWebcam() ? menu : null\" />\n\n<mat-menu #menu=\"matMenu\">\n  <button mat-menu-item (click)=\"openDialog()\">Upload</button>\n  <button mat-menu-item (click)=\"webcamModal.open()\">Use Camera</button>\n</mat-menu>\n\n<modal-comp #webcamModal width=\"1080px\" [showFooter]=\"false\" header=\"Webcam\">\n  <ng-template modalBody>\n    <lib-webcam-media [fileName]=\"fileName()\" [width]=\"mediaWidth()\" (closed)=\"webcamModal.close(); $event ? acceptFiles($event?.latestFile) : null\" />\n  </ng-template>\n</modal-comp>\n"]}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/file-upload/file-upload.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/file-upload/file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  inject,\n  input,\n  model,\n  output,\n} from '@angular/core';\nimport { NgIf, NgClass, NgFor } from '@angular/common';\nimport { BtnComponent } from '../btn/btn.component';\nimport { UtilityService } from '../../../Services/utility.service';\nimport ModalComponents from '../modal-components/modal.components';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { WebcamMediaComponent } from '../webcam-media/webcam-media.component';\n\n@Component({\n  selector: 'app-file-upload',\n  templateUrl: './file-upload.component.html',\n  styleUrls: ['./file-upload.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.Default,\n  imports: [\n    NgIf,\n    NgClass,\n    NgFor,\n    BtnComponent,\n    ModalComponents,\n    MatMenuModule,\n    WebcamMediaComponent,\n  ],\n})\nexport class FileUploadComponent implements OnInit {\n  @Input() help: string;\n  @Input() label: string;\n  mediaWidth = model<number>(1080);\n  class = input<string>();\n  useWebcam = input<boolean>(false);\n  /**\n   * Only useful if using the webcam option\n   */\n  fileName = input<string>();\n  @Input() disabled: boolean;\n  @Input() multiple: boolean;\n  mini = input(true);\n  @Input() useDocumentModal: boolean;\n  listFiles = input(true);\n  accept: string;\n  @Input('accept') set _accept(v: string) {\n    switch (v) {\n      case 'image':\n        this.accept = '.png,.jpg,.jpeg,.bmp';\n        break;\n\n      default:\n        this.accept = v;\n        break;\n    }\n  }\n  // @ViewChild('uploadInput') uploadInputRef: ElementRef<HTMLInputElement>;\n  readonly file = model<File>();\n  readonly fileChange = output<File>();\n  readonly files = model<File[]>();\n  readonly filesChange = output<File[]>();\n\n  public uS = inject(UtilityService);\n\n  constructor() {}\n\n  ngOnInit(): void {}\n\n  get isSingle() {\n    return !this.multiple;\n  }\n  protected acceptFiles(...files: File[]) {\n    this.files.set(files);\n    this.file.set(files ? files[0] : null);\n    this.emitFiles();\n  }\n  protected emitFiles() {\n    if (this.multiple) this.filesChange.emit(this.files());\n    else this.fileChange.emit(this.file());\n  }\n\n  onUpload(event: any) {\n    const files = Array.from<File>(event.target.files);\n    this.acceptFiles(...files);\n  }\n\n  removeFile(index: number) {\n    this.files.update((files) => {\n      files.splice(index, 1);\n      return [...files];\n    });\n    this.file.set(this.files() ? this.files()?.[0] : null);\n\n    this.fileChange.emit(this.file());\n    this.filesChange.emit(this.files());\n  }\n  openDialog() {\n    const inp = document.createElement('input');\n    inp.type = 'file';\n    inp.accept = this.accept;\n    inp.multiple = this.multiple;\n    inp.onchange = (e) => {\n      this.onUpload(e);\n      inp.remove();\n    };\n    // document.body.appendChild(inp);\n    inp.click();\n  }\n}\n","@if (listFiles()) {\n  <div [ngClass]=\"{ meta: mini() }\" class=\"{{ class() }} form-label mb-2 hide-scroll\">\n    @for (item of files(); track item) {\n      <div class=\"row align-items-start mb-1\">\n        <div class=\"col\">\n          <div class=\"hide-scroll file-name\">\n            {{ item?.name }}\n          </div>\n        </div>\n        <div class=\"col-auto text-end\">\n          <span class=\"text-danger pointer p-1 fa fa-close\" (click)=\"removeFile($index)\"></span>\n        </div>\n      </div>\n    }\n  </div>\n}\n<!-- <input type=\"file\"  style=\"display: none;\" accept=\"{{accept}}\" (change)=\"onUpload($event)\" #uploadInput [multiple]=\"multiple\"> -->\n<app-btn\n  icon=\"upload\"\n  (mclick)=\"useWebcam() ? null : openDialog()\"\n  [type]=\"file() ? 'primary' : 'secondary'\"\n  [disabled]=\"disabled\"\n  [help]=\"help\"\n  [text]=\"label\"\n  [matMenuTriggerFor]=\"useWebcam() ? menu : null\" />\n\n<mat-menu #menu=\"matMenu\">\n  <button mat-menu-item (click)=\"openDialog()\">Upload</button>\n  <button mat-menu-item (click)=\"webcamModal.open()\">Use Camera</button>\n</mat-menu>\n\n<modal-comp #webcamModal width=\"1080px\" [showFooter]=\"false\" header=\"Webcam\">\n  <ng-template modalBody>\n    <lib-webcam-media [fileName]=\"fileName()\" [width]=\"mediaWidth()\" (closed)=\"webcamModal.close(); $event ? acceptFiles($event?.latestFile) : null\" />\n  </ng-template>\n</modal-comp>\n"]}
@@ -207,7 +207,7 @@ export class FormGeneratorComponent extends BaseFormGenerator {
207
207
  this.onSubmit.emit(this.formValue());
208
208
  }
209
209
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: FormGeneratorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
210
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: FormGeneratorComponent, isStandalone: true, selector: "form-generator", inputs: { keyField: { classPropertyName: "keyField", publicName: "keyField", isSignal: false, isRequired: false, transformFunction: null }, presetValueForSingleOption: { classPropertyName: "presetValueForSingleOption", publicName: "presetValueForSingleOption", isSignal: true, isRequired: false, transformFunction: null }, isCreate: { classPropertyName: "isCreate", publicName: "isCreate", isSignal: true, isRequired: false, transformFunction: null }, submitOnEnterKey: { classPropertyName: "submitOnEnterKey", publicName: "submitOnEnterKey", isSignal: true, isRequired: false, transformFunction: null }, submitFunc: { classPropertyName: "submitFunc", publicName: "submitFunc", isSignal: false, isRequired: false, transformFunction: null }, submitBtnText: { classPropertyName: "submitBtnText", publicName: "submitBtnText", isSignal: true, isRequired: false, transformFunction: null }, submitBtnTemplate: { classPropertyName: "submitBtnTemplate", publicName: "submitBtnTemplate", isSignal: true, isRequired: false, transformFunction: null }, submitSuccessText: { classPropertyName: "submitSuccessText", publicName: "submitSuccessText", isSignal: true, isRequired: false, transformFunction: null }, showSubmitBtn: { classPropertyName: "showSubmitBtn", publicName: "showSubmitBtn", isSignal: true, isRequired: false, transformFunction: null }, gridStyle: { classPropertyName: "gridStyle", publicName: "gridStyle", isSignal: true, isRequired: false, transformFunction: null }, gridMDStyle: { classPropertyName: "gridMDStyle", publicName: "gridMDStyle", isSignal: true, isRequired: false, transformFunction: null }, gridLGStyle: { classPropertyName: "gridLGStyle", publicName: "gridLGStyle", isSignal: true, isRequired: false, transformFunction: null }, gridXXLStyle: { classPropertyName: "gridXXLStyle", publicName: "gridXXLStyle", isSignal: true, isRequired: false, transformFunction: null }, formGridClass: { classPropertyName: "formGridClass", publicName: "formGridClass", isSignal: true, isRequired: false, transformFunction: null }, useLoader: { classPropertyName: "useLoader", publicName: "useLoader", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: false, transformFunction: null }, _formSchemaNoForm: { classPropertyName: "_formSchemaNoForm", publicName: "formSchemaNoForm", isSignal: false, isRequired: false, transformFunction: null }, _isShow: { classPropertyName: "_isShow", publicName: "isShow", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { onSubmit: "onSubmit", mchange: "mchange", saved: "saved", form: "formChange" }, viewQueries: [{ propertyName: "formTagRef", first: true, predicate: ["formTag"], descendants: true, isSignal: true }, { propertyName: "submitBtnRef", first: true, predicate: ["submitBtn"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n <form [formGroup]=\"form()\" #formTag>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedFormSchema(); track scheme.id) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [stacked]=\"scheme.stacked\"\n [name]=\"scheme.field\"\n [noFormat]=\"scheme.noFormat\"\n [verbose]=\"scheme.verbose\"\n [debug]=\"scheme.debug\"\n (mchange)=\"mchangeEmitter()\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @case (scheme.type == 'autocomplete') {\n <app-autocomplete\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [stacked]=\"scheme.stacked\"\n [verbose]=\"scheme.verbose\"\n [presetValue]=\"scheme.presetValue\"\n [labelField]=\"scheme.labelField\"\n [noFormat]=\"scheme.noFormat\"\n [labelType]=\"scheme.labelType | toAny\"\n (mchange)=\"mchangeEmitter()\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field\"\n [debug]=\"scheme.debug\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [optionFormatter]=\"scheme.optionFormatter\"\n [valueField]=\"scheme.valueField\"\n [optionsFunc]=\"scheme.optionsFunc\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [hint]=\"scheme.hint\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @case (scheme.type == 'richtext') {\n <rich-text-editor-rf\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label!\"\n [clearOnDisable]=\"scheme.clearOnDisable!\"\n [stacked]=\"scheme.stacked\"\n [verbose]=\"scheme.verbose\"\n [labelField]=\"scheme.labelField!\"\n [noFormat]=\"scheme.noFormat!\"\n [labelType]=\"scheme.labelType | toAny\"\n (mchange)=\"mchangeEmitter()\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field\"\n [debug]=\"scheme.debug!\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag!\"\n [optionFormatter]=\"scheme.optionFormatter!\"\n [valueField]=\"scheme.valueField!\"\n [optionsFunc]=\"scheme.optionsFunc!\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [autoPickValueField]=\"scheme.autoPickValueField!\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [hint]=\"scheme.hint!\"\n [maxLength]=\"scheme.maxLength\"\n [minLength]=\"scheme.minLength\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @default {\n <app-input-basic\n [noFormat]=\"scheme.noFormat\"\n [name]=\"scheme.field\"\n [form]=\"scheme.form || form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [type]=\"scheme.type\"\n [verbose]=\"scheme.verbose\"\n [valueField]=\"scheme.valueField\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [presetValue]=\"scheme.presetValue\"\n [stacked]=\"scheme.stacked\"\n [labelType]=\"scheme.labelType | toAny\"\n [checkedSignal]=\"scheme.checked\"\n [showValidation]=\"!!scheme.asyncValidators\"\n [showValidationIcon]=\"!!scheme.asyncValidators\"\n [debug]=\"scheme.debug\"\n (mchange)=\"mchangeEmitter()\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [labelField]=\"scheme.labelField\"\n [optionFormatter]=\"scheme.optionFormatter\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [decimalPoints]=\"scheme.decimalPoints\"\n [hint]=\"scheme.hint\"\n [max]=\"scheme.max\"\n [min]=\"scheme.min\"\n [maxLength]=\"scheme.maxLength\"\n [minLength]=\"scheme.minLength\"\n [placeholder]=\"scheme.placeholder\"\n [label]=\"scheme.label\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n }\n </div>\n }\n </div>\n <div class=\"row row-cols-auto justify-content-end\">\n <div class=\"\">\n @if (showSubmitBtn()) {\n <app-btn\n [text]=\"submitBtnText()\"\n group=\"submit\"\n [form]=\"form()\"\n (mclick)=\"submit(submitBtn)\"\n #submitBtn />\n }\n @if (submitBtnTemplate()) {\n <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n }\n </div>\n </div>\n </form>\n</loader>\n", styles: [""], dependencies: [{ kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: PhoneNumberComponent, selector: "app-phone-number", inputs: ["showLabel", "countryCode3", "config"], outputs: ["onCountrySelect"] }, { kind: "component", type: AutocompleteComponent, selector: "app-autocomplete,autocomplete", inputs: ["showRequiredTag", "validate", "options"] }, { kind: "component", type: InputBasicComponent, selector: "app-input-basic,app-input", inputs: ["accept", "autocomplete", "input", "contextData", "decimalPoints", "files", "hide", "hint", "labelLink", "lblCl", "light", "loading", "multiple", "optionsFunc", "theme", "vms", "xsmall", "setCurrentDate", "options"], outputs: ["mSelectedOptionLabel"] }, { kind: "component", type: RichTextEditorRFComponent, selector: "rich-text-editor-rf" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "pipe", type: FunctionCaller2, name: "functionCaller2" }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }] }); }
210
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: FormGeneratorComponent, isStandalone: true, selector: "form-generator", inputs: { keyField: { classPropertyName: "keyField", publicName: "keyField", isSignal: false, isRequired: false, transformFunction: null }, presetValueForSingleOption: { classPropertyName: "presetValueForSingleOption", publicName: "presetValueForSingleOption", isSignal: true, isRequired: false, transformFunction: null }, isCreate: { classPropertyName: "isCreate", publicName: "isCreate", isSignal: true, isRequired: false, transformFunction: null }, submitOnEnterKey: { classPropertyName: "submitOnEnterKey", publicName: "submitOnEnterKey", isSignal: true, isRequired: false, transformFunction: null }, submitFunc: { classPropertyName: "submitFunc", publicName: "submitFunc", isSignal: false, isRequired: false, transformFunction: null }, submitBtnText: { classPropertyName: "submitBtnText", publicName: "submitBtnText", isSignal: true, isRequired: false, transformFunction: null }, submitBtnTemplate: { classPropertyName: "submitBtnTemplate", publicName: "submitBtnTemplate", isSignal: true, isRequired: false, transformFunction: null }, submitSuccessText: { classPropertyName: "submitSuccessText", publicName: "submitSuccessText", isSignal: true, isRequired: false, transformFunction: null }, showSubmitBtn: { classPropertyName: "showSubmitBtn", publicName: "showSubmitBtn", isSignal: true, isRequired: false, transformFunction: null }, gridStyle: { classPropertyName: "gridStyle", publicName: "gridStyle", isSignal: true, isRequired: false, transformFunction: null }, gridMDStyle: { classPropertyName: "gridMDStyle", publicName: "gridMDStyle", isSignal: true, isRequired: false, transformFunction: null }, gridLGStyle: { classPropertyName: "gridLGStyle", publicName: "gridLGStyle", isSignal: true, isRequired: false, transformFunction: null }, gridXXLStyle: { classPropertyName: "gridXXLStyle", publicName: "gridXXLStyle", isSignal: true, isRequired: false, transformFunction: null }, formGridClass: { classPropertyName: "formGridClass", publicName: "formGridClass", isSignal: true, isRequired: false, transformFunction: null }, useLoader: { classPropertyName: "useLoader", publicName: "useLoader", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: false, transformFunction: null }, _formSchemaNoForm: { classPropertyName: "_formSchemaNoForm", publicName: "formSchemaNoForm", isSignal: false, isRequired: false, transformFunction: null }, _isShow: { classPropertyName: "_isShow", publicName: "isShow", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { onSubmit: "onSubmit", mchange: "mchange", saved: "saved", form: "formChange" }, viewQueries: [{ propertyName: "formTagRef", first: true, predicate: ["formTag"], descendants: true, isSignal: true }, { propertyName: "submitBtnRef", first: true, predicate: ["submitBtn"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n <form [formGroup]=\"form()\" #formTag>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedFormSchema(); track scheme.id) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [stacked]=\"scheme.stacked\"\n [name]=\"scheme.field\"\n [noFormat]=\"scheme.noFormat\"\n [verbose]=\"scheme.verbose\"\n [debug]=\"scheme.debug\"\n (mchange)=\"mchangeEmitter()\"\n [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationMsg]=\"scheme.showValidationMsg\" \n [countryCode3]=\"scheme.countryCode3\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @case (scheme.type == 'autocomplete') {\n <app-autocomplete\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [stacked]=\"scheme.stacked\"\n [verbose]=\"scheme.verbose\"\n [presetValue]=\"scheme.presetValue\"\n [labelField]=\"scheme.labelField\"\n [noFormat]=\"scheme.noFormat\"\n [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n [labelType]=\"scheme.labelType | toAny\"\n (mchange)=\"mchangeEmitter()\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field\"\n [debug]=\"scheme.debug\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [optionFormatter]=\"scheme.optionFormatter\"\n [valueField]=\"scheme.valueField\"\n [optionsFunc]=\"scheme.optionsFunc\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [hint]=\"scheme.hint\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @case (scheme.type == 'richtext') {\n <rich-text-editor-rf\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label!\"\n [clearOnDisable]=\"scheme.clearOnDisable!\"\n [stacked]=\"scheme.stacked\"\n [verbose]=\"scheme.verbose\"\n [labelField]=\"scheme.labelField!\"\n [noFormat]=\"scheme.noFormat!\"\n [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n [labelType]=\"scheme.labelType | toAny\"\n (mchange)=\"mchangeEmitter()\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field\"\n [debug]=\"scheme.debug!\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag!\"\n [optionFormatter]=\"scheme.optionFormatter!\"\n [valueField]=\"scheme.valueField!\"\n [optionsFunc]=\"scheme.optionsFunc!\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [autoPickValueField]=\"scheme.autoPickValueField!\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [hint]=\"scheme.hint!\"\n [maxLength]=\"scheme.maxLength\"\n [minLength]=\"scheme.minLength\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @default {\n <app-input-basic\n [noFormat]=\"scheme.noFormat\"\n [name]=\"scheme.field\"\n [form]=\"scheme.form || form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [type]=\"scheme.type\"\n [verbose]=\"scheme.verbose\"\n [valueField]=\"scheme.valueField\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [presetValue]=\"scheme.presetValue\"\n [stacked]=\"scheme.stacked\"\n [labelType]=\"scheme.labelType | toAny\"\n [checkedSignal]=\"scheme.checked\"\n [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n [debug]=\"scheme.debug\"\n (mchange)=\"mchangeEmitter()\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [labelField]=\"scheme.labelField\"\n [optionFormatter]=\"scheme.optionFormatter\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [decimalPoints]=\"scheme.decimalPoints\"\n [hint]=\"scheme.hint\"\n [max]=\"scheme.max\"\n [min]=\"scheme.min\"\n [maxLength]=\"scheme.maxLength\"\n [minLength]=\"scheme.minLength\"\n [placeholder]=\"scheme.placeholder\"\n [label]=\"scheme.label\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n }\n </div>\n }\n </div>\n <div class=\"row row-cols-auto justify-content-end\">\n <div class=\"\">\n @if (showSubmitBtn()) {\n <app-btn\n [text]=\"submitBtnText()\"\n group=\"submit\"\n [form]=\"form()\"\n (mclick)=\"submit(submitBtn)\"\n #submitBtn />\n }\n @if (submitBtnTemplate()) {\n <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n }\n </div>\n </div>\n </form>\n</loader>\n", styles: [""], dependencies: [{ kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: PhoneNumberComponent, selector: "app-phone-number", inputs: ["showLabel", "countryCode3", "config"], outputs: ["onCountrySelect"] }, { kind: "component", type: AutocompleteComponent, selector: "app-autocomplete,autocomplete", inputs: ["showRequiredTag", "validate", "options"] }, { kind: "component", type: InputBasicComponent, selector: "app-input-basic,app-input", inputs: ["accept", "autocomplete", "input", "contextData", "decimalPoints", "files", "hide", "hint", "labelLink", "lblCl", "light", "loading", "multiple", "optionsFunc", "theme", "vms", "xsmall", "setCurrentDate", "options"], outputs: ["mSelectedOptionLabel"] }, { kind: "component", type: RichTextEditorRFComponent, selector: "rich-text-editor-rf" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "pipe", type: FunctionCaller2, name: "functionCaller2" }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }] }); }
211
211
  }
212
212
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: FormGeneratorComponent, decorators: [{
213
213
  type: Component,
@@ -226,7 +226,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
226
226
  ReactiveFormsModule,
227
227
  FunctionCaller2,
228
228
  ToAnyPipe,
229
- ], template: "<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n <form [formGroup]=\"form()\" #formTag>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedFormSchema(); track scheme.id) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [stacked]=\"scheme.stacked\"\n [name]=\"scheme.field\"\n [noFormat]=\"scheme.noFormat\"\n [verbose]=\"scheme.verbose\"\n [debug]=\"scheme.debug\"\n (mchange)=\"mchangeEmitter()\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @case (scheme.type == 'autocomplete') {\n <app-autocomplete\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [stacked]=\"scheme.stacked\"\n [verbose]=\"scheme.verbose\"\n [presetValue]=\"scheme.presetValue\"\n [labelField]=\"scheme.labelField\"\n [noFormat]=\"scheme.noFormat\"\n [labelType]=\"scheme.labelType | toAny\"\n (mchange)=\"mchangeEmitter()\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field\"\n [debug]=\"scheme.debug\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [optionFormatter]=\"scheme.optionFormatter\"\n [valueField]=\"scheme.valueField\"\n [optionsFunc]=\"scheme.optionsFunc\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [hint]=\"scheme.hint\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @case (scheme.type == 'richtext') {\n <rich-text-editor-rf\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label!\"\n [clearOnDisable]=\"scheme.clearOnDisable!\"\n [stacked]=\"scheme.stacked\"\n [verbose]=\"scheme.verbose\"\n [labelField]=\"scheme.labelField!\"\n [noFormat]=\"scheme.noFormat!\"\n [labelType]=\"scheme.labelType | toAny\"\n (mchange)=\"mchangeEmitter()\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field\"\n [debug]=\"scheme.debug!\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag!\"\n [optionFormatter]=\"scheme.optionFormatter!\"\n [valueField]=\"scheme.valueField!\"\n [optionsFunc]=\"scheme.optionsFunc!\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [autoPickValueField]=\"scheme.autoPickValueField!\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [hint]=\"scheme.hint!\"\n [maxLength]=\"scheme.maxLength\"\n [minLength]=\"scheme.minLength\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @default {\n <app-input-basic\n [noFormat]=\"scheme.noFormat\"\n [name]=\"scheme.field\"\n [form]=\"scheme.form || form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [type]=\"scheme.type\"\n [verbose]=\"scheme.verbose\"\n [valueField]=\"scheme.valueField\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [presetValue]=\"scheme.presetValue\"\n [stacked]=\"scheme.stacked\"\n [labelType]=\"scheme.labelType | toAny\"\n [checkedSignal]=\"scheme.checked\"\n [showValidation]=\"!!scheme.asyncValidators\"\n [showValidationIcon]=\"!!scheme.asyncValidators\"\n [debug]=\"scheme.debug\"\n (mchange)=\"mchangeEmitter()\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [labelField]=\"scheme.labelField\"\n [optionFormatter]=\"scheme.optionFormatter\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [decimalPoints]=\"scheme.decimalPoints\"\n [hint]=\"scheme.hint\"\n [max]=\"scheme.max\"\n [min]=\"scheme.min\"\n [maxLength]=\"scheme.maxLength\"\n [minLength]=\"scheme.minLength\"\n [placeholder]=\"scheme.placeholder\"\n [label]=\"scheme.label\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n }\n </div>\n }\n </div>\n <div class=\"row row-cols-auto justify-content-end\">\n <div class=\"\">\n @if (showSubmitBtn()) {\n <app-btn\n [text]=\"submitBtnText()\"\n group=\"submit\"\n [form]=\"form()\"\n (mclick)=\"submit(submitBtn)\"\n #submitBtn />\n }\n @if (submitBtnTemplate()) {\n <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n }\n </div>\n </div>\n </form>\n</loader>\n" }]
229
+ ], template: "<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n <form [formGroup]=\"form()\" #formTag>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedFormSchema(); track scheme.id) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [stacked]=\"scheme.stacked\"\n [name]=\"scheme.field\"\n [noFormat]=\"scheme.noFormat\"\n [verbose]=\"scheme.verbose\"\n [debug]=\"scheme.debug\"\n (mchange)=\"mchangeEmitter()\"\n [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationMsg]=\"scheme.showValidationMsg\" \n [countryCode3]=\"scheme.countryCode3\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @case (scheme.type == 'autocomplete') {\n <app-autocomplete\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [stacked]=\"scheme.stacked\"\n [verbose]=\"scheme.verbose\"\n [presetValue]=\"scheme.presetValue\"\n [labelField]=\"scheme.labelField\"\n [noFormat]=\"scheme.noFormat\"\n [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n [labelType]=\"scheme.labelType | toAny\"\n (mchange)=\"mchangeEmitter()\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field\"\n [debug]=\"scheme.debug\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [optionFormatter]=\"scheme.optionFormatter\"\n [valueField]=\"scheme.valueField\"\n [optionsFunc]=\"scheme.optionsFunc\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [hint]=\"scheme.hint\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @case (scheme.type == 'richtext') {\n <rich-text-editor-rf\n [form]=\"scheme.form || form()\"\n [label]=\"scheme.label!\"\n [clearOnDisable]=\"scheme.clearOnDisable!\"\n [stacked]=\"scheme.stacked\"\n [verbose]=\"scheme.verbose\"\n [labelField]=\"scheme.labelField!\"\n [noFormat]=\"scheme.noFormat!\"\n [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n [labelType]=\"scheme.labelType | toAny\"\n (mchange)=\"mchangeEmitter()\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field\"\n [debug]=\"scheme.debug!\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag!\"\n [optionFormatter]=\"scheme.optionFormatter!\"\n [valueField]=\"scheme.valueField!\"\n [optionsFunc]=\"scheme.optionsFunc!\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [autoPickValueField]=\"scheme.autoPickValueField!\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [hint]=\"scheme.hint!\"\n [maxLength]=\"scheme.maxLength\"\n [minLength]=\"scheme.minLength\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n @default {\n <app-input-basic\n [noFormat]=\"scheme.noFormat\"\n [name]=\"scheme.field\"\n [form]=\"scheme.form || form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [type]=\"scheme.type\"\n [verbose]=\"scheme.verbose\"\n [valueField]=\"scheme.valueField\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [presetValue]=\"scheme.presetValue\"\n [stacked]=\"scheme.stacked\"\n [labelType]=\"scheme.labelType | toAny\"\n [checkedSignal]=\"scheme.checked\"\n [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n [debug]=\"scheme.debug\"\n (mchange)=\"mchangeEmitter()\"\n [setFormattedValue]=\"scheme.setControlFormattedValue\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [labelField]=\"scheme.labelField\"\n [optionFormatter]=\"scheme.optionFormatter\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n [decimalPoints]=\"scheme.decimalPoints\"\n [hint]=\"scheme.hint\"\n [max]=\"scheme.max\"\n [min]=\"scheme.min\"\n [maxLength]=\"scheme.maxLength\"\n [minLength]=\"scheme.minLength\"\n [placeholder]=\"scheme.placeholder\"\n [label]=\"scheme.label\"\n [showValidationMsg]=\"scheme.showValidationMsg\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \" />\n }\n }\n </div>\n }\n </div>\n <div class=\"row row-cols-auto justify-content-end\">\n <div class=\"\">\n @if (showSubmitBtn()) {\n <app-btn\n [text]=\"submitBtnText()\"\n group=\"submit\"\n [form]=\"form()\"\n (mclick)=\"submit(submitBtn)\"\n #submitBtn />\n }\n @if (submitBtnTemplate()) {\n <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n }\n </div>\n </div>\n </form>\n</loader>\n" }]
230
230
  }], ctorParameters: () => [], propDecorators: { keyField: [{
231
231
  type: Input
232
232
  }], onSubmit: [{
@@ -247,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
247
247
  type: Input,
248
248
  args: ['isShow']
249
249
  }] } });
250
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { debounceTime, filter, last, switchMap, tap, map, startWith } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    RichTextEditorRFComponent,\n    BtnComponent,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> },\n> extends BaseFormGenerator<TFormGroup, IFormSchema<TFormGroup>> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  readonly presetValueForSingleOption = input(false);\n  readonly isCreate = input<boolean>();\n  readonly submitOnEnterKey = input<boolean>(false);\n  readonly formTagRef = viewChild<ElementRef<HTMLFormElement>>('formTag');\n\n  /**Emitted just before calling the save function */\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  /**Emitted after receiving feedback from the submit function */\n  @Output() saved = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  readonly submitBtnText = input('Submit');\n  readonly submitBtnTemplate = input<TemplateRef<any>>();\n  readonly submitSuccessText = input('Saved successfully');\n  readonly showSubmitBtn = input(true);\n\n  readonly gridStyle = input<number | 'auto'>();\n  readonly gridMDStyle = input<number | 'auto'>();\n  readonly gridLGStyle = input<number | 'auto'>();\n  readonly gridXXLStyle = input<number | 'auto'>();\n\n  readonly formGridClass = input<string>();\n  readonly useLoader = input<boolean>();\n  readonly loading = input<boolean>();\n\n  readonly _loading = signal<boolean>(false);\n\n  readonly computedLoading = computed(() =>\n    this.useLoader() ? this.loading() || this._loading() : false,\n  );\n\n  readonly submitBtnRef = viewChild<BtnComponent>('submitBtn');\n  readonly form = model<FormGroup<TFormGroup>>();\n\n  readonly  formValue = toSignal(\n    toObservable(this.form).pipe(\n      filter(() => !!this.form()),\n      switchMap(() =>\n        this.form()\n          .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))\n          .pipe(startWith(this.form()?.getRawValue() || {})),\n      ),\n    ),\n    // { initialValue: this.form()?.getRawValue() || {} },\n  );\n\n  submissionResponse: any;\n  @Input({ alias: 'formSchema' }) set _formSchema(v: IFormSchema<TFormGroup>[]) {\n    this.init(cloneDeep(v.filter((x) => x)));\n  }\n  @Input({ alias: 'formSchemaNoForm' }) set _formSchemaNoForm(v: IFormSchema<TFormGroup>[]) {\n    if (v) {\n      const form = new FormGroup({});\n      for (const item of v) {\n        form.addControl(\n          item.field?.toString(),\n          new FormControl(item.value, [].concat(item.isRequired ? [Validators.required] : [])),\n        );\n      }\n      this.form.set(form as any as FormGroup<TFormGroup>);\n      this._formSchema = v;\n    }\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form()?.disable({ emitEvent: false });\n    else this.form()?.enable();\n\n    setTimeout(() => {\n      if (v) this.form()?.disable({ emitEvent: false });\n      else this.form()?.enable();\n    }, 500);\n  }\n  readonly   optionsMap = signal<IFormOptions>({});\n  // formVal = computed(() => this.form?.getRawValue());\n\n  readonly   computedFormSchema = computed<IFormSchema<TFormGroup>[]>(() => {\n    const formSchema = this.formSchema() || [],\n      presetValueForSingleOption = this.presetValueForSingleOption(),\n      isCreate = this.isCreate(),\n      ret: IFormSchema<TFormGroup>[] = [];\n    formSchema.forEach((scheme) => {\n      if (!scheme.hidden) {\n        if (isCreate)\n          scheme.presetValue =\n            scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  constructor() {\n    super();\n\n    let listenToKey: Subscription;\n    this.destroyRef.onDestroy(() => {\n      listenToKey?.unsubscribe();\n    });\n    effect(() => {\n      const ftr = this.formTagRef(),\n        submitOnEnterKey = this.submitOnEnterKey();\n      // debugger;\n\n      listenToKey?.unsubscribe();\n      if (ftr?.nativeElement && submitOnEnterKey)\n        listenToKey = fromEvent(ftr.nativeElement, 'keydown')\n          .pipe(\n            debounceTime(100),\n            filter(\n              (r: KeyboardEvent) => (r.code === 'Enter' || r.keyCode === 13) && this.form().valid,\n            ),\n          )\n          .subscribe((r: KeyboardEvent) => {\n            this.submit(this.submitBtnRef());\n          });\n    });\n  }\n\n  init(schema: IFormSchema<TFormGroup>[]) {\n    // debugger;\n    this.onDestroy();\n    this._setFormSchemas(schema || []);\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit) {\n          const formValue = this.form()?.getRawValue();\n          scheme.onChangeFunc(formValue, formValue[scheme.field?.toString()], this);\n        }\n  }\n\n  handleFormScheme(scheme: IFormSchema<TFormGroup>) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (this.formService.config.showValidationMessagesByDefault)\n      if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n        scheme.autoPickValueField = true;\n    // if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form()\n        ?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0))\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.formValue(), r, this);\n        });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: IFormSchema<TFormGroup>, options$: Observable<any[]>) {\n    options$.subscribe((r) => {\n      // scheme.options = r;\n      this.updateFormSchema(scheme.field, { options: r });\n    });\n  }\n\n  detachFormScheme(fieldName?: keyof TFormGroup) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  protected mchangeEmitter() {\n    this.mchange.emit(this.formValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    return this.formSchemaMap()[fieldName as string];\n  };\n\n  addToFormSchema(formScheme: IFormSchema<TFormGroup>) {\n    this.removeFromFormSchema(formScheme.field);\n    this.handleFormScheme(formScheme);\n  }\n\n  updateFormSchema(fieldName: keyof TFormGroup, scheme: Partial<IFormSchema<TFormGroup>>) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n  updateAllFormSchema(map: (formField: IFormSchema<TFormGroup>) => IFormSchema<TFormGroup>) {\n    return super._updateAllFormSchema(map);\n  }\n\n  removeFromFormSchema(fieldName: keyof TFormGroup) {\n    this.detachFormScheme(fieldName);\n    const onRemove = this.formSchemaMap()[fieldName as string]?.onRemoveFunc;\n    if (onRemove) onRemove(this.formValue() as any, this.formValue()[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.formValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        this.utilityService.info(this.submitSuccessText(), 1);\n        this.saved.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.formValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n  <form [formGroup]=\"form()\" #formTag>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n        gridLGStyle()\n      }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.id) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [name]=\"scheme.field\"\n                [noFormat]=\"scheme.noFormat\"\n                [verbose]=\"scheme.verbose\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showValidation]=\"scheme.showValidation\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [showValidationIcon]=\"scheme.showValidationIcon\"\n                [countryCode3]=\"scheme.countryCode3\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <app-autocomplete\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [presetValue]=\"scheme.presetValue\"\n                [labelField]=\"scheme.labelField\"\n                [noFormat]=\"scheme.noFormat\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                [valueField]=\"scheme.valueField\"\n                [optionsFunc]=\"scheme.optionsFunc\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'richtext') {\n              <rich-text-editor-rf\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label!\"\n                [clearOnDisable]=\"scheme.clearOnDisable!\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [labelField]=\"scheme.labelField!\"\n                [noFormat]=\"scheme.noFormat!\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug!\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag!\"\n                [optionFormatter]=\"scheme.optionFormatter!\"\n                [valueField]=\"scheme.valueField!\"\n                [optionsFunc]=\"scheme.optionsFunc!\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField!\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint!\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @default {\n              <app-input-basic\n                [noFormat]=\"scheme.noFormat\"\n                [name]=\"scheme.field\"\n                [form]=\"scheme.form || form()\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [type]=\"scheme.type\"\n                [verbose]=\"scheme.verbose\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"!!scheme.asyncValidators\"\n                [showValidationIcon]=\"!!scheme.asyncValidators\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [labelField]=\"scheme.labelField\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [decimalPoints]=\"scheme.decimalPoints\"\n                [hint]=\"scheme.hint\"\n                [max]=\"scheme.max\"\n                [min]=\"scheme.min\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n          }\n        </div>\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn()) {\n          <app-btn\n            [text]=\"submitBtnText()\"\n            group=\"submit\"\n            [form]=\"form()\"\n            (mclick)=\"submit(submitBtn)\"\n            #submitBtn />\n        }\n        @if (submitBtnTemplate()) {\n          <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n        }\n      </div>\n    </div>\n  </form>\n</loader>\n"]}
250
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { debounceTime, filter, last, switchMap, tap, map, startWith } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    RichTextEditorRFComponent,\n    BtnComponent,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> },\n> extends BaseFormGenerator<TFormGroup, IFormSchema<TFormGroup>> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  readonly presetValueForSingleOption = input(false);\n  readonly isCreate = input<boolean>();\n  readonly submitOnEnterKey = input<boolean>(false);\n  readonly formTagRef = viewChild<ElementRef<HTMLFormElement>>('formTag');\n\n  /**Emitted just before calling the save function */\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  /**Emitted after receiving feedback from the submit function */\n  @Output() saved = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  readonly submitBtnText = input('Submit');\n  readonly submitBtnTemplate = input<TemplateRef<any>>();\n  readonly submitSuccessText = input('Saved successfully');\n  readonly showSubmitBtn = input(true);\n\n  readonly gridStyle = input<number | 'auto'>();\n  readonly gridMDStyle = input<number | 'auto'>();\n  readonly gridLGStyle = input<number | 'auto'>();\n  readonly gridXXLStyle = input<number | 'auto'>();\n\n  readonly formGridClass = input<string>();\n  readonly useLoader = input<boolean>();\n  readonly loading = input<boolean>();\n\n  readonly _loading = signal<boolean>(false);\n\n  readonly computedLoading = computed(() =>\n    this.useLoader() ? this.loading() || this._loading() : false,\n  );\n\n  readonly submitBtnRef = viewChild<BtnComponent>('submitBtn');\n  readonly form = model<FormGroup<TFormGroup>>();\n\n  readonly  formValue = toSignal(\n    toObservable(this.form).pipe(\n      filter(() => !!this.form()),\n      switchMap(() =>\n        this.form()\n          .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))\n          .pipe(startWith(this.form()?.getRawValue() || {})),\n      ),\n    ),\n    // { initialValue: this.form()?.getRawValue() || {} },\n  );\n\n  submissionResponse: any;\n  @Input({ alias: 'formSchema' }) set _formSchema(v: IFormSchema<TFormGroup>[]) {\n    this.init(cloneDeep(v.filter((x) => x)));\n  }\n  @Input({ alias: 'formSchemaNoForm' }) set _formSchemaNoForm(v: IFormSchema<TFormGroup>[]) {\n    if (v) {\n      const form = new FormGroup({});\n      for (const item of v) {\n        form.addControl(\n          item.field?.toString(),\n          new FormControl(item.value, [].concat(item.isRequired ? [Validators.required] : [])),\n        );\n      }\n      this.form.set(form as any as FormGroup<TFormGroup>);\n      this._formSchema = v;\n    }\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form()?.disable({ emitEvent: false });\n    else this.form()?.enable();\n\n    setTimeout(() => {\n      if (v) this.form()?.disable({ emitEvent: false });\n      else this.form()?.enable();\n    }, 500);\n  }\n  readonly   optionsMap = signal<IFormOptions>({});\n  // formVal = computed(() => this.form?.getRawValue());\n\n  readonly   computedFormSchema = computed<IFormSchema<TFormGroup>[]>(() => {\n    const formSchema = this.formSchema() || [],\n      presetValueForSingleOption = this.presetValueForSingleOption(),\n      isCreate = this.isCreate(),\n      ret: IFormSchema<TFormGroup>[] = [];\n    formSchema.forEach((scheme) => {\n      if (!scheme.hidden) {\n        if (isCreate)\n          scheme.presetValue =\n            scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  constructor() {\n    super();\n\n    let listenToKey: Subscription;\n    this.destroyRef.onDestroy(() => {\n      listenToKey?.unsubscribe();\n    });\n    effect(() => {\n      const ftr = this.formTagRef(),\n        submitOnEnterKey = this.submitOnEnterKey();\n      // debugger;\n\n      listenToKey?.unsubscribe();\n      if (ftr?.nativeElement && submitOnEnterKey)\n        listenToKey = fromEvent(ftr.nativeElement, 'keydown')\n          .pipe(\n            debounceTime(100),\n            filter(\n              (r: KeyboardEvent) => (r.code === 'Enter' || r.keyCode === 13) && this.form().valid,\n            ),\n          )\n          .subscribe((r: KeyboardEvent) => {\n            this.submit(this.submitBtnRef());\n          });\n    });\n  }\n\n  init(schema: IFormSchema<TFormGroup>[]) {\n    // debugger;\n    this.onDestroy();\n    this._setFormSchemas(schema || []);\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit) {\n          const formValue = this.form()?.getRawValue();\n          scheme.onChangeFunc(formValue, formValue[scheme.field?.toString()], this);\n        }\n  }\n\n  handleFormScheme(scheme: IFormSchema<TFormGroup>) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (this.formService.config.showValidationMessagesByDefault)\n      if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n        scheme.autoPickValueField = true;\n    // if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form()\n        ?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0))\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.formValue(), r, this);\n        });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: IFormSchema<TFormGroup>, options$: Observable<any[]>) {\n    options$.subscribe((r) => {\n      // scheme.options = r;\n      this.updateFormSchema(scheme.field, { options: r });\n    });\n  }\n\n  detachFormScheme(fieldName?: keyof TFormGroup) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  protected mchangeEmitter() {\n    this.mchange.emit(this.formValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    return this.formSchemaMap()[fieldName as string];\n  };\n\n  addToFormSchema(formScheme: IFormSchema<TFormGroup>) {\n    this.removeFromFormSchema(formScheme.field);\n    this.handleFormScheme(formScheme);\n  }\n\n  updateFormSchema(fieldName: keyof TFormGroup, scheme: Partial<IFormSchema<TFormGroup>>) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n  updateAllFormSchema(map: (formField: IFormSchema<TFormGroup>) => IFormSchema<TFormGroup>) {\n    return super._updateAllFormSchema(map);\n  }\n\n  removeFromFormSchema(fieldName: keyof TFormGroup) {\n    this.detachFormScheme(fieldName);\n    const onRemove = this.formSchemaMap()[fieldName as string]?.onRemoveFunc;\n    if (onRemove) onRemove(this.formValue() as any, this.formValue()[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.formValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        this.utilityService.info(this.submitSuccessText(), 1);\n        this.saved.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.formValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n  <form [formGroup]=\"form()\" #formTag>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n        gridLGStyle()\n      }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.id) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [name]=\"scheme.field\"\n                [noFormat]=\"scheme.noFormat\"\n                [verbose]=\"scheme.verbose\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationMsg]=\"scheme.showValidationMsg\" \n                [countryCode3]=\"scheme.countryCode3\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <app-autocomplete\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [presetValue]=\"scheme.presetValue\"\n                [labelField]=\"scheme.labelField\"\n                [noFormat]=\"scheme.noFormat\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                [valueField]=\"scheme.valueField\"\n                [optionsFunc]=\"scheme.optionsFunc\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'richtext') {\n              <rich-text-editor-rf\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label!\"\n                [clearOnDisable]=\"scheme.clearOnDisable!\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [labelField]=\"scheme.labelField!\"\n                [noFormat]=\"scheme.noFormat!\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug!\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag!\"\n                [optionFormatter]=\"scheme.optionFormatter!\"\n                [valueField]=\"scheme.valueField!\"\n                [optionsFunc]=\"scheme.optionsFunc!\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField!\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint!\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @default {\n              <app-input-basic\n                [noFormat]=\"scheme.noFormat\"\n                [name]=\"scheme.field\"\n                [form]=\"scheme.form || form()\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [type]=\"scheme.type\"\n                [verbose]=\"scheme.verbose\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [labelField]=\"scheme.labelField\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [decimalPoints]=\"scheme.decimalPoints\"\n                [hint]=\"scheme.hint\"\n                [max]=\"scheme.max\"\n                [min]=\"scheme.min\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n          }\n        </div>\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn()) {\n          <app-btn\n            [text]=\"submitBtnText()\"\n            group=\"submit\"\n            [form]=\"form()\"\n            (mclick)=\"submit(submitBtn)\"\n            #submitBtn />\n        }\n        @if (submitBtnTemplate()) {\n          <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n        }\n      </div>\n    </div>\n  </form>\n</loader>\n"]}