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.
- package/esm2022/lib/components/app-component-sections/activities/activities.component.mjs +3 -3
- package/esm2022/lib/components/app-component-sections/feedback-section/feedback-section.component.mjs +2 -2
- package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +3 -3
- package/esm2022/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.mjs +2 -2
- package/esm2022/lib/components/shared-components/form-field/checkbox/checkbox.component.mjs +42 -31
- package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs +63 -14
- package/esm2022/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.mjs +70 -137
- package/esm2022/lib/components/shared-components/form-field/date-picker/date-picker.component.mjs +42 -78
- package/esm2022/lib/components/shared-components/form-field/input/input.component.mjs +5 -19
- package/esm2022/lib/components/shared-components/form-field/input-currency/input-currency.component.mjs +23 -115
- package/esm2022/lib/components/shared-components/form-field/input-email/input-email.component.mjs +20 -72
- package/esm2022/lib/components/shared-components/form-field/input-mask/input-mask.component.mjs +20 -74
- package/esm2022/lib/components/shared-components/form-field/input-number/input-number.component.mjs +20 -104
- package/esm2022/lib/components/shared-components/form-field/input-telephone/input-telephone.component.mjs +20 -39
- package/esm2022/lib/components/shared-components/form-field/textarea/textarea.component.mjs +27 -59
- package/esm2022/lib/components/shared-components/form-field/validation-errors/validation-errors.component.mjs +3 -6
- package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +2 -2
- package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +37 -23
- package/fesm2022/bpm-core.mjs +524 -908
- package/fesm2022/bpm-core.mjs.map +1 -1
- package/lib/components/app-component-sections/activities/activities.component.d.ts +2 -2
- package/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.d.ts +1 -1
- package/lib/components/app-component-sections/form-section/form-section.component.d.ts +1 -1
- package/lib/components/app-component-sections/service-header/service-header.component.d.ts +1 -1
- package/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.d.ts +1 -1
- package/lib/components/shared-components/form-field/checkbox/checkbox.component.d.ts +10 -7
- package/lib/components/shared-components/form-field/control-value-accessor.directive.d.ts +15 -5
- package/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.d.ts +15 -15
- package/lib/components/shared-components/form-field/date-picker/date-picker.component.d.ts +6 -13
- package/lib/components/shared-components/form-field/input/input.component.d.ts +2 -6
- package/lib/components/shared-components/form-field/input-currency/input-currency.component.d.ts +6 -23
- package/lib/components/shared-components/form-field/input-email/input-email.component.d.ts +4 -18
- package/lib/components/shared-components/form-field/input-mask/input-mask.component.d.ts +4 -18
- package/lib/components/shared-components/form-field/input-number/input-number.component.d.ts +5 -20
- package/lib/components/shared-components/form-field/input-telephone/input-telephone.component.d.ts +4 -15
- package/lib/components/shared-components/form-field/textarea/textarea.component.d.ts +5 -14
- package/lib/components/shared-components/form-field/validation-errors/validation-errors.component.d.ts +1 -2
- package/lib/testComponent/request-details-section/request-details-section.component.d.ts +5 -7
- package/package.json +3 -2
- package/esm2022/lib/testComponent/services/state-machine.service.mjs +0 -148
- 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
|
-
|
|
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:
|
|
109
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: InputTelephoneComponent, isStandalone: true, selector: "app-input-telephone", inputs: {
|
|
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
|
-
}],
|
|
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 {
|
|
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 {
|
|
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
|
|
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
|
-
|
|
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: "
|
|
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
|
-
|
|
78
|
-
], standalone: true,
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
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"
|
|
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 }
|
|
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,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvdmFsaWRhdGlvbi1lcnJvcnMvdmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvdmFsaWRhdGlvbi1lcnJvcnMvdmFsaWRhdGlvbi1lcnJvcnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBNEIsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3hELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7QUFhcEYsTUFBTSxPQUFPLHlCQUFnQyxTQUFRLDZCQUFtQztJQUM3RSxNQUFNLEdBQUcsRUFBRSxDQUFDO0lBQ1osbUJBQW1CLEdBQUcsRUFBRSxDQUFDO0lBQ2xDLGFBQWEsR0FBRztRQUNkLFFBQVEsRUFBRSx3QkFBd0I7UUFDbEMsU0FBUyxFQUFFLHVCQUF1QjtRQUNsQyxTQUFTLEVBQUUsdUJBQXVCO0tBQ25DLENBQUM7SUFFRixXQUFXLENBQUMsT0FBc0I7UUFDaEMsTUFBTSxFQUFFLG1CQUFtQixFQUFFLEdBQUcsT0FBTyxDQUFDO1FBQ3hDLElBQUksbUJBQW1CLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsYUFBYSxHQUFHO2dCQUNuQixHQUFHLElBQUksQ0FBQyxhQUFhO2dCQUNyQixHQUFHLG1CQUFtQixDQUFDLFlBQVk7YUFDcEMsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO3VHQWpCVSx5QkFBeUI7MkZBQXpCLHlCQUF5Qix1TUNoQnRDLDRTQU1HLHlERE1DLFlBQVksMEZBQ1osUUFBUTs7MkZBR0MseUJBQXlCO2tCQVhyQyxTQUFTOytCQUNFLHVCQUF1QixjQUdyQixJQUFJLFdBQ1A7d0JBQ1AsS0FBSzt3QkFDTCxZQUFZO3dCQUNaLFFBQVE7cUJBQ1Q7OEJBR1EsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLG1CQUFtQjtzQkFBM0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSwgTmdGb3IgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0RXJyb3IgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3JEaXJlY3RpdmUgfSBmcm9tICcuLi9jb250cm9sLXZhbHVlLWFjY2Vzc29yLmRpcmVjdGl2ZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC12YWxpZGF0aW9uLWVycm9ycycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3ZhbGlkYXRpb24tZXJyb3JzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi92YWxpZGF0aW9uLWVycm9ycy5jb21wb25lbnQuc2NzcyddLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW1xyXG4gICAgTmdGb3IsXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBNYXRFcnJvclxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFZhbGlkYXRpb25FcnJvcnNDb21wb25lbnQ8VHlwZT4gZXh0ZW5kcyBDb250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZTxUeXBlPiAge1xyXG4gIEBJbnB1dCgpIGVycm9ycyA9IHt9O1xyXG4gIEBJbnB1dCgpIGN1c3RvbUVycm9yTWVzc2FnZXMgPSB7fTtcclxuICBlcnJvck1lc3NhZ2VzID0ge1xyXG4gICAgcmVxdWlyZWQ6ICdUaGlzIGZpZWxkIGlzIHJlcXVpcmVkJyxcclxuICAgIG1heGxlbmd0aDogJ1RoaXMgZmllbGQgbWF4IGxlbmd0aCcsXHJcbiAgICBtaW5sZW5ndGg6ICdUaGlzIGZpZWxkIG1pbiBsZW5ndGgnLFxyXG4gIH07XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIGNvbnN0IHsgY3VzdG9tRXJyb3JNZXNzYWdlcyB9ID0gY2hhbmdlcztcclxuICAgIGlmIChjdXN0b21FcnJvck1lc3NhZ2VzKSB7XHJcbiAgICAgIHRoaXMuZXJyb3JNZXNzYWdlcyA9IHtcclxuICAgICAgICAuLi50aGlzLmVycm9yTWVzc2FnZXMsXHJcbiAgICAgICAgLi4uY3VzdG9tRXJyb3JNZXNzYWdlcy5jdXJyZW50VmFsdWUsXHJcbiAgICAgIH07XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIiAgQGlmKGNvbnRyb2wudG91Y2hlZCkge1xyXG4gICAgQGZvcihlcnJvciBvZiBlcnJvcnMgfCBrZXl2YWx1ZTsgdHJhY2sgZXJyb3IgKSB7XHJcbiAgICAgICAgICAgIDxtYXQtZXJyb3IgY2xhc3M9XCJtYi0yXCI+XHJcbiAgICAgICAgICAgICAgICB7eyBlcnJvck1lc3NhZ2VzW2Vycm9yLmtleV0gfX0ge3tlcnJvcnNbJ21heGxlbmd0aCddPy5yZXF1aXJlZExlbmd0aH19IHt7ZXJyb3JzWydtaW5sZW5ndGgnXT8ucmVxdWlyZWRMZW5ndGh9fVxyXG4gICAgICAgICAgICAgIDwvbWF0LWVycm9yPlxyXG4gICAgfVxyXG4gIH0iXX0=
|
package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs
CHANGED
|
@@ -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: ["
|
|
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,
|
|
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"]}
|