@qbs-origin/origin-form 0.8.10 → 0.8.12
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/esm2022/lib/form-css.helper.mjs +122 -28
- package/esm2022/lib/formly/custom-section-separator.component.mjs +11 -3
- package/esm2022/lib/formly/form-section-separator.component.mjs +34 -11
- package/esm2022/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.mjs +23 -8
- package/esm2022/lib/formly/formly-radio/formly-radio-component.mjs +3 -3
- package/esm2022/lib/formly/formly-row-spacer.mjs +12 -0
- package/esm2022/lib/formly/formly-row-wrapper.mjs +32 -0
- package/esm2022/lib/formly/formly-scan-id/formly-scan-id.component.mjs +21 -26
- package/esm2022/lib/model-population.helper.mjs +22 -1
- package/esm2022/lib/models/flux.model.mjs +1 -1
- package/esm2022/lib/models/forms.model.mjs +77 -25
- package/esm2022/lib/origin-form.component.mjs +170 -55
- package/esm2022/lib/origin-form.module.mjs +11 -1
- package/esm2022/lib/services/applicationData.service.mjs +1 -1
- package/fesm2022/qbs-origin-origin-form.mjs +518 -151
- package/fesm2022/qbs-origin-origin-form.mjs.map +1 -1
- package/lib/form-css.helper.d.ts +7 -0
- package/lib/formly/form-section-separator.component.d.ts +2 -2
- package/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.d.ts +2 -1
- package/lib/formly/formly-row-spacer.d.ts +6 -0
- package/lib/formly/formly-row-wrapper.d.ts +6 -0
- package/lib/models/flux.model.d.ts +4 -0
- package/lib/models/forms.model.d.ts +22 -6
- package/lib/origin-form.component.d.ts +6 -1
- package/lib/origin-form.module.d.ts +64 -62
- package/lib/services/applicationData.service.d.ts +1 -1
- package/package.json +1 -1
|
@@ -36,38 +36,97 @@ export class FormCssHelper {
|
|
|
36
36
|
case '.component-data':
|
|
37
37
|
cssText = this.getSpecificCssForData(key, values, cssRules);
|
|
38
38
|
break;
|
|
39
|
+
case '.component-dictionary':
|
|
40
|
+
cssText = this.getSpecificCssForDictionary(key, values, cssRules);
|
|
41
|
+
break;
|
|
39
42
|
case '.table-details':
|
|
40
43
|
cssText = this.getSpecificCssForTableDetail(values);
|
|
41
44
|
break;
|
|
42
45
|
case '.table-header':
|
|
43
46
|
cssText = this.getSpecificCssForTableHeader(values);
|
|
44
47
|
break;
|
|
48
|
+
case '.component-progress-bar':
|
|
49
|
+
cssText = this.getSpecificCssForProgressBar(values);
|
|
50
|
+
break;
|
|
51
|
+
}
|
|
52
|
+
// Append component-level margin rules (applies to all 5 margin-enabled components)
|
|
53
|
+
const marginTop = values['component-margin-top'];
|
|
54
|
+
const marginBottom = values['component-margin-bottom'];
|
|
55
|
+
const marginParts = [];
|
|
56
|
+
if (marginTop && marginTop !== 'none') {
|
|
57
|
+
marginParts.push(`margin-top: ${marginTop} !important;`);
|
|
58
|
+
}
|
|
59
|
+
if (marginBottom && marginBottom !== 'none') {
|
|
60
|
+
marginParts.push(`margin-bottom: ${marginBottom} !important;`);
|
|
61
|
+
}
|
|
62
|
+
if (marginParts.length > 0) {
|
|
63
|
+
cssText += ` ${key} { ${marginParts.join(' ')} }`;
|
|
45
64
|
}
|
|
46
65
|
return cssText;
|
|
47
66
|
}
|
|
67
|
+
static getSpecificCssForDictionary(key, values, cssRules) {
|
|
68
|
+
let inputSpecificCss = '';
|
|
69
|
+
const fontStyleSource = cssRules['.component-dictionary-value'] || cssRules['.font-input'];
|
|
70
|
+
if (fontStyleSource) {
|
|
71
|
+
const fontStyleForInputText = { ...fontStyleSource };
|
|
72
|
+
if (values['text-align']) {
|
|
73
|
+
fontStyleForInputText['text-align'] = values['text-align'];
|
|
74
|
+
}
|
|
75
|
+
fontStyleForInputText['color'] = (fontStyleForInputText['color'] || '') + ' !important';
|
|
76
|
+
inputSpecificCss = this.styleObjectToString({ ...fontStyleForInputText });
|
|
77
|
+
}
|
|
78
|
+
let labelSpecificCss = '';
|
|
79
|
+
const labelSource = cssRules['.component-dictionary-label'];
|
|
80
|
+
if (labelSource) {
|
|
81
|
+
labelSpecificCss = this.styleObjectToString({ ...labelSource });
|
|
82
|
+
}
|
|
83
|
+
var css = `
|
|
84
|
+
.mat-mdc-text-field-wrapper.mdc-text-field {
|
|
85
|
+
${this.styleObjectToString({ ...values })};
|
|
86
|
+
border-style: solid;
|
|
87
|
+
input {
|
|
88
|
+
${inputSpecificCss}
|
|
89
|
+
}
|
|
90
|
+
mat-label {
|
|
91
|
+
${labelSpecificCss}
|
|
92
|
+
}
|
|
93
|
+
.mdc-line-ripple--active::after {
|
|
94
|
+
border-bottom-color: ${labelSource ? labelSource['color'] : 'inherit'}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
.component-dictionary-label label {
|
|
99
|
+
${labelSpecificCss}
|
|
100
|
+
}
|
|
101
|
+
`;
|
|
102
|
+
return `${key} { ${css} }`;
|
|
103
|
+
}
|
|
48
104
|
static getSpecificCssForInput(key, values, cssRules) {
|
|
49
105
|
let inputSpecificCss = '';
|
|
50
106
|
let signInputSpecificCss = '';
|
|
51
|
-
const
|
|
52
|
-
if (
|
|
107
|
+
const fontStyleSource = cssRules['.component-text-field-value'] || cssRules['.font-input'];
|
|
108
|
+
if (fontStyleSource) {
|
|
109
|
+
const fontStyleForInputText = { ...fontStyleSource };
|
|
53
110
|
//transfer property from component to input
|
|
54
111
|
if (values['text-align']) {
|
|
55
112
|
fontStyleForInputText['text-align'] = values['text-align'];
|
|
56
113
|
}
|
|
57
|
-
fontStyleForInputText['color']
|
|
58
|
-
inputSpecificCss = this.styleObjectToString(fontStyleForInputText);
|
|
59
|
-
signInputSpecificCss = this.styleObjectToString(fontStyleForInputText, true);
|
|
114
|
+
fontStyleForInputText['color'] = (fontStyleForInputText['color'] || '') + ' !important';
|
|
115
|
+
inputSpecificCss = this.styleObjectToString({ ...fontStyleForInputText });
|
|
116
|
+
signInputSpecificCss = this.styleObjectToString({ ...fontStyleForInputText }, true);
|
|
60
117
|
}
|
|
61
118
|
let labelSpecificCss = '';
|
|
62
119
|
let signLabelSpecificCss = '';
|
|
63
|
-
const
|
|
64
|
-
if (
|
|
65
|
-
labelSpecificCss = this.styleObjectToString(
|
|
66
|
-
signLabelSpecificCss = this.styleObjectToString(
|
|
120
|
+
const labelSource = cssRules['.component-text-field-label'];
|
|
121
|
+
if (labelSource) {
|
|
122
|
+
labelSpecificCss = this.styleObjectToString({ ...labelSource });
|
|
123
|
+
signLabelSpecificCss = this.styleObjectToString({ ...labelSource }, true);
|
|
67
124
|
}
|
|
125
|
+
const textareaHeight = values['textarea-height'] || '';
|
|
126
|
+
const textareaMaxHeight = values['textarea-max-height'] || '';
|
|
68
127
|
var css = `
|
|
69
128
|
.mat-mdc-text-field-wrapper.mdc-text-field {
|
|
70
|
-
${this.styleObjectToString(values)};
|
|
129
|
+
${this.styleObjectToString({ ...values })};
|
|
71
130
|
border-style: solid;
|
|
72
131
|
input {
|
|
73
132
|
${inputSpecificCss}
|
|
@@ -76,13 +135,13 @@ export class FormCssHelper {
|
|
|
76
135
|
${labelSpecificCss}
|
|
77
136
|
}
|
|
78
137
|
.mdc-line-ripple--active::after {
|
|
79
|
-
border-bottom-color: ${
|
|
138
|
+
border-bottom-color: ${labelSource ? labelSource['color'] : 'inherit'}
|
|
80
139
|
}
|
|
81
140
|
}
|
|
82
141
|
|
|
83
142
|
input.component-text-field {
|
|
84
143
|
border-style: solid !important;
|
|
85
|
-
${this.styleObjectToString(values, true)};
|
|
144
|
+
${this.styleObjectToString({ ...values }, true)};
|
|
86
145
|
${signInputSpecificCss}
|
|
87
146
|
}
|
|
88
147
|
|
|
@@ -90,7 +149,34 @@ export class FormCssHelper {
|
|
|
90
149
|
${signLabelSpecificCss}
|
|
91
150
|
}
|
|
92
151
|
`;
|
|
93
|
-
|
|
152
|
+
// Flat explicit rules scoped to textarea only.
|
|
153
|
+
// :has(textarea) on the infix ensures min-height/max-height do NOT affect
|
|
154
|
+
// text/numeric inputs that share the same .component-text-field class.
|
|
155
|
+
const textareaFlatCss = `
|
|
156
|
+
${key} .mat-mdc-text-field-wrapper.mdc-text-field:has(textarea) .mat-mdc-form-field-infix {
|
|
157
|
+
${textareaHeight ? `min-height: ${textareaHeight} !important;` : ''}
|
|
158
|
+
}
|
|
159
|
+
${key} .mat-mdc-text-field-wrapper.mdc-text-field textarea {
|
|
160
|
+
${inputSpecificCss}
|
|
161
|
+
${textareaHeight ? `min-height: ${textareaHeight} !important;` : ''}
|
|
162
|
+
${textareaMaxHeight && textareaMaxHeight !== 'none' ? `max-height: ${textareaMaxHeight} !important; overflow-y: auto !important;` : ''}
|
|
163
|
+
resize: none !important;
|
|
164
|
+
}
|
|
165
|
+
`;
|
|
166
|
+
return `${key} { ${css}} ${textareaFlatCss}`;
|
|
167
|
+
}
|
|
168
|
+
static getSpecificCssForProgressBar(values) {
|
|
169
|
+
const startColor = values['startColor'] || '#8848EF';
|
|
170
|
+
const endColor = values['endColor'] || '#8848EF';
|
|
171
|
+
const height = values['height'] || '4px';
|
|
172
|
+
const borderRadius = values['borderRadius'] || '7px';
|
|
173
|
+
return `
|
|
174
|
+
.component-progress-bar {
|
|
175
|
+
background: linear-gradient(to right, ${startColor}, ${endColor}) !important;
|
|
176
|
+
height: ${height} !important;
|
|
177
|
+
border-radius: ${borderRadius} !important;
|
|
178
|
+
}
|
|
179
|
+
`;
|
|
94
180
|
}
|
|
95
181
|
static getSpecificCssForTableHeader(values) {
|
|
96
182
|
const backgroundColor = values['background-color'] || '#ffffff';
|
|
@@ -271,7 +357,8 @@ export class FormCssHelper {
|
|
|
271
357
|
.component-text-field mat-label,
|
|
272
358
|
.component-checkbox mat-label,
|
|
273
359
|
.component-radio mat-label,
|
|
274
|
-
.component-date mat-label
|
|
360
|
+
.component-date mat-label,
|
|
361
|
+
.component-dictionary mat-label {
|
|
275
362
|
${cssRules['.font-label']
|
|
276
363
|
? this.styleObjectToString(cssRules['.font-label'])
|
|
277
364
|
: ''}
|
|
@@ -326,21 +413,22 @@ export class FormCssHelper {
|
|
|
326
413
|
}
|
|
327
414
|
static getSpecificCssForData(key, values, cssRules) {
|
|
328
415
|
let inputSpecificCss = '';
|
|
329
|
-
const
|
|
330
|
-
if (
|
|
416
|
+
const fontStyleSource = cssRules['.component-date-value'] || cssRules['.component-data-value'] || cssRules['.font-list'];
|
|
417
|
+
if (fontStyleSource) {
|
|
418
|
+
const fontStyleForInputText = { ...fontStyleSource };
|
|
331
419
|
//transfer property from component to input
|
|
332
420
|
if (values['text-align']) {
|
|
333
421
|
fontStyleForInputText['text-align'] = values['text-align'];
|
|
334
422
|
}
|
|
335
|
-
inputSpecificCss = this.styleObjectToString(fontStyleForInputText);
|
|
423
|
+
inputSpecificCss = this.styleObjectToString({ ...fontStyleForInputText });
|
|
336
424
|
}
|
|
337
425
|
let labelSpecificCss = '';
|
|
338
|
-
const
|
|
339
|
-
if (
|
|
340
|
-
labelSpecificCss = this.styleObjectToString(
|
|
426
|
+
const labelSource = cssRules['.component-data-label'];
|
|
427
|
+
if (labelSource) {
|
|
428
|
+
labelSpecificCss = this.styleObjectToString({ ...labelSource });
|
|
341
429
|
}
|
|
342
430
|
return ` ${key} { .mat-mdc-text-field-wrapper.mdc-text-field {
|
|
343
|
-
${this.styleObjectToString(values)};
|
|
431
|
+
${this.styleObjectToString({ ...values })};
|
|
344
432
|
border-style:solid;
|
|
345
433
|
input{
|
|
346
434
|
${inputSpecificCss}
|
|
@@ -353,15 +441,21 @@ export class FormCssHelper {
|
|
|
353
441
|
}
|
|
354
442
|
} `;
|
|
355
443
|
}
|
|
444
|
+
static { this.INTERNAL_KEYS = ['textarea-height', 'textarea-max-height', 'component-margin-top', 'component-margin-bottom']; }
|
|
356
445
|
static styleObjectToString(values, important = false) {
|
|
357
|
-
values
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
446
|
+
const output = { ...values };
|
|
447
|
+
// Remove internal keys that are not valid CSS properties
|
|
448
|
+
this.INTERNAL_KEYS.forEach(k => delete output[k]);
|
|
449
|
+
if (!output['width']) {
|
|
450
|
+
output['width'] =
|
|
451
|
+
'calc(100%' +
|
|
452
|
+
('margin-left' in output ? ` - ${output['margin-left']}` : '') +
|
|
453
|
+
('margin-right' in output ? ` - ${output['margin-right']}` : '') +
|
|
454
|
+
')';
|
|
455
|
+
}
|
|
456
|
+
return Object.entries(output)
|
|
363
457
|
.map(([key, value]) => `${key}: ${value}${important ? ' !important' : ''}`)
|
|
364
458
|
.join('; ');
|
|
365
459
|
}
|
|
366
460
|
}
|
|
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":"AAEA,MAAM,OAAO,aAAa;IAEjB,MAAM,CAAC,oBAAoB,CAAC,QAAkB,EAAE,aAAsB;QAC3E,IAAI,WAAW,GAAG,aAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAC3D,IAAI,aAAa,EAAE,CAAC;YAClB,MAAM,OAAO,GAAG,IAAI,CAAC,oBAAoB,CACvC,0CAA0C,EAC1C,EAAE,OAAO,EAAE,MAAM,EAAE,EACnB,QAAQ,CACT,CAAC;YACF,WAAW,IAAI,OAAO,CAAC;QACzB,CAAC;QACD,OAAO,WAAW,CAAC;IACrB,CAAC;IAEO,MAAM,CAAC,gBAAgB,CAAC,QAAkB;QAChD,MAAM,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;aACzC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;aAC1D,IAAI,CAAC,GAAG,CAAC,CAAC;QACb,OAAO,WAAW,CAAC;IACrB,CAAC;IAEO,MAAM,CAAC,oBAAoB,CACjC,GAAW,EACX,MAAsC,EACtC,QAAkB;QAElB,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;aACxC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC;aAC7B,IAAI,CAAC,GAAG,CAAC,CAAC;QACb,IAAI,OAAO,GAAG,IAAI,GAAG,KAAK,YAAY,IAAI,CAAC;QAE3C,QAAQ,GAAG,EAAE,CAAC;YACZ,KAAK,uBAAuB;gBAC1B,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;gBAC7D,MAAM;YACR,KAAK,qBAAqB;gBACxB,OAAO,GAAG,IAAI,CAAC,yBAAyB,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;gBAChE,MAAM;YACR,KAAK,iBAAiB;gBACpB,OAAO,GAAG,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;gBACjE,MAAM;YACR,KAAK,eAAe,CAAC;YACrB,KAAK,kBAAkB;gBACrB,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;gBACxD,MAAM;YACR,KAAK,iBAAiB,CAAC;YACvB,KAAK,iBAAiB;gBACpB,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;gBAC5D,MAAM;YACR,KAAK,gBAAgB;gBACnB,OAAO,GAAG,IAAI,CAAC,4BAA4B,CAAC,MAAM,CAAC,CAAC;gBACpD,MAAM;YACR,KAAK,eAAe;gBAClB,OAAO,GAAG,IAAI,CAAC,4BAA4B,CAAC,MAAM,CAAC,CAAC;gBACpD,MAAM;QACV,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAEM,MAAM,CAAC,sBAAsB,CAClC,GAAW,EACX,MAAsC,EACtC,QAAkB;QAElB,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,IAAI,oBAAoB,GAAG,EAAE,CAAC;QAC9B,MAAM,qBAAqB,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;QACtD,IAAI,qBAAqB,EAAE,CAAC;YAC1B,2CAA2C;YAC3C,IAAI,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;gBACzB,qBAAqB,CAAC,YAAY,CAAC,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;YAC7D,CAAC;YACD,qBAAqB,CAAC,OAAO,CAAC,IAAI,aAAa,CAAC;YAChD,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,qBAAqB,CAAC,CAAC;YACnE,oBAAoB,GAAG,IAAI,CAAC,mBAAmB,CAC7C,qBAAqB,EACrB,IAAI,CACL,CAAC;QACJ,CAAC;QAED,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,IAAI,oBAAoB,GAAG,EAAE,CAAC;QAC9B,MAAM,qBAAqB,GAAG,QAAQ,CAAC,6BAA6B,CAAC,CAAC;QACtE,IAAI,qBAAqB,EAAE,CAAC;YAC1B,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,qBAAqB,CAAC,CAAC;YACnE,oBAAoB,GAAG,IAAI,CAAC,mBAAmB,CAC7C,qBAAqB,EACrB,IAAI,CACL,CAAC;QACJ,CAAC;QAED,IAAI,GAAG,GAAG;;QAEN,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC;;;UAG9B,gBAAgB;;;UAGhB,gBAAgB;;;+BAGK,qBAAqB,CAAC,OAAO,CAAC;;;;;;QAMrD,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC;QACtC,oBAAoB;;;;QAIpB,oBAAoB;;KAEvB,CAAC;QAEF,OAAO,GAAG,GAAG,MAAM,GAAG,GAAG,CAAC;IAC5B,CAAC;IAEM,MAAM,CAAC,4BAA4B,CACxC,MAAsC;QAEtC,MAAM,eAAe,GAAG,MAAM,CAAC,kBAAkB,CAAC,IAAI,SAAS,CAAC;QAChE,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,CAAC;QAC/C,MAAM,MAAM,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QACtC,MAAM,WAAW,GAAG,MAAM,CAAC,cAAc,CAAC,IAAI,SAAS,CAAC;QACxD,MAAM,cAAc,GAAG,MAAM,CAAC,iBAAiB,CAAC,IAAI,UAAU,CAAC;QAC/D,MAAM,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,IAAI,GAAG,CAAC;QACtD,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,MAAM,CAAC;QACjD,MAAM,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,IAAI,QAAQ,CAAC;QAC3D,MAAM,UAAU,GAAG,MAAM,CAAC,aAAa,CAAC,IAAI,mBAAmB,CAAC;QAChE,MAAM,QAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,MAAM,CAAC;QAC/C,MAAM,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,IAAI,QAAQ,CAAC;QAC3D,MAAM,OAAO,GAAG,MAAM,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC;QAC3C,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC;QACxC,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,MAAM,CAAC;QAE1C,MAAM,GAAG,GAAG;;;yBAGS,cAAc;wBACf,aAAa;qBAChB,UAAU;mBACZ,QAAQ;;;gBAGX,MAAM;;yBAEG,MAAM;;;0BAGL,eAAe;eAC1B,KAAK;yBACK,cAAc;0BACb,aAAa;kBACrB,MAAM,UAAU,WAAW;0BACnB,aAAa;uBAChB,UAAU;qBACZ,QAAQ;;;eAGd,SAAS;gBACR,MAAM,UAAU,WAAW;oBACvB,SAAS;wBACL,aAAa;iBACpB,OAAO;gBACR,MAAM;;;KAGjB,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,MAAM,CAAC,4BAA4B,CACxC,MAAsC;QAEtC,MAAM,eAAe,GAAG,MAAM,CAAC,kBAAkB,CAAC,IAAI,SAAS,CAAC;QAChE,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,CAAC;QAC/C,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,MAAM,CAAC;QACjD,MAAM,aAAa,GAAG,MAAM,CAAC,eAAe,CAAC,IAAI,QAAQ,CAAC;QAC1D,MAAM,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,IAAI,QAAQ,CAAC;QAC3D,MAAM,OAAO,GAAG,MAAM,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC;QAC3C,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,KAAK,CAAC;QAC/C,MAAM,cAAc,GAAG,MAAM,CAAC,iBAAiB,CAAC,IAAI,SAAS,CAAC;QAC9D,MAAM,oBAAoB,GAAG,MAAM,CAAC,wBAAwB,CAAC,IAAI,SAAS,CAAC;QAE3E,MAAM,GAAG,GAAG;;;2BAGW,eAAe;;;kBAGxB,SAAS,UAAU,cAAc;qBAC9B,SAAS,UAAU,cAAc;aACzC,SAAS;kBACJ,SAAS;sBACL,aAAa;sBACb,aAAa;;;;;wBAKX,oBAAoB;;;;;eAK7B,OAAO;;;KAGjB,CAAC;QAEF,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,MAAM,CAAC,yBAAyB,CACrC,GAAW,EACX,MAAsC,EACtC,QAAkB;QAElB,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,MAAM,qBAAqB,GAAG,QAAQ,CAAC,2BAA2B,CAAC,CAAC;QACpE,IAAI,qBAAqB,EAAE,CAAC;YAC1B,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,qBAAqB,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,GAAG,GAAG;;oBAEM,MAAM,CAAC,YAAY,CAAC;sBAClB,MAAM,CAAC,cAAc,CAAC;uBACrB,MAAM,CAAC,eAAe,CAAC;qBACzB,MAAM,CAAC,aAAa,CAAC;;UAEhC,gBAAgB;;;;;kCAKQ,MAAM,CAAC,cAAc,CAAC;mCACrB,MAAM,CAAC,cAAc,CAAC;qCACpB,MAAM,CAAC,cAAc,CAAC;;;;;;;4BAO/B,MAAM,CAAC,kBAAkB,CAAC;kBACpC,MAAM,CAAC,cAAc,CAAC,UAAU,MAAM,CAAC,cAAc,CAAC;yBAC/C,MAAM,CAAC,eAAe,CAAC;kCACd,MAAM,CAAC,cAAc,CAAC;mCACrB,MAAM,CAAC,cAAc,CAAC;;;;gBAIzC,MAAM,CAAC,cAAc,CAAC,UAAU,MAAM,CAAC,cAAc,CAAC;;;eAGvD,MAAM,CAAC,OAAO,CAAC;MACxB,CAAC;QACH,OAAO,GAAG,GAAG,MAAM,GAAG,IAAI,CAAC;IAC7B,CAAC;IAEO,MAAM,CAAC,0BAA0B,CACvC,GAAW,EACX,MAAsC,EACtC,QAAkB;QAElB,MAAM,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAE1D,0CAA0C;QAC1C,MAAM,aAAa,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAClD,MAAM,YAAY,GAAG,aAAa;YAChC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACzC,CAAC,CAAC,EAAE,CAAC;QAEP,kCAAkC;QAClC,MAAM,aAAa,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAClD,MAAM,eAAe,GAAG,aAAa;YACnC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACzC,CAAC,CAAC,EAAE,CAAC;QAEP,qCAAqC;QACrC,MAAM,aAAa,GAAG,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAClD,MAAM,kBAAkB,GAAG,aAAa;YACtC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACzC,CAAC,CAAC,EAAE,CAAC;QAEP,OAAO;;;YAGC,YAAY;;;;;UAKd,YAAY;;;;UAIZ,YAAY;;;;;UAKZ,eAAe;;;;;UAKf,kBAAkB;;;;;UAKlB,YAAY;;;;;;;UAOZ,QAAQ,CAAC,aAAa,CAAC;YACzB,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;YACnD,CAAC,CAAC,EACJ;;KAED,CAAC;IACJ,CAAC;IAEM,MAAM,CAAC,sBAAsB,CAClC,MAAsC,EACtC,QAAkB;QAElB,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,MAAM,qBAAqB,GAAG,QAAQ,CAAC,wBAAwB,CAAC,CAAC;QACjE,IAAI,qBAAqB,EAAE,CAAC;YAC1B,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,qBAAqB,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,GAAG,GAAG;;oBAEM,MAAM,CAAC,YAAY,CAAC;sBAClB,MAAM,CAAC,cAAc,CAAC;uBACrB,MAAM,CAAC,eAAe,CAAC;qBACzB,MAAM,CAAC,aAAa,CAAC;;UAEhC,gBAAgB;;;;;;;;;;;;oCAYU,MAAM,CAAC,cAAc,CAAC;qCACrB,MAAM,CAAC,cAAc,CAAC;;gCAE3B,MAAM,CAAC,kBAAkB,CAAC;sBACpC,MAAM,CAAC,cAAc,CAAC,UAAU,MAAM,CAAC,cAAc,CAAC;;sCAEtC,MAAM,CAAC,cAAc,CAAC;uCACrB,MAAM,CAAC,cAAc,CAAC;;8BAE/B,MAAM,CAAC,kBAAkB,CAAC;;;8BAG1B,MAAM,CAAC,OAAO,CAAC;;;;;;KAMxC,CAAC;QAEF,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,MAAM,CAAC,qBAAqB,CACjC,GAAW,EACX,MAAsC,EACtC,QAAkB;QAElB,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,MAAM,qBAAqB,GAAG,QAAQ,CAAC,YAAY,CAAC,CAAC;QACrD,IAAI,qBAAqB,EAAE,CAAC;YAC1B,2CAA2C;YAC3C,IAAI,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;gBACzB,qBAAqB,CAAC,YAAY,CAAC,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;YAC7D,CAAC;YACD,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,qBAAqB,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,MAAM,qBAAqB,GAAG,QAAQ,CAAC,uBAAuB,CAAC,CAAC;QAChE,IAAI,qBAAqB,EAAE,CAAC;YAC1B,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,qBAAqB,CAAC,CAAC;QACrE,CAAC;QACD,OAAO,IAAI,GAAG;4BACU,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC;;;8BAG9B,gBAAgB;;;;+BAIf,gBAAgB;;;;uBAIxB,CAAC;IACtB,CAAC;IAEM,MAAM,CAAC,mBAAmB,CAC/B,MAAsC,EACtC,YAAqB,KAAK;QAE1B,MAAM,CAAC,OAAO,CAAC;YACb,WAAW;gBACX,CAAC,aAAa,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,MAAM,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC9D,CAAC,cAAc,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,MAAM,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;gBAChE,GAAG,CAAC;QAEN,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;aAC1B,GAAG,CACF,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,KAAK,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,EAAE,CACtE;aACA,IAAI,CAAC,IAAI,CAAC,CAAC;IAChB,CAAC;CACF","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"]}
|
|
461
|
+
//# 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 '.component-dictionary':\n        cssText = this.getSpecificCssForDictionary(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     case '.component-progress-bar':\n        cssText = this.getSpecificCssForProgressBar(values);\n        break;\n    }\n\n    // Append component-level margin rules (applies to all 5 margin-enabled components)\n    const marginTop = values['component-margin-top'];\n    const marginBottom = values['component-margin-bottom'];\n    const marginParts: string[] = [];\n    if (marginTop && marginTop !== 'none') {\n      marginParts.push(`margin-top: ${marginTop} !important;`);\n    }\n    if (marginBottom && marginBottom !== 'none') {\n      marginParts.push(`margin-bottom: ${marginBottom} !important;`);\n    }\n    if (marginParts.length > 0) {\n      cssText += ` ${key} { ${marginParts.join(' ')} }`;\n    }\n\n    return cssText;\n  }\n\n  public static getSpecificCssForDictionary(\n    key: string,\n    values: { [property: string]: string },\n    cssRules: CssRules\n  ): string {\n    let inputSpecificCss = '';\n    const fontStyleSource = cssRules['.component-dictionary-value'] || cssRules['.font-input'];\n    if (fontStyleSource) {\n      const fontStyleForInputText = { ...fontStyleSource };\n      if (values['text-align']) {\n        fontStyleForInputText['text-align'] = values['text-align'];\n      }\n      fontStyleForInputText['color'] = (fontStyleForInputText['color'] || '') + ' !important';\n      inputSpecificCss = this.styleObjectToString({ ...fontStyleForInputText });\n    }\n\n    let labelSpecificCss = '';\n    const labelSource = cssRules['.component-dictionary-label'];\n    if (labelSource) {\n      labelSpecificCss = this.styleObjectToString({ ...labelSource });\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: ${labelSource ? labelSource['color'] : 'inherit'}\n      }\n    }\n\n    .component-dictionary-label label {\n      ${labelSpecificCss}\n    }\n    `;\n\n    return `${key} { ${css} }`;\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 fontStyleSource = cssRules['.component-text-field-value'] || cssRules['.font-input'];\n    if (fontStyleSource) {\n      const fontStyleForInputText = { ...fontStyleSource };\n      //transfer property from component to input\n      if (values['text-align']) {\n        fontStyleForInputText['text-align'] = values['text-align'];\n      }\n      fontStyleForInputText['color'] = (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 labelSource = cssRules['.component-text-field-label'];\n    if (labelSource) {\n      labelSpecificCss = this.styleObjectToString({ ...labelSource });\n      signLabelSpecificCss = this.styleObjectToString(\n        { ...labelSource },\n        true\n      );\n    }\n\n    const textareaHeight = values['textarea-height'] || '';\n    const textareaMaxHeight = values['textarea-max-height'] || '';\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: ${labelSource ? labelSource['color'] : 'inherit'}\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    // Flat explicit rules scoped to textarea only.\n    // :has(textarea) on the infix ensures min-height/max-height do NOT affect\n    // text/numeric inputs that share the same .component-text-field class.\n    const textareaFlatCss = `\n    ${key} .mat-mdc-text-field-wrapper.mdc-text-field:has(textarea) .mat-mdc-form-field-infix {\n      ${textareaHeight ? `min-height: ${textareaHeight} !important;` : ''}\n    }\n    ${key} .mat-mdc-text-field-wrapper.mdc-text-field textarea {\n      ${inputSpecificCss}\n      ${textareaHeight ? `min-height: ${textareaHeight} !important;` : ''}\n      ${textareaMaxHeight && textareaMaxHeight !== 'none' ? `max-height: ${textareaMaxHeight} !important; overflow-y: auto !important;` : ''}\n      resize: none !important;\n    }\n    `;\n\n    return `${key} { ${css}} ${textareaFlatCss}`;\n  }\n\n  public static getSpecificCssForProgressBar(values: { [property: string]: string }): string {\n    const startColor = values['startColor'] || '#8848EF';\n    const endColor = values['endColor'] || '#8848EF';\n    const height = values['height'] || '4px';\n    const borderRadius = values['borderRadius'] || '7px';\n\n    return `\n      .component-progress-bar {\n        background: linear-gradient(to right, ${startColor}, ${endColor}) !important;\n        height: ${height} !important;\n        border-radius: ${borderRadius} !important;\n      }\n    `;\n  }\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      .component-dictionary 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 fontStyleSource = cssRules['.component-date-value'] || cssRules['.component-data-value'] || cssRules['.font-list'];\n    if (fontStyleSource) {\n      const fontStyleForInputText = { ...fontStyleSource };\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 labelSource = cssRules['.component-data-label'];\n    if (labelSource) {\n      labelSpecificCss = this.styleObjectToString({ ...labelSource });\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  private static readonly INTERNAL_KEYS = ['textarea-height', 'textarea-max-height', 'component-margin-top', 'component-margin-bottom'];\n\n  public static styleObjectToString(\n    values: { [property: string]: string },\n    important: boolean = false\n  ): string {\n    const output = { ...values };\n    // Remove internal keys that are not valid CSS properties\n    this.INTERNAL_KEYS.forEach(k => delete output[k]);\n\n    if (!output['width']) {\n      output['width'] =\n        'calc(100%' +\n        ('margin-left' in output ? ` - ${output['margin-left']}` : '') +\n        ('margin-right' in output ? ` - ${output['margin-right']}` : '') +\n        ')';\n    }\n\n    return Object.entries(output)\n      .map(\n        ([key, value]) => `${key}: ${value}${important ? ' !important' : ''}`\n      )\n      .join('; ');\n  }\n}\n"]}
|
|
@@ -6,7 +6,11 @@ import * as i2 from "@ngx-formly/core";
|
|
|
6
6
|
export class CustomSectionComponent extends FieldType {
|
|
7
7
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CustomSectionComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
8
8
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: CustomSectionComponent, selector: "formly-custom-section", usesInheritance: true, ngImport: i0, template: `
|
|
9
|
-
<div
|
|
9
|
+
<div
|
|
10
|
+
class="custom-section"
|
|
11
|
+
[style.paddingTop]="props['sectionMarginTop']"
|
|
12
|
+
[style.paddingBottom]="props['sectionMarginBottom']"
|
|
13
|
+
>
|
|
10
14
|
<ng-container *ngFor="let field of field.fieldGroup">
|
|
11
15
|
<formly-field
|
|
12
16
|
[field]="field"
|
|
@@ -19,7 +23,11 @@ export class CustomSectionComponent extends FieldType {
|
|
|
19
23
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CustomSectionComponent, decorators: [{
|
|
20
24
|
type: Component,
|
|
21
25
|
args: [{ selector: 'formly-custom-section', template: `
|
|
22
|
-
<div
|
|
26
|
+
<div
|
|
27
|
+
class="custom-section"
|
|
28
|
+
[style.paddingTop]="props['sectionMarginTop']"
|
|
29
|
+
[style.paddingBottom]="props['sectionMarginBottom']"
|
|
30
|
+
>
|
|
23
31
|
<ng-container *ngFor="let field of field.fieldGroup">
|
|
24
32
|
<formly-field
|
|
25
33
|
[field]="field"
|
|
@@ -29,4 +37,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
29
37
|
</div>
|
|
30
38
|
`, 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
39
|
}] });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXNlY3Rpb24tc2VwYXJhdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29yaWdpbi1mb3JtL3NyYy9saWIvZm9ybWx5L2N1c3RvbS1zZWN0aW9uLXNlcGFyYXRvci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7Ozs7QUFzQzdDLE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxTQUFTOytHQUF4QyxzQkFBc0I7bUdBQXRCLHNCQUFzQixvRkFsQ3ZCOzs7Ozs7Ozs7Ozs7O0dBYVQ7OzRGQXFCVSxzQkFBc0I7a0JBcENsQyxTQUFTOytCQUNFLHVCQUF1QixZQUN2Qjs7Ozs7Ozs7Ozs7OztHQWFUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGaWVsZFR5cGUgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZm9ybWx5LWN1c3RvbS1zZWN0aW9uJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2XG4gICAgICBjbGFzcz1cImN1c3RvbS1zZWN0aW9uXCJcbiAgICAgIFtzdHlsZS5wYWRkaW5nVG9wXT1cInByb3BzWydzZWN0aW9uTWFyZ2luVG9wJ11cIlxuICAgICAgW3N0eWxlLnBhZGRpbmdCb3R0b21dPVwicHJvcHNbJ3NlY3Rpb25NYXJnaW5Cb3R0b20nXVwiXG4gICAgPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgZmllbGQgb2YgZmllbGQuZmllbGRHcm91cFwiPlxuICAgICAgICA8Zm9ybWx5LWZpZWxkXG4gICAgICAgICAgW2ZpZWxkXT1cImZpZWxkXCJcbiAgICAgICAgICBbbmdDbGFzc109XCJmaWVsZC5jbGFzc05hbWVcIlxuICAgICAgICA+PC9mb3JtbHktZmllbGQ+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVzOiBbXG4gICAgYFxuICAgICAgLmN1c3RvbS1zZWN0aW9uIHtcbiAgICAgICAgZGlzcGxheTogZ3JpZDtcbiAgICAgICAgZ2FwOiA1cHg7XG4gICAgICAgIG1hcmdpbi1ib3R0b206IDVweDtcbiAgICAgICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiByZXBlYXQoMTIsIDFmcik7XG4gICAgICB9XG4gICAgICAuZnVsbC13aWR0aCB7XG4gICAgICAgIGdyaWQtY29sdW1uOiBzcGFuIDEyO1xuICAgICAgfVxuICAgICAgLmhhbGYtd2lkdGgge1xuICAgICAgICBncmlkLWNvbHVtbjogc3BhbiA2O1xuICAgICAgfVxuICAgICAgLnF1YXJ0ZXItd2lkdGgge1xuICAgICAgICBncmlkLWNvbHVtbjogc3BhbiAzO1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEN1c3RvbVNlY3Rpb25Db21wb25lbnQgZXh0ZW5kcyBGaWVsZFR5cGUgeyB9XG4iXX0=
|
|
@@ -3,34 +3,57 @@ import { FieldType } from '@ngx-formly/core';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
5
|
export class FormSectionSeparatorComponent extends FieldType {
|
|
6
|
+
constructor() {
|
|
7
|
+
super(...arguments);
|
|
8
|
+
this.heading2Style = {};
|
|
9
|
+
this.separatorStyle = {};
|
|
10
|
+
}
|
|
6
11
|
ngOnInit() {
|
|
7
12
|
if (this.props['design']) {
|
|
8
|
-
|
|
9
|
-
const
|
|
10
|
-
if (
|
|
11
|
-
this.
|
|
13
|
+
// Use the corrected CSS class name for Heading 2
|
|
14
|
+
const heading2Design = this.props['design']['.font-heading-2'];
|
|
15
|
+
if (heading2Design) {
|
|
16
|
+
this.heading2Style = heading2Design;
|
|
17
|
+
}
|
|
18
|
+
// Apply separator section styles
|
|
19
|
+
const separatorDesign = this.props['design']['.separator-section'];
|
|
20
|
+
if (separatorDesign) {
|
|
21
|
+
this.separatorStyle = {
|
|
22
|
+
...separatorDesign,
|
|
23
|
+
display: separatorDesign.height && separatorDesign.height !== '0px'
|
|
24
|
+
? 'block'
|
|
25
|
+
: 'none',
|
|
26
|
+
};
|
|
12
27
|
}
|
|
13
28
|
}
|
|
14
29
|
}
|
|
15
30
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormSectionSeparatorComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
16
31
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormSectionSeparatorComponent, selector: "form-section-separator", usesInheritance: true, ngImport: i0, template: `
|
|
17
|
-
<div class="separator" style="
|
|
32
|
+
<div class="separator form-section-title" [style.paddingTop]="props['sectionMarginTop'] || '2%'">
|
|
18
33
|
<h2 *ngIf="to && to['title']" [ngStyle]="heading2Style">
|
|
19
34
|
{{ to['title'] }}
|
|
20
35
|
</h2>
|
|
21
|
-
<hr
|
|
36
|
+
<hr
|
|
37
|
+
*ngIf="to && to['showSeparator']"
|
|
38
|
+
[ngStyle]="separatorStyle"
|
|
39
|
+
class="section-separator"
|
|
40
|
+
/>
|
|
22
41
|
</div>
|
|
23
|
-
`, isInline: true, styles: [".separator{
|
|
42
|
+
`, isInline: true, styles: [".separator{padding-bottom:2%}.section-separator{border:none;margin:10px 0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
24
43
|
}
|
|
25
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormSectionSeparatorComponent, decorators: [{
|
|
26
45
|
type: Component,
|
|
27
46
|
args: [{ selector: 'form-section-separator', template: `
|
|
28
|
-
<div class="separator" style="
|
|
47
|
+
<div class="separator form-section-title" [style.paddingTop]="props['sectionMarginTop'] || '2%'">
|
|
29
48
|
<h2 *ngIf="to && to['title']" [ngStyle]="heading2Style">
|
|
30
49
|
{{ to['title'] }}
|
|
31
50
|
</h2>
|
|
32
|
-
<hr
|
|
51
|
+
<hr
|
|
52
|
+
*ngIf="to && to['showSeparator']"
|
|
53
|
+
[ngStyle]="separatorStyle"
|
|
54
|
+
class="section-separator"
|
|
55
|
+
/>
|
|
33
56
|
</div>
|
|
34
|
-
`, styles: [".separator{
|
|
57
|
+
`, styles: [".separator{padding-bottom:2%}.section-separator{border:none;margin:10px 0}\n"] }]
|
|
35
58
|
}] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zZWN0aW9uLXNlcGFyYXRvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vcmlnaW4tZm9ybS9zcmMvbGliL2Zvcm1seS9mb3JtLXNlY3Rpb24tc2VwYXJhdG9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7O0FBNEI3QyxNQUFNLE9BQU8sNkJBQThCLFNBQVEsU0FBUztJQTFCNUQ7O1FBMkJFLGtCQUFhLEdBQVEsRUFBRSxDQUFDO1FBQ3hCLG1CQUFjLEdBQVEsRUFBRSxDQUFDO0tBdUIxQjtJQXJCQyxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7WUFDekIsaURBQWlEO1lBQ2pELE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsaUJBQWlCLENBQUMsQ0FBQztZQUMvRCxJQUFJLGNBQWMsRUFBRSxDQUFDO2dCQUNuQixJQUFJLENBQUMsYUFBYSxHQUFHLGNBQWMsQ0FBQztZQUN0QyxDQUFDO1lBRUQsaUNBQWlDO1lBQ2pDLE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsb0JBQW9CLENBQUMsQ0FBQztZQUNuRSxJQUFJLGVBQWUsRUFBRSxDQUFDO2dCQUNwQixJQUFJLENBQUMsY0FBYyxHQUFHO29CQUNwQixHQUFHLGVBQWU7b0JBQ2xCLE9BQU8sRUFDTCxlQUFlLENBQUMsTUFBTSxJQUFJLGVBQWUsQ0FBQyxNQUFNLEtBQUssS0FBSzt3QkFDeEQsQ0FBQyxDQUFDLE9BQU87d0JBQ1QsQ0FBQyxDQUFDLE1BQU07aUJBQ2IsQ0FBQztZQUNKLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQzsrR0F4QlUsNkJBQTZCO21HQUE3Qiw2QkFBNkIscUZBeEI5Qjs7Ozs7Ozs7Ozs7R0FXVDs7NEZBYVUsNkJBQTZCO2tCQTFCekMsU0FBUzsrQkFDRSx3QkFBd0IsWUFDeEI7Ozs7Ozs7Ozs7O0dBV1QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmllbGRUeXBlIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2Zvcm0tc2VjdGlvbi1zZXBhcmF0b3InLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJzZXBhcmF0b3IgZm9ybS1zZWN0aW9uLXRpdGxlXCIgW3N0eWxlLnBhZGRpbmdUb3BdPVwicHJvcHNbJ3NlY3Rpb25NYXJnaW5Ub3AnXSB8fCAnMiUnXCI+XG4gICAgICA8aDIgKm5nSWY9XCJ0byAmJiB0b1sndGl0bGUnXVwiIFtuZ1N0eWxlXT1cImhlYWRpbmcyU3R5bGVcIj5cbiAgICAgICAge3sgdG9bJ3RpdGxlJ10gfX1cbiAgICAgIDwvaDI+XG4gICAgICA8aHJcbiAgICAgICAgKm5nSWY9XCJ0byAmJiB0b1snc2hvd1NlcGFyYXRvciddXCJcbiAgICAgICAgW25nU3R5bGVdPVwic2VwYXJhdG9yU3R5bGVcIlxuICAgICAgICBjbGFzcz1cInNlY3Rpb24tc2VwYXJhdG9yXCJcbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlczogW1xuICAgIGBcbiAgICAgIC5zZXBhcmF0b3Ige1xuICAgICAgICBwYWRkaW5nLWJvdHRvbTogMiU7XG4gICAgICB9XG4gICAgICAuc2VjdGlvbi1zZXBhcmF0b3Ige1xuICAgICAgICBib3JkZXI6IG5vbmU7XG4gICAgICAgIG1hcmdpbjogMTBweCAwO1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZvcm1TZWN0aW9uU2VwYXJhdG9yQ29tcG9uZW50IGV4dGVuZHMgRmllbGRUeXBlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgaGVhZGluZzJTdHlsZTogYW55ID0ge307XG4gIHNlcGFyYXRvclN0eWxlOiBhbnkgPSB7fTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5wcm9wc1snZGVzaWduJ10pIHtcbiAgICAgIC8vIFVzZSB0aGUgY29ycmVjdGVkIENTUyBjbGFzcyBuYW1lIGZvciBIZWFkaW5nIDJcbiAgICAgIGNvbnN0IGhlYWRpbmcyRGVzaWduID0gdGhpcy5wcm9wc1snZGVzaWduJ11bJy5mb250LWhlYWRpbmctMiddO1xuICAgICAgaWYgKGhlYWRpbmcyRGVzaWduKSB7XG4gICAgICAgIHRoaXMuaGVhZGluZzJTdHlsZSA9IGhlYWRpbmcyRGVzaWduO1xuICAgICAgfVxuXG4gICAgICAvLyBBcHBseSBzZXBhcmF0b3Igc2VjdGlvbiBzdHlsZXNcbiAgICAgIGNvbnN0IHNlcGFyYXRvckRlc2lnbiA9IHRoaXMucHJvcHNbJ2Rlc2lnbiddWycuc2VwYXJhdG9yLXNlY3Rpb24nXTtcbiAgICAgIGlmIChzZXBhcmF0b3JEZXNpZ24pIHtcbiAgICAgICAgdGhpcy5zZXBhcmF0b3JTdHlsZSA9IHtcbiAgICAgICAgICAuLi5zZXBhcmF0b3JEZXNpZ24sXG4gICAgICAgICAgZGlzcGxheTpcbiAgICAgICAgICAgIHNlcGFyYXRvckRlc2lnbi5oZWlnaHQgJiYgc2VwYXJhdG9yRGVzaWduLmhlaWdodCAhPT0gJzBweCdcbiAgICAgICAgICAgICAgPyAnYmxvY2snXG4gICAgICAgICAgICAgIDogJ25vbmUnLFxuICAgICAgICB9O1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19
|