@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,367 @@
1
+ export class FormCssHelper {
2
+ static convertToStyleString(cssRules, isDisplayMode) {
3
+ let styleString = FormCssHelper.convertToCssText(cssRules);
4
+ if (isDisplayMode) {
5
+ const newRule = this.convertRuleToCssText('.mat-horizontal-stepper-header-container', { display: 'none' }, cssRules);
6
+ styleString += newRule;
7
+ }
8
+ return styleString;
9
+ }
10
+ static convertToCssText(cssRules) {
11
+ const styleString = Object.entries(cssRules)
12
+ .map(([k, v]) => this.convertRuleToCssText(k, v, cssRules))
13
+ .join(' ');
14
+ return styleString;
15
+ }
16
+ static convertRuleToCssText(key, values, cssRules) {
17
+ const valuesAsText = Object.entries(values)
18
+ .map(([k, v]) => `${k}:${v};`)
19
+ .join(' ');
20
+ let cssText = ` ${key} {${valuesAsText}} `;
21
+ switch (key) {
22
+ case '.component-text-field':
23
+ cssText = this.getSpecificCssForInput(key, values, cssRules);
24
+ break;
25
+ case '.component-checkbox':
26
+ cssText = this.getSpecificCssForCheckBox(key, values, cssRules);
27
+ break;
28
+ case '.font-heading-1':
29
+ cssText = this.getSpecificCssForStepLabel(key, values, cssRules);
30
+ break;
31
+ case '.formly-radio':
32
+ case '.component-radio':
33
+ cssText = this.getSpecificCssForRadio(values, cssRules);
34
+ break;
35
+ case '.component-date':
36
+ case '.component-data':
37
+ cssText = this.getSpecificCssForData(key, values, cssRules);
38
+ break;
39
+ case '.table-details':
40
+ cssText = this.getSpecificCssForTableDetail(values);
41
+ break;
42
+ case '.table-header':
43
+ cssText = this.getSpecificCssForTableHeader(values);
44
+ break;
45
+ }
46
+ return cssText;
47
+ }
48
+ static getSpecificCssForInput(key, values, cssRules) {
49
+ let inputSpecificCss = '';
50
+ let signInputSpecificCss = '';
51
+ const fontStyleForInputText = cssRules['.font-input'];
52
+ if (fontStyleForInputText) {
53
+ //transfer property from component to input
54
+ if (values['text-align']) {
55
+ fontStyleForInputText['text-align'] = values['text-align'];
56
+ }
57
+ fontStyleForInputText['color'] += ' !important';
58
+ inputSpecificCss = this.styleObjectToString(fontStyleForInputText);
59
+ signInputSpecificCss = this.styleObjectToString(fontStyleForInputText, true);
60
+ }
61
+ let labelSpecificCss = '';
62
+ let signLabelSpecificCss = '';
63
+ const fontStyleForLabelText = cssRules['.component-text-field-label'];
64
+ if (fontStyleForLabelText) {
65
+ labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);
66
+ signLabelSpecificCss = this.styleObjectToString(fontStyleForLabelText, true);
67
+ }
68
+ var css = `
69
+ .mat-mdc-text-field-wrapper.mdc-text-field {
70
+ ${this.styleObjectToString(values)};
71
+ border-style: solid;
72
+ input {
73
+ ${inputSpecificCss}
74
+ }
75
+ mat-label {
76
+ ${labelSpecificCss}
77
+ }
78
+ .mdc-line-ripple--active::after {
79
+ border-bottom-color: ${fontStyleForLabelText['color']}
80
+ }
81
+ }
82
+
83
+ input.component-text-field {
84
+ border-style: solid !important;
85
+ ${this.styleObjectToString(values, true)};
86
+ ${signInputSpecificCss}
87
+ }
88
+
89
+ .component-text-field-label label {
90
+ ${signLabelSpecificCss}
91
+ }
92
+ `;
93
+ return `${key} { ${css}}`;
94
+ }
95
+ static getSpecificCssForTableHeader(values) {
96
+ const backgroundColor = values['background-color'] || '#ffffff';
97
+ const textColor = values['color'] || '#000000';
98
+ const border = values['border-width'];
99
+ const borderColor = values['border-color'] || '#000000';
100
+ const borderCollapse = values['border-collapse'] || 'collapse';
101
+ const borderSpacing = values['border-spacing'] || '0';
102
+ const textAlign = values['text-align'] || 'left';
103
+ const verticalAlign = values['vertical-align'] || 'middle';
104
+ const fontFamily = values['font-family'] || 'Arial, sans-serif';
105
+ const fontSize = values['font-size'] || '14px';
106
+ const letterSpacing = values['letter-spacing'] || 'normal';
107
+ const padding = values['padding'] || '8px';
108
+ const width = values['width'] || 'auto';
109
+ const height = values['height'] || 'auto';
110
+ const css = `
111
+ table
112
+ {
113
+ border-collapse: ${borderCollapse} !important;
114
+ border-spacing: ${borderSpacing};
115
+ font-family: ${fontFamily};
116
+ font-size: ${fontSize};
117
+ }
118
+ table th {
119
+ height: ${height};
120
+ }
121
+ table td{height: ${height};
122
+ }
123
+ .table-head tr th{
124
+ background-color: ${backgroundColor} !important;
125
+ width: ${width} !important;
126
+ border-collapse: ${borderCollapse};
127
+ border-spacing: ${borderSpacing};
128
+ border: ${border} solid ${borderColor};
129
+ vertical-align: ${verticalAlign};
130
+ font-family: ${fontFamily};
131
+ font-size: ${fontSize};
132
+ }
133
+ .table-head {
134
+ color: ${textColor};
135
+ border: ${border} solid ${borderColor};
136
+ text-align: ${textAlign};
137
+ letter-spacing: ${letterSpacing};
138
+ padding: ${padding};
139
+ height: ${height};
140
+ }
141
+
142
+ `;
143
+ return css;
144
+ }
145
+ static getSpecificCssForTableDetail(values) {
146
+ const backgroundColor = values['background-color'] || '#ffffff';
147
+ const textColor = values['color'] || '#000000';
148
+ const textAlign = values['text-align'] || 'left';
149
+ const verticalAlign = values['verticalAlign'] || 'middle';
150
+ const letterSpacing = values['letter-spacing'] || 'normal';
151
+ const padding = values['padding'] || '8px';
152
+ const rowBorder = values['rowborder'] || '1px';
153
+ const rowBorderColor = values['rowborder-color'] || '#000000';
154
+ const hoverBackgroundColor = values['hover-background-color'] || '#f0f0f0';
155
+ const css = `
156
+
157
+ .table-detail{
158
+ background-color: ${backgroundColor}
159
+ }
160
+ .table-detail .ng-star-inserted {
161
+ border-top: ${rowBorder} solid ${rowBorderColor} !important;
162
+ border-bottom: ${rowBorder} solid ${rowBorderColor} !important;
163
+ color: ${textColor} !important;
164
+ text-align: ${textAlign};
165
+ vertical-align: ${verticalAlign};
166
+ letter-spacing: ${letterSpacing};
167
+ }
168
+
169
+
170
+ .table-detail .ng-star-inserted:hover {
171
+ background-color: ${hoverBackgroundColor} !important;
172
+
173
+ }
174
+
175
+ .table-detail td {
176
+ padding: ${padding} !important;
177
+ }
178
+
179
+ `;
180
+ return css;
181
+ }
182
+ static getSpecificCssForCheckBox(key, values, cssRules) {
183
+ let labelSpecificCss = '';
184
+ const fontStyleForLabelText = cssRules['.component-checkbox-label'];
185
+ if (fontStyleForLabelText) {
186
+ labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);
187
+ }
188
+ var css = `
189
+ .mat-mdc-text-field-wrapper.mdc-checkbox-field {
190
+ margin-top: ${values['margin-top']};
191
+ margin-right: ${values['margin-right']};
192
+ margin-bottom: ${values['margin-bottom']};
193
+ margin-left: ${values['margin-left']};
194
+ .mdc-form-field > label {
195
+ ${labelSpecificCss};
196
+ padding-left: 0;
197
+ padding-top: 2px;
198
+ };
199
+ .mdc-checkbox {
200
+ width: calc(18px + (2 * ${values['border-width']}));
201
+ height: calc(18px + (2 * ${values['border-width']}));
202
+ flex: 0 0 calc(18px + (2 * ${values['border-width']}));
203
+ }
204
+ .mdc-checkbox .mdc-checkbox__native-control {
205
+ width: 100%;
206
+ height: 100%;
207
+ }
208
+ .mdc-checkbox__background {
209
+ background-color: ${values['background-color']} !important;
210
+ border: ${values['border-width']} solid ${values['border-color']} !important;
211
+ border-radius: ${values['border-radius']};
212
+ width: calc(19px + (2 * ${values['border-width']}));
213
+ height: calc(19px + (2 * ${values['border-width']}));
214
+ };
215
+ }
216
+ .mdc-checkbox__native-control:enabled:checked~.mdc-checkbox__background {
217
+ border: ${values['border-width']} solid ${values['border-color']} !important;
218
+ }
219
+ .mdc-checkbox__checkmark-path {
220
+ color: ${values['color']} !important;
221
+ }`;
222
+ return `${key} { ${css} }`;
223
+ }
224
+ static getSpecificCssForStepLabel(key, values, cssRules) {
225
+ const labelSpecificCss = this.styleObjectToString(values);
226
+ // Map Heading 1 to step labels in stepper
227
+ const heading1Style = cssRules['.font-heading-1'];
228
+ const stepLabelCss = heading1Style
229
+ ? this.styleObjectToString(heading1Style)
230
+ : '';
231
+ // Map Heading 2 to section titles
232
+ const heading2Style = cssRules['.font-heading-2'];
233
+ const sectionTitleCss = heading2Style
234
+ ? this.styleObjectToString(heading2Style)
235
+ : '';
236
+ // Map Heading 3 to step descriptions
237
+ const heading3Style = cssRules['.font-heading-3'];
238
+ const stepDescriptionCss = heading3Style
239
+ ? this.styleObjectToString(heading3Style)
240
+ : '';
241
+ return `
242
+ .mat-horizontal-stepper-wrapper {
243
+ .mat-step-text-label {
244
+ ${stepLabelCss}
245
+ }
246
+ }
247
+
248
+ .mat-step-label {
249
+ ${stepLabelCss}
250
+ }
251
+
252
+ .mat-step-label-selected {
253
+ ${stepLabelCss}
254
+ }
255
+
256
+ .form-section-title h2,
257
+ .separator h2 {
258
+ ${sectionTitleCss}
259
+ }
260
+
261
+ .step-description,
262
+ .mat-step-sub-label {
263
+ ${stepDescriptionCss}
264
+ }
265
+
266
+ .mat-stepper-horizontal .mat-step-label,
267
+ .mat-stepper-vertical .mat-step-label {
268
+ ${stepLabelCss}
269
+ }
270
+
271
+ .component-text-field mat-label,
272
+ .component-checkbox mat-label,
273
+ .component-radio mat-label,
274
+ .component-date mat-label {
275
+ ${cssRules['.font-label']
276
+ ? this.styleObjectToString(cssRules['.font-label'])
277
+ : ''}
278
+ }
279
+ `;
280
+ }
281
+ static getSpecificCssForRadio(values, cssRules) {
282
+ let labelSpecificCss = '';
283
+ const fontStyleForLabelText = cssRules['.component-radio-label'];
284
+ if (fontStyleForLabelText) {
285
+ labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);
286
+ }
287
+ var css = `
288
+ .mat-mdc-text-field-wrapper.mdc-radiobox-field {
289
+ margin-top: ${values['margin-top']};
290
+ margin-right: ${values['margin-right']};
291
+ margin-bottom: ${values['margin-bottom']};
292
+ margin-left: ${values['margin-left']};
293
+ label {
294
+ ${labelSpecificCss};
295
+ padding-left: 0;
296
+ p {
297
+ margin: 0 0 10px;
298
+ }
299
+ }
300
+ .mat-mdc-radio-button {
301
+ .mdc-radio__native-control {
302
+ width: 100%;
303
+ height: 100%;
304
+ }
305
+ .mdc-radio {
306
+ width: calc(20px + (2 * ${values['border-width']}));
307
+ height: calc(20px + (2 * ${values['border-width']}));
308
+ .mdc-radio__background {
309
+ background-color: ${values['background-color']} !important;
310
+ border: ${values['border-width']} solid ${values['border-color']} !important;
311
+ border-radius: 50%;
312
+ width: calc(20px + (2 * ${values['border-width']}));
313
+ height: calc(20px + (2 * ${values['border-width']}));
314
+ .mdc-radio__outer-circle {
315
+ border-color: ${values['background-color']} !important;
316
+ }
317
+ .mdc-radio__inner-circle {
318
+ border-color: ${values['color']} !important;
319
+ }
320
+ }
321
+ }
322
+ }
323
+ }
324
+ `;
325
+ return css;
326
+ }
327
+ static getSpecificCssForData(key, values, cssRules) {
328
+ let inputSpecificCss = '';
329
+ const fontStyleForInputText = cssRules['.font-list'];
330
+ if (fontStyleForInputText) {
331
+ //transfer property from component to input
332
+ if (values['text-align']) {
333
+ fontStyleForInputText['text-align'] = values['text-align'];
334
+ }
335
+ inputSpecificCss = this.styleObjectToString(fontStyleForInputText);
336
+ }
337
+ let labelSpecificCss = '';
338
+ const fontStyleForLabelText = cssRules['.component-data-label'];
339
+ if (fontStyleForLabelText) {
340
+ labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);
341
+ }
342
+ return ` ${key} { .mat-mdc-text-field-wrapper.mdc-text-field {
343
+ ${this.styleObjectToString(values)};
344
+ border-style:solid;
345
+ input{
346
+ ${inputSpecificCss}
347
+ }
348
+ .mat-mdc-form-field-infix {
349
+ .mat-mdc-form-field-input-control::placeholder{
350
+ ${labelSpecificCss}
351
+ }
352
+ }
353
+ }
354
+ } `;
355
+ }
356
+ static styleObjectToString(values, important = false) {
357
+ values['width'] =
358
+ 'calc(100%' +
359
+ ('margin-left' in values ? ` - ${values['margin-left']}` : '') +
360
+ ('margin-right' in values ? ` - ${values['margin-right']}` : '') +
361
+ ')';
362
+ return Object.entries(values)
363
+ .map(([key, value]) => `${key}: ${value}${important ? ' !important' : ''}`)
364
+ .join('; ');
365
+ }
366
+ }
367
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-css.helper.js","sourceRoot":"","sources":["../../../../projects/origin-form/src/lib/form-css.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { CssRules } from \"./others/utils\";\n\nexport class FormCssHelper {\n\n  public static convertToStyleString(cssRules: CssRules, isDisplayMode: boolean): string {\n    let styleString = FormCssHelper.convertToCssText(cssRules);\n    if (isDisplayMode) {\n      const newRule = this.convertRuleToCssText(\n        '.mat-horizontal-stepper-header-container',\n        { display: 'none' },\n        cssRules\n      );\n      styleString += newRule;\n    }\n    return styleString;\n  }\n\n  private static convertToCssText(cssRules: CssRules): string {\n    const styleString = Object.entries(cssRules)\n      .map(([k, v]) => this.convertRuleToCssText(k, v, cssRules))\n      .join(' ');\n    return styleString;\n  }\n\n  private static convertRuleToCssText(\n    key: string,\n    values: { [property: string]: string },\n    cssRules: CssRules\n  ) {\n    const valuesAsText = Object.entries(values)\n      .map(([k, v]) => `${k}:${v};`)\n      .join(' ');\n    let cssText = ` ${key} {${valuesAsText}} `;\n\n    switch (key) {\n      case '.component-text-field':\n        cssText = this.getSpecificCssForInput(key, values, cssRules);\n        break;\n      case '.component-checkbox':\n        cssText = this.getSpecificCssForCheckBox(key, values, cssRules);\n        break;\n      case '.font-heading-1':\n        cssText = this.getSpecificCssForStepLabel(key, values, cssRules);\n        break;\n      case '.formly-radio':\n      case '.component-radio':\n        cssText = this.getSpecificCssForRadio(values, cssRules);\n        break;\n      case '.component-date':\n      case '.component-data':\n        cssText = this.getSpecificCssForData(key, values, cssRules);\n        break;\n      case '.table-details':\n        cssText = this.getSpecificCssForTableDetail(values);\n        break;\n      case '.table-header':\n        cssText = this.getSpecificCssForTableHeader(values);\n        break;\n    }\n    return cssText;\n  }\n\n  public static getSpecificCssForInput(\n    key: string,\n    values: { [property: string]: string },\n    cssRules: CssRules\n  ) {\n    let inputSpecificCss = '';\n    let signInputSpecificCss = '';\n    const fontStyleForInputText = cssRules['.font-input'];\n    if (fontStyleForInputText) {\n      //transfer property from component to input\n      if (values['text-align']) {\n        fontStyleForInputText['text-align'] = values['text-align'];\n      }\n      fontStyleForInputText['color'] += ' !important';\n      inputSpecificCss = this.styleObjectToString(fontStyleForInputText);\n      signInputSpecificCss = this.styleObjectToString(\n        fontStyleForInputText,\n        true\n      );\n    }\n\n    let labelSpecificCss = '';\n    let signLabelSpecificCss = '';\n    const fontStyleForLabelText = cssRules['.component-text-field-label'];\n    if (fontStyleForLabelText) {\n      labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);\n      signLabelSpecificCss = this.styleObjectToString(\n        fontStyleForLabelText,\n        true\n      );\n    }\n\n    var css = `\n    .mat-mdc-text-field-wrapper.mdc-text-field {\n      ${this.styleObjectToString(values)};\n      border-style: solid;\n      input {\n        ${inputSpecificCss}\n      }\n      mat-label {\n        ${labelSpecificCss}\n      }\n      .mdc-line-ripple--active::after {\n        border-bottom-color: ${fontStyleForLabelText['color']}\n      }\n    }\n\n    input.component-text-field {\n      border-style: solid !important;\n      ${this.styleObjectToString(values, true)};\n      ${signInputSpecificCss}\n    }\n\n    .component-text-field-label label {\n      ${signLabelSpecificCss}\n    }\n    `;\n\n    return `${key} { ${css}}`;\n  }\n\n  public static getSpecificCssForTableHeader(\n    values: { [property: string]: string }\n  ): string {\n    const backgroundColor = values['background-color'] || '#ffffff';\n    const textColor = values['color'] || '#000000';\n    const border = values['border-width'];\n    const borderColor = values['border-color'] || '#000000';\n    const borderCollapse = values['border-collapse'] || 'collapse';\n    const borderSpacing = values['border-spacing'] || '0';\n    const textAlign = values['text-align'] || 'left';\n    const verticalAlign = values['vertical-align'] || 'middle';\n    const fontFamily = values['font-family'] || 'Arial, sans-serif';\n    const fontSize = values['font-size'] || '14px';\n    const letterSpacing = values['letter-spacing'] || 'normal';\n    const padding = values['padding'] || '8px';\n    const width = values['width'] || 'auto';\n    const height = values['height'] || 'auto';\n\n    const css = `\n    table \n     {\n      border-collapse: ${borderCollapse} !important;\n      border-spacing: ${borderSpacing};   \n      font-family: ${fontFamily};\n      font-size: ${fontSize};\n    }\n      table th {\n      height: ${height};\n      }\n      table td{height: ${height};\n      }\n    .table-head tr th{\n      background-color: ${backgroundColor} !important;\n      width: ${width} !important;\n      border-collapse: ${borderCollapse};\n        border-spacing: ${borderSpacing};\n        border: ${border} solid ${borderColor}; \n        vertical-align: ${verticalAlign};\n        font-family: ${fontFamily};\n        font-size: ${fontSize};\n      }\n    .table-head {\n      color: ${textColor};\n      border: ${border} solid ${borderColor};  \n      text-align: ${textAlign};            \n      letter-spacing: ${letterSpacing};\n      padding: ${padding};      \n      height: ${height};\n     }\n\n    `;\n    return css;\n  }\n\n  public static getSpecificCssForTableDetail(\n    values: { [property: string]: string }\n  ): string {\n    const backgroundColor = values['background-color'] || '#ffffff';\n    const textColor = values['color'] || '#000000';\n    const textAlign = values['text-align'] || 'left';\n    const verticalAlign = values['verticalAlign'] || 'middle';\n    const letterSpacing = values['letter-spacing'] || 'normal';\n    const padding = values['padding'] || '8px';\n    const rowBorder = values['rowborder'] || '1px';\n    const rowBorderColor = values['rowborder-color'] || '#000000';\n    const hoverBackgroundColor = values['hover-background-color'] || '#f0f0f0';\n\n    const css = `    \n\n      .table-detail{\n       background-color: ${backgroundColor}\n      }\n        .table-detail .ng-star-inserted {\n    border-top: ${rowBorder} solid ${rowBorderColor} !important;\n    border-bottom: ${rowBorder} solid ${rowBorderColor} !important;    \n    color: ${textColor} !important;\n    text-align: ${textAlign};\n    vertical-align: ${verticalAlign};\n    letter-spacing: ${letterSpacing};    \n  }\n  \n\n  .table-detail .ng-star-inserted:hover {\n    background-color: ${hoverBackgroundColor} !important;\n    \n  }\n\n  .table-detail td {\n    padding: ${padding} !important;\n  }\n     \n    `;\n\n    return css;\n  }\n\n  public static getSpecificCssForCheckBox(\n    key: string,\n    values: { [property: string]: string },\n    cssRules: CssRules\n  ): string {\n    let labelSpecificCss = '';\n    const fontStyleForLabelText = cssRules['.component-checkbox-label'];\n    if (fontStyleForLabelText) {\n      labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);\n    }\n\n    var css = `\n    .mat-mdc-text-field-wrapper.mdc-checkbox-field {\n      margin-top: ${values['margin-top']};\n      margin-right: ${values['margin-right']};\n      margin-bottom: ${values['margin-bottom']};\n      margin-left: ${values['margin-left']};\n      .mdc-form-field > label {\n        ${labelSpecificCss};\n        padding-left: 0;\n        padding-top: 2px;\n      };\n      .mdc-checkbox {\n        width: calc(18px + (2 * ${values['border-width']}));\n        height: calc(18px + (2 * ${values['border-width']}));\n        flex: 0 0 calc(18px + (2 * ${values['border-width']}));\n      }\n      .mdc-checkbox .mdc-checkbox__native-control {\n        width: 100%;\n        height: 100%;\n      }\n      .mdc-checkbox__background {\n        background-color: ${values['background-color']} !important;\n        border: ${values['border-width']} solid ${values['border-color']} !important;\n        border-radius: ${values['border-radius']};\n        width: calc(19px + (2 * ${values['border-width']}));\n        height: calc(19px + (2 * ${values['border-width']}));\n      };\n    }\n    .mdc-checkbox__native-control:enabled:checked~.mdc-checkbox__background {\n      border: ${values['border-width']} solid ${values['border-color']} !important;\n    }\n    .mdc-checkbox__checkmark-path {\n      color: ${values['color']} !important;\n    }`;\n    return `${key} { ${css} }`;\n  }\n\n  private static getSpecificCssForStepLabel(\n    key: string,\n    values: { [property: string]: string },\n    cssRules: CssRules\n  ) {\n    const labelSpecificCss = this.styleObjectToString(values);\n\n    // Map Heading 1 to step labels in stepper\n    const heading1Style = cssRules['.font-heading-1'];\n    const stepLabelCss = heading1Style\n      ? this.styleObjectToString(heading1Style)\n      : '';\n\n    // Map Heading 2 to section titles\n    const heading2Style = cssRules['.font-heading-2'];\n    const sectionTitleCss = heading2Style\n      ? this.styleObjectToString(heading2Style)\n      : '';\n\n    // Map Heading 3 to step descriptions\n    const heading3Style = cssRules['.font-heading-3'];\n    const stepDescriptionCss = heading3Style\n      ? this.styleObjectToString(heading3Style)\n      : '';\n\n    return ` \n      .mat-horizontal-stepper-wrapper {\n        .mat-step-text-label {\n          ${stepLabelCss}\n        }\n      }\n      \n      .mat-step-label {\n        ${stepLabelCss}\n      }\n      \n      .mat-step-label-selected {\n        ${stepLabelCss}\n      }\n      \n      .form-section-title h2,\n      .separator h2 {\n        ${sectionTitleCss}\n      }\n      \n      .step-description,\n      .mat-step-sub-label {\n        ${stepDescriptionCss}\n      }\n      \n      .mat-stepper-horizontal .mat-step-label,\n      .mat-stepper-vertical .mat-step-label {\n        ${stepLabelCss}\n      }\n      \n      .component-text-field mat-label,\n      .component-checkbox mat-label,\n      .component-radio mat-label,\n      .component-date mat-label {\n        ${cssRules['.font-label']\n        ? this.styleObjectToString(cssRules['.font-label'])\n        : ''\n      }\n      }\n    `;\n  }\n\n  public static getSpecificCssForRadio(\n    values: { [property: string]: string },\n    cssRules: CssRules\n  ) {\n    let labelSpecificCss = '';\n    const fontStyleForLabelText = cssRules['.component-radio-label'];\n    if (fontStyleForLabelText) {\n      labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);\n    }\n\n    var css = `\n    .mat-mdc-text-field-wrapper.mdc-radiobox-field {\n      margin-top: ${values['margin-top']};\n      margin-right: ${values['margin-right']};\n      margin-bottom: ${values['margin-bottom']};\n      margin-left: ${values['margin-left']};\n      label {\n        ${labelSpecificCss};\n        padding-left: 0;\n        p {\n          margin: 0 0 10px;\n        }\n      }\n      .mat-mdc-radio-button {\n        .mdc-radio__native-control {\n          width: 100%;\n          height: 100%;\n        }\n        .mdc-radio {\n          width: calc(20px + (2 * ${values['border-width']}));\n          height: calc(20px + (2 * ${values['border-width']}));\n          .mdc-radio__background {\n            background-color: ${values['background-color']} !important;\n            border: ${values['border-width']} solid ${values['border-color']} !important;\n            border-radius: 50%;\n            width: calc(20px + (2 * ${values['border-width']}));\n            height: calc(20px + (2 * ${values['border-width']}));\n            .mdc-radio__outer-circle {\n              border-color: ${values['background-color']} !important;\n            }\n            .mdc-radio__inner-circle {\n              border-color: ${values['color']} !important;\n            }\n          }\n        }\n      }\n    }\n    `;\n\n    return css;\n  }\n\n  public static getSpecificCssForData(\n    key: string,\n    values: { [property: string]: string },\n    cssRules: CssRules\n  ) {\n    let inputSpecificCss = '';\n    const fontStyleForInputText = cssRules['.font-list'];\n    if (fontStyleForInputText) {\n      //transfer property from component to input\n      if (values['text-align']) {\n        fontStyleForInputText['text-align'] = values['text-align'];\n      }\n      inputSpecificCss = this.styleObjectToString(fontStyleForInputText);\n    }\n\n    let labelSpecificCss = '';\n    const fontStyleForLabelText = cssRules['.component-data-label'];\n    if (fontStyleForLabelText) {\n      labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);\n    }\n    return ` ${key} { .mat-mdc-text-field-wrapper.mdc-text-field {\n                          ${this.styleObjectToString(values)};\n                          border-style:solid;\n                          input{\n                            ${inputSpecificCss}\n                          }\n                         .mat-mdc-form-field-infix {\n                           .mat-mdc-form-field-input-control::placeholder{\n                             ${labelSpecificCss}\n                           }\n                         }\n                       }\n                    } `;\n  }\n\n  public static styleObjectToString(\n    values: { [property: string]: string },\n    important: boolean = false\n  ): string {\n    values['width'] =\n      'calc(100%' +\n      ('margin-left' in values ? ` - ${values['margin-left']}` : '') +\n      ('margin-right' in values ? ` - ${values['margin-right']}` : '') +\n      ')';\n\n    return Object.entries(values)\n      .map(\n        ([key, value]) => `${key}: ${value}${important ? ' !important' : ''}`\n      )\n      .join('; ');\n  }\n}\n"]}
@@ -0,0 +1,52 @@
1
+ import { Component } from "@angular/core";
2
+ import { FieldType } from "@ngx-formly/core";
3
+ import { Utils } from "../others/utils";
4
+ import * as i0 from "@angular/core";
5
+ export class BaseFormlyControlComponent extends FieldType {
6
+ onInit() { }
7
+ onPageSelected() { }
8
+ async onPageSelectedAsync() { }
9
+ canAdvance() {
10
+ return true;
11
+ }
12
+ constructor(cdr) {
13
+ super();
14
+ this.cdr = cdr;
15
+ }
16
+ async ngOnInit() {
17
+ this.props['cdr'] = this.cdr;
18
+ this.props['component'] = this;
19
+ this.env = this.props['env'];
20
+ this.langIso = this.props['langIso'];
21
+ this.controlData = this.props['controlData'];
22
+ this.isDisplayMode = this.props['isDisplayMode'];
23
+ this.appDataId = this.props['appDataId'];
24
+ this.appId = this.props['appId'];
25
+ this.title = this.props['label'];
26
+ this.dataUrlId = this.props['dataUrlId'];
27
+ this.onInit();
28
+ }
29
+ getErrorTranslationMessage(errorCode, ...params) {
30
+ const translation = Utils.findErrorTranslationLabel(this.controlData.errorsTranslations, this.langIso, errorCode);
31
+ let errorMessage = 'An error has occured';
32
+ if (translation && translation.value) {
33
+ errorMessage = translation.value;
34
+ if (params) {
35
+ for (let i = 0; i < params.length; i++) {
36
+ errorMessage = errorMessage.replace('{' + i + '}', params[i]);
37
+ }
38
+ }
39
+ }
40
+ return errorMessage;
41
+ }
42
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseFormlyControlComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
43
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: BaseFormlyControlComponent, selector: "base-formly-component", usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
44
+ }
45
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseFormlyControlComponent, decorators: [{
46
+ type: Component,
47
+ args: [{
48
+ selector: 'base-formly-component',
49
+ template: '',
50
+ }]
51
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }] });
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZUZvcm1seUNvbnRyb2xDb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vcmlnaW4tZm9ybS9zcmMvbGliL2Zvcm1seS9iYXNlRm9ybWx5Q29udHJvbENvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUE2QixNQUFNLGVBQWUsQ0FBQztBQUNyRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDN0MsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQU94QyxNQUFNLE9BQWdCLDBCQUEyQixTQUFRLFNBQVM7SUFXaEUsTUFBTSxLQUFJLENBQUM7SUFDWCxjQUFjLEtBQUksQ0FBQztJQUNuQixLQUFLLENBQUMsbUJBQW1CLEtBQUksQ0FBQztJQUM5QixVQUFVO1FBQ1IsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsWUFBbUIsR0FBc0I7UUFDdkMsS0FBSyxFQUFFLENBQUM7UUFEUyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtJQUV6QyxDQUFDO0lBRUQsS0FBSyxDQUFDLFFBQVE7UUFDWixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUM7UUFDN0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDL0IsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzdCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQVcsQ0FBQztRQUMvQyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDN0MsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBQ2pELElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN6QyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN6QyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVELDBCQUEwQixDQUFDLFNBQWlCLEVBQUUsR0FBRyxNQUFnQjtRQUMvRCxNQUFNLFdBQVcsR0FBRyxLQUFLLENBQUMseUJBQXlCLENBQ2pELElBQUksQ0FBQyxXQUFXLENBQUMsa0JBQWtCLEVBQ25DLElBQUksQ0FBQyxPQUFPLEVBQ1osU0FBUyxDQUNWLENBQUM7UUFDRixJQUFJLFlBQVksR0FBRyxzQkFBc0IsQ0FBQztRQUMxQyxJQUFJLFdBQVcsSUFBSSxXQUFXLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDckMsWUFBWSxHQUFHLFdBQVcsQ0FBQyxLQUFLLENBQUM7WUFDakMsSUFBSSxNQUFNLEVBQUUsQ0FBQztnQkFDWCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO29CQUN2QyxZQUFZLEdBQUcsWUFBWSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEdBQUcsQ0FBQyxHQUFHLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDaEUsQ0FBQztZQUNILENBQUM7UUFDSCxDQUFDO1FBQ0QsT0FBTyxZQUFZLENBQUM7SUFDdEIsQ0FBQzsrR0FwRG1CLDBCQUEwQjttR0FBMUIsMEJBQTBCLG9GQUZwQyxFQUFFOzs0RkFFUSwwQkFBMEI7a0JBSi9DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsUUFBUSxFQUFFLEVBQUU7aUJBQ2IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgQ2hhbmdlRGV0ZWN0b3JSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgRmllbGRUeXBlIH0gZnJvbSBcIkBuZ3gtZm9ybWx5L2NvcmVcIjtcbmltcG9ydCB7IFV0aWxzIH0gZnJvbSBcIi4uL290aGVycy91dGlsc1wiO1xuaW1wb3J0IHsgQ29udHJvbERhdGEgfSBmcm9tIFwiLi4vbW9kZWxzL2ZsdXgubW9kZWxcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYmFzZS1mb3JtbHktY29tcG9uZW50JyxcbiAgdGVtcGxhdGU6ICcnLFxufSlcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlRm9ybWx5Q29udHJvbENvbXBvbmVudCBleHRlbmRzIEZpZWxkVHlwZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIGxhbmdJc286IHN0cmluZztcbiAgY29udHJvbERhdGE6IENvbnRyb2xEYXRhO1xuICBpc0xvYWRpbmc6IGJvb2xlYW47XG4gIGlzRGlzcGxheU1vZGU6IGJvb2xlYW47XG4gIGVudjogc3RyaW5nO1xuICBhcHBEYXRhSWQ6IHN0cmluZztcbiAgZGF0YVVybElkOiBzdHJpbmc7XG4gIGFwcElkOiBzdHJpbmc7XG4gIHRpdGxlOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgb25Jbml0KCkge31cbiAgb25QYWdlU2VsZWN0ZWQoKSB7fVxuICBhc3luYyBvblBhZ2VTZWxlY3RlZEFzeW5jKCkge31cbiAgY2FuQWR2YW5jZSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuXG4gIGFzeW5jIG5nT25Jbml0KCkge1xuICAgIHRoaXMucHJvcHNbJ2NkciddID0gdGhpcy5jZHI7XG4gICAgdGhpcy5wcm9wc1snY29tcG9uZW50J10gPSB0aGlzO1xuICAgIHRoaXMuZW52ID0gdGhpcy5wcm9wc1snZW52J107XG4gICAgdGhpcy5sYW5nSXNvID0gdGhpcy5wcm9wc1snbGFuZ0lzbyddIGFzIHN0cmluZztcbiAgICB0aGlzLmNvbnRyb2xEYXRhID0gdGhpcy5wcm9wc1snY29udHJvbERhdGEnXTtcbiAgICB0aGlzLmlzRGlzcGxheU1vZGUgPSB0aGlzLnByb3BzWydpc0Rpc3BsYXlNb2RlJ107XG4gICAgdGhpcy5hcHBEYXRhSWQgPSB0aGlzLnByb3BzWydhcHBEYXRhSWQnXTtcbiAgICB0aGlzLmFwcElkID0gdGhpcy5wcm9wc1snYXBwSWQnXTtcbiAgICB0aGlzLnRpdGxlID0gdGhpcy5wcm9wc1snbGFiZWwnXTtcbiAgICB0aGlzLmRhdGFVcmxJZCA9IHRoaXMucHJvcHNbJ2RhdGFVcmxJZCddO1xuICAgIHRoaXMub25Jbml0KCk7XG4gIH1cblxuICBnZXRFcnJvclRyYW5zbGF0aW9uTWVzc2FnZShlcnJvckNvZGU6IHN0cmluZywgLi4ucGFyYW1zOiBzdHJpbmdbXSkge1xuICAgIGNvbnN0IHRyYW5zbGF0aW9uID0gVXRpbHMuZmluZEVycm9yVHJhbnNsYXRpb25MYWJlbChcbiAgICAgIHRoaXMuY29udHJvbERhdGEuZXJyb3JzVHJhbnNsYXRpb25zLFxuICAgICAgdGhpcy5sYW5nSXNvLFxuICAgICAgZXJyb3JDb2RlXG4gICAgKTtcbiAgICBsZXQgZXJyb3JNZXNzYWdlID0gJ0FuIGVycm9yIGhhcyBvY2N1cmVkJztcbiAgICBpZiAodHJhbnNsYXRpb24gJiYgdHJhbnNsYXRpb24udmFsdWUpIHtcbiAgICAgIGVycm9yTWVzc2FnZSA9IHRyYW5zbGF0aW9uLnZhbHVlO1xuICAgICAgaWYgKHBhcmFtcykge1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHBhcmFtcy5sZW5ndGg7IGkrKykge1xuICAgICAgICAgIGVycm9yTWVzc2FnZSA9IGVycm9yTWVzc2FnZS5yZXBsYWNlKCd7JyArIGkgKyAnfScsIHBhcmFtc1tpXSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGVycm9yTWVzc2FnZTtcbiAgfVxufVxuIl19
@@ -0,0 +1,59 @@
1
+ import { Component } from '@angular/core';
2
+ import { FieldType } from '@ngx-formly/core';
3
+ import { Utils } from '../others/utils';
4
+ import * as i0 from "@angular/core";
5
+ export class BaseFormlyStepComponent extends FieldType {
6
+ onInit() { }
7
+ onPageSelected() { }
8
+ async onPageSelectedAsync() { }
9
+ canAdvance() {
10
+ return true;
11
+ }
12
+ constructor(cdr) {
13
+ super();
14
+ this.cdr = cdr;
15
+ }
16
+ async ngOnInit() {
17
+ this.props['cdr'] = this.cdr;
18
+ this.props['component'] = this;
19
+ this.env = this.props['env'];
20
+ this.langIso = this.props['langIso'];
21
+ this.stepData = this.props['stepData'];
22
+ this.controlData = this.props['controlData'];
23
+ this.isDisplayMode = this.props['isDisplayMode'];
24
+ this.appDataId = this.props['appDataId'];
25
+ this.appId = this.props['appId'];
26
+ this.stepsSettings = this.props['stepsSettings'];
27
+ this.title = this.props['label'];
28
+ this.dataUrlId = this.props['dataUrlId'];
29
+ this.onInit();
30
+ }
31
+ onEvent(data) {
32
+ if (this.props['event']) {
33
+ this.props['event'](data);
34
+ }
35
+ }
36
+ getErrorTranslationMessage(errorCode, ...params) {
37
+ const translation = Utils.findErrorTranslationLabel(this.stepData.errorsTranslations, this.langIso, errorCode);
38
+ let errorMessage = 'An error has occured';
39
+ if (translation && translation.value) {
40
+ errorMessage = translation.value;
41
+ if (params) {
42
+ for (let i = 0; i < params.length; i++) {
43
+ errorMessage = errorMessage.replace('{' + i + '}', params[i]);
44
+ }
45
+ }
46
+ }
47
+ return errorMessage;
48
+ }
49
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseFormlyStepComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
50
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: BaseFormlyStepComponent, selector: "base-formly-component", usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
51
+ }
52
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseFormlyStepComponent, decorators: [{
53
+ type: Component,
54
+ args: [{
55
+ selector: 'base-formly-component',
56
+ template: '',
57
+ }]
58
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }] });
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZUZvcm1seVN0ZXBDb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vcmlnaW4tZm9ybS9zcmMvbGliL2Zvcm1seS9iYXNlRm9ybWx5U3RlcENvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNyRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFN0MsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQU94QyxNQUFNLE9BQWdCLHVCQUF3QixTQUFRLFNBQVM7SUFhN0QsTUFBTSxLQUFLLENBQUM7SUFDWixjQUFjLEtBQUssQ0FBQztJQUNwQixLQUFLLENBQUMsbUJBQW1CLEtBQUssQ0FBQztJQUMvQixVQUFVO1FBQ1IsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsWUFBbUIsR0FBc0I7UUFDdkMsS0FBSyxFQUFFLENBQUM7UUFEUyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtJQUV6QyxDQUFDO0lBRUQsS0FBSyxDQUFDLFFBQVE7UUFDWixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUM7UUFDN0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDL0IsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzdCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQVcsQ0FBQztRQUMvQyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDdkMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUNqRCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDekMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUNqRCxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3pDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUVoQixDQUFDO0lBRUQsT0FBTyxDQUFDLElBQVM7UUFDZixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzVCLENBQUM7SUFDSCxDQUFDO0lBRUQsMEJBQTBCLENBQUMsU0FBaUIsRUFBRSxHQUFHLE1BQWdCO1FBQy9ELE1BQU0sV0FBVyxHQUFHLEtBQUssQ0FBQyx5QkFBeUIsQ0FDakQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsRUFDaEMsSUFBSSxDQUFDLE9BQU8sRUFDWixTQUFTLENBQ1YsQ0FBQztRQUNGLElBQUksWUFBWSxHQUFHLHNCQUFzQixDQUFDO1FBQzFDLElBQUksV0FBVyxJQUFJLFdBQVcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNyQyxZQUFZLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQztZQUNqQyxJQUFJLE1BQU0sRUFBRSxDQUFDO2dCQUNYLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7b0JBQ3ZDLFlBQVksR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsR0FBRyxDQUFDLEdBQUcsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNoRSxDQUFDO1lBQ0gsQ0FBQztRQUNILENBQUM7UUFDRCxPQUFPLFlBQVksQ0FBQztJQUN0QixDQUFDOytHQS9EbUIsdUJBQXVCO21HQUF2Qix1QkFBdUIsb0ZBRmpDLEVBQUU7OzRGQUVRLHVCQUF1QjtrQkFKNUMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxRQUFRLEVBQUUsRUFBRTtpQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmllbGRUeXBlIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBTdGVwc1NldHRpbmdzIH0gZnJvbSAnLi4vbW9kZWxzL2Zvcm1zLm1vZGVsJztcbmltcG9ydCB7IFV0aWxzIH0gZnJvbSAnLi4vb3RoZXJzL3V0aWxzJztcbmltcG9ydCB7IENvbnRyb2xEYXRhLCBTdGVwRGF0YSB9IGZyb20gJy4uL21vZGVscy9mbHV4Lm1vZGVsJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYmFzZS1mb3JtbHktY29tcG9uZW50JyxcbiAgdGVtcGxhdGU6ICcnLFxufSlcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlRm9ybWx5U3RlcENvbXBvbmVudCBleHRlbmRzIEZpZWxkVHlwZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIGxhbmdJc286IHN0cmluZztcbiAgc3RlcERhdGE6IFN0ZXBEYXRhO1xuICBjb250cm9sRGF0YTogQ29udHJvbERhdGE7XG4gIGlzTG9hZGluZzogYm9vbGVhbjtcbiAgaXNEaXNwbGF5TW9kZTogYm9vbGVhbjtcbiAgZW52OiBzdHJpbmc7XG4gIGFwcERhdGFJZDogc3RyaW5nO1xuICBkYXRhVXJsSWQ6IHN0cmluZztcbiAgYXBwSWQ6IHN0cmluZztcbiAgc3RlcHNTZXR0aW5nczogU3RlcHNTZXR0aW5ncztcbiAgdGl0bGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICBvbkluaXQoKSB7IH1cbiAgb25QYWdlU2VsZWN0ZWQoKSB7IH1cbiAgYXN5bmMgb25QYWdlU2VsZWN0ZWRBc3luYygpIHsgfVxuICBjYW5BZHZhbmNlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHVibGljIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgYXN5bmMgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5wcm9wc1snY2RyJ10gPSB0aGlzLmNkcjtcbiAgICB0aGlzLnByb3BzWydjb21wb25lbnQnXSA9IHRoaXM7XG4gICAgdGhpcy5lbnYgPSB0aGlzLnByb3BzWydlbnYnXTtcbiAgICB0aGlzLmxhbmdJc28gPSB0aGlzLnByb3BzWydsYW5nSXNvJ10gYXMgc3RyaW5nO1xuICAgIHRoaXMuc3RlcERhdGEgPSB0aGlzLnByb3BzWydzdGVwRGF0YSddO1xuICAgIHRoaXMuY29udHJvbERhdGEgPSB0aGlzLnByb3BzWydjb250cm9sRGF0YSddO1xuICAgIHRoaXMuaXNEaXNwbGF5TW9kZSA9IHRoaXMucHJvcHNbJ2lzRGlzcGxheU1vZGUnXTtcbiAgICB0aGlzLmFwcERhdGFJZCA9IHRoaXMucHJvcHNbJ2FwcERhdGFJZCddO1xuICAgIHRoaXMuYXBwSWQgPSB0aGlzLnByb3BzWydhcHBJZCddO1xuICAgIHRoaXMuc3RlcHNTZXR0aW5ncyA9IHRoaXMucHJvcHNbJ3N0ZXBzU2V0dGluZ3MnXTtcbiAgICB0aGlzLnRpdGxlID0gdGhpcy5wcm9wc1snbGFiZWwnXTtcbiAgICB0aGlzLmRhdGFVcmxJZCA9IHRoaXMucHJvcHNbJ2RhdGFVcmxJZCddO1xuICAgIHRoaXMub25Jbml0KCk7XG5cbiAgfVxuXG4gIG9uRXZlbnQoZGF0YTogYW55KSB7XG4gICAgaWYgKHRoaXMucHJvcHNbJ2V2ZW50J10pIHtcbiAgICAgIHRoaXMucHJvcHNbJ2V2ZW50J10oZGF0YSk7XG4gICAgfVxuICB9XG5cbiAgZ2V0RXJyb3JUcmFuc2xhdGlvbk1lc3NhZ2UoZXJyb3JDb2RlOiBzdHJpbmcsIC4uLnBhcmFtczogc3RyaW5nW10pIHtcbiAgICBjb25zdCB0cmFuc2xhdGlvbiA9IFV0aWxzLmZpbmRFcnJvclRyYW5zbGF0aW9uTGFiZWwoXG4gICAgICB0aGlzLnN0ZXBEYXRhLmVycm9yc1RyYW5zbGF0aW9ucyxcbiAgICAgIHRoaXMubGFuZ0lzbyxcbiAgICAgIGVycm9yQ29kZVxuICAgICk7XG4gICAgbGV0IGVycm9yTWVzc2FnZSA9ICdBbiBlcnJvciBoYXMgb2NjdXJlZCc7XG4gICAgaWYgKHRyYW5zbGF0aW9uICYmIHRyYW5zbGF0aW9uLnZhbHVlKSB7XG4gICAgICBlcnJvck1lc3NhZ2UgPSB0cmFuc2xhdGlvbi52YWx1ZTtcbiAgICAgIGlmIChwYXJhbXMpIHtcbiAgICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBwYXJhbXMubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICBlcnJvck1lc3NhZ2UgPSBlcnJvck1lc3NhZ2UucmVwbGFjZSgneycgKyBpICsgJ30nLCBwYXJhbXNbaV0pO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBlcnJvck1lc3NhZ2U7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,32 @@
1
+ import { Component } from '@angular/core';
2
+ import { FieldType } from '@ngx-formly/core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@ngx-formly/core";
6
+ export class CustomSectionComponent extends FieldType {
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomSectionComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CustomSectionComponent, selector: "formly-custom-section", usesInheritance: true, ngImport: i0, template: `
9
+ <div class="custom-section">
10
+ <ng-container *ngFor="let field of field.fieldGroup">
11
+ <formly-field
12
+ [field]="field"
13
+ [ngClass]="field.className"
14
+ ></formly-field>
15
+ </ng-container>
16
+ </div>
17
+ `, isInline: true, styles: [".custom-section{display:grid;gap:5px;margin-bottom:5px;grid-template-columns:repeat(12,1fr)}.full-width{grid-column:span 12}.half-width{grid-column:span 6}.quarter-width{grid-column:span 3}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.FormlyField, selector: "formly-field", inputs: ["field"] }] }); }
18
+ }
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomSectionComponent, decorators: [{
20
+ type: Component,
21
+ args: [{ selector: 'formly-custom-section', template: `
22
+ <div class="custom-section">
23
+ <ng-container *ngFor="let field of field.fieldGroup">
24
+ <formly-field
25
+ [field]="field"
26
+ [ngClass]="field.className"
27
+ ></formly-field>
28
+ </ng-container>
29
+ </div>
30
+ `, styles: [".custom-section{display:grid;gap:5px;margin-bottom:5px;grid-template-columns:repeat(12,1fr)}.full-width{grid-column:span 12}.half-width{grid-column:span 6}.quarter-width{grid-column:span 3}\n"] }]
31
+ }] });
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXNlY3Rpb24tc2VwYXJhdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29yaWdpbi1mb3JtL3NyYy9saWIvZm9ybWx5L2N1c3RvbS1zZWN0aW9uLXNlcGFyYXRvci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7Ozs7QUFrQzdDLE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxTQUFTOytHQUF4QyxzQkFBc0I7bUdBQXRCLHNCQUFzQixvRkE5QnZCOzs7Ozs7Ozs7R0FTVDs7NEZBcUJVLHNCQUFzQjtrQkFoQ2xDLFNBQVM7K0JBQ0UsdUJBQXVCLFlBQ3ZCOzs7Ozs7Ozs7R0FTVCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmllbGRUeXBlIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2Zvcm1seS1jdXN0b20tc2VjdGlvbicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImN1c3RvbS1zZWN0aW9uXCI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBmaWVsZCBvZiBmaWVsZC5maWVsZEdyb3VwXCI+XG4gICAgICAgIDxmb3JtbHktZmllbGRcbiAgICAgICAgICBbZmllbGRdPVwiZmllbGRcIlxuICAgICAgICAgIFtuZ0NsYXNzXT1cImZpZWxkLmNsYXNzTmFtZVwiXG4gICAgICAgID48L2Zvcm1seS1maWVsZD5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICAuY3VzdG9tLXNlY3Rpb24ge1xuICAgICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgICBnYXA6IDVweDtcbiAgICAgICAgbWFyZ2luLWJvdHRvbTogNXB4O1xuICAgICAgICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IHJlcGVhdCgxMiwgMWZyKTtcbiAgICAgIH1cbiAgICAgIC5mdWxsLXdpZHRoIHtcbiAgICAgICAgZ3JpZC1jb2x1bW46IHNwYW4gMTI7XG4gICAgICB9XG4gICAgICAuaGFsZi13aWR0aCB7XG4gICAgICAgIGdyaWQtY29sdW1uOiBzcGFuIDY7XG4gICAgICB9XG4gICAgICAucXVhcnRlci13aWR0aCB7XG4gICAgICAgIGdyaWQtY29sdW1uOiBzcGFuIDM7XG4gICAgICB9XG4gICAgYCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgQ3VzdG9tU2VjdGlvbkNvbXBvbmVudCBleHRlbmRzIEZpZWxkVHlwZSB7fSJdfQ==
@@ -0,0 +1,36 @@
1
+ import { Component } from '@angular/core';
2
+ import { FieldType } from '@ngx-formly/core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ export class FormSectionSeparatorComponent extends FieldType {
6
+ ngOnInit() {
7
+ if (this.props['design']) {
8
+ this.heading2Style = this.props['design']['.font-heading-2'];
9
+ const separatorStyle = this.props['design']['.separator-section'];
10
+ if (separatorStyle && separatorStyle['height'] !== '0px') {
11
+ this.separatorStyle = separatorStyle;
12
+ }
13
+ }
14
+ }
15
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormSectionSeparatorComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
16
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormSectionSeparatorComponent, selector: "form-section-separator", usesInheritance: true, ngImport: i0, template: `
17
+ <div class="separator" style="margin: 2% ;">
18
+ <h2 *ngIf="to && to['title']" [ngStyle]="heading2Style">
19
+ {{ to['title'] }}
20
+ </h2>
21
+ <hr *ngIf="to && to['showSeparator']" [ngStyle]="separatorStyle" />
22
+ </div>
23
+ `, isInline: true, styles: [".separator{margin:2% 0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
24
+ }
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormSectionSeparatorComponent, decorators: [{
26
+ type: Component,
27
+ args: [{ selector: 'form-section-separator', template: `
28
+ <div class="separator" style="margin: 2% ;">
29
+ <h2 *ngIf="to && to['title']" [ngStyle]="heading2Style">
30
+ {{ to['title'] }}
31
+ </h2>
32
+ <hr *ngIf="to && to['showSeparator']" [ngStyle]="separatorStyle" />
33
+ </div>
34
+ `, styles: [".separator{margin:2% 0}\n"] }]
35
+ }] });
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zZWN0aW9uLXNlcGFyYXRvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vcmlnaW4tZm9ybS9zcmMvbGliL2Zvcm1seS9mb3JtLXNlY3Rpb24tc2VwYXJhdG9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7O0FBb0I3QyxNQUFNLE9BQU8sNkJBQThCLFNBQVEsU0FBUztJQUkxRCxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7WUFDekIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLENBQUM7WUFDN0QsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1lBQ2xFLElBQUksY0FBYyxJQUFJLGNBQWMsQ0FBQyxRQUFRLENBQUMsS0FBSyxLQUFLLEVBQUUsQ0FBQztnQkFDekQsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7WUFDdkMsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDOytHQVpVLDZCQUE2QjttR0FBN0IsNkJBQTZCLHFGQWhCOUI7Ozs7Ozs7R0FPVDs7NEZBU1UsNkJBQTZCO2tCQWxCekMsU0FBUzsrQkFDRSx3QkFBd0IsWUFDeEI7Ozs7Ozs7R0FPVCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGaWVsZFR5cGUgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZm9ybS1zZWN0aW9uLXNlcGFyYXRvcicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cInNlcGFyYXRvclwiIHN0eWxlPVwibWFyZ2luOiAyJSA7XCI+XG4gICAgICA8aDIgKm5nSWY9XCJ0byAmJiB0b1sndGl0bGUnXVwiIFtuZ1N0eWxlXT1cImhlYWRpbmcyU3R5bGVcIj5cbiAgICAgICAge3sgdG9bJ3RpdGxlJ10gfX1cbiAgICAgIDwvaDI+XG4gICAgICA8aHIgKm5nSWY9XCJ0byAmJiB0b1snc2hvd1NlcGFyYXRvciddXCIgW25nU3R5bGVdPVwic2VwYXJhdG9yU3R5bGVcIiAvPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICAuc2VwYXJhdG9yIHtcbiAgICAgICAgbWFyZ2luOiAyJSAwO1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZvcm1TZWN0aW9uU2VwYXJhdG9yQ29tcG9uZW50IGV4dGVuZHMgRmllbGRUeXBlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgaGVhZGluZzJTdHlsZTogW3Byb3A6IHN0cmluZ107XG4gIHNlcGFyYXRvclN0eWxlOiBbcHJvcDogc3RyaW5nXTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5wcm9wc1snZGVzaWduJ10pIHtcbiAgICAgIHRoaXMuaGVhZGluZzJTdHlsZSA9IHRoaXMucHJvcHNbJ2Rlc2lnbiddWycuZm9udC1oZWFkaW5nLTInXTtcbiAgICAgIGNvbnN0IHNlcGFyYXRvclN0eWxlID0gdGhpcy5wcm9wc1snZGVzaWduJ11bJy5zZXBhcmF0b3Itc2VjdGlvbiddO1xuICAgICAgaWYgKHNlcGFyYXRvclN0eWxlICYmIHNlcGFyYXRvclN0eWxlWydoZWlnaHQnXSAhPT0gJzBweCcpIHtcbiAgICAgICAgdGhpcy5zZXBhcmF0b3JTdHlsZSA9IHNlcGFyYXRvclN0eWxlO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19