dot-fp
Curried version of dot-prop-immutable.
Installation
$ npm install dot-fp
or
$ yarn add dot-fp
Description
The motivation for this module is to have a simple utility for changing state in a React-Redux application without mutating the existing state of plain JavaScript objects.
None of the functions mutate the input object. For efficiency, the returned object is not a deep clone of the original, but a shallow copy of the objects in the mutated path.
Usage
var dot = require('dot-fp');
var state = { todos: [] }, index = 0;
state = dot.set(state)('todos')(list => [...list, {text: 'cleanup', complete: false}])
state = {...state, todos: [...state.todos, {text: 'cleanup', complete: false}]};
state = dot.set(state)(`todos.${index}.complete`)(true)
state = {...state, todos: [
...state.todos.slice(0, index),
{...state.todos[index], complete: true},
...state.todos.slice(index + 1)
]};
state = dot.delete(state)(`todos.${index}`)
state = {...state, todos: [
...state.todos.slice(0, index),
...state.todos.slice(index + 1)
]};
get
Access a nested property by a dot path
dot.get({foo: {bar: 'unicorn'}})('foo.bar')
dot.get({foo: {bar: 'a'}})('foo.notDefined.deep')
dot.get({foo: {'dot.dot': 'unicorn'}})('foo.dot\\.dot')
or use a property array as a path.
dot.get({foo: {'dot.dot': 'unicorn'}})(['foo', 'dot.dot'])
It is also possible to index into an array where the special index $end
refers to the last element of the array.
var obj = {foo: [{ bar: 'gold-unicorn'}, 'white-unicorn', 'silver-unicorn']};
dot.get(obj)('foo.1')
dot.get(obj)('foo.0.bar')
dot.get(obj)('foo.$end')
dot.get([{ bar: 'gold-unicorn'}, 'white-unicorn', 'silver-unicorn'])('0.bar')
set
Modify a nested property by a dot path
var obj = {foo: {bar: 'a'}};
var obj1 = dot.set(obj)('foo.bar')('b');
var obj2 = dot.set(obj1 )('foo.baz')('x');
where obj
, obj1
, obj2
, obj3
all are different objects.
Use a function to modify the selected property, where first argument is the old value.
dot.set({foo: {bar: 'a'}})('foo.bar')(v => v + 'bc')
Modify a nested array
var obj = {foo: [{ bar: 'gold-unicorn'}, 'white-unicorn', 'silver-unicorn']};
dot.set(obj)('foo.1')('platin-unicorn')
dot.set(obj)('foo.0.bar')('platin-unicorn')
dot.set(obj)('foo.$end')('platin-unicorn')
delete
Delete a nested property/array by a dot path
var obj = {foo: [{ bar: 'gold-unicorn'}, 'white-unicorn', 'silver-unicorn']};
dot.delete(obj)('foo.$end');
dot.delete(obj)('foo.0.bar');
toggle
Toggle a boolean a value by a dot path.
var obj = {foo: { bar: true } };
dot.toggle(obj)('foo.bar');
merge
Merge a value by a dot path.
The target value must be an object, array, null, or undefined.
- If target is an object, Object.assign({}, target, param) is used.
- If target an array, target.concat(param) is used.
- If target is null or undefined, the value is simply set.
var obj = {foo: { bar: {a:1, b:2 } };
dot.merge(obj)('foo.bar')({c:3});
var arr = {foo: { bar: [1, 2] } };
dot.merge(arr)('foo.bar')([3, 4]);
License
MIT