histor
TypeScript icon, indicating that this package has built-in type declarations

1.0.1 • Public • Published

histor

histor is a enhancer to watch the deep change of an object and tell the detail of the change.

Install

$ yarn add histor

or

$ npm i histor

Usage

histor(object, onChange)

Accept an object and a onChange callback function. The callback function will be called if any part of the object is changed.

The onChange callback will receive a change detail whose type is:

interface IDiff {
  path: (string | number)[] // the path chain of the changed key
  from: any // previous value before change of the prop
  to: any // current value after change of the prop
}

Example:

import histor from 'histor'
 
const person = {
  name: 'wee',
  skills: ['eat', 'sleep'],
  pets: {
    cat: {
      name: 'c1'
    },
    dog: 'd1'
  }
}
 
const p = histor(person, diff => {
  console.log(`$${diff.path.map(p => `[${p}]`).join('')}${diff.from} ==> ${diff.to}`)
})
 
person.pets.cat.name = 'c2'
// it will log:
// `$[pets][cat][name]: c1 ==> c2`

⚠️ CAVEAT

  • The change diff will just keep a reference to the changed value. So if the new value or the new value has been changed deeply afterward. The previous diff will be changed at the same time. So it's better to serialize the diff to make it immutable.

Thanks

Inspired by on-change.

License

MIT

Readme

Keywords

Package Sidebar

Install

npm i histor

Weekly Downloads

3

Version

1.0.1

License

MIT

Unpacked Size

8.67 kB

Total Files

18

Last publish

Collaborators

  • fi3ework