ets-fe-ng-sdk 17.0.417 → 17.0.419

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.
@@ -61,13 +61,13 @@ export class FormErrorComponent {
61
61
  for (const key in form.controls) {
62
62
  if (Object.prototype.hasOwnProperty.call(form.controls, key)) {
63
63
  const control = form.controls[key];
64
- messages.push(...this.getErrorMessages(control, key, _index, form.labelValue ||
65
- (formName ? this.uS.formatField(formName) : formName?.toSentenceCase())));
64
+ messages.push(...this.getErrorMessages(control, key, _index, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
66
65
  }
67
66
  }
68
67
  else if (form instanceof FormArray)
69
68
  for (let index = 0; index < form.length; index++) {
70
69
  const control = form.controls[index];
70
+ debugger;
71
71
  messages.push(...this.getErrorMessages(control, undefined, index + 1, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
72
72
  }
73
73
  return messages;
@@ -75,7 +75,7 @@ export class FormErrorComponent {
75
75
  // console.log('message', this.message);
76
76
  }
77
77
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormErrorComponent, deps: [{ token: i0.ElementRef }, { token: i1.UtilityService }], target: i0.ɵɵFactoryTarget.Component }); }
78
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: FormErrorComponent, isStandalone: true, selector: "form-error", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, lgGridNo: { classPropertyName: "lgGridNo", publicName: "lgGridNo", isSignal: true, isRequired: false, transformFunction: null }, xxlGridNo: { classPropertyName: "xxlGridNo", publicName: "xxlGridNo", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (hasError()) {\n <div class=\"d-flex justify-content-end mt-2\">\n <app-btn\n text=\"Form Errors\"\n icon=\"info\"\n type=\"clear\"\n mclass=\"btn-outline-warning\"\n (mclick)=\"errCont.hidden = !errCont.hidden\" />\n </div>\n <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n @if (false) {\n <div class=\"col-lg-12 d-flex\">\n <div>\n <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n <!-- <hr class=\"my-0\"> -->\n </div>\n </div>\n }\n @for (item of errors(); track item) {\n @if (item.formControl) {\n <div class=\"d-flex\">\n @if (item.parent) {\n <app-info-icon text=\"Group: {{item.parent}}\" />\n }\n <app-validation-message\n [label]=\"item.label | titlecase\"\n [ignoreDirtiness]=\"true\"\n [control]=\"item.formControl\" />\n </div>\n }\n }\n </div>\n </div>\n}\n", styles: [":host ::ng-deep .errormssg{color:#870000}:host .form-error-container{border-radius:10px}:host app-info-icon{margin-right:5px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }, { kind: "component", type: ValidationMessageComponent, selector: "app-validation-message", inputs: ["debug", "label", "hideOverflow", "minLength", "maxLength", "ignoreDirtiness", "customMessage", "control", "input"], outputs: ["labelChange"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "component", type: InfoIconComponent, selector: "app-info-icon", inputs: ["text", "coloured", "left", "right"] }] }); }
78
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: FormErrorComponent, isStandalone: true, selector: "form-error", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, lgGridNo: { classPropertyName: "lgGridNo", publicName: "lgGridNo", isSignal: true, isRequired: false, transformFunction: null }, xxlGridNo: { classPropertyName: "xxlGridNo", publicName: "xxlGridNo", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (hasError()) {\n <div class=\"d-flex justify-content-end mt-2\">\n <app-btn\n text=\"Form Errors\"\n icon=\"info\"\n type=\"clear\"\n mclass=\"btn-outline-warning\"\n (mclick)=\"errCont.hidden = !errCont.hidden\" />\n </div>\n <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n @if (false) {\n <div class=\"col-lg-12 d-flex\">\n <div>\n <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n <!-- <hr class=\"my-0\"> -->\n </div>\n </div>\n }\n @for (item of errors(); track item) {\n @if (item.formControl) {\n <div class=\"error-item-case\">\n @if (item.parent) {\n <app-info-icon text=\"Group: {{ item.parent }}\" />\n <!-- <div class=\"\" [matTooltip]=\"item.parent\">Parent</div> -->\n }\n <app-validation-message\n [label]=\"item.label | titlecase\"\n [ignoreDirtiness]=\"true\"\n [control]=\"item.formControl\" />\n </div>\n }\n }\n </div>\n </div>\n}\n", styles: [":host ::ng-deep .errormssg{color:#870000}:host .form-error-container{border-radius:10px}:host app-info-icon{margin-right:5px}:host .error-item-case{display:flex;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }, { kind: "component", type: ValidationMessageComponent, selector: "app-validation-message", inputs: ["debug", "label", "hideOverflow", "minLength", "maxLength", "ignoreDirtiness", "customMessage", "control", "input"], outputs: ["labelChange"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "component", type: InfoIconComponent, selector: "app-info-icon", inputs: ["text", "coloured", "left", "right"] }] }); }
79
79
  }
80
80
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormErrorComponent, decorators: [{
81
81
  type: Component,
@@ -86,7 +86,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
86
86
  BtnComponent,
87
87
  MatTooltipModule,
88
88
  InfoIconComponent,
89
- ], template: "@if (hasError()) {\n <div class=\"d-flex justify-content-end mt-2\">\n <app-btn\n text=\"Form Errors\"\n icon=\"info\"\n type=\"clear\"\n mclass=\"btn-outline-warning\"\n (mclick)=\"errCont.hidden = !errCont.hidden\" />\n </div>\n <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n @if (false) {\n <div class=\"col-lg-12 d-flex\">\n <div>\n <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n <!-- <hr class=\"my-0\"> -->\n </div>\n </div>\n }\n @for (item of errors(); track item) {\n @if (item.formControl) {\n <div class=\"d-flex\">\n @if (item.parent) {\n <app-info-icon text=\"Group: {{item.parent}}\" />\n }\n <app-validation-message\n [label]=\"item.label | titlecase\"\n [ignoreDirtiness]=\"true\"\n [control]=\"item.formControl\" />\n </div>\n }\n }\n </div>\n </div>\n}\n", styles: [":host ::ng-deep .errormssg{color:#870000}:host .form-error-container{border-radius:10px}:host app-info-icon{margin-right:5px}\n"] }]
89
+ ], template: "@if (hasError()) {\n <div class=\"d-flex justify-content-end mt-2\">\n <app-btn\n text=\"Form Errors\"\n icon=\"info\"\n type=\"clear\"\n mclass=\"btn-outline-warning\"\n (mclick)=\"errCont.hidden = !errCont.hidden\" />\n </div>\n <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n @if (false) {\n <div class=\"col-lg-12 d-flex\">\n <div>\n <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n <!-- <hr class=\"my-0\"> -->\n </div>\n </div>\n }\n @for (item of errors(); track item) {\n @if (item.formControl) {\n <div class=\"error-item-case\">\n @if (item.parent) {\n <app-info-icon text=\"Group: {{ item.parent }}\" />\n <!-- <div class=\"\" [matTooltip]=\"item.parent\">Parent</div> -->\n }\n <app-validation-message\n [label]=\"item.label | titlecase\"\n [ignoreDirtiness]=\"true\"\n [control]=\"item.formControl\" />\n </div>\n }\n }\n </div>\n </div>\n}\n", styles: [":host ::ng-deep .errormssg{color:#870000}:host .form-error-container{border-radius:10px}:host app-info-icon{margin-right:5px}:host .error-item-case{display:flex;align-items:center}\n"] }]
90
90
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.UtilityService }] });
91
91
  function hasError(control) {
92
92
  if (control?.pending)
@@ -97,4 +97,4 @@ function hasError(control) {
97
97
  return true;
98
98
  return false;
99
99
  }
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-error.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-error/form-error.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-error/form-error.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  Signal,\n  computed,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport { AbstractControl, FormArray, FormControl, FormGroup } from '@angular/forms';\nimport { debounceTime, filter, map, merge, Subscription, switchMap } from 'rxjs';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { BtnComponent } from '../btn/btn.component';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { uniqBy } from 'lodash-es';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { InfoIconComponent } from '../info-icon/info-icon.component';\n\n@Component({\n  selector: 'form-error',\n  standalone: true,\n  templateUrl: './form-error.component.html',\n  styleUrls: ['./form-error.component.scss'],\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    SDKTranslatePipe,\n    ValidationMessageComponent,\n    BtnComponent,\n    MatTooltipModule,\n    InfoIconComponent,\n  ],\n})\nexport class FormErrorComponent {\n  // readonly errors = signal<{ formControl: AbstractControl; label: string; parent?: string }[]>([]);\n  readonly form = input<Form | Form[]>();\n  readonly errors = toSignal<IError>(\n    toObservable(this.form).pipe(\n      filter((v) => !!v),\n      switchMap((v) =>\n        Array.isArray(v)\n          ? merge(...v.map((f) => f.statusChanges)).pipe(\n              debounceTime(600),\n              map((formStatus) => {\n                if (\n                  formStatus == 'INVALID' ||\n                  formStatus == 'PENDING' ||\n                  v.some((f) => f.status == 'INVALID' || f.status == 'PENDING')\n                )\n                  return (\n                    uniqBy(\n                      v.flatMap((f) => this.getErrorMessages(f)),\n                      'message',\n                    ) || []\n                  );\n                else {\n                  return [];\n                }\n              }),\n            )\n          : v.statusChanges.pipe(\n              debounceTime(600),\n              map((formStatus) => {\n                if (\n                  formStatus == 'INVALID' ||\n                  formStatus == 'PENDING' ||\n                  v.status == 'INVALID' ||\n                  v.status == 'PENDING'\n                )\n                  return this.getErrorMessages(v);\n                else {\n                  return [];\n                }\n              }),\n            ),\n      ),\n      debounceTime(600),\n    ),\n  );\n\n  // protected form?: Form;\n  // protected forms?: Form[];\n  readonly lgGridNo = input<number | 'auto'>(2);\n  readonly xxlGridNo = input<number | 'auto'>(3);\n\n  readonly hasError = computed<boolean>(() => this.errors()?.length > 0);\n\n  constructor(\n    public el: ElementRef<HTMLElement>,\n    public uS: UtilityService,\n  ) {}\n\n  getErrorMessages(\n    form: Form | AbstractControl,\n    formName?: string,\n    _index?: number,\n    parent?: string,\n  ): IError {\n    // debugger;\n    let messages: IError = [];\n    if (hasError(form)) {\n      // debugger;\n      messages.push({\n        formControl: form,\n        label:\n          (_index ? `Item ${_index}: ` : '') +\n          (form.labelValue ||\n            (formName ? this.uS.formatField(formName) : formName?.toSentenceCase())),\n        parent,\n      });\n    }\n    if (form instanceof FormGroup)\n      for (const key in form.controls) {\n        if (Object.prototype.hasOwnProperty.call(form.controls, key)) {\n          const control = form.controls[key];\n          messages.push(\n            ...this.getErrorMessages(\n              control,\n              key,\n              _index,\n              form.labelValue ||\n                (formName ? this.uS.formatField(formName) : formName?.toSentenceCase()),\n            ),\n          );\n        }\n      }\n    else if (form instanceof FormArray)\n      for (let index = 0; index < form.length; index++) {\n        const control = form.controls[index];\n        messages.push(\n          ...this.getErrorMessages(\n            control,\n            undefined,\n            index + 1,\n            form.labelValue || (formName ? this.uS.formatField(formName) : parent),\n          ),\n        );\n      }\n    return messages;\n    // debugger;\n    // console.log('message', this.message);\n  }\n}\ntype Form = FormGroup | FormControl | FormArray;\ntype IError = { formControl: AbstractControl; label: string; parent: string | null }[];\nfunction hasError(control: AbstractControl) {\n  if (control?.pending) return true;\n  else if (!control?.errors) return false;\n  else if (Object.keys(control.errors).length) return true;\n  return false;\n}\n","@if (hasError()) {\n  <div class=\"d-flex justify-content-end mt-2\">\n    <app-btn\n      text=\"Form Errors\"\n      icon=\"info\"\n      type=\"clear\"\n      mclass=\"btn-outline-warning\"\n      (mclick)=\"errCont.hidden = !errCont.hidden\" />\n  </div>\n  <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n    <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n      @if (false) {\n        <div class=\"col-lg-12 d-flex\">\n          <div>\n            <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n            <!-- <hr class=\"my-0\"> -->\n          </div>\n        </div>\n      }\n      @for (item of errors(); track item) {\n        @if (item.formControl) {\n          <div class=\"d-flex\">\n            @if (item.parent) {\n              <app-info-icon text=\"Group: {{item.parent}}\" />\n            }\n            <app-validation-message\n              [label]=\"item.label | titlecase\"\n              [ignoreDirtiness]=\"true\"\n              [control]=\"item.formControl\" />\n          </div>\n        }\n      }\n    </div>\n  </div>\n}\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-error.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-error/form-error.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-error/form-error.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  Signal,\n  computed,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport { AbstractControl, FormArray, FormControl, FormGroup } from '@angular/forms';\nimport { debounceTime, filter, map, merge, Subscription, switchMap } from 'rxjs';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { BtnComponent } from '../btn/btn.component';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { uniqBy } from 'lodash-es';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { InfoIconComponent } from '../info-icon/info-icon.component';\n\n@Component({\n  selector: 'form-error',\n  standalone: true,\n  templateUrl: './form-error.component.html',\n  styleUrls: ['./form-error.component.scss'],\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    SDKTranslatePipe,\n    ValidationMessageComponent,\n    BtnComponent,\n    MatTooltipModule,\n    InfoIconComponent,\n  ],\n})\nexport class FormErrorComponent {\n  // readonly errors = signal<{ formControl: AbstractControl; label: string; parent?: string }[]>([]);\n  readonly form = input<Form | Form[]>();\n  readonly errors = toSignal<IError>(\n    toObservable(this.form).pipe(\n      filter((v) => !!v),\n      switchMap((v) =>\n        Array.isArray(v)\n          ? merge(...v.map((f) => f.statusChanges)).pipe(\n              debounceTime(600),\n              map((formStatus) => {\n                if (\n                  formStatus == 'INVALID' ||\n                  formStatus == 'PENDING' ||\n                  v.some((f) => f.status == 'INVALID' || f.status == 'PENDING')\n                )\n                  return (\n                    uniqBy(\n                      v.flatMap((f) => this.getErrorMessages(f)),\n                      'message',\n                    ) || []\n                  );\n                else {\n                  return [];\n                }\n              }),\n            )\n          : v.statusChanges.pipe(\n              debounceTime(600),\n              map((formStatus) => {\n                if (\n                  formStatus == 'INVALID' ||\n                  formStatus == 'PENDING' ||\n                  v.status == 'INVALID' ||\n                  v.status == 'PENDING'\n                )\n                  return this.getErrorMessages(v);\n                else {\n                  return [];\n                }\n              }),\n            ),\n      ),\n      debounceTime(600),\n    ),\n  );\n\n  // protected form?: Form;\n  // protected forms?: Form[];\n  readonly lgGridNo = input<number | 'auto'>(2);\n  readonly xxlGridNo = input<number | 'auto'>(3);\n\n  readonly hasError = computed<boolean>(() => this.errors()?.length > 0);\n\n  constructor(\n    public el: ElementRef<HTMLElement>,\n    public uS: UtilityService,\n  ) {}\n\n  getErrorMessages(\n    form: Form | AbstractControl,\n    formName?: string,\n    _index?: number,\n    parent?: string,\n  ): IError {\n    // debugger;\n    let messages: IError = [];\n    if (hasError(form)) {\n      // debugger;\n      messages.push({\n        formControl: form,\n        label:\n          (_index ? `Item ${_index}: ` : '') +\n          (form.labelValue ||\n            (formName ? this.uS.formatField(formName) : formName?.toSentenceCase())),\n        parent,\n      });\n    }\n    if (form instanceof FormGroup)\n      for (const key in form.controls) {\n        if (Object.prototype.hasOwnProperty.call(form.controls, key)) {\n          const control = form.controls[key];\n          messages.push(\n            ...this.getErrorMessages(\n              control,\n              key,\n              _index,\n              form.labelValue || (formName ? this.uS.formatField(formName) : parent),\n            ),\n          );\n        }\n      }\n    else if (form instanceof FormArray)\n      for (let index = 0; index < form.length; index++) {\n        const control = form.controls[index];\n        debugger;\n        messages.push(\n          ...this.getErrorMessages(\n            control,\n            undefined,\n            index + 1,\n            form.labelValue || (formName ? this.uS.formatField(formName) : parent),\n          ),\n        );\n      }\n    return messages;\n    // debugger;\n    // console.log('message', this.message);\n  }\n}\ntype Form = FormGroup | FormControl | FormArray;\ntype IError = { formControl: AbstractControl; label: string; parent: string | null }[];\nfunction hasError(control: AbstractControl) {\n  if (control?.pending) return true;\n  else if (!control?.errors) return false;\n  else if (Object.keys(control.errors).length) return true;\n  return false;\n}\n","@if (hasError()) {\n  <div class=\"d-flex justify-content-end mt-2\">\n    <app-btn\n      text=\"Form Errors\"\n      icon=\"info\"\n      type=\"clear\"\n      mclass=\"btn-outline-warning\"\n      (mclick)=\"errCont.hidden = !errCont.hidden\" />\n  </div>\n  <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n    <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n      @if (false) {\n        <div class=\"col-lg-12 d-flex\">\n          <div>\n            <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n            <!-- <hr class=\"my-0\"> -->\n          </div>\n        </div>\n      }\n      @for (item of errors(); track item) {\n        @if (item.formControl) {\n          <div class=\"error-item-case\">\n            @if (item.parent) {\n              <app-info-icon text=\"Group: {{ item.parent }}\" />\n              <!-- <div class=\"\" [matTooltip]=\"item.parent\">Parent</div> -->\n            }\n            <app-validation-message\n              [label]=\"item.label | titlecase\"\n              [ignoreDirtiness]=\"true\"\n              [control]=\"item.formControl\" />\n          </div>\n        }\n      }\n    </div>\n  </div>\n}\n"]}
@@ -12689,13 +12689,13 @@ class FormErrorComponent {
12689
12689
  for (const key in form.controls) {
12690
12690
  if (Object.prototype.hasOwnProperty.call(form.controls, key)) {
12691
12691
  const control = form.controls[key];
12692
- messages.push(...this.getErrorMessages(control, key, _index, form.labelValue ||
12693
- (formName ? this.uS.formatField(formName) : formName?.toSentenceCase())));
12692
+ messages.push(...this.getErrorMessages(control, key, _index, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
12694
12693
  }
12695
12694
  }
12696
12695
  else if (form instanceof FormArray)
12697
12696
  for (let index = 0; index < form.length; index++) {
12698
12697
  const control = form.controls[index];
12698
+ debugger;
12699
12699
  messages.push(...this.getErrorMessages(control, undefined, index + 1, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
12700
12700
  }
12701
12701
  return messages;
@@ -12703,7 +12703,7 @@ class FormErrorComponent {
12703
12703
  // console.log('message', this.message);
12704
12704
  }
12705
12705
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormErrorComponent, deps: [{ token: i0.ElementRef }, { token: UtilityService }], target: i0.ɵɵFactoryTarget.Component }); }
12706
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: FormErrorComponent, isStandalone: true, selector: "form-error", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, lgGridNo: { classPropertyName: "lgGridNo", publicName: "lgGridNo", isSignal: true, isRequired: false, transformFunction: null }, xxlGridNo: { classPropertyName: "xxlGridNo", publicName: "xxlGridNo", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (hasError()) {\n <div class=\"d-flex justify-content-end mt-2\">\n <app-btn\n text=\"Form Errors\"\n icon=\"info\"\n type=\"clear\"\n mclass=\"btn-outline-warning\"\n (mclick)=\"errCont.hidden = !errCont.hidden\" />\n </div>\n <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n @if (false) {\n <div class=\"col-lg-12 d-flex\">\n <div>\n <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n <!-- <hr class=\"my-0\"> -->\n </div>\n </div>\n }\n @for (item of errors(); track item) {\n @if (item.formControl) {\n <div class=\"d-flex\">\n @if (item.parent) {\n <app-info-icon text=\"Group: {{item.parent}}\" />\n }\n <app-validation-message\n [label]=\"item.label | titlecase\"\n [ignoreDirtiness]=\"true\"\n [control]=\"item.formControl\" />\n </div>\n }\n }\n </div>\n </div>\n}\n", styles: [":host ::ng-deep .errormssg{color:#870000}:host .form-error-container{border-radius:10px}:host app-info-icon{margin-right:5px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }, { kind: "component", type: ValidationMessageComponent, selector: "app-validation-message", inputs: ["debug", "label", "hideOverflow", "minLength", "maxLength", "ignoreDirtiness", "customMessage", "control", "input"], outputs: ["labelChange"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "component", type: InfoIconComponent, selector: "app-info-icon", inputs: ["text", "coloured", "left", "right"] }] }); }
12706
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: FormErrorComponent, isStandalone: true, selector: "form-error", inputs: { form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: false, transformFunction: null }, lgGridNo: { classPropertyName: "lgGridNo", publicName: "lgGridNo", isSignal: true, isRequired: false, transformFunction: null }, xxlGridNo: { classPropertyName: "xxlGridNo", publicName: "xxlGridNo", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (hasError()) {\n <div class=\"d-flex justify-content-end mt-2\">\n <app-btn\n text=\"Form Errors\"\n icon=\"info\"\n type=\"clear\"\n mclass=\"btn-outline-warning\"\n (mclick)=\"errCont.hidden = !errCont.hidden\" />\n </div>\n <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n @if (false) {\n <div class=\"col-lg-12 d-flex\">\n <div>\n <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n <!-- <hr class=\"my-0\"> -->\n </div>\n </div>\n }\n @for (item of errors(); track item) {\n @if (item.formControl) {\n <div class=\"error-item-case\">\n @if (item.parent) {\n <app-info-icon text=\"Group: {{ item.parent }}\" />\n <!-- <div class=\"\" [matTooltip]=\"item.parent\">Parent</div> -->\n }\n <app-validation-message\n [label]=\"item.label | titlecase\"\n [ignoreDirtiness]=\"true\"\n [control]=\"item.formControl\" />\n </div>\n }\n }\n </div>\n </div>\n}\n", styles: [":host ::ng-deep .errormssg{color:#870000}:host .form-error-container{border-radius:10px}:host app-info-icon{margin-right:5px}:host .error-item-case{display:flex;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }, { kind: "component", type: ValidationMessageComponent, selector: "app-validation-message", inputs: ["debug", "label", "hideOverflow", "minLength", "maxLength", "ignoreDirtiness", "customMessage", "control", "input"], outputs: ["labelChange"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "verbose", "loading", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "form", "forms", "help", "iconBtn", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid", "disabled"], outputs: ["loadingChange", "leftCustomIconChange", "mclick", "disabledChange"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "component", type: InfoIconComponent, selector: "app-info-icon", inputs: ["text", "coloured", "left", "right"] }] }); }
12707
12707
  }
12708
12708
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormErrorComponent, decorators: [{
12709
12709
  type: Component,
@@ -12714,7 +12714,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
12714
12714
  BtnComponent,
12715
12715
  MatTooltipModule,
12716
12716
  InfoIconComponent,
12717
- ], template: "@if (hasError()) {\n <div class=\"d-flex justify-content-end mt-2\">\n <app-btn\n text=\"Form Errors\"\n icon=\"info\"\n type=\"clear\"\n mclass=\"btn-outline-warning\"\n (mclick)=\"errCont.hidden = !errCont.hidden\" />\n </div>\n <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n @if (false) {\n <div class=\"col-lg-12 d-flex\">\n <div>\n <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n <!-- <hr class=\"my-0\"> -->\n </div>\n </div>\n }\n @for (item of errors(); track item) {\n @if (item.formControl) {\n <div class=\"d-flex\">\n @if (item.parent) {\n <app-info-icon text=\"Group: {{item.parent}}\" />\n }\n <app-validation-message\n [label]=\"item.label | titlecase\"\n [ignoreDirtiness]=\"true\"\n [control]=\"item.formControl\" />\n </div>\n }\n }\n </div>\n </div>\n}\n", styles: [":host ::ng-deep .errormssg{color:#870000}:host .form-error-container{border-radius:10px}:host app-info-icon{margin-right:5px}\n"] }]
12717
+ ], template: "@if (hasError()) {\n <div class=\"d-flex justify-content-end mt-2\">\n <app-btn\n text=\"Form Errors\"\n icon=\"info\"\n type=\"clear\"\n mclass=\"btn-outline-warning\"\n (mclick)=\"errCont.hidden = !errCont.hidden\" />\n </div>\n <div class=\"border form-error-container p-3 mt-2\" #errCont [hidden]=\"true\">\n <div class=\"row row-cols-lg-{{ lgGridNo() }} row-cols-xxl-{{ xxlGridNo() }}\">\n @if (false) {\n <div class=\"col-lg-12 d-flex\">\n <div>\n <div class=\"pe-3\">{{ 'Form errors' | appTranslate | async }}</div>\n <!-- <hr class=\"my-0\"> -->\n </div>\n </div>\n }\n @for (item of errors(); track item) {\n @if (item.formControl) {\n <div class=\"error-item-case\">\n @if (item.parent) {\n <app-info-icon text=\"Group: {{ item.parent }}\" />\n <!-- <div class=\"\" [matTooltip]=\"item.parent\">Parent</div> -->\n }\n <app-validation-message\n [label]=\"item.label | titlecase\"\n [ignoreDirtiness]=\"true\"\n [control]=\"item.formControl\" />\n </div>\n }\n }\n </div>\n </div>\n}\n", styles: [":host ::ng-deep .errormssg{color:#870000}:host .form-error-container{border-radius:10px}:host app-info-icon{margin-right:5px}:host .error-item-case{display:flex;align-items:center}\n"] }]
12718
12718
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: UtilityService }] });
12719
12719
  function hasError(control) {
12720
12720
  if (control?.pending)