Create "curried" templates from deep JS structures using ES6 template syntax
In a browser:
<script src="deep-template.js"></script>
Using npm:
$ npm i -g npm
$ npm i --save deep-template
var deepTemplate = require('deep-template');
var buildPath = deepTemplate('/api/users/${id}/');
buildPath({id: '549873456448'}); // -> "/api/users/549873456448/"
var configTemplate = {
a: ['/api/users/${id}/${action}'],
b: {
deep: {
foo: [
{
stuff: 'DEFAULT_ENV=${env}'
}
]
}
},
c: function() { console.log('avoided') },
d: /keepRegExp/gim,
e: 'keep simple texts',
f: 10
};
var defaults = {action: 'defaultAction', env: '/usr/bin/bash'};
var configBuilder = deepTemplate(configTemplate, defaults);
configBuilder({id: '549873456448'});
/* -> {
a: ["/api/users/549873456448/defaultAction"],
b: {
deep: {
foo: [{
stuff: "DEFAULT_ENV=/usr/bin/bash"
}]
}
},
c: function() { console.log('avoided') },
d: /keepRegExp/gim,
e: "keep simple texts",
f: 10
}
*/
var arrayBuildPath = deepTemplate('/api/users/${0}/${1}/${2}', [null, null, 'ascending']);
arrayBuildPath(['549873456448', 'getUser']); // -> "/api/users/549873456448/getUser/ascending"