@rangertechnologies/ngnxt 2.1.154 → 2.1.156

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/esm2022/environments/version.mjs +2 -2
  2. package/esm2022/lib/components/custom-button/custom-button.component.mjs +6 -3
  3. package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +6 -3
  4. package/esm2022/lib/components/custom-date/custom-date.component.mjs +10 -5
  5. package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +9 -3
  6. package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +10 -5
  7. package/esm2022/lib/components/custom-input/custom-input.component.mjs +8 -3
  8. package/esm2022/lib/components/custom-label/custom-label.component.mjs +6 -3
  9. package/esm2022/lib/components/custom-model/custom-model.component.mjs +6 -3
  10. package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +6 -3
  11. package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +7 -3
  12. package/esm2022/lib/components/custom-time/custom-time.component.mjs +10 -5
  13. package/esm2022/lib/components/datatable/datatable.component.mjs +2 -2
  14. package/esm2022/lib/components/dependent-table/dependent-table.component.mjs +6 -3
  15. package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +9 -4
  16. package/esm2022/lib/components/file-upload/file-upload.component.mjs +7 -4
  17. package/esm2022/lib/components/file-view/file-view.component.mjs +7 -4
  18. package/esm2022/lib/components/pick-location/pick-location.component.mjs +11 -7
  19. package/esm2022/lib/components/search-box/search-box.component.mjs +8 -3
  20. package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +10 -6
  21. package/esm2022/lib/i18n.pipe.mjs +4 -3
  22. package/esm2022/lib/nxt-app.module.mjs +93 -52
  23. package/esm2022/lib/pages/booklet/booklet.component.mjs +11 -4
  24. package/esm2022/lib/pages/builder/properties/properties.component.mjs +9 -7
  25. package/esm2022/lib/pages/pdfDesigner/pdf-designer/pdf-designer.component.mjs +371 -0
  26. package/esm2022/lib/pages/pdfDesigner/pdf-properties/pdf-properties.component.mjs +964 -0
  27. package/esm2022/lib/pages/questionbook/questionbook.component.mjs +33 -28
  28. package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +20 -15
  29. package/esm2022/lib/pages/summary-page/summary-page.component.mjs +8 -5
  30. package/esm2022/lib/services/pdf-designer.service.mjs +366 -0
  31. package/esm2022/public-api.mjs +4 -1
  32. package/fesm2022/rangertechnologies-ngnxt.mjs +7734 -5972
  33. package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
  34. package/lib/components/custom-button/custom-button.component.d.ts +1 -1
  35. package/lib/components/custom-calendar/custom-calendar.component.d.ts +1 -1
  36. package/lib/components/custom-date/custom-date.component.d.ts +1 -1
  37. package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +1 -1
  38. package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +1 -1
  39. package/lib/components/custom-input/custom-input.component.d.ts +1 -1
  40. package/lib/components/custom-label/custom-label.component.d.ts +1 -1
  41. package/lib/components/custom-model/custom-model.component.d.ts +1 -1
  42. package/lib/components/custom-radio/custom-radio.component.d.ts +1 -1
  43. package/lib/components/custom-text-area/custom-text-area.component.d.ts +1 -1
  44. package/lib/components/custom-time/custom-time.component.d.ts +1 -1
  45. package/lib/components/dependent-table/dependent-table.component.d.ts +1 -1
  46. package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +1 -1
  47. package/lib/components/file-upload/file-upload.component.d.ts +1 -1
  48. package/lib/components/file-view/file-view.component.d.ts +1 -1
  49. package/lib/components/pick-location/pick-location.component.d.ts +1 -1
  50. package/lib/components/search-box/search-box.component.d.ts +1 -1
  51. package/lib/components/table-appendix/table-appendix.component.d.ts +1 -1
  52. package/lib/i18n.pipe.d.ts +1 -1
  53. package/lib/nxt-app.module.d.ts +43 -41
  54. package/lib/pages/booklet/booklet.component.d.ts +1 -1
  55. package/lib/pages/pdfDesigner/pdf-designer/pdf-designer.component.d.ts +60 -0
  56. package/lib/pages/pdfDesigner/pdf-properties/pdf-properties.component.d.ts +596 -0
  57. package/lib/pages/questionbook/questionbook.component.d.ts +1 -1
  58. package/lib/pages/questionnaire/questionnaire.component.d.ts +1 -1
  59. package/lib/pages/summary-page/summary-page.component.d.ts +1 -1
  60. package/lib/services/pdf-designer.service.d.ts +66 -0
  61. package/package.json +1 -1
  62. package/public-api.d.ts +2 -0
  63. package/rangertechnologies-ngnxt-2.1.156.tgz +0 -0
  64. package/rangertechnologies-ngnxt-2.1.154.tgz +0 -0
@@ -0,0 +1,371 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { VERSION } from '../../../../environments/version';
3
+ import { PdfPropertiesComponent } from '../pdf-properties/pdf-properties.component';
4
+ import { CommonModule } from '@angular/common';
5
+ import { MatTooltipModule } from '@angular/material/tooltip';
6
+ import { FormsModule } from '@angular/forms';
7
+ import { NxtDatatable } from '../../../components/datatable/datatable.component';
8
+ import { BookletComponent } from '../../booklet/booklet.component';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../../services/pdf-designer.service";
11
+ import * as i2 from "@angular/common";
12
+ import * as i3 from "@angular/material/tooltip";
13
+ import * as i4 from "@angular/forms";
14
+ export class PdfDesignerComponent {
15
+ pdfDesignerService;
16
+ //@Output() elementButtonClicked = new EventEmitter<string>();
17
+ pdfJSON;
18
+ bookletId;
19
+ templateMode = new EventEmitter();
20
+ field;
21
+ pdfElements = [];
22
+ elements = [];
23
+ bookId;
24
+ sections = {
25
+ basic: true, // Basic Elements open by default
26
+ advanced: true // Advanced Elements closed by default
27
+ };
28
+ elementsList = [];
29
+ elementDisabledArray;
30
+ version = VERSION.version; //SKS10MAR25 get version from environment/version.ts
31
+ pdf;
32
+ selectedElement = null;
33
+ isSelectTablePopup = false;
34
+ currentType;
35
+ addTable = true;
36
+ dots = Array(6);
37
+ draggedIndex = null;
38
+ templateSelected = false;
39
+ //subscription: any;
40
+ constructor(pdfDesignerService) {
41
+ this.pdfDesignerService = pdfDesignerService;
42
+ }
43
+ // AP-06MAR25 New Design Change Elements Basic , Advanced
44
+ // AP-06MAR25 Add RichText Area
45
+ // AP-12MAR25 Add Date
46
+ ngOnInit() {
47
+ this.elementsList = [
48
+ { "type": "text", "img": "Text", "label": "Text" },
49
+ { "type": "image", "img": "Image", "label": "Image" },
50
+ { "type": "Line", "img": "line", "label": "Line" },
51
+ { "type": "Space", "img": "space", "label": "Space" },
52
+ { "type": "Table", "img": "Table", "label": "Table" },
53
+ { "type": "Pdf", "img": "Search", "label": "Pdf" },
54
+ ];
55
+ this.elementDisabledArray = {
56
+ Table: [
57
+ 'Pdf', 'Calendar', "Boolean", 'List', 'Table', 'Checkbox', 'Radio',
58
+ 'Dropdown', 'RichTextArea', 'Number', 'Label', 'image',
59
+ 'Email', 'Date', 'Time', 'DateTime', 'Line', 'Space'
60
+ ]
61
+ };
62
+ this.pdfDesignerService.pdfElements$.subscribe(elements => {
63
+ setTimeout(() => {
64
+ this.pdfElements = elements.map(field => ({ ...field }));
65
+ }, 0);
66
+ });
67
+ if (this.pdfJSON && (this.pdfJSON !== '')) {
68
+ this.initializeForm();
69
+ }
70
+ else {
71
+ this.pdfDesignerService.newBook();
72
+ }
73
+ // AP-12MAR25 - Added to handle bookletId
74
+ if (this.bookletId) {
75
+ localStorage.setItem('unique_id', this.bookletId);
76
+ }
77
+ this.pdf = this.pdfDesignerService.getBook();
78
+ this.pdfDesignerService.selectedElement$.subscribe(index => {
79
+ const elements = this.pdfDesignerService.getElements();
80
+ if (index >= 0) {
81
+ this.selectedElement = elements[index];
82
+ }
83
+ // this.pdfElements = [...elements]
84
+ });
85
+ this.pdfDesignerService.addElementWithId();
86
+ }
87
+ isSectionOpen(section) {
88
+ return this.sections[section];
89
+ }
90
+ // AP - 26FEB25 - Added ngOnChanges to handle changes in pdfJSON
91
+ ngOnChanges(changes) {
92
+ if (changes['pdfJSON'] && changes['pdfJSON'].currentValue) {
93
+ if (this.pdfJSON && (this.pdfJSON !== '')) {
94
+ this.initializeForm();
95
+ }
96
+ else {
97
+ this.pdfDesignerService.newBook();
98
+ }
99
+ }
100
+ }
101
+ // AP-08APR25 Template is selected, update form elements and emit template mode
102
+ onTemplateSelected(event) {
103
+ this.pdfDesignerService.clearElements();
104
+ event.elements.forEach(el => this.pdfDesignerService.addElement(el));
105
+ // Emit template mode to parent
106
+ this.templateMode.emit(true);
107
+ }
108
+ initializeForm() {
109
+ if (!this.pdfJSON || !this.pdfJSON) {
110
+ console.warn("Invalid pdfJSON structure");
111
+ return;
112
+ }
113
+ this.pdfElements = [];
114
+ this.pdfDesignerService.clearElements();
115
+ this.pdfDesignerService.intializeBook(this.pdfJSON);
116
+ const pdfMapKey = Object.keys(this.pdfJSON)[0];
117
+ const pdfArray = this.pdfJSON[pdfMapKey];
118
+ if (Array.isArray(pdfArray)) {
119
+ pdfArray.forEach((subQuestion) => {
120
+ // AP-04APR24 If subQuestion.style exists as a string and is empty, replace it with a default style object
121
+ if (typeof subQuestion.style === "string" && subQuestion.style.trim() === "") {
122
+ subQuestion.style = {
123
+ "labelClass": null,
124
+ "labelStyle": null,
125
+ "labelValueStyle": null,
126
+ "inputClass": null,
127
+ "inputStyle": null,
128
+ "bookStyle": null,
129
+ "direction": "ltr",
130
+ "questionStyle": null
131
+ };
132
+ }
133
+ });
134
+ }
135
+ this.pdfElements = this.pdfDesignerService.getElements();
136
+ }
137
+ // Add this method to handle element selection
138
+ selectElement(index) {
139
+ this.selectedFieldIndex = index; // element is selected
140
+ this.pdfDesignerService.setSelectedElement(index);
141
+ this.pdf = this.pdfDesignerService.getBook();
142
+ //const element = this.pdfElements[index];
143
+ // this.elementButtonClicked.emit(element.type);
144
+ }
145
+ //selectedIndex: number | null = null;
146
+ selectedFieldIndex = null; // element is cleared
147
+ selectHeading(event) {
148
+ this.pdfDesignerService.selectHeading(event); //AP-10MAR25 Updates the selected heading in the service
149
+ this.pdf = this.pdfDesignerService.getBook(); //AP-10MAR25 Retrieves the updated pdf/form data
150
+ }
151
+ // AP-17APR25 generateUiId
152
+ generateUiId() {
153
+ return this.pdfDesignerService.addElementWithId();
154
+ }
155
+ addElement(type) {
156
+ const unique_id = this.generateUiId();
157
+ this.currentType = type;
158
+ if (this.selectedElement?.type === 'Table' && this.addTable) {
159
+ this.isSelectTablePopup = true;
160
+ }
161
+ else {
162
+ const newElement = {
163
+ id: unique_id,
164
+ type,
165
+ margin: [0, 0, 0, 0],
166
+ fontSize: 14,
167
+ fontWeight: '400',
168
+ fontStyle: [],
169
+ alignItems: 'center',
170
+ referenceField: null,
171
+ question: null,
172
+ questionNumber: this.pdfDesignerService.getElements().length + 1,
173
+ fieldsMeta: [],
174
+ pdfReference: null,
175
+ pdfReferenceQuestions: null,
176
+ style: {
177
+ labelClass: null,
178
+ labelStyle: null,
179
+ labelValueStyle: null,
180
+ inputClass: null,
181
+ inputStyle: null,
182
+ bookStyle: null,
183
+ direction: 'ltr',
184
+ questionStyle: null,
185
+ },
186
+ imageData: null,
187
+ imageSize: type === 'image' ? { width: 150, height: 150 } : null,
188
+ tableConfig: type === 'Table' ? {
189
+ isNosIndicator: false,
190
+ addInlineRecord: true,
191
+ isPagination: false,
192
+ actionButton: false,
193
+ isDeleteRow: true,
194
+ isEditRow: false,
195
+ searchBar: false,
196
+ isButtons: false,
197
+ } : null,
198
+ width: 100,
199
+ styleClass: unique_id,
200
+ };
201
+ this.pdfDesignerService.addElement(newElement);
202
+ this.pdfElements = this.pdfDesignerService.getElements();
203
+ this.addTable = true;
204
+ }
205
+ }
206
+ onQuestionChange(value, index) {
207
+ console.log("onQuestionChange", value, index);
208
+ // Update the local field first
209
+ this.pdfElements[index].question = value;
210
+ // Update the service with the new question value
211
+ this.pdfDesignerService.elementUpdate(index, this.pdfElements[index]);
212
+ }
213
+ // Remove an element by index
214
+ removeElement(field, index) {
215
+ this.pdfDesignerService.removeElementComponent(field.id);
216
+ this.pdfElements = this.pdfDesignerService.getElements();
217
+ }
218
+ onDragStart(event, index) {
219
+ this.draggedIndex = index;
220
+ event.dataTransfer?.setData('text/plain', index.toString());
221
+ }
222
+ // Allow dropping by preventing default
223
+ onDragOver(event, index) {
224
+ event.preventDefault();
225
+ }
226
+ // Handle drop event
227
+ onDrop(event, dropIndex) {
228
+ event.preventDefault();
229
+ if (this.draggedIndex === null || this.draggedIndex === dropIndex)
230
+ return;
231
+ const draggedItem = this.pdfElements[this.draggedIndex];
232
+ // Remove dragged item from old position and insert it in new position
233
+ this.pdfElements.splice(this.draggedIndex, 1);
234
+ this.pdfElements.splice(dropIndex, 0, draggedItem);
235
+ //AP-28MAR25 Update questionNumber dynamically based on new order
236
+ this.pdfElements.forEach((element, index) => {
237
+ element.questionNumber = index + 1;
238
+ });
239
+ // Reset dragged index
240
+ this.draggedIndex = null;
241
+ // Notify service about the update
242
+ this.pdfDesignerService.updateElementsOrder(this.pdfElements);
243
+ }
244
+ toggleBoolean(field) {
245
+ field.boolean = !field.boolean;
246
+ }
247
+ getFontStyles(field) {
248
+ const margin = field.margin || [0, 0, 0, 0]; // [left, top, right, bottom]
249
+ const fontStyles = field.fontStyle || [];
250
+ return {
251
+ 'font-family': field.font || 'Helvetica Neue',
252
+ //'font-weight': field.fontWeight || '400',
253
+ 'font-size': field.fontSize ? `${field.fontSize}px` : '14px',
254
+ 'width': field.width ? `${field.width}%` : '100%',
255
+ //'text-align': field.textAlign || 'left',
256
+ 'align-items': field.alignItems || 'center',
257
+ 'border-radius': '5px',
258
+ 'border-width': field.lineWidth ? `${field.lineWidth}px` : '1px',
259
+ 'color': field.fontColor || '#000000',
260
+ 'font-style': fontStyles.includes('italic') ? 'italic' : 'normal',
261
+ 'font-weight': fontStyles.includes('bold') ? 'bold' : (field.fontWeight || '400'),
262
+ 'margin': `${margin[0]}px ${margin[1]}px ${margin[2]}px ${margin[3]}px`,
263
+ 'padding-top': field.paddingTop ? `${field.paddingTop}px` : '0px',
264
+ 'padding-bottom': field.paddingBottom ? `${field.paddingBottom}px` : '10px',
265
+ };
266
+ }
267
+ getLineStyles(field) {
268
+ const styles = {
269
+ 'font-family': field.font || 'Helvetica Neue',
270
+ 'font-weight': field.fontWeight || '400',
271
+ 'font-size': field.fontSize || '14px',
272
+ 'width': field.width ? `${field.width}%` : '100%',
273
+ 'text-align': field.textAlign || 'left',
274
+ 'border-radius': '5px',
275
+ 'border-width': field.lineWidth ? `${field.lineWidth}px` : '1px',
276
+ 'border-style': field.lineStyle?.toLowerCase() || 'solid',
277
+ 'color': field.fontColor || '#000000',
278
+ //'border-color': field.color || '#EFF8FF',
279
+ 'margin-top': field.paddingTop ? `${field.paddingTop}px` : '0px',
280
+ 'margin-bottom': field.paddingBottom ? `${field.paddingBottom}px` : '10px'
281
+ };
282
+ return styles;
283
+ }
284
+ // SKS13MAR25 table popup conformation based element add
285
+ onClose() {
286
+ this.isSelectTablePopup = false;
287
+ this.addTable = false;
288
+ this.addElement(this.currentType);
289
+ }
290
+ // SKS13MAR25 column element add inside a table
291
+ addOnTable() {
292
+ this.addTable = true;
293
+ this.isSelectTablePopup = false;
294
+ const elements = [...this.pdfDesignerService.getElements()];
295
+ // Find the element and update its columns
296
+ const index = elements.findIndex(el => el.id === this.selectedElement.id);
297
+ const rowNum = this.pdfElements[index].columns ? this.pdfElements[index].columns?.length : 0;
298
+ const unique_id = this.generateUiId();
299
+ const tableElement = {
300
+ label: `HEADER LABEL ${rowNum}`,
301
+ fieldName: `FIELD NAME${rowNum}`,
302
+ type: this.currentType,
303
+ id: unique_id
304
+ };
305
+ this.pdfDesignerService.addTableElement(tableElement, this.selectedFieldIndex);
306
+ this.pdfElements = this.pdfDesignerService.getElements();
307
+ // this.addTableData(unique_id, fieldName)
308
+ }
309
+ addTableData(fieldId, fieldName) {
310
+ // this.pdfDesignerService.addTablefieldData(tableElement);
311
+ }
312
+ columnSelected(event) {
313
+ // console.log(event)
314
+ // SKS19MAR25 table column update
315
+ this.pdfDesignerService.setSelectedTableElement(this.selectedFieldIndex, event);
316
+ }
317
+ removeColumn(event) {
318
+ // console.log(event)
319
+ this.pdfDesignerService.removeSelectedTableElement(this.selectedFieldIndex, event);
320
+ }
321
+ // SKS25MAR25 image add
322
+ async fileChangeEvent(index, event) {
323
+ const file = event.target.files[0];
324
+ if (file) {
325
+ try {
326
+ const imageData = await this.readFileAsDataURL(file);
327
+ this.pdfElements[index].imageData = imageData;
328
+ this.pdfElements[index].orgImageData = imageData;
329
+ // Initialize logo size if not already set
330
+ if (!this.pdfElements[index].imageSize) {
331
+ this.pdfElements[index].imageSize = { width: 150, height: 150 };
332
+ }
333
+ await this.pdfDesignerService.elementUpdate(index, this.pdfElements[index]);
334
+ }
335
+ catch (error) {
336
+ console.error("Error reading file:", error);
337
+ }
338
+ }
339
+ }
340
+ readFileAsDataURL(file) {
341
+ return new Promise((resolve, reject) => {
342
+ const reader = new FileReader();
343
+ reader.onload = () => resolve(reader.result);
344
+ reader.onerror = (error) => reject(error);
345
+ reader.readAsDataURL(file);
346
+ });
347
+ }
348
+ // SKS2APR25 disabled element
349
+ isElementDisabled(elementType) {
350
+ if (this.selectedElement) {
351
+ const elements = this.elementDisabledArray[this.selectedElement.type];
352
+ if (elements) {
353
+ return elements.includes(elementType);
354
+ }
355
+ }
356
+ return false;
357
+ }
358
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PdfDesignerComponent, deps: [{ token: i1.PdfDesignerService }], target: i0.ɵɵFactoryTarget.Component });
359
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PdfDesignerComponent, isStandalone: true, selector: "app-pdf-designer", inputs: { pdfJSON: "pdfJSON", bookletId: "bookletId" }, outputs: { templateMode: "templateMode" }, usesOnChanges: true, ngImport: i0, template: "<!-- AP 22JAN25 - form preview and All form elements -->\n<!-- AP 25FEB25 - All elements update -->\n<div class=\"form-container\">\n <div class=\"center-frame\">\n <!-- Form Builder Section All Elements -->\n <div class=\"form-builder\">\n\n <ng-container *ngFor=\"let element of elementsList\">\n <div class=\"element\" [class.disabled]=\"isElementDisabled(element.type)\"\n (click)=\"!isElementDisabled(element.type) && addElement(element.type)\"\n [draggable]=\"!isElementDisabled(element.type)\"\n [matTooltip]=\"isElementDisabled(element.type) ? 'This element is not supported when a ' + (selectedElement?.type || 'certain element') + ' is present' : null\">\n <img src=\"../assets/icons/{{ element.img }}.svg\" class=\"element-icon\">\n <div class=\"hover-label\">{{ element.label }}</div>\n <div class=\"drag-dots\">\n <div class=\"dot\" *ngFor=\"let dot of dots\"></div>\n </div>\n </div>\n </ng-container>\n\n <!-- <div class=\"template-section\">\n <app-templates (templateSelected)=\"onTemplateSelected($event)\"></app-templates>\n </div> -->\n\n <!-- SKS10MAR25 footer version show -->\n <div class=\"sticky-footer-version\">\n {{version}}\n </div>\n </div>\n <!-- AP-27MAR25 Remove CDK drag and drop replace draggable function -->\n <div class=\"form-preview\">\n <!-- AP-10MAR25 Heading -->\n <div class=\"field-container\"\n style=\"width: 100%;background-color: #EFF8FF; border: 1px solid #E6F3FF;display: flex;justify-content: center;margin-bottom:10px\"\n (click)=\"selectHeading('Header')\">\n <div class=\"label-container\" style=\"padding: 10px;\">\n <div *ngIf=\"pdf\">\n <div *ngIf=\"pdf.title == ''\" style=\"color:#3f4a525c\">Heading</div>\n <div *ngIf=\"pdf.title !== ''\">{{pdf.title}}</div>\n </div>\n </div>\n </div>\n\n <ng-container *ngFor=\"let field of pdfElements; let i = index\" getProperties().elementProps>\n \n <!-- AP-19MAR25 Line Element -->\n <div *ngIf=\"field?.type === 'Line'\" class=\"line-field\" (click)=\"selectElement(i)\"\n [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\" (dragstart)=\"onDragStart($event, i)\"\n (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"line-element\">\n <div></div>\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n <hr class=\"custom-line\" style=\"display: inline-flex\" [ngStyle]=\"getLineStyles(field)\" />\n </div>\n\n <!--SKS25MAR25 Image Upload Element -->\n <div *ngIf=\"field?.type === 'image'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\" (dragstart)=\"onDragStart($event, i)\"\n (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\" [ngStyle]=\"getFontStyles(field)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <div>\n <div class=\"logo-container\">\n <!-- Logo preview area -->\n <div class=\"logo-preview\" *ngIf=\"field.imageData\">\n <img [src]=\"field.imageData\" />\n </div>\n\n <!-- Upload button -->\n <div *ngIf=\"!field.imageData\" class=\"logo-upload-placeholder\">\n <label for=\"logo-upload-{{i}}\" class=\"logo-upload-label\">\n <img src=\"../assets/icons/Image.svg\" alt=\"Upload\" />\n <span>Upload Image</span>\n </label>\n <input type=\"file\" id=\"logo-upload-{{i}}\" accept=\"image/*\" (change)=\"fileChangeEvent(i, $event)\"\n style=\"display: none;\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Space Element -->\n <div *ngIf=\"field?.type === 'Space'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\" style=\"height:93px\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\" style=\"margin: -11px -11px 0 0;\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Boolean Element -->\n <div *ngIf=\"field?.type === 'Boolean'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"checkbox\" [checked]=\"field.boolean\" (change)=\"toggleBoolean(field)\"\n [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n\n <!-- Calendar -->\n <div *ngIf=\"field?.type === 'Calendar'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n\n </div>\n <input type=\"date\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- AP -12MAR25 Date -->\n <div *ngIf=\"field?.type === 'Date'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n\n </div>\n <input type=\"date\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- AP-21MAR25 Add Time element -->\n <!-- Time Field -->\n <div *ngIf=\"field?.type === 'Time'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"time\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- AP-28MAR25 DateTime -->\n <div *ngIf=\"field?.type === 'DateTime'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"datetime-local\" class=\"custom-input\" />\n </div>\n </div>\n </div>\n\n <!-- Email -->\n <div *ngIf=\"field?.type === 'Email'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"email\" class=\"custom-input\" [placeholder]=\"'Enter email'\"\n [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- Numbers -->\n <div *ngIf=\"field?.type === 'Number'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"number\" class=\"custom-input\" [placeholder]=\"'Enter number'\"\n [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- TextArea -->\n <div *ngIf=\"field?.type === 'text'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <textarea class=\"custom-textarea\" [placeholder]=\"'Enter detailed text here...'\"[(ngModel)]=\"field.question\" \n (ngModelChange)=\"onQuestionChange($event, i)\"[style.height.px]=\"field.size || 100\"></textarea>\n </div>\n </div>\n </div>\n\n <!-- Label -->\n <div *ngIf=\"field?.type === 'Label'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Pdf -->\n <div *ngIf=\"field?.type === 'Pdf'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <!-- <lib-booklet [bookletJSON]=\"field.pdfReferenceQuestions\"></lib-booklet> -->\n <div *ngIf=\"field?.pdfReferenceQuestions\">\n <ng-container *ngFor=\"let field of field?.pdfReferenceQuestions[field?.pdfReference]; let i = index\">\n <!-- AP-19MAR25 Line Element -->\n <div *ngIf=\"field?.type === 'Line'\" class=\"line-field\">\n <hr class=\"custom-line\" style=\"display: inline-flex\" [ngStyle]=\"getLineStyles(field)\" />\n </div>\n\n <div *ngIf=\"field?.type === 'image'\" class=\"field-container\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div>\n <div class=\"logo-container\">\n <!-- Logo preview area -->\n <div class=\"logo-preview\" *ngIf=\"field.imageData\">\n <img [src]=\"field.imageData\" />\n </div>\n\n <!-- Upload button -->\n <div *ngIf=\"!field.imageData\" class=\"logo-upload-placeholder\">\n <label for=\"logo-upload-{{i}}\" class=\"logo-upload-label\">\n <img src=\"../assets/icons/Image.svg\" alt=\"Upload\" />\n <span>Upload Image</span>\n </label>\n <input type=\"file\" id=\"logo-upload-{{i}}\" accept=\"image/*\"\n (change)=\"fileChangeEvent(i, $event)\" style=\"display: none;\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"field?.type === 'Space'\" class=\"field-container\">\n <div class=\"field-wrapper\" style=\"height:93px\">\n </div>\n </div>\n <div *ngIf=\"field?.type === 'text'\" class=\"field-container\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <textarea class=\"custom-textarea\" [placeholder]=\"'Enter detailed text here...'\"\n [style.height.px]=\"field.size || 100\" [value]=\"field.value ? field.value : ''\"></textarea>\n </div>\n </div>\n </div>\n <!-- AP-06MAR25 -->\n <div *ngIf=\"field?.type === 'Table'\" class=\"field-container\">\n <div class=\"field-wrapper\" style=\"overflow: hidden;\">\n <div class=\"field-content\">\n <div class=\"nxt-table-container\">\n <nxt-datatable isButtons [question]=\"field\" from=\"formBuilder\" [apiMeta]=\"field?.subText\"\n [tableConfig]=\"field.tableConfig\" tableId=\"\" direction=\"ltr\" tableWidth=\"auto\"\n isEditable=true (columnSelected)=columnSelected($event) (removeColumn)=removeColumn($event)>\n </nxt-datatable>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n\n <!-- File -->\n <div *ngIf=\"field?.type === 'File'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"file\" class=\"custom-input\" />\n </div>\n </div>\n </div>\n\n <!-- CheckBox -->\n <div *ngIf=\"field?.type === 'Checkbox'\" class=\"checkbox-field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n\n <div class=\"checkbox-options-container\">\n <div *ngFor=\"let option of field.options\" class=\"checkbox-option\">\n <input type=\"checkbox\" [id]=\"option.value + i\" [name]=\"field.id\" [value]=\"option.value || field.value\"\n class=\"checkbox-input\">\n <label [for]=\"option.value + i\" class=\"checkbox-label\">{{ option.value }}</label>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Radio -->\n <div *ngIf=\"field?.type === 'Radio'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <div class=\"radio-options-container\">\n <div *ngFor=\"let option of field.options; let j = index\" class=\"radio-option\">\n <input type=\"radio\" [id]=\"'radio-' + field.id + '-' + j\" [name]=\"'radio-group-' + field.id\"\n [value]=\"option.value || field.value\" [(ngModel)]=\"field.selectedValue\" class=\"radio-input\">\n <label [for]=\"'radio-' + field.id + '-' + j\" class=\"radio-label\"> {{ option.value }}</label>\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- Dropdown -->\n <div *ngIf=\"field?.type === 'Dropdown'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <select id=\"options\" class=\"dropdown\">\n <option *ngFor=\"let option of field.options\" [value]=\"option.value || field.value\"> {{ option.value\n }} </option>\n </select>\n </div>\n </div>\n </div>\n\n <!-- Table -->\n <!-- AP-06MAR25 -->\n <div *ngIf=\"field?.type === 'Table'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\" style=\"overflow: hidden;\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <div class=\"nxt-table-container\">\n <nxt-datatable isButtons [question]=\"field\" from=\"formBuilder\" [apiMeta]=\"field?.subText\"\n [tableConfig]=\"field.tableConfig\" tableId=\"\" direction=\"ltr\" tableWidth=\"auto\" isEditable=true\n (columnSelected)=columnSelected($event) (removeColumn)=removeColumn($event)>\n </nxt-datatable>\n </div>\n </div>\n </div>\n </div>\n\n <!-- List -->\n <!-- AP-06MAR25 - List data show-->\n <div *ngIf=\"field?.type === 'List'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"text\" class=\"custom-input\" placeholder=\"Search...\"\n [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n <!-- SKS13MAR25 popup conformation box -->\n <div class=\"dialog-overlay\" *ngIf=\"isSelectTablePopup\">\n <div class=\"dialog-box\">\n <button class=\"close-btn-fb\" (click)=\"onClose()\">\u2715</button>\n <p>These element want to add a table</p>\n <div class=\"button-container-fb\">\n <button class=\"yes-btn-fb\" (click)=\"addOnTable()\">Yes</button>\n <button class=\"no-btn-fb\" (click)=\"onClose()\">No</button>\n </div>\n </div>\n </div>\n <app-pdf-properties></app-pdf-properties>\n</div>", styles: [".center-frame{display:flex;border-right-width:0}.head-elements{font-size:17px;font-weight:600}.form-builder{width:33.33%;height:calc(100vh - 20px);overflow-y:auto;background-color:#fff;padding:10px;border-right:10px solid #86A8CD;box-shadow:2px 2px 10px #0000001a}.form-builder .element{display:flex;align-items:center;gap:15px;margin-top:10px;padding:10px;border-radius:5px;background:#f8fafc;cursor:pointer;border-left:10px solid #E2F1FF;position:relative;color:#000}.form-builder .element:hover{background:#0250d9;color:#fff;border-left:10px solid #234465}.form-builder .element img{width:20px;height:20px;transition:filter .3s ease}.form-builder .element:hover img{filter:invert(1)}.form-builder .hover-label{font-size:15px;font-weight:400;color:#000;transition:color .3s ease}.form-builder .element:hover .hover-label{color:#fff}.form-builder .section-title{font-weight:700;font-size:16px;margin-top:10px;padding:5px;border-bottom:1px solid #ddd;color:#000;display:flex;justify-content:space-between;align-items:center}.form-builder .section-title:after{content:\"\\25bc\";font-size:12px;color:#555}.form-builder .section{margin-bottom:10px}.toggle-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:10px}.arrow-icon{width:19px;height:23px;transition:transform .3s ease}.toggle-header:hover .arrow-icon{transform:scale(1.1)}.drag-dots{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,1fr);gap:3px;position:absolute;right:15px;top:50%;transform:translateY(-50%)}.dot{width:5px;height:5px;border-radius:50%;background-color:#cbd5e1;transition:background-color .3s ease}.form-builder .element:hover .dot{background-color:#ffffffb3}.field-wrapper{background-color:#eff8ff;border:1px solid #E6F3FF;border-radius:5px;padding:10px}.required:after{content:\"*\";color:red;margin-left:5px}.custom-input{width:100%;padding:8px;border:1px solid #DDDBDA;background-color:#fff;border-radius:5px;outline:none}.custom-input:focus{border-color:#00008b;box-shadow:0 0 5px #0000ff80}.delete-icon{width:19px;height:19px;margin-top:-5px}.field-container{padding-right:5px;padding-left:5px;transition:background .2s}.field-container:hover .top-right,.field-container.highlight .top-right,.label-container:hover .delete-icon{opacity:1;visibility:visible}.form-preview{width:100%;height:calc(100vh - 20px);overflow-y:auto;display:flex;flex-wrap:wrap;align-items:flex-start;padding:10px;height:fit-content;max-height:calc(100vh - 20px)}.field-content{display:flex;flex-direction:column;gap:5px}.label-container{display:flex;justify-content:flex-end;align-items:center}.top-right{display:flex;gap:10px;padding:6px;border:1px solid #d7edff;margin-top:-10px;background-color:#d7edff;margin-right:-10px;opacity:0;visibility:hidden;cursor:grab;transition:opacity .1s ease-in-out,visibility .1s ease-in-out}.drag-dot{height:13px}.custom-input,.custom-textarea,.dropdown,.checkbox-options-container,.radio-options-container{width:100%}.form-builder .element .drag-dots:active{cursor:grabbing}.dropdown{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;background-color:#fff;font-size:14px;color:#333;outline:none;cursor:pointer}.dropdown:focus{border-color:#007bff;box-shadow:0 0 5px #007bff80}.line-field{width:100%;margin:10px 0;background-color:#eff8ff;border:1px solid #E6F3FF;border-radius:5px;padding:3px}.checkbox-field-container:hover{box-shadow:0 2px 8px #0000001a}.checkbox-options-container{display:flex;flex-direction:column;gap:5px;padding:8px;min-height:38px;border:1px solid #DDDBDA;background-color:#fff;outline:none;border-radius:6px}.checkbox-option,.radio-option{display:flex;align-items:center;gap:8px;padding:8px;background-color:#fff;border-radius:4px;transition:background-color .2s ease}.checkbox-option:hover{background-color:#f1f3f5}.checkbox-input,.radio-input{width:18px;height:18px;accent-color:#4dabf7;cursor:pointer}.checkbox-label,.radio-label{font-size:14px;color:#495057;cursor:pointer;-webkit-user-select:none;user-select:none}.label-container label{font-size:15px;font-weight:400}.required:after{content:\" *\";color:red}.radio-options-container{display:flex;flex-direction:column;gap:5px;padding:8px;min-height:38px;border:1px solid #DDDBDA;background-color:#fff;outline:none;border-radius:6px}.radio-input:checked{border-color:#007bff;background-color:#007bff}.radio-input:checked:after{content:\"\";width:8px;height:8px;background:#fff;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.custom-textarea{width:100%;min-height:100px;border:1px solid #ccc;border-radius:4px;padding:8px;resize:vertical}.highlight{border:2px solid #5592FD!important;background-color:#eff8ff}.table-container label{font-size:14px;font-weight:700;margin-bottom:5px;display:block}.sticky-footer-version{position:fixed;bottom:0;padding:10px;text-align:center}.nxt-table-container{display:flex;justify-content:center;align-items:center;width:100%}nxt-datatable{width:100%!important;table-layout:fixed;max-width:100%}.dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.dialog-box{background:#fff;padding:20px;border-radius:5px;text-align:center;width:300px;position:relative}.close-btn-fb{position:absolute;top:4px;right:4px;background:#ff4242;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:10px;cursor:pointer}.button-container-fb{display:flex;justify-content:flex-end;gap:10px}.yes-btn-fb{background:green;color:#fff;border:none;padding:0 12px;border-radius:5px;cursor:pointer}.no-btn-fb{background:gray;color:#fff;border:none;padding:8px 15px;border-radius:5px;cursor:pointer}.line-element{width:100%;display:flex;justify-content:space-between;align-items:center}.custom-line{width:100%;border:1px solid #000}.logo-container{display:flex;flex-direction:column;padding:10px;border:1px dashed #ccc;border-radius:5px;background-color:#f9f9f9}.logo-preview{position:relative;border:1px solid #e0e0e0;background-color:#fff;overflow:hidden}.logo-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:150px;height:150px;border:2px dashed #ccc;cursor:pointer;inline-size:auto}.logo-upload-label{display:flex;flex-direction:column;align-items:center;cursor:pointer;color:#666}.logo-upload-label img{width:32px;height:32px;margin-bottom:8px}.element.disabled{opacity:.5;cursor:not-allowed}.form-container{display:flex;flex-wrap:wrap;border:10px solid #86A8CD}.center-frame{width:74%}app-pdf-properties{border-left:10px solid #86A8CD;width:25%}:host ::ng-deep .questiondiv1{padding-left:0!important;padding-right:0!important}:host ::ng-deep .form-group.content-box{padding-bottom:0!important}:host ::ng-deep .custom-textarea{min-height:40px!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: PdfPropertiesComponent, selector: "app-pdf-properties", inputs: ["selectedElementType", "templateSelected"], outputs: ["formButtonHandler", "templateSaveHandler"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: FormsModule }, { 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.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { 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"] }, { kind: "component", type: NxtDatatable, selector: "nxt-datatable", inputs: ["data", "tableFilterData", "columns", "withCheckBox", "searchBar", "tableSaveButton", "stickyColumn", "tableWidth", "actionColumHeader", "actionButton", "title", "isButtons", "buttonArray", "tableId", "isEditRow", "isDeleteRow", "addInlineRecord", "searchConfigs", "direction", "pagination", "actionButtonArray", "multipleFilter", "isPagination", "isNosIndicator", "isEditable", "from", "question", "rowTextSize", "rowTextColor", "apiMeta", "summaryRows", "summaryColumns", "isLoading", "tableConfig", "tableParams", "listViews"], outputs: ["tableRowClick", "onEditData", "saveButtonData", "onDeleteData", "buttonEmit", "hyperLinkEmit", "sideNavEmit", "actionButtonEmit", "columnSelected", "removeColumn", "valueChange", "selectedValues", "fileEmit", "NxtTableParamsEmit", "NxtTableFilterEmit", "NxtTableEmit"] }] });
360
+ }
361
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PdfDesignerComponent, decorators: [{
362
+ type: Component,
363
+ args: [{ selector: 'app-pdf-designer', standalone: true, imports: [CommonModule, PdfPropertiesComponent, MatTooltipModule, FormsModule, NxtDatatable, BookletComponent], template: "<!-- AP 22JAN25 - form preview and All form elements -->\n<!-- AP 25FEB25 - All elements update -->\n<div class=\"form-container\">\n <div class=\"center-frame\">\n <!-- Form Builder Section All Elements -->\n <div class=\"form-builder\">\n\n <ng-container *ngFor=\"let element of elementsList\">\n <div class=\"element\" [class.disabled]=\"isElementDisabled(element.type)\"\n (click)=\"!isElementDisabled(element.type) && addElement(element.type)\"\n [draggable]=\"!isElementDisabled(element.type)\"\n [matTooltip]=\"isElementDisabled(element.type) ? 'This element is not supported when a ' + (selectedElement?.type || 'certain element') + ' is present' : null\">\n <img src=\"../assets/icons/{{ element.img }}.svg\" class=\"element-icon\">\n <div class=\"hover-label\">{{ element.label }}</div>\n <div class=\"drag-dots\">\n <div class=\"dot\" *ngFor=\"let dot of dots\"></div>\n </div>\n </div>\n </ng-container>\n\n <!-- <div class=\"template-section\">\n <app-templates (templateSelected)=\"onTemplateSelected($event)\"></app-templates>\n </div> -->\n\n <!-- SKS10MAR25 footer version show -->\n <div class=\"sticky-footer-version\">\n {{version}}\n </div>\n </div>\n <!-- AP-27MAR25 Remove CDK drag and drop replace draggable function -->\n <div class=\"form-preview\">\n <!-- AP-10MAR25 Heading -->\n <div class=\"field-container\"\n style=\"width: 100%;background-color: #EFF8FF; border: 1px solid #E6F3FF;display: flex;justify-content: center;margin-bottom:10px\"\n (click)=\"selectHeading('Header')\">\n <div class=\"label-container\" style=\"padding: 10px;\">\n <div *ngIf=\"pdf\">\n <div *ngIf=\"pdf.title == ''\" style=\"color:#3f4a525c\">Heading</div>\n <div *ngIf=\"pdf.title !== ''\">{{pdf.title}}</div>\n </div>\n </div>\n </div>\n\n <ng-container *ngFor=\"let field of pdfElements; let i = index\" getProperties().elementProps>\n \n <!-- AP-19MAR25 Line Element -->\n <div *ngIf=\"field?.type === 'Line'\" class=\"line-field\" (click)=\"selectElement(i)\"\n [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\" (dragstart)=\"onDragStart($event, i)\"\n (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"line-element\">\n <div></div>\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n <hr class=\"custom-line\" style=\"display: inline-flex\" [ngStyle]=\"getLineStyles(field)\" />\n </div>\n\n <!--SKS25MAR25 Image Upload Element -->\n <div *ngIf=\"field?.type === 'image'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\" (dragstart)=\"onDragStart($event, i)\"\n (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\" [ngStyle]=\"getFontStyles(field)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <div>\n <div class=\"logo-container\">\n <!-- Logo preview area -->\n <div class=\"logo-preview\" *ngIf=\"field.imageData\">\n <img [src]=\"field.imageData\" />\n </div>\n\n <!-- Upload button -->\n <div *ngIf=\"!field.imageData\" class=\"logo-upload-placeholder\">\n <label for=\"logo-upload-{{i}}\" class=\"logo-upload-label\">\n <img src=\"../assets/icons/Image.svg\" alt=\"Upload\" />\n <span>Upload Image</span>\n </label>\n <input type=\"file\" id=\"logo-upload-{{i}}\" accept=\"image/*\" (change)=\"fileChangeEvent(i, $event)\"\n style=\"display: none;\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Space Element -->\n <div *ngIf=\"field?.type === 'Space'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\" style=\"height:93px\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\" style=\"margin: -11px -11px 0 0;\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Boolean Element -->\n <div *ngIf=\"field?.type === 'Boolean'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"checkbox\" [checked]=\"field.boolean\" (change)=\"toggleBoolean(field)\"\n [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n\n <!-- Calendar -->\n <div *ngIf=\"field?.type === 'Calendar'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n\n </div>\n <input type=\"date\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- AP -12MAR25 Date -->\n <div *ngIf=\"field?.type === 'Date'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n\n </div>\n <input type=\"date\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- AP-21MAR25 Add Time element -->\n <!-- Time Field -->\n <div *ngIf=\"field?.type === 'Time'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"time\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- AP-28MAR25 DateTime -->\n <div *ngIf=\"field?.type === 'DateTime'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"datetime-local\" class=\"custom-input\" />\n </div>\n </div>\n </div>\n\n <!-- Email -->\n <div *ngIf=\"field?.type === 'Email'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"email\" class=\"custom-input\" [placeholder]=\"'Enter email'\"\n [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- Numbers -->\n <div *ngIf=\"field?.type === 'Number'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"number\" class=\"custom-input\" [placeholder]=\"'Enter number'\"\n [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n\n <!-- TextArea -->\n <div *ngIf=\"field?.type === 'text'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <textarea class=\"custom-textarea\" [placeholder]=\"'Enter detailed text here...'\"[(ngModel)]=\"field.question\" \n (ngModelChange)=\"onQuestionChange($event, i)\"[style.height.px]=\"field.size || 100\"></textarea>\n </div>\n </div>\n </div>\n\n <!-- Label -->\n <div *ngIf=\"field?.type === 'Label'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Pdf -->\n <div *ngIf=\"field?.type === 'Pdf'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <!-- <lib-booklet [bookletJSON]=\"field.pdfReferenceQuestions\"></lib-booklet> -->\n <div *ngIf=\"field?.pdfReferenceQuestions\">\n <ng-container *ngFor=\"let field of field?.pdfReferenceQuestions[field?.pdfReference]; let i = index\">\n <!-- AP-19MAR25 Line Element -->\n <div *ngIf=\"field?.type === 'Line'\" class=\"line-field\">\n <hr class=\"custom-line\" style=\"display: inline-flex\" [ngStyle]=\"getLineStyles(field)\" />\n </div>\n\n <div *ngIf=\"field?.type === 'image'\" class=\"field-container\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div>\n <div class=\"logo-container\">\n <!-- Logo preview area -->\n <div class=\"logo-preview\" *ngIf=\"field.imageData\">\n <img [src]=\"field.imageData\" />\n </div>\n\n <!-- Upload button -->\n <div *ngIf=\"!field.imageData\" class=\"logo-upload-placeholder\">\n <label for=\"logo-upload-{{i}}\" class=\"logo-upload-label\">\n <img src=\"../assets/icons/Image.svg\" alt=\"Upload\" />\n <span>Upload Image</span>\n </label>\n <input type=\"file\" id=\"logo-upload-{{i}}\" accept=\"image/*\"\n (change)=\"fileChangeEvent(i, $event)\" style=\"display: none;\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"field?.type === 'Space'\" class=\"field-container\">\n <div class=\"field-wrapper\" style=\"height:93px\">\n </div>\n </div>\n <div *ngIf=\"field?.type === 'text'\" class=\"field-container\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <textarea class=\"custom-textarea\" [placeholder]=\"'Enter detailed text here...'\"\n [style.height.px]=\"field.size || 100\" [value]=\"field.value ? field.value : ''\"></textarea>\n </div>\n </div>\n </div>\n <!-- AP-06MAR25 -->\n <div *ngIf=\"field?.type === 'Table'\" class=\"field-container\">\n <div class=\"field-wrapper\" style=\"overflow: hidden;\">\n <div class=\"field-content\">\n <div class=\"nxt-table-container\">\n <nxt-datatable isButtons [question]=\"field\" from=\"formBuilder\" [apiMeta]=\"field?.subText\"\n [tableConfig]=\"field.tableConfig\" tableId=\"\" direction=\"ltr\" tableWidth=\"auto\"\n isEditable=true (columnSelected)=columnSelected($event) (removeColumn)=removeColumn($event)>\n </nxt-datatable>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n\n <!-- File -->\n <div *ngIf=\"field?.type === 'File'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"file\" class=\"custom-input\" />\n </div>\n </div>\n </div>\n\n <!-- CheckBox -->\n <div *ngIf=\"field?.type === 'Checkbox'\" class=\"checkbox-field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n\n <div class=\"checkbox-options-container\">\n <div *ngFor=\"let option of field.options\" class=\"checkbox-option\">\n <input type=\"checkbox\" [id]=\"option.value + i\" [name]=\"field.id\" [value]=\"option.value || field.value\"\n class=\"checkbox-input\">\n <label [for]=\"option.value + i\" class=\"checkbox-label\">{{ option.value }}</label>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Radio -->\n <div *ngIf=\"field?.type === 'Radio'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <div class=\"radio-options-container\">\n <div *ngFor=\"let option of field.options; let j = index\" class=\"radio-option\">\n <input type=\"radio\" [id]=\"'radio-' + field.id + '-' + j\" [name]=\"'radio-group-' + field.id\"\n [value]=\"option.value || field.value\" [(ngModel)]=\"field.selectedValue\" class=\"radio-input\">\n <label [for]=\"'radio-' + field.id + '-' + j\" class=\"radio-label\"> {{ option.value }}</label>\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- Dropdown -->\n <div *ngIf=\"field?.type === 'Dropdown'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <select id=\"options\" class=\"dropdown\">\n <option *ngFor=\"let option of field.options\" [value]=\"option.value || field.value\"> {{ option.value\n }} </option>\n </select>\n </div>\n </div>\n </div>\n\n <!-- Table -->\n <!-- AP-06MAR25 -->\n <div *ngIf=\"field?.type === 'Table'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\" style=\"overflow: hidden;\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <div class=\"nxt-table-container\">\n <nxt-datatable isButtons [question]=\"field\" from=\"formBuilder\" [apiMeta]=\"field?.subText\"\n [tableConfig]=\"field.tableConfig\" tableId=\"\" direction=\"ltr\" tableWidth=\"auto\" isEditable=true\n (columnSelected)=columnSelected($event) (removeColumn)=removeColumn($event)>\n </nxt-datatable>\n </div>\n </div>\n </div>\n </div>\n\n <!-- List -->\n <!-- AP-06MAR25 - List data show-->\n <div *ngIf=\"field?.type === 'List'\" class=\"field-container\" (click)=\"selectElement(i)\"\n [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n <div class=\"field-wrapper\">\n <div class=\"field-content\">\n <div class=\"label-container\">\n <div class=\"top-right\">\n <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n </div>\n </div>\n <input type=\"text\" class=\"custom-input\" placeholder=\"Search...\"\n [value]=\"field.value ? field.value : ''\" />\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n <!-- SKS13MAR25 popup conformation box -->\n <div class=\"dialog-overlay\" *ngIf=\"isSelectTablePopup\">\n <div class=\"dialog-box\">\n <button class=\"close-btn-fb\" (click)=\"onClose()\">\u2715</button>\n <p>These element want to add a table</p>\n <div class=\"button-container-fb\">\n <button class=\"yes-btn-fb\" (click)=\"addOnTable()\">Yes</button>\n <button class=\"no-btn-fb\" (click)=\"onClose()\">No</button>\n </div>\n </div>\n </div>\n <app-pdf-properties></app-pdf-properties>\n</div>", styles: [".center-frame{display:flex;border-right-width:0}.head-elements{font-size:17px;font-weight:600}.form-builder{width:33.33%;height:calc(100vh - 20px);overflow-y:auto;background-color:#fff;padding:10px;border-right:10px solid #86A8CD;box-shadow:2px 2px 10px #0000001a}.form-builder .element{display:flex;align-items:center;gap:15px;margin-top:10px;padding:10px;border-radius:5px;background:#f8fafc;cursor:pointer;border-left:10px solid #E2F1FF;position:relative;color:#000}.form-builder .element:hover{background:#0250d9;color:#fff;border-left:10px solid #234465}.form-builder .element img{width:20px;height:20px;transition:filter .3s ease}.form-builder .element:hover img{filter:invert(1)}.form-builder .hover-label{font-size:15px;font-weight:400;color:#000;transition:color .3s ease}.form-builder .element:hover .hover-label{color:#fff}.form-builder .section-title{font-weight:700;font-size:16px;margin-top:10px;padding:5px;border-bottom:1px solid #ddd;color:#000;display:flex;justify-content:space-between;align-items:center}.form-builder .section-title:after{content:\"\\25bc\";font-size:12px;color:#555}.form-builder .section{margin-bottom:10px}.toggle-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:10px}.arrow-icon{width:19px;height:23px;transition:transform .3s ease}.toggle-header:hover .arrow-icon{transform:scale(1.1)}.drag-dots{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,1fr);gap:3px;position:absolute;right:15px;top:50%;transform:translateY(-50%)}.dot{width:5px;height:5px;border-radius:50%;background-color:#cbd5e1;transition:background-color .3s ease}.form-builder .element:hover .dot{background-color:#ffffffb3}.field-wrapper{background-color:#eff8ff;border:1px solid #E6F3FF;border-radius:5px;padding:10px}.required:after{content:\"*\";color:red;margin-left:5px}.custom-input{width:100%;padding:8px;border:1px solid #DDDBDA;background-color:#fff;border-radius:5px;outline:none}.custom-input:focus{border-color:#00008b;box-shadow:0 0 5px #0000ff80}.delete-icon{width:19px;height:19px;margin-top:-5px}.field-container{padding-right:5px;padding-left:5px;transition:background .2s}.field-container:hover .top-right,.field-container.highlight .top-right,.label-container:hover .delete-icon{opacity:1;visibility:visible}.form-preview{width:100%;height:calc(100vh - 20px);overflow-y:auto;display:flex;flex-wrap:wrap;align-items:flex-start;padding:10px;height:fit-content;max-height:calc(100vh - 20px)}.field-content{display:flex;flex-direction:column;gap:5px}.label-container{display:flex;justify-content:flex-end;align-items:center}.top-right{display:flex;gap:10px;padding:6px;border:1px solid #d7edff;margin-top:-10px;background-color:#d7edff;margin-right:-10px;opacity:0;visibility:hidden;cursor:grab;transition:opacity .1s ease-in-out,visibility .1s ease-in-out}.drag-dot{height:13px}.custom-input,.custom-textarea,.dropdown,.checkbox-options-container,.radio-options-container{width:100%}.form-builder .element .drag-dots:active{cursor:grabbing}.dropdown{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;background-color:#fff;font-size:14px;color:#333;outline:none;cursor:pointer}.dropdown:focus{border-color:#007bff;box-shadow:0 0 5px #007bff80}.line-field{width:100%;margin:10px 0;background-color:#eff8ff;border:1px solid #E6F3FF;border-radius:5px;padding:3px}.checkbox-field-container:hover{box-shadow:0 2px 8px #0000001a}.checkbox-options-container{display:flex;flex-direction:column;gap:5px;padding:8px;min-height:38px;border:1px solid #DDDBDA;background-color:#fff;outline:none;border-radius:6px}.checkbox-option,.radio-option{display:flex;align-items:center;gap:8px;padding:8px;background-color:#fff;border-radius:4px;transition:background-color .2s ease}.checkbox-option:hover{background-color:#f1f3f5}.checkbox-input,.radio-input{width:18px;height:18px;accent-color:#4dabf7;cursor:pointer}.checkbox-label,.radio-label{font-size:14px;color:#495057;cursor:pointer;-webkit-user-select:none;user-select:none}.label-container label{font-size:15px;font-weight:400}.required:after{content:\" *\";color:red}.radio-options-container{display:flex;flex-direction:column;gap:5px;padding:8px;min-height:38px;border:1px solid #DDDBDA;background-color:#fff;outline:none;border-radius:6px}.radio-input:checked{border-color:#007bff;background-color:#007bff}.radio-input:checked:after{content:\"\";width:8px;height:8px;background:#fff;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.custom-textarea{width:100%;min-height:100px;border:1px solid #ccc;border-radius:4px;padding:8px;resize:vertical}.highlight{border:2px solid #5592FD!important;background-color:#eff8ff}.table-container label{font-size:14px;font-weight:700;margin-bottom:5px;display:block}.sticky-footer-version{position:fixed;bottom:0;padding:10px;text-align:center}.nxt-table-container{display:flex;justify-content:center;align-items:center;width:100%}nxt-datatable{width:100%!important;table-layout:fixed;max-width:100%}.dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.dialog-box{background:#fff;padding:20px;border-radius:5px;text-align:center;width:300px;position:relative}.close-btn-fb{position:absolute;top:4px;right:4px;background:#ff4242;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:10px;cursor:pointer}.button-container-fb{display:flex;justify-content:flex-end;gap:10px}.yes-btn-fb{background:green;color:#fff;border:none;padding:0 12px;border-radius:5px;cursor:pointer}.no-btn-fb{background:gray;color:#fff;border:none;padding:8px 15px;border-radius:5px;cursor:pointer}.line-element{width:100%;display:flex;justify-content:space-between;align-items:center}.custom-line{width:100%;border:1px solid #000}.logo-container{display:flex;flex-direction:column;padding:10px;border:1px dashed #ccc;border-radius:5px;background-color:#f9f9f9}.logo-preview{position:relative;border:1px solid #e0e0e0;background-color:#fff;overflow:hidden}.logo-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:150px;height:150px;border:2px dashed #ccc;cursor:pointer;inline-size:auto}.logo-upload-label{display:flex;flex-direction:column;align-items:center;cursor:pointer;color:#666}.logo-upload-label img{width:32px;height:32px;margin-bottom:8px}.element.disabled{opacity:.5;cursor:not-allowed}.form-container{display:flex;flex-wrap:wrap;border:10px solid #86A8CD}.center-frame{width:74%}app-pdf-properties{border-left:10px solid #86A8CD;width:25%}:host ::ng-deep .questiondiv1{padding-left:0!important;padding-right:0!important}:host ::ng-deep .form-group.content-box{padding-bottom:0!important}:host ::ng-deep .custom-textarea{min-height:40px!important}\n"] }]
364
+ }], ctorParameters: () => [{ type: i1.PdfDesignerService }], propDecorators: { pdfJSON: [{
365
+ type: Input
366
+ }], bookletId: [{
367
+ type: Input
368
+ }], templateMode: [{
369
+ type: Output
370
+ }] } });
371
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pdf-designer.component.js","sourceRoot":"","sources":["../../../../../../../projects/nxt-app/src/lib/pages/pdfDesigner/pdf-designer/pdf-designer.component.ts","../../../../../../../projects/nxt-app/src/lib/pages/pdfDesigner/pdf-designer/pdf-designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges } from '@angular/core';\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { v4 as uuidv4 } from 'uuid';\nimport { VERSION } from '../../../../environments/version';\nimport { PdfPropertiesComponent } from '../pdf-properties/pdf-properties.component';\nimport { CommonModule } from '@angular/common';\nimport { PdfDesignerService } from '../../../services/pdf-designer.service';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { FormsModule } from '@angular/forms';\nimport { NxtDatatable } from '../../../components/datatable/datatable.component';\nimport { BookletComponent } from '../../booklet/booklet.component';\n\n\n@Component({\n  selector: 'app-pdf-designer',\n  standalone: true,\n  imports: [CommonModule, PdfPropertiesComponent, MatTooltipModule, FormsModule, NxtDatatable, BookletComponent],\n  templateUrl: './pdf-designer.component.html',\n  styleUrls: ['./pdf-designer.component.css']\n})\nexport class PdfDesignerComponent {\n  //@Output() elementButtonClicked = new EventEmitter<string>();\n  @Input() pdfJSON: any;\n  @Input() bookletId: any;\n  @Output() templateMode = new EventEmitter<boolean>();\n  field: any;\n  pdfElements: any[] = [];\n  elements: any[] = [];\n  bookId: string;\n  sections = {\n    basic: true,    // Basic Elements open by default\n    advanced: true // Advanced Elements closed by default\n  };\n  elementsList: any[] = [];\n  elementDisabledArray: any;\n  version = VERSION.version; //SKS10MAR25 get version from environment/version.ts \n  pdf: any;\n  selectedElement: any = null;\n  isSelectTablePopup: boolean = false;\n  currentType: string;\n  addTable: boolean = true;\n  dots = Array(6);\n  draggedIndex: number | null = null;\n  templateSelected = false;\n\n  //subscription: any;\n  constructor(private pdfDesignerService: PdfDesignerService) {\n  }\n  //  AP-06MAR25 New Design Change Elements Basic , Advanced\n  // AP-06MAR25 Add RichText Area\n  // AP-12MAR25 Add Date\n  ngOnInit() {\n    this.elementsList = [\n      { \"type\": \"text\", \"img\": \"Text\", \"label\": \"Text\" },\n      { \"type\": \"image\", \"img\": \"Image\", \"label\": \"Image\" },\n      { \"type\": \"Line\", \"img\": \"line\", \"label\": \"Line\" },\n      { \"type\": \"Space\", \"img\": \"space\", \"label\": \"Space\" },\n      { \"type\": \"Table\", \"img\": \"Table\", \"label\": \"Table\" },\n      { \"type\": \"Pdf\", \"img\": \"Search\", \"label\": \"Pdf\" },\n    ];\n    this.elementDisabledArray = {\n      Table: [\n        'Pdf', 'Calendar', \"Boolean\", 'List', 'Table', 'Checkbox', 'Radio',\n        'Dropdown', 'RichTextArea', 'Number', 'Label', 'image',\n        'Email', 'Date', 'Time', 'DateTime', 'Line', 'Space'\n      ]\n    };\n\n    this.pdfDesignerService.pdfElements$.subscribe(elements => {\n      setTimeout(() => {\n        this.pdfElements = elements.map(field => ({ ...field }));\n      }, 0);\n    });\n    if (this.pdfJSON && (this.pdfJSON !== '')) {\n      this.initializeForm();\n    } else {\n      this.pdfDesignerService.newBook()\n    }\n    // AP-12MAR25 - Added to handle bookletId\n    if (this.bookletId) {\n      localStorage.setItem('unique_id', this.bookletId);\n\n    }\n    this.pdf = this.pdfDesignerService.getBook();\n    this.pdfDesignerService.selectedElement$.subscribe(index => {\n      const elements = this.pdfDesignerService.getElements();\n      if (index >= 0) {\n        this.selectedElement = elements[index];\n      }\n      // this.pdfElements = [...elements]\n    });\n    this.pdfDesignerService.addElementWithId();\n  }\n\n  isSectionOpen(section: string): boolean {\n    return this.sections[section];\n  }\n\n  // AP - 26FEB25 - Added ngOnChanges to handle changes in pdfJSON\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['pdfJSON'] && changes['pdfJSON'].currentValue) {\n      if (this.pdfJSON && (this.pdfJSON !== '')) {\n        this.initializeForm();\n      } else {\n        this.pdfDesignerService.newBook()\n      }\n    }\n  }\n  // AP-08APR25 Template is selected, update form elements and emit template mode\n  onTemplateSelected(event: { selectedTemplate: any; elements: any[] }) {\n    this.pdfDesignerService.clearElements();\n    event.elements.forEach(el => this.pdfDesignerService.addElement(el));\n\n    // Emit template mode to parent\n    this.templateMode.emit(true);\n  }\n\n  private initializeForm() {\n    if (!this.pdfJSON || !this.pdfJSON) {\n      console.warn(\"Invalid pdfJSON structure\");\n      return;\n    }\n    this.pdfElements = []\n    this.pdfDesignerService.clearElements();\n    this.pdfDesignerService.intializeBook(this.pdfJSON);\n\n    const pdfMapKey = Object.keys(this.pdfJSON)[0];\n    const pdfArray = this.pdfJSON[pdfMapKey];\n\n    if (Array.isArray(pdfArray)) {\n      pdfArray.forEach((subQuestion) => {\n        // AP-04APR24 If subQuestion.style exists as a string and is empty, replace it with a default style object\n        if (typeof subQuestion.style === \"string\" && subQuestion.style.trim() === \"\") {\n          subQuestion.style = {\n            \"labelClass\": null,\n            \"labelStyle\": null,\n            \"labelValueStyle\": null,\n            \"inputClass\": null,\n            \"inputStyle\": null,\n            \"bookStyle\": null,\n            \"direction\": \"ltr\",\n            \"questionStyle\": null\n          };\n        }\n      });\n    }\n    this.pdfElements = this.pdfDesignerService.getElements();\n  }\n\n  // Add this method to handle element selection\n  selectElement(index: number) {\n    this.selectedFieldIndex = index; // element is selected\n    this.pdfDesignerService.setSelectedElement(index);\n    this.pdf = this.pdfDesignerService.getBook();\n    //const element = this.pdfElements[index];\n    // this.elementButtonClicked.emit(element.type);  \n  }\n  //selectedIndex: number | null = null;\n  selectedFieldIndex: number | null = null; // element is cleared\n\n  selectHeading(event: any) {\n    this.pdfDesignerService.selectHeading(event); //AP-10MAR25 Updates the selected heading in the service  \n    this.pdf = this.pdfDesignerService.getBook(); //AP-10MAR25 Retrieves the updated pdf/form data \n  }\n  // AP-17APR25 generateUiId \n  generateUiId() {\n    return this.pdfDesignerService.addElementWithId();\n  }\n\n  addElement(type: string): void {\n    const unique_id = this.generateUiId();\n    this.currentType = type\n    if (this.selectedElement?.type === 'Table' && this.addTable) {\n      this.isSelectTablePopup = true\n    } else {\n      const newElement = {\n        id: unique_id,\n        type,\n        margin: [0, 0, 0, 0],\n        fontSize: 14,\n        fontWeight: '400',\n        fontStyle: [],\n        alignItems: 'center',\n        referenceField: null,\n        question: null,\n        questionNumber: this.pdfDesignerService.getElements().length + 1,\n        fieldsMeta: [],\n        pdfReference: null,\n        pdfReferenceQuestions: null,\n        style: {\n          labelClass: null,\n          labelStyle: null,\n          labelValueStyle: null,\n          inputClass: null,\n          inputStyle: null,\n          bookStyle: null,\n          direction: 'ltr',\n          questionStyle: null,\n        },\n        imageData: null,\n        imageSize: type === 'image' ? { width: 150, height: 150 } : null,\n        tableConfig: type === 'Table' ? {\n          isNosIndicator: false,\n          addInlineRecord: true,\n          isPagination: false,\n          actionButton: false,\n          isDeleteRow: true,\n          isEditRow: false,\n          searchBar: false,\n          isButtons: false,\n        } : null,\n\n        width: 100,\n        styleClass: unique_id,\n      };\n      this.pdfDesignerService.addElement(newElement);\n      this.pdfElements = this.pdfDesignerService.getElements();\n      this.addTable = true\n    }\n  }\n  onQuestionChange(value: string, index: number) {\n    console.log(\"onQuestionChange\", value, index);\n    // Update the local field first\n    this.pdfElements[index].question = value;\n    // Update the service with the new question value\n    this.pdfDesignerService.elementUpdate(index, this.pdfElements[index]);\n  }\n  // Remove an element by index\n  removeElement(field: any, index: number): void {\n    this.pdfDesignerService.removeElementComponent(field.id);\n    this.pdfElements = this.pdfDesignerService.getElements();\n  }\n\n  onDragStart(event: DragEvent, index: number) {\n    this.draggedIndex = index;\n    event.dataTransfer?.setData('text/plain', index.toString());\n  }\n\n  // Allow dropping by preventing default\n  onDragOver(event: DragEvent, index: number) {\n    event.preventDefault();\n  }\n\n  // Handle drop event\n  onDrop(event: DragEvent, dropIndex: number) {\n    event.preventDefault();\n\n    if (this.draggedIndex === null || this.draggedIndex === dropIndex) return;\n\n    const draggedItem = this.pdfElements[this.draggedIndex];\n\n    // Remove dragged item from old position and insert it in new position\n    this.pdfElements.splice(this.draggedIndex, 1);\n    this.pdfElements.splice(dropIndex, 0, draggedItem);\n\n    //AP-28MAR25 Update questionNumber dynamically based on new order\n    this.pdfElements.forEach((element, index) => {\n      element.questionNumber = index + 1;\n    });\n\n    // Reset dragged index\n    this.draggedIndex = null;\n\n    // Notify service about the update\n    this.pdfDesignerService.updateElementsOrder(this.pdfElements);\n  }\n\n\n  toggleBoolean(field: any): void {\n    field.boolean = !field.boolean;\n  }\ngetFontStyles(field: any): any {\n  const margin = field.margin || [0, 0, 0, 0];  // [left, top, right, bottom]\n  const fontStyles = field.fontStyle || [];\n  \n  return {\n    'font-family': field.font || 'Helvetica Neue',\n    //'font-weight': field.fontWeight || '400',\n    'font-size': field.fontSize ? `${field.fontSize}px` : '14px',\n    'width': field.width ? `${field.width}%` : '100%',\n    //'text-align': field.textAlign || 'left',\n    'align-items': field.alignItems || 'center',\n    'border-radius': '5px',\n    'border-width': field.lineWidth ? `${field.lineWidth}px` : '1px',\n    'color': field.fontColor || '#000000',\n    'font-style': fontStyles.includes('italic') ? 'italic' : 'normal',\n    'font-weight': fontStyles.includes('bold') ? 'bold' : (field.fontWeight || '400'),\n    'margin': `${margin[0]}px ${margin[1]}px ${margin[2]}px ${margin[3]}px`,\n    'padding-top': field.paddingTop ? `${field.paddingTop}px` : '0px',\n    'padding-bottom': field.paddingBottom ? `${field.paddingBottom}px` : '10px',\n  };\n}\n  \n  getLineStyles(field: any): any {\n    const styles: any = {\n      'font-family': field.font || 'Helvetica Neue',\n      'font-weight': field.fontWeight || '400',\n      'font-size': field.fontSize || '14px',\n      'width': field.width ? `${field.width }%` : '100%',\n      'text-align': field.textAlign || 'left',\n      'border-radius': '5px',\n      'border-width': field.lineWidth ? `${field.lineWidth}px` : '1px',\n      'border-style': field.lineStyle?.toLowerCase() || 'solid',\n      'color': field.fontColor || '#000000',\n      //'border-color': field.color || '#EFF8FF', \n      'margin-top': field.paddingTop ? `${field.paddingTop}px` : '0px',\n      'margin-bottom': field.paddingBottom ? `${field.paddingBottom}px` : '10px'\n    };\n    return styles;\n  }\n  // SKS13MAR25 table popup conformation based element add\n  onClose() {\n    this.isSelectTablePopup = false\n    this.addTable = false\n    this.addElement(this.currentType)\n  }\n  // SKS13MAR25 column element add inside a table\n  addOnTable() {\n    this.addTable = true\n    this.isSelectTablePopup = false\n    const elements = [...this.pdfDesignerService.getElements()];\n\n    // Find the element and update its columns\n    const index = elements.findIndex(el => el.id === this.selectedElement.id);\n    const rowNum = this.pdfElements[index].columns ? this.pdfElements[index].columns?.length : 0\n    const unique_id = this.generateUiId();\n    const tableElement = {\n      label: `HEADER LABEL ${rowNum}`,\n      fieldName: `FIELD NAME${rowNum}`,\n      type: this.currentType,\n      id: unique_id\n    }\n    this.pdfDesignerService.addTableElement(tableElement, this.selectedFieldIndex);\n    this.pdfElements = this.pdfDesignerService.getElements();\n    // this.addTableData(unique_id, fieldName)\n  }\n  addTableData(fieldId, fieldName) {\n    // this.pdfDesignerService.addTablefieldData(tableElement);\n  }\n  columnSelected(event: any) {\n    // console.log(event)\n    // SKS19MAR25 table column update\n    this.pdfDesignerService.setSelectedTableElement(this.selectedFieldIndex, event);\n  }\n  removeColumn(event: any) {\n    // console.log(event)\n    this.pdfDesignerService.removeSelectedTableElement(this.selectedFieldIndex, event);\n  }\n\n  // SKS25MAR25 image add\n  async fileChangeEvent(index: any, event: any): Promise<void> {\n    const file = event.target.files[0];\n    if (file) {\n      try {\n        const imageData = await this.readFileAsDataURL(file);\n        this.pdfElements[index].imageData = imageData;\n        this.pdfElements[index].orgImageData = imageData;\n        // Initialize logo size if not already set\n        if (!this.pdfElements[index].imageSize) {\n          this.pdfElements[index].imageSize = { width: 150, height: 150 };\n        }\n\n        await this.pdfDesignerService.elementUpdate(index, this.pdfElements[index]);\n      } catch (error) {\n        console.error(\"Error reading file:\", error);\n      }\n    }\n  }\n\n  private readFileAsDataURL(file: File): Promise<string> {\n    return new Promise((resolve, reject) => {\n      const reader = new FileReader();\n      reader.onload = () => resolve(reader.result as string);\n      reader.onerror = (error) => reject(error);\n      reader.readAsDataURL(file);\n    });\n  }\n  // SKS2APR25 disabled element\n  isElementDisabled(elementType: string): boolean {\n    if (this.selectedElement) {\n      const elements = this.elementDisabledArray[this.selectedElement.type]\n      if (elements) {\n        return elements.includes(elementType);\n      }\n    }\n    return false;\n  }\n}","<!-- AP 22JAN25 - form preview and All form elements -->\n<!-- AP 25FEB25 - All elements update -->\n<div class=\"form-container\">\n  <div class=\"center-frame\">\n    <!-- Form Builder Section All Elements -->\n    <div class=\"form-builder\">\n\n      <ng-container *ngFor=\"let element of elementsList\">\n        <div class=\"element\" [class.disabled]=\"isElementDisabled(element.type)\"\n          (click)=\"!isElementDisabled(element.type) && addElement(element.type)\"\n          [draggable]=\"!isElementDisabled(element.type)\"\n          [matTooltip]=\"isElementDisabled(element.type) ? 'This element is not supported when a ' + (selectedElement?.type || 'certain element') + ' is present' : null\">\n          <img src=\"../assets/icons/{{ element.img }}.svg\" class=\"element-icon\">\n          <div class=\"hover-label\">{{ element.label }}</div>\n          <div class=\"drag-dots\">\n            <div class=\"dot\" *ngFor=\"let dot of dots\"></div>\n          </div>\n        </div>\n      </ng-container>\n\n      <!-- <div class=\"template-section\">\n        <app-templates (templateSelected)=\"onTemplateSelected($event)\"></app-templates>\n      </div> -->\n\n      <!-- SKS10MAR25 footer version show -->\n      <div class=\"sticky-footer-version\">\n        {{version}}\n      </div>\n    </div>\n    <!-- AP-27MAR25 Remove CDK drag and drop replace draggable function  -->\n    <div class=\"form-preview\">\n      <!-- AP-10MAR25 Heading -->\n      <div class=\"field-container\"\n        style=\"width: 100%;background-color: #EFF8FF; border: 1px solid #E6F3FF;display: flex;justify-content: center;margin-bottom:10px\"\n        (click)=\"selectHeading('Header')\">\n        <div class=\"label-container\" style=\"padding: 10px;\">\n          <div *ngIf=\"pdf\">\n            <div *ngIf=\"pdf.title == ''\" style=\"color:#3f4a525c\">Heading</div>\n            <div *ngIf=\"pdf.title !== ''\">{{pdf.title}}</div>\n          </div>\n        </div>\n      </div>\n\n      <ng-container *ngFor=\"let field of pdfElements; let i = index\" getProperties().elementProps>\n       \n        <!-- AP-19MAR25 Line Element -->\n        <div *ngIf=\"field?.type === 'Line'\" class=\"line-field\" (click)=\"selectElement(i)\"\n          [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\" (dragstart)=\"onDragStart($event, i)\"\n          (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"line-element\">\n            <div></div>\n            <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n          </div>\n          <hr class=\"custom-line\" style=\"display: inline-flex\" [ngStyle]=\"getLineStyles(field)\" />\n        </div>\n\n        <!--SKS25MAR25 Image Upload Element -->\n        <div *ngIf=\"field?.type === 'image'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\" (dragstart)=\"onDragStart($event, i)\"\n          (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\" [ngStyle]=\"getFontStyles(field)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <div>\n                <div class=\"logo-container\">\n                  <!-- Logo preview area -->\n                  <div class=\"logo-preview\" *ngIf=\"field.imageData\">\n                    <img [src]=\"field.imageData\" />\n                  </div>\n\n                  <!-- Upload button -->\n                  <div *ngIf=\"!field.imageData\" class=\"logo-upload-placeholder\">\n                    <label for=\"logo-upload-{{i}}\" class=\"logo-upload-label\">\n                      <img src=\"../assets/icons/Image.svg\" alt=\"Upload\" />\n                      <span>Upload Image</span>\n                    </label>\n                    <input type=\"file\" id=\"logo-upload-{{i}}\" accept=\"image/*\" (change)=\"fileChangeEvent(i, $event)\"\n                      style=\"display: none;\" />\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n\n        <!-- Space Element -->\n        <div *ngIf=\"field?.type === 'Space'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\" style=\"height:93px\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\" style=\"margin: -11px -11px 0 0;\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n\n        <!-- Boolean Element -->\n        <div *ngIf=\"field?.type === 'Boolean'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"label-container\">\n              <div class=\"top-right\">\n                <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n                <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n              </div>\n            </div>\n            <input type=\"checkbox\" [checked]=\"field.boolean\" (change)=\"toggleBoolean(field)\"\n              [value]=\"field.value ? field.value : ''\" />\n          </div>\n        </div>\n\n        <!-- Calendar -->\n        <div *ngIf=\"field?.type === 'Calendar'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n\n              </div>\n              <input type=\"date\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n            </div>\n          </div>\n        </div>\n\n        <!-- AP -12MAR25 Date -->\n        <div *ngIf=\"field?.type === 'Date'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n\n              </div>\n              <input type=\"date\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n            </div>\n          </div>\n        </div>\n\n        <!-- AP-21MAR25 Add Time element -->\n        <!-- Time Field -->\n        <div *ngIf=\"field?.type === 'Time'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <input type=\"time\" class=\"custom-input\" [value]=\"field.value ? field.value : ''\" />\n            </div>\n          </div>\n        </div>\n\n        <!-- AP-28MAR25 DateTime -->\n        <div *ngIf=\"field?.type === 'DateTime'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <input type=\"datetime-local\" class=\"custom-input\" />\n            </div>\n          </div>\n        </div>\n\n        <!-- Email -->\n        <div *ngIf=\"field?.type === 'Email'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <input type=\"email\" class=\"custom-input\" [placeholder]=\"'Enter email'\"\n                [value]=\"field.value ? field.value : ''\" />\n            </div>\n          </div>\n        </div>\n\n        <!-- Numbers -->\n        <div *ngIf=\"field?.type === 'Number'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <input type=\"number\" class=\"custom-input\" [placeholder]=\"'Enter number'\"\n                [value]=\"field.value ? field.value : ''\" />\n            </div>\n          </div>\n        </div>\n\n        <!-- TextArea -->\n        <div *ngIf=\"field?.type === 'text'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <textarea class=\"custom-textarea\" [placeholder]=\"'Enter detailed text here...'\"[(ngModel)]=\"field.question\" \n              (ngModelChange)=\"onQuestionChange($event, i)\"[style.height.px]=\"field.size || 100\"></textarea>\n            </div>\n          </div>\n        </div>\n\n        <!-- Label -->\n        <div *ngIf=\"field?.type === 'Label'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n\n        <!-- Pdf -->\n        <div *ngIf=\"field?.type === 'Pdf'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <!-- <lib-booklet [bookletJSON]=\"field.pdfReferenceQuestions\"></lib-booklet> -->\n              <div *ngIf=\"field?.pdfReferenceQuestions\">\n                <ng-container *ngFor=\"let field of field?.pdfReferenceQuestions[field?.pdfReference]; let i = index\">\n                  <!-- AP-19MAR25 Line Element -->\n                  <div *ngIf=\"field?.type === 'Line'\" class=\"line-field\">\n                    <hr class=\"custom-line\" style=\"display: inline-flex\" [ngStyle]=\"getLineStyles(field)\" />\n                  </div>\n\n                  <div *ngIf=\"field?.type === 'image'\" class=\"field-container\">\n                    <div class=\"field-wrapper\">\n                      <div class=\"field-content\">\n                        <div>\n                          <div class=\"logo-container\">\n                            <!-- Logo preview area -->\n                            <div class=\"logo-preview\" *ngIf=\"field.imageData\">\n                              <img [src]=\"field.imageData\" />\n                            </div>\n\n                            <!-- Upload button -->\n                            <div *ngIf=\"!field.imageData\" class=\"logo-upload-placeholder\">\n                              <label for=\"logo-upload-{{i}}\" class=\"logo-upload-label\">\n                                <img src=\"../assets/icons/Image.svg\" alt=\"Upload\" />\n                                <span>Upload Image</span>\n                              </label>\n                              <input type=\"file\" id=\"logo-upload-{{i}}\" accept=\"image/*\"\n                                (change)=\"fileChangeEvent(i, $event)\" style=\"display: none;\" />\n                            </div>\n                          </div>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                  <div *ngIf=\"field?.type === 'Space'\" class=\"field-container\">\n                    <div class=\"field-wrapper\" style=\"height:93px\">\n                    </div>\n                  </div>\n                  <div *ngIf=\"field?.type === 'text'\" class=\"field-container\">\n                    <div class=\"field-wrapper\">\n                      <div class=\"field-content\">\n                        <textarea class=\"custom-textarea\" [placeholder]=\"'Enter detailed text here...'\"\n                          [style.height.px]=\"field.size || 100\" [value]=\"field.value ? field.value : ''\"></textarea>\n                      </div>\n                    </div>\n                  </div>\n                  <!-- AP-06MAR25 -->\n                  <div *ngIf=\"field?.type === 'Table'\" class=\"field-container\">\n                    <div class=\"field-wrapper\" style=\"overflow: hidden;\">\n                      <div class=\"field-content\">\n                        <div class=\"nxt-table-container\">\n                          <nxt-datatable isButtons [question]=\"field\" from=\"formBuilder\" [apiMeta]=\"field?.subText\"\n                            [tableConfig]=\"field.tableConfig\" tableId=\"\" direction=\"ltr\" tableWidth=\"auto\"\n                            isEditable=true (columnSelected)=columnSelected($event) (removeColumn)=removeColumn($event)>\n                          </nxt-datatable>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </ng-container>\n              </div>\n            </div>\n          </div>\n        </div>\n\n        <!-- File -->\n        <div *ngIf=\"field?.type === 'File'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <input type=\"file\" class=\"custom-input\" />\n            </div>\n          </div>\n        </div>\n\n        <!-- CheckBox -->\n        <div *ngIf=\"field?.type === 'Checkbox'\" class=\"checkbox-field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n\n              <div class=\"checkbox-options-container\">\n                <div *ngFor=\"let option of field.options\" class=\"checkbox-option\">\n                  <input type=\"checkbox\" [id]=\"option.value + i\" [name]=\"field.id\" [value]=\"option.value || field.value\"\n                    class=\"checkbox-input\">\n                  <label [for]=\"option.value + i\" class=\"checkbox-label\">{{ option.value }}</label>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n\n        <!-- Radio -->\n        <div *ngIf=\"field?.type === 'Radio'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <div class=\"radio-options-container\">\n                <div *ngFor=\"let option of field.options; let j = index\" class=\"radio-option\">\n                  <input type=\"radio\" [id]=\"'radio-' + field.id + '-' + j\" [name]=\"'radio-group-' + field.id\"\n                    [value]=\"option.value || field.value\" [(ngModel)]=\"field.selectedValue\" class=\"radio-input\">\n                  <label [for]=\"'radio-' + field.id + '-' + j\" class=\"radio-label\"> {{ option.value }}</label>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n        <!-- Dropdown -->\n        <div *ngIf=\"field?.type === 'Dropdown'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <select id=\"options\" class=\"dropdown\">\n                <option *ngFor=\"let option of field.options\" [value]=\"option.value || field.value\"> {{ option.value\n                  }} </option>\n              </select>\n            </div>\n          </div>\n        </div>\n\n        <!--  Table  -->\n        <!-- AP-06MAR25 -->\n        <div *ngIf=\"field?.type === 'Table'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\" style=\"overflow: hidden;\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <div class=\"nxt-table-container\">\n                <nxt-datatable isButtons [question]=\"field\" from=\"formBuilder\" [apiMeta]=\"field?.subText\"\n                  [tableConfig]=\"field.tableConfig\" tableId=\"\" direction=\"ltr\" tableWidth=\"auto\" isEditable=true\n                  (columnSelected)=columnSelected($event) (removeColumn)=removeColumn($event)>\n                </nxt-datatable>\n              </div>\n            </div>\n          </div>\n        </div>\n\n        <!-- List -->\n        <!-- AP-06MAR25 - List data show-->\n        <div *ngIf=\"field?.type === 'List'\" class=\"field-container\" (click)=\"selectElement(i)\"\n          [ngStyle]=\"getFontStyles(field)\" [class.highlight]=\"selectedFieldIndex === i\" draggable=\"true\"\n          (dragstart)=\"onDragStart($event, i)\" (dragover)=\"onDragOver($event, i)\" (drop)=\"onDrop($event, i)\">\n          <div class=\"field-wrapper\">\n            <div class=\"field-content\">\n              <div class=\"label-container\">\n                <div class=\"top-right\">\n                  <img src=\"../assets/icons/drag-dots.svg\" alt=\"Drag\" class=\"drag-dot\" />\n                  <img src=\"../assets/icons/Trash.svg\" (click)=\"removeElement(field, i)\" class=\"delete-icon\" />\n                </div>\n              </div>\n              <input type=\"text\" class=\"custom-input\" placeholder=\"Search...\"\n                [value]=\"field.value ? field.value : ''\" />\n            </div>\n          </div>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n  <!-- SKS13MAR25 popup conformation box -->\n  <div class=\"dialog-overlay\" *ngIf=\"isSelectTablePopup\">\n    <div class=\"dialog-box\">\n      <button class=\"close-btn-fb\" (click)=\"onClose()\">✕</button>\n      <p>These element want to add a table</p>\n      <div class=\"button-container-fb\">\n        <button class=\"yes-btn-fb\" (click)=\"addOnTable()\">Yes</button>\n        <button class=\"no-btn-fb\" (click)=\"onClose()\">No</button>\n      </div>\n    </div>\n  </div>\n  <app-pdf-properties></app-pdf-properties>\n</div>"]}