@rkosafo/cai.components 0.0.24 → 0.0.26

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.
@@ -31,6 +31,7 @@
31
31
  setData({ ...$data, [name]: e.value });
32
32
  } else {
33
33
  const d = e.map((a: any) => a.value);
34
+ // console.log({ d });
34
35
  setData({ ...$data, [name]: d });
35
36
  }
36
37
  if (onChange) onChange(e);
@@ -271,8 +271,7 @@
271
271
  }
272
272
 
273
273
  async function handleAction({ action, data }: { action: string; data: FormData }) {
274
- let formData = Object.fromEntries(data.entries());
275
-
274
+ let formData = data;
276
275
  try {
277
276
  isLoading = true;
278
277
  const ret = editing
@@ -132,7 +132,6 @@
132
132
  return (hidden = true);
133
133
  }
134
134
  }
135
-
136
135
  function _onsubmit(ev: SubmitEvent & { currentTarget: HTMLFormElement }) {
137
136
  onsubmit?.(ev as any);
138
137
  if (ev.defaultPrevented) return;
@@ -142,20 +141,13 @@
142
141
  const mainForm = ev.currentTarget;
143
142
  let returnValue = '';
144
143
 
145
- // Find all nested forms within the main form
146
144
  const nestedForms = mainForm.querySelectorAll('form');
147
145
  const combinedFormData = new FormData();
148
146
 
149
- // Add data from main form (excluding nested forms)
150
- new FormData(mainForm).forEach((value, key) => {
151
- combinedFormData.append(key, value);
152
- });
153
-
154
- // Add data from all nested forms
147
+ // Collect all form data
148
+ new FormData(mainForm).forEach((value, key) => combinedFormData.append(key, value));
155
149
  nestedForms.forEach((nestedForm) => {
156
- new FormData(nestedForm).forEach((value, key) => {
157
- combinedFormData.append(key, value);
158
- });
150
+ new FormData(nestedForm).forEach((value, key) => combinedFormData.append(key, value));
159
151
  });
160
152
 
161
153
  if (ev.submitter instanceof HTMLButtonElement || ev.submitter instanceof HTMLInputElement) {
@@ -166,14 +158,42 @@
166
158
  return (hidden = true);
167
159
  }
168
160
 
169
- if (
170
- typeof onaction === 'function' &&
171
- onaction({ action: returnValue, data: combinedFormData }) === false
172
- ) {
161
+ // Convert FormData → object
162
+ const data: Record<string, any> = {};
163
+ for (const [key, value] of combinedFormData.entries()) {
164
+ if (data[key] !== undefined) {
165
+ if (!Array.isArray(data[key])) data[key] = [data[key]];
166
+ data[key].push(value);
167
+ } else {
168
+ data[key] = value;
169
+ }
170
+ }
171
+
172
+ // Cast values and normalize arrays
173
+ Object.keys(data).forEach((key) => {
174
+ const val = data[key];
175
+ if (Array.isArray(val)) {
176
+ data[key] = val.map((v) => tryCast(v));
177
+ } else {
178
+ // Force array for certain fields
179
+ if (['dashboards', 'permissions', 'reports'].includes(key)) {
180
+ data[key] = [tryCast(val)];
181
+ } else {
182
+ data[key] = tryCast(val);
183
+ }
184
+ }
185
+ });
186
+
187
+ if (typeof onaction === 'function' && onaction({ action: returnValue, data }) === false) {
173
188
  return;
174
189
  }
190
+ }
175
191
 
176
- // hidden = true;
192
+ function tryCast(v: any) {
193
+ if (v === 'true') return true;
194
+ if (v === 'false') return false;
195
+ if (!isNaN(Number(v)) && v !== '') return Number(v);
196
+ return v;
177
197
  }
178
198
 
179
199
  createDismissableContext(close);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rkosafo/cai.components",
3
- "version": "0.0.24",
3
+ "version": "0.0.26",
4
4
  "files": [
5
5
  "dist",
6
6
  "!dist/**/*.test.*",