Transform object from one structure to another by using schema. It's useful in API when you want to modify data before sending it to clients
Note: This module works in browsers and Node.js >= 6.0.
Try demo on RunKit.
npm install mapper.js
const mapper = require('mapper.js');
<script src="node_modules/mapper.js/dist/mapper.js">
or minified version
<script src="node_modules/mapper.js/dist/mapper.min.js">
You can use the module with AMD/CommonJS or just use window.mapper
.
There are two ways to use module:
Parameters
data
(Object | Object[]) - Object or array of objects to mapschema
(Function | Object) - Schema which defines how to map object
Return value
(Object | Object[]) - Result of mapping (object or array of objects)
const mapper = require('mapper.js');
const result = mapper(object, schema);
Parameters
schema
(Function | Object) - Schema which defines how to map object
Return value
(Function): Mapping function which can be called with data
further
const mapper = require('mapper.js');
const map = mapper(schema);
const result = map(object);
const mapper = require('mapper.js');
const products = [
{
type: 'book',
name: 'The Adventures of Tom Sawyer',
description: 'Awesome book',
count: 1
},
{
type: 'sugar',
description: 'Very tasty',
weight: 3000
}
];
const productsSchemas = {
book: {
name: true,
count: true
},
sugar: {
weight: true
}
};
// function accepts an object and has to return a schema
const schema = product => Object.assign({}, productsSchemas[product.type], { type: true });
const result = mapper(products, schema);
Imagine we have collection of users and each user object has the following structure:
const user = {
id: 12345,
firstName: 'Peter',
lastName: 'Parker',
company: {
name: 'Daily Bugle',
position: 'Photographer'
},
email: '[email protected]',
socialNetworks: {
vk: 'https://vk.com/peter.parker',
facebook: 'https://www.facebook.com/peter.parker'
},
friends: [
{
id: 12346,
firstName: 'Mary Jane',
lastName: 'Watson'
},
{
id: 12347,
firstName: 'Harold',
lastName: 'Osborn'
}
]
};
We want to send users data to clients in a different format:
{
id: 12345,
fullName: 'Peter Parker',
companyName: 'Daily Bugle',
contacts: {
email: '[email protected]',
vk: 'https://vk.com/peter.parker',
facebook: 'https://www.facebook.com/peter.parker'
},
friends: [
{ id: 12346, fullName: 'Mary Jane Watson' },
{ id: 12347, fullName: 'Harold Osborn' }
]
}
We can do it by using the schema:
const mapper = require('mapper.js');
const userSchema = {
// take field without any changes
id: true, // or '=',
// you can specify function and return custom value
fullName: (fullName, user) => user.firstName + ' ' + user.lastName,
// take "name" field from "company" object
companyName: 'company.name', // or '=company.name'
// you can work with embedded objects
contacts: {
// by default property path is relative to current object,
// so if you want to get value from top-level object ("user" in example) use "$"
email: '$.email', // or '=$.email'
// function takes 4 arguments:
// - current value of property = user.contacts.facebook
// - current object = user.contacts
// - original object = user
// - path as array = ['contacts', 'facebook']
facebook: (facebook, contacts, user, path) => user.socialNetworks.facebook,
vk: '$.socialNetworks.vk'
},
// for arrays use array with schema for item
friends: [{
id: true,
fullName: (fullName, friend) => friend.firstName + ' ' + friend.lastName
}]
};
const result = mapper(user, userSchema); // or mapper(userSchema)(user)
npm install
npm run build
npm install
npm test