ets-fe-ng-sdk 17.0.416 → 17.0.418

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.
@@ -2,7 +2,7 @@ import { Injectable } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class AutocompleteService {
4
4
  constructor() {
5
- this.invalidSelectionError = { custom: `Invalid value` };
5
+ this.invalidSelectionError = { invalid: true };
6
6
  this.displayWith = (options) => (val) => {
7
7
  console.log('this.options', options);
8
8
  return options?.find((x) => x.value == val)?.label || val;
@@ -26,4 +26,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
26
26
  providedIn: 'root',
27
27
  }]
28
28
  }], ctorParameters: () => [] });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvU2hhcmVkL2NvbXBvbmVudHMvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTTNDLE1BQU0sT0FBTyxtQkFBbUI7SUFHOUI7UUFGUywwQkFBcUIsR0FBRyxFQUFFLE1BQU0sRUFBRSxlQUFlLEVBQUUsQ0FBQztRQWU3RCxnQkFBVyxHQUFHLENBQUMsT0FBYyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3hDLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQ3JDLE9BQU8sT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxHQUFHLENBQUMsRUFBRSxLQUFLLElBQUksR0FBRyxDQUFDO1FBQzVELENBQUMsQ0FBQztJQWhCYSxDQUFDO0lBRWhCLGFBQWEsQ0FBQyxLQUFhLEVBQUUsT0FBa0I7UUFDN0MsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQyxPQUFPLFdBQVc7WUFDaEIsQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUN2RixDQUFDLENBQUMsT0FBTyxDQUFDO0lBQ2QsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFhO1FBQzFCLE9BQU8sS0FBSyxFQUFFLFFBQVEsRUFBRSxFQUFFLFdBQVcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDN0QsQ0FBQzs4R0FkVSxtQkFBbUI7a0hBQW5CLG1CQUFtQixjQUZsQixNQUFNOzsyRkFFUCxtQkFBbUI7a0JBSC9CLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSU9wdGlvbiB9IGZyb20gJy4uL2lucHV0L2lucHV0LnNlcnZpY2UnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgQXV0b2NvbXBsZXRlU2VydmljZSB7XG4gIHJlYWRvbmx5IGludmFsaWRTZWxlY3Rpb25FcnJvciA9IHsgY3VzdG9tOiBgSW52YWxpZCB2YWx1ZWAgfTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgZmlsdGVyT3B0aW9ucyhxdWVyeTogc3RyaW5nLCBvcHRpb25zOiBJT3B0aW9uW10pOiBJT3B0aW9uW10ge1xuICAgIGNvbnN0IGZpbHRlclZhbHVlID0gdGhpcy5ub3JtYWxpemVWYWx1ZShxdWVyeSk7XG4gICAgcmV0dXJuIGZpbHRlclZhbHVlXG4gICAgICA/IG9wdGlvbnM/LmZpbHRlcigob3B0aW9uKSA9PiB0aGlzLm5vcm1hbGl6ZVZhbHVlKG9wdGlvbi5sYWJlbCk/LmluY2x1ZGVzKGZpbHRlclZhbHVlKSlcbiAgICAgIDogb3B0aW9ucztcbiAgfVxuXG4gIG5vcm1hbGl6ZVZhbHVlKHZhbHVlOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiB2YWx1ZT8udG9TdHJpbmcoKT8udG9Mb3dlckNhc2UoKS5yZXBsYWNlKC9cXHMvZywgJycpO1xuICB9XG5cbiAgZGlzcGxheVdpdGggPSAob3B0aW9uczogYW55W10pID0+ICh2YWwpID0+IHtcbiAgICBjb25zb2xlLmxvZygndGhpcy5vcHRpb25zJywgb3B0aW9ucyk7XG4gICAgcmV0dXJuIG9wdGlvbnM/LmZpbmQoKHgpID0+IHgudmFsdWUgPT0gdmFsKT8ubGFiZWwgfHwgdmFsO1xuICB9O1xufVxuIl19
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvU2hhcmVkL2NvbXBvbmVudHMvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzNDLE1BQU0sT0FBTyxtQkFBbUI7SUFHOUI7UUFGUywwQkFBcUIsR0FBMEIsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFlMUUsZ0JBQVcsR0FBRyxDQUFDLE9BQWMsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUN4QyxPQUFPLENBQUMsR0FBRyxDQUFDLGNBQWMsRUFBRSxPQUFPLENBQUMsQ0FBQztZQUNyQyxPQUFPLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksR0FBRyxDQUFDLEVBQUUsS0FBSyxJQUFJLEdBQUcsQ0FBQztRQUM1RCxDQUFDLENBQUM7SUFoQmEsQ0FBQztJQUVoQixhQUFhLENBQUMsS0FBYSxFQUFFLE9BQWtCO1FBQzdDLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0MsT0FBTyxXQUFXO1lBQ2hCLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDdkYsQ0FBQyxDQUFDLE9BQU8sQ0FBQztJQUNkLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBYTtRQUMxQixPQUFPLEtBQUssRUFBRSxRQUFRLEVBQUUsRUFBRSxXQUFXLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzdELENBQUM7OEdBZFUsbUJBQW1CO2tIQUFuQixtQkFBbUIsY0FGbEIsTUFBTTs7MkZBRVAsbUJBQW1CO2tCQUgvQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElPcHRpb24gfSBmcm9tICcuLi9pbnB1dC9pbnB1dC5zZXJ2aWNlJztcbmltcG9ydCB7IEN1c3RvbVZhbGlkYXRpb25FcnJvciB9IGZyb20gJy4uLy4uL21vZGVscy9pbmRleC5tb2RlbCc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBBdXRvY29tcGxldGVTZXJ2aWNlIHtcbiAgcmVhZG9ubHkgaW52YWxpZFNlbGVjdGlvbkVycm9yOiBDdXN0b21WYWxpZGF0aW9uRXJyb3IgPSB7IGludmFsaWQ6IHRydWUgfTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgZmlsdGVyT3B0aW9ucyhxdWVyeTogc3RyaW5nLCBvcHRpb25zOiBJT3B0aW9uW10pOiBJT3B0aW9uW10ge1xuICAgIGNvbnN0IGZpbHRlclZhbHVlID0gdGhpcy5ub3JtYWxpemVWYWx1ZShxdWVyeSk7XG4gICAgcmV0dXJuIGZpbHRlclZhbHVlXG4gICAgICA/IG9wdGlvbnM/LmZpbHRlcigob3B0aW9uKSA9PiB0aGlzLm5vcm1hbGl6ZVZhbHVlKG9wdGlvbi5sYWJlbCk/LmluY2x1ZGVzKGZpbHRlclZhbHVlKSlcbiAgICAgIDogb3B0aW9ucztcbiAgfVxuXG4gIG5vcm1hbGl6ZVZhbHVlKHZhbHVlOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiB2YWx1ZT8udG9TdHJpbmcoKT8udG9Mb3dlckNhc2UoKS5yZXBsYWNlKC9cXHMvZywgJycpO1xuICB9XG5cbiAgZGlzcGxheVdpdGggPSAob3B0aW9uczogYW55W10pID0+ICh2YWwpID0+IHtcbiAgICBjb25zb2xlLmxvZygndGhpcy5vcHRpb25zJywgb3B0aW9ucyk7XG4gICAgcmV0dXJuIG9wdGlvbnM/LmZpbmQoKHgpID0+IHgudmFsdWUgPT0gdmFsKT8ubGFiZWwgfHwgdmFsO1xuICB9O1xufVxuIl19
@@ -1,5 +1,5 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { Component, input, } from '@angular/core';
2
+ import { Component, computed, 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';
@@ -12,6 +12,7 @@ import { InfoIconComponent } from '../info-icon/info-icon.component';
12
12
  import * as i0 from "@angular/core";
13
13
  import * as i1 from "../../../Services/utility.service";
14
14
  import * as i2 from "@angular/common";
15
+ import * as i3 from "@angular/material/tooltip";
15
16
  export class FormErrorComponent {
16
17
  constructor(el, uS) {
17
18
  this.el = el;
@@ -42,6 +43,7 @@ export class FormErrorComponent {
42
43
  // protected forms?: Form[];
43
44
  this.lgGridNo = input(2);
44
45
  this.xxlGridNo = input(3);
46
+ this.hasError = computed(() => this.errors()?.length > 0);
45
47
  }
46
48
  getErrorMessages(form, formName, _index, parent) {
47
49
  // debugger;
@@ -60,21 +62,21 @@ export class FormErrorComponent {
60
62
  for (const key in form.controls) {
61
63
  if (Object.prototype.hasOwnProperty.call(form.controls, key)) {
62
64
  const control = form.controls[key];
63
- messages.push(...this.getErrorMessages(control, key, _index, form.labelValue ||
64
- (formName ? this.uS.formatField(formName) : formName?.toSentenceCase())));
65
+ messages.push(...this.getErrorMessages(control, key, _index, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
65
66
  }
66
67
  }
67
68
  else if (form instanceof FormArray)
68
69
  for (let index = 0; index < form.length; index++) {
69
70
  const control = form.controls[index];
70
- messages.push(...this.getErrorMessages(control, undefined, index + 1));
71
+ debugger;
72
+ messages.push(...this.getErrorMessages(control, undefined, index + 1, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
71
73
  }
72
74
  return messages;
73
75
  // debugger;
74
76
  // console.log('message', this.message);
75
77
  }
76
78
  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 }); }
77
- 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 (errors()?.length) {\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}\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
+ 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: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: InfoIconComponent, selector: "app-info-icon", inputs: ["text", "coloured", "left", "right"] }] }); }
78
80
  }
79
81
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormErrorComponent, decorators: [{
80
82
  type: Component,
@@ -83,8 +85,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
83
85
  SDKTranslatePipe,
84
86
  ValidationMessageComponent,
85
87
  BtnComponent,
86
- MatTooltipModule, InfoIconComponent
87
- ], template: "@if (errors()?.length) {\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}\n"] }]
88
+ MatTooltipModule,
89
+ InfoIconComponent,
90
+ ], 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"] }]
88
91
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.UtilityService }] });
89
92
  function hasError(control) {
90
93
  if (control?.pending)
@@ -95,4 +98,4 @@ function hasError(control) {
95
98
  return true;
96
99
  return false;
97
100
  }
98
- //# 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,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  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(...this.getErrorMessages(control, undefined, index + 1));\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 (errors()?.length) {\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"]}
101
+ //# 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"]}
@@ -106,6 +106,7 @@ export var ELanguage;
106
106
  export var EValidationType;
107
107
  (function (EValidationType) {
108
108
  EValidationType["custom"] = "custom";
109
+ EValidationType["invalid"] = "invalid";
109
110
  EValidationType["maxlength"] = "maxlength";
110
111
  EValidationType["minlength"] = "minlength";
111
112
  EValidationType["pattern"] = "pattern";
@@ -122,4 +123,4 @@ export var EMenuType;
122
123
  })(EMenuType || (EMenuType = {}));
123
124
  export class Constant {
124
125
  }
125
- //# 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?: (val: any) => 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?: (row: any, cellField: keyof TRow, setLoading?: (value: boolean) => void, index?: number) => 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?: (val: any) => string | undefined | Promise<string | undefined> | Observable<string | undefined>;\n  expandedFormatter?: (val: any) => 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 = 'AGT' | 'AOC' | 'AP' | 'CN' | 'CSD' | 'ID' | 'LI' | 'LIC' | 'PP' | 'RIB' | '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  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  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 = 'string' | 'number' | 'bigint' | 'boolean' | 'symbol' | 'undefined' | 'object' | '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"]}
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"]}
@@ -16,8 +16,11 @@ export const configValidationMessages = {
16
16
  [EValidationType.email]: {
17
17
  message: 'Email is invalid.',
18
18
  },
19
+ [EValidationType.invalid]: {
20
+ message: ' is invalid.',
21
+ },
19
22
  [EValidationType.pattern]: { message: ' is invalid.' },
20
- [EValidationType.notFound]: { message: " doesn't exist" },
23
+ [EValidationType.notFound]: { message: " doesn't exist." },
21
24
  [EValidationType.custom]: {},
22
25
  };
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1tZXNzYWdlcy5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvY29uZmlncy92YWxpZGF0aW9uLW1lc3NhZ2VzLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFzQixNQUFNLDhCQUE4QixDQUFDO0FBRW5GLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFxRDtJQUN4RixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUU7SUFDeEQsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLEVBQUU7UUFDM0IsT0FBTyxFQUFFLGlEQUFpRDtLQUMzRDtJQUNELENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQzNCLE9BQU8sRUFBRSxrREFBa0Q7S0FDNUQ7SUFDRCxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUN4QixPQUFPLEVBQUUsa0JBQWtCO0tBQzVCO0lBQ0QsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDdEIsT0FBTyxFQUFFLHlCQUF5QjtLQUNuQztJQUNELENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQ3ZCLE9BQU8sRUFBRSxtQkFBbUI7S0FDN0I7SUFDRCxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUU7SUFDdEQsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUU7SUFDekQsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRTtDQUM3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRVZhbGlkYXRpb25UeXBlLCBJVmFsaWRhdGlvbk1lc3NhZ2UgfSBmcm9tICcuLi9TaGFyZWQvbW9kZWxzL2luZGV4Lm1vZGVsJztcblxuZXhwb3J0IGNvbnN0IGNvbmZpZ1ZhbGlkYXRpb25NZXNzYWdlczogeyBbeCBpbiBFVmFsaWRhdGlvblR5cGVdOiB7IG1lc3NhZ2U/OiBzdHJpbmcgfSB9ID0ge1xuICBbRVZhbGlkYXRpb25UeXBlLnJlcXVpcmVkXTogeyBtZXNzYWdlOiAnIGlzIHJlcXVpcmVkLicgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5tYXhsZW5ndGhdOiB7XG4gICAgbWVzc2FnZTogJyBtdXN0IGJlIGF0IG1vc3Qge3ttYXhMZW5ndGh9fSBjaGFyYWN0ZXJzIGxvbmcuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5taW5sZW5ndGhdOiB7XG4gICAgbWVzc2FnZTogJyBtdXN0IGJlIGF0IGxlYXN0IHt7bWluTGVuZ3RofX0gY2hhcmFjdGVycyBsb25nLicsXG4gIH0sXG4gIFtFVmFsaWRhdGlvblR5cGUudW5pcXVlXToge1xuICAgIG1lc3NhZ2U6ICcgYWxyZWFkeSBleGlzdHMuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS51c2VkXToge1xuICAgIG1lc3NhZ2U6ICcgaGFzIGFscmVhZHkgYmVlbiB1c2VkLicsXG4gIH0sXG4gIFtFVmFsaWRhdGlvblR5cGUuZW1haWxdOiB7XG4gICAgbWVzc2FnZTogJ0VtYWlsIGlzIGludmFsaWQuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5wYXR0ZXJuXTogeyBtZXNzYWdlOiAnIGlzIGludmFsaWQuJyB9LFxuICBbRVZhbGlkYXRpb25UeXBlLm5vdEZvdW5kXTogeyBtZXNzYWdlOiBcIiBkb2Vzbid0IGV4aXN0XCIgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5jdXN0b21dOiB7fSxcbn07XG4iXX0=
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1tZXNzYWdlcy5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvY29uZmlncy92YWxpZGF0aW9uLW1lc3NhZ2VzLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFzQixNQUFNLDhCQUE4QixDQUFDO0FBRW5GLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFxRDtJQUN4RixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUU7SUFDeEQsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLEVBQUU7UUFDM0IsT0FBTyxFQUFFLGlEQUFpRDtLQUMzRDtJQUNELENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQzNCLE9BQU8sRUFBRSxrREFBa0Q7S0FDNUQ7SUFDRCxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUN4QixPQUFPLEVBQUUsa0JBQWtCO0tBQzVCO0lBQ0QsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDdEIsT0FBTyxFQUFFLHlCQUF5QjtLQUNuQztJQUNELENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQ3ZCLE9BQU8sRUFBRSxtQkFBbUI7S0FDN0I7SUFDRCxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUN6QixPQUFPLEVBQUUsY0FBYztLQUN4QjtJQUNELENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRTtJQUN0RCxDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRTtJQUMxRCxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFO0NBQzdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFVmFsaWRhdGlvblR5cGUsIElWYWxpZGF0aW9uTWVzc2FnZSB9IGZyb20gJy4uL1NoYXJlZC9tb2RlbHMvaW5kZXgubW9kZWwnO1xuXG5leHBvcnQgY29uc3QgY29uZmlnVmFsaWRhdGlvbk1lc3NhZ2VzOiB7IFt4IGluIEVWYWxpZGF0aW9uVHlwZV06IHsgbWVzc2FnZT86IHN0cmluZyB9IH0gPSB7XG4gIFtFVmFsaWRhdGlvblR5cGUucmVxdWlyZWRdOiB7IG1lc3NhZ2U6ICcgaXMgcmVxdWlyZWQuJyB9LFxuICBbRVZhbGlkYXRpb25UeXBlLm1heGxlbmd0aF06IHtcbiAgICBtZXNzYWdlOiAnIG11c3QgYmUgYXQgbW9zdCB7e21heExlbmd0aH19IGNoYXJhY3RlcnMgbG9uZy4nLFxuICB9LFxuICBbRVZhbGlkYXRpb25UeXBlLm1pbmxlbmd0aF06IHtcbiAgICBtZXNzYWdlOiAnIG11c3QgYmUgYXQgbGVhc3Qge3ttaW5MZW5ndGh9fSBjaGFyYWN0ZXJzIGxvbmcuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS51bmlxdWVdOiB7XG4gICAgbWVzc2FnZTogJyBhbHJlYWR5IGV4aXN0cy4nLFxuICB9LFxuICBbRVZhbGlkYXRpb25UeXBlLnVzZWRdOiB7XG4gICAgbWVzc2FnZTogJyBoYXMgYWxyZWFkeSBiZWVuIHVzZWQuJyxcbiAgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5lbWFpbF06IHtcbiAgICBtZXNzYWdlOiAnRW1haWwgaXMgaW52YWxpZC4nLFxuICB9LFxuICBbRVZhbGlkYXRpb25UeXBlLmludmFsaWRdOiB7XG4gICAgbWVzc2FnZTogJyBpcyBpbnZhbGlkLicsXG4gIH0sXG4gIFtFVmFsaWRhdGlvblR5cGUucGF0dGVybl06IHsgbWVzc2FnZTogJyBpcyBpbnZhbGlkLicgfSxcbiAgW0VWYWxpZGF0aW9uVHlwZS5ub3RGb3VuZF06IHsgbWVzc2FnZTogXCIgZG9lc24ndCBleGlzdC5cIiB9LFxuICBbRVZhbGlkYXRpb25UeXBlLmN1c3RvbV06IHt9LFxufTtcbiJdfQ==
@@ -354,6 +354,7 @@ var ELanguage;
354
354
  var EValidationType;
355
355
  (function (EValidationType) {
356
356
  EValidationType["custom"] = "custom";
357
+ EValidationType["invalid"] = "invalid";
357
358
  EValidationType["maxlength"] = "maxlength";
358
359
  EValidationType["minlength"] = "minlength";
359
360
  EValidationType["pattern"] = "pattern";
@@ -1237,8 +1238,11 @@ const configValidationMessages = {
1237
1238
  [EValidationType.email]: {
1238
1239
  message: 'Email is invalid.',
1239
1240
  },
1241
+ [EValidationType.invalid]: {
1242
+ message: ' is invalid.',
1243
+ },
1240
1244
  [EValidationType.pattern]: { message: ' is invalid.' },
1241
- [EValidationType.notFound]: { message: " doesn't exist" },
1245
+ [EValidationType.notFound]: { message: " doesn't exist." },
1242
1246
  [EValidationType.custom]: {},
1243
1247
  };
1244
1248
 
@@ -6556,7 +6560,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
6556
6560
 
6557
6561
  class AutocompleteService {
6558
6562
  constructor() {
6559
- this.invalidSelectionError = { custom: `Invalid value` };
6563
+ this.invalidSelectionError = { invalid: true };
6560
6564
  this.displayWith = (options) => (val) => {
6561
6565
  console.log('this.options', options);
6562
6566
  return options?.find((x) => x.value == val)?.label || val;
@@ -12666,6 +12670,7 @@ class FormErrorComponent {
12666
12670
  // protected forms?: Form[];
12667
12671
  this.lgGridNo = input(2);
12668
12672
  this.xxlGridNo = input(3);
12673
+ this.hasError = computed(() => this.errors()?.length > 0);
12669
12674
  }
12670
12675
  getErrorMessages(form, formName, _index, parent) {
12671
12676
  // debugger;
@@ -12684,21 +12689,21 @@ class FormErrorComponent {
12684
12689
  for (const key in form.controls) {
12685
12690
  if (Object.prototype.hasOwnProperty.call(form.controls, key)) {
12686
12691
  const control = form.controls[key];
12687
- messages.push(...this.getErrorMessages(control, key, _index, form.labelValue ||
12688
- (formName ? this.uS.formatField(formName) : formName?.toSentenceCase())));
12692
+ messages.push(...this.getErrorMessages(control, key, _index, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
12689
12693
  }
12690
12694
  }
12691
12695
  else if (form instanceof FormArray)
12692
12696
  for (let index = 0; index < form.length; index++) {
12693
12697
  const control = form.controls[index];
12694
- messages.push(...this.getErrorMessages(control, undefined, index + 1));
12698
+ debugger;
12699
+ messages.push(...this.getErrorMessages(control, undefined, index + 1, form.labelValue || (formName ? this.uS.formatField(formName) : parent)));
12695
12700
  }
12696
12701
  return messages;
12697
12702
  // debugger;
12698
12703
  // console.log('message', this.message);
12699
12704
  }
12700
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 }); }
12701
- 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 (errors()?.length) {\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}\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: "directive", type: i11.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: InfoIconComponent, selector: "app-info-icon", inputs: ["text", "coloured", "left", "right"] }] }); }
12702
12707
  }
12703
12708
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: FormErrorComponent, decorators: [{
12704
12709
  type: Component,
@@ -12707,8 +12712,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
12707
12712
  SDKTranslatePipe,
12708
12713
  ValidationMessageComponent,
12709
12714
  BtnComponent,
12710
- MatTooltipModule, InfoIconComponent
12711
- ], template: "@if (errors()?.length) {\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}\n"] }]
12715
+ MatTooltipModule,
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=\"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"] }]
12712
12718
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: UtilityService }] });
12713
12719
  function hasError(control) {
12714
12720
  if (control?.pending)