@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,245 @@
1
+ import { Component } from '@angular/core';
2
+ import { Utils } from '../../others/utils';
3
+ import { firstValueFrom } from 'rxjs';
4
+ import { BaseFormlyControlComponent } from '../baseFormlyControlComponent';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../../services/applicationData.service";
7
+ import * as i2 from "../../services/dialog.service";
8
+ import * as i3 from "@angular/common";
9
+ import * as i4 from "ng2-pdf-viewer";
10
+ import * as i5 from "@angular/material/progress-spinner";
11
+ export class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {
12
+ constructor(appDataService, dialog, cdr) {
13
+ super(cdr);
14
+ this.appDataService = appDataService;
15
+ this.dialog = dialog;
16
+ this.documents = [];
17
+ this.currentIndex = 0;
18
+ this.currentPdf = '';
19
+ this.cachedDocuments = {};
20
+ }
21
+ onInit() {
22
+ if (this.isDisplayMode === true) {
23
+ this.getDocuments();
24
+ }
25
+ }
26
+ getDocuments() {
27
+ const configDocs = this.controlData?.specificControlData?.documents;
28
+ if (configDocs) {
29
+ this.isLoading = true;
30
+ let cmd = {
31
+ appDataId: this.appDataId,
32
+ controlId: this.controlData.identifier,
33
+ isDisplayMode: this.isDisplayMode,
34
+ appConfigurationUUID: this.appId,
35
+ environment: this.env,
36
+ };
37
+ this.appDataService.getGenerateDocuments(cmd).subscribe({
38
+ next: (result) => {
39
+ this.isLoading = false;
40
+ this.documents = this.orderDocumentsAsConfigured(result);
41
+ if (this.documents && this.documents.length > 0) {
42
+ this.showDocument(this.documents[0]);
43
+ }
44
+ this.checkCanGoBackNext();
45
+ this.cdr.detectChanges();
46
+ },
47
+ error: (err) => {
48
+ this.isLoading = false;
49
+ this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'failToView');
50
+ this.cdr.detectChanges();
51
+ },
52
+ });
53
+ }
54
+ this.cdr.detectChanges();
55
+ }
56
+ orderDocumentsAsConfigured(documents) {
57
+ let list = [];
58
+ if (documents) {
59
+ const configuradDocuments = this.controlData?.specificControlData?.documents;
60
+ if (configuradDocuments) {
61
+ configuradDocuments.forEach((d) => {
62
+ const found = documents.find((f) => f.documentId === d.id);
63
+ if (found) {
64
+ list.push(found);
65
+ }
66
+ });
67
+ }
68
+ }
69
+ return list;
70
+ }
71
+ retry() {
72
+ this.getDocuments();
73
+ }
74
+ onPageSelected() {
75
+ this.getDocuments();
76
+ }
77
+ async showDocument(doc) {
78
+ this.currentDocument = doc;
79
+ const cached = this.cachedDocuments[doc.documentId];
80
+ if (cached) {
81
+ this.currentPdf = cached;
82
+ }
83
+ else {
84
+ this.isLoading = true;
85
+ if (doc.isApiDocument === true) {
86
+ let apiRequest = {
87
+ appDataId: this.appDataId,
88
+ documentId: doc.documentId,
89
+ };
90
+ this.appDataService.doDocumentRequest(apiRequest).subscribe({
91
+ next: (docs) => {
92
+ if (docs && docs.length > 0) {
93
+ docs.forEach((d) => {
94
+ const b64 = Utils.base64toBlob(d.content);
95
+ this.blobToArrayBuffer(b64).then((r) => {
96
+ if (d.documentId === doc.documentId) {
97
+ this.setCurrentDocument(doc.documentId, r);
98
+ }
99
+ this.cachedDocuments[d.documentId] = r;
100
+ });
101
+ });
102
+ }
103
+ else {
104
+ this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'noDocumentsToShow');
105
+ }
106
+ },
107
+ error: (err) => {
108
+ this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'failToView');
109
+ this.isLoading = false;
110
+ this.cdr.detectChanges();
111
+ },
112
+ });
113
+ }
114
+ else if (doc.content) {
115
+ // Document has content directly available - convert to blob
116
+ let content = doc.content;
117
+ // Check if content is a data URL and extract the base64 part
118
+ if (content.startsWith('data:')) {
119
+ const base64Start = content.indexOf(',');
120
+ if (base64Start !== -1) {
121
+ content = content.substring(base64Start + 1);
122
+ }
123
+ }
124
+ // Check if document needs PDF conversion
125
+ const originalContent = doc.content;
126
+ const isPdf = originalContent.includes('data:application/pdf') ||
127
+ originalContent.includes('application/pdf');
128
+ if (!isPdf) {
129
+ // For non-PDF documents, we need to convert to PDF or handle differently
130
+ console.warn('Non-PDF document detected. Converting to PDF...', doc.name);
131
+ // Call backend conversion API
132
+ this.convertToPdf(content, doc).then((pdfContent) => {
133
+ if (pdfContent) {
134
+ this.setCurrentDocument(doc.documentId, pdfContent);
135
+ }
136
+ else {
137
+ this.isLoading = false;
138
+ this.cdr.detectChanges();
139
+ }
140
+ });
141
+ }
142
+ else {
143
+ const b64 = Utils.base64toBlob(content);
144
+ this.blobToArrayBuffer(b64).then((r) => {
145
+ this.setCurrentDocument(doc.documentId, r);
146
+ });
147
+ }
148
+ }
149
+ else {
150
+ // Download file case
151
+ this.appDataService
152
+ .downloadFile(this.props['appDataId'], doc.documentId, doc.fileName)
153
+ .subscribe({
154
+ next: (data) => {
155
+ this.blobToArrayBuffer(data).then((r) => {
156
+ this.setCurrentDocument(doc.documentId, r);
157
+ });
158
+ },
159
+ error: (err) => {
160
+ this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'failToView');
161
+ this.isLoading = false;
162
+ this.cdr.detectChanges();
163
+ },
164
+ });
165
+ }
166
+ }
167
+ }
168
+ setCurrentDocument(documentId, r) {
169
+ this.cachedDocuments[documentId] = r;
170
+ this.currentPdf = r;
171
+ this.isLoading = false;
172
+ this.cdr.detectChanges();
173
+ }
174
+ blobToArrayBuffer(blob) {
175
+ return new Promise((resolve, _) => {
176
+ const reader = new FileReader();
177
+ reader.onloadend = () => resolve(reader.result);
178
+ reader.readAsDataURL(blob);
179
+ });
180
+ }
181
+ nextDocument() {
182
+ if (this.currentIndex < this.documents.length) {
183
+ this.currentIndex++;
184
+ this.showDocument(this.documents[this.currentIndex]);
185
+ }
186
+ this.checkCanGoBackNext();
187
+ }
188
+ prevDocument() {
189
+ if (this.currentIndex >= 0) {
190
+ this.currentIndex--;
191
+ this.showDocument(this.documents[this.currentIndex]);
192
+ }
193
+ this.checkCanGoBackNext();
194
+ }
195
+ checkCanGoBackNext() {
196
+ if (this.currentIndex === 0) {
197
+ this.canGoBack = false;
198
+ }
199
+ else {
200
+ this.canGoBack = true;
201
+ }
202
+ if (this.currentIndex < this.documents.length - 1) {
203
+ this.canGoNext = true;
204
+ }
205
+ else {
206
+ this.canGoNext = false;
207
+ }
208
+ }
209
+ async convertToPdf(content, doc) {
210
+ // Call backend API to convert document to PDF
211
+ try {
212
+ const conversionRequest = {
213
+ content: content,
214
+ fileName: doc.name,
215
+ documentId: doc.documentId,
216
+ appDataId: this.appDataId,
217
+ appConfigurationUUID: this.appId,
218
+ environment: this.env,
219
+ };
220
+ const response = await firstValueFrom(this.appDataService.convertDocumentToPdf(conversionRequest));
221
+ if (response?.success && response.pdfContent) {
222
+ // Convert PDF base64 to blob and return
223
+ const pdfBlob = Utils.base64toBlob(response.pdfContent);
224
+ return this.blobToArrayBuffer(pdfBlob);
225
+ }
226
+ else {
227
+ console.error('PDF conversion failed:', response?.errorMessage);
228
+ this.dialog.popError(response?.errorMessage || 'Failed to convert document to PDF');
229
+ return null;
230
+ }
231
+ }
232
+ catch (error) {
233
+ console.error('PDF conversion failed:', error);
234
+ this.dialog.popError('Failed to convert document to PDF');
235
+ return null;
236
+ }
237
+ }
238
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyViewDocumentsComponent, deps: [{ token: i1.ApplicationDataService }, { token: i2.DialogService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
239
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormlyViewDocumentsComponent, selector: "app-formly-view-documents", usesInheritance: true, ngImport: i0, template: "<p *ngIf=\"isLoading === false && (!documents || documents.length === 0)\">\n {{ getErrorTranslationMessage(\"noDocumentsToShow\") }}\n</p>\n\n<div class=\"buttons-container\">\n <button (click)=\"prevDocument()\"\n [disabled]=\"!canGoBack\"\n class=\"nav-button larger-width-nav-buttons\">\n &#8592;\n </button>\n\n <p class=\"file-info font-paragraph\" *ngIf=\"currentDocument\">\n {{ this.currentDocument.name }}\n </p>\n\n <button (click)=\"nextDocument()\"\n [disabled]=\"!canGoNext\"\n class=\"nav-button larger-width-nav-buttons\">\n &#8594;\n </button>\n</div>\n\n<mat-spinner *ngIf=\"isLoading === true\" class=\"m-x-auto\"></mat-spinner>\n<pdf-viewer *ngIf=\"isLoading === false\"\n [src]=\"currentPdf\"\n [render-text]=\"true\"\n [original-size]=\"false\"\n [external-link-target]=\"'blank'\"\n class=\"pdf-viewer\"></pdf-viewer>\n", styles: [".buttons-container button{margin-right:5px;margin-bottom:10px;margin-top:10px}ng2-pdf-viewer{display:block;margin:0 auto;width:80%;height:600px}.pdf-viewer-container{display:flex;flex-direction:column;align-items:center;margin:20px}.pdf-viewer{width:80vw;height:86.254vw;max-width:1000px;max-height:1414px;min-width:300px;min-height:424px;overflow:auto;margin:auto}.nav-button{width:60px;height:35px;background-color:#7f81ff;display:flex;justify-content:center;align-items:center;color:#fff;text-align:center;border:none;padding:5px 10px;border-radius:10px;cursor:pointer;font-size:1.4rem;font-weight:700;transition:background-color .3s ease-in}.smaller-width-nav-buttons-section{display:none}.nav-button:hover{background-color:#9091ff}.nav-button:disabled{background-color:#ccc;cursor:not-allowed}.file-info{margin:0 10px;font-weight:700;font-size:1.8rem}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.PdfViewerComponent, selector: "pdf-viewer", inputs: ["src", "c-maps-url", "page", "render-text", "render-text-mode", "original-size", "show-all", "stick-to-page", "zoom", "zoom-scale", "rotation", "external-link-target", "autoresize", "fit-to-page", "show-borders"], outputs: ["after-load-complete", "page-rendered", "pages-initialized", "text-layer-rendered", "error", "on-progress", "pageChange"] }, { kind: "component", type: i5.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }] }); }
240
+ }
241
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyViewDocumentsComponent, decorators: [{
242
+ type: Component,
243
+ args: [{ selector: 'app-formly-view-documents', template: "<p *ngIf=\"isLoading === false && (!documents || documents.length === 0)\">\n {{ getErrorTranslationMessage(\"noDocumentsToShow\") }}\n</p>\n\n<div class=\"buttons-container\">\n <button (click)=\"prevDocument()\"\n [disabled]=\"!canGoBack\"\n class=\"nav-button larger-width-nav-buttons\">\n &#8592;\n </button>\n\n <p class=\"file-info font-paragraph\" *ngIf=\"currentDocument\">\n {{ this.currentDocument.name }}\n </p>\n\n <button (click)=\"nextDocument()\"\n [disabled]=\"!canGoNext\"\n class=\"nav-button larger-width-nav-buttons\">\n &#8594;\n </button>\n</div>\n\n<mat-spinner *ngIf=\"isLoading === true\" class=\"m-x-auto\"></mat-spinner>\n<pdf-viewer *ngIf=\"isLoading === false\"\n [src]=\"currentPdf\"\n [render-text]=\"true\"\n [original-size]=\"false\"\n [external-link-target]=\"'blank'\"\n class=\"pdf-viewer\"></pdf-viewer>\n", styles: [".buttons-container button{margin-right:5px;margin-bottom:10px;margin-top:10px}ng2-pdf-viewer{display:block;margin:0 auto;width:80%;height:600px}.pdf-viewer-container{display:flex;flex-direction:column;align-items:center;margin:20px}.pdf-viewer{width:80vw;height:86.254vw;max-width:1000px;max-height:1414px;min-width:300px;min-height:424px;overflow:auto;margin:auto}.nav-button{width:60px;height:35px;background-color:#7f81ff;display:flex;justify-content:center;align-items:center;color:#fff;text-align:center;border:none;padding:5px 10px;border-radius:10px;cursor:pointer;font-size:1.4rem;font-weight:700;transition:background-color .3s ease-in}.smaller-width-nav-buttons-section{display:none}.nav-button:hover{background-color:#9091ff}.nav-button:disabled{background-color:#ccc;cursor:not-allowed}.file-info{margin:0 10px;font-weight:700;font-size:1.8rem}\n"] }]
244
+ }], ctorParameters: () => [{ type: i1.ApplicationDataService }, { type: i2.DialogService }, { type: i0.ChangeDetectorRef }] });
245
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-view-documents.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-view-documents/formly-view-documents.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-view-documents/formly-view-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component } from '@angular/core';\nimport { ApplicationDataService } from '../../services/applicationData.service';\nimport { DialogService } from '../../services/dialog.service';\nimport { ApiDocumentRequest, ApplicationGetGeneratedDocumentsDto, ConvertDocumentToPdfRequest, GeneratedDocument } from '../../models/application.model';\nimport { Utils } from '../../others/utils';\nimport { firstValueFrom } from 'rxjs';\nimport { BaseFormlyControlComponent } from '../baseFormlyControlComponent';\n\n@Component({\n  selector: 'app-formly-view-documents',\n  templateUrl: './formly-view-documents.component.html',\n  styleUrl: './formly-view-documents.component.scss',\n})\nexport class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {\n  documents: GeneratedDocument[] = [];\n  isDownloading: boolean;\n  currentIndex: number = 0;\n  canGoBack: boolean;\n  canGoNext: boolean;\n\n  currentPdf: any = '';\n  currentDocument: GeneratedDocument;\n  cachedDocuments: any = {};\n\n  constructor(\n    private appDataService: ApplicationDataService,\n    private dialog: DialogService,\n    cdr: ChangeDetectorRef\n  ) {\n    super(cdr);\n  }\n\n  override onInit() {\n    if (this.isDisplayMode === true) {\n      this.getDocuments();\n    }\n  }\n\n  getDocuments() {\n    const configDocs = this.controlData?.specificControlData?.documents;\n    if (configDocs) {\n      this.isLoading = true;\n      let cmd: ApplicationGetGeneratedDocumentsDto = {\n        appDataId: this.appDataId,\n        controlId: this.controlData.identifier,\n        isDisplayMode: this.isDisplayMode,\n        appConfigurationUUID: this.appId,\n        environment: this.env,\n      };\n\n      this.appDataService.getGenerateDocuments(cmd).subscribe({\n        next: (result) => {\n          this.isLoading = false;\n          this.documents = this.orderDocumentsAsConfigured(result);\n          if (this.documents && this.documents.length > 0) {\n            this.showDocument(this.documents[0]);\n          }\n          this.checkCanGoBackNext();\n          this.cdr.detectChanges();\n        },\n        error: (err) => {\n          this.isLoading = false;\n\n          this.dialog.popErrorTranslation(\n            this.controlData.errorsTranslations,\n            this.langIso,\n            'failToView'\n          );\n\n          this.cdr.detectChanges();\n        },\n      });\n    }\n    this.cdr.detectChanges();\n  }\n\n  orderDocumentsAsConfigured(\n    documents: GeneratedDocument[]\n  ): GeneratedDocument[] {\n    let list: GeneratedDocument[] = [];\n    if (documents) {\n      const configuradDocuments =\n        this.controlData?.specificControlData?.documents;\n      if (configuradDocuments) {\n        configuradDocuments.forEach((d: any) => {\n          const found = documents.find((f: any) => f.documentId === d.id);\n          if (found) {\n            list.push(found);\n          }\n        });\n      }\n    }\n    return list;\n  }\n\n  retry() {\n    this.getDocuments();\n  }\n\n  override onPageSelected() {\n    this.getDocuments();\n  }\n\n  async showDocument(doc: GeneratedDocument) {\n    this.currentDocument = doc;\n    const cached = this.cachedDocuments[doc.documentId];\n    if (cached) {\n      this.currentPdf = cached;\n    } else {\n      this.isLoading = true;\n      if (doc.isApiDocument === true) {\n        let apiRequest: ApiDocumentRequest = {\n          appDataId: this.appDataId,\n          documentId: doc.documentId,\n        };\n        this.appDataService.doDocumentRequest(apiRequest).subscribe({\n          next: (docs) => {\n            if (docs && docs.length > 0) {\n              docs.forEach((d) => {\n                const b64 = Utils.base64toBlob(d.content);\n                this.blobToArrayBuffer(b64).then((r) => {\n                  if (d.documentId === doc.documentId) {\n                    this.setCurrentDocument(doc.documentId, r);\n                  }\n                  this.cachedDocuments[d.documentId] = r;\n                });\n              });\n            } else {\n              this.dialog.popErrorTranslation(\n                this.controlData.errorsTranslations,\n                this.langIso,\n                'noDocumentsToShow'\n              );\n            }\n          },\n          error: (err) => {\n            this.dialog.popErrorTranslation(\n              this.controlData.errorsTranslations,\n              this.langIso,\n              'failToView'\n            );\n            this.isLoading = false;\n            this.cdr.detectChanges();\n          },\n        });\n      } else if ((doc as any).content) {\n        // Document has content directly available - convert to blob\n        let content = (doc as any).content;\n\n        // Check if content is a data URL and extract the base64 part\n        if (content.startsWith('data:')) {\n          const base64Start = content.indexOf(',');\n          if (base64Start !== -1) {\n            content = content.substring(base64Start + 1);\n          }\n        }\n\n        // Check if document needs PDF conversion\n        const originalContent = (doc as any).content;\n        const isPdf =\n          originalContent.includes('data:application/pdf') ||\n          originalContent.includes('application/pdf');\n\n        if (!isPdf) {\n          // For non-PDF documents, we need to convert to PDF or handle differently\n          console.warn(\n            'Non-PDF document detected. Converting to PDF...',\n            doc.name\n          );\n          // Call backend conversion API\n          this.convertToPdf(content, doc).then((pdfContent) => {\n            if (pdfContent) {\n              this.setCurrentDocument(doc.documentId, pdfContent);\n            } else {\n              this.isLoading = false;\n              this.cdr.detectChanges();\n            }\n          });\n        } else {\n          const b64 = Utils.base64toBlob(content);\n          this.blobToArrayBuffer(b64).then((r) => {\n            this.setCurrentDocument(doc.documentId, r);\n          });\n        }\n      } else {\n        // Download file case\n        this.appDataService\n          .downloadFile(this.props['appDataId'], doc.documentId, doc.fileName)\n          .subscribe({\n            next: (data) => {\n              this.blobToArrayBuffer(data).then((r) => {\n                this.setCurrentDocument(doc.documentId, r);\n              });\n            },\n            error: (err) => {\n              this.dialog.popErrorTranslation(\n                this.controlData.errorsTranslations,\n                this.langIso,\n                'failToView'\n              );\n              this.isLoading = false;\n              this.cdr.detectChanges();\n            },\n          });\n      }\n    }\n  }\n\n  setCurrentDocument(documentId: string, r: any) {\n    this.cachedDocuments[documentId] = r;\n    this.currentPdf = r;\n    this.isLoading = false;\n    this.cdr.detectChanges();\n  }\n\n  blobToArrayBuffer(blob: any) {\n    return new Promise((resolve, _) => {\n      const reader = new FileReader();\n      reader.onloadend = () => resolve(reader.result);\n      reader.readAsDataURL(blob);\n    });\n  }\n\n  nextDocument() {\n    if (this.currentIndex < this.documents.length) {\n      this.currentIndex++;\n      this.showDocument(this.documents[this.currentIndex]);\n    }\n    this.checkCanGoBackNext();\n  }\n\n  prevDocument() {\n    if (this.currentIndex >= 0) {\n      this.currentIndex--;\n      this.showDocument(this.documents[this.currentIndex]);\n    }\n    this.checkCanGoBackNext();\n  }\n\n  checkCanGoBackNext() {\n    if (this.currentIndex === 0) {\n      this.canGoBack = false;\n    } else {\n      this.canGoBack = true;\n    }\n    if (this.currentIndex < this.documents.length - 1) {\n      this.canGoNext = true;\n    } else {\n      this.canGoNext = false;\n    }\n  }\n\n  private async convertToPdf(\n    content: string,\n    doc: GeneratedDocument\n  ): Promise<any> {\n    // Call backend API to convert document to PDF\n    try {\n      const conversionRequest: ConvertDocumentToPdfRequest = {\n        content: content,\n        fileName: doc.name,\n        documentId: doc.documentId,\n        appDataId: this.appDataId,\n        appConfigurationUUID: this.appId,\n        environment: this.env,\n      };\n\n      const response = await firstValueFrom(\n        this.appDataService.convertDocumentToPdf(conversionRequest)\n      );\n\n      if (response?.success && response.pdfContent) {\n        // Convert PDF base64 to blob and return\n        const pdfBlob = Utils.base64toBlob(response.pdfContent);\n        return this.blobToArrayBuffer(pdfBlob);\n      } else {\n        console.error('PDF conversion failed:', response?.errorMessage);\n        this.dialog.popError(\n          response?.errorMessage || 'Failed to convert document to PDF'\n        );\n        return null;\n      }\n    } catch (error) {\n      console.error('PDF conversion failed:', error);\n      this.dialog.popError('Failed to convert document to PDF');\n      return null;\n    }\n  }\n}\n","<p *ngIf=\"isLoading === false && (!documents || documents.length === 0)\">\n  {{ getErrorTranslationMessage(\"noDocumentsToShow\") }}\n</p>\n\n<div class=\"buttons-container\">\n  <button (click)=\"prevDocument()\"\n          [disabled]=\"!canGoBack\"\n          class=\"nav-button larger-width-nav-buttons\">\n    &#8592;\n  </button>\n\n  <p class=\"file-info font-paragraph\" *ngIf=\"currentDocument\">\n    {{ this.currentDocument.name }}\n  </p>\n\n  <button (click)=\"nextDocument()\"\n          [disabled]=\"!canGoNext\"\n          class=\"nav-button larger-width-nav-buttons\">\n    &#8594;\n  </button>\n</div>\n\n<mat-spinner *ngIf=\"isLoading === true\" class=\"m-x-auto\"></mat-spinner>\n<pdf-viewer *ngIf=\"isLoading === false\"\n            [src]=\"currentPdf\"\n            [render-text]=\"true\"\n            [original-size]=\"false\"\n            [external-link-target]=\"'blank'\"\n            class=\"pdf-viewer\"></pdf-viewer>\n"]}
@@ -0,0 +1,160 @@
1
+ import { Component } from '@angular/core';
2
+ import { DimensionType, SectionType, StepControlType, } from '../../models/forms.model';
3
+ import { FormControl } from '@angular/forms';
4
+ import { Utils } from '../../others/utils';
5
+ import { BaseFormlyStepComponent } from '../baseFormlyStepComponent';
6
+ import { DependentDictionaryData } from '../../models/flux.model';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../services/applicationData.service";
9
+ import * as i2 from "@angular/common";
10
+ import * as i3 from "@angular/material/card";
11
+ import * as i4 from "@angular/material/progress-spinner";
12
+ import * as i5 from "../../shared-components/grid.component";
13
+ export class FormlyViewOffersComponent extends BaseFormlyStepComponent {
14
+ constructor(appDataService, cdr) {
15
+ super(cdr);
16
+ this.appDataService = appDataService;
17
+ this.offers = [];
18
+ this.config = {
19
+ filter: false,
20
+ };
21
+ }
22
+ onInit() {
23
+ this.isLoading = true;
24
+ this.appModel = this.props['appModel'];
25
+ this.configureColumns();
26
+ }
27
+ onPageSelected() {
28
+ this.isLoading = true;
29
+ this.appDataService.getOffers(this.appDataId).subscribe({
30
+ next: (result) => {
31
+ this.offers = result;
32
+ this.configureDataSource();
33
+ this.isLoading = false;
34
+ this.cdr.detectChanges();
35
+ },
36
+ error: (err) => {
37
+ this.isLoading = false;
38
+ this.cdr.detectChanges();
39
+ },
40
+ });
41
+ }
42
+ configureColumns() {
43
+ const columns = this.stepData.config.columns;
44
+ columns.sort((a, b) => a.order - b.order);
45
+ const idMap = new Map();
46
+ const baseColumns = columns.map((col) => {
47
+ let id = col.field.replace(/[^a-zA-Z0-9]+/g, '_');
48
+ const count = idMap.get(id) || 0;
49
+ idMap.set(id, count + 1);
50
+ if (count > 0) {
51
+ id = `${id}_${count}`;
52
+ }
53
+ return {
54
+ id,
55
+ originalField: col.field,
56
+ label: col.name.find((n) => n.languageIso === this.langIso)?.value || 'N/A',
57
+ };
58
+ });
59
+ const actionColumns = [
60
+ {
61
+ id: 'open',
62
+ icon: 'eye',
63
+ route: '#',
64
+ },
65
+ ];
66
+ this.columns = [...baseColumns, ...actionColumns];
67
+ }
68
+ configureDataSource() {
69
+ const columns = this.columns.filter((c) => c.originalField);
70
+ let dataSource = [];
71
+ this.offers.forEach((o) => {
72
+ let dataSourceRow = {};
73
+ dataSourceRow['offerId'] = o.offerId;
74
+ columns.forEach((column) => {
75
+ const columnField = column.originalField;
76
+ if (columnField.startsWith('api')) {
77
+ const fieldId = columnField.split(' -> ').pop();
78
+ const offerField = o.fields.find((f) => f.fieldId === fieldId);
79
+ const value = offerField ? offerField.value : '';
80
+ dataSourceRow[column.id] = value;
81
+ }
82
+ else if (columnField.startsWith('metadata')) {
83
+ switch (columnField) {
84
+ case 'metadata.appDataId': {
85
+ dataSourceRow[column.id] = this.appDataId;
86
+ break;
87
+ }
88
+ case 'metadata.configurationId': {
89
+ dataSourceRow[column.id] = this.appModel.applicationUuid;
90
+ break;
91
+ }
92
+ default: {
93
+ }
94
+ }
95
+ }
96
+ else {
97
+ const value = this.form.value[columnField];
98
+ if (value !== undefined) {
99
+ dataSourceRow[column.id] = value;
100
+ }
101
+ }
102
+ });
103
+ dataSource.push(dataSourceRow);
104
+ });
105
+ this.datasource = dataSource;
106
+ }
107
+ offerSelected(offer) {
108
+ const formGroup = this.form;
109
+ const formValues = this.form.value || {};
110
+ const selectedOffer = this.offers.find((o) => o.offerId === offer.id.offerId);
111
+ if (!selectedOffer)
112
+ return;
113
+ selectedOffer.fields.forEach((f) => {
114
+ formValues[f.fieldId] = f.value;
115
+ if (!formGroup.controls[f.fieldId]) {
116
+ formGroup.addControl(f.fieldId, new FormControl(f.value));
117
+ }
118
+ });
119
+ this.form.patchValue(formValues);
120
+ this.stepData.config.offerId = selectedOffer.offerId;
121
+ const section = {
122
+ title: '',
123
+ titleStyle: '',
124
+ translations: [],
125
+ showSectionTitle: false,
126
+ showSectionSeparator: false,
127
+ isNavigationSection: false,
128
+ dependentDictionary: new DependentDictionaryData(),
129
+ presentationControls: [],
130
+ canDepend: false,
131
+ identifier: Utils.generateUUID(),
132
+ type: SectionType.Collect,
133
+ controls: selectedOffer.fields.map((f) => ({
134
+ identifier: f.fieldId,
135
+ title: '',
136
+ translations: [],
137
+ type: StepControlType.ManualInput,
138
+ dimension: 0,
139
+ dimensionType: DimensionType.Percentage,
140
+ autoDimension: false,
141
+ specificControlData: undefined,
142
+ dependentDictionary: new DependentDictionaryData(),
143
+ canDepend: false,
144
+ isMandatory: false,
145
+ })),
146
+ };
147
+ this.stepData.sections = [section];
148
+ if (this.props['event']) {
149
+ this.isLoading = true;
150
+ this.props['event'](selectedOffer.offerId);
151
+ }
152
+ }
153
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyViewOffersComponent, deps: [{ token: i1.ApplicationDataService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
154
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormlyViewOffersComponent, selector: "app-formly-view-offers", usesInheritance: true, ngImport: i0, template: "<mat-spinner *ngIf=\"isLoading\" class=\"m-x-auto upload-spinner\"></mat-spinner>\n<ng-container class=\"d-flex flex-row\" *ngIf=\"!isLoading\">\n <mat-card class=\"cardWithShadow blue_theme theme-card align-items-stretch\">\n <mat-card-content class=\"p-24\">\n <shared-grid [data]=\"datasource\"\n [count]=\"datasource.length\"\n [columns]=\"columns\"\n [config]=\"config\"\n (open)=\"offerSelected($event)\"></shared-grid>\n </mat-card-content>\n </mat-card>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i3.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i4.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i5.GridComponent, selector: "shared-grid", inputs: ["data", "count", "columns", "config"], outputs: ["reload", "delete", "duplicate", "open"] }] }); }
155
+ }
156
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormlyViewOffersComponent, decorators: [{
157
+ type: Component,
158
+ args: [{ selector: 'app-formly-view-offers', template: "<mat-spinner *ngIf=\"isLoading\" class=\"m-x-auto upload-spinner\"></mat-spinner>\n<ng-container class=\"d-flex flex-row\" *ngIf=\"!isLoading\">\n <mat-card class=\"cardWithShadow blue_theme theme-card align-items-stretch\">\n <mat-card-content class=\"p-24\">\n <shared-grid [data]=\"datasource\"\n [count]=\"datasource.length\"\n [columns]=\"columns\"\n [config]=\"config\"\n (open)=\"offerSelected($event)\"></shared-grid>\n </mat-card-content>\n </mat-card>\n</ng-container>\n" }]
159
+ }], ctorParameters: () => [{ type: i1.ApplicationDataService }, { type: i0.ChangeDetectorRef }] });
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-view-offers.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-view-offers/formly-view-offers.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-view-offers/formly-view-offers.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component } from '@angular/core';\nimport { ApplicationDataService } from '../../services/applicationData.service';\nimport {\n  DimensionType,\n  FormModel,\n  SectionType,\n  StepControlType,\n} from '../../models/forms.model';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { Utils } from '../../others/utils';\nimport { BaseFormlyStepComponent } from '../baseFormlyStepComponent';\nimport { DependentDictionaryData } from '../../models/flux.model';\n\n@Component({\n  selector: 'app-formly-view-offers',\n  templateUrl: './formly-view-offers.component.html',\n  styleUrl: './formly-view-offers.component.scss',\n})\nexport class FormlyViewOffersComponent extends BaseFormlyStepComponent {\n  appModel: FormModel;\n  offers: any = [];\n  columns: any;\n  datasource: any[];\n  config = {\n    filter: false,\n  };\n  constructor(\n    private appDataService: ApplicationDataService,\n    cdr: ChangeDetectorRef\n  ) {\n    super(cdr);\n  }\n\n  override onInit() {\n    this.isLoading = true;\n    this.appModel = this.props['appModel'];\n    this.configureColumns();\n  }\n\n  override onPageSelected() {\n    this.isLoading = true;\n\n    this.appDataService.getOffers(this.appDataId).subscribe({\n      next: (result) => {\n        this.offers = result;\n        this.configureDataSource();\n        this.isLoading = false;\n        this.cdr.detectChanges();\n      },\n      error: (err) => {\n        this.isLoading = false;\n        this.cdr.detectChanges();\n      },\n    });\n  }\n\n  configureColumns() {\n    const columns = this.stepData.config.columns;\n    columns.sort(\n      (a: { order: number }, b: { order: number }) => a.order - b.order\n    );\n\n    const idMap = new Map<string, number>();\n    const baseColumns = columns.map((col: { field: any; name: any[] }) => {\n      let id = col.field.replace(/[^a-zA-Z0-9]+/g, '_');\n      const count = idMap.get(id) || 0;\n      idMap.set(id, count + 1);\n      if (count > 0) {\n        id = `${id}_${count}`;\n      }\n      return {\n        id,\n        originalField: col.field,\n        label:\n          col.name.find((n) => n.languageIso === this.langIso)?.value || 'N/A',\n      };\n    });\n\n    const actionColumns = [\n      {\n        id: 'open',\n        icon: 'eye',\n        route: '#',\n      },\n    ];\n\n    this.columns = [...baseColumns, ...actionColumns];\n  }\n\n  configureDataSource() {\n    const columns = this.columns.filter((c: any) => c.originalField);\n\n    let dataSource: any[] = [];\n\n    this.offers.forEach((o: any) => {\n      let dataSourceRow: Record<string, any> = {};\n      dataSourceRow['offerId'] = o.offerId;\n      columns.forEach((column: any) => {\n        const columnField = column.originalField;\n        if (columnField.startsWith('api')) {\n          const fieldId = columnField.split(' -> ').pop();\n          const offerField = o.fields.find((f: any) => f.fieldId === fieldId);\n          const value = offerField ? offerField.value : '';\n          dataSourceRow[column.id] = value;\n        } else if (columnField.startsWith('metadata')) {\n          switch (columnField) {\n            case 'metadata.appDataId': {\n              dataSourceRow[column.id] = this.appDataId;\n              break;\n            }\n            case 'metadata.configurationId': {\n              dataSourceRow[column.id] = this.appModel.applicationUuid;\n              break;\n            }\n            default: {\n            }\n          }\n        } else {\n          const value = this.form.value[columnField];\n          if (value !== undefined) {\n            dataSourceRow[column.id] = value;\n          }\n        }\n      });\n\n      dataSource.push(dataSourceRow);\n    });\n    this.datasource = dataSource;\n  }\n\n  offerSelected(offer: any) {\n    const formGroup = this.form as FormGroup;\n    const formValues = this.form.value || {};\n\n    const selectedOffer = this.offers.find(\n      (o: any) => o.offerId === offer.id.offerId\n    );\n    if (!selectedOffer) return;\n\n    selectedOffer.fields.forEach((f: any) => {\n      formValues[f.fieldId] = f.value;\n\n      if (!formGroup.controls[f.fieldId]) {\n        formGroup.addControl(f.fieldId, new FormControl(f.value));\n      }\n    });\n\n    this.form.patchValue(formValues);\n    this.stepData.config.offerId = selectedOffer.offerId;\n\n    const section = {\n      title: '',\n      titleStyle: '',\n      translations: [],\n      showSectionTitle: false,\n      showSectionSeparator: false,\n      isNavigationSection: false,\n      dependentDictionary: new DependentDictionaryData(),\n      presentationControls: [],\n      canDepend: false,\n      identifier: Utils.generateUUID(),\n      type: SectionType.Collect,\n      controls: selectedOffer.fields.map((f: any) => ({\n        identifier: f.fieldId,\n        title: '',\n        translations: [],\n        type: StepControlType.ManualInput,\n        dimension: 0,\n        dimensionType: DimensionType.Percentage,\n        autoDimension: false,\n        specificControlData: undefined,\n        dependentDictionary: new DependentDictionaryData(),\n        canDepend: false,\n        isMandatory: false,\n      })),\n    };\n\n    this.stepData.sections = [section];\n    if (this.props['event']) {\n      this.isLoading = true;\n      this.props['event'](selectedOffer.offerId);\n    }\n  }\n}\n","<mat-spinner *ngIf=\"isLoading\" class=\"m-x-auto upload-spinner\"></mat-spinner>\n<ng-container class=\"d-flex flex-row\" *ngIf=\"!isLoading\">\n  <mat-card class=\"cardWithShadow blue_theme theme-card align-items-stretch\">\n    <mat-card-content class=\"p-24\">\n      <shared-grid [data]=\"datasource\"\n                   [count]=\"datasource.length\"\n                   [columns]=\"columns\"\n                   [config]=\"config\"\n                   (open)=\"offerSelected($event)\"></shared-grid>\n    </mat-card-content>\n  </mat-card>\n</ng-container>\n"]}