ets-fe-ng-sdk 17.0.355 → 17.0.356
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 +8 -8
- package/esm2022/lib/Shared/components/input/input-td-rf.component.mjs +16 -11
- package/esm2022/lib/Shared/components/table-https/table-https.component.mjs +2 -2
- package/esm2022/lib/Shared/components/table-plain/table-plain.component.mjs +2 -2
- package/fesm2022/ets-fe-ng-sdk.mjs +22 -18
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Services/utility.service.d.ts +1 -1
- package/lib/Shared/components/btn/btn.component.d.ts +1 -1
- package/lib/Shared/components/fields-to-display/fields-to-display.component.d.ts +3 -3
- package/lib/Shared/components/index-comp-layout/index-comp-layout.component.d.ts +1 -1
- package/lib/Shared/components/input/input-td-rf.component.d.ts +1 -0
- package/lib/Shared/components/page-template/page-template.component.d.ts +1 -1
- package/lib/Shared/components/table-https/table-https.component.d.ts +3 -3
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { moveItemInArray, transferArrayItem, CdkDropList, CdkDrag, CdkDragPlaceholder, CdkDragHandle } from '@angular/cdk/drag-drop';
|
|
2
|
-
import { Component, EventEmitter, Input, Output, computed, inject, signal } from '@angular/core';
|
|
2
|
+
import { Component, EventEmitter, Input, Output, computed, inject, model, signal } from '@angular/core';
|
|
3
3
|
import { MatSlideToggleModule } from '@angular/material/slide-toggle';
|
|
4
4
|
import { cloneDeep, uniqBy } from 'lodash-es';
|
|
5
5
|
import { FilterArrayByStringPipe, ResponsiveValPipe } from '../../pipes/utility.pipe';
|
|
@@ -32,14 +32,14 @@ export class FieldsToDisplayComponent {
|
|
|
32
32
|
}) || []).concat(allFields), 'f'));
|
|
33
33
|
}
|
|
34
34
|
constructor() {
|
|
35
|
-
this.
|
|
36
|
-
this.
|
|
35
|
+
this.query1 = model(undefined);
|
|
36
|
+
this.query2 = model(undefined);
|
|
37
37
|
this.allFields = signal([]);
|
|
38
|
-
this.filteredAllFields = computed(() => this.filterArrayByStringPipe.transform(this.allFields(), this.
|
|
38
|
+
this.filteredAllFields = computed(() => this.filterArrayByStringPipe.transform(this.allFields(), this.query1(), ['f', 't']));
|
|
39
39
|
this.activeFields = computed(() => this.allFields().filter((x) => x.active));
|
|
40
40
|
// activeFields = signal<TableCol[]>([]);
|
|
41
41
|
this.nonActiveFields = computed(() => this.filterArrayByStringPipe
|
|
42
|
-
.transform(this.allFields().filter((x) => !x.active), this.
|
|
42
|
+
.transform(this.allFields().filter((x) => !x.active), this.query2(), ['f', 't'])
|
|
43
43
|
.sort2('t', true));
|
|
44
44
|
this.fieldsChanged = new EventEmitter();
|
|
45
45
|
this.filterArrayByStringPipe = inject(FilterArrayByStringPipe);
|
|
@@ -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.2.3", ngImport: i0, type: FieldsToDisplayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
78
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: FieldsToDisplayComponent, isStandalone: true, selector: "fields-to-display", inputs: { _fields: ["fields", "_fields"], _currentColumns: ["currentColumns", "_currentColumns"] }, outputs: { 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 [model]=\"query()\" (modelChange)=\"query.set($event)\" 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 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 #search \n [model]=\"searchInput()\"\n (modelChange)=\"searchInput.set($event)\"\n placeholder=\"Search by name\"></app-input-td-rf>\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", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "disabled", "form", "forms", "help", "iconBtn", "loading", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid"], outputs: ["mclick"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: InputTD_RFComponent, selector: "app-input-td-rf", inputs: ["validators", "asyncValidators", "model", "disabled"], 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" }] }); }
|
|
78
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", 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", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "disabled", "form", "forms", "help", "iconBtn", "loading", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid"], outputs: ["mclick"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: InputTD_RFComponent, selector: "app-input-td-rf", inputs: ["validators", "asyncValidators", "model", "disabled"], 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" }] }); }
|
|
79
79
|
}
|
|
80
80
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: FieldsToDisplayComponent, decorators: [{
|
|
81
81
|
type: Component,
|
|
@@ -97,7 +97,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
97
97
|
ModalComponents,
|
|
98
98
|
ResponsiveValPipe,
|
|
99
99
|
TranslatePipe,
|
|
100
|
-
], providers: [FilterArrayByStringPipe], 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 [
|
|
100
|
+
], providers: [FilterArrayByStringPipe], 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"] }]
|
|
101
101
|
}], ctorParameters: () => [], propDecorators: { _fields: [{
|
|
102
102
|
type: Input,
|
|
103
103
|
args: ['fields']
|
|
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", 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 { CdkDragDrop, moveItemInArray, transferArrayItem, CdkDropList, CdkDrag, CdkDragPlaceholder, CdkDragHandle } from '@angular/cdk/drag-drop';\nimport { Component, EventEmitter, Input, Output, computed, inject, signal } 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  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  query = signal<string | undefined>(undefined);\n  searchInput = signal<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  allFields = signal<TableCol[]>([]);\n\n  filteredAllFields = computed<TableCol[]>(() => this.filterArrayByStringPipe.transform(this.allFields(), this.query()!, ['f', 't']));\n\n  activeFields = computed<TableCol[]>(() => this.allFields().filter((x) => x.active));\n  // activeFields = signal<TableCol[]>([]);\n\n  nonActiveFields = computed<TableCol[]>(() =>\n    this.filterArrayByStringPipe\n      .transform(\n        this.allFields().filter((x) => !x.active),\n        this.searchInput()!,\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(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);\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 [model]=\"query()\" (modelChange)=\"query.set($event)\" 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 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                  #search \n                  [model]=\"searchInput()\"\n                  (modelChange)=\"searchInput.set($event)\"\n                  placeholder=\"Search by name\"></app-input-td-rf>\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 { CdkDragDrop, moveItemInArray, transferArrayItem, CdkDropList, CdkDrag, CdkDragPlaceholder, CdkDragHandle } from '@angular/cdk/drag-drop';\nimport { Component, EventEmitter, Input, Output, computed, inject, model, signal } 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  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  query1 = model<string | undefined>(undefined);\n  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  allFields = signal<TableCol[]>([]);\n\n  filteredAllFields = computed<TableCol[]>(() => this.filterArrayByStringPipe.transform(this.allFields(), this.query1()!, ['f', 't']));\n\n  activeFields = computed<TableCol[]>(() => this.allFields().filter((x) => x.active));\n  // activeFields = signal<TableCol[]>([]);\n\n  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(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);\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"]}
|
|
@@ -5,6 +5,7 @@ import { InputProviders, InputSharedModules } from './input-shared.module';
|
|
|
5
5
|
import { DateInputComponent } from './date-input/date-input.component';
|
|
6
6
|
import { debounceTime } from 'rxjs';
|
|
7
7
|
import { cloneDeep } from 'lodash-es';
|
|
8
|
+
import { toObservable } from '@angular/core/rxjs-interop';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@angular/common";
|
|
10
11
|
import * as i2 from "../btn/btn.component";
|
|
@@ -56,14 +57,24 @@ export class InputTD_RFComponent extends InputBasicComponent {
|
|
|
56
57
|
this.control()?.enable();
|
|
57
58
|
}
|
|
58
59
|
}
|
|
59
|
-
// @Input('type') set _type(v: InputType) {
|
|
60
|
-
// super._type = v;
|
|
61
|
-
// if (v == 'percentage') this.oType = 'number';
|
|
62
|
-
// }
|
|
63
60
|
constructor() {
|
|
64
61
|
super();
|
|
65
62
|
this.modelChange = new EventEmitter();
|
|
63
|
+
// @Input('type') set _type(v: InputType) {
|
|
64
|
+
// super._type = v;
|
|
65
|
+
// if (v == 'percentage') this.oType = 'number';
|
|
66
|
+
// }
|
|
67
|
+
this.valueChanges = toObservable(this.valueSignal)
|
|
68
|
+
.pipe(debounceTime(100))
|
|
69
|
+
.subscribe((r) => {
|
|
70
|
+
// debugger;
|
|
71
|
+
console.log('td-rf emit', r + '');
|
|
72
|
+
this.modelChange.emit(cloneDeep(r));
|
|
73
|
+
this.disableControl();
|
|
74
|
+
});
|
|
66
75
|
this.name.set('item');
|
|
76
|
+
// effect(()=>{
|
|
77
|
+
// })
|
|
67
78
|
}
|
|
68
79
|
ngOnInit() {
|
|
69
80
|
super.ngOnInit();
|
|
@@ -73,12 +84,6 @@ export class InputTD_RFComponent extends InputBasicComponent {
|
|
|
73
84
|
item: new FormControl(this.model, this.validators, this.asyncValidators),
|
|
74
85
|
}));
|
|
75
86
|
this.disableControl();
|
|
76
|
-
this.control()?.valueChanges.pipe(debounceTime(100)).subscribe((r) => {
|
|
77
|
-
// debugger;
|
|
78
|
-
console.log('td-rf emit', r + '');
|
|
79
|
-
this.modelChange.emit(cloneDeep(r));
|
|
80
|
-
this.disableControl();
|
|
81
|
-
});
|
|
82
87
|
// this.control?.statusChanges.subscribe((r) => {
|
|
83
88
|
// if (this.debug) debugger;
|
|
84
89
|
// });
|
|
@@ -113,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
113
118
|
type: Input,
|
|
114
119
|
args: ['disabled']
|
|
115
120
|
}] } });
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-td-rf.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input-td-rf.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAiB,MAAM,eAAe,CAAC;AACtF,OAAO,EAAoB,WAAW,EAAE,SAAS,EAAe,MAAM,gBAAgB,CAAC;AACvF,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;;;;;;;;;;;;;;;;AAUtC,MAAM,OAAO,mBAAmC,SAAQ,mBAAsC;IAE5F,IAAyB,WAAW,CAAC,CAAgB;QACnD,IAAI,CAAC,OAAO,EAAE,EAAE,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAClD,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,CAAC,OAAO,EAAE,EAAE,sBAAsB,EAAE,CAAC;IAC3C,CAAC;IAGD,IAA8B,gBAAgB,CAAC,CAAqB;QAClE,IAAI,CAAC,OAAO,EAAE,EAAE,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACvD,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC;QACzB,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,CAAC,OAAO,EAAE,EAAE,sBAAsB,EAAE,CAAC;IAC3C,CAAC;IAGD,IAAoB,MAAM,CAAC,CAAM;QAC/B,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK;YAAE,OAAO;QAC5B,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,IAAI,CAAC,KAAK,EAAE;YAAE,QAAQ,CAAC;QAC3B,IAAI,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,CAAC;QACzB,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;QAC9B,IAAI,IAAI,CAAC,cAAc,EAAE;YAAE,IAAI,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC;IACvD,CAAC;IAGD,IAAgC,SAAS,CAAC,CAAU;QAClD,IAAI,IAAI,CAAC,KAAK,EAAE;YAAE,QAAQ,CAAC;QAC3B,IAAI,CAAC,EAAE;YACL,IAAI,IAAI,CAAC,cAAc,EAAE;gBAAE,IAAI,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC;YACnD,IAAI,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC;SAC3B;aAAM,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE;YACnC,IAAI,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,CAAC;SAC1B;IACH,CAAC;IACD,2CAA2C;IAC3C,qBAAqB;IACrB,kDAAkD;IAClD,IAAI;IACJ;QACE,KAAK,EAAE,CAAC;QAhBA,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAiBzC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACxB,CAAC;IAEQ,QAAQ;QACf,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,IAAI,CAAC,KAAK,EAAE;YAAE,QAAQ,CAAC;QAC3B,IAAI,CAAC,IAAI,CAAC,GAAG,CACX,IAAI,SAAS,CAAC;YACZ,IAAI,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,eAAe,CAAC;SACzE,CAAC,CACH,CAAC;QACF,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,OAAO,EAAE,EAAE,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACnE,YAAY;YACZ,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC;YAElC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC;QACH,iDAAiD;QACjD,8BAA8B;QAC9B,MAAM;IACR,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,IAAI,CAAC,IAAI,EAAE,IAAI,MAAM,EAAE;YACzB,YAAY;YACZ,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;SACvB;IACH,CAAC;IAEQ,eAAe;QACtB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;8GA5EU,mBAAmB;kGAAnB,mBAAmB,6RAHnB,cAAc,sECb3B,+vUAmQA,u5BDrPY,kBAAkB;;2FAEjB,mBAAmB;kBAR/B,SAAS;+BACE,iBAAiB,cAGf,IAAI,aACL,cAAc,WAChB,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;wDAIxB,WAAW;sBAAnC,KAAK;uBAAC,YAAY;gBAQW,gBAAgB;sBAA7C,KAAK;uBAAC,iBAAiB;gBAQJ,MAAM;sBAAzB,KAAK;uBAAC,OAAO;gBAQJ,WAAW;sBAApB,MAAM;gBAEyB,SAAS;sBAAxC,KAAK;uBAAC,UAAU","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges } from '@angular/core';\nimport { AsyncValidatorFn, FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { InputBasicComponent } from './input-basic.component';\nimport { InputProviders, InputSharedModules } from './input-shared.module';\nimport { DateInputComponent } from './date-input/date-input.component';\nimport { debounceTime } from 'rxjs';\nimport { cloneDeep } from 'lodash-es';\n\n@Component({\n  selector: 'app-input-td-rf',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  standalone: true,\n  providers: InputProviders,\n  imports: [DateInputComponent, InputSharedModules],\n})\nexport class InputTD_RFComponent<TOption = any> extends InputBasicComponent<any, any, TOption> {\n  validators: ValidatorFn[];\n  @Input('validators') set _validators(v: ValidatorFn[]) {\n    this.control()?.removeValidators(this.validators);\n    this.validators = v;\n    this.control()?.setValidators(v);\n    this.control()?.updateValueAndValidity();\n  }\n\n  asyncValidators: AsyncValidatorFn[];\n  @Input('asyncValidators') set _asyncValidators(v: AsyncValidatorFn[]) {\n    this.control()?.removeValidators(this.asyncValidators);\n    this.asyncValidators = v;\n    this.control()?.setValidators(v);\n    this.control()?.updateValueAndValidity();\n  }\n\n  private model: any;\n  @Input('model') set _model(v: any) {\n    if (v == this.model) return;\n    this.model = v;\n    if (this.debug()) debugger;\n    this.control()?.enable();\n    this.control()?.patchValue(v);\n    if (this.disabledSignal()) this.control()?.disable();\n  }\n  @Output() modelChange = new EventEmitter();\n\n  @Input('disabled') override set _disabled(v: boolean) {\n    if (this.debug()) debugger;\n    if (v) {\n      if (this.clearOnDisable()) this.control()?.reset();\n      this.control()?.disable();\n    } else if (this.control()?.disabled) {\n      this.control()?.enable();\n    }\n  }\n  // @Input('type') set _type(v: InputType) {\n  //   super._type = v;\n  //   if (v == 'percentage') this.oType = 'number';\n  // }\n  constructor() {\n    super();\n    this.name.set('item');\n  }\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n    if (this.debug()) debugger;\n    this.form.set(\n      new FormGroup({\n        item: new FormControl(this.model, this.validators, this.asyncValidators),\n      }),\n    );\n    this.disableControl();\n    this.control()?.valueChanges.pipe(debounceTime(100)).subscribe((r) => {\n      // debugger;\n      console.log('td-rf emit', r + '');\n\n      this.modelChange.emit(cloneDeep(r));\n      this.disableControl();\n    });\n    // this.control?.statusChanges.subscribe((r) => {\n    //   if (this.debug) debugger;\n    // });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.name() != 'item') {\n      // debugger;\n      this.name.set('item');\n    }\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n  }\n}\n","<!-- <div>form().getRawValue: {{ff}}</div> -->\n@if(verbose()){<div>disabledSignal: {{disabledSignal()}}</div>\n<div>validSignal: {{validSignal()}}</div>\n<div>invalidSignal: {{invalidSignal()}}</div>\n<div>valueSignal: {{valueSignal()}}</div>\n<div>hasValue: {{hasValue()}}</div>\n<div>dirtySignal: {{dirtySignal()}}</div>\n<div>touchedSignal: {{touchedSignal()}}</div>\n<div>errorsSignal: {{errorsSignaljson()}}</div>\n<div>pendingSignal: {{pendingSignal()}}</div>\n<div>pristineSignal: {{pristineSignal()}}</div>\n<div>controlRequiredSignal: {{controlRequiredSignal()}}</div>\n<div>isRequiredSignal: {{isRequiredSignal()}}</div>}\n<div class=\"  custom-input align-items-center {{ typeSignal() }} gx-1\" [formGroup]=\"form()|toAny\" [ngClass]=\"{ 'd-flex': !stackedSignal() }\">\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"form()\"\n      [hint]=\"hint\"\n      [id]=\"idSignal()\"\n      [invalidCheckbox]=\"invalidCheckboxSignal()\"\n      [isRequired]=\"isRequiredSignal()\"\n      [label]=\"labelSignal()\"\n      [lblCl]=\"lblCl\"\n      [light]=\"light\"\n      [mini]=\"miniSignal()\"\n      [ngClass]=\"{ 'w-100': stackedSignal() }\"\n      [inlineHint]=\"inlineHint\"\n      [showRequiredTag]=\"showRequiredTagSignal()\"\n      [showLabel]=\"showLabelSignal()\"\n      [small]=\"smallSignal()\"\n      [stacked]=\"stackedSignal()\"\n      [theme]=\"theme\"\n      [xsmall]=\"xsmall\"></app-input-label>\n  }\n  <div class=\"d-flex align-items-center {{ inputContClassSignal() }} \">\n    <div\n      class=\"position-relative d-flex input-content w-100\"\n      [ngClass]=\"{\n        'ms-2': !stackedSignal(),\n        showValidationIcon: showValidationSignal() || showValidationIconSignal(),\n        dontFormatAsInput: dontFormatAsInputSignal()\n      }\">\n      <ng-template #date> \n        <date-input\n          #dateInput\n          [debug]=\"debug()\"\n          [readonly]=\"readonlySignal()\"\n          [id]=\"idSignal()\"\n          class=\"w-100\"\n          [type]=\"typeSignal()\"\n          (valueChanged)=\"dateChanged($event)\"\n          [value]=\"valueSignal()\"\n          [inputClass]=\"inputClassSignal()\"\n          [disabled]=\"disabledSignal()\"\n          [max]=\"maxSignal()\"\n          [min]=\"minSignal()\"\n          [valid]=\"validSignal()\"\n          [invalid]=\"invalidSignal()\"\n          [showValidation]=\"showValidationSignal()\" />\n      </ng-template>\n      @switch (typeSignal()) {\n        <!-- DATE -->\n        @case ('date') {\n          <ng-container *ngTemplateOutlet=\"date\" />\n        }\n        <!-- DATETIME-LOCAL -->\n        @case ('datetime-local') {\n          <ng-container *ngTemplateOutlet=\"date\" />\n        }\n        <!-- CHECKBOX -->\n        @case ('checkbox') {\n          <input\n            type=\"checkbox\"\n            [id]=\"idSignal()\"\n            [formControlName]=\"nameStrSignal()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [attr.data-debug]=\"debug()\"\n            class=\"{{ inpClSignal() }} d-inline-block form-control width-unset\"\n            placeholder=\"{{ placeholder() }}\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [checked]=\"checkedSignal()\"\n            [attr.indeterminate]=\"indeterminate\" />\n        }\n        @case ('checkedbox') {\n          <input\n            type=\"checkbox\"\n            class=\"{{ inpClSignal() }} d-inline-block form-control width-unset\"\n            [checked]=\"checkedSignal()\"\n            [attr.data-debug]=\"debug()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\" />\n        }\n        <!-- FILE -->\n        @case ('file') {\n          <input type=\"file\" [id]=\"idSignal()\" [class]=\"inputClassSignal()\" (change)=\"upload($event)\" [accept]=\"accept\" [attr.multiple]=\"multiple\" />\n        }\n        <!-- FILE BUTTON-->\n        @case ('fileButton') {\n          <input\n            type=\"file\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            (change)=\"upload($event)\"\n            [accept]=\"accept\"\n            [attr.multiple]=\"multiple\"\n            hidden\n            #file />\n          <app-btn\n            class=\"w-100\"\n            (mclick)=\"file.click()\"\n            icon=\"upload\"\n            [type]=\"files ? 'primary' : 'secondary'\"\n            text=\"{{ placeholder() || labelSignal() || 'Upload' }}\"></app-btn>\n        }\n        <!-- SELECT -->\n        @case ('select') {\n          <!-- [attr.disabled]=\"disabled\" -->\n          <mat-select\n            #matSelectTag\n            placeholder=\"{{ placeholder() }}\"\n            formControlName=\"{{ nameStrSignal() }}\"\n            [id]=\"idSignal()\"\n            class=\"{{ cls() }} {{ inputClassSignal() }}\"\n            [required]=\"requiredSignal()\"\n            (selectionChange)=\"change({ target: $event })\">\n            @if (showEmptyOptionSignal()) {\n              <mat-option selected [value]=\"null\" class=\"empty-option\">\n                {{ placeholder() }}\n              </mat-option>\n            }\n            @for (item of options(); track iS.trackByValue($index, item)) {\n              <mat-option [value]=\"item.value\">\n                <div class=\"option\" [matTooltip]=\"item.label\" [matTooltipShowDelay]=\"1000\" [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\" #ele>\n                  {{ item.label | appTranslate: translateOptions() | async }}\n                </div>\n              </mat-option>\n            }\n          </mat-select>\n        }\n        <!-- TEXTAREA -->\n        @case ('textarea') {\n          <textarea\n            [formControlName]=\"nameStrSignal()\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [rows]=\"textareaRowsSignal()\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"></textarea>\n        }\n        <!-- Radio -->\n        @case ('radio') {\n          <input\n            type=\"radio\"\n            [formControlName]=\"nameStrSignal()\"\n            [id]=\"idSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [value]=\"valueSignal()\" />\n        }\n        <!-- Viewer -->\n        @case ('viewer') {\n          <input\n            type=\"text\"\n            [id]=\"idSignal()\"\n            placeholder=\"{{ placeholder() }}\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [class]=\"inputClassSignal()\"\n            [readonly]=\"true\"\n            [value]=\"valueSignal()\" />\n        }\n        <!-- PASSWORD -->\n        @case ('password') {\n          <input\n            type=\"{{ showPasswordSignal() ? 'text' : 'password' }}\"\n            [formControlName]=\"nameStrSignal()\"\n            placeholder=\"{{ placeholder() }}\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            [required]=\"requiredSignal()\"\n            [max]=\"maxSignal()\"\n            [min]=\"minSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [value]=\"valueSignal()\" />\n          <div class=\"password-icons pointer\" (click)=\"showPasswordSignal.set(!showPasswordSignal())\">\n            @if (showPasswordSignal()) {\n              <i class=\"fa fa-eye-slash\"></i>\n            } @else {\n              <i class=\"fa fa-eye\"></i>\n            }\n          </div>\n        }\n        <!-- DEFAULT -->\n        @default {\n          <div [class]=\"inputClassSignal()\" [ngClass]=\"{ 'has-prefix': !!prefixSignal(), disabled: readonlySignal() || disabledSignal() }\">\n            @if (prefixSignal()) {\n              <div class=\"prefix-val\" #prefixVal>\n                {{ prefixSignal() }}\n              </div>\n            }\n            <input\n              [type]=\"typeSignal()\"\n              [formControlName]=\"nameStrSignal()\"\n              placeholder=\"{{ placeholder() }}\"\n              [id]=\"idSignal()\"\n              [matTooltip]=\"ele.innerText\"\n              [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n              #ele\n              [attr.data-debug]=\"debug()\"\n              [attr.data-noformat]=\"computedNoFormat()\"\n              [attr.data-otype]=\"oTypeSignal()\"\n              [required]=\"requiredSignal()\"\n              [max]=\"maxSignal()\"\n              [min]=\"minSignal()\"\n              [readonly]=\"readonlySignal()\"\n              (change)=\"change($event)\" />\n          </div>\n        }\n      }\n\n      @if (dirtySignal() && (showValidationSignal() || showValidationIconSignal())) {\n        <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-check\"></i>\n        </div>\n        <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n        <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-times\"></i>\n        </div>\n      }\n      <!-- <mat-form-field class=\"input\" appearance=\"fill\">\n        <input type=\"{{inp.type}}\" matInput [formControl]=\"inp.formControl\">\n        <mat-error *ngFor=\"let validation of inp.vms\">\n          <ng-container *ngIf=\"validation|validator:inp.formControl:inp.formControl?.value\">\n            {{validation.message|validationMsg:inp.prefix:inp.suffix}}\n          </ng-container>\n        </mat-error>\n      </mat-form-field> -->\n    </div>\n    @if (endLabelSignal()) {\n      <div class=\"col-auto text-primary ms-2\" (click)=\"iS.log(form())\" [matTooltip]=\"endLabelTooltipSignal() | appTranslate | async\">\n        {{ endLabelSignal() | appTranslate | async }}\n      </div>\n    }\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [minLength]=\"minLength\" [maxLength]=\"maxLength\" [control]=\"control()\" />\n}\n"]}
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-td-rf.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input-td-rf.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges, effect } from '@angular/core';\nimport { AsyncValidatorFn, FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { InputBasicComponent } from './input-basic.component';\nimport { InputProviders, InputSharedModules } from './input-shared.module';\nimport { DateInputComponent } from './date-input/date-input.component';\nimport { debounceTime } from 'rxjs';\nimport { cloneDeep } from 'lodash-es';\nimport { toObservable } from '@angular/core/rxjs-interop';\n\n@Component({\n  selector: 'app-input-td-rf',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  standalone: true,\n  providers: InputProviders,\n  imports: [DateInputComponent, InputSharedModules],\n})\nexport class InputTD_RFComponent<TOption = any> extends InputBasicComponent<any, any, TOption> {\n  validators: ValidatorFn[];\n  @Input('validators') set _validators(v: ValidatorFn[]) {\n    this.control()?.removeValidators(this.validators);\n    this.validators = v;\n    this.control()?.setValidators(v);\n    this.control()?.updateValueAndValidity();\n  }\n\n  asyncValidators: AsyncValidatorFn[];\n  @Input('asyncValidators') set _asyncValidators(v: AsyncValidatorFn[]) {\n    this.control()?.removeValidators(this.asyncValidators);\n    this.asyncValidators = v;\n    this.control()?.setValidators(v);\n    this.control()?.updateValueAndValidity();\n  }\n\n  private model: any;\n  @Input('model') set _model(v: any) {\n    if (v == this.model) return;\n    this.model = v;\n    if (this.debug()) debugger;\n    this.control()?.enable();\n    this.control()?.patchValue(v);\n    if (this.disabledSignal()) this.control()?.disable();\n  }\n  @Output() modelChange = new EventEmitter();\n\n  @Input('disabled') override set _disabled(v: boolean) {\n    if (this.debug()) debugger;\n    if (v) {\n      if (this.clearOnDisable()) this.control()?.reset();\n      this.control()?.disable();\n    } else if (this.control()?.disabled) {\n      this.control()?.enable();\n    }\n  }\n  // @Input('type') set _type(v: InputType) {\n  //   super._type = v;\n  //   if (v == 'percentage') this.oType = 'number';\n  // }\n\n  protected valueChanges = toObservable(this.valueSignal)\n    .pipe(debounceTime(100))\n    .subscribe((r) => {\n      // debugger;\n      console.log('td-rf emit', r + '');\n\n      this.modelChange.emit(cloneDeep(r));\n      this.disableControl();\n    });\n  constructor() {\n    super();\n    this.name.set('item');\n    // effect(()=>{\n\n    // })\n  }\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n    if (this.debug()) debugger;\n    this.form.set(\n      new FormGroup({\n        item: new FormControl(this.model, this.validators, this.asyncValidators),\n      }),\n    );\n    this.disableControl();\n    // this.control?.statusChanges.subscribe((r) => {\n    //   if (this.debug) debugger;\n    // });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.name() != 'item') {\n      // debugger;\n      this.name.set('item');\n    }\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n  }\n}\n","<!-- <div>form().getRawValue: {{ff}}</div> -->\n@if(verbose()){<div>disabledSignal: {{disabledSignal()}}</div>\n<div>validSignal: {{validSignal()}}</div>\n<div>invalidSignal: {{invalidSignal()}}</div>\n<div>valueSignal: {{valueSignal()}}</div>\n<div>hasValue: {{hasValue()}}</div>\n<div>dirtySignal: {{dirtySignal()}}</div>\n<div>touchedSignal: {{touchedSignal()}}</div>\n<div>errorsSignal: {{errorsSignaljson()}}</div>\n<div>pendingSignal: {{pendingSignal()}}</div>\n<div>pristineSignal: {{pristineSignal()}}</div>\n<div>controlRequiredSignal: {{controlRequiredSignal()}}</div>\n<div>isRequiredSignal: {{isRequiredSignal()}}</div>}\n<div class=\"  custom-input align-items-center {{ typeSignal() }} gx-1\" [formGroup]=\"form()|toAny\" [ngClass]=\"{ 'd-flex': !stackedSignal() }\">\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"form()\"\n      [hint]=\"hint\"\n      [id]=\"idSignal()\"\n      [invalidCheckbox]=\"invalidCheckboxSignal()\"\n      [isRequired]=\"isRequiredSignal()\"\n      [label]=\"labelSignal()\"\n      [lblCl]=\"lblCl\"\n      [light]=\"light\"\n      [mini]=\"miniSignal()\"\n      [ngClass]=\"{ 'w-100': stackedSignal() }\"\n      [inlineHint]=\"inlineHint\"\n      [showRequiredTag]=\"showRequiredTagSignal()\"\n      [showLabel]=\"showLabelSignal()\"\n      [small]=\"smallSignal()\"\n      [stacked]=\"stackedSignal()\"\n      [theme]=\"theme\"\n      [xsmall]=\"xsmall\"></app-input-label>\n  }\n  <div class=\"d-flex align-items-center {{ inputContClassSignal() }} \">\n    <div\n      class=\"position-relative d-flex input-content w-100\"\n      [ngClass]=\"{\n        'ms-2': !stackedSignal(),\n        showValidationIcon: showValidationSignal() || showValidationIconSignal(),\n        dontFormatAsInput: dontFormatAsInputSignal()\n      }\">\n      <ng-template #date> \n        <date-input\n          #dateInput\n          [debug]=\"debug()\"\n          [readonly]=\"readonlySignal()\"\n          [id]=\"idSignal()\"\n          class=\"w-100\"\n          [type]=\"typeSignal()\"\n          (valueChanged)=\"dateChanged($event)\"\n          [value]=\"valueSignal()\"\n          [inputClass]=\"inputClassSignal()\"\n          [disabled]=\"disabledSignal()\"\n          [max]=\"maxSignal()\"\n          [min]=\"minSignal()\"\n          [valid]=\"validSignal()\"\n          [invalid]=\"invalidSignal()\"\n          [showValidation]=\"showValidationSignal()\" />\n      </ng-template>\n      @switch (typeSignal()) {\n        <!-- DATE -->\n        @case ('date') {\n          <ng-container *ngTemplateOutlet=\"date\" />\n        }\n        <!-- DATETIME-LOCAL -->\n        @case ('datetime-local') {\n          <ng-container *ngTemplateOutlet=\"date\" />\n        }\n        <!-- CHECKBOX -->\n        @case ('checkbox') {\n          <input\n            type=\"checkbox\"\n            [id]=\"idSignal()\"\n            [formControlName]=\"nameStrSignal()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [attr.data-debug]=\"debug()\"\n            class=\"{{ inpClSignal() }} d-inline-block form-control width-unset\"\n            placeholder=\"{{ placeholder() }}\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [checked]=\"checkedSignal()\"\n            [attr.indeterminate]=\"indeterminate\" />\n        }\n        @case ('checkedbox') {\n          <input\n            type=\"checkbox\"\n            class=\"{{ inpClSignal() }} d-inline-block form-control width-unset\"\n            [checked]=\"checkedSignal()\"\n            [attr.data-debug]=\"debug()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\" />\n        }\n        <!-- FILE -->\n        @case ('file') {\n          <input type=\"file\" [id]=\"idSignal()\" [class]=\"inputClassSignal()\" (change)=\"upload($event)\" [accept]=\"accept\" [attr.multiple]=\"multiple\" />\n        }\n        <!-- FILE BUTTON-->\n        @case ('fileButton') {\n          <input\n            type=\"file\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            (change)=\"upload($event)\"\n            [accept]=\"accept\"\n            [attr.multiple]=\"multiple\"\n            hidden\n            #file />\n          <app-btn\n            class=\"w-100\"\n            (mclick)=\"file.click()\"\n            icon=\"upload\"\n            [type]=\"files ? 'primary' : 'secondary'\"\n            text=\"{{ placeholder() || labelSignal() || 'Upload' }}\"></app-btn>\n        }\n        <!-- SELECT -->\n        @case ('select') {\n          <!-- [attr.disabled]=\"disabled\" -->\n          <mat-select\n            #matSelectTag\n            placeholder=\"{{ placeholder() }}\"\n            formControlName=\"{{ nameStrSignal() }}\"\n            [id]=\"idSignal()\"\n            class=\"{{ cls() }} {{ inputClassSignal() }}\"\n            [required]=\"requiredSignal()\"\n            (selectionChange)=\"change({ target: $event })\">\n            @if (showEmptyOptionSignal()) {\n              <mat-option selected [value]=\"null\" class=\"empty-option\">\n                {{ placeholder() }}\n              </mat-option>\n            }\n            @for (item of options(); track iS.trackByValue($index, item)) {\n              <mat-option [value]=\"item.value\">\n                <div class=\"option\" [matTooltip]=\"item.label\" [matTooltipShowDelay]=\"1000\" [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\" #ele>\n                  {{ item.label | appTranslate: translateOptions() | async }}\n                </div>\n              </mat-option>\n            }\n          </mat-select>\n        }\n        <!-- TEXTAREA -->\n        @case ('textarea') {\n          <textarea\n            [formControlName]=\"nameStrSignal()\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [rows]=\"textareaRowsSignal()\"\n            [required]=\"requiredSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"></textarea>\n        }\n        <!-- Radio -->\n        @case ('radio') {\n          <input\n            type=\"radio\"\n            [formControlName]=\"nameStrSignal()\"\n            [id]=\"idSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [value]=\"valueSignal()\" />\n        }\n        <!-- Viewer -->\n        @case ('viewer') {\n          <input\n            type=\"text\"\n            [id]=\"idSignal()\"\n            placeholder=\"{{ placeholder() }}\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [class]=\"inputClassSignal()\"\n            [readonly]=\"true\"\n            [value]=\"valueSignal()\" />\n        }\n        <!-- PASSWORD -->\n        @case ('password') {\n          <input\n            type=\"{{ showPasswordSignal() ? 'text' : 'password' }}\"\n            [formControlName]=\"nameStrSignal()\"\n            placeholder=\"{{ placeholder() }}\"\n            [attr.data-noformat]=\"computedNoFormat()\"\n            [id]=\"idSignal()\"\n            [class]=\"inputClassSignal()\"\n            [required]=\"requiredSignal()\"\n            [max]=\"maxSignal()\"\n            [min]=\"minSignal()\"\n            [readonly]=\"readonlySignal()\"\n            (change)=\"change($event)\"\n            [value]=\"valueSignal()\" />\n          <div class=\"password-icons pointer\" (click)=\"showPasswordSignal.set(!showPasswordSignal())\">\n            @if (showPasswordSignal()) {\n              <i class=\"fa fa-eye-slash\"></i>\n            } @else {\n              <i class=\"fa fa-eye\"></i>\n            }\n          </div>\n        }\n        <!-- DEFAULT -->\n        @default {\n          <div [class]=\"inputClassSignal()\" [ngClass]=\"{ 'has-prefix': !!prefixSignal(), disabled: readonlySignal() || disabledSignal() }\">\n            @if (prefixSignal()) {\n              <div class=\"prefix-val\" #prefixVal>\n                {{ prefixSignal() }}\n              </div>\n            }\n            <input\n              [type]=\"typeSignal()\"\n              [formControlName]=\"nameStrSignal()\"\n              placeholder=\"{{ placeholder() }}\"\n              [id]=\"idSignal()\"\n              [matTooltip]=\"ele.innerText\"\n              [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n              #ele\n              [attr.data-debug]=\"debug()\"\n              [attr.data-noformat]=\"computedNoFormat()\"\n              [attr.data-otype]=\"oTypeSignal()\"\n              [required]=\"requiredSignal()\"\n              [max]=\"maxSignal()\"\n              [min]=\"minSignal()\"\n              [readonly]=\"readonlySignal()\"\n              (change)=\"change($event)\" />\n          </div>\n        }\n      }\n\n      @if (dirtySignal() && (showValidationSignal() || showValidationIconSignal())) {\n        <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-check\"></i>\n        </div>\n        <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n        <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-times\"></i>\n        </div>\n      }\n      <!-- <mat-form-field class=\"input\" appearance=\"fill\">\n        <input type=\"{{inp.type}}\" matInput [formControl]=\"inp.formControl\">\n        <mat-error *ngFor=\"let validation of inp.vms\">\n          <ng-container *ngIf=\"validation|validator:inp.formControl:inp.formControl?.value\">\n            {{validation.message|validationMsg:inp.prefix:inp.suffix}}\n          </ng-container>\n        </mat-error>\n      </mat-form-field> -->\n    </div>\n    @if (endLabelSignal()) {\n      <div class=\"col-auto text-primary ms-2\" (click)=\"iS.log(form())\" [matTooltip]=\"endLabelTooltipSignal() | appTranslate | async\">\n        {{ endLabelSignal() | appTranslate | async }}\n      </div>\n    }\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [minLength]=\"minLength\" [maxLength]=\"maxLength\" [control]=\"control()\" />\n}\n"]}
|