@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.
Files changed (27) hide show
  1. package/esm2022/lib/form-css.helper.mjs +122 -28
  2. package/esm2022/lib/formly/custom-section-separator.component.mjs +11 -3
  3. package/esm2022/lib/formly/form-section-separator.component.mjs +34 -11
  4. package/esm2022/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.mjs +23 -8
  5. package/esm2022/lib/formly/formly-radio/formly-radio-component.mjs +3 -3
  6. package/esm2022/lib/formly/formly-row-spacer.mjs +12 -0
  7. package/esm2022/lib/formly/formly-row-wrapper.mjs +32 -0
  8. package/esm2022/lib/formly/formly-scan-id/formly-scan-id.component.mjs +21 -26
  9. package/esm2022/lib/model-population.helper.mjs +22 -1
  10. package/esm2022/lib/models/flux.model.mjs +1 -1
  11. package/esm2022/lib/models/forms.model.mjs +77 -25
  12. package/esm2022/lib/origin-form.component.mjs +170 -55
  13. package/esm2022/lib/origin-form.module.mjs +11 -1
  14. package/esm2022/lib/services/applicationData.service.mjs +1 -1
  15. package/fesm2022/qbs-origin-origin-form.mjs +518 -151
  16. package/fesm2022/qbs-origin-origin-form.mjs.map +1 -1
  17. package/lib/form-css.helper.d.ts +7 -0
  18. package/lib/formly/form-section-separator.component.d.ts +2 -2
  19. package/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.d.ts +2 -1
  20. package/lib/formly/formly-row-spacer.d.ts +6 -0
  21. package/lib/formly/formly-row-wrapper.d.ts +6 -0
  22. package/lib/models/flux.model.d.ts +4 -0
  23. package/lib/models/forms.model.d.ts +22 -6
  24. package/lib/origin-form.component.d.ts +6 -1
  25. package/lib/origin-form.module.d.ts +64 -62
  26. package/lib/services/applicationData.service.d.ts +1 -1
  27. 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 fontStyleForInputText = cssRules['.font-input'];
52
- if (fontStyleForInputText) {
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'] += ' !important';
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 fontStyleForLabelText = cssRules['.component-text-field-label'];
64
- if (fontStyleForLabelText) {
65
- labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);
66
- signLabelSpecificCss = this.styleObjectToString(fontStyleForLabelText, true);
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: ${fontStyleForLabelText['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
- return `${key} { ${css}}`;
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 fontStyleForInputText = cssRules['.font-list'];
330
- if (fontStyleForInputText) {
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 fontStyleForLabelText = cssRules['.component-data-label'];
339
- if (fontStyleForLabelText) {
340
- labelSpecificCss = this.styleObjectToString(fontStyleForLabelText);
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['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)
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":"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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"]}
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 class="custom-section">
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 class="custom-section">
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXNlY3Rpb24tc2VwYXJhdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29yaWdpbi1mb3JtL3NyYy9saWIvZm9ybWx5L2N1c3RvbS1zZWN0aW9uLXNlcGFyYXRvci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7Ozs7QUFrQzdDLE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxTQUFTOytHQUF4QyxzQkFBc0I7bUdBQXRCLHNCQUFzQixvRkE5QnZCOzs7Ozs7Ozs7R0FTVDs7NEZBcUJVLHNCQUFzQjtrQkFoQ2xDLFNBQVM7K0JBQ0UsdUJBQXVCLFlBQ3ZCOzs7Ozs7Ozs7R0FTVCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmllbGRUeXBlIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2Zvcm1seS1jdXN0b20tc2VjdGlvbicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImN1c3RvbS1zZWN0aW9uXCI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBmaWVsZCBvZiBmaWVsZC5maWVsZEdyb3VwXCI+XG4gICAgICAgIDxmb3JtbHktZmllbGRcbiAgICAgICAgICBbZmllbGRdPVwiZmllbGRcIlxuICAgICAgICAgIFtuZ0NsYXNzXT1cImZpZWxkLmNsYXNzTmFtZVwiXG4gICAgICAgID48L2Zvcm1seS1maWVsZD5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICAuY3VzdG9tLXNlY3Rpb24ge1xuICAgICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgICBnYXA6IDVweDtcbiAgICAgICAgbWFyZ2luLWJvdHRvbTogNXB4O1xuICAgICAgICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IHJlcGVhdCgxMiwgMWZyKTtcbiAgICAgIH1cbiAgICAgIC5mdWxsLXdpZHRoIHtcbiAgICAgICAgZ3JpZC1jb2x1bW46IHNwYW4gMTI7XG4gICAgICB9XG4gICAgICAuaGFsZi13aWR0aCB7XG4gICAgICAgIGdyaWQtY29sdW1uOiBzcGFuIDY7XG4gICAgICB9XG4gICAgICAucXVhcnRlci13aWR0aCB7XG4gICAgICAgIGdyaWQtY29sdW1uOiBzcGFuIDM7XG4gICAgICB9XG4gICAgYCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgQ3VzdG9tU2VjdGlvbkNvbXBvbmVudCBleHRlbmRzIEZpZWxkVHlwZSB7fSJdfQ==
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
- 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;
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="margin: 2% ;">
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 *ngIf="to && to['showSeparator']" [ngStyle]="separatorStyle" />
36
+ <hr
37
+ *ngIf="to && to['showSeparator']"
38
+ [ngStyle]="separatorStyle"
39
+ class="section-separator"
40
+ />
22
41
  </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"] }] }); }
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="margin: 2% ;">
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 *ngIf="to && to['showSeparator']" [ngStyle]="separatorStyle" />
51
+ <hr
52
+ *ngIf="to && to['showSeparator']"
53
+ [ngStyle]="separatorStyle"
54
+ class="section-separator"
55
+ />
33
56
  </div>
34
- `, styles: [".separator{margin:2% 0}\n"] }]
57
+ `, styles: [".separator{padding-bottom:2%}.section-separator{border:none;margin:10px 0}\n"] }]
35
58
  }] });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zZWN0aW9uLXNlcGFyYXRvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vcmlnaW4tZm9ybS9zcmMvbGliL2Zvcm1seS9mb3JtLXNlY3Rpb24tc2VwYXJhdG9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7O0FBb0I3QyxNQUFNLE9BQU8sNkJBQThCLFNBQVEsU0FBUztJQUkxRCxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7WUFDekIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLENBQUM7WUFDN0QsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1lBQ2xFLElBQUksY0FBYyxJQUFJLGNBQWMsQ0FBQyxRQUFRLENBQUMsS0FBSyxLQUFLLEVBQUUsQ0FBQztnQkFDekQsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7WUFDdkMsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDOytHQVpVLDZCQUE2QjttR0FBN0IsNkJBQTZCLHFGQWhCOUI7Ozs7Ozs7R0FPVDs7NEZBU1UsNkJBQTZCO2tCQWxCekMsU0FBUzsrQkFDRSx3QkFBd0IsWUFDeEI7Ozs7Ozs7R0FPVCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGaWVsZFR5cGUgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZm9ybS1zZWN0aW9uLXNlcGFyYXRvcicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cInNlcGFyYXRvclwiIHN0eWxlPVwibWFyZ2luOiAyJSA7XCI+XG4gICAgICA8aDIgKm5nSWY9XCJ0byAmJiB0b1sndGl0bGUnXVwiIFtuZ1N0eWxlXT1cImhlYWRpbmcyU3R5bGVcIj5cbiAgICAgICAge3sgdG9bJ3RpdGxlJ10gfX1cbiAgICAgIDwvaDI+XG4gICAgICA8aHIgKm5nSWY9XCJ0byAmJiB0b1snc2hvd1NlcGFyYXRvciddXCIgW25nU3R5bGVdPVwic2VwYXJhdG9yU3R5bGVcIiAvPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICAuc2VwYXJhdG9yIHtcbiAgICAgICAgbWFyZ2luOiAyJSAwO1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZvcm1TZWN0aW9uU2VwYXJhdG9yQ29tcG9uZW50IGV4dGVuZHMgRmllbGRUeXBlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgaGVhZGluZzJTdHlsZTogW3Byb3A6IHN0cmluZ107XG4gIHNlcGFyYXRvclN0eWxlOiBbcHJvcDogc3RyaW5nXTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5wcm9wc1snZGVzaWduJ10pIHtcbiAgICAgIHRoaXMuaGVhZGluZzJTdHlsZSA9IHRoaXMucHJvcHNbJ2Rlc2lnbiddWycuZm9udC1oZWFkaW5nLTInXTtcbiAgICAgIGNvbnN0IHNlcGFyYXRvclN0eWxlID0gdGhpcy5wcm9wc1snZGVzaWduJ11bJy5zZXBhcmF0b3Itc2VjdGlvbiddO1xuICAgICAgaWYgKHNlcGFyYXRvclN0eWxlICYmIHNlcGFyYXRvclN0eWxlWydoZWlnaHQnXSAhPT0gJzBweCcpIHtcbiAgICAgICAgdGhpcy5zZXBhcmF0b3JTdHlsZSA9IHNlcGFyYXRvclN0eWxlO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zZWN0aW9uLXNlcGFyYXRvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vcmlnaW4tZm9ybS9zcmMvbGliL2Zvcm1seS9mb3JtLXNlY3Rpb24tc2VwYXJhdG9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7O0FBNEI3QyxNQUFNLE9BQU8sNkJBQThCLFNBQVEsU0FBUztJQTFCNUQ7O1FBMkJFLGtCQUFhLEdBQVEsRUFBRSxDQUFDO1FBQ3hCLG1CQUFjLEdBQVEsRUFBRSxDQUFDO0tBdUIxQjtJQXJCQyxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7WUFDekIsaURBQWlEO1lBQ2pELE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsaUJBQWlCLENBQUMsQ0FBQztZQUMvRCxJQUFJLGNBQWMsRUFBRSxDQUFDO2dCQUNuQixJQUFJLENBQUMsYUFBYSxHQUFHLGNBQWMsQ0FBQztZQUN0QyxDQUFDO1lBRUQsaUNBQWlDO1lBQ2pDLE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsb0JBQW9CLENBQUMsQ0FBQztZQUNuRSxJQUFJLGVBQWUsRUFBRSxDQUFDO2dCQUNwQixJQUFJLENBQUMsY0FBYyxHQUFHO29CQUNwQixHQUFHLGVBQWU7b0JBQ2xCLE9BQU8sRUFDTCxlQUFlLENBQUMsTUFBTSxJQUFJLGVBQWUsQ0FBQyxNQUFNLEtBQUssS0FBSzt3QkFDeEQsQ0FBQyxDQUFDLE9BQU87d0JBQ1QsQ0FBQyxDQUFDLE1BQU07aUJBQ2IsQ0FBQztZQUNKLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQzsrR0F4QlUsNkJBQTZCO21HQUE3Qiw2QkFBNkIscUZBeEI5Qjs7Ozs7Ozs7Ozs7R0FXVDs7NEZBYVUsNkJBQTZCO2tCQTFCekMsU0FBUzsrQkFDRSx3QkFBd0IsWUFDeEI7Ozs7Ozs7Ozs7O0dBV1QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmllbGRUeXBlIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2Zvcm0tc2VjdGlvbi1zZXBhcmF0b3InLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJzZXBhcmF0b3IgZm9ybS1zZWN0aW9uLXRpdGxlXCIgW3N0eWxlLnBhZGRpbmdUb3BdPVwicHJvcHNbJ3NlY3Rpb25NYXJnaW5Ub3AnXSB8fCAnMiUnXCI+XG4gICAgICA8aDIgKm5nSWY9XCJ0byAmJiB0b1sndGl0bGUnXVwiIFtuZ1N0eWxlXT1cImhlYWRpbmcyU3R5bGVcIj5cbiAgICAgICAge3sgdG9bJ3RpdGxlJ10gfX1cbiAgICAgIDwvaDI+XG4gICAgICA8aHJcbiAgICAgICAgKm5nSWY9XCJ0byAmJiB0b1snc2hvd1NlcGFyYXRvciddXCJcbiAgICAgICAgW25nU3R5bGVdPVwic2VwYXJhdG9yU3R5bGVcIlxuICAgICAgICBjbGFzcz1cInNlY3Rpb24tc2VwYXJhdG9yXCJcbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlczogW1xuICAgIGBcbiAgICAgIC5zZXBhcmF0b3Ige1xuICAgICAgICBwYWRkaW5nLWJvdHRvbTogMiU7XG4gICAgICB9XG4gICAgICAuc2VjdGlvbi1zZXBhcmF0b3Ige1xuICAgICAgICBib3JkZXI6IG5vbmU7XG4gICAgICAgIG1hcmdpbjogMTBweCAwO1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZvcm1TZWN0aW9uU2VwYXJhdG9yQ29tcG9uZW50IGV4dGVuZHMgRmllbGRUeXBlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgaGVhZGluZzJTdHlsZTogYW55ID0ge307XG4gIHNlcGFyYXRvclN0eWxlOiBhbnkgPSB7fTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5wcm9wc1snZGVzaWduJ10pIHtcbiAgICAgIC8vIFVzZSB0aGUgY29ycmVjdGVkIENTUyBjbGFzcyBuYW1lIGZvciBIZWFkaW5nIDJcbiAgICAgIGNvbnN0IGhlYWRpbmcyRGVzaWduID0gdGhpcy5wcm9wc1snZGVzaWduJ11bJy5mb250LWhlYWRpbmctMiddO1xuICAgICAgaWYgKGhlYWRpbmcyRGVzaWduKSB7XG4gICAgICAgIHRoaXMuaGVhZGluZzJTdHlsZSA9IGhlYWRpbmcyRGVzaWduO1xuICAgICAgfVxuXG4gICAgICAvLyBBcHBseSBzZXBhcmF0b3Igc2VjdGlvbiBzdHlsZXNcbiAgICAgIGNvbnN0IHNlcGFyYXRvckRlc2lnbiA9IHRoaXMucHJvcHNbJ2Rlc2lnbiddWycuc2VwYXJhdG9yLXNlY3Rpb24nXTtcbiAgICAgIGlmIChzZXBhcmF0b3JEZXNpZ24pIHtcbiAgICAgICAgdGhpcy5zZXBhcmF0b3JTdHlsZSA9IHtcbiAgICAgICAgICAuLi5zZXBhcmF0b3JEZXNpZ24sXG4gICAgICAgICAgZGlzcGxheTpcbiAgICAgICAgICAgIHNlcGFyYXRvckRlc2lnbi5oZWlnaHQgJiYgc2VwYXJhdG9yRGVzaWduLmhlaWdodCAhPT0gJzBweCdcbiAgICAgICAgICAgICAgPyAnYmxvY2snXG4gICAgICAgICAgICAgIDogJ25vbmUnLFxuICAgICAgICB9O1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19