@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.
- package/README.md +24 -0
- package/esm2022/lib/action-step-handler.mjs +163 -0
- package/esm2022/lib/auth-client.service.mjs +69 -0
- package/esm2022/lib/enums/label.keys.mjs +721 -0
- package/esm2022/lib/form-css.helper.mjs +367 -0
- package/esm2022/lib/formly/baseFormlyControlComponent.mjs +52 -0
- package/esm2022/lib/formly/baseFormlyStepComponent.mjs +59 -0
- package/esm2022/lib/formly/custom-section-separator.component.mjs +32 -0
- package/esm2022/lib/formly/form-section-separator.component.mjs +36 -0
- package/esm2022/lib/formly/formly-action.mjs +56 -0
- package/esm2022/lib/formly/formly-checkbox/formly-checkbox.component.mjs +52 -0
- package/esm2022/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.mjs +261 -0
- package/esm2022/lib/formly/formly-download-documents/formly-download-documents.component.mjs +126 -0
- package/esm2022/lib/formly/formly-enrol-card/formly-enrol-card.component.mjs +120 -0
- package/esm2022/lib/formly/formly-field-stepper/formly-field-stepper.component.mjs +762 -0
- package/esm2022/lib/formly/formly-generate-documents/formly-generate-documents.component.mjs +57 -0
- package/esm2022/lib/formly/formly-identification.component.mjs +84 -0
- package/esm2022/lib/formly/formly-open-banking/formly-open-banking.component.mjs +590 -0
- package/esm2022/lib/formly/formly-paragraph/formly-paragraph.component.mjs +35 -0
- package/esm2022/lib/formly/formly-radio/formly-radio-component.mjs +49 -0
- package/esm2022/lib/formly/formly-row-fille.mjs +12 -0
- package/esm2022/lib/formly/formly-scan-id/formly-scan-id.component.mjs +284 -0
- package/esm2022/lib/formly/formly-sign/formly-sign.component.mjs +173 -0
- package/esm2022/lib/formly/formly-upload-documents/formly-upload-documents.component.mjs +198 -0
- package/esm2022/lib/formly/formly-validate-contact-info/formly-validate-contact-info.component.mjs +124 -0
- package/esm2022/lib/formly/formly-view-documents/formly-view-documents.component.mjs +245 -0
- package/esm2022/lib/formly/formly-view-offers/formly-view-offers.component.mjs +160 -0
- package/esm2022/lib/model-population.helper.mjs +265 -0
- package/esm2022/lib/models/application-type.model.mjs +12 -0
- package/esm2022/lib/models/application.model.mjs +30 -0
- package/esm2022/lib/models/auth/users.model.mjs +2 -0
- package/esm2022/lib/models/dictionary.model.mjs +20 -0
- package/esm2022/lib/models/flux.model.mjs +105 -0
- package/esm2022/lib/models/forms.model.mjs +572 -0
- package/esm2022/lib/models/label-info.model.mjs +2 -0
- package/esm2022/lib/models/label.model.mjs +2 -0
- package/esm2022/lib/models/language.model.mjs +3 -0
- package/esm2022/lib/models/list.model.mjs +2 -0
- package/esm2022/lib/models/partner.model.mjs +3 -0
- package/esm2022/lib/models/treeview.model.mjs +15 -0
- package/esm2022/lib/origin-form-auth.service.mjs +40 -0
- package/esm2022/lib/origin-form-config.model.mjs +2 -0
- package/esm2022/lib/origin-form-token.interceptor.mjs +35 -0
- package/esm2022/lib/origin-form.component.mjs +2391 -0
- package/esm2022/lib/origin-form.module.mjs +479 -0
- package/esm2022/lib/origin-form.service.mjs +14 -0
- package/esm2022/lib/others/check-list.database.mjs +55 -0
- package/esm2022/lib/others/config-service.mjs +42 -0
- package/esm2022/lib/others/dictionary-label-info.mjs +3 -0
- package/esm2022/lib/others/environment-type.mjs +21 -0
- package/esm2022/lib/others/external-link.directive.mjs +49 -0
- package/esm2022/lib/others/flux-helper.mjs +1397 -0
- package/esm2022/lib/others/picker.component.mjs +119 -0
- package/esm2022/lib/others/translation.pipe.mjs +21 -0
- package/esm2022/lib/others/translations-helper.mjs +258 -0
- package/esm2022/lib/others/utils.mjs +272 -0
- package/esm2022/lib/services/applicationData.service.mjs +145 -0
- package/esm2022/lib/services/auth-http.service.mjs +80 -0
- package/esm2022/lib/services/dialog.service.mjs +56 -0
- package/esm2022/lib/services/dictionary.service.mjs +198 -0
- package/esm2022/lib/services/forms.service.mjs +47 -0
- package/esm2022/lib/services/labels.service.mjs +29 -0
- package/esm2022/lib/services/language.service.mjs +24 -0
- package/esm2022/lib/services/open-banking.service.mjs +194 -0
- package/esm2022/lib/services/origin-form-signalr-handler.service.mjs +107 -0
- package/esm2022/lib/services/origin-form-signalr.service.mjs +105 -0
- package/esm2022/lib/services/otp.service.mjs +28 -0
- package/esm2022/lib/services/proxy.service.mjs +79 -0
- package/esm2022/lib/services/scroll-to-error.service.mjs +369 -0
- package/esm2022/lib/services/translation.service.mjs +27 -0
- package/esm2022/lib/shared-components/confirmation.component.mjs +34 -0
- package/esm2022/lib/shared-components/dictionaries-tree.component.mjs +301 -0
- package/esm2022/lib/shared-components/grid.component.mjs +241 -0
- package/esm2022/lib/shared-components/treeview/treeview.component.mjs +224 -0
- package/esm2022/lib/theme-css.mjs +2254 -0
- package/esm2022/lib/theme-injector.service.mjs +26 -0
- package/esm2022/public-api.mjs +4 -0
- package/esm2022/qbs-origin-origin-form.mjs +5 -0
- package/fesm2022/qbs-origin-origin-form.mjs +15215 -0
- package/fesm2022/qbs-origin-origin-form.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/action-step-handler.d.ts +49 -0
- package/lib/auth-client.service.d.ts +17 -0
- package/lib/enums/label.keys.d.ts +720 -0
- package/lib/form-css.helper.d.ts +28 -0
- package/lib/formly/baseFormlyControlComponent.d.ts +25 -0
- package/lib/formly/baseFormlyStepComponent.d.ts +29 -0
- package/lib/formly/custom-section-separator.component.d.ts +6 -0
- package/lib/formly/form-section-separator.component.d.ts +10 -0
- package/lib/formly/formly-action.d.ts +13 -0
- package/lib/formly/formly-checkbox/formly-checkbox.component.d.ts +15 -0
- package/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.d.ts +45 -0
- package/lib/formly/formly-download-documents/formly-download-documents.component.d.ts +22 -0
- package/lib/formly/formly-enrol-card/formly-enrol-card.component.d.ts +114 -0
- package/lib/formly/formly-field-stepper/formly-field-stepper.component.d.ts +79 -0
- package/lib/formly/formly-generate-documents/formly-generate-documents.component.d.ts +17 -0
- package/lib/formly/formly-identification.component.d.ts +19 -0
- package/lib/formly/formly-open-banking/formly-open-banking.component.d.ts +119 -0
- package/lib/formly/formly-paragraph/formly-paragraph.component.d.ts +10 -0
- package/lib/formly/formly-radio/formly-radio-component.d.ts +15 -0
- package/lib/formly/formly-row-fille.d.ts +6 -0
- package/lib/formly/formly-scan-id/formly-scan-id.component.d.ts +41 -0
- package/lib/formly/formly-sign/formly-sign.component.d.ts +36 -0
- package/lib/formly/formly-upload-documents/formly-upload-documents.component.d.ts +25 -0
- package/lib/formly/formly-validate-contact-info/formly-validate-contact-info.component.d.ts +79 -0
- package/lib/formly/formly-view-documents/formly-view-documents.component.d.ts +33 -0
- package/lib/formly/formly-view-offers/formly-view-offers.component.d.ts +23 -0
- package/lib/model-population.helper.d.ts +8 -0
- package/lib/models/application-type.model.d.ts +27 -0
- package/lib/models/application.model.d.ts +107 -0
- package/lib/models/auth/users.model.d.ts +20 -0
- package/lib/models/dictionary.model.d.ts +77 -0
- package/lib/models/flux.model.d.ts +101 -0
- package/lib/models/forms.model.d.ts +504 -0
- package/lib/models/label-info.model.d.ts +10 -0
- package/lib/models/label.model.d.ts +4 -0
- package/lib/models/language.model.d.ts +5 -0
- package/lib/models/list.model.d.ts +8 -0
- package/lib/models/partner.model.d.ts +12 -0
- package/lib/models/treeview.model.d.ts +17 -0
- package/lib/origin-form-auth.service.d.ts +15 -0
- package/lib/origin-form-config.model.d.ts +12 -0
- package/lib/origin-form-token.interceptor.d.ts +12 -0
- package/lib/origin-form.component.d.ts +231 -0
- package/lib/origin-form.module.d.ts +84 -0
- package/lib/origin-form.service.d.ts +6 -0
- package/lib/others/check-list.database.d.ts +16 -0
- package/lib/others/config-service.d.ts +22 -0
- package/lib/others/dictionary-label-info.d.ts +6 -0
- package/lib/others/environment-type.d.ts +8 -0
- package/lib/others/external-link.directive.d.ts +12 -0
- package/lib/others/flux-helper.d.ts +115 -0
- package/lib/others/picker.component.d.ts +36 -0
- package/lib/others/translation.pipe.d.ts +10 -0
- package/lib/others/translations-helper.d.ts +31 -0
- package/lib/others/utils.d.ts +37 -0
- package/lib/services/applicationData.service.d.ts +35 -0
- package/lib/services/auth-http.service.d.ts +21 -0
- package/lib/services/dialog.service.d.ts +20 -0
- package/lib/services/dictionary.service.d.ts +89 -0
- package/lib/services/forms.service.d.ts +17 -0
- package/lib/services/labels.service.d.ts +13 -0
- package/lib/services/language.service.d.ts +14 -0
- package/lib/services/open-banking.service.d.ts +137 -0
- package/lib/services/origin-form-signalr-handler.service.d.ts +29 -0
- package/lib/services/origin-form-signalr.service.d.ts +24 -0
- package/lib/services/otp.service.d.ts +22 -0
- package/lib/services/proxy.service.d.ts +29 -0
- package/lib/services/scroll-to-error.service.d.ts +54 -0
- package/lib/services/translation.service.d.ts +10 -0
- package/lib/shared-components/confirmation.component.d.ts +77 -0
- package/lib/shared-components/dictionaries-tree.component.d.ts +51 -0
- package/lib/shared-components/grid.component.d.ts +138 -0
- package/lib/shared-components/treeview/treeview.component.d.ts +121 -0
- package/lib/theme-css.d.ts +2 -0
- package/lib/theme-injector.service.d.ts +8 -0
- package/package.json +42 -0
- package/public-api.d.ts +3 -0
- package/schematics-compiled/collection.json +10 -0
- package/schematics-compiled/ng-add/index.d.ts +2 -0
- package/schematics-compiled/ng-add/index.js +67 -0
- package/schematics-compiled/ng-add/index.js.map +1 -0
- package/schematics-compiled/ng-add/schema.json +8 -0
- package/src/lib/assets/fonts/Figtree-Bold.ttf +0 -0
- package/src/lib/assets/fonts/Figtree-Light.ttf +0 -0
- package/src/lib/assets/fonts/Figtree-Regular.ttf +0 -0
- package/src/lib/assets/fonts/Sora-ExtraBold.ttf +0 -0
- package/src/lib/assets/fonts/Sora-Light.ttf +0 -0
- package/src/lib/assets/fonts/Sora-Regular.ttf +0 -0
- package/src/lib/assets/fonts/ttrounds-bold-webfont.woff +0 -0
- package/src/lib/assets/fonts/ttrounds-bold-webfont.woff2 +0 -0
- package/src/lib/assets/fonts/ttrounds-regular-webfont.woff +0 -0
- package/src/lib/assets/fonts/ttrounds-regular-webfont.woff2 +0 -0
- package/src/lib/assets/fonts/ttrounds-thin-webfont.woff +0 -0
- package/src/lib/assets/fonts/ttrounds-thin-webfont.woff2 +0 -0
- package/src/lib/assets/images/flag/icon-flag-de.svg +10 -0
- package/src/lib/assets/images/flag/icon-flag-en.svg +1 -0
- package/src/lib/assets/images/flag/icon-flag-es.svg +11 -0
- package/src/lib/assets/images/flag/icon-flag-fr.svg +1 -0
- package/src/lib/assets/images/flag/icon-flag-ro.svg +11 -0
- package/src/lib/assets/images/flag/origin-form/new-id-card.png +0 -0
- 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
|