ets-fe-ng-sdk 17.0.350 → 17.0.352

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.
@@ -1,4 +1,4 @@
1
- import { Component } from '@angular/core';
1
+ import { Component, computed, inject } from '@angular/core';
2
2
  import { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';
3
3
  import { FormsModule } from '@angular/forms';
4
4
  import { FormGeneratorComponent } from '../form-generator.component';
@@ -13,8 +13,7 @@ import { TextCase2Component } from '../../text-case-2/text-case-2.component';
13
13
  import { Pipe } from '@angular/core';
14
14
  import * as i0 from "@angular/core";
15
15
  import * as i1 from "../../input/input.service";
16
- import * as i2 from "@angular/common";
17
- import * as i3 from "@angular/forms";
16
+ import * as i2 from "@angular/forms";
18
17
  export class ListOptionFinderPipe {
19
18
  transform(value, options, valueField, labelField, labelType, optionFormatter) {
20
19
  const formattedOptions = this.iS.optionsFormatter(options, valueField, optionFormatter, labelType, labelField, false);
@@ -33,6 +32,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
33
32
  export class FormGeneratedValueComponent extends FormGeneratorComponent {
34
33
  constructor() {
35
34
  super();
35
+ this.listOptionFinderPipe = inject(ListOptionFinderPipe);
36
+ this.computedListValue = computed(() => {
37
+ const fv = this.formValue() || {}, optionsMap = this.optionsMap();
38
+ return this.computedFormSchema().map((f) => ({
39
+ ...f,
40
+ formattedValue: f.type == 'autocomplete'
41
+ ? this.listOptionFinderPipe.transform(fv[f.field], f.options || optionsMap[f.field], f.valueField, f.labelField, f.labelType, f.optionFormatter)
42
+ : this.formatValue(f, fv[f.field]),
43
+ }));
44
+ });
36
45
  this.formatValue = (item, value) => {
37
46
  if (item.formatter)
38
47
  return item.formatter(this.formValue(), item.field);
@@ -53,7 +62,7 @@ export class FormGeneratedValueComponent extends FormGeneratorComponent {
53
62
  };
54
63
  }
55
64
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: FormGeneratedValueComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
56
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: FormGeneratedValueComponent, isStandalone: true, selector: "form-generated-value", usesInheritance: true, ngImport: i0, template: "<loader [loading]=\"computedLoading()\">\n <form>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedFormSchema(); track scheme.field) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n #inputTag />\n }\n @case (scheme.type == 'autocomplete') {\n <ng-container\n *ngTemplateOutlet=\"\n labelValue;\n context: {\n $implicit: {\n scheme,\n value:\n formValue()[scheme.field | toAny]\n | listOptionFinder\n : scheme.options || optionsMap[scheme.field | toAny]\n : scheme.valueField\n : scheme.labelField\n : scheme.labelType\n : scheme.optionFormatter\n }\n }\n \"></ng-container>\n }\n @default {\n <ng-container\n *ngTemplateOutlet=\"\n labelValue;\n context: { $implicit: { scheme, value: formValue()[scheme.field | toAny] } }\n \" />\n }\n }\n </div>\n }\n </div>\n </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n <div class=\"\">\n <div class=\"text-primary\">\n {{ obj.scheme.label }}\n </div>\n <div class=\" \">\n {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n </div>\n </div>\n</ng-template>\n", styles: [":host ::ng-deep input:not([type=checkbox]),:host ::ng-deep .control-bg-gray.form-control,:host ::ng-deep textarea{border:none!important;background-color:transparent!important;padding:0!important;height:auto!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "pipe", type: FunctionCaller2, name: "functionCaller2" }, { kind: "pipe", type: ListOptionFinderPipe, name: "listOptionFinder" }, { kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "component", type: PhoneNumberComponent, selector: "app-phone-number", inputs: ["showLabel", "countryCode3", "config"], outputs: ["onCountrySelect"] }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }, { kind: "pipe", type: ValueOrXPipe, name: "valueOrX" }] }); }
65
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: FormGeneratedValueComponent, isStandalone: true, selector: "form-generated-value", providers: [ListOptionFinderPipe], usesInheritance: true, ngImport: i0, template: "<loader [loading]=\"computedLoading()\">\n <form>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedListValue(); track scheme.field) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n #inputTag />\n } \n @default {\n <div class=\"\">\n <div class=\"text-primary\">\n {{ scheme.label }}\n </div>\n <div class=\" \">\n {{ scheme.formattedValue | valueOrX: '-' }}\n </div>\n </div>\n }\n }\n </div>\n }\n </div>\n </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n <div class=\"\">\n <div class=\"text-primary\">\n {{ obj.scheme.label }}\n </div>\n <div class=\" \">\n {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n </div>\n </div>\n</ng-template>\n", styles: [":host ::ng-deep input:not([type=checkbox]),:host ::ng-deep .control-bg-gray.form-control,:host ::ng-deep textarea{border:none!important;background-color:transparent!important;padding:0!important;height:auto!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "pipe", type: FunctionCaller2, name: "functionCaller2" }, { kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "component", type: PhoneNumberComponent, selector: "app-phone-number", inputs: ["showLabel", "countryCode3", "config"], outputs: ["onCountrySelect"] }, { kind: "pipe", type: ValueOrXPipe, name: "valueOrX" }] }); }
57
66
  }
58
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: FormGeneratedValueComponent, decorators: [{
59
68
  type: Component,
@@ -75,6 +84,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
75
84
  ToAnyPipe,
76
85
  ValidationMessageComponent,
77
86
  ValueOrXPipe,
78
- ], template: "<loader [loading]=\"computedLoading()\">\n <form>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedFormSchema(); track scheme.field) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n #inputTag />\n }\n @case (scheme.type == 'autocomplete') {\n <ng-container\n *ngTemplateOutlet=\"\n labelValue;\n context: {\n $implicit: {\n scheme,\n value:\n formValue()[scheme.field | toAny]\n | listOptionFinder\n : scheme.options || optionsMap[scheme.field | toAny]\n : scheme.valueField\n : scheme.labelField\n : scheme.labelType\n : scheme.optionFormatter\n }\n }\n \"></ng-container>\n }\n @default {\n <ng-container\n *ngTemplateOutlet=\"\n labelValue;\n context: { $implicit: { scheme, value: formValue()[scheme.field | toAny] } }\n \" />\n }\n }\n </div>\n }\n </div>\n </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n <div class=\"\">\n <div class=\"text-primary\">\n {{ obj.scheme.label }}\n </div>\n <div class=\" \">\n {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n </div>\n </div>\n</ng-template>\n", styles: [":host ::ng-deep input:not([type=checkbox]),:host ::ng-deep .control-bg-gray.form-control,:host ::ng-deep textarea{border:none!important;background-color:transparent!important;padding:0!important;height:auto!important}\n"] }]
87
+ ], providers: [ListOptionFinderPipe], template: "<loader [loading]=\"computedLoading()\">\n <form>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedListValue(); track scheme.field) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n #inputTag />\n } \n @default {\n <div class=\"\">\n <div class=\"text-primary\">\n {{ scheme.label }}\n </div>\n <div class=\" \">\n {{ scheme.formattedValue | valueOrX: '-' }}\n </div>\n </div>\n }\n }\n </div>\n }\n </div>\n </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n <div class=\"\">\n <div class=\"text-primary\">\n {{ obj.scheme.label }}\n </div>\n <div class=\" \">\n {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n </div>\n </div>\n</ng-template>\n", styles: [":host ::ng-deep input:not([type=checkbox]),:host ::ng-deep .control-bg-gray.form-control,:host ::ng-deep textarea{border:none!important;background-color:transparent!important;padding:0!important;height:auto!important}\n"] }]
79
88
  }], ctorParameters: () => [] });
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generated-value.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generated-value/form-generated-value.component.ts","../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generated-value/form-generated-value.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAClF,OAAO,EAAmB,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC9D,OAAO,EAAE,sBAAsB,EAAe,MAAM,6BAA6B,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,EAAE,0BAA0B,EAAE,MAAM,6DAA6D,CAAC;AACzG,OAAO,EAAE,qBAAqB,EAAE,MAAM,2CAA2C,CAAC;AAClF,OAAO,EAAE,mBAAmB,EAAmB,MAAM,mCAAmC,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EACL,eAAe,EACf,eAAe,EACf,mBAAmB,EACnB,SAAS,EACT,YAAY,GACb,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAC7E,OAAO,EAAE,IAAI,EAAiB,MAAM,eAAe,CAAC;;;;;AAIpD,MAAM,OAAO,oBAAoB;IAC/B,SAAS,CACP,KAAa,EACb,OAAwB,EACxB,UAAkB,EAClB,UAAkB,EAClB,SAA0B,EAC1B,eAAsC;QAEtC,MAAM,gBAAgB,GAAG,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAC/C,OAAO,EACP,UAAU,EACV,eAAe,EACf,SAAS,EACT,UAAU,EACV,KAAK,CACN,CAAC;QACF,OAAO,gBAAgB,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,EAAE,KAAK,CAAC;IAChE,CAAC;IACD,YAAmB,EAAgB;QAAhB,OAAE,GAAF,EAAE,CAAc;IAAG,CAAC;8GAnB5B,oBAAoB;4GAApB,oBAAoB;;2FAApB,oBAAoB;kBADhC,IAAI;mBAAC,EAAE,IAAI,EAAE,kBAAkB,EAAE,UAAU,EAAE,IAAI,EAAE;;AAgDpD,MAAM,OAAO,2BAIX,SAAQ,sBAAkC;IAC1C;QACE,KAAK,EAAE,CAAC;QAGV,gBAAW,GAAG,CACZ,IAAiB,EACjB,KAAgC,EACL,EAAE;YAC7B,IAAI,IAAI,CAAC,SAAS;gBAAE,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,EAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC1E,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO,KAAK,CAAC;iBAChC,IAAI,IAAI,CAAC,IAAI,IAAI,UAAU,IAAI,IAAI,CAAC,IAAI,IAAI,YAAY;gBAAE,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;iBACtF,IAAI,IAAI,CAAC,IAAI,IAAI,MAAM;gBAC1B,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAe,EAAE,eAAe,CAAC,CAAC;iBAC7E,IAAI,IAAI,CAAC,IAAI,IAAI,gBAAgB;gBACpC,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,KAAe,CAAC,CAAC;iBACtD,IAAI,IAAI,CAAC,OAAO,IAAI,OAAO;gBAAE,OAAO,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,KAAe,CAAC,CAAC;iBACrF,IAAI,IAAI,CAAC,IAAI,IAAI,QAAQ;gBAAE,OAAO,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC;;gBACnF,OAAO,KAAK,CAAC;QACpB,CAAC,CAAC;IAhBF,CAAC;8GAPU,2BAA2B;kGAA3B,2BAA2B,uGCrExC,w8EAoEA,oRDhBI,YAAY,qMACZ,WAAW,mdAEX,eAAe,mDAjCN,oBAAoB,yDAoC7B,eAAe,uHAGf,oBAAoB,uIAGpB,SAAS,yCAET,YAAY;;2FAGH,2BAA2B;kBAzBvC,SAAS;+BACE,sBAAsB,cACpB,IAAI,WAGP;wBACP,qBAAqB;wBACrB,YAAY;wBACZ,YAAY;wBACZ,WAAW;wBACX,eAAe;wBACf,eAAe;wBACf,mBAAmB;wBACnB,oBAAoB;wBACpB,eAAe;wBACf,eAAe;wBACf,gBAAgB;wBAChB,oBAAoB;wBACpB,mBAAmB;wBACnB,kBAAkB;wBAClB,SAAS;wBACT,0BAA0B;wBAC1B,YAAY;qBACb","sourcesContent":["import { Component } from '@angular/core';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { AbstractControl, FormsModule } from '@angular/forms';\nimport { FormGeneratorComponent, IFormSchema } from '../form-generator.component';\nimport { LoaderComponent } from '../../loader/loader.component';\nimport { PhoneNumberComponent } from '../../phone-number/phone-number.component';\nimport { ValidationMessageComponent } from '../../input/validation-message/validation-message.component';\nimport { AutocompleteComponent } from '../../autocomplete/autocomplete.component';\nimport { InputBasicComponent, OptionLabelType } from '../../input/input-basic.component';\nimport { BtnComponent } from '../../btn/btn.component';\nimport {\n  FunctionCaller1,\n  FunctionCaller2,\n  StrConcatenatorPipe,\n  ToAnyPipe,\n  ValueOrXPipe,\n} from '../../../pipes/utility.pipe';\nimport { TextCase2Component } from '../../text-case-2/text-case-2.component';\nimport { Pipe, PipeTransform } from '@angular/core';\nimport { InputService } from '../../input/input.service';\n\n@Pipe({ name: 'listOptionFinder', standalone: true })\nexport class ListOptionFinderPipe implements PipeTransform {\n  transform(\n    value: string,\n    options: { x: string }[],\n    valueField: string,\n    labelField: string,\n    labelType: OptionLabelType,\n    optionFormatter: (item: any) => string,\n  ): string {\n    const formattedOptions = this.iS.optionsFormatter(\n      options,\n      valueField,\n      optionFormatter,\n      labelType,\n      labelField,\n      false,\n    );\n    return formattedOptions?.find((x) => x.value == value)?.label;\n  }\n  constructor(public iS: InputService) {}\n}\n\n@Component({\n  selector: 'form-generated-value',\n  standalone: true,\n  templateUrl: './form-generated-value.component.html',\n  styleUrls: ['./form-generated-value.component.scss'],\n  imports: [\n    AutocompleteComponent,\n    BtnComponent,\n    CommonModule,\n    FormsModule,\n    FunctionCaller1,\n    FunctionCaller2,\n    InputBasicComponent,\n    ListOptionFinderPipe,\n    LoaderComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    PhoneNumberComponent,\n    StrConcatenatorPipe,\n    TextCase2Component,\n    ToAnyPipe,\n    ValidationMessageComponent,\n    ValueOrXPipe,\n  ],\n})\nexport class FormGeneratedValueComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends FormGeneratorComponent<TFormGroup> {\n  constructor() {\n    super();\n  }\n\n  formatValue = (\n    item: IFormSchema,\n    value: string | boolean | number,\n  ): string | boolean | number => {\n    if (item.formatter) return item.formatter(this.formValue() as any, item.field);\n    else if (item.noFormat) return value;\n    else if (item.type == 'checkbox' || item.type == 'checkedbox') return value ? 'Yes' : 'No';\n    else if (item.type == 'date')\n      return this.utilityService.datePipe.transform(value as string, 'EE, MMMM d, y');\n    else if (item.type == 'datetime-local')\n      return this.utilityService.fullDateTime(value as string);\n    else if (item.subType == 'money') return this.utilityService.moneyParser(value as string);\n    else if (item.type == 'number') return this.utilityService.numberPipe.transform(+value);\n    else return value;\n  };\n}\n","<loader [loading]=\"computedLoading()\">\n  <form>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n        gridLGStyle()\n      }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.field) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [name]=\"scheme.field\"\n                [showLabel]=\"false\"\n                [noFormat]=\"scheme.noFormat\"\n                [debug]=\"scheme.debug\"\n                [showValidation]=\"scheme.showValidation\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationIcon]=\"scheme.showValidationIcon\"\n                [countryCode3]=\"scheme.countryCode3\"\n                #inputTag />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <ng-container\n                *ngTemplateOutlet=\"\n                  labelValue;\n                  context: {\n                    $implicit: {\n                      scheme,\n                      value:\n                        formValue()[scheme.field | toAny]\n                        | listOptionFinder\n                          : scheme.options || optionsMap[scheme.field | toAny]\n                          : scheme.valueField\n                          : scheme.labelField\n                          : scheme.labelType\n                          : scheme.optionFormatter\n                    }\n                  }\n                \"></ng-container>\n            }\n            @default {\n              <ng-container\n                *ngTemplateOutlet=\"\n                  labelValue;\n                  context: { $implicit: { scheme, value: formValue()[scheme.field | toAny] } }\n                \" />\n            }\n          }\n        </div>\n      }\n    </div>\n  </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n  <div class=\"\">\n    <div class=\"text-primary\">\n      {{ obj.scheme.label }}\n    </div>\n    <div class=\" \">\n      {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n    </div>\n  </div>\n</ng-template>\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generated-value.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generated-value/form-generated-value.component.ts","../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generated-value/form-generated-value.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAClF,OAAO,EAAmB,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC9D,OAAO,EAAE,sBAAsB,EAAe,MAAM,6BAA6B,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,EAAE,0BAA0B,EAAE,MAAM,6DAA6D,CAAC;AACzG,OAAO,EAAE,qBAAqB,EAAE,MAAM,2CAA2C,CAAC;AAClF,OAAO,EAAE,mBAAmB,EAAmB,MAAM,mCAAmC,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EACL,eAAe,EACf,eAAe,EACf,mBAAmB,EACnB,SAAS,EACT,YAAY,GACb,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAC7E,OAAO,EAAE,IAAI,EAAiB,MAAM,eAAe,CAAC;;;;AAIpD,MAAM,OAAO,oBAAoB;IAC/B,SAAS,CACP,KAAa,EACb,OAAwB,EACxB,UAAkB,EAClB,UAAkB,EAClB,SAA0B,EAC1B,eAAsC;QAEtC,MAAM,gBAAgB,GAAG,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAC/C,OAAO,EACP,UAAU,EACV,eAAe,EACf,SAAS,EACT,UAAU,EACV,KAAK,CACN,CAAC;QACF,OAAO,gBAAgB,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,EAAE,KAAK,CAAC;IAChE,CAAC;IACD,YAAmB,EAAgB;QAAhB,OAAE,GAAF,EAAE,CAAc;IAAG,CAAC;8GAnB5B,oBAAoB;4GAApB,oBAAoB;;2FAApB,oBAAoB;kBADhC,IAAI;mBAAC,EAAE,IAAI,EAAE,kBAAkB,EAAE,UAAU,EAAE,IAAI,EAAE;;AAiDpD,MAAM,OAAO,2BAIX,SAAQ,sBAAkC;IAE1C;QACE,KAAK,EAAE,CAAC;QAFH,yBAAoB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAK3D,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAChC,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,EAC/B,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC,kBAAkB,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAC3C,GAAG,CAAC;gBACJ,cAAc,EACZ,CAAC,CAAC,IAAI,IAAI,cAAc;oBACtB,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,SAAS,CACjC,EAAE,CAAC,CAAC,CAAC,KAAY,CAAC,EAClB,CAAC,CAAC,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,KAAe,CAAC,EAC1C,CAAC,CAAC,UAAU,EACZ,CAAC,CAAC,UAAU,EACZ,CAAC,CAAC,SAAS,EACX,CAAC,CAAC,eAAe,CAClB;oBACH,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAY,CAAC,CAAC;aAC9C,CAAC,CAAC,CAAC;QACN,CAAC,CAAC,CAAC;QACH,gBAAW,GAAG,CACZ,IAAiB,EACjB,KAAgC,EACL,EAAE;YAC7B,IAAI,IAAI,CAAC,SAAS;gBAAE,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,EAAS,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC1E,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO,KAAK,CAAC;iBAChC,IAAI,IAAI,CAAC,IAAI,IAAI,UAAU,IAAI,IAAI,CAAC,IAAI,IAAI,YAAY;gBAAE,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;iBACtF,IAAI,IAAI,CAAC,IAAI,IAAI,MAAM;gBAC1B,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAe,EAAE,eAAe,CAAC,CAAC;iBAC7E,IAAI,IAAI,CAAC,IAAI,IAAI,gBAAgB;gBACpC,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,KAAe,CAAC,CAAC;iBACtD,IAAI,IAAI,CAAC,OAAO,IAAI,OAAO;gBAAE,OAAO,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,KAAe,CAAC,CAAC;iBACrF,IAAI,IAAI,CAAC,IAAI,IAAI,QAAQ;gBAAE,OAAO,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC;;gBACnF,OAAO,KAAK,CAAC;QACpB,CAAC,CAAC;IAlCF,CAAC;8GARU,2BAA2B;kGAA3B,2BAA2B,mEAF3B,CAAC,oBAAoB,CAAC,iDCpEnC,iyDAoDA,oRDAI,YAAY,8BACZ,WAAW,mdAEX,eAAe,wDAGf,eAAe,uHAGf,oBAAoB,uIAKpB,YAAY;;2FAIH,2BAA2B;kBA1BvC,SAAS;+BACE,sBAAsB,cACpB,IAAI,WAGP;wBACP,qBAAqB;wBACrB,YAAY;wBACZ,YAAY;wBACZ,WAAW;wBACX,eAAe;wBACf,eAAe;wBACf,mBAAmB;wBACnB,oBAAoB;wBACpB,eAAe;wBACf,eAAe;wBACf,gBAAgB;wBAChB,oBAAoB;wBACpB,mBAAmB;wBACnB,kBAAkB;wBAClB,SAAS;wBACT,0BAA0B;wBAC1B,YAAY;qBACb,aACU,CAAC,oBAAoB,CAAC","sourcesContent":["import { Component, computed, inject } from '@angular/core';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { AbstractControl, FormsModule } from '@angular/forms';\nimport { FormGeneratorComponent, IFormSchema } from '../form-generator.component';\nimport { LoaderComponent } from '../../loader/loader.component';\nimport { PhoneNumberComponent } from '../../phone-number/phone-number.component';\nimport { ValidationMessageComponent } from '../../input/validation-message/validation-message.component';\nimport { AutocompleteComponent } from '../../autocomplete/autocomplete.component';\nimport { InputBasicComponent, OptionLabelType } from '../../input/input-basic.component';\nimport { BtnComponent } from '../../btn/btn.component';\nimport {\n  FunctionCaller1,\n  FunctionCaller2,\n  StrConcatenatorPipe,\n  ToAnyPipe,\n  ValueOrXPipe,\n} from '../../../pipes/utility.pipe';\nimport { TextCase2Component } from '../../text-case-2/text-case-2.component';\nimport { Pipe, PipeTransform } from '@angular/core';\nimport { InputService } from '../../input/input.service';\n\n@Pipe({ name: 'listOptionFinder', standalone: true })\nexport class ListOptionFinderPipe implements PipeTransform {\n  transform(\n    value: string,\n    options: { x: string }[],\n    valueField: string,\n    labelField: string,\n    labelType: OptionLabelType,\n    optionFormatter: (item: any) => string,\n  ): string {\n    const formattedOptions = this.iS.optionsFormatter(\n      options,\n      valueField,\n      optionFormatter,\n      labelType,\n      labelField,\n      false,\n    );\n    return formattedOptions?.find((x) => x.value == value)?.label;\n  }\n  constructor(public iS: InputService) {}\n}\n\n@Component({\n  selector: 'form-generated-value',\n  standalone: true,\n  templateUrl: './form-generated-value.component.html',\n  styleUrls: ['./form-generated-value.component.scss'],\n  imports: [\n    AutocompleteComponent,\n    BtnComponent,\n    CommonModule,\n    FormsModule,\n    FunctionCaller1,\n    FunctionCaller2,\n    InputBasicComponent,\n    ListOptionFinderPipe,\n    LoaderComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    PhoneNumberComponent,\n    StrConcatenatorPipe,\n    TextCase2Component,\n    ToAnyPipe,\n    ValidationMessageComponent,\n    ValueOrXPipe,\n  ],\n  providers: [ListOptionFinderPipe],\n})\nexport class FormGeneratedValueComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends FormGeneratorComponent<TFormGroup> {\n  public listOptionFinderPipe = inject(ListOptionFinderPipe);\n  constructor() {\n    super();\n  }\n\n  computedListValue = computed(() => {\n    const fv = this.formValue() || {},\n      optionsMap = this.optionsMap();\n    return this.computedFormSchema().map((f) => ({\n      ...f,\n      formattedValue:\n        f.type == 'autocomplete'\n          ? this.listOptionFinderPipe.transform(\n              fv[f.field as any],\n              f.options || optionsMap[f.field as string],\n              f.valueField,\n              f.labelField,\n              f.labelType,\n              f.optionFormatter,\n            )\n          : this.formatValue(f, fv[f.field as any]),\n    }));\n  });\n  formatValue = (\n    item: IFormSchema,\n    value: string | boolean | number,\n  ): string | boolean | number => {\n    if (item.formatter) return item.formatter(this.formValue() as any, item.field);\n    else if (item.noFormat) return value;\n    else if (item.type == 'checkbox' || item.type == 'checkedbox') return value ? 'Yes' : 'No';\n    else if (item.type == 'date')\n      return this.utilityService.datePipe.transform(value as string, 'EE, MMMM d, y');\n    else if (item.type == 'datetime-local')\n      return this.utilityService.fullDateTime(value as string);\n    else if (item.subType == 'money') return this.utilityService.moneyParser(value as string);\n    else if (item.type == 'number') return this.utilityService.numberPipe.transform(+value);\n    else return value;\n  };\n}\n","<loader [loading]=\"computedLoading()\">\n  <form>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n        gridLGStyle()\n      }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedListValue(); track scheme.field) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [name]=\"scheme.field\"\n                [showLabel]=\"false\"\n                [noFormat]=\"scheme.noFormat\"\n                [debug]=\"scheme.debug\"\n                [showValidation]=\"scheme.showValidation\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationIcon]=\"scheme.showValidationIcon\"\n                [countryCode3]=\"scheme.countryCode3\"\n                #inputTag />\n            } \n            @default {\n              <div class=\"\">\n                <div class=\"text-primary\">\n                  {{ scheme.label }}\n                </div>\n                <div class=\" \">\n                  {{ scheme.formattedValue | valueOrX: '-' }}\n                </div>\n              </div>\n            }\n          }\n        </div>\n      }\n    </div>\n  </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n  <div class=\"\">\n    <div class=\"text-primary\">\n      {{ obj.scheme.label }}\n    </div>\n    <div class=\" \">\n      {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -74,7 +74,9 @@ export class FormGeneratorComponent extends BaseFormGenerator {
74
74
  this.computedLoading = computed(() => (this.useLoader() ? this.loading() || this._loading() : false));
75
75
  this.submitBtnRef = viewChild('submitBtn');
76
76
  this.form = model();
77
- this.formValue = toSignal(toObservable(this.form).pipe(switchMap((form) => form.valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))), startWith(this.form()?.getRawValue() || {})), { initialValue: this.form()?.getRawValue() || {} });
77
+ this.formValue = toSignal(toObservable(this.form).pipe(filter(() => !!this.form()), switchMap(() => this.form()
78
+ .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))
79
+ .pipe(startWith(this.form()?.getRawValue() || {})))));
78
80
  this.optionsMap = signal({});
79
81
  // formVal = computed(() => this.form?.getRawValue());
80
82
  this.computedFormSchema = computed(() => {
@@ -245,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
245
247
  type: Input,
246
248
  args: ['isShow']
247
249
  }] } });
248
- //# 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  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { debounceTime, filter, last, switchMap, tap, map, startWith } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    RichTextEditorRFComponent,\n    BtnComponent,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> },\n> extends BaseFormGenerator<TFormGroup, IFormSchema<TFormGroup>> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  presetValueForSingleOption = input(false);\n  isCreate = input<boolean>();\n  submitOnEnterKey = input<boolean>(false);\n  formTagRef = viewChild<ElementRef<HTMLFormElement>>('formTag');\n\n  /**Emitted just before calling the save function */\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  /**Emitted after receiving feedback from the submit function */\n  @Output() saved = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  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  submitBtnRef = viewChild<BtnComponent>('submitBtn');\n  form = model<FormGroup<TFormGroup>>();\n\n  formValue = toSignal(\n    toObservable(this.form).pipe(\n      switchMap((form) => form.valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))),\n      startWith(this.form()?.getRawValue()||{}),\n    ),\n    { initialValue: this.form()?.getRawValue() || {} },\n  );\n\n  submissionResponse: any;\n  @Input({ alias: 'formSchema' }) set _formSchema(v: IFormSchema<TFormGroup>[]) {\n    this.init(cloneDeep(v.filter((x) => x)));\n  }\n  @Input({ alias: 'formSchemaNoForm' }) set _formSchemaNoForm(v: IFormSchema<TFormGroup>[]) {\n    if (v) {\n      const form = new FormGroup({});\n      for (const item of v) {\n        form.addControl(\n          item.field?.toString(),\n          new FormControl(item.value, [].concat(item.isRequired ? [Validators.required] : [])),\n        );\n      }\n      this.form.set(form as any as FormGroup<TFormGroup>);\n      this._formSchema = v;\n    }\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form()?.disable({ emitEvent: false });\n    else this.form()?.enable();\n\n    setTimeout(() => {\n      if (v) this.form()?.disable({ emitEvent: false });\n      else this.form()?.enable();\n    }, 500);\n  }\n  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)\n          scheme.presetValue =\n            scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  constructor() {\n    super();\n\n    let listenToKey: Subscription;\n    this.destroyRef.onDestroy(() => {\n      listenToKey?.unsubscribe();\n    });\n    effect(() => {\n      const ftr = this.formTagRef(),\n        submitOnEnterKey = this.submitOnEnterKey();\n      // debugger;\n\n      listenToKey?.unsubscribe();\n      if (ftr?.nativeElement && submitOnEnterKey)\n        listenToKey = fromEvent(ftr.nativeElement, 'keydown')\n          .pipe(\n            debounceTime(100),\n            filter(\n              (r: KeyboardEvent) => (r.code === 'Enter' || r.keyCode === 13) && this.form().valid,\n            ),\n          )\n          .subscribe((r: KeyboardEvent) => {\n            this.submit(this.submitBtnRef());\n          });\n    });\n  }\n\n  init(schema: 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) {\n          const formValue = this.form()?.getRawValue();\n          scheme.onChangeFunc(formValue, formValue[scheme.field?.toString()], this);\n        }\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))\n        scheme.autoPickValueField = true;\n    // if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form()\n        ?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0))\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.formValue(), r, this);\n        });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: 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.formValue());\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.formValue() as any, this.formValue()[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.formValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        this.utilityService.info(this.submitSuccessText(), 1);\n        this.saved.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.formValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n  <form [formGroup]=\"form()\" #formTag >\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{ 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                [verbose]=\"scheme.verbose\"\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: formValue() : (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                [verbose]=\"scheme.verbose\"\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: formValue() : (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                [verbose]=\"scheme.verbose\"\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                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf! | functionCaller2: formValue() : (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                [verbose]=\"scheme.verbose\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"!!scheme.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                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (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()\"  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"]}
250
+ //# 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  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport { debounceTime, filter, last, switchMap, tap, map, startWith } from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    RichTextEditorRFComponent,\n    BtnComponent,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> },\n> extends BaseFormGenerator<TFormGroup, IFormSchema<TFormGroup>> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  presetValueForSingleOption = input(false);\n  isCreate = input<boolean>();\n  submitOnEnterKey = input<boolean>(false);\n  formTagRef = viewChild<ElementRef<HTMLFormElement>>('formTag');\n\n  /**Emitted just before calling the save function */\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  /**Emitted after receiving feedback from the submit function */\n  @Output() saved = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  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  submitBtnRef = viewChild<BtnComponent>('submitBtn');\n  form = model<FormGroup<TFormGroup>>();\n\n  formValue = toSignal(\n    toObservable(this.form).pipe(\n      filter(() => !!this.form()),\n      switchMap(() =>\n        this.form()\n          .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))\n          .pipe(startWith(this.form()?.getRawValue() || {})),\n      ),\n    ),\n    // { initialValue: this.form()?.getRawValue() || {} },\n  );\n\n  submissionResponse: any;\n  @Input({ alias: 'formSchema' }) set _formSchema(v: IFormSchema<TFormGroup>[]) {\n    this.init(cloneDeep(v.filter((x) => x)));\n  }\n  @Input({ alias: 'formSchemaNoForm' }) set _formSchemaNoForm(v: IFormSchema<TFormGroup>[]) {\n    if (v) {\n      const form = new FormGroup({});\n      for (const item of v) {\n        form.addControl(\n          item.field?.toString(),\n          new FormControl(item.value, [].concat(item.isRequired ? [Validators.required] : [])),\n        );\n      }\n      this.form.set(form as any as FormGroup<TFormGroup>);\n      this._formSchema = v;\n    }\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form()?.disable({ emitEvent: false });\n    else this.form()?.enable();\n\n    setTimeout(() => {\n      if (v) this.form()?.disable({ emitEvent: false });\n      else this.form()?.enable();\n    }, 500);\n  }\n  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)\n          scheme.presetValue =\n            scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  constructor() {\n    super();\n\n    let listenToKey: Subscription;\n    this.destroyRef.onDestroy(() => {\n      listenToKey?.unsubscribe();\n    });\n    effect(() => {\n      const ftr = this.formTagRef(),\n        submitOnEnterKey = this.submitOnEnterKey();\n      // debugger;\n\n      listenToKey?.unsubscribe();\n      if (ftr?.nativeElement && submitOnEnterKey)\n        listenToKey = fromEvent(ftr.nativeElement, 'keydown')\n          .pipe(\n            debounceTime(100),\n            filter(\n              (r: KeyboardEvent) => (r.code === 'Enter' || r.keyCode === 13) && this.form().valid,\n            ),\n          )\n          .subscribe((r: KeyboardEvent) => {\n            this.submit(this.submitBtnRef());\n          });\n    });\n  }\n\n  init(schema: 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) {\n          const formValue = this.form()?.getRawValue();\n          scheme.onChangeFunc(formValue, formValue[scheme.field?.toString()], this);\n        }\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))\n        scheme.autoPickValueField = true;\n    // if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form()\n        ?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0))\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.formValue(), r, this);\n        });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: 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.formValue());\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.formValue() as any, this.formValue()[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.formValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        this.utilityService.info(this.submitSuccessText(), 1);\n        this.saved.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.formValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n  <form [formGroup]=\"form()\" #formTag >\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{ 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                [verbose]=\"scheme.verbose\"\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: formValue() : (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                [verbose]=\"scheme.verbose\"\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: formValue() : (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                [verbose]=\"scheme.verbose\"\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                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf! | functionCaller2: formValue() : (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                [verbose]=\"scheme.verbose\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"!!scheme.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                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"scheme.disabled || (scheme.disabledIf | functionCaller2: formValue() : (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()\"  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"]}
@@ -11990,7 +11990,9 @@ class FormGeneratorComponent extends BaseFormGenerator {
11990
11990
  this.computedLoading = computed(() => (this.useLoader() ? this.loading() || this._loading() : false));
11991
11991
  this.submitBtnRef = viewChild('submitBtn');
11992
11992
  this.form = model();
11993
- this.formValue = toSignal(toObservable(this.form).pipe(switchMap$1((form) => form.valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))), startWith(this.form()?.getRawValue() || {})), { initialValue: this.form()?.getRawValue() || {} });
11993
+ this.formValue = toSignal(toObservable(this.form).pipe(filter$1(() => !!this.form()), switchMap$1(() => this.form()
11994
+ .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))
11995
+ .pipe(startWith(this.form()?.getRawValue() || {})))));
11994
11996
  this.optionsMap = signal({});
11995
11997
  // formVal = computed(() => this.form?.getRawValue());
11996
11998
  this.computedFormSchema = computed(() => {
@@ -12871,6 +12873,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
12871
12873
  class FormGeneratedValueComponent extends FormGeneratorComponent {
12872
12874
  constructor() {
12873
12875
  super();
12876
+ this.listOptionFinderPipe = inject(ListOptionFinderPipe);
12877
+ this.computedListValue = computed(() => {
12878
+ const fv = this.formValue() || {}, optionsMap = this.optionsMap();
12879
+ return this.computedFormSchema().map((f) => ({
12880
+ ...f,
12881
+ formattedValue: f.type == 'autocomplete'
12882
+ ? this.listOptionFinderPipe.transform(fv[f.field], f.options || optionsMap[f.field], f.valueField, f.labelField, f.labelType, f.optionFormatter)
12883
+ : this.formatValue(f, fv[f.field]),
12884
+ }));
12885
+ });
12874
12886
  this.formatValue = (item, value) => {
12875
12887
  if (item.formatter)
12876
12888
  return item.formatter(this.formValue(), item.field);
@@ -12891,7 +12903,7 @@ class FormGeneratedValueComponent extends FormGeneratorComponent {
12891
12903
  };
12892
12904
  }
12893
12905
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: FormGeneratedValueComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
12894
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: FormGeneratedValueComponent, isStandalone: true, selector: "form-generated-value", usesInheritance: true, ngImport: i0, template: "<loader [loading]=\"computedLoading()\">\n <form>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedFormSchema(); track scheme.field) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n #inputTag />\n }\n @case (scheme.type == 'autocomplete') {\n <ng-container\n *ngTemplateOutlet=\"\n labelValue;\n context: {\n $implicit: {\n scheme,\n value:\n formValue()[scheme.field | toAny]\n | listOptionFinder\n : scheme.options || optionsMap[scheme.field | toAny]\n : scheme.valueField\n : scheme.labelField\n : scheme.labelType\n : scheme.optionFormatter\n }\n }\n \"></ng-container>\n }\n @default {\n <ng-container\n *ngTemplateOutlet=\"\n labelValue;\n context: { $implicit: { scheme, value: formValue()[scheme.field | toAny] } }\n \" />\n }\n }\n </div>\n }\n </div>\n </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n <div class=\"\">\n <div class=\"text-primary\">\n {{ obj.scheme.label }}\n </div>\n <div class=\" \">\n {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n </div>\n </div>\n</ng-template>\n", styles: [":host ::ng-deep input:not([type=checkbox]),:host ::ng-deep .control-bg-gray.form-control,:host ::ng-deep textarea{border:none!important;background-color:transparent!important;padding:0!important;height:auto!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3$1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "pipe", type: FunctionCaller2, name: "functionCaller2" }, { kind: "pipe", type: ListOptionFinderPipe, name: "listOptionFinder" }, { kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "component", type: PhoneNumberComponent, selector: "app-phone-number", inputs: ["showLabel", "countryCode3", "config"], outputs: ["onCountrySelect"] }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }, { kind: "pipe", type: ValueOrXPipe, name: "valueOrX" }] }); }
12906
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: FormGeneratedValueComponent, isStandalone: true, selector: "form-generated-value", providers: [ListOptionFinderPipe], usesInheritance: true, ngImport: i0, template: "<loader [loading]=\"computedLoading()\">\n <form>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedListValue(); track scheme.field) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n #inputTag />\n } \n @default {\n <div class=\"\">\n <div class=\"text-primary\">\n {{ scheme.label }}\n </div>\n <div class=\" \">\n {{ scheme.formattedValue | valueOrX: '-' }}\n </div>\n </div>\n }\n }\n </div>\n }\n </div>\n </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n <div class=\"\">\n <div class=\"text-primary\">\n {{ obj.scheme.label }}\n </div>\n <div class=\" \">\n {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n </div>\n </div>\n</ng-template>\n", styles: [":host ::ng-deep input:not([type=checkbox]),:host ::ng-deep .control-bg-gray.form-control,:host ::ng-deep textarea{border:none!important;background-color:transparent!important;padding:0!important;height:auto!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3$1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "pipe", type: FunctionCaller2, name: "functionCaller2" }, { kind: "component", type: LoaderComponent, selector: "loader", inputs: ["class", "text", "loading", "height", "width", "ratioHW"] }, { kind: "component", type: PhoneNumberComponent, selector: "app-phone-number", inputs: ["showLabel", "countryCode3", "config"], outputs: ["onCountrySelect"] }, { kind: "pipe", type: ValueOrXPipe, name: "valueOrX" }] }); }
12895
12907
  }
12896
12908
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: FormGeneratedValueComponent, decorators: [{
12897
12909
  type: Component,
@@ -12913,7 +12925,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
12913
12925
  ToAnyPipe,
12914
12926
  ValidationMessageComponent,
12915
12927
  ValueOrXPipe,
12916
- ], template: "<loader [loading]=\"computedLoading()\">\n <form>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedFormSchema(); track scheme.field) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n #inputTag />\n }\n @case (scheme.type == 'autocomplete') {\n <ng-container\n *ngTemplateOutlet=\"\n labelValue;\n context: {\n $implicit: {\n scheme,\n value:\n formValue()[scheme.field | toAny]\n | listOptionFinder\n : scheme.options || optionsMap[scheme.field | toAny]\n : scheme.valueField\n : scheme.labelField\n : scheme.labelType\n : scheme.optionFormatter\n }\n }\n \"></ng-container>\n }\n @default {\n <ng-container\n *ngTemplateOutlet=\"\n labelValue;\n context: { $implicit: { scheme, value: formValue()[scheme.field | toAny] } }\n \" />\n }\n }\n </div>\n }\n </div>\n </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n <div class=\"\">\n <div class=\"text-primary\">\n {{ obj.scheme.label }}\n </div>\n <div class=\" \">\n {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n </div>\n </div>\n</ng-template>\n", styles: [":host ::ng-deep input:not([type=checkbox]),:host ::ng-deep .control-bg-gray.form-control,:host ::ng-deep textarea{border:none!important;background-color:transparent!important;padding:0!important;height:auto!important}\n"] }]
12928
+ ], providers: [ListOptionFinderPipe], template: "<loader [loading]=\"computedLoading()\">\n <form>\n <div\n class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n gridLGStyle()\n }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n @for (scheme of computedListValue(); track scheme.field) {\n <div class=\"col {{ scheme.cls }} \">\n @switch (true) {\n @case (scheme.type == 'tel') {\n <app-phone-number\n [form]=\"form()\"\n [label]=\"scheme.label\"\n [clearOnDisable]=\"scheme.clearOnDisable\"\n [name]=\"scheme.field\"\n [showLabel]=\"false\"\n [noFormat]=\"scheme.noFormat\"\n [debug]=\"scheme.debug\"\n [showValidation]=\"scheme.showValidation\"\n [autoPickValueField]=\"scheme.autoPickValueField\"\n [showRequiredTag]=\"scheme.showRequiredTag\"\n [showValidationIcon]=\"scheme.showValidationIcon\"\n [countryCode3]=\"scheme.countryCode3\"\n #inputTag />\n } \n @default {\n <div class=\"\">\n <div class=\"text-primary\">\n {{ scheme.label }}\n </div>\n <div class=\" \">\n {{ scheme.formattedValue | valueOrX: '-' }}\n </div>\n </div>\n }\n }\n </div>\n }\n </div>\n </form>\n</loader>\n\n<ng-template #labelValue let-obj>\n <div class=\"\">\n <div class=\"text-primary\">\n {{ obj.scheme.label }}\n </div>\n <div class=\" \">\n {{ formatValue | functionCaller2: obj.scheme : obj.value | valueOrX: '-' }}\n </div>\n </div>\n</ng-template>\n", styles: [":host ::ng-deep input:not([type=checkbox]),:host ::ng-deep .control-bg-gray.form-control,:host ::ng-deep textarea{border:none!important;background-color:transparent!important;padding:0!important;height:auto!important}\n"] }]
12917
12929
  }], ctorParameters: () => [] });
12918
12930
 
12919
12931
  class FormLinkComponent {