mutability
v1.1.2
Published
A JavaScript library for transactional mutable updates
Downloads
258
Maintainers
Readme
mutability
A JavaScript library for transactional mutable updates based on Mutative.
Motivation
When we want to perform transactional updates on a mutable object, if an error is caught during the update process, the mutable update will not be applied at all. Otherwise, the mutable update will be applied to the mutable object. Therefore, we need a tool to implement this functionality.
Installation
yarn add mutative mutability
or with npm
npm install mutative mutability
Usage
import { mutate } from 'mutability';
test('base - mutate', () => {
const baseState = {
a: {
c: 1,
},
};
const { patches, inversePatches } = mutate(baseState, (draft) => {
draft.a.c = 2;
});
expect(baseState).toEqual({ a: { c: 2 } });
expect({ patches, inversePatches }).toEqual({
patches: [
{
op: 'replace',
path: ['a', 'c'],
value: 2,
},
],
inversePatches: [
{
op: 'replace',
path: ['a', 'c'],
value: 1,
},
],
});
apply(baseState, inversePatches);
expect(baseState).toEqual({ a: { c: 1 } });
});
test('base - mutate with error', () => {
const baseState = {
a: {
c: 1,
},
b: {
c: 1,
},
};
try {
mutate(baseState, (draft) => {
draft.a.c = 2;
throw new Error('error');
draft.b.c = 2;
});
} catch (e) {
//
}
expect(baseState).toEqual({
a: {
c: 1,
},
b: {
c: 1,
},
});
});
APIs
mutate()
Mutate the mutable object, and return the patches and inverse patches.
apply()
Apply the mutable update with patches.
License
Mutability is MIT licensed.