Skip to content

Commit

Permalink
toFormData helper function (axios#3757)
Browse files Browse the repository at this point in the history
* adding toFormData test

* adding toFormData

Co-authored-by: Jay <jasonsaayman@gmail.com>
  • Loading branch information
carpben and jasonsaayman committed Dec 23, 2021
1 parent 563aaa6 commit 876b314
Show file tree
Hide file tree
Showing 2 changed files with 73 additions and 0 deletions.
55 changes: 55 additions & 0 deletions lib/helpers/toFormData.js
@@ -0,0 +1,55 @@
'use strict';

function combinedKey(parentKey, elKey) {
return parentKey + '.' + elKey;
}

function buildFormData(formData, data, parentKey) {
if (Array.isArray(data)) {
data.forEach(function buildArray(el, i) {
buildFormData(formData, el, combinedKey(parentKey, i));
});
} else if (
typeof data === 'object' &&
!(data instanceof File || data === null)
) {
Object.keys(data).forEach(function buildObject(key) {
buildFormData(
formData,
data[key],
parentKey ? combinedKey(parentKey, key) : key
);
});
} else {
if (data === undefined) {
return;
}

var value =
typeof data === 'boolean' || typeof data === 'number'
? data.toString()
: data;
formData.append(parentKey, value);
}
}

/**
* convert a data object to FormData
*
* type FormDataPrimitive = string | Blob | number | boolean
* interface FormDataNest {
* [x: string]: FormVal
* }
*
* type FormVal = FormDataNest | FormDataPrimitive
*
* @param {FormVal} data
*/

module.exports = function getFormData(data) {
var formData = new FormData();

buildFormData(formData, data);

return formData;
};
18 changes: 18 additions & 0 deletions test/specs/helpers/toFormData.spec.js
@@ -0,0 +1,18 @@
var toFormData = require("../../../lib/helpers/toFormData");

describe("toFormData", function () {
it("Convert nested data object to FormDAta", function () {
var o = {
val: 123,
nested: {
arr: ["hello", "world"],
},
};

convertedVal = toFormData(o);
expect(convertedVal instanceof FormData).toEqual(true);
expect(Array.from(convertedVal.keys()).length).toEqual(3);
expect(convertedVal.get("val")).toEqual("123")
expect(convertedVal.get("nested.arr.0")).toEqual("hello")
});
});

0 comments on commit 876b314

Please sign in to comment.