@nubitio/crud 0.4.0 → 0.4.1
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/dist/index.cjs +12 -8
- package/dist/index.mjs +12 -8
- package/package.json +3 -3
package/dist/index.cjs
CHANGED
|
@@ -597,10 +597,12 @@ function serializeDateField(formData, field) {
|
|
|
597
597
|
}
|
|
598
598
|
function serializeNumericField(formData, field) {
|
|
599
599
|
if (field.isIdentity) return;
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
formData[field.name]
|
|
603
|
-
|
|
600
|
+
const val = formData[field.name];
|
|
601
|
+
if (val === null || val === void 0 || val === "") {
|
|
602
|
+
delete formData[field.name];
|
|
603
|
+
return;
|
|
604
|
+
}
|
|
605
|
+
formData[field.name] = field.sendAsString ? Number(val).toFixed(field.precision || 2) : Number(val);
|
|
604
606
|
}
|
|
605
607
|
/**
|
|
606
608
|
* Serializes detail grid rows (entity refs, numeric coercion, identity cleanup).
|
|
@@ -615,10 +617,12 @@ function serializeDetailRows(rows, detailFields, detailIdField, isEditMode, adap
|
|
|
615
617
|
else detail[field.name] = serialized;
|
|
616
618
|
});
|
|
617
619
|
if (field.type === "number" || field.type === "currency") details.forEach((detail) => {
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
detail[field.name]
|
|
621
|
-
|
|
620
|
+
const val = detail[field.name];
|
|
621
|
+
if (val === null || val === void 0 || val === "") {
|
|
622
|
+
delete detail[field.name];
|
|
623
|
+
return;
|
|
624
|
+
}
|
|
625
|
+
detail[field.name] = field.sendAsString ? Number(val).toFixed(field.precision || 2) : Number(val);
|
|
622
626
|
});
|
|
623
627
|
});
|
|
624
628
|
details.forEach((detail) => {
|
package/dist/index.mjs
CHANGED
|
@@ -573,10 +573,12 @@ function serializeDateField(formData, field) {
|
|
|
573
573
|
}
|
|
574
574
|
function serializeNumericField(formData, field) {
|
|
575
575
|
if (field.isIdentity) return;
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
formData[field.name]
|
|
579
|
-
|
|
576
|
+
const val = formData[field.name];
|
|
577
|
+
if (val === null || val === void 0 || val === "") {
|
|
578
|
+
delete formData[field.name];
|
|
579
|
+
return;
|
|
580
|
+
}
|
|
581
|
+
formData[field.name] = field.sendAsString ? Number(val).toFixed(field.precision || 2) : Number(val);
|
|
580
582
|
}
|
|
581
583
|
/**
|
|
582
584
|
* Serializes detail grid rows (entity refs, numeric coercion, identity cleanup).
|
|
@@ -591,10 +593,12 @@ function serializeDetailRows(rows, detailFields, detailIdField, isEditMode, adap
|
|
|
591
593
|
else detail[field.name] = serialized;
|
|
592
594
|
});
|
|
593
595
|
if (field.type === "number" || field.type === "currency") details.forEach((detail) => {
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
detail[field.name]
|
|
597
|
-
|
|
596
|
+
const val = detail[field.name];
|
|
597
|
+
if (val === null || val === void 0 || val === "") {
|
|
598
|
+
delete detail[field.name];
|
|
599
|
+
return;
|
|
600
|
+
}
|
|
601
|
+
detail[field.name] = field.sendAsString ? Number(val).toFixed(field.precision || 2) : Number(val);
|
|
598
602
|
});
|
|
599
603
|
});
|
|
600
604
|
details.forEach((detail) => {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nubitio/crud",
|
|
3
|
-
"version": "0.4.
|
|
3
|
+
"version": "0.4.1",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "Declarative CRUD engine with field DSL, forms, datagrids, RBAC, conditional logic and pluggable adapters (Hydra/REST).",
|
|
6
6
|
"license": "MIT",
|
|
@@ -56,8 +56,8 @@
|
|
|
56
56
|
"react-dom": "^19.0.0",
|
|
57
57
|
"react-i18next": "^14.0.0",
|
|
58
58
|
"react-router-dom": "^6.0.0",
|
|
59
|
-
"@nubitio/core": "^0.4.
|
|
60
|
-
"@nubitio/ui": "^0.4.
|
|
59
|
+
"@nubitio/core": "^0.4.1",
|
|
60
|
+
"@nubitio/ui": "^0.4.1"
|
|
61
61
|
},
|
|
62
62
|
"dependencies": {
|
|
63
63
|
"react-dropzone": "^15.0.0"
|