bpm-core 0.0.27 → 0.0.28

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.
Files changed (41) hide show
  1. package/esm2022/lib/components/app-component-sections/activities/activities.component.mjs +3 -3
  2. package/esm2022/lib/components/app-component-sections/feedback-section/feedback-section.component.mjs +2 -2
  3. package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +3 -3
  4. package/esm2022/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.mjs +2 -2
  5. package/esm2022/lib/components/shared-components/form-field/checkbox/checkbox.component.mjs +42 -31
  6. package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs +63 -14
  7. package/esm2022/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.mjs +70 -137
  8. package/esm2022/lib/components/shared-components/form-field/date-picker/date-picker.component.mjs +42 -78
  9. package/esm2022/lib/components/shared-components/form-field/input/input.component.mjs +5 -19
  10. package/esm2022/lib/components/shared-components/form-field/input-currency/input-currency.component.mjs +23 -115
  11. package/esm2022/lib/components/shared-components/form-field/input-email/input-email.component.mjs +20 -72
  12. package/esm2022/lib/components/shared-components/form-field/input-mask/input-mask.component.mjs +20 -74
  13. package/esm2022/lib/components/shared-components/form-field/input-number/input-number.component.mjs +20 -104
  14. package/esm2022/lib/components/shared-components/form-field/input-telephone/input-telephone.component.mjs +20 -39
  15. package/esm2022/lib/components/shared-components/form-field/textarea/textarea.component.mjs +27 -59
  16. package/esm2022/lib/components/shared-components/form-field/validation-errors/validation-errors.component.mjs +3 -6
  17. package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +2 -2
  18. package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +37 -23
  19. package/fesm2022/bpm-core.mjs +524 -908
  20. package/fesm2022/bpm-core.mjs.map +1 -1
  21. package/lib/components/app-component-sections/activities/activities.component.d.ts +2 -2
  22. package/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.d.ts +1 -1
  23. package/lib/components/app-component-sections/form-section/form-section.component.d.ts +1 -1
  24. package/lib/components/app-component-sections/service-header/service-header.component.d.ts +1 -1
  25. package/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.d.ts +1 -1
  26. package/lib/components/shared-components/form-field/checkbox/checkbox.component.d.ts +10 -7
  27. package/lib/components/shared-components/form-field/control-value-accessor.directive.d.ts +15 -5
  28. package/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.d.ts +15 -15
  29. package/lib/components/shared-components/form-field/date-picker/date-picker.component.d.ts +6 -13
  30. package/lib/components/shared-components/form-field/input/input.component.d.ts +2 -6
  31. package/lib/components/shared-components/form-field/input-currency/input-currency.component.d.ts +6 -23
  32. package/lib/components/shared-components/form-field/input-email/input-email.component.d.ts +4 -18
  33. package/lib/components/shared-components/form-field/input-mask/input-mask.component.d.ts +4 -18
  34. package/lib/components/shared-components/form-field/input-number/input-number.component.d.ts +5 -20
  35. package/lib/components/shared-components/form-field/input-telephone/input-telephone.component.d.ts +4 -15
  36. package/lib/components/shared-components/form-field/textarea/textarea.component.d.ts +5 -14
  37. package/lib/components/shared-components/form-field/validation-errors/validation-errors.component.d.ts +1 -2
  38. package/lib/testComponent/request-details-section/request-details-section.component.d.ts +5 -7
  39. package/package.json +3 -2
  40. package/esm2022/lib/testComponent/services/state-machine.service.mjs +0 -148
  41. package/lib/testComponent/services/state-machine.service.d.ts +0 -29
@@ -1,28 +1,20 @@
1
- import { FormControl, FormsModule } from '@angular/forms';
1
+ import { FormControl, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
2
2
  /* eslint-disable @typescript-eslint/no-explicit-any */
3
3
  /* eslint-disable @angular-eslint/component-selector */
4
- import { Component, Input, Output, EventEmitter, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
4
+ import { Component, Input, Output, EventEmitter, CUSTOM_ELEMENTS_SCHEMA, forwardRef } from '@angular/core';
5
5
  import { MatError, MatFormField } from "@angular/material/form-field";
6
6
  import { InfoItemComponent } from "../info-item/info-item.component";
7
7
  import { NgIf } from "@angular/common";
8
+ import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
8
9
  import * as i0 from "@angular/core";
9
- import * as i1 from "../../../../services";
10
- export class InputTelephoneComponent {
11
- i18n;
12
- label;
13
- value;
10
+ export class InputTelephoneComponent extends ControlValueAccessorDirective {
14
11
  tooltip;
15
12
  floatLabel = 'auto';
16
13
  className = 'bordered-input';
17
- placeholder;
18
14
  showLabel = true;
19
- isReadOnly = false;
20
15
  matPrefix;
21
16
  iconPrefixName;
22
- matSuffix;
23
17
  iconSuffixName;
24
- required = true;
25
- disabled = false;
26
18
  field;
27
19
  name;
28
20
  controller = new FormControl();
@@ -30,17 +22,12 @@ export class InputTelephoneComponent {
30
22
  checkPhoneError = new EventEmitter();
31
23
  phoneValue = new EventEmitter();
32
24
  totalNumber = new EventEmitter();
33
- maxLength;
34
- minLength;
35
25
  countryCode = '966';
36
26
  showEdit = false;
37
27
  inputValue = new EventEmitter();
38
28
  emitedValue = new EventEmitter();
39
29
  telhasError;
40
30
  emitedError = new EventEmitter();
41
- constructor(i18n) {
42
- this.i18n = i18n;
43
- }
44
31
  onCountryChange(event) {
45
32
  this.countryCode = event.dialCode;
46
33
  // console.log(event)
@@ -105,8 +92,14 @@ export class InputTelephoneComponent {
105
92
  // console.log('xxxxxxxxxxxxxx',this.countryCode,data.target.value)
106
93
  this.inputValue.emit(data.target.value);
107
94
  }
108
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: InputTelephoneComponent, deps: [{ token: i1.CoreI18nService }], target: i0.ɵɵFactoryTarget.Component });
109
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: InputTelephoneComponent, isStandalone: true, selector: "app-input-telephone", inputs: { label: "label", value: "value", tooltip: "tooltip", floatLabel: "floatLabel", className: "className", placeholder: "placeholder", showLabel: "showLabel", isReadOnly: "isReadOnly", matPrefix: "matPrefix", iconPrefixName: "iconPrefixName", matSuffix: "matSuffix", iconSuffixName: "iconSuffixName", required: "required", disabled: "disabled", field: "field", name: "name", controller: "controller", error: "error", maxLength: "maxLength", minLength: "minLength", showEdit: "showEdit" }, outputs: { checkPhoneError: "checkPhoneError", phoneValue: "phoneValue", totalNumber: "totalNumber", inputValue: "inputValue", emitedValue: "emitedValue", emitedError: "emitedError" }, ngImport: i0, template: "<ng-container *ngIf=\"!isReadOnly\">\r\n <div class=\"d-flex justify-content-between mb-1\" *ngIf=\"showLabel\">\r\n <span class=\"form-label mb-0\">{{label}}</span>\r\n <span *ngIf=\"!required\" class=\"fs-11 fc-dark-gray\"> {{i18n.translate('Optional')}}\r\n </span>\r\n </div>\r\n <mat-form-field style=\"height: 50px;\" class=\"primary-form input-telephone {{className}}\" floatLabel=\"always\">\r\n <mat-label>\r\n {{label}}\r\n </mat-label>\r\n <label class=\"mat-form-content\">\r\n <!-- [placeholder]=\"label\" -->\r\n <!-- <input matInput [disabled]=\"disabled\" ng2TelInput numberOnly #phone\r\n [ng2TelInputOptions]=\"{initialCountry: 'sa', utilsScript: 'assets/js/utils.js'}\" (hasError)=\"hasError($event)\"\r\n (ng2TelOutput)=\"getNumber($event)\" (intlTelInputObject)=\"telInputObject($event)\"\r\n (countryChange)=\"onCountryChange($event)\" [(ngModel)]=\"field\" [name]=\"name\"\r\n oninput=\"this.value.replace(/[^0-9.]/g, ''); this.value = this.value.replace(/(\\..*)\\./g, '$1');\"\r\n [maxlength]=\"maxLength\" [minLength]=\"minLength\" />-->\r\n </label>\r\n\r\n </mat-form-field>\r\n <mat-error class=\"mb-2 fs-14\" *ngIf=\"controller?.errors?.['incorrect']\">\r\n {{error}}\r\n </mat-error>\r\n <!-- <mat-error *ngIf=\"controller?.errors?.incorrect\" class=\"fc-red1-imp\"> {{error}} </mat-error> -->\r\n\r\n\r\n <!-- <span *ngIf=\"telhasError\"> {{error}}</span> -->\r\n</ng-container>\r\n\r\n\r\n<ng-container *ngIf=\"isReadOnly\">\r\n <app-info-item class=\"info-item w-100\" [type]=\"'telephone'\" [label]=\"label\"\r\n [value]=\"field\"></app-info-item>\r\n</ng-container>\r\n", styles: ["[dir=rtl] :host .mat-input-element{direction:ltr;text-align:right}\n"], dependencies: [{ kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: InfoItemComponent, selector: "app-info-item", inputs: ["label", "value", "name", "type", "dateType", "multiple", "insideTable", "hasLabel", "arrayList", "actionType", "download"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
95
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: InputTelephoneComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
96
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: InputTelephoneComponent, isStandalone: true, selector: "app-input-telephone", inputs: { tooltip: "tooltip", floatLabel: "floatLabel", className: "className", showLabel: "showLabel", matPrefix: "matPrefix", iconPrefixName: "iconPrefixName", iconSuffixName: "iconSuffixName", field: "field", name: "name", controller: "controller", error: "error", showEdit: "showEdit" }, outputs: { checkPhoneError: "checkPhoneError", phoneValue: "phoneValue", totalNumber: "totalNumber", inputValue: "inputValue", emitedValue: "emitedValue", emitedError: "emitedError" }, providers: [
97
+ {
98
+ provide: NG_VALUE_ACCESSOR,
99
+ useExisting: forwardRef(() => InputTelephoneComponent),
100
+ multi: true,
101
+ },
102
+ ], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"!isReadOnly\">\r\n <div class=\"d-flex justify-content-between mb-1\" *ngIf=\"showLabel\">\r\n <span class=\"form-label mb-0\">{{label}}</span>\r\n <span *ngIf=\"!required\" class=\"fs-11 fc-dark-gray\"> {{i18n.translate('Optional')}}\r\n </span>\r\n </div>\r\n <mat-form-field style=\"height: 50px;\" class=\"primary-form input-telephone {{className}}\" floatLabel=\"always\">\r\n <mat-label>\r\n {{label}}\r\n </mat-label>\r\n <label class=\"mat-form-content\">\r\n <!-- [placeholder]=\"label\" -->\r\n <!-- <input matInput [disabled]=\"disabled\" ng2TelInput numberOnly #phone\r\n [ng2TelInputOptions]=\"{initialCountry: 'sa', utilsScript: 'assets/js/utils.js'}\" (hasError)=\"hasError($event)\"\r\n (ng2TelOutput)=\"getNumber($event)\" (intlTelInputObject)=\"telInputObject($event)\"\r\n (countryChange)=\"onCountryChange($event)\" [(ngModel)]=\"field\" [name]=\"name\"\r\n oninput=\"this.value.replace(/[^0-9.]/g, ''); this.value = this.value.replace(/(\\..*)\\./g, '$1');\"\r\n [maxlength]=\"maxLength\" [minLength]=\"minLength\" />-->\r\n </label>\r\n\r\n </mat-form-field>\r\n <mat-error class=\"mb-2 fs-14\" *ngIf=\"controller?.errors?.['incorrect']\">\r\n {{error}}\r\n </mat-error>\r\n <!-- <mat-error *ngIf=\"controller?.errors?.incorrect\" class=\"fc-red1-imp\"> {{error}} </mat-error> -->\r\n\r\n\r\n <!-- <span *ngIf=\"telhasError\"> {{error}}</span> -->\r\n</ng-container>\r\n\r\n\r\n<ng-container *ngIf=\"isReadOnly\">\r\n <app-info-item class=\"info-item w-100\" [type]=\"'telephone'\" [label]=\"label\"\r\n [value]=\"field\"></app-info-item>\r\n</ng-container>\r\n", styles: ["[dir=rtl] :host .mat-input-element{direction:ltr;text-align:right}\n"], dependencies: [{ kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: InfoItemComponent, selector: "app-info-item", inputs: ["label", "value", "name", "type", "dateType", "multiple", "insideTable", "hasLabel", "arrayList", "actionType", "download"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
110
103
  }
111
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: InputTelephoneComponent, decorators: [{
112
105
  type: Component,
@@ -117,35 +110,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
117
110
  FormsModule,
118
111
  NgIf,
119
112
  // Ng2TelInputModule
113
+ ], providers: [
114
+ {
115
+ provide: NG_VALUE_ACCESSOR,
116
+ useExisting: forwardRef(() => InputTelephoneComponent),
117
+ multi: true,
118
+ },
120
119
  ], template: "<ng-container *ngIf=\"!isReadOnly\">\r\n <div class=\"d-flex justify-content-between mb-1\" *ngIf=\"showLabel\">\r\n <span class=\"form-label mb-0\">{{label}}</span>\r\n <span *ngIf=\"!required\" class=\"fs-11 fc-dark-gray\"> {{i18n.translate('Optional')}}\r\n </span>\r\n </div>\r\n <mat-form-field style=\"height: 50px;\" class=\"primary-form input-telephone {{className}}\" floatLabel=\"always\">\r\n <mat-label>\r\n {{label}}\r\n </mat-label>\r\n <label class=\"mat-form-content\">\r\n <!-- [placeholder]=\"label\" -->\r\n <!-- <input matInput [disabled]=\"disabled\" ng2TelInput numberOnly #phone\r\n [ng2TelInputOptions]=\"{initialCountry: 'sa', utilsScript: 'assets/js/utils.js'}\" (hasError)=\"hasError($event)\"\r\n (ng2TelOutput)=\"getNumber($event)\" (intlTelInputObject)=\"telInputObject($event)\"\r\n (countryChange)=\"onCountryChange($event)\" [(ngModel)]=\"field\" [name]=\"name\"\r\n oninput=\"this.value.replace(/[^0-9.]/g, ''); this.value = this.value.replace(/(\\..*)\\./g, '$1');\"\r\n [maxlength]=\"maxLength\" [minLength]=\"minLength\" />-->\r\n </label>\r\n\r\n </mat-form-field>\r\n <mat-error class=\"mb-2 fs-14\" *ngIf=\"controller?.errors?.['incorrect']\">\r\n {{error}}\r\n </mat-error>\r\n <!-- <mat-error *ngIf=\"controller?.errors?.incorrect\" class=\"fc-red1-imp\"> {{error}} </mat-error> -->\r\n\r\n\r\n <!-- <span *ngIf=\"telhasError\"> {{error}}</span> -->\r\n</ng-container>\r\n\r\n\r\n<ng-container *ngIf=\"isReadOnly\">\r\n <app-info-item class=\"info-item w-100\" [type]=\"'telephone'\" [label]=\"label\"\r\n [value]=\"field\"></app-info-item>\r\n</ng-container>\r\n", styles: ["[dir=rtl] :host .mat-input-element{direction:ltr;text-align:right}\n"] }]
121
- }], ctorParameters: () => [{ type: i1.CoreI18nService }], propDecorators: { label: [{
122
- type: Input
123
- }], value: [{
124
- type: Input
125
- }], tooltip: [{
120
+ }], propDecorators: { tooltip: [{
126
121
  type: Input
127
122
  }], floatLabel: [{
128
123
  type: Input
129
124
  }], className: [{
130
125
  type: Input
131
- }], placeholder: [{
132
- type: Input
133
126
  }], showLabel: [{
134
127
  type: Input
135
- }], isReadOnly: [{
136
- type: Input
137
128
  }], matPrefix: [{
138
129
  type: Input
139
130
  }], iconPrefixName: [{
140
131
  type: Input
141
- }], matSuffix: [{
142
- type: Input
143
132
  }], iconSuffixName: [{
144
133
  type: Input
145
- }], required: [{
146
- type: Input
147
- }], disabled: [{
148
- type: Input
149
134
  }], field: [{
150
135
  type: Input
151
136
  }], name: [{
@@ -160,10 +145,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
160
145
  type: Output
161
146
  }], totalNumber: [{
162
147
  type: Output
163
- }], maxLength: [{
164
- type: Input
165
- }], minLength: [{
166
- type: Input
167
148
  }], showEdit: [{
168
149
  type: Input
169
150
  }], inputValue: [{
@@ -173,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
173
154
  }], emitedError: [{
174
155
  type: Output
175
156
  }] } });
176
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-telephone.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input-telephone/input-telephone.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input-telephone/input-telephone.component.html"],"names":[],"mappings":"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","sourcesContent":["import {FormControl, FormsModule} from '@angular/forms';\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n/* eslint-disable @angular-eslint/component-selector */\r\nimport { Component, Input, Output, EventEmitter, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';\r\nimport {FloatLabelType, MatError, MatFormField} from \"@angular/material/form-field\";\r\nimport { CoreI18nService } from '../../../../services';\r\nimport {Ng2TelInputModule} from \"ng2-tel-input\";\r\nimport {InfoItemComponent} from \"../info-item/info-item.component\";\r\nimport {NgIf} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'app-input-telephone',\r\n  templateUrl: './input-telephone.component.html',\r\n  styleUrls: ['./input-telephone.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  standalone: true,\r\n  imports: [\r\n    MatFormField,\r\n    MatError,\r\n    InfoItemComponent,\r\n    FormsModule,\r\n    NgIf,\r\n    // Ng2TelInputModule\r\n  ]\r\n})\r\nexport class InputTelephoneComponent {\r\n  @Input() label!: string;\r\n  @Input() value!: string;\r\n  @Input() tooltip!: string;\r\n  @Input() floatLabel: any = 'auto';\r\n  @Input() className = 'bordered-input';\r\n  @Input() placeholder!: string;\r\n  @Input() showLabel = true;\r\n  @Input() isReadOnly = false;\r\n  @Input() matPrefix!: boolean;\r\n  @Input() iconPrefixName!: string;\r\n  @Input() matSuffix!: boolean;\r\n  @Input() iconSuffixName!: string;\r\n  @Input() required = true;\r\n  @Input() disabled = false;\r\n  @Input() field: any;\r\n  @Input() name: string;\r\n  @Input() controller: FormControl = new FormControl();\r\n  @Input() error!: string;\r\n  @Output() checkPhoneError = new EventEmitter<boolean>();\r\n  @Output() phoneValue = new EventEmitter<string>();\r\n  @Output() totalNumber = new EventEmitter<string>();\r\n  @Input() maxLength: any;\r\n  @Input() minLength: any;\r\n  countryCode = '966';\r\n  @Input() showEdit = false;\r\n  @Output() inputValue = new EventEmitter();\r\n  @Output() emitedValue = new EventEmitter();\r\n  telhasError: boolean;\r\n  @Output() emitedError = new EventEmitter();\r\n  constructor(\r\n    public i18n: CoreI18nService\r\n  ) { }\r\n\r\n\r\n\r\n  onCountryChange(event: any) {\r\n    this.countryCode = event.dialCode\r\n    // console.log(event)\r\n  }\r\n\r\n  hasError(event: boolean) {\r\n    console.log(event);\r\n    this.telhasError = !event\r\n    if (this.telhasError) {\r\n      this.emitedError.emit(this.telhasError)\r\n\r\n      console.log(\" error\", this.error);\r\n      this.controller.setErrors({ 'incorrect': true });\r\n      this.error = this.i18n.translate('messageErrorPhoneNumber');\r\n    } else {\r\n      this.controller.setErrors({ 'incorrect': false });\r\n    }\r\n    this.emitedValue.emit(\r\n      {\r\n        field:this.field,\r\n        hasError:this.telhasError\r\n      }\r\n     )\r\n\r\n    // this.checkPhoneError.emit(event);\r\n\r\n    // if (this.controller.value != null) {\r\n    //   if (event == false && this.controller.value.length < 0) {\r\n    //     // this.phoneHasErrReqiured = true;\r\n    //     // this.phoneHasErrValid = false;\r\n\r\n    //     this.error = this.translate.translate('messageErrorPhoneNumber');\r\n\r\n    //   } else {\r\n    //     if (event == false) {\r\n    //       if (this.controller.value.length == 0) {\r\n    //         this.error = this.translate.translate('messageErrorPhoneNumber');\r\n    //       } else {\r\n    //         this.error = this.translate.translate('messageErrorPhoneNumber');\r\n    //       }\r\n    //     } else {\r\n    //       if (this.controller.value.length == 0) {\r\n    //         this.error = this.translate.translate('messageErrorPhoneNumber');\r\n    //       } else {\r\n    //         this.error = '';\r\n    //       }\r\n    //     }\r\n    //   }\r\n    // } else {\r\n    //   this.error = this.translate.translate('messageErrorPhoneNumber');\r\n    // }\r\n    // // console.log(\" this.error\", this.error);\r\n  }\r\n\r\n  getNumber(event: any) {\r\n    console.log('ssssssssssssssssssssssssssssssssssssssssssssssss')\r\n    this.phoneValue.emit(this.countryCode)\r\n    this.totalNumber.emit(event)\r\n   // this.emitedValue.emit(this.field)\r\n    this.emitedError.emit(this.telhasError)\r\n  }\r\n\r\n  telInputObject($event: any) {\r\n    console.log(event)\r\n  }\r\n\r\n  editClicked() {\r\n    console.log('xxxxxxxxxxxxxx')\r\n    // this.editPhone.emit()\r\n  }\r\n\r\n  onValueChange(data: any) {\r\n    // console.log('xxxxxxxxxxxxxx',this.countryCode,data.target.value)\r\n    this.inputValue.emit(data.target.value)\r\n  }\r\n\r\n}\r\n","<ng-container *ngIf=\"!isReadOnly\">\r\n  <div class=\"d-flex justify-content-between mb-1\" *ngIf=\"showLabel\">\r\n    <span class=\"form-label mb-0\">{{label}}</span>\r\n    <span *ngIf=\"!required\" class=\"fs-11 fc-dark-gray\"> {{i18n.translate('Optional')}}\r\n    </span>\r\n  </div>\r\n  <mat-form-field style=\"height: 50px;\" class=\"primary-form input-telephone {{className}}\" floatLabel=\"always\">\r\n    <mat-label>\r\n      {{label}}\r\n    </mat-label>\r\n    <label class=\"mat-form-content\">\r\n      <!-- [placeholder]=\"label\" -->\r\n    <!--  <input matInput [disabled]=\"disabled\" ng2TelInput numberOnly #phone\r\n        [ng2TelInputOptions]=\"{initialCountry: 'sa', utilsScript: 'assets/js/utils.js'}\" (hasError)=\"hasError($event)\"\r\n        (ng2TelOutput)=\"getNumber($event)\" (intlTelInputObject)=\"telInputObject($event)\"\r\n        (countryChange)=\"onCountryChange($event)\" [(ngModel)]=\"field\" [name]=\"name\"\r\n        oninput=\"this.value.replace(/[^0-9.]/g, ''); this.value = this.value.replace(/(\\..*)\\./g, '$1');\"\r\n        [maxlength]=\"maxLength\" [minLength]=\"minLength\" />-->\r\n      </label>\r\n\r\n    </mat-form-field>\r\n    <mat-error class=\"mb-2 fs-14\" *ngIf=\"controller?.errors?.['incorrect']\">\r\n      {{error}}\r\n    </mat-error>\r\n    <!-- <mat-error *ngIf=\"controller?.errors?.incorrect\" class=\"fc-red1-imp\"> {{error}} </mat-error> -->\r\n\r\n\r\n    <!-- <span  *ngIf=\"telhasError\"> {{error}}</span> -->\r\n</ng-container>\r\n\r\n\r\n<ng-container *ngIf=\"isReadOnly\">\r\n  <app-info-item class=\"info-item w-100\"  [type]=\"'telephone'\" [label]=\"label\"\r\n    [value]=\"field\"></app-info-item>\r\n</ng-container>\r\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-telephone.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input-telephone/input-telephone.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input-telephone/input-telephone.component.html"],"names":[],"mappings":"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","sourcesContent":["import {FormControl, FormsModule, NG_VALUE_ACCESSOR} from '@angular/forms';\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n/* eslint-disable @angular-eslint/component-selector */\r\nimport { Component, Input, Output, EventEmitter, CUSTOM_ELEMENTS_SCHEMA, forwardRef } from '@angular/core';\r\nimport {FloatLabelType, MatError, MatFormField} from \"@angular/material/form-field\";\r\nimport { CoreI18nService } from '../../../../services';\r\nimport {Ng2TelInputModule} from \"ng2-tel-input\";\r\nimport {InfoItemComponent} from \"../info-item/info-item.component\";\r\nimport {NgIf} from \"@angular/common\";\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\n\r\n@Component({\r\n  selector: 'app-input-telephone',\r\n  templateUrl: './input-telephone.component.html',\r\n  styleUrls: ['./input-telephone.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  standalone: true,\r\n  imports: [\r\n    MatFormField,\r\n    MatError,\r\n    InfoItemComponent,\r\n    FormsModule,\r\n    NgIf,\r\n    // Ng2TelInputModule\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTelephoneComponent),\r\n      multi: true,\r\n    },\r\n  ]\r\n})\r\nexport class InputTelephoneComponent<Type> extends ControlValueAccessorDirective<Type> {\r\n  @Input() tooltip!: string;\r\n  @Input() floatLabel: any = 'auto';\r\n  @Input() className = 'bordered-input';\r\n  @Input() showLabel = true;\r\n  @Input() matPrefix!: boolean;\r\n  @Input() iconPrefixName!: string;\r\n  @Input() iconSuffixName!: string;\r\n  @Input() field: any;\r\n  @Input() name: string;\r\n  @Input() controller: FormControl = new FormControl();\r\n  @Input() error!: string;\r\n  @Output() checkPhoneError = new EventEmitter<boolean>();\r\n  @Output() phoneValue = new EventEmitter<string>();\r\n  @Output() totalNumber = new EventEmitter<string>();\r\n  countryCode = '966';\r\n  @Input() showEdit = false;\r\n  @Output() inputValue = new EventEmitter();\r\n  @Output() emitedValue = new EventEmitter();\r\n  telhasError: boolean;\r\n  @Output() emitedError = new EventEmitter();\r\n\r\n\r\n\r\n  onCountryChange(event: any) {\r\n    this.countryCode = event.dialCode\r\n    // console.log(event)\r\n  }\r\n\r\n  hasError(event: boolean) {\r\n    console.log(event);\r\n    this.telhasError = !event\r\n    if (this.telhasError) {\r\n      this.emitedError.emit(this.telhasError)\r\n\r\n      console.log(\" error\", this.error);\r\n      this.controller.setErrors({ 'incorrect': true });\r\n      this.error = this.i18n.translate('messageErrorPhoneNumber');\r\n    } else {\r\n      this.controller.setErrors({ 'incorrect': false });\r\n    }\r\n    this.emitedValue.emit(\r\n      {\r\n        field:this.field,\r\n        hasError:this.telhasError\r\n      }\r\n     )\r\n\r\n    // this.checkPhoneError.emit(event);\r\n\r\n    // if (this.controller.value != null) {\r\n    //   if (event == false && this.controller.value.length < 0) {\r\n    //     // this.phoneHasErrReqiured = true;\r\n    //     // this.phoneHasErrValid = false;\r\n\r\n    //     this.error = this.translate.translate('messageErrorPhoneNumber');\r\n\r\n    //   } else {\r\n    //     if (event == false) {\r\n    //       if (this.controller.value.length == 0) {\r\n    //         this.error = this.translate.translate('messageErrorPhoneNumber');\r\n    //       } else {\r\n    //         this.error = this.translate.translate('messageErrorPhoneNumber');\r\n    //       }\r\n    //     } else {\r\n    //       if (this.controller.value.length == 0) {\r\n    //         this.error = this.translate.translate('messageErrorPhoneNumber');\r\n    //       } else {\r\n    //         this.error = '';\r\n    //       }\r\n    //     }\r\n    //   }\r\n    // } else {\r\n    //   this.error = this.translate.translate('messageErrorPhoneNumber');\r\n    // }\r\n    // // console.log(\" this.error\", this.error);\r\n  }\r\n\r\n  getNumber(event: any) {\r\n    console.log('ssssssssssssssssssssssssssssssssssssssssssssssss')\r\n    this.phoneValue.emit(this.countryCode)\r\n    this.totalNumber.emit(event)\r\n   // this.emitedValue.emit(this.field)\r\n    this.emitedError.emit(this.telhasError)\r\n  }\r\n\r\n  telInputObject($event: any) {\r\n    console.log(event)\r\n  }\r\n\r\n  editClicked() {\r\n    console.log('xxxxxxxxxxxxxx')\r\n    // this.editPhone.emit()\r\n  }\r\n\r\n  onValueChange(data: any) {\r\n    // console.log('xxxxxxxxxxxxxx',this.countryCode,data.target.value)\r\n    this.inputValue.emit(data.target.value)\r\n  }\r\n\r\n}\r\n","<ng-container *ngIf=\"!isReadOnly\">\r\n  <div class=\"d-flex justify-content-between mb-1\" *ngIf=\"showLabel\">\r\n    <span class=\"form-label mb-0\">{{label}}</span>\r\n    <span *ngIf=\"!required\" class=\"fs-11 fc-dark-gray\"> {{i18n.translate('Optional')}}\r\n    </span>\r\n  </div>\r\n  <mat-form-field style=\"height: 50px;\" class=\"primary-form input-telephone {{className}}\" floatLabel=\"always\">\r\n    <mat-label>\r\n      {{label}}\r\n    </mat-label>\r\n    <label class=\"mat-form-content\">\r\n      <!-- [placeholder]=\"label\" -->\r\n    <!--  <input matInput [disabled]=\"disabled\" ng2TelInput numberOnly #phone\r\n        [ng2TelInputOptions]=\"{initialCountry: 'sa', utilsScript: 'assets/js/utils.js'}\" (hasError)=\"hasError($event)\"\r\n        (ng2TelOutput)=\"getNumber($event)\" (intlTelInputObject)=\"telInputObject($event)\"\r\n        (countryChange)=\"onCountryChange($event)\" [(ngModel)]=\"field\" [name]=\"name\"\r\n        oninput=\"this.value.replace(/[^0-9.]/g, ''); this.value = this.value.replace(/(\\..*)\\./g, '$1');\"\r\n        [maxlength]=\"maxLength\" [minLength]=\"minLength\" />-->\r\n      </label>\r\n\r\n    </mat-form-field>\r\n    <mat-error class=\"mb-2 fs-14\" *ngIf=\"controller?.errors?.['incorrect']\">\r\n      {{error}}\r\n    </mat-error>\r\n    <!-- <mat-error *ngIf=\"controller?.errors?.incorrect\" class=\"fc-red1-imp\"> {{error}} </mat-error> -->\r\n\r\n\r\n    <!-- <span  *ngIf=\"telhasError\"> {{error}}</span> -->\r\n</ng-container>\r\n\r\n\r\n<ng-container *ngIf=\"isReadOnly\">\r\n  <app-info-item class=\"info-item w-100\"  [type]=\"'telephone'\" [label]=\"label\"\r\n    [value]=\"field\"></app-info-item>\r\n</ng-container>\r\n"]}
@@ -1,88 +1,56 @@
1
- import { ReactiveFormsModule, Validators } from '@angular/forms';
1
+ import { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
2
2
  /* eslint-disable @angular-eslint/component-selector */
3
3
  /* eslint-disable @angular-eslint/use-lifecycle-interface */
4
- import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
5
- import { BaseComponent } from '../base-component/base-component.component';
4
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, forwardRef, Input } from '@angular/core';
6
5
  import { MatFormField } from "@angular/material/form-field";
7
6
  import { NgClass, NgIf } from "@angular/common";
8
- import { InfoItemComponent } from "../info-item/info-item.component";
7
+ import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
8
+ import { MatInput } from '@angular/material/input';
9
+ import { ValidationErrorsComponent } from '../validation-errors/validation-errors.component';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "@angular/forms";
11
- export class TextareaComponent extends BaseComponent {
12
- label;
13
- tooltip;
12
+ export class TextareaComponent extends ControlValueAccessorDirective {
14
13
  className;
15
14
  preventSpecailChar;
16
- textAreaFocus = false;
17
- ngOnChanges(changes) {
18
- if (changes?.['field'].currentValue == '' || changes?.['field'].currentValue == null) {
19
- this.controller.setValue('');
20
- }
21
- else {
22
- this.controller.setValue(changes['field'].currentValue);
23
- }
24
- if (changes?.['disabled']?.previousValue !== changes?.['disabled']?.currentValue) {
25
- if (this.disabled)
26
- this.controller.disable();
27
- else
28
- this.controller.enable();
29
- }
30
- }
31
- ngOnInit() {
32
- // this.resetPropagator.subscribe(this, this.resetData);
33
- this.field == undefined ? (this.field = '') : this.field;
34
- this.controller.setValue(this.field);
35
- if (this.minLength) {
36
- this.controller.setValidators([
37
- Validators.minLength(+this.minLength),
38
- ]);
39
- }
40
- if (this.maxLength) {
41
- this.controller.setValidators([
42
- Validators.maxLength(+this.maxLength),
43
- ]);
44
- }
45
- if (this.required) {
46
- this.controller.setValidators([Validators.required]);
47
- }
48
- }
49
15
  focusInFunction() {
50
- this.textAreaFocus = true;
51
16
  this.validateTextAreaBorder();
52
17
  }
53
18
  focusOutFunction() {
54
- this.textAreaFocus = false;
55
19
  this.validateTextAreaBorder();
56
20
  }
57
21
  validateTextAreaBorder() {
58
- return {
59
- "field-border-error": (this.field && this.field.length < this.minLength) || (this.field && this.field.length > this.maxLength),
60
- };
61
- }
62
- onValueChange(event) {
63
- const target = event.target;
64
- const data = target.value;
65
- this.emitedValue.emit(data.trim());
22
+ // return {
23
+ // "field-border-error": (this.field && this.field.length < this.minLength) || (this.field && this.field.length > this.maxLength),
24
+ // }
66
25
  }
67
26
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TextareaComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
68
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: TextareaComponent, isStandalone: true, selector: "app-textarea", inputs: { label: "label", tooltip: "tooltip", className: "className", preventSpecailChar: "preventSpecailChar" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"!isReadOnly\">\r\n <div class=\"d-flex justify-content-between mb-1\" *ngIf=\"hasLabel\">\r\n <span class=\"form-label mb-0\">{{ label }}</span>\r\n <span *ngIf=\"!required\" class=\"fs-11 fc-dark-gray\">\r\n <!-- {{'Optional'| transloco}} -->{{ i18n.translate('Optional') }}\r\n </span>\r\n </div>\r\n <mat-form-field class=\"custom-textarea bordered-input {{className}}\">\r\n <mat-label>{{ label }}</mat-label>\r\n <label class=\"mat-form-content\">\r\n\r\n <textarea *ngIf=\"type === 'arOnly'\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\" arOnly\r\n (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"controller\" matInput></textarea>\r\n\r\n <textarea *ngIf=\"type === 'enOnly'\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\" enOnly\r\n (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"controller\" matInput></textarea>\r\n\r\n <!-- <textarea *ngIf=\"preventSpecailChar\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\"\r\n specialIsAlphaNumeric\r\n (input)=\"onValueChange($event.target.value)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"controller\" matInput></textarea>-->\r\n <!--&& !preventSpecailChar-->\r\n <textarea *ngIf=\"type !== 'enOnly' && type !== 'arOnly' \" [placeholder]=\"placeholder\" [minlength]=\"minLength\"\r\n [maxlength]=\"maxLength\" min=\"minlength\" specialIsAlphaNumeric\r\n (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"controller\" matInput></textarea>\r\n\r\n </label>\r\n <!-- [(ngModel)]=\"field\" [name]=\"name\" -->\r\n <mat-error *ngIf=\"field && field?.length < minLength\">{{ errorMessage }}</mat-error>\r\n <mat-error *ngIf=\"field && field?.length > maxLength\">{{ errorMessage }}</mat-error>\r\n <mat-error class=\"mb-2\" *ngIf=\"!field && (!controller?.valid)\">{{ i18n.translate('validFieldError') }}{{ label }}</mat-error>\r\n\r\n\r\n <mat-hint class=\"d-flex align-items-center gap-1 mt-1\" *ngIf=\"showHint\">\r\n <span class=\"sfi sfi-info fs-17 fc-dark-gray\" [ngClass]=\"{'fc-oasis-light-imp':value}\"></span>\r\n <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n </mat-hint>\r\n\r\n\r\n </mat-form-field>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"isReadOnly && (showIfEmpty || field)\">\r\n <app-info-item class=\"info-item w-100\" [insideTable]=\"insideTable\" [label]=\"label\" [value]=\"field\" [type]=\"type\"></app-info-item>\r\n</ng-container>\r\n", styles: [":host{flex-grow:1}:host ::ng-deep mat-form-field.custom-textarea .mat-form-field-flex{padding:var(--input-padding)}:host ::ng-deep table mat-form-field.custom-textarea .mat-form-field-flex{--input-height: 80px}\n"], dependencies: [{ kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: InfoItemComponent, selector: "app-info-item", inputs: ["label", "value", "name", "type", "dateType", "multiple", "insideTable", "hasLabel", "arrayList", "actionType", "download"] }] });
27
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TextareaComponent, isStandalone: true, selector: "app-textarea", inputs: { className: "className", preventSpecailChar: "preventSpecailChar" }, providers: [
28
+ {
29
+ provide: NG_VALUE_ACCESSOR,
30
+ useExisting: forwardRef(() => TextareaComponent),
31
+ multi: true,
32
+ },
33
+ ], usesInheritance: true, ngImport: i0, template: "@if(!isReadOnly){\r\n <ng-container>\r\n @if (label){\r\n <div class=\"d-flex justify-content-between mb-1\">\r\n <span class=\"form-label mb-0\">{{ label }}</span>\r\n @if(!required){\r\n <span class=\"fs-11 fc-dark-gray\">\r\n <!-- {{'Optional'| transloco}} -->{{ i18n.translate('Optional') }}\r\n </span>\r\n }\r\n </div>\r\n }\r\n <mat-form-field class=\"custom-textarea bordered-input {{className}}\">\r\n <mat-label>{{ label }}</mat-label>\r\n <label class=\"mat-form-content\">\r\n @if (type === 'arOnly'){\r\n <textarea [placeholder]=\"placeholder\" min=\"minlength\" arOnly\r\n (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"control\" matInput></textarea>\r\n }\r\n @if (type === 'enOnly'){\r\n <textarea [placeholder]=\"placeholder\" min=\"minlength\" enOnly\r\n (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"control\" matInput></textarea>\r\n }\r\n @if (type !== 'enOnly' && type !== 'arOnly' ){\r\n <textarea [placeholder]=\"placeholder\" \r\n [maxlength]=\"maxLength\" min=\"minlength\" specialIsAlphaNumeric\r\n (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"control\" matInput></textarea>\r\n }\r\n \r\n </label>\r\n @if (showHint){\r\n <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n <span class=\"sfi sfi-info fs-17 fc-dark-gray\" [ngClass]=\"{'fc-oasis-light-imp':value}\"></span>\r\n <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n </mat-hint>\r\n }\r\n \r\n </mat-form-field>\r\n <app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n \r\n </ng-container>\r\n}\r\n@if (isReadOnly && (showIfEmpty || control)){\r\n <ng-container>\r\n <app-info-item class=\"info-item w-100\" [insideTable]=\"insideTable\" [label]=\"label\" [value]=\"control\" [type]=\"type\"></app-info-item>\r\n </ng-container>\r\n}\r\n\r\n", styles: [":host{flex-grow:1}:host ::ng-deep mat-form-field.custom-textarea .mat-form-field-flex{padding:var(--input-padding)}:host ::ng-deep table mat-form-field.custom-textarea .mat-form-field-flex{--input-height: 80px}\n"], dependencies: [{ kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ValidationErrorsComponent, selector: "app-validation-errors", inputs: ["errors", "customErrorMessages"] }] });
69
34
  }
70
35
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TextareaComponent, decorators: [{
71
36
  type: Component,
72
37
  args: [{ selector: 'app-textarea', schemas: [CUSTOM_ELEMENTS_SCHEMA], imports: [
73
38
  MatFormField,
39
+ MatInput,
74
40
  ReactiveFormsModule,
75
41
  NgIf,
76
42
  NgClass,
77
- InfoItemComponent
78
- ], standalone: true, template: "<ng-container *ngIf=\"!isReadOnly\">\r\n <div class=\"d-flex justify-content-between mb-1\" *ngIf=\"hasLabel\">\r\n <span class=\"form-label mb-0\">{{ label }}</span>\r\n <span *ngIf=\"!required\" class=\"fs-11 fc-dark-gray\">\r\n <!-- {{'Optional'| transloco}} -->{{ i18n.translate('Optional') }}\r\n </span>\r\n </div>\r\n <mat-form-field class=\"custom-textarea bordered-input {{className}}\">\r\n <mat-label>{{ label }}</mat-label>\r\n <label class=\"mat-form-content\">\r\n\r\n <textarea *ngIf=\"type === 'arOnly'\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\" arOnly\r\n (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"controller\" matInput></textarea>\r\n\r\n <textarea *ngIf=\"type === 'enOnly'\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\" enOnly\r\n (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"controller\" matInput></textarea>\r\n\r\n <!-- <textarea *ngIf=\"preventSpecailChar\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\"\r\n specialIsAlphaNumeric\r\n (input)=\"onValueChange($event.target.value)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"controller\" matInput></textarea>-->\r\n <!--&& !preventSpecailChar-->\r\n <textarea *ngIf=\"type !== 'enOnly' && type !== 'arOnly' \" [placeholder]=\"placeholder\" [minlength]=\"minLength\"\r\n [maxlength]=\"maxLength\" min=\"minlength\" specialIsAlphaNumeric\r\n (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"controller\" matInput></textarea>\r\n\r\n </label>\r\n <!-- [(ngModel)]=\"field\" [name]=\"name\" -->\r\n <mat-error *ngIf=\"field && field?.length < minLength\">{{ errorMessage }}</mat-error>\r\n <mat-error *ngIf=\"field && field?.length > maxLength\">{{ errorMessage }}</mat-error>\r\n <mat-error class=\"mb-2\" *ngIf=\"!field && (!controller?.valid)\">{{ i18n.translate('validFieldError') }}{{ label }}</mat-error>\r\n\r\n\r\n <mat-hint class=\"d-flex align-items-center gap-1 mt-1\" *ngIf=\"showHint\">\r\n <span class=\"sfi sfi-info fs-17 fc-dark-gray\" [ngClass]=\"{'fc-oasis-light-imp':value}\"></span>\r\n <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n </mat-hint>\r\n\r\n\r\n </mat-form-field>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"isReadOnly && (showIfEmpty || field)\">\r\n <app-info-item class=\"info-item w-100\" [insideTable]=\"insideTable\" [label]=\"label\" [value]=\"field\" [type]=\"type\"></app-info-item>\r\n</ng-container>\r\n", styles: [":host{flex-grow:1}:host ::ng-deep mat-form-field.custom-textarea .mat-form-field-flex{padding:var(--input-padding)}:host ::ng-deep table mat-form-field.custom-textarea .mat-form-field-flex{--input-height: 80px}\n"] }]
79
- }], propDecorators: { label: [{
80
- type: Input
81
- }], tooltip: [{
82
- type: Input
83
- }], className: [{
43
+ ValidationErrorsComponent
44
+ ], standalone: true, providers: [
45
+ {
46
+ provide: NG_VALUE_ACCESSOR,
47
+ useExisting: forwardRef(() => TextareaComponent),
48
+ multi: true,
49
+ },
50
+ ], template: "@if(!isReadOnly){\r\n <ng-container>\r\n @if (label){\r\n <div class=\"d-flex justify-content-between mb-1\">\r\n <span class=\"form-label mb-0\">{{ label }}</span>\r\n @if(!required){\r\n <span class=\"fs-11 fc-dark-gray\">\r\n <!-- {{'Optional'| transloco}} -->{{ i18n.translate('Optional') }}\r\n </span>\r\n }\r\n </div>\r\n }\r\n <mat-form-field class=\"custom-textarea bordered-input {{className}}\">\r\n <mat-label>{{ label }}</mat-label>\r\n <label class=\"mat-form-content\">\r\n @if (type === 'arOnly'){\r\n <textarea [placeholder]=\"placeholder\" min=\"minlength\" arOnly\r\n (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"control\" matInput></textarea>\r\n }\r\n @if (type === 'enOnly'){\r\n <textarea [placeholder]=\"placeholder\" min=\"minlength\" enOnly\r\n (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"control\" matInput></textarea>\r\n }\r\n @if (type !== 'enOnly' && type !== 'arOnly' ){\r\n <textarea [placeholder]=\"placeholder\" \r\n [maxlength]=\"maxLength\" min=\"minlength\" specialIsAlphaNumeric\r\n (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n [formControl]=\"control\" matInput></textarea>\r\n }\r\n \r\n </label>\r\n @if (showHint){\r\n <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n <span class=\"sfi sfi-info fs-17 fc-dark-gray\" [ngClass]=\"{'fc-oasis-light-imp':value}\"></span>\r\n <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n </mat-hint>\r\n }\r\n \r\n </mat-form-field>\r\n <app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n \r\n </ng-container>\r\n}\r\n@if (isReadOnly && (showIfEmpty || control)){\r\n <ng-container>\r\n <app-info-item class=\"info-item w-100\" [insideTable]=\"insideTable\" [label]=\"label\" [value]=\"control\" [type]=\"type\"></app-info-item>\r\n </ng-container>\r\n}\r\n\r\n", styles: [":host{flex-grow:1}:host ::ng-deep mat-form-field.custom-textarea .mat-form-field-flex{padding:var(--input-padding)}:host ::ng-deep table mat-form-field.custom-textarea .mat-form-field-flex{--input-height: 80px}\n"] }]
51
+ }], propDecorators: { className: [{
84
52
  type: Input
85
53
  }], preventSpecailChar: [{
86
54
  type: Input
87
55
  }] } });
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/textarea/textarea.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/textarea/textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ReactiveFormsModule, Validators} from '@angular/forms';\r\n/* eslint-disable @angular-eslint/component-selector */\r\n/* eslint-disable @angular-eslint/use-lifecycle-interface */\r\nimport {Component, CUSTOM_ELEMENTS_SCHEMA, Input, OnChanges, SimpleChanges} from '@angular/core';\r\nimport { BaseComponent } from '../base-component/base-component.component';\r\nimport {MatFormField} from \"@angular/material/form-field\";\r\nimport {NgClass, NgIf} from \"@angular/common\";\r\nimport {InfoItemComponent} from \"../info-item/info-item.component\";\r\n\r\n@Component({\r\n  selector: 'app-textarea',\r\n  templateUrl: './textarea.component.html',\r\n  styleUrls: ['./textarea.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    MatFormField,\r\n    ReactiveFormsModule,\r\n    NgIf,\r\n    NgClass,\r\n    InfoItemComponent\r\n  ],\r\n  standalone: true\r\n})\r\nexport class TextareaComponent extends BaseComponent implements OnChanges {\r\n  @Input() label!: string;\r\n  @Input() tooltip!: string;\r\n  @Input() className!: string;\r\n  @Input() preventSpecailChar!: boolean;\r\n  textAreaFocus = false\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n      if (changes?.['field'].currentValue == '' || changes?.['field'].currentValue == null) {\r\n        this.controller.setValue('');\r\n      }else{\r\n        this.controller.setValue(changes['field'].currentValue)\r\n      }\r\n      if(changes?.['disabled']?.previousValue !== changes?.['disabled']?.currentValue){\r\n        if(this.disabled) this.controller.disable();\r\n        else this.controller.enable();\r\n      }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // this.resetPropagator.subscribe(this, this.resetData);\r\n    this.field == undefined ? (this.field = '') : this.field;\r\n    this.controller.setValue(this.field);\r\n    if (this.minLength ) {\r\n      this.controller.setValidators([\r\n        Validators.minLength(+this.minLength),\r\n      ]);\r\n    }\r\n    if (this.maxLength ) {\r\n      this.controller.setValidators([\r\n        Validators.maxLength(+this.maxLength),\r\n      ]);\r\n    }\r\n    if (this.required) {\r\n      this.controller.setValidators([Validators.required]);\r\n    }\r\n  }\r\n\r\n  focusInFunction() {\r\n    this.textAreaFocus = true;\r\n    this.validateTextAreaBorder();\r\n  }\r\n\r\n  focusOutFunction() {\r\n    this.textAreaFocus = false;\r\n    this.validateTextAreaBorder();\r\n  }\r\n\r\n  validateTextAreaBorder() {\r\n    return {\r\n      \"field-border-error\": (this.field && this.field.length < this.minLength) || (this.field && this.field.length > this.maxLength),\r\n    }\r\n  }\r\n\r\n  onValueChange(event) {\r\n    const target = event.target as HTMLInputElement;\r\n    const data = target.value\r\n    this.emitedValue.emit(data.trim());\r\n  }\r\n\r\n}\r\n","<ng-container *ngIf=\"!isReadOnly\">\r\n  <div class=\"d-flex justify-content-between mb-1\" *ngIf=\"hasLabel\">\r\n    <span class=\"form-label mb-0\">{{ label }}</span>\r\n    <span *ngIf=\"!required\" class=\"fs-11 fc-dark-gray\">\r\n      <!-- {{'Optional'| transloco}}  -->{{ i18n.translate('Optional') }}\r\n    </span>\r\n  </div>\r\n  <mat-form-field class=\"custom-textarea bordered-input  {{className}}\">\r\n    <mat-label>{{ label }}</mat-label>\r\n    <label class=\"mat-form-content\">\r\n\r\n        <textarea *ngIf=\"type === 'arOnly'\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\" arOnly\r\n                  (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n                  [formControl]=\"controller\" matInput></textarea>\r\n\r\n      <textarea *ngIf=\"type === 'enOnly'\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\" enOnly\r\n                (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n                [formControl]=\"controller\" matInput></textarea>\r\n\r\n      <!--      <textarea *ngIf=\"preventSpecailChar\" [placeholder]=\"placeholder\" [minlength]=\"minLength\" [maxlength]=\"maxLength\" min=\"minlength\"\r\n                      specialIsAlphaNumeric\r\n                      (input)=\"onValueChange($event.target.value)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n                      [formControl]=\"controller\" matInput></textarea>-->\r\n      <!--&& !preventSpecailChar-->\r\n      <textarea *ngIf=\"type !== 'enOnly' &&  type !== 'arOnly' \" [placeholder]=\"placeholder\" [minlength]=\"minLength\"\r\n                [maxlength]=\"maxLength\" min=\"minlength\" specialIsAlphaNumeric\r\n                (input)=\"onValueChange($event)\" (focusout)=\"focusOutFunction()\" (focusin)=\"focusInFunction()\" max=\"maxValue\"\r\n                [formControl]=\"controller\" matInput></textarea>\r\n\r\n    </label>\r\n    <!-- [(ngModel)]=\"field\" [name]=\"name\" -->\r\n    <mat-error *ngIf=\"field && field?.length < minLength\">{{ errorMessage }}</mat-error>\r\n    <mat-error *ngIf=\"field && field?.length > maxLength\">{{ errorMessage }}</mat-error>\r\n    <mat-error class=\"mb-2\" *ngIf=\"!field && (!controller?.valid)\">{{ i18n.translate('validFieldError') }}{{ label }}</mat-error>\r\n\r\n\r\n    <mat-hint class=\"d-flex align-items-center gap-1 mt-1\" *ngIf=\"showHint\">\r\n      <span class=\"sfi sfi-info fs-17 fc-dark-gray\" [ngClass]=\"{'fc-oasis-light-imp':value}\"></span>\r\n      <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n    </mat-hint>\r\n\r\n\r\n  </mat-form-field>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"isReadOnly && (showIfEmpty || field)\">\r\n  <app-info-item class=\"info-item w-100\" [insideTable]=\"insideTable\" [label]=\"label\" [value]=\"field\" [type]=\"type\"></app-info-item>\r\n</ng-container>\r\n"]}
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGFyZWEuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvdGV4dGFyZWEvdGV4dGFyZWEuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvdGV4dGFyZWEvdGV4dGFyZWEuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGlCQUFpQixFQUFFLG1CQUFtQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDdEUsdURBQXVEO0FBQ3ZELDREQUE0RDtBQUM1RCxPQUFPLEVBQUMsU0FBUyxFQUFFLHNCQUFzQixFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDbkYsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQzFELE9BQU8sRUFBQyxPQUFPLEVBQUUsSUFBSSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDOUMsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDcEYsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ25ELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGtEQUFrRCxDQUFDOzs7QUF3QjdGLE1BQU0sT0FBTyxpQkFBd0IsU0FBUSw2QkFBbUM7SUFDckUsU0FBUyxDQUFVO0lBQ25CLGtCQUFrQixDQUFXO0lBR3RDLGVBQWU7UUFDYixJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztJQUNoQyxDQUFDO0lBRUQsZ0JBQWdCO1FBQ2QsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVELHNCQUFzQjtRQUNwQixXQUFXO1FBQ1gsb0lBQW9JO1FBQ3BJLElBQUk7SUFDTixDQUFDO3VHQWpCVSxpQkFBaUI7MkZBQWpCLGlCQUFpQix5SUFSakI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLGlCQUFpQixDQUFDO2dCQUNoRCxLQUFLLEVBQUUsSUFBSTthQUNaO1NBQ0YsaURDOUJILHVyRUFtREEsOFFEbkNJLFlBQVksNExBQ1osUUFBUSxnVUFDUixtQkFBbUIsNnVCQUVuQixPQUFPLG9GQUNQLHlCQUF5Qjs7MkZBV2hCLGlCQUFpQjtrQkF0QjdCLFNBQVM7K0JBQ0UsY0FBYyxXQUdmLENBQUMsc0JBQXNCLENBQUMsV0FDeEI7d0JBQ1AsWUFBWTt3QkFDWixRQUFRO3dCQUNSLG1CQUFtQjt3QkFDbkIsSUFBSTt3QkFDSixPQUFPO3dCQUNQLHlCQUF5QjtxQkFDMUIsY0FDVyxJQUFJLGFBQ0w7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsa0JBQWtCLENBQUM7NEJBQ2hELEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGOzhCQUdRLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csa0JBQWtCO3NCQUExQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOR19WQUxVRV9BQ0NFU1NPUiwgUmVhY3RpdmVGb3Jtc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG4vKiBlc2xpbnQtZGlzYWJsZSBAYW5ndWxhci1lc2xpbnQvY29tcG9uZW50LXNlbGVjdG9yICovXHJcbi8qIGVzbGludC1kaXNhYmxlIEBhbmd1bGFyLWVzbGludC91c2UtbGlmZWN5Y2xlLWludGVyZmFjZSAqL1xyXG5pbXBvcnQge0NvbXBvbmVudCwgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgZm9yd2FyZFJlZiwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge01hdEZvcm1GaWVsZH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGRcIjtcclxuaW1wb3J0IHtOZ0NsYXNzLCBOZ0lmfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlIH0gZnJvbSAnLi4vY29udHJvbC12YWx1ZS1hY2Nlc3Nvci5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBNYXRJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcclxuaW1wb3J0IHsgVmFsaWRhdGlvbkVycm9yc0NvbXBvbmVudCB9IGZyb20gJy4uL3ZhbGlkYXRpb24tZXJyb3JzL3ZhbGlkYXRpb24tZXJyb3JzLmNvbXBvbmVudCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC10ZXh0YXJlYScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RleHRhcmVhLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi90ZXh0YXJlYS5jb21wb25lbnQuc2NzcyddLFxyXG4gIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBNYXRGb3JtRmllbGQsXHJcbiAgICBNYXRJbnB1dCxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBOZ0lmLFxyXG4gICAgTmdDbGFzcyxcclxuICAgIFZhbGlkYXRpb25FcnJvcnNDb21wb25lbnRcclxuICBdLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBUZXh0YXJlYUNvbXBvbmVudCksXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgfSxcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUZXh0YXJlYUNvbXBvbmVudDxUeXBlPiBleHRlbmRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlPFR5cGU+IHtcclxuICBASW5wdXQoKSBjbGFzc05hbWUhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgcHJldmVudFNwZWNhaWxDaGFyITogYm9vbGVhbjtcclxuXHJcblxyXG4gIGZvY3VzSW5GdW5jdGlvbigpIHtcclxuICAgIHRoaXMudmFsaWRhdGVUZXh0QXJlYUJvcmRlcigpO1xyXG4gIH1cclxuXHJcbiAgZm9jdXNPdXRGdW5jdGlvbigpIHtcclxuICAgIHRoaXMudmFsaWRhdGVUZXh0QXJlYUJvcmRlcigpO1xyXG4gIH1cclxuXHJcbiAgdmFsaWRhdGVUZXh0QXJlYUJvcmRlcigpIHtcclxuICAgIC8vIHJldHVybiB7XHJcbiAgICAvLyAgIFwiZmllbGQtYm9yZGVyLWVycm9yXCI6ICh0aGlzLmZpZWxkICYmIHRoaXMuZmllbGQubGVuZ3RoIDwgdGhpcy5taW5MZW5ndGgpIHx8ICh0aGlzLmZpZWxkICYmIHRoaXMuZmllbGQubGVuZ3RoID4gdGhpcy5tYXhMZW5ndGgpLFxyXG4gICAgLy8gfVxyXG4gIH1cclxufVxyXG4iLCJAaWYoIWlzUmVhZE9ubHkpe1xyXG4gIDxuZy1jb250YWluZXI+XHJcbiAgICBAaWYgKGxhYmVsKXtcclxuICAgICAgPGRpdiBjbGFzcz1cImQtZmxleCBqdXN0aWZ5LWNvbnRlbnQtYmV0d2VlbiBtYi0xXCI+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJmb3JtLWxhYmVsIG1iLTBcIj57eyBsYWJlbCB9fTwvc3Bhbj5cclxuICAgICAgICBAaWYoIXJlcXVpcmVkKXtcclxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZnMtMTEgZmMtZGFyay1ncmF5XCI+XHJcbiAgICAgICAgICAgIDwhLS0ge3snT3B0aW9uYWwnfCB0cmFuc2xvY299fSAgLS0+e3sgaTE4bi50cmFuc2xhdGUoJ09wdGlvbmFsJykgfX1cclxuICAgICAgICAgIDwvc3Bhbj5cclxuICAgICAgICB9XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgfVxyXG4gICAgPG1hdC1mb3JtLWZpZWxkIGNsYXNzPVwiY3VzdG9tLXRleHRhcmVhIGJvcmRlcmVkLWlucHV0ICB7e2NsYXNzTmFtZX19XCI+XHJcbiAgICAgIDxtYXQtbGFiZWw+e3sgbGFiZWwgfX08L21hdC1sYWJlbD5cclxuICAgICAgPGxhYmVsIGNsYXNzPVwibWF0LWZvcm0tY29udGVudFwiPlxyXG4gICAgICAgIEBpZiAodHlwZSA9PT0gJ2FyT25seScpe1xyXG4gICAgICAgICAgPHRleHRhcmVhIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiICAgbWluPVwibWlubGVuZ3RoXCIgYXJPbmx5XHJcbiAgICAgICAgICAoZm9jdXNvdXQpPVwiZm9jdXNPdXRGdW5jdGlvbigpXCIgKGZvY3VzaW4pPVwiZm9jdXNJbkZ1bmN0aW9uKClcIiBtYXg9XCJtYXhWYWx1ZVwiXHJcbiAgICAgICAgIFtmb3JtQ29udHJvbF09XCJjb250cm9sXCIgbWF0SW5wdXQ+PC90ZXh0YXJlYT5cclxuICAgICAgICB9XHJcbiAgICAgICAgQGlmICh0eXBlID09PSAnZW5Pbmx5Jyl7XHJcbiAgICAgICAgICA8dGV4dGFyZWEgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiICBtaW49XCJtaW5sZW5ndGhcIiBlbk9ubHlcclxuICAgICAgICAgIChmb2N1c291dCk9XCJmb2N1c091dEZ1bmN0aW9uKClcIiAoZm9jdXNpbik9XCJmb2N1c0luRnVuY3Rpb24oKVwiIG1heD1cIm1heFZhbHVlXCJcclxuICAgICAgICAgW2Zvcm1Db250cm9sXT1cImNvbnRyb2xcIiBtYXRJbnB1dD48L3RleHRhcmVhPlxyXG4gICAgICAgIH1cclxuICAgICAgIEBpZiAodHlwZSAhPT0gJ2VuT25seScgJiYgIHR5cGUgIT09ICdhck9ubHknICl7XHJcbiAgICAgICAgPHRleHRhcmVhIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiIFxyXG4gICAgICAgIFttYXhsZW5ndGhdPVwibWF4TGVuZ3RoXCIgbWluPVwibWlubGVuZ3RoXCIgc3BlY2lhbElzQWxwaGFOdW1lcmljXHJcbiAgICAgICAgIChmb2N1c291dCk9XCJmb2N1c091dEZ1bmN0aW9uKClcIiAoZm9jdXNpbik9XCJmb2N1c0luRnVuY3Rpb24oKVwiIG1heD1cIm1heFZhbHVlXCJcclxuICAgICAgICBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiIG1hdElucHV0PjwvdGV4dGFyZWE+XHJcbiAgICAgICB9XHJcbiAgICAgICBcclxuICAgICAgPC9sYWJlbD5cclxuICAgICAgQGlmIChzaG93SGludCl7XHJcbiAgICAgICAgPG1hdC1oaW50IGNsYXNzPVwiZC1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlciBnYXAtMSBtdC0xXCI+XHJcbiAgICAgICAgICA8c3BhbiBjbGFzcz1cInNmaSBzZmktaW5mbyBmcy0xNyBmYy1kYXJrLWdyYXlcIiBbbmdDbGFzc109XCJ7J2ZjLW9hc2lzLWxpZ2h0LWltcCc6dmFsdWV9XCI+PC9zcGFuPlxyXG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJmcy0xMiBmYy1ibGFjayBsaW5lLWhlaWdodC0xXCI+e3sgaGludCB9fTwvc3Bhbj5cclxuICAgICAgICA8L21hdC1oaW50PlxyXG4gICAgICB9XHJcbiAgICBcclxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XHJcbiAgPGFwcC12YWxpZGF0aW9uLWVycm9ycyBbZXJyb3JzXT1cImNvbnRyb2wuZXJyb3JzXCI+PC9hcHAtdmFsaWRhdGlvbi1lcnJvcnM+XHJcbiAgXHJcbiAgPC9uZy1jb250YWluZXI+XHJcbn1cclxuQGlmIChpc1JlYWRPbmx5ICYmIChzaG93SWZFbXB0eSB8fCBjb250cm9sKSl7XHJcbiAgPG5nLWNvbnRhaW5lcj5cclxuICAgIDxhcHAtaW5mby1pdGVtIGNsYXNzPVwiaW5mby1pdGVtIHctMTAwXCIgW2luc2lkZVRhYmxlXT1cImluc2lkZVRhYmxlXCIgW2xhYmVsXT1cImxhYmVsXCIgW3ZhbHVlXT1cImNvbnRyb2xcIiBbdHlwZV09XCJ0eXBlXCI+PC9hcHAtaW5mby1pdGVtPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG59XHJcblxyXG4iXX0=
@@ -7,7 +7,6 @@ import * as i1 from "@angular/common";
7
7
  export class ValidationErrorsComponent extends ControlValueAccessorDirective {
8
8
  errors = {};
9
9
  customErrorMessages = {};
10
- label;
11
10
  errorMessages = {
12
11
  required: 'This field is required',
13
12
  maxlength: 'This field max length',
@@ -23,7 +22,7 @@ export class ValidationErrorsComponent extends ControlValueAccessorDirective {
23
22
  }
24
23
  }
25
24
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ValidationErrorsComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
26
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: ValidationErrorsComponent, isStandalone: true, selector: "app-validation-errors", inputs: { errors: "errors", customErrorMessages: "customErrorMessages", label: "label" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: " @if(control.touched) {\r\n @for(error of errors | keyvalue; track error ) {\r\n <mat-error class=\"mb-2\">\r\n {{ errorMessages[error.key] }} {{errors['maxlength']?.requiredLength}} {{errors['minlength']?.requiredLength}}\r\n </mat-error>\r\n }\r\n }\r\n\r\n ", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.KeyValuePipe, name: "keyvalue" }, { kind: "directive", type: MatError, selector: "mat-error, [matError]", inputs: ["id"] }] });
25
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: ValidationErrorsComponent, isStandalone: true, selector: "app-validation-errors", inputs: { errors: "errors", customErrorMessages: "customErrorMessages" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: " @if(control.touched) {\r\n @for(error of errors | keyvalue; track error ) {\r\n <mat-error class=\"mb-2\">\r\n {{ errorMessages[error.key] }} {{errors['maxlength']?.requiredLength}} {{errors['minlength']?.requiredLength}}\r\n </mat-error>\r\n }\r\n }", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.KeyValuePipe, name: "keyvalue" }, { kind: "directive", type: MatError, selector: "mat-error, [matError]", inputs: ["id"] }] });
27
26
  }
28
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ValidationErrorsComponent, decorators: [{
29
28
  type: Component,
@@ -31,12 +30,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
31
30
  NgFor,
32
31
  CommonModule,
33
32
  MatError
34
- ], template: " @if(control.touched) {\r\n @for(error of errors | keyvalue; track error ) {\r\n <mat-error class=\"mb-2\">\r\n {{ errorMessages[error.key] }} {{errors['maxlength']?.requiredLength}} {{errors['minlength']?.requiredLength}}\r\n </mat-error>\r\n }\r\n }\r\n\r\n " }]
33
+ ], template: " @if(control.touched) {\r\n @for(error of errors | keyvalue; track error ) {\r\n <mat-error class=\"mb-2\">\r\n {{ errorMessages[error.key] }} {{errors['maxlength']?.requiredLength}} {{errors['minlength']?.requiredLength}}\r\n </mat-error>\r\n }\r\n }" }]
35
34
  }], propDecorators: { errors: [{
36
35
  type: Input
37
36
  }], customErrorMessages: [{
38
37
  type: Input
39
- }], label: [{
40
- type: Input
41
38
  }] } });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvdmFsaWRhdGlvbi1lcnJvcnMvdmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvdmFsaWRhdGlvbi1lcnJvcnMvdmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBNEIsTUFBTSxlQUFlLENBQUM7QUFFM0UsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3hELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7QUFhcEYsTUFBTSxPQUFPLHlCQUFnQyxTQUFRLDZCQUFtQztJQUM3RSxNQUFNLEdBQUcsRUFBRSxDQUFDO0lBQ1osbUJBQW1CLEdBQUcsRUFBRSxDQUFDO0lBQ3pCLEtBQUssQ0FBUztJQUN2QixhQUFhLEdBQUc7UUFDZCxRQUFRLEVBQUUsd0JBQXdCO1FBQ2xDLFNBQVMsRUFBRSx1QkFBdUI7UUFDbEMsU0FBUyxFQUFFLHVCQUF1QjtLQUNuQyxDQUFDO0lBRUYsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLE1BQU0sRUFBRSxtQkFBbUIsRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUN4QyxJQUFJLG1CQUFtQixFQUFFLENBQUM7WUFDeEIsSUFBSSxDQUFDLGFBQWEsR0FBRztnQkFDbkIsR0FBRyxJQUFJLENBQUMsYUFBYTtnQkFDckIsR0FBRyxtQkFBbUIsQ0FBQyxZQUFZO2FBQ3BDLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQzt1R0FsQlUseUJBQXlCOzJGQUF6Qix5QkFBeUIsdU5DakJ0QyxzVEFRRSx5RERLRSxZQUFZLDBGQUNaLFFBQVE7OzJGQUdDLHlCQUF5QjtrQkFYckMsU0FBUzsrQkFDRSx1QkFBdUIsY0FHckIsSUFBSSxXQUNQO3dCQUNQLEtBQUs7d0JBQ0wsWUFBWTt3QkFDWixRQUFRO3FCQUNUOzhCQUdRLE1BQU07c0JBQWQsS0FBSztnQkFDRyxtQkFBbUI7c0JBQTNCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlLCBOZ0ZvciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBWYWxpZGF0aW9uRXJyb3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBNYXRFcnJvciB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZSB9IGZyb20gJy4uL2NvbnRyb2wtdmFsdWUtYWNjZXNzb3IuZGlyZWN0aXZlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLXZhbGlkYXRpb24tZXJyb3JzJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3ZhbGlkYXRpb24tZXJyb3JzLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBOZ0ZvcixcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIE1hdEVycm9yXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFsaWRhdGlvbkVycm9yc0NvbXBvbmVudDxUeXBlPiBleHRlbmRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlPFR5cGU+ICB7XHJcbiAgQElucHV0KCkgZXJyb3JzID0ge307XHJcbiAgQElucHV0KCkgY3VzdG9tRXJyb3JNZXNzYWdlcyA9IHt9O1xyXG4gIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmc7XHJcbiAgZXJyb3JNZXNzYWdlcyA9IHtcclxuICAgIHJlcXVpcmVkOiAnVGhpcyBmaWVsZCBpcyByZXF1aXJlZCcsXHJcbiAgICBtYXhsZW5ndGg6ICdUaGlzIGZpZWxkIG1heCBsZW5ndGgnLFxyXG4gICAgbWlubGVuZ3RoOiAnVGhpcyBmaWVsZCBtaW4gbGVuZ3RoJyxcclxuICB9O1xyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICBjb25zdCB7IGN1c3RvbUVycm9yTWVzc2FnZXMgfSA9IGNoYW5nZXM7XHJcbiAgICBpZiAoY3VzdG9tRXJyb3JNZXNzYWdlcykge1xyXG4gICAgICB0aGlzLmVycm9yTWVzc2FnZXMgPSB7XHJcbiAgICAgICAgLi4udGhpcy5lcnJvck1lc3NhZ2VzLFxyXG4gICAgICAgIC4uLmN1c3RvbUVycm9yTWVzc2FnZXMuY3VycmVudFZhbHVlLFxyXG4gICAgICB9O1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iLCIgIEBpZihjb250cm9sLnRvdWNoZWQpIHtcclxuICAgIEBmb3IoZXJyb3Igb2YgZXJyb3JzIHwga2V5dmFsdWU7IHRyYWNrIGVycm9yICkge1xyXG4gICAgICAgICAgICA8bWF0LWVycm9yIGNsYXNzPVwibWItMlwiPlxyXG4gICAgICAgICAgICAgICAge3sgZXJyb3JNZXNzYWdlc1tlcnJvci5rZXldIH19IHt7ZXJyb3JzWydtYXhsZW5ndGgnXT8ucmVxdWlyZWRMZW5ndGh9fSB7e2Vycm9yc1snbWlubGVuZ3RoJ10/LnJlcXVpcmVkTGVuZ3RofX1cclxuICAgICAgICAgICAgICA8L21hdC1lcnJvcj5cclxuICAgIH1cclxuICB9XHJcblxyXG4gICJdfQ==
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvdmFsaWRhdGlvbi1lcnJvcnMvdmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvdmFsaWRhdGlvbi1lcnJvcnMvdmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBNEIsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3hELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7QUFhcEYsTUFBTSxPQUFPLHlCQUFnQyxTQUFRLDZCQUFtQztJQUM3RSxNQUFNLEdBQUcsRUFBRSxDQUFDO0lBQ1osbUJBQW1CLEdBQUcsRUFBRSxDQUFDO0lBQ2xDLGFBQWEsR0FBRztRQUNkLFFBQVEsRUFBRSx3QkFBd0I7UUFDbEMsU0FBUyxFQUFFLHVCQUF1QjtRQUNsQyxTQUFTLEVBQUUsdUJBQXVCO0tBQ25DLENBQUM7SUFFRixXQUFXLENBQUMsT0FBc0I7UUFDaEMsTUFBTSxFQUFFLG1CQUFtQixFQUFFLEdBQUcsT0FBTyxDQUFDO1FBQ3hDLElBQUksbUJBQW1CLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsYUFBYSxHQUFHO2dCQUNuQixHQUFHLElBQUksQ0FBQyxhQUFhO2dCQUNyQixHQUFHLG1CQUFtQixDQUFDLFlBQVk7YUFDcEMsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO3VHQWpCVSx5QkFBeUI7MkZBQXpCLHlCQUF5Qix1TUNoQnRDLDRTQU1HLHlERE1DLFlBQVksMEZBQ1osUUFBUTs7MkZBR0MseUJBQXlCO2tCQVhyQyxTQUFTOytCQUNFLHVCQUF1QixjQUdyQixJQUFJLFdBQ1A7d0JBQ1AsS0FBSzt3QkFDTCxZQUFZO3dCQUNaLFFBQVE7cUJBQ1Q7OEJBR1EsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLG1CQUFtQjtzQkFBM0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSwgTmdGb3IgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0RXJyb3IgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3JEaXJlY3RpdmUgfSBmcm9tICcuLi9jb250cm9sLXZhbHVlLWFjY2Vzc29yLmRpcmVjdGl2ZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC12YWxpZGF0aW9uLWVycm9ycycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3ZhbGlkYXRpb24tZXJyb3JzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi92YWxpZGF0aW9uLWVycm9ycy5jb21wb25lbnQuc2NzcyddLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW1xyXG4gICAgTmdGb3IsXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBNYXRFcnJvclxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFZhbGlkYXRpb25FcnJvcnNDb21wb25lbnQ8VHlwZT4gZXh0ZW5kcyBDb250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZTxUeXBlPiAge1xyXG4gIEBJbnB1dCgpIGVycm9ycyA9IHt9O1xyXG4gIEBJbnB1dCgpIGN1c3RvbUVycm9yTWVzc2FnZXMgPSB7fTtcclxuICBlcnJvck1lc3NhZ2VzID0ge1xyXG4gICAgcmVxdWlyZWQ6ICdUaGlzIGZpZWxkIGlzIHJlcXVpcmVkJyxcclxuICAgIG1heGxlbmd0aDogJ1RoaXMgZmllbGQgbWF4IGxlbmd0aCcsXHJcbiAgICBtaW5sZW5ndGg6ICdUaGlzIGZpZWxkIG1pbiBsZW5ndGgnLFxyXG4gIH07XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIGNvbnN0IHsgY3VzdG9tRXJyb3JNZXNzYWdlcyB9ID0gY2hhbmdlcztcclxuICAgIGlmIChjdXN0b21FcnJvck1lc3NhZ2VzKSB7XHJcbiAgICAgIHRoaXMuZXJyb3JNZXNzYWdlcyA9IHtcclxuICAgICAgICAuLi50aGlzLmVycm9yTWVzc2FnZXMsXHJcbiAgICAgICAgLi4uY3VzdG9tRXJyb3JNZXNzYWdlcy5jdXJyZW50VmFsdWUsXHJcbiAgICAgIH07XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIiAgQGlmKGNvbnRyb2wudG91Y2hlZCkge1xyXG4gICAgQGZvcihlcnJvciBvZiBlcnJvcnMgfCBrZXl2YWx1ZTsgdHJhY2sgZXJyb3IgKSB7XHJcbiAgICAgICAgICAgIDxtYXQtZXJyb3IgY2xhc3M9XCJtYi0yXCI+XHJcbiAgICAgICAgICAgICAgICB7eyBlcnJvck1lc3NhZ2VzW2Vycm9yLmtleV0gfX0ge3tlcnJvcnNbJ21heGxlbmd0aCddPy5yZXF1aXJlZExlbmd0aH19IHt7ZXJyb3JzWydtaW5sZW5ndGgnXT8ucmVxdWlyZWRMZW5ndGh9fVxyXG4gICAgICAgICAgICAgIDwvbWF0LWVycm9yPlxyXG4gICAgfVxyXG4gIH0iXX0=
@@ -69,7 +69,7 @@ export class GeneralApproverSectionComponent {
69
69
  this.fieldsForm.reset();
70
70
  }
71
71
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: GeneralApproverSectionComponent, deps: [{ token: i1.CoreI18nService }, { token: i2.FormBuilder }, { token: i1.ActionStateService }], target: i0.ɵɵFactoryTarget.Component });
72
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: GeneralApproverSectionComponent, isStandalone: true, selector: "app-general-approver-section", inputs: { isReadOnly: "isReadOnly", section: "section", form: "form", lov: "lov", className: "className" }, ngImport: i0, template: "<div\r\n [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n <div class=\"d-flex gap-2\">\r\n\r\n Request details working fine\r\n\r\n </div>\r\n\r\n </ds-alert>\r\n\r\n <form [formGroup]=\"fieldsForm\">\r\n <app-input formControlName=\"input1\"></app-input>\r\n </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n <div class=\"mt-4\">\r\n <lib-action-buttons\r\n [lovOptions]=\"lov?.['decision']?.options\"\r\n [lovType]=\"lov?.['decision']?.type\"\r\n [section]=\"section\"\r\n [form]=\"form\"\r\n [sections]=\"form.sections\"\r\n [showApprovalCycle]=\"true\"\r\n [customCall]=\"false\"\r\n [fieldsForm]=\"fieldsForm\"\r\n (customCallEmit)=\"customCallSubmit($event)\"\r\n (resetFormEmit)=\"resetForm()\"\r\n />\r\n </div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: InputComponent, selector: "app-input", inputs: ["label", "hasTooltip", "tooltip", "floatLabel", "className", "showLabel", "iconPrefixName", "matSuffix", "iconSuffixName", "emitedChangedValue1"] }, { kind: "component", type: ActionButtonsComponent, selector: "lib-action-buttons", inputs: ["lovOptions", "lovType", "fieldsForm", "form", "section", "sections", "showApprovalCycle", "customCall"], outputs: ["resetFormEmit", "customCallEmit"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
72
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: GeneralApproverSectionComponent, isStandalone: true, selector: "app-general-approver-section", inputs: { isReadOnly: "isReadOnly", section: "section", form: "form", lov: "lov", className: "className" }, ngImport: i0, template: "<div\r\n [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n <div class=\"d-flex gap-2\">\r\n\r\n Request details working fine\r\n\r\n </div>\r\n\r\n </ds-alert>\r\n\r\n <form [formGroup]=\"fieldsForm\">\r\n <app-input formControlName=\"input1\"></app-input>\r\n </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n <div class=\"mt-4\">\r\n <lib-action-buttons\r\n [lovOptions]=\"lov?.['decision']?.options\"\r\n [lovType]=\"lov?.['decision']?.type\"\r\n [section]=\"section\"\r\n [form]=\"form\"\r\n [sections]=\"form.sections\"\r\n [showApprovalCycle]=\"true\"\r\n [customCall]=\"false\"\r\n [fieldsForm]=\"fieldsForm\"\r\n (customCallEmit)=\"customCallSubmit($event)\"\r\n (resetFormEmit)=\"resetForm()\"\r\n />\r\n </div>\r\n}\r\n", styles: [".form-section-divide{--form-section-columns: 1fr 1fr}@media (max-width: 756px){.form-section-divide{--form-section-columns: 100%}}.form-section-divide .full{grid-column:1/-1}.head-title{position:relative;margin-bottom:12px}.head-title h3{display:inline-block;color:#8e9aa0;font-size:14px;font-weight:500;background-color:#fff;padding-inline-end:20px;position:relative;z-index:2;margin:0}.head-title:after{content:\"\";position:absolute;width:100%;height:1px;background-color:#dee0e2;top:50%;left:0;right:0;transform:translateY(-50%);z-index:1}.chamber{margin-bottom:20px}.chamber .chamber-content{background-color:#f8f8f8;padding:20px}.chamber .chamber-content .chamber-select{display:flex}.chamber .chamber-content mat-checkbox{font-size:14px}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: InputComponent, selector: "app-input", inputs: ["hasTooltip", "tooltip", "floatLabel", "className", "showLabel", "iconPrefixName", "iconSuffixName", "emitedChangedValue1"] }, { kind: "component", type: ActionButtonsComponent, selector: "lib-action-buttons", inputs: ["lovOptions", "lovType", "fieldsForm", "form", "section", "sections", "showApprovalCycle", "customCall"], outputs: ["resetFormEmit", "customCallEmit"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
73
73
  }
74
74
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: GeneralApproverSectionComponent, decorators: [{
75
75
  type: Component,
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
94
94
  }], className: [{
95
95
  type: Input
96
96
  }] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general-approver-section.component.js","sourceRoot":"","sources":["../../../../../../projects/bpm-core/src/lib/testComponent/general-approver-section/general-approver-section.component.ts","../../../../../../projects/bpm-core/src/lib/testComponent/general-approver-section/general-approver-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, Input, NO_ERRORS_SCHEMA, OnInit} from '@angular/core';\r\nimport {Form, Section} from \"../../interfaces\";\r\nimport {ActionStateService, CoreI18nService} from \"../../services\";\r\nimport {NgClass, NgForOf, NgIf} from \"@angular/common\";\r\nimport {ActionButtonsComponent} from \"../../components/shared-components\";\r\nimport {FormBuilder, FormControl, FormGroup, ReactiveFormsModule, Validators} from \"@angular/forms\";\r\nimport {CustomSearchableComponent, InputComponent} from '../../components/shared-components';\r\nimport {ValidationErrorsComponent} from '../../components/shared-components/form-field/validation-errors/validation-errors.component';\r\n\r\n@Component({\r\n  selector: 'app-general-approver-section',\r\n  templateUrl: './general-approver-section.component.html',\r\n  styleUrls: ['./general-approver-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],\r\n  imports: [\r\n    NgClass,\r\n    InputComponent,\r\n    NgIf,\r\n    NgForOf,\r\n    ActionButtonsComponent,\r\n    ReactiveFormsModule,\r\n    ValidationErrorsComponent,\r\n    CustomSearchableComponent\r\n  ]\r\n})\r\nexport class GeneralApproverSectionComponent implements OnInit{\r\n\r\n  @Input() isReadOnly: boolean;\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() className: string = \"info-section\";\r\n  fieldsForm: FormGroup;\r\n  numbers = [...Array(100).keys()].map(i => i + 1);\r\n\r\n  formGroup = new FormGroup({\r\n    name: new FormControl('', [Validators.required, Validators.maxLength(3), Validators.minLength(2)]),\r\n    countries: new FormControl('', Validators.required),\r\n  });\r\n\r\n\r\n  constructor(public i18n: CoreI18nService, private fb: FormBuilder, private actionStateService: ActionStateService) {\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.createForm();\r\n  }\r\n\r\n  createForm() {\r\n    let newForm = {\r\n      input1: ['', Validators.required]\r\n    };\r\n    this.lov?.['decision']?.options?.forEach(option => {\r\n      newForm[option.value] = [''];\r\n    })\r\n    this.fieldsForm = this.fb.group(newForm);\r\n\r\n    const checkValidityAndUpdate = () => {\r\n      this.lov?.['decision']?.options?.forEach(option => {\r\n        let isActionValid = this.checkValidity(option.value);\r\n        this.actionStateService.setActionValid(option.value, isActionValid);\r\n        this.section.body.details = this.fieldsForm.value\r\n      });\r\n    }\r\n\r\n    checkValidityAndUpdate();\r\n\r\n    this.fieldsForm.valueChanges.subscribe(() => {\r\n      checkValidityAndUpdate();\r\n    });\r\n\r\n  }\r\n\r\n  checkValidity(action: string): boolean {\r\n    switch (action) {\r\n      case 'APPROVE':\r\n        return true;\r\n      case 'REJECT':\r\n        return this.fieldsForm.valid;\r\n      case 'SENDBACK':\r\n        return this.fieldsForm.valid;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n\r\n  customCallSubmit(action: string) {\r\n    console.log('customCallSubmit', action)\r\n  }\r\n\r\n  resetForm() {\r\n    this.fieldsForm.reset()\r\n  }\r\n\r\n}\r\n","<div\r\n  [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n  <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n    <div class=\"d-flex gap-2\">\r\n\r\n      Request details working fine\r\n\r\n    </div>\r\n\r\n  </ds-alert>\r\n\r\n  <form [formGroup]=\"fieldsForm\">\r\n    <app-input formControlName=\"input1\"></app-input>\r\n  </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n  <div class=\"mt-4\">\r\n    <lib-action-buttons\r\n      [lovOptions]=\"lov?.['decision']?.options\"\r\n      [lovType]=\"lov?.['decision']?.type\"\r\n      [section]=\"section\"\r\n      [form]=\"form\"\r\n      [sections]=\"form.sections\"\r\n      [showApprovalCycle]=\"true\"\r\n      [customCall]=\"false\"\r\n      [fieldsForm]=\"fieldsForm\"\r\n      (customCallEmit)=\"customCallSubmit($event)\"\r\n      (resetFormEmit)=\"resetForm()\"\r\n    />\r\n  </div>\r\n}\r\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general-approver-section.component.js","sourceRoot":"","sources":["../../../../../../projects/bpm-core/src/lib/testComponent/general-approver-section/general-approver-section.component.ts","../../../../../../projects/bpm-core/src/lib/testComponent/general-approver-section/general-approver-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, Input, NO_ERRORS_SCHEMA, OnInit} from '@angular/core';\r\nimport {Form, Section} from \"../../interfaces\";\r\nimport {ActionStateService, CoreI18nService} from \"../../services\";\r\nimport {NgClass, NgForOf, NgIf} from \"@angular/common\";\r\nimport {ActionButtonsComponent} from \"../../components/shared-components\";\r\nimport {FormBuilder, FormControl, FormGroup, ReactiveFormsModule, Validators} from \"@angular/forms\";\r\nimport {CustomSearchableComponent, InputComponent} from '../../components/shared-components';\r\nimport {ValidationErrorsComponent} from '../../components/shared-components/form-field/validation-errors/validation-errors.component';\r\n\r\n@Component({\r\n  selector: 'app-general-approver-section',\r\n  templateUrl: './general-approver-section.component.html',\r\n  styleUrls: ['./general-approver-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],\r\n  imports: [\r\n    NgClass,\r\n    InputComponent,\r\n    NgIf,\r\n    NgForOf,\r\n    ActionButtonsComponent,\r\n    ReactiveFormsModule,\r\n    ValidationErrorsComponent,\r\n    CustomSearchableComponent\r\n  ]\r\n})\r\nexport class GeneralApproverSectionComponent implements OnInit{\r\n\r\n  @Input() isReadOnly: boolean;\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() className: string = \"info-section\";\r\n  fieldsForm: FormGroup;\r\n  numbers = [...Array(100).keys()].map(i => i + 1);\r\n\r\n  formGroup = new FormGroup({\r\n    name: new FormControl('', [Validators.required, Validators.maxLength(3), Validators.minLength(2)]),\r\n    countries: new FormControl('', Validators.required),\r\n  });\r\n\r\n\r\n  constructor(public i18n: CoreI18nService, private fb: FormBuilder, private actionStateService: ActionStateService) {\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.createForm();\r\n  }\r\n\r\n  createForm() {\r\n    let newForm = {\r\n      input1: ['', Validators.required]\r\n    };\r\n    this.lov?.['decision']?.options?.forEach(option => {\r\n      newForm[option.value] = [''];\r\n    })\r\n    this.fieldsForm = this.fb.group(newForm);\r\n\r\n    const checkValidityAndUpdate = () => {\r\n      this.lov?.['decision']?.options?.forEach(option => {\r\n        let isActionValid = this.checkValidity(option.value);\r\n        this.actionStateService.setActionValid(option.value, isActionValid);\r\n        this.section.body.details = this.fieldsForm.value\r\n      });\r\n    }\r\n\r\n    checkValidityAndUpdate();\r\n\r\n    this.fieldsForm.valueChanges.subscribe(() => {\r\n      checkValidityAndUpdate();\r\n    });\r\n\r\n  }\r\n\r\n  checkValidity(action: string): boolean {\r\n    switch (action) {\r\n      case 'APPROVE':\r\n        return true;\r\n      case 'REJECT':\r\n        return this.fieldsForm.valid;\r\n      case 'SENDBACK':\r\n        return this.fieldsForm.valid;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n\r\n  customCallSubmit(action: string) {\r\n    console.log('customCallSubmit', action)\r\n  }\r\n\r\n  resetForm() {\r\n    this.fieldsForm.reset()\r\n  }\r\n\r\n}\r\n","<div\r\n  [ngClass]=\"{'form-section-divide form-section':!section?.header?.readOnly,'info-section':section?.header?.readOnly}\">\r\n\r\n  <ds-alert class=\"full\" type=\"warning\" icon=\"info\">\r\n\r\n    <div class=\"d-flex gap-2\">\r\n\r\n      Request details working fine\r\n\r\n    </div>\r\n\r\n  </ds-alert>\r\n\r\n  <form [formGroup]=\"fieldsForm\">\r\n    <app-input formControlName=\"input1\"></app-input>\r\n  </form>\r\n\r\n</div>\r\n@if (!section?.header?.readOnly) {\r\n  <div class=\"mt-4\">\r\n    <lib-action-buttons\r\n      [lovOptions]=\"lov?.['decision']?.options\"\r\n      [lovType]=\"lov?.['decision']?.type\"\r\n      [section]=\"section\"\r\n      [form]=\"form\"\r\n      [sections]=\"form.sections\"\r\n      [showApprovalCycle]=\"true\"\r\n      [customCall]=\"false\"\r\n      [fieldsForm]=\"fieldsForm\"\r\n      (customCallEmit)=\"customCallSubmit($event)\"\r\n      (resetFormEmit)=\"resetForm()\"\r\n    />\r\n  </div>\r\n}\r\n"]}