@qbs-origin/origin-form 0.5.0

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 (182) hide show
  1. package/README.md +24 -0
  2. package/esm2022/lib/action-step-handler.mjs +163 -0
  3. package/esm2022/lib/auth-client.service.mjs +69 -0
  4. package/esm2022/lib/enums/label.keys.mjs +721 -0
  5. package/esm2022/lib/form-css.helper.mjs +367 -0
  6. package/esm2022/lib/formly/baseFormlyControlComponent.mjs +52 -0
  7. package/esm2022/lib/formly/baseFormlyStepComponent.mjs +59 -0
  8. package/esm2022/lib/formly/custom-section-separator.component.mjs +32 -0
  9. package/esm2022/lib/formly/form-section-separator.component.mjs +36 -0
  10. package/esm2022/lib/formly/formly-action.mjs +56 -0
  11. package/esm2022/lib/formly/formly-checkbox/formly-checkbox.component.mjs +52 -0
  12. package/esm2022/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.mjs +261 -0
  13. package/esm2022/lib/formly/formly-download-documents/formly-download-documents.component.mjs +126 -0
  14. package/esm2022/lib/formly/formly-enrol-card/formly-enrol-card.component.mjs +120 -0
  15. package/esm2022/lib/formly/formly-field-stepper/formly-field-stepper.component.mjs +762 -0
  16. package/esm2022/lib/formly/formly-generate-documents/formly-generate-documents.component.mjs +57 -0
  17. package/esm2022/lib/formly/formly-identification.component.mjs +84 -0
  18. package/esm2022/lib/formly/formly-open-banking/formly-open-banking.component.mjs +590 -0
  19. package/esm2022/lib/formly/formly-paragraph/formly-paragraph.component.mjs +35 -0
  20. package/esm2022/lib/formly/formly-radio/formly-radio-component.mjs +49 -0
  21. package/esm2022/lib/formly/formly-row-fille.mjs +12 -0
  22. package/esm2022/lib/formly/formly-scan-id/formly-scan-id.component.mjs +284 -0
  23. package/esm2022/lib/formly/formly-sign/formly-sign.component.mjs +173 -0
  24. package/esm2022/lib/formly/formly-upload-documents/formly-upload-documents.component.mjs +198 -0
  25. package/esm2022/lib/formly/formly-validate-contact-info/formly-validate-contact-info.component.mjs +124 -0
  26. package/esm2022/lib/formly/formly-view-documents/formly-view-documents.component.mjs +245 -0
  27. package/esm2022/lib/formly/formly-view-offers/formly-view-offers.component.mjs +160 -0
  28. package/esm2022/lib/model-population.helper.mjs +265 -0
  29. package/esm2022/lib/models/application-type.model.mjs +12 -0
  30. package/esm2022/lib/models/application.model.mjs +30 -0
  31. package/esm2022/lib/models/auth/users.model.mjs +2 -0
  32. package/esm2022/lib/models/dictionary.model.mjs +20 -0
  33. package/esm2022/lib/models/flux.model.mjs +105 -0
  34. package/esm2022/lib/models/forms.model.mjs +572 -0
  35. package/esm2022/lib/models/label-info.model.mjs +2 -0
  36. package/esm2022/lib/models/label.model.mjs +2 -0
  37. package/esm2022/lib/models/language.model.mjs +3 -0
  38. package/esm2022/lib/models/list.model.mjs +2 -0
  39. package/esm2022/lib/models/partner.model.mjs +3 -0
  40. package/esm2022/lib/models/treeview.model.mjs +15 -0
  41. package/esm2022/lib/origin-form-auth.service.mjs +40 -0
  42. package/esm2022/lib/origin-form-config.model.mjs +2 -0
  43. package/esm2022/lib/origin-form-token.interceptor.mjs +35 -0
  44. package/esm2022/lib/origin-form.component.mjs +2391 -0
  45. package/esm2022/lib/origin-form.module.mjs +479 -0
  46. package/esm2022/lib/origin-form.service.mjs +14 -0
  47. package/esm2022/lib/others/check-list.database.mjs +55 -0
  48. package/esm2022/lib/others/config-service.mjs +42 -0
  49. package/esm2022/lib/others/dictionary-label-info.mjs +3 -0
  50. package/esm2022/lib/others/environment-type.mjs +21 -0
  51. package/esm2022/lib/others/external-link.directive.mjs +49 -0
  52. package/esm2022/lib/others/flux-helper.mjs +1397 -0
  53. package/esm2022/lib/others/picker.component.mjs +119 -0
  54. package/esm2022/lib/others/translation.pipe.mjs +21 -0
  55. package/esm2022/lib/others/translations-helper.mjs +258 -0
  56. package/esm2022/lib/others/utils.mjs +272 -0
  57. package/esm2022/lib/services/applicationData.service.mjs +145 -0
  58. package/esm2022/lib/services/auth-http.service.mjs +80 -0
  59. package/esm2022/lib/services/dialog.service.mjs +56 -0
  60. package/esm2022/lib/services/dictionary.service.mjs +198 -0
  61. package/esm2022/lib/services/forms.service.mjs +47 -0
  62. package/esm2022/lib/services/labels.service.mjs +29 -0
  63. package/esm2022/lib/services/language.service.mjs +24 -0
  64. package/esm2022/lib/services/open-banking.service.mjs +194 -0
  65. package/esm2022/lib/services/origin-form-signalr-handler.service.mjs +107 -0
  66. package/esm2022/lib/services/origin-form-signalr.service.mjs +105 -0
  67. package/esm2022/lib/services/otp.service.mjs +28 -0
  68. package/esm2022/lib/services/proxy.service.mjs +79 -0
  69. package/esm2022/lib/services/scroll-to-error.service.mjs +369 -0
  70. package/esm2022/lib/services/translation.service.mjs +27 -0
  71. package/esm2022/lib/shared-components/confirmation.component.mjs +34 -0
  72. package/esm2022/lib/shared-components/dictionaries-tree.component.mjs +301 -0
  73. package/esm2022/lib/shared-components/grid.component.mjs +241 -0
  74. package/esm2022/lib/shared-components/treeview/treeview.component.mjs +224 -0
  75. package/esm2022/lib/theme-css.mjs +2254 -0
  76. package/esm2022/lib/theme-injector.service.mjs +26 -0
  77. package/esm2022/public-api.mjs +4 -0
  78. package/esm2022/qbs-origin-origin-form.mjs +5 -0
  79. package/fesm2022/qbs-origin-origin-form.mjs +15215 -0
  80. package/fesm2022/qbs-origin-origin-form.mjs.map +1 -0
  81. package/index.d.ts +5 -0
  82. package/lib/action-step-handler.d.ts +49 -0
  83. package/lib/auth-client.service.d.ts +17 -0
  84. package/lib/enums/label.keys.d.ts +720 -0
  85. package/lib/form-css.helper.d.ts +28 -0
  86. package/lib/formly/baseFormlyControlComponent.d.ts +25 -0
  87. package/lib/formly/baseFormlyStepComponent.d.ts +29 -0
  88. package/lib/formly/custom-section-separator.component.d.ts +6 -0
  89. package/lib/formly/form-section-separator.component.d.ts +10 -0
  90. package/lib/formly/formly-action.d.ts +13 -0
  91. package/lib/formly/formly-checkbox/formly-checkbox.component.d.ts +15 -0
  92. package/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.d.ts +45 -0
  93. package/lib/formly/formly-download-documents/formly-download-documents.component.d.ts +22 -0
  94. package/lib/formly/formly-enrol-card/formly-enrol-card.component.d.ts +114 -0
  95. package/lib/formly/formly-field-stepper/formly-field-stepper.component.d.ts +79 -0
  96. package/lib/formly/formly-generate-documents/formly-generate-documents.component.d.ts +17 -0
  97. package/lib/formly/formly-identification.component.d.ts +19 -0
  98. package/lib/formly/formly-open-banking/formly-open-banking.component.d.ts +119 -0
  99. package/lib/formly/formly-paragraph/formly-paragraph.component.d.ts +10 -0
  100. package/lib/formly/formly-radio/formly-radio-component.d.ts +15 -0
  101. package/lib/formly/formly-row-fille.d.ts +6 -0
  102. package/lib/formly/formly-scan-id/formly-scan-id.component.d.ts +41 -0
  103. package/lib/formly/formly-sign/formly-sign.component.d.ts +36 -0
  104. package/lib/formly/formly-upload-documents/formly-upload-documents.component.d.ts +25 -0
  105. package/lib/formly/formly-validate-contact-info/formly-validate-contact-info.component.d.ts +79 -0
  106. package/lib/formly/formly-view-documents/formly-view-documents.component.d.ts +33 -0
  107. package/lib/formly/formly-view-offers/formly-view-offers.component.d.ts +23 -0
  108. package/lib/model-population.helper.d.ts +8 -0
  109. package/lib/models/application-type.model.d.ts +27 -0
  110. package/lib/models/application.model.d.ts +107 -0
  111. package/lib/models/auth/users.model.d.ts +20 -0
  112. package/lib/models/dictionary.model.d.ts +77 -0
  113. package/lib/models/flux.model.d.ts +101 -0
  114. package/lib/models/forms.model.d.ts +504 -0
  115. package/lib/models/label-info.model.d.ts +10 -0
  116. package/lib/models/label.model.d.ts +4 -0
  117. package/lib/models/language.model.d.ts +5 -0
  118. package/lib/models/list.model.d.ts +8 -0
  119. package/lib/models/partner.model.d.ts +12 -0
  120. package/lib/models/treeview.model.d.ts +17 -0
  121. package/lib/origin-form-auth.service.d.ts +15 -0
  122. package/lib/origin-form-config.model.d.ts +12 -0
  123. package/lib/origin-form-token.interceptor.d.ts +12 -0
  124. package/lib/origin-form.component.d.ts +231 -0
  125. package/lib/origin-form.module.d.ts +84 -0
  126. package/lib/origin-form.service.d.ts +6 -0
  127. package/lib/others/check-list.database.d.ts +16 -0
  128. package/lib/others/config-service.d.ts +22 -0
  129. package/lib/others/dictionary-label-info.d.ts +6 -0
  130. package/lib/others/environment-type.d.ts +8 -0
  131. package/lib/others/external-link.directive.d.ts +12 -0
  132. package/lib/others/flux-helper.d.ts +115 -0
  133. package/lib/others/picker.component.d.ts +36 -0
  134. package/lib/others/translation.pipe.d.ts +10 -0
  135. package/lib/others/translations-helper.d.ts +31 -0
  136. package/lib/others/utils.d.ts +37 -0
  137. package/lib/services/applicationData.service.d.ts +35 -0
  138. package/lib/services/auth-http.service.d.ts +21 -0
  139. package/lib/services/dialog.service.d.ts +20 -0
  140. package/lib/services/dictionary.service.d.ts +89 -0
  141. package/lib/services/forms.service.d.ts +17 -0
  142. package/lib/services/labels.service.d.ts +13 -0
  143. package/lib/services/language.service.d.ts +14 -0
  144. package/lib/services/open-banking.service.d.ts +137 -0
  145. package/lib/services/origin-form-signalr-handler.service.d.ts +29 -0
  146. package/lib/services/origin-form-signalr.service.d.ts +24 -0
  147. package/lib/services/otp.service.d.ts +22 -0
  148. package/lib/services/proxy.service.d.ts +29 -0
  149. package/lib/services/scroll-to-error.service.d.ts +54 -0
  150. package/lib/services/translation.service.d.ts +10 -0
  151. package/lib/shared-components/confirmation.component.d.ts +77 -0
  152. package/lib/shared-components/dictionaries-tree.component.d.ts +51 -0
  153. package/lib/shared-components/grid.component.d.ts +138 -0
  154. package/lib/shared-components/treeview/treeview.component.d.ts +121 -0
  155. package/lib/theme-css.d.ts +2 -0
  156. package/lib/theme-injector.service.d.ts +8 -0
  157. package/package.json +42 -0
  158. package/public-api.d.ts +3 -0
  159. package/schematics-compiled/collection.json +10 -0
  160. package/schematics-compiled/ng-add/index.d.ts +2 -0
  161. package/schematics-compiled/ng-add/index.js +67 -0
  162. package/schematics-compiled/ng-add/index.js.map +1 -0
  163. package/schematics-compiled/ng-add/schema.json +8 -0
  164. package/src/lib/assets/fonts/Figtree-Bold.ttf +0 -0
  165. package/src/lib/assets/fonts/Figtree-Light.ttf +0 -0
  166. package/src/lib/assets/fonts/Figtree-Regular.ttf +0 -0
  167. package/src/lib/assets/fonts/Sora-ExtraBold.ttf +0 -0
  168. package/src/lib/assets/fonts/Sora-Light.ttf +0 -0
  169. package/src/lib/assets/fonts/Sora-Regular.ttf +0 -0
  170. package/src/lib/assets/fonts/ttrounds-bold-webfont.woff +0 -0
  171. package/src/lib/assets/fonts/ttrounds-bold-webfont.woff2 +0 -0
  172. package/src/lib/assets/fonts/ttrounds-regular-webfont.woff +0 -0
  173. package/src/lib/assets/fonts/ttrounds-regular-webfont.woff2 +0 -0
  174. package/src/lib/assets/fonts/ttrounds-thin-webfont.woff +0 -0
  175. package/src/lib/assets/fonts/ttrounds-thin-webfont.woff2 +0 -0
  176. package/src/lib/assets/images/flag/icon-flag-de.svg +10 -0
  177. package/src/lib/assets/images/flag/icon-flag-en.svg +1 -0
  178. package/src/lib/assets/images/flag/icon-flag-es.svg +11 -0
  179. package/src/lib/assets/images/flag/icon-flag-fr.svg +1 -0
  180. package/src/lib/assets/images/flag/icon-flag-ro.svg +11 -0
  181. package/src/lib/assets/images/flag/origin-form/new-id-card.png +0 -0
  182. package/src/lib/assets/images/flag/origin-form/old-id-card.png +0 -0
@@ -0,0 +1,173 @@
1
+ import { Component, ViewChild, inject, } from '@angular/core';
2
+ import { ConfigService } from '../../others/config-service';
3
+ import { FluxType } from '../../models/forms.model';
4
+ import { BaseFormlyStepComponent } from '../baseFormlyStepComponent';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../../origin-form-auth.service";
7
+ import * as i2 from "../../services/dialog.service";
8
+ import * as i3 from "sign-lib";
9
+ export class FormlySignComponent extends BaseFormlyStepComponent {
10
+ constructor(authService, cdr, dialog) {
11
+ super(cdr);
12
+ this.authService = authService;
13
+ this.dialog = dialog;
14
+ this.canProceed = false;
15
+ this._signButtonStyle = {};
16
+ this.configService = inject(ConfigService);
17
+ }
18
+ onInit() { }
19
+ async onPageSelectedAsync() {
20
+ const styleObj = this.props?.['design']?.['.button-otpaction'];
21
+ if (styleObj) {
22
+ const camelCaseStyle = {};
23
+ Object.keys(styleObj).forEach((key) => {
24
+ const camelKey = key.replace(/-([a-z])/g, (g) => g[1].toUpperCase());
25
+ camelCaseStyle[camelKey] = styleObj[key];
26
+ });
27
+ this._signButtonStyle = camelCaseStyle;
28
+ }
29
+ else {
30
+ this._signButtonStyle = {};
31
+ }
32
+ // Reset component state when page is selected
33
+ this.canProceed = false;
34
+ this.config = await this.getConfig();
35
+ this.addPhoneNumbertoConfig();
36
+ this.config = {
37
+ ...this.config,
38
+ ShowConfirm: this.stepData.config.showConfirm ?? false,
39
+ SignMode: this.stepData.config.companySign ?? false ? 'both' : 'client',
40
+ ...(Object.keys(this.signButtonStyle).length > 0
41
+ ? {
42
+ Styles: {
43
+ ...(this.config.Styles || {}),
44
+ buttonStyles: this.signButtonStyle,
45
+ },
46
+ }
47
+ : {}),
48
+ };
49
+ if (this.config.Styles?.buttonStyles) {
50
+ console.log(`🧫 FormlySignComponent: Styles for sign button are sent:`, this.config.Styles.buttonStyles);
51
+ console.log('config', this.config);
52
+ }
53
+ console.log(`🔷 FormlySignComponent: Initializing sign component for step ${this.stepData.identifier}`);
54
+ //very important to trigger input parameter pass to SignLib component
55
+ this.cdr.detectChanges();
56
+ // Wait a bit for ViewChild to be available and then initialize
57
+ await new Promise((resolve) => setTimeout(resolve, 50));
58
+ // Ensure SignLibComponent is properly initialized
59
+ if (this.signLib) {
60
+ console.log(`🔷 FormlySignComponent: SignLibComponent found, calling ngOnInit for step ${this.stepData.identifier}`);
61
+ await this.signLib.ngOnInit();
62
+ }
63
+ else {
64
+ console.warn(`🔷 FormlySignComponent: SignLibComponent not found for step ${this.stepData.identifier}`);
65
+ }
66
+ }
67
+ async retryAsync() {
68
+ await this.onPageSelectedAsync();
69
+ }
70
+ async getConfig() {
71
+ return {
72
+ AppDataId: this.props['appDataId'],
73
+ StepId: this.stepData.identifier,
74
+ Token: this.authService.getToken(),
75
+ BaseUrl: this.configService.readConfig().baseUrlGateway,
76
+ AutoSign: this.stepData.isVisible === false,
77
+ };
78
+ }
79
+ addPhoneNumbertoConfig() {
80
+ const phoneKey = this.stepData.config.componentCollected;
81
+ if (phoneKey) {
82
+ let phoneNumber = null;
83
+ // Get references to parent form and model from props
84
+ const parentForm = this.props['parentForm'];
85
+ const model = this.props['getModel']();
86
+ const flux = this.props['flux'];
87
+ // First try to get from parent form control (for validated phone numbers)
88
+ const formControl = parentForm?.get(phoneKey);
89
+ phoneNumber = formControl?.value;
90
+ // If not found in form control, try from model
91
+ if (!phoneNumber && model && model[phoneKey]) {
92
+ phoneNumber = model[phoneKey];
93
+ }
94
+ if (!phoneNumber && phoneKey === 'validated-phone' && flux) {
95
+ const phoneStep = flux.find((step) => step.type === FluxType.Phone);
96
+ if (phoneStep &&
97
+ phoneStep.config &&
98
+ phoneStep.config.componentCollected) {
99
+ const originalPhoneKey = phoneStep.config.componentCollected;
100
+ // Try from parent form first, then model
101
+ phoneNumber =
102
+ parentForm?.get(originalPhoneKey)?.value ||
103
+ (model && model[originalPhoneKey]);
104
+ }
105
+ }
106
+ if (phoneNumber) {
107
+ this.config = {
108
+ ...this.config,
109
+ PhoneNumber: phoneNumber,
110
+ };
111
+ }
112
+ else {
113
+ console.warn('🔷 FormlySignComponent: No phone number found for key:', phoneKey);
114
+ }
115
+ }
116
+ else {
117
+ console.warn('🔷 FormlySignComponent: No componentCollected key found in step config');
118
+ }
119
+ }
120
+ canAdvance() {
121
+ if (!this.canProceed) {
122
+ this.dialog.popError('signComponent.viewfiles.waitForSign');
123
+ return false;
124
+ }
125
+ return true;
126
+ }
127
+ libEvent(event) {
128
+ if (event && event.toLowerCase() === 'success') {
129
+ this.canProceed = true;
130
+ }
131
+ this.onEvent(event);
132
+ }
133
+ get signButtonStyle() {
134
+ return this._signButtonStyle;
135
+ }
136
+ ngOnDestroy() {
137
+ console.log('🔷 FormlySignComponent: Destroying component and cleaning up SignLibComponent');
138
+ // Cleanup SignLibComponent if it exists
139
+ if (this.signLib) {
140
+ try {
141
+ // Call destroy method if it exists (check for various possible cleanup methods)
142
+ if (typeof this.signLib.ngOnDestroy === 'function') {
143
+ this.signLib.ngOnDestroy();
144
+ }
145
+ else if (typeof this.signLib.destroy === 'function') {
146
+ this.signLib.destroy();
147
+ }
148
+ else if (typeof this.signLib.cleanup === 'function') {
149
+ this.signLib.cleanup();
150
+ }
151
+ // Clear any references
152
+ this.signLib = null;
153
+ }
154
+ catch (error) {
155
+ console.warn('🔷 FormlySignComponent: Error during SignLibComponent cleanup:', error);
156
+ }
157
+ }
158
+ // Reset component state
159
+ this.canProceed = false;
160
+ this.config = null;
161
+ console.log('🔷 FormlySignComponent: Component cleanup completed');
162
+ }
163
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlySignComponent, deps: [{ token: i1.OriginFormAuthService }, { token: i0.ChangeDetectorRef }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
164
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormlySignComponent, selector: "formly-sign", viewQueries: [{ propertyName: "signLib", first: true, predicate: ["signLib"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<lib-sign #signLib [config]=\"config\" (event)=\"libEvent($event)\"> </lib-sign>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "component", type: i3.SignLibComponent, selector: "lib-sign", inputs: ["config", "instanceId"], outputs: ["event"] }] }); }
165
+ }
166
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlySignComponent, decorators: [{
167
+ type: Component,
168
+ args: [{ selector: 'formly-sign', template: "<lib-sign #signLib [config]=\"config\" (event)=\"libEvent($event)\"> </lib-sign>\n", styles: [":host{display:block}\n"] }]
169
+ }], ctorParameters: () => [{ type: i1.OriginFormAuthService }, { type: i0.ChangeDetectorRef }, { type: i2.DialogService }], propDecorators: { signLib: [{
170
+ type: ViewChild,
171
+ args: ['signLib']
172
+ }] } });
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-sign.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-sign/formly-sign.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-sign/formly-sign.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewChild,\n  inject,\n  ChangeDetectorRef,\n  OnDestroy,\n} from '@angular/core';\nimport { SignLibComponent } from 'sign-lib';\nimport { firstValueFrom } from 'rxjs';\nimport { ConfigService } from '../../others/config-service';\nimport { OriginFormAuthService } from '../../origin-form-auth.service';\nimport { DialogService } from '../../services/dialog.service';\nimport { FluxType } from '../../models/forms.model';\nimport { BaseFormlyStepComponent } from '../baseFormlyStepComponent';\n\n@Component({\n  selector: 'formly-sign',\n  templateUrl: './formly-sign.component.html',\n  styleUrl: './formly-sign.component.scss',\n})\nexport class FormlySignComponent\n  extends BaseFormlyStepComponent\n  implements OnDestroy\n{\n  @ViewChild('signLib') signLib: SignLibComponent;\n  canProceed: boolean = false;\n  private _signButtonStyle: { [key: string]: string } = {};\n  public config: any;\n  configService = inject(ConfigService);\n  constructor(\n    public authService: OriginFormAuthService,\n    cdr: ChangeDetectorRef,\n    private dialog: DialogService\n  ) {\n    super(cdr);\n  }\n\n  override onInit() {}\n\n  override async onPageSelectedAsync() {\n    const styleObj = this.props?.['design']?.['.button-otpaction'];\n    if (styleObj) {\n      const camelCaseStyle: { [key: string]: string } = {};\n      Object.keys(styleObj).forEach((key) => {\n        const camelKey = key.replace(/-([a-z])/g, (g) => g[1].toUpperCase());\n        camelCaseStyle[camelKey] = styleObj[key];\n      });\n      this._signButtonStyle = camelCaseStyle;\n    } else {\n      this._signButtonStyle = {};\n    }\n    // Reset component state when page is selected\n    this.canProceed = false;\n\n    this.config = await this.getConfig();\n    this.addPhoneNumbertoConfig();\n\n    this.config = {\n      ...this.config,\n      ShowConfirm: this.stepData.config.showConfirm ?? false,\n      SignMode: this.stepData.config.companySign ?? false ? 'both' : 'client',\n      ...(Object.keys(this.signButtonStyle).length > 0\n        ? {\n            Styles: {\n              ...(this.config.Styles || {}),\n              buttonStyles: this.signButtonStyle,\n            },\n          }\n        : {}),\n    };\n\n    if (this.config.Styles?.buttonStyles) {\n      console.log(\n        `🧫 FormlySignComponent: Styles for sign button are sent:`,\n        this.config.Styles.buttonStyles\n      );\n      console.log('config', this.config);\n    }\n\n    console.log(\n      `🔷 FormlySignComponent: Initializing sign component for step ${this.stepData.identifier}`\n    );\n\n    //very important to trigger input parameter pass to SignLib component\n    this.cdr.detectChanges();\n\n    // Wait a bit for ViewChild to be available and then initialize\n    await new Promise((resolve) => setTimeout(resolve, 50));\n\n    // Ensure SignLibComponent is properly initialized\n    if (this.signLib) {\n      console.log(\n        `🔷 FormlySignComponent: SignLibComponent found, calling ngOnInit for step ${this.stepData.identifier}`\n      );\n      await this.signLib.ngOnInit();\n    } else {\n      console.warn(\n        `🔷 FormlySignComponent: SignLibComponent not found for step ${this.stepData.identifier}`\n      );\n    }\n  }\n\n  async retryAsync() {\n    await this.onPageSelectedAsync();\n  }\n\n  async getConfig() {\n    return {\n      AppDataId: this.props['appDataId'],\n      StepId: this.stepData.identifier,\n      Token: this.authService.getToken(),\n      BaseUrl: this.configService.readConfig().baseUrlGateway,\n      AutoSign: this.stepData.isVisible === false,\n    };\n  }\n\n  private addPhoneNumbertoConfig(): void {\n    const phoneKey = this.stepData.config.componentCollected;\n\n    if (phoneKey) {\n      let phoneNumber = null;\n\n      // Get references to parent form and model from props\n      const parentForm = this.props['parentForm'];\n      const model = this.props['getModel']();\n      const flux = this.props['flux'];\n\n      // First try to get from parent form control (for validated phone numbers)\n      const formControl = parentForm?.get(phoneKey);\n      phoneNumber = formControl?.value;\n\n      // If not found in form control, try from model\n      if (!phoneNumber && model && model[phoneKey]) {\n        phoneNumber = model[phoneKey];\n      }\n\n      if (!phoneNumber && phoneKey === 'validated-phone' && flux) {\n        const phoneStep = flux.find(\n          (step: any) => step.type === FluxType.Phone\n        );\n        if (\n          phoneStep &&\n          phoneStep.config &&\n          phoneStep.config.componentCollected\n        ) {\n          const originalPhoneKey = phoneStep.config.componentCollected;\n          // Try from parent form first, then model\n          phoneNumber =\n            parentForm?.get(originalPhoneKey)?.value ||\n            (model && model[originalPhoneKey]);\n        }\n      }\n\n      if (phoneNumber) {\n        this.config = {\n          ...this.config,\n          PhoneNumber: phoneNumber,\n        };\n      } else {\n        console.warn(\n          '🔷 FormlySignComponent: No phone number found for key:',\n          phoneKey\n        );\n      }\n    } else {\n      console.warn(\n        '🔷 FormlySignComponent: No componentCollected key found in step config'\n      );\n    }\n  }\n\n  override canAdvance(): boolean {\n    if (!this.canProceed) {\n      this.dialog.popError('signComponent.viewfiles.waitForSign');\n      return false;\n    }\n    return true;\n  }\n\n  libEvent(event: any) {\n    if (event && event.toLowerCase() === 'success') {\n      this.canProceed = true;\n    }\n    this.onEvent(event);\n  }\n\n  get signButtonStyle(): { [key: string]: string } {\n    return this._signButtonStyle;\n  }\n\n  ngOnDestroy(): void {\n    console.log(\n      '🔷 FormlySignComponent: Destroying component and cleaning up SignLibComponent'\n    );\n\n    // Cleanup SignLibComponent if it exists\n    if (this.signLib) {\n      try {\n        // Call destroy method if it exists (check for various possible cleanup methods)\n        if (typeof (this.signLib as any).ngOnDestroy === 'function') {\n          (this.signLib as any).ngOnDestroy();\n        } else if (typeof (this.signLib as any).destroy === 'function') {\n          (this.signLib as any).destroy();\n        } else if (typeof (this.signLib as any).cleanup === 'function') {\n          (this.signLib as any).cleanup();\n        }\n\n        // Clear any references\n        (this.signLib as any) = null;\n      } catch (error) {\n        console.warn(\n          '🔷 FormlySignComponent: Error during SignLibComponent cleanup:',\n          error\n        );\n      }\n    }\n\n    // Reset component state\n    this.canProceed = false;\n    this.config = null;\n\n    console.log('🔷 FormlySignComponent: Component cleanup completed');\n  }\n}\n","<lib-sign #signLib [config]=\"config\" (event)=\"libEvent($event)\"> </lib-sign>\n"]}
@@ -0,0 +1,198 @@
1
+ import { Component } from '@angular/core';
2
+ import { Observable } from 'rxjs';
3
+ import { ApplicationUploadDocumentsDto } from '../../models/application.model';
4
+ import { Utils } from '../../others/utils';
5
+ import { BaseFormlyControlComponent } from '../baseFormlyControlComponent';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../services/dialog.service";
8
+ import * as i2 from "../../services/applicationData.service";
9
+ import * as i3 from "@angular/common";
10
+ import * as i4 from "@angular/material/button";
11
+ import * as i5 from "@angular/material/icon";
12
+ import * as i6 from "@angular/material/progress-spinner";
13
+ import * as i7 from "../../others/translation.pipe";
14
+ export class FormlyUploadDocumentsComponent extends BaseFormlyControlComponent {
15
+ constructor(dialog, appDataService, cdr) {
16
+ super(cdr);
17
+ this.dialog = dialog;
18
+ this.appDataService = appDataService;
19
+ this.mandatoryDocuments = [];
20
+ }
21
+ onInit() {
22
+ this.isDisabled = false;
23
+ if (this.controlData && this.controlData.specificControlData) {
24
+ this.documents = this.controlData.specificControlData.documents;
25
+ this.mandatoryDocuments = this.documents
26
+ .filter((d) => d.isMandatory)
27
+ .map((d) => d.documentId);
28
+ }
29
+ const appDocuments = this.props['documentsData'];
30
+ if (appDocuments && this.documents) {
31
+ this.documents.forEach((d) => {
32
+ const appDoc = appDocuments.find((ad) => ad.id === d.documentId);
33
+ d.documentName =
34
+ appDoc?.translations?.find(t => t.languageIso === this.langIso)?.value ||
35
+ appDoc?.name ||
36
+ d.documentId;
37
+ });
38
+ }
39
+ }
40
+ async submitUploadAsync(doc, uploadPayload) {
41
+ this.cdr.detectChanges();
42
+ let obs = new Observable((subscriber) => {
43
+ if (doc.isUploading) {
44
+ this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'waitForUpload');
45
+ subscriber.next();
46
+ }
47
+ else {
48
+ doc.isUploading = true;
49
+ this.isDisabled = true;
50
+ this.appDataService.uploadDocuments(uploadPayload).subscribe({
51
+ next: (res) => {
52
+ subscriber.next();
53
+ doc.isUploading = false;
54
+ doc.isUploadSuccess = true;
55
+ this.cdr.detectChanges();
56
+ this.mandatoryDocuments = [];
57
+ if (res) {
58
+ this.isDisabled = false;
59
+ }
60
+ if (res && res.length > 0) {
61
+ this.documents.forEach((d) => {
62
+ if (res.includes(d.documentId)) {
63
+ this.mandatoryDocuments.push(d.documentId);
64
+ }
65
+ });
66
+ }
67
+ },
68
+ error: (err) => {
69
+ subscriber.next();
70
+ doc.isUploading = false;
71
+ this.isDisabled = false;
72
+ this.cdr.detectChanges();
73
+ },
74
+ });
75
+ this.cdr.detectChanges();
76
+ }
77
+ });
78
+ return obs;
79
+ }
80
+ pullFromUI(doc, fileInput) {
81
+ return new Promise((resolve, reject) => {
82
+ const reader = new FileReader();
83
+ reader.readAsDataURL(fileInput);
84
+ reader.onload = () => {
85
+ doc.fileName = fileInput.name;
86
+ doc.fileData = reader.result?.toString().split(';base64,')[1] || '';
87
+ this.cdr.detectChanges();
88
+ let appDocs = this.getNewUploadPayload();
89
+ this.documents.forEach((d) => {
90
+ if (d.documentId === doc.documentId) {
91
+ appDocs.documents.push({
92
+ documentId: d.documentId,
93
+ fileData: doc.fileData,
94
+ fileName: doc.fileName,
95
+ });
96
+ }
97
+ });
98
+ this.cdr.detectChanges();
99
+ resolve(appDocs);
100
+ };
101
+ reader.onerror = (error) => {
102
+ reject(error);
103
+ };
104
+ });
105
+ }
106
+ isValid() {
107
+ let isValid = true;
108
+ if (this.documents) {
109
+ let errorMessages = [];
110
+ this.documents.forEach((d) => {
111
+ if (this.mandatoryDocuments.includes(d.documentId)) {
112
+ const msg = Utils.createErrorTranslationMssageWithParameters(this.controlData.errorsTranslations, this.langIso, 'isMandatory', [d.documentName]);
113
+ errorMessages.push(msg);
114
+ isValid = false;
115
+ }
116
+ });
117
+ if (errorMessages.length > 0) {
118
+ this.dialog.popError(errorMessages.join('\n'));
119
+ }
120
+ }
121
+ return isValid;
122
+ }
123
+ selectFile(event, doc) {
124
+ doc.fileData = undefined;
125
+ if (!event.target.files[0] || event.target.files[0].length === 0) {
126
+ return;
127
+ }
128
+ const file = event.target.files[0];
129
+ if (file) {
130
+ let invalidType = true;
131
+ if (doc.documentExtensions && doc.documentExtensions !== '') {
132
+ const docExtensions = doc.documentExtensions.split(';');
133
+ if (docExtensions && docExtensions.length > 0) {
134
+ const fileExtension = Utils.getFileExtension(file.name);
135
+ if (fileExtension) {
136
+ docExtensions.forEach((d) => {
137
+ if (fileExtension.toLowerCase() == d.toLowerCase()) {
138
+ invalidType = false;
139
+ }
140
+ });
141
+ }
142
+ }
143
+ else {
144
+ invalidType = false;
145
+ }
146
+ }
147
+ else {
148
+ invalidType = false;
149
+ }
150
+ if (invalidType) {
151
+ this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'invalidType', doc.documentExtensions);
152
+ event.currentTarget.value = '';
153
+ return;
154
+ }
155
+ if (file.size) {
156
+ const sizeInKB = file.size / 1024;
157
+ if (sizeInKB > doc.documentMaxSize) {
158
+ this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'maxSize', doc.documentMaxSize.toString() + 'KB');
159
+ event.currentTarget.value = '';
160
+ return;
161
+ }
162
+ }
163
+ this.pullFromUI(doc, file)
164
+ .then(async (res) => {
165
+ (await this.submitUploadAsync(doc, res)).subscribe();
166
+ this.cdr.detectChanges();
167
+ })
168
+ .catch((error) => {
169
+ console.error('Error processing file:', error);
170
+ });
171
+ }
172
+ this.cdr.detectChanges();
173
+ }
174
+ canAdvance() {
175
+ this.cdr.detectChanges();
176
+ let canProceed = false;
177
+ if (this.isValid()) {
178
+ canProceed = true;
179
+ }
180
+ return canProceed;
181
+ }
182
+ getNewUploadPayload() {
183
+ let uploadPayload = new ApplicationUploadDocumentsDto();
184
+ uploadPayload.appDataId = this.appDataId;
185
+ uploadPayload.appId = this.appId;
186
+ uploadPayload.controlId = this.controlData.identifier;
187
+ uploadPayload.env = this.env;
188
+ uploadPayload.documents = [];
189
+ return uploadPayload;
190
+ }
191
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyUploadDocumentsComponent, deps: [{ token: i1.DialogService }, { token: i2.ApplicationDataService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
192
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormlyUploadDocumentsComponent, selector: "app-formly-upload-documents", usesInheritance: true, ngImport: i0, template: "<p *ngIf=\"title\">\n {{ title }}\n</p>\n\n<table>\n <thead class=\"table-head\">\n <tr>\n <th>\n {{ \"document\" | translate }}\n </th>\n <th>\n {{ \"format\" | translate }}\n </th>\n <th>\n {{ \"flux.components.uploadDocument.maxSize\" | translate }}\n </th>\n <th>\n {{ \"stepControl.mandatory\" | translate }}\n </th>\n </tr>\n </thead>\n <tbody class=\"table-detail\">\n <tr *ngFor=\"let doc of documents; let i = index\">\n <td>\n {{ doc.documentName }}\n </td>\n <td>\n {{ doc.documentExtensions }}\n </td>\n <td>\n {{ doc.documentMaxSize }}\n </td>\n <td>\n {{ (doc.isMandatory ? \"yes\" : \"no\") | translate }}\n </td>\n <td>\n <div>\n <input\n type=\"file\"\n #fileInput\n (change)=\"selectFile($event, doc)\"\n hidden\n />\n <button\n mat-flat-button\n color=\"primary\"\n (click)=\"fileInput.click()\"\n [disabled]=\"this.isDisabled\"\n >\n <mat-icon>cloud_upload</mat-icon>\n {{\n doc.fileName\n ? doc.fileName\n : (\"common.actions.upload\" | translate)\n }}\n </button>\n </div>\n </td>\n <td *ngIf=\"doc.fileName\">\n <i-tabler\n *ngIf=\"\n doc.isUploading === false &&\n doc.isUploadSuccess === true &&\n doc.fileName\n \"\n class=\"icon-25 text-white bg-primary rounded\"\n name=\"check\"\n ></i-tabler>\n <mat-spinner\n *ngIf=\"doc.isUploading === true\"\n class=\"m-x-auto upload-spinner\"\n ></mat-spinner>\n </td>\n </tr>\n </tbody>\n</table>\n", styles: [".upload-spinner{width:30px!important}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
193
+ }
194
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyUploadDocumentsComponent, decorators: [{
195
+ type: Component,
196
+ args: [{ selector: 'app-formly-upload-documents', template: "<p *ngIf=\"title\">\n {{ title }}\n</p>\n\n<table>\n <thead class=\"table-head\">\n <tr>\n <th>\n {{ \"document\" | translate }}\n </th>\n <th>\n {{ \"format\" | translate }}\n </th>\n <th>\n {{ \"flux.components.uploadDocument.maxSize\" | translate }}\n </th>\n <th>\n {{ \"stepControl.mandatory\" | translate }}\n </th>\n </tr>\n </thead>\n <tbody class=\"table-detail\">\n <tr *ngFor=\"let doc of documents; let i = index\">\n <td>\n {{ doc.documentName }}\n </td>\n <td>\n {{ doc.documentExtensions }}\n </td>\n <td>\n {{ doc.documentMaxSize }}\n </td>\n <td>\n {{ (doc.isMandatory ? \"yes\" : \"no\") | translate }}\n </td>\n <td>\n <div>\n <input\n type=\"file\"\n #fileInput\n (change)=\"selectFile($event, doc)\"\n hidden\n />\n <button\n mat-flat-button\n color=\"primary\"\n (click)=\"fileInput.click()\"\n [disabled]=\"this.isDisabled\"\n >\n <mat-icon>cloud_upload</mat-icon>\n {{\n doc.fileName\n ? doc.fileName\n : (\"common.actions.upload\" | translate)\n }}\n </button>\n </div>\n </td>\n <td *ngIf=\"doc.fileName\">\n <i-tabler\n *ngIf=\"\n doc.isUploading === false &&\n doc.isUploadSuccess === true &&\n doc.fileName\n \"\n class=\"icon-25 text-white bg-primary rounded\"\n name=\"check\"\n ></i-tabler>\n <mat-spinner\n *ngIf=\"doc.isUploading === true\"\n class=\"m-x-auto upload-spinner\"\n ></mat-spinner>\n </td>\n </tr>\n </tbody>\n</table>\n", styles: [".upload-spinner{width:30px!important}\n"] }]
197
+ }], ctorParameters: () => [{ type: i1.DialogService }, { type: i2.ApplicationDataService }, { type: i0.ChangeDetectorRef }] });
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-upload-documents.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-upload-documents/formly-upload-documents.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-upload-documents/formly-upload-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component } from '@angular/core';\nimport { ApplicationDataService } from '../../services/applicationData.service';\nimport {\n  AppDocument,\n  UploadDocumentDetails,\n} from '../../models/forms.model';\nimport { DialogService } from '../../services/dialog.service';\nimport { Observable } from 'rxjs';\nimport { ApplicationUploadDocumentsDto } from '../../models/application.model';\nimport { Utils } from '../../others/utils';\nimport { BaseFormlyControlComponent } from '../baseFormlyControlComponent';\n\n@Component({\n  selector: 'app-formly-upload-documents',\n  templateUrl: './formly-upload-documents.component.html',\n  styleUrl: './formly-upload-documents.component.scss',\n})\nexport class FormlyUploadDocumentsComponent extends BaseFormlyControlComponent {\n  documents: UploadDocumentDetails[];\n  mandatoryDocuments: string[] = [];\n  isDisabled: boolean;\n  constructor(\n    private dialog: DialogService,\n    private appDataService: ApplicationDataService,\n    cdr: ChangeDetectorRef\n  ) {\n    super(cdr);\n  }\n\n  override onInit(): void {\n    this.isDisabled = false;\n    if (this.controlData && this.controlData.specificControlData) {\n      this.documents = this.controlData.specificControlData.documents as UploadDocumentDetails[];\n      this.mandatoryDocuments = this.documents\n        .filter((d) => d.isMandatory)\n        .map((d) => d.documentId);\n    }\n\n    const appDocuments = this.props['documentsData'] as AppDocument[];\n    if (appDocuments && this.documents) {\n      this.documents.forEach((d) => {\n        const appDoc = appDocuments.find((ad) => ad.id === d.documentId);\n        d.documentName =\n          appDoc?.translations?.find(t => t.languageIso === this.langIso)?.value ||\n          appDoc?.name ||\n          d.documentId;\n      });\n    }\n  }\n\n  async submitUploadAsync(\n    doc: UploadDocumentDetails,\n    uploadPayload: ApplicationUploadDocumentsDto\n  ): Promise<Observable<number>> {\n    this.cdr.detectChanges();\n    let obs = new Observable<number>((subscriber) => {\n      if (doc.isUploading) {\n        this.dialog.popErrorTranslation(\n          this.controlData.errorsTranslations,\n          this.langIso,\n          'waitForUpload'\n        );\n        subscriber.next();\n      } else {\n        doc.isUploading = true;\n        this.isDisabled = true;\n        this.appDataService.uploadDocuments(uploadPayload).subscribe({\n          next: (res) => {\n            subscriber.next();\n            doc.isUploading = false;\n            doc.isUploadSuccess = true;\n\n            this.cdr.detectChanges();\n            this.mandatoryDocuments = [];\n            if (res) {\n              this.isDisabled = false;\n            }\n            if (res && res.length > 0) {\n              this.documents.forEach((d) => {\n                if (res.includes(d.documentId)) {\n                  this.mandatoryDocuments.push(d.documentId);\n                }\n              });\n            }\n          },\n          error: (err) => {\n            subscriber.next();\n            doc.isUploading = false;\n            this.isDisabled = false;\n            this.cdr.detectChanges();\n          },\n        });\n        this.cdr.detectChanges();\n      }\n    });\n\n    return obs;\n  }\n\n  pullFromUI(\n    doc: UploadDocumentDetails,\n    fileInput: File\n  ): Promise<ApplicationUploadDocumentsDto> {\n    return new Promise((resolve, reject) => {\n      const reader = new FileReader();\n      reader.readAsDataURL(fileInput);\n      reader.onload = () => {\n        doc.fileName = fileInput.name;\n        doc.fileData = reader.result?.toString().split(';base64,')[1] || '';\n\n        this.cdr.detectChanges();\n\n        let appDocs = this.getNewUploadPayload();\n        this.documents.forEach((d) => {\n          if (d.documentId === doc.documentId) {\n            appDocs.documents.push({\n              documentId: d.documentId,\n              fileData: doc.fileData,\n              fileName: doc.fileName,\n            });\n          }\n        });\n\n        this.cdr.detectChanges();\n        resolve(appDocs);\n      };\n      reader.onerror = (error) => {\n        reject(error);\n      };\n    });\n  }\n\n  isValid(): boolean {\n    let isValid = true;\n    if (this.documents) {\n      let errorMessages: string[] = [];\n      this.documents.forEach((d) => {\n        if (this.mandatoryDocuments.includes(d.documentId)) {\n          const msg = Utils.createErrorTranslationMssageWithParameters(\n            this.controlData.errorsTranslations,\n            this.langIso,\n            'isMandatory',\n            [d.documentName]\n          );\n          errorMessages.push(msg);\n          isValid = false;\n        }\n      });\n      if (errorMessages.length > 0) {\n        this.dialog.popError(errorMessages.join('\\n'));\n      }\n    }\n    return isValid;\n  }\n\n  selectFile(event: any, doc: UploadDocumentDetails): void {\n    doc.fileData = undefined;\n    if (!event.target.files[0] || event.target.files[0].length === 0) {\n      return;\n    }\n    const file = event.target.files[0];\n    if (file) {\n      let invalidType: boolean = true;\n      if (doc.documentExtensions && doc.documentExtensions !== '') {\n        const docExtensions = doc.documentExtensions.split(';');\n        if (docExtensions && docExtensions.length > 0) {\n          const fileExtension = Utils.getFileExtension(file.name);\n          if (fileExtension) {\n            docExtensions.forEach((d) => {\n              if (fileExtension.toLowerCase() == d.toLowerCase()) {\n                invalidType = false;\n              }\n            });\n          }\n        } else {\n          invalidType = false;\n        }\n      } else {\n        invalidType = false;\n      }\n      if (invalidType) {\n        this.dialog.popErrorTranslation(\n          this.controlData.errorsTranslations,\n          this.langIso,\n          'invalidType',\n          doc.documentExtensions\n        );\n        event.currentTarget.value = '';\n        return;\n      }\n      if (file.size) {\n        const sizeInKB = file.size / 1024;\n        if (sizeInKB > doc.documentMaxSize) {\n          this.dialog.popErrorTranslation(\n            this.controlData.errorsTranslations,\n            this.langIso,\n            'maxSize',\n            doc.documentMaxSize.toString() + 'KB'\n          );\n\n          event.currentTarget.value = '';\n          return;\n        }\n      }\n\n      this.pullFromUI(doc, file)\n        .then(async (res) => {\n          (await this.submitUploadAsync(doc, res)).subscribe();\n          this.cdr.detectChanges();\n        })\n        .catch((error) => {\n          console.error('Error processing file:', error);\n        });\n    }\n    this.cdr.detectChanges();\n  }\n\n  override canAdvance(): boolean {\n    this.cdr.detectChanges();\n    let canProceed = false;\n\n    if (this.isValid()) {\n      canProceed = true;\n    }\n\n    return canProceed;\n  }\n\n  getNewUploadPayload(): ApplicationUploadDocumentsDto {\n    let uploadPayload = new ApplicationUploadDocumentsDto();\n    uploadPayload.appDataId = this.appDataId;\n    uploadPayload.appId = this.appId;\n    uploadPayload.controlId = this.controlData.identifier;\n    uploadPayload.env = this.env;\n    uploadPayload.documents = [];\n\n    return uploadPayload;\n  }\n}\n","<p *ngIf=\"title\">\n  {{ title }}\n</p>\n\n<table>\n  <thead class=\"table-head\">\n    <tr>\n      <th>\n        {{ \"document\" | translate }}\n      </th>\n      <th>\n        {{ \"format\" | translate }}\n      </th>\n      <th>\n        {{ \"flux.components.uploadDocument.maxSize\" | translate }}\n      </th>\n      <th>\n        {{ \"stepControl.mandatory\" | translate }}\n      </th>\n    </tr>\n  </thead>\n  <tbody class=\"table-detail\">\n    <tr *ngFor=\"let doc of documents; let i = index\">\n      <td>\n        {{ doc.documentName }}\n      </td>\n      <td>\n        {{ doc.documentExtensions }}\n      </td>\n      <td>\n        {{ doc.documentMaxSize }}\n      </td>\n      <td>\n        {{ (doc.isMandatory ? \"yes\" : \"no\") | translate }}\n      </td>\n      <td>\n        <div>\n          <input\n            type=\"file\"\n            #fileInput\n            (change)=\"selectFile($event, doc)\"\n            hidden\n          />\n          <button\n            mat-flat-button\n            color=\"primary\"\n            (click)=\"fileInput.click()\"\n            [disabled]=\"this.isDisabled\"\n          >\n            <mat-icon>cloud_upload</mat-icon>\n            {{\n              doc.fileName\n                ? doc.fileName\n                : (\"common.actions.upload\" | translate)\n            }}\n          </button>\n        </div>\n      </td>\n      <td *ngIf=\"doc.fileName\">\n        <i-tabler\n          *ngIf=\"\n            doc.isUploading === false &&\n            doc.isUploadSuccess === true &&\n            doc.fileName\n          \"\n          class=\"icon-25 text-white bg-primary rounded\"\n          name=\"check\"\n        ></i-tabler>\n        <mat-spinner\n          *ngIf=\"doc.isUploading === true\"\n          class=\"m-x-auto upload-spinner\"\n        ></mat-spinner>\n      </td>\n    </tr>\n  </tbody>\n</table>\n"]}
@@ -0,0 +1,124 @@
1
+ import { Component, } from '@angular/core';
2
+ import { FormControl, Validators } from '@angular/forms';
3
+ import { BehaviorSubject } from 'rxjs';
4
+ import { FluxType } from '../../models/forms.model';
5
+ import { LabelKeys } from '../../enums/label.keys';
6
+ import { BaseFormlyStepComponent } from '../baseFormlyStepComponent';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../services/otp.service";
9
+ import * as i2 from "../../services/dialog.service";
10
+ import * as i3 from "@angular/common";
11
+ import * as i4 from "@angular/forms";
12
+ import * as i5 from "@angular/material/input";
13
+ import * as i6 from "@angular/material/form-field";
14
+ import * as i7 from "@angular/material/button";
15
+ export class FormlyValidateContactInfoComponent extends BaseFormlyStepComponent {
16
+ constructor(otpService, dialog, cdr) {
17
+ super(cdr);
18
+ this.otpService = otpService;
19
+ this.dialog = dialog;
20
+ this._otpButtonStyle = {};
21
+ this.control = new FormControl('', [Validators.required]);
22
+ this.otp = new FormControl('', [Validators.required]);
23
+ this.sent = new BehaviorSubject(false);
24
+ this.popMessageKeys = LabelKeys.popMessages;
25
+ this.otpValidated = new BehaviorSubject(false);
26
+ }
27
+ ngAfterViewInit() { }
28
+ onPageSelected() {
29
+ const styleObj = this.props?.['design']?.['.button-otpaction'];
30
+ if (styleObj) {
31
+ const camelCaseStyle = {};
32
+ Object.keys(styleObj).forEach((key) => {
33
+ const camelKey = key.replace(/-([a-z])/g, (g) => g[1].toUpperCase());
34
+ camelCaseStyle[camelKey] = styleObj[key];
35
+ });
36
+ this._otpButtonStyle = camelCaseStyle;
37
+ }
38
+ else {
39
+ this._otpButtonStyle = {};
40
+ }
41
+ const group = this.form;
42
+ group.addControl(this.stepData.sections[0].controls[0].identifier, this.control);
43
+ if (this.stepData) {
44
+ if (this.stepData.type == FluxType.Email) {
45
+ this.isEmail = true;
46
+ this.control.setValidators([Validators.required, Validators.email]);
47
+ this.control.updateValueAndValidity();
48
+ }
49
+ if (this.stepData.type == FluxType.Phone) {
50
+ this.isEmail = false;
51
+ this.control.setValidators([
52
+ Validators.required,
53
+ Validators.pattern('^(\\+40|40|0)?(7[0-8][0-9]|2[0-9]{2}|3[0-9]{2})([\\s\\.-]?\\d{3}){2}$'),
54
+ ]);
55
+ this.control.updateValueAndValidity();
56
+ }
57
+ if (this.stepData.config.collected) {
58
+ const value = this.form.get(this.stepData.config.componentCollected)?.value;
59
+ this.control.setValue(value);
60
+ this.form
61
+ .get(this.stepData.config.componentCollected)
62
+ ?.valueChanges.subscribe(() => {
63
+ this.control.setValue(this.form.get(this.stepData.config.componentCollected)?.value);
64
+ });
65
+ }
66
+ this.buttonText =
67
+ this.stepData.type === FluxType.Email
68
+ ? this.props['labels']?.emailButtonLabel
69
+ : this.props['labels']?.phoneButtonLabel;
70
+ }
71
+ }
72
+ get otpButtonStyle() {
73
+ return this._otpButtonStyle;
74
+ }
75
+ sendOtp() {
76
+ this.control.markAsTouched();
77
+ if (this.control.valid) {
78
+ this.otpService
79
+ .generate({
80
+ phoneNumber: this.stepData.type == FluxType.Phone ? this.control.value : null,
81
+ emailAddress: this.stepData.type == FluxType.Email ? this.control.value : null,
82
+ appDataId: this.appDataId,
83
+ stepId: this.stepData.identifier,
84
+ })
85
+ .subscribe({
86
+ next: (response) => {
87
+ if (response.ok && response.body === true) {
88
+ this.sent.next(true);
89
+ }
90
+ },
91
+ });
92
+ }
93
+ }
94
+ validateOtp() {
95
+ this.otp.markAsTouched();
96
+ if (this.otp.valid) {
97
+ this.otpService
98
+ .validate({
99
+ otpCode: this.otp.value,
100
+ appDataId: this.appDataId,
101
+ stepId: this.stepData.identifier,
102
+ })
103
+ .subscribe({
104
+ next: (response) => {
105
+ if (response.ok && response.body === true) {
106
+ this.dialog.popSuccess(this.props['labels'].otpSuccessLabel);
107
+ this.otpValidated.next(true);
108
+ this.onEvent('success');
109
+ }
110
+ else {
111
+ this.dialog.popError(this.props['labels'].otpErrorLabel);
112
+ }
113
+ },
114
+ });
115
+ }
116
+ }
117
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyValidateContactInfoComponent, deps: [{ token: i1.OtpService }, { token: i2.DialogService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
118
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormlyValidateContactInfoComponent, selector: "app-formly-validate-contact-info", usesInheritance: true, ngImport: i0, template: "<div class=\"component-text-field\">\n <div *ngIf=\"!(sent | async); else otpTemplate\">\n <mat-form-field class=\"full-width\">\n <mat-label>\n {{ isEmail ? props[\"labels\"].emailLabel : props[\"labels\"].phoneLabel }}\n </mat-label>\n <input\n matInput\n type=\"text\"\n [formControl]=\"control\"\n [readonly]=\"stepData.config.collected\"\n />\n </mat-form-field>\n <div\n *ngIf=\"\n control.invalid &&\n (control.dirty || control.touched) &&\n control.hasError('required')\n \"\n class=\"alert alert-danger\"\n >\n {{\n isEmail\n ? props[\"labels\"].emailRequiredLabel\n : props[\"labels\"].phoneRequiredLabel\n }}\n </div>\n <div\n *ngIf=\"\n control.invalid &&\n (control.dirty || control.touched) &&\n !control.hasError('required')\n \"\n class=\"alert alert-danger\"\n >\n {{\n isEmail\n ? props[\"labels\"].emailErrorLabel\n : props[\"labels\"].phoneErrorLabel\n }}\n </div>\n <button\n mat-button\n type=\"button\"\n [ngStyle]=\"otpButtonStyle\"\n (click)=\"sendOtp()\"\n >\n {{ buttonText }}\n </button>\n </div>\n</div>\n\n<ng-template #otpTemplate>\n <mat-form-field class=\"full-width\">\n <mat-label>\n {{ props[\"labels\"].otpLabel }}\n </mat-label>\n <input matInput type=\"text\" [formControl]=\"otp\" />\n </mat-form-field>\n <button\n mat-button\n type=\"button\"\n *ngIf=\"!(otpValidated | async)\"\n [ngStyle]=\"otpButtonStyle\"\n (click)=\"validateOtp()\"\n >\n {{ props[\"labels\"].otpButtonLabel }}\n </button>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "component", type: i7.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); }
119
+ }
120
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyValidateContactInfoComponent, decorators: [{
121
+ type: Component,
122
+ args: [{ selector: 'app-formly-validate-contact-info', template: "<div class=\"component-text-field\">\n <div *ngIf=\"!(sent | async); else otpTemplate\">\n <mat-form-field class=\"full-width\">\n <mat-label>\n {{ isEmail ? props[\"labels\"].emailLabel : props[\"labels\"].phoneLabel }}\n </mat-label>\n <input\n matInput\n type=\"text\"\n [formControl]=\"control\"\n [readonly]=\"stepData.config.collected\"\n />\n </mat-form-field>\n <div\n *ngIf=\"\n control.invalid &&\n (control.dirty || control.touched) &&\n control.hasError('required')\n \"\n class=\"alert alert-danger\"\n >\n {{\n isEmail\n ? props[\"labels\"].emailRequiredLabel\n : props[\"labels\"].phoneRequiredLabel\n }}\n </div>\n <div\n *ngIf=\"\n control.invalid &&\n (control.dirty || control.touched) &&\n !control.hasError('required')\n \"\n class=\"alert alert-danger\"\n >\n {{\n isEmail\n ? props[\"labels\"].emailErrorLabel\n : props[\"labels\"].phoneErrorLabel\n }}\n </div>\n <button\n mat-button\n type=\"button\"\n [ngStyle]=\"otpButtonStyle\"\n (click)=\"sendOtp()\"\n >\n {{ buttonText }}\n </button>\n </div>\n</div>\n\n<ng-template #otpTemplate>\n <mat-form-field class=\"full-width\">\n <mat-label>\n {{ props[\"labels\"].otpLabel }}\n </mat-label>\n <input matInput type=\"text\" [formControl]=\"otp\" />\n </mat-form-field>\n <button\n mat-button\n type=\"button\"\n *ngIf=\"!(otpValidated | async)\"\n [ngStyle]=\"otpButtonStyle\"\n (click)=\"validateOtp()\"\n >\n {{ props[\"labels\"].otpButtonLabel }}\n </button>\n</ng-template>\n" }]
123
+ }], ctorParameters: () => [{ type: i1.OtpService }, { type: i2.DialogService }, { type: i0.ChangeDetectorRef }] });
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-validate-contact-info.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-validate-contact-info/formly-validate-contact-info.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-validate-contact-info/formly-validate-contact-info.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  AfterViewInit,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { OtpService } from '../../services/otp.service';\nimport { BehaviorSubject } from 'rxjs';\nimport { FluxType } from '../../models/forms.model';\nimport { DialogService } from '../../services/dialog.service';\nimport { LabelKeys } from '../../enums/label.keys';\nimport { BaseFormlyStepComponent } from '../baseFormlyStepComponent';\n\n@Component({\n  selector: 'app-formly-validate-contact-info',\n  templateUrl: './formly-validate-contact-info.component.html',\n  styleUrl: './formly-validate-contact-info.component.scss',\n})\nexport class FormlyValidateContactInfoComponent\n  extends BaseFormlyStepComponent\n  implements OnInit, AfterViewInit\n{\n  private _otpButtonStyle: { [key: string]: string } = {};\n  control: FormControl = new FormControl('', [Validators.required]);\n  otp: FormControl = new FormControl('', [Validators.required]);\n\n  sent: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  isEmail: boolean;\n  popMessageKeys = LabelKeys.popMessages;\n  otpValidated: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  buttonText: '';\n\n  constructor(\n    private otpService: OtpService,\n    private dialog: DialogService,\n    cdr: ChangeDetectorRef\n  ) {\n    super(cdr);\n  }\n\n  ngAfterViewInit(): void {}\n\n  override onPageSelected() {\n    const styleObj = this.props?.['design']?.['.button-otpaction'];\n    if (styleObj) {\n      const camelCaseStyle: { [key: string]: string } = {};\n      Object.keys(styleObj).forEach((key) => {\n        const camelKey = key.replace(/-([a-z])/g, (g) => g[1].toUpperCase());\n        camelCaseStyle[camelKey] = styleObj[key];\n      });\n      this._otpButtonStyle = camelCaseStyle;\n    } else {\n      this._otpButtonStyle = {};\n    }\n    const group = this.form as FormGroup;\n    group.addControl(\n      this.stepData.sections[0].controls[0].identifier,\n      this.control\n    );\n\n    if (this.stepData) {\n      if (this.stepData.type == FluxType.Email) {\n        this.isEmail = true;\n        this.control.setValidators([Validators.required, Validators.email]);\n        this.control.updateValueAndValidity();\n      }\n\n      if (this.stepData.type == FluxType.Phone) {\n        this.isEmail = false;\n        this.control.setValidators([\n          Validators.required,\n          Validators.pattern(\n            '^(\\\\+40|40|0)?(7[0-8][0-9]|2[0-9]{2}|3[0-9]{2})([\\\\s\\\\.-]?\\\\d{3}){2}$'\n          ),\n        ]);\n        this.control.updateValueAndValidity();\n      }\n\n      if (this.stepData.config.collected) {\n        const value = this.form.get(\n          this.stepData.config.componentCollected\n        )?.value;\n        this.control.setValue(value);\n\n        this.form\n          .get(this.stepData.config.componentCollected)\n          ?.valueChanges.subscribe(() => {\n            this.control.setValue(\n              this.form.get(this.stepData.config.componentCollected)?.value\n            );\n          });\n      }\n\n      this.buttonText =\n        this.stepData.type === FluxType.Email\n          ? this.props['labels']?.emailButtonLabel\n          : this.props['labels']?.phoneButtonLabel;\n    }\n  }\n\n  get otpButtonStyle(): { [key: string]: string } {\n    return this._otpButtonStyle;\n  }\n\n  sendOtp() {\n    this.control.markAsTouched();\n\n    if (this.control.valid) {\n      this.otpService\n        .generate({\n          phoneNumber:\n            this.stepData.type == FluxType.Phone ? this.control.value : null,\n          emailAddress:\n            this.stepData.type == FluxType.Email ? this.control.value : null,\n          appDataId: this.appDataId,\n          stepId: this.stepData.identifier,\n        })\n        .subscribe({\n          next: (response) => {\n            if (response.ok && response.body === true) {\n              this.sent.next(true);\n            }\n          },\n        });\n    }\n  }\n\n  validateOtp() {\n    this.otp.markAsTouched();\n\n    if (this.otp.valid) {\n      this.otpService\n        .validate({\n          otpCode: this.otp.value,\n          appDataId: this.appDataId,\n          stepId: this.stepData.identifier,\n        })\n        .subscribe({\n          next: (response) => {\n            if (response.ok && response.body === true) {\n              this.dialog.popSuccess(this.props['labels'].otpSuccessLabel);\n              this.otpValidated.next(true);\n              this.onEvent('success');\n            } else {\n              this.dialog.popError(this.props['labels'].otpErrorLabel);\n            }\n          },\n        });\n    }\n  }\n}\n","<div class=\"component-text-field\">\n  <div *ngIf=\"!(sent | async); else otpTemplate\">\n    <mat-form-field class=\"full-width\">\n      <mat-label>\n        {{ isEmail ? props[\"labels\"].emailLabel : props[\"labels\"].phoneLabel }}\n      </mat-label>\n      <input\n        matInput\n        type=\"text\"\n        [formControl]=\"control\"\n        [readonly]=\"stepData.config.collected\"\n      />\n    </mat-form-field>\n    <div\n      *ngIf=\"\n        control.invalid &&\n        (control.dirty || control.touched) &&\n        control.hasError('required')\n      \"\n      class=\"alert alert-danger\"\n    >\n      {{\n        isEmail\n          ? props[\"labels\"].emailRequiredLabel\n          : props[\"labels\"].phoneRequiredLabel\n      }}\n    </div>\n    <div\n      *ngIf=\"\n        control.invalid &&\n        (control.dirty || control.touched) &&\n        !control.hasError('required')\n      \"\n      class=\"alert alert-danger\"\n    >\n      {{\n        isEmail\n          ? props[\"labels\"].emailErrorLabel\n          : props[\"labels\"].phoneErrorLabel\n      }}\n    </div>\n    <button\n      mat-button\n      type=\"button\"\n      [ngStyle]=\"otpButtonStyle\"\n      (click)=\"sendOtp()\"\n    >\n      {{ buttonText }}\n    </button>\n  </div>\n</div>\n\n<ng-template #otpTemplate>\n  <mat-form-field class=\"full-width\">\n    <mat-label>\n      {{ props[\"labels\"].otpLabel }}\n    </mat-label>\n    <input matInput type=\"text\" [formControl]=\"otp\" />\n  </mat-form-field>\n  <button\n    mat-button\n    type=\"button\"\n    *ngIf=\"!(otpValidated | async)\"\n    [ngStyle]=\"otpButtonStyle\"\n    (click)=\"validateOtp()\"\n  >\n    {{ props[\"labels\"].otpButtonLabel }}\n  </button>\n</ng-template>\n"]}