ets-fe-ng-sdk 18.0.6 → 18.0.8

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.
@@ -134,8 +134,11 @@ export class BtnComponent {
134
134
  this.formSchema = input();
135
135
  this.debug = input();
136
136
  this.formIsInvalid = computed(() => {
137
- const form = this.formState(), onFormInvalid = this.onFormInvalid(), formSchema = this.formSchema();
138
- return form && form.invalid && onFormInvalid == OnFormInvalid.warn && formSchema?.length
137
+ const formState = this.formState(), form = this.form(), onFormInvalid = this.onFormInvalid(), formSchema = this.formSchema();
138
+ return formState &&
139
+ formState.invalid &&
140
+ onFormInvalid == OnFormInvalid.warn &&
141
+ formSchema?.length
139
142
  ? formSchema.some((f) => form.controls[f.field?.toString()]?.invalid)
140
143
  : null;
141
144
  }, { equal: isEqual });
@@ -336,4 +339,4 @@ var OnFormInvalid;
336
339
  OnFormInvalid["disable"] = "disable";
337
340
  OnFormInvalid["warn"] = "warn";
338
341
  })(OnFormInvalid || (OnFormInvalid = {}));
339
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"btn.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/btn/btn.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/btn/btn.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n  booleanAttribute,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n} from '@angular/core';\nimport {\n  FormControl,\n  FormGroup,\n  FormArray,\n  AbstractControl,\n  FormControlStatus,\n} from '@angular/forms';\nimport { IconDefinition, faLock } from '@fortawesome/free-solid-svg-icons';\nimport { BtnService } from './btn.service';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { TranslatorDirective } from '../../directives/translator.directive';\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\nimport { MatBadgeModule } from '@angular/material/badge';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { NgClass, NgIf, AsyncPipe, JsonPipe } from '@angular/common';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport { IconType, BtnType, BtnGroup } from './btn.model';\nimport { isEqual } from 'lodash-es';\nimport { BehaviorSubject, debounceTime, filter, map, merge, of, startWith, switchMap } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\nfunction booleanAttribute2(value: string | boolean | undefined) {\n  return booleanAttribute(value);\n}\n@Component({\n  selector: 'app-btn',\n  templateUrl: './btn.component.html',\n  styleUrls: ['./btn.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  // //\n  imports: [\n    NgClass,\n    NgIf,\n    MatTooltipModule,\n    MatBadgeModule,\n    FontAwesomeModule,\n    JsonPipe,\n    TranslatorDirective,\n    AsyncPipe,\n    SDKTranslatePipe,\n  ],\n}) // Inherited\nexport class BtnComponent implements OnInit {\n  /** To be passed when to check for specific invalid form fields */\n  readonly formSchema = input<IFormSchema[]>();\n  readonly debug = input<boolean>();\n  readonly formIsInvalid = computed<boolean>(\n    () => {\n      const form = this.formState(),\n        onFormInvalid = this.onFormInvalid(),\n        formSchema = this.formSchema();\n\n      return form && form.invalid && onFormInvalid == OnFormInvalid.warn && formSchema?.length\n        ? formSchema.some((f) => (<FormGroup>form).controls[f.field?.toString()]?.invalid)\n        : null;\n    },\n    { equal: isEqual },\n  );\n  readonly centerBtn = input<boolean>(true);\n  readonly danger = input<boolean>();\n  readonly warning = input<boolean>();\n  readonly verbose = input<boolean>();\n  // counter = signal(0);\n\n  protected iconType: IconType;\n  readonly iconBtn = signal<boolean>(false);\n  readonly loading = model<boolean>(false);\n\n  @Input('icon') set _icon(v: IconType) {\n    this.iconType = v;\n    const res = this.btnS.getIcon(v);\n    if (!res) return;\n    if (res.iconPosition == 'right') {\n      this.rightIcon.set(res.icon);\n      this.rightCustomIcon.set(res.iconString);\n    } else {\n      this.leftIcon.set(res.icon);\n      this.leftCustomIcon.set(res.iconString);\n    }\n  }\n  @Input('rightIcon') set _rightIcon(v: IconType) {\n    this.iconType = v;\n    const res = this.btnS.getIcon(v);\n    this.rightIcon.set(res.icon);\n    this.rightCustomIcon.set(res.iconString);\n  }\n  @Input('leftIcon') set _leftIcon(v: IconType) {\n    this.iconType = v;\n    const res = this.btnS.getIcon(v);\n    this.leftIcon.set(res.icon);\n    this.leftCustomIcon.set(res.iconString);\n  }\n\n  @Input('type') set _type(v: BtnType) {\n    const { _icon, _mclass, _type } = this.btnS.getType(v);\n    this._mclass.update((mclass) => _mclass || mclass);\n    if (_icon) this._icon = _icon;\n    if (_type) this._type = _type;\n  }\n\n  @Input('group') set _group(v: BtnGroup) {\n    switch (v) {\n      case 'add':\n        this._type = 'outline';\n        this._icon = 'add';\n        this.iconBtn.set(true);\n        break;\n      case 'clone':\n        this._type = 'secondary';\n        this._icon = 'clone';\n        this._text.set('Clone');\n        break;\n      case 'create':\n        this._type = 'outline';\n        this._icon = 'add';\n        this._text.set('Create');\n        break;\n      case 'close':\n        this._type = 'danger-outline';\n        this.customIcon = this.btnS.getIcon('close').iconString;\n        this.iconBtn.set(true);\n        break;\n      case 'delete':\n        this._type = 'danger-outline';\n        this._icon = 'delete';\n        this.iconBtn.set(true);\n        break;\n      case 'download':\n        this._type = 'secondary';\n        this._icon = 'download';\n        this.iconBtn.set(true);\n        break;\n      case 'edit':\n        this._type = 'secondary';\n        this._icon = 'edit';\n        this.iconBtn.set(true);\n        break;\n      case 'link':\n        this._type = 'secondary';\n        this.customIcon = 'fa fa-eye';\n        this.iconBtn.set(true);\n        break;\n      case 'search':\n        this._type = 'secondary';\n        this._icon = 'search';\n        this.iconBtn.set(true);\n        break;\n      case 'show':\n        this._type = 'secondary';\n        this._icon = 'show';\n        this._text.set('Show');\n        break;\n      case 'submit':\n        this._type = 'secondary';\n        this._icon = 'save';\n        this._text.set('Submit');\n        break;\n      case 'save':\n        this._group = 'submit';\n        break;\n    }\n  }\n  readonly _mclass = signal<string>('');\n  readonly actionType = input<'submit' | 'button' | 'reset'>('button');\n  readonly animate = input(false, { transform: booleanAttribute2 as undefined });\n  @Input({ transform: booleanAttribute2 }) excludeLogging = false;\n  @Input() loggingValue: string;\n  readonly badge = input<string | number>(null);\n  readonly class = input<string>();\n  /**\n   * Sets the left side icon\n   */\n  @Input() set customIcon(v: string) {\n    this.leftCustomIcon.set(v);\n  }\n\n  // formState = computed<IFormState>(() => {\n  //   const d = this.checkFormState();\n\n  //   if (this.debug()) {\n  //     debugger;\n  //   }\n  //   return {\n  //     pending: this.form?.pending,\n  //     dirty: this.form?.dirty,\n  //     invalid: this.form?.invalid,\n  //     pristine: this.form?.pristine,\n  //     valid: this.form?.valid,\n  //   };\n  // });\n  readonly checkFormState$ = new BehaviorSubject<IFormState>({});\n  // protected formSub: Subscription;\n  // protected formsSub: Subscription;\n  readonly form = input<\n    FormGroup<any> | FormControl<any> | FormArray<any> | AbstractControl<any, any>\n  >();\n  protected readonly formState = toSignal(\n    toObservable(this.form).pipe(\n      filter((x) => !!x),\n\n      switchMap((form) =>\n        form.statusChanges.pipe(\n          startWith(\n            this.form()\n              ? <IFormState>{\n                  pending: this.form()?.pending,\n                  dirty: this.form()?.dirty,\n                  invalid: this.form()?.invalid,\n                  pristine: this.form()?.pristine,\n                  valid: this.form()?.valid,\n                  status: this.form()?.status,\n                }\n              : null,\n          ),\n          map(() => {\n            const form = this.form();\n            return form\n              ? <IFormState>{\n                  pending: form.pending,\n                  dirty: form.dirty,\n                  invalid: form.invalid,\n                  pristine: form.pristine,\n                  valid: form.valid,\n                  status: form.status,\n                }\n              : null;\n          }),\n        ),\n      ),\n    ),\n  );\n  readonly forms =\n    input<(FormGroup<any> | AbstractControl<any, any> | FormControl<any> | FormArray<any>)[]>();\n  protected readonly formsState = toSignal(\n    toObservable(this.forms).pipe(\n      filter((x) => !!x && x.length > 0),\n      switchMap((forms) =>\n        merge(...forms.map((form) => form.statusChanges)).pipe(\n          debounceTime(500),\n          map(() => {\n            const forms = this.forms();\n            if (!forms) return null;\n            const fs: Omit<IFormState, 'status'> = {\n              pending: true,\n              dirty: true,\n              invalid: true,\n              pristine: true,\n              valid: true,\n            };\n            forms.forEach((x) => {\n              if (!x.pending) fs.pending = x.pending;\n              if (!x.dirty) fs.dirty = x.dirty;\n              if (!x.invalid) fs.invalid = x.invalid;\n              if (!x.pristine) fs.pristine = x.pristine;\n              if (!x.valid) fs.valid = x.valid;\n            });\n            return fs;\n          }),\n        ),\n      ),\n    ),\n  );\n\n  readonly help = input<string | null | undefined>();\n  /**\n   * @deprecated no longer needed to detect the correct spacing between icon and text\n   */\n  @Input({ transform: booleanAttribute2, alias: 'iconBtn' }) set _iconBtn(v: boolean) {\n    this.iconBtn.set(v || false);\n  }\n\n  readonly mclass = input<string>(null);\n  readonly showHelpIcon = input(true);\n  readonly rightIcon = signal<IconDefinition>(null);\n  @Input({ alias: 'rightCustomIcon' }) set _rightCustomIcon(v: string) {\n    this.rightCustomIcon.set(v);\n  }\n  readonly rightCustomIcon = signal<string>(null);\n  readonly leftIcon = signal<IconDefinition>(null);\n  readonly leftCustomIcon = model<string>(null);\n  readonly text = input<string | null | undefined>();\n  readonly valid = input(true);\n  readonly mini = input<boolean>(false, { transform: booleanAttribute2 as undefined });\n  readonly onFormInvalid = input<keyof typeof OnFormInvalid>(OnFormInvalid.disable);\n  @Output() mclick = new EventEmitter();\n  @ViewChild('innerText') innerText: ElementRef<HTMLSpanElement>;\n  readonly lockedIcon = signal(faLock);\n  protected readonly _text = signal<string | null>(undefined);\n  readonly disabled = model<boolean | null>(false);\n  readonly computedText = computed(() => {\n    const input = this.text(),\n      local = this._text();\n    return input == null ? local : input;\n  });\n  public btnS = inject(BtnService);\n  protected readonly isLeftIcon = computed(() => this.leftIcon() || this.leftCustomIcon());\n  protected readonly isRightIcon = computed(() => this.rightIcon() || this.rightCustomIcon());\n\n  constructor() {\n    effect(() => {\n      const fs = this.formState();\n      if (this.debug()) debugger;\n    });\n  }\n\n  ngAfterViewChecked(): void {\n    //Called after every check of the component's view. Applies to components only.\n    //Add 'implements AfterViewChecked' to the class.\n  }\n\n  ngOnInit(): void {\n    if (!this._mclass()) this._type = this.btnS.defaultType;\n  }\n\n  setLoader(val: boolean) {\n    this.loading.set(val);\n  }\n  get extractText() {\n    return `Clicked on ${\n      this.text() || this.innerText?.nativeElement?.innerHTML || this.iconType || 'button'\n    } ${this.loggingValue ? '\\nTrack value: ' + this.loggingValue : ''}`;\n  }\n  click($event) {\n    // debugger\n    if (this.isDisabled() || this.loading()) return;\n    this.mclick.emit($event);\n    this.btnS.logClick(this);\n  }\n\n  readonly isDisabled = computed(() => {\n    if (this.debug()) debugger;\n    const disabled = this.disabled(),\n      valid = this.valid(),\n      onFormInvalid = this.onFormInvalid(),\n      form = this.formState(),\n      forms = this.formsState();\n    return (\n      disabled ||\n      !valid ||\n      (onFormInvalid == OnFormInvalid.disable &&\n        (form?.invalid || form?.pending || forms?.pending)) ||\n      false\n    );\n  });\n\n  disable() {\n    this.disabled.set(true);\n  }\n\n  enable() {\n    this.disabled.set(false);\n  }\n}\nenum OnFormInvalid {\n  disable = 'disable',\n  warn = 'warn',\n}\ninterface IFormState {\n  pending?: boolean;\n  dirty?: boolean;\n  invalid?: boolean;\n  pristine?: boolean;\n  valid?: boolean;\n  status?: FormControlStatus;\n}\n","@if (verbose()) {\n <div class=\"\">\n  formState():{{formState()|json}}\n </div>\n <div class=\"\">\n  form():{{form()?.value|json}}\n </div>\n}\n<span\n  class=\"{{ class() }}  d-flex  align-items-center justify-content-center\"\n  [ngClass]=\"{ disabled: isDisabled(), mini: mini() }\"\n  (click)=\"btnS.checkForm(this)\">\n  @if (showHelpIcon() && help()) {\n    <i class=\"fa fa-info-circle me-2 text-primary\" [matTooltip]=\"help() | appTranslate | async\"></i>\n  }\n  <button\n    type=\"{{ actionType() }}\"\n    class=\"{{ mclass() }} {{ _mclass() || 'btn' }} d-flex align-items-center \"\n    [matBadge]=\"badge()\"\n    [ngClass]=\"{\n      changecolor: valid(),\n      'btn-raised': animate(),\n      disabled: isDisabled(),\n      isDanger: danger(),\n      isWarning: warning(),\n      invalid: formIsInvalid(),\n      'justify-content-center': centerBtn()\n    }\"\n    [disabled]=\"isDisabled()\"\n    (click)=\"click($event)\"\n    [matTooltip]=\"showHelpIcon() ? null : (help() | appTranslate | async)\">\n    @if (!loading()) {\n      @if (isLeftIcon()) {\n        @if (isDisabled()) {\n          <fa-icon [icon]=\"lockedIcon()\" />\n        } @else if (leftCustomIcon()) {\n          <i class=\"{{ leftCustomIcon() }}\"></i>\n        } @else {\n          <fa-icon [icon]=\"leftIcon()\" />\n        }\n      }\n    }\n\n    @if (computedText()) {\n      <span\n        class=\"\"\n        [ngClass]=\"{\n          'ms-1': leftIcon() || leftCustomIcon(),\n          'me-1': rightIcon() || rightCustomIcon()\n        }\">\n        {{ computedText() | appTranslate | async }}\n      </span>\n    } @else {\n      <span\n        class=\" \"\n        [ngClass]=\"{\n          'ms-1': innerText.innerText && (leftIcon() || leftCustomIcon()),\n          'me-1': innerText.innerText && (rightIcon() || rightCustomIcon())\n        }\"\n        #innerText\n        appTranslator>\n        <ng-content></ng-content>\n      </span>\n    }\n\n    @if (loading()) {\n      <span class=\"fa fa-spinner ms-{{ iconBtn() ? '' : '2' }} fa-spin\"></span>\n    } @else {\n      @if (isRightIcon()) {\n        @if (isDisabled()) {\n          <fa-icon [icon]=\"lockedIcon()\" />\n        } @else if (rightCustomIcon()) {\n          <i class=\"{{ rightCustomIcon() }}\"></i>\n        } @else {\n          <fa-icon [icon]=\"rightIcon()\" />\n        }\n      }\n    }\n  </button>\n</span>\n"]}
342
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"btn.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/btn/btn.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/btn/btn.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n  booleanAttribute,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n} from '@angular/core';\nimport {\n  FormControl,\n  FormGroup,\n  FormArray,\n  AbstractControl,\n  FormControlStatus,\n} from '@angular/forms';\nimport { IconDefinition, faLock } from '@fortawesome/free-solid-svg-icons';\nimport { BtnService } from './btn.service';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { TranslatorDirective } from '../../directives/translator.directive';\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\nimport { MatBadgeModule } from '@angular/material/badge';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { NgClass, NgIf, AsyncPipe, JsonPipe } from '@angular/common';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport { IconType, BtnType, BtnGroup } from './btn.model';\nimport { isEqual } from 'lodash-es';\nimport { BehaviorSubject, debounceTime, filter, map, merge, of, startWith, switchMap } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\nfunction booleanAttribute2(value: string | boolean | undefined) {\n  return booleanAttribute(value);\n}\n@Component({\n  selector: 'app-btn',\n  templateUrl: './btn.component.html',\n  styleUrls: ['./btn.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  // //\n  imports: [\n    NgClass,\n    NgIf,\n    MatTooltipModule,\n    MatBadgeModule,\n    FontAwesomeModule,\n    JsonPipe,\n    TranslatorDirective,\n    AsyncPipe,\n    SDKTranslatePipe,\n  ],\n}) // Inherited\nexport class BtnComponent implements OnInit {\n  /** To be passed when to check for specific invalid form fields */\n  readonly formSchema = input<IFormSchema[]>();\n  readonly debug = input<boolean>();\n  readonly formIsInvalid = computed<boolean>(\n    () => {\n      const formState = this.formState(),\n        form = this.form(),\n        onFormInvalid = this.onFormInvalid(),\n        formSchema = this.formSchema();\n\n      return formState &&\n        formState.invalid &&\n        onFormInvalid == OnFormInvalid.warn &&\n        formSchema?.length\n        ? formSchema.some((f) => (<FormGroup>form).controls[f.field?.toString()]?.invalid)\n        : null;\n    },\n    { equal: isEqual },\n  );\n  readonly centerBtn = input<boolean>(true);\n  readonly danger = input<boolean>();\n  readonly warning = input<boolean>();\n  readonly verbose = input<boolean>();\n  // counter = signal(0);\n\n  protected iconType: IconType;\n  readonly iconBtn = signal<boolean>(false);\n  readonly loading = model<boolean>(false);\n\n  @Input('icon') set _icon(v: IconType) {\n    this.iconType = v;\n    const res = this.btnS.getIcon(v);\n    if (!res) return;\n    if (res.iconPosition == 'right') {\n      this.rightIcon.set(res.icon);\n      this.rightCustomIcon.set(res.iconString);\n    } else {\n      this.leftIcon.set(res.icon);\n      this.leftCustomIcon.set(res.iconString);\n    }\n  }\n  @Input('rightIcon') set _rightIcon(v: IconType) {\n    this.iconType = v;\n    const res = this.btnS.getIcon(v);\n    this.rightIcon.set(res.icon);\n    this.rightCustomIcon.set(res.iconString);\n  }\n  @Input('leftIcon') set _leftIcon(v: IconType) {\n    this.iconType = v;\n    const res = this.btnS.getIcon(v);\n    this.leftIcon.set(res.icon);\n    this.leftCustomIcon.set(res.iconString);\n  }\n\n  @Input('type') set _type(v: BtnType) {\n    const { _icon, _mclass, _type } = this.btnS.getType(v);\n    this._mclass.update((mclass) => _mclass || mclass);\n    if (_icon) this._icon = _icon;\n    if (_type) this._type = _type;\n  }\n\n  @Input('group') set _group(v: BtnGroup) {\n    switch (v) {\n      case 'add':\n        this._type = 'outline';\n        this._icon = 'add';\n        this.iconBtn.set(true);\n        break;\n      case 'clone':\n        this._type = 'secondary';\n        this._icon = 'clone';\n        this._text.set('Clone');\n        break;\n      case 'create':\n        this._type = 'outline';\n        this._icon = 'add';\n        this._text.set('Create');\n        break;\n      case 'close':\n        this._type = 'danger-outline';\n        this.customIcon = this.btnS.getIcon('close').iconString;\n        this.iconBtn.set(true);\n        break;\n      case 'delete':\n        this._type = 'danger-outline';\n        this._icon = 'delete';\n        this.iconBtn.set(true);\n        break;\n      case 'download':\n        this._type = 'secondary';\n        this._icon = 'download';\n        this.iconBtn.set(true);\n        break;\n      case 'edit':\n        this._type = 'secondary';\n        this._icon = 'edit';\n        this.iconBtn.set(true);\n        break;\n      case 'link':\n        this._type = 'secondary';\n        this.customIcon = 'fa fa-eye';\n        this.iconBtn.set(true);\n        break;\n      case 'search':\n        this._type = 'secondary';\n        this._icon = 'search';\n        this.iconBtn.set(true);\n        break;\n      case 'show':\n        this._type = 'secondary';\n        this._icon = 'show';\n        this._text.set('Show');\n        break;\n      case 'submit':\n        this._type = 'secondary';\n        this._icon = 'save';\n        this._text.set('Submit');\n        break;\n      case 'save':\n        this._group = 'submit';\n        break;\n    }\n  }\n  readonly _mclass = signal<string>('');\n  readonly actionType = input<'submit' | 'button' | 'reset'>('button');\n  readonly animate = input(false, { transform: booleanAttribute2 as undefined });\n  @Input({ transform: booleanAttribute2 }) excludeLogging = false;\n  @Input() loggingValue: string;\n  readonly badge = input<string | number>(null);\n  readonly class = input<string>();\n  /**\n   * Sets the left side icon\n   */\n  @Input() set customIcon(v: string) {\n    this.leftCustomIcon.set(v);\n  }\n\n  // formState = computed<IFormState>(() => {\n  //   const d = this.checkFormState();\n\n  //   if (this.debug()) {\n  //     debugger;\n  //   }\n  //   return {\n  //     pending: this.form?.pending,\n  //     dirty: this.form?.dirty,\n  //     invalid: this.form?.invalid,\n  //     pristine: this.form?.pristine,\n  //     valid: this.form?.valid,\n  //   };\n  // });\n  readonly checkFormState$ = new BehaviorSubject<IFormState>({});\n  // protected formSub: Subscription;\n  // protected formsSub: Subscription;\n  readonly form = input<\n    FormGroup<any> | FormControl<any> | FormArray<any> | AbstractControl<any, any>\n  >();\n  protected readonly formState = toSignal(\n    toObservable(this.form).pipe(\n      filter((x) => !!x),\n      switchMap((form) =>\n        form.statusChanges.pipe(\n          startWith(\n            this.form()\n              ? <IFormState>{\n                  pending: this.form()?.pending,\n                  dirty: this.form()?.dirty,\n                  invalid: this.form()?.invalid,\n                  pristine: this.form()?.pristine,\n                  valid: this.form()?.valid,\n                  status: this.form()?.status,\n                }\n              : null,\n          ),\n          map(() => {\n            const form = this.form();\n            return form\n              ? <IFormState>{\n                  pending: form.pending,\n                  dirty: form.dirty,\n                  invalid: form.invalid,\n                  pristine: form.pristine,\n                  valid: form.valid,\n                  status: form.status,\n                }\n              : null;\n          }),\n        ),\n      ),\n    ),\n  );\n  readonly forms =\n    input<(FormGroup<any> | AbstractControl<any, any> | FormControl<any> | FormArray<any>)[]>();\n  protected readonly formsState = toSignal(\n    toObservable(this.forms).pipe(\n      filter((x) => !!x && x.length > 0),\n      switchMap((forms) =>\n        merge(...forms.map((form) => form.statusChanges)).pipe(\n          debounceTime(500),\n          map(() => {\n            const forms = this.forms();\n            if (!forms) return null;\n            const fs: Omit<IFormState, 'status'> = {\n              pending: true,\n              dirty: true,\n              invalid: true,\n              pristine: true,\n              valid: true,\n            };\n            forms.forEach((x) => {\n              if (!x.pending) fs.pending = x.pending;\n              if (!x.dirty) fs.dirty = x.dirty;\n              if (!x.invalid) fs.invalid = x.invalid;\n              if (!x.pristine) fs.pristine = x.pristine;\n              if (!x.valid) fs.valid = x.valid;\n            });\n            return fs;\n          }),\n        ),\n      ),\n    ),\n  );\n\n  readonly help = input<string | null | undefined>();\n  /**\n   * @deprecated no longer needed to detect the correct spacing between icon and text\n   */\n  @Input({ transform: booleanAttribute2, alias: 'iconBtn' }) set _iconBtn(v: boolean) {\n    this.iconBtn.set(v || false);\n  }\n\n  readonly mclass = input<string>(null);\n  readonly showHelpIcon = input(true);\n  readonly rightIcon = signal<IconDefinition>(null);\n  @Input({ alias: 'rightCustomIcon' }) set _rightCustomIcon(v: string) {\n    this.rightCustomIcon.set(v);\n  }\n  readonly rightCustomIcon = signal<string>(null);\n  readonly leftIcon = signal<IconDefinition>(null);\n  readonly leftCustomIcon = model<string>(null);\n  readonly text = input<string | null | undefined>();\n  readonly valid = input(true);\n  readonly mini = input<boolean>(false, { transform: booleanAttribute2 as undefined });\n  readonly onFormInvalid = input<keyof typeof OnFormInvalid>(OnFormInvalid.disable);\n  @Output() mclick = new EventEmitter();\n  @ViewChild('innerText') innerText: ElementRef<HTMLSpanElement>;\n  readonly lockedIcon = signal(faLock);\n  protected readonly _text = signal<string | null>(undefined);\n  readonly disabled = model<boolean | null>(false);\n  readonly computedText = computed(() => {\n    const input = this.text(),\n      local = this._text();\n    return input == null ? local : input;\n  });\n  public btnS = inject(BtnService);\n  protected readonly isLeftIcon = computed(() => this.leftIcon() || this.leftCustomIcon());\n  protected readonly isRightIcon = computed(() => this.rightIcon() || this.rightCustomIcon());\n\n  constructor() {\n    effect(() => {\n      const fs = this.formState();\n      if (this.debug()) debugger;\n    });\n  }\n\n  ngAfterViewChecked(): void {\n    //Called after every check of the component's view. Applies to components only.\n    //Add 'implements AfterViewChecked' to the class.\n  }\n\n  ngOnInit(): void {\n    if (!this._mclass()) this._type = this.btnS.defaultType;\n  }\n\n  setLoader(val: boolean) {\n    this.loading.set(val);\n  }\n  get extractText() {\n    return `Clicked on ${\n      this.text() || this.innerText?.nativeElement?.innerHTML || this.iconType || 'button'\n    } ${this.loggingValue ? '\\nTrack value: ' + this.loggingValue : ''}`;\n  }\n  click($event) {\n    // debugger\n    if (this.isDisabled() || this.loading()) return;\n    this.mclick.emit($event);\n    this.btnS.logClick(this);\n  }\n\n  readonly isDisabled = computed(() => {\n    if (this.debug()) debugger;\n    const disabled = this.disabled(),\n      valid = this.valid(),\n      onFormInvalid = this.onFormInvalid(),\n      form = this.formState(),\n      forms = this.formsState();\n    return (\n      disabled ||\n      !valid ||\n      (onFormInvalid == OnFormInvalid.disable &&\n        (form?.invalid || form?.pending || forms?.pending)) ||\n      false\n    );\n  });\n\n  disable() {\n    this.disabled.set(true);\n  }\n\n  enable() {\n    this.disabled.set(false);\n  }\n}\nenum OnFormInvalid {\n  disable = 'disable',\n  warn = 'warn',\n}\ninterface IFormState {\n  pending?: boolean;\n  dirty?: boolean;\n  invalid?: boolean;\n  pristine?: boolean;\n  valid?: boolean;\n  status?: FormControlStatus;\n}\n","@if (verbose()) {\n <div class=\"\">\n  formState():{{formState()|json}}\n </div>\n <div class=\"\">\n  form():{{form()?.value|json}}\n </div>\n}\n<span\n  class=\"{{ class() }}  d-flex  align-items-center justify-content-center\"\n  [ngClass]=\"{ disabled: isDisabled(), mini: mini() }\"\n  (click)=\"btnS.checkForm(this)\">\n  @if (showHelpIcon() && help()) {\n    <i class=\"fa fa-info-circle me-2 text-primary\" [matTooltip]=\"help() | appTranslate | async\"></i>\n  }\n  <button\n    type=\"{{ actionType() }}\"\n    class=\"{{ mclass() }} {{ _mclass() || 'btn' }} d-flex align-items-center \"\n    [matBadge]=\"badge()\"\n    [ngClass]=\"{\n      changecolor: valid(),\n      'btn-raised': animate(),\n      disabled: isDisabled(),\n      isDanger: danger(),\n      isWarning: warning(),\n      invalid: formIsInvalid(),\n      'justify-content-center': centerBtn()\n    }\"\n    [disabled]=\"isDisabled()\"\n    (click)=\"click($event)\"\n    [matTooltip]=\"showHelpIcon() ? null : (help() | appTranslate | async)\">\n    @if (!loading()) {\n      @if (isLeftIcon()) {\n        @if (isDisabled()) {\n          <fa-icon [icon]=\"lockedIcon()\" />\n        } @else if (leftCustomIcon()) {\n          <i class=\"{{ leftCustomIcon() }}\"></i>\n        } @else {\n          <fa-icon [icon]=\"leftIcon()\" />\n        }\n      }\n    }\n\n    @if (computedText()) {\n      <span\n        class=\"\"\n        [ngClass]=\"{\n          'ms-1': leftIcon() || leftCustomIcon(),\n          'me-1': rightIcon() || rightCustomIcon()\n        }\">\n        {{ computedText() | appTranslate | async }}\n      </span>\n    } @else {\n      <span\n        class=\" \"\n        [ngClass]=\"{\n          'ms-1': innerText.innerText && (leftIcon() || leftCustomIcon()),\n          'me-1': innerText.innerText && (rightIcon() || rightCustomIcon())\n        }\"\n        #innerText\n        appTranslator>\n        <ng-content></ng-content>\n      </span>\n    }\n\n    @if (loading()) {\n      <span class=\"fa fa-spinner ms-{{ iconBtn() ? '' : '2' }} fa-spin\"></span>\n    } @else {\n      @if (isRightIcon()) {\n        @if (isDisabled()) {\n          <fa-icon [icon]=\"lockedIcon()\" />\n        } @else if (rightCustomIcon()) {\n          <i class=\"{{ rightCustomIcon() }}\"></i>\n        } @else {\n          <fa-icon [icon]=\"rightIcon()\" />\n        }\n      }\n    }\n  </button>\n</span>\n"]}
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, Component, DestroyRef, computed, effect, inject, model, signal, } from '@angular/core';
1
+ import { ChangeDetectorRef, Component, DestroyRef, computed, inject, model, signal, } from '@angular/core';
2
2
  import { UtilityService } from '../../../Services/utility.service';
3
3
  import { TableService } from '../table-plain/table-plain.service';
4
4
  import * as i0 from "@angular/core";
@@ -21,9 +21,6 @@ export class BaseFormGenerator {
21
21
  this.destroyRef = inject(DestroyRef);
22
22
  this.cdr = inject(ChangeDetectorRef);
23
23
  this.useCustomLabels = model(true);
24
- effect(() => {
25
- console.log('formschema update', this.formSchema(), this.formSchemaMap());
26
- });
27
24
  this.destroyRef.onDestroy(() => {
28
25
  this.onDestroy();
29
26
  });
@@ -82,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
82
79
  template: '',
83
80
  }]
84
81
  }], ctorParameters: () => [] });
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  computed,\n  effect,\n  inject,\n  model,\n  signal,\n} from '@angular/core';\nimport { AbstractControl, AsyncValidatorFn, FormGroup, ValidatorFn } from '@angular/forms';\nimport { OptionLabelType } from '../input/input-basic.component';\nimport { Observable, Subscription } from 'rxjs';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { IObjectLiteral, InputType } from '../../models/index.model';\nimport { IconType } from '../btn/btn.model';\nimport { TableService } from '../table-plain/table-plain.service';\n\n@Component({\n  template: '',\n})\nexport abstract class BaseFormGenerator<\n  TFormGroup extends IObjectLiteral,\n  TBaseFormSchema extends { field?: any; label?: string; _id?: string } = any,\n> {\n  public readonly tableService = inject(TableService);\n  protected _formSchemaMap = signal<{ [field: string]: TBaseFormSchema }>({});\n  protected formSchemaMap = computed(() => this._formSchemaMap());\n  readonly formSchema = computed<TBaseFormSchema[]>(() => {\n    const res = Object.values(this.formSchemaMap()).filter((x) => x);\n    return (\n      this.useCustomLabels()\n        ? res.map((f) => ({\n            ...f,\n            label: f.label ? this.tableService.customLabelMap[f.field] || f.label : f.label,\n          }))\n        : res\n    ).filter((x) => !!x);\n  });\n  subs: { [fieldName: string]: Subscription } = {};\n\n  public utilityService = inject(UtilityService);\n  public destroyRef = inject(DestroyRef);\n  public cdr = inject(ChangeDetectorRef);\n\n  readonly useCustomLabels = model(true);\n\n  constructor() {\n    effect(() => {\n      console.log('formschema update', this.formSchema(), this.formSchemaMap());\n    });\n    this.destroyRef.onDestroy(() => {\n      this.onDestroy();\n    });\n  }\n\n  onDestroy() {\n    Object.values(this.subs).forEach((s) => {\n      s?.unsubscribe();\n    });\n    this.subs = {};\n  }\n\n  protected _setFormSchemas(schemas: TBaseFormSchema[]) {\n    const obj: { [field: string]: TBaseFormSchema } = {};\n    for (const f of schemas || [])\n      if (f) obj[f.field] = { ...f, _id: this.utilityService.generateUUID() };\n\n    this._formSchemaMap.set(obj);\n  }\n\n  protected _updateFormSchema(field: string, scheme: Partial<TBaseFormSchema>) {\n    if (!scheme || !Object.keys(scheme).length) return;\n    this._formSchemaMap.update((formSchemaMap) => {\n      const existing = formSchemaMap[field];\n      return {\n        ...formSchemaMap,\n        [field as any]: !existing\n          ? { ...scheme, _id: this.utilityService.generateUUID() }\n          : { ...existing, ...scheme, _id: existing._id || this.utilityService.generateUUID() },\n      };\n    });\n  }\n\n  protected _updateAllFormSchema(map: (formField: TBaseFormSchema) => TBaseFormSchema) {\n    this._formSchemaMap.update((formSchemaMap) => {\n      const newFormSchemaMap: typeof formSchemaMap = {};\n      for (const key in formSchemaMap)\n        if (Object.prototype.hasOwnProperty.call(formSchemaMap, key))\n          newFormSchemaMap[key] = {\n            ...map(formSchemaMap[key]),\n            _id: newFormSchemaMap[key]?._id || this.utilityService.generateUUID(),\n          };\n      return newFormSchemaMap;\n    });\n    return this.formSchema();\n  }\n\n  protected _removeFormSchema(field: string) {\n    this._formSchemaMap.update((formSchemaMap) => {\n      delete formSchemaMap[field];\n      return formSchemaMap;\n    });\n  }\n}\n\nexport interface IBaseFormSchema<\n  T,\n  Component extends BaseFormGenerator<T>,\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> {\n  asyncValidators?: AsyncValidatorFn[];\n  autoPickValueField?: boolean;\n  checked?: boolean;\n  clearOnDisable?: boolean;\n  cls?: string;\n  countryCode3?: string;\n  children?: IBaseFormSchema<T, Component, TFormGroup>[];\n  decimalPoints?: number;\n  disabled?: boolean;\n  disabledIf?: (row: any, cellField?: string) => boolean;\n  // hideIfFunc?: (row) => boolean;\n  field: keyof TFormGroup;\n  form?: FormGroup<TFormGroup>;\n  getCountryCode3Key?: string;\n  hidden?: boolean;\n  hint?: string;\n  id?: string;\n  _id?: string;\n  isRequired?: boolean;\n  isSearchField?: boolean;\n  label?: string;\n  labelField?: string;\n  labelType?: OptionLabelType;\n  optionLabelFormatter?: (row) => string;\n  max?: number;\n  min?: number;\n  minLength?: number;\n  maxLength?: number;\n  noFormat?: boolean;\n  optionFormatter?: (item: any) => string;\n  options?: any[];\n  optionsAsync?: Observable<any[]> | Promise<any[]>;\n  optionsInitFunc?: Observable<any[]>;\n  optionsInitFunc2?: () => Observable<any[]>;\n  optionsKey?: string;\n  placeholder?: string;\n  searchFunc?: (...args) => any;\n  setAsCountryCode3?: boolean;\n  setControlFormattedValue?: boolean;\n  showValidation?: boolean;\n  showValidationIcon?: boolean;\n  templateValue?: any;\n  type?: InputType;\n  validators?: ValidatorFn[];\n  value?: any;\n  valueField?: string;\n  optionsFunc?: (...val: any) => Observable<any[]>;\n  triggerOnChangeOnInit?: boolean;\n  formatter?: (row: { [K in keyof TFormGroup]: any }, fieldName: keyof TFormGroup) => string;\n  extra?: any;\n  onChangeFunc?: (\n    row: { [K in keyof TFormGroup]?: TFormGroup[K]['value'] },\n    cellValue?: any,\n    component?: Component,\n  ) => Observable<any[]> | any;\n  onRemoveFunc?: (\n    row: { [K in keyof TFormGroup]: TFormGroup[K]['value'] },\n    cell?: any,\n    component?: Component,\n  ) => any;\n  selectedOptionLabel?: string;\n  stacked?: boolean;\n  debug?: boolean;\n  showValidationMsg?: boolean;\n  dontFormatAsInput?: boolean;\n  showRequiredTag?: boolean;\n  tableFormatter?: (\n    val: any,\n  ) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  icon?: IconType;\n  verbose?: boolean;\n}\n"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  computed,\n  effect,\n  inject,\n  model,\n  signal,\n} from '@angular/core';\nimport { AbstractControl, AsyncValidatorFn, FormGroup, ValidatorFn } from '@angular/forms';\nimport { OptionLabelType } from '../input/input-basic.component';\nimport { Observable, Subscription } from 'rxjs';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { IObjectLiteral, InputType } from '../../models/index.model';\nimport { IconType } from '../btn/btn.model';\nimport { TableService } from '../table-plain/table-plain.service';\n\n@Component({\n  template: '',\n})\nexport abstract class BaseFormGenerator<\n  TFormGroup extends IObjectLiteral,\n  TBaseFormSchema extends { field?: any; label?: string; _id?: string } = any,\n> {\n  public readonly tableService = inject(TableService);\n  protected _formSchemaMap = signal<{ [field: string]: TBaseFormSchema }>({});\n  protected formSchemaMap = computed(() => this._formSchemaMap());\n  readonly formSchema = computed<TBaseFormSchema[]>(() => {\n    const res = Object.values(this.formSchemaMap()).filter((x) => x);\n    return (\n      this.useCustomLabels()\n        ? res.map((f) => ({\n            ...f,\n            label: f.label ? this.tableService.customLabelMap[f.field] || f.label : f.label,\n          }))\n        : res\n    ).filter((x) => !!x);\n  });\n  subs: { [fieldName: string]: Subscription } = {};\n\n  public utilityService = inject(UtilityService);\n  public destroyRef = inject(DestroyRef);\n  public cdr = inject(ChangeDetectorRef);\n\n  readonly useCustomLabels = model(true);\n\n  constructor() {\n    this.destroyRef.onDestroy(() => {\n      this.onDestroy();\n    });\n  }\n\n  onDestroy() {\n    Object.values(this.subs).forEach((s) => {\n      s?.unsubscribe();\n    });\n    this.subs = {};\n  }\n\n  protected _setFormSchemas(schemas: TBaseFormSchema[]) {\n    const obj: { [field: string]: TBaseFormSchema } = {};\n    for (const f of schemas || [])\n      if (f) obj[f.field] = { ...f, _id: this.utilityService.generateUUID() };\n\n    this._formSchemaMap.set(obj);\n  }\n\n  protected _updateFormSchema(field: string, scheme: Partial<TBaseFormSchema>) {\n    if (!scheme || !Object.keys(scheme).length) return;\n    this._formSchemaMap.update((formSchemaMap) => {\n      const existing = formSchemaMap[field];\n      return {\n        ...formSchemaMap,\n        [field as any]: !existing\n          ? { ...scheme, _id: this.utilityService.generateUUID() }\n          : { ...existing, ...scheme, _id: existing._id || this.utilityService.generateUUID() },\n      };\n    });\n  }\n\n  protected _updateAllFormSchema(map: (formField: TBaseFormSchema) => TBaseFormSchema) {\n    this._formSchemaMap.update((formSchemaMap) => {\n      const newFormSchemaMap: typeof formSchemaMap = {};\n      for (const key in formSchemaMap)\n        if (Object.prototype.hasOwnProperty.call(formSchemaMap, key))\n          newFormSchemaMap[key] = {\n            ...map(formSchemaMap[key]),\n            _id: newFormSchemaMap[key]?._id || this.utilityService.generateUUID(),\n          };\n      return newFormSchemaMap;\n    });\n    return this.formSchema();\n  }\n\n  protected _removeFormSchema(field: string) {\n    this._formSchemaMap.update((formSchemaMap) => {\n      delete formSchemaMap[field];\n      return formSchemaMap;\n    });\n  }\n}\n\nexport interface IBaseFormSchema<\n  T,\n  Component extends BaseFormGenerator<T>,\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> {\n  asyncValidators?: AsyncValidatorFn[];\n  autoPickValueField?: boolean;\n  checked?: boolean;\n  clearOnDisable?: boolean;\n  cls?: string;\n  countryCode3?: string;\n  children?: IBaseFormSchema<T, Component, TFormGroup>[];\n  decimalPoints?: number;\n  disabled?: boolean;\n  disabledIf?: (row: any, cellField?: string) => boolean;\n  // hideIfFunc?: (row) => boolean;\n  field: keyof TFormGroup;\n  form?: FormGroup<TFormGroup>;\n  getCountryCode3Key?: string;\n  hidden?: boolean;\n  hint?: string;\n  id?: string;\n  _id?: string;\n  isRequired?: boolean;\n  isSearchField?: boolean;\n  label?: string;\n  labelField?: string;\n  labelType?: OptionLabelType;\n  optionLabelFormatter?: (row) => string;\n  max?: number;\n  min?: number;\n  minLength?: number;\n  maxLength?: number;\n  noFormat?: boolean;\n  optionFormatter?: (item: any) => string;\n  options?: any[];\n  optionsAsync?: Observable<any[]> | Promise<any[]>;\n  optionsInitFunc?: Observable<any[]>;\n  optionsInitFunc2?: () => Observable<any[]>;\n  optionsKey?: string;\n  placeholder?: string;\n  searchFunc?: (...args) => any;\n  setAsCountryCode3?: boolean;\n  setControlFormattedValue?: boolean;\n  showValidation?: boolean;\n  showValidationIcon?: boolean;\n  templateValue?: any;\n  type?: InputType;\n  validators?: ValidatorFn[];\n  value?: any;\n  valueField?: string;\n  optionsFunc?: (...val: any) => Observable<any[]>;\n  triggerOnChangeOnInit?: boolean;\n  formatter?: (row: { [K in keyof TFormGroup]: any }, fieldName: keyof TFormGroup) => string;\n  extra?: any;\n  onChangeFunc?: (\n    row: { [K in keyof TFormGroup]?: TFormGroup[K]['value'] },\n    cellValue?: any,\n    component?: Component,\n  ) => Observable<any[]> | any;\n  onRemoveFunc?: (\n    row: { [K in keyof TFormGroup]: TFormGroup[K]['value'] },\n    cell?: any,\n    component?: Component,\n  ) => any;\n  selectedOptionLabel?: string;\n  stacked?: boolean;\n  debug?: boolean;\n  showValidationMsg?: boolean;\n  dontFormatAsInput?: boolean;\n  showRequiredTag?: boolean;\n  tableFormatter?: (\n    val: any,\n  ) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  icon?: IconType;\n  verbose?: boolean;\n}\n"]}
@@ -28,6 +28,9 @@ export class TableInputRowComponent extends FormGeneratorComponent {
28
28
  this.isShow = input();
29
29
  this.hideAdd = input();
30
30
  this.actionBtns = input();
31
+ this.formschemaUpdate = effect(() => {
32
+ console.log('formschema update', this.formSchema(), this.formSchemaMap());
33
+ });
31
34
  this.childrenFormSchemaMap = input({});
32
35
  this.isShowEffect = effect(() => {
33
36
  const form = this.form();
@@ -36,7 +39,7 @@ export class TableInputRowComponent extends FormGeneratorComponent {
36
39
  }, { allowSignalWrites: true });
37
40
  }
38
41
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputRowComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
39
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputRowComponent, isStandalone: true, selector: "tr[table-input-row]", inputs: { isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, hideAdd: { classPropertyName: "hideAdd", publicName: "hideAdd", isSignal: true, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, childrenFormSchemaMap: { classPropertyName: "childrenFormSchemaMap", publicName: "childrenFormSchemaMap", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDeleteRowFunc: "onDeleteRowFunc", onAddRowFunc: "onAddRowFunc", onActionButtonClick: "onActionButtonClick" }, usesInheritance: true, ngImport: i0, template: "@for (scheme of formSchema(); track scheme._id) {\n @switch (true) {\n @case (scheme.type == 'tel') {\n <td class=\"{{ scheme.cls }}\">\n <app-phone-number\n [form]=\"form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n [showValidationMsg]=\"true\"\n [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"\n #inputTag></app-phone-number>\n </td>\n }\n @case (scheme.type == 'autocomplete') {\n <td class=\"{{ scheme.cls }}\">\n <app-autocomplete\n [form]=\"form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [labelField]=\"scheme.labelField\"\n [noFormat]=\"scheme.noFormat\"\n [labelType]=\"scheme.labelType | toAny\"\n [showValidationMsg]=\"true\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field | toAny\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [debug]=\"scheme.debug\"\n [optionFormatter]=\"scheme.optionFormatter\"\n [valueField]=\"scheme.valueField\"\n [options]=\"scheme.options || optionsMap[scheme.field | toAny]\"\n [hint]=\"scheme.hint\"\n [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"\n #inputTag></app-autocomplete>\n </td>\n }\n @case (scheme.type == 'button') {\n <td class=\"{{ scheme.cls }} w-1\">\n <div class=\"d-flex\">\n <app-btn\n [text]=\"scheme.label\"\n [type]=\"\n (form() | hasFormValue: (childrenFormSchemaMap()[scheme.field].formSchemaStr | toAny) : (formValue()))\n ? 'primary'\n : 'secondary'\n \"\n onFormInvalid=\"warn\"\n [form]=\"form()\"\n [icon]=\"scheme.icon\"\n [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n [matTooltip]=\"formValue() | formValue: childrenFormSchemaMap()[scheme.field].formSchema | toAny\"\n (mclick)=\"dModal.open()\" />\n </div>\n <modal-comp #dModal [showFooter]=\"false\" header=\"{{ scheme.label }} Form\" width=\"70%\">\n <ng-template modalBody>\n <form-generator\n [form]=\"form()\"\n [gridXXLStyle]=\"4\"\n [gridLGStyle]=\"4\"\n [showSubmitBtn]=\"false\"\n [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n (onSubmit)=\"dModal.close()\"></form-generator>\n @if (!isShow()) {\n <div class=\"d-flex justify-content-end\">\n <app-btn (mclick)=\"dModal.close()\" text=\"Done\" />\n </div>\n }\n </ng-template>\n </modal-comp>\n </td>\n }\n @default {\n <td class=\"{{ scheme.cls }}\">\n <app-input-basic\n #formField\n [name]=\"scheme.field | toAny\"\n [form]=\"form()\"\n [dontFormatAsInput]=\"scheme.dontFormatAsInput\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [type]=\"scheme.type\"\n [valueField]=\"scheme.valueField\"\n [labelType]=\"scheme.labelType | toAny\"\n [showValidationMsg]=\"true\"\n [checkedSignal]=\"scheme.checked\"\n [showValidation]=\"!!scheme.asyncValidators\"\n [noFormat]=\"scheme.noFormat\"\n [showValidationIcon]=\"!!scheme.asyncValidators\"\n [debug]=\"scheme.debug\"\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 [placeholder]=\"scheme.placeholder\"\n [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"></app-input-basic>\n </td>\n }\n }\n}\n@if (!isShow()) {\n @if (onDeleteRowFunc) {\n <td class=\"w-1\">\n <app-btn group=\"delete\" [iconBtn]=\"true\" (mclick)=\"onDeleteRowFunc.emit({ btn: deleteBtn })\" #deleteBtn />\n </td>\n }\n @if (onAddRowFunc) {\n <td class=\"w-1\">\n <app-btn [iconBtn]=\"true\" group=\"add\" [disabled]=\"hideAdd()\" (mclick)=\"onAddRowFunc.emit({ btn: addBtn })\" #addBtn></app-btn>\n </td>\n }\n @for (actionBtn of actionBtns(); track actionBtn.icon) {\n <td class=\"w-1\">\n <app-btn\n [iconBtn]=\"true\"\n [group]=\"actionBtn.group\"\n [icon]=\"actionBtn.icon\"\n (mclick)=\"\n onActionButtonClick.emit({\n btn: actionBtnTemp,\n actionButton: actionBtn\n })\n \"\n #actionBtnTemp></app-btn>\n </td>\n }\n}\n", styles: [""], dependencies: [{ kind: "component", type: AutocompleteComponent, selector: "app-autocomplete,autocomplete", inputs: ["showRequiredTag", "validate", "options"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "component", type: FormGeneratorComponent, selector: "form-generator", inputs: ["keyField", "presetValueForSingleOption", "isCreate", "submitOnEnterKey", "submitFunc", "submitBtnText", "submitBtnTemplate", "submitSuccessText", "showSubmitBtn", "gridStyle", "gridMDStyle", "gridLGStyle", "gridXXLStyle", "formGridClass", "useLoader", "loading", "form", "formSchema", "formSchemaNoForm", "isShow"], outputs: ["onSubmit", "mchange", "saved", "formChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "pipe", type: FormValuePipe, name: "formValue" }, { kind: "pipe", type: FunctionCaller2, name: "functionCaller2" }, { kind: "pipe", type: HasFormValuePipe, name: "hasFormValue" }, { kind: "component", type: InputBasicComponent, selector: "app-input-basic,app-input", inputs: ["accept", "autocomplete", "input", "contextData", "decimalPoints", "files", "hide", "hint", "clearOnDisable", "labelLink", "lblCl", "light", "loading", "multiple", "optionsFunc", "theme", "vms", "xsmall", "setCurrentDate", "options"], outputs: ["mSelectedOptionLabel"] }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i1.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i2.ModalComponent, selector: "modal-comp", inputs: ["header", "bodyTemplateRef", "footerTemplateRef", "showHeader", "loading", "isFullscreen", "showFooter", "width", "minWidth", "height", "maxHeight", "icon", "data", "disableClose", "hasBackdrop"], outputs: ["headerChange", "showHeaderChange", "loadingChange", "showFooterChange", "modalOpen", "modalClose"] }, { kind: "directive", type: i3.ModalBodyDirective, selector: "[modalBody]" }, { kind: "component", type: PhoneNumberComponent, selector: "app-phone-number", inputs: ["showLabel", "countryCode3", "config"], outputs: ["onCountrySelect"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }] }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: TableInputRowComponent, isStandalone: true, selector: "tr[table-input-row]", inputs: { isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, hideAdd: { classPropertyName: "hideAdd", publicName: "hideAdd", isSignal: true, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, childrenFormSchemaMap: { classPropertyName: "childrenFormSchemaMap", publicName: "childrenFormSchemaMap", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDeleteRowFunc: "onDeleteRowFunc", onAddRowFunc: "onAddRowFunc", onActionButtonClick: "onActionButtonClick" }, usesInheritance: true, ngImport: i0, template: "@for (scheme of formSchema(); track scheme._id) {\n @if (scheme.type == 'button') {\n <td class=\"{{ scheme.cls }} w-1\">\n <div class=\"d-flex\">\n <app-btn\n [text]=\"scheme.label\"\n [type]=\"\n (form()\n | hasFormValue\n : (childrenFormSchemaMap()[scheme.field].formSchemaStr | toAny)\n : formValue())\n ? 'primary'\n : 'secondary'\n \"\n onFormInvalid=\"warn\"\n [form]=\"form()\"\n [icon]=\"scheme.icon\"\n [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n [matTooltip]=\"\n formValue() | formValue: childrenFormSchemaMap()[scheme.field].formSchema | toAny\n \"\n (mclick)=\"dModal.open()\" />\n </div>\n <modal-comp #dModal [showFooter]=\"false\" header=\"{{ scheme.label }} Form\" width=\"70%\">\n <ng-template modalBody>\n <form-generator\n [form]=\"form()\"\n [gridXXLStyle]=\"4\"\n [gridLGStyle]=\"4\"\n [showSubmitBtn]=\"false\"\n [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n (onSubmit)=\"dModal.close()\"></form-generator>\n @if (!isShow()) {\n <div class=\"d-flex justify-content-end\">\n <app-btn (mclick)=\"dModal.close()\" text=\"Done\" />\n </div>\n }\n </ng-template>\n </modal-comp>\n </td>\n } @else if (scheme.field) {\n @switch (true) {\n @case (scheme.type == 'tel') {\n <td class=\"{{ scheme.cls }}\">\n <app-phone-number\n [form]=\"form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n [showValidationMsg]=\"true\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \"\n #inputTag></app-phone-number>\n </td>\n }\n @case (scheme.type == 'autocomplete') {\n <td class=\"{{ scheme.cls }}\">\n <app-autocomplete\n [form]=\"form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [labelField]=\"scheme.labelField\"\n [noFormat]=\"scheme.noFormat\"\n [labelType]=\"scheme.labelType | toAny\"\n [showValidationMsg]=\"true\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field | toAny\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [debug]=\"scheme.debug\"\n [optionFormatter]=\"scheme.optionFormatter\"\n [valueField]=\"scheme.valueField\"\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 #inputTag></app-autocomplete>\n </td>\n }\n\n @default {\n <td class=\"{{ scheme.cls }}\">\n <app-input-basic\n #formField\n [name]=\"scheme.field | toAny\"\n [form]=\"form()\"\n [dontFormatAsInput]=\"scheme.dontFormatAsInput\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [type]=\"scheme.type\"\n [valueField]=\"scheme.valueField\"\n [labelType]=\"scheme.labelType | toAny\"\n [showValidationMsg]=\"true\"\n [checkedSignal]=\"scheme.checked\"\n [showValidation]=\"!!scheme.asyncValidators\"\n [noFormat]=\"scheme.noFormat\"\n [showValidationIcon]=\"!!scheme.asyncValidators\"\n [debug]=\"scheme.debug\"\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 [placeholder]=\"scheme.placeholder\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \"></app-input-basic>\n </td>\n }\n }\n }\n}\n@if (!isShow()) {\n @if (onDeleteRowFunc) {\n <td class=\"w-1\">\n <app-btn\n group=\"delete\"\n [iconBtn]=\"true\"\n (mclick)=\"onDeleteRowFunc.emit({ btn: deleteBtn })\"\n #deleteBtn />\n </td>\n }\n @if (onAddRowFunc) {\n <td class=\"w-1\">\n <app-btn\n [iconBtn]=\"true\"\n group=\"add\"\n [disabled]=\"hideAdd()\"\n (mclick)=\"onAddRowFunc.emit({ btn: addBtn })\"\n #addBtn></app-btn>\n </td>\n }\n @for (actionBtn of actionBtns(); track actionBtn.icon) {\n <td class=\"w-1\">\n <app-btn\n [iconBtn]=\"true\"\n [group]=\"actionBtn.group\"\n [icon]=\"actionBtn.icon\"\n (mclick)=\"\n onActionButtonClick.emit({\n btn: actionBtnTemp,\n actionButton: actionBtn\n })\n \"\n #actionBtnTemp></app-btn>\n </td>\n }\n}\n", styles: [""], dependencies: [{ kind: "component", type: AutocompleteComponent, selector: "app-autocomplete,autocomplete", inputs: ["showRequiredTag", "validate", "options"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "component", type: FormGeneratorComponent, selector: "form-generator", inputs: ["keyField", "presetValueForSingleOption", "isCreate", "submitOnEnterKey", "submitFunc", "submitBtnText", "submitBtnTemplate", "submitSuccessText", "showSubmitBtn", "gridStyle", "gridMDStyle", "gridLGStyle", "gridXXLStyle", "formGridClass", "useLoader", "loading", "form", "formSchema", "formSchemaNoForm", "isShow"], outputs: ["onSubmit", "mchange", "saved", "formChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "pipe", type: FormValuePipe, name: "formValue" }, { kind: "pipe", type: FunctionCaller2, name: "functionCaller2" }, { kind: "pipe", type: HasFormValuePipe, name: "hasFormValue" }, { kind: "component", type: InputBasicComponent, selector: "app-input-basic,app-input", inputs: ["accept", "autocomplete", "input", "contextData", "decimalPoints", "files", "hide", "hint", "clearOnDisable", "labelLink", "lblCl", "light", "loading", "multiple", "optionsFunc", "theme", "vms", "xsmall", "setCurrentDate", "options"], outputs: ["mSelectedOptionLabel"] }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i1.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i2.ModalComponent, selector: "modal-comp", inputs: ["header", "bodyTemplateRef", "footerTemplateRef", "showHeader", "loading", "isFullscreen", "showFooter", "width", "minWidth", "height", "maxHeight", "icon", "data", "disableClose", "hasBackdrop"], outputs: ["headerChange", "showHeaderChange", "loadingChange", "showFooterChange", "modalOpen", "modalClose"] }, { kind: "directive", type: i3.ModalBodyDirective, selector: "[modalBody]" }, { kind: "component", type: PhoneNumberComponent, selector: "app-phone-number", inputs: ["showLabel", "countryCode3", "config"], outputs: ["onCountrySelect"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }] }); }
40
43
  }
41
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableInputRowComponent, decorators: [{
42
45
  type: Component,
@@ -69,7 +72,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
69
72
  ToAnyPipe,
70
73
  SDKTranslatePipe,
71
74
  ValidationMessageComponent,
72
- ], template: "@for (scheme of formSchema(); track scheme._id) {\n @switch (true) {\n @case (scheme.type == 'tel') {\n <td class=\"{{ scheme.cls }}\">\n <app-phone-number\n [form]=\"form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n [showValidationMsg]=\"true\"\n [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"\n #inputTag></app-phone-number>\n </td>\n }\n @case (scheme.type == 'autocomplete') {\n <td class=\"{{ scheme.cls }}\">\n <app-autocomplete\n [form]=\"form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [labelField]=\"scheme.labelField\"\n [noFormat]=\"scheme.noFormat\"\n [labelType]=\"scheme.labelType | toAny\"\n [showValidationMsg]=\"true\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field | toAny\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [debug]=\"scheme.debug\"\n [optionFormatter]=\"scheme.optionFormatter\"\n [valueField]=\"scheme.valueField\"\n [options]=\"scheme.options || optionsMap[scheme.field | toAny]\"\n [hint]=\"scheme.hint\"\n [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"\n #inputTag></app-autocomplete>\n </td>\n }\n @case (scheme.type == 'button') {\n <td class=\"{{ scheme.cls }} w-1\">\n <div class=\"d-flex\">\n <app-btn\n [text]=\"scheme.label\"\n [type]=\"\n (form() | hasFormValue: (childrenFormSchemaMap()[scheme.field].formSchemaStr | toAny) : (formValue()))\n ? 'primary'\n : 'secondary'\n \"\n onFormInvalid=\"warn\"\n [form]=\"form()\"\n [icon]=\"scheme.icon\"\n [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n [matTooltip]=\"formValue() | formValue: childrenFormSchemaMap()[scheme.field].formSchema | toAny\"\n (mclick)=\"dModal.open()\" />\n </div>\n <modal-comp #dModal [showFooter]=\"false\" header=\"{{ scheme.label }} Form\" width=\"70%\">\n <ng-template modalBody>\n <form-generator\n [form]=\"form()\"\n [gridXXLStyle]=\"4\"\n [gridLGStyle]=\"4\"\n [showSubmitBtn]=\"false\"\n [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n (onSubmit)=\"dModal.close()\"></form-generator>\n @if (!isShow()) {\n <div class=\"d-flex justify-content-end\">\n <app-btn (mclick)=\"dModal.close()\" text=\"Done\" />\n </div>\n }\n </ng-template>\n </modal-comp>\n </td>\n }\n @default {\n <td class=\"{{ scheme.cls }}\">\n <app-input-basic\n #formField\n [name]=\"scheme.field | toAny\"\n [form]=\"form()\"\n [dontFormatAsInput]=\"scheme.dontFormatAsInput\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [type]=\"scheme.type\"\n [valueField]=\"scheme.valueField\"\n [labelType]=\"scheme.labelType | toAny\"\n [showValidationMsg]=\"true\"\n [checkedSignal]=\"scheme.checked\"\n [showValidation]=\"!!scheme.asyncValidators\"\n [noFormat]=\"scheme.noFormat\"\n [showValidationIcon]=\"!!scheme.asyncValidators\"\n [debug]=\"scheme.debug\"\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 [placeholder]=\"scheme.placeholder\"\n [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"></app-input-basic>\n </td>\n }\n }\n}\n@if (!isShow()) {\n @if (onDeleteRowFunc) {\n <td class=\"w-1\">\n <app-btn group=\"delete\" [iconBtn]=\"true\" (mclick)=\"onDeleteRowFunc.emit({ btn: deleteBtn })\" #deleteBtn />\n </td>\n }\n @if (onAddRowFunc) {\n <td class=\"w-1\">\n <app-btn [iconBtn]=\"true\" group=\"add\" [disabled]=\"hideAdd()\" (mclick)=\"onAddRowFunc.emit({ btn: addBtn })\" #addBtn></app-btn>\n </td>\n }\n @for (actionBtn of actionBtns(); track actionBtn.icon) {\n <td class=\"w-1\">\n <app-btn\n [iconBtn]=\"true\"\n [group]=\"actionBtn.group\"\n [icon]=\"actionBtn.icon\"\n (mclick)=\"\n onActionButtonClick.emit({\n btn: actionBtnTemp,\n actionButton: actionBtn\n })\n \"\n #actionBtnTemp></app-btn>\n </td>\n }\n}\n" }]
75
+ ], template: "@for (scheme of formSchema(); track scheme._id) {\n @if (scheme.type == 'button') {\n <td class=\"{{ scheme.cls }} w-1\">\n <div class=\"d-flex\">\n <app-btn\n [text]=\"scheme.label\"\n [type]=\"\n (form()\n | hasFormValue\n : (childrenFormSchemaMap()[scheme.field].formSchemaStr | toAny)\n : formValue())\n ? 'primary'\n : 'secondary'\n \"\n onFormInvalid=\"warn\"\n [form]=\"form()\"\n [icon]=\"scheme.icon\"\n [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n [matTooltip]=\"\n formValue() | formValue: childrenFormSchemaMap()[scheme.field].formSchema | toAny\n \"\n (mclick)=\"dModal.open()\" />\n </div>\n <modal-comp #dModal [showFooter]=\"false\" header=\"{{ scheme.label }} Form\" width=\"70%\">\n <ng-template modalBody>\n <form-generator\n [form]=\"form()\"\n [gridXXLStyle]=\"4\"\n [gridLGStyle]=\"4\"\n [showSubmitBtn]=\"false\"\n [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n (onSubmit)=\"dModal.close()\"></form-generator>\n @if (!isShow()) {\n <div class=\"d-flex justify-content-end\">\n <app-btn (mclick)=\"dModal.close()\" text=\"Done\" />\n </div>\n }\n </ng-template>\n </modal-comp>\n </td>\n } @else if (scheme.field) {\n @switch (true) {\n @case (scheme.type == 'tel') {\n <td class=\"{{ scheme.cls }}\">\n <app-phone-number\n [form]=\"form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n [showValidationMsg]=\"true\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \"\n #inputTag></app-phone-number>\n </td>\n }\n @case (scheme.type == 'autocomplete') {\n <td class=\"{{ scheme.cls }}\">\n <app-autocomplete\n [form]=\"form()\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [labelField]=\"scheme.labelField\"\n [noFormat]=\"scheme.noFormat\"\n [labelType]=\"scheme.labelType | toAny\"\n [showValidationMsg]=\"true\"\n (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n [name]=\"scheme.field | toAny\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [debug]=\"scheme.debug\"\n [optionFormatter]=\"scheme.optionFormatter\"\n [valueField]=\"scheme.valueField\"\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 #inputTag></app-autocomplete>\n </td>\n }\n\n @default {\n <td class=\"{{ scheme.cls }}\">\n <app-input-basic\n #formField\n [name]=\"scheme.field | toAny\"\n [form]=\"form()\"\n [dontFormatAsInput]=\"scheme.dontFormatAsInput\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [type]=\"scheme.type\"\n [valueField]=\"scheme.valueField\"\n [labelType]=\"scheme.labelType | toAny\"\n [showValidationMsg]=\"true\"\n [checkedSignal]=\"scheme.checked\"\n [showValidation]=\"!!scheme.asyncValidators\"\n [noFormat]=\"scheme.noFormat\"\n [showValidationIcon]=\"!!scheme.asyncValidators\"\n [debug]=\"scheme.debug\"\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 [placeholder]=\"scheme.placeholder\"\n [disabled]=\"\n scheme.disabled ||\n (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n \"></app-input-basic>\n </td>\n }\n }\n }\n}\n@if (!isShow()) {\n @if (onDeleteRowFunc) {\n <td class=\"w-1\">\n <app-btn\n group=\"delete\"\n [iconBtn]=\"true\"\n (mclick)=\"onDeleteRowFunc.emit({ btn: deleteBtn })\"\n #deleteBtn />\n </td>\n }\n @if (onAddRowFunc) {\n <td class=\"w-1\">\n <app-btn\n [iconBtn]=\"true\"\n group=\"add\"\n [disabled]=\"hideAdd()\"\n (mclick)=\"onAddRowFunc.emit({ btn: addBtn })\"\n #addBtn></app-btn>\n </td>\n }\n @for (actionBtn of actionBtns(); track actionBtn.icon) {\n <td class=\"w-1\">\n <app-btn\n [iconBtn]=\"true\"\n [group]=\"actionBtn.group\"\n [icon]=\"actionBtn.icon\"\n (mclick)=\"\n onActionButtonClick.emit({\n btn: actionBtnTemp,\n actionButton: actionBtn\n })\n \"\n #actionBtnTemp></app-btn>\n </td>\n }\n}\n" }]
73
76
  }], propDecorators: { onDeleteRowFunc: [{
74
77
  type: Output
75
78
  }], onAddRowFunc: [{
@@ -77,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
77
80
  }], onActionButtonClick: [{
78
81
  type: Output
79
82
  }] } });
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input-row.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input-row/table-input-row.component.ts","../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input-row/table-input-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AsyncPipe,\n  JsonPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgSwitch,\n  NgSwitchCase,\n  NgSwitchDefault,\n} from '@angular/common';\nimport { Component, EventEmitter, Output, computed, effect, input } from '@angular/core';\nimport { AbstractControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTooltipModule } from '@angular/material/tooltip';\n\nimport { PaginatorComponent } from '../../paginator/paginator.component';\nimport {\n  FilterFormArrayGroupPipe,\n  FormValuePipe,\n  FunctionCaller2,\n  HasFormValuePipe,\n  ToAnyPipe,\n} from '../../../pipes/utility.pipe';\nimport { SDKTranslatePipe } from '../../../pipes/translate.pipe';\nimport { AutocompleteComponent } from '../../autocomplete/autocomplete.component';\nimport { BtnComponent } from '../../btn/btn.component';\nimport { FormGeneratorComponent, IFormSchema } from '../../form-generator/form-generator.component';\nimport { InputBasicComponent } from '../../input/input-basic.component';\nimport { ValidationMessageComponent } from '../../input/validation-message/validation-message.component';\nimport { LoaderComponent } from '../../loader/loader.component';\nimport { PhoneNumberComponent } from '../../phone-number/phone-number.component';\nimport { ModalComponents } from '../../modal-components/modal.components';\nimport { PaginatorPipe } from '../../../pipes/paginator.pipe';\nimport { ITableInputBtn } from '../table-input.component';\n\n@Component({\n  selector: 'tr[table-input-row]',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTooltipModule,\n    ModalComponents,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input-row.component.html',\n  styleUrls: ['./table-input-row.component.scss'],\n})\nexport class TableInputRowComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends FormGeneratorComponent<TFormGroup> {\n  @Output() onDeleteRowFunc = new EventEmitter<{ btn?: BtnComponent }>();\n  @Output() onAddRowFunc = new EventEmitter<{ btn?: BtnComponent }>();\n  @Output() onActionButtonClick = new EventEmitter<{\n    btn?: BtnComponent;\n    actionButton: ITableInputBtn;\n  }>();\n  readonly isShow = input<boolean>();\n  readonly hideAdd = input<boolean>();\n  readonly actionBtns = input<ITableInputBtn[]>(); \n\n  readonly childrenFormSchemaMap = input<{\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  }>({});\n\n  readonly isShowEffect = effect(\n    () => {\n      const form = this.form();\n      if (this.isShow()) form.disable();\n    },\n    { allowSignalWrites: true },\n  );\n}\n","@for (scheme of formSchema(); track scheme._id) {\n  @switch (true) {\n    @case (scheme.type == 'tel') {\n      <td class=\"{{ scheme.cls }}\">\n        <app-phone-number\n          [form]=\"form()\"\n          [clearOnDisable]=\"scheme.clearOnDisable\"\n          [name]=\"scheme.field\"\n          [showLabel]=\"false\"\n          [noFormat]=\"scheme.noFormat\"\n          [debug]=\"scheme.debug\"\n          [showValidation]=\"scheme.showValidation\"\n          [clearOnDisable]=\"scheme.clearOnDisable\"\n          [showValidationIcon]=\"scheme.showValidationIcon\"\n          [countryCode3]=\"scheme.countryCode3\"\n          [showValidationMsg]=\"true\"\n          [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"\n          #inputTag></app-phone-number>\n      </td>\n    }\n    @case (scheme.type == 'autocomplete') {\n      <td class=\"{{ scheme.cls }}\">\n        <app-autocomplete\n          [form]=\"form()\"\n          [clearOnDisable]=\"scheme.clearOnDisable\"\n          [labelField]=\"scheme.labelField\"\n          [noFormat]=\"scheme.noFormat\"\n          [labelType]=\"scheme.labelType | toAny\"\n          [showValidationMsg]=\"true\"\n          (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n          [name]=\"scheme.field | toAny\"\n          [clearOnDisable]=\"scheme.clearOnDisable\"\n          [debug]=\"scheme.debug\"\n          [optionFormatter]=\"scheme.optionFormatter\"\n          [valueField]=\"scheme.valueField\"\n          [options]=\"scheme.options || optionsMap[scheme.field | toAny]\"\n          [hint]=\"scheme.hint\"\n          [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"\n          #inputTag></app-autocomplete>\n      </td>\n    }\n    @case (scheme.type == 'button') {\n      <td class=\"{{ scheme.cls }} w-1\">\n        <div class=\"d-flex\">\n          <app-btn\n            [text]=\"scheme.label\"\n            [type]=\"\n              (form() | hasFormValue: (childrenFormSchemaMap()[scheme.field].formSchemaStr | toAny) : (formValue()))\n                ? 'primary'\n                : 'secondary'\n            \"\n            onFormInvalid=\"warn\"\n            [form]=\"form()\"\n            [icon]=\"scheme.icon\"\n            [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n            [matTooltip]=\"formValue() | formValue: childrenFormSchemaMap()[scheme.field].formSchema | toAny\"\n            (mclick)=\"dModal.open()\" />\n        </div>\n        <modal-comp #dModal [showFooter]=\"false\" header=\"{{ scheme.label }} Form\" width=\"70%\">\n          <ng-template modalBody>\n            <form-generator\n              [form]=\"form()\"\n              [gridXXLStyle]=\"4\"\n              [gridLGStyle]=\"4\"\n              [showSubmitBtn]=\"false\"\n              [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n              (onSubmit)=\"dModal.close()\"></form-generator>\n            @if (!isShow()) {\n              <div class=\"d-flex justify-content-end\">\n                <app-btn (mclick)=\"dModal.close()\" text=\"Done\" />\n              </div>\n            }\n          </ng-template>\n        </modal-comp>\n      </td>\n    }\n    @default {\n      <td class=\"{{ scheme.cls }}\">\n        <app-input-basic\n          #formField\n          [name]=\"scheme.field | toAny\"\n          [form]=\"form()\"\n          [dontFormatAsInput]=\"scheme.dontFormatAsInput\"\n          [clearOnDisable]=\"scheme.clearOnDisable\"\n          [type]=\"scheme.type\"\n          [valueField]=\"scheme.valueField\"\n          [labelType]=\"scheme.labelType | toAny\"\n          [showValidationMsg]=\"true\"\n          [checkedSignal]=\"scheme.checked\"\n          [showValidation]=\"!!scheme.asyncValidators\"\n          [noFormat]=\"scheme.noFormat\"\n          [showValidationIcon]=\"!!scheme.asyncValidators\"\n          [debug]=\"scheme.debug\"\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          [placeholder]=\"scheme.placeholder\"\n          [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\"></app-input-basic>\n      </td>\n    }\n  }\n}\n@if (!isShow()) {\n  @if (onDeleteRowFunc) {\n    <td class=\"w-1\">\n      <app-btn group=\"delete\" [iconBtn]=\"true\" (mclick)=\"onDeleteRowFunc.emit({ btn: deleteBtn })\" #deleteBtn />\n    </td>\n  }\n  @if (onAddRowFunc) {\n    <td class=\"w-1\">\n      <app-btn [iconBtn]=\"true\" group=\"add\" [disabled]=\"hideAdd()\" (mclick)=\"onAddRowFunc.emit({ btn: addBtn })\" #addBtn></app-btn>\n    </td>\n  }\n  @for (actionBtn of actionBtns(); track actionBtn.icon) {\n    <td class=\"w-1\">\n      <app-btn\n        [iconBtn]=\"true\"\n        [group]=\"actionBtn.group\"\n        [icon]=\"actionBtn.icon\"\n        (mclick)=\"\n          onActionButtonClick.emit({\n            btn: actionBtnTemp,\n            actionButton: actionBtn\n          })\n        \"\n        #actionBtnTemp></app-btn>\n    </td>\n  }\n}\n"]}
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input-row.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input-row/table-input-row.component.ts","../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input-row/table-input-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AsyncPipe,\n  JsonPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgSwitch,\n  NgSwitchCase,\n  NgSwitchDefault,\n} from '@angular/common';\nimport { Component, EventEmitter, Output, computed, effect, input } from '@angular/core';\nimport { AbstractControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTooltipModule } from '@angular/material/tooltip';\n\nimport { PaginatorComponent } from '../../paginator/paginator.component';\nimport {\n  FilterFormArrayGroupPipe,\n  FormValuePipe,\n  FunctionCaller2,\n  HasFormValuePipe,\n  ToAnyPipe,\n} from '../../../pipes/utility.pipe';\nimport { SDKTranslatePipe } from '../../../pipes/translate.pipe';\nimport { AutocompleteComponent } from '../../autocomplete/autocomplete.component';\nimport { BtnComponent } from '../../btn/btn.component';\nimport { FormGeneratorComponent, IFormSchema } from '../../form-generator/form-generator.component';\nimport { InputBasicComponent } from '../../input/input-basic.component';\nimport { ValidationMessageComponent } from '../../input/validation-message/validation-message.component';\nimport { LoaderComponent } from '../../loader/loader.component';\nimport { PhoneNumberComponent } from '../../phone-number/phone-number.component';\nimport { ModalComponents } from '../../modal-components/modal.components';\nimport { PaginatorPipe } from '../../../pipes/paginator.pipe';\nimport { ITableInputBtn } from '../table-input.component';\n\n@Component({\n  selector: 'tr[table-input-row]',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTooltipModule,\n    ModalComponents,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input-row.component.html',\n  styleUrls: ['./table-input-row.component.scss'],\n})\nexport class TableInputRowComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends FormGeneratorComponent<TFormGroup> {\n  @Output() onDeleteRowFunc = new EventEmitter<{ btn?: BtnComponent }>();\n  @Output() onAddRowFunc = new EventEmitter<{ btn?: BtnComponent }>();\n  @Output() onActionButtonClick = new EventEmitter<{\n    btn?: BtnComponent;\n    actionButton: ITableInputBtn;\n  }>();\n  readonly isShow = input<boolean>();\n  readonly hideAdd = input<boolean>();\n  readonly actionBtns = input<ITableInputBtn[]>();\n\n  formschemaUpdate = effect(() => {\n    console.log('formschema update', this.formSchema(), this.formSchemaMap());\n  });\n\n  readonly childrenFormSchemaMap = input<{\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  }>({});\n\n  readonly isShowEffect = effect(\n    () => {\n      const form = this.form();\n      if (this.isShow()) form.disable();\n    },\n    { allowSignalWrites: true },\n  );\n}\n","@for (scheme of formSchema(); track scheme._id) {\n  @if (scheme.type == 'button') {\n    <td class=\"{{ scheme.cls }} w-1\">\n      <div class=\"d-flex\">\n        <app-btn\n          [text]=\"scheme.label\"\n          [type]=\"\n            (form()\n            | hasFormValue\n              : (childrenFormSchemaMap()[scheme.field].formSchemaStr | toAny)\n              : formValue())\n              ? 'primary'\n              : 'secondary'\n          \"\n          onFormInvalid=\"warn\"\n          [form]=\"form()\"\n          [icon]=\"scheme.icon\"\n          [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n          [matTooltip]=\"\n            formValue() | formValue: childrenFormSchemaMap()[scheme.field].formSchema | toAny\n          \"\n          (mclick)=\"dModal.open()\" />\n      </div>\n      <modal-comp #dModal [showFooter]=\"false\" header=\"{{ scheme.label }} Form\" width=\"70%\">\n        <ng-template modalBody>\n          <form-generator\n            [form]=\"form()\"\n            [gridXXLStyle]=\"4\"\n            [gridLGStyle]=\"4\"\n            [showSubmitBtn]=\"false\"\n            [formSchema]=\"childrenFormSchemaMap()[scheme.field].formSchema\"\n            (onSubmit)=\"dModal.close()\"></form-generator>\n          @if (!isShow()) {\n            <div class=\"d-flex justify-content-end\">\n              <app-btn (mclick)=\"dModal.close()\" text=\"Done\" />\n            </div>\n          }\n        </ng-template>\n      </modal-comp>\n    </td>\n  } @else if (scheme.field) {\n    @switch (true) {\n      @case (scheme.type == 'tel') {\n        <td class=\"{{ scheme.cls }}\">\n          <app-phone-number\n            [form]=\"form()\"\n            [clearOnDisable]=\"scheme.clearOnDisable\"\n            [name]=\"scheme.field\"\n            [showLabel]=\"false\"\n            [noFormat]=\"scheme.noFormat\"\n            [debug]=\"scheme.debug\"\n            [showValidation]=\"scheme.showValidation\"\n            [clearOnDisable]=\"scheme.clearOnDisable\"\n            [showValidationIcon]=\"scheme.showValidationIcon\"\n            [countryCode3]=\"scheme.countryCode3\"\n            [showValidationMsg]=\"true\"\n            [disabled]=\"\n              scheme.disabled ||\n              (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n            \"\n            #inputTag></app-phone-number>\n        </td>\n      }\n      @case (scheme.type == 'autocomplete') {\n        <td class=\"{{ scheme.cls }}\">\n          <app-autocomplete\n            [form]=\"form()\"\n            [clearOnDisable]=\"scheme.clearOnDisable\"\n            [labelField]=\"scheme.labelField\"\n            [noFormat]=\"scheme.noFormat\"\n            [labelType]=\"scheme.labelType | toAny\"\n            [showValidationMsg]=\"true\"\n            (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n            [name]=\"scheme.field | toAny\"\n            [clearOnDisable]=\"scheme.clearOnDisable\"\n            [debug]=\"scheme.debug\"\n            [optionFormatter]=\"scheme.optionFormatter\"\n            [valueField]=\"scheme.valueField\"\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            #inputTag></app-autocomplete>\n        </td>\n      }\n\n      @default {\n        <td class=\"{{ scheme.cls }}\">\n          <app-input-basic\n            #formField\n            [name]=\"scheme.field | toAny\"\n            [form]=\"form()\"\n            [dontFormatAsInput]=\"scheme.dontFormatAsInput\"\n            [clearOnDisable]=\"scheme.clearOnDisable\"\n            [type]=\"scheme.type\"\n            [valueField]=\"scheme.valueField\"\n            [labelType]=\"scheme.labelType | toAny\"\n            [showValidationMsg]=\"true\"\n            [checkedSignal]=\"scheme.checked\"\n            [showValidation]=\"!!scheme.asyncValidators\"\n            [noFormat]=\"scheme.noFormat\"\n            [showValidationIcon]=\"!!scheme.asyncValidators\"\n            [debug]=\"scheme.debug\"\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            [placeholder]=\"scheme.placeholder\"\n            [disabled]=\"\n              scheme.disabled ||\n              (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n            \"></app-input-basic>\n        </td>\n      }\n    }\n  }\n}\n@if (!isShow()) {\n  @if (onDeleteRowFunc) {\n    <td class=\"w-1\">\n      <app-btn\n        group=\"delete\"\n        [iconBtn]=\"true\"\n        (mclick)=\"onDeleteRowFunc.emit({ btn: deleteBtn })\"\n        #deleteBtn />\n    </td>\n  }\n  @if (onAddRowFunc) {\n    <td class=\"w-1\">\n      <app-btn\n        [iconBtn]=\"true\"\n        group=\"add\"\n        [disabled]=\"hideAdd()\"\n        (mclick)=\"onAddRowFunc.emit({ btn: addBtn })\"\n        #addBtn></app-btn>\n    </td>\n  }\n  @for (actionBtn of actionBtns(); track actionBtn.icon) {\n    <td class=\"w-1\">\n      <app-btn\n        [iconBtn]=\"true\"\n        [group]=\"actionBtn.group\"\n        [icon]=\"actionBtn.icon\"\n        (mclick)=\"\n          onActionButtonClick.emit({\n            btn: actionBtnTemp,\n            actionButton: actionBtn\n          })\n        \"\n        #actionBtnTemp></app-btn>\n    </td>\n  }\n}\n"]}
@@ -231,4 +231,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
231
231
  type: ViewChild,
232
232
  args: [PaginatorComponent]
233
233
  }] } });
234
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,EAEL,SAAS,EACT,QAAQ,EACR,MAAM,EACN,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAGL,WAAW,EACX,SAAS,EACT,WAAW,EACX,mBAAmB,EACnB,UAAU,GACX,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,wBAAwB,EACxB,aAAa,EACb,eAAe,EACf,gBAAgB,EAChB,SAAS,GACV,MAAM,0BAA0B,CAAC;AAElC,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAC/E,OAAO,EAAE,0BAA0B,EAAE,MAAM,0DAA0D,CAAC;AACtG,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAC9E,OAAO,EACL,SAAS,EACT,QAAQ,EACR,OAAO,EACP,KAAK,EACL,IAAI,EACJ,QAAQ,EACR,YAAY,EACZ,eAAe,GAChB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AAEpF,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;AACrF,OAAO,EAAwB,GAAG,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAE5D,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;;AAEpE;;GAEG;AAyCH,MAAM,OAAO,mBAKX,SAAQ,sBAAkC;IA7C5C;;QAmDW,cAAS,GAAG,KAAK,EAAoC,CAAC;QAEtD,yBAAoB,GAAG,KAAK,EAAU,CAAC;QACvC,WAAM,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QACrB,WAAM,GAAG,KAAK,EAAW,CAAC;QAI1B,aAAQ,GAAG,MAAM,CAAS,EAAE,CAAC,CAAC;QAC9B,cAAS,GAAG,MAAM,CAA0C,IAAI,CAAC,CAAC;QAClE,eAAU,GAAG,KAAK,EAAoB,CAAC;QA+BvC,eAAU,GAAG,KAAK,EAA8D,CAAC;QACvE,eAAU,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QAC/B,gBAAW,GAAG,MAAM,CAAgB,EAAE,CAAC,CAAC;QACxC,iBAAY,GAAG,MAAM,CAAU,IAAI,CAAC,CAAC;QAC9C,0BAAqB,GAK3B,EAAE,CAAC;QAME,0BAAqB,GAAG,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;QAC/D,0BAAqB,GAAG,QAAQ,CACvC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAC/B,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,CACtE,CACF,CAAC;QAEO,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE;YACzC,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,EAChC,eAAe,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACjD,MAAM,UAAU,GAAG,SAAS,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBACzD,KAAK;gBACL,IAAI,EAAE,CAAC;gBACP,EAAE,EAAE,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE;aACvC,CAAC,CAAC,CAAC;YACJ,MAAM,YAAY,GAAG,IAAI,CAAC,wBAAwB,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;YAChF,OAAO,YAAY;gBACjB,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAC7B,IAAI,CAAC,wBAAwB,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,CAC7D;gBACH,CAAC,CAAC,UAAU,CAAC;QACjB,CAAC,CAAC,CAAC;QACM,kCAA6B,GAAG,QAAQ,CAAC,GAAG,EAAE;YACrD,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,EAAE,EACxC,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAC/B,OAAO,IAAI,CAAC,YAAY,EAAE;gBACxB,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAC1B,SAAS,EACT,SAAS,EAAE,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE,EACtC,SAAS,EAAE,SAAS,IAAI,CAAC,CAC1B;gBACH,CAAC,CAAC,SAAS,CAAC;QAChB,CAAC,CAAC,CAAC;QAEM,4BAAuB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,MAAM,CAAC,CAAC;QAEnE,mBAAc,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QACjD,6BAAwB,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QAC5D,kBAAa,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QA+BnC,wBAAmB,GAAG,CAAC,KAAgC,EAAE,EAAE;YACnE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;gBAClB,IAAI,CAAC,CAAC,YAAY;oBAAE,CAAC,CAAC,qBAAqB,GAAG,IAAI,CAAC;qBAC9C,IAAI,CAAC,CAAC,IAAI,IAAI,QAAQ;oBAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YACpE,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;QA4BF,qBAAgB,GAAG,CACjB,KAAa,EACb,OAA8B,EAC9B,MAA8B,EAC9B,EAAE;YACF,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,EAAE,MAAM,CAAC,CAAC;YAC1D,kBAAkB;QACpB,CAAC,CAAC;QAEF,kBAAa,GAAG,CAAC,KAAa,EAAE,EAAE;YAChC,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC;YACzD,kBAAkB;YAClB,4CAA4C;QAC9C,CAAC,CAAC;QAEF,wBAAmB,GAAG,GAAG,EAAE;YACzB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACxC,CAAC,CAAC;KA6BH;IAhNC,SAAS,CAAC,IAA6B;QACrC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC;IAMD,IAAuB,SAAS,CAAC,CAAS;QACxC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC;IAID,IAA6D,WAAW,CACtE,CAA4B;QAE5B,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC5B,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC;IACxB,CAAC;IAeD,IAA2B,aAAa,CAAC,CAAU;QACjD,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC5B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC;QACrD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC;IA0DD,QAAQ;QACN,IAAI,IAAI,CAAC,YAAY,IAAI,SAAS,EAAE,CAAC;YACnC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,eAAe;QACb,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC,EAAE,IAAI,CAAC,CAAC;IACX,CAAC;IAED,OAAO;QACL,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;IACjC,CAAC;IAEQ,SAAS;QAChB,IAAI,CAAC,sBAAsB,EAAE,WAAW,EAAE,CAAC;QAC3C,OAAO,KAAK,CAAC,SAAS,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,MAA+C;QACzD,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,kBAAkB,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IASQ,IAAI,CAAC,MAAiC;QAC7C,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzB,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;YAC3C,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC;gBACxE,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YACrC,CAAC;QACH,CAAC;QACD,YAAY;QACZ,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,MAAM;YACR,KAAK,MAAM,MAAM,IAAI,MAAM,EAAE,CAAC;gBAC5B,0CAA0C;gBAC1C,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAChC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAED,uBAAuB,CACrB,KAAa,EACb,IAA2B,EAC3B,CAAuD;QAEvD,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;QACnD,kBAAkB;IACpB,CAAC;IAqBQ,gBAAgB,CAAC,MAAmB;QAC3C,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;QAC/C,IAAI,MAAM,CAAC,kBAAkB,IAAI,IAAI,IAAI,CAAC,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;YACjF,MAAM,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAEnC,IAAI,MAAM,CAAC,eAAe,EAAE,CAAC;YAC3B,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;gBACrC,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC;gBACnB,qCAAqC;YACvC,CAAC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACvE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,IAAI,WAAW,EAAE,CAAC,CAAC;QAC1E,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,IAAI,QAAQ,EAAE,CAAC;YACnC,IAAI,MAAM,CAAC,QAAQ,EAAE,MAAM;gBACzB,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,KAAe,CAAC,GAAG;oBACnD,UAAU,EAAE,MAAM,CAAC,QAAQ;oBAC3B,aAAa,EAAE,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAe,CAAC;iBAC7D,CAAC;QACN,CAAC;QACD,MAAM,CAAC,UAAU;YACf,MAAM,CAAC,UAAU;gBACL,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAE,EAAE,YAAY,CACzE,UAAU,CAAC,QAAQ,CACpB,CAAC;IACN,CAAC;8GAvNU,mBAAmB;kGAAnB,mBAAmB,2sDAFnB,CAAC,wBAAwB,EAAE,aAAa,CAAC,8EAmEzC,kBAAkB,uECvK/B,o/FA2EA,kIDTI,SAAS,8CAET,YAAY,mgBAEZ,sBAAsB,ybACtB,WAAW,8BAOX,kBAAkB,8BAClB,aAAa,8BACb,gBAAgB,+BAEhB,OAAO,oFAMP,kBAAkB,sKAGlB,mBAAmB,+BACnB,sBAAsB,sMAEtB,gBAAgB;;2FAQP,mBAAmB;kBAxC/B,SAAS;+BACE,aAAa,cACX,IAAI,WACP;wBACP,SAAS;wBACT,qBAAqB;wBACrB,YAAY;wBACZ,wBAAwB;wBACxB,sBAAsB;wBACtB,WAAW;wBACX,aAAa;wBACb,eAAe;wBACf,gBAAgB;wBAChB,mBAAmB;wBACnB,QAAQ;wBACR,eAAe;wBACf,kBAAkB;wBAClB,aAAa;wBACb,gBAAgB;wBAChB,cAAc;wBACd,OAAO;wBACP,KAAK;wBACL,IAAI;wBACJ,QAAQ;wBACR,YAAY;wBACZ,eAAe;wBACf,kBAAkB;wBAClB,aAAa;wBACb,oBAAoB;wBACpB,mBAAmB;wBACnB,sBAAsB;wBACtB,SAAS;wBACT,gBAAgB;wBAChB,wBAAwB;wBACxB,0BAA0B;qBAC3B,aAGU,CAAC,wBAAwB,EAAE,aAAa,CAAC;8BAkB7B,SAAS;sBAA/B,KAAK;uBAAC,UAAU;gBAM4C,WAAW;sBAAvE,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE;gBAO9C,mBAAmB;sBADlB,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAKhB,aAAa;sBAArB,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBACqB,aAAa;sBAAvC,KAAK;uBAAC,cAAc;gBAuBU,kBAAkB;sBAAhD,SAAS;uBAAC,kBAAkB","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  computed,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormArray,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport {\n  FilterFormArrayGroupPipe,\n  FormValuePipe,\n  FunctionCaller2,\n  HasFormValuePipe,\n  ToAnyPipe,\n} from '../../pipes/utility.pipe';\n\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport {\n  AsyncPipe,\n  JsonPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgSwitch,\n  NgSwitchCase,\n  NgSwitchDefault,\n} from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { FormGeneratorComponent } from '../form-generator/form-generator.component';\n\nimport { PaginatorComponent } from '../paginator/paginator.component';\nimport { ModalComponent } from '../modal/modal.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { TableInputRowComponent } from './table-input-row/table-input-row.component';\nimport { Subscription, filter, map, switchMap } from 'rxjs';\nimport { IBtn } from '../btn/btn.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { PaginatorPipe } from '../../pipes/paginator.pipe';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Table Input Component\n */\n@Component({\n  selector: 'table-input',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTabsModule,\n    MatTooltipModule,\n    ModalComponent,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    TableInputRowComponent,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    FilterFormArrayGroupPipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input.component.html',\n  styleUrls: ['./table-input.component.scss'],\n  providers: [FilterFormArrayGroupPipe, PaginatorPipe],\n})\nexport class TableInputComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n  >\n  extends FormGeneratorComponent<TFormGroup>\n  implements OnInit\n{\n  logColumn(_t20: IFormSchema<TFormGroup>) {\n    console.log(_t20);\n  }\n  readonly formArray = input<FormArray<FormGroup<TFormGroup>>>();\n\n  readonly filterContainerClass = input<string>();\n  readonly border = input(true);\n  readonly isShow = input<boolean>();\n  @Input('pageSize') set _pageSize(v: number) {\n    this.pageSize.set(v);\n  }\n  readonly pageSize = signal<number>(10);\n  readonly pageState = signal<{ pageIndex: number; pageSize: number }>(null);\n  readonly actionBtns = input<ITableInputBtn[]>();\n  @Input({ required: true, alias: 'formSchema' }) override set _formSchema(\n    v: IFormSchema<TFormGroup>[],\n  ) {\n    this.preFormatFormSchema(v);\n    super._formSchema = v;\n  }\n  @Input({ required: true })\n  singleFormStructure: FormGroup<TFormGroup>;\n  /**\n   * Leave empty if you don't want the delete button to show\n   */\n  @Input() deleteRowFunc: (\n    index: number,\n    data?: FormGroup<TFormGroup>['value'],\n    config?: { btn: BtnComponent },\n  ) => any;\n  /**\n   * Leave empty if you don't want the add button to show\n   */\n  @Input() addRowFunc: (index: number, data?: FormGroup<TFormGroup>['value']) => any;\n  @Input('usePaginator') set _usePaginator(v: boolean) {\n    if (v) {\n      this.usePaginator.set(true);\n      this.pageSize.update((pageSize) => pageSize || 10);\n    } else {\n      this.usePaginator.set(false);\n      this.pageSize.set(undefined);\n    }\n  }\n\n  readonly tableClass = input<'table table-responsive table-responsive table-borderless'>();\n  protected readonly filterForm = new FormGroup({});\n  protected readonly filterForms = signal<IFormSchema[]>([]);\n  protected readonly usePaginator = signal<boolean>(true);\n  protected childrenFormSchemaMap: {\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  } = {};\n  refresher: number;\n  formArrayPaginationSub: Subscription;\n\n  @ViewChild(PaginatorComponent) paginatorComponent: PaginatorComponent;\n\n  readonly filterFormValueSignal = toSignal(this.filterForm.valueChanges);\n  readonly formArrayLengthSignal = toSignal<number>(\n    toObservable(this.formArray).pipe(\n      switchMap((form) => form?.valueChanges.pipe(map(() => form?.length))),\n    ),\n  );\n\n  readonly filteredFormArray = computed(() => {\n    this.formArrayLengthSignal();\n    const formArray = this.formArray(),\n      filterFormValue = this.filterFormValueSignal();\n    const formGroups = formArray?.controls?.map((c, index) => ({\n      index,\n      form: c,\n      id: this.utilityService.generateUUID(),\n    }));\n    const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);\n    return filterObject\n      ? formGroups.filter(({ form }) =>\n          this.filterFormArrayGroupPipe.filterFunc(filterObject)(form),\n        )\n      : formGroups;\n  });\n  readonly paginatedAndFilteredFormArray = computed(() => {\n    const formArray = this.filteredFormArray(),\n      pageState = this.pageState();\n    return this.usePaginator()\n      ? this.paginatorPipe.transform(\n          formArray,\n          pageState?.pageSize || this.pageSize(),\n          pageState?.pageIndex || 0,\n        )\n      : formArray;\n  });\n\n  readonly filteredFormArrayLength = computed(() => this.filteredFormArray().length);\n\n  public override utilityService = inject(UtilityService);\n  public filterFormArrayGroupPipe = inject(FilterFormArrayGroupPipe);\n  public paginatorPipe = inject(PaginatorPipe);\n\n  ngOnInit(): void {\n    if (this.usePaginator == undefined) {\n      this._usePaginator = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.refresh();\n    }, 1000);\n  }\n\n  refresh() {\n    this.refresher = Math.random();\n  }\n\n  override onDestroy() {\n    this.formArrayPaginationSub?.unsubscribe();\n    return super.onDestroy();\n  }\n\n  pageChanged($event: { pageIndex: number; pageSize: number }) {\n    this.pageState.set($event);\n  }\n\n  resetPaginator() {\n    this.paginatorComponent?.reset();\n  }\n\n  protected preFormatFormSchema = (items: IFormSchema<TFormGroup>[]) => {\n    items.forEach((x) => {\n      if (x.onChangeFunc) x.triggerOnChangeOnInit = true;\n      else if (x.type == 'button') this.preFormatFormSchema(x.children);\n    });\n  };\n\n  override init(schema: IFormSchema<TFormGroup>[]): void {\n    this.filterForms.set([]);\n    for (const key in this.filterForm.controls) {\n      if (Object.prototype.hasOwnProperty.call(this.filterForm.controls, key)) {\n        this.filterForm.removeControl(key);\n      }\n    }\n    // debugger;\n    this.onDestroy();\n    if (schema)\n      for (const scheme of schema) {\n        // scheme.form = this.form || scheme.form;\n        this.handleFormScheme(scheme);\n      }\n    this._setFormSchemas(schema);\n  }\n\n  handleActionButtonClick(\n    index: number,\n    form: FormGroup<TFormGroup>,\n    e: { btn?: BtnComponent; actionButton: ITableInputBtn },\n  ) {\n    e.actionButton.action({ index, form, btn: e.btn });\n    // this.refresh();\n  }\n\n  deleteRowClicked = (\n    index: number,\n    rowForm: FormGroup<TFormGroup>,\n    config?: { btn: BtnComponent },\n  ) => {\n    this.deleteRowFunc(index, rowForm?.getRawValue(), config);\n    // this.refresh();\n  };\n\n  addRowClicked = (index: number) => {\n    this.addRowFunc(index + 1, this.filterFormValueSignal());\n    // this.refresh();\n    // this.filterForm.updateValueAndValidity();\n  };\n\n  checkRequiredFields = () => {\n    console.log(this.singleFormStructure);\n  };\n\n  override handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n      scheme.autoPickValueField = true;\n\n    if (scheme.optionsInitFunc) {\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        // this.optionsMap[scheme.field] = r;\n      });\n    }\n    if (scheme.isSearchField) {\n      this.filterForms.update((filterForms) => filterForms.concat([scheme]));\n      this.filterForm.addControl(scheme.field?.toString(), new FormControl());\n    } else if (scheme.type == 'button') {\n      if (scheme.children?.length)\n        this.childrenFormSchemaMap[scheme.field as string] = {\n          formSchema: scheme.children,\n          formSchemaStr: scheme.children.map((x) => x.field as string),\n        };\n    }\n    scheme.isRequired =\n      scheme.isRequired ||\n      (<FormGroup>this.singleFormStructure?.controls[scheme.field])?.hasValidator(\n        Validators.required,\n      );\n  }\n}\n\nexport interface ITableInputBtn extends IBtn {\n  action?: (arg?: { index: number; form: FormGroup; btn: BtnComponent }) => void;\n}\n","<div class=\"table-input\">\n  @if (filterForms()?.length) {\n    <div class=\"mb-3 {{ filterContainerClass() }}\">\n      <div class=\"d-flex\">\n        <app-btn\n          text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n          [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n          (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n      </div>\n      <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n        <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n        <div class=\"d-flex justify-content-end\">\n          <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n        </div>\n      </div>\n    </div>\n  }\n\n  <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n    <div class=\" \">\n      <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n        <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n          <tr class=\"text-center\">\n            @for (item of formSchema(); track item.label) {\n              <th class=\"{{ item.cls }}\" (click)=\"logColumn(item)\">\n                {{ item.label | appTranslate | async }}\n                {{ item.isRequired ? '*' : '' }}\n              </th>\n            }\n            @if (!isShow()) {\n              <th></th>\n              <th></th>\n              @for (actionBtn of actionBtns(); track actionBtn) {\n                <th></th>\n              }\n            }\n          </tr>\n        </thead>\n        <tbody>\n          @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n            <tr\n              table-input-row\n              (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n              [isShow]=\"isShow()\"\n              [form]=\"subForm.form\"\n              [actionBtns]=\"actionBtns()\"\n              [formSchema]=\"formSchema()\"\n              [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n              (onDeleteRowFunc)=\"\n                deleteRowClicked(subForm.index, subForm.form, {\n                  btn: $event?.btn\n                })\n              \"\n              (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n          } @empty {\n            <tr>\n              <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n                {{ 'There are no items' | appTranslate | async }}\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    </div>\n\n    <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n      <paginator\n        #paginatorTag\n        [arrayLength]=\"filteredFormArrayLength()\"\n        (pageChanged)=\"pageChanged($event)\"\n        [pageSize]=\"pageSize()\"\n        [resetIndexFunc]=\"filterForm.valueChanges\" />\n    </div>\n  </div>\n</div>\n"]}
234
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  computed,\n  effect,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormArray,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport {\n  FilterFormArrayGroupPipe,\n  FormValuePipe,\n  FunctionCaller2,\n  HasFormValuePipe,\n  ToAnyPipe,\n} from '../../pipes/utility.pipe';\n\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport {\n  AsyncPipe,\n  JsonPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgSwitch,\n  NgSwitchCase,\n  NgSwitchDefault,\n} from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { FormGeneratorComponent } from '../form-generator/form-generator.component';\n\nimport { PaginatorComponent } from '../paginator/paginator.component';\nimport { ModalComponent } from '../modal/modal.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { TableInputRowComponent } from './table-input-row/table-input-row.component';\nimport { Subscription, filter, map, switchMap } from 'rxjs';\nimport { IBtn } from '../btn/btn.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { PaginatorPipe } from '../../pipes/paginator.pipe';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Table Input Component\n */\n@Component({\n  selector: 'table-input',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTabsModule,\n    MatTooltipModule,\n    ModalComponent,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    TableInputRowComponent,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    FilterFormArrayGroupPipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input.component.html',\n  styleUrls: ['./table-input.component.scss'],\n  providers: [FilterFormArrayGroupPipe, PaginatorPipe],\n})\nexport class TableInputComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n  >\n  extends FormGeneratorComponent<TFormGroup>\n  implements OnInit\n{\n  logColumn(_t20: IFormSchema<TFormGroup>) {\n    console.log(_t20);\n  }\n  readonly formArray = input<FormArray<FormGroup<TFormGroup>>>();\n\n  readonly filterContainerClass = input<string>();\n  readonly border = input(true);\n  readonly isShow = input<boolean>();\n  @Input('pageSize') set _pageSize(v: number) {\n    this.pageSize.set(v);\n  }\n  readonly pageSize = signal<number>(10);\n  readonly pageState = signal<{ pageIndex: number; pageSize: number }>(null);\n  readonly actionBtns = input<ITableInputBtn[]>();\n  @Input({ required: true, alias: 'formSchema' }) override set _formSchema(\n    v: IFormSchema<TFormGroup>[],\n  ) {\n    this.preFormatFormSchema(v);\n    super._formSchema = v;\n  }\n  @Input({ required: true })\n  singleFormStructure: FormGroup<TFormGroup>;\n  /**\n   * Leave empty if you don't want the delete button to show\n   */\n  @Input() deleteRowFunc: (\n    index: number,\n    data?: FormGroup<TFormGroup>['value'],\n    config?: { btn: BtnComponent },\n  ) => any;\n  /**\n   * Leave empty if you don't want the add button to show\n   */\n  @Input() addRowFunc: (index: number, data?: FormGroup<TFormGroup>['value']) => any;\n  @Input('usePaginator') set _usePaginator(v: boolean) {\n    if (v) {\n      this.usePaginator.set(true);\n      this.pageSize.update((pageSize) => pageSize || 10);\n    } else {\n      this.usePaginator.set(false);\n      this.pageSize.set(undefined);\n    }\n  }\n\n  readonly tableClass = input<'table table-responsive table-responsive table-borderless'>();\n  protected readonly filterForm = new FormGroup({});\n  protected readonly filterForms = signal<IFormSchema[]>([]);\n  protected readonly usePaginator = signal<boolean>(true);\n  protected childrenFormSchemaMap: {\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  } = {};\n  refresher: number;\n  formArrayPaginationSub: Subscription;\n\n  @ViewChild(PaginatorComponent) paginatorComponent: PaginatorComponent;\n\n  readonly filterFormValueSignal = toSignal(this.filterForm.valueChanges);\n  readonly formArrayLengthSignal = toSignal<number>(\n    toObservable(this.formArray).pipe(\n      switchMap((form) => form?.valueChanges.pipe(map(() => form?.length))),\n    ),\n  );\n\n  readonly filteredFormArray = computed(() => {\n    this.formArrayLengthSignal();\n    const formArray = this.formArray(),\n      filterFormValue = this.filterFormValueSignal();\n    const formGroups = formArray?.controls?.map((c, index) => ({\n      index,\n      form: c,\n      id: this.utilityService.generateUUID(),\n    }));\n    const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);\n    return filterObject\n      ? formGroups.filter(({ form }) =>\n          this.filterFormArrayGroupPipe.filterFunc(filterObject)(form),\n        )\n      : formGroups;\n  });\n  readonly paginatedAndFilteredFormArray = computed(() => {\n    const formArray = this.filteredFormArray(),\n      pageState = this.pageState();\n    return this.usePaginator()\n      ? this.paginatorPipe.transform(\n          formArray,\n          pageState?.pageSize || this.pageSize(),\n          pageState?.pageIndex || 0,\n        )\n      : formArray;\n  });\n\n  readonly filteredFormArrayLength = computed(() => this.filteredFormArray().length);\n\n  public override utilityService = inject(UtilityService);\n  public filterFormArrayGroupPipe = inject(FilterFormArrayGroupPipe);\n  public paginatorPipe = inject(PaginatorPipe);\n\n  ngOnInit(): void {\n    if (this.usePaginator == undefined) {\n      this._usePaginator = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.refresh();\n    }, 1000);\n  }\n\n  refresh() {\n    this.refresher = Math.random();\n  }\n\n  override onDestroy() {\n    this.formArrayPaginationSub?.unsubscribe();\n    return super.onDestroy();\n  }\n\n  pageChanged($event: { pageIndex: number; pageSize: number }) {\n    this.pageState.set($event);\n  }\n\n  resetPaginator() {\n    this.paginatorComponent?.reset();\n  }\n\n  protected preFormatFormSchema = (items: IFormSchema<TFormGroup>[]) => {\n    items.forEach((x) => {\n      if (x.onChangeFunc) x.triggerOnChangeOnInit = true;\n      else if (x.type == 'button') this.preFormatFormSchema(x.children);\n    });\n  };\n\n  override init(schema: IFormSchema<TFormGroup>[]): void {\n    this.filterForms.set([]);\n    for (const key in this.filterForm.controls) {\n      if (Object.prototype.hasOwnProperty.call(this.filterForm.controls, key)) {\n        this.filterForm.removeControl(key);\n      }\n    }\n    // debugger;\n    this.onDestroy();\n    if (schema)\n      for (const scheme of schema) {\n        // scheme.form = this.form || scheme.form;\n        this.handleFormScheme(scheme);\n      }\n    this._setFormSchemas(schema);\n  }\n\n  handleActionButtonClick(\n    index: number,\n    form: FormGroup<TFormGroup>,\n    e: { btn?: BtnComponent; actionButton: ITableInputBtn },\n  ) {\n    e.actionButton.action({ index, form, btn: e.btn });\n    // this.refresh();\n  }\n\n  deleteRowClicked = (\n    index: number,\n    rowForm: FormGroup<TFormGroup>,\n    config?: { btn: BtnComponent },\n  ) => {\n    this.deleteRowFunc(index, rowForm?.getRawValue(), config);\n    // this.refresh();\n  };\n\n  addRowClicked = (index: number) => {\n    this.addRowFunc(index + 1, this.filterFormValueSignal());\n    // this.refresh();\n    // this.filterForm.updateValueAndValidity();\n  };\n\n  checkRequiredFields = () => {\n    console.log(this.singleFormStructure);\n  };\n\n  override handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n      scheme.autoPickValueField = true;\n\n    if (scheme.optionsInitFunc) {\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        // this.optionsMap[scheme.field] = r;\n      });\n    }\n    if (scheme.isSearchField) {\n      this.filterForms.update((filterForms) => filterForms.concat([scheme]));\n      this.filterForm.addControl(scheme.field?.toString(), new FormControl());\n    } else if (scheme.type == 'button') {\n      if (scheme.children?.length)\n        this.childrenFormSchemaMap[scheme.field as string] = {\n          formSchema: scheme.children,\n          formSchemaStr: scheme.children.map((x) => x.field as string),\n        };\n    }\n    scheme.isRequired =\n      scheme.isRequired ||\n      (<FormGroup>this.singleFormStructure?.controls[scheme.field])?.hasValidator(\n        Validators.required,\n      );\n  }\n}\n\nexport interface ITableInputBtn extends IBtn {\n  action?: (arg?: { index: number; form: FormGroup; btn: BtnComponent }) => void;\n}\n","<div class=\"table-input\">\n  @if (filterForms()?.length) {\n    <div class=\"mb-3 {{ filterContainerClass() }}\">\n      <div class=\"d-flex\">\n        <app-btn\n          text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n          [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n          (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n      </div>\n      <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n        <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n        <div class=\"d-flex justify-content-end\">\n          <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n        </div>\n      </div>\n    </div>\n  }\n\n  <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n    <div class=\" \">\n      <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n        <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n          <tr class=\"text-center\">\n            @for (item of formSchema(); track item.label) {\n              <th class=\"{{ item.cls }}\" (click)=\"logColumn(item)\">\n                {{ item.label | appTranslate | async }}\n                {{ item.isRequired ? '*' : '' }}\n              </th>\n            }\n            @if (!isShow()) {\n              <th></th>\n              <th></th>\n              @for (actionBtn of actionBtns(); track actionBtn) {\n                <th></th>\n              }\n            }\n          </tr>\n        </thead>\n        <tbody>\n          @for (subForm of paginatedAndFilteredFormArray(); track subForm.id; let i = $index) {\n            <tr\n              table-input-row\n              (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n              [isShow]=\"isShow()\"\n              [form]=\"subForm.form\"\n              [actionBtns]=\"actionBtns()\"\n              [formSchema]=\"formSchema()\"\n              [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n              (onDeleteRowFunc)=\"\n                deleteRowClicked(subForm.index, subForm.form, {\n                  btn: $event?.btn\n                })\n              \"\n              (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n          } @empty {\n            <tr>\n              <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n                {{ 'There are no items' | appTranslate | async }}\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    </div>\n\n    <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n      <paginator\n        #paginatorTag\n        [arrayLength]=\"filteredFormArrayLength()\"\n        (pageChanged)=\"pageChanged($event)\"\n        [pageSize]=\"pageSize()\"\n        [resetIndexFunc]=\"filterForm.valueChanges\" />\n    </div>\n  </div>\n</div>\n"]}