ets-fe-ng-sdk 17.0.290 → 17.0.291
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.base.component.mjs +2 -2
- package/esm2022/lib/Shared/components/form-generator/form-generator.component.mjs +5 -5
- package/fesm2022/ets-fe-ng-sdk.mjs +5 -5
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Services/utility.service.d.ts +1 -1
- package/lib/Shared/components/btn/btn.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -32,7 +32,7 @@ export class BaseFormGenerator {
|
|
|
32
32
|
this.formSchemaMap.update((formSchemaMap) => {
|
|
33
33
|
const newFormSchemaMap = {};
|
|
34
34
|
for (const key in formSchemaMap) {
|
|
35
|
-
if (Object.prototype.hasOwnProperty.call(
|
|
35
|
+
if (Object.prototype.hasOwnProperty.call(formSchemaMap, key)) {
|
|
36
36
|
newFormSchemaMap[key] = map(formSchemaMap[key]);
|
|
37
37
|
}
|
|
38
38
|
}
|
|
@@ -47,4 +47,4 @@ export class BaseFormGenerator {
|
|
|
47
47
|
});
|
|
48
48
|
}
|
|
49
49
|
}
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# 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":"AAAA,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAIrE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AAInE,MAAM,OAAgB,iBAAiB;IAQrC;QAPA,kBAAa,GAAG,MAAM,CAAuC,EAAE,CAAC,CAAC;QACjE,eAAU,GAAG,QAAQ,CAAoB,GAAG,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACrG,SAAI,GAA0C,EAAE,CAAC;QAE1C,mBAAc,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QACxC,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAGrC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7B,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,SAAS;QACP,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YACrC,CAAC,EAAE,WAAW,EAAE,CAAC;QACnB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;IACjB,CAAC;IAES,eAAe,CAAC,OAA0B;QAClD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;IACzD,CAAC;IAES,iBAAiB,CAAC,KAAa,EAAE,MAAgC;QACzE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,aAAa,EAAE,EAAE;YAC1C,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;YACtC,2BAA2B;YAC3B,OAAO,EAAE,GAAG,aAAa,EAAE,CAAC,KAAY,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,QAAQ,EAAE,GAAG,MAAM,EAAE,EAAE,CAAC;YAC7F,4HAA4H;QAC9H,CAAC,CAAC,CAAC;IACL,CAAC;IACS,oBAAoB,CAAC,GAAoD;QACjF,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,aAAa,EAAE,EAAE;YAC1C,MAAM,gBAAgB,GAAyB,EAAE,CAAC;YAClD,KAAK,MAAM,GAAG,IAAI,aAAa,EAAE;gBAC/B,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC,EAAE;oBAC5D,gBAAgB,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;iBACjD;aACF;YACD,OAAO,gBAAgB,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3B,CAAC;IAES,iBAAiB,CAAC,KAAa;QACvC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,aAAa,EAAE,EAAE;YAC1C,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;YAC5B,OAAO,aAAa,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC;CACF","sourcesContent":["import { DestroyRef, computed, inject, signal } 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';\n\nexport abstract class BaseFormGenerator<TFormGroup extends IObjectLiteral, TBaseFormSchema extends { field?: any } = any> {\n  formSchemaMap = signal<{ [field: string]: TBaseFormSchema }>({});\n  formSchema = computed<TBaseFormSchema[]>(() => Object.values(this.formSchemaMap()).filter((x) => x));\n  subs: { [fieldName: string]: Subscription } = {};\n\n  public utilityService = inject(UtilityService);\n  public destroyRef = inject(DestroyRef);\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    this.formSchemaMap.set((schemas || []).toMap('field'));\n  }\n\n  protected _updateFormSchema(field: string, scheme: Partial<TBaseFormSchema>) {\n    this.formSchemaMap.update((formSchemaMap) => {\n      const existing = formSchemaMap[field];\n      // if (!existing) debugger;\n      return { ...formSchemaMap, [field as any]: !existing ? scheme : { ...existing, ...scheme } };\n      // return !sch ? { ...formSchemaMap, [field as any]: scheme } : { ...formSchemaMap, [field as any]: { ...sch, ...scheme } };\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] = map(formSchemaMap[key]);\n        }\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  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  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  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?: (row: { [K in keyof TFormGroup]?: TFormGroup[K]['value'] }, cellValue?: any, component?: Component) => Observable<any[]> | any;\n  onRemoveFunc?: (row: { [K in keyof TFormGroup]: TFormGroup[K]['value'] }, cell?: any, component?: Component) => any;\n  selectedOptionLabel?: string;\n  stacked?: boolean;\n  debug?: boolean;\n  showValidationMsg?: boolean;\n  dontFormatAsInput?: boolean;\n  showRequiredTag?: boolean;\n  tableFormatter?: (val: any) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  icon?: IconType;\n}\n"]}
|
|
@@ -115,10 +115,10 @@ export class FormGeneratorComponent extends BaseFormGenerator {
|
|
|
115
115
|
}
|
|
116
116
|
}
|
|
117
117
|
handleOptionsFetched(scheme, options$) {
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
118
|
+
options$.subscribe((r) => {
|
|
119
|
+
// scheme.options = r;
|
|
120
|
+
this.updateFormSchema(scheme.field, { options: r });
|
|
121
|
+
});
|
|
122
122
|
}
|
|
123
123
|
detachFormScheme(fieldName) {
|
|
124
124
|
this.subs[fieldName]?.unsubscribe();
|
|
@@ -206,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
|
|
|
206
206
|
type: Input,
|
|
207
207
|
args: ['isShow']
|
|
208
208
|
}] } });
|
|
209
|
-
//# 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 { Component, EventEmitter, Input, Output, TemplateRef, computed, inject, input, signal } from '@angular/core';\nimport { AbstractControl, FormGroup, FormsModule } from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { debounceTime, last, tap } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable } from 'rxjs';\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    RichTextEditorRFComponent,\n    BtnComponent,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> }> extends BaseFormGenerator<\n  TFormGroup,\n  IFormSchema<TFormGroup>\n> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  presetValueForSingleOption = input(false);\n  isCreate = input<boolean>();\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  submitBtnText = input('Submit');\n  submitBtnTemplate = input<TemplateRef<any>>();\n  submitSuccessText = input('Saved successfully');\n  showSubmitBtn = input(true);\n\n  gridStyle = input<number | 'auto'>();\n  gridMDStyle = input<number | 'auto'>();\n  gridLGStyle = input<number | 'auto'>();\n  gridXXLStyle = input<number | 'auto'>();\n\n  formGridClass = input<string>();\n  useLoader = input<boolean>();\n  loading = input<boolean>();\n\n  _loading = signal<boolean>(false);\n\n  computedLoading = computed(() => (this.useLoader() ? this.loading() || this._loading() : false));\n\n  @Input() form: FormGroup<TFormGroup>;\n  submissionResponse: any;\n  @Input({ required: true, alias: 'formSchema' }) set _formSchema(v: IFormSchema<TFormGroup>[]) {\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 = signal<IFormOptions>({});\n  // formVal = computed(() => this.form?.getRawValue());\n\n  computedFormSchema = computed<IFormSchema<TFormGroup>[]>(() => {\n    const formSchema = this.formSchema() || [],\n      presetValueForSingleOption = this.presetValueForSingleOption(),\n      isCreate = this.isCreate(),\n      ret: IFormSchema<TFormGroup>[] = [];\n    formSchema.forEach((scheme) => {\n      if (!scheme.hidden) {\n        if (isCreate) scheme.presetValue = scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  init(schema: IFormSchema<TFormGroup>[]) {\n    // debugger;\n    this.onDestroy();\n    this._setFormSchemas(schema || []);\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit) scheme.onChangeFunc(this.form.getRawValue(), this.form.getRawValue()[scheme.field?.toString()], this);\n  }\n\n  handleFormScheme(scheme: IFormSchema<TFormGroup>) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (this.formService.config.showValidationMessagesByDefault)\n      if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField)) scheme.autoPickValueField = true;\n    if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0)).subscribe((r) => {\n        scheme.onChangeFunc(this.form.getRawValue(), r, this);\n      });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: IFormSchema<TFormGroup>, options$: Observable<any[]>) {\n    // options$.subscribe((r) => {\n    //   // scheme.options = r;\n    //   this.updateFormSchema(scheme.field, { options: r });\n    // });\n  }\n\n  detachFormScheme(fieldName?: keyof TFormGroup) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  protected mchangeEmitter() {\n    this.mchange.emit(this.form.getRawValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    return this.formSchemaMap()[fieldName as string];\n  };\n\n  addToFormSchema(formScheme: IFormSchema<TFormGroup>) {\n    this.removeFromFormSchema(formScheme.field);\n    this.handleFormScheme(formScheme);\n  }\n\n  updateFormSchema(fieldName: keyof TFormGroup, scheme: Partial<IFormSchema<TFormGroup>>) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n  updateAllFormSchema(map: (formField: IFormSchema<TFormGroup>) => IFormSchema<TFormGroup>) {\n    return super._updateAllFormSchema(map);\n  }\n\n  removeFromFormSchema(fieldName: keyof TFormGroup) {\n    this.detachFormScheme(fieldName);\n    const onRemove = this.formSchemaMap()[fieldName as string]?.onRemoveFunc;\n    if (onRemove) onRemove(this.form.getRawValue() as any, this.form.controls[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.form.getRawValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        this.utilityService.info(this.submitSuccessText(), 1);\n        this._submissionResponse.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.form.getRawValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<loader [loading]=\"computedLoading()\">\n  <form>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{ gridLGStyle() }} row-cols-xxl-{{\n        gridXXLStyle()\n      }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.id) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"scheme.form || form\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [name]=\"scheme.field\"\n                [noFormat]=\"scheme.noFormat\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showValidation]=\"scheme.showValidation\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [showValidationIcon]=\"scheme.showValidationIcon\"\n                [countryCode3]=\"scheme.countryCode3\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: form.value : (scheme.field | toAny))\" />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <app-autocomplete\n                [form]=\"scheme.form || form\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [presetValue]=\"scheme.presetValue\"\n                [labelField]=\"scheme.labelField\"\n                [noFormat]=\"scheme.noFormat\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                [valueField]=\"scheme.valueField\"\n                [optionsFunc]=\"scheme.optionsFunc\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: form.value : (scheme.field | toAny))\" />\n            }\n            @case (scheme.type == 'richtext') {\n              <rich-text-editor-rf\n                [form]=\"scheme.form || form\"\n                [label]=\"scheme.label!\"\n                [clearOnDisable]=\"scheme.clearOnDisable!\"\n                [stacked]=\"scheme.stacked\"\n                [labelField]=\"scheme.labelField!\"\n                [noFormat]=\"scheme.noFormat!\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug!\"\n                [showRequiredTag]=\"scheme.showRequiredTag!\"\n                [optionFormatter]=\"scheme.optionFormatter!\"\n                [valueField]=\"scheme.valueField!\"\n                [optionsFunc]=\"scheme.optionsFunc!\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField!\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint!\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf! | functionCaller2: form.value : (scheme.field | toAny))\" />\n            }\n            @default {\n              <app-input-basic\n                [noFormat]=\"scheme.noFormat\"\n                [name]=\"scheme.field\"\n                [form]=\"scheme.form || form\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [type]=\"scheme.type\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"!!scheme.asyncValidators\"\n                [showValidationIcon]=\"!!scheme.asyncValidators\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [labelField]=\"scheme.labelField\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [decimalPoints]=\"scheme.decimalPoints\"\n                [hint]=\"scheme.hint\"\n                [max]=\"scheme.max\"\n                [min]=\"scheme.min\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: form.value : (scheme.field | toAny))\" />\n            }\n          }\n        </div>\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn()) {\n          <app-btn [text]=\"submitBtnText()\" actionType=\"submit\" group=\"submit\" [form]=\"form\" (mclick)=\"submit(submitBtn)\" #submitBtn />\n        }\n        @if (submitBtnTemplate()) {\n          <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n        }\n      </div>\n    </div>\n  </form>\n</loader>\n"]}
|
|
209
|
+
//# 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 { Component, EventEmitter, Input, Output, TemplateRef, computed, inject, input, signal } from '@angular/core';\nimport { AbstractControl, FormGroup, FormsModule } from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { debounceTime, last, tap } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable } from 'rxjs';\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    RichTextEditorRFComponent,\n    BtnComponent,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> }> extends BaseFormGenerator<\n  TFormGroup,\n  IFormSchema<TFormGroup>\n> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  presetValueForSingleOption = input(false);\n  isCreate = input<boolean>();\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  submitBtnText = input('Submit');\n  submitBtnTemplate = input<TemplateRef<any>>();\n  submitSuccessText = input('Saved successfully');\n  showSubmitBtn = input(true);\n\n  gridStyle = input<number | 'auto'>();\n  gridMDStyle = input<number | 'auto'>();\n  gridLGStyle = input<number | 'auto'>();\n  gridXXLStyle = input<number | 'auto'>();\n\n  formGridClass = input<string>();\n  useLoader = input<boolean>();\n  loading = input<boolean>();\n\n  _loading = signal<boolean>(false);\n\n  computedLoading = computed(() => (this.useLoader() ? this.loading() || this._loading() : false));\n\n  @Input() form: FormGroup<TFormGroup>;\n  submissionResponse: any;\n  @Input({ required: true, alias: 'formSchema' }) set _formSchema(v: IFormSchema<TFormGroup>[]) {\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 = signal<IFormOptions>({});\n  // formVal = computed(() => this.form?.getRawValue());\n\n  computedFormSchema = computed<IFormSchema<TFormGroup>[]>(() => {\n    const formSchema = this.formSchema() || [],\n      presetValueForSingleOption = this.presetValueForSingleOption(),\n      isCreate = this.isCreate(),\n      ret: IFormSchema<TFormGroup>[] = [];\n    formSchema.forEach((scheme) => {\n      if (!scheme.hidden) {\n        if (isCreate) scheme.presetValue = scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  init(schema: IFormSchema<TFormGroup>[]) {\n    // debugger;\n    this.onDestroy();\n    this._setFormSchemas(schema || []);\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit) scheme.onChangeFunc(this.form.getRawValue(), this.form.getRawValue()[scheme.field?.toString()], this);\n  }\n\n  handleFormScheme(scheme: IFormSchema<TFormGroup>) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (this.formService.config.showValidationMessagesByDefault)\n      if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField)) scheme.autoPickValueField = true;\n    if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0)).subscribe((r) => {\n        scheme.onChangeFunc(this.form.getRawValue(), r, this);\n      });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: IFormSchema<TFormGroup>, options$: Observable<any[]>) {\n    options$.subscribe((r) => {\n      // scheme.options = r;\n      this.updateFormSchema(scheme.field, { options: r });\n    });\n  }\n\n  detachFormScheme(fieldName?: keyof TFormGroup) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  protected mchangeEmitter() {\n    this.mchange.emit(this.form.getRawValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    return this.formSchemaMap()[fieldName as string];\n  };\n\n  addToFormSchema(formScheme: IFormSchema<TFormGroup>) {\n    this.removeFromFormSchema(formScheme.field);\n    this.handleFormScheme(formScheme);\n  }\n\n  updateFormSchema(fieldName: keyof TFormGroup, scheme: Partial<IFormSchema<TFormGroup>>) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n  updateAllFormSchema(map: (formField: IFormSchema<TFormGroup>) => IFormSchema<TFormGroup>) {\n    return super._updateAllFormSchema(map);\n  }\n\n  removeFromFormSchema(fieldName: keyof TFormGroup) {\n    this.detachFormScheme(fieldName);\n    const onRemove = this.formSchemaMap()[fieldName as string]?.onRemoveFunc;\n    if (onRemove) onRemove(this.form.getRawValue() as any, this.form.controls[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.form.getRawValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        this.utilityService.info(this.submitSuccessText(), 1);\n        this._submissionResponse.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.form.getRawValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<loader [loading]=\"computedLoading()\">\n  <form>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{ gridLGStyle() }} row-cols-xxl-{{\n        gridXXLStyle()\n      }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.id) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"scheme.form || form\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [name]=\"scheme.field\"\n                [noFormat]=\"scheme.noFormat\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showValidation]=\"scheme.showValidation\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [showValidationIcon]=\"scheme.showValidationIcon\"\n                [countryCode3]=\"scheme.countryCode3\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: form.value : (scheme.field | toAny))\" />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <app-autocomplete\n                [form]=\"scheme.form || form\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [presetValue]=\"scheme.presetValue\"\n                [labelField]=\"scheme.labelField\"\n                [noFormat]=\"scheme.noFormat\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                [valueField]=\"scheme.valueField\"\n                [optionsFunc]=\"scheme.optionsFunc\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: form.value : (scheme.field | toAny))\" />\n            }\n            @case (scheme.type == 'richtext') {\n              <rich-text-editor-rf\n                [form]=\"scheme.form || form\"\n                [label]=\"scheme.label!\"\n                [clearOnDisable]=\"scheme.clearOnDisable!\"\n                [stacked]=\"scheme.stacked\"\n                [labelField]=\"scheme.labelField!\"\n                [noFormat]=\"scheme.noFormat!\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug!\"\n                [showRequiredTag]=\"scheme.showRequiredTag!\"\n                [optionFormatter]=\"scheme.optionFormatter!\"\n                [valueField]=\"scheme.valueField!\"\n                [optionsFunc]=\"scheme.optionsFunc!\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField!\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint!\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf! | functionCaller2: form.value : (scheme.field | toAny))\" />\n            }\n            @default {\n              <app-input-basic\n                [noFormat]=\"scheme.noFormat\"\n                [name]=\"scheme.field\"\n                [form]=\"scheme.form || form\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [type]=\"scheme.type\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"!!scheme.asyncValidators\"\n                [showValidationIcon]=\"!!scheme.asyncValidators\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [labelField]=\"scheme.labelField\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [decimalPoints]=\"scheme.decimalPoints\"\n                [hint]=\"scheme.hint\"\n                [max]=\"scheme.max\"\n                [min]=\"scheme.min\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: form.value : (scheme.field | toAny))\" />\n            }\n          }\n        </div>\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn()) {\n          <app-btn [text]=\"submitBtnText()\" actionType=\"submit\" group=\"submit\" [form]=\"form\" (mclick)=\"submit(submitBtn)\" #submitBtn />\n        }\n        @if (submitBtnTemplate()) {\n          <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"></ng-container>\n        }\n      </div>\n    </div>\n  </form>\n</loader>\n"]}
|
|
@@ -11891,7 +11891,7 @@ class BaseFormGenerator {
|
|
|
11891
11891
|
this.formSchemaMap.update((formSchemaMap) => {
|
|
11892
11892
|
const newFormSchemaMap = {};
|
|
11893
11893
|
for (const key in formSchemaMap) {
|
|
11894
|
-
if (Object.prototype.hasOwnProperty.call(
|
|
11894
|
+
if (Object.prototype.hasOwnProperty.call(formSchemaMap, key)) {
|
|
11895
11895
|
newFormSchemaMap[key] = map(formSchemaMap[key]);
|
|
11896
11896
|
}
|
|
11897
11897
|
}
|
|
@@ -12006,10 +12006,10 @@ class FormGeneratorComponent extends BaseFormGenerator {
|
|
|
12006
12006
|
}
|
|
12007
12007
|
}
|
|
12008
12008
|
handleOptionsFetched(scheme, options$) {
|
|
12009
|
-
|
|
12010
|
-
|
|
12011
|
-
|
|
12012
|
-
|
|
12009
|
+
options$.subscribe((r) => {
|
|
12010
|
+
// scheme.options = r;
|
|
12011
|
+
this.updateFormSchema(scheme.field, { options: r });
|
|
12012
|
+
});
|
|
12013
12013
|
}
|
|
12014
12014
|
detachFormScheme(fieldName) {
|
|
12015
12015
|
this.subs[fieldName]?.unsubscribe();
|