ets-fe-ng-sdk 17.0.8 → 17.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/Shared/components/form-generator/form-generator.component.mjs +1 -1
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Shared/components/form-generator/form-generator.component.d.ts +1 -1
- package/lib/Shared/components/info-dialog/info-dialog.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -217,4 +217,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImpor
|
|
|
217
217
|
type: Input,
|
|
218
218
|
args: ['isShow']
|
|
219
219
|
}] } });
|
|
220
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  AsyncValidatorFn,\n  FormGroup,\n  FormsModule,\n  ValidatorFn,\n} from '@angular/forms';\nimport { cloneDeep } from 'lodash-es';\nimport { debounceTime } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport {\n  InputBasicComponent,\n  OptionLabelType,\n} 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  CommonModule,\n  NgSwitchDefault,\n  NgTemplateOutlet,\n} from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { Observable, Subscription } from 'rxjs';\nimport { InfoDialogService } from '../info-dialog/info-dialog.service';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { InputType } from '../../models/index.model';\nimport { IconType } from '../btn/btn.model';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    BtnComponent,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: TFormGroup[K];\n  } = any,\n> implements OnInit\n{\n  @Input() keyField: 'field' | 'label' = 'field';\n\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  @Output('submissionResponse') _submissionResponse = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  @Input() submitBtnText: string = 'Submit';\n  @Input() submitBtnTemplate: TemplateRef<any>;\n  @Input() submitSuccessText: string = 'Save';\n  @Input() showSubmitBtn: boolean = true;\n\n  @Input() gridStyle: number | 'auto';\n  @Input() gridMDStyle: number | 'auto';\n  @Input() gridLGStyle: number | 'auto';\n  @Input() gridXXLStyle: number | 'auto';\n\n  @Input() formGridClass: string;\n  @Input() useLoader: boolean;\n  @Input() loading: boolean;\n\n  @Input({ required: true }) form: FormGroup<TFormGroup>;\n  formSchema: IFormSchema<TFormGroup>[];\n  submissionResponse: any;\n  @Input({ required: true, alias: 'formSchema' }) set _formSchema(\n    v: IFormSchema<TFormGroup>[],\n  ) {\n    this.init(cloneDeep(v.filter((x) => x)));\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form?.disable({ emitEvent: false });\n    else this.form?.enable();\n\n    setTimeout(() => {\n      if (v) this.form?.disable({ emitEvent: false });\n      else this.form?.enable();\n    }, 500);\n  }\n  optionsMap: IFormOptions = {};\n  cellCountryCode3s: IFormOptions = {};\n  subs: { fieldName: string; sub: Subscription }[] = [];\n  // miscIndex: TMiscIndex;\n\n  constructor(public uS: UtilityService) {}\n\n  ngOnInit(): void {}\n  ngOnDestroy(): void {\n    this.subs.forEach((s) => {\n      s?.sub?.unsubscribe();\n    });\n    this.subs = [];\n  }\n  init(schema: IFormSchema[]) {\n    // debugger;\n    this.ngOnDestroy();\n    // debugger;\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    this.formSchema = schema;\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit)\n          scheme.onChangeFunc(\n            this.form.getRawValue(),\n            this.form.getRawValue()[scheme.field],\n            this,\n          );\n  }\n  handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.uS.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (\n      scheme.autoPickValueField == null &&\n      (!scheme.valueField || !scheme.labelField)\n    )\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.onChangeFunc) {\n      if (scheme.debug) debugger;\n      const sub = this.form?.controls[scheme.field?.toString()]?.valueChanges\n        .pipe(debounceTime(0))\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.form.getRawValue(), r, this);\n        });\n      this.subs.push({ sub: sub, fieldName: scheme.field?.toString() });\n    }\n  }\n  detachFormScheme(schemeIndex?: number, fieldName?: string) {\n    this.subs\n      .find(\n        (x) =>\n          x.fieldName == this.formSchema[schemeIndex]?.field ||\n          x.fieldName == fieldName,\n      )\n      ?.sub?.unsubscribe();\n  }\n  amendFormScheme = (\n    fieldName: keyof TFormGroup,\n    formScheme: Partial<IFormSchema<TFormGroup>>,\n  ) => {\n    // debugger;\n    const ind = this.formSchema.findIndex((x) => x.field == fieldName);\n    if (ind > -1) {\n      this.formSchema[ind] = {\n        ...this.formSchema[ind],\n        ...(formScheme as any),\n      };\n      // debugger;\n      // this.formSchema[ind].options = formScheme.options;\n      // debugger;\n    }\n  };\n\n  mchangeEmitter() {\n    this.mchange.emit(this.form.getRawValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    const ind = this.formSchema.findIndex((x) => x.field == fieldName);\n    return ind > -1 ? this.formSchema[ind] : null;\n  };\n  addToFormSchema(formScheme: IFormSchema) {\n    this.removeFromFormSchema(formScheme.field?.toString());\n    const _fs = cloneDeep(formScheme);\n    this.handleFormScheme(_fs);\n    this.formSchema.push(_fs);\n  }\n  removeFromFormSchema(fieldName: string) {\n    const ind = this.formSchema.findIndex((x) => x.field == fieldName);\n    this.detachFormScheme(ind, fieldName);\n    if (ind > -1) {\n      if (this.formSchema[ind]?.onRemoveFunc)\n        this.formSchema[ind]?.onRemoveFunc(\n          this.form.getRawValue() as any,\n          this.form.controls[fieldName],\n          this,\n        );\n      this.formSchema.splice(ind, 1);\n    }\n  }\n  setOptionLabel($event: any, scheme: IFormSchema) {\n    scheme.selectedOptionLabel = $event;\n  }\n  async submit() {\n    if (this.submitFunc) {\n      this.loading = true;\n      this.onSubmit.emit(this.form.value);\n      try {\n        this.submissionResponse = await this.submitFunc(this.form.value);\n        this.uS.info(this.submitSuccessText, 1);\n        this._submissionResponse.emit(this.submissionResponse);\n      } catch (error) {\n        this.uS.info(error, 0);\n      }\n      this.loading = false;\n    } else this.onSubmit.emit(this.form.value);\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n  TOptionLabelType = OptionLabelType,\n  TInputType = InputType,\n> {\n  asyncValidators?: AsyncValidatorFn[];\n  autoPickValueField?: boolean;\n  checked?: boolean;\n  clearOnDisable?: boolean;\n  cls?: string;\n  countryCode3?: string;\n  children: IFormSchema<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  isRequired?: boolean;\n  isSearchField?: boolean;\n  label?: string;\n  labelField?: string;\n  labelType?: TOptionLabelType;\n  optionLabelFormatter?: (row) => string;\n  max?: number;\n  min?: number;\n  noFormat?: boolean;\n  optionFormatter?: (item: any) => string;\n  options?: any[];\n  optionsAsync?: Observable<any[]> | Promise<any[]>;\n  optionsInitFunc?: Observable<any[]>;\n  optionsKey?: string;\n  placeholder?: string;\n  searchFunc?: (...args) => any;\n  setAsCountryCode3?: boolean;\n  showValidation?: boolean;\n  showValidationIcon?: boolean;\n  templateValue?: any;\n  type?: TInputType;\n  validators?: ValidatorFn[];\n  value?: any;\n  valueField?: string;\n  optionsFunc?: (...val: any) => Observable<any[]>;\n  triggerOnChangeOnInit?: boolean;\n  formatter?: (\n    row: { [K in keyof TFormGroup]: any },\n    fieldName: keyof TFormGroup,\n  ) => string;\n  extra?: any;\n  onChangeFunc?: (\n    row: { [K in keyof TFormGroup]?: TFormGroup[K]['value'] },\n    cellValue?: any,\n    _this?: FormGeneratorComponent<TFormGroup>,\n  ) => Observable<any[]> | any;\n  onRemoveFunc?: (\n    row: { [K in keyof TFormGroup]: TFormGroup[K]['value'] },\n    cell?: any,\n    _this?: FormGeneratorComponent<TFormGroup>,\n  ) => any;\n  selectedOptionLabel?: string;\n  stacked?: boolean;\n  debug?: boolean;\n  showValidationMsg?: boolean;\n  dontFormatAsInput?: boolean;\n  showRequiredTag?: boolean;\n  icon?: IconType;\n}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<loader [loading]=\"useLoader && loading\">\n  <form>\n    <div\n      class=\"row row-cols-{{gridStyle}} row-cols-md-{{gridMDStyle}} row-cols-lg-{{gridLGStyle}} row-cols-xxl-{{gridXXLStyle}} align-items-center {{formGridClass}}\">\n      @for (scheme of formSchema; track uS.trackByID($index, scheme)) {\n\n      @if (!scheme.hidden && (!scheme.hideIfFunc || !scheme.hideIfFunc(form.value))) {\n      <div class=\"col {{scheme.cls}} \">\n\n        @switch (true) {\n        @case (scheme.type == 'tel') {\n\n        <app-phone-number [form]=\"scheme.form||form\" [label]=\"scheme.label\" [clearOnDisable]=\"scheme.clearOnDisable\"\n          [stacked]=\"scheme.stacked\" [name]=\"scheme.field\" [showLabel]=\"false\" [noFormat]=\"scheme.noFormat\"\n          [debug]=\"scheme.debug\" (mchange)=\"mchangeEmitter()\" [showValidation]=\"scheme.showValidation\"\n          [autoPickValueField]=\"scheme.autoPickValueField\" [showRequiredTag]=\"scheme.showRequiredTag\"\n          [showValidationMsg]=\"scheme.showValidationMsg\" [showValidationIcon]=\"scheme.showValidationIcon\"\n          [countryCode3]=\"cellCountryCode3s[scheme.getCountryCode3Key] || scheme.countryCode3\"\n          [disabled]=\"scheme.disabled||(scheme.disabledIf|functionCaller2:form.value:(scheme.field|toAny))\" />\n\n        }\n        @case (scheme.type == 'autocomplete') {\n\n        <app-autocomplete [form]=\"scheme.form||form\" [label]=\"scheme.label\" [clearOnDisable]=\"scheme.clearOnDisable\"\n          [stacked]=\"scheme.stacked\" [labelField]=\"scheme.labelField\" [noFormat]=\"scheme.noFormat\"\n          [labelType]=\"scheme.labelType\" (mchange)=\"mchangeEmitter()\"\n          (mSelectedOptionLabel)=\"setOptionLabel($event,scheme)\" [name]=\"scheme.field\" [debug]=\"scheme.debug\"\n          [showRequiredTag]=\"scheme.showRequiredTag\" [optionFormatter]=\"scheme.optionFormatter\"\n          [valueField]=\"scheme.valueField\" [optionsFunc]=\"scheme.optionsFunc\"\n          [showValidationMsg]=\"scheme.showValidationMsg\" [autoPickValueField]=\"scheme.autoPickValueField\"\n          [options]=\" scheme.options||optionsMap[scheme.field|toAny]\" [hint]=\"scheme.hint\"\n          [disabled]=\"scheme.disabled||(scheme.disabledIf|functionCaller2: form.value:(scheme.field|toAny))\" />\n\n        }\n        @default {\n\n        <app-input-basic [noFormat]=\"scheme.noFormat\" [name]=\"scheme.field\" [form]=\"scheme.form||form\"\n          [clearOnDisable]=\"scheme.clearOnDisable\" [type]=\"scheme.type\" [valueField]=\"scheme.valueField\"\n          [autoPickValueField]=\"scheme.autoPickValueField\" [stacked]=\"scheme.stacked\" [labelType]=\"scheme.labelType\"\n          [checked]=\"scheme.checked\" [showValidation]=\"!!scheme.asyncValidators\"\n          [showValidationIcon]=\"!!scheme.asyncValidators\" [debug]=\"scheme.debug\" (mchange)=\"mchangeEmitter()\"\n          [showRequiredTag]=\"scheme.showRequiredTag\" [labelField]=\"scheme.labelField\"\n          [optionFormatter]=\"scheme.optionFormatter\" (mSelectedOptionLabel)=\"setOptionLabel($event,scheme)\"\n          [options]=\"scheme.options||optionsMap[scheme.field|toAny]\" [decimalPoints]=\"scheme.decimalPoints\"\n          [hint]=\"scheme.hint\" [max]=\"scheme.max\" [min]=\"scheme.min\" [placeholder]=\"scheme.placeholder\"\n          [label]=\"scheme.label\" [showValidationMsg]=\"scheme.showValidationMsg\"\n          [disabled]=\"scheme.disabled||(scheme.disabledIf|functionCaller2:form.value:(scheme.field|toAny))\" />\n        }\n        }\n\n      </div>\n      }\n\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn ) {\n        <app-btn [text]=\"submitBtnText\" actionType=\"submit\" group=\"submit\" [form]=\"form\" (mclick)=\"submit()\" />\n        }\n        @if (submitBtnTemplate) {\n\n        <ng-container *ngTemplateOutlet=\"submitBtnTemplate\"></ng-container>\n\n        }\n      </div>\n    </div>\n  </form>\n</loader>"]}
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  AsyncValidatorFn,\n  FormGroup,\n  FormsModule,\n  ValidatorFn,\n} from '@angular/forms';\nimport { cloneDeep } from 'lodash-es';\nimport { debounceTime } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport {\n  InputBasicComponent,\n  OptionLabelType,\n} 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  CommonModule,\n  NgSwitchDefault,\n  NgTemplateOutlet,\n} from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { Observable, Subscription } from 'rxjs';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { InputType } from '../../models/index.model';\nimport { IconType } from '../btn/btn.model';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    BtnComponent,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: TFormGroup[K];\n  } = any,\n> implements OnInit\n{\n  @Input() keyField: 'field' | 'label' = 'field';\n\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  @Output('submissionResponse') _submissionResponse = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  @Input() submitBtnText: string = 'Submit';\n  @Input() submitBtnTemplate: TemplateRef<any>;\n  @Input() submitSuccessText: string = 'Save';\n  @Input() showSubmitBtn: boolean = true;\n\n  @Input() gridStyle: number | 'auto';\n  @Input() gridMDStyle: number | 'auto';\n  @Input() gridLGStyle: number | 'auto';\n  @Input() gridXXLStyle: number | 'auto';\n\n  @Input() formGridClass: string;\n  @Input() useLoader: boolean;\n  @Input() loading: boolean;\n\n  @Input({ required: true }) form: FormGroup<TFormGroup>;\n  formSchema: IFormSchema<TFormGroup>[];\n  submissionResponse: any;\n  @Input({ required: true, alias: 'formSchema' }) set _formSchema(\n    v: IFormSchema<TFormGroup>[],\n  ) {\n    this.init(cloneDeep(v.filter((x) => x)));\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form?.disable({ emitEvent: false });\n    else this.form?.enable();\n\n    setTimeout(() => {\n      if (v) this.form?.disable({ emitEvent: false });\n      else this.form?.enable();\n    }, 500);\n  }\n  optionsMap: IFormOptions = {};\n  cellCountryCode3s: IFormOptions = {};\n  subs: { fieldName: string; sub: Subscription }[] = [];\n  // miscIndex: TMiscIndex;\n\n  constructor(public uS: UtilityService) {}\n\n  ngOnInit(): void {}\n  ngOnDestroy(): void {\n    this.subs.forEach((s) => {\n      s?.sub?.unsubscribe();\n    });\n    this.subs = [];\n  }\n  init(schema: IFormSchema[]) {\n    // debugger;\n    this.ngOnDestroy();\n    // debugger;\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    this.formSchema = schema;\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit)\n          scheme.onChangeFunc(\n            this.form.getRawValue(),\n            this.form.getRawValue()[scheme.field],\n            this,\n          );\n  }\n  handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.uS.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (\n      scheme.autoPickValueField == null &&\n      (!scheme.valueField || !scheme.labelField)\n    )\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.onChangeFunc) {\n      if (scheme.debug) debugger;\n      const sub = this.form?.controls[scheme.field?.toString()]?.valueChanges\n        .pipe(debounceTime(0))\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.form.getRawValue(), r, this);\n        });\n      this.subs.push({ sub: sub, fieldName: scheme.field?.toString() });\n    }\n  }\n  detachFormScheme(schemeIndex?: number, fieldName?: string) {\n    this.subs\n      .find(\n        (x) =>\n          x.fieldName == this.formSchema[schemeIndex]?.field ||\n          x.fieldName == fieldName,\n      )\n      ?.sub?.unsubscribe();\n  }\n  amendFormScheme = (\n    fieldName: keyof TFormGroup,\n    formScheme: Partial<IFormSchema<TFormGroup>>,\n  ) => {\n    // debugger;\n    const ind = this.formSchema.findIndex((x) => x.field == fieldName);\n    if (ind > -1) {\n      this.formSchema[ind] = {\n        ...this.formSchema[ind],\n        ...(formScheme as any),\n      };\n      // debugger;\n      // this.formSchema[ind].options = formScheme.options;\n      // debugger;\n    }\n  };\n\n  mchangeEmitter() {\n    this.mchange.emit(this.form.getRawValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    const ind = this.formSchema.findIndex((x) => x.field == fieldName);\n    return ind > -1 ? this.formSchema[ind] : null;\n  };\n  addToFormSchema(formScheme: IFormSchema) {\n    this.removeFromFormSchema(formScheme.field?.toString());\n    const _fs = cloneDeep(formScheme);\n    this.handleFormScheme(_fs);\n    this.formSchema.push(_fs);\n  }\n  removeFromFormSchema(fieldName: string) {\n    const ind = this.formSchema.findIndex((x) => x.field == fieldName);\n    this.detachFormScheme(ind, fieldName);\n    if (ind > -1) {\n      if (this.formSchema[ind]?.onRemoveFunc)\n        this.formSchema[ind]?.onRemoveFunc(\n          this.form.getRawValue() as any,\n          this.form.controls[fieldName],\n          this,\n        );\n      this.formSchema.splice(ind, 1);\n    }\n  }\n  setOptionLabel($event: any, scheme: IFormSchema) {\n    scheme.selectedOptionLabel = $event;\n  }\n  async submit() {\n    if (this.submitFunc) {\n      this.loading = true;\n      this.onSubmit.emit(this.form.value);\n      try {\n        this.submissionResponse = await this.submitFunc(this.form.value);\n        this.uS.info(this.submitSuccessText, 1);\n        this._submissionResponse.emit(this.submissionResponse);\n      } catch (error) {\n        this.uS.info(error, 0);\n      }\n      this.loading = false;\n    } else this.onSubmit.emit(this.form.value);\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n  TOptionLabelType = OptionLabelType,\n  TInputType = InputType,\n> {\n  asyncValidators?: AsyncValidatorFn[];\n  autoPickValueField?: boolean;\n  checked?: boolean;\n  clearOnDisable?: boolean;\n  cls?: string;\n  countryCode3?: string;\n  children?: IFormSchema<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  isRequired?: boolean;\n  isSearchField?: boolean;\n  label?: string;\n  labelField?: string;\n  labelType?: TOptionLabelType;\n  optionLabelFormatter?: (row) => string;\n  max?: number;\n  min?: number;\n  noFormat?: boolean;\n  optionFormatter?: (item: any) => string;\n  options?: any[];\n  optionsAsync?: Observable<any[]> | Promise<any[]>;\n  optionsInitFunc?: Observable<any[]>;\n  optionsKey?: string;\n  placeholder?: string;\n  searchFunc?: (...args) => any;\n  setAsCountryCode3?: boolean;\n  showValidation?: boolean;\n  showValidationIcon?: boolean;\n  templateValue?: any;\n  type?: TInputType;\n  validators?: ValidatorFn[];\n  value?: any;\n  valueField?: string;\n  optionsFunc?: (...val: any) => Observable<any[]>;\n  triggerOnChangeOnInit?: boolean;\n  formatter?: (\n    row: { [K in keyof TFormGroup]: any },\n    fieldName: keyof TFormGroup,\n  ) => string;\n  extra?: any;\n  onChangeFunc?: (\n    row: { [K in keyof TFormGroup]?: TFormGroup[K]['value'] },\n    cellValue?: any,\n    _this?: FormGeneratorComponent<TFormGroup>,\n  ) => Observable<any[]> | any;\n  onRemoveFunc?: (\n    row: { [K in keyof TFormGroup]: TFormGroup[K]['value'] },\n    cell?: any,\n    _this?: FormGeneratorComponent<TFormGroup>,\n  ) => any;\n  selectedOptionLabel?: string;\n  stacked?: boolean;\n  debug?: boolean;\n  showValidationMsg?: boolean;\n  dontFormatAsInput?: boolean;\n  showRequiredTag?: boolean;\n  icon?: IconType;\n}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<loader [loading]=\"useLoader && loading\">\n  <form>\n    <div\n      class=\"row row-cols-{{gridStyle}} row-cols-md-{{gridMDStyle}} row-cols-lg-{{gridLGStyle}} row-cols-xxl-{{gridXXLStyle}} align-items-center {{formGridClass}}\">\n      @for (scheme of formSchema; track uS.trackByID($index, scheme)) {\n\n      @if (!scheme.hidden && (!scheme.hideIfFunc || !scheme.hideIfFunc(form.value))) {\n      <div class=\"col {{scheme.cls}} \">\n\n        @switch (true) {\n        @case (scheme.type == 'tel') {\n\n        <app-phone-number [form]=\"scheme.form||form\" [label]=\"scheme.label\" [clearOnDisable]=\"scheme.clearOnDisable\"\n          [stacked]=\"scheme.stacked\" [name]=\"scheme.field\" [showLabel]=\"false\" [noFormat]=\"scheme.noFormat\"\n          [debug]=\"scheme.debug\" (mchange)=\"mchangeEmitter()\" [showValidation]=\"scheme.showValidation\"\n          [autoPickValueField]=\"scheme.autoPickValueField\" [showRequiredTag]=\"scheme.showRequiredTag\"\n          [showValidationMsg]=\"scheme.showValidationMsg\" [showValidationIcon]=\"scheme.showValidationIcon\"\n          [countryCode3]=\"cellCountryCode3s[scheme.getCountryCode3Key] || scheme.countryCode3\"\n          [disabled]=\"scheme.disabled||(scheme.disabledIf|functionCaller2:form.value:(scheme.field|toAny))\" />\n\n        }\n        @case (scheme.type == 'autocomplete') {\n\n        <app-autocomplete [form]=\"scheme.form||form\" [label]=\"scheme.label\" [clearOnDisable]=\"scheme.clearOnDisable\"\n          [stacked]=\"scheme.stacked\" [labelField]=\"scheme.labelField\" [noFormat]=\"scheme.noFormat\"\n          [labelType]=\"scheme.labelType\" (mchange)=\"mchangeEmitter()\"\n          (mSelectedOptionLabel)=\"setOptionLabel($event,scheme)\" [name]=\"scheme.field\" [debug]=\"scheme.debug\"\n          [showRequiredTag]=\"scheme.showRequiredTag\" [optionFormatter]=\"scheme.optionFormatter\"\n          [valueField]=\"scheme.valueField\" [optionsFunc]=\"scheme.optionsFunc\"\n          [showValidationMsg]=\"scheme.showValidationMsg\" [autoPickValueField]=\"scheme.autoPickValueField\"\n          [options]=\" scheme.options||optionsMap[scheme.field|toAny]\" [hint]=\"scheme.hint\"\n          [disabled]=\"scheme.disabled||(scheme.disabledIf|functionCaller2: form.value:(scheme.field|toAny))\" />\n\n        }\n        @default {\n\n        <app-input-basic [noFormat]=\"scheme.noFormat\" [name]=\"scheme.field\" [form]=\"scheme.form||form\"\n          [clearOnDisable]=\"scheme.clearOnDisable\" [type]=\"scheme.type\" [valueField]=\"scheme.valueField\"\n          [autoPickValueField]=\"scheme.autoPickValueField\" [stacked]=\"scheme.stacked\" [labelType]=\"scheme.labelType\"\n          [checked]=\"scheme.checked\" [showValidation]=\"!!scheme.asyncValidators\"\n          [showValidationIcon]=\"!!scheme.asyncValidators\" [debug]=\"scheme.debug\" (mchange)=\"mchangeEmitter()\"\n          [showRequiredTag]=\"scheme.showRequiredTag\" [labelField]=\"scheme.labelField\"\n          [optionFormatter]=\"scheme.optionFormatter\" (mSelectedOptionLabel)=\"setOptionLabel($event,scheme)\"\n          [options]=\"scheme.options||optionsMap[scheme.field|toAny]\" [decimalPoints]=\"scheme.decimalPoints\"\n          [hint]=\"scheme.hint\" [max]=\"scheme.max\" [min]=\"scheme.min\" [placeholder]=\"scheme.placeholder\"\n          [label]=\"scheme.label\" [showValidationMsg]=\"scheme.showValidationMsg\"\n          [disabled]=\"scheme.disabled||(scheme.disabledIf|functionCaller2:form.value:(scheme.field|toAny))\" />\n        }\n        }\n\n      </div>\n      }\n\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn ) {\n        <app-btn [text]=\"submitBtnText\" actionType=\"submit\" group=\"submit\" [form]=\"form\" (mclick)=\"submit()\" />\n        }\n        @if (submitBtnTemplate) {\n\n        <ng-container *ngTemplateOutlet=\"submitBtnTemplate\"></ng-container>\n\n        }\n      </div>\n    </div>\n  </form>\n</loader>"]}
|