@rangertechnologies/ngnxt 2.1.83 → 2.1.85
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/components/custom-rich-text/custom-rich-text.component.mjs +27 -12
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +33 -5
- package/esm2022/lib/nxt-app.module.mjs +41 -11
- package/esm2022/lib/pages/builder/element/element.component.mjs +155 -0
- package/esm2022/lib/pages/builder/menu/menu.component.mjs +28 -0
- package/esm2022/lib/pages/builder/properties/properties.component.mjs +480 -0
- package/esm2022/lib/services/data.service.mjs +3 -3
- package/esm2022/lib/services/form-builder.service.mjs +163 -0
- package/esm2022/public-api.mjs +4 -1
- package/fesm2022/rangertechnologies-ngnxt.mjs +901 -28
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/custom-rich-text/custom-rich-text.component.d.ts +1 -1
- package/lib/components/pick-location/pick-location.component.d.ts +5 -3
- package/lib/nxt-app.module.d.ts +18 -14
- package/lib/pages/builder/element/element.component.d.ts +29 -0
- package/lib/pages/builder/menu/menu.component.d.ts +10 -0
- package/lib/pages/builder/properties/properties.component.d.ts +531 -0
- package/lib/services/form-builder.service.d.ts +72 -0
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
- package/rangertechnologies-ngnxt-2.1.85.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.83.tgz +0 -0
|
@@ -0,0 +1,480 @@
|
|
|
1
|
+
import { Component, Input, ViewChild } 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
|
+
// selectedElement: any;
|
|
11
|
+
colorWheel;
|
|
12
|
+
ctx;
|
|
13
|
+
selectedOption = '';
|
|
14
|
+
selectedElementIndex = -1;
|
|
15
|
+
// @Input() selectedElement: any;
|
|
16
|
+
selectedElementType = '';
|
|
17
|
+
selectedAlign = 'align-left'; // Add this property
|
|
18
|
+
selectedStyles = []; // Using array since multiple styles can be selected
|
|
19
|
+
errorMessage = '';
|
|
20
|
+
selectedElement = null; // Receive the selected element
|
|
21
|
+
onToggleChange(property, event) {
|
|
22
|
+
const value = event.target.checked;
|
|
23
|
+
if (this.selectedElement) {
|
|
24
|
+
const update = { [property]: value };
|
|
25
|
+
this.formBuilderService.updateElement(this.selectedElementIndex, update);
|
|
26
|
+
// Update the selected element directly for immediate UI feedback
|
|
27
|
+
this.selectedElement[property] = value;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
updateProperties(elementType) {
|
|
31
|
+
// Reset alignment and styles if switching elements
|
|
32
|
+
this.selectedAlign = 'align-left';
|
|
33
|
+
this.selectedStyles = [];
|
|
34
|
+
// Fetch the properties of the selected element type
|
|
35
|
+
const properties = this.getProperties();
|
|
36
|
+
if (properties) {
|
|
37
|
+
// Make sure the properties are dynamically updated
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
onAlignSelect(value) {
|
|
41
|
+
if (this.selectedElement) {
|
|
42
|
+
this.selectedElement.textAlign = value;
|
|
43
|
+
console.log(`Selected alignment: ${value}`);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
onStyleSelect(value) {
|
|
47
|
+
if (!this.selectedElement)
|
|
48
|
+
return;
|
|
49
|
+
// Initialize styles array if it doesn't exist
|
|
50
|
+
this.selectedElement.styles = this.selectedElement.styles || [];
|
|
51
|
+
// Ensure only one style is selected at a time
|
|
52
|
+
this.selectedElement.styles = [value];
|
|
53
|
+
console.log('Updated styles:', this.selectedElement.styles);
|
|
54
|
+
}
|
|
55
|
+
isStyleActive(value) {
|
|
56
|
+
return this.selectedElement?.styles?.includes(value) || false;
|
|
57
|
+
}
|
|
58
|
+
elementProperties = {
|
|
59
|
+
// Add other element types here similarly
|
|
60
|
+
'Text': {
|
|
61
|
+
elementProps: [
|
|
62
|
+
// questionText - Label-follow all element properties
|
|
63
|
+
{ label: 'Label', placeholder: 'Enter Text ', type: 'text', key: 'questionText' },
|
|
64
|
+
// question - Placeholder-follow all element properties
|
|
65
|
+
{ label: 'placeholder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
66
|
+
{ label: 'Help Text', placeholder: 'Enter Text ', type: 'text', key: 'helpText' },
|
|
67
|
+
{ label: '', type: 'toggleGroup' },
|
|
68
|
+
// errorMessage - Error Msg-follow all element properties
|
|
69
|
+
{ label: 'Error Msg', placeholder: 'Enter Text ', type: 'text', key: 'errorMsg' },
|
|
70
|
+
{ label: 'Font', type: 'select', key: 'font',
|
|
71
|
+
options: ['Helvetica Neue', 'Arial', 'Times New Roman', 'Roboto'] },
|
|
72
|
+
{ label: 'Weight', type: 'select', key: 'fontWeight',
|
|
73
|
+
options: [
|
|
74
|
+
{ value: '400', label: '400-Normal' },
|
|
75
|
+
{ value: '500', label: '500-Medium' },
|
|
76
|
+
{ value: '600', label: '600-Semi Bold' },
|
|
77
|
+
{ value: '700', label: '700-Bold' }
|
|
78
|
+
] },
|
|
79
|
+
// { label: 'Size', unit: 'PX', type: 'number', key: 'size' },
|
|
80
|
+
{ label: 'Align', type: 'align', key: 'textAlign',
|
|
81
|
+
options: [
|
|
82
|
+
{ value: 'left', icon: 'textalign-left' },
|
|
83
|
+
{ value: 'center', icon: 'align-center' },
|
|
84
|
+
{ value: 'right', icon: 'align-right' },
|
|
85
|
+
{ value: 'justifyleft', icon: 'align-justifyleft' },
|
|
86
|
+
{ value: 'justifyright', icon: 'align-justifyright' }
|
|
87
|
+
] },
|
|
88
|
+
{ label: 'Style', type: 'style', key: 'styles',
|
|
89
|
+
options: [
|
|
90
|
+
{ value: 'italic', icon: 'italic' },
|
|
91
|
+
{ value: 'bold', icon: 'bold' },
|
|
92
|
+
{ value: 'underline', icon: 'underline' },
|
|
93
|
+
{ value: 'texticon', icon: 'texticon' },
|
|
94
|
+
{ value: 'capitalize', icon: 'capitalize' },
|
|
95
|
+
{ value: 'resize', icon: 'resize' }
|
|
96
|
+
] },
|
|
97
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' }
|
|
98
|
+
],
|
|
99
|
+
fieldProps: [
|
|
100
|
+
{ label: 'Field Required', type: 'radio' },
|
|
101
|
+
{ label: 'Default Value', placeholder: 'Enter Text ', type: 'text', key: 'defaultValue' },
|
|
102
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
103
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
104
|
+
{ label: 'Sub Text', placeholder: 'Enter Text ', type: 'text' }
|
|
105
|
+
]
|
|
106
|
+
},
|
|
107
|
+
'CheckBox': {
|
|
108
|
+
elementProps: [
|
|
109
|
+
{ label: 'Label', placeholder: 'Enter Text ', type: 'text', key: 'questionText' },
|
|
110
|
+
{ label: 'Place Holder', placeholder: 'Enter Text ', type: 'text', key: 'question' },
|
|
111
|
+
{ label: 'Help Text', placeholder: 'Enter Text ', type: 'text', key: 'helpText' },
|
|
112
|
+
{ label: '', type: 'toggleGroup' },
|
|
113
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
114
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
115
|
+
],
|
|
116
|
+
fieldProps: [
|
|
117
|
+
{ label: 'Field Required', type: 'radio' },
|
|
118
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
119
|
+
{
|
|
120
|
+
label: 'Chk Options',
|
|
121
|
+
type: 'optionsGroup',
|
|
122
|
+
key: 'chkOptions',
|
|
123
|
+
options: [
|
|
124
|
+
{ label: 'Option 1', value: '', type: 'text', key: 'option1' },
|
|
125
|
+
],
|
|
126
|
+
addOptionLabel: 'Add Variant', // Text for the plus icon
|
|
127
|
+
icon: 'plus' // Icon for adding options
|
|
128
|
+
},
|
|
129
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
130
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
131
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
132
|
+
]
|
|
133
|
+
},
|
|
134
|
+
'Calendar': {
|
|
135
|
+
elementProps: [
|
|
136
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
137
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
138
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
139
|
+
{ label: '', type: 'toggleGroup' },
|
|
140
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
141
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
142
|
+
],
|
|
143
|
+
fieldProps: [
|
|
144
|
+
{ label: 'Field Required', type: 'radio' },
|
|
145
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
146
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
147
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
148
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
149
|
+
]
|
|
150
|
+
},
|
|
151
|
+
'Time': {
|
|
152
|
+
elementProps: [
|
|
153
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'label' },
|
|
154
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'placeholder' },
|
|
155
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
156
|
+
{ label: '', type: 'toggleGroup' },
|
|
157
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
158
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
159
|
+
],
|
|
160
|
+
fieldProps: [
|
|
161
|
+
{ label: 'Field Required', type: 'radio' },
|
|
162
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
163
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
164
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
165
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
166
|
+
]
|
|
167
|
+
},
|
|
168
|
+
'Email': {
|
|
169
|
+
elementProps: [
|
|
170
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
171
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
172
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
173
|
+
{ label: '', type: 'toggleGroup' },
|
|
174
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
175
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
176
|
+
],
|
|
177
|
+
fieldProps: [
|
|
178
|
+
{ label: 'Field Required', type: 'radio' },
|
|
179
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
180
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
181
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
182
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
183
|
+
]
|
|
184
|
+
},
|
|
185
|
+
'File': {
|
|
186
|
+
elementProps: [
|
|
187
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
188
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
189
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
190
|
+
{ label: 'Support Type', type: 'select', key: 'supportType', options: [
|
|
191
|
+
{ label: 'Images (JPEG, PNG, GIF)', value: 'image/*', extensions: ['.jpg', '.jpeg', '.png', '.gif'] },
|
|
192
|
+
{ label: 'Audio (MP3, WAV, AIFF)', value: 'audio/*', extensions: ['.mp3', '.wav', '.aiff'] },
|
|
193
|
+
{ label: 'Video (MP4, AVI, HEVC)', value: 'video/*', extensions: ['.mp4', '.avi', '.hevc'] },
|
|
194
|
+
{ 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'] },
|
|
195
|
+
{ label: 'Executables (EXE, BAD, SH)', value: 'application/x-msdownload,application/x-sh', extensions: ['.exe', '.bad', '.sh'] },
|
|
196
|
+
{ label: 'Archives (ZIP, RAR, Git-hub)', value: 'application/zip,application/x-rar-compressed,application/x-git', extensions: ['.zip', '.rar', '.git'] }
|
|
197
|
+
] },
|
|
198
|
+
{ label: '', type: 'toggleGroup' },
|
|
199
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
200
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
201
|
+
],
|
|
202
|
+
fieldProps: [
|
|
203
|
+
{ label: 'Field Required', type: 'radio' },
|
|
204
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
205
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
206
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
207
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
208
|
+
]
|
|
209
|
+
},
|
|
210
|
+
'List': {
|
|
211
|
+
elementProps: [
|
|
212
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
213
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
214
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
215
|
+
{ label: '', type: 'toggleGroup' },
|
|
216
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
217
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
218
|
+
],
|
|
219
|
+
fieldProps: [
|
|
220
|
+
{ label: 'Field Required', type: 'radio' },
|
|
221
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
222
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
223
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
224
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
225
|
+
]
|
|
226
|
+
}, 'TextArea': {
|
|
227
|
+
elementProps: [
|
|
228
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
229
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
230
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
231
|
+
{ label: '', type: 'toggleGroup' },
|
|
232
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
233
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
234
|
+
],
|
|
235
|
+
fieldProps: [
|
|
236
|
+
{ label: 'Field Required', type: 'radio', key: 'required' },
|
|
237
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },
|
|
238
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
239
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
240
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
241
|
+
]
|
|
242
|
+
}, 'Numbers': {
|
|
243
|
+
elementProps: [
|
|
244
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
245
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
246
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
247
|
+
{ label: '', type: 'toggleGroup' },
|
|
248
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
249
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
250
|
+
],
|
|
251
|
+
fieldProps: [
|
|
252
|
+
{ label: 'Field Required', type: 'radio' },
|
|
253
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
254
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
255
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
256
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
257
|
+
]
|
|
258
|
+
}, 'Dropdown': {
|
|
259
|
+
elementProps: [
|
|
260
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
261
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
262
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
263
|
+
{ label: '', type: 'toggleGroup' },
|
|
264
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
265
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
266
|
+
],
|
|
267
|
+
fieldProps: [
|
|
268
|
+
{ label: 'Field Required', type: 'radio' },
|
|
269
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
270
|
+
{
|
|
271
|
+
label: 'Chk Options',
|
|
272
|
+
type: 'optionsGroup',
|
|
273
|
+
key: 'chkOptions',
|
|
274
|
+
options: [
|
|
275
|
+
{ label: 'Option 1', value: '', type: 'text', key: 'option1' },
|
|
276
|
+
],
|
|
277
|
+
addOptionLabel: 'Add Variant', // Text for the plus icon
|
|
278
|
+
icon: 'plus' // Icon for adding options
|
|
279
|
+
},
|
|
280
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
281
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
282
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' },
|
|
283
|
+
]
|
|
284
|
+
}, 'Image': {
|
|
285
|
+
elementProps: [
|
|
286
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
287
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
288
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
289
|
+
{ label: '', type: 'toggleGroup' },
|
|
290
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
291
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
292
|
+
],
|
|
293
|
+
fieldProps: [
|
|
294
|
+
{ label: 'Field Required', type: 'radio' },
|
|
295
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
296
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
297
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
298
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
299
|
+
]
|
|
300
|
+
}, 'Radio': {
|
|
301
|
+
elementProps: [
|
|
302
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
303
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
304
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
305
|
+
{ label: '', type: 'toggleGroup' },
|
|
306
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
307
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
308
|
+
],
|
|
309
|
+
fieldProps: [
|
|
310
|
+
{ label: 'Field Required', type: 'radio' },
|
|
311
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
312
|
+
{
|
|
313
|
+
label: 'Radio Options', // Updated label to reflect radio context
|
|
314
|
+
type: 'optionsGroup',
|
|
315
|
+
key: 'radioOptions', // Updated key for radio context
|
|
316
|
+
options: [
|
|
317
|
+
{ label: 'Option 1', value: '', type: 'text', key: 'option1' },
|
|
318
|
+
{ label: 'Option 2', value: '', type: 'text', key: 'option2' },
|
|
319
|
+
],
|
|
320
|
+
addOptionLabel: 'Add Option', // Updated label for add button
|
|
321
|
+
icon: 'plus', // Icon for adding options
|
|
322
|
+
},
|
|
323
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
324
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
325
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' },
|
|
326
|
+
]
|
|
327
|
+
},
|
|
328
|
+
'Book': {
|
|
329
|
+
elementProps: [
|
|
330
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
331
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
332
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
333
|
+
{ label: '', type: 'toggleGroup' },
|
|
334
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
335
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
336
|
+
],
|
|
337
|
+
fieldProps: [
|
|
338
|
+
{ label: 'Field Required', type: 'radio' },
|
|
339
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
340
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
341
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
342
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
343
|
+
]
|
|
344
|
+
}, 'Button': {
|
|
345
|
+
elementProps: [
|
|
346
|
+
{ label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },
|
|
347
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
348
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
349
|
+
{ label: '', type: 'toggleGroup' },
|
|
350
|
+
{ label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },
|
|
351
|
+
{ label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },
|
|
352
|
+
],
|
|
353
|
+
fieldProps: [
|
|
354
|
+
{ label: 'Field Required', type: 'radio' },
|
|
355
|
+
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text' },
|
|
356
|
+
{ label: 'Reference', placeholder: 'Reference Field', type: 'text' },
|
|
357
|
+
{ label: 'Style', placeholder: 'Style JSON', type: 'text' },
|
|
358
|
+
{ label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }
|
|
359
|
+
]
|
|
360
|
+
},
|
|
361
|
+
};
|
|
362
|
+
constructor(http, formBuilderService) {
|
|
363
|
+
this.http = http;
|
|
364
|
+
this.formBuilderService = formBuilderService;
|
|
365
|
+
}
|
|
366
|
+
ngOnInit() {
|
|
367
|
+
this.formBuilderService.selectedElement$.subscribe(index => {
|
|
368
|
+
this.selectedElementIndex = index;
|
|
369
|
+
if (index >= 0) {
|
|
370
|
+
const elements = this.formBuilderService.getElements();
|
|
371
|
+
console.log('Selected element:', elements);
|
|
372
|
+
this.selectedElement = elements[index];
|
|
373
|
+
}
|
|
374
|
+
});
|
|
375
|
+
}
|
|
376
|
+
validateInput(value, type) {
|
|
377
|
+
if (type === 'label' || type === 'placeholder') {
|
|
378
|
+
const regex = /^[a-zA-Z0-9\s]*$/;
|
|
379
|
+
if (!regex.test(value)) {
|
|
380
|
+
this.errorMessage = 'Only letters and numbers are allowed';
|
|
381
|
+
return false;
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
this.errorMessage = '';
|
|
385
|
+
return true;
|
|
386
|
+
}
|
|
387
|
+
updateProperty(key, value) {
|
|
388
|
+
if (this.selectedElementIndex >= 0) {
|
|
389
|
+
if (key === 'questionText' || key === 'question') {
|
|
390
|
+
if (!this.validateInput(value, key)) {
|
|
391
|
+
return;
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
if (key === 'fontWeight') {
|
|
395
|
+
// Extract just the number value from the option
|
|
396
|
+
value = value.split('-')[0];
|
|
397
|
+
}
|
|
398
|
+
if (key === 'styles') {
|
|
399
|
+
const currentStyles = this.selectedElement.styles || [];
|
|
400
|
+
if (value === 'capitalize' || value === 'lowercase') {
|
|
401
|
+
// Remove the opposite case if it exists
|
|
402
|
+
const oppositeStyle = value === 'capitalize' ? 'lowercase' : 'capitalize';
|
|
403
|
+
const filteredStyles = currentStyles.filter(s => s !== oppositeStyle);
|
|
404
|
+
value = currentStyles.includes(value)
|
|
405
|
+
? filteredStyles.filter(s => s !== value)
|
|
406
|
+
: [...filteredStyles, value];
|
|
407
|
+
}
|
|
408
|
+
else {
|
|
409
|
+
// Toggle other styles
|
|
410
|
+
value = currentStyles.includes(value)
|
|
411
|
+
? currentStyles.filter(s => s !== value)
|
|
412
|
+
: [...currentStyles, value];
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
const update = { [key]: value };
|
|
416
|
+
this.formBuilderService.updateElement(this.selectedElementIndex, update);
|
|
417
|
+
// Special handling for font and font weight
|
|
418
|
+
if (key === 'font') {
|
|
419
|
+
this.selectedElement.font = value; // Directly update the selected element's font property
|
|
420
|
+
}
|
|
421
|
+
}
|
|
422
|
+
}
|
|
423
|
+
onRequiredChange(value) {
|
|
424
|
+
if (this.selectedElement) {
|
|
425
|
+
// Remove any existing asterisks first
|
|
426
|
+
let label = this.selectedElement.label.replace(/\s*\*+$/, '');
|
|
427
|
+
if (value) {
|
|
428
|
+
label = `${label} *`; // Add single asterisk
|
|
429
|
+
}
|
|
430
|
+
this.updateProperty('label', label);
|
|
431
|
+
this.updateProperty('required', value);
|
|
432
|
+
}
|
|
433
|
+
}
|
|
434
|
+
getProperties() {
|
|
435
|
+
if (!this.selectedElement)
|
|
436
|
+
return null;
|
|
437
|
+
return this.elementProperties[this.selectedElement.type];
|
|
438
|
+
}
|
|
439
|
+
// openColorPicker(propertyKey: string) {
|
|
440
|
+
// // If you want to use the browser's native color picker:
|
|
441
|
+
// const input = document.createElement('input');
|
|
442
|
+
// input.type = 'color';
|
|
443
|
+
// input.value = this.selectedElement[propertyKey];
|
|
444
|
+
// input.addEventListener('change', (e: any) => {
|
|
445
|
+
// this.updateProperty(propertyKey, e.target.value);
|
|
446
|
+
// });
|
|
447
|
+
// input.click();
|
|
448
|
+
// }
|
|
449
|
+
// Function to add a new option to prop options
|
|
450
|
+
addOption(options) {
|
|
451
|
+
options.push({ label: '', value: '' });
|
|
452
|
+
}
|
|
453
|
+
// Function to remove an option from prop options
|
|
454
|
+
removeOption(options, index) {
|
|
455
|
+
options.splice(index, 1);
|
|
456
|
+
}
|
|
457
|
+
download() {
|
|
458
|
+
console.log('Question Book:', this.formBuilderService.downloadElement());
|
|
459
|
+
}
|
|
460
|
+
save() {
|
|
461
|
+
const apiURL = 'https://dev-api.rangerfusion.com/nxt/';
|
|
462
|
+
this.http.post(apiURL, this.formBuilderService.downloadElement()).subscribe((response) => {
|
|
463
|
+
console.log('Response:', response);
|
|
464
|
+
}, (error) => {
|
|
465
|
+
console.error('Error:', error);
|
|
466
|
+
});
|
|
467
|
+
}
|
|
468
|
+
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 });
|
|
469
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PropertiesComponent, selector: "app-properties", inputs: { selectedElementType: "selectedElementType" }, viewQueries: [{ propertyName: "colorWheel", first: true, predicate: ["colorWheel"], descendants: true }], ngImport: i0, template: "<!-- AP 22JAN25 - Field and Element Properties -->\r\n<!-- properties.component.html -->\r\n<div class=\"container\">\r\n <link href=\"https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap\" rel=\"stylesheet\">\r\n<!-- Design Header Section -->\r\n<div class=\"design-header\">\r\n <h1 class=\"header-title\">Element Properties</h1>\r\n <div class=\"menu-container\">\r\n <div class=\"menu-item\" (click)=\"download()\">\r\n <span >Download</span>\r\n </div>\r\n <div class=\"menu-item\">\r\n <span>Start</span>\r\n </div>\r\n <div class=\"menu-item\">\r\n <span>Path</span>\r\n </div>\r\n <div class=\"menu-item\">\r\n <span>Clone</span>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- properties.component.html -->\r\n<div class=\"all-properties\">\r\n <div *ngIf=\"errorMessage\" class=\"error-message\">\r\n {{ errorMessage }}\r\n </div>\r\n <!-- Element Properties -->\r\n <details class=\"first-properties\" open>\r\n <summary class=\"text-sm \">Elements Properties</summary>\r\n <div class=\"inner-content\" *ngIf=\"getProperties()\">\r\n <ng-container *ngFor=\"let prop of getProperties().elementProps\">\r\n <div class=\"flex-items-center\">\r\n <label class=\"text-sm\">{{ prop.label }}</label>\r\n <div class=\"label-properties\">\r\n <!-- Text Input -->\r\n <input *ngIf=\"prop.type === 'text'\"\r\n type=\"text\"\r\n [placeholder]=\"prop.placeholder\"\r\n [value]=\"selectedElement[prop.key]\"\r\n (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n [class.read-only]=\"selectedElement.readOnly\"\r\n [readonly]=\"selectedElement.readOnly\"\r\n class=\"text-sm1 \"\r\n />\r\n <div *ngIf=\"prop.key === 'helpText' && selectedElement.helpText\" class=\"help-text\">\r\n {{ selectedElement.helpText }}\r\n </div>\r\n\r\n\r\n <!-- Font Selection -->\r\n<div *ngIf=\"prop.key === 'font'\" class=\"font-selection\">\r\n <!-- <label>{{ prop.label }}</label> -->\r\n <select\r\n *ngIf=\"prop.type === 'select' && prop.key === 'font'\"\r\n class=\"font-selection1\"\r\n [value]=\"selectedElement?.font\"\r\n (change)=\"updateProperty('font', $event.target.value)\">\r\n <option *ngFor=\"let option of prop.options\" [value]=\"option\">\r\n {{ option }}\r\n </option>\r\n </select>\r\n</div>\r\n\r\n<!-- file -->\r\n<!-- Add this inside the elementProps loop where other inputs are rendered -->\r\n<select *ngIf=\"prop.type === 'select' && prop.key === 'supportType'\"\r\n class=\"file \"\r\n[value]=\"selectedElement[prop.key]\"\r\n(change)=\"updateProperty(prop.key, $event.target.value)\">\r\n<option value=\"\">Select file category</option>\r\n<option *ngFor=\"let option of prop.options\" [value]=\"option.value\">\r\n{{ option.label }}\r\n</option>\r\n</select>\r\n\r\n<!-- Font Weight Selection -->\r\n<div *ngIf=\"prop.key === 'fontWeight'\" class=\"font-weight\">\r\n <!-- <label>{{ prop.label }}</label> -->\r\n <select\r\n *ngIf=\"prop.type === 'select' && prop.key === 'fontWeight'\"\r\n class=\"font-weight1 \"\r\n [value]=\"selectedElement?.fontWeight\"\r\n (change)=\"updateProperty('fontWeight', $event.target.value)\">\r\n <option *ngFor=\"let option of prop.options\" [value]=\"option.value\">\r\n {{ option.label }}\r\n </option>\r\n </select>\r\n</div>\r\n\r\n <!-- Number Input with Unit -->\r\n <div *ngIf=\"prop.type === 'number'\" class=\"size-controls\">\r\n <div class=\"size-input-group\">\r\n <input\r\n type=\"number\"\r\n [value]=\"selectedElement[prop.key]\"\r\n (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n [min]=\"prop.min || 1\"\r\n [max]=\"prop.max || 999999\"\r\n class=\"size-value\"\r\n />\r\n <span class=\"size-unit\">{{ prop.unit }}</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Toggle Group -->\r\n<!-- Toggle Group -->\r\n<div *ngIf=\"prop.type === 'toggleGroup'\" class=\"toggle-group\">\r\n<div class=\"toggle-item1\">\r\n <span class=\"toggle-label\">Read Only</span>\r\n <label class=\"switch\">\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"selectedElement?.readOnly\"\r\n (change)=\"onToggleChange('readOnly', $event)\"\r\n />\r\n <span class=\"slider\"></span>\r\n </label>\r\n</div>\r\n\r\n<div class=\"toggle-item2\">\r\n <span class=\"toggle-label\">Is Hide</span>\r\n <label class=\"switch\">\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"selectedElement?.isHide\"\r\n (change)=\"onToggleChange('isHide', $event)\"\r\n />\r\n <span class=\"slider\"></span>\r\n </label>\r\n</div>\r\n</div>\r\n\r\n <!-- Text Align Buttons -->\r\n <div *ngIf=\"prop.type === 'align'\"class=\"font-align\">\r\n <button\r\n *ngFor=\"let option of prop.options\"\r\n (click)=\"onAlignSelect(option.value)\"\r\n [class.active]=\"selectedElement?.textAlign === option.value\"\r\n class=\"align-btn\"\r\n [title]=\"option.value\"\r\n >\r\n <img\r\n [src]=\"'../assets/icons/' + option.icon + '.svg'\"\r\n [alt]=\"option.value\"\r\n class=\"icon-size\"\r\n />\r\n </button>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"prop.key === 'size'\" class=\"size-controls\">\r\n <label>{{ prop.label }}</label>\r\n <input\r\n type=\"number\"\r\n [value]=\"selectedElement[prop.key]\"\r\n (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n class=\"size-input\"\r\n />\r\n <span class=\"size-unit\">{{ prop.unit }}</span>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"prop.type === 'style'\" class=\"font-style\">\r\n <button\r\n *ngFor=\"let option of prop.options\"\r\n (click)=\"onStyleSelect(option.value)\"\r\n [class.active]=\"isStyleActive(option.value)\"\r\n class=\"style-btn\"\r\n [title]=\"option.value\"\r\n >\r\n <img\r\n [src]=\"'../assets/icons/' + option.icon + '.svg'\"\r\n [alt]=\"option.value\"\r\n class=\"icon-size\"\r\n />\r\n </button>\r\n </div>\r\n\r\n<!-- Field Size Controls -->\r\n<div *ngIf=\"prop.key === 'fieldSize'\" class=\"field-size-controls\">\r\n <div class=\"size-group\">\r\n <label class=\"size-label\">Width</label>\r\n <div class=\"value-container\">\r\n <input\r\n type=\"number\"\r\n [value]=\"selectedElement?.width\"\r\n (input)=\"updateProperty('width', $event.target.value)\"\r\n class=\"size-input\"\r\n\r\n />\r\n <span class=\"unit\">PX</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"prop.key === 'fieldSize'\" class=\"field-size-controls\">\r\n <div class=\"size-group\">\r\n <label class=\"size-label\">Height</label>\r\n <div class=\"value-container\">\r\n <input\r\n type=\"number\"\r\n [value]=\"selectedElement?.height\"\r\n (input)=\"updateProperty('height', $event.target.value)\"\r\n class=\"size-input\"\r\n />\r\n <span class=\"unit\">PX</span>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n</div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </details>\r\n\r\n <!-- Field Elements Properties -->\r\n<details class=\"second-property\">\r\n <summary class=\"text-font-medium\">Field Elements Properties</summary>\r\n <div class=\"space-y-4\" *ngIf=\"getProperties()\">\r\n <ng-container *ngFor=\"let prop of getProperties().fieldProps\">\r\n <div class=\"flex-items-center \">\r\n <label class=\"text-sm\">{{ prop.label }}</label>\r\n <div class=\"input-box-field\">\r\n <!-- Input Box -->\r\n <input\r\n *ngIf=\"prop.type === 'text'\"\r\n type=\"text\"\r\n [placeholder]=\"prop.placeholder\"\r\n class=\"field-input\"\r\n />\r\n <!-- Radio Group -->\r\n<div *ngIf=\"prop.type === 'radio'\" class=\"radio-item\">\r\n\r\n\r\n <div class=\"sizes\">\r\n <div class=\"flex-gap\">\r\n <div class=\"flex-items\">\r\n <input\r\n type=\"radio\"\r\n [checked]=\"selectedElement.required\"\r\n (change)=\"onRequiredChange(true)\"\r\n name=\"required\"\r\n class=\"radio-input\"\r\n />\r\n <label\r\n class=\"text-label\"\r\n >\r\n Required\r\n </label>\r\n </div>\r\n <div class=\"flex-items\">\r\n <input\r\n type=\"radio\"\r\n [checked]=\"!selectedElement.required\"\r\n (change)=\"onRequiredChange(false)\"\r\n name=\"required\"\r\n class=\"radio-input\"\r\n />\r\n <label\r\n class=\"text-sm text-gray-400\"\r\n >\r\n Not Required\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n</div>\r\n <!-- Chk Options Group -->\r\n <div *ngIf=\"prop.type === 'optionsGroup'\" class=\"options-container\">\r\n <div\r\n *ngFor=\"let option of prop.options; let i = index\"\r\n class=\"option-items\"\r\n >\r\n <!-- Option Input -->\r\n <input\r\n type=\"text\"\r\n [(ngModel)]=\"prop.options[i].label\"\r\n placeholder=\"Option {{ i + 1 }}\"\r\n class=\"options\"\r\n />\r\n <input\r\n type=\"text\"\r\n [(ngModel)]=\"prop.options[i].value\"\r\n placeholder=\"Value\"\r\n class=\"values\"\r\n />\r\n <!-- Remove Button -->\r\n <div class=\"remove\">\r\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeOption(prop.options, i)\"></div>\r\n </div>\r\n <!-- Add Button -->\r\n <button\r\n type=\"button\"\r\n class=\"add-btn\"\r\n (click)=\"addOption(prop.options)\"\r\n >\r\n <div class=\"add-varient\">\r\n <span class=\"text-lg\">+</span>\r\n <span>Add Variants</span></div>\r\n </button>\r\n</div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <div class=\"design-footer\">\r\n <button class=\"btn\">Cancel</button>\r\n <button class=\"btn\" (click)=\"save()\">Save</button>\r\n </div>\r\n</details>\r\n</div>\r\n\r\n\r\n</div>\r\n", styles: [".container{position:absolute;right:0;top:0;width:25%}.all-properties{padding:0;margin:-32px -13px 0 0;background-color:#f8fafc;position:relative;top:3px;max-height:549px;overflow-y:auto}.first-properties{padding-top:16px;padding-left:15px}details summary{font-weight:700;color:#1b1b43;cursor:pointer}details[open] summary{padding-bottom:5px;margin-bottom:1rem}label{flex:0 0 120px;color:#b8b8b8;font-size:.875rem;font-weight:500;margin:0;padding:0}input,select{flex:1;background-color:#eaedf1;color:#bebfbf;border-radius:.375rem;padding:.5rem;font-size:.875rem;width:100%;box-sizing:border-box;transition:border-color .2s}input:focus,select:focus{border-color:#1b1b43;outline:none}button{background-color:#eaedf1;color:#6b7280;border:1px solid #D1D5DB;border-radius:.375rem;padding:.5rem;cursor:pointer;transition:all .2s}button:hover{background-color:#e5e7eb}button.selected{background-color:#0b1f34;color:#fff;border-color:#1e90ff}.color-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:50px;height:50px;background-color:transparent;border:none;cursor:pointer}.color-input::-webkit-color-swatch,.color-input::-moz-color-swatch{border-radius:5px;border:none}.inner-content{position:relative;left:30px;width:90%}.label-properties{position:relative;top:-12px;left:-37px}.required-indicator{color:red;margin-left:4px}.toggle-item1{position:relative;left:-94px;width:124px;color:#b8b8b8}.toggle-item2{width:100px;position:relative;top:-24px;left:84px;color:#b8b8b8}.flex-gap-1{display:flex;grid-template-columns:repeat(4,auto)}.help-text,.error-message{font-size:12px;margin-top:4px}.help-text{color:#666}.error-message{color:#ef4444}.read-only{background-color:#f5f5f5;cursor:not-allowed}.font-selection,.font-weight{width:190px}.design-header{padding:17px;background-color:#fff;margin-bottom:2rem}.header-title{font-size:16px;font-weight:500;text-align:center;margin:0 0 20px 5px}.menu-container{display:flex;justify-content:space-between;max-width:800px;margin:0 auto;background-color:#f8f9fa;border-radius:8px}.menu-item{flex:1;text-align:center;padding:7px;cursor:pointer;transition:all .3s ease;border-right:2px solid #e9ecef}.menu-item span{color:#656f7b;font-size:1rem}.menu-container{display:flex;justify-content:space-between;max-width:800px;margin:0 auto;background-color:#f8f9fa;border-radius:8px;padding:.5rem}.menu-item{flex:1;text-align:center;padding:m;cursor:pointer;transition:all .3s ease;border-right:1px solid #e9ecef}.menu-item:last-child{border-right:none}.menu-item:hover{background-color:#e9ecef;border-radius:4px}.menu-item span{color:#495057;font-size:1rem}.switch{position:relative;display:inline-block;width:40px;height:24px;right:-20px;margin:0 8px}.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:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#2196f3}input:checked+.slider:before{transform:translate(16px)}.font-align{display:flex;gap:2px}.align-btn,.style-btn{width:36px;height:36px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer;transition:all .2s}.align-btn:hover,.style-btn:hover{background:#e5e7eb}.align-btn.active,.style-btn.active{background:#202e3a;color:#fff;border-color:#4b5563}.align-btn.active img,.style-btn.active img{filter:brightness(0) invert(1)}.icon-size{width:16px;height:16px}.button-group{display:flex;gap:4px;padding:4px;background:#f9fafb;border-radius:6px}.field-size-controls{display:flex;flex-direction:row;position:relative;gap:13px;font-family:Arial,sans-serif}.size-group{display:flex;align-items:center}.size-label{font-size:15px;color:#000}.value-container{display:flex;height:43px;align-items:center;background-color:#f5f5f5;border-radius:11px;position:relative;right:74px}.font-style{display:flex;gap:1px}.size-input{font-size:15px;border:none;background:transparent;width:46px;text-align:center;outline:none}.size-input:focus{outline:none}.unit{font-size:13px;width:22px;color:#00000080}.file-upload-container{position:relative;margin-bottom:1rem}.file-upload-container input[type=file]{margin-top:.5rem}.text-font-medium{padding-left:15px;padding-bottom:20px}.options-container{display:flex;flex-direction:column;gap:.5rem}.option-item{display:flex;align-items:center;gap:1rem}.option-items{display:flex;gap:20px}.options{width:69px}.values{width:49px}.remove{width:34px;border-radius:50px;height:35px;background-color:#f7eff0}.remove img{position:relative;top:6px;left:9px}.add-btn{background:none;border:none;font-size:1rem;cursor:pointer;display:flex;align-items:center;width:328px;position:relative;right:123px;background-color:#f1f4f7}.add-btn:hover{color:#3182ce}.text-lg{border:1px solid gray;width:22px;border-radius:5px}.add-varient{display:flex;gap:13px;position:relative;left:101px}input{border:1px solid #ccc;padding:.5rem;border-radius:.25rem;width:100%}.space-y-4{position:relative;left:28px}.flex-items-center{display:flex;position:relative;top:2px;margin-bottom:28px}.input-box-field{width:207px}.text-sm{height:30px}.radio-item{position:relative;left:-5px}.flex-gap{display:flex;gap:18px}.design-footer{display:flex;justify-content:center;gap:30px;background-color:#f1f4f7}.btn{width:110px;color:#fff;margin-top:20px;margin-bottom:20px;background-color:#a5adbc}.btn:hover{background-color:#2196f3;color:#fff}\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"] }] });
|
|
470
|
+
}
|
|
471
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PropertiesComponent, decorators: [{
|
|
472
|
+
type: Component,
|
|
473
|
+
args: [{ selector: 'app-properties', template: "<!-- AP 22JAN25 - Field and Element Properties -->\r\n<!-- properties.component.html -->\r\n<div class=\"container\">\r\n <link href=\"https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap\" rel=\"stylesheet\">\r\n<!-- Design Header Section -->\r\n<div class=\"design-header\">\r\n <h1 class=\"header-title\">Element Properties</h1>\r\n <div class=\"menu-container\">\r\n <div class=\"menu-item\" (click)=\"download()\">\r\n <span >Download</span>\r\n </div>\r\n <div class=\"menu-item\">\r\n <span>Start</span>\r\n </div>\r\n <div class=\"menu-item\">\r\n <span>Path</span>\r\n </div>\r\n <div class=\"menu-item\">\r\n <span>Clone</span>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- properties.component.html -->\r\n<div class=\"all-properties\">\r\n <div *ngIf=\"errorMessage\" class=\"error-message\">\r\n {{ errorMessage }}\r\n </div>\r\n <!-- Element Properties -->\r\n <details class=\"first-properties\" open>\r\n <summary class=\"text-sm \">Elements Properties</summary>\r\n <div class=\"inner-content\" *ngIf=\"getProperties()\">\r\n <ng-container *ngFor=\"let prop of getProperties().elementProps\">\r\n <div class=\"flex-items-center\">\r\n <label class=\"text-sm\">{{ prop.label }}</label>\r\n <div class=\"label-properties\">\r\n <!-- Text Input -->\r\n <input *ngIf=\"prop.type === 'text'\"\r\n type=\"text\"\r\n [placeholder]=\"prop.placeholder\"\r\n [value]=\"selectedElement[prop.key]\"\r\n (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n [class.read-only]=\"selectedElement.readOnly\"\r\n [readonly]=\"selectedElement.readOnly\"\r\n class=\"text-sm1 \"\r\n />\r\n <div *ngIf=\"prop.key === 'helpText' && selectedElement.helpText\" class=\"help-text\">\r\n {{ selectedElement.helpText }}\r\n </div>\r\n\r\n\r\n <!-- Font Selection -->\r\n<div *ngIf=\"prop.key === 'font'\" class=\"font-selection\">\r\n <!-- <label>{{ prop.label }}</label> -->\r\n <select\r\n *ngIf=\"prop.type === 'select' && prop.key === 'font'\"\r\n class=\"font-selection1\"\r\n [value]=\"selectedElement?.font\"\r\n (change)=\"updateProperty('font', $event.target.value)\">\r\n <option *ngFor=\"let option of prop.options\" [value]=\"option\">\r\n {{ option }}\r\n </option>\r\n </select>\r\n</div>\r\n\r\n<!-- file -->\r\n<!-- Add this inside the elementProps loop where other inputs are rendered -->\r\n<select *ngIf=\"prop.type === 'select' && prop.key === 'supportType'\"\r\n class=\"file \"\r\n[value]=\"selectedElement[prop.key]\"\r\n(change)=\"updateProperty(prop.key, $event.target.value)\">\r\n<option value=\"\">Select file category</option>\r\n<option *ngFor=\"let option of prop.options\" [value]=\"option.value\">\r\n{{ option.label }}\r\n</option>\r\n</select>\r\n\r\n<!-- Font Weight Selection -->\r\n<div *ngIf=\"prop.key === 'fontWeight'\" class=\"font-weight\">\r\n <!-- <label>{{ prop.label }}</label> -->\r\n <select\r\n *ngIf=\"prop.type === 'select' && prop.key === 'fontWeight'\"\r\n class=\"font-weight1 \"\r\n [value]=\"selectedElement?.fontWeight\"\r\n (change)=\"updateProperty('fontWeight', $event.target.value)\">\r\n <option *ngFor=\"let option of prop.options\" [value]=\"option.value\">\r\n {{ option.label }}\r\n </option>\r\n </select>\r\n</div>\r\n\r\n <!-- Number Input with Unit -->\r\n <div *ngIf=\"prop.type === 'number'\" class=\"size-controls\">\r\n <div class=\"size-input-group\">\r\n <input\r\n type=\"number\"\r\n [value]=\"selectedElement[prop.key]\"\r\n (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n [min]=\"prop.min || 1\"\r\n [max]=\"prop.max || 999999\"\r\n class=\"size-value\"\r\n />\r\n <span class=\"size-unit\">{{ prop.unit }}</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Toggle Group -->\r\n<!-- Toggle Group -->\r\n<div *ngIf=\"prop.type === 'toggleGroup'\" class=\"toggle-group\">\r\n<div class=\"toggle-item1\">\r\n <span class=\"toggle-label\">Read Only</span>\r\n <label class=\"switch\">\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"selectedElement?.readOnly\"\r\n (change)=\"onToggleChange('readOnly', $event)\"\r\n />\r\n <span class=\"slider\"></span>\r\n </label>\r\n</div>\r\n\r\n<div class=\"toggle-item2\">\r\n <span class=\"toggle-label\">Is Hide</span>\r\n <label class=\"switch\">\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"selectedElement?.isHide\"\r\n (change)=\"onToggleChange('isHide', $event)\"\r\n />\r\n <span class=\"slider\"></span>\r\n </label>\r\n</div>\r\n</div>\r\n\r\n <!-- Text Align Buttons -->\r\n <div *ngIf=\"prop.type === 'align'\"class=\"font-align\">\r\n <button\r\n *ngFor=\"let option of prop.options\"\r\n (click)=\"onAlignSelect(option.value)\"\r\n [class.active]=\"selectedElement?.textAlign === option.value\"\r\n class=\"align-btn\"\r\n [title]=\"option.value\"\r\n >\r\n <img\r\n [src]=\"'../assets/icons/' + option.icon + '.svg'\"\r\n [alt]=\"option.value\"\r\n class=\"icon-size\"\r\n />\r\n </button>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"prop.key === 'size'\" class=\"size-controls\">\r\n <label>{{ prop.label }}</label>\r\n <input\r\n type=\"number\"\r\n [value]=\"selectedElement[prop.key]\"\r\n (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n class=\"size-input\"\r\n />\r\n <span class=\"size-unit\">{{ prop.unit }}</span>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"prop.type === 'style'\" class=\"font-style\">\r\n <button\r\n *ngFor=\"let option of prop.options\"\r\n (click)=\"onStyleSelect(option.value)\"\r\n [class.active]=\"isStyleActive(option.value)\"\r\n class=\"style-btn\"\r\n [title]=\"option.value\"\r\n >\r\n <img\r\n [src]=\"'../assets/icons/' + option.icon + '.svg'\"\r\n [alt]=\"option.value\"\r\n class=\"icon-size\"\r\n />\r\n </button>\r\n </div>\r\n\r\n<!-- Field Size Controls -->\r\n<div *ngIf=\"prop.key === 'fieldSize'\" class=\"field-size-controls\">\r\n <div class=\"size-group\">\r\n <label class=\"size-label\">Width</label>\r\n <div class=\"value-container\">\r\n <input\r\n type=\"number\"\r\n [value]=\"selectedElement?.width\"\r\n (input)=\"updateProperty('width', $event.target.value)\"\r\n class=\"size-input\"\r\n\r\n />\r\n <span class=\"unit\">PX</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"prop.key === 'fieldSize'\" class=\"field-size-controls\">\r\n <div class=\"size-group\">\r\n <label class=\"size-label\">Height</label>\r\n <div class=\"value-container\">\r\n <input\r\n type=\"number\"\r\n [value]=\"selectedElement?.height\"\r\n (input)=\"updateProperty('height', $event.target.value)\"\r\n class=\"size-input\"\r\n />\r\n <span class=\"unit\">PX</span>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n</div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </details>\r\n\r\n <!-- Field Elements Properties -->\r\n<details class=\"second-property\">\r\n <summary class=\"text-font-medium\">Field Elements Properties</summary>\r\n <div class=\"space-y-4\" *ngIf=\"getProperties()\">\r\n <ng-container *ngFor=\"let prop of getProperties().fieldProps\">\r\n <div class=\"flex-items-center \">\r\n <label class=\"text-sm\">{{ prop.label }}</label>\r\n <div class=\"input-box-field\">\r\n <!-- Input Box -->\r\n <input\r\n *ngIf=\"prop.type === 'text'\"\r\n type=\"text\"\r\n [placeholder]=\"prop.placeholder\"\r\n class=\"field-input\"\r\n />\r\n <!-- Radio Group -->\r\n<div *ngIf=\"prop.type === 'radio'\" class=\"radio-item\">\r\n\r\n\r\n <div class=\"sizes\">\r\n <div class=\"flex-gap\">\r\n <div class=\"flex-items\">\r\n <input\r\n type=\"radio\"\r\n [checked]=\"selectedElement.required\"\r\n (change)=\"onRequiredChange(true)\"\r\n name=\"required\"\r\n class=\"radio-input\"\r\n />\r\n <label\r\n class=\"text-label\"\r\n >\r\n Required\r\n </label>\r\n </div>\r\n <div class=\"flex-items\">\r\n <input\r\n type=\"radio\"\r\n [checked]=\"!selectedElement.required\"\r\n (change)=\"onRequiredChange(false)\"\r\n name=\"required\"\r\n class=\"radio-input\"\r\n />\r\n <label\r\n class=\"text-sm text-gray-400\"\r\n >\r\n Not Required\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n</div>\r\n <!-- Chk Options Group -->\r\n <div *ngIf=\"prop.type === 'optionsGroup'\" class=\"options-container\">\r\n <div\r\n *ngFor=\"let option of prop.options; let i = index\"\r\n class=\"option-items\"\r\n >\r\n <!-- Option Input -->\r\n <input\r\n type=\"text\"\r\n [(ngModel)]=\"prop.options[i].label\"\r\n placeholder=\"Option {{ i + 1 }}\"\r\n class=\"options\"\r\n />\r\n <input\r\n type=\"text\"\r\n [(ngModel)]=\"prop.options[i].value\"\r\n placeholder=\"Value\"\r\n class=\"values\"\r\n />\r\n <!-- Remove Button -->\r\n <div class=\"remove\">\r\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeOption(prop.options, i)\"></div>\r\n </div>\r\n <!-- Add Button -->\r\n <button\r\n type=\"button\"\r\n class=\"add-btn\"\r\n (click)=\"addOption(prop.options)\"\r\n >\r\n <div class=\"add-varient\">\r\n <span class=\"text-lg\">+</span>\r\n <span>Add Variants</span></div>\r\n </button>\r\n</div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <div class=\"design-footer\">\r\n <button class=\"btn\">Cancel</button>\r\n <button class=\"btn\" (click)=\"save()\">Save</button>\r\n </div>\r\n</details>\r\n</div>\r\n\r\n\r\n</div>\r\n", styles: [".container{position:absolute;right:0;top:0;width:25%}.all-properties{padding:0;margin:-32px -13px 0 0;background-color:#f8fafc;position:relative;top:3px;max-height:549px;overflow-y:auto}.first-properties{padding-top:16px;padding-left:15px}details summary{font-weight:700;color:#1b1b43;cursor:pointer}details[open] summary{padding-bottom:5px;margin-bottom:1rem}label{flex:0 0 120px;color:#b8b8b8;font-size:.875rem;font-weight:500;margin:0;padding:0}input,select{flex:1;background-color:#eaedf1;color:#bebfbf;border-radius:.375rem;padding:.5rem;font-size:.875rem;width:100%;box-sizing:border-box;transition:border-color .2s}input:focus,select:focus{border-color:#1b1b43;outline:none}button{background-color:#eaedf1;color:#6b7280;border:1px solid #D1D5DB;border-radius:.375rem;padding:.5rem;cursor:pointer;transition:all .2s}button:hover{background-color:#e5e7eb}button.selected{background-color:#0b1f34;color:#fff;border-color:#1e90ff}.color-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:50px;height:50px;background-color:transparent;border:none;cursor:pointer}.color-input::-webkit-color-swatch,.color-input::-moz-color-swatch{border-radius:5px;border:none}.inner-content{position:relative;left:30px;width:90%}.label-properties{position:relative;top:-12px;left:-37px}.required-indicator{color:red;margin-left:4px}.toggle-item1{position:relative;left:-94px;width:124px;color:#b8b8b8}.toggle-item2{width:100px;position:relative;top:-24px;left:84px;color:#b8b8b8}.flex-gap-1{display:flex;grid-template-columns:repeat(4,auto)}.help-text,.error-message{font-size:12px;margin-top:4px}.help-text{color:#666}.error-message{color:#ef4444}.read-only{background-color:#f5f5f5;cursor:not-allowed}.font-selection,.font-weight{width:190px}.design-header{padding:17px;background-color:#fff;margin-bottom:2rem}.header-title{font-size:16px;font-weight:500;text-align:center;margin:0 0 20px 5px}.menu-container{display:flex;justify-content:space-between;max-width:800px;margin:0 auto;background-color:#f8f9fa;border-radius:8px}.menu-item{flex:1;text-align:center;padding:7px;cursor:pointer;transition:all .3s ease;border-right:2px solid #e9ecef}.menu-item span{color:#656f7b;font-size:1rem}.menu-container{display:flex;justify-content:space-between;max-width:800px;margin:0 auto;background-color:#f8f9fa;border-radius:8px;padding:.5rem}.menu-item{flex:1;text-align:center;padding:m;cursor:pointer;transition:all .3s ease;border-right:1px solid #e9ecef}.menu-item:last-child{border-right:none}.menu-item:hover{background-color:#e9ecef;border-radius:4px}.menu-item span{color:#495057;font-size:1rem}.switch{position:relative;display:inline-block;width:40px;height:24px;right:-20px;margin:0 8px}.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:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#2196f3}input:checked+.slider:before{transform:translate(16px)}.font-align{display:flex;gap:2px}.align-btn,.style-btn{width:36px;height:36px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer;transition:all .2s}.align-btn:hover,.style-btn:hover{background:#e5e7eb}.align-btn.active,.style-btn.active{background:#202e3a;color:#fff;border-color:#4b5563}.align-btn.active img,.style-btn.active img{filter:brightness(0) invert(1)}.icon-size{width:16px;height:16px}.button-group{display:flex;gap:4px;padding:4px;background:#f9fafb;border-radius:6px}.field-size-controls{display:flex;flex-direction:row;position:relative;gap:13px;font-family:Arial,sans-serif}.size-group{display:flex;align-items:center}.size-label{font-size:15px;color:#000}.value-container{display:flex;height:43px;align-items:center;background-color:#f5f5f5;border-radius:11px;position:relative;right:74px}.font-style{display:flex;gap:1px}.size-input{font-size:15px;border:none;background:transparent;width:46px;text-align:center;outline:none}.size-input:focus{outline:none}.unit{font-size:13px;width:22px;color:#00000080}.file-upload-container{position:relative;margin-bottom:1rem}.file-upload-container input[type=file]{margin-top:.5rem}.text-font-medium{padding-left:15px;padding-bottom:20px}.options-container{display:flex;flex-direction:column;gap:.5rem}.option-item{display:flex;align-items:center;gap:1rem}.option-items{display:flex;gap:20px}.options{width:69px}.values{width:49px}.remove{width:34px;border-radius:50px;height:35px;background-color:#f7eff0}.remove img{position:relative;top:6px;left:9px}.add-btn{background:none;border:none;font-size:1rem;cursor:pointer;display:flex;align-items:center;width:328px;position:relative;right:123px;background-color:#f1f4f7}.add-btn:hover{color:#3182ce}.text-lg{border:1px solid gray;width:22px;border-radius:5px}.add-varient{display:flex;gap:13px;position:relative;left:101px}input{border:1px solid #ccc;padding:.5rem;border-radius:.25rem;width:100%}.space-y-4{position:relative;left:28px}.flex-items-center{display:flex;position:relative;top:2px;margin-bottom:28px}.input-box-field{width:207px}.text-sm{height:30px}.radio-item{position:relative;left:-5px}.flex-gap{display:flex;gap:18px}.design-footer{display:flex;justify-content:center;gap:30px;background-color:#f1f4f7}.btn{width:110px;color:#fff;margin-top:20px;margin-bottom:20px;background-color:#a5adbc}.btn:hover{background-color:#2196f3;color:#fff}\n"] }]
|
|
474
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.FormBuilderService }], propDecorators: { colorWheel: [{
|
|
475
|
+
type: ViewChild,
|
|
476
|
+
args: ['colorWheel']
|
|
477
|
+
}], selectedElementType: [{
|
|
478
|
+
type: Input
|
|
479
|
+
}] } });
|
|
480
|
+
//# 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\r\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\r\nimport { Component, ElementRef, EventEmitter, Input, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { FormBuilderService } from '../../../services/form-builder.service';\r\n\r\n@Component({\r\n  selector: 'app-properties',\r\n  templateUrl: './properties.component.html',\r\n  styleUrls: ['./properties.component.css']\r\n})\r\nexport class PropertiesComponent implements OnInit {\r\n  // selectedElement: any;\r\n  @ViewChild('colorWheel') colorWheel: ElementRef<HTMLCanvasElement>;\r\n  private ctx: CanvasRenderingContext2D;\r\n\r\n  selectedOption: string = '';\r\n\r\n  selectedElementIndex: number = -1;\r\n  // @Input() selectedElement: any;\r\n  @Input() selectedElementType: string = '';\r\n  selectedAlign: string = 'align-left';  // Add this property\r\n  selectedStyles: string[] = [];  // Using array since multiple styles can be selected\r\n  errorMessage: string = '';\r\n\r\n  selectedElement: any = null;  // Receive the selected element\r\n\r\n\r\n\r\n  onToggleChange(property: string, event: any) {\r\n    const value = event.target.checked;\r\n    if (this.selectedElement) {\r\n      const update = { [property]: value };\r\n      this.formBuilderService.updateElement(this.selectedElementIndex, update);\r\n\r\n      // Update the selected element directly for immediate UI feedback\r\n      this.selectedElement[property] = value;\r\n    }\r\n  }\r\n\r\n\r\n  updateProperties(elementType: string): void {\r\n    // Reset alignment and styles if switching elements\r\n    this.selectedAlign = 'align-left';\r\n    this.selectedStyles = [];\r\n\r\n    // Fetch the properties of the selected element type\r\n    const properties = this.getProperties();\r\n    if (properties) {\r\n      // Make sure the properties are dynamically updated\r\n    }\r\n  }\r\n\r\n  onAlignSelect(value: string): void {\r\n    if (this.selectedElement) {\r\n      this.selectedElement.textAlign = value;\r\n      console.log(`Selected alignment: ${value}`);\r\n    }\r\n  }\r\n\r\n\r\n  onStyleSelect(value: string): void {\r\n    if (!this.selectedElement) return;\r\n\r\n    // Initialize styles array if it doesn't exist\r\n    this.selectedElement.styles = this.selectedElement.styles || [];\r\n\r\n    // Ensure only one style is selected at a time\r\n    this.selectedElement.styles = [value];\r\n\r\n    console.log('Updated styles:', this.selectedElement.styles);\r\n}\r\n\r\n\r\n  isStyleActive(value: string): boolean {\r\n    return this.selectedElement?.styles?.includes(value) || false;\r\n  }\r\n\r\n\r\n  elementProperties = {\r\n\r\n        // Add other element types here similarly\r\n   'Text': {\r\n      elementProps: [\r\n\r\n        // questionText - Label-follow all element properties\r\n        { label: 'Label', placeholder: 'Enter Text ', type: 'text',key: 'questionText' },\r\n\r\n        // question - Placeholder-follow all element properties\r\n        { label: 'placeholder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text ', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n\r\n        // errorMessage - Error Msg-follow all element properties\r\n        { label: 'Error Msg', placeholder: 'Enter Text ', type: 'text',key: 'errorMsg' },\r\n        { label: 'Font', type: 'select',  key: 'font' ,\r\n          options: ['Helvetica Neue', 'Arial', 'Times New Roman', 'Roboto'] },\r\n        { label: 'Weight', type: 'select',key: 'fontWeight',\r\n          options: [\r\n            { value: '400', label: '400-Normal' },\r\n            { value: '500', label: '500-Medium' },\r\n            { value: '600', label: '600-Semi Bold' },\r\n            { value: '700', label: '700-Bold' }\r\n          ] },\r\n        // { label: 'Size', unit: 'PX', type: 'number', key: 'size'  },\r\n        { label: 'Align', type: 'align', key: 'textAlign',\r\n          options: [\r\n            { value: 'left', icon: 'textalign-left' },\r\n            { value: 'center', icon: 'align-center' },\r\n            { value: 'right', icon: 'align-right' },\r\n            { value: 'justifyleft', icon: 'align-justifyleft' },\r\n            { value: 'justifyright', icon: 'align-justifyright' }\r\n\r\n          ] },\r\n        { label: 'Style', type: 'style',key: 'styles',\r\n\r\n          options: [\r\n            { value: 'italic', icon: 'italic' },\r\n            { value: 'bold', icon: 'bold' },\r\n            { value: 'underline', icon: 'underline' },\r\n            { value: 'texticon', icon: 'texticon' },\r\n            { value: 'capitalize', icon: 'capitalize' },\r\n            { value: 'resize', icon: 'resize' }\r\n\r\n\r\n          ] },\r\n          { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' }\r\n\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text ', type: 'text',key: 'defaultValue'  },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text  ', type: 'text' }\r\n      ]\r\n    },\r\n    'CheckBox': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text ', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text ', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text ', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        {\r\n          label: 'Chk Options',\r\n          type: 'optionsGroup',\r\n          key: 'chkOptions',\r\n          options: [\r\n            { label: 'Option 1', value: '', type: 'text', key: 'option1' },\r\n          ],\r\n          addOptionLabel: 'Add Variant', // Text for the plus icon\r\n          icon: 'plus' // Icon for adding options\r\n        },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },\r\n\r\n    'Calendar': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },\r\n    'Time': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'label' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'placeholder'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },\r\n    'Email': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },\r\n      'File': {\r\n        elementProps: [\r\n          { label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },\r\n          { label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },\r\n          { label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },\r\n\r\n          { label: 'Support Type', type: 'select', key: 'supportType', options: [\r\n            { label: 'Images (JPEG, PNG, GIF)', value: 'image/*', extensions: ['.jpg','.jpeg','.png','.gif'] },\r\n            { label: 'Audio (MP3, WAV, AIFF)', value: 'audio/*', extensions: ['.mp3','.wav','.aiff'] },\r\n            { label: 'Video (MP4, AVI, HEVC)', value: 'video/*', extensions: ['.mp4','.avi','.hevc'] },\r\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'] },\r\n            { label: 'Executables (EXE, BAD, SH)', value: 'application/x-msdownload,application/x-sh', extensions: ['.exe','.bad','.sh'] },\r\n            { label: 'Archives (ZIP, RAR, Git-hub)', value: 'application/zip,application/x-rar-compressed,application/x-git', extensions: ['.zip','.rar','.git'] }\r\n          ]},\r\n          { label: '', type: 'toggleGroup' },\r\n          { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n          { label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },\r\n        ],\r\n        fieldProps: [\r\n          { label: 'Field Required', type: 'radio' },\r\n          { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n          { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n          { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n          { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n        ]\r\n      },\r\n      'List': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    }, 'TextArea': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio', key: 'required' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },'Numbers': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },'Dropdown': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        {\r\n          label: 'Chk Options',\r\n          type: 'optionsGroup',\r\n          key: 'chkOptions',\r\n          options: [\r\n            { label: 'Option 1', value: '', type: 'text', key: 'option1' },\r\n          ],\r\n          addOptionLabel: 'Add Variant', // Text for the plus icon\r\n          icon: 'plus' // Icon for adding options\r\n        },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' },\r\n\r\n      ]\r\n    },'Image': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },'Radio': {\r\n  elementProps: [\r\n    { label: 'Label', placeholder: 'Enter Text', type: 'text', key: 'questionText' },\r\n    { label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },\r\n    { label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },\r\n    { label: '', type: 'toggleGroup' },\r\n    { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n    { label: 'Error Msg', placeholder: 'Enter Text', type: 'text', key: 'errorMsg' },\r\n  ],\r\n  fieldProps: [\r\n    { label: 'Field Required', type: 'radio' },\r\n    { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n    {\r\n      label: 'Radio Options', // Updated label to reflect radio context\r\n      type: 'optionsGroup',\r\n      key: 'radioOptions', // Updated key for radio context\r\n      options: [\r\n        { label: 'Option 1', value: '', type: 'text', key: 'option1' },\r\n        { label: 'Option 2', value: '', type: 'text', key: 'option2' },\r\n      ],\r\n      addOptionLabel: 'Add Option', // Updated label for add button\r\n      icon: 'plus', // Icon for adding options\r\n    },\r\n    { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n    { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n    { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' },\r\n  ]\r\n}\r\n,'Book': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },'Button': {\r\n      elementProps: [\r\n        { label: 'Label', placeholder: 'Enter Text', type: 'text',key: 'questionText' },\r\n        { label: 'Place Holder', placeholder: 'Enter Text', type: 'text' , key: 'question'},\r\n        { label: 'Help Text', placeholder: 'Enter Text', type: 'text',key: 'helpText' },\r\n        { label: '', type: 'toggleGroup' },\r\n        { label: 'Field Size', type: 'fieldSize', key: 'fieldSize' },\r\n        { label: 'Error Msg', placeholder: 'Enter Text', type: 'text',key: 'errorMsg' },\r\n      ],\r\n      fieldProps: [\r\n        { label: 'Field Required', type: 'radio' },\r\n        { label: 'Default Value', placeholder: 'Enter Text', type: 'text' },\r\n        { label: 'Reference', placeholder: 'Reference Field', type: 'text' },\r\n        { label: 'Style', placeholder: 'Style JSON', type: 'text' },\r\n        { label: 'Sub Text', placeholder: 'Enter Text', type: 'text' }\r\n      ]\r\n    },\r\n  };\r\n\r\n  constructor(private http: HttpClient,private formBuilderService: FormBuilderService) {}\r\n\r\n\r\n  ngOnInit() {\r\n    this.formBuilderService.selectedElement$.subscribe(index => {\r\n      this.selectedElementIndex = index;\r\n      if (index >= 0) {\r\n        const elements = this.formBuilderService.getElements();\r\n        console.log('Selected element:', elements);\r\n        this.selectedElement = elements[index];\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  validateInput(value: string, type: string): boolean {\r\n    if (type === 'label' || type === 'placeholder') {\r\n      const regex = /^[a-zA-Z0-9\\s]*$/;\r\n      if (!regex.test(value)) {\r\n        this.errorMessage = 'Only letters and numbers are allowed';\r\n        return false;\r\n      }\r\n    }\r\n    this.errorMessage = '';\r\n    return true;\r\n  }\r\n\r\n  updateProperty(key: string, value: any) {\r\n    if (this.selectedElementIndex >= 0) {\r\n      if (key === 'questionText' || key === 'question') {\r\n        if (!this.validateInput(value, key)) {\r\n          return;\r\n        }\r\n      }\r\n\r\n      if (key === 'fontWeight') {\r\n        // Extract just the number value from the option\r\n        value = value.split('-')[0];\r\n      }\r\n      if (key === 'styles') {\r\n        const currentStyles = this.selectedElement.styles || [];\r\n        if (value === 'capitalize' || value === 'lowercase') {\r\n          // Remove the opposite case if it exists\r\n          const oppositeStyle = value === 'capitalize' ? 'lowercase' : 'capitalize';\r\n          const filteredStyles = currentStyles.filter(s => s !== oppositeStyle);\r\n          value = currentStyles.includes(value)\r\n            ? filteredStyles.filter(s => s !== value)\r\n            : [...filteredStyles, value];\r\n        } else {\r\n          // Toggle other styles\r\n          value = currentStyles.includes(value)\r\n            ? currentStyles.filter(s => s !== value)\r\n            : [...currentStyles, value];\r\n        }\r\n      }\r\n\r\n      const update = { [key]: value };\r\n      this.formBuilderService.updateElement(this.selectedElementIndex, update);\r\n\r\n      // Special handling for font and font weight\r\n      if (key === 'font') {\r\n        this.selectedElement.font = value; // Directly update the selected element's font property\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  onRequiredChange(value: boolean) {\r\n    if (this.selectedElement) {\r\n      // Remove any existing asterisks first\r\n      let label = this.selectedElement.label.replace(/\\s*\\*+$/, '');\r\n      if (value) {\r\n        label = `${label} *`; // Add single asterisk\r\n      }\r\n      this.updateProperty('label', label);\r\n      this.updateProperty('required', value);\r\n    }\r\n  }\r\n  getProperties() {\r\n    if (!this.selectedElement) return null;\r\n    return this.elementProperties[this.selectedElement.type];\r\n  }\r\n\r\n  // openColorPicker(propertyKey: string) {\r\n  //   // If you want to use the browser's native color picker:\r\n  //   const input = document.createElement('input');\r\n  //   input.type = 'color';\r\n  //   input.value = this.selectedElement[propertyKey];\r\n  //   input.addEventListener('change', (e: any) => {\r\n  //     this.updateProperty(propertyKey, e.target.value);\r\n  //   });\r\n  //   input.click();\r\n  // }\r\n   // Function to add a new option to prop options\r\n   addOption(options: any[]) {\r\n    options.push({ label: '', value: '' });\r\n  }\r\n// Function to remove an option from prop options\r\nremoveOption(options: any[], index: number) {\r\n    options.splice(index, 1);\r\n  }\r\n  download() {\r\n    console.log('Question Book:', this.formBuilderService.downloadElement());\r\n\r\n  }\r\n  save() {\r\n    const apiURL = 'https://dev-api.rangerfusion.com/nxt/';\r\n    this.http.post(apiURL, this.formBuilderService.downloadElement()).subscribe(\r\n      (response) => {\r\n        console.log('Response:', response);\r\n      },\r\n      (error: HttpErrorResponse) => {\r\n        console.error('Error:', error);\r\n      }\r\n    );\r\n  }\r\n\r\n}\r\n","<!-- AP 22JAN25 - Field and Element Properties -->\r\n<!-- properties.component.html -->\r\n<div class=\"container\">\r\n  <link href=\"https://fonts.googleapis.com/css?family=Roboto:300,400,500&display=swap\" rel=\"stylesheet\">\r\n<!-- Design Header Section -->\r\n<div class=\"design-header\">\r\n  <h1 class=\"header-title\">Element Properties</h1>\r\n  <div class=\"menu-container\">\r\n    <div class=\"menu-item\" (click)=\"download()\">\r\n      <span >Download</span>\r\n    </div>\r\n    <div class=\"menu-item\">\r\n      <span>Start</span>\r\n    </div>\r\n    <div class=\"menu-item\">\r\n      <span>Path</span>\r\n    </div>\r\n    <div class=\"menu-item\">\r\n      <span>Clone</span>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!-- properties.component.html -->\r\n<div class=\"all-properties\">\r\n  <div *ngIf=\"errorMessage\" class=\"error-message\">\r\n      {{ errorMessage }}\r\n    </div>\r\n  <!-- Element Properties -->\r\n  <details class=\"first-properties\" open>\r\n    <summary class=\"text-sm \">Elements Properties</summary>\r\n    <div class=\"inner-content\" *ngIf=\"getProperties()\">\r\n      <ng-container *ngFor=\"let prop of getProperties().elementProps\">\r\n        <div class=\"flex-items-center\">\r\n          <label class=\"text-sm\">{{ prop.label }}</label>\r\n          <div class=\"label-properties\">\r\n            <!-- Text Input -->\r\n            <input *ngIf=\"prop.type === 'text'\"\r\n            type=\"text\"\r\n            [placeholder]=\"prop.placeholder\"\r\n            [value]=\"selectedElement[prop.key]\"\r\n            (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n            [class.read-only]=\"selectedElement.readOnly\"\r\n            [readonly]=\"selectedElement.readOnly\"\r\n            class=\"text-sm1 \"\r\n          />\r\n          <div *ngIf=\"prop.key === 'helpText' && selectedElement.helpText\" class=\"help-text\">\r\n              {{ selectedElement.helpText }}\r\n            </div>\r\n\r\n\r\n         <!-- Font Selection -->\r\n<div *ngIf=\"prop.key === 'font'\" class=\"font-selection\">\r\n  <!-- <label>{{ prop.label }}</label> -->\r\n  <select\r\n  *ngIf=\"prop.type === 'select' && prop.key === 'font'\"\r\n    class=\"font-selection1\"\r\n    [value]=\"selectedElement?.font\"\r\n    (change)=\"updateProperty('font', $event.target.value)\">\r\n    <option *ngFor=\"let option of prop.options\" [value]=\"option\">\r\n      {{ option }}\r\n    </option>\r\n  </select>\r\n</div>\r\n\r\n<!-- file -->\r\n<!-- Add this inside the elementProps loop where other inputs are rendered -->\r\n<select *ngIf=\"prop.type === 'select' && prop.key === 'supportType'\"\r\n class=\"file \"\r\n[value]=\"selectedElement[prop.key]\"\r\n(change)=\"updateProperty(prop.key, $event.target.value)\">\r\n<option value=\"\">Select file category</option>\r\n<option *ngFor=\"let option of prop.options\" [value]=\"option.value\">\r\n{{ option.label }}\r\n</option>\r\n</select>\r\n\r\n<!-- Font Weight Selection -->\r\n<div *ngIf=\"prop.key === 'fontWeight'\" class=\"font-weight\">\r\n  <!-- <label>{{ prop.label }}</label> -->\r\n  <select\r\n  *ngIf=\"prop.type === 'select' && prop.key === 'fontWeight'\"\r\n    class=\"font-weight1 \"\r\n    [value]=\"selectedElement?.fontWeight\"\r\n    (change)=\"updateProperty('fontWeight', $event.target.value)\">\r\n    <option *ngFor=\"let option of prop.options\" [value]=\"option.value\">\r\n      {{ option.label }}\r\n    </option>\r\n  </select>\r\n</div>\r\n\r\n            <!-- Number Input with Unit -->\r\n            <div *ngIf=\"prop.type === 'number'\" class=\"size-controls\">\r\n              <div class=\"size-input-group\">\r\n                  <input\r\n                  type=\"number\"\r\n                  [value]=\"selectedElement[prop.key]\"\r\n                  (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n                  [min]=\"prop.min || 1\"\r\n                  [max]=\"prop.max || 999999\"\r\n                  class=\"size-value\"\r\n                />\r\n                <span class=\"size-unit\">{{ prop.unit }}</span>\r\n              </div>\r\n            </div>\r\n\r\n           <!-- Toggle Group -->\r\n<!-- Toggle Group -->\r\n<div *ngIf=\"prop.type === 'toggleGroup'\" class=\"toggle-group\">\r\n<div class=\"toggle-item1\">\r\n  <span class=\"toggle-label\">Read Only</span>\r\n  <label class=\"switch\">\r\n    <input\r\n      type=\"checkbox\"\r\n      [checked]=\"selectedElement?.readOnly\"\r\n      (change)=\"onToggleChange('readOnly', $event)\"\r\n    />\r\n    <span class=\"slider\"></span>\r\n  </label>\r\n</div>\r\n\r\n<div class=\"toggle-item2\">\r\n  <span class=\"toggle-label\">Is Hide</span>\r\n  <label class=\"switch\">\r\n    <input\r\n      type=\"checkbox\"\r\n      [checked]=\"selectedElement?.isHide\"\r\n      (change)=\"onToggleChange('isHide', $event)\"\r\n    />\r\n    <span class=\"slider\"></span>\r\n  </label>\r\n</div>\r\n</div>\r\n\r\n            <!-- Text Align Buttons -->\r\n            <div *ngIf=\"prop.type === 'align'\"class=\"font-align\">\r\n              <button\r\n                *ngFor=\"let option of prop.options\"\r\n                (click)=\"onAlignSelect(option.value)\"\r\n                [class.active]=\"selectedElement?.textAlign === option.value\"\r\n                class=\"align-btn\"\r\n                [title]=\"option.value\"\r\n              >\r\n                <img\r\n                  [src]=\"'../assets/icons/' + option.icon + '.svg'\"\r\n                  [alt]=\"option.value\"\r\n                  class=\"icon-size\"\r\n                />\r\n              </button>\r\n            </div>\r\n\r\n\r\n            <div *ngIf=\"prop.key === 'size'\" class=\"size-controls\">\r\n              <label>{{ prop.label }}</label>\r\n              <input\r\n                type=\"number\"\r\n                [value]=\"selectedElement[prop.key]\"\r\n                (input)=\"updateProperty(prop.key, $event.target.value)\"\r\n                class=\"size-input\"\r\n              />\r\n              <span class=\"size-unit\">{{ prop.unit }}</span>\r\n            </div>\r\n\r\n\r\n            <div *ngIf=\"prop.type === 'style'\"  class=\"font-style\">\r\n              <button\r\n                *ngFor=\"let option of prop.options\"\r\n                (click)=\"onStyleSelect(option.value)\"\r\n                [class.active]=\"isStyleActive(option.value)\"\r\n                class=\"style-btn\"\r\n                [title]=\"option.value\"\r\n              >\r\n                <img\r\n                  [src]=\"'../assets/icons/' + option.icon + '.svg'\"\r\n                  [alt]=\"option.value\"\r\n                  class=\"icon-size\"\r\n                />\r\n              </button>\r\n            </div>\r\n\r\n<!-- Field Size Controls -->\r\n<div *ngIf=\"prop.key === 'fieldSize'\" class=\"field-size-controls\">\r\n  <div class=\"size-group\">\r\n    <label  class=\"size-label\">Width</label>\r\n    <div class=\"value-container\">\r\n    <input\r\n      type=\"number\"\r\n      [value]=\"selectedElement?.width\"\r\n      (input)=\"updateProperty('width', $event.target.value)\"\r\n      class=\"size-input\"\r\n\r\n    />\r\n    <span class=\"unit\">PX</span>\r\n  </div>\r\n  </div>\r\n\r\n  <div *ngIf=\"prop.key === 'fieldSize'\" class=\"field-size-controls\">\r\n    <div class=\"size-group\">\r\n      <label class=\"size-label\">Height</label>\r\n      <div class=\"value-container\">\r\n        <input\r\n          type=\"number\"\r\n          [value]=\"selectedElement?.height\"\r\n          (input)=\"updateProperty('height', $event.target.value)\"\r\n          class=\"size-input\"\r\n        />\r\n        <span class=\"unit\">PX</span>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n</div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </details>\r\n\r\n  <!-- Field Elements Properties -->\r\n<details class=\"second-property\">\r\n  <summary class=\"text-font-medium\">Field Elements Properties</summary>\r\n  <div class=\"space-y-4\" *ngIf=\"getProperties()\">\r\n    <ng-container *ngFor=\"let prop of getProperties().fieldProps\">\r\n      <div class=\"flex-items-center \">\r\n        <label class=\"text-sm\">{{ prop.label }}</label>\r\n        <div class=\"input-box-field\">\r\n          <!-- Input Box -->\r\n          <input\r\n            *ngIf=\"prop.type === 'text'\"\r\n            type=\"text\"\r\n            [placeholder]=\"prop.placeholder\"\r\n            class=\"field-input\"\r\n          />\r\n          <!-- Radio Group -->\r\n<div *ngIf=\"prop.type === 'radio'\" class=\"radio-item\">\r\n\r\n\r\n      <div class=\"sizes\">\r\n          <div class=\"flex-gap\">\r\n    <div class=\"flex-items\">\r\n      <input\r\n      type=\"radio\"\r\n      [checked]=\"selectedElement.required\"\r\n      (change)=\"onRequiredChange(true)\"\r\n      name=\"required\"\r\n      class=\"radio-input\"\r\n    />\r\n      <label\r\n        class=\"text-label\"\r\n      >\r\n        Required\r\n      </label>\r\n    </div>\r\n    <div class=\"flex-items\">\r\n      <input\r\n      type=\"radio\"\r\n      [checked]=\"!selectedElement.required\"\r\n      (change)=\"onRequiredChange(false)\"\r\n      name=\"required\"\r\n      class=\"radio-input\"\r\n    />\r\n      <label\r\n        class=\"text-sm text-gray-400\"\r\n      >\r\n        Not Required\r\n      </label>\r\n    </div>\r\n  </div>\r\n</div>\r\n</div>\r\n <!-- Chk Options Group -->\r\n <div *ngIf=\"prop.type === 'optionsGroup'\" class=\"options-container\">\r\n  <div\r\n    *ngFor=\"let option of prop.options; let i = index\"\r\n    class=\"option-items\"\r\n  >\r\n    <!-- Option Input -->\r\n    <input\r\n      type=\"text\"\r\n      [(ngModel)]=\"prop.options[i].label\"\r\n      placeholder=\"Option {{ i + 1 }}\"\r\n      class=\"options\"\r\n    />\r\n    <input\r\n      type=\"text\"\r\n      [(ngModel)]=\"prop.options[i].value\"\r\n      placeholder=\"Value\"\r\n      class=\"values\"\r\n    />\r\n    <!-- Remove Button -->\r\n    <div class=\"remove\">\r\n    <img src=\"../assets/icons/Trash.svg\" (click)=\"removeOption(prop.options, i)\"></div>\r\n  </div>\r\n  <!-- Add Button -->\r\n  <button\r\n    type=\"button\"\r\n    class=\"add-btn\"\r\n    (click)=\"addOption(prop.options)\"\r\n  >\r\n  <div class=\"add-varient\">\r\n    <span class=\"text-lg\">+</span>\r\n    <span>Add Variants</span></div>\r\n  </button>\r\n</div>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n  <div class=\"design-footer\">\r\n    <button class=\"btn\">Cancel</button>\r\n    <button class=\"btn\" (click)=\"save()\">Save</button>\r\n  </div>\r\n</details>\r\n</div>\r\n\r\n\r\n</div>\r\n"]}
|