UNPKG

zustand-utils

Version:
44 lines 2.27 kB
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty"; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } import { createContext as reactCreateContext, createElement, useContext, useMemo, useRef } from 'react'; import { useStore } from 'zustand'; /** * create context for individual App * mostly use for component */ export var createContext = function createContext() { var ZustandContext = /*#__PURE__*/reactCreateContext(undefined); var Provider = function Provider(_ref) { var createStore = _ref.createStore, children = _ref.children; var storeRef = useRef(); if (!storeRef.current) { storeRef.current = createStore(); } return /*#__PURE__*/createElement(ZustandContext.Provider, { value: storeRef.current }, children); }; var useContextStore = function useContextStore(selector, equalityFn) { var store = useContext(ZustandContext); if (!store) { throw new Error('Seems like you have not used zustand provider as an ancestor.'); } return useStore(store, selector, equalityFn); }; var useStoreApi = function useStoreApi() { var store = useContext(ZustandContext); if (!store) { throw new Error('Seems like you have not used zustand provider as an ancestor.'); } return useMemo(function () { return _objectSpread({}, store); }, [store]); }; return { Provider: Provider, useStore: useContextStore, useStoreApi: useStoreApi }; };