@rangertechnologies/ngnxt 2.1.106 → 2.1.107
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/ar.i18n.mjs +29 -0
- package/esm2022/lib/components/button/nxt-button.component.mjs +130 -0
- package/esm2022/lib/components/custom-button/custom-button.component.mjs +39 -0
- package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +366 -0
- package/esm2022/lib/components/custom-date/custom-date.component.mjs +47 -0
- package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +48 -0
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +219 -0
- package/esm2022/lib/components/custom-image/custom-image.component.mjs +34 -0
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +93 -0
- package/esm2022/lib/components/custom-label/custom-label.component.mjs +21 -0
- package/esm2022/lib/components/custom-model/custom-model.component.mjs +48 -0
- package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +115 -0
- package/esm2022/lib/components/custom-rich-text/custom-rich-text.component.mjs +186 -0
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +347 -0
- package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +65 -0
- package/esm2022/lib/components/custom-time/custom-time.component.mjs +61 -0
- package/esm2022/lib/components/datatable/datatable.component.mjs +801 -0
- package/esm2022/lib/components/dependent-table/dependent-table.component.mjs +42 -0
- package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +39 -0
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +279 -0
- package/esm2022/lib/components/file-view/file-view.component.mjs +46 -0
- package/esm2022/lib/components/loader/loader.component.mjs +23 -0
- package/esm2022/lib/components/pagination/pagination.component.mjs +100 -0
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +216 -0
- package/esm2022/lib/components/search-box/search-box.component.mjs +202 -0
- package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +123 -0
- package/esm2022/lib/directives/componenthost/componenthost.directive.mjs +19 -0
- package/esm2022/lib/en.i18n.mjs +29 -0
- package/esm2022/lib/i18n-config.service.mjs +4 -0
- package/esm2022/lib/i18n.component.mjs +47 -0
- package/esm2022/lib/i18n.module.mjs +38 -0
- package/esm2022/lib/i18n.pipe.mjs +25 -0
- package/esm2022/lib/i18n.service.mjs +56 -0
- package/esm2022/lib/interfaces/actionMeta.mjs +2 -0
- package/esm2022/lib/interfaces/apimeta.mjs +2 -0
- package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -0
- package/esm2022/lib/model/bookletWrapper.mjs +9 -0
- package/esm2022/lib/model/changeWrapper.mjs +11 -0
- package/esm2022/lib/model/errorWrapper.mjs +6 -0
- package/esm2022/lib/model/tableWrapper.mjs +20 -0
- package/esm2022/lib/nxt-app.component.mjs +22 -0
- package/esm2022/lib/nxt-app.module.mjs +399 -0
- package/esm2022/lib/nxt-app.service.mjs +14 -0
- package/esm2022/lib/pages/booklet/booklet.component.mjs +541 -0
- package/esm2022/lib/pages/builder/element/element.component.mjs +199 -0
- package/esm2022/lib/pages/builder/form/form.component.mjs +34 -0
- package/esm2022/lib/pages/builder/menu/menu.component.mjs +28 -0
- package/esm2022/lib/pages/builder/properties/properties.component.mjs +494 -0
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +458 -0
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2387 -0
- package/esm2022/lib/pages/summary-page/summary-page.component.mjs +76 -0
- package/esm2022/lib/pipe/date/date.pipe.mjs +28 -0
- package/esm2022/lib/pipe/editColumnCheck/edit-column-check.pipe.mjs +28 -0
- package/esm2022/lib/pipe/editColumnDropdown/edit-column-dropdown.pipe.mjs +20 -0
- package/esm2022/lib/pipe/editColumnType/edit-column-type.pipe.mjs +20 -0
- package/esm2022/lib/pipe/get-value.pipe.mjs +50 -0
- package/esm2022/lib/pipe/search-filter/search-filter.pipe.mjs +39 -0
- package/esm2022/lib/pipe/time/time.pipe.mjs +26 -0
- package/esm2022/lib/sample.mjs +3715 -0
- package/esm2022/lib/services/change.service.mjs +53 -0
- package/esm2022/lib/services/data.service.mjs +80 -0
- package/esm2022/lib/services/form-builder.service.mjs +165 -0
- package/esm2022/lib/services/salesforce.service.mjs +46 -0
- package/esm2022/lib/services/shared.service.mjs +100 -0
- package/esm2022/lib/services/storage.service.mjs +44 -0
- package/esm2022/lib/tam.i18n.mjs +29 -0
- package/esm2022/lib/wrapper.mjs +175 -0
- package/esm2022/public-api.mjs +22 -0
- package/esm2022/rangertechnologies-ngnxt.mjs +5 -0
- package/fesm2022/rangertechnologies-ngnxt.mjs +12895 -0
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/ar.i18n.d.ts +24 -0
- package/lib/components/button/nxt-button.component.d.ts +38 -0
- package/lib/components/custom-button/custom-button.component.d.ts +16 -0
- package/lib/components/custom-calendar/custom-calendar.component.d.ts +65 -0
- package/lib/components/custom-date/custom-date.component.d.ts +18 -0
- package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +19 -0
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +39 -0
- package/lib/components/custom-image/custom-image.component.d.ts +13 -0
- package/lib/components/custom-input/custom-input.component.d.ts +31 -0
- package/lib/components/custom-label/custom-label.component.d.ts +10 -0
- package/lib/components/custom-model/custom-model.component.d.ts +19 -0
- package/lib/components/custom-radio/custom-radio.component.d.ts +33 -0
- package/lib/components/custom-rich-text/custom-rich-text.component.d.ts +29 -0
- package/lib/components/custom-table/custom-table.component.d.ts +65 -0
- package/lib/components/custom-text-area/custom-text-area.component.d.ts +22 -0
- package/lib/components/custom-time/custom-time.component.d.ts +18 -0
- package/lib/components/datatable/datatable.component.d.ts +126 -0
- package/lib/components/dependent-table/dependent-table.component.d.ts +15 -0
- package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +16 -0
- package/lib/components/file-upload/file-upload.component.d.ts +47 -0
- package/lib/components/file-view/file-view.component.d.ts +16 -0
- package/lib/components/loader/loader.component.d.ts +11 -0
- package/lib/components/pagination/pagination.component.d.ts +36 -0
- package/lib/components/pick-location/pick-location.component.d.ts +44 -0
- package/lib/components/search-box/search-box.component.d.ts +43 -0
- package/lib/components/table-appendix/table-appendix.component.d.ts +30 -0
- package/lib/directives/componenthost/componenthost.directive.d.ts +8 -0
- package/lib/en.i18n.d.ts +24 -0
- package/lib/i18n-config.service.d.ts +2 -0
- package/lib/i18n.component.d.ts +11 -0
- package/lib/i18n.module.d.ts +9 -0
- package/lib/i18n.pipe.d.ts +10 -0
- package/lib/i18n.service.d.ts +14 -0
- package/lib/interfaces/actionMeta.d.ts +5 -0
- package/lib/interfaces/apimeta.d.ts +15 -0
- package/lib/interfaces/dependencyMeta.d.ts +8 -0
- package/lib/model/bookletWrapper.d.ts +5 -0
- package/lib/model/changeWrapper.d.ts +10 -0
- package/lib/model/errorWrapper.d.ts +5 -0
- package/lib/model/tableWrapper.d.ts +18 -0
- package/lib/nxt-app.component.d.ts +8 -0
- package/lib/nxt-app.module.d.ts +52 -0
- package/lib/nxt-app.service.d.ts +6 -0
- package/lib/pages/booklet/booklet.component.d.ts +68 -0
- package/lib/pages/builder/element/element.component.d.ts +33 -0
- package/lib/pages/builder/form/form.component.d.ts +11 -0
- package/lib/pages/builder/menu/menu.component.d.ts +10 -0
- package/lib/pages/builder/properties/properties.component.d.ts +575 -0
- package/lib/pages/questionbook/questionbook.component.d.ts +68 -0
- package/lib/pages/questionnaire/questionnaire.component.d.ts +220 -0
- package/lib/pages/summary-page/summary-page.component.d.ts +20 -0
- package/lib/pipe/date/date.pipe.d.ts +7 -0
- package/lib/pipe/editColumnCheck/edit-column-check.pipe.d.ts +7 -0
- package/lib/pipe/editColumnDropdown/edit-column-dropdown.pipe.d.ts +7 -0
- package/lib/pipe/editColumnType/edit-column-type.pipe.d.ts +7 -0
- package/lib/pipe/get-value.pipe.d.ts +7 -0
- package/lib/pipe/search-filter/search-filter.pipe.d.ts +8 -0
- package/lib/pipe/time/time.pipe.d.ts +7 -0
- package/lib/sample.d.ts +11 -0
- package/lib/services/change.service.d.ts +22 -0
- package/lib/services/data.service.d.ts +13 -0
- package/lib/services/form-builder.service.d.ts +76 -0
- package/lib/services/salesforce.service.d.ts +11 -0
- package/lib/services/shared.service.d.ts +15 -0
- package/lib/services/storage.service.d.ts +13 -0
- package/lib/tam.i18n.d.ts +24 -0
- package/lib/wrapper.d.ts +203 -0
- package/package.json +1 -5
- package/public-api.d.ts +15 -0
- package/rangertechnologies-ngnxt-2.1.107.tgz +0 -0
- package/src/lib/style.css +1817 -0
|
@@ -0,0 +1,494 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common/http";
|
|
4
|
+
import * as i2 from "../../../services/form-builder.service";
|
|
5
|
+
import * as i3 from "@angular/common";
|
|
6
|
+
import * as i4 from "@angular/forms";
|
|
7
|
+
export class PropertiesComponent {
|
|
8
|
+
http;
|
|
9
|
+
formBuilderService;
|
|
10
|
+
formButtonHandler = new EventEmitter();
|
|
11
|
+
selectedOption = '';
|
|
12
|
+
selectedElementIndex = -1;
|
|
13
|
+
selectedElementType = '';
|
|
14
|
+
selectedAlign = 'align-left'; // Add this property
|
|
15
|
+
selectedStyles = []; // Using array since multiple styles can be selected
|
|
16
|
+
errorMessage = '';
|
|
17
|
+
selectedElement = null; // Receive the selected element
|
|
18
|
+
onToggleChange(key, event) {
|
|
19
|
+
const checked = event.target.checked;
|
|
20
|
+
this.selectedElement = { ...this.selectedElement, [key]: checked };
|
|
21
|
+
this.updateProperty(key, checked); //AP-06MAR25 Bug Fixed
|
|
22
|
+
}
|
|
23
|
+
updateProperties(elementType) {
|
|
24
|
+
// Reset alignment and styles if switching elements
|
|
25
|
+
this.selectedAlign = 'align-left';
|
|
26
|
+
this.selectedStyles = [];
|
|
27
|
+
// Fetch the properties of the selected element type
|
|
28
|
+
const properties = this.getProperties();
|
|
29
|
+
if (properties) {
|
|
30
|
+
// Make sure the properties are dynamically updated
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
onAlignSelect(value) {
|
|
34
|
+
if (this.selectedElement) {
|
|
35
|
+
this.selectedElement.textAlign = value;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
onStyleSelect(value) {
|
|
39
|
+
if (!this.selectedElement)
|
|
40
|
+
return;
|
|
41
|
+
// Initialize styles array if it doesn't exist
|
|
42
|
+
this.selectedElement.styles = this.selectedElement.styles || [];
|
|
43
|
+
// Ensure only one style is selected at a time
|
|
44
|
+
this.selectedElement.styles = [value];
|
|
45
|
+
}
|
|
46
|
+
isStyleActive(value) {
|
|
47
|
+
return this.selectedElement?.styles?.includes(value) || false;
|
|
48
|
+
}
|
|
49
|
+
elementProperties = {
|
|
50
|
+
'Text': {
|
|
51
|
+
elementProps: [
|
|
52
|
+
// questionText - Label-follow all element properties
|
|
53
|
+
{ label: 'Label', placeholder: 'Enter Text ', type: 'text', key: 'questionText' },
|
|
54
|
+
// question - Placeholder-follow all element properties
|
|
55
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
56
|
+
{ label: 'Help Text', placeholder: 'Enter Text ', type: 'text', key: 'helpText' },
|
|
57
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
58
|
+
// errorMessage - Error Msg-follow all element properties
|
|
59
|
+
{ label: 'Error Msg', placeholder: 'Enter Text ', type: 'text', key: 'errorMessage' },
|
|
60
|
+
{ label: 'Font', type: 'select', key: 'font',
|
|
61
|
+
options: ['Helvetica Neue', 'Arial', 'Times New Roman', 'Roboto'] },
|
|
62
|
+
{ label: 'Weight', type: 'select', key: 'fontWeight',
|
|
63
|
+
options: [
|
|
64
|
+
{ value: '400', label: '400-Normal' },
|
|
65
|
+
{ value: '500', label: '500-Medium' },
|
|
66
|
+
{ value: '600', label: '600-Semi Bold' },
|
|
67
|
+
{ value: '700', label: '700-Bold' }
|
|
68
|
+
] },
|
|
69
|
+
// { label: 'Size', unit: 'PX', type: 'number', key: 'size' },
|
|
70
|
+
// { label: 'Align', type: 'align', key: 'textAlign',
|
|
71
|
+
// options: [
|
|
72
|
+
// { value: 'left', icon: 'textalign-left' },
|
|
73
|
+
// { value: 'center', icon: 'align-center' },
|
|
74
|
+
// { value: 'right', icon: 'align-right' },
|
|
75
|
+
// { value: 'justifyleft', icon: 'align-justifyleft' },
|
|
76
|
+
// { value: 'justifyright', icon: 'align-justifyright' }
|
|
77
|
+
// ] },
|
|
78
|
+
// { label: 'Style', type: 'style',key: 'styles',
|
|
79
|
+
// options: [
|
|
80
|
+
// { value: 'italic', icon: 'italic' },
|
|
81
|
+
// { value: 'bold', icon: 'bold' },
|
|
82
|
+
// { value: 'underline', icon: 'underline' },
|
|
83
|
+
// { value: 'texticon', icon: 'texticon' },
|
|
84
|
+
// { value: 'capitalize', icon: 'capitalize' },
|
|
85
|
+
// { value: 'resize', icon: 'resize' }
|
|
86
|
+
// ] },
|
|
87
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' }
|
|
88
|
+
],
|
|
89
|
+
fieldProps: [
|
|
90
|
+
{ label: 'Field Required', type: 'radio', key: 'isRequired' },
|
|
91
|
+
{ label: 'Default Value', placeholder: 'Enter Text ', type: 'text', key: 'defaultValue' },
|
|
92
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
93
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
94
|
+
{ label: 'SubText', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
95
|
+
]
|
|
96
|
+
},
|
|
97
|
+
'CheckBox': {
|
|
98
|
+
elementProps: [
|
|
99
|
+
{ label: 'Label', placeholder: 'Enter Text ', type: 'text', key: 'questionText' },
|
|
100
|
+
{ label: 'Place Holder', placeholder: 'Enter Text ', type: 'text', key: 'question' },
|
|
101
|
+
{ label: 'Help Text', placeholder: 'Enter Text ', type: 'text', key: 'helpText' },
|
|
102
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
103
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
104
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
105
|
+
],
|
|
106
|
+
fieldProps: [
|
|
107
|
+
{ label: 'Field Required', type: 'radio' },
|
|
108
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
109
|
+
{
|
|
110
|
+
label: 'Options',
|
|
111
|
+
type: 'checkbox',
|
|
112
|
+
key: 'options',
|
|
113
|
+
addOptionLabel: 'Add Option',
|
|
114
|
+
icon: 'plus'
|
|
115
|
+
},
|
|
116
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
117
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
118
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
119
|
+
]
|
|
120
|
+
},
|
|
121
|
+
'Calendar': {
|
|
122
|
+
elementProps: [
|
|
123
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
124
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
125
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
126
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
127
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
128
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
129
|
+
],
|
|
130
|
+
fieldProps: [
|
|
131
|
+
{ label: 'Field Required', type: 'radio' },
|
|
132
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
133
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
134
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
135
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
136
|
+
]
|
|
137
|
+
},
|
|
138
|
+
'Time': {
|
|
139
|
+
elementProps: [
|
|
140
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'label' },
|
|
141
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'placeholder' },
|
|
142
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
143
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
144
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
145
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
146
|
+
],
|
|
147
|
+
fieldProps: [
|
|
148
|
+
{ label: 'Field Required', type: 'radio' },
|
|
149
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
150
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
151
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
152
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
153
|
+
]
|
|
154
|
+
},
|
|
155
|
+
'Email': {
|
|
156
|
+
elementProps: [
|
|
157
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
158
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
159
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
160
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
161
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
162
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
163
|
+
],
|
|
164
|
+
fieldProps: [
|
|
165
|
+
{ label: 'Field Required', type: 'radio' },
|
|
166
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
167
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
168
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
169
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
170
|
+
]
|
|
171
|
+
},
|
|
172
|
+
'File': {
|
|
173
|
+
elementProps: [
|
|
174
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
175
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
176
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
177
|
+
{ label: 'Support Type', type: 'select', key: 'supportType', options: [
|
|
178
|
+
{ label: 'Images (JPEG, PNG, GIF)', value: 'image/*', extensions: ['.jpg', '.jpeg', '.png', '.gif'] },
|
|
179
|
+
{ label: 'Audio (MP3, WAV, AIFF)', value: 'audio/*', extensions: ['.mp3', '.wav', '.aiff'] },
|
|
180
|
+
{ label: 'Video (MP4, AVI, HEVC)', value: 'video/*', extensions: ['.mp4', '.avi', '.hevc'] },
|
|
181
|
+
{ label: 'Documents (DOC, DOCX, PPT, PDF)', value: 'application/pdf,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document,application/vnd.ms-powerpoint', extensions: ['.doc', '.docx', '.ppt', '.pdf'] },
|
|
182
|
+
{ label: 'Executables (EXE, BAD, SH)', value: 'application/x-msdownload,application/x-sh', extensions: ['.exe', '.bad', '.sh'] },
|
|
183
|
+
{ label: 'Archives (ZIP, RAR, Git-hub)', value: 'application/zip,application/x-rar-compressed,application/x-git', extensions: ['.zip', '.rar', '.git'] }
|
|
184
|
+
] },
|
|
185
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
186
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
187
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
188
|
+
],
|
|
189
|
+
fieldProps: [
|
|
190
|
+
{ label: 'Field Required', type: 'radio' },
|
|
191
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
192
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
193
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
194
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
195
|
+
]
|
|
196
|
+
},
|
|
197
|
+
'List': {
|
|
198
|
+
elementProps: [
|
|
199
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
200
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
201
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
202
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
203
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
204
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
205
|
+
],
|
|
206
|
+
fieldProps: [
|
|
207
|
+
{ label: 'Field Required', type: 'radio' },
|
|
208
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
209
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
210
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
211
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
212
|
+
]
|
|
213
|
+
},
|
|
214
|
+
'TextArea': {
|
|
215
|
+
elementProps: [
|
|
216
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
217
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
218
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
219
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
220
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
221
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
222
|
+
],
|
|
223
|
+
fieldProps: [
|
|
224
|
+
{ label: 'Field Required', type: 'radio', key: 'required' },
|
|
225
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },
|
|
226
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
227
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
228
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
229
|
+
]
|
|
230
|
+
},
|
|
231
|
+
'RichTextArea': {
|
|
232
|
+
elementProps: [
|
|
233
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
234
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
235
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
236
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
237
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
238
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
239
|
+
],
|
|
240
|
+
fieldProps: [
|
|
241
|
+
{ label: 'Field Required', type: 'radio', key: 'required' },
|
|
242
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },
|
|
243
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
244
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
245
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
246
|
+
]
|
|
247
|
+
},
|
|
248
|
+
'Number': {
|
|
249
|
+
elementProps: [
|
|
250
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
251
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
252
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
253
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
254
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
255
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
256
|
+
],
|
|
257
|
+
fieldProps: [
|
|
258
|
+
{ label: 'Field Required', type: 'radio' },
|
|
259
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
260
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
261
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
262
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
263
|
+
]
|
|
264
|
+
},
|
|
265
|
+
'Dropdown': {
|
|
266
|
+
elementProps: [
|
|
267
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
268
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
269
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
270
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
271
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
272
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
273
|
+
],
|
|
274
|
+
fieldProps: [
|
|
275
|
+
{ label: 'Field Required', type: 'radio' },
|
|
276
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
277
|
+
{
|
|
278
|
+
label: 'Options',
|
|
279
|
+
type: 'dropdown',
|
|
280
|
+
key: 'options',
|
|
281
|
+
addOptionLabel: 'Add Variant',
|
|
282
|
+
icon: 'plus'
|
|
283
|
+
},
|
|
284
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
285
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
286
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
287
|
+
]
|
|
288
|
+
},
|
|
289
|
+
'Image': {
|
|
290
|
+
elementProps: [
|
|
291
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
292
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
293
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
294
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
295
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
296
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
297
|
+
],
|
|
298
|
+
fieldProps: [
|
|
299
|
+
{ label: 'Field Required', type: 'radio' },
|
|
300
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
301
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
302
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
303
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
304
|
+
]
|
|
305
|
+
},
|
|
306
|
+
'Radio': {
|
|
307
|
+
elementProps: [
|
|
308
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
309
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
310
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
311
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
312
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
313
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
314
|
+
],
|
|
315
|
+
fieldProps: [
|
|
316
|
+
{ label: 'Field Required', type: 'radio' },
|
|
317
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
318
|
+
{
|
|
319
|
+
label: 'Options',
|
|
320
|
+
type: 'radio',
|
|
321
|
+
key: 'options',
|
|
322
|
+
addOptionLabel: 'Add Option',
|
|
323
|
+
icon: 'plus'
|
|
324
|
+
},
|
|
325
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
326
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
327
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
328
|
+
]
|
|
329
|
+
},
|
|
330
|
+
'Label': {
|
|
331
|
+
elementProps: [
|
|
332
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
333
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
334
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
335
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
336
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
337
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
338
|
+
],
|
|
339
|
+
fieldProps: [
|
|
340
|
+
{ label: 'Field Required', type: 'radio' },
|
|
341
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
342
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
343
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
344
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
345
|
+
]
|
|
346
|
+
},
|
|
347
|
+
'Table': {
|
|
348
|
+
elementProps: [
|
|
349
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
350
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
351
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
352
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' }
|
|
353
|
+
],
|
|
354
|
+
fieldProps: [
|
|
355
|
+
{ label: 'Field Required', type: 'radio' },
|
|
356
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
357
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
358
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' },
|
|
359
|
+
]
|
|
360
|
+
},
|
|
361
|
+
'Book': {
|
|
362
|
+
elementProps: [
|
|
363
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
364
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
365
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
366
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
367
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
368
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
369
|
+
],
|
|
370
|
+
fieldProps: [
|
|
371
|
+
{ label: 'Field Required', type: 'radio' },
|
|
372
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
373
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
374
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
375
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
376
|
+
]
|
|
377
|
+
},
|
|
378
|
+
'Button': {
|
|
379
|
+
elementProps: [
|
|
380
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
381
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
382
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
383
|
+
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
384
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'size' },
|
|
385
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },
|
|
386
|
+
],
|
|
387
|
+
fieldProps: [
|
|
388
|
+
{ label: 'Field Required', type: 'radio' },
|
|
389
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
390
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
391
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },
|
|
392
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }
|
|
393
|
+
]
|
|
394
|
+
},
|
|
395
|
+
};
|
|
396
|
+
constructor(http, formBuilderService) {
|
|
397
|
+
this.http = http;
|
|
398
|
+
this.formBuilderService = formBuilderService;
|
|
399
|
+
}
|
|
400
|
+
ngOnInit() {
|
|
401
|
+
this.formBuilderService.selectedElement$.subscribe(index => {
|
|
402
|
+
this.selectedElementIndex = index;
|
|
403
|
+
if (index >= 0) {
|
|
404
|
+
const elements = this.formBuilderService.getElements();
|
|
405
|
+
this.selectedElement = elements[index];
|
|
406
|
+
}
|
|
407
|
+
});
|
|
408
|
+
}
|
|
409
|
+
validateInput(value, type) {
|
|
410
|
+
if (type === 'label' || type === 'placeholder') {
|
|
411
|
+
const regex = /^[a-zA-Z0-9\s]*$/;
|
|
412
|
+
if (!regex.test(value)) {
|
|
413
|
+
this.errorMessage = 'Only letters and numbers are allowed';
|
|
414
|
+
return false;
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
this.errorMessage = '';
|
|
418
|
+
return true;
|
|
419
|
+
}
|
|
420
|
+
updateProperty(key, value) {
|
|
421
|
+
if (this.selectedElementIndex >= 0) {
|
|
422
|
+
if (key === 'questionText' || key === 'question') {
|
|
423
|
+
if (!this.validateInput(value, key)) {
|
|
424
|
+
return;
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
if (key === 'fontWeight') {
|
|
428
|
+
// Extract just the number value from the option
|
|
429
|
+
value = value.split('-')[0];
|
|
430
|
+
}
|
|
431
|
+
if (key === 'styles') {
|
|
432
|
+
const currentStyles = this.selectedElement.styles || [];
|
|
433
|
+
if (value === 'capitalize' || value === 'lowercase') {
|
|
434
|
+
// Remove the opposite case if it exists
|
|
435
|
+
const oppositeStyle = value === 'capitalize' ? 'lowercase' : 'capitalize';
|
|
436
|
+
const filteredStyles = currentStyles.filter(s => s !== oppositeStyle);
|
|
437
|
+
value = currentStyles.includes(value)
|
|
438
|
+
? filteredStyles.filter(s => s !== value)
|
|
439
|
+
: [...filteredStyles, value];
|
|
440
|
+
}
|
|
441
|
+
else {
|
|
442
|
+
// Toggle other styles
|
|
443
|
+
value = currentStyles.includes(value)
|
|
444
|
+
? currentStyles.filter(s => s !== value)
|
|
445
|
+
: [...currentStyles, value];
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
const update = { [key]: value };
|
|
449
|
+
this.formBuilderService.updateElement(this.selectedElementIndex, update);
|
|
450
|
+
// Special handling for font and font weight
|
|
451
|
+
if (key === 'font') {
|
|
452
|
+
this.selectedElement.font = value; // Directly update the selected element's font property
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
onRequiredChange(value) {
|
|
457
|
+
if (this.selectedElement) {
|
|
458
|
+
let label = this.selectedElement.label ? this.selectedElement.label.replace(/\s*\*+$/, '') : 'Label';
|
|
459
|
+
if (value) {
|
|
460
|
+
label = `${label} *`;
|
|
461
|
+
}
|
|
462
|
+
this.updateProperty('label', label);
|
|
463
|
+
this.updateProperty('isRequired', value);
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
getProperties() {
|
|
467
|
+
if (!this.selectedElement)
|
|
468
|
+
return null;
|
|
469
|
+
return this.elementProperties[this.selectedElement.type];
|
|
470
|
+
}
|
|
471
|
+
addOption(options) {
|
|
472
|
+
options.push({ label: '', value: '' });
|
|
473
|
+
}
|
|
474
|
+
removeOption(options, index) {
|
|
475
|
+
options.splice(index, 1);
|
|
476
|
+
}
|
|
477
|
+
// download() {
|
|
478
|
+
// console.log('Question Book:', this.formBuilderService.downloadElement());
|
|
479
|
+
// }
|
|
480
|
+
handleButtonClick() {
|
|
481
|
+
this.formButtonHandler.emit(this.formBuilderService.downloadElement());
|
|
482
|
+
}
|
|
483
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PropertiesComponent, deps: [{ token: i1.HttpClient }, { token: i2.FormBuilderService }], target: i0.ɵɵFactoryTarget.Component });
|
|
484
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PropertiesComponent, selector: "app-properties", inputs: { selectedElementType: "selectedElementType" }, outputs: { formButtonHandler: "formButtonHandler" }, ngImport: i0, template: "<!-- AP 22JAN25 - Field and Element Properties -->\n<link href=\"https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap\" rel=\"stylesheet\">\n<div class=\"properties\">\n\n<!-- Design Header Section -->\n<div class=\"design-header\">\n <h1 class=\"header-title\">Properties</h1>\n <!-- AP 25FEB25 - not used -->\n <!-- <div class=\"menu-container\">\n <div class=\"menu-item\" (click)=\"download()\">\n <span >Download</span>\n </div>\n <div class=\"menu-item\">\n <span>Start</span>\n </div>\n <div class=\"menu-item\">\n <span>Path</span>\n </div>\n <div class=\"menu-item\">\n <span>Clone</span>\n </div>\n </div> -->\n</div>\n\n<div class=\"all-properties\">\n<div *ngIf=\"errorMessage\" class=\"error-message\">{{ errorMessage }}</div>\n\n<!-- Element Properties -->\n <!-- AP-06MAR25 Select element type show -->\n<details class=\"first-properties\" open>\n <summary class=\"text-sm \">Elements Properties</summary>\n <div class=\"inner-content\" *ngIf=\"getProperties()\">\n {{selectedElement.type}}\n <ng-container *ngFor=\"let prop of getProperties().elementProps\">\n <div class=\"flex-items-center\">\n <label class=\"text-sm\">{{ prop.label }}</label>\n <div class=\"label-properties\">\n\n<!-- Text Input -->\n<input *ngIf=\"prop.type === 'text'\"\n type=\"text\"\n [placeholder]=\"prop.placeholder\"\n [value]=\"selectedElement[prop.key]\"\n (input)=\"updateProperty(prop.key, $event.target.value)\"\n [class.read-only]=\"selectedElement.readOnly\"\n [readonly]=\"selectedElement.readOnly\"\n class=\"text-sm1 \"/>\n\n<div *ngIf=\"prop.key === 'helpText' && selectedElement.helpText\" class=\"help-text\">{{ selectedElement.helpText }}</div>\n\n<!-- Font Selection -->\n<div *ngIf=\"prop.key === 'font'\" class=\"font-selection\">\n <!-- <label>{{ prop.label }}</label> -->\n <select *ngIf=\"prop.type === 'select' && prop.key === 'font'\" class=\"font-selection1\" [value]=\"selectedElement?.font\"\n (change)=\"updateProperty('font', $event.target.value)\">\n <option *ngFor=\"let option of prop.options\" [value]=\"option\"> {{ option }} </option>\n </select>\n</div>\n\n<!-- file -->\n<!-- Add this inside the elementProps loop where other inputs are rendered -->\n<select *ngIf=\"prop.type === 'select' && prop.key === 'supportType'\" class=\"file\" [value]=\"selectedElement[prop.key]\"\n(change)=\"updateProperty(prop.key, $event.target.value)\">\n<option value=\"\">Select file category</option>\n<option *ngFor=\"let option of prop.options\" [value]=\"option.value\"> {{ option.label }} </option>\n</select>\n\n<!-- Font Weight Selection -->\n<div *ngIf=\"prop.key === 'fontWeight'\" class=\"font-weight\">\n <!-- <label>{{ prop.label }}</label> -->\n <select *ngIf=\"prop.type === 'select' && prop.key === 'fontWeight'\" class=\"font-weight\" [value]=\"selectedElement?.fontWeight\"\n (change)=\"updateProperty('fontWeight', $event.target.value)\">\n <option *ngFor=\"let option of prop.options\" [value]=\"option.value\"> {{ option.label }} </option>\n </select>\n</div>\n \n<!-- Toggle Group -->\n<div *ngIf=\"prop.type === 'toggleGroup'\" class=\"toggle-group\">\n <div class=\"toggle-item\">\n <span class=\"toggle-label\">Read Only</span>\n <label class=\"switch\">\n <input type=\"checkbox\" [checked]=\"selectedElement?.isReadOnly\" \n (change)=\"onToggleChange('isReadOnly', $event)\" />\n <span class=\"slider\"></span>\n </label>\n </div>\n\n <div class=\"toggle-item\">\n <span class=\"toggle-label\">Is Hide</span>\n <label class=\"switch\">\n <input type=\"checkbox\" [checked]=\"selectedElement?.isHidden\" \n (change)=\"onToggleChange('isHidden', $event)\" />\n <span class=\"slider\"></span>\n </label>\n </div>\n</div>\n\n<!-- Text Align Buttons -->\n<div *ngIf=\"prop.type === 'align'\"class=\"font-align\">\n <button *ngFor=\"let option of prop.options\" (click)=\"onAlignSelect(option.value)\" \n [class.active]=\"selectedElement?.textAlign === option.value\" class=\"align-btn\" [title]=\"option.value\">\n <img [src]=\"'../assets/icons/' + option.icon + '.svg'\" [alt]=\"option.value\" class=\"icon-size\"/>\n </button>\n</div>\n\n<div *ngIf=\"prop.type === 'style'\" class=\"font-style\">\n <button *ngFor=\"let option of prop.options\" (click)=\"onStyleSelect(option.value)\"\n [class.active]=\"isStyleActive(option.value)\" class=\"style-btn\" [title]=\"option.value\">\n <img [src]=\"'../assets/icons/' + option.icon + '.svg'\" [alt]=\"option.value\" class=\"icon-size\"/>\n </button>\n</div>\n\n<!-- Field Size Controls -->\n<!-- AP 25FEB25 - Change key size -->\n<div *ngIf=\"prop.key === 'size'\" class=\"field-size-controls\">\n <div class=\"size-group\">\n <label class=\"size-label\">Width</label>\n <div class=\"value-container\">\n <input type=\"number\" [value]=\"selectedElement?.size\" (input)=\"updateProperty('size', $event.target.value)\" class=\"size-input\"/>\n </div>\n </div>\n</div>\n\n</div>\n</div>\n</ng-container>\n</div>\n</details>\n\n<!-- Field Elements Properties -->\n <!-- AP-06MAR25 Show elements ID -->\n<details class=\"second-property\">\n <summary class=\"text-font-medium\">Field Elements Properties</summary>\n <div class=\"space-y-4\" *ngIf=\"getProperties()\">\n <div style=\"font-size: 13px; padding:5px;border-radius:3px;background-color:#eff8ff;\"> id : {{selectedElement.id}}</div>\n <ng-container *ngFor=\"let prop of getProperties().fieldProps\">\n <div class=\"flex-items-center \">\n <label class=\"text-sm\">{{ prop.label }}</label>\n <div class=\"input-box-field\">\n <!-- Input Box -->\n <div class=\"input-box-field\">\n <input *ngIf=\"prop.type === 'text'\" type=\"text\" [placeholder]=\"prop.placeholder\" [value]=\"selectedElement[prop.key]\"\n (input)=\"updateProperty(prop.key, $event.target.value)\"/> </div>\n \n <!-- Radio Group -->\n<div *ngIf=\"prop.type === 'radio'\" class=\"radio-item\">\n <div class=\"sizes\">\n <div class=\"flex-gap\">\n <div class=\"flex-items\">\n <input type=\"radio\" [checked]=\"selectedElement?.isRequired\" (change)=\"onRequiredChange(true)\" name=\"required\" class=\"radio-input\"/>\n <label class=\"text-label\"> Required </label>\n </div>\n <div class=\"flex-items\">\n <input type=\"radio\" [checked]=\"!selectedElement?.isRequired\" (change)=\"onRequiredChange(false)\" name=\"required\" class=\"radio-input\"/>\n <label class=\"text-sm text-gray-400\"> Not Required </label>\n </div>\n </div>\n</div>\n</div> \n\n<!-- AP 25FEB25 - handled options -->\n<div *ngIf=\"prop.type === 'dropdown' || prop.type === 'checkbox' || prop.type === 'radio' && prop.key === 'options'\" class=\"options-container\">\n <div *ngFor=\"let option of selectedElement[prop.key]; let i = index\" class=\"option-items\">\n <input type=\"text\" [(ngModel)]=\"selectedElement[prop.key][i].value\" placeholder=\"Option {{ i + 1 }}\" class=\"options\"/>\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeOption(selectedElement[prop.key], i)\">\n </div>\n <button (click)=\"addOption(selectedElement[prop.key])\">\n <div class=\"add-varient\">\n <span class=\"text-lg\">+</span>\n <span>Add</span>\n </div>\n </button>\n</div>\n\n</div>\n</div>\n</ng-container>\n</div>\n</details>\n\n<div class=\"design-footer\">\n <button class=\"btn\">Cancel</button>\n <button class=\"btn\" (click)=\"handleButtonClick()\">Save</button>\n</div>\n\n</div>\n</div>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap\";*{margin:0;padding:0;box-sizing:border-box;font-family:Roboto,sans-serif}.properties{height:100vh;overflow-y:auto}.design-header{display:flex;justify-content:center;align-items:center;padding:15px 20px;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px}.header-title{font-size:20px;font-weight:400;color:#222}.all-properties details{background:#fff;border:1px solid #ddd;border-radius:8px;margin-bottom:12px;padding:12px;box-shadow:0 2px 8px #0000000d}.all-properties summary{font-size:15px;font-weight:400;cursor:pointer;padding:6px;transition:color .3s}.all-properties summary:hover{color:#007bff}.inner-content{padding:12px 0}label{font-size:14px;font-weight:500;color:#444;margin-bottom:5px;display:block}input[type=text],input[type=number],select{width:100%;height:40px;padding:10px;font-size:14px;border:1px solid #ccc;border-radius:6px;outline:none;transition:.3s;background:#f8f8f8}input:focus,select:focus{border-color:#007bff;background:#fff;box-shadow:0 0 5px #007bff4d}button{padding:10px 15px;border:none;border-radius:6px;background:#007bff;color:#fff;font-size:15px;cursor:pointer;transition:.3s}button:hover{background:#0056b3;transform:translateY(-2px)}.toggle-group{display:flex;align-items:center;gap:20px}.toggle-item{display:flex;align-items:center;gap:10px}.switch{position:relative;width:42px;height:22px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:\"\";height:20px;width:20px;left:1px;bottom:1px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#2196f3}input:checked+.slider:before{transform:translate(18px)}.radio-item{display:flex;align-items:center;gap:20px}.radio-item input{accent-color:#007bff}.options-container{display:flex;flex-direction:column;gap:12px}.options{width:100%}.field-size-controls{display:flex;align-items:center;gap:12px}.size-input{width:110px;text-align:center}.design-footer{display:flex;justify-content:space-between;margin-top:20px}.design-footer .btn{background:#007bff;color:#fff;padding:10px 18px;border-radius:6px;font-size:15px;transition:.3s}.design-footer .btn:hover{background:#0056b3}@media (max-width: 768px){.properties{max-width:100%;padding:12px}.design-header{flex-direction:column;align-items:flex-start;padding:15px}.toggle-group{flex-direction:column;gap:12px}.field-size-controls{flex-direction:column}.design-footer{flex-direction:column;gap:12px;align-items:center}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
485
|
+
}
|
|
486
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PropertiesComponent, decorators: [{
|
|
487
|
+
type: Component,
|
|
488
|
+
args: [{ selector: 'app-properties', template: "<!-- AP 22JAN25 - Field and Element Properties -->\n<link href=\"https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap\" rel=\"stylesheet\">\n<div class=\"properties\">\n\n<!-- Design Header Section -->\n<div class=\"design-header\">\n <h1 class=\"header-title\">Properties</h1>\n <!-- AP 25FEB25 - not used -->\n <!-- <div class=\"menu-container\">\n <div class=\"menu-item\" (click)=\"download()\">\n <span >Download</span>\n </div>\n <div class=\"menu-item\">\n <span>Start</span>\n </div>\n <div class=\"menu-item\">\n <span>Path</span>\n </div>\n <div class=\"menu-item\">\n <span>Clone</span>\n </div>\n </div> -->\n</div>\n\n<div class=\"all-properties\">\n<div *ngIf=\"errorMessage\" class=\"error-message\">{{ errorMessage }}</div>\n\n<!-- Element Properties -->\n <!-- AP-06MAR25 Select element type show -->\n<details class=\"first-properties\" open>\n <summary class=\"text-sm \">Elements Properties</summary>\n <div class=\"inner-content\" *ngIf=\"getProperties()\">\n {{selectedElement.type}}\n <ng-container *ngFor=\"let prop of getProperties().elementProps\">\n <div class=\"flex-items-center\">\n <label class=\"text-sm\">{{ prop.label }}</label>\n <div class=\"label-properties\">\n\n<!-- Text Input -->\n<input *ngIf=\"prop.type === 'text'\"\n type=\"text\"\n [placeholder]=\"prop.placeholder\"\n [value]=\"selectedElement[prop.key]\"\n (input)=\"updateProperty(prop.key, $event.target.value)\"\n [class.read-only]=\"selectedElement.readOnly\"\n [readonly]=\"selectedElement.readOnly\"\n class=\"text-sm1 \"/>\n\n<div *ngIf=\"prop.key === 'helpText' && selectedElement.helpText\" class=\"help-text\">{{ selectedElement.helpText }}</div>\n\n<!-- Font Selection -->\n<div *ngIf=\"prop.key === 'font'\" class=\"font-selection\">\n <!-- <label>{{ prop.label }}</label> -->\n <select *ngIf=\"prop.type === 'select' && prop.key === 'font'\" class=\"font-selection1\" [value]=\"selectedElement?.font\"\n (change)=\"updateProperty('font', $event.target.value)\">\n <option *ngFor=\"let option of prop.options\" [value]=\"option\"> {{ option }} </option>\n </select>\n</div>\n\n<!-- file -->\n<!-- Add this inside the elementProps loop where other inputs are rendered -->\n<select *ngIf=\"prop.type === 'select' && prop.key === 'supportType'\" class=\"file\" [value]=\"selectedElement[prop.key]\"\n(change)=\"updateProperty(prop.key, $event.target.value)\">\n<option value=\"\">Select file category</option>\n<option *ngFor=\"let option of prop.options\" [value]=\"option.value\"> {{ option.label }} </option>\n</select>\n\n<!-- Font Weight Selection -->\n<div *ngIf=\"prop.key === 'fontWeight'\" class=\"font-weight\">\n <!-- <label>{{ prop.label }}</label> -->\n <select *ngIf=\"prop.type === 'select' && prop.key === 'fontWeight'\" class=\"font-weight\" [value]=\"selectedElement?.fontWeight\"\n (change)=\"updateProperty('fontWeight', $event.target.value)\">\n <option *ngFor=\"let option of prop.options\" [value]=\"option.value\"> {{ option.label }} </option>\n </select>\n</div>\n \n<!-- Toggle Group -->\n<div *ngIf=\"prop.type === 'toggleGroup'\" class=\"toggle-group\">\n <div class=\"toggle-item\">\n <span class=\"toggle-label\">Read Only</span>\n <label class=\"switch\">\n <input type=\"checkbox\" [checked]=\"selectedElement?.isReadOnly\" \n (change)=\"onToggleChange('isReadOnly', $event)\" />\n <span class=\"slider\"></span>\n </label>\n </div>\n\n <div class=\"toggle-item\">\n <span class=\"toggle-label\">Is Hide</span>\n <label class=\"switch\">\n <input type=\"checkbox\" [checked]=\"selectedElement?.isHidden\" \n (change)=\"onToggleChange('isHidden', $event)\" />\n <span class=\"slider\"></span>\n </label>\n </div>\n</div>\n\n<!-- Text Align Buttons -->\n<div *ngIf=\"prop.type === 'align'\"class=\"font-align\">\n <button *ngFor=\"let option of prop.options\" (click)=\"onAlignSelect(option.value)\" \n [class.active]=\"selectedElement?.textAlign === option.value\" class=\"align-btn\" [title]=\"option.value\">\n <img [src]=\"'../assets/icons/' + option.icon + '.svg'\" [alt]=\"option.value\" class=\"icon-size\"/>\n </button>\n</div>\n\n<div *ngIf=\"prop.type === 'style'\" class=\"font-style\">\n <button *ngFor=\"let option of prop.options\" (click)=\"onStyleSelect(option.value)\"\n [class.active]=\"isStyleActive(option.value)\" class=\"style-btn\" [title]=\"option.value\">\n <img [src]=\"'../assets/icons/' + option.icon + '.svg'\" [alt]=\"option.value\" class=\"icon-size\"/>\n </button>\n</div>\n\n<!-- Field Size Controls -->\n<!-- AP 25FEB25 - Change key size -->\n<div *ngIf=\"prop.key === 'size'\" class=\"field-size-controls\">\n <div class=\"size-group\">\n <label class=\"size-label\">Width</label>\n <div class=\"value-container\">\n <input type=\"number\" [value]=\"selectedElement?.size\" (input)=\"updateProperty('size', $event.target.value)\" class=\"size-input\"/>\n </div>\n </div>\n</div>\n\n</div>\n</div>\n</ng-container>\n</div>\n</details>\n\n<!-- Field Elements Properties -->\n <!-- AP-06MAR25 Show elements ID -->\n<details class=\"second-property\">\n <summary class=\"text-font-medium\">Field Elements Properties</summary>\n <div class=\"space-y-4\" *ngIf=\"getProperties()\">\n <div style=\"font-size: 13px; padding:5px;border-radius:3px;background-color:#eff8ff;\"> id : {{selectedElement.id}}</div>\n <ng-container *ngFor=\"let prop of getProperties().fieldProps\">\n <div class=\"flex-items-center \">\n <label class=\"text-sm\">{{ prop.label }}</label>\n <div class=\"input-box-field\">\n <!-- Input Box -->\n <div class=\"input-box-field\">\n <input *ngIf=\"prop.type === 'text'\" type=\"text\" [placeholder]=\"prop.placeholder\" [value]=\"selectedElement[prop.key]\"\n (input)=\"updateProperty(prop.key, $event.target.value)\"/> </div>\n \n <!-- Radio Group -->\n<div *ngIf=\"prop.type === 'radio'\" class=\"radio-item\">\n <div class=\"sizes\">\n <div class=\"flex-gap\">\n <div class=\"flex-items\">\n <input type=\"radio\" [checked]=\"selectedElement?.isRequired\" (change)=\"onRequiredChange(true)\" name=\"required\" class=\"radio-input\"/>\n <label class=\"text-label\"> Required </label>\n </div>\n <div class=\"flex-items\">\n <input type=\"radio\" [checked]=\"!selectedElement?.isRequired\" (change)=\"onRequiredChange(false)\" name=\"required\" class=\"radio-input\"/>\n <label class=\"text-sm text-gray-400\"> Not Required </label>\n </div>\n </div>\n</div>\n</div> \n\n<!-- AP 25FEB25 - handled options -->\n<div *ngIf=\"prop.type === 'dropdown' || prop.type === 'checkbox' || prop.type === 'radio' && prop.key === 'options'\" class=\"options-container\">\n <div *ngFor=\"let option of selectedElement[prop.key]; let i = index\" class=\"option-items\">\n <input type=\"text\" [(ngModel)]=\"selectedElement[prop.key][i].value\" placeholder=\"Option {{ i + 1 }}\" class=\"options\"/>\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeOption(selectedElement[prop.key], i)\">\n </div>\n <button (click)=\"addOption(selectedElement[prop.key])\">\n <div class=\"add-varient\">\n <span class=\"text-lg\">+</span>\n <span>Add</span>\n </div>\n </button>\n</div>\n\n</div>\n</div>\n</ng-container>\n</div>\n</details>\n\n<div class=\"design-footer\">\n <button class=\"btn\">Cancel</button>\n <button class=\"btn\" (click)=\"handleButtonClick()\">Save</button>\n</div>\n\n</div>\n</div>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap\";*{margin:0;padding:0;box-sizing:border-box;font-family:Roboto,sans-serif}.properties{height:100vh;overflow-y:auto}.design-header{display:flex;justify-content:center;align-items:center;padding:15px 20px;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px}.header-title{font-size:20px;font-weight:400;color:#222}.all-properties details{background:#fff;border:1px solid #ddd;border-radius:8px;margin-bottom:12px;padding:12px;box-shadow:0 2px 8px #0000000d}.all-properties summary{font-size:15px;font-weight:400;cursor:pointer;padding:6px;transition:color .3s}.all-properties summary:hover{color:#007bff}.inner-content{padding:12px 0}label{font-size:14px;font-weight:500;color:#444;margin-bottom:5px;display:block}input[type=text],input[type=number],select{width:100%;height:40px;padding:10px;font-size:14px;border:1px solid #ccc;border-radius:6px;outline:none;transition:.3s;background:#f8f8f8}input:focus,select:focus{border-color:#007bff;background:#fff;box-shadow:0 0 5px #007bff4d}button{padding:10px 15px;border:none;border-radius:6px;background:#007bff;color:#fff;font-size:15px;cursor:pointer;transition:.3s}button:hover{background:#0056b3;transform:translateY(-2px)}.toggle-group{display:flex;align-items:center;gap:20px}.toggle-item{display:flex;align-items:center;gap:10px}.switch{position:relative;width:42px;height:22px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:\"\";height:20px;width:20px;left:1px;bottom:1px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#2196f3}input:checked+.slider:before{transform:translate(18px)}.radio-item{display:flex;align-items:center;gap:20px}.radio-item input{accent-color:#007bff}.options-container{display:flex;flex-direction:column;gap:12px}.options{width:100%}.field-size-controls{display:flex;align-items:center;gap:12px}.size-input{width:110px;text-align:center}.design-footer{display:flex;justify-content:space-between;margin-top:20px}.design-footer .btn{background:#007bff;color:#fff;padding:10px 18px;border-radius:6px;font-size:15px;transition:.3s}.design-footer .btn:hover{background:#0056b3}@media (max-width: 768px){.properties{max-width:100%;padding:12px}.design-header{flex-direction:column;align-items:flex-start;padding:15px}.toggle-group{flex-direction:column;gap:12px}.field-size-controls{flex-direction:column}.design-footer{flex-direction:column;gap:12px;align-items:center}}\n"] }]
|
|
489
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.FormBuilderService }], propDecorators: { formButtonHandler: [{
|
|
490
|
+
type: Output
|
|
491
|
+
}], selectedElementType: [{
|
|
492
|
+
type: Input
|
|
493
|
+
}] } });
|
|
494
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"properties.component.js","sourceRoot":"","sources":["../../../../../../../projects/nxt-app/src/lib/pages/builder/properties/properties.component.ts","../../../../../../../projects/nxt-app/src/lib/pages/builder/properties/properties.component.html"],"names":[],"mappings":"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","sourcesContent":["// AP 22JAN25\nimport { HttpClient } from '@angular/common/http';\nimport { Component, ElementRef, EventEmitter, Input, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { FormBuilderService } from '../../../services/form-builder.service';\n\n@Component({\n  selector: 'app-properties',\n  templateUrl: './properties.component.html',\n  styleUrls: ['./properties.component.css']\n})\nexport class PropertiesComponent implements OnInit {\n\n  @Output() formButtonHandler = new EventEmitter<any>(); \n  selectedOption: string = '';\n  selectedElementIndex: number = -1;\n  @Input() selectedElementType: string = '';\n  selectedAlign: string = 'align-left';  // Add this property\n  selectedStyles: string[] = [];  // Using array since multiple styles can be selected\n  errorMessage: string = '';\n  selectedElement: any = null;  // Receive the selected element\n\n  onToggleChange(key: string, event: Event) {\n    const checked = (event.target as HTMLInputElement).checked;\n    this.selectedElement = { ...this.selectedElement, [key]: checked };\n    this.updateProperty(key,checked); //AP-06MAR25 Bug Fixed\n  }  \n\n  updateProperties(elementType: string): void {\n    // Reset alignment and styles if switching elements\n    this.selectedAlign = 'align-left';\n    this.selectedStyles = [];\n\n    // Fetch the properties of the selected element type\n    const properties = this.getProperties();\n    if (properties) {\n      // Make sure the properties are dynamically updated\n    }\n  }\n\n  onAlignSelect(value: string): void {\n    if (this.selectedElement) {\n      this.selectedElement.textAlign = value;\n    }\n  }\n\n  onStyleSelect(value: string): void {\n    if (!this.selectedElement) return;\n\n    // Initialize styles array if it doesn't exist\n    this.selectedElement.styles = this.selectedElement.styles || [];\n\n    // Ensure only one style is selected at a time\n    this.selectedElement.styles = [value];\n\n  }\n\n  isStyleActive(value: string): boolean {\n    return this.selectedElement?.styles?.includes(value) || false;\n  }\n\n  elementProperties = {\n\n   'Text': {\n      elementProps: [\n\n        // questionText - Label-follow all element properties\n        { label: 'Label', placeholder: 'Enter Text ', type: 'text',key: 'questionText' },\n\n        // question - Placeholder-follow all element properties\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text ', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n\n        // errorMessage - Error Msg-follow all element properties\n        { label: 'Error Msg', placeholder: 'Enter Text ', type: 'text',key: 'errorMessage' },\n        { label: 'Font', type: 'select',  key: 'font' ,\n          options: ['Helvetica Neue', 'Arial', 'Times New Roman', 'Roboto'] },\n        { label: 'Weight', type: 'select',key: 'fontWeight',\n          options: [\n            { value: '400', label: '400-Normal' },\n            { value: '500', label: '500-Medium' },\n            { value: '600', label: '600-Semi Bold' },\n            { value: '700', label: '700-Bold' }\n          ] },\n        // { label: 'Size', unit: 'PX', type: 'number', key: 'size'  },\n        // { label: 'Align', type: 'align', key: 'textAlign',\n        //   options: [\n        //     { value: 'left', icon: 'textalign-left' },\n        //     { value: 'center', icon: 'align-center' },\n        //     { value: 'right', icon: 'align-right' },\n        //     { value: 'justifyleft', icon: 'align-justifyleft' },\n        //     { value: 'justifyright', icon: 'align-justifyright' }\n\n        //   ] },\n        // { label: 'Style', type: 'style',key: 'styles',\n\n        //   options: [\n        //     { value: 'italic', icon: 'italic' },\n        //     { value: 'bold', icon: 'bold' },\n        //     { value: 'underline', icon: 'underline' },\n        //     { value: 'texticon', icon: 'texticon' },\n        //     { value: 'capitalize', icon: 'capitalize' },\n        //     { value: 'resize', icon: 'resize' }\n\n\n        //   ] },\n          { label: 'Field Size', type: 'fieldSize', key: 'size' }\n\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio', key: 'isRequired' },\n        { label: 'Default Value', placeholder: 'Enter Text ', type: 'text',key: 'defaultValue'  },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'SubText', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n\n    'CheckBox': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text ', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text ', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text ', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        {\n          label: 'Options',\n          type: 'checkbox', \n          key: 'options',\n          addOptionLabel: 'Add Option',\n          icon: 'plus'\n        },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n\n    'Calendar': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n\n    'Time': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'label' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'placeholder'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n\n    'Email': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n\n    'File': {\n        elementProps: [\n          { label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },\n          { label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },\n          { label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },\n\n          { label: 'Support Type', type: 'select', key: 'supportType', options: [\n            { label: 'Images (JPEG, PNG, GIF)', value: 'image/*', extensions: ['.jpg','.jpeg','.png','.gif'] },\n            { label: 'Audio (MP3, WAV, AIFF)', value: 'audio/*', extensions: ['.mp3','.wav','.aiff'] },\n            { label: 'Video (MP4, AVI, HEVC)', value: 'video/*', extensions: ['.mp4','.avi','.hevc'] },\n            { label: 'Documents (DOC, DOCX, PPT, PDF)', value: 'application/pdf,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document,application/vnd.ms-powerpoint', extensions: ['.doc','.docx','.ppt','.pdf'] },\n            { label: 'Executables (EXE, BAD, SH)', value: 'application/x-msdownload,application/x-sh', extensions: ['.exe','.bad','.sh'] },\n            { label: 'Archives (ZIP, RAR, Git-hub)', value: 'application/zip,application/x-rar-compressed,application/x-git', extensions: ['.zip','.rar','.git'] }\n          ]},\n          { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n          { label: 'Field Size', type: 'fieldSize', key: 'size' },\n          { label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },\n        ],\n        fieldProps: [\n          { label: 'Field Required', type: 'radio' },\n          { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n         { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n        ]\n    },\n\n    'List': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    }, \n    \n    'TextArea': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio', key: 'required' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n    \n    'RichTextArea': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio', key: 'required' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n    \n    'Number': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n    \n    'Dropdown': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        {\n          label: 'Options',\n          type: 'dropdown',\n          key: 'options', \n          addOptionLabel: 'Add Variant',\n          icon: 'plus'\n        },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n\n      ]\n    },\n    \n    'Image': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n    \n    'Radio': {\n  elementProps: [\n    { label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },\n    { label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },\n    { label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },\n    { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n    { label: 'Field Size', type: 'fieldSize', key: 'size' },\n    { label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' },\n  ],\n  fieldProps: [\n    { label: 'Field Required', type: 'radio' },\n    { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n    {\n      label: 'Options',\n      type: 'radio', \n      key: 'options',\n      addOptionLabel: 'Add Option',\n      icon: 'plus'\n    },\n    { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n  ]\n    },\n    \n    'Label': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n\n    'Table': {\n  elementProps: [\n    { label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },\n    { label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },\n    { label: 'Field Size', type: 'fieldSize', key: 'size' },\n    { label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMessage' }\n  ],\n  fieldProps: [\n    { label: 'Field Required', type: 'radio' },\n    { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n    { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n    { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' },\n  ]\n    },\n    \n    'Book': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n    \n    'Button': {\n      elementProps: [\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\n        { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n        { label: 'Field Size', type: 'fieldSize', key: 'size' },\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMessage' },\n      ],\n      fieldProps: [\n        { label: 'Field Required', type: 'radio' },\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n        { label: 'Style', placeholder: 'Style JSON', type: 'text', key: 'style' },\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text', key: 'subText' }\n      ]\n    },\n  };\n\n  constructor(private http: HttpClient,private formBuilderService: FormBuilderService) {}\n\n  ngOnInit() {\n    this.formBuilderService.selectedElement$.subscribe(index => {\n      this.selectedElementIndex = index;\n      if (index >= 0) {\n        const elements = this.formBuilderService.getElements();\n        this.selectedElement = elements[index];\n      }\n      \n    });    \n  }\n\n  validateInput(value: string, type: string): boolean {\n    if (type === 'label' || type === 'placeholder') {\n      const regex = /^[a-zA-Z0-9\\s]*$/;\n      if (!regex.test(value)) {\n        this.errorMessage = 'Only letters and numbers are allowed';\n        return false;\n      }\n    }\n    this.errorMessage = '';\n    return true;\n  }\n\n  updateProperty(key: string, value: any) {\n    if (this.selectedElementIndex >= 0) {\n      if (key === 'questionText' || key === 'question') {\n        if (!this.validateInput(value, key)) {\n          return;\n        }\n      }\n\n      if (key === 'fontWeight') {\n        // Extract just the number value from the option\n        value = value.split('-')[0];\n      }\n\n      if (key === 'styles') {\n        const currentStyles = this.selectedElement.styles || [];\n        if (value === 'capitalize' || value === 'lowercase') {\n          // Remove the opposite case if it exists\n          const oppositeStyle = value === 'capitalize' ? 'lowercase' : 'capitalize';\n          const filteredStyles = currentStyles.filter(s => s !== oppositeStyle);\n          value = currentStyles.includes(value)\n            ? filteredStyles.filter(s => s !== value)\n            : [...filteredStyles, value];\n        } else {\n          // Toggle other styles\n          value = currentStyles.includes(value)\n            ? currentStyles.filter(s => s !== value)\n            : [...currentStyles, value];\n        }\n      }\n\n      const update = { [key]: value };\n      this.formBuilderService.updateElement(this.selectedElementIndex, update);\n\n      // Special handling for font and font weight\n      if (key === 'font') {\n        this.selectedElement.font = value; // Directly update the selected element's font property\n      }\n    }\n  }\n\n  onRequiredChange(value: boolean) {\n    if (this.selectedElement) {\n      let label = this.selectedElement.label ? this.selectedElement.label.replace(/\\s*\\*+$/, '') : 'Label';\n  \n      if (value) {\n        label = `${label} *`; \n      }\n\n      this.updateProperty('label', label);\n      this.updateProperty('isRequired', value);\n    }\n  }\n  \n  getProperties() {\n    if (!this.selectedElement) return null;\n    return this.elementProperties[this.selectedElement.type];\n  }\n  \n  addOption(options: any[]) {\n    options.push({ label: '', value: '' }); \n  }\n\n  removeOption(options: any[], index: number) {\n    options.splice(index, 1);\n  }  \n\n  // download() {\n  //   console.log('Question Book:', this.formBuilderService.downloadElement());\n  // }\n\n  handleButtonClick(){\n    this.formButtonHandler.emit(this.formBuilderService.downloadElement());\n  }\n\n}\n","<!-- AP 22JAN25 - Field and Element Properties -->\n<link href=\"https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap\" rel=\"stylesheet\">\n<div class=\"properties\">\n\n<!-- Design Header Section -->\n<div class=\"design-header\">\n  <h1 class=\"header-title\">Properties</h1>\n  <!-- AP 25FEB25 - not used -->\n  <!-- <div class=\"menu-container\">\n    <div class=\"menu-item\" (click)=\"download()\">\n      <span >Download</span>\n    </div>\n    <div class=\"menu-item\">\n      <span>Start</span>\n    </div>\n    <div class=\"menu-item\">\n      <span>Path</span>\n    </div>\n    <div class=\"menu-item\">\n      <span>Clone</span>\n    </div>\n  </div> -->\n</div>\n\n<div class=\"all-properties\">\n<div *ngIf=\"errorMessage\" class=\"error-message\">{{ errorMessage }}</div>\n\n<!-- Element Properties -->\n <!-- AP-06MAR25 Select element type show -->\n<details class=\"first-properties\" open>\n  <summary class=\"text-sm \">Elements Properties</summary>\n    <div class=\"inner-content\" *ngIf=\"getProperties()\">\n      {{selectedElement.type}}\n      <ng-container *ngFor=\"let prop of getProperties().elementProps\">\n        <div class=\"flex-items-center\">\n          <label class=\"text-sm\">{{ prop.label }}</label>\n          <div class=\"label-properties\">\n\n<!-- Text Input -->\n<input *ngIf=\"prop.type === 'text'\"\n            type=\"text\"\n            [placeholder]=\"prop.placeholder\"\n            [value]=\"selectedElement[prop.key]\"\n            (input)=\"updateProperty(prop.key, $event.target.value)\"\n            [class.read-only]=\"selectedElement.readOnly\"\n            [readonly]=\"selectedElement.readOnly\"\n            class=\"text-sm1 \"/>\n\n<div *ngIf=\"prop.key === 'helpText' && selectedElement.helpText\" class=\"help-text\">{{ selectedElement.helpText }}</div>\n\n<!-- Font Selection -->\n<div *ngIf=\"prop.key === 'font'\" class=\"font-selection\">\n  <!-- <label>{{ prop.label }}</label> -->\n  <select *ngIf=\"prop.type === 'select' && prop.key === 'font'\" class=\"font-selection1\" [value]=\"selectedElement?.font\"\n    (change)=\"updateProperty('font', $event.target.value)\">\n    <option *ngFor=\"let option of prop.options\" [value]=\"option\"> {{ option }} </option>\n  </select>\n</div>\n\n<!-- file -->\n<!-- Add this inside the elementProps loop where other inputs are rendered -->\n<select *ngIf=\"prop.type === 'select' && prop.key === 'supportType'\" class=\"file\" [value]=\"selectedElement[prop.key]\"\n(change)=\"updateProperty(prop.key, $event.target.value)\">\n<option value=\"\">Select file category</option>\n<option *ngFor=\"let option of prop.options\" [value]=\"option.value\"> {{ option.label }} </option>\n</select>\n\n<!-- Font Weight Selection -->\n<div *ngIf=\"prop.key === 'fontWeight'\" class=\"font-weight\">\n  <!-- <label>{{ prop.label }}</label> -->\n  <select *ngIf=\"prop.type === 'select' && prop.key === 'fontWeight'\" class=\"font-weight\" [value]=\"selectedElement?.fontWeight\"\n    (change)=\"updateProperty('fontWeight', $event.target.value)\">\n    <option *ngFor=\"let option of prop.options\" [value]=\"option.value\"> {{ option.label }} </option>\n  </select>\n</div>\n        \n<!-- Toggle Group -->\n<div *ngIf=\"prop.type === 'toggleGroup'\" class=\"toggle-group\">\n  <div class=\"toggle-item\">\n    <span class=\"toggle-label\">Read Only</span>\n    <label class=\"switch\">\n      <input type=\"checkbox\" [checked]=\"selectedElement?.isReadOnly\" \n             (change)=\"onToggleChange('isReadOnly', $event)\" />\n      <span class=\"slider\"></span>\n    </label>\n  </div>\n\n  <div class=\"toggle-item\">\n    <span class=\"toggle-label\">Is Hide</span>\n    <label class=\"switch\">\n      <input type=\"checkbox\" [checked]=\"selectedElement?.isHidden\" \n             (change)=\"onToggleChange('isHidden', $event)\" />\n      <span class=\"slider\"></span>\n    </label>\n  </div>\n</div>\n\n<!-- Text Align Buttons -->\n<div *ngIf=\"prop.type === 'align'\"class=\"font-align\">\n <button *ngFor=\"let option of prop.options\" (click)=\"onAlignSelect(option.value)\" \n  [class.active]=\"selectedElement?.textAlign === option.value\" class=\"align-btn\" [title]=\"option.value\">\n  <img [src]=\"'../assets/icons/' + option.icon + '.svg'\" [alt]=\"option.value\" class=\"icon-size\"/>\n  </button>\n</div>\n\n<div *ngIf=\"prop.type === 'style'\"  class=\"font-style\">\n  <button *ngFor=\"let option of prop.options\" (click)=\"onStyleSelect(option.value)\"\n  [class.active]=\"isStyleActive(option.value)\" class=\"style-btn\" [title]=\"option.value\">\n   <img [src]=\"'../assets/icons/' + option.icon + '.svg'\" [alt]=\"option.value\" class=\"icon-size\"/>\n  </button>\n</div>\n\n<!-- Field Size Controls -->\n<!-- AP 25FEB25 - Change key size -->\n<div *ngIf=\"prop.key === 'size'\" class=\"field-size-controls\">\n  <div class=\"size-group\">\n    <label  class=\"size-label\">Width</label>\n    <div class=\"value-container\">\n    <input type=\"number\" [value]=\"selectedElement?.size\" (input)=\"updateProperty('size', $event.target.value)\" class=\"size-input\"/>\n  </div>\n  </div>\n</div>\n\n</div>\n</div>\n</ng-container>\n</div>\n</details>\n\n<!-- Field Elements Properties -->\n <!-- AP-06MAR25 Show elements ID  -->\n<details class=\"second-property\">\n  <summary class=\"text-font-medium\">Field Elements Properties</summary>\n  <div class=\"space-y-4\" *ngIf=\"getProperties()\">\n    <div style=\"font-size: 13px; padding:5px;border-radius:3px;background-color:#eff8ff;\"> id : {{selectedElement.id}}</div>\n    <ng-container *ngFor=\"let prop of getProperties().fieldProps\">\n      <div class=\"flex-items-center \">\n        <label class=\"text-sm\">{{ prop.label }}</label>\n        <div class=\"input-box-field\">\n          <!-- Input Box -->\n          <div class=\"input-box-field\">\n            <input *ngIf=\"prop.type === 'text'\" type=\"text\" [placeholder]=\"prop.placeholder\" [value]=\"selectedElement[prop.key]\"\n              (input)=\"updateProperty(prop.key, $event.target.value)\"/> </div>\n              \n          <!-- Radio Group -->\n<div *ngIf=\"prop.type === 'radio'\" class=\"radio-item\">\n  <div class=\"sizes\">\n    <div class=\"flex-gap\">\n    <div class=\"flex-items\">\n      <input type=\"radio\" [checked]=\"selectedElement?.isRequired\" (change)=\"onRequiredChange(true)\" name=\"required\" class=\"radio-input\"/>\n      <label class=\"text-label\"> Required </label>\n    </div>\n    <div class=\"flex-items\">\n      <input type=\"radio\" [checked]=\"!selectedElement?.isRequired\" (change)=\"onRequiredChange(false)\" name=\"required\" class=\"radio-input\"/>\n      <label class=\"text-sm text-gray-400\"> Not Required </label>\n    </div>\n  </div>\n</div>\n</div> \n\n<!-- AP 25FEB25 - handled options -->\n<div *ngIf=\"prop.type === 'dropdown' || prop.type === 'checkbox' || prop.type === 'radio' && prop.key === 'options'\" class=\"options-container\">\n  <div *ngFor=\"let option of selectedElement[prop.key]; let i = index\" class=\"option-items\">\n    <input type=\"text\" [(ngModel)]=\"selectedElement[prop.key][i].value\" placeholder=\"Option {{ i + 1 }}\" class=\"options\"/>\n    <img src=\"../assets/icons/Trash.svg\" (click)=\"removeOption(selectedElement[prop.key], i)\">\n  </div>\n  <button (click)=\"addOption(selectedElement[prop.key])\">\n    <div class=\"add-varient\">\n      <span class=\"text-lg\">+</span>\n      <span>Add</span>\n    </div>\n  </button>\n</div>\n\n</div>\n</div>\n</ng-container>\n</div>\n</details>\n\n<div class=\"design-footer\">\n  <button class=\"btn\">Cancel</button>\n  <button class=\"btn\" (click)=\"handleButtonClick()\">Save</button>\n</div>\n\n</div>\n</div>\n"]}
|