ets-fe-ng-sdk 18.0.3 → 18.0.4

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.
@@ -15,10 +15,11 @@ import { MatTooltipModule } from '@angular/material/tooltip';
15
15
  import { MatExpansionModule } from '@angular/material/expansion';
16
16
  import { MatTabsModule } from '@angular/material/tabs';
17
17
  import { TableInputRowComponent } from './table-input-row/table-input-row.component';
18
+ import { map, switchMap } from 'rxjs';
18
19
  import { UtilityService } from '../../../Services/utility.service';
19
20
  import { SDKTranslatePipe } from '../../pipes/translate.pipe';
20
21
  import { PaginatorPipe } from '../../pipes/paginator.pipe';
21
- import { toSignal } from '@angular/core/rxjs-interop';
22
+ import { toObservable, toSignal } from '@angular/core/rxjs-interop';
22
23
  import * as i0 from "@angular/core";
23
24
  /**
24
25
  * Table Input Component
@@ -26,6 +27,7 @@ import * as i0 from "@angular/core";
26
27
  export class TableInputComponent extends FormGeneratorComponent {
27
28
  constructor() {
28
29
  super(...arguments);
30
+ this.formArray = input();
29
31
  this.filterContainerClass = input();
30
32
  this.border = input(true);
31
33
  this.isShow = input();
@@ -38,11 +40,15 @@ export class TableInputComponent extends FormGeneratorComponent {
38
40
  this.usePaginator = signal(true);
39
41
  this.childrenFormSchemaMap = {};
40
42
  this.filterFormValueSignal = toSignal(this.filterForm.valueChanges);
41
- this.formArrayLengthSignal = signal(undefined);
43
+ this.formArrayLengthSignal = toSignal(toObservable(this.formArray).pipe(switchMap((form) => form?.valueChanges.pipe(map(() => form?.length)))));
42
44
  this.filteredFormArray = computed(() => {
43
45
  this.formArrayLengthSignal();
44
- const formArray = this.formArray, filterFormValue = this.filterFormValueSignal();
45
- const formGroups = formArray?.controls?.map((c, index) => ({ index, form: c }));
46
+ const formArray = this.formArray(), filterFormValue = this.filterFormValueSignal();
47
+ const formGroups = formArray?.controls?.map((c, index) => ({
48
+ index,
49
+ form: c,
50
+ id: this.utilityService.generateUUID(),
51
+ }));
46
52
  const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);
47
53
  return filterObject
48
54
  ? formGroups.filter(({ form }) => this.filterFormArrayGroupPipe.filterFunc(filterObject)(form))
@@ -50,7 +56,6 @@ export class TableInputComponent extends FormGeneratorComponent {
50
56
  });
51
57
  this.paginatedAndFilteredFormArray = computed(() => {
52
58
  const formArray = this.filteredFormArray(), pageState = this.pageState();
53
- // debugger;
54
59
  return this.usePaginator()
55
60
  ? this.paginatorPipe.transform(formArray, pageState?.pageSize || this.pageSize(), pageState?.pageIndex || 0)
56
61
  : formArray;
@@ -80,14 +85,6 @@ export class TableInputComponent extends FormGeneratorComponent {
80
85
  console.log(this.singleFormStructure);
81
86
  };
82
87
  }
83
- // @Input() pageType
84
- set _formArray(v) {
85
- this.formArray = v;
86
- if (v)
87
- v.valueChanges.subscribe((r) => {
88
- this.formArrayLengthSignal.set(v?.length);
89
- });
90
- }
91
88
  set _pageSize(v) {
92
89
  this.pageSize.set(v);
93
90
  }
@@ -174,7 +171,7 @@ export class TableInputComponent extends FormGeneratorComponent {
174
171
  this.singleFormStructure?.controls[scheme.field]?.hasValidator(Validators.required);
175
172
  }
176
173
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
177
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { _formArray: { classPropertyName: "_formArray", publicName: "formArray", isSignal: false, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "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: 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: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTabsModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PaginatorComponent, selector: "paginator", inputs: ["pageSize", "pageIndex", "arrayLength", "resetIndexFunc", "pageSizeOptions"], outputs: ["pageChanged"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: TableInputRowComponent, selector: "tr[table-input-row]", inputs: ["isShow", "hideAdd", "actionBtns", "childrenFormSchemaMap"], outputs: ["onDeleteRowFunc", "onAddRowFunc", "onActionButtonClick"] }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
174
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { formArray: { classPropertyName: "formArray", publicName: "formArray", isSignal: true, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "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: 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: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTabsModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PaginatorComponent, selector: "paginator", inputs: ["pageSize", "pageIndex", "arrayLength", "resetIndexFunc", "pageSizeOptions"], outputs: ["pageChanged"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: TableInputRowComponent, selector: "tr[table-input-row]", inputs: ["isShow", "hideAdd", "actionBtns", "childrenFormSchemaMap"], outputs: ["onDeleteRowFunc", "onAddRowFunc", "onActionButtonClick"] }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
178
175
  }
179
176
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputComponent, decorators: [{
180
177
  type: Component,
@@ -210,11 +207,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
210
207
  SDKTranslatePipe,
211
208
  FilterFormArrayGroupPipe,
212
209
  ValidationMessageComponent,
213
- ], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"] }]
214
- }], propDecorators: { _formArray: [{
215
- type: Input,
216
- args: ['formArray']
217
- }], _pageSize: [{
210
+ ], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"] }]
211
+ }], propDecorators: { _pageSize: [{
218
212
  type: Input,
219
213
  args: ['pageSize']
220
214
  }], _formSchema: [{
@@ -234,4 +228,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
234
228
  type: ViewChild,
235
229
  args: [PaginatorComponent]
236
230
  }] } });
237
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  computed,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormArray,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport {\n  FilterFormArrayGroupPipe,\n  FormValuePipe,\n  FunctionCaller2,\n  HasFormValuePipe,\n  ToAnyPipe,\n} from '../../pipes/utility.pipe';\n\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport {\n  AsyncPipe,\n  JsonPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgSwitch,\n  NgSwitchCase,\n  NgSwitchDefault,\n} from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { FormGeneratorComponent } from '../form-generator/form-generator.component';\n\nimport { PaginatorComponent } from '../paginator/paginator.component';\nimport { ModalComponent } from '../modal/modal.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { TableInputRowComponent } from './table-input-row/table-input-row.component';\nimport { Subscription, filter } from 'rxjs';\nimport { IBtn } from '../btn/btn.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { PaginatorPipe } from '../../pipes/paginator.pipe';\nimport { toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Table Input Component\n */\n@Component({\n  selector: 'table-input',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTabsModule,\n    MatTooltipModule,\n    ModalComponent,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    TableInputRowComponent,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    FilterFormArrayGroupPipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input.component.html',\n  styleUrls: ['./table-input.component.scss'],\n  providers: [FilterFormArrayGroupPipe, PaginatorPipe],\n})\nexport class TableInputComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n  >\n  extends FormGeneratorComponent<TFormGroup>\n  implements OnInit\n{\n  formArray: FormArray<FormGroup<TFormGroup>>;\n  // @Input() pageType\n  @Input('formArray') set _formArray(v: FormArray<FormGroup<TFormGroup>>) {\n    this.formArray = v;\n    if (v)\n      v.valueChanges.subscribe((r) => {\n        this.formArrayLengthSignal.set(v?.length);\n      });\n  }\n  readonly filterContainerClass = input<string>();\n  readonly border = input(true);\n  readonly isShow = input<boolean>();\n  @Input('pageSize') set _pageSize(v: number) {\n    this.pageSize.set(v);\n  }\n  readonly pageSize = signal<number>(10);\n  readonly pageState = signal<{ pageIndex: number; pageSize: number }>(null);\n  readonly actionBtns = input<ITableInputBtn[]>();\n  @Input({ required: true, alias: 'formSchema' }) override set _formSchema(\n    v: IFormSchema<TFormGroup>[],\n  ) {\n    this.preFormatFormSchema(v);\n    super._formSchema = v;\n  }\n  @Input({ required: true })\n  singleFormStructure: FormGroup<TFormGroup>;\n  /**\n   * Leave empty if you don't want the delete button to show\n   */\n  @Input() deleteRowFunc: (\n    index: number,\n    data?: FormGroup<TFormGroup>['value'],\n    config?: { btn: BtnComponent },\n  ) => any;\n  /**\n   * Leave empty if you don't want the add button to show\n   */\n  @Input() addRowFunc: (index: number, data?: FormGroup<TFormGroup>['value']) => any;\n  @Input('usePaginator') set _usePaginator(v: boolean) {\n    if (v) {\n      this.usePaginator.set(true);\n      this.pageSize.update((pageSize) => pageSize || 10);\n    } else {\n      this.usePaginator.set(false);\n      this.pageSize.set(undefined);\n    }\n  }\n\n  readonly tableClass = input<'table table-responsive table-responsive table-borderless'>();\n  protected readonly filterForm = new FormGroup({});\n  protected readonly filterForms = signal<IFormSchema[]>([]);\n  protected readonly usePaginator = signal<boolean>(true);\n  protected childrenFormSchemaMap: {\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  } = {};\n  refresher: number;\n  formArrayPaginationSub: Subscription;\n\n  @ViewChild(PaginatorComponent) paginatorComponent: PaginatorComponent;\n\n  readonly filterFormValueSignal = toSignal(this.filterForm.valueChanges);\n  readonly formArrayLengthSignal = signal<number>(undefined);\n\n  readonly filteredFormArray = computed<{ form: FormGroup<TFormGroup>; index: number }[]>(() => {\n    this.formArrayLengthSignal();\n    const formArray = this.formArray,\n      filterFormValue = this.filterFormValueSignal();\n    const formGroups = formArray?.controls?.map((c, index) => ({ index, form: c }));\n    const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);\n    return filterObject\n      ? formGroups.filter(({ form }) =>\n          this.filterFormArrayGroupPipe.filterFunc(filterObject)(form),\n        )\n      : formGroups;\n  });\n  readonly paginatedAndFilteredFormArray = computed<\n    { form: FormGroup<TFormGroup>; index: number }[]\n  >(() => {\n    const formArray = this.filteredFormArray(),\n      pageState = this.pageState();\n    // debugger;\n    return this.usePaginator()\n      ? this.paginatorPipe.transform(\n          formArray,\n          pageState?.pageSize || this.pageSize(),\n          pageState?.pageIndex || 0,\n        )\n      : formArray;\n  });\n\n  readonly filteredFormArrayLength = computed(() => this.filteredFormArray().length);\n\n  public override utilityService = inject(UtilityService);\n  public filterFormArrayGroupPipe = inject(FilterFormArrayGroupPipe);\n  public paginatorPipe = inject(PaginatorPipe);\n\n  ngOnInit(): void {\n    if (this.usePaginator == undefined) {\n      this._usePaginator = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.refresh();\n    }, 1000);\n  }\n\n  refresh() {\n    this.refresher = Math.random();\n  }\n\n  override onDestroy() {\n    this.formArrayPaginationSub?.unsubscribe();\n    return super.onDestroy();\n  }\n\n  pageChanged($event: { pageIndex: number; pageSize: number }) {\n    this.pageState.set($event);\n  }\n\n  resetPaginator() {\n    this.paginatorComponent?.reset();\n  }\n\n  protected preFormatFormSchema = (items: IFormSchema<TFormGroup>[]) => {\n    items.forEach((x) => {\n      if (x.onChangeFunc) x.triggerOnChangeOnInit = true;\n      else if (x.type == 'button') this.preFormatFormSchema(x.children);\n    });\n  };\n\n  override init(schema: IFormSchema<TFormGroup>[]): void {\n    this.filterForms.set([]);\n    for (const key in this.filterForm.controls) {\n      if (Object.prototype.hasOwnProperty.call(this.filterForm.controls, key)) {\n        this.filterForm.removeControl(key);\n      }\n    }\n    // debugger;\n    this.onDestroy();\n    if (schema)\n      for (const scheme of schema) {\n        // scheme.form = this.form || scheme.form;\n        this.handleFormScheme(scheme);\n      }\n    this._setFormSchemas(schema);\n  }\n\n  handleActionButtonClick(\n    index: number,\n    form: FormGroup<TFormGroup>,\n    e: { btn?: BtnComponent; actionButton: ITableInputBtn },\n  ) {\n    e.actionButton.action({ index, form, btn: e.btn });\n    // this.refresh();\n  }\n\n  deleteRowClicked = (\n    index: number,\n    rowForm: FormGroup<TFormGroup>,\n    config?: { btn: BtnComponent },\n  ) => {\n    this.deleteRowFunc(index, rowForm?.getRawValue(), config);\n    // this.refresh();\n  };\n\n  addRowClicked = (index: number) => {\n    this.addRowFunc(index + 1, this.filterFormValueSignal());\n    // this.refresh();\n    // this.filterForm.updateValueAndValidity();\n  };\n\n  checkRequiredFields = () => {\n    console.log(this.singleFormStructure);\n  };\n\n  override handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n      scheme.autoPickValueField = true;\n\n    if (scheme.optionsInitFunc) {\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        // this.optionsMap[scheme.field] = r;\n      });\n    }\n    if (scheme.isSearchField) {\n      this.filterForms.update((filterForms) => filterForms.concat([scheme]));\n      this.filterForm.addControl(scheme.field?.toString(), new FormControl());\n    } else if (scheme.type == 'button') {\n      if (scheme.children?.length)\n        this.childrenFormSchemaMap[scheme.field as string] = {\n          formSchema: scheme.children,\n          formSchemaStr: scheme.children.map((x) => x.field as string),\n        };\n    }\n    scheme.isRequired =\n      scheme.isRequired ||\n      (<FormGroup>this.singleFormStructure?.controls[scheme.field])?.hasValidator(\n        Validators.required,\n      );\n  }\n}\n\nexport interface ITableInputBtn extends IBtn {\n  action?: (arg?: { index: number; form: FormGroup; btn: BtnComponent }) => void;\n}\n","<div class=\"table-input\">\n  @if (filterForms()?.length) {\n    <div class=\"mb-3 {{ filterContainerClass() }}\">\n      <div class=\"d-flex\">\n        <app-btn\n          text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n          [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n          (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n      </div>\n      <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n        <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n        <div class=\"d-flex justify-content-end\">\n          <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n        </div>\n      </div>\n    </div>\n  }\n\n  <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n    <div class=\" \">\n      <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n        <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n          <tr class=\"text-center\">\n            @for (item of formSchema(); track item.label) {\n              <th class=\"{{ item.cls }}\">\n                {{ item.label | appTranslate | async }}\n                {{ item.isRequired ? '*' : '' }}\n              </th>\n            }\n            @if (!isShow()) {\n              <th></th>\n              <th></th>\n              @for (actionBtn of actionBtns(); track actionBtn) {\n                <th></th>\n              }\n            }\n          </tr>\n        </thead>\n        <tbody>\n          @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n            <tr\n              table-input-row\n              (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n              [isShow]=\"isShow()\"\n              [form]=\"subForm.form\"\n              [actionBtns]=\"actionBtns()\"\n              [formSchema]=\"formSchema()\"\n              [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n              (onDeleteRowFunc)=\"\n                deleteRowClicked(subForm.index, subForm.form, {\n                  btn: $event?.btn\n                })\n              \"\n              (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n          } @empty {\n            <tr>\n              <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n                {{ 'There are no items' | appTranslate | async }}\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    </div>\n\n    <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n      <paginator\n        #paginatorTag\n        [arrayLength]=\"filteredFormArrayLength()\"\n        (pageChanged)=\"pageChanged($event)\"\n        [pageSize]=\"pageSize()\"\n        [resetIndexFunc]=\"filterForm.valueChanges\" />\n    </div>\n  </div>\n</div>\n"]}
231
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  computed,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormArray,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport {\n  FilterFormArrayGroupPipe,\n  FormValuePipe,\n  FunctionCaller2,\n  HasFormValuePipe,\n  ToAnyPipe,\n} from '../../pipes/utility.pipe';\n\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport {\n  AsyncPipe,\n  JsonPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgSwitch,\n  NgSwitchCase,\n  NgSwitchDefault,\n} from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { FormGeneratorComponent } from '../form-generator/form-generator.component';\n\nimport { PaginatorComponent } from '../paginator/paginator.component';\nimport { ModalComponent } from '../modal/modal.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { TableInputRowComponent } from './table-input-row/table-input-row.component';\nimport { Subscription, filter, map, switchMap } from 'rxjs';\nimport { IBtn } from '../btn/btn.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { PaginatorPipe } from '../../pipes/paginator.pipe';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Table Input Component\n */\n@Component({\n  selector: 'table-input',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTabsModule,\n    MatTooltipModule,\n    ModalComponent,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    TableInputRowComponent,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    FilterFormArrayGroupPipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input.component.html',\n  styleUrls: ['./table-input.component.scss'],\n  providers: [FilterFormArrayGroupPipe, PaginatorPipe],\n})\nexport class TableInputComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n  >\n  extends FormGeneratorComponent<TFormGroup>\n  implements OnInit\n{\n  readonly formArray = input<FormArray<FormGroup<TFormGroup>>>();\n\n  readonly filterContainerClass = input<string>();\n  readonly border = input(true);\n  readonly isShow = input<boolean>();\n  @Input('pageSize') set _pageSize(v: number) {\n    this.pageSize.set(v);\n  }\n  readonly pageSize = signal<number>(10);\n  readonly pageState = signal<{ pageIndex: number; pageSize: number }>(null);\n  readonly actionBtns = input<ITableInputBtn[]>();\n  @Input({ required: true, alias: 'formSchema' }) override set _formSchema(\n    v: IFormSchema<TFormGroup>[],\n  ) {\n    this.preFormatFormSchema(v);\n    super._formSchema = v;\n  }\n  @Input({ required: true })\n  singleFormStructure: FormGroup<TFormGroup>;\n  /**\n   * Leave empty if you don't want the delete button to show\n   */\n  @Input() deleteRowFunc: (\n    index: number,\n    data?: FormGroup<TFormGroup>['value'],\n    config?: { btn: BtnComponent },\n  ) => any;\n  /**\n   * Leave empty if you don't want the add button to show\n   */\n  @Input() addRowFunc: (index: number, data?: FormGroup<TFormGroup>['value']) => any;\n  @Input('usePaginator') set _usePaginator(v: boolean) {\n    if (v) {\n      this.usePaginator.set(true);\n      this.pageSize.update((pageSize) => pageSize || 10);\n    } else {\n      this.usePaginator.set(false);\n      this.pageSize.set(undefined);\n    }\n  }\n\n  readonly tableClass = input<'table table-responsive table-responsive table-borderless'>();\n  protected readonly filterForm = new FormGroup({});\n  protected readonly filterForms = signal<IFormSchema[]>([]);\n  protected readonly usePaginator = signal<boolean>(true);\n  protected childrenFormSchemaMap: {\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  } = {};\n  refresher: number;\n  formArrayPaginationSub: Subscription;\n\n  @ViewChild(PaginatorComponent) paginatorComponent: PaginatorComponent;\n\n  readonly filterFormValueSignal = toSignal(this.filterForm.valueChanges);\n  readonly formArrayLengthSignal = toSignal<number>(\n    toObservable(this.formArray).pipe(\n      switchMap((form) => form?.valueChanges.pipe(map(() => form?.length))),\n    ),\n  );\n\n  readonly filteredFormArray = computed(() => {\n    this.formArrayLengthSignal();\n    const formArray = this.formArray(),\n      filterFormValue = this.filterFormValueSignal();\n    const formGroups = formArray?.controls?.map((c, index) => ({\n      index,\n      form: c,\n      id: this.utilityService.generateUUID(),\n    }));\n    const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);\n    return filterObject\n      ? formGroups.filter(({ form }) =>\n          this.filterFormArrayGroupPipe.filterFunc(filterObject)(form),\n        )\n      : formGroups;\n  });\n  readonly paginatedAndFilteredFormArray = computed(() => {\n    const formArray = this.filteredFormArray(),\n      pageState = this.pageState();\n    return this.usePaginator()\n      ? this.paginatorPipe.transform(\n          formArray,\n          pageState?.pageSize || this.pageSize(),\n          pageState?.pageIndex || 0,\n        )\n      : formArray;\n  });\n\n  readonly filteredFormArrayLength = computed(() => this.filteredFormArray().length);\n\n  public override utilityService = inject(UtilityService);\n  public filterFormArrayGroupPipe = inject(FilterFormArrayGroupPipe);\n  public paginatorPipe = inject(PaginatorPipe);\n\n  ngOnInit(): void {\n    if (this.usePaginator == undefined) {\n      this._usePaginator = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.refresh();\n    }, 1000);\n  }\n\n  refresh() {\n    this.refresher = Math.random();\n  }\n\n  override onDestroy() {\n    this.formArrayPaginationSub?.unsubscribe();\n    return super.onDestroy();\n  }\n\n  pageChanged($event: { pageIndex: number; pageSize: number }) {\n    this.pageState.set($event);\n  }\n\n  resetPaginator() {\n    this.paginatorComponent?.reset();\n  }\n\n  protected preFormatFormSchema = (items: IFormSchema<TFormGroup>[]) => {\n    items.forEach((x) => {\n      if (x.onChangeFunc) x.triggerOnChangeOnInit = true;\n      else if (x.type == 'button') this.preFormatFormSchema(x.children);\n    });\n  };\n\n  override init(schema: IFormSchema<TFormGroup>[]): void {\n    this.filterForms.set([]);\n    for (const key in this.filterForm.controls) {\n      if (Object.prototype.hasOwnProperty.call(this.filterForm.controls, key)) {\n        this.filterForm.removeControl(key);\n      }\n    }\n    // debugger;\n    this.onDestroy();\n    if (schema)\n      for (const scheme of schema) {\n        // scheme.form = this.form || scheme.form;\n        this.handleFormScheme(scheme);\n      }\n    this._setFormSchemas(schema);\n  }\n\n  handleActionButtonClick(\n    index: number,\n    form: FormGroup<TFormGroup>,\n    e: { btn?: BtnComponent; actionButton: ITableInputBtn },\n  ) {\n    e.actionButton.action({ index, form, btn: e.btn });\n    // this.refresh();\n  }\n\n  deleteRowClicked = (\n    index: number,\n    rowForm: FormGroup<TFormGroup>,\n    config?: { btn: BtnComponent },\n  ) => {\n    this.deleteRowFunc(index, rowForm?.getRawValue(), config);\n    // this.refresh();\n  };\n\n  addRowClicked = (index: number) => {\n    this.addRowFunc(index + 1, this.filterFormValueSignal());\n    // this.refresh();\n    // this.filterForm.updateValueAndValidity();\n  };\n\n  checkRequiredFields = () => {\n    console.log(this.singleFormStructure);\n  };\n\n  override handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n      scheme.autoPickValueField = true;\n\n    if (scheme.optionsInitFunc) {\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        // this.optionsMap[scheme.field] = r;\n      });\n    }\n    if (scheme.isSearchField) {\n      this.filterForms.update((filterForms) => filterForms.concat([scheme]));\n      this.filterForm.addControl(scheme.field?.toString(), new FormControl());\n    } else if (scheme.type == 'button') {\n      if (scheme.children?.length)\n        this.childrenFormSchemaMap[scheme.field as string] = {\n          formSchema: scheme.children,\n          formSchemaStr: scheme.children.map((x) => x.field as string),\n        };\n    }\n    scheme.isRequired =\n      scheme.isRequired ||\n      (<FormGroup>this.singleFormStructure?.controls[scheme.field])?.hasValidator(\n        Validators.required,\n      );\n  }\n}\n\nexport interface ITableInputBtn extends IBtn {\n  action?: (arg?: { index: number; form: FormGroup; btn: BtnComponent }) => void;\n}\n","<div class=\"table-input\">\n  @if (filterForms()?.length) {\n    <div class=\"mb-3 {{ filterContainerClass() }}\">\n      <div class=\"d-flex\">\n        <app-btn\n          text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n          [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n          (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n      </div>\n      <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n        <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n        <div class=\"d-flex justify-content-end\">\n          <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n        </div>\n      </div>\n    </div>\n  }\n\n  <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n    <div class=\" \">\n      <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n        <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n          <tr class=\"text-center\">\n            @for (item of formSchema(); track item.label) {\n              <th class=\"{{ item.cls }}\">\n                {{ item.label | appTranslate | async }}\n                {{ item.isRequired ? '*' : '' }}\n              </th>\n            }\n            @if (!isShow()) {\n              <th></th>\n              <th></th>\n              @for (actionBtn of actionBtns(); track actionBtn) {\n                <th></th>\n              }\n            }\n          </tr>\n        </thead>\n        <tbody>\n          @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n            <tr\n              table-input-row\n              (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n              [isShow]=\"isShow()\"\n              [form]=\"subForm.form\"\n              [actionBtns]=\"actionBtns()\"\n              [formSchema]=\"formSchema()\"\n              [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n              (onDeleteRowFunc)=\"\n                deleteRowClicked(subForm.index, subForm.form, {\n                  btn: $event?.btn\n                })\n              \"\n              (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n          } @empty {\n            <tr>\n              <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n                {{ 'There are no items' | appTranslate | async }}\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    </div>\n\n    <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n      <paginator\n        #paginatorTag\n        [arrayLength]=\"filteredFormArrayLength()\"\n        (pageChanged)=\"pageChanged($event)\"\n        [pageSize]=\"pageSize()\"\n        [resetIndexFunc]=\"filterForm.valueChanges\" />\n    </div>\n  </div>\n</div>\n"]}
@@ -15247,6 +15247,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
15247
15247
  class TableInputComponent extends FormGeneratorComponent {
15248
15248
  constructor() {
15249
15249
  super(...arguments);
15250
+ this.formArray = input();
15250
15251
  this.filterContainerClass = input();
15251
15252
  this.border = input(true);
15252
15253
  this.isShow = input();
@@ -15259,11 +15260,15 @@ class TableInputComponent extends FormGeneratorComponent {
15259
15260
  this.usePaginator = signal(true);
15260
15261
  this.childrenFormSchemaMap = {};
15261
15262
  this.filterFormValueSignal = toSignal(this.filterForm.valueChanges);
15262
- this.formArrayLengthSignal = signal(undefined);
15263
+ this.formArrayLengthSignal = toSignal(toObservable(this.formArray).pipe(switchMap((form) => form?.valueChanges.pipe(map$1(() => form?.length)))));
15263
15264
  this.filteredFormArray = computed(() => {
15264
15265
  this.formArrayLengthSignal();
15265
- const formArray = this.formArray, filterFormValue = this.filterFormValueSignal();
15266
- const formGroups = formArray?.controls?.map((c, index) => ({ index, form: c }));
15266
+ const formArray = this.formArray(), filterFormValue = this.filterFormValueSignal();
15267
+ const formGroups = formArray?.controls?.map((c, index) => ({
15268
+ index,
15269
+ form: c,
15270
+ id: this.utilityService.generateUUID(),
15271
+ }));
15267
15272
  const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);
15268
15273
  return filterObject
15269
15274
  ? formGroups.filter(({ form }) => this.filterFormArrayGroupPipe.filterFunc(filterObject)(form))
@@ -15271,7 +15276,6 @@ class TableInputComponent extends FormGeneratorComponent {
15271
15276
  });
15272
15277
  this.paginatedAndFilteredFormArray = computed(() => {
15273
15278
  const formArray = this.filteredFormArray(), pageState = this.pageState();
15274
- // debugger;
15275
15279
  return this.usePaginator()
15276
15280
  ? this.paginatorPipe.transform(formArray, pageState?.pageSize || this.pageSize(), pageState?.pageIndex || 0)
15277
15281
  : formArray;
@@ -15301,14 +15305,6 @@ class TableInputComponent extends FormGeneratorComponent {
15301
15305
  console.log(this.singleFormStructure);
15302
15306
  };
15303
15307
  }
15304
- // @Input() pageType
15305
- set _formArray(v) {
15306
- this.formArray = v;
15307
- if (v)
15308
- v.valueChanges.subscribe((r) => {
15309
- this.formArrayLengthSignal.set(v?.length);
15310
- });
15311
- }
15312
15308
  set _pageSize(v) {
15313
15309
  this.pageSize.set(v);
15314
15310
  }
@@ -15395,7 +15391,7 @@ class TableInputComponent extends FormGeneratorComponent {
15395
15391
  this.singleFormStructure?.controls[scheme.field]?.hasValidator(Validators.required);
15396
15392
  }
15397
15393
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
15398
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { _formArray: { classPropertyName: "_formArray", publicName: "formArray", isSignal: false, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "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: 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: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTabsModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PaginatorComponent, selector: "paginator", inputs: ["pageSize", "pageIndex", "arrayLength", "resetIndexFunc", "pageSizeOptions"], outputs: ["pageChanged"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: TableInputRowComponent, selector: "tr[table-input-row]", inputs: ["isShow", "hideAdd", "actionBtns", "childrenFormSchemaMap"], outputs: ["onDeleteRowFunc", "onAddRowFunc", "onActionButtonClick"] }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
15394
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { formArray: { classPropertyName: "formArray", publicName: "formArray", isSignal: true, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "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: 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: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTabsModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PaginatorComponent, selector: "paginator", inputs: ["pageSize", "pageIndex", "arrayLength", "resetIndexFunc", "pageSizeOptions"], outputs: ["pageChanged"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: TableInputRowComponent, selector: "tr[table-input-row]", inputs: ["isShow", "hideAdd", "actionBtns", "childrenFormSchemaMap"], outputs: ["onDeleteRowFunc", "onAddRowFunc", "onActionButtonClick"] }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
15399
15395
  }
15400
15396
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputComponent, decorators: [{
15401
15397
  type: Component,
@@ -15431,11 +15427,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
15431
15427
  SDKTranslatePipe,
15432
15428
  FilterFormArrayGroupPipe,
15433
15429
  ValidationMessageComponent,
15434
- ], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"] }]
15435
- }], propDecorators: { _formArray: [{
15436
- type: Input,
15437
- args: ['formArray']
15438
- }], _pageSize: [{
15430
+ ], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"] }]
15431
+ }], propDecorators: { _pageSize: [{
15439
15432
  type: Input,
15440
15433
  args: ['pageSize']
15441
15434
  }], _formSchema: [{