ets-fe-ng-sdk 18.0.110 → 18.0.112

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.
@@ -252,4 +252,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
252
252
  type: Input,
253
253
  args: ['isShow']
254
254
  }] } });
255
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { debounceTime, filter, last, switchMap, tap, map, startWith } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    RichTextEditorRFComponent,\n    BtnComponent,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> },\n  TFormSchema extends IFormSchema<TFormGroup> = IFormSchema<TFormGroup>,\n> extends BaseFormGenerator<TFormGroup, TFormSchema> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  readonly presetValueForSingleOption = input(false);\n  readonly isCreate = input<boolean>();\n  readonly submitOnEnterKey = input<boolean>(false);\n  readonly formTagRef = viewChild<ElementRef<HTMLFormElement>>('formTag');\n\n  /**Emitted just before calling the save function */\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  /**Emitted after receiving feedback from the submit function */\n  @Output() saved = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  readonly submitBtnText = input('Submit');\n  readonly submitBtnTemplate = input<TemplateRef<any>>();\n  readonly submitSuccessText = input('Saved successfully');\n  readonly showSubmitBtn = input(true);\n\n  readonly gridStyle = input<number | 'auto'>();\n  readonly gridMDStyle = input<number | 'auto'>();\n  readonly gridLGStyle = input<number | 'auto'>();\n  readonly gridXXLStyle = input<number | 'auto'>();\n\n  readonly formGridClass = input<string>();\n  readonly useLoader = input<boolean>();\n  readonly loading = input<boolean>();\n\n  readonly _loading = signal<boolean>(false);\n\n  readonly computedLoading = computed(() =>\n    this.useLoader() ? this.loading() || this._loading() : false,\n  );\n\n  readonly submitBtnRef = viewChild<BtnComponent>('submitBtn');\n  readonly form = model<FormGroup<TFormGroup>>();\n\n  readonly formValue = toSignal(\n    toObservable(this.form).pipe(\n      filter(() => !!this.form()),\n      switchMap(() =>\n        this.form()\n          .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))\n          .pipe(startWith(this.form()?.getRawValue() || {})),\n      ),\n    ),\n    // { initialValue: this.form()?.getRawValue() || {} },\n  );\n\n  submissionResponse: any;\n  @Input({ alias: 'formSchema' }) set _formSchema(v: TFormSchema[] | IFormSchema<any>[]) {\n    this.init(cloneDeep(v.filter((x) => x)) as TFormSchema[]);\n  }\n  @Input({ alias: 'formSchemaNoForm' }) set _formSchemaNoForm(v: TFormSchema[]) {\n    if (v) {\n      const form = new FormGroup({});\n      for (const item of v) {\n        form.addControl(\n          item.field?.toString(),\n          new FormControl(item.value, [].concat(item.isRequired ? [Validators.required] : [])),\n        );\n      }\n      this.form.set(form as any as FormGroup<TFormGroup>);\n      this._formSchema = v;\n    }\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form()?.disable({ emitEvent: false });\n    else this.form()?.enable();\n\n    setTimeout(() => {\n      if (v) this.form()?.disable({ emitEvent: false });\n      else this.form()?.enable();\n    }, 500);\n  }\n  readonly optionsMap = signal<IFormOptions>({});\n  // formVal = computed(() => this.form?.getRawValue());\n\n  readonly computedFormSchema = computed<IFormSchema<TFormGroup>[]>(() => {\n    const formSchema = this.formSchema() || [],\n      presetValueForSingleOption = this.presetValueForSingleOption(),\n      isCreate = this.isCreate(),\n      ret: IFormSchema<TFormGroup>[] = [];\n    formSchema.forEach((scheme) => {\n      if (!scheme.hidden) {\n        if (isCreate)\n          scheme.presetValue =\n            scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  constructor() {\n    super();\n\n    let listenToKey: Subscription;\n    this.destroyRef.onDestroy(() => {\n      listenToKey?.unsubscribe();\n    });\n    // effect(() => {\n    //   console.log(this.formSchema());\n    // });\n    effect(() => {\n      const ftr = this.formTagRef(),\n        submitOnEnterKey = this.submitOnEnterKey();\n      // debugger;\n\n      listenToKey?.unsubscribe();\n      if (ftr?.nativeElement && submitOnEnterKey)\n        listenToKey = fromEvent(ftr.nativeElement, 'keydown')\n          .pipe(\n            debounceTime(100),\n            filter(\n              (r: KeyboardEvent) => (r.code === 'Enter' || r.keyCode === 13) && this.form().valid,\n            ),\n          )\n          .subscribe((r: KeyboardEvent) => {\n            this.submit(this.submitBtnRef());\n          });\n    });\n  }\n\n  init(schema: TFormSchema[]) {\n    // debugger;\n    if (this.debug()) debugger;\n    this.onDestroy();\n    this._setFormSchemas(schema || []);\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit) {\n          const formValue = this.form()?.getRawValue();\n          scheme.onChangeFunc(formValue, formValue[scheme.field?.toString()], this);\n        }\n  }\n\n  handleFormScheme(scheme: TFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (this.formService.config.showValidationMessagesByDefault)\n      if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n        scheme.autoPickValueField = true;\n    // if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form()\n        ?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0))\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.formValue(), r, this);\n        });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: TFormSchema, options$: Observable<any[]>) {\n    options$.subscribe((r) => {\n      this.updateFormSchema(scheme.field, { options: r } as TFormSchema);\n    });\n  }\n\n  detachFormScheme(fieldName?: keyof TFormGroup) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  protected mchangeEmitter() {\n    this.mchange.emit(this.formValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    return this.formSchemaMap()[fieldName as string];\n  };\n\n  addToFormSchema(formScheme: TFormSchema) {\n    this.removeFromFormSchema(formScheme.field);\n    this.handleFormScheme(formScheme);\n  }\n\n  updateFormSchema(fieldName: keyof TFormGroup, scheme: Partial<TFormSchema>) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n  updateAllFormSchema(map: (formField: IFormSchema<TFormGroup>) => TFormSchema) {\n    return super._updateAllFormSchema(map);\n  }\n\n  removeFromFormSchema(fieldName: keyof TFormGroup) {\n    this.detachFormScheme(fieldName);\n    const onRemove = this.formSchemaMap()[fieldName as string]?.onRemoveFunc;\n    if (onRemove) onRemove(this.formValue() as any, this.formValue()[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.formValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        if (this.submitSuccessText()) this.utilityService.info(this.submitSuccessText(), 1);\n        this.saved.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.formValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n  <form [formGroup]=\"form()\" #formTag>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n        gridLGStyle()\n      }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.field) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [name]=\"scheme.field\"\n                [noFormat]=\"scheme.noFormat\"\n                [verbose]=\"scheme.verbose\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationMsg]=\"scheme.showValidationMsg\" \n                [countryCode3]=\"scheme.countryCode3\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <app-autocomplete\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [presetValue]=\"scheme.presetValue\"\n                [labelField]=\"scheme.labelField\"\n                [noFormat]=\"scheme.noFormat\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                [valueField]=\"scheme.valueField\"\n                [optionsFunc]=\"scheme.optionsFunc\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'richtext') {\n              <rich-text-editor-rf\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label!\"\n                [clearOnDisable]=\"scheme.clearOnDisable!\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [labelField]=\"scheme.labelField!\"\n                [noFormat]=\"scheme.noFormat!\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug!\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag!\"\n                [optionFormatter]=\"scheme.optionFormatter!\"\n                [valueField]=\"scheme.valueField!\"\n                [optionsFunc]=\"scheme.optionsFunc!\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField!\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint!\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @default {\n              <app-input-basic\n                [noFormat]=\"scheme.noFormat\"\n                [name]=\"scheme.field\"\n                [form]=\"scheme.form || form()\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [type]=\"scheme.type\"\n                [verbose]=\"scheme.verbose\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [labelField]=\"scheme.labelField\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [decimalPoints]=\"scheme.decimalPoints\"\n                [hint]=\"scheme.hint\"\n                [max]=\"scheme.max\"\n                [min]=\"scheme.min\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n          }\n        </div>\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn()) {\n          <app-btn\n            [text]=\"submitBtnText()\"\n            group=\"submit\"\n            [form]=\"form()\"\n            (mclick)=\"submit(submitBtn)\"\n            #submitBtn />\n        }\n        @if (submitBtnTemplate()) {\n          <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n        }\n      </div>\n    </div>\n  </form>\n</loader>\n"]}
255
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { debounceTime, filter, last, switchMap, tap, map, startWith } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    RichTextEditorRFComponent,\n    BtnComponent,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> },\n  TFormSchema extends IFormSchema<TFormGroup> = IFormSchema<TFormGroup>,\n> extends BaseFormGenerator<TFormGroup, TFormSchema> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  readonly presetValueForSingleOption = input(false);\n  readonly isCreate = input<boolean>();\n  readonly submitOnEnterKey = input<boolean>(false);\n  readonly formTagRef = viewChild<ElementRef<HTMLFormElement>>('formTag');\n\n  /**Emitted just before calling the save function */\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  /**Emitted after receiving feedback from the submit function */\n  @Output() saved = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  readonly submitBtnText = input('Submit');\n  readonly submitBtnTemplate = input<TemplateRef<any>>();\n  readonly submitSuccessText = input('Saved successfully');\n  readonly showSubmitBtn = input(true);\n\n  readonly gridStyle = input<number | 'auto'>();\n  readonly gridMDStyle = input<number | 'auto'>();\n  readonly gridLGStyle = input<number | 'auto'>();\n  readonly gridXXLStyle = input<number | 'auto'>();\n\n  readonly formGridClass = input<string>();\n  readonly useLoader = input<boolean>();\n  readonly loading = input<boolean>();\n\n  readonly _loading = signal<boolean>(false);\n\n  readonly computedLoading = computed(() =>\n    this.useLoader() ? this.loading() || this._loading() : false,\n  );\n\n  readonly submitBtnRef = viewChild<BtnComponent>('submitBtn');\n  readonly form = model<FormGroup<TFormGroup>>();\n\n  readonly formValue = toSignal(\n    toObservable(this.form).pipe(\n      filter(() => !!this.form()),\n      switchMap(() =>\n        this.form()\n          .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))\n          .pipe(startWith(this.form()?.getRawValue() || {})),\n      ),\n    ),\n    // { initialValue: this.form()?.getRawValue() || {} },\n  );\n\n  submissionResponse: any;\n  @Input({ alias: 'formSchema' }) set _formSchema(v: TFormSchema[] | IFormSchema<any>[]) {\n    this.init(cloneDeep(v.filter((x) => x)) as TFormSchema[]);\n  }\n  @Input({ alias: 'formSchemaNoForm' }) set _formSchemaNoForm(v: TFormSchema[]) {\n    if (v) {\n      const form = new FormGroup({});\n      for (const item of v) {\n        form.addControl(\n          item.field?.toString(),\n          new FormControl(item.value, [].concat(item.isRequired ? [Validators.required] : [])),\n        );\n      }\n      this.form.set(form as any as FormGroup<TFormGroup>);\n      this._formSchema = v;\n    }\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form()?.disable({ emitEvent: false });\n    else this.form()?.enable();\n\n    setTimeout(() => {\n      if (v) this.form()?.disable({ emitEvent: false });\n      else this.form()?.enable();\n    }, 500);\n  }\n  readonly optionsMap = signal<IFormOptions>({});\n  // formVal = computed(() => this.form?.getRawValue());\n\n  readonly computedFormSchema = computed<IFormSchema<TFormGroup>[]>(() => {\n    const formSchema = this.formSchema() || [],\n      presetValueForSingleOption = this.presetValueForSingleOption(),\n      isCreate = this.isCreate(),\n      ret: IFormSchema<TFormGroup>[] = [];\n    formSchema.forEach((scheme) => {\n      if (!scheme.hidden) {\n        if (isCreate)\n          scheme.presetValue =\n            scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  constructor() {\n    super();\n\n    let listenToKey: Subscription;\n    this.destroyRef.onDestroy(() => {\n      listenToKey?.unsubscribe();\n    });\n    // effect(() => {\n    //   console.log(this.formSchema());\n    // });\n    effect(() => {\n      const ftr = this.formTagRef(),\n        submitOnEnterKey = this.submitOnEnterKey();\n      // debugger;\n\n      listenToKey?.unsubscribe();\n      if (ftr?.nativeElement && submitOnEnterKey)\n        listenToKey = fromEvent(ftr.nativeElement, 'keydown')\n          .pipe(\n            debounceTime(100),\n            filter(\n              (r: KeyboardEvent) => (r.code === 'Enter' || r.keyCode === 13) && this.form().valid,\n            ),\n          )\n          .subscribe((r: KeyboardEvent) => {\n            this.submit(this.submitBtnRef());\n          });\n    });\n  }\n\n  init(schema: TFormSchema[]) {\n    // debugger;\n    if (this.debug()) debugger;\n    this.onDestroy();\n    this._setFormSchemas(schema || []);\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit) {\n          const formValue = this.form()?.getRawValue();\n          scheme.onChangeFunc(formValue, formValue[scheme.field?.toString()], this);\n        }\n  }\n\n  handleFormScheme(scheme: TFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (this.formService.config.showValidationMessagesByDefault)\n      if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n        scheme.autoPickValueField = true;\n    // if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form()\n        ?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0))\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.formValue(), r, this);\n        });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: TFormSchema, options$: Observable<any[]>) {\n    options$.subscribe((r) => {\n      this.updateFormSchema(scheme.field, { options: r } as TFormSchema);\n    });\n  }\n\n  detachFormScheme(fieldName?: keyof TFormGroup) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  protected mchangeEmitter() {\n    this.mchange.emit(this.formValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    return this.formSchemaMap()[fieldName as string];\n  };\n\n  addToFormSchema(formScheme: TFormSchema) {\n    this.removeFromFormSchema(formScheme.field);\n    this.handleFormScheme(formScheme);\n  }\n\n  updateFormSchema(fieldName: keyof TFormGroup, scheme: Partial<TFormSchema>) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n  updateAllFormSchema(map: (formField: IFormSchema<TFormGroup>) => TFormSchema) {\n    return super._updateAllFormSchema(map);\n  }\n\n  removeFromFormSchema(fieldName: keyof TFormGroup) {\n    this.detachFormScheme(fieldName);\n    const onRemove = this.formSchemaMap()[fieldName as string]?.onRemoveFunc;\n    if (onRemove) onRemove(this.formValue() as any, this.formValue()[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.formValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        if (this.submitSuccessText()) this.utilityService.info(this.submitSuccessText(), 1);\n        this.saved.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.formValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n  /**\n   * Template variable model:\n   * ```\n   * {\n   *    row: FormGroup<TFormGroup>;\n   *    scheme: IFormSchema;\n   * }\n   * ```\n   */\n  templateRef?: TemplateRef<any>;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n  <form [formGroup]=\"form()\" #formTag>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n        gridLGStyle()\n      }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.field) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [name]=\"scheme.field\"\n                [noFormat]=\"scheme.noFormat\"\n                [verbose]=\"scheme.verbose\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationMsg]=\"scheme.showValidationMsg\" \n                [countryCode3]=\"scheme.countryCode3\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <app-autocomplete\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [presetValue]=\"scheme.presetValue\"\n                [labelField]=\"scheme.labelField\"\n                [noFormat]=\"scheme.noFormat\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                [valueField]=\"scheme.valueField\"\n                [optionsFunc]=\"scheme.optionsFunc\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'richtext') {\n              <rich-text-editor-rf\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label!\"\n                [clearOnDisable]=\"scheme.clearOnDisable!\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [labelField]=\"scheme.labelField!\"\n                [noFormat]=\"scheme.noFormat!\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug!\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag!\"\n                [optionFormatter]=\"scheme.optionFormatter!\"\n                [valueField]=\"scheme.valueField!\"\n                [optionsFunc]=\"scheme.optionsFunc!\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField!\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint!\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @default {\n              <app-input-basic\n                [noFormat]=\"scheme.noFormat\"\n                [name]=\"scheme.field\"\n                [form]=\"scheme.form || form()\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [type]=\"scheme.type\"\n                [verbose]=\"scheme.verbose\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [labelField]=\"scheme.labelField\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [decimalPoints]=\"scheme.decimalPoints\"\n                [hint]=\"scheme.hint\"\n                [max]=\"scheme.max\"\n                [min]=\"scheme.min\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n          }\n        </div>\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn()) {\n          <app-btn\n            [text]=\"submitBtnText()\"\n            group=\"submit\"\n            [form]=\"form()\"\n            (mclick)=\"submit(submitBtn)\"\n            #submitBtn />\n        }\n        @if (submitBtnTemplate()) {\n          <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n        }\n      </div>\n    </div>\n  </form>\n</loader>\n"]}
@@ -30,6 +30,7 @@ export class TableBaseComponent {
30
30
  this.orderDirection = input('asc');
31
31
  this.orderField = input();
32
32
  this.pageSize = input(10);
33
+ this.customTemplates = input();
33
34
  this.startSectionTemplate = input();
34
35
  this.computedPageSizeOptions = computed(() => {
35
36
  const defaultPageSizeOptions = this.defaultPageSizeOptions(), pageSizeOptions = this.pageSizeOptions(), resultsLength = this.resultsLength();
@@ -107,10 +108,12 @@ export class TableBaseComponent {
107
108
  debugger;
108
109
  if (!columns?.length)
109
110
  return;
111
+ const customTemplates = this.customTemplates();
110
112
  const cellsToCheckFor = {};
111
113
  // const dateFields = { createdOn: 1, updatedOn: 1 };
112
114
  for (let index = 0; index < columns.length; index++) {
113
115
  const item = columns[index];
116
+ item.customTemplate = customTemplates[item.f];
114
117
  if (!(item.previewOnHover === false ||
115
118
  (!item.onHoverHandler && !this.tS.generalColumnPropMap[item.f]?.onHoverHandler))) {
116
119
  item._onHoverFunction = (event, row) => (item.onHoverHandler || this.tS.generalColumnPropMap[item.f]?.onHoverHandler).action(row, event);
@@ -253,7 +256,7 @@ export class TableBaseComponent {
253
256
  this.cdr.detectChanges();
254
257
  }
255
258
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TableBaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
256
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.0", type: TableBaseComponent, isStandalone: true, selector: "ng-component", inputs: { _rowOptions: { classPropertyName: "_rowOptions", publicName: "rowOptions", isSignal: true, isRequired: false, transformFunction: null }, rowOptionsMap: { classPropertyName: "rowOptionsMap", publicName: "rowOptionsMap", isSignal: true, isRequired: false, transformFunction: null }, centerCells: { classPropertyName: "centerCells", publicName: "centerCells", isSignal: true, isRequired: false, transformFunction: null }, curvy: { classPropertyName: "curvy", publicName: "curvy", isSignal: true, isRequired: false, transformFunction: null }, distinct: { classPropertyName: "distinct", publicName: "distinct", isSignal: true, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null }, isExpandable: { classPropertyName: "isExpandable", publicName: "isExpandable", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, isDisabledFunc: { classPropertyName: "isDisabledFunc", publicName: "isDisabledFunc", isSignal: true, isRequired: false, transformFunction: null }, noItemTxt: { classPropertyName: "noItemTxt", publicName: "noItemTxt", isSignal: true, isRequired: false, transformFunction: null }, nowrap: { classPropertyName: "nowrap", publicName: "nowrap", isSignal: true, isRequired: false, transformFunction: null }, debug: { classPropertyName: "debug", publicName: "debug", isSignal: true, isRequired: false, transformFunction: null }, expandedRowTemplate: { classPropertyName: "expandedRowTemplate", publicName: "expandedRowTemplate", isSignal: true, isRequired: false, transformFunction: null }, orderDirection: { classPropertyName: "orderDirection", publicName: "orderDirection", isSignal: true, isRequired: false, transformFunction: null }, orderField: { classPropertyName: "orderField", publicName: "orderField", isSignal: true, isRequired: false, transformFunction: null }, pageSize: { classPropertyName: "pageSize", publicName: "pageSize", isSignal: true, isRequired: false, transformFunction: null }, startSectionTemplate: { classPropertyName: "startSectionTemplate", publicName: "startSectionTemplate", isSignal: true, isRequired: false, transformFunction: null }, pageSizeOptions: { classPropertyName: "pageSizeOptions", publicName: "pageSizeOptions", isSignal: true, isRequired: false, transformFunction: null }, placeSelectionAtRight: { classPropertyName: "placeSelectionAtRight", publicName: "placeSelectionAtRight", isSignal: true, isRequired: false, transformFunction: null }, showAdditionalColumns: { classPropertyName: "showAdditionalColumns", publicName: "showAdditionalColumns", isSignal: true, isRequired: false, transformFunction: null }, showExport: { classPropertyName: "showExport", publicName: "showExport", isSignal: true, isRequired: false, transformFunction: null }, showRowPointer: { classPropertyName: "showRowPointer", publicName: "showRowPointer", isSignal: true, isRequired: false, transformFunction: null }, smallerFonts: { classPropertyName: "smallerFonts", publicName: "smallerFonts", isSignal: true, isRequired: false, transformFunction: null }, striped: { classPropertyName: "striped", publicName: "striped", isSignal: true, isRequired: false, transformFunction: null }, tableContainerClass: { classPropertyName: "tableContainerClass", publicName: "tableContainerClass", isSignal: true, isRequired: false, transformFunction: null }, useSelection: { classPropertyName: "useSelection", publicName: "useSelection", isSignal: true, isRequired: false, transformFunction: null }, formSchemaToColumns: { classPropertyName: "formSchemaToColumns", publicName: "formSchemaToColumns", isSignal: true, isRequired: false, transformFunction: null }, uploadSchemaToColumns: { classPropertyName: "uploadSchemaToColumns", publicName: "uploadSchemaToColumns", isSignal: true, isRequired: false, transformFunction: null }, _displayedColumns: { classPropertyName: "_displayedColumns", publicName: "displayedColumns", isSignal: true, isRequired: false, transformFunction: null }, useCustomLabels: { classPropertyName: "useCustomLabels", publicName: "useCustomLabels", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { _rowClick: "rowClick", emitCheckbox: "emitCheckbox", selectionChanged: "selectionChanged", useCustomLabels: "useCustomLabelsChange" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }, { propertyName: "sort", first: true, predicate: MatSort, descendants: true }, { propertyName: "table", first: true, predicate: ["table"], descendants: true }], ngImport: i0, template: '', isInline: true }); }
259
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.0", type: TableBaseComponent, isStandalone: true, selector: "ng-component", inputs: { _rowOptions: { classPropertyName: "_rowOptions", publicName: "rowOptions", isSignal: true, isRequired: false, transformFunction: null }, rowOptionsMap: { classPropertyName: "rowOptionsMap", publicName: "rowOptionsMap", isSignal: true, isRequired: false, transformFunction: null }, centerCells: { classPropertyName: "centerCells", publicName: "centerCells", isSignal: true, isRequired: false, transformFunction: null }, curvy: { classPropertyName: "curvy", publicName: "curvy", isSignal: true, isRequired: false, transformFunction: null }, distinct: { classPropertyName: "distinct", publicName: "distinct", isSignal: true, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null }, isExpandable: { classPropertyName: "isExpandable", publicName: "isExpandable", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, isDisabledFunc: { classPropertyName: "isDisabledFunc", publicName: "isDisabledFunc", isSignal: true, isRequired: false, transformFunction: null }, noItemTxt: { classPropertyName: "noItemTxt", publicName: "noItemTxt", isSignal: true, isRequired: false, transformFunction: null }, nowrap: { classPropertyName: "nowrap", publicName: "nowrap", isSignal: true, isRequired: false, transformFunction: null }, debug: { classPropertyName: "debug", publicName: "debug", isSignal: true, isRequired: false, transformFunction: null }, expandedRowTemplate: { classPropertyName: "expandedRowTemplate", publicName: "expandedRowTemplate", isSignal: true, isRequired: false, transformFunction: null }, orderDirection: { classPropertyName: "orderDirection", publicName: "orderDirection", isSignal: true, isRequired: false, transformFunction: null }, orderField: { classPropertyName: "orderField", publicName: "orderField", isSignal: true, isRequired: false, transformFunction: null }, pageSize: { classPropertyName: "pageSize", publicName: "pageSize", isSignal: true, isRequired: false, transformFunction: null }, customTemplates: { classPropertyName: "customTemplates", publicName: "customTemplates", isSignal: true, isRequired: false, transformFunction: null }, startSectionTemplate: { classPropertyName: "startSectionTemplate", publicName: "startSectionTemplate", isSignal: true, isRequired: false, transformFunction: null }, pageSizeOptions: { classPropertyName: "pageSizeOptions", publicName: "pageSizeOptions", isSignal: true, isRequired: false, transformFunction: null }, placeSelectionAtRight: { classPropertyName: "placeSelectionAtRight", publicName: "placeSelectionAtRight", isSignal: true, isRequired: false, transformFunction: null }, showAdditionalColumns: { classPropertyName: "showAdditionalColumns", publicName: "showAdditionalColumns", isSignal: true, isRequired: false, transformFunction: null }, showExport: { classPropertyName: "showExport", publicName: "showExport", isSignal: true, isRequired: false, transformFunction: null }, showRowPointer: { classPropertyName: "showRowPointer", publicName: "showRowPointer", isSignal: true, isRequired: false, transformFunction: null }, smallerFonts: { classPropertyName: "smallerFonts", publicName: "smallerFonts", isSignal: true, isRequired: false, transformFunction: null }, striped: { classPropertyName: "striped", publicName: "striped", isSignal: true, isRequired: false, transformFunction: null }, tableContainerClass: { classPropertyName: "tableContainerClass", publicName: "tableContainerClass", isSignal: true, isRequired: false, transformFunction: null }, useSelection: { classPropertyName: "useSelection", publicName: "useSelection", isSignal: true, isRequired: false, transformFunction: null }, formSchemaToColumns: { classPropertyName: "formSchemaToColumns", publicName: "formSchemaToColumns", isSignal: true, isRequired: false, transformFunction: null }, uploadSchemaToColumns: { classPropertyName: "uploadSchemaToColumns", publicName: "uploadSchemaToColumns", isSignal: true, isRequired: false, transformFunction: null }, _displayedColumns: { classPropertyName: "_displayedColumns", publicName: "displayedColumns", isSignal: true, isRequired: false, transformFunction: null }, useCustomLabels: { classPropertyName: "useCustomLabels", publicName: "useCustomLabels", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { _rowClick: "rowClick", emitCheckbox: "emitCheckbox", selectionChanged: "selectionChanged", useCustomLabels: "useCustomLabelsChange" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }, { propertyName: "sort", first: true, predicate: MatSort, descendants: true }, { propertyName: "table", first: true, predicate: ["table"], descendants: true }], ngImport: i0, template: '', isInline: true }); }
257
260
  }
258
261
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TableBaseComponent, decorators: [{
259
262
  type: Component,
@@ -283,4 +286,4 @@ class TableColFormatted extends TableCol {
283
286
  this._onHoverDelay = 0;
284
287
  }
285
288
  }
286
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table/table-base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC3E,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,MAAM,EAGN,SAAS,EAET,QAAQ,EACR,MAAM,EACN,KAAK,EACL,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,IAAI,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3E,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEtC,OAAO,EAKL,QAAQ,GACT,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,oBAAoB,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAC5E,OAAO,EAAE,GAAG,EAAE,SAAS,EAAO,MAAM,MAAM,CAAC;;AAS3C,MAAM,OAAgB,kBAAkB;IALxC;QAMqB,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC1C,gBAAW,GAAG,KAAK,CAAsB,IAAI,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC;QACxE,kBAAa,GAAG,KAAK,EAAgD,CAAC;QACtE,gBAAW,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACpC,UAAK,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAC9B,aAAQ,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QACzC,6BAA6B;QACpB,WAAM,GAAG,KAAK,EAAU,CAAC;QACzB,iBAAY,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAC9C,6DAA6D;QACpD,UAAK,GAAG,KAAK,EAAU,CAAC;QACxB,mBAAc,GAAG,KAAK,EAA2B,CAAC;QAClD,cAAS,GAAG,KAAK,CAAC,oBAAoB,CAAC,CAAC;QACxC,WAAM,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QAC9B,UAAK,GAAG,KAAK,EAAW,CAAC;QACzB,wBAAmB,GAAG,KAAK,EAAoB,CAAC;QAChD,mBAAc,GAAG,KAAK,CAAW,KAAK,CAAC,CAAC;QACxC,eAAU,GAAG,KAAK,EAAe,CAAC;QAClC,aAAQ,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;QACrB,yBAAoB,GAAG,KAAK,EAA4B,CAAC;QACzD,4BAAuB,GAAG,QAAQ,CAAW,GAAG,EAAE;YACzD,MAAM,sBAAsB,GAAG,IAAI,CAAC,sBAAsB,EAAE,EAC1D,eAAe,GAAG,IAAI,CAAC,eAAe,EAAE,EACxC,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YACvC,MAAM,OAAO,GAAG,eAAe,EAAE,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,sBAAsB,CAAC;YACnF,OAAO,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;QACpF,CAAC,CAAC,CAAC;QACM,2BAAsB,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QACvE,oBAAe,GAAG,KAAK,EAAY,CAAC;QACpC,0BAAqB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC,CAAC,6DAA6D;QAC5G,0BAAqB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAC9C,eAAU,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACnC,mBAAc,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACvC,iBAAY,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACrC,YAAO,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QAC/B,wBAAmB,GAAG,KAAK,EAAU,CAAC;QACtC,iBAAY,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAErC,wBAAmB,GAAG,KAAK,EAA0C,CAAC;QACtE,0BAAqB,GAAG,KAAK,EAA6C,CAAC;QAE3E,sBAAiB,GAAG,KAAK,CAAoB,EAAE,EAAE,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAChF,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE;YACxC,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACnE,OAAO,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QACpF,CAAC,CAAC,CAAC;QACH,gHAAgH;QAChH,YAAY;QACH,6BAAwB,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAC;QAEpE,2EAA2E;QAClE,uBAAkB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAC1C,SAAS,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,gBAAgB,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CACtF,CAAC;QACO,wBAAmB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrF,gCAA2B,GAAG,QAAQ,CAAC,GAAG,EAAE,CACnD,SAAS,CACP,IAAI,CAAC,wBAAwB,EAAE,EAAE,KAAK,CAAC,GAAG,CAEzC,CACF,CACF,CAAC;QAEO,6BAAwB,GAAG,QAAQ,CAA6B,GAAG,EAAE;YAC5E,MAAM,EAAE,GACJ,IAAI,CAAC,kBAAkB,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACnC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBACT,IAAI,CAAC,CAAC,IAAI,IAAI,QAAQ;wBAAE,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;yBAClC,IAAI,CAAC,CAAC,IAAI,IAAI,MAAM;wBAAE,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;oBAC3C,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;gBAClB,CAAC;gBACD,OAAO,CAAC,CAAC;YACX,CAAC,CAAC,IAAI,EAAE,EACV,eAAe,GAAG,IAAI,CAAC,wBAAwB,EAAE,EACjD,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,EAAE,EAChD,qBAAqB,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACvD,IAAI,OAAO,GAAG,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC;iBAC3D,MAAM,CACL,mBAAmB,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAC/B,CAAC,EAAE,CAAC,CAAC,KAA6B;gBAClC,CAAC,EAAE,CAAC,CAAC,KAAK;gBACV,SAAS,EAAE,CAAC,CAAC,cAAc;aAC5B,CAAC,CAAC,IAAI,EAAE,CACV;iBACA,MAAM,CACL,qBAAqB;gBACnB,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;iBACvB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KAA6B,EAAE,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,EAAE,CAC1E,CAAC;YACJ,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACrC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YAC5B,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC,CAAC;QAEiB,cAAS,GAAG,IAAI,YAAY,EAAS,CAAC;QAChD,iBAAY,GAAG,IAAI,YAAY,EAIrC,CAAC;QAMc,wBAAmB,GAAG,MAAM,CAAC,6CAA6C,CAAC,CAAC;QACtF,eAAU,GAAG,QAAQ,CAAW,GAAG,EAAE,CAC5C,IAAI,CAAC,EAAE,CAAC,YAAY,CAClB,IAAI,CAAC,wBAAwB,EAAE,EAC/B,IAAI,CAAC,aAAa,EAAE,EACpB,IAAI,CAAC,YAAY,EAAE,EACnB,IAAI,CAAC,qBAAqB,EAAE,EAC5B,IAAI,CAAC,YAAY,EAAE,CACpB,CACF,CAAC;QACO,oBAAe,GAAG,MAAM,CAAQ,IAAI,CAAC,CAAC;QACtC,cAAS,GAAG,IAAI,cAAc,CAAQ,IAAI,EAAE,EAAE,CAAC,CAAC;QAC/C,sBAAiB,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACtD,wBAAmB,GAAG,QAAQ,CACrC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CACzB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EACnC,SAAS,CAAC,EAAE,CAAC,CACd,CACF,CAAC;QACO,qBAAgB,GAAE,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;QAEpD,qBAAgB,GAE/B,EAAE,CAAC;QACA,OAAE,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAC5B,OAAE,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;QACxB,oBAAe,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAEvC,gFAAgF;QACvE,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,MAAM,IAAI,IAAI,CAAC,IAAI,EAAE,EAAE,MAAM,CAAC,CAAC;QACzF,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACtE,eAAU,GAAG,QAAQ,CAAsB,GAAG,EAAE,CACvD,IAAI,CAAC,WAAW,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CACpD,CAAC;QACO,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,MAAM,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QA0BrF,kBAAa,GAAG,CAAC,OAAmC,EAAE,EAAE;YAChE,IAAI,IAAI,CAAC,KAAK,EAAE;gBAAE,QAAQ,CAAC;YAC3B,IAAI,CAAC,OAAO,EAAE,MAAM;gBAAE,OAAO;YAC7B,MAAM,eAAe,GAAoC,EAAE,CAAC;YAC5D,qDAAqD;YACrD,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC;gBACpD,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;gBAC5B,IACE,CAAC,CACC,IAAI,CAAC,cAAc,KAAK,KAAK;oBAC7B,CAAC,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,cAAc,CAAC,CAChF,EACD,CAAC;oBACD,IAAI,CAAC,gBAAgB,GAAG,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CACrC,CAAC,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC,MAAM,CAClF,GAAG,EACH,KAAK,CACN,CAAC;oBACJ,IAAI,CAAC,aAAa,GAAG,CACnB,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,cAAc,CAC5E,CAAC,KAAK,CAAC;gBACV,CAAC;gBACD,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;oBACzD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG;wBAC9B,QAAQ,EAAE,IAAI,CAAC,QAAQ;wBACvB,SAAS,EAAE,IAAI,CAAC,SAAS;qBAC1B,CAAC;oBACF,SAAS;gBACX,CAAC;gBACD,MAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClD,IAAI,WAAW,EAAE,CAAC;oBAChB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC;oBACrC,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,SAAS,CAAC;oBACvC,SAAS;gBACX,CAAC;qBAAM,CAAC;oBACN,MAAM,cAAc,GAAG,IAAI,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC;oBACxD,IACE,cAAc,IAAI,IAAI;wBACtB,cAAc,CAAC,QAAQ,CAAC,MAAM,CAAC;wBAC/B,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,EAC9B,CAAC;wBACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;wBACrB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;wBACrC,SAAS;oBACX,CAAC;gBACH,CAAC;gBAED,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;YAClC,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;gBAAE,OAAO;YACzB,mEAAmE;YACnE,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;gBAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,MAAM;oBAAE,MAAM;gBAChD,KAAK,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;oBAClC,MAAM,IAAI,GAAG,OAAO,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC;oBAC3C,MAAM,KAAK,GAAG,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC;oBAC9B,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;wBACvB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC;wBAC5C,OAAO,eAAe,CAAC,GAAG,CAAC,CAAC;wBAC5B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;wBAClC,SAAS;oBACX,CAAC;yBAAM,IAAI,KAAK,IAAI,QAAQ,EAAE,CAAC;wBAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC;wBACrC,OAAO,eAAe,CAAC,GAAG,CAAC,CAAC;wBAC5B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;wBAClC,SAAS;oBACX,CAAC;yBAAM,IAAI,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;wBAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC;wBACtC,OAAO,eAAe,CAAC,GAAG,CAAC,CAAC;wBAC5B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;wBAClC,SAAS;oBACX,CAAC;yBAAM,IAAI,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;wBACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC;wBACpC,OAAO,eAAe,CAAC,GAAG,CAAC,CAAC;wBAC5B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;wBAClC,SAAS;oBACX,CAAC;gBACH,CAAC;YACH,CAAC;YACD,KAAK,MAAM,GAAG,IAAI,eAAe;gBAAE,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;QACrF,CAAC,CAAC;QAMO,oBAAe,GAAG,QAAQ,CAAoB,GAAG,EAAE;YAC1D,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,EAC9C,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,EAAE,EAChD,2BAA2B,GAAG,IAAI,CAAC,2BAA2B,EAAE,CAAC;YAEnE,OAAO,IAAI;iBACR,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACT,MAAM,CAAC,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;gBACjC,OAAO;oBACL,GAAG,CAAC;oBACJ,CAAC,EAAE,CAAQ;oBACX,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;oBACjC,MAAM,EAAE,CAAC,CAAC,2BAA2B,CAAC,CAAC,CAAC;iBACzC,CAAC;YACJ,CAAC,CAAC;iBACD,MAAM,CACL,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC,CAAC,CAAC,QAAQ;gBACX,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,MAAM,KAAK,CAAC,CAAC,CACpF;iBACA,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QACtB,CAAC,CAAC,CAAC;QASM,mBAAc,GAAG,MAAM,CAAC,CAAC,GAAU,EAAE,EAAE;YAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YAC7E,OAAO,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,iBAAY,GAAG,CAAC,IAAc,EAAE,GAAU,EAAsC,EAAE;YAChF,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;YACzD,MAAM,WAAW,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;YAC5E,IAAI,EAAE;gBACJ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBAC1B,MAAM,CAAC,KAAK,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBAClC,WAAW,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC;gBAC3B,CAAC,CAAC,CAAC;YACL,0BAA0B;YAC1B,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC;QAChC,CAAC,CAAC;QAEO,0BAAqB,GAAG,MAAM,CAAS,IAAI,CAAC,CAAC;QAE7C,6BAAwB,GAAG,MAAM,CAAmC,SAAS,CAAC,CAAC;KAczF;IA7KC,mDAAmD;IACnD,aAAa,CAAC,GAAW;QACvB,IAAI,CAAC,GAAG;YAAE,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,MAAM,CAAC;QACvE,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,OAAO,CAAC;IAC1E,CAAC;IAED,aAAa,CAAC,MAAsD;QAClE,MAAM,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC;QAC5B,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAC/B,IAAI;aACD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,MAAM,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC;aAC9C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,MAAM,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC;aACxD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACT,IAAI,CAAC,CAAC,IAAI,KAAK,QAAQ;gBAAE,CAAC,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC;YAC3D,OAAO,CAAC,CAAC;QACX,CAAC,CAAC,CACL,CAAC;IACJ,CAAC;IAED,uBAAuB,CAAC,GAAG;QACzB,OAAO,CAAC,KAAc,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC;IACvD,CAAC;IAqFD,cAAc,CAAC,KAAkB,EAAE,IAAW,EAAE,KAAU;QACxD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;IACjD,CAAC;IAyBD,QAAQ,CAAC,CAAQ;QACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;IACjC,CAAC;IAsBD,UAAU,CAAC,GAAU,EAAE,MAAgB,EAAE,KAAqB;QAC5D,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,CAAC;QACnD,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IAED,SAAS;QACP,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;8GA1TmB,kBAAkB;kGAAlB,kBAAkB,88IAsG3B,YAAY,uEACZ,OAAO,iIA3GR,EAAE;;2FAIQ,kBAAkB;kBALvC,SAAS;mBAAC;oBACT,QAAQ,EAAE,EAAE;oBACZ,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,EAAE;iBACZ;8BAgGqB,SAAS;sBAA5B,MAAM;uBAAC,UAAU;gBACR,YAAY;sBAArB,MAAM;gBAMkB,SAAS;sBAAjC,SAAS;uBAAC,YAAY;gBACH,IAAI;sBAAvB,SAAS;uBAAC,OAAO;gBACE,KAAK;sBAAxB,SAAS;uBAAC,OAAO;;AAqNpB,MAAM,iBAAwB,SAAQ,QAAc;IAApD;;QAEE,kBAAa,GAAY,CAAC,CAAC;IAC7B,CAAC;CAAA","sourcesContent":["import { SelectionChange, SelectionModel } from '@angular/cdk/collections';\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Output,\n  Signal,\n  TemplateRef,\n  ViewChild,\n  WritableSignal,\n  computed,\n  inject,\n  input,\n  model,\n  signal,\n} from '@angular/core';\nimport { MatPaginator as MatPaginator } from '@angular/material/paginator';\nimport { MatSort } from '@angular/material/sort';\nimport { MatTable as MatTable } from '@angular/material/table';\nimport { cloneDeep } from 'lodash-es';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport {\n  IObjectLiteral,\n  IRowOption,\n  IStrictFormGroup,\n  SortType,\n  TableCol,\n} from '../../models/index.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { TableService } from './table-plain.service';\nimport { outputFromObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { map, startWith, tap } from 'rxjs';\nimport { ModalComponent } from '../modal/modal.component';\nimport { NELEvent, NELMouseEventHandler } from '../../directives/native-event-listeners.directive';\n\n@Component({\n  template: '',\n  standalone: true,\n  imports: [],\n})\nexport abstract class TableBaseComponent<TItem extends IObjectLiteral> {\n  protected readonly cdr = inject(ChangeDetectorRef);\n  readonly _rowOptions = input<IRowOption<TItem>[]>(null, { alias: 'rowOptions' });\n  readonly rowOptionsMap = input<(row: TItem) => (IRowOption<TItem> | null)[]>();\n  readonly centerCells = input<boolean>(false);\n  readonly curvy = input<boolean>(false);\n  readonly distinct = input<boolean>(true);\n  /**Appears above the table */\n  readonly header = input<string>();\n  readonly isExpandable = input<boolean>(false);\n  /** Used to name metadata of the table like exported files */\n  readonly label = input<string>();\n  readonly isDisabledFunc = input<(row: TItem) => boolean>();\n  readonly noItemTxt = input('There are no items');\n  readonly nowrap = input<boolean>(true);\n  readonly debug = input<boolean>();\n  readonly expandedRowTemplate = input<TemplateRef<any>>();\n  readonly orderDirection = input<SortType>('asc');\n  readonly orderField = input<keyof TItem>();\n  readonly pageSize = input(10);\n  readonly startSectionTemplate = input<TemplateRef<HTMLElement>>();\n  readonly computedPageSizeOptions = computed<number[]>(() => {\n    const defaultPageSizeOptions = this.defaultPageSizeOptions(),\n      pageSizeOptions = this.pageSizeOptions(),\n      resultsLength = this.resultsLength();\n    const options = pageSizeOptions?.length ? pageSizeOptions : defaultPageSizeOptions;\n    return options.concat(options?.lastItem() > resultsLength ? [] : [resultsLength]);\n  });\n  readonly defaultPageSizeOptions = signal([5, 10, 20, 50, 100, 500, 1000, 5000]);\n  readonly pageSizeOptions = input<number[]>();\n  readonly placeSelectionAtRight = input<boolean>(false); // support customizing the position of the select checkboxes.\n  readonly showAdditionalColumns = input<boolean>(false);\n  readonly showExport = input<boolean>(false);\n  readonly showRowPointer = input<boolean>(false);\n  readonly smallerFonts = input<boolean>(false);\n  readonly striped = input<boolean>(true);\n  readonly tableContainerClass = input<string>();\n  readonly useSelection = input<boolean>(false);\n\n  readonly formSchemaToColumns = input<IFormSchema<IStrictFormGroup<TItem>>[]>();\n  readonly uploadSchemaToColumns = input<{ field?: keyof TItem; label?: string }[]>();\n\n  readonly _displayedColumns = input<TableCol<TItem>[]>([], { alias: 'displayedColumns' });\n  readonly displayedColumns = computed(() => {\n    const columns = this._displayedColumns()?.filter((x) => !x.ignore);\n    return this.useCustomLabels() ? this.tS.globalColumnsFormatter(columns) : columns;\n  });\n  /**Used to update the displayed columns through internal activities like modification from Additional columns */\n  // protected\n  readonly overrideDisplayedColumns = signal<TableCol<TItem>[]>(null);\n\n  /**Columns that are not marked as Additional Columns and are not disabled*/\n  readonly presentableColumns = computed(() =>\n    cloneDeep(this.displayedColumns()?.filter((x) => !x.additionalColumn && !x.disabled)),\n  );\n  readonly displayedColumnsMap = computed(() => cloneDeep(this.displayedColumns()?.toMap('f')));\n  readonly computedDisplayedColumnsMap = computed(() =>\n    cloneDeep(\n      this.computedDisplayedColumns()?.toMap('f') as {\n        [k in keyof TItem]: TableColFormatted<TItem>;\n      },\n    ),\n  );\n\n  readonly computedDisplayedColumns = computed<TableColFormatted<TItem>[]>(() => {\n    const dc =\n        this.presentableColumns()?.map((c) => {\n          if (!c.t) {\n            if (c.type == 'button') c.t = 'Action';\n            else if (c.type == 'btns') c.t = 'Actions';\n            c.sticky = true;\n          }\n          return c;\n        }) || [],\n      overrideColumns = this.overrideDisplayedColumns(),\n      formSchemaToColumns = this.formSchemaToColumns(),\n      uploadSchemaToColumns = this.uploadSchemaToColumns();\n    let columns = (overrideColumns?.length ? overrideColumns : dc)\n      .concat(\n        formSchemaToColumns?.map((x) => ({\n          f: x.field as TableCol<TItem>['f'],\n          t: x.label,\n          formatter: x.tableFormatter,\n        })) || [],\n      )\n      .concat(\n        uploadSchemaToColumns\n          ?.filter((x) => x.field)\n          .map((x) => ({ f: x.field as TableCol<TItem>['f'], t: x.label })) || [],\n      );\n    columns = columns.filter((x) => x.f);\n    this.handleColumns(columns);\n    return columns;\n  });\n\n  @Output('rowClick') _rowClick = new EventEmitter<TItem>();\n  @Output() emitCheckbox = new EventEmitter<{\n    field: keyof TItem;\n    item: TItem;\n    value: boolean;\n  }>();\n\n  @ViewChild(MatPaginator) paginator: MatPaginator;\n  @ViewChild(MatSort) sort: MatSort;\n  @ViewChild('table') table: MatTable<any>;\n  readonly resultsLength: Signal<number>;\n  protected readonly starterSectionClass = signal('row row-cols-lg-auto g-3 align-items-center');\n  readonly rawColumns = computed<string[]>(() =>\n    this.tS.getRawFields(\n      this.computedDisplayedColumns(),\n      this.hasRowOptions(),\n      this.useSelection(),\n      this.placeSelectionAtRight(),\n      this.isExpandable(),\n    ),\n  );\n  readonly expandedElement = signal<TItem>(null);\n  readonly selection = new SelectionModel<TItem>(true, []);\n  protected _selectionChanged = toSignal(this.selection.changed);\n  readonly selectedItemsSignal = toSignal(\n    this.selection.changed.pipe( \n      map((r) => this.selection.selected),\n      startWith([]),\n    ),\n  );\n  readonly selectionChanged =outputFromObservable(this.selection.changed)\n\n  protected readonly cellFormatterMap: {\n    [k in keyof TItem]?: Partial<TableColFormatted<TItem>>;\n  } = {};\n  public uS = inject(UtilityService);\n  public tS = inject(TableService);\n  readonly useCustomLabels = model(true);\n\n  /** Whether the number of selected elements matches the total number of rows. */\n  readonly isAllSelected = computed(() => this.selectedItemsSignal().length == this.data()?.length);\n  readonly isAnySelected = computed(() => this.selectedItemsSignal().length > 0);\n  readonly rowOptions = computed<IRowOption<TItem>[]>(() =>\n    this._rowOptions()?.filter((x) => !!x && !x.ignore),\n  );\n  readonly hasRowOptions = computed(() => !!this.rowOptions()?.length || !!this.rowOptionsMap());\n\n  /** The label for the checkbox on the passed row */\n  checkboxLabel(row?: TItem): string {\n    if (!row) return `${this.isAllSelected() ? 'deselect' : 'select'} all`;\n    return `${this.selection.isSelected(row) ? 'deselect' : 'select'} row `;\n  }\n\n  fieldsChanged($event: { nFields: TableCol[]; allFields: TableCol[] }) {\n    const cols = $event.nFields;\n    this.overrideDisplayedColumns.set(\n      cols\n        .filter((x) => !(x.type == 'btns' && x.sticky))\n        .concat(cols.filter((x) => x.type == 'btns' && x.sticky))\n        .map((x) => {\n          if (x.type === 'number') x.formatter = this.uS.moneyParser;\n          return x;\n        }),\n    );\n  }\n\n  getActionStatusCallback(col) {\n    return (state: boolean) => (col.btn.loading = state);\n  }\n  readonly data: WritableSignal<TItem[]>;\n\n  protected handleColumns = (columns: TableColFormatted<TItem>[]) => {\n    if (this.debug()) debugger;\n    if (!columns?.length) return;\n    const cellsToCheckFor: { [k in keyof TItem]?: number } = {};\n    // const dateFields = { createdOn: 1, updatedOn: 1 };\n    for (let index = 0; index < columns.length; index++) {\n      const item = columns[index];\n      if (\n        !(\n          item.previewOnHover === false ||\n          (!item.onHoverHandler && !this.tS.generalColumnPropMap[item.f]?.onHoverHandler)\n        )\n      ) {\n        item._onHoverFunction = (event, row) =>\n          (item.onHoverHandler || this.tS.generalColumnPropMap[item.f]?.onHoverHandler).action(\n            row,\n            event,\n          );\n        item._onHoverDelay = (\n          item.onHoverHandler || this.tS.generalColumnPropMap[item.f]?.onHoverHandler\n        ).delay;\n      }\n      if (item.noFormat || item.formatter || item.formatterRow) {\n        this.cellFormatterMap[item.f] = {\n          noFormat: item.noFormat,\n          formatter: item.formatter,\n        };\n        continue;\n      }\n      const savedConfig = this.cellFormatterMap[item.f];\n      if (savedConfig) {\n        item.noFormat = savedConfig.noFormat;\n        item.formatter = savedConfig.formatter;\n        continue;\n      } else {\n        const itemFieldLower = item.f?.toString().toLowerCase();\n        if (\n          itemFieldLower == 'id' ||\n          itemFieldLower.includes('year') ||\n          itemFieldLower.includes('age')\n        ) {\n          item.noFormat = true;\n          this.cellFormatterMap[item.f] = item;\n          continue;\n        }\n      }\n\n      cellsToCheckFor[item.f] = index;\n    }\n    if (!this.data()) return;\n    // console.log('cellsToCheckFor', JSON.stringify(cellsToCheckFor));\n    for (const row of this.data()) {\n      if (!Object.keys(cellsToCheckFor).length) break;\n      for (const key in cellsToCheckFor) {\n        const cell = columns[cellsToCheckFor[key]];\n        const typeo = typeof row[key];\n        if (typeo == 'boolean') {\n          cell.formatter = this.uS.yesNoCellFormatter;\n          delete cellsToCheckFor[key];\n          this.cellFormatterMap[key] = cell;\n          continue;\n        } else if (typeo == 'number') {\n          cell.formatter = this.uS.moneyParser;\n          delete cellsToCheckFor[key];\n          this.cellFormatterMap[key] = cell;\n          continue;\n        } else if (this.uS.isDatTimeValue(row[key])) {\n          cell.formatter = this.uS.fullDateTime;\n          delete cellsToCheckFor[key];\n          this.cellFormatterMap[key] = cell;\n          continue;\n        } else if (this.uS.isDateValue(row[key])) {\n          cell.formatter = this.uS.dateFormat;\n          delete cellsToCheckFor[key];\n          this.cellFormatterMap[key] = cell;\n          continue;\n        }\n      }\n    }\n    for (const key in cellsToCheckFor) this.cellFormatterMap[key] = { noFormat: true };\n  };\n\n  outputCheckbox(field: keyof TItem, item: TItem, value: any) {\n    this.emitCheckbox.emit({ field, item, value });\n  }\n\n  readonly allTableColumns = computed<TableCol<TItem>[]>(() => {\n    const keys = Object.keys(this.data()?.[0] || {}),\n      displayedColumnsMap = this.displayedColumnsMap(),\n      computedDisplayedColumnsMap = this.computedDisplayedColumnsMap();\n\n    return keys\n      .map((k) => {\n        const e = displayedColumnsMap[k];\n        return {\n          ...e,\n          f: k as any,\n          t: e?.t || this.uS.formatField(k),\n          active: !!computedDisplayedColumnsMap[k],\n        };\n      })\n      .filter(\n        (x) =>\n          !x.disabled &&\n          !(x?.f?.toString().toLowerCase().endsWith('id') && x?.f?.toString().length === 2),\n      )\n      .sort2('t', true);\n  });\n\n  rowClick(e: TItem) {\n    this._rowClick.emit(e);\n  }\n\n  get selectedItems() {\n    return this.selection.selected;\n  }\n  readonly formOptionsMap = signal((row: TItem) => {\n    const options = this.rowOptionsMap()?.(row)?.filter((x) => !!x && !x.ignore);\n    return options?.length ? options : null;\n  });\n\n  extractRoute = (cell: TableCol, row: TItem): { route: string; queryParams: {} } => {\n    const [route, qp] = cell.routeFormatter(row)?.split('?');\n    const queryParams = (cell.mqueryParams ? cell.mqueryParams(row) : {}) || {};\n    if (qp)\n      qp.split('&').forEach((q) => {\n        const [field, val] = q.split('=');\n        queryParams[field] = val;\n      });\n    // console.log(route, qp);\n    return { route, queryParams };\n  };\n\n  readonly ngAfterViewInitSignal = signal<number>(null);\n\n  readonly selectedCellForExpansion = signal<{ column: TableCol; row: TItem }>(undefined);\n\n  expandCell(row: TItem, column: TableCol, modal: ModalComponent) {\n    this.selectedCellForExpansion.set({ row, column });\n    modal.open();\n  }\n\n  closeExpandedCell() {\n    this.selectedCellForExpansion.set(undefined);\n  }\n\n  refreshUI() {\n    this.cdr.detectChanges();\n  }\n}\n\nclass TableColFormatted<TRow> extends TableCol<TRow> {\n  _onHoverFunction?: NELMouseEventHandler<TRow>['action'];\n  _onHoverDelay?: number = 0;\n}\n"]}
289
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table/table-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { SelectionChange, SelectionModel } from '@angular/cdk/collections';\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Output,\n  Signal,\n  TemplateRef,\n  ViewChild,\n  WritableSignal,\n  computed,\n  inject,\n  input,\n  model,\n  signal,\n} from '@angular/core';\nimport { MatPaginator as MatPaginator } from '@angular/material/paginator';\nimport { MatSort } from '@angular/material/sort';\nimport { MatTable as MatTable } from '@angular/material/table';\nimport { cloneDeep } from 'lodash-es';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport {\n  IObjectLiteral,\n  IRowOption,\n  IStrictFormGroup,\n  SortType,\n  TableCol,\n} from '../../models/index.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { TableService } from './table-plain.service';\nimport { outputFromObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { map, startWith, tap } from 'rxjs';\nimport { ModalComponent } from '../modal/modal.component';\nimport { NELEvent, NELMouseEventHandler } from '../../directives/native-event-listeners.directive';\n\n@Component({\n  template: '',\n  standalone: true,\n  imports: [],\n})\nexport abstract class TableBaseComponent<TItem extends IObjectLiteral> {\n  protected readonly cdr = inject(ChangeDetectorRef);\n  readonly _rowOptions = input<IRowOption<TItem>[]>(null, { alias: 'rowOptions' });\n  readonly rowOptionsMap = input<(row: TItem) => (IRowOption<TItem> | null)[]>();\n  readonly centerCells = input<boolean>(false);\n  readonly curvy = input<boolean>(false);\n  readonly distinct = input<boolean>(true);\n  /**Appears above the table */\n  readonly header = input<string>();\n  readonly isExpandable = input<boolean>(false);\n  /** Used to name metadata of the table like exported files */\n  readonly label = input<string>();\n  readonly isDisabledFunc = input<(row: TItem) => boolean>();\n  readonly noItemTxt = input('There are no items');\n  readonly nowrap = input<boolean>(true);\n  readonly debug = input<boolean>();\n  readonly expandedRowTemplate = input<TemplateRef<any>>();\n  readonly orderDirection = input<SortType>('asc');\n  readonly orderField = input<keyof TItem>();\n  readonly pageSize = input(10);\n  readonly customTemplates = input<{ [x in keyof TItem]?: TemplateRef<any> }>();\n  readonly startSectionTemplate = input<TemplateRef<HTMLElement>>();\n  readonly computedPageSizeOptions = computed<number[]>(() => {\n    const defaultPageSizeOptions = this.defaultPageSizeOptions(),\n      pageSizeOptions = this.pageSizeOptions(),\n      resultsLength = this.resultsLength();\n    const options = pageSizeOptions?.length ? pageSizeOptions : defaultPageSizeOptions;\n    return options.concat(options?.lastItem() > resultsLength ? [] : [resultsLength]);\n  });\n  readonly defaultPageSizeOptions = signal([5, 10, 20, 50, 100, 500, 1000, 5000]);\n  readonly pageSizeOptions = input<number[]>();\n  readonly placeSelectionAtRight = input<boolean>(false); // support customizing the position of the select checkboxes.\n  readonly showAdditionalColumns = input<boolean>(false);\n  readonly showExport = input<boolean>(false);\n  readonly showRowPointer = input<boolean>(false);\n  readonly smallerFonts = input<boolean>(false);\n  readonly striped = input<boolean>(true);\n  readonly tableContainerClass = input<string>();\n  readonly useSelection = input<boolean>(false);\n\n  readonly formSchemaToColumns = input<IFormSchema<IStrictFormGroup<TItem>>[]>();\n  readonly uploadSchemaToColumns = input<{ field?: keyof TItem; label?: string }[]>();\n\n  readonly _displayedColumns = input<TableCol<TItem>[]>([], { alias: 'displayedColumns' });\n  readonly displayedColumns = computed(() => {\n    const columns = this._displayedColumns()?.filter((x) => !x.ignore);\n    return this.useCustomLabels() ? this.tS.globalColumnsFormatter(columns) : columns;\n  });\n  /**Used to update the displayed columns through internal activities like modification from Additional columns */\n  // protected\n  readonly overrideDisplayedColumns = signal<TableCol<TItem>[]>(null);\n\n  /**Columns that are not marked as Additional Columns and are not disabled*/\n  readonly presentableColumns = computed(() =>\n    cloneDeep(this.displayedColumns()?.filter((x) => !x.additionalColumn && !x.disabled)),\n  );\n  readonly displayedColumnsMap = computed(() => cloneDeep(this.displayedColumns()?.toMap('f')));\n  readonly computedDisplayedColumnsMap = computed(() =>\n    cloneDeep(\n      this.computedDisplayedColumns()?.toMap('f') as {\n        [k in keyof TItem]: TableColFormatted<TItem>;\n      },\n    ),\n  );\n\n  readonly computedDisplayedColumns = computed<TableColFormatted<TItem>[]>(() => {\n    const dc =\n        this.presentableColumns()?.map((c) => {\n          if (!c.t) {\n            if (c.type == 'button') c.t = 'Action';\n            else if (c.type == 'btns') c.t = 'Actions';\n            c.sticky = true;\n          }\n          return c;\n        }) || [],\n      overrideColumns = this.overrideDisplayedColumns(),\n      formSchemaToColumns = this.formSchemaToColumns(),\n      uploadSchemaToColumns = this.uploadSchemaToColumns();\n    let columns = (overrideColumns?.length ? overrideColumns : dc)\n      .concat(\n        formSchemaToColumns?.map((x) => ({\n          f: x.field as TableCol<TItem>['f'],\n          t: x.label,\n          formatter: x.tableFormatter,\n        })) || [],\n      )\n      .concat(\n        uploadSchemaToColumns\n          ?.filter((x) => x.field)\n          .map((x) => ({ f: x.field as TableCol<TItem>['f'], t: x.label })) || [],\n      );\n    columns = columns.filter((x) => x.f);\n    this.handleColumns(columns);\n    return columns;\n  });\n\n  @Output('rowClick') _rowClick = new EventEmitter<TItem>();\n  @Output() emitCheckbox = new EventEmitter<{\n    field: keyof TItem;\n    item: TItem;\n    value: boolean;\n  }>();\n\n  @ViewChild(MatPaginator) paginator: MatPaginator;\n  @ViewChild(MatSort) sort: MatSort;\n  @ViewChild('table') table: MatTable<any>;\n  readonly resultsLength: Signal<number>;\n  protected readonly starterSectionClass = signal('row row-cols-lg-auto g-3 align-items-center');\n  readonly rawColumns = computed<string[]>(() =>\n    this.tS.getRawFields(\n      this.computedDisplayedColumns(),\n      this.hasRowOptions(),\n      this.useSelection(),\n      this.placeSelectionAtRight(),\n      this.isExpandable(),\n    ),\n  );\n  readonly expandedElement = signal<TItem>(null);\n  readonly selection = new SelectionModel<TItem>(true, []);\n  protected _selectionChanged = toSignal(this.selection.changed);\n  readonly selectedItemsSignal = toSignal(\n    this.selection.changed.pipe(\n      map((r) => this.selection.selected),\n      startWith([]),\n    ),\n  );\n  readonly selectionChanged = outputFromObservable(this.selection.changed);\n\n  protected readonly cellFormatterMap: {\n    [k in keyof TItem]?: Partial<TableColFormatted<TItem>>;\n  } = {};\n  public uS = inject(UtilityService);\n  public tS = inject(TableService);\n  readonly useCustomLabels = model(true);\n\n  /** Whether the number of selected elements matches the total number of rows. */\n  readonly isAllSelected = computed(() => this.selectedItemsSignal().length == this.data()?.length);\n  readonly isAnySelected = computed(() => this.selectedItemsSignal().length > 0);\n  readonly rowOptions = computed<IRowOption<TItem>[]>(() =>\n    this._rowOptions()?.filter((x) => !!x && !x.ignore),\n  );\n  readonly hasRowOptions = computed(() => !!this.rowOptions()?.length || !!this.rowOptionsMap());\n\n  /** The label for the checkbox on the passed row */\n  checkboxLabel(row?: TItem): string {\n    if (!row) return `${this.isAllSelected() ? 'deselect' : 'select'} all`;\n    return `${this.selection.isSelected(row) ? 'deselect' : 'select'} row `;\n  }\n\n  fieldsChanged($event: { nFields: TableCol[]; allFields: TableCol[] }) {\n    const cols = $event.nFields;\n    this.overrideDisplayedColumns.set(\n      cols\n        .filter((x) => !(x.type == 'btns' && x.sticky))\n        .concat(cols.filter((x) => x.type == 'btns' && x.sticky))\n        .map((x) => {\n          if (x.type === 'number') x.formatter = this.uS.moneyParser;\n          return x;\n        }),\n    );\n  }\n\n  getActionStatusCallback(col) {\n    return (state: boolean) => (col.btn.loading = state);\n  }\n  readonly data: WritableSignal<TItem[]>;\n\n  protected handleColumns = (columns: TableColFormatted<TItem>[]) => {\n    if (this.debug()) debugger;\n    if (!columns?.length) return;\n\n    const customTemplates = this.customTemplates();\n    const cellsToCheckFor: { [k in keyof TItem]?: number } = {};\n    // const dateFields = { createdOn: 1, updatedOn: 1 };\n    for (let index = 0; index < columns.length; index++) {\n      const item = columns[index];\n      item.customTemplate = customTemplates[item.f];\n      if (\n        !(\n          item.previewOnHover === false ||\n          (!item.onHoverHandler && !this.tS.generalColumnPropMap[item.f]?.onHoverHandler)\n        )\n      ) {\n        item._onHoverFunction = (event, row) =>\n          (item.onHoverHandler || this.tS.generalColumnPropMap[item.f]?.onHoverHandler).action(\n            row,\n            event,\n          );\n        item._onHoverDelay = (\n          item.onHoverHandler || this.tS.generalColumnPropMap[item.f]?.onHoverHandler\n        ).delay;\n      }\n      if (item.noFormat || item.formatter || item.formatterRow) {\n        this.cellFormatterMap[item.f] = {\n          noFormat: item.noFormat,\n          formatter: item.formatter,\n        };\n        continue;\n      }\n      const savedConfig = this.cellFormatterMap[item.f];\n      if (savedConfig) {\n        item.noFormat = savedConfig.noFormat;\n        item.formatter = savedConfig.formatter;\n        continue;\n      } else {\n        const itemFieldLower = item.f?.toString().toLowerCase();\n        if (\n          itemFieldLower == 'id' ||\n          itemFieldLower.includes('year') ||\n          itemFieldLower.includes('age')\n        ) {\n          item.noFormat = true;\n          this.cellFormatterMap[item.f] = item;\n          continue;\n        }\n      }\n\n      cellsToCheckFor[item.f] = index;\n    }\n    if (!this.data()) return;\n    // console.log('cellsToCheckFor', JSON.stringify(cellsToCheckFor));\n    for (const row of this.data()) {\n      if (!Object.keys(cellsToCheckFor).length) break;\n      for (const key in cellsToCheckFor) {\n        const cell = columns[cellsToCheckFor[key]];\n        const typeo = typeof row[key];\n        if (typeo == 'boolean') {\n          cell.formatter = this.uS.yesNoCellFormatter;\n          delete cellsToCheckFor[key];\n          this.cellFormatterMap[key] = cell;\n          continue;\n        } else if (typeo == 'number') {\n          cell.formatter = this.uS.moneyParser;\n          delete cellsToCheckFor[key];\n          this.cellFormatterMap[key] = cell;\n          continue;\n        } else if (this.uS.isDatTimeValue(row[key])) {\n          cell.formatter = this.uS.fullDateTime;\n          delete cellsToCheckFor[key];\n          this.cellFormatterMap[key] = cell;\n          continue;\n        } else if (this.uS.isDateValue(row[key])) {\n          cell.formatter = this.uS.dateFormat;\n          delete cellsToCheckFor[key];\n          this.cellFormatterMap[key] = cell;\n          continue;\n        }\n      }\n    }\n    for (const key in cellsToCheckFor) this.cellFormatterMap[key] = { noFormat: true };\n  };\n\n  outputCheckbox(field: keyof TItem, item: TItem, value: any) {\n    this.emitCheckbox.emit({ field, item, value });\n  }\n\n  readonly allTableColumns = computed<TableCol<TItem>[]>(() => {\n    const keys = Object.keys(this.data()?.[0] || {}),\n      displayedColumnsMap = this.displayedColumnsMap(),\n      computedDisplayedColumnsMap = this.computedDisplayedColumnsMap();\n\n    return keys\n      .map((k) => {\n        const e = displayedColumnsMap[k];\n        return {\n          ...e,\n          f: k as any,\n          t: e?.t || this.uS.formatField(k),\n          active: !!computedDisplayedColumnsMap[k],\n        };\n      })\n      .filter(\n        (x) =>\n          !x.disabled &&\n          !(x?.f?.toString().toLowerCase().endsWith('id') && x?.f?.toString().length === 2),\n      )\n      .sort2('t', true);\n  });\n\n  rowClick(e: TItem) {\n    this._rowClick.emit(e);\n  }\n\n  get selectedItems() {\n    return this.selection.selected;\n  }\n  readonly formOptionsMap = signal((row: TItem) => {\n    const options = this.rowOptionsMap()?.(row)?.filter((x) => !!x && !x.ignore);\n    return options?.length ? options : null;\n  });\n\n  extractRoute = (cell: TableCol, row: TItem): { route: string; queryParams: {} } => {\n    const [route, qp] = cell.routeFormatter(row)?.split('?');\n    const queryParams = (cell.mqueryParams ? cell.mqueryParams(row) : {}) || {};\n    if (qp)\n      qp.split('&').forEach((q) => {\n        const [field, val] = q.split('=');\n        queryParams[field] = val;\n      });\n    // console.log(route, qp);\n    return { route, queryParams };\n  };\n\n  readonly ngAfterViewInitSignal = signal<number>(null);\n\n  readonly selectedCellForExpansion = signal<{ column: TableCol; row: TItem }>(undefined);\n\n  expandCell(row: TItem, column: TableCol, modal: ModalComponent) {\n    this.selectedCellForExpansion.set({ row, column });\n    modal.open();\n  }\n\n  closeExpandedCell() {\n    this.selectedCellForExpansion.set(undefined);\n  }\n\n  refreshUI() {\n    this.cdr.detectChanges();\n  }\n}\n\nclass TableColFormatted<TRow> extends TableCol<TRow> {\n  _onHoverFunction?: NELMouseEventHandler<TRow>['action'];\n  _onHoverDelay?: number = 0;\n}\n"]}