@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
- if (header.valueSource === 'SELECTED_VALUES') {
59
- if (selectedValues.length > 0) {
60
- if (header.inputValue === 'SINGLE_VALUE') {
61
- headers = headers.set(header.keyName, selectedValues[0]);
62
- }
63
- else if (header.inputValue === 'ARRAY_OF_VALUES') {
64
- headers = headers.set(header.keyName, selectedValues.join(','));
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
- // else skip
68
- }
69
- else if (header.inputValue) {
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
- headers = headers.set(header.keyName, header.inputValue);
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
- if (param.valueSource === 'SELECTED_VALUES') {
86
- // Only add selectedIds if values exist
87
- if (selectedValues.length > 0) {
88
- if (param.inputValue === 'SINGLE_VALUE') {
89
- params = params.set(param.keyName, selectedValues[0]);
90
- }
91
- else if (param.inputValue === 'ARRAY_OF_VALUES') {
92
- selectedValues.forEach((val) => {
93
- params = params.append(param.keyName, val);
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
- else if (param.inputValue) {
100
- // Normal custom or search params
101
- params = params.set(param.keyName, param.inputValue);
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 && pathVar.inputValue) {
111
- url = url.replace(`{${pathVar.keyName}}`, pathVar.inputValue);
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 || !subFormData?.duplicateSubmission?.sourceSubmissionIds) {
174
- console.error("Invalid subFormData", subFormData);
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
- if (header.valueSource === 'SELECTED_VALUES') {
1118
- if (selectedValues.length > 0) {
1119
- if (header.inputValue === 'SINGLE_VALUE') {
1120
- headers = headers.set(header.keyName, selectedValues[0]);
1121
- }
1122
- else if (header.inputValue === 'ARRAY_OF_VALUES') {
1123
- headers = headers.set(header.keyName, selectedValues.join(','));
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
- // else skip
1127
- }
1128
- else if (header.inputValue) {
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
- headers = headers.set(header.keyName, header.inputValue);
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
- if (param.valueSource === 'SELECTED_VALUES') {
1145
- // Only add selectedIds if values exist
1146
- if (selectedValues.length > 0) {
1147
- if (param.inputValue === 'SINGLE_VALUE') {
1148
- params = params.set(param.keyName, selectedValues[0]);
1149
- }
1150
- else if (param.inputValue === 'ARRAY_OF_VALUES') {
1151
- selectedValues.forEach((val) => {
1152
- params = params.append(param.keyName, val);
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
- // ❌ If no values, do nothing (skip param entirely)
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 (param.inputValue) {
1159
- // Normal custom or search params
1160
- params = params.set(param.keyName, param.inputValue);
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 && pathVar.inputValue) {
1170
- url = url.replace(`{${pathVar.keyName}}`, pathVar.inputValue);
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 || !subFormData?.duplicateSubmission?.sourceSubmissionIds) {
1233
- console.error("Invalid subFormData", subFormData);
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