ets-fe-ng-sdk 17.0.419 → 17.0.421

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,5 +1,5 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { Component, computed, input, } from '@angular/core';
2
+ import { Component, computed, effect, input } from '@angular/core';
3
3
  import { FormArray, FormGroup } from '@angular/forms';
4
4
  import { debounceTime, filter, map, merge, switchMap } from 'rxjs';
5
5
  import { ValidationMessageComponent } from '../input/validation-message/validation-message.component';
@@ -43,6 +43,9 @@ export class FormErrorComponent {
43
43
  this.lgGridNo = input(2);
44
44
  this.xxlGridNo = input(3);
45
45
  this.hasError = computed(() => this.errors()?.length > 0);
46
+ effect(() => {
47
+ console.log('errored forms', this.errors());
48
+ });
46
49
  }
47
50
  getErrorMessages(form, formName, _index, parent) {
48
51
  // debugger;
@@ -67,7 +70,7 @@ export class FormErrorComponent {
67
70
  else if (form instanceof FormArray)
68
71
  for (let index = 0; index < form.length; index++) {
69
72
  const control = form.controls[index];
70
- debugger;
73
+ // debugger;
71
74
  messages.push(...this.getErrorMessages(control, undefined, index + 1, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
72
75
  }
73
76
  return messages;
@@ -97,4 +100,4 @@ function hasError(control) {
97
100
  return true;
98
101
  return false;
99
102
  }
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"]}
103
+ //# 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 { Component, ElementRef, computed, effect, input } from '@angular/core';\nimport { AbstractControl, FormArray, FormControl, FormGroup } from '@angular/forms';\nimport { debounceTime, filter, map, merge, 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    effect(() => {\n      console.log('errored forms', this.errors());\n    });\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"]}
@@ -2,6 +2,7 @@ import { Component, Pipe, computed, forwardRef, inject, input, model, } from '@a
2
2
  import { SDKTranslatePipe } from '../../../pipes/translate.pipe';
3
3
  import { NgIf, NgFor, AsyncPipe, CommonModule } from '@angular/common';
4
4
  import { MatTooltipModule } from '@angular/material/tooltip';
5
+ import { EValidationType } from '../../../models/index.model';
5
6
  import { ValidationMessageService } from './validation-message.service';
6
7
  import { debounceTime, filter, merge, switchMap } from 'rxjs';
7
8
  import { toSignal, toObservable } from '@angular/core/rxjs-interop';
@@ -38,6 +39,10 @@ export class ValidationMessageComponent {
38
39
  this.formFieldNotifier();
39
40
  return this.control()?.errors;
40
41
  });
42
+ this.pending = computed(() => {
43
+ this.formFieldNotifier();
44
+ return this.control()?.pending;
45
+ });
41
46
  this.dirty = computed(() => {
42
47
  this.formFieldNotifier();
43
48
  return this.control()?.dirty;
@@ -51,9 +56,11 @@ export class ValidationMessageComponent {
51
56
  // console.log('ERROR check', ++this.computeCount);
52
57
  if (this.debug())
53
58
  debugger;
54
- const errors = this.errors(), validations = this.vmS.validationMessages(), label = this.labelComputed(), maxLength = this.maxLength(), minLength = this.minLength(), customMessage = this.customMessage(), ignoreDirtiness = this.ignoreDirtiness(), dirty = this.dirty(), touched = this.touched();
59
+ const errors = this.errors(), pending = this.pending(), validations = this.vmS.validationMessages(), label = this.labelComputed(), maxLength = this.maxLength(), minLength = this.minLength(), customMessage = this.customMessage(), ignoreDirtiness = this.ignoreDirtiness(), dirty = this.dirty(), touched = this.touched();
55
60
  return errors && (ignoreDirtiness || dirty || touched)
56
- ? Object.entries(errors).map(([type, controlMessage]) => this.vmS.transform({ message: validations[type]?.message, type: type }, label, maxLength, minLength, controlMessage || customMessage))
61
+ ? Object.entries(errors)
62
+ .concat(pending ? [[EValidationType.pending, true]] : [])
63
+ .map(([type, controlMessage]) => this.vmS.transform({ message: validations[type]?.message, type: type }, label, maxLength, minLength, controlMessage || customMessage))
57
64
  : [];
58
65
  });
59
66
  this.labelComputed = computed(() => {
@@ -94,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
94
101
  standalone: true,
95
102
  }]
96
103
  }] });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-message.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/validation-message/validation-message.component.ts","../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/validation-message/validation-message.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Pipe,\n  PipeTransform,\n  computed,\n  forwardRef,\n  inject,\n  input,\n  model,\n} from '@angular/core';\nimport { AbstractControl } from '@angular/forms';\nimport { SDKTranslatePipe } from '../../../pipes/translate.pipe';\nimport { NgIf, NgFor, AsyncPipe, CommonModule } from '@angular/common';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { EValidationType, IObjectLiteral } from '../../../models/index.model';\nimport { ValidationMessageService } from './validation-message.service';\nimport { InputBasicComponent } from '../input-basic.component';\nimport { debounceTime, filter, merge, switchMap } from 'rxjs';\nimport { toSignal, toObservable } from '@angular/core/rxjs-interop';\n\n@Component({\n  selector: 'app-validation-message',\n  templateUrl: './validation-message.component.html',\n  styleUrls: ['./validation-message.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  //\n  imports: [\n    NgIf,\n    NgFor,\n    AsyncPipe,\n    CommonModule,\n    SDKTranslatePipe,\n    forwardRef(() => ErrorMessagePipe),\n    MatTooltipModule,\n  ],\n})\nexport class ValidationMessageComponent {\n  readonly debug = input<boolean>();\n\n  protected readonly computedControl = computed(() => this.control() || this.input()?.control());\n\n  protected readonly formFieldNotifier = toSignal(\n    toObservable(this.computedControl).pipe(\n      filter(() => this.control() != null),\n      switchMap((control) => merge(control?.valueChanges, control?.statusChanges)),\n      debounceTime(100),\n    ),\n  );\n  readonly label = model<string | undefined>();\n\n  readonly hideOverflow = input<boolean>(true);\n\n  readonly minLength = computed<number | undefined>(() => {\n    const t = this._minLength(),\n      i = this.input()?.minLength,\n      i2 = this.input()?.minSignal();\n    return t || i || +i2;\n  });\n  readonly _minLength = input<number>(undefined, { alias: 'minLength' });\n\n  readonly maxLength = computed<number | undefined>(() => {\n    const t = this._maxLength(),\n      i = this.input()?.maxLength,\n      i2 = this.input()?.maxSignal();\n    return t || i || +i2;\n  });\n  readonly _maxLength = input<number>(undefined, { alias: 'maxLength' });\n\n  readonly ignoreDirtiness = input<boolean>();\n  readonly customMessage = input('Value is invalid');\n\n  readonly control = input<AbstractControl>();\n\n  readonly input = input<InputBasicComponent | undefined>();\n\n  //   errors = computed<IObjectLiteral|undefined>(()=>{\n  // const controls\n  //     return undefined\n  //   });\n\n  readonly vmS = inject(ValidationMessageService);\n\n  readonly errors = computed<IObjectLiteral | undefined>(() => {\n    this.formFieldNotifier();\n    return this.control()?.errors;\n  });\n  readonly dirty = computed<boolean>(() => {\n    this.formFieldNotifier();\n    return this.control()?.dirty;\n  });\n  readonly touched = computed<boolean>(() => {\n    this.formFieldNotifier();\n    return this.control()?.touched;\n  });\n  // computeCount = 0;\n  readonly computedErrors = computed(() => {\n    // console.log('ERROR check', ++this.computeCount);\n    if (this.debug()) debugger;\n    const errors = this.errors(),\n      validations = this.vmS.validationMessages(),\n      label = this.labelComputed(),\n      maxLength = this.maxLength(),\n      minLength = this.minLength(),\n      customMessage = this.customMessage(),\n      ignoreDirtiness = this.ignoreDirtiness(),\n      dirty = this.dirty(),\n      touched = this.touched();\n\n    return errors && (ignoreDirtiness || dirty || touched)\n      ? Object.entries(errors).map(([type, controlMessage]) =>\n          this.vmS.transform(\n            { message: validations[type as EValidationType]?.message!, type: type as any },\n            label,\n            maxLength,\n            minLength,\n            controlMessage || customMessage,\n          ),\n        )\n      : [];\n  });\n\n  readonly labelComputed = computed<string>(() => {\n    if (this.debug()) debugger;\n    this.label();\n    this.input()?.labelSignal?.();\n    return this.label() || this.input()?.labelSignal?.();\n  });\n}\n\n@Pipe({\n  name: 'errorMessage',\n  standalone: true,\n})\nexport class ErrorMessagePipe implements PipeTransform {\n  vmS = inject(ValidationMessageService);\n  transform = this.vmS.transform;\n}\n","<div class=\"text-danger\" [ngClass]=\"{ hideOverflow: hideOverflow() }\" #el>\n  @for (error of computedErrors(); track error) {\n    <span\n      class=\"me-2 errormssg hide-scroll\"\n      [matTooltip]=\"ele.innerText\"\n      [matTooltipDisabled]=\"\n        ele.scrollHeight <= ele.offsetHeight && ele.scrollWidth <= ele.offsetWidth\n      \"\n      [innerHTML]=\"error | appTranslate | async\"\n      #ele></span>\n  }\n</div>\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-message.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/validation-message/validation-message.component.ts","../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/input/validation-message/validation-message.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,IAAI,EAEJ,QAAQ,EACR,UAAU,EACV,MAAM,EACN,KAAK,EACL,KAAK,GACN,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAkB,MAAM,6BAA6B,CAAC;AAC9E,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AAExE,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;;;;AAmBpE,MAAM,OAAO,0BAA0B;IAjBvC;QAkBW,UAAK,GAAG,KAAK,EAAW,CAAC;QAEf,oBAAe,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;QAE5E,sBAAiB,GAAG,QAAQ,CAC7C,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,IAAI,CACrC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,EACpC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,EAC5E,YAAY,CAAC,GAAG,CAAC,CAClB,CACF,CAAC;QACO,UAAK,GAAG,KAAK,EAAsB,CAAC;QAEpC,iBAAY,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QAEpC,cAAS,GAAG,QAAQ,CAAqB,GAAG,EAAE;YACrD,MAAM,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,EACzB,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,EAC3B,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC;YACjC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACM,eAAU,GAAG,KAAK,CAAS,SAAS,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;QAE9D,cAAS,GAAG,QAAQ,CAAqB,GAAG,EAAE;YACrD,MAAM,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,EACzB,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,EAC3B,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC;YACjC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACM,eAAU,GAAG,KAAK,CAAS,SAAS,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;QAE9D,oBAAe,GAAG,KAAK,EAAW,CAAC;QACnC,kBAAa,GAAG,KAAK,CAAC,kBAAkB,CAAC,CAAC;QAE1C,YAAO,GAAG,KAAK,EAAmB,CAAC;QAEnC,UAAK,GAAG,KAAK,EAAmC,CAAC;QAE1D,sDAAsD;QACtD,iBAAiB;QACjB,uBAAuB;QACvB,QAAQ;QAEC,QAAG,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QAEvC,WAAM,GAAG,QAAQ,CAA6B,GAAG,EAAE;YAC1D,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC,OAAO,EAAE,EAAE,MAAM,CAAC;QAChC,CAAC,CAAC,CAAC;QACM,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC/B,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC,OAAO,EAAE,EAAE,OAAO,CAAC;QACjC,CAAC,CAAC,CAAC;QACM,UAAK,GAAG,QAAQ,CAAU,GAAG,EAAE;YACtC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC,OAAO,EAAE,EAAE,KAAK,CAAC;QAC/B,CAAC,CAAC,CAAC;QACM,YAAO,GAAG,QAAQ,CAAU,GAAG,EAAE;YACxC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC,OAAO,EAAE,EAAE,OAAO,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,oBAAoB;QACX,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE;YACtC,mDAAmD;YACnD,IAAI,IAAI,CAAC,KAAK,EAAE;gBAAE,QAAQ,CAAC;YAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,EAC1B,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,EACxB,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,kBAAkB,EAAE,EAC3C,KAAK,GAAG,IAAI,CAAC,aAAa,EAAE,EAC5B,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,EAC5B,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,EAC5B,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,EACpC,eAAe,GAAG,IAAI,CAAC,eAAe,EAAE,EACxC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,EACpB,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAE3B,OAAO,MAAM,IAAI,CAAC,eAAe,IAAI,KAAK,IAAI,OAAO,CAAC;gBACpD,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;qBACnB,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;qBACxD,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,cAAc,CAAC,EAAE,EAAE,CAC9B,IAAI,CAAC,GAAG,CAAC,SAAS,CAChB,EAAE,OAAO,EAAE,WAAW,CAAC,IAAuB,CAAC,EAAE,OAAQ,EAAE,IAAI,EAAE,IAAW,EAAE,EAC9E,KAAK,EACL,SAAS,EACT,SAAS,EACT,cAAc,IAAI,aAAa,CAChC,CACF;gBACL,CAAC,CAAC,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;QAEM,kBAAa,GAAG,QAAQ,CAAS,GAAG,EAAE;YAC7C,IAAI,IAAI,CAAC,KAAK,EAAE;gBAAE,QAAQ,CAAC;YAC3B,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,EAAE,EAAE,WAAW,EAAE,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,WAAW,EAAE,EAAE,CAAC;QACvD,CAAC,CAAC,CAAC;KACJ;8GAlGY,0BAA0B;kGAA1B,0BAA0B,syCCtCvC,obAYA,sODmBI,SAAS,kEACT,YAAY,kKACZ,gBAAgB,yEAEhB,gBAAgB;;2FAGP,0BAA0B;kBAjBtC,SAAS;+BACE,wBAAwB,cAGtB,IAAI,WAGP;wBACP,IAAI;wBACJ,KAAK;wBACL,SAAS;wBACT,YAAY;wBACZ,gBAAgB;wBAChB,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC;wBAClC,gBAAgB;qBACjB;;AA0GH,MAAM,OAAO,gBAAgB;IAJ7B;QAKE,QAAG,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QACvC,cAAS,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC;KAChC;8GAHY,gBAAgB;4GAAhB,gBAAgB;;2FAAhB,gBAAgB;kBAJ5B,IAAI;mBAAC;oBACJ,IAAI,EAAE,cAAc;oBACpB,UAAU,EAAE,IAAI;iBACjB","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Pipe,\n  PipeTransform,\n  computed,\n  forwardRef,\n  inject,\n  input,\n  model,\n} from '@angular/core';\nimport { AbstractControl } from '@angular/forms';\nimport { SDKTranslatePipe } from '../../../pipes/translate.pipe';\nimport { NgIf, NgFor, AsyncPipe, CommonModule } from '@angular/common';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { EValidationType, IObjectLiteral } from '../../../models/index.model';\nimport { ValidationMessageService } from './validation-message.service';\nimport { InputBasicComponent } from '../input-basic.component';\nimport { debounceTime, filter, merge, switchMap } from 'rxjs';\nimport { toSignal, toObservable } from '@angular/core/rxjs-interop';\n\n@Component({\n  selector: 'app-validation-message',\n  templateUrl: './validation-message.component.html',\n  styleUrls: ['./validation-message.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  //\n  imports: [\n    NgIf,\n    NgFor,\n    AsyncPipe,\n    CommonModule,\n    SDKTranslatePipe,\n    forwardRef(() => ErrorMessagePipe),\n    MatTooltipModule,\n  ],\n})\nexport class ValidationMessageComponent {\n  readonly debug = input<boolean>();\n\n  protected readonly computedControl = computed(() => this.control() || this.input()?.control());\n\n  protected readonly formFieldNotifier = toSignal(\n    toObservable(this.computedControl).pipe(\n      filter(() => this.control() != null),\n      switchMap((control) => merge(control?.valueChanges, control?.statusChanges)),\n      debounceTime(100),\n    ),\n  );\n  readonly label = model<string | undefined>();\n\n  readonly hideOverflow = input<boolean>(true);\n\n  readonly minLength = computed<number | undefined>(() => {\n    const t = this._minLength(),\n      i = this.input()?.minLength,\n      i2 = this.input()?.minSignal();\n    return t || i || +i2;\n  });\n  readonly _minLength = input<number>(undefined, { alias: 'minLength' });\n\n  readonly maxLength = computed<number | undefined>(() => {\n    const t = this._maxLength(),\n      i = this.input()?.maxLength,\n      i2 = this.input()?.maxSignal();\n    return t || i || +i2;\n  });\n  readonly _maxLength = input<number>(undefined, { alias: 'maxLength' });\n\n  readonly ignoreDirtiness = input<boolean>();\n  readonly customMessage = input('Value is invalid');\n\n  readonly control = input<AbstractControl>();\n\n  readonly input = input<InputBasicComponent | undefined>();\n\n  //   errors = computed<IObjectLiteral|undefined>(()=>{\n  // const controls\n  //     return undefined\n  //   });\n\n  readonly vmS = inject(ValidationMessageService);\n\n  readonly errors = computed<IObjectLiteral | undefined>(() => {\n    this.formFieldNotifier();\n    return this.control()?.errors;\n  });\n  readonly pending = computed(() => {\n    this.formFieldNotifier();\n    return this.control()?.pending;\n  });\n  readonly dirty = computed<boolean>(() => {\n    this.formFieldNotifier();\n    return this.control()?.dirty;\n  });\n  readonly touched = computed<boolean>(() => {\n    this.formFieldNotifier();\n    return this.control()?.touched;\n  });\n  // computeCount = 0;\n  readonly computedErrors = computed(() => {\n    // console.log('ERROR check', ++this.computeCount);\n    if (this.debug()) debugger;\n    const errors = this.errors(),\n      pending = this.pending(),\n      validations = this.vmS.validationMessages(),\n      label = this.labelComputed(),\n      maxLength = this.maxLength(),\n      minLength = this.minLength(),\n      customMessage = this.customMessage(),\n      ignoreDirtiness = this.ignoreDirtiness(),\n      dirty = this.dirty(),\n      touched = this.touched();\n\n    return errors && (ignoreDirtiness || dirty || touched)\n      ? Object.entries(errors)\n          .concat(pending ? [[EValidationType.pending, true]] : [])\n          .map(([type, controlMessage]) =>\n            this.vmS.transform(\n              { message: validations[type as EValidationType]?.message!, type: type as any },\n              label,\n              maxLength,\n              minLength,\n              controlMessage || customMessage,\n            ),\n          )\n      : [];\n  });\n\n  readonly labelComputed = computed<string>(() => {\n    if (this.debug()) debugger;\n    this.label();\n    this.input()?.labelSignal?.();\n    return this.label() || this.input()?.labelSignal?.();\n  });\n}\n\n@Pipe({\n  name: 'errorMessage',\n  standalone: true,\n})\nexport class ErrorMessagePipe implements PipeTransform {\n  vmS = inject(ValidationMessageService);\n  transform = this.vmS.transform;\n}\n","<div class=\"text-danger\" [ngClass]=\"{ hideOverflow: hideOverflow() }\" #el>\n  @for (error of computedErrors(); track error) {\n    <span\n      class=\"me-2 errormssg hide-scroll\"\n      [matTooltip]=\"ele.innerText\"\n      [matTooltipDisabled]=\"\n        ele.scrollHeight <= ele.offsetHeight && ele.scrollWidth <= ele.offsetWidth\n      \"\n      [innerHTML]=\"error | appTranslate | async\"\n      #ele></span>\n  }\n</div>\n"]}
@@ -115,6 +115,7 @@ export var EValidationType;
115
115
  EValidationType["notFound"] = "notFound";
116
116
  EValidationType["used"] = "used";
117
117
  EValidationType["email"] = "email";
118
+ EValidationType["pending"] = "pending";
118
119
  })(EValidationType || (EValidationType = {}));
119
120
  export var EMenuType;
120
121
  (function (EMenuType) {
@@ -123,4 +124,4 @@ export var EMenuType;
123
124
  })(EMenuType || (EMenuType = {}));
124
125
  export class Constant {
125
126
  }
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.model.js","sourceRoot":"","sources":["../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/models/index.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormControl, FormGroup } from '@angular/forms';\nimport { Observable } from 'rxjs';\nimport { configForms } from './form.class';\nimport { AppRouteBase } from './RouteItem.class';\nimport { Btn, IconType } from '../components/btn/btn.model';\n\n//#region inputs\ninterface IETSInputBase {\n  name?: string;\n  label: string;\n  value?: any;\n  placeholder?: string;\n  cls?: string;\n  required?: boolean;\n  type?: InputType;\n}\ninterface IETSFCInput extends IETSInputBase {\n  name: string;\n  prefix?: string;\n  suffix?: string;\n  formControl: AbstractControl;\n  form: FormGroup;\n  vms?: IValidationMessage[];\n}\n\nexport type InputType =\n  | 'autocomplete'\n  | 'button'\n  | 'checkbox'\n  | 'checkedbox'\n  | 'color'\n  | 'date'\n  | 'datetime-local'\n  | 'dhm'\n  | 'email'\n  | 'file'\n  | 'fileButton'\n  | 'number'\n  | 'password'\n  | 'progress'\n  | 'percentage'\n  | 'richtext'\n  | 'radio'\n  | 'select'\n  | 'tel'\n  | 'text'\n  | 'textarea'\n  | 'time'\n  | 'viewer';\nexport class FCInput implements IETSFCInput {\n  name: string;\n  label: string;\n  placeholder?: string;\n  cls?: string;\n  prefix?: string;\n  suffix?: string;\n  required?: boolean;\n  type?: InputType;\n  formControl: AbstractControl;\n  vms?: IValidationMessage[];\n  form: FormGroup;\n  constructor(\n    label: string,\n    name?: string,\n    formControl?: AbstractControl,\n    type?: InputType,\n    required?: boolean,\n    placeholder?: string,\n    vms?: IValidationMessage[],\n    prefix?: string,\n    suffix?: string,\n  ) {\n    this.name = name || 'fn' + Math.round(Math.random() * 100000);\n    this.label = label;\n    this.formControl = formControl || configForms.default();\n    this.type = type || 'text';\n    this.required = required || false;\n    this.vms = vms || [];\n    this.placeholder = placeholder;\n    this.prefix = prefix;\n    this.suffix = suffix;\n  }\n}\nexport class CETSInput implements IETSInputBase {\n  name: string;\n  label: string;\n  placeholder?: string;\n  cls?: string;\n  required?: boolean;\n  type?: InputType;\n  value: string;\n  hide: boolean;\n  disabled: boolean;\n  readonly: boolean;\n  id: string;\n  hasError: boolean;\n  get isEmpty() {\n    return this.value == null || this.value == undefined;\n  }\n  x: number;\n  y: number;\n  constructor(\n    label: string,\n    name?: string,\n    value?: any,\n    type?: InputType,\n    required?: boolean,\n    placeholder?: string,\n    vms?: IValidationMessage[],\n    prefix?: string,\n    suffix?: string,\n  ) {\n    this.name = name;\n    this.id = 'inputID' + Math.round(Math.random() * 10000000);\n    this.label = label;\n    this.value = value;\n    this.type = type || 'text';\n    this.required = required || false;\n    this.placeholder = placeholder;\n  }\n}\n//#endregion\n\n//#region key value pair\nexport interface IKVP {\n  readonly key?: any;\n  value?: string | boolean | number;\n  cls?: string;\n}\nexport class ETSKVP implements IKVP {\n  readonly key: string;\n  value?: string | boolean | number;\n  cls?: string;\n  constructor(key: string, value?: string | boolean | number, cls?: string) {\n    this.key = key;\n    this.value = value;\n    this.cls = cls;\n  }\n}\nexport class ETSFKVP extends ETSKVP {\n  label: string;\n  editable?: boolean;\n  editing?: boolean;\n  route?: string;\n  routeFunc?: (item) => Promise<string> | Observable<string>;\n  hint?: string;\n  valueHint?: string;\n  action?: any;\n  isPhone?: boolean;\n  isEmail?: boolean;\n  formatter?: (val: any) => string | Promise<string> | Observable<string>;\n  constructor(\n    key: string,\n    label: string,\n    editable?: boolean,\n    value?: string | boolean | number,\n    public inputType?: InputType,\n    hint?: string,\n    action?: any,\n    formatter?: (val: any) => string | Promise<string>,\n    cls?: string,\n    route?: string,\n    valueHint?: string,\n  ) {\n    super(key, value, cls);\n    this.label = label;\n    this.hint = hint;\n    this.editable = editable;\n    this.action = action;\n    this.formatter = formatter;\n    this.route = route;\n    this.valueHint = valueHint;\n  }\n}\n//#endregion\n\n//#region lbl\nexport interface ILbl extends IKVP {\n  hint?: string;\n}\nexport class Lbl implements ILbl {\n  readonly key: string;\n  value: string | boolean | number;\n  hint?: string;\n  cls?: string;\n  constructor(key: string, value?: string | boolean | number, hint?: string, cls?: string) {\n    this.key = key;\n    this.value = value || '-';\n    this.hint = hint;\n    this.cls = cls;\n  }\n}\n//#endregion\n//#region btn\n//#endregion\n\n//#region table columns\nexport interface IRowOption<TRow> {\n  t: string;\n  itemClass?: string;\n  iconClass?: string;\n  action?: (row: TRow) => void;\n}\nexport type CellType = InputType | 'table' | 'btns' | 'editable' | 'input';\nexport interface ITableCol<T = any> {\n  t: string;\n  f: keyof T;\n  disabled?: boolean;\n  formatter?: (\n    val: any,\n  ) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  p?: string[];\n  formatterP?: (...val: any) => string;\n  hintFormatter?: (val: any) => Promise<string>;\n  routeFormatter?: FormatterFuncType<string, T>;\n  mqueryParams?: FormatterFuncType<{}, T>;\n  type?: CellType;\n  /**Use it to add column definitions for the Addition Columns component. Columns flagged as true will not show on the table until selected by the user.*/\n  additionalColumn?: boolean;\n  active?: boolean;\n}\nexport class TableCol<TRow = any> implements ITableCol<TRow> {\n  action?: (\n    row: any,\n    cellField: keyof TRow,\n    setLoading?: (value: boolean) => void,\n    index?: number,\n  ) => any;\n  active?: boolean;\n  additionalColumn?: boolean;\n  btn?: Btn<TRow>;\n  buttons?: Btn<TRow>[];\n  checked?: boolean;\n  sticky?: boolean;\n  f: keyof TRow;\n  formatter?: (\n    val: any,\n  ) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  expandedFormatter?: (\n    val: any,\n  ) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  hintFormatter?: (val: any) => Promise<string>;\n  formatterRow?: FormatterFuncType<string, TRow>;\n  expandedFormatterRow?: FormatterFuncType<string, TRow>;\n  hint?: string;\n  icon?: IconType;\n  mqueryParams?: FormatterFuncType<{}, TRow>;\n  p?: string[];\n  disabled?: boolean;\n  routeFormatter?: FormatterFuncType<string, TRow>;\n  subTable?: TableCol[];\n  t: string;\n  type?: CellType;\n  /**Specify whether to show button to expand column */\n  expandable?: boolean;\n  /**Width to use when modal is opened */\n  expandedWidth?: string;\n  noFormat?: boolean;\n  constructor(\n    t: string,\n    f?: keyof TRow,\n    formatter?: (val: any) => string | Promise<string>,\n    formatterRow?: FormatterFuncType,\n    type?: CellType,\n    checked?: boolean,\n    routeFormatter?: FormatterFuncType<string, TRow>,\n    mqueryParams?: FormatterFuncType<{}, TRow>,\n    action?: (row: any, cellField: keyof TRow) => any,\n  ) {\n    this.t = t;\n    this.f = f || (('f' + Math.round(Math.random() * 1000000)) as any);\n    this.formatter = formatter;\n    this.formatterRow = formatterRow;\n    this.type = type;\n    this.checked = checked || false;\n    this.routeFormatter = routeFormatter;\n    this.mqueryParams = mqueryParams;\n    this.action = action;\n  }\n}\n\n//#endregion\n\ntype FormatterFuncType<R = string, T = any> = (row: T, cellField?: keyof T) => R;\nexport interface ICodeTitle<Code = string> {\n  code: Code;\n  title: string;\n}\n\nexport interface ICodeDescription {\n  code: string;\n  description: string;\n}\n\nexport interface IMktDescription {\n  mktEventCode: string;\n  description: string;\n}\n\nexport interface ICode {\n  code: string;\n}\nexport enum EMenuLocation {\n  viewPage1 = 'viewPage',\n}\nexport enum Day {\n  sunday = 'Sunday',\n  monday = 'Monday',\n  tuesday = 'Tuesday',\n  wednesday = 'Wednesday',\n  thursday = 'Thursday',\n  friday = 'Friday',\n  saturday = 'Saturday',\n}\nexport enum EPageType {\n  clonePage = 'clonePage',\n  editPage = 'editPage',\n  showPage = 'showPage',\n  createPage = 'createPage',\n  indexPage = 'indexPage',\n}\nexport interface IDocMetadata {\n  boxNo?: string;\n  branch?: string;\n  category?: string;\n  createdBy?: string;\n  policyCode?: string;\n  policyNo?: string;\n  policyNoSuffix?: string;\n  refCat?: RefCat;\n  refNo?: string | number;\n  sensitivity?: string;\n  subCategory?: SubCategory;\n  title: string;\n}\nexport type RefCat =\n  | 'AGT'\n  | 'APP'\n  | 'ASS'\n  | 'AUTH'\n  | 'BAN'\n  | 'BAT'\n  | 'BRA'\n  | 'CLA'\n  | 'CLI'\n  | 'COM'\n  | 'COU'\n  | 'COV'\n  | 'DN'\n  | 'DOC'\n  | 'END'\n  | 'ENR'\n  | 'GRO'\n  | 'NB'\n  | 'PAY'\n  | 'PNS'\n  | 'PO'\n  | 'POL'\n  | 'PRO'\n  | 'QUO'\n  | 'RAT'\n  | 'SN'\n  | 'ST'\n  | 'TAR'\n  | 'TAS'\n  | 'TRA'\n  | 'TSC'\n  | 'USR'\n  | 'WF';\nexport type SubCategory =\n  | 'AGT'\n  | 'AOC'\n  | 'AP'\n  | 'CN'\n  | 'CSD'\n  | 'ID'\n  | 'LI'\n  | 'LIC'\n  | 'PP'\n  | 'RIB'\n  | 'SI';\nexport interface ISystem<SystemType = ESystem, TESystemBusLine = ESystemBusLine> {\n  appRoute: AppRouteBase;\n  name: SystemType;\n  busline: TESystemBusLine;\n  colourCode: string;\n  rootPath: string;\n}\n\nexport enum ESystem {}\nexport enum ESubSystem {}\nexport enum ESystemBusLine {}\nexport enum ELanguage {\n  EN = 'EN',\n  FR = 'FR',\n}\n\nexport enum EValidationType {\n  custom = 'custom',\n  invalid  = 'invalid',\n  maxlength = 'maxlength',\n  minlength = 'minlength',\n  pattern = 'pattern',\n  required = 'required',\n  unique = 'unique',\n  notFound = 'notFound',\n  used = 'used',\n  email = 'email',\n}\nexport interface IValidationMessage {\n  type: EValidationType;\n  message: string;\n}\nexport type SortType = 'asc' | 'desc';\n\ninterface Sort {\n  sorted: boolean;\n  unsorted: boolean;\n  empty: boolean;\n}\n\ninterface IPage<T> {\n  content: T[];\n  number: number;\n  size: number;\n  totalElements: number;\n  totalPages: number;\n  last: boolean;\n  first: boolean;\n  sort: Sort;\n  numberOfElements: number;\n  empty: boolean;\n}\n\ninterface GetQuery<T> {\n  pageNumber?: number;\n  pageSize?: number;\n  sortBy?: keyof T;\n  sortDirection?: SortType | 'DESC' | 'ASC';\n}\n\nexport type IGetQuery<T = any> = Partial<T> & GetQuery<T>;\n\nexport interface ISearchResponse<T = any> {\n  page: IPage<T>;\n  listSize: number;\n  pageNumber?: number;\n  pageSize?: number;\n  searchCriteria: any;\n  query?: IGetQuery;\n}\n\nexport interface ISearchResponse2<T = any> {\n  content: T[];\n  empty: boolean;\n  first: boolean;\n  last: boolean;\n  number: number;\n  numberOfElements: number;\n  size: number;\n  totalElements: number;\n  totalPages: number;\n  query?: IGetQuery;\n  sort: {\n    sorted: boolean;\n    unsorted: boolean;\n    empty: boolean;\n  };\n}\n\nexport type ImageType = 'pp' | 'other';\nexport interface ITab {\n  id?: string;\n  target?: string;\n  label: string;\n  form?: string;\n  postFunction?: (\n    data: any,\n    productCode?: string,\n  ) => Observable<{\n    data: any;\n    productCode: string;\n  }>;\n  putFunction?: (\n    data: any,\n    productCode: string,\n  ) => Observable<{\n    data: any;\n    productCode: string;\n  }>;\n  data?: any;\n}\nexport interface CustomValidationError {\n  custom?: string;\n  invalid?: boolean;\n  maxlength?: boolean;\n  maxLength?: boolean;\n  minlength?: boolean;\n  minLength?: boolean;\n  notFound?: boolean;\n  notUnique?: boolean;\n  pattern?: boolean;\n  required?: boolean;\n  used?: boolean;\n}\nexport enum EMenuType {\n  horizontal = 'H',\n  vertical = 'V',\n}\nexport interface IValueLabel<T> {\n  value: T;\n  label: string;\n}\n\nexport interface IConfigImages {\n  favicon: string;\n  watermark: string;\n  logo: {\n    dark: string;\n    light: string;\n  };\n  pp: {\n    src: string;\n    min: string;\n  };\n  other: {\n    src: string;\n    min: string;\n  };\n}\nexport class Constant {\n  //   constructor() {}\n}\n\nexport interface ITableName {\n  schema: string;\n  primaryTable: string;\n}\nexport interface ITypeDescription {\n  description: string;\n  type: string;\n}\nexport interface IServiceFunction {\n  _base?: (...args) => any;\n  search: (...args) => Observable<any>;\n  create: (...args) => Observable<any>;\n}\n\nexport type TypeOf =\n  | 'string'\n  | 'number'\n  | 'bigint'\n  | 'boolean'\n  | 'symbol'\n  | 'undefined'\n  | 'object'\n  | 'function';\n\nexport type Status = 'COMPLETED' | 'PENDING';\n\nexport type IStrictFormGroup<T> = {\n  [x in keyof T]: FormControl<T[x]>;\n};\n\nexport interface IObjectLiteral {\n  [x: string]: any;\n}\n\nexport interface IFile_Metadata {\n  file: File;\n  metadata: IDocMetadata;\n}\nexport type InputSubType = 'money';\n"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.model.js","sourceRoot":"","sources":["../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/models/index.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormControl, FormGroup } from '@angular/forms';\nimport { Observable } from 'rxjs';\nimport { configForms } from './form.class';\nimport { AppRouteBase } from './RouteItem.class';\nimport { Btn, IconType } from '../components/btn/btn.model';\n\n//#region inputs\ninterface IETSInputBase {\n  name?: string;\n  label: string;\n  value?: any;\n  placeholder?: string;\n  cls?: string;\n  required?: boolean;\n  type?: InputType;\n}\ninterface IETSFCInput extends IETSInputBase {\n  name: string;\n  prefix?: string;\n  suffix?: string;\n  formControl: AbstractControl;\n  form: FormGroup;\n  vms?: IValidationMessage[];\n}\n\nexport type InputType =\n  | 'autocomplete'\n  | 'button'\n  | 'checkbox'\n  | 'checkedbox'\n  | 'color'\n  | 'date'\n  | 'datetime-local'\n  | 'dhm'\n  | 'email'\n  | 'file'\n  | 'fileButton'\n  | 'number'\n  | 'password'\n  | 'progress'\n  | 'percentage'\n  | 'richtext'\n  | 'radio'\n  | 'select'\n  | 'tel'\n  | 'text'\n  | 'textarea'\n  | 'time'\n  | 'viewer';\nexport class FCInput implements IETSFCInput {\n  name: string;\n  label: string;\n  placeholder?: string;\n  cls?: string;\n  prefix?: string;\n  suffix?: string;\n  required?: boolean;\n  type?: InputType;\n  formControl: AbstractControl;\n  vms?: IValidationMessage[];\n  form: FormGroup;\n  constructor(\n    label: string,\n    name?: string,\n    formControl?: AbstractControl,\n    type?: InputType,\n    required?: boolean,\n    placeholder?: string,\n    vms?: IValidationMessage[],\n    prefix?: string,\n    suffix?: string,\n  ) {\n    this.name = name || 'fn' + Math.round(Math.random() * 100000);\n    this.label = label;\n    this.formControl = formControl || configForms.default();\n    this.type = type || 'text';\n    this.required = required || false;\n    this.vms = vms || [];\n    this.placeholder = placeholder;\n    this.prefix = prefix;\n    this.suffix = suffix;\n  }\n}\nexport class CETSInput implements IETSInputBase {\n  name: string;\n  label: string;\n  placeholder?: string;\n  cls?: string;\n  required?: boolean;\n  type?: InputType;\n  value: string;\n  hide: boolean;\n  disabled: boolean;\n  readonly: boolean;\n  id: string;\n  hasError: boolean;\n  get isEmpty() {\n    return this.value == null || this.value == undefined;\n  }\n  x: number;\n  y: number;\n  constructor(\n    label: string,\n    name?: string,\n    value?: any,\n    type?: InputType,\n    required?: boolean,\n    placeholder?: string,\n    vms?: IValidationMessage[],\n    prefix?: string,\n    suffix?: string,\n  ) {\n    this.name = name;\n    this.id = 'inputID' + Math.round(Math.random() * 10000000);\n    this.label = label;\n    this.value = value;\n    this.type = type || 'text';\n    this.required = required || false;\n    this.placeholder = placeholder;\n  }\n}\n//#endregion\n\n//#region key value pair\nexport interface IKVP {\n  readonly key?: any;\n  value?: string | boolean | number;\n  cls?: string;\n}\nexport class ETSKVP implements IKVP {\n  readonly key: string;\n  value?: string | boolean | number;\n  cls?: string;\n  constructor(key: string, value?: string | boolean | number, cls?: string) {\n    this.key = key;\n    this.value = value;\n    this.cls = cls;\n  }\n}\nexport class ETSFKVP extends ETSKVP {\n  label: string;\n  editable?: boolean;\n  editing?: boolean;\n  route?: string;\n  routeFunc?: (item) => Promise<string> | Observable<string>;\n  hint?: string;\n  valueHint?: string;\n  action?: any;\n  isPhone?: boolean;\n  isEmail?: boolean;\n  formatter?: (val: any) => string | Promise<string> | Observable<string>;\n  constructor(\n    key: string,\n    label: string,\n    editable?: boolean,\n    value?: string | boolean | number,\n    public inputType?: InputType,\n    hint?: string,\n    action?: any,\n    formatter?: (val: any) => string | Promise<string>,\n    cls?: string,\n    route?: string,\n    valueHint?: string,\n  ) {\n    super(key, value, cls);\n    this.label = label;\n    this.hint = hint;\n    this.editable = editable;\n    this.action = action;\n    this.formatter = formatter;\n    this.route = route;\n    this.valueHint = valueHint;\n  }\n}\n//#endregion\n\n//#region lbl\nexport interface ILbl extends IKVP {\n  hint?: string;\n}\nexport class Lbl implements ILbl {\n  readonly key: string;\n  value: string | boolean | number;\n  hint?: string;\n  cls?: string;\n  constructor(key: string, value?: string | boolean | number, hint?: string, cls?: string) {\n    this.key = key;\n    this.value = value || '-';\n    this.hint = hint;\n    this.cls = cls;\n  }\n}\n//#endregion\n//#region btn\n//#endregion\n\n//#region table columns\nexport interface IRowOption<TRow> {\n  t: string;\n  itemClass?: string;\n  iconClass?: string;\n  action?: (row: TRow) => void;\n}\nexport type CellType = InputType | 'table' | 'btns' | 'editable' | 'input';\nexport interface ITableCol<T = any> {\n  t: string;\n  f: keyof T;\n  disabled?: boolean;\n  formatter?: (\n    val: any,\n  ) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  p?: string[];\n  formatterP?: (...val: any) => string;\n  hintFormatter?: (val: any) => Promise<string>;\n  routeFormatter?: FormatterFuncType<string, T>;\n  mqueryParams?: FormatterFuncType<{}, T>;\n  type?: CellType;\n  /**Use it to add column definitions for the Addition Columns component. Columns flagged as true will not show on the table until selected by the user.*/\n  additionalColumn?: boolean;\n  active?: boolean;\n}\nexport class TableCol<TRow = any> implements ITableCol<TRow> {\n  action?: (\n    row: any,\n    cellField: keyof TRow,\n    setLoading?: (value: boolean) => void,\n    index?: number,\n  ) => any;\n  active?: boolean;\n  additionalColumn?: boolean;\n  btn?: Btn<TRow>;\n  buttons?: Btn<TRow>[];\n  checked?: boolean;\n  sticky?: boolean;\n  f: keyof TRow;\n  formatter?: (\n    val: any,\n  ) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  expandedFormatter?: (\n    val: any,\n  ) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  hintFormatter?: (val: any) => Promise<string>;\n  formatterRow?: FormatterFuncType<string, TRow>;\n  expandedFormatterRow?: FormatterFuncType<string, TRow>;\n  hint?: string;\n  icon?: IconType;\n  mqueryParams?: FormatterFuncType<{}, TRow>;\n  p?: string[];\n  disabled?: boolean;\n  routeFormatter?: FormatterFuncType<string, TRow>;\n  subTable?: TableCol[];\n  t: string;\n  type?: CellType;\n  /**Specify whether to show button to expand column */\n  expandable?: boolean;\n  /**Width to use when modal is opened */\n  expandedWidth?: string;\n  noFormat?: boolean;\n  constructor(\n    t: string,\n    f?: keyof TRow,\n    formatter?: (val: any) => string | Promise<string>,\n    formatterRow?: FormatterFuncType,\n    type?: CellType,\n    checked?: boolean,\n    routeFormatter?: FormatterFuncType<string, TRow>,\n    mqueryParams?: FormatterFuncType<{}, TRow>,\n    action?: (row: any, cellField: keyof TRow) => any,\n  ) {\n    this.t = t;\n    this.f = f || (('f' + Math.round(Math.random() * 1000000)) as any);\n    this.formatter = formatter;\n    this.formatterRow = formatterRow;\n    this.type = type;\n    this.checked = checked || false;\n    this.routeFormatter = routeFormatter;\n    this.mqueryParams = mqueryParams;\n    this.action = action;\n  }\n}\n\n//#endregion\n\ntype FormatterFuncType<R = string, T = any> = (row: T, cellField?: keyof T) => R;\nexport interface ICodeTitle<Code = string> {\n  code: Code;\n  title: string;\n}\n\nexport interface ICodeDescription {\n  code: string;\n  description: string;\n}\n\nexport interface IMktDescription {\n  mktEventCode: string;\n  description: string;\n}\n\nexport interface ICode {\n  code: string;\n}\nexport enum EMenuLocation {\n  viewPage1 = 'viewPage',\n}\nexport enum Day {\n  sunday = 'Sunday',\n  monday = 'Monday',\n  tuesday = 'Tuesday',\n  wednesday = 'Wednesday',\n  thursday = 'Thursday',\n  friday = 'Friday',\n  saturday = 'Saturday',\n}\nexport enum EPageType {\n  clonePage = 'clonePage',\n  editPage = 'editPage',\n  showPage = 'showPage',\n  createPage = 'createPage',\n  indexPage = 'indexPage',\n}\nexport interface IDocMetadata {\n  boxNo?: string;\n  branch?: string;\n  category?: string;\n  createdBy?: string;\n  policyCode?: string;\n  policyNo?: string;\n  policyNoSuffix?: string;\n  refCat?: RefCat;\n  refNo?: string | number;\n  sensitivity?: string;\n  subCategory?: SubCategory;\n  title: string;\n}\nexport type RefCat =\n  | 'AGT'\n  | 'APP'\n  | 'ASS'\n  | 'AUTH'\n  | 'BAN'\n  | 'BAT'\n  | 'BRA'\n  | 'CLA'\n  | 'CLI'\n  | 'COM'\n  | 'COU'\n  | 'COV'\n  | 'DN'\n  | 'DOC'\n  | 'END'\n  | 'ENR'\n  | 'GRO'\n  | 'NB'\n  | 'PAY'\n  | 'PNS'\n  | 'PO'\n  | 'POL'\n  | 'PRO'\n  | 'QUO'\n  | 'RAT'\n  | 'SN'\n  | 'ST'\n  | 'TAR'\n  | 'TAS'\n  | 'TRA'\n  | 'TSC'\n  | 'USR'\n  | 'WF';\nexport type SubCategory =\n  | 'AGT'\n  | 'AOC'\n  | 'AP'\n  | 'CN'\n  | 'CSD'\n  | 'ID'\n  | 'LI'\n  | 'LIC'\n  | 'PP'\n  | 'RIB'\n  | 'SI';\nexport interface ISystem<SystemType = ESystem, TESystemBusLine = ESystemBusLine> {\n  appRoute: AppRouteBase;\n  name: SystemType;\n  busline: TESystemBusLine;\n  colourCode: string;\n  rootPath: string;\n}\n\nexport enum ESystem {}\nexport enum ESubSystem {}\nexport enum ESystemBusLine {}\nexport enum ELanguage {\n  EN = 'EN',\n  FR = 'FR',\n}\n\nexport enum EValidationType {\n  custom = 'custom',\n  invalid  = 'invalid',\n  maxlength = 'maxlength',\n  minlength = 'minlength',\n  pattern = 'pattern',\n  required = 'required',\n  unique = 'unique',\n  notFound = 'notFound',\n  used = 'used',\n  email = 'email',\n  pending = \"pending\",\n}\nexport interface IValidationMessage {\n  type: EValidationType;\n  message: string;\n}\nexport type SortType = 'asc' | 'desc';\n\ninterface Sort {\n  sorted: boolean;\n  unsorted: boolean;\n  empty: boolean;\n}\n\ninterface IPage<T> {\n  content: T[];\n  number: number;\n  size: number;\n  totalElements: number;\n  totalPages: number;\n  last: boolean;\n  first: boolean;\n  sort: Sort;\n  numberOfElements: number;\n  empty: boolean;\n}\n\ninterface GetQuery<T> {\n  pageNumber?: number;\n  pageSize?: number;\n  sortBy?: keyof T;\n  sortDirection?: SortType | 'DESC' | 'ASC';\n}\n\nexport type IGetQuery<T = any> = Partial<T> & GetQuery<T>;\n\nexport interface ISearchResponse<T = any> {\n  page: IPage<T>;\n  listSize: number;\n  pageNumber?: number;\n  pageSize?: number;\n  searchCriteria: any;\n  query?: IGetQuery;\n}\n\nexport interface ISearchResponse2<T = any> {\n  content: T[];\n  empty: boolean;\n  first: boolean;\n  last: boolean;\n  number: number;\n  numberOfElements: number;\n  size: number;\n  totalElements: number;\n  totalPages: number;\n  query?: IGetQuery;\n  sort: {\n    sorted: boolean;\n    unsorted: boolean;\n    empty: boolean;\n  };\n}\n\nexport type ImageType = 'pp' | 'other';\nexport interface ITab {\n  id?: string;\n  target?: string;\n  label: string;\n  form?: string;\n  postFunction?: (\n    data: any,\n    productCode?: string,\n  ) => Observable<{\n    data: any;\n    productCode: string;\n  }>;\n  putFunction?: (\n    data: any,\n    productCode: string,\n  ) => Observable<{\n    data: any;\n    productCode: string;\n  }>;\n  data?: any;\n}\nexport interface CustomValidationError {\n  custom?: string;\n  invalid?: boolean;\n  maxlength?: boolean;\n  maxLength?: boolean;\n  minlength?: boolean;\n  minLength?: boolean;\n  notFound?: boolean;\n  notUnique?: boolean;\n  pattern?: boolean;\n  required?: boolean;\n  used?: boolean;\n}\nexport enum EMenuType {\n  horizontal = 'H',\n  vertical = 'V',\n}\nexport interface IValueLabel<T> {\n  value: T;\n  label: string;\n}\n\nexport interface IConfigImages {\n  favicon: string;\n  watermark: string;\n  logo: {\n    dark: string;\n    light: string;\n  };\n  pp: {\n    src: string;\n    min: string;\n  };\n  other: {\n    src: string;\n    min: string;\n  };\n}\nexport class Constant {\n  //   constructor() {}\n}\n\nexport interface ITableName {\n  schema: string;\n  primaryTable: string;\n}\nexport interface ITypeDescription {\n  description: string;\n  type: string;\n}\nexport interface IServiceFunction {\n  _base?: (...args) => any;\n  search: (...args) => Observable<any>;\n  create: (...args) => Observable<any>;\n}\n\nexport type TypeOf =\n  | 'string'\n  | 'number'\n  | 'bigint'\n  | 'boolean'\n  | 'symbol'\n  | 'undefined'\n  | 'object'\n  | 'function';\n\nexport type Status = 'COMPLETED' | 'PENDING';\n\nexport type IStrictFormGroup<T> = {\n  [x in keyof T]: FormControl<T[x]>;\n};\n\nexport interface IObjectLiteral {\n  [x: string]: any;\n}\n\nexport interface IFile_Metadata {\n  file: File;\n  metadata: IDocMetadata;\n}\nexport type InputSubType = 'money';\n"]}
@@ -19,8 +19,11 @@ export const configValidationMessages = {
19
19
  [EValidationType.invalid]: {
20
20
  message: ' is invalid.',
21
21
  },
22
+ [EValidationType.pending]: {
23
+ message: ' is being checked.',
24
+ },
22
25
  [EValidationType.pattern]: { message: ' is invalid.' },
23
26
  [EValidationType.notFound]: { message: " doesn't exist." },
24
27
  [EValidationType.custom]: {},
25
28
  };
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1tZXNzYWdlcy5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvY29uZmlncy92YWxpZGF0aW9uLW1lc3NhZ2VzLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFzQixNQUFNLDhCQUE4QixDQUFDO0FBRW5GLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFxRDtJQUN4RixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUU7SUFDeEQsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLEVBQUU7UUFDM0IsT0FBTyxFQUFFLGlEQUFpRDtLQUMzRDtJQUNELENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQzNCLE9BQU8sRUFBRSxrREFBa0Q7S0FDNUQ7SUFDRCxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUN4QixPQUFPLEVBQUUsa0JBQWtCO0tBQzVCO0lBQ0QsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDdEIsT0FBTyxFQUFFLHlCQUF5QjtLQUNuQztJQUNELENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQ3ZCLE9BQU8sRUFBRSxtQkFBbUI7S0FDN0I7SUFDRCxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUN6QixPQUFPLEVBQUUsY0FBYztLQUN4QjtJQUNELENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRTtJQUN0RCxDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRTtJQUMxRCxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFO0NBQzdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFVmFsaWRhdGlvblR5cGUsIElWYWxpZGF0aW9uTWVzc2FnZSB9IGZyb20gJy4uL1NoYXJlZC9tb2RlbHMvaW5kZXgubW9kZWwnO1xuXG5leHBvcnQgY29uc3QgY29uZmlnVmFsaWRhdGlvbk1lc3NhZ2VzOiB7IFt4IGluIEVWYWxpZGF0aW9uVHlwZV06IHsgbWVzc2FnZT86IHN0cmluZyB9IH0gPSB7XG4gIFtFVmFsaWRhdGlvblR5cGUucmVxdWlyZWRdOiB7IG1lc3NhZ2U6ICcgaXMgcmVxdWlyZWQuJyB9LFxuICBbRVZhbGlkYXRpb25UeXBlLm1heGxlbmd0aF06IHtcbiAgICBtZXNzYWdlOiAnIG11c3QgYmUgYXQgbW9zdCB7e21heExlbmd0aH19IGNoYXJhY3RlcnMgbG9uZy4nLFxuICB9LFxuICBbRVZhbGlkYXRpb25UeXBlLm1pbmxlbmd0aF06IHtcbiAgICBtZXNzYWdlOiAnIG11c3QgYmUgYXQgbGVhc3Qge3ttaW5MZW5ndGh9fSBjaGFyYWN0ZXJzIGxvbmcuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS51bmlxdWVdOiB7XG4gICAgbWVzc2FnZTogJyBhbHJlYWR5IGV4aXN0cy4nLFxuICB9LFxuICBbRVZhbGlkYXRpb25UeXBlLnVzZWRdOiB7XG4gICAgbWVzc2FnZTogJyBoYXMgYWxyZWFkeSBiZWVuIHVzZWQuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5lbWFpbF06IHtcbiAgICBtZXNzYWdlOiAnRW1haWwgaXMgaW52YWxpZC4nLFxuICB9LFxuICBbRVZhbGlkYXRpb25UeXBlLmludmFsaWRdOiB7XG4gICAgbWVzc2FnZTogJyBpcyBpbnZhbGlkLicsXG4gIH0sXG4gIFtFVmFsaWRhdGlvblR5cGUucGF0dGVybl06IHsgbWVzc2FnZTogJyBpcyBpbnZhbGlkLicgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5ub3RGb3VuZF06IHsgbWVzc2FnZTogXCIgZG9lc24ndCBleGlzdC5cIiB9LFxuICBbRVZhbGlkYXRpb25UeXBlLmN1c3RvbV06IHt9LFxufTtcbiJdfQ==
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1tZXNzYWdlcy5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvY29uZmlncy92YWxpZGF0aW9uLW1lc3NhZ2VzLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFzQixNQUFNLDhCQUE4QixDQUFDO0FBRW5GLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFxRDtJQUN4RixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUU7SUFDeEQsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLEVBQUU7UUFDM0IsT0FBTyxFQUFFLGlEQUFpRDtLQUMzRDtJQUNELENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQzNCLE9BQU8sRUFBRSxrREFBa0Q7S0FDNUQ7SUFDRCxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUN4QixPQUFPLEVBQUUsa0JBQWtCO0tBQzVCO0lBQ0QsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDdEIsT0FBTyxFQUFFLHlCQUF5QjtLQUNuQztJQUNELENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQ3ZCLE9BQU8sRUFBRSxtQkFBbUI7S0FDN0I7SUFDRCxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUN6QixPQUFPLEVBQUUsY0FBYztLQUN4QjtJQUNELENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQ3pCLE9BQU8sRUFBRSxvQkFBb0I7S0FDOUI7SUFDRCxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUU7SUFDdEQsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUU7SUFDMUQsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRTtDQUM3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRVZhbGlkYXRpb25UeXBlLCBJVmFsaWRhdGlvbk1lc3NhZ2UgfSBmcm9tICcuLi9TaGFyZWQvbW9kZWxzL2luZGV4Lm1vZGVsJztcblxuZXhwb3J0IGNvbnN0IGNvbmZpZ1ZhbGlkYXRpb25NZXNzYWdlczogeyBbeCBpbiBFVmFsaWRhdGlvblR5cGVdOiB7IG1lc3NhZ2U/OiBzdHJpbmcgfSB9ID0ge1xuICBbRVZhbGlkYXRpb25UeXBlLnJlcXVpcmVkXTogeyBtZXNzYWdlOiAnIGlzIHJlcXVpcmVkLicgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5tYXhsZW5ndGhdOiB7XG4gICAgbWVzc2FnZTogJyBtdXN0IGJlIGF0IG1vc3Qge3ttYXhMZW5ndGh9fSBjaGFyYWN0ZXJzIGxvbmcuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5taW5sZW5ndGhdOiB7XG4gICAgbWVzc2FnZTogJyBtdXN0IGJlIGF0IGxlYXN0IHt7bWluTGVuZ3RofX0gY2hhcmFjdGVycyBsb25nLicsXG4gIH0sXG4gIFtFVmFsaWRhdGlvblR5cGUudW5pcXVlXToge1xuICAgIG1lc3NhZ2U6ICcgYWxyZWFkeSBleGlzdHMuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS51c2VkXToge1xuICAgIG1lc3NhZ2U6ICcgaGFzIGFscmVhZHkgYmVlbiB1c2VkLicsXG4gIH0sXG4gIFtFVmFsaWRhdGlvblR5cGUuZW1haWxdOiB7XG4gICAgbWVzc2FnZTogJ0VtYWlsIGlzIGludmFsaWQuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5pbnZhbGlkXToge1xuICAgIG1lc3NhZ2U6ICcgaXMgaW52YWxpZC4nLFxuICB9LFxuICBbRVZhbGlkYXRpb25UeXBlLnBlbmRpbmddOiB7XG4gICAgbWVzc2FnZTogJyBpcyBiZWluZyBjaGVja2VkLicsXG4gIH0sXG4gIFtFVmFsaWRhdGlvblR5cGUucGF0dGVybl06IHsgbWVzc2FnZTogJyBpcyBpbnZhbGlkLicgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5ub3RGb3VuZF06IHsgbWVzc2FnZTogXCIgZG9lc24ndCBleGlzdC5cIiB9LFxuICBbRVZhbGlkYXRpb25UeXBlLmN1c3RvbV06IHt9LFxufTtcbiJdfQ==
@@ -363,6 +363,7 @@ var EValidationType;
363
363
  EValidationType["notFound"] = "notFound";
364
364
  EValidationType["used"] = "used";
365
365
  EValidationType["email"] = "email";
366
+ EValidationType["pending"] = "pending";
366
367
  })(EValidationType || (EValidationType = {}));
367
368
  var EMenuType;
368
369
  (function (EMenuType) {
@@ -1241,6 +1242,9 @@ const configValidationMessages = {
1241
1242
  [EValidationType.invalid]: {
1242
1243
  message: ' is invalid.',
1243
1244
  },
1245
+ [EValidationType.pending]: {
1246
+ message: ' is being checked.',
1247
+ },
1244
1248
  [EValidationType.pattern]: { message: ' is invalid.' },
1245
1249
  [EValidationType.notFound]: { message: " doesn't exist." },
1246
1250
  [EValidationType.custom]: {},
@@ -5344,6 +5348,10 @@ class ValidationMessageComponent {
5344
5348
  this.formFieldNotifier();
5345
5349
  return this.control()?.errors;
5346
5350
  });
5351
+ this.pending = computed(() => {
5352
+ this.formFieldNotifier();
5353
+ return this.control()?.pending;
5354
+ });
5347
5355
  this.dirty = computed(() => {
5348
5356
  this.formFieldNotifier();
5349
5357
  return this.control()?.dirty;
@@ -5357,9 +5365,11 @@ class ValidationMessageComponent {
5357
5365
  // console.log('ERROR check', ++this.computeCount);
5358
5366
  if (this.debug())
5359
5367
  debugger;
5360
- const errors = this.errors(), validations = this.vmS.validationMessages(), label = this.labelComputed(), maxLength = this.maxLength(), minLength = this.minLength(), customMessage = this.customMessage(), ignoreDirtiness = this.ignoreDirtiness(), dirty = this.dirty(), touched = this.touched();
5368
+ const errors = this.errors(), pending = this.pending(), validations = this.vmS.validationMessages(), label = this.labelComputed(), maxLength = this.maxLength(), minLength = this.minLength(), customMessage = this.customMessage(), ignoreDirtiness = this.ignoreDirtiness(), dirty = this.dirty(), touched = this.touched();
5361
5369
  return errors && (ignoreDirtiness || dirty || touched)
5362
- ? Object.entries(errors).map(([type, controlMessage]) => this.vmS.transform({ message: validations[type]?.message, type: type }, label, maxLength, minLength, controlMessage || customMessage))
5370
+ ? Object.entries(errors)
5371
+ .concat(pending ? [[EValidationType.pending, true]] : [])
5372
+ .map(([type, controlMessage]) => this.vmS.transform({ message: validations[type]?.message, type: type }, label, maxLength, minLength, controlMessage || customMessage))
5363
5373
  : [];
5364
5374
  });
5365
5375
  this.labelComputed = computed(() => {
@@ -12671,6 +12681,9 @@ class FormErrorComponent {
12671
12681
  this.lgGridNo = input(2);
12672
12682
  this.xxlGridNo = input(3);
12673
12683
  this.hasError = computed(() => this.errors()?.length > 0);
12684
+ effect(() => {
12685
+ console.log('errored forms', this.errors());
12686
+ });
12674
12687
  }
12675
12688
  getErrorMessages(form, formName, _index, parent) {
12676
12689
  // debugger;
@@ -12695,7 +12708,7 @@ class FormErrorComponent {
12695
12708
  else if (form instanceof FormArray)
12696
12709
  for (let index = 0; index < form.length; index++) {
12697
12710
  const control = form.controls[index];
12698
- debugger;
12711
+ // debugger;
12699
12712
  messages.push(...this.getErrorMessages(control, undefined, index + 1, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
12700
12713
  }
12701
12714
  return messages;