ets-fe-ng-sdk 18.0.14 → 18.0.17

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.
@@ -379,4 +379,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImpor
379
379
  type: Input,
380
380
  args: ['formSchema']
381
381
  }] } });
382
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"find-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Reusables/reusable-comps/find-item/find-item.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Reusables/reusable-comps/find-item/find-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  TemplateRef,\n  signal,\n  computed,\n  input,\n  inject,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport {\n  Observable,\n  Subject,\n  debounceTime,\n  filter,\n  lastValueFrom,\n  map,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport { UserActivityService } from '../../../Reusables/reusable-pages/user-activity/ua-extras/user-activity.service';\nimport {\n  ITableSearchResp,\n  TableHttpsComponent,\n} from '../../../Shared/components/table-https/table-https.component';\nimport {\n  IObjectLiteral,\n  IRowOption,\n  IStrictFormGroup,\n  SortType,\n  TableCol,\n} from '../../../Shared/models/index.model';\nimport { EUA } from '../../reusable-pages/user-activity/ua-extras/user-activity.model';\nimport { FunctionCaller2, ToAnyPipe } from '../../../Shared/pipes/utility.pipe';\nimport { TablePlainComponent } from '../../../Shared/components/table-plain/table-plain.component';\nimport { BtnComponent } from '../../../Shared/components/btn/btn.component';\nimport { InputBasicComponent } from '../../../Shared/components/input/input-basic.component';\nimport { AutocompleteComponent } from '../../../Shared/components/autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../../../Shared/components/input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../../../Shared/components/phone-number/phone-number.component';\nimport { NgIf, NgFor, NgSwitch, NgSwitchCase, NgSwitchDefault, AsyncPipe } from '@angular/common';\nimport { LoaderComponent } from '../../../Shared/components/loader/loader.component';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { Config } from '../../../configs/index.config';\nimport { ActivatedRoute, Router, RouterLink } from '@angular/router';\nimport {\n  BaseFormGenerator,\n  IBaseFormSchema,\n} from '../../../Shared/components/form-generator/form-generator.base.component';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n@Component({\n  selector: 'app-find-item,find-item',\n  templateUrl: './find-item.component.html',\n  styleUrls: ['./find-item.component.scss'],\n  standalone: true,\n  imports: [\n    LoaderComponent,\n    NgIf,\n    FormsModule,\n    NgFor,\n    NgSwitch,\n    NgSwitchCase,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    RouterLink,\n    NgSwitchDefault,\n    InputBasicComponent,\n    BtnComponent,\n    TableHttpsComponent,\n    TablePlainComponent,\n    AsyncPipe,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FindItemComponent<\n    TQuery extends IObjectLiteral = any,\n    TRow extends IObjectLiteral = any,\n  >\n  extends BaseFormGenerator<TQuery, ISearchFormSchema<TQuery, TRow>>\n  implements OnInit\n{\n  /**\n   * Whether to sort schema\n   */\n  readonly autoFormatSchema = input(true);\n  readonly autoOrder = input(true);\n  readonly centerCells = input<boolean>();\n  readonly _displayedColumns = input<TableCol<TRow>[]>([], { alias: 'displayedColumns' });\n  readonly displayedColumns = computed(() =>\n    this.useCustomLabels()\n      ? this.tableService.globalColumnsFormatter(this._displayedColumns())\n      : this._displayedColumns(),\n  );\n  /**\n   * Row grid configuration\n   */\n  readonly gridClass = input('col-md-4 col-xxl-3');\n  readonly hideForm = input(false);\n  readonly expandedRowTemplate = input<TemplateRef<any>>();\n  readonly isTablePaginated = input(false);\n  readonly rowOptionsMap = input<(row: TRow) => IRowOption<TRow>[]>();\n  readonly isExpandable = input(false);\n  readonly label = input<string>();\n  readonly nowrap = input(false);\n  readonly options = input<IRowOption<TRow>[]>(undefined, { alias: 'rowOptions' });\n  readonly orderDirection = input<SortType>('asc');\n  readonly orderField = input<keyof TRow>();\n  readonly pageSize = input(10);\n  readonly searchFunction = input<(data: any) => Observable<TRow[] | { content: TRow[] }>>();\n  readonly showData = input(true);\n  readonly searchIfNoQuery = input(true);\n  readonly showExport = input(true);\n  readonly showFilter = input(false);\n  readonly showRefreshBtn = input<boolean>();\n  readonly startSectionTemplate = input<TemplateRef<HTMLElement>>();\n  form: FormGroup;\n  /**\n   * Used to specify if the search button should be shown\n   */\n  readonly showSearchBtn = input(true);\n  /**\n   * Used to specify if the clear form button should be shown\n   */\n  readonly showClearBtn = input(true);\n  /**\n   * Used to specify if validation messages should be shown\n   */\n  readonly showValidationMsg = input(true);\n  readonly createBtnRoute = input('../create');\n  /**\n   * Used to specify if show additional column button wiil be displayed or not.\n   */\n  readonly showAdditionalColumns = input(true);\n  readonly smallerFonts = input(false);\n  /** Use checkboxes */\n  readonly useSelection = input(false);\n\n  @Output('rowClick') _rowClick = new EventEmitter<any>();\n  @Output() clickedCreate = new EventEmitter();\n  @ViewChild(TableHttpsComponent) tableHTTPSREF: TableHttpsComponent<TRow>;\n  @ViewChild(TablePlainComponent) tablePlainRef: TablePlainComponent<TRow>;\n  readonly tableHTTPSREFSignal = viewChild<TableHttpsComponent<TRow>>(TableHttpsComponent);\n  readonly tablePlainRefSignal = viewChild<TablePlainComponent<TRow>>(TablePlainComponent);\n  readonly data = signal<TRow[]>([]);\n  readonly loading = signal<boolean>(false);\n  readonly searchForm = computed<FormGroup>(() => {\n    const form = new FormGroup({}),\n      schema = this.formSchema();\n    schema\n      .filter((x) => !x.standalone)\n      .forEach((s) => {\n        if (s.onChangeFunc) {\n          const sub = form.controls[s.field.toString()]?.valueChanges\n            .pipe(debounceTime(0))\n            .subscribe((r) => s.onChangeFunc(form.getRawValue(), r, this));\n          this.subs[s.field as string] = sub;\n        }\n        form.registerControl(\n          s.field.toString(),\n          new FormControl(s.value, s.validators, s.asyncValidators),\n        );\n      });\n    return form;\n  });\n  readonly standaloneForm = computed<FormGroup>(() => {\n    const form = new FormGroup({}),\n      schema = this.formSchema();\n    schema\n      .filter((x) => !!x.standalone)\n      .forEach((s) =>\n        form.registerControl(\n          s.field.toString(),\n          new FormControl(s.value, s.validators, s.asyncValidators),\n        ),\n      );\n    return form;\n  });\n  /**\n   * Used to specify if show create button is needed.\n   */\n  readonly createButton = input(false);\n\n  @Input('formSchema') set _formSchema(v: ISearchFormSchema<TQuery, TRow>[]) {\n    this.init(cloneDeep(v?.filter((x) => x)));\n  }\n\n  readonly searchObservableFunc = input<(data: any) => Observable<ITableSearchResp<TRow>>>();\n  readonly delimiterField = '~~~';\n  readonly delimiterWord = '~~';\n  readonly searchTrigger = new Subject<IObjectLiteral>();\n\n  readonly computedFormSchema = computed<ISearchFormSchema<TQuery, TRow>[]>(\n    () => {\n      const formSchema = this.formSchema() || [],\n        standaloneForm = this.standaloneForm(),\n        searchForm = this.searchForm();\n\n      return formSchema\n        .filter((x) => !x.hidden)\n        .map((scheme) => {\n          scheme.form = scheme.standalone ? standaloneForm : searchForm;\n          return scheme;\n        });\n    },\n    { equal: isEqual },\n  );\n\n  public uaS = inject(UserActivityService);\n  public router = inject(Router);\n  public route = inject(ActivatedRoute);\n\n  protected readonly subs2 = this.utilityService.createSubscriptionManager();\n\n  ngOnInit(): void {\n    //  this.fetchSavedQuery()\n    let allowImmediateSearch = false;\n    this.subs2.clear();\n    this.subs2.push(\n      this.searchTrigger\n        .pipe(\n          tap(() => {\n            console.log('Log subs 1');\n          }),\n          filter(() => !allowImmediateSearch),\n          debounceTime(200),\n          tap(() => {\n            allowImmediateSearch = true;\n          }),\n          tap(() => {\n            console.log('Log subs 1.1');\n          }),\n          switchMap((r) => this._search()),\n        )\n        .subscribe((r) => {\n          // debugger;\n        }),\n      this.searchTrigger\n        .pipe(\n          tap(() => {\n            console.log('Log subs 2');\n          }),\n          filter(() => allowImmediateSearch),\n          tap(() => {\n            console.log('Log subs 2.1');\n          }),\n          switchMap((r) => this._search()),\n        )\n        .subscribe((r) => {\n          // debugger;\n        }),\n    );\n  }\n\n  override onDestroy() {\n    this.subs2?.clear();\n    return super.onDestroy();\n  }\n\n  fetchSavedQuery() {\n    try {\n      const prevQueryString = this.route.snapshot.queryParamMap.get('q');\n      if (prevQueryString) {\n        const prevQuery: { [f: string]: any } = {};\n        const fields = prevQueryString.split(this.delimiterField);\n        for (const field of fields) {\n          const f = field.split(this.delimiterWord);\n          // debugger;\n          if (f[1] == null || f[1] == 'null') continue;\n          prevQuery[f[0]] = f[1];\n        }\n        this.searchForm()?.patchValue(prevQuery);\n        if (Object.values(prevQuery).some((x) => x != null)) this.search();\n      }\n    } catch (error) {\n      console.error(error);\n    }\n  }\n  init(schema: ISearchFormSchema<TQuery, TRow>[]) {\n    this.onDestroy();\n    if (!schema?.length) {\n      this._setFormSchemas(schema);\n      return;\n    }\n    // debugger;\n    this.handleAllSchema(schema);\n    for (const scheme of this.formSchema()) this.handleFormScheme(scheme);\n    for (const scheme of this.formSchema())\n      if (scheme.triggerOnChangeOnInit)\n        scheme.onChangeFunc(this.form.getRawValue(), this.form.getRawValue()[scheme.field], this);\n  }\n\n  handleAllSchema(schema: ISearchFormSchema<TQuery, TRow>[]) {\n    schema.forEach((x) => (x.type = x.type || 'text'));\n    if (this.autoFormatSchema() || this.autoOrder()) {\n      if (this.autoFormatSchema()) {\n        schema\n          .filter((x) => x.type == 'select')\n          .forEach((x) => {\n            if (x.options?.length > 5 || !x.options) x.type = 'autocomplete';\n          });\n        schema\n          .filter((x) => x.type == 'checkbox')\n          .forEach((x) => {\n            x.type = 'select';\n            x.options = Config.boolList;\n            x.labelField = 'title';\n            x.valueField = 'code';\n          });\n        this._setFormSchemas(schema);\n      }\n      if (this.autoOrder()) {\n        schema = schema.sort2('label', true);\n        this._setFormSchemas([\n          ...schema?.filter((x) => x.action && x.type != 'checkbox'),\n          ...schema?.filter((x) => !x.action && x.type != 'checkbox'),\n          ...schema?.filter((x) => x.type == 'checkbox'),\n        ]);\n      }\n    } else this._setFormSchemas(schema);\n  }\n\n  handleFormScheme(scheme: ISearchFormSchema<TQuery, TRow>) {\n    scheme.id = this.utilityService.generateUUID();\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc)\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        this.updateFormSchema(scheme.field, { options: r });\n        // this.optionsMap[scheme.field] = r;\n      });\n\n    if (scheme.optionsInitFunc2)\n      scheme.optionsInitFunc2().subscribe((r) => {\n        scheme.options = r;\n        this.updateFormSchema(scheme.field, { options: r });\n        // this.optionsMap[scheme.field] = r;\n      });\n  }\n\n  updateFormSchema(\n    fieldName: keyof TQuery,\n    scheme: Partial<ISearchFormSchema<{ [k in keyof TQuery]: AbstractControl<any, any> | any }>>,\n  ) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n\n  updateAllFormSchema(\n    map: (formField: ISearchFormSchema<TQuery, TRow>) => ISearchFormSchema<TQuery, TRow>,\n  ) {\n    return super._updateAllFormSchema(map);\n  }\n\n  detachFormScheme(fieldName?: keyof TQuery) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  readonly searchFormValue = toSignal(\n    toObservable(this.searchForm).pipe(\n      switchMap(\n        (form) =>\n          form?.valueChanges.pipe(\n            map(() => this.utilityService.deleteNull(this.searchForm()?.getRawValue())),\n          ),\n      ),\n    ),\n  );\n  readonly standaloneFormValue = toSignal(\n    toObservable(this.standaloneForm).pipe(\n      switchMap(\n        (form) =>\n          form?.valueChanges.pipe(\n            map(() => this.utilityService.deleteNull(this.standaloneForm()?.getRawValue())),\n          ),\n      ),\n    ),\n  );\n  readonly allSearchFormValue = computed(() => ({\n    ...this.searchFormValue(),\n    ...this.standaloneFormValue(),\n  }));\n\n  trackByRowID = (index, item) => {\n    return item?.value?.__rowID;\n  };\n\n  clearFilters() {\n    this.searchForm()?.reset();\n    this.search();\n  }\n\n  refresh() {\n    this.cdr.detectChanges();\n    this.search();\n    this.cdr.detectChanges();\n  }\n\n  search() {\n    this.searchTrigger.next(this.searchForm().getRawValue());\n  }\n\n  protected async _search() {\n    // debugger;\n    if (!this.searchForm()) return;\n    const req = this.utilityService.deleteNull(cloneDeep(this.searchForm()?.getRawValue()));\n    // debugger;\n    if (this.isTablePaginated()) {\n      if (!this.data()) this.loading.set(true);\n      this.data.set([]);\n      setTimeout(() => {\n        this.tableHTTPSREF?.search(req);\n        this.loading.set(false);\n      }, 0);\n    } else if (this.searchFunction) {\n      try {\n        this.loading.set(true);\n        const data = await lastValueFrom(\n          this.searchFunction()({\n            ...req,\n            sortBy: this.orderField() || 'createdOn',\n            sortDirection: this.orderDirection()?.toUpperCase() || 'DESC',\n          }),\n        );\n        this.data.set(data?.['content'] || data);\n        console.log(data);\n      } catch (error) {\n        console.error(Error);\n      }\n      this.loading.set(false);\n    }\n    try {\n      this.uaS.add({\n        code: EUA.searched,\n        activityDescription: this.label() + ' ' + JSON.stringify(req),\n      });\n    } catch (error) {\n      debugger;\n    }\n  }\n\n  saveQuery(query = this.searchFormValue()) {\n    this.router.navigate([], {\n      queryParams: {\n        q: Object.keys(query)\n          .filter((x) => query[x] != null)\n          .map((k) => `${k}${this.delimiterWord}${query[k]}`)\n          .join(this.delimiterField),\n      },\n      replaceUrl: true,\n      relativeTo: this.route,\n      queryParamsHandling: 'merge',\n    });\n  }\n  rowClick(e) {\n    this._rowClick.emit(e);\n  }\n\n  get selection() {\n    return this.tableHTTPSREF?.selectedItems || this.tablePlainRef?.selectedItems;\n  }\n  readonly selectionSignal = signal<TRow[]>([]);\n\n  readonly isAnySelected = computed(() => {\n    const th = this.tableHTTPSREFSignal()?.isAnySelected(),\n      tp = this.tablePlainRefSignal()?.isAnySelected();\n    return th || tp;\n  });\n  protected setSelection() {\n    this.selectionSignal.set(\n      this.tableHTTPSREF?.selectedItemsSignal() || this.tablePlainRef?.selectedItemsSignal(),\n    );\n  }\n}\n\nexport interface ISearchFormSchema<\n  TQuery extends IObjectLiteral = any,\n  TRow extends IObjectLiteral = any,\n> extends IBaseFormSchema<\n    TQuery,\n    FindItemComponent<TQuery, TRow>,\n    {\n      [K in keyof TQuery]: AbstractControl<any, any>;\n    }\n  > {\n  standalone?: boolean;\n  action?: (row: TRow, cell: any, form?: FormGroup<IStrictFormGroup<TQuery>>) => any;\n}\n","<loader [loading]=\"loading()\">\n  @if (!hideForm() && searchForm()) {\n    <form [formGroup]=\"searchForm()\" (ngSubmit)=\"search()\">\n      <div class=\"row align-items-center\">\n        @for (scheme of computedFormSchema(); track scheme._id) {\n          <div class=\"{{ gridClass() }} \">\n            <div class=\"row align-items-end\">\n              @switch (true) {\n                @case (scheme.type == 'tel') {\n                  <div class=\"col\">\n                    <app-phone-number\n                      [form]=\"scheme.form\"\n                      [label]=\"scheme.label\"\n                      [name]=\"scheme.field\"\n                      [showLabel]=\"false\"\n                      [showValidation]=\"scheme.showValidation\"\n                      [showValidationIcon]=\"scheme.showValidationIcon\"\n                      [countryCode3]=\"scheme.countryCode3\"\n                      [disabled]=\"\n                        scheme.disabledIf\n                          | functionCaller2: searchFormValue() : (scheme.field | toAny)\n                      \"\n                      #inputTag />\n                    @if (showValidationMsg()) {\n                      <app-validation-message [input]=\"inputTag\" />\n                    }\n                  </div>\n                }\n                @case (scheme.type == 'autocomplete') {\n                  <div class=\"col\">\n                    <app-autocomplete\n                      [form]=\"scheme.form\"\n                      [label]=\"scheme.label\"\n                      [labelField]=\"scheme.labelField\"\n                      [autoPickValueField]=\"scheme.autoPickValueField\"\n                      [labelType]=\"scheme.labelType | toAny\"\n                      [optionsFunc]=\"scheme.optionsFunc\"\n                      [name]=\"scheme.field\"\n                      [optionFormatter]=\"scheme.optionFormatter\"\n                      [valueField]=\"scheme.valueField\"\n                      [options]=\"scheme.options\"\n                      [hint]=\"scheme.hint\"\n                      [disabled]=\"\n                        scheme.disabledIf\n                          | functionCaller2: searchFormValue : (scheme.field | toAny)\n                      \"\n                      #inputTag />\n                    @if (showValidationMsg()) {\n                      <app-validation-message [input]=\"inputTag\" />\n                    }\n                  </div>\n                }\n                @default {\n                  <div class=\"col\">\n                    <form>\n                      <div class=\"gx-2 row align-items-end\">\n                        <div class=\"col\">\n                          <app-input-basic\n                            #formField\n                            [name]=\"scheme.field\"\n                            [form]=\"scheme.form\"\n                            [type]=\"scheme.type\"\n                            [autoPickValueField]=\"scheme.autoPickValueField\"\n                            [valueField]=\"scheme.valueField\"\n                            [labelType]=\"scheme.labelType | toAny\"\n                            [checkedSignal]=\"scheme.checked\"\n                            [showValidation]=\"!!scheme.asyncValidators\"\n                            [showValidationIcon]=\"!!scheme.asyncValidators\"\n                            [noFormat]=\"true\"\n                            [labelField]=\"scheme.labelField\"\n                            [optionFormatter]=\"scheme.optionFormatter\"\n                            [options]=\"scheme.options\"\n                            [decimalPoints]=\"scheme.decimalPoints\"\n                            [hint]=\"scheme.hint\"\n                            [max]=\"scheme.max\"\n                            [min]=\"scheme.min\"\n                            [placeholder]=\"scheme.placeholder\"\n                            [label]=\"scheme.label\"\n                            [disabled]=\"\n                              scheme.disabledIf\n                                | functionCaller2: searchFormValue : (scheme.field | toAny)\n                            \" />\n                        </div>\n                        @if (scheme.standalone && scheme.action) {\n                          <div class=\"col-auto\">\n                            <app-btn\n                              group=\"show\"\n                              [disabled]=\"!formField?.validSignal()\"\n                              actionType=\"submit\"\n                              (mclick)=\"\n                                scheme.action(\n                                  allSearchFormValue(),\n                                  formField.valueSignal(),\n                                  standaloneForm()\n                                )\n                              \" />\n                          </div>\n                        }\n                        @if (scheme.action && !scheme.standalone) {\n                          <div class=\"col-auto\">\n                            <app-btn\n                              [icon]=\"scheme.icon\"\n                              [iconBtn]=\"true\"\n                              actionType=\"submit\"\n                              (mclick)=\"\n                                scheme.action(\n                                  allSearchFormValue(),\n                                  formField.valueSignal(),\n                                  searchForm()\n                                )\n                              \" />\n                          </div>\n                        }\n                      </div>\n                    </form>\n                  </div>\n                  @if (showValidationMsg()) {\n                    <app-validation-message [input]=\"formField\" />\n                  }\n                }\n              }\n            </div>\n          </div>\n        }\n        <div class=\"col-md justify-content-end d-flex\">\n          @if (showClearBtn()) {\n            <app-btn type=\"danger-outline\" text=\"Clear\" icon=\"delete\" (mclick)=\"clearFilters()\" />\n          }\n          <span class=\"mx-1\"></span>\n          @if (showSearchBtn()) {\n            <app-btn\n              [group]=\"'search'\"\n              [iconBtn]=\"true\"\n              text=\"Search\"\n              actionType=\"submit\"\n              [excludeLogging]=\"true\"\n              [disabled]=\"!searchFunction() && !isTablePaginated()\"\n              (mclick)=\"search()\" />\n          }\n          @if (createButton()) {\n            <span class=\"mx-1\"></span>\n            @if (createBtnRoute()) {\n              <app-btn\n                type=\"outline\"\n                text=\"Create\"\n                icon=\"add\"\n                (mclick)=\"clickedCreate.emit()\"\n                routerLink=\"{{ createBtnRoute() }}\" />\n            } @else {\n              <app-btn type=\"outline\" text=\"Create\" icon=\"add\" (mclick)=\"clickedCreate.emit()\" />\n            }\n          }\n        </div>\n      </div>\n    </form>\n  }\n\n  <ng-content select=\"[tablePanel]\"></ng-content>\n\n  @if (displayedColumns()?.length) {\n    <div class=\"mt-3\" [hidden]=\"!showData() || (!data() && !isTablePaginated())\">\n      <ng-container>\n        @if (isTablePaginated()) {\n          <table-https\n            #tableHTTPS\n            [searchIfNoQuery]=\"searchIfNoQuery()\"\n            [displayedColumns]=\"displayedColumns()\"\n            [observableFunc]=\"searchObservableFunc()\"\n            (rowClick)=\"rowClick($event)\"\n            (selectionChanged)=\"setSelection()\"\n            [centerCells]=\"centerCells()\"\n            [expandedRowTemplate]=\"expandedRowTemplate()\"\n            [isExpandable]=\"isExpandable()\"\n            [label]=\"label()\"\n            [nowrap]=\"nowrap()\"\n            [orderDirection]=\"orderDirection()\"\n            [orderField]=\"orderField()\"\n            [pageSize]=\"pageSize()\"\n            [rowOptions]=\"options()\"\n            [rowOptionsMap]=\"rowOptionsMap()\"\n            [showAdditionalColumns]=\"showAdditionalColumns()\"\n            [showExport]=\"showExport()\"\n            [showRefreshBtn]=\"showRefreshBtn()\"\n            [smallerFonts]=\"smallerFonts()\"\n            [startSectionTemplate]=\"startSectionTemplate()\"\n            [useSelection]=\"useSelection()\"\n            noItemTxt=\"No results found\" />\n        } @else {\n          <table-plain\n            [distinct]=\"true\"\n            [showPager]=\"true\"\n            [pageSize]=\"pageSize()\"\n            [centerCells]=\"false\"\n            [startSectionTemplate]=\"startSectionTemplate()\"\n            [smallerFonts]=\"smallerFonts()\"\n            [nowrap]=\"nowrap()\"\n            [showFilter]=\"showFilter()\"\n            [showExport]=\"showExport()\"\n            [isExpandable]=\"isExpandable()\"\n            [expandedRowTemplate]=\"expandedRowTemplate()\"\n            [label]=\"label()\"\n            noItemTxt=\"No results found\"\n            (rowClick)=\"rowClick($event)\"\n            [orderField]=\"orderField()\"\n            [rowOptions]=\"options()\"\n            [rowOptionsMap]=\"rowOptionsMap()\"\n            [showAdditionalColumns]=\"showAdditionalColumns()\"\n            [orderDirection]=\"orderDirection()\"\n            [displayedColumns]=\"displayedColumns()\"\n            (selectionChanged)=\"setSelection()\"\n            [data]=\"data()\" />\n        }\n      </ng-container>\n    </div>\n  }\n</loader>\n"]}
382
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"find-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Reusables/reusable-comps/find-item/find-item.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Reusables/reusable-comps/find-item/find-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,KAAK,EACL,MAAM,EACN,YAAY,EACZ,SAAS,EAET,MAAM,EACN,QAAQ,EACR,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAEL,WAAW,EACX,SAAS,EACT,WAAW,EACX,mBAAmB,GACpB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAEL,OAAO,EACP,YAAY,EACZ,MAAM,EACN,aAAa,EACb,GAAG,EACH,SAAS,EACT,GAAG,GACJ,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,mBAAmB,EAAE,MAAM,iFAAiF,CAAC;AACtH,OAAO,EAEL,mBAAmB,GACpB,MAAM,8DAA8D,CAAC;AAQtE,OAAO,EAAE,GAAG,EAAE,MAAM,kEAAkE,CAAC;AACvF,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAChF,OAAO,EAAE,mBAAmB,EAAE,MAAM,8DAA8D,CAAC;AACnG,OAAO,EAAE,YAAY,EAAE,MAAM,8CAA8C,CAAC;AAC5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,wDAAwD,CAAC;AAC7F,OAAO,EAAE,qBAAqB,EAAE,MAAM,gEAAgE,CAAC;AACvG,OAAO,EAAE,0BAA0B,EAAE,MAAM,kFAAkF,CAAC;AAC9H,OAAO,EAAE,oBAAoB,EAAE,MAAM,gEAAgE,CAAC;AACtG,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,YAAY,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAClG,OAAO,EAAE,eAAe,EAAE,MAAM,oDAAoD,CAAC;AACrF,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACrE,OAAO,EACL,iBAAiB,GAElB,MAAM,yEAAyE,CAAC;AACjF,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;;;AA6BpE,MAAM,OAAO,iBAIX,SAAQ,iBAA0D;IA/BpE;;QAkCE;;WAEG;QACM,qBAAgB,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAC/B,cAAS,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QACxB,gBAAW,GAAG,KAAK,EAAW,CAAC;QAC/B,sBAAiB,GAAG,KAAK,CAAmB,EAAE,EAAE,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAC/E,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE,CACxC,IAAI,CAAC,eAAe,EAAE;YACpB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACpE,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAC7B,CAAC;QACF;;WAEG;QACM,cAAS,GAAG,KAAK,CAAC,oBAAoB,CAAC,CAAC;QACxC,aAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QACxB,wBAAmB,GAAG,KAAK,EAAoB,CAAC;QAChD,qBAAgB,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAChC,kBAAa,GAAG,KAAK,EAA8C,CAAC;QACpE,iBAAY,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAC5B,UAAK,GAAG,KAAK,EAAU,CAAC;QACxB,WAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QACtB,YAAO,GAAG,KAAK,CAAqB,SAAS,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC;QACxE,mBAAc,GAAG,KAAK,CAAW,KAAK,CAAC,CAAC;QACxC,eAAU,GAAG,KAAK,EAAc,CAAC;QACjC,aAAQ,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;QACrB,mBAAc,GAAG,KAAK,EAA2D,CAAC;QAClF,aAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QACvB,oBAAe,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAC9B,eAAU,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QACzB,eAAU,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAC1B,mBAAc,GAAG,KAAK,EAAW,CAAC;QAClC,yBAAoB,GAAG,KAAK,EAA4B,CAAC;QAElE;;WAEG;QACM,kBAAa,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QACrC;;WAEG;QACM,iBAAY,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QACpC;;WAEG;QACM,sBAAiB,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAChC,mBAAc,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC;QAC7C;;WAEG;QACM,0BAAqB,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QACpC,iBAAY,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QACrC,qBAAqB;QACZ,iBAAY,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAEjB,cAAS,GAAG,IAAI,YAAY,EAAO,CAAC;QAC9C,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAGpC,wBAAmB,GAAG,SAAS,CAA4B,mBAAmB,CAAC,CAAC;QAChF,wBAAmB,GAAG,SAAS,CAA4B,mBAAmB,CAAC,CAAC;QAChF,SAAI,GAAG,MAAM,CAAS,EAAE,CAAC,CAAC;QAC1B,YAAO,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QACjC,eAAU,GAAG,QAAQ,CAAY,GAAG,EAAE;YAC7C,MAAM,IAAI,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,EAC5B,MAAM,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAC7B,MAAM;iBACH,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;iBAC5B,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;gBACb,IAAI,CAAC,CAAC,YAAY,EAAE,CAAC;oBACnB,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,EAAE,YAAY;yBACxD,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;yBACrB,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;oBACjE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,KAAe,CAAC,GAAG,GAAG,CAAC;gBACrC,CAAC;gBACD,IAAI,CAAC,eAAe,CAClB,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,EAClB,IAAI,WAAW,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC,eAAe,CAAC,CAC1D,CAAC;YACJ,CAAC,CAAC,CAAC;YACL,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;QACM,mBAAc,GAAG,QAAQ,CAAY,GAAG,EAAE;YACjD,MAAM,IAAI,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,EAC5B,MAAM,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAC7B,MAAM;iBACH,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;iBAC7B,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CACb,IAAI,CAAC,eAAe,CAClB,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,EAClB,IAAI,WAAW,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC,eAAe,CAAC,CAC1D,CACF,CAAC;YACJ,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;QACH;;WAEG;QACM,iBAAY,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAM5B,yBAAoB,GAAG,KAAK,EAAqD,CAAC;QAClF,mBAAc,GAAG,KAAK,CAAC;QACvB,kBAAa,GAAG,IAAI,CAAC;QACrB,kBAAa,GAAG,IAAI,OAAO,EAAkB,CAAC;QAE9C,uBAAkB,GAAG,QAAQ,CACpC,GAAG,EAAE;YACH,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,EACxC,cAAc,GAAG,IAAI,CAAC,cAAc,EAAE,EACtC,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAEjC,OAAO,UAAU;iBACd,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;iBACxB,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;gBACd,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC;gBAC9D,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC,CAAC;QACP,CAAC,EACD,EAAE,KAAK,EAAE,OAAO,EAAE,CACnB,CAAC;QAEK,QAAG,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAClC,WAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACxB,UAAK,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAEnB,UAAK,GAAG,IAAI,CAAC,cAAc,CAAC,yBAAyB,EAAE,CAAC;QAkJlE,oBAAe,GAAG,QAAQ,CACjC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAChC,SAAS,CACP,CAAC,IAAI,EAAE,EAAE,CACP,IAAI,EAAE,YAAY,CAAC,IAAI,CACrB,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC,CAC5E,CACJ,CACF,CACF,CAAC;QACO,wBAAmB,GAAG,QAAQ,CACrC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,IAAI,CACpC,SAAS,CACP,CAAC,IAAI,EAAE,EAAE,CACP,IAAI,EAAE,YAAY,CAAC,IAAI,CACrB,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC,CAChF,CACJ,CACF,CACF,CAAC;QACO,uBAAkB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC;YAC5C,GAAG,IAAI,CAAC,eAAe,EAAE;YACzB,GAAG,IAAI,CAAC,mBAAmB,EAAE;SAC9B,CAAC,CAAC,CAAC;QAEJ,iBAAY,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;YAC7B,OAAO,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC;QAC9B,CAAC,CAAC;QA4EO,oBAAe,GAAG,MAAM,CAAS,EAAE,CAAC,CAAC;QAErC,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE;YACrC,MAAM,EAAE,GAAG,IAAI,CAAC,mBAAmB,EAAE,EAAE,aAAa,EAAE,EACpD,EAAE,GAAG,IAAI,CAAC,mBAAmB,EAAE,EAAE,aAAa,EAAE,CAAC;YACnD,OAAO,EAAE,IAAI,EAAE,CAAC;QAClB,CAAC,CAAC,CAAC;KAMJ;IAlSC,IAAyB,WAAW,CAAC,CAAoC;QACvE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IA6BD,QAAQ;QACN,0BAA0B;QAC1B,IAAI,oBAAoB,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;QACnB,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,aAAa;aACf,IAAI,CACH,GAAG,CAAC,GAAG,EAAE;YACP,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC5B,CAAC,CAAC,EACF,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,oBAAoB,CAAC,EACnC,YAAY,CAAC,GAAG,CAAC,EACjB,GAAG,CAAC,GAAG,EAAE;YACP,oBAAoB,GAAG,IAAI,CAAC;QAC9B,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE;YACP,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC9B,CAAC,CAAC,EACF,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CACjC;aACA,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACf,YAAY;QACd,CAAC,CAAC,EACJ,IAAI,CAAC,aAAa;aACf,IAAI,CACH,GAAG,CAAC,GAAG,EAAE;YACP,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC5B,CAAC,CAAC,EACF,MAAM,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC,EAClC,GAAG,CAAC,GAAG,EAAE;YACP,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC9B,CAAC,CAAC,EACF,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CACjC;aACA,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACf,YAAY;QACd,CAAC,CAAC,CACL,CAAC;IACJ,CAAC;IAEQ,SAAS;QAChB,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC;QACpB,OAAO,KAAK,CAAC,SAAS,EAAE,CAAC;IAC3B,CAAC;IAED,eAAe;QACb,IAAI,CAAC;YACH,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACnE,IAAI,eAAe,EAAE,CAAC;gBACpB,MAAM,SAAS,GAAyB,EAAE,CAAC;gBAC3C,MAAM,MAAM,GAAG,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBAC1D,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBAC3B,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;oBAC1C,YAAY;oBACZ,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,MAAM;wBAAE,SAAS;oBAC7C,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACzB,CAAC;gBACD,IAAI,CAAC,UAAU,EAAE,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;gBACzC,IAAI,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC;oBAAE,IAAI,CAAC,MAAM,EAAE,CAAC;YACrE,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IACD,IAAI,CAAC,MAAyC;QAC5C,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;YACpB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;YAC7B,OAAO;QACT,CAAC;QACD,YAAY;QACZ,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QAC7B,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,UAAU,EAAE;YAAE,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACtE,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,UAAU,EAAE;YACpC,IAAI,MAAM,CAAC,qBAAqB;gBAC9B,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC;IAChG,CAAC;IAED,eAAe,CAAC,MAAyC;QACvD,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC;QACnD,IAAI,IAAI,CAAC,gBAAgB,EAAE,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YAChD,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE,CAAC;gBAC5B,MAAM;qBACH,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,QAAQ,CAAC;qBACjC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBACb,IAAI,CAAC,CAAC,OAAO,EAAE,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO;wBAAE,CAAC,CAAC,IAAI,GAAG,cAAc,CAAC;gBACnE,CAAC,CAAC,CAAC;gBACL,MAAM;qBACH,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,UAAU,CAAC;qBACnC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBACb,CAAC,CAAC,IAAI,GAAG,QAAQ,CAAC;oBAClB,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC,QAAQ,CAAC;oBAC5B,CAAC,CAAC,UAAU,GAAG,OAAO,CAAC;oBACvB,CAAC,CAAC,UAAU,GAAG,MAAM,CAAC;gBACxB,CAAC,CAAC,CAAC;gBACL,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;YAC/B,CAAC;YACD,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;gBACrB,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;gBACrC,IAAI,CAAC,eAAe,CAAC;oBACnB,GAAG,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,IAAI,IAAI,UAAU,CAAC;oBAC1D,GAAG,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,IAAI,IAAI,UAAU,CAAC;oBAC3D,GAAG,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,UAAU,CAAC;iBAC/C,CAAC,CAAC;YACL,CAAC;QACH,CAAC;;YAAM,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;IAED,gBAAgB,CAAC,MAAuC;QACtD,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;QAC/C,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAE5C,IAAI,MAAM,CAAC,eAAe;YACxB,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;gBACrC,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC;gBACnB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;gBACpD,qCAAqC;YACvC,CAAC,CAAC,CAAC;QAEL,IAAI,MAAM,CAAC,gBAAgB;YACzB,MAAM,CAAC,gBAAgB,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;gBACxC,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC;gBACnB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;gBACpD,qCAAqC;YACvC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,gBAAgB,CACd,SAAuB,EACvB,MAA4F;QAE5F,OAAO,KAAK,CAAC,iBAAiB,CAAC,SAAmB,EAAE,MAAM,CAAC,CAAC;IAC9D,CAAC;IAED,mBAAmB,CACjB,GAAoF;QAEpF,OAAO,KAAK,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC;IAED,gBAAgB,CAAC,SAAwB;QACvC,IAAI,CAAC,IAAI,CAAC,SAAmB,CAAC,EAAE,WAAW,EAAE,CAAC;IAChD,CAAC;IA+BD,YAAY;QACV,IAAI,CAAC,UAAU,EAAE,EAAE,KAAK,EAAE,CAAC;QAC3B,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;IAC3D,CAAC;IAES,KAAK,CAAC,OAAO;QACrB,YAAY;QACZ,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAAE,OAAO;QAC/B,MAAM,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;QACxF,YAAY;QACZ,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE,CAAC;YAC5B,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;gBAAE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACzC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAClB,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;gBAChC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC,EAAE,CAAC,CAAC,CAAC;QACR,CAAC;aAAM,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YAC/B,IAAI,CAAC;gBACH,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACvB,MAAM,IAAI,GAAG,MAAM,aAAa,CAC9B,IAAI,CAAC,cAAc,EAAE,CAAC;oBACpB,GAAG,GAAG;oBACN,MAAM,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,WAAW;oBACxC,aAAa,EAAE,IAAI,CAAC,cAAc,EAAE,EAAE,WAAW,EAAE,IAAI,MAAM;iBAC9D,CAAC,CACH,CAAC;gBACF,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,CAAC;gBACzC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACpB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACvB,CAAC;YACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;QACD,IAAI,CAAC;YACH,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;gBACX,IAAI,EAAE,GAAG,CAAC,QAAQ;gBAClB,mBAAmB,EAAE,IAAI,CAAC,KAAK,EAAE,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;aAC9D,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,QAAQ,CAAC;QACX,CAAC;IACH,CAAC;IAED,SAAS,CAAC,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE;QACtC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,EAAE;YACvB,WAAW,EAAE;gBACX,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;qBAClB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;qBAC/B,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;qBAClD,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;aAC7B;YACD,UAAU,EAAE,IAAI;YAChB,UAAU,EAAE,IAAI,CAAC,KAAK;YACtB,mBAAmB,EAAE,OAAO;SAC7B,CAAC,CAAC;IACL,CAAC;IACD,QAAQ,CAAC,CAAC;QACR,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,aAAa,EAAE,aAAa,IAAI,IAAI,CAAC,aAAa,EAAE,aAAa,CAAC;IAChF,CAAC;IAQS,YAAY;QACpB,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,IAAI,CAAC,aAAa,EAAE,mBAAmB,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE,mBAAmB,EAAE,CACvF,CAAC;IACJ,CAAC;8GA7YU,iBAAiB;kGAAjB,iBAAiB,g0JAmEwC,mBAAmB,sGACnB,mBAAmB,gGAH5E,mBAAmB,gFACnB,mBAAmB,uEC3JhC,k1SAwNA,0DDpJI,eAAe,sHAEf,WAAW,wdAIX,oBAAoB,4IACpB,0BAA0B,2NAC1B,qBAAqB,8HACrB,UAAU,oOAEV,mBAAmB,6VACnB,YAAY,mgBACZ,mBAAmB,iMACnB,mBAAmB,wSAEnB,mBAAmB,2KACnB,eAAe,mDACf,SAAS;;2FAGA,iBAAiB;kBA3B7B,SAAS;+BACE,yBAAyB,cAGvB,IAAI,WACP;wBACP,eAAe;wBACf,IAAI;wBACJ,WAAW;wBACX,KAAK;wBACL,QAAQ;wBACR,YAAY;wBACZ,oBAAoB;wBACpB,0BAA0B;wBAC1B,qBAAqB;wBACrB,UAAU;wBACV,eAAe;wBACf,mBAAmB;wBACnB,YAAY;wBACZ,mBAAmB;wBACnB,mBAAmB;wBACnB,SAAS;wBACT,mBAAmB;wBACnB,eAAe;wBACf,SAAS;qBACV;8BAiEmB,SAAS;sBAA5B,MAAM;uBAAC,UAAU;gBACR,aAAa;sBAAtB,MAAM;gBACyB,aAAa;sBAA5C,SAAS;uBAAC,mBAAmB;gBACE,aAAa;sBAA5C,SAAS;uBAAC,mBAAmB;gBA0CL,WAAW;sBAAnC,KAAK;uBAAC,YAAY","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  TemplateRef,\n  signal,\n  computed,\n  input,\n  inject,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport {\n  Observable,\n  Subject,\n  debounceTime,\n  filter,\n  lastValueFrom,\n  map,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport { UserActivityService } from '../../../Reusables/reusable-pages/user-activity/ua-extras/user-activity.service';\nimport {\n  ITableSearchResp,\n  TableHttpsComponent,\n} from '../../../Shared/components/table-https/table-https.component';\nimport {\n  IObjectLiteral,\n  IRowOption,\n  IStrictFormGroup,\n  SortType,\n  TableCol,\n} from '../../../Shared/models/index.model';\nimport { EUA } from '../../reusable-pages/user-activity/ua-extras/user-activity.model';\nimport { FunctionCaller2, ToAnyPipe } from '../../../Shared/pipes/utility.pipe';\nimport { TablePlainComponent } from '../../../Shared/components/table-plain/table-plain.component';\nimport { BtnComponent } from '../../../Shared/components/btn/btn.component';\nimport { InputBasicComponent } from '../../../Shared/components/input/input-basic.component';\nimport { AutocompleteComponent } from '../../../Shared/components/autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../../../Shared/components/input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../../../Shared/components/phone-number/phone-number.component';\nimport { NgIf, NgFor, NgSwitch, NgSwitchCase, NgSwitchDefault, AsyncPipe } from '@angular/common';\nimport { LoaderComponent } from '../../../Shared/components/loader/loader.component';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { Config } from '../../../configs/index.config';\nimport { ActivatedRoute, Router, RouterLink } from '@angular/router';\nimport {\n  BaseFormGenerator,\n  IBaseFormSchema,\n} from '../../../Shared/components/form-generator/form-generator.base.component';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n@Component({\n  selector: 'app-find-item,find-item',\n  templateUrl: './find-item.component.html',\n  styleUrls: ['./find-item.component.scss'],\n  standalone: true,\n  imports: [\n    LoaderComponent,\n    NgIf,\n    FormsModule,\n    NgFor,\n    NgSwitch,\n    NgSwitchCase,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    RouterLink,\n    NgSwitchDefault,\n    InputBasicComponent,\n    BtnComponent,\n    TableHttpsComponent,\n    TablePlainComponent,\n    AsyncPipe,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FindItemComponent<\n    TQuery extends IObjectLiteral = any,\n    TRow extends IObjectLiteral = any,\n  >\n  extends BaseFormGenerator<TQuery, ISearchFormSchema<TQuery, TRow>>\n  implements OnInit\n{\n  /**\n   * Whether to sort schema\n   */\n  readonly autoFormatSchema = input(true);\n  readonly autoOrder = input(true);\n  readonly centerCells = input<boolean>();\n  readonly _displayedColumns = input<TableCol<TRow>[]>([], { alias: 'displayedColumns' });\n  readonly displayedColumns = computed(() =>\n    this.useCustomLabels()\n      ? this.tableService.globalColumnsFormatter(this._displayedColumns())\n      : this._displayedColumns(),\n  );\n  /**\n   * Row grid configuration\n   */\n  readonly gridClass = input('col-md-4 col-xxl-3');\n  readonly hideForm = input(false);\n  readonly expandedRowTemplate = input<TemplateRef<any>>();\n  readonly isTablePaginated = input(false);\n  readonly rowOptionsMap = input<(row: TRow) => (IRowOption<TRow> | null)[]>();\n  readonly isExpandable = input(false);\n  readonly label = input<string>();\n  readonly nowrap = input(false);\n  readonly options = input<IRowOption<TRow>[]>(undefined, { alias: 'rowOptions' });\n  readonly orderDirection = input<SortType>('asc');\n  readonly orderField = input<keyof TRow>();\n  readonly pageSize = input(10);\n  readonly searchFunction = input<(data: any) => Observable<TRow[] | { content: TRow[] }>>();\n  readonly showData = input(true);\n  readonly searchIfNoQuery = input(true);\n  readonly showExport = input(true);\n  readonly showFilter = input(false);\n  readonly showRefreshBtn = input<boolean>();\n  readonly startSectionTemplate = input<TemplateRef<HTMLElement>>();\n  form: FormGroup;\n  /**\n   * Used to specify if the search button should be shown\n   */\n  readonly showSearchBtn = input(true);\n  /**\n   * Used to specify if the clear form button should be shown\n   */\n  readonly showClearBtn = input(true);\n  /**\n   * Used to specify if validation messages should be shown\n   */\n  readonly showValidationMsg = input(true);\n  readonly createBtnRoute = input('../create');\n  /**\n   * Used to specify if show additional column button wiil be displayed or not.\n   */\n  readonly showAdditionalColumns = input(true);\n  readonly smallerFonts = input(false);\n  /** Use checkboxes */\n  readonly useSelection = input(false);\n\n  @Output('rowClick') _rowClick = new EventEmitter<any>();\n  @Output() clickedCreate = new EventEmitter();\n  @ViewChild(TableHttpsComponent) tableHTTPSREF: TableHttpsComponent<TRow>;\n  @ViewChild(TablePlainComponent) tablePlainRef: TablePlainComponent<TRow>;\n  readonly tableHTTPSREFSignal = viewChild<TableHttpsComponent<TRow>>(TableHttpsComponent);\n  readonly tablePlainRefSignal = viewChild<TablePlainComponent<TRow>>(TablePlainComponent);\n  readonly data = signal<TRow[]>([]);\n  readonly loading = signal<boolean>(false);\n  readonly searchForm = computed<FormGroup>(() => {\n    const form = new FormGroup({}),\n      schema = this.formSchema();\n    schema\n      .filter((x) => !x.standalone)\n      .forEach((s) => {\n        if (s.onChangeFunc) {\n          const sub = form.controls[s.field.toString()]?.valueChanges\n            .pipe(debounceTime(0))\n            .subscribe((r) => s.onChangeFunc(form.getRawValue(), r, this));\n          this.subs[s.field as string] = sub;\n        }\n        form.registerControl(\n          s.field.toString(),\n          new FormControl(s.value, s.validators, s.asyncValidators),\n        );\n      });\n    return form;\n  });\n  readonly standaloneForm = computed<FormGroup>(() => {\n    const form = new FormGroup({}),\n      schema = this.formSchema();\n    schema\n      .filter((x) => !!x.standalone)\n      .forEach((s) =>\n        form.registerControl(\n          s.field.toString(),\n          new FormControl(s.value, s.validators, s.asyncValidators),\n        ),\n      );\n    return form;\n  });\n  /**\n   * Used to specify if show create button is needed.\n   */\n  readonly createButton = input(false);\n\n  @Input('formSchema') set _formSchema(v: ISearchFormSchema<TQuery, TRow>[]) {\n    this.init(cloneDeep(v?.filter((x) => x)));\n  }\n\n  readonly searchObservableFunc = input<(data: any) => Observable<ITableSearchResp<TRow>>>();\n  readonly delimiterField = '~~~';\n  readonly delimiterWord = '~~';\n  readonly searchTrigger = new Subject<IObjectLiteral>();\n\n  readonly computedFormSchema = computed<ISearchFormSchema<TQuery, TRow>[]>(\n    () => {\n      const formSchema = this.formSchema() || [],\n        standaloneForm = this.standaloneForm(),\n        searchForm = this.searchForm();\n\n      return formSchema\n        .filter((x) => !x.hidden)\n        .map((scheme) => {\n          scheme.form = scheme.standalone ? standaloneForm : searchForm;\n          return scheme;\n        });\n    },\n    { equal: isEqual },\n  );\n\n  public uaS = inject(UserActivityService);\n  public router = inject(Router);\n  public route = inject(ActivatedRoute);\n\n  protected readonly subs2 = this.utilityService.createSubscriptionManager();\n\n  ngOnInit(): void {\n    //  this.fetchSavedQuery()\n    let allowImmediateSearch = false;\n    this.subs2.clear();\n    this.subs2.push(\n      this.searchTrigger\n        .pipe(\n          tap(() => {\n            console.log('Log subs 1');\n          }),\n          filter(() => !allowImmediateSearch),\n          debounceTime(200),\n          tap(() => {\n            allowImmediateSearch = true;\n          }),\n          tap(() => {\n            console.log('Log subs 1.1');\n          }),\n          switchMap((r) => this._search()),\n        )\n        .subscribe((r) => {\n          // debugger;\n        }),\n      this.searchTrigger\n        .pipe(\n          tap(() => {\n            console.log('Log subs 2');\n          }),\n          filter(() => allowImmediateSearch),\n          tap(() => {\n            console.log('Log subs 2.1');\n          }),\n          switchMap((r) => this._search()),\n        )\n        .subscribe((r) => {\n          // debugger;\n        }),\n    );\n  }\n\n  override onDestroy() {\n    this.subs2?.clear();\n    return super.onDestroy();\n  }\n\n  fetchSavedQuery() {\n    try {\n      const prevQueryString = this.route.snapshot.queryParamMap.get('q');\n      if (prevQueryString) {\n        const prevQuery: { [f: string]: any } = {};\n        const fields = prevQueryString.split(this.delimiterField);\n        for (const field of fields) {\n          const f = field.split(this.delimiterWord);\n          // debugger;\n          if (f[1] == null || f[1] == 'null') continue;\n          prevQuery[f[0]] = f[1];\n        }\n        this.searchForm()?.patchValue(prevQuery);\n        if (Object.values(prevQuery).some((x) => x != null)) this.search();\n      }\n    } catch (error) {\n      console.error(error);\n    }\n  }\n  init(schema: ISearchFormSchema<TQuery, TRow>[]) {\n    this.onDestroy();\n    if (!schema?.length) {\n      this._setFormSchemas(schema);\n      return;\n    }\n    // debugger;\n    this.handleAllSchema(schema);\n    for (const scheme of this.formSchema()) this.handleFormScheme(scheme);\n    for (const scheme of this.formSchema())\n      if (scheme.triggerOnChangeOnInit)\n        scheme.onChangeFunc(this.form.getRawValue(), this.form.getRawValue()[scheme.field], this);\n  }\n\n  handleAllSchema(schema: ISearchFormSchema<TQuery, TRow>[]) {\n    schema.forEach((x) => (x.type = x.type || 'text'));\n    if (this.autoFormatSchema() || this.autoOrder()) {\n      if (this.autoFormatSchema()) {\n        schema\n          .filter((x) => x.type == 'select')\n          .forEach((x) => {\n            if (x.options?.length > 5 || !x.options) x.type = 'autocomplete';\n          });\n        schema\n          .filter((x) => x.type == 'checkbox')\n          .forEach((x) => {\n            x.type = 'select';\n            x.options = Config.boolList;\n            x.labelField = 'title';\n            x.valueField = 'code';\n          });\n        this._setFormSchemas(schema);\n      }\n      if (this.autoOrder()) {\n        schema = schema.sort2('label', true);\n        this._setFormSchemas([\n          ...schema?.filter((x) => x.action && x.type != 'checkbox'),\n          ...schema?.filter((x) => !x.action && x.type != 'checkbox'),\n          ...schema?.filter((x) => x.type == 'checkbox'),\n        ]);\n      }\n    } else this._setFormSchemas(schema);\n  }\n\n  handleFormScheme(scheme: ISearchFormSchema<TQuery, TRow>) {\n    scheme.id = this.utilityService.generateUUID();\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc)\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        this.updateFormSchema(scheme.field, { options: r });\n        // this.optionsMap[scheme.field] = r;\n      });\n\n    if (scheme.optionsInitFunc2)\n      scheme.optionsInitFunc2().subscribe((r) => {\n        scheme.options = r;\n        this.updateFormSchema(scheme.field, { options: r });\n        // this.optionsMap[scheme.field] = r;\n      });\n  }\n\n  updateFormSchema(\n    fieldName: keyof TQuery,\n    scheme: Partial<ISearchFormSchema<{ [k in keyof TQuery]: AbstractControl<any, any> | any }>>,\n  ) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n\n  updateAllFormSchema(\n    map: (formField: ISearchFormSchema<TQuery, TRow>) => ISearchFormSchema<TQuery, TRow>,\n  ) {\n    return super._updateAllFormSchema(map);\n  }\n\n  detachFormScheme(fieldName?: keyof TQuery) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  readonly searchFormValue = toSignal(\n    toObservable(this.searchForm).pipe(\n      switchMap(\n        (form) =>\n          form?.valueChanges.pipe(\n            map(() => this.utilityService.deleteNull(this.searchForm()?.getRawValue())),\n          ),\n      ),\n    ),\n  );\n  readonly standaloneFormValue = toSignal(\n    toObservable(this.standaloneForm).pipe(\n      switchMap(\n        (form) =>\n          form?.valueChanges.pipe(\n            map(() => this.utilityService.deleteNull(this.standaloneForm()?.getRawValue())),\n          ),\n      ),\n    ),\n  );\n  readonly allSearchFormValue = computed(() => ({\n    ...this.searchFormValue(),\n    ...this.standaloneFormValue(),\n  }));\n\n  trackByRowID = (index, item) => {\n    return item?.value?.__rowID;\n  };\n\n  clearFilters() {\n    this.searchForm()?.reset();\n    this.search();\n  }\n\n  refresh() {\n    this.cdr.detectChanges();\n    this.search();\n    this.cdr.detectChanges();\n  }\n\n  search() {\n    this.searchTrigger.next(this.searchForm().getRawValue());\n  }\n\n  protected async _search() {\n    // debugger;\n    if (!this.searchForm()) return;\n    const req = this.utilityService.deleteNull(cloneDeep(this.searchForm()?.getRawValue()));\n    // debugger;\n    if (this.isTablePaginated()) {\n      if (!this.data()) this.loading.set(true);\n      this.data.set([]);\n      setTimeout(() => {\n        this.tableHTTPSREF?.search(req);\n        this.loading.set(false);\n      }, 0);\n    } else if (this.searchFunction) {\n      try {\n        this.loading.set(true);\n        const data = await lastValueFrom(\n          this.searchFunction()({\n            ...req,\n            sortBy: this.orderField() || 'createdOn',\n            sortDirection: this.orderDirection()?.toUpperCase() || 'DESC',\n          }),\n        );\n        this.data.set(data?.['content'] || data);\n        console.log(data);\n      } catch (error) {\n        console.error(Error);\n      }\n      this.loading.set(false);\n    }\n    try {\n      this.uaS.add({\n        code: EUA.searched,\n        activityDescription: this.label() + ' ' + JSON.stringify(req),\n      });\n    } catch (error) {\n      debugger;\n    }\n  }\n\n  saveQuery(query = this.searchFormValue()) {\n    this.router.navigate([], {\n      queryParams: {\n        q: Object.keys(query)\n          .filter((x) => query[x] != null)\n          .map((k) => `${k}${this.delimiterWord}${query[k]}`)\n          .join(this.delimiterField),\n      },\n      replaceUrl: true,\n      relativeTo: this.route,\n      queryParamsHandling: 'merge',\n    });\n  }\n  rowClick(e) {\n    this._rowClick.emit(e);\n  }\n\n  get selection() {\n    return this.tableHTTPSREF?.selectedItems || this.tablePlainRef?.selectedItems;\n  }\n  readonly selectionSignal = signal<TRow[]>([]);\n\n  readonly isAnySelected = computed(() => {\n    const th = this.tableHTTPSREFSignal()?.isAnySelected(),\n      tp = this.tablePlainRefSignal()?.isAnySelected();\n    return th || tp;\n  });\n  protected setSelection() {\n    this.selectionSignal.set(\n      this.tableHTTPSREF?.selectedItemsSignal() || this.tablePlainRef?.selectedItemsSignal(),\n    );\n  }\n}\n\nexport interface ISearchFormSchema<\n  TQuery extends IObjectLiteral = any,\n  TRow extends IObjectLiteral = any,\n> extends IBaseFormSchema<\n    TQuery,\n    FindItemComponent<TQuery, TRow>,\n    {\n      [K in keyof TQuery]: AbstractControl<any, any>;\n    }\n  > {\n  standalone?: boolean;\n  action?: (row: TRow, cell: any, form?: FormGroup<IStrictFormGroup<TQuery>>) => any;\n}\n","<loader [loading]=\"loading()\">\n  @if (!hideForm() && searchForm()) {\n    <form [formGroup]=\"searchForm()\" (ngSubmit)=\"search()\">\n      <div class=\"row align-items-center\">\n        @for (scheme of computedFormSchema(); track scheme._id) {\n          <div class=\"{{ gridClass() }} \">\n            <div class=\"row align-items-end\">\n              @switch (true) {\n                @case (scheme.type == 'tel') {\n                  <div class=\"col\">\n                    <app-phone-number\n                      [form]=\"scheme.form\"\n                      [label]=\"scheme.label\"\n                      [name]=\"scheme.field\"\n                      [showLabel]=\"false\"\n                      [showValidation]=\"scheme.showValidation\"\n                      [showValidationIcon]=\"scheme.showValidationIcon\"\n                      [countryCode3]=\"scheme.countryCode3\"\n                      [disabled]=\"\n                        scheme.disabledIf\n                          | functionCaller2: searchFormValue() : (scheme.field | toAny)\n                      \"\n                      #inputTag />\n                    @if (showValidationMsg()) {\n                      <app-validation-message [input]=\"inputTag\" />\n                    }\n                  </div>\n                }\n                @case (scheme.type == 'autocomplete') {\n                  <div class=\"col\">\n                    <app-autocomplete\n                      [form]=\"scheme.form\"\n                      [label]=\"scheme.label\"\n                      [labelField]=\"scheme.labelField\"\n                      [autoPickValueField]=\"scheme.autoPickValueField\"\n                      [labelType]=\"scheme.labelType | toAny\"\n                      [optionsFunc]=\"scheme.optionsFunc\"\n                      [name]=\"scheme.field\"\n                      [optionFormatter]=\"scheme.optionFormatter\"\n                      [valueField]=\"scheme.valueField\"\n                      [options]=\"scheme.options\"\n                      [hint]=\"scheme.hint\"\n                      [disabled]=\"\n                        scheme.disabledIf\n                          | functionCaller2: searchFormValue : (scheme.field | toAny)\n                      \"\n                      #inputTag />\n                    @if (showValidationMsg()) {\n                      <app-validation-message [input]=\"inputTag\" />\n                    }\n                  </div>\n                }\n                @default {\n                  <div class=\"col\">\n                    <form>\n                      <div class=\"gx-2 row align-items-end\">\n                        <div class=\"col\">\n                          <app-input-basic\n                            #formField\n                            [name]=\"scheme.field\"\n                            [form]=\"scheme.form\"\n                            [type]=\"scheme.type\"\n                            [autoPickValueField]=\"scheme.autoPickValueField\"\n                            [valueField]=\"scheme.valueField\"\n                            [labelType]=\"scheme.labelType | toAny\"\n                            [checkedSignal]=\"scheme.checked\"\n                            [showValidation]=\"!!scheme.asyncValidators\"\n                            [showValidationIcon]=\"!!scheme.asyncValidators\"\n                            [noFormat]=\"true\"\n                            [labelField]=\"scheme.labelField\"\n                            [optionFormatter]=\"scheme.optionFormatter\"\n                            [options]=\"scheme.options\"\n                            [decimalPoints]=\"scheme.decimalPoints\"\n                            [hint]=\"scheme.hint\"\n                            [max]=\"scheme.max\"\n                            [min]=\"scheme.min\"\n                            [placeholder]=\"scheme.placeholder\"\n                            [label]=\"scheme.label\"\n                            [disabled]=\"\n                              scheme.disabledIf\n                                | functionCaller2: searchFormValue : (scheme.field | toAny)\n                            \" />\n                        </div>\n                        @if (scheme.standalone && scheme.action) {\n                          <div class=\"col-auto\">\n                            <app-btn\n                              group=\"show\"\n                              [disabled]=\"!formField?.validSignal()\"\n                              actionType=\"submit\"\n                              (mclick)=\"\n                                scheme.action(\n                                  allSearchFormValue(),\n                                  formField.valueSignal(),\n                                  standaloneForm()\n                                )\n                              \" />\n                          </div>\n                        }\n                        @if (scheme.action && !scheme.standalone) {\n                          <div class=\"col-auto\">\n                            <app-btn\n                              [icon]=\"scheme.icon\"\n                              [iconBtn]=\"true\"\n                              actionType=\"submit\"\n                              (mclick)=\"\n                                scheme.action(\n                                  allSearchFormValue(),\n                                  formField.valueSignal(),\n                                  searchForm()\n                                )\n                              \" />\n                          </div>\n                        }\n                      </div>\n                    </form>\n                  </div>\n                  @if (showValidationMsg()) {\n                    <app-validation-message [input]=\"formField\" />\n                  }\n                }\n              }\n            </div>\n          </div>\n        }\n        <div class=\"col-md justify-content-end d-flex\">\n          @if (showClearBtn()) {\n            <app-btn type=\"danger-outline\" text=\"Clear\" icon=\"delete\" (mclick)=\"clearFilters()\" />\n          }\n          <span class=\"mx-1\"></span>\n          @if (showSearchBtn()) {\n            <app-btn\n              [group]=\"'search'\"\n              [iconBtn]=\"true\"\n              text=\"Search\"\n              actionType=\"submit\"\n              [excludeLogging]=\"true\"\n              [disabled]=\"!searchFunction() && !isTablePaginated()\"\n              (mclick)=\"search()\" />\n          }\n          @if (createButton()) {\n            <span class=\"mx-1\"></span>\n            @if (createBtnRoute()) {\n              <app-btn\n                type=\"outline\"\n                text=\"Create\"\n                icon=\"add\"\n                (mclick)=\"clickedCreate.emit()\"\n                routerLink=\"{{ createBtnRoute() }}\" />\n            } @else {\n              <app-btn type=\"outline\" text=\"Create\" icon=\"add\" (mclick)=\"clickedCreate.emit()\" />\n            }\n          }\n        </div>\n      </div>\n    </form>\n  }\n\n  <ng-content select=\"[tablePanel]\"></ng-content>\n\n  @if (displayedColumns()?.length) {\n    <div class=\"mt-3\" [hidden]=\"!showData() || (!data() && !isTablePaginated())\">\n      <ng-container>\n        @if (isTablePaginated()) {\n          <table-https\n            #tableHTTPS\n            [searchIfNoQuery]=\"searchIfNoQuery()\"\n            [displayedColumns]=\"displayedColumns()\"\n            [observableFunc]=\"searchObservableFunc()\"\n            (rowClick)=\"rowClick($event)\"\n            (selectionChanged)=\"setSelection()\"\n            [centerCells]=\"centerCells()\"\n            [expandedRowTemplate]=\"expandedRowTemplate()\"\n            [isExpandable]=\"isExpandable()\"\n            [label]=\"label()\"\n            [nowrap]=\"nowrap()\"\n            [orderDirection]=\"orderDirection()\"\n            [orderField]=\"orderField()\"\n            [pageSize]=\"pageSize()\"\n            [rowOptions]=\"options()\"\n            [rowOptionsMap]=\"rowOptionsMap()\"\n            [showAdditionalColumns]=\"showAdditionalColumns()\"\n            [showExport]=\"showExport()\"\n            [showRefreshBtn]=\"showRefreshBtn()\"\n            [smallerFonts]=\"smallerFonts()\"\n            [startSectionTemplate]=\"startSectionTemplate()\"\n            [useSelection]=\"useSelection()\"\n            noItemTxt=\"No results found\" />\n        } @else {\n          <table-plain\n            [distinct]=\"true\"\n            [showPager]=\"true\"\n            [pageSize]=\"pageSize()\"\n            [centerCells]=\"false\"\n            [startSectionTemplate]=\"startSectionTemplate()\"\n            [smallerFonts]=\"smallerFonts()\"\n            [nowrap]=\"nowrap()\"\n            [showFilter]=\"showFilter()\"\n            [showExport]=\"showExport()\"\n            [isExpandable]=\"isExpandable()\"\n            [expandedRowTemplate]=\"expandedRowTemplate()\"\n            [label]=\"label()\"\n            noItemTxt=\"No results found\"\n            (rowClick)=\"rowClick($event)\"\n            [orderField]=\"orderField()\"\n            [rowOptions]=\"options()\"\n            [rowOptionsMap]=\"rowOptionsMap()\"\n            [showAdditionalColumns]=\"showAdditionalColumns()\"\n            [orderDirection]=\"orderDirection()\"\n            [displayedColumns]=\"displayedColumns()\"\n            (selectionChanged)=\"setSelection()\"\n            [data]=\"data()\" />\n        }\n      </ng-container>\n    </div>\n  }\n</loader>\n"]}
@@ -1,7 +1,7 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { Component, EventEmitter, Input, Output, input, signal, } from '@angular/core';
2
+ import { Component, Input, computed, inject, input, model, output, signal } from '@angular/core';
3
3
  import { MatSlideToggleModule } from '@angular/material/slide-toggle';
4
- import { InputBasicComponent } from '../input/input-basic.component';
4
+ import { InputService } from '../input/input.service';
5
5
  import { BtnComponent } from '../btn/btn.component';
6
6
  import { InputTD_RFComponent } from '../input/input-td-rf.component';
7
7
  import { FormsModule } from '@angular/forms';
@@ -10,46 +10,36 @@ import { MatTooltipModule } from '@angular/material/tooltip';
10
10
  import { MatMenuModule } from '@angular/material/menu';
11
11
  import { FilterArrayByStringPipe } from '../../pipes/utility.pipe';
12
12
  import * as i0 from "@angular/core";
13
- import * as i1 from "../input/input.service";
14
- import * as i2 from "@angular/common";
15
- import * as i3 from "@angular/material/slide-toggle";
16
- import * as i4 from "@angular/forms";
17
- import * as i5 from "@angular/material/tooltip";
18
- import * as i6 from "@angular/material/menu";
13
+ import * as i1 from "@angular/common";
14
+ import * as i2 from "@angular/material/slide-toggle";
15
+ import * as i3 from "@angular/forms";
16
+ import * as i4 from "@angular/material/tooltip";
17
+ import * as i5 from "@angular/material/menu";
19
18
  export class ToggleInputFormComponent {
20
- set setGrid(num) {
21
- this.xxlGrid.set(num);
22
- this.lgGrid.set(num > 3 ? num - 1 : num);
23
- this.mdGrid.set(num > 3 ? Math.floor(this.lgGrid() / 2) : num);
24
- }
25
- set _list(v) {
26
- this.rawList = v;
27
- const list = this.iS.optionsFormatter(v, this.valueField, null, this.labelType(), this.labelField(), false) || [];
28
- for (const item of list)
29
- item.checked = item.originalRow.checked;
30
- this.list.set(list);
31
- if (this.defaultToggleAll() && !list.some((x) => x.checked))
32
- this.toggleAll({ checked: true });
33
- }
34
- // @Input('list')set _list:T[]
35
- constructor(iS) {
36
- this.iS = iS;
37
- this.list = signal([]);
38
- // @Input() set savedData(v: TRow[]) {
39
- // if(v)
40
- // v.forEach(row=>{
41
- // this.
42
- // })
43
- // }
44
- this.currentGrid = signal(undefined);
45
- this.xxlGrid = signal(undefined);
46
- this.lgGrid = signal(undefined);
47
- this.mdGrid = signal(undefined);
48
- this.labelType = input();
19
+ constructor() {
20
+ this.iS = inject(InputService);
21
+ this.addToFormFunc = input();
49
22
  this.defaultToggleAll = input();
23
+ this.deleteFromFormFunc = input();
24
+ this.gridNo = model(6);
50
25
  this.labelField = input();
51
- this.showToggleAll = true;
52
- this.selected = new EventEmitter();
26
+ this.labelType = input();
27
+ this.searchQuery = model();
28
+ this.showToggleAll = input(true);
29
+ this.valueField = input.required();
30
+ this.selected = output();
31
+ this.list = signal([]);
32
+ this._currentGrid = signal(undefined);
33
+ this.currentGrid = computed(() => this._currentGrid());
34
+ this.xxlGrid = computed(() => this.gridNo());
35
+ this.lgGrid = computed(() => {
36
+ const num = this.gridNo();
37
+ return num > 3 ? num - 1 : num;
38
+ });
39
+ this.mdGrid = computed(() => {
40
+ const num = this.gridNo(), lgGrid = this.lgGrid();
41
+ return num > 3 ? Math.floor(lgGrid / 2) : num;
42
+ });
53
43
  this.columnLengths = signal([
54
44
  { label: `List`, value: 1 },
55
45
  { label: `Dual`, value: 2 },
@@ -57,14 +47,25 @@ export class ToggleInputFormComponent {
57
47
  { label: `Medium`, value: 4 },
58
48
  { label: `Maximum`, value: 6 },
59
49
  ]);
60
- this.setGrid = 6;
61
50
  }
62
- toggledItem(e, item) {
51
+ set _list(v) {
52
+ const list = this.iS.optionsFormatter(v, this.valueField(), null, this.labelType(), this.labelField(), false) || [];
53
+ let foundChecked = false;
54
+ for (const item of list) {
55
+ item.checked = item.originalRow.checked;
56
+ if (!foundChecked)
57
+ foundChecked = item.originalRow.checked;
58
+ }
59
+ this.list.set(list);
60
+ if (this.defaultToggleAll() && !foundChecked)
61
+ this.toggleAll({ checked: true });
62
+ }
63
+ toggleItem(e, item) {
63
64
  // throw new Error('Method not implemented.');
64
65
  if (e.checked)
65
- this.addToFormFunc?.(item);
66
+ this.addToFormFunc()?.(item);
66
67
  else
67
- this.deleteFromFormFunc?.(item);
68
+ this.deleteFromFormFunc()?.(item);
68
69
  this.emitSelected();
69
70
  }
70
71
  toggleAll(e) {
@@ -74,7 +75,7 @@ export class ToggleInputFormComponent {
74
75
  .filter((x) => !x.checked)
75
76
  .forEach((x) => {
76
77
  x.checked = true;
77
- this.addToFormFunc?.(x.originalRow);
78
+ this.addToFormFunc()?.(x.originalRow);
78
79
  });
79
80
  return list;
80
81
  });
@@ -84,7 +85,7 @@ export class ToggleInputFormComponent {
84
85
  .filter((x) => x.checked)
85
86
  .forEach((x) => {
86
87
  x.checked = false;
87
- this.deleteFromFormFunc?.(x.originalRow);
88
+ this.deleteFromFormFunc()?.(x.originalRow);
88
89
  });
89
90
  return list;
90
91
  });
@@ -95,8 +96,11 @@ export class ToggleInputFormComponent {
95
96
  .filter((x) => x.checked)
96
97
  .map((x) => x.originalRow));
97
98
  }
98
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ToggleInputFormComponent, deps: [{ token: i1.InputService }], target: i0.ɵɵFactoryTarget.Component }); }
99
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: ToggleInputFormComponent, isStandalone: true, selector: "toggle-input-form", inputs: { setGrid: { classPropertyName: "setGrid", publicName: "gridNo", isSignal: false, isRequired: false, transformFunction: null }, _list: { classPropertyName: "_list", publicName: "list", isSignal: false, isRequired: true, transformFunction: null }, labelType: { classPropertyName: "labelType", publicName: "labelType", isSignal: true, isRequired: false, transformFunction: null }, defaultToggleAll: { classPropertyName: "defaultToggleAll", publicName: "defaultToggleAll", isSignal: true, isRequired: false, transformFunction: null }, labelField: { classPropertyName: "labelField", publicName: "labelField", isSignal: true, isRequired: false, transformFunction: null }, valueField: { classPropertyName: "valueField", publicName: "valueField", isSignal: false, isRequired: true, transformFunction: null }, showToggleAll: { classPropertyName: "showToggleAll", publicName: "showToggleAll", isSignal: false, isRequired: false, transformFunction: null }, addToFormFunc: { classPropertyName: "addToFormFunc", publicName: "addToFormFunc", isSignal: false, isRequired: false, transformFunction: null }, deleteFromFormFunc: { classPropertyName: "deleteFromFormFunc", publicName: "deleteFromFormFunc", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { selected: "selected" }, ngImport: i0, template: "<div class=\"pb-3\">\n\t<div class=\"row align-items-center justify-content-between g-3\">\n\t\t<div class=\"col-lg-auto\">\n\t\t\t<mat-slide-toggle (change)=\"toggleAll($event)\" [checked]=\"defaultToggleAll()\">\n\t\t\t\t{{ 'Toggle All' | appTranslate | async }}\n\t\t\t</mat-slide-toggle>\n\t\t</div>\n\t\t<div class=\"col-lg d-flex justify-content-end\">\n\t\t\t<div class=\"row align-items-center g-3\">\n\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t<app-btn\n\t\t\t\t\t\ticonBtn\n\t\t\t\t\t\t[showHelpIcon]=\"false\"\n\t\t\t\t\t\thelp=\"{{ searchBox.hidden ? 'Open search' : 'Close search' }}\"\n\t\t\t\t\t\t[icon]=\"searchBox.hidden ? 'search' : 'close'\"\n\t\t\t\t\t\t(mclick)=\"searchBox.hidden = !searchBox.hidden\" />\n\t\t\t\t</div>\n\t\t\t\t<div class=\"col-auto\" [hidden]=\"true\" #searchBox>\n\t\t\t\t\t<app-input-td-rf\n\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\t[noFormat]=\"true\"\n\t\t\t\t\t\t[showLabel]=\"false\"\n\t\t\t\t\t\tplaceholder=\"Type to search\"\n\t\t\t\t\t\t[(model)]=\"searchQuery\" />\n\t\t\t\t</div>\n\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t<app-btn\n\t\t\t\t\t\tcustomIcon=\"fa fa-list\"\n\t\t\t\t\t\t[showHelpIcon]=\"false\"\n\t\t\t\t\t\thelp=\"Grid Style\"\n\t\t\t\t\t\t[matMenuTriggerFor]=\"gridMenu\" />\n\t\t\t\t\t<mat-menu #gridMenu=\"matMenu\" class=\"\">\n\t\t\t\t\t\t@for (item of columnLengths(); track item) {\n\t\t\t\t\t\t\t<button\n\t\t\t\t\t\t\t\tmat-menu-item\n\t\t\t\t\t\t\t\t(click)=\"setGrid = item.value\"\n\t\t\t\t\t\t\t\t[ngClass]=\"{ 'text-primary': item.value == currentGrid() }\">\n\t\t\t\t\t\t\t\t{{ item.label | appTranslate | async }}\n\t\t\t\t\t\t\t</button>\n\t\t\t\t\t\t}\n\t\t\t\t\t</mat-menu>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</div>\n<div class=\"row row-cols-md-{{ mdGrid() }} row-cols-lg-{{ lgGrid() }} row-cols-xxl-{{ xxlGrid() }} g-3\">\n\t@for (item of list() | filterArrayByString: searchQuery : ['label']; track item.value) {\n\t\t<div class=\"\">\n\t\t\t<div class=\"border rounded-10 p-10\">\n\t\t\t\t<div class=\"row align-items-center\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tclass=\"col text-ellipsis\"\n\t\t\t\t\t\t[matTooltip]=\"ele.innerText\"\n\t\t\t\t\t\t[matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n\t\t\t\t\t\t#ele>\n\t\t\t\t\t\t{{ item.label }}\n\t\t\t\t\t</div>\n\t\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t\t<mat-slide-toggle [(ngModel)]=\"item.checked\" (change)=\"toggledItem($event, item.originalRow)\" />\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t}\n</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: i3.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: "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: "pipe", type: FilterArrayByStringPipe, name: "filterArrayByString" }, { kind: "component", type: InputTD_RFComponent, selector: "app-input-td-rf", inputs: ["validators", "asyncValidators", "model"], outputs: ["modelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i6.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i6.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i6.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
99
+ getSelected() {
100
+ return this.list();
101
+ }
102
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ToggleInputFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
103
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: ToggleInputFormComponent, isStandalone: true, selector: "toggle-input-form", inputs: { addToFormFunc: { classPropertyName: "addToFormFunc", publicName: "addToFormFunc", isSignal: true, isRequired: false, transformFunction: null }, defaultToggleAll: { classPropertyName: "defaultToggleAll", publicName: "defaultToggleAll", isSignal: true, isRequired: false, transformFunction: null }, deleteFromFormFunc: { classPropertyName: "deleteFromFormFunc", publicName: "deleteFromFormFunc", isSignal: true, isRequired: false, transformFunction: null }, gridNo: { classPropertyName: "gridNo", publicName: "gridNo", isSignal: true, isRequired: false, transformFunction: null }, labelField: { classPropertyName: "labelField", publicName: "labelField", isSignal: true, isRequired: false, transformFunction: null }, labelType: { classPropertyName: "labelType", publicName: "labelType", isSignal: true, isRequired: false, transformFunction: null }, searchQuery: { classPropertyName: "searchQuery", publicName: "searchQuery", isSignal: true, isRequired: false, transformFunction: null }, showToggleAll: { classPropertyName: "showToggleAll", publicName: "showToggleAll", isSignal: true, isRequired: false, transformFunction: null }, valueField: { classPropertyName: "valueField", publicName: "valueField", isSignal: true, isRequired: true, transformFunction: null }, _list: { classPropertyName: "_list", publicName: "list", isSignal: false, isRequired: true, transformFunction: null } }, outputs: { gridNo: "gridNoChange", searchQuery: "searchQueryChange", selected: "selected" }, ngImport: i0, template: "<div class=\"pb-3\">\n <div class=\"row align-items-center justify-content-between g-3\">\n <div class=\"col-lg-auto\">\n <mat-slide-toggle (change)=\"toggleAll($event)\" [checked]=\"defaultToggleAll()\">\n {{ 'Toggle All' | appTranslate | async }}\n </mat-slide-toggle>\n </div>\n <div class=\"col-lg d-flex justify-content-end\">\n <div class=\"row align-items-center g-3\">\n <div class=\"col-auto\">\n <app-btn\n iconBtn\n [showHelpIcon]=\"false\"\n help=\"{{ searchBox.hidden ? 'Open search' : 'Close search' }}\"\n [icon]=\"searchBox.hidden ? 'search' : 'close'\"\n (mclick)=\"searchBox.hidden = !searchBox.hidden\" />\n </div>\n <div class=\"col-auto\" [hidden]=\"true\" #searchBox>\n <app-input-td-rf\n type=\"text\"\n [noFormat]=\"true\"\n [showLabel]=\"false\"\n placeholder=\"Type to search\"\n [(model)]=\"searchQuery\" />\n </div>\n <div class=\"col-auto\">\n <app-btn\n customIcon=\"fa fa-list\"\n [showHelpIcon]=\"false\"\n help=\"Grid Style\"\n [matMenuTriggerFor]=\"gridMenu\" />\n <mat-menu #gridMenu=\"matMenu\" class=\"\">\n @for (item of columnLengths(); track item.value) {\n <button\n mat-menu-item\n (click)=\"gridNo.set(item.value)\"\n [ngClass]=\"{ 'text-primary': item.value == _currentGrid() }\">\n {{ item.label | appTranslate | async }}\n </button>\n }\n </mat-menu>\n </div>\n </div>\n </div>\n </div>\n</div>\n<div\n class=\"row row-cols-md-{{ mdGrid() }} row-cols-lg-{{ lgGrid() }} row-cols-xxl-{{\n xxlGrid()\n }} g-3\">\n @for (item of list() | filterArrayByString: searchQuery() : ['label']; track item.value) {\n <div class=\"\">\n <div class=\"border rounded-10 p-10\">\n <div class=\"row align-items-center\">\n <div\n class=\"col text-ellipsis\"\n [matTooltip]=\"ele.innerText\"\n [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n #ele>\n {{ item.label }}\n </div>\n <div class=\"col-auto\">\n <mat-slide-toggle\n [(ngModel)]=\"item.checked\"\n (change)=\"toggleItem($event, item.originalRow)\" />\n </div>\n </div>\n </div>\n </div>\n }\n</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: i2.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: "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: "pipe", type: FilterArrayByStringPipe, name: "filterArrayByString" }, { kind: "component", type: InputTD_RFComponent, selector: "app-input-td-rf", inputs: ["validators", "asyncValidators", "model"], outputs: ["modelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i5.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i5.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
100
104
  }
101
105
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ToggleInputFormComponent, decorators: [{
102
106
  type: Component,
@@ -105,29 +109,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImpor
105
109
  MatSlideToggleModule,
106
110
  BtnComponent,
107
111
  FilterArrayByStringPipe,
108
- InputBasicComponent,
109
112
  InputTD_RFComponent,
110
113
  FormsModule,
111
114
  MatTooltipModule,
112
115
  MatMenuModule,
113
116
  SDKTranslatePipe,
114
- ], template: "<div class=\"pb-3\">\n\t<div class=\"row align-items-center justify-content-between g-3\">\n\t\t<div class=\"col-lg-auto\">\n\t\t\t<mat-slide-toggle (change)=\"toggleAll($event)\" [checked]=\"defaultToggleAll()\">\n\t\t\t\t{{ 'Toggle All' | appTranslate | async }}\n\t\t\t</mat-slide-toggle>\n\t\t</div>\n\t\t<div class=\"col-lg d-flex justify-content-end\">\n\t\t\t<div class=\"row align-items-center g-3\">\n\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t<app-btn\n\t\t\t\t\t\ticonBtn\n\t\t\t\t\t\t[showHelpIcon]=\"false\"\n\t\t\t\t\t\thelp=\"{{ searchBox.hidden ? 'Open search' : 'Close search' }}\"\n\t\t\t\t\t\t[icon]=\"searchBox.hidden ? 'search' : 'close'\"\n\t\t\t\t\t\t(mclick)=\"searchBox.hidden = !searchBox.hidden\" />\n\t\t\t\t</div>\n\t\t\t\t<div class=\"col-auto\" [hidden]=\"true\" #searchBox>\n\t\t\t\t\t<app-input-td-rf\n\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\t[noFormat]=\"true\"\n\t\t\t\t\t\t[showLabel]=\"false\"\n\t\t\t\t\t\tplaceholder=\"Type to search\"\n\t\t\t\t\t\t[(model)]=\"searchQuery\" />\n\t\t\t\t</div>\n\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t<app-btn\n\t\t\t\t\t\tcustomIcon=\"fa fa-list\"\n\t\t\t\t\t\t[showHelpIcon]=\"false\"\n\t\t\t\t\t\thelp=\"Grid Style\"\n\t\t\t\t\t\t[matMenuTriggerFor]=\"gridMenu\" />\n\t\t\t\t\t<mat-menu #gridMenu=\"matMenu\" class=\"\">\n\t\t\t\t\t\t@for (item of columnLengths(); track item) {\n\t\t\t\t\t\t\t<button\n\t\t\t\t\t\t\t\tmat-menu-item\n\t\t\t\t\t\t\t\t(click)=\"setGrid = item.value\"\n\t\t\t\t\t\t\t\t[ngClass]=\"{ 'text-primary': item.value == currentGrid() }\">\n\t\t\t\t\t\t\t\t{{ item.label | appTranslate | async }}\n\t\t\t\t\t\t\t</button>\n\t\t\t\t\t\t}\n\t\t\t\t\t</mat-menu>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</div>\n<div class=\"row row-cols-md-{{ mdGrid() }} row-cols-lg-{{ lgGrid() }} row-cols-xxl-{{ xxlGrid() }} g-3\">\n\t@for (item of list() | filterArrayByString: searchQuery : ['label']; track item.value) {\n\t\t<div class=\"\">\n\t\t\t<div class=\"border rounded-10 p-10\">\n\t\t\t\t<div class=\"row align-items-center\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tclass=\"col text-ellipsis\"\n\t\t\t\t\t\t[matTooltip]=\"ele.innerText\"\n\t\t\t\t\t\t[matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n\t\t\t\t\t\t#ele>\n\t\t\t\t\t\t{{ item.label }}\n\t\t\t\t\t</div>\n\t\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t\t<mat-slide-toggle [(ngModel)]=\"item.checked\" (change)=\"toggledItem($event, item.originalRow)\" />\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t}\n</div>\n", styles: [":host{display:block}\n"] }]
115
- }], ctorParameters: () => [{ type: i1.InputService }], propDecorators: { setGrid: [{
116
- type: Input,
117
- args: ['gridNo']
118
- }], _list: [{
117
+ ], template: "<div class=\"pb-3\">\n <div class=\"row align-items-center justify-content-between g-3\">\n <div class=\"col-lg-auto\">\n <mat-slide-toggle (change)=\"toggleAll($event)\" [checked]=\"defaultToggleAll()\">\n {{ 'Toggle All' | appTranslate | async }}\n </mat-slide-toggle>\n </div>\n <div class=\"col-lg d-flex justify-content-end\">\n <div class=\"row align-items-center g-3\">\n <div class=\"col-auto\">\n <app-btn\n iconBtn\n [showHelpIcon]=\"false\"\n help=\"{{ searchBox.hidden ? 'Open search' : 'Close search' }}\"\n [icon]=\"searchBox.hidden ? 'search' : 'close'\"\n (mclick)=\"searchBox.hidden = !searchBox.hidden\" />\n </div>\n <div class=\"col-auto\" [hidden]=\"true\" #searchBox>\n <app-input-td-rf\n type=\"text\"\n [noFormat]=\"true\"\n [showLabel]=\"false\"\n placeholder=\"Type to search\"\n [(model)]=\"searchQuery\" />\n </div>\n <div class=\"col-auto\">\n <app-btn\n customIcon=\"fa fa-list\"\n [showHelpIcon]=\"false\"\n help=\"Grid Style\"\n [matMenuTriggerFor]=\"gridMenu\" />\n <mat-menu #gridMenu=\"matMenu\" class=\"\">\n @for (item of columnLengths(); track item.value) {\n <button\n mat-menu-item\n (click)=\"gridNo.set(item.value)\"\n [ngClass]=\"{ 'text-primary': item.value == _currentGrid() }\">\n {{ item.label | appTranslate | async }}\n </button>\n }\n </mat-menu>\n </div>\n </div>\n </div>\n </div>\n</div>\n<div\n class=\"row row-cols-md-{{ mdGrid() }} row-cols-lg-{{ lgGrid() }} row-cols-xxl-{{\n xxlGrid()\n }} g-3\">\n @for (item of list() | filterArrayByString: searchQuery() : ['label']; track item.value) {\n <div class=\"\">\n <div class=\"border rounded-10 p-10\">\n <div class=\"row align-items-center\">\n <div\n class=\"col text-ellipsis\"\n [matTooltip]=\"ele.innerText\"\n [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n #ele>\n {{ item.label }}\n </div>\n <div class=\"col-auto\">\n <mat-slide-toggle\n [(ngModel)]=\"item.checked\"\n (change)=\"toggleItem($event, item.originalRow)\" />\n </div>\n </div>\n </div>\n </div>\n }\n</div>\n", styles: [":host{display:block}\n"] }]
118
+ }], propDecorators: { _list: [{
119
119
  type: Input,
120
120
  args: [{ alias: 'list', required: true }]
121
- }], valueField: [{
122
- type: Input,
123
- args: [{ required: true }]
124
- }], showToggleAll: [{
125
- type: Input
126
- }], addToFormFunc: [{
127
- type: Input
128
- }], deleteFromFormFunc: [{
129
- type: Input
130
- }], selected: [{
131
- type: Output
132
121
  }] } });
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toggle-input-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/toggle-input-form/toggle-input-form.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/toggle-input-form/toggle-input-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAEL,SAAS,EACT,YAAY,EAEZ,KAAK,EACL,MAAM,EAEN,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AAE5F,OAAO,EAAmB,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACtF,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAa,WAAW,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;;;;;;;;AAqBnE,MAAM,OAAO,wBAAwB;IAInC,IAAqB,OAAO,CAAC,GAAa;QACxC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACzC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IACjE,CAAC;IAWD,IACI,KAAK,CAAC,CAAY;QACpB,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QACjB,MAAM,IAAI,GACR,IAAI,CAAC,EAAE,CAAC,gBAAgB,CACtB,CAAC,EACD,IAAI,CAAC,UAAoB,EACzB,IAAI,EACJ,IAAI,CAAC,SAAS,EAAE,EAChB,IAAI,CAAC,UAAU,EAAY,EAC3B,KAAK,CACN,IAAI,EAAE,CAAC;QACV,KAAK,MAAM,IAAI,IAAI,IAAI;YAAE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;QACjE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACpB,IAAI,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YAAE,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IACjG,CAAC;IAmBD,8BAA8B;IAC9B,YAAmB,EAAgB;QAAhB,OAAE,GAAF,EAAE,CAAc;QApDnC,SAAI,GAAG,MAAM,CAAkB,EAAE,CAAC,CAAC;QAOnC,sCAAsC;QACtC,SAAS;QACT,oBAAoB;QACpB,QAAQ;QACR,MAAM;QACN,IAAI;QACJ,gBAAW,GAAG,MAAM,CAAS,SAAS,CAAC,CAAC;QACxC,YAAO,GAAG,MAAM,CAAS,SAAS,CAAC,CAAC;QACpC,WAAM,GAAG,MAAM,CAAS,SAAS,CAAC,CAAC;QACnC,WAAM,GAAG,MAAM,CAAS,SAAS,CAAC,CAAC;QAiBnC,cAAS,GAAG,KAAK,EAAmB,CAAC;QACrC,qBAAgB,GAAG,KAAK,EAAW,CAAC;QACpC,eAAU,GAAG,KAAK,EAAiB,CAAC;QAE3B,kBAAa,GAAY,IAAI,CAAC;QAI7B,aAAQ,GAAG,IAAI,YAAY,EAAa,CAAC;QAEnD,kBAAa,GAAG,MAAM,CAAuC;YAC3D,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE;YAC3B,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE;YAC3B,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE;YAC7B,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE;YAC7B,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE;SAC/B,CAAC,CAAC;QAID,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,WAAW,CAAC,CAAuB,EAAE,IAAa;QAChD,8CAA8C;QAC9C,IAAI,CAAC,CAAC,OAAO;YAAE,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,CAAC;;YACrC,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,SAAS,CAAC,CAAuB;QAC/B,IAAI,CAAC,CAAC,OAAO;YACX,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;gBACxB,IAAI;qBACD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;qBACzB,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBACb,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC;oBACjB,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;gBACtC,CAAC,CAAC,CAAC;gBACL,OAAO,IAAI,CAAC;YACd,CAAC,CAAC,CAAC;;YAEH,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;gBACxB,IAAI;qBACD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;qBACxB,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBACb,CAAC,CAAC,OAAO,GAAG,KAAK,CAAC;oBAClB,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;gBAC3C,CAAC,CAAC,CAAC;gBACL,OAAO,IAAI,CAAC;YACd,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,IAAI,CAAC,IAAI,EAAE;aACR,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;aACxB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAC7B,CAAC;IACJ,CAAC;8GA/FU,wBAAwB;kGAAxB,wBAAwB,81CC1CrC,y8EAkEA,+EDpCI,YAAY,iLACZ,oBAAoB,mWACpB,YAAY,8fACZ,uBAAuB,4DAEvB,mBAAmB,yIACnB,WAAW,8VACX,gBAAgB,4TAChB,aAAa,yvBACb,gBAAgB;;2FAGP,wBAAwB;kBAnBpC,SAAS;+BACE,mBAAmB,cACjB,IAAI,WAIP;wBACP,YAAY;wBACZ,oBAAoB;wBACpB,YAAY;wBACZ,uBAAuB;wBACvB,mBAAmB;wBACnB,mBAAmB;wBACnB,WAAW;wBACX,gBAAgB;wBAChB,aAAa;wBACb,gBAAgB;qBACjB;iFAMoB,OAAO;sBAA3B,KAAK;uBAAC,QAAQ;gBAgBX,KAAK;sBADR,KAAK;uBAAC,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAmBb,UAAU;sBAApC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAChB,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBAEI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  Output,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport { MatSlideToggleChange, MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { IOption, InputService } from '../input/input.service';\nimport { OptionLabelType, InputBasicComponent } from '../input/input-basic.component';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputTD_RFComponent } from '../input/input-td-rf.component';\nimport { FormArray, FormsModule } from '@angular/forms';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { FilterArrayByStringPipe } from '../../pipes/utility.pipe';\n\n@Component({\n  selector: 'toggle-input-form',\n  standalone: true,\n  templateUrl: './toggle-input-form.component.html',\n  styleUrl: './toggle-input-form.component.scss',\n  //\n  imports: [\n    CommonModule,\n    MatSlideToggleModule,\n    BtnComponent,\n    FilterArrayByStringPipe,\n    InputBasicComponent,\n    InputTD_RFComponent,\n    FormsModule,\n    MatTooltipModule,\n    MatMenuModule,\n    SDKTranslatePipe,\n  ],\n})\nexport class ToggleInputFormComponent<TOption extends { checked?: boolean }, TRow> {\n  rawList: TOption[];\n  list = signal<IToggleOption[]>([]);\n  searchQuery: string;\n  @Input('gridNo') set setGrid(num: GridSize) {\n    this.xxlGrid.set(num);\n    this.lgGrid.set(num > 3 ? num - 1 : num);\n    this.mdGrid.set(num > 3 ? Math.floor(this.lgGrid() / 2) : num);\n  }\n  // @Input() set savedData(v: TRow[]) {\n  // \tif(v)\n  // \tv.forEach(row=>{\n  // this.\n  // \t})\n  // }\n  currentGrid = signal<number>(undefined);\n  xxlGrid = signal<number>(undefined);\n  lgGrid = signal<number>(undefined);\n  mdGrid = signal<number>(undefined);\n  @Input({ alias: 'list', required: true })\n  set _list(v: TOption[]) {\n    this.rawList = v;\n    const list: IToggleOption[] =\n      this.iS.optionsFormatter(\n        v,\n        this.valueField as string,\n        null,\n        this.labelType(),\n        this.labelField() as string,\n        false,\n      ) || [];\n    for (const item of list) item.checked = item.originalRow.checked;\n    this.list.set(list);\n    if (this.defaultToggleAll() && !list.some((x) => x.checked)) this.toggleAll({ checked: true });\n  }\n  labelType = input<OptionLabelType>();\n  defaultToggleAll = input<boolean>();\n  labelField = input<keyof TOption>();\n  @Input({ required: true }) valueField: keyof TOption;\n  @Input() showToggleAll: boolean = true;\n  @Input() addToFormFunc: (data?: TOption) => any;\n  @Input() deleteFromFormFunc: (data?: TOption) => any;\n\n  @Output() selected = new EventEmitter<TOption[]>();\n\n  columnLengths = signal<{ label: string; value: GridSize }[]>([\n    { label: `List`, value: 1 },\n    { label: `Dual`, value: 2 },\n    { label: `Triple`, value: 3 },\n    { label: `Medium`, value: 4 },\n    { label: `Maximum`, value: 6 },\n  ]);\n\n  // @Input('list')set _list:T[]\n  constructor(public iS: InputService) {\n    this.setGrid = 6;\n  }\n\n  toggledItem(e: { checked: boolean }, item: TOption) {\n    // throw new Error('Method not implemented.');\n    if (e.checked) this.addToFormFunc?.(item);\n    else this.deleteFromFormFunc?.(item);\n    this.emitSelected();\n  }\n\n  toggleAll(e: { checked: boolean }) {\n    if (e.checked)\n      this.list.update((list) => {\n        list\n          .filter((x) => !x.checked)\n          .forEach((x) => {\n            x.checked = true;\n            this.addToFormFunc?.(x.originalRow);\n          });\n        return list;\n      });\n    else\n      this.list.update((list) => {\n        list\n          .filter((x) => x.checked)\n          .forEach((x) => {\n            x.checked = false;\n            this.deleteFromFormFunc?.(x.originalRow);\n          });\n        return list;\n      });\n    this.emitSelected();\n  }\n\n  emitSelected() {\n    this.selected.emit(\n      this.list()\n        .filter((x) => x.checked)\n        .map((x) => x.originalRow),\n    );\n  }\n}\ninterface IToggleOption extends IOption {\n  checked?: boolean;\n}\ntype GridSize = 6 | 4 | 3 | 2 | 1;\n","<div class=\"pb-3\">\n\t<div class=\"row align-items-center justify-content-between g-3\">\n\t\t<div class=\"col-lg-auto\">\n\t\t\t<mat-slide-toggle (change)=\"toggleAll($event)\" [checked]=\"defaultToggleAll()\">\n\t\t\t\t{{ 'Toggle All' | appTranslate | async }}\n\t\t\t</mat-slide-toggle>\n\t\t</div>\n\t\t<div class=\"col-lg d-flex justify-content-end\">\n\t\t\t<div class=\"row align-items-center g-3\">\n\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t<app-btn\n\t\t\t\t\t\ticonBtn\n\t\t\t\t\t\t[showHelpIcon]=\"false\"\n\t\t\t\t\t\thelp=\"{{ searchBox.hidden ? 'Open search' : 'Close search' }}\"\n\t\t\t\t\t\t[icon]=\"searchBox.hidden ? 'search' : 'close'\"\n\t\t\t\t\t\t(mclick)=\"searchBox.hidden = !searchBox.hidden\" />\n\t\t\t\t</div>\n\t\t\t\t<div class=\"col-auto\" [hidden]=\"true\" #searchBox>\n\t\t\t\t\t<app-input-td-rf\n\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\t[noFormat]=\"true\"\n\t\t\t\t\t\t[showLabel]=\"false\"\n\t\t\t\t\t\tplaceholder=\"Type to search\"\n\t\t\t\t\t\t[(model)]=\"searchQuery\" />\n\t\t\t\t</div>\n\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t<app-btn\n\t\t\t\t\t\tcustomIcon=\"fa fa-list\"\n\t\t\t\t\t\t[showHelpIcon]=\"false\"\n\t\t\t\t\t\thelp=\"Grid Style\"\n\t\t\t\t\t\t[matMenuTriggerFor]=\"gridMenu\" />\n\t\t\t\t\t<mat-menu #gridMenu=\"matMenu\" class=\"\">\n\t\t\t\t\t\t@for (item of columnLengths(); track item) {\n\t\t\t\t\t\t\t<button\n\t\t\t\t\t\t\t\tmat-menu-item\n\t\t\t\t\t\t\t\t(click)=\"setGrid = item.value\"\n\t\t\t\t\t\t\t\t[ngClass]=\"{ 'text-primary': item.value == currentGrid() }\">\n\t\t\t\t\t\t\t\t{{ item.label | appTranslate | async }}\n\t\t\t\t\t\t\t</button>\n\t\t\t\t\t\t}\n\t\t\t\t\t</mat-menu>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</div>\n<div class=\"row row-cols-md-{{ mdGrid() }} row-cols-lg-{{ lgGrid() }} row-cols-xxl-{{ xxlGrid() }} g-3\">\n\t@for (item of list() | filterArrayByString: searchQuery : ['label']; track item.value) {\n\t\t<div class=\"\">\n\t\t\t<div class=\"border rounded-10 p-10\">\n\t\t\t\t<div class=\"row align-items-center\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tclass=\"col text-ellipsis\"\n\t\t\t\t\t\t[matTooltip]=\"ele.innerText\"\n\t\t\t\t\t\t[matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n\t\t\t\t\t\t#ele>\n\t\t\t\t\t\t{{ item.label }}\n\t\t\t\t\t</div>\n\t\t\t\t\t<div class=\"col-auto\">\n\t\t\t\t\t\t<mat-slide-toggle [(ngModel)]=\"item.checked\" (change)=\"toggledItem($event, item.originalRow)\" />\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t}\n</div>\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toggle-input-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/toggle-input-form/toggle-input-form.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/toggle-input-form/toggle-input-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input, computed, inject, input, model, output, signal } from '@angular/core';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { InputService } from '../input/input.service';\nimport { OptionLabelType } from '../input/input-basic.component';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputTD_RFComponent } from '../input/input-td-rf.component';\nimport { FormsModule } from '@angular/forms';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { FilterArrayByStringPipe } from '../../pipes/utility.pipe';\nimport { IToggleOption } from './toggle-input-form.model';\n\n@Component({\n  selector: 'toggle-input-form',\n  standalone: true,\n  templateUrl: './toggle-input-form.component.html',\n  styleUrl: './toggle-input-form.component.scss',\n  // changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    MatSlideToggleModule,\n    BtnComponent,\n    FilterArrayByStringPipe,\n    InputTD_RFComponent,\n    FormsModule,\n    MatTooltipModule,\n    MatMenuModule,\n    SDKTranslatePipe,\n  ],\n})\nexport class ToggleInputFormComponent<TOption extends { checked?: boolean }, TRow> {\n  protected readonly iS = inject(InputService);\n\n  readonly addToFormFunc = input<(data?: TOption) => any>();\n  readonly defaultToggleAll = input<boolean>();\n  readonly deleteFromFormFunc = input<(data?: TOption) => any>();\n  readonly gridNo = model<GridSize>(6);\n  readonly labelField = input<keyof TOption>();\n  readonly labelType = input<OptionLabelType>();\n  readonly searchQuery = model<string>();\n  readonly showToggleAll = input<boolean>(true);\n  readonly valueField = input.required<keyof TOption>();\n\n  readonly selected = output<TOption[]>();\n\n  protected readonly list = signal<IToggleOption<TOption>[]>([]);\n\n  protected readonly _currentGrid = signal<number>(undefined);\n  readonly currentGrid = computed<number>(() => this._currentGrid());\n  protected readonly xxlGrid = computed<number>(() => this.gridNo());\n  protected readonly lgGrid = computed<number>(() => {\n    const num = this.gridNo();\n    return num > 3 ? num - 1 : num;\n  });\n  protected readonly mdGrid = computed<number>(() => {\n    const num = this.gridNo(),\n      lgGrid = this.lgGrid();\n    return num > 3 ? Math.floor(lgGrid / 2) : num;\n  });\n\n  @Input({ alias: 'list', required: true })\n  set _list(v: TOption[]) {\n    const list: IToggleOption<TOption>[] =\n      this.iS.optionsFormatter(\n        v,\n        this.valueField() as string,\n        null,\n        this.labelType(),\n        this.labelField() as string,\n        false,\n      ) || [];\n    let foundChecked = false;\n    for (const item of list) {\n      item.checked = item.originalRow.checked;\n      if (!foundChecked) foundChecked = item.originalRow.checked;\n    }\n    this.list.set(list);\n    if (this.defaultToggleAll() && !foundChecked) this.toggleAll({ checked: true });\n  }\n\n  protected readonly columnLengths = signal<{ label: string; value: GridSize }[]>([\n    { label: `List`, value: 1 },\n    { label: `Dual`, value: 2 },\n    { label: `Triple`, value: 3 },\n    { label: `Medium`, value: 4 },\n    { label: `Maximum`, value: 6 },\n  ]);\n\n  protected toggleItem(e: { checked: boolean }, item: TOption) {\n    // throw new Error('Method not implemented.');\n    if (e.checked) this.addToFormFunc()?.(item);\n    else this.deleteFromFormFunc()?.(item);\n    this.emitSelected();\n  }\n\n  protected toggleAll(e: { checked: boolean }) {\n    if (e.checked)\n      this.list.update((list) => {\n        list\n          .filter((x) => !x.checked)\n          .forEach((x) => {\n            x.checked = true;\n            this.addToFormFunc()?.(x.originalRow);\n          });\n        return list;\n      });\n    else\n      this.list.update((list) => {\n        list\n          .filter((x) => x.checked)\n          .forEach((x) => {\n            x.checked = false;\n            this.deleteFromFormFunc()?.(x.originalRow);\n          });\n        return list;\n      });\n    this.emitSelected();\n  }\n\n  protected emitSelected() {\n    this.selected.emit(\n      this.list()\n        .filter((x) => x.checked)\n        .map((x) => x.originalRow),\n    );\n  }\n\n  getSelected() {\n    return this.list();\n  }\n}\ntype GridSize = 6 | 4 | 3 | 2 | 1;\n","<div class=\"pb-3\">\n  <div class=\"row align-items-center justify-content-between g-3\">\n    <div class=\"col-lg-auto\">\n      <mat-slide-toggle (change)=\"toggleAll($event)\" [checked]=\"defaultToggleAll()\">\n        {{ 'Toggle All' | appTranslate | async }}\n      </mat-slide-toggle>\n    </div>\n    <div class=\"col-lg d-flex justify-content-end\">\n      <div class=\"row align-items-center g-3\">\n        <div class=\"col-auto\">\n          <app-btn\n            iconBtn\n            [showHelpIcon]=\"false\"\n            help=\"{{ searchBox.hidden ? 'Open search' : 'Close search' }}\"\n            [icon]=\"searchBox.hidden ? 'search' : 'close'\"\n            (mclick)=\"searchBox.hidden = !searchBox.hidden\" />\n        </div>\n        <div class=\"col-auto\" [hidden]=\"true\" #searchBox>\n          <app-input-td-rf\n            type=\"text\"\n            [noFormat]=\"true\"\n            [showLabel]=\"false\"\n            placeholder=\"Type to search\"\n            [(model)]=\"searchQuery\" />\n        </div>\n        <div class=\"col-auto\">\n          <app-btn\n            customIcon=\"fa fa-list\"\n            [showHelpIcon]=\"false\"\n            help=\"Grid Style\"\n            [matMenuTriggerFor]=\"gridMenu\" />\n          <mat-menu #gridMenu=\"matMenu\" class=\"\">\n            @for (item of columnLengths(); track item.value) {\n              <button\n                mat-menu-item\n                (click)=\"gridNo.set(item.value)\"\n                [ngClass]=\"{ 'text-primary': item.value == _currentGrid() }\">\n                {{ item.label | appTranslate | async }}\n              </button>\n            }\n          </mat-menu>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n<div\n  class=\"row row-cols-md-{{ mdGrid() }} row-cols-lg-{{ lgGrid() }} row-cols-xxl-{{\n    xxlGrid()\n  }} g-3\">\n  @for (item of list() | filterArrayByString: searchQuery() : ['label']; track item.value) {\n    <div class=\"\">\n      <div class=\"border rounded-10 p-10\">\n        <div class=\"row align-items-center\">\n          <div\n            class=\"col text-ellipsis\"\n            [matTooltip]=\"ele.innerText\"\n            [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n            #ele>\n            {{ item.label }}\n          </div>\n          <div class=\"col-auto\">\n            <mat-slide-toggle\n              [(ngModel)]=\"item.checked\"\n              (change)=\"toggleItem($event, item.originalRow)\" />\n          </div>\n        </div>\n      </div>\n    </div>\n  }\n</div>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9nZ2xlLWlucHV0LWZvcm0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvU2hhcmVkL2NvbXBvbmVudHMvdG9nZ2xlLWlucHV0LWZvcm0vdG9nZ2xlLWlucHV0LWZvcm0ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElPcHRpb24gfSBmcm9tIFwiLi4vaW5wdXQvaW5wdXQuc2VydmljZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIElUb2dnbGVPcHRpb248VFJvdz4gZXh0ZW5kcyBJT3B0aW9uPFRSb3c+IHtcbiAgY2hlY2tlZD86IGJvb2xlYW47XG59XG4iXX0=