bpm-core 0.0.104 → 0.0.105
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/bpm-core.mjs +5 -0
- package/esm2022/lib/app/app.component.mjs +79 -0
- package/esm2022/lib/classes/form-validation.mjs +80 -0
- package/esm2022/lib/classes/index.mjs +2 -0
- package/esm2022/lib/components/app-component-sections/activities/activities.component.mjs +44 -0
- package/esm2022/lib/components/app-component-sections/approvals/approvals.component.mjs +23 -0
- package/esm2022/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.mjs +113 -0
- package/esm2022/lib/components/app-component-sections/faq-sidenav/faq-sidenav.component.mjs +25 -0
- package/esm2022/lib/components/app-component-sections/faqs/faqs.component.mjs +27 -0
- package/esm2022/lib/components/app-component-sections/faqs/index.mjs +2 -0
- package/esm2022/lib/components/app-component-sections/feedback-section/feedback-section.component.mjs +237 -0
- package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs +255 -0
- package/esm2022/lib/components/app-component-sections/index.mjs +9 -0
- package/esm2022/lib/components/app-component-sections/layout/header/header.component.mjs +79 -0
- package/esm2022/lib/components/app-component-sections/layout/layout.component.mjs +89 -0
- package/esm2022/lib/components/app-component-sections/layout/side-nav/side-nav.component.mjs +158 -0
- package/esm2022/lib/components/app-component-sections/main-request-details/main-request-details.component.mjs +34 -0
- package/esm2022/lib/components/app-component-sections/previous-requests/previous-requests.component.mjs +345 -0
- package/esm2022/lib/components/app-component-sections/profile-section/profile-section.component.mjs +45 -0
- package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +271 -0
- package/esm2022/lib/components/app-component-sections/status/status.component.mjs +38 -0
- package/esm2022/lib/components/app-component-sections/workflow-section/workflow-section.component.mjs +164 -0
- package/esm2022/lib/components/shared-components/action-buttons/action-buttons.component.mjs +138 -0
- package/esm2022/lib/components/shared-components/dialogs/confirm-dialog/confirm-dialog.component.mjs +30 -0
- package/esm2022/lib/components/shared-components/dialogs/delete-dialog/delete-dialog.component.mjs +29 -0
- package/esm2022/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.mjs +67 -0
- package/esm2022/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.mjs +138 -0
- package/esm2022/lib/components/shared-components/form-field/attachment-section/attachment-section.component.mjs +234 -0
- package/esm2022/lib/components/shared-components/form-field/base-component/base-component.component.mjs +198 -0
- package/esm2022/lib/components/shared-components/form-field/checkbox/checkbox.component.mjs +91 -0
- package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs +185 -0
- package/esm2022/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.mjs +131 -0
- package/esm2022/lib/components/shared-components/form-field/date-picker/date-format.mjs +31 -0
- package/esm2022/lib/components/shared-components/form-field/date-picker/date-picker.component.mjs +175 -0
- package/esm2022/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.mjs +186 -0
- package/esm2022/lib/components/shared-components/form-field/doc-uploader/docs-uploader.component.mjs +525 -0
- package/esm2022/lib/components/shared-components/form-field/form-label/form-label.component.mjs +33 -0
- package/esm2022/lib/components/shared-components/form-field/index.mjs +26 -0
- package/esm2022/lib/components/shared-components/form-field/info-item/info-item.component.mjs +76 -0
- package/esm2022/lib/components/shared-components/form-field/input/input.component.mjs +71 -0
- package/esm2022/lib/components/shared-components/form-field/input-autocomplete/index.mjs +3 -0
- package/esm2022/lib/components/shared-components/form-field/input-autocomplete/input-autocomplete.model.mjs +2 -0
- package/esm2022/lib/components/shared-components/form-field/input-currency/input-currency.component.mjs +73 -0
- package/esm2022/lib/components/shared-components/form-field/input-email/input-email.component.mjs +69 -0
- package/esm2022/lib/components/shared-components/form-field/input-mask/input-mask.component.mjs +61 -0
- package/esm2022/lib/components/shared-components/form-field/input-number/input-number.component.mjs +74 -0
- package/esm2022/lib/components/shared-components/form-field/input-telephone/input-telephone.component.mjs +85 -0
- package/esm2022/lib/components/shared-components/form-field/radio/radio.component.mjs +52 -0
- package/esm2022/lib/components/shared-components/form-field/repeated-list/repeated-list.component.mjs +32 -0
- package/esm2022/lib/components/shared-components/form-field/search-employee/search-employee.component.mjs +192 -0
- package/esm2022/lib/components/shared-components/form-field/select/select.component.mjs +191 -0
- package/esm2022/lib/components/shared-components/form-field/shared-imports.mjs +36 -0
- package/esm2022/lib/components/shared-components/form-field/table-list/table-list.component.mjs +116 -0
- package/esm2022/lib/components/shared-components/form-field/textarea/special-chars.directive.mjs +39 -0
- package/esm2022/lib/components/shared-components/form-field/textarea/textarea.component.mjs +57 -0
- package/esm2022/lib/components/shared-components/form-field/toggle-button/toggle-button.component.mjs +90 -0
- package/esm2022/lib/components/shared-components/form-field/validation-errors/validation-errors.component.mjs +43 -0
- package/esm2022/lib/components/shared-components/index.mjs +9 -0
- package/esm2022/lib/components/shared-components/table/table.component.mjs +243 -0
- package/esm2022/lib/components/shared-components/terms-conditions/terms-conditions.component.mjs +31 -0
- package/esm2022/lib/components/shared-components/title-section/title-section.component.mjs +31 -0
- package/esm2022/lib/constants/constants.mjs +149 -0
- package/esm2022/lib/constants/index.mjs +2 -0
- package/esm2022/lib/directives/ar.directive.mjs +54 -0
- package/esm2022/lib/directives/currency.directive.mjs +92 -0
- package/esm2022/lib/directives/en.directive.mjs +51 -0
- package/esm2022/lib/directives/number.directive.mjs +68 -0
- package/esm2022/lib/directives/skip-location.directive.mjs +28 -0
- package/esm2022/lib/enums/actions.enum.mjs +22 -0
- package/esm2022/lib/enums/colors.enum.mjs +6 -0
- package/esm2022/lib/enums/events.enum.mjs +6 -0
- package/esm2022/lib/functions/data-to-blob.mjs +12 -0
- package/esm2022/lib/functions/encode-password.mjs +14 -0
- package/esm2022/lib/functions/handel-error-response.mjs +12 -0
- package/esm2022/lib/functions/index.mjs +5 -0
- package/esm2022/lib/functions/is-valid-data.mjs +42 -0
- package/esm2022/lib/helpers/shared.helper.mjs +26 -0
- package/esm2022/lib/hooks/index.mjs +3 -0
- package/esm2022/lib/hooks/load-form.mjs +13 -0
- package/esm2022/lib/hooks/save-form.mjs +18 -0
- package/esm2022/lib/i18n/ar.mjs +200 -0
- package/esm2022/lib/i18n/en.mjs +204 -0
- package/esm2022/lib/i18n/index.mjs +3 -0
- package/esm2022/lib/interfaces/action.interface.mjs +2 -0
- package/esm2022/lib/interfaces/api-response.interface.mjs +2 -0
- package/esm2022/lib/interfaces/document-file.interface.mjs +2 -0
- package/esm2022/lib/interfaces/form-items.interface.mjs +2 -0
- package/esm2022/lib/interfaces/form.interface.mjs +150 -0
- package/esm2022/lib/interfaces/igate-user.interface.mjs +2 -0
- package/esm2022/lib/interfaces/index.mjs +8 -0
- package/esm2022/lib/interfaces/lov-list.interface.mjs +2 -0
- package/esm2022/lib/interfaces/lov.interface.mjs +2 -0
- package/esm2022/lib/interfaces/shared.interface.mjs +2 -0
- package/esm2022/lib/pipes/currency.pipe.mjs +66 -0
- package/esm2022/lib/pipes/format-as-password.pipe.mjs +19 -0
- package/esm2022/lib/pipes/index.mjs +3 -0
- package/esm2022/lib/pipes/status-style.pipe.mjs +57 -0
- package/esm2022/lib/pipes/translate.pipe.mjs +36 -0
- package/esm2022/lib/regex/index.mjs +2 -0
- package/esm2022/lib/regex/regex-patterns.mjs +4 -0
- package/esm2022/lib/services/action.service.ts.mjs +25 -0
- package/esm2022/lib/services/core.service.ts.mjs +527 -0
- package/esm2022/lib/services/feedBack.service.mjs +81 -0
- package/esm2022/lib/services/i18n.service.mjs +36 -0
- package/esm2022/lib/services/index.mjs +6 -0
- package/esm2022/lib/services/sidenav.service.mjs +36 -0
- package/esm2022/lib/testComponent/config/segment-dynamic-loader.config.mjs +8 -0
- package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +90 -0
- package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +482 -0
- package/esm2022/lib/testComponent/services/i18n.service.mjs +39 -0
- package/esm2022/lib/testComponent/services/segment-dynamic-loader.service.mjs +54 -0
- package/esm2022/lib/validators/id.validator.mjs +66 -0
- package/esm2022/lib/validators/index.mjs +8 -0
- package/esm2022/lib/validators/string-to-boolean.pipe.mjs +16 -0
- package/esm2022/lib/validators/text.directive.mjs +50 -0
- package/esm2022/lib/validators/timer.pipe.mjs +19 -0
- package/esm2022/public-api.mjs +19 -0
- package/fesm2022/bpm-core.mjs +244 -226
- package/fesm2022/bpm-core.mjs.map +1 -1
- package/lib/components/shared-components/form-field/checkbox/checkbox.component.d.ts +1 -2
- package/lib/components/shared-components/form-field/control-value-accessor.directive.d.ts +1 -1
- package/lib/components/shared-components/form-field/shared-imports.d.ts +2 -2
- package/lib/components/shared-components/form-field/textarea/special-chars.directive.d.ts +1 -1
- package/lib/components/shared-components/title-section/title-section.component.d.ts +1 -1
- package/lib/directives/currency.directive.d.ts +1 -0
- package/lib/pipes/currency.pipe.d.ts +1 -1
- package/lib/pipes/format-as-password.pipe.d.ts +1 -1
- package/lib/validators/string-to-boolean.pipe.d.ts +1 -1
- package/lib/validators/text.directive.d.ts +1 -1
- package/lib/validators/timer.pipe.d.ts +1 -1
- package/package.json +4 -2
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
import { MAT_DATE_FORMATS } from '@angular/material/core';
|
|
2
|
+
import { FormControl } from '@angular/forms';
|
|
3
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
|
+
import { Component, Input, Output, EventEmitter, forwardRef, Inject, } from '@angular/core';
|
|
5
|
+
import { ControlContainer, NgForm, NG_VALUE_ACCESSOR, } from '@angular/forms';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../../../services";
|
|
8
|
+
import * as i2 from "@angular/common/http";
|
|
9
|
+
import * as i3 from "@angular/forms";
|
|
10
|
+
import * as i4 from "@angular/material/core";
|
|
11
|
+
import * as i5 from "@angular/material/dialog";
|
|
12
|
+
import * as i6 from "../../../../pipes";
|
|
13
|
+
import * as i7 from "@angular/platform-browser";
|
|
14
|
+
import * as i8 from "../date-picker/date-format";
|
|
15
|
+
const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
|
|
16
|
+
provide: NG_VALUE_ACCESSOR,
|
|
17
|
+
useExisting: forwardRef(() => BaseComponent),
|
|
18
|
+
multi: true,
|
|
19
|
+
};
|
|
20
|
+
export class BaseComponent {
|
|
21
|
+
i18n;
|
|
22
|
+
http;
|
|
23
|
+
fb;
|
|
24
|
+
dateAdapter;
|
|
25
|
+
cdRef;
|
|
26
|
+
dialog;
|
|
27
|
+
dialogRef;
|
|
28
|
+
dialogData;
|
|
29
|
+
mycurrencyPipe;
|
|
30
|
+
dateFormat;
|
|
31
|
+
sanitizer;
|
|
32
|
+
hideOption = false;
|
|
33
|
+
// hideOption: InputSignal<boolean> = input(false);
|
|
34
|
+
type = 'text';
|
|
35
|
+
// hideOption: InputSignal<string> = input('text');
|
|
36
|
+
loading;
|
|
37
|
+
// loading: InputSignal<boolean>;
|
|
38
|
+
field;
|
|
39
|
+
// loafieldding: InputSignal<any>;
|
|
40
|
+
labelTextReadMode;
|
|
41
|
+
// labelTextReadMode: InputSignal<string>
|
|
42
|
+
labelTextWriteMode;
|
|
43
|
+
// labelTextWriteMode: InputSignal<string>
|
|
44
|
+
isReadOnly;
|
|
45
|
+
// isReadOnly: InputSignal<boolean>;
|
|
46
|
+
name;
|
|
47
|
+
// name: InputSignal<string>
|
|
48
|
+
required = true;
|
|
49
|
+
// required: InputSignal<boolean> = input(true);
|
|
50
|
+
mask;
|
|
51
|
+
// mask: InputSignal<string>
|
|
52
|
+
allowedExtensions = '';
|
|
53
|
+
// allowedExtensions: InputSignal<string> = input('');
|
|
54
|
+
link;
|
|
55
|
+
// link: InputSignal<boolean>;
|
|
56
|
+
multiple;
|
|
57
|
+
// multiple: InputSignal<boolean>;
|
|
58
|
+
insideTable;
|
|
59
|
+
// insideTable: InputSignal<boolean>;
|
|
60
|
+
showIfEmpty = false;
|
|
61
|
+
// showIfEmpty: InputSignal<boolean> = input(false);
|
|
62
|
+
showErrorMessage;
|
|
63
|
+
// showErrorMessage: InputSignal<boolean>;
|
|
64
|
+
showHint = false;
|
|
65
|
+
// showHint: InputSignal<boolean> = input(false);
|
|
66
|
+
hint = '';
|
|
67
|
+
// hint: InputSignal<string> = input('');
|
|
68
|
+
errorMessage;
|
|
69
|
+
// errorMessage: InputSignal<string>
|
|
70
|
+
placeholder;
|
|
71
|
+
// placeholder: InputSignal<string>
|
|
72
|
+
maxLength;
|
|
73
|
+
// maxLength: InputSignal<number>
|
|
74
|
+
minLength;
|
|
75
|
+
// minLength: InputSignal<number>
|
|
76
|
+
maxValue;
|
|
77
|
+
// maxValue: InputSignal<string>
|
|
78
|
+
minValue;
|
|
79
|
+
// minValue: InputSignal<string>
|
|
80
|
+
disabled = false;
|
|
81
|
+
// disabled: InputSignal<boolean> = input(false);
|
|
82
|
+
lov;
|
|
83
|
+
// lov: InputSignal<any>
|
|
84
|
+
hasLabel = true;
|
|
85
|
+
// hasLabel: InputSignal<boolean> = input(true);
|
|
86
|
+
section;
|
|
87
|
+
// section: InputSignal<Section>
|
|
88
|
+
controller = new FormControl();
|
|
89
|
+
value;
|
|
90
|
+
emitedValue = new EventEmitter();
|
|
91
|
+
filesize;
|
|
92
|
+
// public options: any;
|
|
93
|
+
randomID = Math.floor(Math.random() * (999999 - 100000)) + 100000;
|
|
94
|
+
constructor(i18n, http, fb, dateAdapter, cdRef, dialog, dialogRef, dialogData, mycurrencyPipe, dateFormat, sanitizer) {
|
|
95
|
+
this.i18n = i18n;
|
|
96
|
+
this.http = http;
|
|
97
|
+
this.fb = fb;
|
|
98
|
+
this.dateAdapter = dateAdapter;
|
|
99
|
+
this.cdRef = cdRef;
|
|
100
|
+
this.dialog = dialog;
|
|
101
|
+
this.dialogRef = dialogRef;
|
|
102
|
+
this.dialogData = dialogData;
|
|
103
|
+
this.mycurrencyPipe = mycurrencyPipe;
|
|
104
|
+
this.dateFormat = dateFormat;
|
|
105
|
+
this.sanitizer = sanitizer;
|
|
106
|
+
this.dateAdapter.setLocale(this.i18n.language);
|
|
107
|
+
this.value = this.field;
|
|
108
|
+
this.emitedValue = new EventEmitter();
|
|
109
|
+
if (this.shouldSetDateFormateInAr) {
|
|
110
|
+
dateFormat.display = { dateInput: 'YYYY/MM/DD' };
|
|
111
|
+
dateFormat.parse = { dateInput: 'YYYY/MM/DD' };
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
get shouldSetDateFormateInAr() {
|
|
115
|
+
return this.i18n.language == 'ar';
|
|
116
|
+
}
|
|
117
|
+
resetData() {
|
|
118
|
+
if (!this.isReadOnly) {
|
|
119
|
+
this.field = '';
|
|
120
|
+
this.controller.setValue(this.field);
|
|
121
|
+
this.controller.markAsUntouched();
|
|
122
|
+
this.emitedValue.emit(this.field);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: BaseComponent, deps: [{ token: i1.CoreI18nService }, { token: i2.HttpClient }, { token: i3.FormBuilder }, { token: i4.DateAdapter }, { token: i0.ChangeDetectorRef }, { token: i5.MatDialog }, { token: i5.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i6.MycurrencyPipe }, { token: MAT_DATE_FORMATS }, { token: i7.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
126
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: BaseComponent, isStandalone: true, selector: "app-base-component", inputs: { hideOption: "hideOption", type: "type", loading: "loading", field: "field", labelTextReadMode: "labelTextReadMode", labelTextWriteMode: "labelTextWriteMode", isReadOnly: "isReadOnly", name: "name", required: "required", mask: "mask", allowedExtensions: "allowedExtensions", link: "link", multiple: "multiple", insideTable: "insideTable", showIfEmpty: "showIfEmpty", showErrorMessage: "showErrorMessage", showHint: "showHint", hint: "hint", errorMessage: "errorMessage", placeholder: "placeholder", maxLength: "maxLength", minLength: "minLength", maxValue: "maxValue", minValue: "minValue", disabled: "disabled", lov: "lov", hasLabel: "hasLabel", section: "section", controller: "controller" }, outputs: { emitedValue: "emitedValue" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], ngImport: i0, template: '', isInline: true, styles: [""], viewProviders: [{ provide: ControlContainer, useExisting: NgForm }] });
|
|
127
|
+
}
|
|
128
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: BaseComponent, decorators: [{
|
|
129
|
+
type: Component,
|
|
130
|
+
args: [{ selector: 'app-base-component', template: '', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewProviders: [{ provide: ControlContainer, useExisting: NgForm }], standalone: true }]
|
|
131
|
+
}], ctorParameters: () => [{ type: i1.CoreI18nService }, { type: i2.HttpClient }, { type: i3.FormBuilder }, { type: i4.DateAdapter }, { type: i0.ChangeDetectorRef }, { type: i5.MatDialog }, { type: i5.MatDialogRef }, { type: undefined, decorators: [{
|
|
132
|
+
type: Inject,
|
|
133
|
+
args: [MAT_DIALOG_DATA]
|
|
134
|
+
}] }, { type: i6.MycurrencyPipe }, { type: i8.CustomDateFormat, decorators: [{
|
|
135
|
+
type: Inject,
|
|
136
|
+
args: [MAT_DATE_FORMATS]
|
|
137
|
+
}] }, { type: i7.DomSanitizer }], propDecorators: { hideOption: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], type: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}], loading: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], field: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], labelTextReadMode: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], labelTextWriteMode: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}], isReadOnly: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], name: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], required: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], mask: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], allowedExtensions: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], link: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], multiple: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], insideTable: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], showIfEmpty: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], showErrorMessage: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], showHint: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], hint: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], errorMessage: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], placeholder: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], maxLength: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], minLength: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], maxValue: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], minValue: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}], disabled: [{
|
|
186
|
+
type: Input
|
|
187
|
+
}], lov: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}], hasLabel: [{
|
|
190
|
+
type: Input
|
|
191
|
+
}], section: [{
|
|
192
|
+
type: Input
|
|
193
|
+
}], controller: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], emitedValue: [{
|
|
196
|
+
type: Output
|
|
197
|
+
}] } });
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-component.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/base-component/base-component.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  forwardRef,\r\n  ChangeDetectorRef,\r\n  Inject,\r\n} from '@angular/core';\r\nimport {\r\n  ControlContainer,\r\n  NgForm,\r\n  NG_VALUE_ACCESSOR,\r\n  FormBuilder,\r\n} from '@angular/forms';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Section } from '../../../../interfaces';\r\nimport {\r\n  CoreI18nService\r\n} from '../../../../services';\r\nimport { MycurrencyPipe } from '../../../../pipes';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { CustomDateFormat } from '../date-picker/date-format';\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => BaseComponent),\r\n  multi: true,\r\n};\r\n@Component({\r\n  selector: 'app-base-component',\r\n  template: '',\r\n  styleUrls: ['./base-component.component.scss'],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR],\r\n  viewProviders: [{provide: ControlContainer, useExisting: NgForm}],\r\n  standalone: true\r\n})\r\nexport class BaseComponent {\r\n  @Input() hideOption = false;\r\n  // hideOption: InputSignal<boolean> = input(false);\r\n  @Input() type = 'text';\r\n  // hideOption: InputSignal<string> = input('text');\r\n  @Input() loading!: boolean;\r\n  // loading: InputSignal<boolean>;\r\n  @Input() field: any;\r\n   // loafieldding: InputSignal<any>;\r\n  @Input() labelTextReadMode: string;\r\n  // labelTextReadMode: InputSignal<string>\r\n  @Input() labelTextWriteMode: string;\r\n  // labelTextWriteMode: InputSignal<string>\r\n  @Input() isReadOnly: boolean;\r\n  // isReadOnly: InputSignal<boolean>;\r\n  @Input() name: string;\r\n  // name: InputSignal<string>\r\n  @Input() required = true;\r\n  // required: InputSignal<boolean> = input(true);\r\n  @Input() mask: string;\r\n  // mask: InputSignal<string>\r\n  @Input() allowedExtensions = '';\r\n  // allowedExtensions: InputSignal<string> = input('');\r\n  @Input() link: boolean;\r\n  // link: InputSignal<boolean>;\r\n  @Input() multiple: boolean;\r\n  // multiple: InputSignal<boolean>;\r\n  @Input() insideTable: boolean;\r\n  // insideTable: InputSignal<boolean>;\r\n  @Input() showIfEmpty = false;\r\n  // showIfEmpty: InputSignal<boolean> = input(false);\r\n  @Input() showErrorMessage: boolean;\r\n  // showErrorMessage: InputSignal<boolean>;\r\n  @Input() showHint = false;\r\n  // showHint: InputSignal<boolean> = input(false);\r\n  @Input() hint = '';\r\n  // hint: InputSignal<string> = input('');\r\n  @Input() errorMessage: string;\r\n  // errorMessage: InputSignal<string>\r\n  @Input() placeholder: string\r\n  // placeholder: InputSignal<string>\r\n  @Input() maxLength: number;\r\n  // maxLength: InputSignal<number>\r\n  @Input() minLength: number;\r\n  // minLength: InputSignal<number>\r\n  @Input() maxValue: string;\r\n  // maxValue: InputSignal<string>\r\n  @Input() minValue: string;\r\n  // minValue: InputSignal<string>\r\n  @Input() disabled = false;\r\n  // disabled: InputSignal<boolean> = input(false);\r\n  @Input() lov: any;\r\n  // lov: InputSignal<any>\r\n  @Input() hasLabel = true;\r\n  // hasLabel: InputSignal<boolean> = input(true);\r\n  @Input() section: Section;\r\n  // section: InputSignal<Section>\r\n  @Input() controller: FormControl = new FormControl();\r\n  value: any;\r\n  @Output() emitedValue = new EventEmitter();\r\n\r\n  filesize: string;\r\n  // public options: any;\r\n  public randomID: number =\r\n  Math.floor(Math.random() * (999999 - 100000)) + 100000;\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    public http: HttpClient,\r\n    public fb: FormBuilder,\r\n    private dateAdapter: DateAdapter<Date>,\r\n    public cdRef: ChangeDetectorRef,\r\n    public dialog: MatDialog,\r\n    public dialogRef: MatDialogRef<any>,\r\n    @Inject(MAT_DIALOG_DATA) public dialogData: any,\r\n    public mycurrencyPipe: MycurrencyPipe,\r\n    @Inject(MAT_DATE_FORMATS) public dateFormat: CustomDateFormat,\r\n    public sanitizer: DomSanitizer\r\n  ) {\r\n    this.dateAdapter.setLocale(this.i18n.language);\r\n    this.value = this.field;\r\n    this.emitedValue = new EventEmitter();\r\n    if (this.shouldSetDateFormateInAr) {\r\n      dateFormat.display = {dateInput: 'YYYY/MM/DD'};\r\n      dateFormat.parse = {dateInput: 'YYYY/MM/DD'};\r\n    }\r\n  }\r\n\r\n  get shouldSetDateFormateInAr(): boolean {\r\n    return this.i18n.language == 'ar';\r\n  }\r\n\r\n  resetData() {\r\n    if (!this.isReadOnly) {\r\n      this.field = '';\r\n      this.controller.setValue(this.field)\r\n      this.controller.markAsUntouched()\r\n      this.emitedValue.emit(this.field);\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, EventEmitter, forwardRef, inject, Input, Output } from '@angular/core';
|
|
2
|
+
import { MatCheckbox } from "@angular/material/checkbox";
|
|
3
|
+
import { FormsModule, NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
|
+
import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
|
|
5
|
+
import { TermsConditionsComponent } from '../../terms-conditions/terms-conditions.component';
|
|
6
|
+
import { MatDialog } from '@angular/material/dialog';
|
|
7
|
+
import { Shareds } from '../shared-imports';
|
|
8
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@angular/forms";
|
|
11
|
+
import * as i2 from "../form-label/form-label.component";
|
|
12
|
+
import * as i3 from "../validation-errors/validation-errors.component";
|
|
13
|
+
import * as i4 from "@angular/common";
|
|
14
|
+
import * as i5 from "../../../../pipes/translate.pipe";
|
|
15
|
+
export class CheckBoxComponent extends ControlValueAccessorDirective {
|
|
16
|
+
containTerms;
|
|
17
|
+
termsLabel;
|
|
18
|
+
linkText;
|
|
19
|
+
hrefLink;
|
|
20
|
+
link;
|
|
21
|
+
termsBody;
|
|
22
|
+
downloadCheckBox = new EventEmitter();
|
|
23
|
+
destroyRef = inject(DestroyRef);
|
|
24
|
+
dialog = inject(MatDialog);
|
|
25
|
+
ngOnInit() {
|
|
26
|
+
super.ngOnInit();
|
|
27
|
+
if (this.control.value == 'true') {
|
|
28
|
+
this.control.setValue(true);
|
|
29
|
+
}
|
|
30
|
+
this.actionStateService.resetAction$
|
|
31
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
32
|
+
.subscribe(res => {
|
|
33
|
+
if (!this.isReadOnly && this.control.enabled) {
|
|
34
|
+
this.control.reset();
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
openUrl() {
|
|
39
|
+
window.open(this.hrefLink);
|
|
40
|
+
}
|
|
41
|
+
valueChange(event) {
|
|
42
|
+
const checked = event.checked;
|
|
43
|
+
this.control.setValue(checked);
|
|
44
|
+
}
|
|
45
|
+
openTermsPopup() {
|
|
46
|
+
const dialogRef = this.dialog.open(TermsConditionsComponent, {
|
|
47
|
+
data: this.termsBody,
|
|
48
|
+
width: '700px',
|
|
49
|
+
panelClass: ['main-popup'],
|
|
50
|
+
});
|
|
51
|
+
dialogRef.afterClosed().subscribe(() => {
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CheckBoxComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
55
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: CheckBoxComponent, isStandalone: true, selector: "app-checkbox", inputs: { containTerms: "containTerms", termsLabel: "termsLabel", linkText: "linkText", hrefLink: "hrefLink", link: "link", termsBody: "termsBody" }, outputs: { downloadCheckBox: "downloadCheckBox" }, providers: [
|
|
56
|
+
{
|
|
57
|
+
provide: NG_VALUE_ACCESSOR,
|
|
58
|
+
useExisting: forwardRef(() => CheckBoxComponent),
|
|
59
|
+
multi: true,
|
|
60
|
+
},
|
|
61
|
+
], usesInheritance: true, ngImport: i0, template: "<mat-checkbox\r\n [ngClass]=\"{'mx-3': isReadOnly}\"\r\n class=\"my-3\"\r\n [style.pointerEvents]=\"isReadOnly ? 'none' : 'auto'\"\r\n id=\"{{ name }}{{ randomID }}\"\r\n [name]=\"name\"\r\n (change)=\"valueChange($event)\"\r\n [checked]=\"control.value ? control.value : false\"\r\n [formControl]=\"control\">\r\n\r\n <div class=\"d-flex pt-1\">\r\n @if(label){\r\n <app-form-label class=\"mb-0\" [label]=\"label\" [optional]=\"required || mandatory ? false : true\" [tooltip]=\"tooltip\"></app-form-label>\r\n }\r\n @if(containTerms) {\r\n <span\r\n class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\"\r\n (click)=\"openTermsPopup(); false\">\r\n {{ termsLabel ? termsLabel : 'termsAndConditions' | translate }}\r\n </span>\r\n }\r\n </div>\r\n\r\n @if(link) {\r\n <ng-container>\r\n <span> | </span>\r\n <a\r\n class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1 d-inline-flex align-items-center gap-1\"\r\n href=\"{{ hrefLink }}\"\r\n target=\"_blank\">\r\n <ds-icon icon=\"external-link\"></ds-icon>\r\n <span class=\"underline\">{{ linkText }}</span>\r\n </a>\r\n </ng-container>\r\n }\r\n</mat-checkbox>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n", styles: [".checkbox{margin-top:10px!important;position:relative;margin-bottom:0!important}.checkbox label{padding-left:30px;font-size:14px;color:#414142}.checkbox input[type=checkbox]{opacity:0}.checkbox input[type=checkbox]+label.checkboxInput{position:absolute;width:25px;height:25px;top:0;left:0;padding-left:0}@media (max-width: 768px){.checkbox input[type=checkbox]+label.checkboxInput{top:8px!important}}.checkbox input[type=checkbox]+label.checkboxInput:before{content:\"\\f096\";font-family:FontAwesome;font-size:25px;display:block;margin-top:-7px;color:#ddd}.checkbox input[type=checkbox]:checked+label.checkboxInput:before{content:\"\\f14a\";color:#da3f7b;background-color:#fff}.mat-mdc-checkbox.mat-accent .mdc-form-field>label{margin:0}.rtlCheckbox.checkbox input[type=checkbox]+label.checkboxInput{left:inherit;right:0;padding-left:0;padding-right:0}.rtlCheckbox.checkbox label{padding-left:0;padding-right:30px}.mat-mdc-checkbox label{cursor:pointer}\n"], dependencies: [{ kind: "component", type: MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "component", type: i2.FormLabelComponent, selector: "app-form-label", inputs: ["tooltip", "label", "optional"] }, { kind: "component", type: i3.ValidationErrorsComponent, selector: "app-validation-errors", inputs: ["errors", "customErrorMessages"] }, { kind: "ngmodule", type: i1.ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] });
|
|
62
|
+
}
|
|
63
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CheckBoxComponent, decorators: [{
|
|
64
|
+
type: Component,
|
|
65
|
+
args: [{ selector: 'app-checkbox', schemas: [CUSTOM_ELEMENTS_SCHEMA], imports: [
|
|
66
|
+
MatCheckbox,
|
|
67
|
+
FormsModule,
|
|
68
|
+
...Shareds
|
|
69
|
+
], standalone: true, providers: [
|
|
70
|
+
{
|
|
71
|
+
provide: NG_VALUE_ACCESSOR,
|
|
72
|
+
useExisting: forwardRef(() => CheckBoxComponent),
|
|
73
|
+
multi: true,
|
|
74
|
+
},
|
|
75
|
+
], template: "<mat-checkbox\r\n [ngClass]=\"{'mx-3': isReadOnly}\"\r\n class=\"my-3\"\r\n [style.pointerEvents]=\"isReadOnly ? 'none' : 'auto'\"\r\n id=\"{{ name }}{{ randomID }}\"\r\n [name]=\"name\"\r\n (change)=\"valueChange($event)\"\r\n [checked]=\"control.value ? control.value : false\"\r\n [formControl]=\"control\">\r\n\r\n <div class=\"d-flex pt-1\">\r\n @if(label){\r\n <app-form-label class=\"mb-0\" [label]=\"label\" [optional]=\"required || mandatory ? false : true\" [tooltip]=\"tooltip\"></app-form-label>\r\n }\r\n @if(containTerms) {\r\n <span\r\n class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\"\r\n (click)=\"openTermsPopup(); false\">\r\n {{ termsLabel ? termsLabel : 'termsAndConditions' | translate }}\r\n </span>\r\n }\r\n </div>\r\n\r\n @if(link) {\r\n <ng-container>\r\n <span> | </span>\r\n <a\r\n class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1 d-inline-flex align-items-center gap-1\"\r\n href=\"{{ hrefLink }}\"\r\n target=\"_blank\">\r\n <ds-icon icon=\"external-link\"></ds-icon>\r\n <span class=\"underline\">{{ linkText }}</span>\r\n </a>\r\n </ng-container>\r\n }\r\n</mat-checkbox>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n", styles: [".checkbox{margin-top:10px!important;position:relative;margin-bottom:0!important}.checkbox label{padding-left:30px;font-size:14px;color:#414142}.checkbox input[type=checkbox]{opacity:0}.checkbox input[type=checkbox]+label.checkboxInput{position:absolute;width:25px;height:25px;top:0;left:0;padding-left:0}@media (max-width: 768px){.checkbox input[type=checkbox]+label.checkboxInput{top:8px!important}}.checkbox input[type=checkbox]+label.checkboxInput:before{content:\"\\f096\";font-family:FontAwesome;font-size:25px;display:block;margin-top:-7px;color:#ddd}.checkbox input[type=checkbox]:checked+label.checkboxInput:before{content:\"\\f14a\";color:#da3f7b;background-color:#fff}.mat-mdc-checkbox.mat-accent .mdc-form-field>label{margin:0}.rtlCheckbox.checkbox input[type=checkbox]+label.checkboxInput{left:inherit;right:0;padding-left:0;padding-right:0}.rtlCheckbox.checkbox label{padding-left:0;padding-right:30px}.mat-mdc-checkbox label{cursor:pointer}\n"] }]
|
|
76
|
+
}], propDecorators: { containTerms: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], termsLabel: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], linkText: [{
|
|
81
|
+
type: Input
|
|
82
|
+
}], hrefLink: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], link: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], termsBody: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], downloadCheckBox: [{
|
|
89
|
+
type: Output
|
|
90
|
+
}] } });
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/checkbox/checkbox.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, EventEmitter, forwardRef, inject, Input, OnInit, Output } from '@angular/core';\r\nimport {MatCheckbox} from \"@angular/material/checkbox\";\r\nimport {FormsModule, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\nimport { TermsConditionsComponent } from '../../terms-conditions/terms-conditions.component';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { Shareds } from '../shared-imports';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'app-checkbox',\r\n  templateUrl: './checkbox.component.html',\r\n  styleUrls: ['./checkbox.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    MatCheckbox,\r\n    FormsModule,\r\n    ...Shareds\r\n  ],\r\n  standalone: true,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => CheckBoxComponent),\r\n      multi: true,\r\n    },\r\n  ]\r\n\r\n})\r\nexport class CheckBoxComponent<Type> extends ControlValueAccessorDirective<Type> implements OnInit {\r\n  @Input() containTerms: boolean;\r\n  @Input() termsLabel: string;\r\n  @Input() linkText: string;\r\n  @Input() hrefLink: string;\r\n  @Input() link: string;\r\n  @Input() termsBody: any;\r\n  @Output() downloadCheckBox = new EventEmitter();\r\n  destroyRef = inject(DestroyRef);\r\n  dialog = inject(MatDialog);\r\n  override ngOnInit(): void {\r\n    super.ngOnInit()\r\n    if (this.control.value == 'true'){\r\n      this.control.setValue(true)\r\n    }\r\n\r\n\r\n    this.actionStateService.resetAction$\r\n    .pipe(takeUntilDestroyed(this.destroyRef))\r\n    .subscribe(res => {\r\n      if (!this.isReadOnly && this.control.enabled) {\r\n        this.control.reset();\r\n      }\r\n    });\r\n    \r\n  }\r\n\r\n  openUrl(){\r\n    window.open(this.hrefLink)\r\n  }\r\n\r\n  valueChange(event: any) {\r\n    const checked = event.checked;\r\n    this.control.setValue(checked)\r\n  }\r\n\r\n  openTermsPopup(): void {\r\n    const dialogRef = this.dialog.open(TermsConditionsComponent, {\r\n      data: this.termsBody,\r\n      width: '700px',\r\n      panelClass: ['main-popup'],\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe(() => {\r\n    });\r\n  }\r\n}\r\n","<mat-checkbox\r\n  [ngClass]=\"{'mx-3': isReadOnly}\"\r\n  class=\"my-3\"\r\n  [style.pointerEvents]=\"isReadOnly ? 'none' : 'auto'\"\r\n  id=\"{{ name }}{{ randomID }}\"\r\n  [name]=\"name\"\r\n  (change)=\"valueChange($event)\"\r\n  [checked]=\"control.value ? control.value : false\"\r\n  [formControl]=\"control\">\r\n\r\n  <div class=\"d-flex pt-1\">\r\n    @if(label){\r\n      <app-form-label class=\"mb-0\" [label]=\"label\" [optional]=\"required || mandatory ? false : true\" [tooltip]=\"tooltip\"></app-form-label>\r\n    }\r\n    @if(containTerms) {\r\n      <span\r\n        class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1\"\r\n        (click)=\"openTermsPopup(); false\">\r\n        {{ termsLabel ? termsLabel : 'termsAndConditions' | translate }}\r\n      </span>\r\n    }\r\n  </div>\r\n\r\n  @if(link) {\r\n    <ng-container>\r\n      <span> | </span>\r\n      <a\r\n        class=\"fs-12 fw-bold fc-coral cursor-pointer mx-1 d-inline-flex align-items-center gap-1\"\r\n        href=\"{{ hrefLink }}\"\r\n        target=\"_blank\">\r\n        <ds-icon icon=\"external-link\"></ds-icon>\r\n        <span class=\"underline\">{{ linkText }}</span>\r\n      </a>\r\n    </ng-container>\r\n  }\r\n</mat-checkbox>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n"]}
|
package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs
ADDED
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { FormControl, FormControlName, FormGroupDirective, NgControl, Validators, } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../../services";
|
|
5
|
+
import * as i2 from "ngx-toastr";
|
|
6
|
+
import * as i3 from "@angular/platform-browser";
|
|
7
|
+
import * as i4 from "@angular/forms";
|
|
8
|
+
export class ControlValueAccessorDirective {
|
|
9
|
+
injector;
|
|
10
|
+
i18n;
|
|
11
|
+
toasterService;
|
|
12
|
+
coreService;
|
|
13
|
+
sanitizer;
|
|
14
|
+
fb;
|
|
15
|
+
actionStateService;
|
|
16
|
+
tooltip;
|
|
17
|
+
isReadOnly;
|
|
18
|
+
hint = '';
|
|
19
|
+
loading;
|
|
20
|
+
placeholder;
|
|
21
|
+
type;
|
|
22
|
+
showErrorMessage;
|
|
23
|
+
showHint;
|
|
24
|
+
showIfEmpty;
|
|
25
|
+
insideTable;
|
|
26
|
+
mask;
|
|
27
|
+
label;
|
|
28
|
+
matSuffix;
|
|
29
|
+
hasTooltip = false;
|
|
30
|
+
name;
|
|
31
|
+
randomID;
|
|
32
|
+
multiple = false;
|
|
33
|
+
searchControl = new FormControl();
|
|
34
|
+
toggleButtonControl = new FormControl();
|
|
35
|
+
employeeSearchControl = new FormControl();
|
|
36
|
+
telephoneControl = new FormControl();
|
|
37
|
+
attachments = [];
|
|
38
|
+
startDateControl = new FormControl();
|
|
39
|
+
endDateControl = new FormControl();
|
|
40
|
+
Validators = Validators;
|
|
41
|
+
minDateValue;
|
|
42
|
+
maxDateValue;
|
|
43
|
+
maxDate;
|
|
44
|
+
// @ViewChild('default')
|
|
45
|
+
datepickerObj;
|
|
46
|
+
minDate;
|
|
47
|
+
customMaxDate;
|
|
48
|
+
customMinDate;
|
|
49
|
+
value;
|
|
50
|
+
control;
|
|
51
|
+
required; //hide optional label and add required validator from angular side
|
|
52
|
+
mandatory; //only hide optional label
|
|
53
|
+
maxLength;
|
|
54
|
+
isDisabled = false;
|
|
55
|
+
constructor(injector, i18n, toasterService, coreService, sanitizer, fb, actionStateService) {
|
|
56
|
+
this.injector = injector;
|
|
57
|
+
this.i18n = i18n;
|
|
58
|
+
this.toasterService = toasterService;
|
|
59
|
+
this.coreService = coreService;
|
|
60
|
+
this.sanitizer = sanitizer;
|
|
61
|
+
this.fb = fb;
|
|
62
|
+
this.actionStateService = actionStateService;
|
|
63
|
+
}
|
|
64
|
+
ngOnInit() {
|
|
65
|
+
this.setFormControl();
|
|
66
|
+
}
|
|
67
|
+
setFormControl() {
|
|
68
|
+
try {
|
|
69
|
+
const formControl = this.injector.get(NgControl);
|
|
70
|
+
switch (formControl.constructor) {
|
|
71
|
+
case FormControlName:
|
|
72
|
+
this.control = this.injector
|
|
73
|
+
.get(FormGroupDirective)
|
|
74
|
+
.getControl(formControl);
|
|
75
|
+
break;
|
|
76
|
+
default:
|
|
77
|
+
this.control = formControl
|
|
78
|
+
.form;
|
|
79
|
+
break;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
catch (err) {
|
|
83
|
+
this.control = new FormControl();
|
|
84
|
+
}
|
|
85
|
+
this.setFormValidators();
|
|
86
|
+
}
|
|
87
|
+
setFormValidators() {
|
|
88
|
+
// this.required = this.control?.hasValidator(Validators.required) ?? false;
|
|
89
|
+
if (this.required) {
|
|
90
|
+
this.searchControl.setValidators(Validators.required);
|
|
91
|
+
this.employeeSearchControl.setValidators(Validators.required);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
this.searchControl.clearValidators();
|
|
95
|
+
this.employeeSearchControl.clearValidators();
|
|
96
|
+
}
|
|
97
|
+
this.searchControl.updateValueAndValidity();
|
|
98
|
+
this.employeeSearchControl.updateValueAndValidity();
|
|
99
|
+
}
|
|
100
|
+
writeValue(value) {
|
|
101
|
+
this.value = value;
|
|
102
|
+
if (!this.value) {
|
|
103
|
+
this.startDateControl.reset();
|
|
104
|
+
this.endDateControl.reset();
|
|
105
|
+
this.telephoneControl.reset();
|
|
106
|
+
this.toggleButtonControl.reset();
|
|
107
|
+
this.attachments = [];
|
|
108
|
+
this.searchControl.reset();
|
|
109
|
+
this.employeeSearchControl.reset();
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
this.startDateControl.setValue(this.value?.startDate);
|
|
113
|
+
this.endDateControl.setValue(this.value?.endDate);
|
|
114
|
+
this.toggleButtonControl.setValue(value);
|
|
115
|
+
this.searchControl.setValue(value['value']);
|
|
116
|
+
this.telephoneControl.setValue(value);
|
|
117
|
+
if (this.value['value'] === '') {
|
|
118
|
+
this.control.reset();
|
|
119
|
+
}
|
|
120
|
+
this.employeeSearchControl.setValue(value['personName']);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
registerOnChange(fn) {
|
|
124
|
+
}
|
|
125
|
+
registerOnTouched(fn) {
|
|
126
|
+
}
|
|
127
|
+
setDisabledState(isDisabled) {
|
|
128
|
+
this.isDisabled = isDisabled;
|
|
129
|
+
}
|
|
130
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ControlValueAccessorDirective, deps: [{ token: i0.Injector }, { token: i1.CoreI18nService }, { token: i2.ToastrService }, { token: i1.CoreService }, { token: i3.DomSanitizer }, { token: i4.FormBuilder }, { token: i1.ActionStateService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
131
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: ControlValueAccessorDirective, selector: "[appControlValueAccessor]", inputs: { tooltip: "tooltip", isReadOnly: "isReadOnly", hint: "hint", loading: "loading", placeholder: "placeholder", type: "type", showErrorMessage: "showErrorMessage", showHint: "showHint", showIfEmpty: "showIfEmpty", insideTable: "insideTable", mask: "mask", label: "label", matSuffix: "matSuffix", hasTooltip: "hasTooltip", name: "name", randomID: "randomID", multiple: "multiple", maxDate: "maxDate", minDate: "minDate", customMaxDate: "customMaxDate", customMinDate: "customMinDate", required: "required", mandatory: "mandatory" }, ngImport: i0 });
|
|
132
|
+
}
|
|
133
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ControlValueAccessorDirective, decorators: [{
|
|
134
|
+
type: Directive,
|
|
135
|
+
args: [{
|
|
136
|
+
selector: '[appControlValueAccessor]',
|
|
137
|
+
}]
|
|
138
|
+
}], ctorParameters: () => [{ type: i0.Injector }, { type: i1.CoreI18nService }, { type: i2.ToastrService }, { type: i1.CoreService }, { type: i3.DomSanitizer }, { type: i4.FormBuilder }, { type: i1.ActionStateService }], propDecorators: { tooltip: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], isReadOnly: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], hint: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], loading: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], placeholder: [{
|
|
147
|
+
type: Input
|
|
148
|
+
}], type: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}], showErrorMessage: [{
|
|
151
|
+
type: Input
|
|
152
|
+
}], showHint: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], showIfEmpty: [{
|
|
155
|
+
type: Input
|
|
156
|
+
}], insideTable: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], mask: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}], label: [{
|
|
161
|
+
type: Input
|
|
162
|
+
}], matSuffix: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], hasTooltip: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], name: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], randomID: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], multiple: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], maxDate: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], minDate: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], customMaxDate: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], customMinDate: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], required: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}], mandatory: [{
|
|
183
|
+
type: Input
|
|
184
|
+
}] } });
|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control-value-accessor.directive.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/control-value-accessor.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAY,KAAK,EAAS,MAAM,eAAe,CAAC;AACjE,OAAO,EAAoC,WAAW,EAAwB,eAAe,EAAE,kBAAkB,EAAE,SAAS,EAAE,UAAU,GAAE,MAAM,gBAAgB,CAAC;;;;;;AASjK,MAAM,OAAO,6BAA6B;IAmDrB;IAA2B;IAC3B;IACA;IAAiC;IACjC;IACA;IApDV,OAAO,CAAC;IACR,UAAU,CAAU;IACpB,IAAI,GAAG,EAAE,CAAC;IACV,OAAO,CAAW;IAClB,WAAW,CAAS;IACpB,IAAI,CAAS;IACb,gBAAgB,CAAS;IACzB,QAAQ,CAAS;IACjB,WAAW,CAAS;IACpB,WAAW,CAAM;IACjB,IAAI,CAAM;IACV,KAAK,CAAU;IACf,SAAS,CAAU;IACnB,UAAU,GAAG,KAAK,CAAC;IACnB,IAAI,CAAU;IACd,QAAQ,CAAU;IAClB,QAAQ,GAAY,KAAK,CAAC;IACnC,aAAa,GAAG,IAAI,WAAW,EAAE,CAAC;IAClC,mBAAmB,GAAG,IAAI,WAAW,EAAE,CAAC;IACxC,qBAAqB,GAAG,IAAI,WAAW,EAAE,CAAC;IAC1C,gBAAgB,GAAG,IAAI,WAAW,EAAE,CAAC;IACrC,WAAW,GAAG,EAAE,CAAC;IAGjB,gBAAgB,GAAG,IAAI,WAAW,EAAE,CAAC;IACrC,cAAc,GAAG,IAAI,WAAW,EAAE,CAAC;IACnC,UAAU,GAAG,UAAU,CAAC;IAKxB,YAAY,CAAK;IACjB,YAAY,CAAK;IACR,OAAO,CAAS;IACzB,wBAAwB;IACjB,aAAa,CAAO;IAClB,OAAO,CAAS;IAChB,aAAa,CAAK;IAClB,aAAa,CAAK;IAE3B,KAAK,CAAM;IACX,OAAO,CAA0B;IACxB,QAAQ,CAAU,CAAC,kEAAkE;IACrF,SAAS,CAAU,CAAC,0BAA0B;IACvD,SAAS,CAAM;IAEf,UAAU,GAAG,KAAK,CAAC;IACnB,YACmB,QAAkB,EAAS,IAAqB,EAChD,cAA6B,EAC7B,WAAwB,EAAS,SAAuB,EACxD,EAAe,EACf,kBAAsC;QAJtC,aAAQ,GAAR,QAAQ,CAAU;QAAS,SAAI,GAAJ,IAAI,CAAiB;QAChD,mBAAc,GAAd,cAAc,CAAe;QAC7B,gBAAW,GAAX,WAAW,CAAa;QAAS,cAAS,GAAT,SAAS,CAAc;QACxD,OAAE,GAAF,EAAE,CAAa;QACf,uBAAkB,GAAlB,kBAAkB,CAAoB;IAGzD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,cAAc;QACZ,IAAI,CAAC;YACH,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACjD,QAAQ,WAAW,CAAC,WAAW,EAAE,CAAC;gBAChC,KAAK,eAAe;oBAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ;yBACzB,GAAG,CAAC,kBAAkB,CAAC;yBACvB,UAAU,CAAC,WAA8B,CAAC,CAAC;oBAC9C,MAAM;gBACR;oBACE,IAAI,CAAC,OAAO,GAAI,WAAoC;yBACjD,IAAmB,CAAC;oBACvB,MAAM;YACV,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,iBAAiB;QAEf,4EAA4E;QAC5E,IAAI,IAAI,CAAC,QAAQ,EAAC,CAAC;YACjB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACtD,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAChE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;YACrC,IAAI,CAAC,qBAAqB,CAAC,eAAe,EAAE,CAAC;QAC/C,CAAC;QACC,IAAI,CAAC,aAAa,CAAC,sBAAsB,EAAE,CAAC;QAC5C,IAAI,CAAC,qBAAqB,CAAC,sBAAsB,EAAE,CAAC;IACxD,CAAC;IAGD,UAAU,CAAC,KAAW;QACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAG,CAAC,IAAI,CAAC,KAAK,EAAC,CAAC;YACd,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YAC9B,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;YAC5B,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YAC9B,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC;YACjC,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;YACtB,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,CAAC;QACrC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;YACtD,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAClD,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;YAC5C,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;YACrC,IAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,EAAC,CAAC;gBAC7B,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;YACtB,CAAC;YACD,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAA;QAC1D,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,EAA8B;IAE/C,CAAC;IAED,iBAAiB,CAAC,EAAc;IAChC,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;uGAnIU,6BAA6B;2FAA7B,6BAA6B;;2FAA7B,6BAA6B;kBAHzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,2BAA2B;iBACtC;uPAIU,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAiBG,OAAO;sBAAf,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAIG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import {Directive, Injector, Input, OnInit} from '@angular/core';\r\nimport {ControlValueAccessor, FormBuilder, FormControl, FormControlDirective, FormControlName, FormGroupDirective, NgControl, Validators,} from '@angular/forms';\r\nimport {ActionStateService, CoreI18nService, CoreService} from '../../../services';\r\nimport {DomSanitizer} from \"@angular/platform-browser\";\r\nimport {ToastrService} from \"ngx-toastr\";\r\nimport { MatDialogRef } from '@angular/material/dialog';\r\n\r\n@Directive({\r\n  selector: '[appControlValueAccessor]',\r\n})\r\nexport class ControlValueAccessorDirective<Type>\r\n  implements ControlValueAccessor, OnInit\r\n{\r\n  @Input() tooltip;\r\n  @Input() isReadOnly: boolean;\r\n  @Input() hint = '';\r\n  @Input() loading!: boolean;\r\n  @Input() placeholder: string;\r\n  @Input() type: string;\r\n  @Input() showErrorMessage: string;\r\n  @Input() showHint: string;\r\n  @Input() showIfEmpty: string;\r\n  @Input() insideTable: any;\r\n  @Input() mask: any;\r\n  @Input() label!: string;\r\n  @Input() matSuffix: boolean;\r\n  @Input() hasTooltip = false;\r\n  @Input() name!: string;\r\n  @Input() randomID!: string;\r\n  @Input() multiple: boolean = false;\r\n  searchControl = new FormControl();\r\n  toggleButtonControl = new FormControl();\r\n  employeeSearchControl = new FormControl();\r\n  telephoneControl = new FormControl();\r\n  attachments = [];\r\n\r\n\r\n  startDateControl = new FormControl();\r\n  endDateControl = new FormControl();\r\n  Validators = Validators;\r\n\r\n\r\n\r\n\r\n  minDateValue: any\r\n  maxDateValue: any\r\n  @Input() maxDate: string;\r\n  // @ViewChild('default')\r\n  public datepickerObj!: any;\r\n  @Input() minDate: string;\r\n  @Input() customMaxDate: any\r\n  @Input() customMinDate: any\r\n\r\n  value: any;\r\n  control: FormControl | undefined;\r\n  @Input() required: boolean; //hide optional label and add required validator from angular side\r\n  @Input() mandatory: boolean; //only hide optional label\r\n  maxLength: any;\r\n\r\n  isDisabled = false;\r\n  constructor(\r\n    private readonly injector: Injector, public i18n: CoreI18nService,\r\n              public toasterService: ToastrService,\r\n              public coreService: CoreService, public sanitizer: DomSanitizer,\r\n              public fb: FormBuilder,\r\n              public actionStateService: ActionStateService\r\n  ) {\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setFormControl();\r\n  }\r\n\r\n  setFormControl() {\r\n    try {\r\n      const formControl = this.injector.get(NgControl);\r\n      switch (formControl.constructor) {\r\n        case FormControlName:\r\n          this.control = this.injector\r\n            .get(FormGroupDirective)\r\n            .getControl(formControl as FormControlName);\r\n          break;\r\n        default:\r\n          this.control = (formControl as FormControlDirective)\r\n            .form as FormControl;\r\n          break;\r\n      }\r\n    } catch (err) {\r\n      this.control = new FormControl();\r\n    }\r\n    this.setFormValidators();\r\n  }\r\n\r\n  setFormValidators(){\r\n\r\n    // this.required = this.control?.hasValidator(Validators.required) ?? false;\r\n    if (this.required){\r\n      this.searchControl.setValidators(Validators.required);\r\n      this.employeeSearchControl.setValidators(Validators.required);\r\n    } else {\r\n      this.searchControl.clearValidators();\r\n      this.employeeSearchControl.clearValidators();\r\n    }\r\n      this.searchControl.updateValueAndValidity();\r\n      this.employeeSearchControl.updateValueAndValidity();\r\n  }\r\n\r\n\r\n  writeValue(value: Type): void {\r\n    this.value = value;\r\n    if(!this.value){\r\n      this.startDateControl.reset();\r\n      this.endDateControl.reset();\r\n      this.telephoneControl.reset();\r\n      this.toggleButtonControl.reset();\r\n      this.attachments = [];\r\n      this.searchControl.reset();\r\n      this.employeeSearchControl.reset();\r\n    } else {\r\n      this.startDateControl.setValue(this.value?.startDate);\r\n      this.endDateControl.setValue(this.value?.endDate);\r\n      this.toggleButtonControl.setValue(value);\r\n      this.searchControl.setValue(value['value']);\r\n      this.telephoneControl.setValue(value)\r\n      if(this.value['value'] === ''){\r\n        this.control.reset()\r\n      }\r\n      this.employeeSearchControl.setValue(value['personName'])\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: (val: Type | null) => Type): void {\r\n\r\n  }\r\n\r\n  registerOnTouched(fn: () => Type): void {\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.isDisabled = isDisabled;\r\n  }\r\n}\r\n"]}
|