redux-dom-mutation-observer
is a Redux middleware for managing DOM tree changes over MutationObserver Web API.
This middleware uses actions to interact with a MutationObserver instance: observe mutations, disconnecting and receiving mutation records.
- Written in TypeScript.
- Interact with a MutationObserver by dispatching actions.
- Handle mutation records with Redux middleware, integrate with Saga, and use reducers to persist state.
$ npm i redux-dom-mutation-observer
Easily add the middleware to your Redux store with applyMiddleware
. To do so, you have to create a middleware instance.
import { applyMiddleware, createStore } from 'redux';
import createMutationObserver from 'redux-dom-mutation-observer';
import reducer from './store/reducer';
// Create the middleware instance.
const mutationObserverMiddleware = createMutationObserver();
// Create the Redux store.
const store = createStore(reducer, applyMiddleware(mutationObserverMiddleware));
redux-dom-mutation-observer
will dispatch every mutation record action automatically, based on what the internal MutationObserver will get. Some actions will need to be dispatched by you.
Feel free to use action creator functions included in the module.
Action is used to start receiving DOM changes notifications that match the given target node and MutationObserverInit options.
import { observe } from 'redux-dom-mutation-observer';
store.dispatch(observe('root', { subtree: true }));
targetId
(string
): A DOM node Id within the DOM tree to watch for changes.options
(MutationObserverInit
): configuration of a mutation observer.
Stops the MutationObserver instance from receiving further notifications.
import { disconnect } from 'redux-dom-mutation-observer';
store.dispatch(disconnect());
Dispatched when the MutationObserver receives a DOM change that qualifies given the targeted node or subtree and options. The payload includes a mutation
key which is a MutationRecord.
{
type: 'REDUX_DOM_MUTATION_OBSERVER::MUTATION_RECORD',
payload: {
mutation: {
// MutationRecord data
}
};
}
- workflowy-link-preview - URLs previewer browser extension for WorkFlowy.
If you have discovered a bug or have a feature suggestion, feel free to create an issue on Github.
Also, you can drop me a message on my twitter - @roman_chukhan.