ets-fe-ng-sdk 17.0.396 → 17.0.397

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":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EAET,KAAK,EAGL,MAAM,EACN,KAAK,EACL,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,eAAe,MAAM,sCAAsC,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;;;;;AAkB9E,MAAM,OAAO,mBAAmB;IAgB9B,IAAqB,OAAO,CAAC,CAAS;QACpC,QAAQ,CAAC,EAAE;YACT,KAAK,OAAO;gBACV,IAAI,CAAC,MAAM,GAAG,sBAAsB,CAAC;gBACrC,MAAM;YAER;gBACE,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;gBAChB,MAAM;SACT;IACH,CAAC;IASD;QAhCA,eAAU,GAAG,KAAK,CAAS,IAAI,CAAC,CAAC;QACjC,UAAK,GAAG,KAAK,EAAU,CAAC;QACxB,cAAS,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAClC;;WAEG;QACH,aAAQ,GAAG,KAAK,EAAU,CAAC;QAG3B,SAAI,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAEnB,cAAS,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAaxB,0EAA0E;QACjE,SAAI,GAAG,KAAK,EAAQ,CAAC;QACrB,eAAU,GAAG,MAAM,EAAQ,CAAC;QAC5B,UAAK,GAAG,KAAK,EAAU,CAAC;QACxB,gBAAW,GAAG,MAAM,EAAU,CAAC;QAEjC,OAAE,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;IAEpB,CAAC;IAEhB,QAAQ,KAAU,CAAC;IAEnB,IAAI,QAAQ;QACV,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC;IACxB,CAAC;IACS,WAAW,CAAC,GAAG,KAAa;QACpC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IACS,SAAS;QACjB,IAAI,IAAI,CAAC,QAAQ;YAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;;YAClD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,QAAQ,CAAC,KAAU;QACjB,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAO,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,UAAU,CAAC,KAAa;QACtB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;YAC1B,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACvB,OAAO,CAAC,GAAG,KAAK,CAAC,CAAC;QACpB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAEvD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACtC,CAAC;IACD,UAAU;QACR,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC5C,GAAG,CAAC,IAAI,GAAG,MAAM,CAAC;QAClB,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QACzB,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC7B,GAAG,CAAC,QAAQ,GAAG,CAAC,CAAC,EAAE,EAAE;YACnB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YACjB,GAAG,CAAC,MAAM,EAAE,CAAC;QACf,CAAC,CAAC;QACF,kCAAkC;QAClC,GAAG,CAAC,KAAK,EAAE,CAAC;IACd,CAAC;8GA9EU,mBAAmB;kGAAnB,mBAAmB,y9DCnChC,w5CAoCA,wIDTI,OAAO,oFAEP,YAAY,y7BAEZ,aAAa,8vBACb,oBAAoB;;2FAGX,mBAAmB;kBAhB/B,SAAS;+BACE,iBAAiB,cAGf,IAAI,mBACC,uBAAuB,CAAC,OAAO,WACvC;wBACP,IAAI;wBACJ,OAAO;wBACP,KAAK;wBACL,YAAY;wBACZ,eAAe;wBACf,aAAa;wBACb,oBAAoB;qBACrB;wDAGQ,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBAGe,OAAO;sBAA3B,KAAK;uBAAC,QAAQ","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"]}
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, Input, Output, contentChild, input, model, signal, viewChild, } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, contentChild, model, signal, viewChild, } from '@angular/core';
2
2
  import { MatDialogModule } from '@angular/material/dialog';
3
3
  import { LoaderComponent } from '../loader/loader.component';
4
4
  import { ModalHeaderComponent } from '../modal-header/modal-header.component';
@@ -20,7 +20,7 @@ export class ModalComponent {
20
20
  this.uS = uS;
21
21
  this.cdr = cdr;
22
22
  this.tempRef = viewChild('temp');
23
- this.header = input();
23
+ this.header = model();
24
24
  /**
25
25
  * Specify if to show the modal header
26
26
  */
@@ -91,7 +91,7 @@ export class ModalComponent {
91
91
  this.cdr.detectChanges();
92
92
  }
93
93
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: ModalComponent, deps: [{ token: i1.UtilityService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
94
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: ModalComponent, isStandalone: true, selector: "modal-comp", inputs: { header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null }, bodyTemplateRef: { classPropertyName: "bodyTemplateRef", publicName: "bodyTemplateRef", isSignal: false, isRequired: false, transformFunction: null }, footerTemplateRef: { classPropertyName: "footerTemplateRef", publicName: "footerTemplateRef", isSignal: false, isRequired: false, transformFunction: null }, showHeader: { classPropertyName: "showHeader", publicName: "showHeader", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, _isFullscreen: { classPropertyName: "_isFullscreen", publicName: "isFullscreen", isSignal: false, isRequired: false, transformFunction: null }, showFooter: { classPropertyName: "showFooter", publicName: "showFooter", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: false, isRequired: false, transformFunction: null }, minWidth: { classPropertyName: "minWidth", publicName: "minWidth", isSignal: false, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: false, isRequired: false, transformFunction: null }, maxHeight: { classPropertyName: "maxHeight", publicName: "maxHeight", isSignal: false, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: false, isRequired: false, transformFunction: null }, data: { classPropertyName: "data", publicName: "data", isSignal: false, isRequired: false, transformFunction: null }, disableClose: { classPropertyName: "disableClose", publicName: "disableClose", isSignal: false, isRequired: false, transformFunction: null }, hasBackdrop: { classPropertyName: "hasBackdrop", publicName: "hasBackdrop", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { showHeader: "showHeaderChange", loading: "loadingChange", showFooter: "showFooterChange", modalOpen: "modalOpen", modalClose: "modalClose" }, queries: [{ propertyName: "bodyTemplate", first: true, predicate: ModalBodyDirective, descendants: true, isSignal: true }, { propertyName: "footerTemplate", first: true, predicate: ModalFooterDirective, descendants: true, isSignal: true }], viewQueries: [{ propertyName: "tempRef", first: true, predicate: ["temp"], descendants: true, isSignal: true }], ngImport: i0, template: "<ng-template #temp>\n <loader [loading]=\"loading()\" [height]=\"cont.offsetHeight\" #loader>\n <div #cont class=\"h-100 modal-comp\"> \n @if (showHeader()) {\n <modal-header [header]=\"header() | trim\" [dialogRef]=\"dialogRef()\" />\n }\n <div\n mat-dialog-content\n class=\"{{ isFullscreen() ? 'p-0' : 'mt-2 px-0 pb-2 pt-0' }} overflow-x-hidden {{\n showFooter() ? '' : 'noFooter h-100'\n }} \">\n <ng-content select=\"[body]\"></ng-content>\n @if (isLoaded()) {\n <ng-container [ngTemplateOutlet]=\"bodyTemplate()?.templateRef\" />\n }\n </div>\n @if (showFooter()) {\n <div mat-dialog-actions class=\"justify-content-end\">\n <ng-content select=\"[footer]\"></ng-content>\n @if (isOpened()) {\n <ng-container [ngTemplateOutlet]=\"footerTemplate()?.templateRef\" />\n }\n </div>\n }\n </div>\n </loader>\n\n <!-- wdwwd -->\n</ng-template>\n", styles: ["::ng-deep .noFooter{max-height:calc(100% - 60px)!important}::ng-deep .loading-content-container{height:100%}\n"], dependencies: [{ kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ModalHeaderComponent, selector: "modal-header", inputs: ["dialogRef", "header", "onCloseValue"], outputs: ["close"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i3.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i3.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "pipe", type: TrimPipe, name: "trim" }] }); }
94
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: ModalComponent, isStandalone: true, selector: "modal-comp", inputs: { header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null }, bodyTemplateRef: { classPropertyName: "bodyTemplateRef", publicName: "bodyTemplateRef", isSignal: false, isRequired: false, transformFunction: null }, footerTemplateRef: { classPropertyName: "footerTemplateRef", publicName: "footerTemplateRef", isSignal: false, isRequired: false, transformFunction: null }, showHeader: { classPropertyName: "showHeader", publicName: "showHeader", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, _isFullscreen: { classPropertyName: "_isFullscreen", publicName: "isFullscreen", isSignal: false, isRequired: false, transformFunction: null }, showFooter: { classPropertyName: "showFooter", publicName: "showFooter", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: false, isRequired: false, transformFunction: null }, minWidth: { classPropertyName: "minWidth", publicName: "minWidth", isSignal: false, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: false, isRequired: false, transformFunction: null }, maxHeight: { classPropertyName: "maxHeight", publicName: "maxHeight", isSignal: false, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: false, isRequired: false, transformFunction: null }, data: { classPropertyName: "data", publicName: "data", isSignal: false, isRequired: false, transformFunction: null }, disableClose: { classPropertyName: "disableClose", publicName: "disableClose", isSignal: false, isRequired: false, transformFunction: null }, hasBackdrop: { classPropertyName: "hasBackdrop", publicName: "hasBackdrop", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { header: "headerChange", showHeader: "showHeaderChange", loading: "loadingChange", showFooter: "showFooterChange", modalOpen: "modalOpen", modalClose: "modalClose" }, queries: [{ propertyName: "bodyTemplate", first: true, predicate: ModalBodyDirective, descendants: true, isSignal: true }, { propertyName: "footerTemplate", first: true, predicate: ModalFooterDirective, descendants: true, isSignal: true }], viewQueries: [{ propertyName: "tempRef", first: true, predicate: ["temp"], descendants: true, isSignal: true }], ngImport: i0, template: "<ng-template #temp>\n <loader [loading]=\"loading()\" [height]=\"cont.offsetHeight\" #loader>\n <div #cont class=\"h-100 modal-comp\"> \n @if (showHeader()) {\n <modal-header [header]=\"header() | trim\" [dialogRef]=\"dialogRef()\" />\n }\n <div\n mat-dialog-content\n class=\"{{ isFullscreen() ? 'p-0' : 'mt-2 px-0 pb-2 pt-0' }} overflow-x-hidden {{\n showFooter() ? '' : 'noFooter h-100'\n }} \">\n <ng-content select=\"[body]\"></ng-content>\n @if (isLoaded()) {\n <ng-container [ngTemplateOutlet]=\"bodyTemplate()?.templateRef\" />\n }\n </div>\n @if (showFooter()) {\n <div mat-dialog-actions class=\"justify-content-end\">\n <ng-content select=\"[footer]\"></ng-content>\n @if (isOpened()) {\n <ng-container [ngTemplateOutlet]=\"footerTemplate()?.templateRef\" />\n }\n </div>\n }\n </div>\n </loader>\n\n <!-- wdwwd -->\n</ng-template>\n", styles: ["::ng-deep .noFooter{max-height:calc(100% - 60px)!important}::ng-deep .loading-content-container{height:100%}\n"], dependencies: [{ kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ModalHeaderComponent, selector: "modal-header", inputs: ["dialogRef", "header", "onCloseValue"], outputs: ["close"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i3.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i3.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "pipe", type: TrimPipe, name: "trim" }] }); }
95
95
  }
96
96
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: ModalComponent, decorators: [{
97
97
  type: Component,
@@ -124,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
124
124
  }], modalClose: [{
125
125
  type: Output
126
126
  }] } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/modal/modal.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild,\n  contentChild,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport { MatDialogRef as MatDialogRef, MatDialogModule } from '@angular/material/dialog';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { ModalHeaderComponent } from '../modal-header/modal-header.component';\nimport { CommonModule } from '@angular/common';\nimport { TrimPipe } from '../../pipes/utility.pipe';\n\nimport { UtilityService } from '../../../Services/utility.service';\nimport { IconType } from '../btn/btn.model';\nimport { ModalBodyDirective } from './modal-body.directive';\nimport { ModalFooterDirective } from './modal-footer.directive';\n\n@Component({\n  selector: 'modal-comp',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  standalone: true,\n  imports: [LoaderComponent, CommonModule, ModalHeaderComponent, MatDialogModule, TrimPipe],\n})\nexport class ModalComponent implements OnInit {\n  protected readonly tempRef = viewChild<TemplateRef<any>>('temp');\n  readonly header = input<string>();\n  /**\n   * When using lazyloader\n   */\n  @Input() bodyTemplateRef: TemplateRef<any>;\n  /**\n   * When using lazyloader\n   */\n  @Input() footerTemplateRef: TemplateRef<any>;\n  /**\n   * Specify if to show the modal header\n   */\n  readonly showHeader = model<boolean>(true);\n  readonly loading = model<boolean>();\n  protected readonly isFullscreen = signal<boolean>(false);\n  @Input('isFullscreen') set _isFullscreen(v: boolean) {\n    this.isFullscreen.set(v);\n    this.showHeader.set(false);\n    this.showFooter.set(false);\n  }\n  /**\n   * Specify if to show the footer section\n   */\n  readonly showFooter = model<boolean>(true);\n  @Input() width: string = 'auto';\n  @Input() minWidth: string = 'auto';\n  @Input() height: string = 'auto';\n  @Input() maxHeight: string = '90vh';\n  @Input() icon: IconType;\n  @Input() data: { [x: string]: any } = {};\n  @Input() disableClose: boolean = false;\n  @Input() hasBackdrop: boolean = true;\n  protected readonly dialogRef = signal<MatDialogRef<any>>(undefined);\n  @Output() modalOpen = new EventEmitter<boolean>();\n  @Output() modalClose = new EventEmitter<boolean>();\n  // public dialogRef: MatDialogRef<typeof this.tempRef>;\n  // public dialogRef: MatDialogRef<ModalComponent>;\n  protected readonly isOpened = signal<boolean>(false);\n  protected readonly isLoaded = signal<boolean>(false);\n  // loaded: boolean = false;\n\n  bodyTemplate = contentChild(ModalBodyDirective);\n  footerTemplate = contentChild(ModalFooterDirective);\n\n  constructor(\n    public uS: UtilityService,\n    public cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit(): void {}\n\n  open(...args) {\n    if (this.isOpened()) return;\n    this.isOpened.set(true);\n    this.isLoaded.set(true);\n    // this.loaded = true;\n    // debugger;\n    this.dialogRef.set(\n      this.uS.dialogOpenerRef(this.tempRef(), {\n        width: this.uS.isMobile ? '90%' : this.width,\n        height: this.height,\n        minWidth: this.uS.isMobile ? '90%' : this.minWidth,\n        maxHeight: this.maxHeight,\n        maxWidth: '100vw',\n        autoFocus: false,\n        disableClose: this.disableClose,\n        hasBackdrop: this.hasBackdrop,\n      }),\n    );\n    this.dialogRef()\n      .afterOpened()\n      .subscribe((r) => {\n        this.cdr.detectChanges();\n        this.modalOpen.emit(true);\n      });\n    this.dialogRef()\n      .afterClosed()\n      .subscribe((r) => {\n        this.cdr.detectChanges();\n        this.isOpened.set(false);\n        this.modalClose.emit(true);\n      });\n    this.cdr.detectChanges();\n  }\n\n  close() {\n    // debugger;\n    if (!this.isOpened()) return;\n    this.dialogRef()?.close();\n    this.isOpened.set(false);\n    this.cdr.detectChanges();\n  }\n}\n","<ng-template #temp>\n  <loader [loading]=\"loading()\" [height]=\"cont.offsetHeight\" #loader>\n    <div #cont class=\"h-100 modal-comp\"> \n      @if (showHeader()) {\n        <modal-header [header]=\"header() | trim\" [dialogRef]=\"dialogRef()\" />\n      }\n      <div\n        mat-dialog-content\n        class=\"{{ isFullscreen() ? 'p-0' : 'mt-2 px-0 pb-2 pt-0' }} overflow-x-hidden {{\n          showFooter() ? '' : 'noFooter h-100'\n        }} \">\n        <ng-content select=\"[body]\"></ng-content>\n        @if (isLoaded()) {\n          <ng-container [ngTemplateOutlet]=\"bodyTemplate()?.templateRef\" />\n        }\n      </div>\n      @if (showFooter()) {\n        <div mat-dialog-actions class=\"justify-content-end\">\n          <ng-content select=\"[footer]\"></ng-content>\n          @if (isOpened()) {\n            <ng-container [ngTemplateOutlet]=\"footerTemplate()?.templateRef\" />\n          }\n        </div>\n      }\n    </div>\n  </loader>\n\n  <!-- wdwwd -->\n</ng-template>\n"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/modal/modal.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild,\n  contentChild,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport { MatDialogRef as MatDialogRef, MatDialogModule } from '@angular/material/dialog';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { ModalHeaderComponent } from '../modal-header/modal-header.component';\nimport { CommonModule } from '@angular/common';\nimport { TrimPipe } from '../../pipes/utility.pipe';\n\nimport { UtilityService } from '../../../Services/utility.service';\nimport { IconType } from '../btn/btn.model';\nimport { ModalBodyDirective } from './modal-body.directive';\nimport { ModalFooterDirective } from './modal-footer.directive';\n\n@Component({\n  selector: 'modal-comp',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  standalone: true,\n  imports: [LoaderComponent, CommonModule, ModalHeaderComponent, MatDialogModule, TrimPipe],\n})\nexport class ModalComponent implements OnInit {\n  protected readonly tempRef = viewChild<TemplateRef<any>>('temp');\n  readonly header = model<string>();\n  /**\n   * When using lazyloader\n   */\n  @Input() bodyTemplateRef: TemplateRef<any>;\n  /**\n   * When using lazyloader\n   */\n  @Input() footerTemplateRef: TemplateRef<any>;\n  /**\n   * Specify if to show the modal header\n   */\n  readonly showHeader = model<boolean>(true);\n  readonly loading = model<boolean>();\n  protected readonly isFullscreen = signal<boolean>(false);\n  @Input('isFullscreen') set _isFullscreen(v: boolean) {\n    this.isFullscreen.set(v);\n    this.showHeader.set(false);\n    this.showFooter.set(false);\n  }\n  /**\n   * Specify if to show the footer section\n   */\n  readonly showFooter = model<boolean>(true);\n  @Input() width: string = 'auto';\n  @Input() minWidth: string = 'auto';\n  @Input() height: string = 'auto';\n  @Input() maxHeight: string = '90vh';\n  @Input() icon: IconType;\n  @Input() data: { [x: string]: any } = {};\n  @Input() disableClose: boolean = false;\n  @Input() hasBackdrop: boolean = true;\n  protected readonly dialogRef = signal<MatDialogRef<any>>(undefined);\n  @Output() modalOpen = new EventEmitter<boolean>();\n  @Output() modalClose = new EventEmitter<boolean>();\n  // public dialogRef: MatDialogRef<typeof this.tempRef>;\n  // public dialogRef: MatDialogRef<ModalComponent>;\n  protected readonly isOpened = signal<boolean>(false);\n  protected readonly isLoaded = signal<boolean>(false);\n  // loaded: boolean = false;\n\n  bodyTemplate = contentChild(ModalBodyDirective);\n  footerTemplate = contentChild(ModalFooterDirective);\n\n  constructor(\n    public uS: UtilityService,\n    public cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit(): void {}\n\n  open(...args) {\n    if (this.isOpened()) return;\n    this.isOpened.set(true);\n    this.isLoaded.set(true);\n    // this.loaded = true;\n    // debugger;\n    this.dialogRef.set(\n      this.uS.dialogOpenerRef(this.tempRef(), {\n        width: this.uS.isMobile ? '90%' : this.width,\n        height: this.height,\n        minWidth: this.uS.isMobile ? '90%' : this.minWidth,\n        maxHeight: this.maxHeight,\n        maxWidth: '100vw',\n        autoFocus: false,\n        disableClose: this.disableClose,\n        hasBackdrop: this.hasBackdrop,\n      }),\n    );\n    this.dialogRef()\n      .afterOpened()\n      .subscribe((r) => {\n        this.cdr.detectChanges();\n        this.modalOpen.emit(true);\n      });\n    this.dialogRef()\n      .afterClosed()\n      .subscribe((r) => {\n        this.cdr.detectChanges();\n        this.isOpened.set(false);\n        this.modalClose.emit(true);\n      });\n    this.cdr.detectChanges();\n  }\n\n  close() {\n    // debugger;\n    if (!this.isOpened()) return;\n    this.dialogRef()?.close();\n    this.isOpened.set(false);\n    this.cdr.detectChanges();\n  }\n}\n","<ng-template #temp>\n  <loader [loading]=\"loading()\" [height]=\"cont.offsetHeight\" #loader>\n    <div #cont class=\"h-100 modal-comp\"> \n      @if (showHeader()) {\n        <modal-header [header]=\"header() | trim\" [dialogRef]=\"dialogRef()\" />\n      }\n      <div\n        mat-dialog-content\n        class=\"{{ isFullscreen() ? 'p-0' : 'mt-2 px-0 pb-2 pt-0' }} overflow-x-hidden {{\n          showFooter() ? '' : 'noFooter h-100'\n        }} \">\n        <ng-content select=\"[body]\"></ng-content>\n        @if (isLoaded()) {\n          <ng-container [ngTemplateOutlet]=\"bodyTemplate()?.templateRef\" />\n        }\n      </div>\n      @if (showFooter()) {\n        <div mat-dialog-actions class=\"justify-content-end\">\n          <ng-content select=\"[footer]\"></ng-content>\n          @if (isOpened()) {\n            <ng-container [ngTemplateOutlet]=\"footerTemplate()?.templateRef\" />\n          }\n        </div>\n      }\n    </div>\n  </loader>\n\n  <!-- wdwwd -->\n</ng-template>\n"]}