A utility function for efficiently applying updates to objects that are being treated as immutable data.
Immutability is, in general, a useful pattern for state management patterns using libraries like Redux. However, not everybody wants to use a large immutability library like ImmutableJS, and using regular objects can lead to a lot of boilerplate.
This library allows you to turn this...
function reducer(state, action) {
switch (action.type) {
case MY_ACTION: {
return {
...state,
subObject1: {
...state.subObject1,
myChange: 'newVal',
},
subObject2: {
...state.subObject2,
myOtherChange: 'otherNewVal',
},
}
}
}
}
into this...
import immutableUpdate from 'immutable-update';
function reducer(state, action) {
switch (action.type) {
case MY_ACTION: {
return immutableUpdate(state, {
subObject1: { myChange: 'newVal' },
subObject2: { myOtherChange: 'otherNewVal' },
});
}
}
}
All references to objects that aren't changed are preserved, so any memoization or React pure rendering things that are checking object identities will work as expected, and no unnecessary copies are made.
npm install --save immutable-update
The immutableState
function is exported as a UMD build, with the name in the
global namespace being immutableState
if you're not using any module system.
The function also accepts an optional 3rd parameter of an array of paths to override, instead of merging.
For example:
const state = {
foo: {
bar: 'baz',
today: 'tix',
},
};
// Returns { foo: { bar: 'hiya', today: 'tix' } }
immutableState(state, {
foo: {
bar: 'hiya',
},
});
// Returns { foo: { bar: 'hiya' } }
immutableState(state, {
foo: {
bar: 'hiya',
},
}, [
'foo'
]);
The strings in this array can be of any format supported by lodash#set.
Please make sure your code passes our tests and linter. PRs/Issues welcome!
npm test
npm run lint
Distributed under the MIT License. See LICENSE
for more information.
Developers: