@rangertechnologies/ngnxt 2.1.108 → 2.1.110
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/environments/version.d.ts +11 -0
- package/esm2022/environments/version.mjs +15 -0
- package/esm2022/lib/pages/builder/element/element.component.mjs +51 -33
- package/esm2022/lib/pages/builder/properties/properties.component.mjs +115 -40
- package/esm2022/lib/services/form-builder.service.mjs +72 -31
- package/fesm2022/rangertechnologies-ngnxt.mjs +249 -101
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/pages/builder/element/element.component.d.ts +3 -0
- package/lib/pages/builder/properties/properties.component.d.ts +19 -65
- package/lib/services/form-builder.service.d.ts +8 -0
- package/package.json +1 -1
- package/rangertechnologies-ngnxt-2.1.110.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.108.tgz +0 -0
|
@@ -7,12 +7,14 @@ export class FormBuilderService {
|
|
|
7
7
|
formElements = [];
|
|
8
8
|
formElementsSubject = new BehaviorSubject([]);
|
|
9
9
|
selectedElementSubject = new BehaviorSubject(-1);
|
|
10
|
+
selectHeaderSubject = new BehaviorSubject(null);
|
|
10
11
|
elementComponent = null;
|
|
11
12
|
book;
|
|
12
13
|
unique_id;
|
|
13
14
|
tempElem;
|
|
14
15
|
formElements$ = this.formElementsSubject.asObservable();
|
|
15
16
|
selectedElement$ = this.selectedElementSubject.asObservable();
|
|
17
|
+
selectHeaderSubject$ = this.selectHeaderSubject.asObservable();
|
|
16
18
|
// book: { bookQuestionsMap: { unique_id: { subQuestions: any[]; }; }; };
|
|
17
19
|
constructor() {
|
|
18
20
|
// Load saved elements from localStorage
|
|
@@ -21,9 +23,30 @@ export class FormBuilderService {
|
|
|
21
23
|
if (savedFormElements) {
|
|
22
24
|
this.formElements = JSON.parse(savedFormElements);
|
|
23
25
|
this.formElementsSubject.next([...this.formElements]);
|
|
24
|
-
// this.book = JSON.parse(localStorage.getItem('book') || '{}');
|
|
25
26
|
this.unique_id = localStorage.getItem('unique_id');
|
|
26
27
|
}
|
|
28
|
+
this.unique_id = localStorage.getItem('unique_id');
|
|
29
|
+
if (localStorage.getItem('status') === "new") {
|
|
30
|
+
this.unique_id = uuidv4();
|
|
31
|
+
this.book = {
|
|
32
|
+
'bookQuestionsMap': {
|
|
33
|
+
[this.unique_id]: {
|
|
34
|
+
'subQuestions': []
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
'questionbook': {
|
|
38
|
+
"action": "[{\"name\": \"Cancel\", \"eventtoemit\": \"close\", \"alt\":\"\"},{\"name\": \"Save\", \"eventtoemit\": \"submit\", \"alt\":\"\",\"endpoint\":\"\",\"method\":\"POST\"}]"
|
|
39
|
+
},
|
|
40
|
+
'records': [{
|
|
41
|
+
'id': this.unique_id,
|
|
42
|
+
'title': 'Untitled',
|
|
43
|
+
'subQuestions': [{}]
|
|
44
|
+
}]
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
intializeBook(book) {
|
|
49
|
+
this.book = book;
|
|
27
50
|
}
|
|
28
51
|
// AP 26FEB25 - clear the form elements
|
|
29
52
|
clearElements() {
|
|
@@ -47,34 +70,27 @@ export class FormBuilderService {
|
|
|
47
70
|
// this.formElements = JSON.parse(savedFormElements);
|
|
48
71
|
// this.formElementsSubject.next([...this.formElements]);
|
|
49
72
|
// this.book = JSON.parse(localStorage.getItem('book') || '{}');
|
|
50
|
-
this.book
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
},
|
|
72
|
-
'records': [{
|
|
73
|
-
'id': this.unique_id,
|
|
74
|
-
'subQuestions': [{}]
|
|
75
|
-
}]
|
|
76
|
-
};
|
|
77
|
-
}
|
|
73
|
+
// if(localStorage.getItem('status') == "edit" && this.book !== undefined){
|
|
74
|
+
// this.unique_id = localStorage.getItem('unique_id');
|
|
75
|
+
// this.book = {
|
|
76
|
+
// 'bookQuestionsMap': {
|
|
77
|
+
// [this.unique_id]: {
|
|
78
|
+
// 'subQuestions': []
|
|
79
|
+
// }
|
|
80
|
+
// }
|
|
81
|
+
// };
|
|
82
|
+
// if(this.book.questionbook == undefined){
|
|
83
|
+
// this.book['questionbook'] = {
|
|
84
|
+
// "action": "[{\"name\": \"Cancel\", \"eventtoemit\": \"close\", \"alt\":\"\"},{\"name\": \"Save\", \"eventtoemit\": \"submit\", \"alt\":\"\",\"endpoint\":\"\",\"method\":\"POST\"}]"
|
|
85
|
+
// }
|
|
86
|
+
// }
|
|
87
|
+
// if(this.book.records == undefined){
|
|
88
|
+
// this.book['records'] = [{
|
|
89
|
+
// 'id': this.unique_id,
|
|
90
|
+
// 'subQuestions': [{}]
|
|
91
|
+
// }]
|
|
92
|
+
// }
|
|
93
|
+
// }
|
|
78
94
|
// this.unique_id = uuidv4();
|
|
79
95
|
// localStorage.setItem('book', JSON.stringify(this.book));
|
|
80
96
|
localStorage.setItem('unique_id', this.unique_id);
|
|
@@ -104,6 +120,11 @@ export class FormBuilderService {
|
|
|
104
120
|
const questionText = updatedElement.questionText.replace(/\s*\*+$/, '');
|
|
105
121
|
updatedElement.questionText = updates.required ? `${questionText} *` : questionText;
|
|
106
122
|
}
|
|
123
|
+
if (elements[index]) {
|
|
124
|
+
elements[index] = { ...elements[index], ...updates };
|
|
125
|
+
this.formElements = elements;
|
|
126
|
+
this.formElementsSubject.next([...this.formElements]);
|
|
127
|
+
}
|
|
107
128
|
}
|
|
108
129
|
// Handle special cases
|
|
109
130
|
if (updates.required === true && updatedElement.questionText && !updatedElement.questionText.endsWith('*')) {
|
|
@@ -117,22 +138,42 @@ export class FormBuilderService {
|
|
|
117
138
|
// localStorage.setItem('formElements', JSON.stringify(this.formElements));
|
|
118
139
|
}
|
|
119
140
|
}
|
|
141
|
+
updateTitle(event) {
|
|
142
|
+
//AP-10MAR25 Updates the title of the first record in the book
|
|
143
|
+
this.book.records[0].title = event;
|
|
144
|
+
}
|
|
120
145
|
setSelectedElement(index) {
|
|
121
146
|
this.selectedElementSubject.next(index);
|
|
122
147
|
}
|
|
148
|
+
selectHeading(event) {
|
|
149
|
+
//AP-10MAR25 Emits the selected heading event
|
|
150
|
+
this.selectHeaderSubject.next(event);
|
|
151
|
+
}
|
|
123
152
|
getElements() {
|
|
124
153
|
return this.formElements.map(element => ({
|
|
125
154
|
...element,
|
|
126
155
|
options: element.options || [],
|
|
127
156
|
}));
|
|
128
157
|
}
|
|
158
|
+
sortElementsByOrder() {
|
|
159
|
+
//AP-10MAR25 Sort elements by current order
|
|
160
|
+
this.formElements.sort((a, b) => a.order - b.order);
|
|
161
|
+
this.formElements.forEach((element, index) => {
|
|
162
|
+
element.order = index + 1;
|
|
163
|
+
});
|
|
164
|
+
this.formElementsSubject.next([...this.formElements]);
|
|
165
|
+
}
|
|
166
|
+
//AP-10MAR25 Returns the current book data
|
|
167
|
+
getBook() {
|
|
168
|
+
return this.book;
|
|
169
|
+
}
|
|
129
170
|
// In FormBuilderService
|
|
130
171
|
downloadElement() {
|
|
131
172
|
this.book.bookQuestionsMap[this.unique_id].subQuestions = this.formElements;
|
|
132
173
|
console.log('book', this.book.bookQuestionsMap[this.unique_id].subQuestions);
|
|
133
174
|
let tempElement = {};
|
|
134
175
|
this.formElements.forEach((element) => {
|
|
135
|
-
if (element.type === 'Dropdown' || element.type === 'Radio' || element.type === '
|
|
176
|
+
if (element.type === 'Dropdown' || element.type === 'Radio' || element.type === 'Checkbox') {
|
|
136
177
|
//AP 25FEB25 - Store the entire question with its options under its ID
|
|
137
178
|
tempElement[element.id] = {
|
|
138
179
|
...element,
|
|
@@ -170,4 +211,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
170
211
|
providedIn: 'root',
|
|
171
212
|
}]
|
|
172
213
|
}], ctorParameters: () => [] });
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-builder.service.js","sourceRoot":"","sources":["../../../../../projects/nxt-app/src/lib/services/form-builder.service.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AAEvC,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;;AAuDpC,MAAM,OAAO,kBAAkB;IACrB,YAAY,GAAkB,EAAE,CAAC;IACjC,mBAAmB,GAAG,IAAI,eAAe,CAAgB,EAAE,CAAC,CAAC;IAC7D,sBAAsB,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC,CAAC;IACzD,gBAAgB,GAA4B,IAAI,CAAC;IACzD,IAAI,CAAK;IACT,SAAS,CAAM;IACf,QAAQ,CAAQ;IAEhB,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC;IACxD,gBAAgB,GAAG,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,CAAC;IAC9D,yEAAyE;IAEzE;QACE,wCAAwC;QACzC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACtB,MAAM,iBAAiB,GAAG,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QAC/D,IAAI,iBAAiB,EAAG,CAAC;YACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;YAClD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACtD,gEAAgE;YAChE,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACrD,CAAC;IACH,CAAC;IAEH,wCAAwC;IACtC,aAAa;QACX,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACxD,CAAC;IACD,sCAAsC;IACtC,mBAAmB;QACjB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAED,mBAAmB,CAAC,SAA2B;QAC7C,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC;IACpC,CAAC;IAED,gCAAgC;IAChC,UAAU,CAAC,OAAoB;QAE7B,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACrB,OAAO,CAAC,OAAO,GAAG,EAAE,CAAC,CAAC,yBAAyB;QACjD,CAAC;QAED,kEAAkE;QAClE,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAClC,qDAAqD;YACrD,yDAAyD;YACzD,gEAAgE;YAChE,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACf,IAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,MAAM,EAAC,CAAC;gBAC3C,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;gBACnD,IAAI,CAAC,IAAI,GAAG;oBACV,kBAAkB,EAAE;wBACjB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;4BAClB,cAAc,EAAE,EAAE;yBACjB;qBACF;iBACF,CAAC;YAEJ,CAAC;iBAAI,CAAC;gBACL,IAAI,CAAC,SAAS,GAAG,MAAM,EAAE,CAAC;gBAC1B,IAAI,CAAC,IAAI,GAAG;oBACV,kBAAkB,EAAE;wBACjB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;4BAClB,cAAc,EAAE,EAAE;yBACjB;qBACF;oBACD,cAAc,EAAE;wBACf,QAAQ,EAAE,0KAA0K;qBACnL;oBACF,SAAS,EAAE,CAAC;4BACX,IAAI,EAAE,IAAI,CAAC,SAAS;4BACnB,cAAc,EAAE,CAAC,EAAE,CAAC;yBACpB,CAAC;iBACJ,CAAA;YAEH,CAAC;YACF,6BAA6B;YAE3B,2DAA2D;YAC3D,YAAY,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACtD,CAAC;QACD,OAAO,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;QAC3C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAChC,2EAA2E;QAC3E,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACxD,CAAC;IAED,aAAa,CAAC,KAAa,EAAE,OAA6B;QACxD,MAAM,QAAQ,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACzC,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YAClB,QAAQ,CAAC,KAAK,CAAC,GAAG;gBAChB,GAAG,QAAQ,CAAC,KAAK,CAAC;gBAClB,GAAG,OAAO;gBACV,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,QAAQ,CAAC,KAAK,CAAC,CAAC,OAAO,IAAI,EAAE;aAC1D,CAAC;YACF,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1C,CAAC;QAEH,IAAI,KAAK,IAAI,CAAC,IAAI,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;YACnD,MAAM,cAAc,GAAG;gBACrB,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;gBAC3B,GAAG,OAAO;aACX,CAAC;YACF,IAAI,OAAO,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;gBACnC,IAAI,cAAc,CAAC,YAAY,EAAE,CAAC;oBAChC,MAAM,YAAY,GAAG,cAAc,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;oBACxE,cAAc,CAAC,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,YAAY,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC;gBACtF,CAAC;YACH,CAAC;YAED,uBAAuB;YACvB,IAAI,OAAO,CAAC,QAAQ,KAAK,IAAI,IAAI,cAAc,CAAC,YAAY,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC3G,cAAc,CAAC,YAAY,GAAG,GAAG,cAAc,CAAC,YAAY,IAAI,CAAC;YACnE,CAAC;iBAAM,IAAI,OAAO,CAAC,QAAQ,KAAK,KAAK,IAAI,cAAc,CAAC,YAAY,IAAI,cAAc,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBAClH,cAAc,CAAC,YAAY,GAAG,cAAc,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC3E,CAAC;YAEC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,cAAc,CAAC;YAC1C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACtD,2EAA2E;QAC7E,CAAC;IACH,CAAC;IAED,kBAAkB,CAAC,KAAa;QAC9B,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YACvC,GAAG,OAAO;YACV,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,EAAE;SAC/B,CAAC,CAAC,CAAC;IACN,CAAC;IACF,wBAAwB;IACzB,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;QAC5E,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,CAAC;QAC7E,IAAI,WAAW,GAAQ,EAAE,CAAC;QAE1B,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACpC,IAAI,OAAO,CAAC,IAAI,KAAK,UAAU,IAAI,OAAO,CAAC,IAAI,KAAK,OAAO,IAAI,OAAO,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;gBAC3F,sEAAsE;gBACtE,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,GAAG;oBACxB,GAAG,OAAO;oBACV,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,EAAE;iBAC/B,CAAC;YACJ,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IACD,wCAAwC;IACxC,mBAAmB,CAAC,eAA8B;QAChD,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,eAAe,CAAC,CAAC;QACzC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;IACD,0BAA0B;IAC1B,uDAAuD;IACvD,sBAAsB,CAAC,EAAO;QAC5B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;YACzC,IAAI,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC;gBACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC9B,CAAC;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC;QAClC,2EAA2E;QAC3E,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACxD,CAAC;wGA7KU,kBAAkB;4GAAlB,kBAAkB,cAFjB,MAAM;;4FAEP,kBAAkB;kBAH9B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["// AP 22JAN25\nimport { Injectable } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport { ElementComponent } from '../pages/builder/element/element.component';\nimport { v4 as uuidv4 } from 'uuid';\ninterface FormElement {\n  id: any;\n  name: any;\n  value?: any;\n  required?: boolean;\n  type: string;\n  questionText?: string;\n  question?: string;\n  helpText?: string;\n  errorMessage?: string;\n  isReadOnly?: boolean;\n  isHidden?: boolean;\n  isDateBackward?: boolean;\n  isDateForward?: boolean;\n  isOptional?: boolean;\n  isTitle?: boolean;\n  nextQuestion?: string;\n  allowedFileExtensions?: string;\n  questionNumber?: number;\n  questionBookId?: string;\n  size?: number;\n  parentQuestion?: string;\n  subText?: string;\n  fieldsMeta?: string;\n  recordTypeName?: string;\n  recordTypeId?: string;\n  trackingId?: string;\n  dateText?: string;\n  timeText?: string;\n  recordId?: string;\n  qbReference?: string;\n  qbReferenceQuestions?: string;\n  questionBookSubTitle?: string;\n  style?: string;\n  title?: string;\n  subTitle?: string;\n  referenceField?: string;\n  additionalRichContent?: string;\n  groupName?: string;\n  x24Hours?: boolean;\n// AP 25FEB25 - options array\n  options?: Array<{\n    value: string;\n    uniqueIdentifier: string;\n    questionId: string;\n    nextQuestion: any;\n    name: string;\n    id: string;\n}>;\n\n}\n@Injectable({\n  providedIn: 'root',\n})\nexport class FormBuilderService {\n  private formElements: FormElement[] = [];\n  private formElementsSubject = new BehaviorSubject<FormElement[]>([]);\n  private selectedElementSubject = new BehaviorSubject<number>(-1);\n  private elementComponent: ElementComponent | null = null;\n  book:any;\n  unique_id: any;\n  tempElem: any[];\n\n  formElements$ = this.formElementsSubject.asObservable();\n  selectedElement$ = this.selectedElementSubject.asObservable();\n  // book: { bookQuestionsMap: { unique_id: { subQuestions: any[]; }; }; };\n\n  constructor() {\n    // Load saved elements from localStorage\n   this.formElements = [];\n    const savedFormElements = localStorage.getItem('formElements');\n    if (savedFormElements ) {\n      this.formElements = JSON.parse(savedFormElements);\n      this.formElementsSubject.next([...this.formElements]);\n      // this.book = JSON.parse(localStorage.getItem('book') || '{}');\n      this.unique_id = localStorage.getItem('unique_id');\n    }\n  }\n  \n// AP 26FEB25 - clear the form elements \n  clearElements() {\n    this.formElements = [];\n    this.formElementsSubject.next([...this.formElements]);\n  }\n  // Get the element component reference\n  getElementComponent(): ElementComponent | null {\n    return this.elementComponent;\n  }\n\n  setElementComponent(component: ElementComponent) {\n    this.elementComponent = component;\n  }\n\n  // Add a new element to the form\n  addElement(element: FormElement): void {\n\n    if (!element.options) {\n      element.options = []; // options is initialized\n    }\n\n    // const savedFormElements = localStorage.getItem('formElements');\n    if (this.formElements.length == 0) {\n      // this.formElements = JSON.parse(savedFormElements);\n      // this.formElementsSubject.next([...this.formElements]);\n      // this.book = JSON.parse(localStorage.getItem('book') || '{}');\n      this.book = {};\n      if(localStorage.getItem('status') == \"edit\"){\n        this.unique_id = localStorage.getItem('unique_id');\n        this.book = {\n          'bookQuestionsMap': {\n             [this.unique_id]: {\n             'subQuestions': []\n             }\n           }\n         };\n\n       }else{\n        this.unique_id = uuidv4();\n        this.book = {\n          'bookQuestionsMap': {\n             [this.unique_id]: {\n             'subQuestions': []\n             }\n           },\n           'questionbook': {\n            \"action\": \"[{\\\"name\\\": \\\"Cancel\\\", \\\"eventtoemit\\\": \\\"close\\\", \\\"alt\\\":\\\"\\\"},{\\\"name\\\": \\\"Save\\\", \\\"eventtoemit\\\": \\\"submit\\\", \\\"alt\\\":\\\"\\\",\\\"endpoint\\\":\\\"\\\",\\\"method\\\":\\\"POST\\\"}]\"\n            },\n           'records': [{\n            'id': this.unique_id,\n             'subQuestions': [{}]\n            }]\n         }\n\n       }\n      // this.unique_id = uuidv4();\n\n        // localStorage.setItem('book', JSON.stringify(this.book));\n        localStorage.setItem('unique_id', this.unique_id);\n    }\n    element['questionBookId'] = this.unique_id;\n    this.formElements.push(element);\n    // localStorage.setItem('formElements', JSON.stringify(this.formElements));\n    this.formElementsSubject.next([...this.formElements]);\n  }\n\n  updateElement(index: number, updates: Partial<FormElement>) {\n    const elements = [...this.getElements()];\n    if (elements[index]) {\n        elements[index] = {\n          ...elements[index],\n          ...updates,\n          options: updates.options || elements[index].options || [],\n        };\n        this.formElementsSubject.next(elements);\n      }\n\n    if (index >= 0 && index < this.formElements.length) {\n      const updatedElement = {\n        ...this.formElements[index],\n        ...updates\n      };\n      if (updates.required !== undefined) {\n        if (updatedElement.questionText) {\n          const questionText = updatedElement.questionText.replace(/\\s*\\*+$/, '');\n          updatedElement.questionText = updates.required ? `${questionText} *` : questionText;\n        }\n      }\n\n      // Handle special cases\n      if (updates.required === true && updatedElement.questionText && !updatedElement.questionText.endsWith('*')) {\n        updatedElement.questionText = `${updatedElement.questionText} *`;\n      } else if (updates.required === false && updatedElement.questionText && updatedElement.questionText.endsWith('*')) {\n        updatedElement.questionText = updatedElement.questionText.slice(0, -2);\n    }\n\n      this.formElements[index] = updatedElement;\n      this.formElementsSubject.next([...this.formElements]);\n      // localStorage.setItem('formElements', JSON.stringify(this.formElements));\n    }\n  }\n\n  setSelectedElement(index: number) {\n    this.selectedElementSubject.next(index);\n  }\n\n  getElements(): FormElement[] {\n    return this.formElements.map(element => ({\n      ...element,\n      options: element.options || [],     \n    }));\n  }\n // In FormBuilderService\ndownloadElement() {\n  this.book.bookQuestionsMap[this.unique_id].subQuestions = this.formElements;\n  console.log('book', this.book.bookQuestionsMap[this.unique_id].subQuestions);\n  let tempElement: any = {};\n\n  this.formElements.forEach((element) => {\n    if (element.type === 'Dropdown' || element.type === 'Radio' || element.type === 'CheckBox') {\n      //AP 25FEB25 - Store the entire question with its options under its ID\n      tempElement[element.id] = {\n        ...element,\n        options: element.options || []\n      };\n    }\n  });\n\n  this.book.sqOptions = tempElement;\n    return this.book;\n  }\n  // AP-06MAR25 - Element new order update\n  updateElementsOrder(updatedElements: FormElement[]): void {\n    this.formElements = [...updatedElements];\n    this.formElementsSubject.next(this.formElements);\n  }\n  // Remove an element by ID\n  // Save elements to localStorage and update the subject\n  removeElementComponent(id: any) {\n    this.tempElem = [];\n    this.formElements.forEach((element: any) => {\n      if (element.id !== id) {\n        this.tempElem.push(element);\n      }\n    });\n    this.formElements = this.tempElem;\n    // localStorage.setItem('formElements', JSON.stringify(this.formElements));\n    this.formElementsSubject.next([...this.formElements]);\n  }\n}\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-builder.service.js","sourceRoot":"","sources":["../../../../../projects/nxt-app/src/lib/services/form-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["// AP 22JAN25\nimport { Injectable } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport { ElementComponent } from '../pages/builder/element/element.component';\nimport { v4 as uuidv4 } from 'uuid';\ninterface FormElement {\n  order: number;\n  id: any;\n  name: any;\n  value?: any;\n  required?: boolean;\n  type: string;\n  questionText?: string;\n  question?: string;\n  helpText?: string;\n  errorMessage?: string;\n  isReadOnly?: boolean;\n  isHidden?: boolean;\n  isDateBackward?: boolean;\n  isDateForward?: boolean;\n  isOptional?: boolean;\n  isTitle?: boolean;\n  nextQuestion?: string;\n  allowedFileExtensions?: string;\n  questionNumber?: number;\n  questionBookId?: string;\n  size?: number;\n  parentQuestion?: string;\n  subText?: string;\n  fieldsMeta?: string;\n  recordTypeName?: string;\n  recordTypeId?: string;\n  trackingId?: string;\n  dateText?: string;\n  timeText?: string;\n  recordId?: string;\n  qbReference?: string;\n  qbReferenceQuestions?: string;\n  questionBookSubTitle?: string;\n  style?: string;\n  title?: string;\n  subTitle?: string;\n  referenceField?: string;\n  additionalRichContent?: string;\n  groupName?: string;\n  x24Hours?: boolean;\n// AP 25FEB25 - options array\n  options?: Array<{\n    value: string;\n    uniqueIdentifier: string;\n    questionId: string;\n    nextQuestion: any;\n    name: string;\n    id: string;\n}>;\n\n}\n@Injectable({\n  providedIn: 'root',\n})\nexport class FormBuilderService {\n  private formElements: FormElement[] = [];\n  private formElementsSubject = new BehaviorSubject<FormElement[]>([]);\n  private selectedElementSubject = new BehaviorSubject<number>(-1);\n  private selectHeaderSubject = new BehaviorSubject<any>(null);\n  private elementComponent: ElementComponent | null = null;\n  book:any;\n  unique_id: any;\n  tempElem: any[];\n\n  formElements$ = this.formElementsSubject.asObservable();\n  selectedElement$ = this.selectedElementSubject.asObservable();\n  selectHeaderSubject$ = this.selectHeaderSubject.asObservable();\n  // book: { bookQuestionsMap: { unique_id: { subQuestions: any[]; }; }; };\n\n  constructor() {\n    // Load saved elements from localStorage\n   this.formElements = [];\n    const savedFormElements = localStorage.getItem('formElements');\n    if (savedFormElements ) {\n      this.formElements = JSON.parse(savedFormElements);\n      this.formElementsSubject.next([...this.formElements]);\n      this.unique_id = localStorage.getItem('unique_id');\n    }\n    this.unique_id = localStorage.getItem('unique_id');\n    \n     if(localStorage.getItem('status') === \"new\"){\n      this.unique_id = uuidv4();\n    this.book = {\n      'bookQuestionsMap': {\n         [this.unique_id]: {\n         'subQuestions': []\n         }\n       },\n       'questionbook': {\n        \"action\": \"[{\\\"name\\\": \\\"Cancel\\\", \\\"eventtoemit\\\": \\\"close\\\", \\\"alt\\\":\\\"\\\"},{\\\"name\\\": \\\"Save\\\", \\\"eventtoemit\\\": \\\"submit\\\", \\\"alt\\\":\\\"\\\",\\\"endpoint\\\":\\\"\\\",\\\"method\\\":\\\"POST\\\"}]\"\n        },\n       'records': [{\n        'id': this.unique_id,\n        'title': 'Untitled',\n         'subQuestions': [{}]\n        }]\n     }\n      \n     }\n  }\n  intializeBook(book : any){\n    this.book = book;\n  }\n\n// AP 26FEB25 - clear the form elements \n  clearElements() {\n    this.formElements = [];\n    this.formElementsSubject.next([...this.formElements]);\n  }\n  // Get the element component reference\n  getElementComponent(): ElementComponent | null {\n    return this.elementComponent;\n  }\n\n  setElementComponent(component: ElementComponent) {\n    this.elementComponent = component;\n  }\n\n  // Add a new element to the form\n  addElement(element: FormElement): void {\n\n    if (!element.options) {\n      element.options = []; // options is initialized\n    }\n\n    // const savedFormElements = localStorage.getItem('formElements');\n    if (this.formElements.length == 0) {\n      // this.formElements = JSON.parse(savedFormElements);\n      // this.formElementsSubject.next([...this.formElements]);\n      // this.book = JSON.parse(localStorage.getItem('book') || '{}');\n\n      // if(localStorage.getItem('status') == \"edit\" && this.book !== undefined){\n      //   this.unique_id = localStorage.getItem('unique_id');\n      //   this.book = {\n      //     'bookQuestionsMap': {\n      //        [this.unique_id]: {\n      //        'subQuestions': []\n      //        }\n      //      }\n      //    };\n      //    if(this.book.questionbook == undefined){\n      //     this.book['questionbook'] = {\n      //       \"action\": \"[{\\\"name\\\": \\\"Cancel\\\", \\\"eventtoemit\\\": \\\"close\\\", \\\"alt\\\":\\\"\\\"},{\\\"name\\\": \\\"Save\\\", \\\"eventtoemit\\\": \\\"submit\\\", \\\"alt\\\":\\\"\\\",\\\"endpoint\\\":\\\"\\\",\\\"method\\\":\\\"POST\\\"}]\"\n      //    }\n      //    }\n         \n      //    if(this.book.records == undefined){\n      //     this.book['records'] = [{\n      //       'id': this.unique_id,\n      //        'subQuestions': [{}]\n      //       }]\n      //    }\n\n      //  }\n      // this.unique_id = uuidv4();\n\n        // localStorage.setItem('book', JSON.stringify(this.book));\n        localStorage.setItem('unique_id', this.unique_id);\n    }\n    element['questionBookId'] = this.unique_id;\n    this.formElements.push(element);\n    // localStorage.setItem('formElements', JSON.stringify(this.formElements));\n    this.formElementsSubject.next([...this.formElements]);\n  }\n\n  updateElement(index: number, updates: Partial<FormElement>) {\n    const elements = [...this.getElements()];\n    if (elements[index]) {\n        elements[index] = {\n          ...elements[index],\n          ...updates,\n          options: updates.options || elements[index].options || [],\n        };\n        this.formElementsSubject.next(elements);\n      }\n\n    if (index >= 0 && index < this.formElements.length) {\n      const updatedElement = {\n        ...this.formElements[index],\n        ...updates\n      };\n      if (updates.required !== undefined) {\n        if (updatedElement.questionText) {\n          const questionText = updatedElement.questionText.replace(/\\s*\\*+$/, '');\n          updatedElement.questionText = updates.required ? `${questionText} *` : questionText;\n        }\n        if (elements[index]) {\n          elements[index] = { ...elements[index], ...updates };\n          this.formElements = elements;\n          this.formElementsSubject.next([...this.formElements]);\n        }\n      }\n\n      // Handle special cases\n      if (updates.required === true && updatedElement.questionText && !updatedElement.questionText.endsWith('*')) {\n        updatedElement.questionText = `${updatedElement.questionText} *`;\n      } else if (updates.required === false && updatedElement.questionText && updatedElement.questionText.endsWith('*')) {\n        updatedElement.questionText = updatedElement.questionText.slice(0, -2);\n    }\n\n      this.formElements[index] = updatedElement;\n      this.formElementsSubject.next([...this.formElements]);\n      // localStorage.setItem('formElements', JSON.stringify(this.formElements));\n    }\n  }\nupdateTitle(event: any){\n  //AP-10MAR25 Updates the title of the first record in the book  \n  this.book.records[0].title = event;\n}\n  setSelectedElement(index: number) {\n    this.selectedElementSubject.next(index);\n  }\n\n  selectHeading(event: any) {\n    //AP-10MAR25 Emits the selected heading event  \n    this.selectHeaderSubject.next(event);\n  }\n\n\n  getElements(): FormElement[] {\n    return this.formElements.map(element => ({\n      ...element,\n      options: element.options || [],     \n    }));\n  }\n  sortElementsByOrder(): void {\n    //AP-10MAR25 Sort elements by current order\n    this.formElements.sort((a, b) => a.order - b.order);\n    this.formElements.forEach((element, index) => {\n      element.order = index + 1;\n    });\n    this.formElementsSubject.next([...this.formElements]);\n  }\n  //AP-10MAR25 Returns the current book data  \n getBook(){\n    return this.book;\n }\n // In FormBuilderService\n downloadElement() {\n  this.book.bookQuestionsMap[this.unique_id].subQuestions = this.formElements;\n  console.log('book', this.book.bookQuestionsMap[this.unique_id].subQuestions);\n  let tempElement: any = {};\n\n  this.formElements.forEach((element) => {\n    if (element.type === 'Dropdown' || element.type === 'Radio' || element.type === 'Checkbox') {\n      //AP 25FEB25 - Store the entire question with its options under its ID\n      tempElement[element.id] = {\n        ...element,\n        options: element.options || []\n      };\n    }\n  });\n\n  this.book.sqOptions = tempElement;\n    return this.book;\n  }\n  // AP-06MAR25 - Element new order update\n  updateElementsOrder(updatedElements: FormElement[]): void {\n    this.formElements = [...updatedElements];\n    this.formElementsSubject.next(this.formElements);\n  }\n  // Remove an element by ID\n  // Save elements to localStorage and update the subject\n  removeElementComponent(id: any) {\n    this.tempElem = [];\n    this.formElements.forEach((element: any) => {\n      if (element.id !== id) {\n        this.tempElem.push(element);\n      }\n    });\n    this.formElements = this.tempElem;\n    // localStorage.setItem('formElements', JSON.stringify(this.formElements));\n    this.formElementsSubject.next([...this.formElements]);\n  }\n}\n"]}
|