{"version":3,"file":"react-tracked-CRAUZypf.js","sources":["../../node_modules/react-tracked/dist/index.modern.mjs"],"sourcesContent":["import { useRef, useEffect, useDebugValue, useReducer, useCallback, useMemo, createContext as createContext$1, useContext, createElement, forwardRef, memo as memo$1 } from 'react';\nimport { createContext, useContextUpdate, useContextSelector } from 'use-context-selector';\nimport { affectedToPathList, isChanged, createProxy, trackMemo } from 'proxy-compare';\nexport { getUntracked as getUntrackedObject } from 'proxy-compare';\n\nconst useAffectedDebugValue = (state, affected) => {\n const pathList = useRef();\n useEffect(() => {\n pathList.current = affectedToPathList(state, affected);\n });\n useDebugValue(state);\n};\n\nconst createTrackedSelector = useSelector => {\n const useTrackedSelector = () => {\n const [, forceUpdate] = useReducer(c => c + 1, 0);\n const affected = new WeakMap();\n const lastAffected = useRef();\n const prevState = useRef();\n const lastState = useRef();\n useEffect(() => {\n lastAffected.current = affected;\n if (prevState.current !== lastState.current && isChanged(prevState.current, lastState.current, affected, new WeakMap())) {\n prevState.current = lastState.current;\n forceUpdate();\n }\n });\n const selector = useCallback(nextState => {\n lastState.current = nextState;\n if (prevState.current && prevState.current !== nextState && lastAffected.current && !isChanged(prevState.current, nextState, lastAffected.current, new WeakMap())) {\n // not changed\n return prevState.current;\n }\n prevState.current = nextState;\n return nextState;\n }, []);\n const state = useSelector(selector);\n if (typeof process === 'object' && process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useAffectedDebugValue(state, affected);\n }\n const proxyCache = useMemo(() => new WeakMap(), []); // per-hook proxyCache\n return createProxy(state, affected, proxyCache);\n };\n return useTrackedSelector;\n};\n\n/* eslint react/destructuring-assignment: off */\nconst createContainer = (useValue, options) => {\n var _options, _options2;\n if (typeof options === 'boolean') {\n // eslint-disable-next-line no-console\n console.warn('boolean option is deprecated, please specify { concurrentMode: true }');\n options = {\n concurrentMode: options\n };\n }\n const {\n stateContextName = 'StateContainer',\n updateContextName = 'UpdateContainer',\n concurrentMode\n } = options || {};\n const StateContext = createContext((_options = options) == null ? void 0 : _options.defaultState);\n const UpdateContext = createContext$1((_options2 = options) == null ? void 0 : _options2.defaultUpdate);\n StateContext.displayName = stateContextName;\n UpdateContext.displayName = updateContextName;\n const Provider = props => {\n const [state, update] = useValue(props);\n return createElement(UpdateContext.Provider, {\n value: update\n }, createElement(StateContext.Provider, {\n value: state\n }, props.children));\n };\n const useSelector = selector => {\n if (typeof process === 'object' && process.env.NODE_ENV !== 'production') {\n const selectorOrig = selector;\n selector = state => {\n if (state === undefined) {\n throw new Error('Please use ');\n }\n return selectorOrig(state);\n };\n }\n const selected = useContextSelector(StateContext, selector);\n useDebugValue(selected);\n return selected;\n };\n const useTrackedState = createTrackedSelector(useSelector);\n const useUpdate = concurrentMode ? () => {\n if (typeof process === 'object' && process.env.NODE_ENV !== 'production' && useContext(UpdateContext) === undefined) {\n throw new Error('Please use ');\n }\n const contextUpdate = useContextUpdate(StateContext);\n const update = useContext(UpdateContext);\n return useCallback((...args) => {\n let result;\n contextUpdate(() => {\n result = update(...args);\n });\n return result;\n }, [contextUpdate, update]);\n }\n // not concurrentMode\n : () => {\n if (typeof process === 'object' && process.env.NODE_ENV !== 'production' && useContext(UpdateContext) === undefined) {\n throw new Error('Please use ');\n }\n return useContext(UpdateContext);\n };\n const useTracked = () => [useTrackedState(), useUpdate()];\n return {\n Provider,\n useTrackedState,\n useTracked,\n useUpdate,\n useSelector\n };\n};\n\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\n\nfunction memo(Component, propsAreEqual) {\n const WrappedComponent = forwardRef((props, ref) => {\n Object.values(props).forEach(trackMemo);\n return createElement(Component, _extends({}, props, {\n ref\n }));\n });\n return memo$1(WrappedComponent, propsAreEqual);\n}\n\nexport { createContainer, createTrackedSelector, memo };\n//# sourceMappingURL=index.modern.mjs.map\n"],"names":["createTrackedSelector","useSelector","forceUpdate","useReducer","c","affected","WeakMap","lastAffected","useRef","prevState","lastState","useEffect","current","isChanged","selector","useCallback","nextState","state","proxyCache","useMemo","createProxy"],"mappings":"iGAKA,MAQMA,EAAuCC,GAChB,KACnB,MAAG,CAAAC,GAAeC,cAAgBC,GAAAA,EAAI,GAAG,GACzCC,MAAeC,QACfC,EAAeC,EAAAA,SACfC,EAAYD,EAAAA,SACZE,EAAYF,EAAAA,SAClBG,EAAAA,WAAU,KACRJ,EAAaK,QAAUP,EACnBI,EAAUG,UAAYF,EAAUE,SAAWC,EAAUJ,EAAUG,QAASF,EAAUE,QAASP,EAAc,IAAAC,WAC3GG,EAAUG,QAAUF,EAAUE,YAEhC,IAEI,MAAAE,EAAWC,eAAyBC,IACxCN,EAAUE,QAAUI,EAChBP,EAAUG,SAAWH,EAAUG,UAAYI,GAAaT,EAAaK,UAAYC,EAAUJ,EAAUG,QAASI,EAAWT,EAAaK,QAAa,IAAAN,SAE9IG,EAAUG,SAEnBH,EAAUG,QAAUI,EACbA,KACN,IACGC,EAAQhB,EAAYa,GAKpB,MAAAI,EAAaC,EAAAA,SAAQ,QAAUb,SAAW,IACzCc,OAAAA,EAAYH,EAAOZ,EAAUa,EAAU","x_google_ignoreList":[0]}