UNPKG

zustand

Version:

🐻 Bear necessities for state management in React

78 lines (61 loc) 1.89 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); function createStore(createState) { var state; var listeners = new Set(); var setState = function setState(partial, replace) { var nextState = typeof partial === 'function' ? partial(state) : partial; if (nextState !== state) { var _previousState = state; state = replace ? nextState : Object.assign({}, state, nextState); listeners.forEach(function (listener) { return listener(state, _previousState); }); } }; var getState = function getState() { return state; }; var subscribeWithSelector = function subscribeWithSelector(listener, selector, equalityFn) { if (selector === void 0) { selector = getState; } if (equalityFn === void 0) { equalityFn = Object.is; } console.warn('[DEPRECATED] Please use `subscribeWithSelector` middleware'); var currentSlice = selector(state); function listenerToAdd() { var nextSlice = selector(state); if (!equalityFn(currentSlice, nextSlice)) { var _previousSlice = currentSlice; listener(currentSlice = nextSlice, _previousSlice); } } listeners.add(listenerToAdd); return function () { return listeners.delete(listenerToAdd); }; }; var subscribe = function subscribe(listener, selector, equalityFn) { if (selector || equalityFn) { return subscribeWithSelector(listener, selector, equalityFn); } listeners.add(listener); return function () { return listeners.delete(listener); }; }; var destroy = function destroy() { return listeners.clear(); }; var api = { setState: setState, getState: getState, subscribe: subscribe, destroy: destroy }; state = createState(setState, getState, api); return api; } exports["default"] = createStore;