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.
Files changed (131) hide show
  1. package/esm2022/bpm-core.mjs +5 -0
  2. package/esm2022/lib/app/app.component.mjs +79 -0
  3. package/esm2022/lib/classes/form-validation.mjs +80 -0
  4. package/esm2022/lib/classes/index.mjs +2 -0
  5. package/esm2022/lib/components/app-component-sections/activities/activities.component.mjs +44 -0
  6. package/esm2022/lib/components/app-component-sections/approvals/approvals.component.mjs +23 -0
  7. package/esm2022/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.mjs +113 -0
  8. package/esm2022/lib/components/app-component-sections/faq-sidenav/faq-sidenav.component.mjs +25 -0
  9. package/esm2022/lib/components/app-component-sections/faqs/faqs.component.mjs +27 -0
  10. package/esm2022/lib/components/app-component-sections/faqs/index.mjs +2 -0
  11. package/esm2022/lib/components/app-component-sections/feedback-section/feedback-section.component.mjs +237 -0
  12. package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs +255 -0
  13. package/esm2022/lib/components/app-component-sections/index.mjs +9 -0
  14. package/esm2022/lib/components/app-component-sections/layout/header/header.component.mjs +79 -0
  15. package/esm2022/lib/components/app-component-sections/layout/layout.component.mjs +89 -0
  16. package/esm2022/lib/components/app-component-sections/layout/side-nav/side-nav.component.mjs +158 -0
  17. package/esm2022/lib/components/app-component-sections/main-request-details/main-request-details.component.mjs +34 -0
  18. package/esm2022/lib/components/app-component-sections/previous-requests/previous-requests.component.mjs +345 -0
  19. package/esm2022/lib/components/app-component-sections/profile-section/profile-section.component.mjs +45 -0
  20. package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +271 -0
  21. package/esm2022/lib/components/app-component-sections/status/status.component.mjs +38 -0
  22. package/esm2022/lib/components/app-component-sections/workflow-section/workflow-section.component.mjs +164 -0
  23. package/esm2022/lib/components/shared-components/action-buttons/action-buttons.component.mjs +138 -0
  24. package/esm2022/lib/components/shared-components/dialogs/confirm-dialog/confirm-dialog.component.mjs +30 -0
  25. package/esm2022/lib/components/shared-components/dialogs/delete-dialog/delete-dialog.component.mjs +29 -0
  26. package/esm2022/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.mjs +67 -0
  27. package/esm2022/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.mjs +138 -0
  28. package/esm2022/lib/components/shared-components/form-field/attachment-section/attachment-section.component.mjs +234 -0
  29. package/esm2022/lib/components/shared-components/form-field/base-component/base-component.component.mjs +198 -0
  30. package/esm2022/lib/components/shared-components/form-field/checkbox/checkbox.component.mjs +91 -0
  31. package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs +185 -0
  32. package/esm2022/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.mjs +131 -0
  33. package/esm2022/lib/components/shared-components/form-field/date-picker/date-format.mjs +31 -0
  34. package/esm2022/lib/components/shared-components/form-field/date-picker/date-picker.component.mjs +175 -0
  35. package/esm2022/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.mjs +186 -0
  36. package/esm2022/lib/components/shared-components/form-field/doc-uploader/docs-uploader.component.mjs +525 -0
  37. package/esm2022/lib/components/shared-components/form-field/form-label/form-label.component.mjs +33 -0
  38. package/esm2022/lib/components/shared-components/form-field/index.mjs +26 -0
  39. package/esm2022/lib/components/shared-components/form-field/info-item/info-item.component.mjs +76 -0
  40. package/esm2022/lib/components/shared-components/form-field/input/input.component.mjs +71 -0
  41. package/esm2022/lib/components/shared-components/form-field/input-autocomplete/index.mjs +3 -0
  42. package/esm2022/lib/components/shared-components/form-field/input-autocomplete/input-autocomplete.model.mjs +2 -0
  43. package/esm2022/lib/components/shared-components/form-field/input-currency/input-currency.component.mjs +73 -0
  44. package/esm2022/lib/components/shared-components/form-field/input-email/input-email.component.mjs +69 -0
  45. package/esm2022/lib/components/shared-components/form-field/input-mask/input-mask.component.mjs +61 -0
  46. package/esm2022/lib/components/shared-components/form-field/input-number/input-number.component.mjs +74 -0
  47. package/esm2022/lib/components/shared-components/form-field/input-telephone/input-telephone.component.mjs +85 -0
  48. package/esm2022/lib/components/shared-components/form-field/radio/radio.component.mjs +52 -0
  49. package/esm2022/lib/components/shared-components/form-field/repeated-list/repeated-list.component.mjs +32 -0
  50. package/esm2022/lib/components/shared-components/form-field/search-employee/search-employee.component.mjs +192 -0
  51. package/esm2022/lib/components/shared-components/form-field/select/select.component.mjs +191 -0
  52. package/esm2022/lib/components/shared-components/form-field/shared-imports.mjs +36 -0
  53. package/esm2022/lib/components/shared-components/form-field/table-list/table-list.component.mjs +116 -0
  54. package/esm2022/lib/components/shared-components/form-field/textarea/special-chars.directive.mjs +39 -0
  55. package/esm2022/lib/components/shared-components/form-field/textarea/textarea.component.mjs +57 -0
  56. package/esm2022/lib/components/shared-components/form-field/toggle-button/toggle-button.component.mjs +90 -0
  57. package/esm2022/lib/components/shared-components/form-field/validation-errors/validation-errors.component.mjs +43 -0
  58. package/esm2022/lib/components/shared-components/index.mjs +9 -0
  59. package/esm2022/lib/components/shared-components/table/table.component.mjs +243 -0
  60. package/esm2022/lib/components/shared-components/terms-conditions/terms-conditions.component.mjs +31 -0
  61. package/esm2022/lib/components/shared-components/title-section/title-section.component.mjs +31 -0
  62. package/esm2022/lib/constants/constants.mjs +149 -0
  63. package/esm2022/lib/constants/index.mjs +2 -0
  64. package/esm2022/lib/directives/ar.directive.mjs +54 -0
  65. package/esm2022/lib/directives/currency.directive.mjs +92 -0
  66. package/esm2022/lib/directives/en.directive.mjs +51 -0
  67. package/esm2022/lib/directives/number.directive.mjs +68 -0
  68. package/esm2022/lib/directives/skip-location.directive.mjs +28 -0
  69. package/esm2022/lib/enums/actions.enum.mjs +22 -0
  70. package/esm2022/lib/enums/colors.enum.mjs +6 -0
  71. package/esm2022/lib/enums/events.enum.mjs +6 -0
  72. package/esm2022/lib/functions/data-to-blob.mjs +12 -0
  73. package/esm2022/lib/functions/encode-password.mjs +14 -0
  74. package/esm2022/lib/functions/handel-error-response.mjs +12 -0
  75. package/esm2022/lib/functions/index.mjs +5 -0
  76. package/esm2022/lib/functions/is-valid-data.mjs +42 -0
  77. package/esm2022/lib/helpers/shared.helper.mjs +26 -0
  78. package/esm2022/lib/hooks/index.mjs +3 -0
  79. package/esm2022/lib/hooks/load-form.mjs +13 -0
  80. package/esm2022/lib/hooks/save-form.mjs +18 -0
  81. package/esm2022/lib/i18n/ar.mjs +200 -0
  82. package/esm2022/lib/i18n/en.mjs +204 -0
  83. package/esm2022/lib/i18n/index.mjs +3 -0
  84. package/esm2022/lib/interfaces/action.interface.mjs +2 -0
  85. package/esm2022/lib/interfaces/api-response.interface.mjs +2 -0
  86. package/esm2022/lib/interfaces/document-file.interface.mjs +2 -0
  87. package/esm2022/lib/interfaces/form-items.interface.mjs +2 -0
  88. package/esm2022/lib/interfaces/form.interface.mjs +150 -0
  89. package/esm2022/lib/interfaces/igate-user.interface.mjs +2 -0
  90. package/esm2022/lib/interfaces/index.mjs +8 -0
  91. package/esm2022/lib/interfaces/lov-list.interface.mjs +2 -0
  92. package/esm2022/lib/interfaces/lov.interface.mjs +2 -0
  93. package/esm2022/lib/interfaces/shared.interface.mjs +2 -0
  94. package/esm2022/lib/pipes/currency.pipe.mjs +66 -0
  95. package/esm2022/lib/pipes/format-as-password.pipe.mjs +19 -0
  96. package/esm2022/lib/pipes/index.mjs +3 -0
  97. package/esm2022/lib/pipes/status-style.pipe.mjs +57 -0
  98. package/esm2022/lib/pipes/translate.pipe.mjs +36 -0
  99. package/esm2022/lib/regex/index.mjs +2 -0
  100. package/esm2022/lib/regex/regex-patterns.mjs +4 -0
  101. package/esm2022/lib/services/action.service.ts.mjs +25 -0
  102. package/esm2022/lib/services/core.service.ts.mjs +527 -0
  103. package/esm2022/lib/services/feedBack.service.mjs +81 -0
  104. package/esm2022/lib/services/i18n.service.mjs +36 -0
  105. package/esm2022/lib/services/index.mjs +6 -0
  106. package/esm2022/lib/services/sidenav.service.mjs +36 -0
  107. package/esm2022/lib/testComponent/config/segment-dynamic-loader.config.mjs +8 -0
  108. package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +90 -0
  109. package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +482 -0
  110. package/esm2022/lib/testComponent/services/i18n.service.mjs +39 -0
  111. package/esm2022/lib/testComponent/services/segment-dynamic-loader.service.mjs +54 -0
  112. package/esm2022/lib/validators/id.validator.mjs +66 -0
  113. package/esm2022/lib/validators/index.mjs +8 -0
  114. package/esm2022/lib/validators/string-to-boolean.pipe.mjs +16 -0
  115. package/esm2022/lib/validators/text.directive.mjs +50 -0
  116. package/esm2022/lib/validators/timer.pipe.mjs +19 -0
  117. package/esm2022/public-api.mjs +19 -0
  118. package/fesm2022/bpm-core.mjs +244 -226
  119. package/fesm2022/bpm-core.mjs.map +1 -1
  120. package/lib/components/shared-components/form-field/checkbox/checkbox.component.d.ts +1 -2
  121. package/lib/components/shared-components/form-field/control-value-accessor.directive.d.ts +1 -1
  122. package/lib/components/shared-components/form-field/shared-imports.d.ts +2 -2
  123. package/lib/components/shared-components/form-field/textarea/special-chars.directive.d.ts +1 -1
  124. package/lib/components/shared-components/title-section/title-section.component.d.ts +1 -1
  125. package/lib/directives/currency.directive.d.ts +1 -0
  126. package/lib/pipes/currency.pipe.d.ts +1 -1
  127. package/lib/pipes/format-as-password.pipe.d.ts +1 -1
  128. package/lib/validators/string-to-boolean.pipe.d.ts +1 -1
  129. package/lib/validators/text.directive.d.ts +1 -1
  130. package/lib/validators/timer.pipe.d.ts +1 -1
  131. 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"]}
@@ -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":"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","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"]}