objectTransformator
Transforms a javascript object from one shape to another.
objectTransformator
comes with some preset transformations.
Installing
Using npm:
\$ npm install @workablehr/object-transformator
Basic usage
import { underscoredKeys } from "@workablehr/object-transformator";
underscoredKeys({ attrV1: "val1", attrs: { attrV2: "val2" } });
Presets
camelizeKeys
Transforms all the object keys to camel case.
- shallow, if true, it transforms only the first level of the object.
- omit, excludes specific keys from the transformation.
import { camelizeKeys } from "@workablehr/object-transformator";
camelizeKeys({ attr_v1: "val1", attrs: { attr_v2: "val2" } });
underscoredKeys
Transforms all the object keys to underscored case.
- shallow, if true, it transforms only the first level of the object.
- omit, excludes specific keys from the transformation.
import { underscoredKeys } from "@workablehr/object-transformator";
underscoredKeys(
{ attrV1: "val1", attrs: { attrV2: "val2" } },
{ shallow: true }
);
transformator
The pure transformator function.
import transformKeys from "@workablehr/object-transformator";
const prefixKeys = (data, prefix, { shallow = false, omit = [] } = {}) =>
transformKeys(data, {
shallow,
func: prefixKeys,
action: (target, key, value) => ({ ...target, [prefix + key]: value }),
omit
});
prefixKeys({ attr1: "val1", attrs: { attr2: "val2" } }, "v1_");
compose
Creates a chain of transformators.
import transformKeys, {compose} from "@workablehr/object-transformator";
const prefixAction = (target, key, value) => ({ ...target, ['v1_' + key]: value })
const payloadTransformator = data =>
transformKeys(data, {
func: payloadTransformator,
action: compose(
camelizeKey,
prefixAction
)
});
payloadTransformator({...});