@piserve-tech/form-submission 1.3.267 → 1.3.269
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.
|
@@ -34,7 +34,7 @@ export class FormService {
|
|
|
34
34
|
.set('progressiveLoading', progressiveLoading);
|
|
35
35
|
return this.http.get(`${this.apiUrl}/api/public/forms/${moduleName}`, {
|
|
36
36
|
headers,
|
|
37
|
-
params
|
|
37
|
+
params,
|
|
38
38
|
});
|
|
39
39
|
}
|
|
40
40
|
fetchDataFromDatabase(database) {
|
|
@@ -52,54 +52,137 @@ export class FormService {
|
|
|
52
52
|
apiConfig.params?.some((p) => p.valueSource === 'PAGE_SIZE');
|
|
53
53
|
// ---------------------- HEADERS ----------------------
|
|
54
54
|
let headers = new HttpHeaders();
|
|
55
|
+
// helper: resolve a value (or values) based on valueSource
|
|
56
|
+
// Apply to headers (assuming `headers` is an HttpHeaders instance)
|
|
55
57
|
if (apiConfig.headers) {
|
|
56
58
|
apiConfig.headers.forEach((header) => {
|
|
57
|
-
if (header.keyName)
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
}
|
|
59
|
+
if (!header.keyName)
|
|
60
|
+
return;
|
|
61
|
+
const rawValue = resolveValueFromSource(header.valueSource, header.inputValue, selectedValues);
|
|
62
|
+
if (header.valueSource === 'SELECTED_VALUES') {
|
|
63
|
+
// Only add header if we have selected values
|
|
64
|
+
if (Array.isArray(rawValue) && rawValue.length > 0) {
|
|
65
|
+
if (header.inputValue === 'SINGLE_VALUE') {
|
|
66
|
+
headers = headers.set(header.keyName, String(rawValue[0]));
|
|
66
67
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
if (header.keyName.toLowerCase() === 'authorization') {
|
|
71
|
-
headers = headers.set(header.keyName, 'Bearer ' + header.inputValue);
|
|
68
|
+
else if (header.inputValue === 'ARRAY_OF_VALUES') {
|
|
69
|
+
// join by comma for headers (common pattern)
|
|
70
|
+
headers = headers.set(header.keyName, rawValue.join(','));
|
|
72
71
|
}
|
|
73
72
|
else {
|
|
74
|
-
|
|
73
|
+
// fallback: join
|
|
74
|
+
headers = headers.set(header.keyName, rawValue.join(','));
|
|
75
75
|
}
|
|
76
76
|
}
|
|
77
|
+
// no selected values -> skip header
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
// For non-selected sources: skip when unresolved
|
|
81
|
+
if (rawValue === null || rawValue === undefined)
|
|
82
|
+
return;
|
|
83
|
+
// If rawValue is array -> join by comma (headers expect single string)
|
|
84
|
+
const headerValue = Array.isArray(rawValue)
|
|
85
|
+
? rawValue.join(',')
|
|
86
|
+
: String(rawValue);
|
|
87
|
+
if (header.keyName.toLowerCase() === 'authorization') {
|
|
88
|
+
// add Bearer only when headerValue is truthy (and not already prefixed)
|
|
89
|
+
const token = headerValue.startsWith('Bearer ')
|
|
90
|
+
? headerValue
|
|
91
|
+
: `Bearer ${headerValue}`;
|
|
92
|
+
headers = headers.set(header.keyName, token);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
headers = headers.set(header.keyName, headerValue);
|
|
77
96
|
}
|
|
78
97
|
});
|
|
79
98
|
}
|
|
80
99
|
// ---------------------- PARAMS ----------------------
|
|
81
100
|
let params = new HttpParams();
|
|
101
|
+
// helper: resolve a value (or values) based on valueSource
|
|
102
|
+
function resolveValueFromSource(valueSource, inputValue, selectedValues = []) {
|
|
103
|
+
if (!valueSource)
|
|
104
|
+
return null;
|
|
105
|
+
switch (valueSource) {
|
|
106
|
+
case 'LOCAL_STORAGE':
|
|
107
|
+
return localStorage.getItem(inputValue); // string or null
|
|
108
|
+
case 'SESSION_STORAGE':
|
|
109
|
+
return sessionStorage.getItem(inputValue); // string or null
|
|
110
|
+
case 'CUSTOM_INPUT':
|
|
111
|
+
case 'QUESTION':
|
|
112
|
+
case 'PAGE_INDEX':
|
|
113
|
+
case 'PAGE_SIZE':
|
|
114
|
+
// inputValue may be a single value or an array/CSV depending on usage
|
|
115
|
+
return inputValue;
|
|
116
|
+
case 'SELECTED_VALUES':
|
|
117
|
+
// For SELECTED_VALUES, return the selectedValues array (caller decides SINGLE/ARRAY behavior)
|
|
118
|
+
return Array.isArray(selectedValues) ? selectedValues : [];
|
|
119
|
+
default:
|
|
120
|
+
console.warn(`Unsupported valueSource for params: ${valueSource}`);
|
|
121
|
+
return null;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
// Usage: build params (assuming `params` is an HttpParams instance)
|
|
82
125
|
if (apiConfig.params) {
|
|
83
126
|
apiConfig.params.forEach((param) => {
|
|
84
|
-
if (param.keyName)
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
127
|
+
if (!param.keyName)
|
|
128
|
+
return;
|
|
129
|
+
// Resolve raw value based on source
|
|
130
|
+
const rawValue = resolveValueFromSource(param.valueSource, param.inputValue, selectedValues);
|
|
131
|
+
// If param expects selected values, handle SINGLE_VALUE vs ARRAY_OF_VALUES
|
|
132
|
+
if (param.valueSource === 'SELECTED_VALUES') {
|
|
133
|
+
// Only add if there are actual selected values
|
|
134
|
+
if (Array.isArray(rawValue) && rawValue.length > 0) {
|
|
135
|
+
if (param.inputValue === 'SINGLE_VALUE') {
|
|
136
|
+
// set to first selected value
|
|
137
|
+
params = params.set(param.keyName, rawValue[0]);
|
|
138
|
+
}
|
|
139
|
+
else if (param.inputValue === 'ARRAY_OF_VALUES') {
|
|
140
|
+
// append each selected value as repeated param
|
|
141
|
+
rawValue.forEach((val) => {
|
|
142
|
+
params = params.append(param.keyName, val);
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
// if inputValue not provided, default to array behavior
|
|
147
|
+
rawValue.forEach((val) => {
|
|
148
|
+
params = params.append(param.keyName, val);
|
|
149
|
+
});
|
|
96
150
|
}
|
|
97
|
-
// ❌ If no values, do nothing (skip param entirely)
|
|
98
151
|
}
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
152
|
+
// if no selected values, skip adding this param
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
// For non-selected valueSources: rawValue could be null/undefined/string/array
|
|
156
|
+
if (rawValue === null || rawValue === undefined) {
|
|
157
|
+
// skip adding param when value not found
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
// If inputValue indicates array-of-values (e.g., param.inputValue === 'ARRAY_OF_VALUES'),
|
|
161
|
+
// accept either an array or a comma-separated string
|
|
162
|
+
if (param.inputValue === 'ARRAY_OF_VALUES') {
|
|
163
|
+
if (Array.isArray(rawValue)) {
|
|
164
|
+
rawValue.forEach((val) => {
|
|
165
|
+
params = params.append(param.keyName, val);
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
else if (typeof rawValue === 'string') {
|
|
169
|
+
// support comma separated string
|
|
170
|
+
rawValue
|
|
171
|
+
.split(',')
|
|
172
|
+
.map((s) => s.trim())
|
|
173
|
+
.filter(Boolean)
|
|
174
|
+
.forEach((val) => {
|
|
175
|
+
params = params.append(param.keyName, val);
|
|
176
|
+
});
|
|
102
177
|
}
|
|
178
|
+
else {
|
|
179
|
+
// fallback: convert to string and append
|
|
180
|
+
params = params.append(param.keyName, String(rawValue));
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
// default: set single value
|
|
185
|
+
params = params.set(param.keyName, String(rawValue));
|
|
103
186
|
}
|
|
104
187
|
});
|
|
105
188
|
}
|
|
@@ -107,8 +190,25 @@ export class FormService {
|
|
|
107
190
|
let url = apiConfig.url;
|
|
108
191
|
if (apiConfig.pathVariables) {
|
|
109
192
|
apiConfig.pathVariables.forEach((pathVar) => {
|
|
110
|
-
if (pathVar.keyName
|
|
111
|
-
|
|
193
|
+
if (pathVar.keyName) {
|
|
194
|
+
let valueToBind = null;
|
|
195
|
+
switch (pathVar.valueSource) {
|
|
196
|
+
case 'LOCAL_STORAGE':
|
|
197
|
+
valueToBind = localStorage.getItem(pathVar.inputValue);
|
|
198
|
+
break;
|
|
199
|
+
case 'SESSION_STORAGE':
|
|
200
|
+
valueToBind = sessionStorage.getItem(pathVar.inputValue);
|
|
201
|
+
break;
|
|
202
|
+
case 'CUSTOM_INPUT':
|
|
203
|
+
case 'QUESTION':
|
|
204
|
+
valueToBind = pathVar.inputValue;
|
|
205
|
+
break;
|
|
206
|
+
default:
|
|
207
|
+
console.warn(`Unsupported valueSource: ${pathVar.valueSource}`);
|
|
208
|
+
}
|
|
209
|
+
if (valueToBind !== null && valueToBind !== undefined) {
|
|
210
|
+
url = url.replace(`{${pathVar.keyName}}`, valueToBind);
|
|
211
|
+
}
|
|
112
212
|
}
|
|
113
213
|
});
|
|
114
214
|
}
|
|
@@ -124,7 +224,7 @@ export class FormService {
|
|
|
124
224
|
formData.append('recaptchaToken', reCAPTCHAToken);
|
|
125
225
|
}
|
|
126
226
|
return this.http.post(url, formData, {
|
|
127
|
-
headers
|
|
227
|
+
headers,
|
|
128
228
|
});
|
|
129
229
|
}
|
|
130
230
|
getSubmittedForm(moduleName, submissionId, pageNumber = 1, rowSet = 0, navigateTo) {
|
|
@@ -153,7 +253,7 @@ export class FormService {
|
|
|
153
253
|
formData.append('recaptchaToken', reCAPTCHAToken);
|
|
154
254
|
}
|
|
155
255
|
return this.http.put(url, formData, {
|
|
156
|
-
headers
|
|
256
|
+
headers,
|
|
157
257
|
});
|
|
158
258
|
}
|
|
159
259
|
previewFile(url) {
|
|
@@ -170,8 +270,9 @@ export class FormService {
|
|
|
170
270
|
return this.http.get(this.apiUrl + `/api/cdn/preview${fullUrl}`, options);
|
|
171
271
|
}
|
|
172
272
|
getSubformSubmissions(subFormData) {
|
|
173
|
-
if (!subFormData?.moduleName ||
|
|
174
|
-
|
|
273
|
+
if (!subFormData?.moduleName ||
|
|
274
|
+
!subFormData?.duplicateSubmission?.sourceSubmissionIds) {
|
|
275
|
+
console.error('Invalid subFormData', subFormData);
|
|
175
276
|
return;
|
|
176
277
|
}
|
|
177
278
|
// Extract data
|
|
@@ -179,8 +280,8 @@ export class FormService {
|
|
|
179
280
|
const submissionIds = subFormData.duplicateSubmission.sourceSubmissionIds;
|
|
180
281
|
// Build query string
|
|
181
282
|
const queryParams = submissionIds
|
|
182
|
-
.map(id => `submissionIds=${encodeURIComponent(id)}`)
|
|
183
|
-
.join(
|
|
283
|
+
.map((id) => `submissionIds=${encodeURIComponent(id)}`)
|
|
284
|
+
.join('&');
|
|
184
285
|
// Final URL
|
|
185
286
|
const url = `${this.apiUrl}/api/public/${moduleName}/subform-submissions?${queryParams}`;
|
|
186
287
|
// Now make API call
|
|
@@ -195,4 +296,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
195
296
|
providedIn: 'root',
|
|
196
297
|
}]
|
|
197
298
|
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.DataService }]; } });
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.service.js","sourceRoot":"","sources":["../../../../projects/form-submission/src/services/form.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';\nimport { DataService } from './data.service';\nimport { Observable } from 'rxjs';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class FormService {\n  private apiUrl: string = '';\n  header: any = {};\n  parentQuestions: any;\n  subformData:any;\n\n  constructor(private http: HttpClient, private dataService: DataService) {\n    this.dataService.apiUrl$.subscribe((data) => {\n      this.apiUrl = data;\n    });\n\n    this.dataService.header$.subscribe((data) => {\n      this.header = data;\n    });\n\n    this.dataService.parentQuestions$.subscribe((questions) => {\n      if (questions) {\n        this.parentQuestions = questions;\n      }\n    });\n\n    this.dataService.subform$.subscribe((data)=>{\n      this.subformData = data;\n    })\n  }\n\n  getQuestions(moduleName: string, pageNumber: number = 1, rowSet: number = 0, progressiveLoading: boolean=true) {\n    const headers = new HttpHeaders({\n        'Accept-Language': this.header.acceptedLanguage,\n    });\n\n    const params = new HttpParams()\n        .set('pageNumber', pageNumber.toString())\n        .set('rowSet', rowSet.toString())\n        .set('progressiveLoading', progressiveLoading);\n\n    return this.http.get<any>(`${this.apiUrl}/api/public/forms/${moduleName}`, {\n        headers,\n        params\n    });\n  }\n\n  fetchDataFromDatabase(database: any) {\n    const headers = new HttpHeaders({ 'Content-Type': 'application/json' });\n    return this.http.post<any>(`${this.apiUrl}/api/load-from-db`, database, {\n      headers,\n    });\n  }\n\n  fetchDataFromLookup(tableName: string) {\n    return this.http.get<any>(`${this.apiUrl}/api/public/lookup/${tableName}`);\n  }\n\n  fetchDataFromExternalAPI(apiConfig: any, selectedValues: any[] = []): Observable<any> {\n\n    // ✅ Check if pagination exists\n    const hasPagination =\n      apiConfig.params?.some((p: any) => p.valueSource === 'PAGE_INDEX') &&\n      apiConfig.params?.some((p: any) => p.valueSource === 'PAGE_SIZE');\n\n\n    // ---------------------- HEADERS ----------------------\n    let headers = new HttpHeaders();\n    if (apiConfig.headers) {\n      apiConfig.headers.forEach((header: any) => {\n        if (header.keyName) {\n          if (header.valueSource === 'SELECTED_VALUES') {\n            if (selectedValues.length > 0) {\n              if (header.inputValue === 'SINGLE_VALUE') {\n                headers = headers.set(header.keyName, selectedValues[0]);\n              } else if (header.inputValue === 'ARRAY_OF_VALUES') {\n                headers = headers.set(header.keyName, selectedValues.join(','));\n              }\n            }\n            // ❌ else skip\n          } else if (header.inputValue) {\n            if (header.keyName.toLowerCase() === 'authorization') {\n              headers = headers.set(\n                header.keyName,\n                'Bearer ' + header.inputValue\n              );\n            } else {\n              headers = headers.set(header.keyName, header.inputValue);\n            }\n          }\n        }\n      });\n    }\n\n    // ---------------------- PARAMS ----------------------\n    let params = new HttpParams();\n    if (apiConfig.params) {\n      apiConfig.params.forEach((param: any) => {\n        if (param.keyName) {\n          if (param.valueSource === 'SELECTED_VALUES') {\n            // ✅ Only add selectedIds if values exist\n            if (selectedValues.length > 0) {\n              if (param.inputValue === 'SINGLE_VALUE') {\n                params = params.set(param.keyName, selectedValues[0]);\n              } else if (param.inputValue === 'ARRAY_OF_VALUES') {\n                selectedValues.forEach((val) => {\n                  params = params.append(param.keyName, val);\n                });\n              }\n            }\n            // ❌ If no values, do nothing (skip param entirely)\n          } else if (param.inputValue) {\n            // Normal custom or search params\n            params = params.set(param.keyName, param.inputValue);\n          }\n        }\n      });\n    }\n\n    // ---------------------- PATH VARIABLES ----------------------\n    let url = apiConfig.url;\n    if (apiConfig.pathVariables) {\n      apiConfig.pathVariables.forEach((pathVar: any) => {\n        if (pathVar.keyName && pathVar.inputValue) {\n          url = url.replace(`{${pathVar.keyName}}`, pathVar.inputValue);\n        }\n      });\n    }\n\n    // ---------------------- FINAL CALL ----------------------\n    return this.http.get<any>(url, { headers, params });\n  }\n\n  submitForm(moduleName: string, formData: FormData, reCAPTCHAToken?:string): Observable<any> {\n    const headers = new HttpHeaders({\n      'Auth-user': this.header.authUser,\n    });\n    const url = `${this.apiUrl}/api/public/forms/${moduleName}/submissions`;\n    if (reCAPTCHAToken) {\n      formData.append('recaptchaToken', reCAPTCHAToken);\n    }\n    return this.http.post(url, formData, {\n      headers\n    });\n  }\n\n  getSubmittedForm(moduleName: string, submissionId: string, pageNumber: number = 1, rowSet: number = 0,navigateTo?:string): Observable<any> {\n    let params = new HttpParams()\n      .set('pageNumber', pageNumber.toString())\n      .set('rowSet', rowSet.toString());\n      if(navigateTo){\n        params = params.set('navigateId', navigateTo);\n      }\n\n    if (this.parentQuestions) {\n      this.parentQuestions.forEach((q: any) => {\n        params = params.append('parentQuestions', q);\n      });\n    }\n        const headers = new HttpHeaders({\n        'Accept-Language': this.header.acceptedLanguage,\n    });\n    return this.http.get<any>(`${this.apiUrl}/api/forms/${moduleName}/submissions/${submissionId}`, {headers, params });\n  }\n\n  updateForm(moduleName: string, submissionId: string, formData: FormData, reCAPTCHAToken?:string): Observable<any> {\n    const headers = new HttpHeaders({\n      'Auth-user': this.header.authUser,\n    });\n    const url = `${this.apiUrl}/api/public/forms/${moduleName}/submissions/${submissionId}`;\n    if (reCAPTCHAToken) {\n      formData.append('recaptchaToken', reCAPTCHAToken);\n    }\n    return this.http.put<any>(url, formData, {\n      headers\n    });\n  }\n  previewFile(url: any): Observable<any> {\n    const headers = new HttpHeaders({\n      'Content-Type': this.header.contentType,\n      'auth-user': this.header.authUser,\n    });\n    const options = {\n      headers: headers,\n    };\n    const fileUrl = url;\n    const encodedFileUrl = encodeURIComponent(fileUrl);\n    const fullUrl = `?url=${encodedFileUrl}`;\n    return this.http.get<any>(this.apiUrl + `/api/cdn/preview${fullUrl}`, options);\n  }\n\n  getSubformSubmissions(subFormData: any) {\n    if (!subFormData?.moduleName || !subFormData?.duplicateSubmission?.sourceSubmissionIds) {\n      console.error(\"Invalid subFormData\", subFormData);\n      return;\n    }\n\n\n    // Extract data\n    const moduleName = subFormData.moduleName;\n    const submissionIds: string[] = subFormData.duplicateSubmission.sourceSubmissionIds;\n\n    // Build query string\n    const queryParams = submissionIds\n      .map(id => `submissionIds=${encodeURIComponent(id)}`)\n      .join(\"&\");\n\n    // Final URL\n    const url = `${this.apiUrl}/api/public/${moduleName}/subform-submissions?${queryParams}`;\n\n    // Now make API call\n    return this.http.get(url);\n  }\n\n\n}\n"]}
|
|
299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.service.js","sourceRoot":"","sources":["../../../../projects/form-submission/src/services/form.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';\nimport { DataService } from './data.service';\nimport { Observable } from 'rxjs';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class FormService {\n  private apiUrl: string = '';\n  header: any = {};\n  parentQuestions: any;\n  subformData: any;\n\n  constructor(private http: HttpClient, private dataService: DataService) {\n    this.dataService.apiUrl$.subscribe((data) => {\n      this.apiUrl = data;\n    });\n\n    this.dataService.header$.subscribe((data) => {\n      this.header = data;\n    });\n\n    this.dataService.parentQuestions$.subscribe((questions) => {\n      if (questions) {\n        this.parentQuestions = questions;\n      }\n    });\n\n    this.dataService.subform$.subscribe((data) => {\n      this.subformData = data;\n    });\n  }\n\n  getQuestions(\n    moduleName: string,\n    pageNumber: number = 1,\n    rowSet: number = 0,\n    progressiveLoading: boolean = true\n  ) {\n    const headers = new HttpHeaders({\n      'Accept-Language': this.header.acceptedLanguage,\n    });\n\n    const params = new HttpParams()\n      .set('pageNumber', pageNumber.toString())\n      .set('rowSet', rowSet.toString())\n      .set('progressiveLoading', progressiveLoading);\n\n    return this.http.get<any>(`${this.apiUrl}/api/public/forms/${moduleName}`, {\n      headers,\n      params,\n    });\n  }\n\n  fetchDataFromDatabase(database: any) {\n    const headers = new HttpHeaders({ 'Content-Type': 'application/json' });\n    return this.http.post<any>(`${this.apiUrl}/api/load-from-db`, database, {\n      headers,\n    });\n  }\n\n  fetchDataFromLookup(tableName: string) {\n    return this.http.get<any>(`${this.apiUrl}/api/public/lookup/${tableName}`);\n  }\n\n  fetchDataFromExternalAPI(\n    apiConfig: any,\n    selectedValues: any[] = []\n  ): Observable<any> {\n    // ✅ Check if pagination exists\n    const hasPagination =\n      apiConfig.params?.some((p: any) => p.valueSource === 'PAGE_INDEX') &&\n      apiConfig.params?.some((p: any) => p.valueSource === 'PAGE_SIZE');\n\n    // ---------------------- HEADERS ----------------------\n    let headers = new HttpHeaders();\n    // helper: resolve a value (or values) based on valueSource\n\n    // Apply to headers (assuming `headers` is an HttpHeaders instance)\n    if (apiConfig.headers) {\n      apiConfig.headers.forEach((header: any) => {\n        if (!header.keyName) return;\n\n        const rawValue = resolveValueFromSource(\n          header.valueSource,\n          header.inputValue,\n          selectedValues\n        );\n\n        if (header.valueSource === 'SELECTED_VALUES') {\n          // Only add header if we have selected values\n          if (Array.isArray(rawValue) && rawValue.length > 0) {\n            if (header.inputValue === 'SINGLE_VALUE') {\n              headers = headers.set(header.keyName, String(rawValue[0]));\n            } else if (header.inputValue === 'ARRAY_OF_VALUES') {\n              // join by comma for headers (common pattern)\n              headers = headers.set(header.keyName, rawValue.join(','));\n            } else {\n              // fallback: join\n              headers = headers.set(header.keyName, rawValue.join(','));\n            }\n          }\n          // no selected values -> skip header\n          return;\n        }\n\n        // For non-selected sources: skip when unresolved\n        if (rawValue === null || rawValue === undefined) return;\n\n        // If rawValue is array -> join by comma (headers expect single string)\n        const headerValue = Array.isArray(rawValue)\n          ? rawValue.join(',')\n          : String(rawValue);\n\n        if (header.keyName.toLowerCase() === 'authorization') {\n          // add Bearer only when headerValue is truthy (and not already prefixed)\n          const token = headerValue.startsWith('Bearer ')\n            ? headerValue\n            : `Bearer ${headerValue}`;\n          headers = headers.set(header.keyName, token);\n        } else {\n          headers = headers.set(header.keyName, headerValue);\n        }\n      });\n    }\n\n    // ---------------------- PARAMS ----------------------\n    let params = new HttpParams();\n    // helper: resolve a value (or values) based on valueSource\n    function resolveValueFromSource(\n      valueSource: string | undefined,\n      inputValue: any,\n      selectedValues: any[] = []\n    ) {\n      if (!valueSource) return null;\n\n      switch (valueSource) {\n        case 'LOCAL_STORAGE':\n          return localStorage.getItem(inputValue); // string or null\n\n        case 'SESSION_STORAGE':\n          return sessionStorage.getItem(inputValue); // string or null\n\n        case 'CUSTOM_INPUT':\n        case 'QUESTION':\n        case 'PAGE_INDEX' :\n        case 'PAGE_SIZE' : \n          // inputValue may be a single value or an array/CSV depending on usage\n          return inputValue;\n\n        case 'SELECTED_VALUES':\n          // For SELECTED_VALUES, return the selectedValues array (caller decides SINGLE/ARRAY behavior)\n          return Array.isArray(selectedValues) ? selectedValues : [];\n\n        default:\n          console.warn(`Unsupported valueSource for params: ${valueSource}`);\n          return null;\n      }\n    }\n\n    // Usage: build params (assuming `params` is an HttpParams instance)\n    if (apiConfig.params) {\n      apiConfig.params.forEach((param: any) => {\n        if (!param.keyName) return;\n\n        // Resolve raw value based on source\n        const rawValue = resolveValueFromSource(\n          param.valueSource,\n          param.inputValue,\n          selectedValues\n        );\n\n        // If param expects selected values, handle SINGLE_VALUE vs ARRAY_OF_VALUES\n        if (param.valueSource === 'SELECTED_VALUES') {\n          // Only add if there are actual selected values\n          if (Array.isArray(rawValue) && rawValue.length > 0) {\n            if (param.inputValue === 'SINGLE_VALUE') {\n              // set to first selected value\n              params = params.set(param.keyName, rawValue[0]);\n            } else if (param.inputValue === 'ARRAY_OF_VALUES') {\n              // append each selected value as repeated param\n              rawValue.forEach((val: any) => {\n                params = params.append(param.keyName, val);\n              });\n            } else {\n              // if inputValue not provided, default to array behavior\n              rawValue.forEach((val: any) => {\n                params = params.append(param.keyName, val);\n              });\n            }\n          }\n          // if no selected values, skip adding this param\n          return;\n        }\n\n        // For non-selected valueSources: rawValue could be null/undefined/string/array\n        if (rawValue === null || rawValue === undefined) {\n          // skip adding param when value not found\n          return;\n        }\n\n        // If inputValue indicates array-of-values (e.g., param.inputValue === 'ARRAY_OF_VALUES'),\n        // accept either an array or a comma-separated string\n        if (param.inputValue === 'ARRAY_OF_VALUES') {\n          if (Array.isArray(rawValue)) {\n            rawValue.forEach((val: any) => {\n              params = params.append(param.keyName, val);\n            });\n          } else if (typeof rawValue === 'string') {\n            // support comma separated string\n            rawValue\n              .split(',')\n              .map((s) => s.trim())\n              .filter(Boolean)\n              .forEach((val: string) => {\n                params = params.append(param.keyName, val);\n              });\n          } else {\n            // fallback: convert to string and append\n            params = params.append(param.keyName, String(rawValue));\n          }\n        } else {\n          // default: set single value\n          params = params.set(param.keyName, String(rawValue));\n        }\n      });\n    }\n\n    // ---------------------- PATH VARIABLES ----------------------\n    let url = apiConfig.url;\n    if (apiConfig.pathVariables) {\n      apiConfig.pathVariables.forEach((pathVar: any) => {\n        if (pathVar.keyName) {\n          let valueToBind: any = null;\n\n          switch (pathVar.valueSource) {\n            case 'LOCAL_STORAGE':\n              valueToBind = localStorage.getItem(pathVar.inputValue);\n              break;\n\n            case 'SESSION_STORAGE':\n              valueToBind = sessionStorage.getItem(pathVar.inputValue);\n              break;\n\n            case 'CUSTOM_INPUT':\n            case 'QUESTION':\n              valueToBind = pathVar.inputValue;\n              break;\n\n            default:\n              console.warn(`Unsupported valueSource: ${pathVar.valueSource}`);\n          }\n\n          if (valueToBind !== null && valueToBind !== undefined) {\n            url = url.replace(`{${pathVar.keyName}}`, valueToBind);\n          }\n        }\n      });\n    }\n\n    // ---------------------- FINAL CALL ----------------------\n    return this.http.get<any>(url, { headers, params });\n  }\n\n  submitForm(\n    moduleName: string,\n    formData: FormData,\n    reCAPTCHAToken?: string\n  ): Observable<any> {\n    const headers = new HttpHeaders({\n      'Auth-user': this.header.authUser,\n    });\n    const url = `${this.apiUrl}/api/public/forms/${moduleName}/submissions`;\n    if (reCAPTCHAToken) {\n      formData.append('recaptchaToken', reCAPTCHAToken);\n    }\n    return this.http.post(url, formData, {\n      headers,\n    });\n  }\n\n  getSubmittedForm(\n    moduleName: string,\n    submissionId: string,\n    pageNumber: number = 1,\n    rowSet: number = 0,\n    navigateTo?: string\n  ): Observable<any> {\n    let params = new HttpParams()\n      .set('pageNumber', pageNumber.toString())\n      .set('rowSet', rowSet.toString());\n    if (navigateTo) {\n      params = params.set('navigateId', navigateTo);\n    }\n\n    if (this.parentQuestions) {\n      this.parentQuestions.forEach((q: any) => {\n        params = params.append('parentQuestions', q);\n      });\n    }\n    const headers = new HttpHeaders({\n      'Accept-Language': this.header.acceptedLanguage,\n    });\n    return this.http.get<any>(\n      `${this.apiUrl}/api/forms/${moduleName}/submissions/${submissionId}`,\n      { headers, params }\n    );\n  }\n\n  updateForm(\n    moduleName: string,\n    submissionId: string,\n    formData: FormData,\n    reCAPTCHAToken?: string\n  ): Observable<any> {\n    const headers = new HttpHeaders({\n      'Auth-user': this.header.authUser,\n    });\n    const url = `${this.apiUrl}/api/public/forms/${moduleName}/submissions/${submissionId}`;\n    if (reCAPTCHAToken) {\n      formData.append('recaptchaToken', reCAPTCHAToken);\n    }\n    return this.http.put<any>(url, formData, {\n      headers,\n    });\n  }\n  previewFile(url: any): Observable<any> {\n    const headers = new HttpHeaders({\n      'Content-Type': this.header.contentType,\n      'auth-user': this.header.authUser,\n    });\n    const options = {\n      headers: headers,\n    };\n    const fileUrl = url;\n    const encodedFileUrl = encodeURIComponent(fileUrl);\n    const fullUrl = `?url=${encodedFileUrl}`;\n    return this.http.get<any>(\n      this.apiUrl + `/api/cdn/preview${fullUrl}`,\n      options\n    );\n  }\n\n  getSubformSubmissions(subFormData: any) {\n    if (\n      !subFormData?.moduleName ||\n      !subFormData?.duplicateSubmission?.sourceSubmissionIds\n    ) {\n      console.error('Invalid subFormData', subFormData);\n      return;\n    }\n\n    // Extract data\n    const moduleName = subFormData.moduleName;\n    const submissionIds: string[] =\n      subFormData.duplicateSubmission.sourceSubmissionIds;\n\n    // Build query string\n    const queryParams = submissionIds\n      .map((id) => `submissionIds=${encodeURIComponent(id)}`)\n      .join('&');\n\n    // Final URL\n    const url = `${this.apiUrl}/api/public/${moduleName}/subform-submissions?${queryParams}`;\n\n    // Now make API call\n    return this.http.get(url);\n  }\n}\n"]}
|
|
@@ -1093,7 +1093,7 @@ class FormService {
|
|
|
1093
1093
|
.set('progressiveLoading', progressiveLoading);
|
|
1094
1094
|
return this.http.get(`${this.apiUrl}/api/public/forms/${moduleName}`, {
|
|
1095
1095
|
headers,
|
|
1096
|
-
params
|
|
1096
|
+
params,
|
|
1097
1097
|
});
|
|
1098
1098
|
}
|
|
1099
1099
|
fetchDataFromDatabase(database) {
|
|
@@ -1111,63 +1111,163 @@ class FormService {
|
|
|
1111
1111
|
apiConfig.params?.some((p) => p.valueSource === 'PAGE_SIZE');
|
|
1112
1112
|
// ---------------------- HEADERS ----------------------
|
|
1113
1113
|
let headers = new HttpHeaders();
|
|
1114
|
+
// helper: resolve a value (or values) based on valueSource
|
|
1115
|
+
// Apply to headers (assuming `headers` is an HttpHeaders instance)
|
|
1114
1116
|
if (apiConfig.headers) {
|
|
1115
1117
|
apiConfig.headers.forEach((header) => {
|
|
1116
|
-
if (header.keyName)
|
|
1117
|
-
|
|
1118
|
-
|
|
1119
|
-
|
|
1120
|
-
|
|
1121
|
-
|
|
1122
|
-
|
|
1123
|
-
|
|
1124
|
-
}
|
|
1118
|
+
if (!header.keyName)
|
|
1119
|
+
return;
|
|
1120
|
+
const rawValue = resolveValueFromSource(header.valueSource, header.inputValue, selectedValues);
|
|
1121
|
+
if (header.valueSource === 'SELECTED_VALUES') {
|
|
1122
|
+
// Only add header if we have selected values
|
|
1123
|
+
if (Array.isArray(rawValue) && rawValue.length > 0) {
|
|
1124
|
+
if (header.inputValue === 'SINGLE_VALUE') {
|
|
1125
|
+
headers = headers.set(header.keyName, String(rawValue[0]));
|
|
1125
1126
|
}
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
if (header.keyName.toLowerCase() === 'authorization') {
|
|
1130
|
-
headers = headers.set(header.keyName, 'Bearer ' + header.inputValue);
|
|
1127
|
+
else if (header.inputValue === 'ARRAY_OF_VALUES') {
|
|
1128
|
+
// join by comma for headers (common pattern)
|
|
1129
|
+
headers = headers.set(header.keyName, rawValue.join(','));
|
|
1131
1130
|
}
|
|
1132
1131
|
else {
|
|
1133
|
-
|
|
1132
|
+
// fallback: join
|
|
1133
|
+
headers = headers.set(header.keyName, rawValue.join(','));
|
|
1134
1134
|
}
|
|
1135
1135
|
}
|
|
1136
|
+
// no selected values -> skip header
|
|
1137
|
+
return;
|
|
1138
|
+
}
|
|
1139
|
+
// For non-selected sources: skip when unresolved
|
|
1140
|
+
if (rawValue === null || rawValue === undefined)
|
|
1141
|
+
return;
|
|
1142
|
+
// If rawValue is array -> join by comma (headers expect single string)
|
|
1143
|
+
const headerValue = Array.isArray(rawValue)
|
|
1144
|
+
? rawValue.join(',')
|
|
1145
|
+
: String(rawValue);
|
|
1146
|
+
if (header.keyName.toLowerCase() === 'authorization') {
|
|
1147
|
+
// add Bearer only when headerValue is truthy (and not already prefixed)
|
|
1148
|
+
const token = headerValue.startsWith('Bearer ')
|
|
1149
|
+
? headerValue
|
|
1150
|
+
: `Bearer ${headerValue}`;
|
|
1151
|
+
headers = headers.set(header.keyName, token);
|
|
1152
|
+
}
|
|
1153
|
+
else {
|
|
1154
|
+
headers = headers.set(header.keyName, headerValue);
|
|
1136
1155
|
}
|
|
1137
1156
|
});
|
|
1138
1157
|
}
|
|
1139
1158
|
// ---------------------- PARAMS ----------------------
|
|
1140
1159
|
let params = new HttpParams();
|
|
1160
|
+
// helper: resolve a value (or values) based on valueSource
|
|
1161
|
+
function resolveValueFromSource(valueSource, inputValue, selectedValues = []) {
|
|
1162
|
+
if (!valueSource)
|
|
1163
|
+
return null;
|
|
1164
|
+
switch (valueSource) {
|
|
1165
|
+
case 'LOCAL_STORAGE':
|
|
1166
|
+
return localStorage.getItem(inputValue); // string or null
|
|
1167
|
+
case 'SESSION_STORAGE':
|
|
1168
|
+
return sessionStorage.getItem(inputValue); // string or null
|
|
1169
|
+
case 'CUSTOM_INPUT':
|
|
1170
|
+
case 'QUESTION':
|
|
1171
|
+
case 'PAGE_INDEX':
|
|
1172
|
+
case 'PAGE_SIZE':
|
|
1173
|
+
// inputValue may be a single value or an array/CSV depending on usage
|
|
1174
|
+
return inputValue;
|
|
1175
|
+
case 'SELECTED_VALUES':
|
|
1176
|
+
// For SELECTED_VALUES, return the selectedValues array (caller decides SINGLE/ARRAY behavior)
|
|
1177
|
+
return Array.isArray(selectedValues) ? selectedValues : [];
|
|
1178
|
+
default:
|
|
1179
|
+
console.warn(`Unsupported valueSource for params: ${valueSource}`);
|
|
1180
|
+
return null;
|
|
1181
|
+
}
|
|
1182
|
+
}
|
|
1183
|
+
// Usage: build params (assuming `params` is an HttpParams instance)
|
|
1141
1184
|
if (apiConfig.params) {
|
|
1142
1185
|
apiConfig.params.forEach((param) => {
|
|
1143
|
-
if (param.keyName)
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
|
|
1148
|
-
|
|
1149
|
-
|
|
1150
|
-
|
|
1151
|
-
|
|
1152
|
-
|
|
1153
|
-
|
|
1154
|
-
|
|
1186
|
+
if (!param.keyName)
|
|
1187
|
+
return;
|
|
1188
|
+
// Resolve raw value based on source
|
|
1189
|
+
const rawValue = resolveValueFromSource(param.valueSource, param.inputValue, selectedValues);
|
|
1190
|
+
// If param expects selected values, handle SINGLE_VALUE vs ARRAY_OF_VALUES
|
|
1191
|
+
if (param.valueSource === 'SELECTED_VALUES') {
|
|
1192
|
+
// Only add if there are actual selected values
|
|
1193
|
+
if (Array.isArray(rawValue) && rawValue.length > 0) {
|
|
1194
|
+
if (param.inputValue === 'SINGLE_VALUE') {
|
|
1195
|
+
// set to first selected value
|
|
1196
|
+
params = params.set(param.keyName, rawValue[0]);
|
|
1197
|
+
}
|
|
1198
|
+
else if (param.inputValue === 'ARRAY_OF_VALUES') {
|
|
1199
|
+
// append each selected value as repeated param
|
|
1200
|
+
rawValue.forEach((val) => {
|
|
1201
|
+
params = params.append(param.keyName, val);
|
|
1202
|
+
});
|
|
1155
1203
|
}
|
|
1156
|
-
|
|
1204
|
+
else {
|
|
1205
|
+
// if inputValue not provided, default to array behavior
|
|
1206
|
+
rawValue.forEach((val) => {
|
|
1207
|
+
params = params.append(param.keyName, val);
|
|
1208
|
+
});
|
|
1209
|
+
}
|
|
1210
|
+
}
|
|
1211
|
+
// if no selected values, skip adding this param
|
|
1212
|
+
return;
|
|
1213
|
+
}
|
|
1214
|
+
// For non-selected valueSources: rawValue could be null/undefined/string/array
|
|
1215
|
+
if (rawValue === null || rawValue === undefined) {
|
|
1216
|
+
// skip adding param when value not found
|
|
1217
|
+
return;
|
|
1218
|
+
}
|
|
1219
|
+
// If inputValue indicates array-of-values (e.g., param.inputValue === 'ARRAY_OF_VALUES'),
|
|
1220
|
+
// accept either an array or a comma-separated string
|
|
1221
|
+
if (param.inputValue === 'ARRAY_OF_VALUES') {
|
|
1222
|
+
if (Array.isArray(rawValue)) {
|
|
1223
|
+
rawValue.forEach((val) => {
|
|
1224
|
+
params = params.append(param.keyName, val);
|
|
1225
|
+
});
|
|
1157
1226
|
}
|
|
1158
|
-
else if (
|
|
1159
|
-
//
|
|
1160
|
-
|
|
1227
|
+
else if (typeof rawValue === 'string') {
|
|
1228
|
+
// support comma separated string
|
|
1229
|
+
rawValue
|
|
1230
|
+
.split(',')
|
|
1231
|
+
.map((s) => s.trim())
|
|
1232
|
+
.filter(Boolean)
|
|
1233
|
+
.forEach((val) => {
|
|
1234
|
+
params = params.append(param.keyName, val);
|
|
1235
|
+
});
|
|
1236
|
+
}
|
|
1237
|
+
else {
|
|
1238
|
+
// fallback: convert to string and append
|
|
1239
|
+
params = params.append(param.keyName, String(rawValue));
|
|
1161
1240
|
}
|
|
1162
1241
|
}
|
|
1242
|
+
else {
|
|
1243
|
+
// default: set single value
|
|
1244
|
+
params = params.set(param.keyName, String(rawValue));
|
|
1245
|
+
}
|
|
1163
1246
|
});
|
|
1164
1247
|
}
|
|
1165
1248
|
// ---------------------- PATH VARIABLES ----------------------
|
|
1166
1249
|
let url = apiConfig.url;
|
|
1167
1250
|
if (apiConfig.pathVariables) {
|
|
1168
1251
|
apiConfig.pathVariables.forEach((pathVar) => {
|
|
1169
|
-
if (pathVar.keyName
|
|
1170
|
-
|
|
1252
|
+
if (pathVar.keyName) {
|
|
1253
|
+
let valueToBind = null;
|
|
1254
|
+
switch (pathVar.valueSource) {
|
|
1255
|
+
case 'LOCAL_STORAGE':
|
|
1256
|
+
valueToBind = localStorage.getItem(pathVar.inputValue);
|
|
1257
|
+
break;
|
|
1258
|
+
case 'SESSION_STORAGE':
|
|
1259
|
+
valueToBind = sessionStorage.getItem(pathVar.inputValue);
|
|
1260
|
+
break;
|
|
1261
|
+
case 'CUSTOM_INPUT':
|
|
1262
|
+
case 'QUESTION':
|
|
1263
|
+
valueToBind = pathVar.inputValue;
|
|
1264
|
+
break;
|
|
1265
|
+
default:
|
|
1266
|
+
console.warn(`Unsupported valueSource: ${pathVar.valueSource}`);
|
|
1267
|
+
}
|
|
1268
|
+
if (valueToBind !== null && valueToBind !== undefined) {
|
|
1269
|
+
url = url.replace(`{${pathVar.keyName}}`, valueToBind);
|
|
1270
|
+
}
|
|
1171
1271
|
}
|
|
1172
1272
|
});
|
|
1173
1273
|
}
|
|
@@ -1183,7 +1283,7 @@ class FormService {
|
|
|
1183
1283
|
formData.append('recaptchaToken', reCAPTCHAToken);
|
|
1184
1284
|
}
|
|
1185
1285
|
return this.http.post(url, formData, {
|
|
1186
|
-
headers
|
|
1286
|
+
headers,
|
|
1187
1287
|
});
|
|
1188
1288
|
}
|
|
1189
1289
|
getSubmittedForm(moduleName, submissionId, pageNumber = 1, rowSet = 0, navigateTo) {
|
|
@@ -1212,7 +1312,7 @@ class FormService {
|
|
|
1212
1312
|
formData.append('recaptchaToken', reCAPTCHAToken);
|
|
1213
1313
|
}
|
|
1214
1314
|
return this.http.put(url, formData, {
|
|
1215
|
-
headers
|
|
1315
|
+
headers,
|
|
1216
1316
|
});
|
|
1217
1317
|
}
|
|
1218
1318
|
previewFile(url) {
|
|
@@ -1229,8 +1329,9 @@ class FormService {
|
|
|
1229
1329
|
return this.http.get(this.apiUrl + `/api/cdn/preview${fullUrl}`, options);
|
|
1230
1330
|
}
|
|
1231
1331
|
getSubformSubmissions(subFormData) {
|
|
1232
|
-
if (!subFormData?.moduleName ||
|
|
1233
|
-
|
|
1332
|
+
if (!subFormData?.moduleName ||
|
|
1333
|
+
!subFormData?.duplicateSubmission?.sourceSubmissionIds) {
|
|
1334
|
+
console.error('Invalid subFormData', subFormData);
|
|
1234
1335
|
return;
|
|
1235
1336
|
}
|
|
1236
1337
|
// Extract data
|
|
@@ -1238,8 +1339,8 @@ class FormService {
|
|
|
1238
1339
|
const submissionIds = subFormData.duplicateSubmission.sourceSubmissionIds;
|
|
1239
1340
|
// Build query string
|
|
1240
1341
|
const queryParams = submissionIds
|
|
1241
|
-
.map(id => `submissionIds=${encodeURIComponent(id)}`)
|
|
1242
|
-
.join(
|
|
1342
|
+
.map((id) => `submissionIds=${encodeURIComponent(id)}`)
|
|
1343
|
+
.join('&');
|
|
1243
1344
|
// Final URL
|
|
1244
1345
|
const url = `${this.apiUrl}/api/public/${moduleName}/subform-submissions?${queryParams}`;
|
|
1245
1346
|
// Now make API call
|