ets-fe-ng-sdk 17.0.384 → 17.0.385
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/Shared/components/fields-to-display/fields-to-display.component.mjs +2 -2
- package/esm2022/lib/Shared/components/file-upload/file-upload.component.mjs +2 -2
- package/esm2022/lib/Shared/components/modal/modal.component.mjs +35 -43
- package/esm2022/lib/Shared/components/modal-form/modal-form.component.mjs +3 -3
- package/esm2022/lib/Shared/components/modal-header/modal-header.component.mjs +13 -16
- package/esm2022/lib/Shared/components/table-https/table-https.component.mjs +2 -2
- package/esm2022/lib/Shared/components/table-input/table-input-row/table-input-row.component.mjs +2 -2
- package/esm2022/lib/Shared/components/table-plain/table-plain.component.mjs +2 -2
- package/fesm2022/ets-fe-ng-sdk.mjs +52 -63
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Shared/components/btn/btn.component.d.ts +2 -2
- package/lib/Shared/components/index-comp-layout/index-comp-layout.component.d.ts +1 -1
- package/lib/Shared/components/info-dialog/info-dialog.component.d.ts +1 -1
- package/lib/Shared/components/modal/modal.component.d.ts +12 -14
- package/lib/Shared/components/modal-form/modal-form.component.d.ts +0 -1
- package/lib/Shared/components/modal-header/modal-header.component.d.ts +6 -6
- package/lib/Shared/components/table-https/table-https.component.d.ts +3 -3
- package/package.json +1 -1
|
@@ -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.0", ngImport: i0, type: FieldsToDisplayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
78
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", 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: ["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" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
78
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", 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", "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" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
79
79
|
}
|
|
80
80
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: FieldsToDisplayComponent, decorators: [{
|
|
81
81
|
type: Component,
|
|
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", 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.0", ngImport: i0, type: FileUploadComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
81
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", 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: ["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.0", 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", "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.0", ngImport: i0, type: FileUploadComponent, decorators: [{
|
|
84
84
|
type: Component,
|
|
@@ -105,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", 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"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, EventEmitter, Input, Output, contentChild, input, 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';
|
|
@@ -12,20 +12,24 @@ import * as i2 from "@angular/common";
|
|
|
12
12
|
import * as i3 from "@angular/material/dialog";
|
|
13
13
|
export class ModalComponent {
|
|
14
14
|
set _isFullscreen(v) {
|
|
15
|
-
this.isFullscreen
|
|
16
|
-
this.showHeader
|
|
17
|
-
this.showFooter
|
|
15
|
+
this.isFullscreen.set(v);
|
|
16
|
+
this.showHeader.set(false);
|
|
17
|
+
this.showFooter.set(false);
|
|
18
18
|
}
|
|
19
19
|
constructor(uS) {
|
|
20
20
|
this.uS = uS;
|
|
21
|
+
this.tempRef = viewChild('temp');
|
|
22
|
+
this.header = input();
|
|
21
23
|
/**
|
|
22
24
|
* Specify if to show the modal header
|
|
23
25
|
*/
|
|
24
|
-
this.showHeader = true;
|
|
26
|
+
this.showHeader = model(true);
|
|
27
|
+
this.loading = input();
|
|
28
|
+
this.isFullscreen = signal(false);
|
|
25
29
|
/**
|
|
26
30
|
* Specify if to show the footer section
|
|
27
31
|
*/
|
|
28
|
-
this.showFooter = true;
|
|
32
|
+
this.showFooter = model(true);
|
|
29
33
|
this.width = 'auto';
|
|
30
34
|
this.minWidth = 'auto';
|
|
31
35
|
this.height = 'auto';
|
|
@@ -33,22 +37,26 @@ export class ModalComponent {
|
|
|
33
37
|
this.data = {};
|
|
34
38
|
this.disableClose = false;
|
|
35
39
|
this.hasBackdrop = true;
|
|
40
|
+
this.dialogRef = signal(undefined);
|
|
36
41
|
this.modalOpen = new EventEmitter();
|
|
37
42
|
this.modalClose = new EventEmitter();
|
|
38
43
|
// public dialogRef: MatDialogRef<typeof this.tempRef>;
|
|
39
44
|
// public dialogRef: MatDialogRef<ModalComponent>;
|
|
40
|
-
this.isOpened = false;
|
|
41
|
-
this.isLoaded = false;
|
|
45
|
+
this.isOpened = signal(false);
|
|
46
|
+
this.isLoaded = signal(false);
|
|
47
|
+
// loaded: boolean = false;
|
|
48
|
+
this.bodyTemplate = contentChild(ModalBodyDirective);
|
|
49
|
+
this.footerTemplate = contentChild(ModalFooterDirective);
|
|
42
50
|
}
|
|
43
51
|
ngOnInit() { }
|
|
44
52
|
open(...args) {
|
|
45
|
-
if (this.isOpened)
|
|
53
|
+
if (this.isOpened())
|
|
46
54
|
return;
|
|
47
|
-
this.isOpened
|
|
48
|
-
this.isLoaded
|
|
55
|
+
this.isOpened.set(true);
|
|
56
|
+
this.isLoaded.set(true);
|
|
49
57
|
// this.loaded = true;
|
|
50
58
|
// debugger;
|
|
51
|
-
this.dialogRef
|
|
59
|
+
this.dialogRef.set(this.uS.dialogOpenerRef(this.tempRef(), {
|
|
52
60
|
width: this.uS.isMobile ? '90%' : this.width,
|
|
53
61
|
height: this.height,
|
|
54
62
|
minWidth: this.uS.isMobile ? '90%' : this.minWidth,
|
|
@@ -57,49 +65,39 @@ export class ModalComponent {
|
|
|
57
65
|
autoFocus: false,
|
|
58
66
|
disableClose: this.disableClose,
|
|
59
67
|
hasBackdrop: this.hasBackdrop,
|
|
60
|
-
});
|
|
61
|
-
this.dialogRef
|
|
68
|
+
}));
|
|
69
|
+
this.dialogRef()
|
|
70
|
+
.afterOpened()
|
|
71
|
+
.subscribe((r) => {
|
|
62
72
|
this.modalOpen.emit(true);
|
|
63
73
|
});
|
|
64
|
-
this.dialogRef
|
|
65
|
-
|
|
74
|
+
this.dialogRef()
|
|
75
|
+
.afterClosed()
|
|
76
|
+
.subscribe((r) => {
|
|
77
|
+
this.isOpened.set(false);
|
|
66
78
|
this.modalClose.emit(true);
|
|
67
79
|
});
|
|
68
80
|
}
|
|
69
81
|
close() {
|
|
70
82
|
// debugger;
|
|
71
|
-
if (!this.isOpened)
|
|
83
|
+
if (!this.isOpened())
|
|
72
84
|
return;
|
|
73
|
-
this.dialogRef
|
|
74
|
-
this.isOpened
|
|
85
|
+
this.dialogRef()?.close();
|
|
86
|
+
this.isOpened.set(false);
|
|
75
87
|
}
|
|
76
88
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ModalComponent, deps: [{ token: i1.UtilityService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: ModalComponent, isStandalone: true, selector: "modal-comp", inputs: { header: "header", bodyTemplateRef: "bodyTemplateRef", footerTemplateRef: "footerTemplateRef", showHeader: "showHeader", loading: "loading",
|
|
89
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", 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", 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\"></ng-container>\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\"></ng-container>\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" }] }); }
|
|
78
90
|
}
|
|
79
91
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ModalComponent, decorators: [{
|
|
80
92
|
type: Component,
|
|
81
|
-
args: [{ selector: 'modal-comp', standalone: true, imports: [LoaderComponent, CommonModule, ModalHeaderComponent, MatDialogModule, TrimPipe], 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\"></ng-container>\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\"></ng-container>\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"] }]
|
|
82
|
-
}], ctorParameters: () => [{ type: i1.UtilityService }], propDecorators: {
|
|
83
|
-
type: ViewChild,
|
|
84
|
-
args: ['temp']
|
|
85
|
-
}], loaderRef: [{
|
|
86
|
-
type: ViewChild,
|
|
87
|
-
args: ['loader']
|
|
88
|
-
}], header: [{
|
|
89
|
-
type: Input
|
|
90
|
-
}], bodyTemplateRef: [{
|
|
93
|
+
args: [{ selector: 'modal-comp', standalone: true, imports: [LoaderComponent, CommonModule, ModalHeaderComponent, MatDialogModule, TrimPipe], 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\"></ng-container>\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\"></ng-container>\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"] }]
|
|
94
|
+
}], ctorParameters: () => [{ type: i1.UtilityService }], propDecorators: { bodyTemplateRef: [{
|
|
91
95
|
type: Input
|
|
92
96
|
}], footerTemplateRef: [{
|
|
93
97
|
type: Input
|
|
94
|
-
}], showHeader: [{
|
|
95
|
-
type: Input
|
|
96
|
-
}], loading: [{
|
|
97
|
-
type: Input
|
|
98
98
|
}], _isFullscreen: [{
|
|
99
99
|
type: Input,
|
|
100
100
|
args: ['isFullscreen']
|
|
101
|
-
}], showFooter: [{
|
|
102
|
-
type: Input
|
|
103
101
|
}], width: [{
|
|
104
102
|
type: Input
|
|
105
103
|
}], minWidth: [{
|
|
@@ -120,11 +118,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
120
118
|
type: Output
|
|
121
119
|
}], modalClose: [{
|
|
122
120
|
type: Output
|
|
123
|
-
}], bodyTemplate: [{
|
|
124
|
-
type: ContentChild,
|
|
125
|
-
args: [ModalBodyDirective]
|
|
126
|
-
}], footerTemplate: [{
|
|
127
|
-
type: ContentChild,
|
|
128
|
-
args: [ModalFooterDirective]
|
|
129
121
|
}] } });
|
|
130
|
-
//# 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 { Component, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild } 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 { Directive } from '@angular/core';\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\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  @ViewChild('temp') tempRef: TemplateRef<any>;\n  @ViewChild('loader') loaderRef: LoaderComponent;\n  @Input() header: 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  @Input() showHeader: boolean = true;\n  @Input() loading: boolean;\n  isFullscreen: boolean;\n  @Input('isFullscreen') set _isFullscreen(v: boolean) {\n    this.isFullscreen = v;\n    this.showHeader = false;\n    this.showFooter = false;\n  }\n  /**\n   * Specify if to show the footer section\n   */\n  @Input() showFooter = 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  public dialogRef: MatDialogRef<any>;\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 isOpened: boolean = false;\n  protected isLoaded: boolean = false;\n  // loaded: boolean = false;\n\n  @ContentChild(ModalBodyDirective) bodyTemplate: ModalBodyDirective;\n  @ContentChild(ModalFooterDirective) footerTemplate: ModalFooterDirective;\n\n  constructor(public uS: UtilityService) {}\n\n  ngOnInit(): void {}\n\n  open(...args) {\n    if (this.isOpened) return;\n    this.isOpened = true;\n    this.isLoaded = true;\n    // this.loaded = true;\n    // debugger;\n    this.dialogRef = 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    this.dialogRef.afterOpened().subscribe((r) => {\n      this.modalOpen.emit(true);\n    });\n    this.dialogRef.afterClosed().subscribe((r) => {\n      this.isOpened = false;\n      this.modalClose.emit(true);\n    });\n  }\n\n  close() {\n    // debugger;\n    if (!this.isOpened) return;\n    this.dialogRef.close();\n    this.isOpened = false;\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\"></ng-container>\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\"></ng-container>\n          }\n        </div>\n      }\n    </div>\n  </loader>\n\n  <!-- wdwwd -->\n</ng-template>\n"]}
|
|
122
|
+
//# 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  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  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 = input<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 isOpened = signal<boolean>(false);\n  protected isLoaded = signal<boolean>(false);\n  // loaded: boolean = false;\n\n  bodyTemplate = contentChild(ModalBodyDirective);\n  footerTemplate = contentChild(ModalFooterDirective);\n\n  constructor(public uS: UtilityService) {}\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.modalOpen.emit(true);\n      });\n    this.dialogRef()\n      .afterClosed()\n      .subscribe((r) => {\n        this.isOpened.set(false);\n        this.modalClose.emit(true);\n      });\n  }\n\n  close() {\n    // debugger;\n    if (!this.isOpened()) return;\n    this.dialogRef()?.close();\n    this.isOpened.set(false);\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\"></ng-container>\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\"></ng-container>\n          }\n        </div>\n      }\n    </div>\n  </loader>\n\n  <!-- wdwwd -->\n</ng-template>\n"]}
|
|
@@ -23,11 +23,11 @@ export class ModalFormComponent extends ModalComponent {
|
|
|
23
23
|
super.open();
|
|
24
24
|
}
|
|
25
25
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ModalFormComponent, deps: [{ token: i1.UtilityService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
26
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: ModalFormComponent, isStandalone: true, selector: "modal-form", inputs: { keyField: "keyField", submitFunc: "submitFunc", text: "text", contextData: "contextData", gridStyle: "gridStyle", gridMDStyle: "gridMDStyle", gridXXLStyle: "gridXXLStyle", form: "form", formSchema: "formSchema" }, outputs: { submitted: "submitted" }, usesInheritance: true, ngImport: i0, template: "<ng-template #temp>\n <modal-header [header]=\"header\" [dialogRef]=\"dialogRef\" />\n <loader [loading]=\"loading\">\n <div mat-dialog-content>\n <form-generator\n [form]=\"form\"\n [formSchema]=\"formSchema\"\n [gridStyle]=\"gridStyle\"\n [gridMDStyle]=\"gridMDStyle\"\n [gridXXLStyle]=\"gridXXLStyle\"\n [submitFunc]=\"submitFunc\"\n [submitBtnText]=\"text\"\n [showSubmitBtn]=\"false\"\n />\n </div>\n <div mat-dialog-actions>\n <div class=\"row row-cols-auto justify-content-end\">\n <app-btn\n [text]=\"text\"\n group=\"submit\"\n [form]=\"form\"\n (mclick)=\"submitted.emit(this.form.value); dialogRef
|
|
26
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: ModalFormComponent, isStandalone: true, selector: "modal-form", inputs: { keyField: "keyField", submitFunc: "submitFunc", text: "text", contextData: "contextData", gridStyle: "gridStyle", gridMDStyle: "gridMDStyle", gridXXLStyle: "gridXXLStyle", form: "form", formSchema: "formSchema" }, outputs: { submitted: "submitted" }, usesInheritance: true, ngImport: i0, template: "<ng-template #temp>\n <modal-header [header]=\"header()\" [dialogRef]=\"dialogRef()\" />\n <loader [loading]=\"loading()\">\n <div mat-dialog-content>\n <form-generator\n [form]=\"form\"\n [formSchema]=\"formSchema\"\n [gridStyle]=\"gridStyle\"\n [gridMDStyle]=\"gridMDStyle\"\n [gridXXLStyle]=\"gridXXLStyle\"\n [submitFunc]=\"submitFunc\"\n [submitBtnText]=\"text\"\n [showSubmitBtn]=\"false\"\n />\n </div>\n <div mat-dialog-actions>\n <div class=\"row row-cols-auto justify-content-end\">\n <app-btn\n [text]=\"text\"\n group=\"submit\"\n [form]=\"form\"\n (mclick)=\"submitted.emit(this.form.value); dialogRef()?.close()\"\n ></app-btn>\n </div>\n </div>\n </loader>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "component", type: ModalHeaderComponent, selector: "modal-header", inputs: ["dialogRef", "header", "onCloseValue"], outputs: ["close"] }, { kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "component", type: FormGeneratorComponent, selector: "form-generator", inputs: ["keyField", "presetValueForSingleOption", "isCreate", "submitOnEnterKey", "submitFunc", "submitBtnText", "submitBtnTemplate", "submitSuccessText", "showSubmitBtn", "gridStyle", "gridMDStyle", "gridLGStyle", "gridXXLStyle", "formGridClass", "useLoader", "loading", "form", "formSchema", "formSchemaNoForm", "isShow"], outputs: ["onSubmit", "mchange", "saved", "formChange"] }, { 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"] }] }); }
|
|
27
27
|
}
|
|
28
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ModalFormComponent, decorators: [{
|
|
29
29
|
type: Component,
|
|
30
|
-
args: [{ selector: 'modal-form', standalone: true, imports: [ModalHeaderComponent, LoaderComponent, FormGeneratorComponent, BtnComponent], template: "<ng-template #temp>\n <modal-header [header]=\"header\" [dialogRef]=\"dialogRef\" />\n <loader [loading]=\"loading\">\n <div mat-dialog-content>\n <form-generator\n [form]=\"form\"\n [formSchema]=\"formSchema\"\n [gridStyle]=\"gridStyle\"\n [gridMDStyle]=\"gridMDStyle\"\n [gridXXLStyle]=\"gridXXLStyle\"\n [submitFunc]=\"submitFunc\"\n [submitBtnText]=\"text\"\n [showSubmitBtn]=\"false\"\n />\n </div>\n <div mat-dialog-actions>\n <div class=\"row row-cols-auto justify-content-end\">\n <app-btn\n [text]=\"text\"\n group=\"submit\"\n [form]=\"form\"\n (mclick)=\"submitted.emit(this.form.value); dialogRef
|
|
30
|
+
args: [{ selector: 'modal-form', standalone: true, imports: [ModalHeaderComponent, LoaderComponent, FormGeneratorComponent, BtnComponent], template: "<ng-template #temp>\n <modal-header [header]=\"header()\" [dialogRef]=\"dialogRef()\" />\n <loader [loading]=\"loading()\">\n <div mat-dialog-content>\n <form-generator\n [form]=\"form\"\n [formSchema]=\"formSchema\"\n [gridStyle]=\"gridStyle\"\n [gridMDStyle]=\"gridMDStyle\"\n [gridXXLStyle]=\"gridXXLStyle\"\n [submitFunc]=\"submitFunc\"\n [submitBtnText]=\"text\"\n [showSubmitBtn]=\"false\"\n />\n </div>\n <div mat-dialog-actions>\n <div class=\"row row-cols-auto justify-content-end\">\n <app-btn\n [text]=\"text\"\n group=\"submit\"\n [form]=\"form\"\n (mclick)=\"submitted.emit(this.form.value); dialogRef()?.close()\"\n ></app-btn>\n </div>\n </div>\n </loader>\n</ng-template>\n" }]
|
|
31
31
|
}], ctorParameters: () => [{ type: i1.UtilityService }], propDecorators: { keyField: [{
|
|
32
32
|
type: Input
|
|
33
33
|
}], submitted: [{
|
|
@@ -49,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
49
49
|
}], formSchema: [{
|
|
50
50
|
type: Input
|
|
51
51
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtZm9ybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvU2hhcmVkL2NvbXBvbmVudHMvbW9kYWwtZm9ybS9tb2RhbC1mb3JtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V0cy1mZS1uZy1zZGsvc3JjL2xpYi9TaGFyZWQvY29tcG9uZW50cy9tb2RhbC1mb3JtL21vZGFsLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzFELE9BQU8sRUFDTCxTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFBRSxNQUFNLEVBQ2QsTUFBTSxlQUFlLENBQUM7QUFLdkIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQzs7O0FBVTlFLE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxjQUFjO0lBZ0JwRCxZQUE0QixFQUFrQjtRQUM1QyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7UUFEZ0IsT0FBRSxHQUFGLEVBQUUsQ0FBZ0I7UUFmckMsYUFBUSxHQUFzQixPQUFPLENBQUM7UUFDckMsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFHckMsU0FBSSxHQUFXLE1BQU0sQ0FBQztRQVEvQixlQUFVLEdBQWlCLEVBQUUsQ0FBQztRQUM5QixzQkFBaUIsR0FBaUIsRUFBRSxDQUFDO0lBSXJDLENBQUM7SUFFUSxRQUFRLEtBQVUsQ0FBQztJQUVuQixJQUFJLENBQUMsV0FBVztRQUN2QixJQUFJLFdBQVcsSUFBSSxJQUFJO1lBQUUsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7UUFDeEQsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2YsQ0FBQzs4R0F6QlUsa0JBQWtCO2tHQUFsQixrQkFBa0Isa1dDdkIvQixnMEJBMkJBLDBERE5jLG9CQUFvQiw4SEFBRSxlQUFlLHVIQUFFLHNCQUFzQiwwYkFBRSxZQUFZOzsyRkFFNUUsa0JBQWtCO2tCQVA5QixTQUFTOytCQUNJLFlBQVksY0FHVixJQUFJLFdBQ1AsQ0FBQyxvQkFBb0IsRUFBRSxlQUFlLEVBQUUsc0JBQXNCLEVBQUUsWUFBWSxDQUFDO21GQUcvRSxRQUFRO3NCQUFoQixLQUFLO2dCQUNJLFNBQVM7c0JBQWxCLE1BQU07Z0JBQ0UsVUFBVTtzQkFBbEIsS0FBSztnQkFFRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBRUcsVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZGFsQ29tcG9uZW50IH0gZnJvbSAnLi4vbW9kYWwvbW9kYWwuY29tcG9uZW50JztcbmltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCwgT3V0cHV0XG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgRm9ybUdyb3VwXG59IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IElGb3JtT3B0aW9ucywgSUZvcm1TY2hlbWEgfSBmcm9tICcuLi8uLi9tb2RlbHMvZm9ybS1zY2hlbWEubW9kZWwnO1xuaW1wb3J0IHsgQnRuQ29tcG9uZW50IH0gZnJvbSAnLi4vYnRuL2J0bi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9ybUdlbmVyYXRvckNvbXBvbmVudCB9IGZyb20gJy4uL2Zvcm0tZ2VuZXJhdG9yL2Zvcm0tZ2VuZXJhdG9yLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBMb2FkZXJDb21wb25lbnQgfSBmcm9tICcuLi9sb2FkZXIvbG9hZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNb2RhbEhlYWRlckNvbXBvbmVudCB9IGZyb20gJy4uL21vZGFsLWhlYWRlci9tb2RhbC1oZWFkZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFV0aWxpdHlTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vU2VydmljZXMvdXRpbGl0eS5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdtb2RhbC1mb3JtJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbW9kYWwtZm9ybS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vbW9kYWwtZm9ybS5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW01vZGFsSGVhZGVyQ29tcG9uZW50LCBMb2FkZXJDb21wb25lbnQsIEZvcm1HZW5lcmF0b3JDb21wb25lbnQsIEJ0bkNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgTW9kYWxGb3JtQ29tcG9uZW50IGV4dGVuZHMgTW9kYWxDb21wb25lbnQge1xuICBASW5wdXQoKSBrZXlGaWVsZDogJ2ZpZWxkJyB8ICdsYWJlbCcgPSAnZmllbGQnO1xuICBAT3V0cHV0KCkgc3VibWl0dGVkID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG4gIEBJbnB1dCgpIHN1Ym1pdEZ1bmM6ICh2YWx1ZTogYW55KSA9PiBQcm9taXNlPGFueT47XG5cbiAgQElucHV0KCkgdGV4dDogc3RyaW5nID0gJ1NhdmUnO1xuICBASW5wdXQoKSBjb250ZXh0RGF0YTogYW55O1xuICBASW5wdXQoKSBncmlkU3R5bGU6IG51bWJlcjtcbiAgQElucHV0KCkgZ3JpZE1EU3R5bGU6IG51bWJlcjtcbiAgQElucHV0KCkgZ3JpZFhYTFN0eWxlOiBudW1iZXI7XG4gIEBJbnB1dCgpIGZvcm06IEZvcm1Hcm91cDtcbiAgc3RhbmRhbG9uZUZvcm06IGFueTtcbiAgQElucHV0KCkgZm9ybVNjaGVtYTogSUZvcm1TY2hlbWFbXTsgXG4gIG9wdGlvbnNNYXA6IElGb3JtT3B0aW9ucyA9IHt9O1xuICBjZWxsQ291bnRyeUNvZGUzczogSUZvcm1PcHRpb25zID0ge307IFxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBvdmVycmlkZSB1UzogVXRpbGl0eVNlcnZpY2UpIHtcbiAgICBzdXBlcih1Uyk7XG4gIH1cblxuICBvdmVycmlkZSBuZ09uSW5pdCgpOiB2b2lkIHt9XG4gXG4gIG92ZXJyaWRlIG9wZW4oY29udGV4dERhdGEpIHtcbiAgICBpZiAoY29udGV4dERhdGEgIT0gbnVsbCkgdGhpcy5jb250ZXh0RGF0YSA9IGNvbnRleHREYXRhO1xuICAgIHN1cGVyLm9wZW4oKTtcbiAgfVxufVxuIiwiPG5nLXRlbXBsYXRlICN0ZW1wPlxuICA8bW9kYWwtaGVhZGVyIFtoZWFkZXJdPVwiaGVhZGVyKClcIiBbZGlhbG9nUmVmXT1cImRpYWxvZ1JlZigpXCIgLz5cbiAgPGxvYWRlciBbbG9hZGluZ109XCJsb2FkaW5nKClcIj5cbiAgICA8ZGl2IG1hdC1kaWFsb2ctY29udGVudD5cbiAgICAgIDxmb3JtLWdlbmVyYXRvclxuICAgICAgICBbZm9ybV09XCJmb3JtXCJcbiAgICAgICAgW2Zvcm1TY2hlbWFdPVwiZm9ybVNjaGVtYVwiXG4gICAgICAgIFtncmlkU3R5bGVdPVwiZ3JpZFN0eWxlXCJcbiAgICAgICAgW2dyaWRNRFN0eWxlXT1cImdyaWRNRFN0eWxlXCJcbiAgICAgICAgW2dyaWRYWExTdHlsZV09XCJncmlkWFhMU3R5bGVcIlxuICAgICAgICBbc3VibWl0RnVuY109XCJzdWJtaXRGdW5jXCJcbiAgICAgICAgW3N1Ym1pdEJ0blRleHRdPVwidGV4dFwiXG4gICAgICAgIFtzaG93U3VibWl0QnRuXT1cImZhbHNlXCJcbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBtYXQtZGlhbG9nLWFjdGlvbnM+XG4gICAgICA8ZGl2IGNsYXNzPVwicm93IHJvdy1jb2xzLWF1dG8ganVzdGlmeS1jb250ZW50LWVuZFwiPlxuICAgICAgICA8YXBwLWJ0blxuICAgICAgICAgIFt0ZXh0XT1cInRleHRcIlxuICAgICAgICAgIGdyb3VwPVwic3VibWl0XCJcbiAgICAgICAgICBbZm9ybV09XCJmb3JtXCJcbiAgICAgICAgICAobWNsaWNrKT1cInN1Ym1pdHRlZC5lbWl0KHRoaXMuZm9ybS52YWx1ZSk7IGRpYWxvZ1JlZigpPy5jbG9zZSgpXCJcbiAgICAgICAgPjwvYXBwLWJ0bj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L2xvYWRlcj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|