{"version":3,"file":"js/4567.chunk.js","mappings":"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","sources":["webpack:///./node_modules/resolve-pathname/esm/resolve-pathname.js","webpack:///./node_modules/value-equal/esm/value-equal.js","webpack:///./node_modules/history/esm/history.js","webpack:///./node_modules/react-is/cjs/react-is.production.min.js","webpack:///./node_modules/react-is/index.js","webpack:///./node_modules/react-redux/es/utils/batch.js","webpack:///./node_modules/react-redux/es/components/Context.js","webpack:///./node_modules/react-redux/es/hooks/useReduxContext.js","webpack:///./node_modules/react-redux/es/hooks/useSelector.js","webpack:///./node_modules/react-redux/es/utils/useSyncExternalStore.js","webpack:///./node_modules/react-redux/es/utils/Subscription.js","webpack:///./node_modules/react-redux/es/utils/useIsomorphicLayoutEffect.js","webpack:///./node_modules/react-redux/es/components/connect.js","webpack:///./node_modules/react-redux/es/components/Provider.js","webpack:///./node_modules/react-redux/es/hooks/useStore.js","webpack:///./node_modules/react-redux/es/hooks/useDispatch.js","webpack:///./node_modules/react-redux/es/index.js","webpack:///./node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.js","webpack:///./node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.js","webpack:///./node_modules/use-sync-external-store/shim/index.js","webpack:///./node_modules/use-sync-external-store/shim/with-selector.js","webpack:///./node_modules/tiny-invariant/dist/esm/tiny-invariant.js"],"sourcesContent":["function isAbsolute(pathname) {\n return pathname.charAt(0) === '/';\n}\n\n// About 1.5x faster than the two-arg version of Array#splice()\nfunction spliceOne(list, index) {\n for (var i = index, k = i + 1, n = list.length; k < n; i += 1, k += 1) {\n list[i] = list[k];\n }\n\n list.pop();\n}\n\n// This implementation is based heavily on node's url.parse\nfunction resolvePathname(to, from) {\n if (from === undefined) from = '';\n\n var toParts = (to && to.split('/')) || [];\n var fromParts = (from && from.split('/')) || [];\n\n var isToAbs = to && isAbsolute(to);\n var isFromAbs = from && isAbsolute(from);\n var mustEndAbs = isToAbs || isFromAbs;\n\n if (to && isAbsolute(to)) {\n // to is absolute\n fromParts = toParts;\n } else if (toParts.length) {\n // to is relative, drop the filename\n fromParts.pop();\n fromParts = fromParts.concat(toParts);\n }\n\n if (!fromParts.length) return '/';\n\n var hasTrailingSlash;\n if (fromParts.length) {\n var last = fromParts[fromParts.length - 1];\n hasTrailingSlash = last === '.' || last === '..' || last === '';\n } else {\n hasTrailingSlash = false;\n }\n\n var up = 0;\n for (var i = fromParts.length; i >= 0; i--) {\n var part = fromParts[i];\n\n if (part === '.') {\n spliceOne(fromParts, i);\n } else if (part === '..') {\n spliceOne(fromParts, i);\n up++;\n } else if (up) {\n spliceOne(fromParts, i);\n up--;\n }\n }\n\n if (!mustEndAbs) for (; up--; up) fromParts.unshift('..');\n\n if (\n mustEndAbs &&\n fromParts[0] !== '' &&\n (!fromParts[0] || !isAbsolute(fromParts[0]))\n )\n fromParts.unshift('');\n\n var result = fromParts.join('/');\n\n if (hasTrailingSlash && result.substr(-1) !== '/') result += '/';\n\n return result;\n}\n\nexport default resolvePathname;\n","function valueOf(obj) {\n return obj.valueOf ? obj.valueOf() : Object.prototype.valueOf.call(obj);\n}\n\nfunction valueEqual(a, b) {\n // Test for strict equality first.\n if (a === b) return true;\n\n // Otherwise, if either of them == null they are not equal.\n if (a == null || b == null) return false;\n\n if (Array.isArray(a)) {\n return (\n Array.isArray(b) &&\n a.length === b.length &&\n a.every(function(item, index) {\n return valueEqual(item, b[index]);\n })\n );\n }\n\n if (typeof a === 'object' || typeof b === 'object') {\n var aValue = valueOf(a);\n var bValue = valueOf(b);\n\n if (aValue !== a || bValue !== b) return valueEqual(aValue, bValue);\n\n return Object.keys(Object.assign({}, a, b)).every(function(key) {\n return valueEqual(a[key], b[key]);\n });\n }\n\n return false;\n}\n\nexport default valueEqual;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport resolvePathname from 'resolve-pathname';\nimport valueEqual from 'value-equal';\nimport warning from 'tiny-warning';\nimport invariant from 'tiny-invariant';\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === '/' ? path : '/' + path;\n}\nfunction stripLeadingSlash(path) {\n return path.charAt(0) === '/' ? path.substr(1) : path;\n}\nfunction hasBasename(path, prefix) {\n return path.toLowerCase().indexOf(prefix.toLowerCase()) === 0 && '/?#'.indexOf(path.charAt(prefix.length)) !== -1;\n}\nfunction stripBasename(path, prefix) {\n return hasBasename(path, prefix) ? path.substr(prefix.length) : path;\n}\nfunction stripTrailingSlash(path) {\n return path.charAt(path.length - 1) === '/' ? path.slice(0, -1) : path;\n}\nfunction parsePath(path) {\n var pathname = path || '/';\n var search = '';\n var hash = '';\n var hashIndex = pathname.indexOf('#');\n\n if (hashIndex !== -1) {\n hash = pathname.substr(hashIndex);\n pathname = pathname.substr(0, hashIndex);\n }\n\n var searchIndex = pathname.indexOf('?');\n\n if (searchIndex !== -1) {\n search = pathname.substr(searchIndex);\n pathname = pathname.substr(0, searchIndex);\n }\n\n return {\n pathname: pathname,\n search: search === '?' ? '' : search,\n hash: hash === '#' ? '' : hash\n };\n}\nfunction createPath(location) {\n var pathname = location.pathname,\n search = location.search,\n hash = location.hash;\n var path = pathname || '/';\n if (search && search !== '?') path += search.charAt(0) === '?' ? search : \"?\" + search;\n if (hash && hash !== '#') path += hash.charAt(0) === '#' ? hash : \"#\" + hash;\n return path;\n}\n\nfunction createLocation(path, state, key, currentLocation) {\n var location;\n\n if (typeof path === 'string') {\n // Two-arg form: push(path, state)\n location = parsePath(path);\n location.state = state;\n } else {\n // One-arg form: push(location)\n location = _extends({}, path);\n if (location.pathname === undefined) location.pathname = '';\n\n if (location.search) {\n if (location.search.charAt(0) !== '?') location.search = '?' + location.search;\n } else {\n location.search = '';\n }\n\n if (location.hash) {\n if (location.hash.charAt(0) !== '#') location.hash = '#' + location.hash;\n } else {\n location.hash = '';\n }\n\n if (state !== undefined && location.state === undefined) location.state = state;\n }\n\n try {\n location.pathname = decodeURI(location.pathname);\n } catch (e) {\n if (e instanceof URIError) {\n throw new URIError('Pathname \"' + location.pathname + '\" could not be decoded. ' + 'This is likely caused by an invalid percent-encoding.');\n } else {\n throw e;\n }\n }\n\n if (key) location.key = key;\n\n if (currentLocation) {\n // Resolve incomplete/relative pathname relative to current location.\n if (!location.pathname) {\n location.pathname = currentLocation.pathname;\n } else if (location.pathname.charAt(0) !== '/') {\n location.pathname = resolvePathname(location.pathname, currentLocation.pathname);\n }\n } else {\n // When there is no prior location and pathname is empty, set it to /\n if (!location.pathname) {\n location.pathname = '/';\n }\n }\n\n return location;\n}\nfunction locationsAreEqual(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash && a.key === b.key && valueEqual(a.state, b.state);\n}\n\nfunction createTransitionManager() {\n var prompt = null;\n\n function setPrompt(nextPrompt) {\n process.env.NODE_ENV !== \"production\" ? warning(prompt == null, 'A history supports only one prompt at a time') : void 0;\n prompt = nextPrompt;\n return function () {\n if (prompt === nextPrompt) prompt = null;\n };\n }\n\n function confirmTransitionTo(location, action, getUserConfirmation, callback) {\n // TODO: If another transition starts while we're still confirming\n // the previous one, we may end up in a weird state. Figure out the\n // best way to handle this.\n if (prompt != null) {\n var result = typeof prompt === 'function' ? prompt(location, action) : prompt;\n\n if (typeof result === 'string') {\n if (typeof getUserConfirmation === 'function') {\n getUserConfirmation(result, callback);\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'A history needs a getUserConfirmation function in order to use a prompt message') : void 0;\n callback(true);\n }\n } else {\n // Return false from a transition hook to cancel the transition.\n callback(result !== false);\n }\n } else {\n callback(true);\n }\n }\n\n var listeners = [];\n\n function appendListener(fn) {\n var isActive = true;\n\n function listener() {\n if (isActive) fn.apply(void 0, arguments);\n }\n\n listeners.push(listener);\n return function () {\n isActive = false;\n listeners = listeners.filter(function (item) {\n return item !== listener;\n });\n };\n }\n\n function notifyListeners() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n listeners.forEach(function (listener) {\n return listener.apply(void 0, args);\n });\n }\n\n return {\n setPrompt: setPrompt,\n confirmTransitionTo: confirmTransitionTo,\n appendListener: appendListener,\n notifyListeners: notifyListeners\n };\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nfunction getConfirmation(message, callback) {\n callback(window.confirm(message)); // eslint-disable-line no-alert\n}\n/**\n * Returns true if the HTML5 history API is supported. Taken from Modernizr.\n *\n * https://github.com/Modernizr/Modernizr/blob/master/LICENSE\n * https://github.com/Modernizr/Modernizr/blob/master/feature-detects/history.js\n * changed to avoid false negatives for Windows Phones: https://github.com/reactjs/react-router/issues/586\n */\n\nfunction supportsHistory() {\n var ua = window.navigator.userAgent;\n if ((ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) && ua.indexOf('Mobile Safari') !== -1 && ua.indexOf('Chrome') === -1 && ua.indexOf('Windows Phone') === -1) return false;\n return window.history && 'pushState' in window.history;\n}\n/**\n * Returns true if browser fires popstate on hash change.\n * IE10 and IE11 do not.\n */\n\nfunction supportsPopStateOnHashChange() {\n return window.navigator.userAgent.indexOf('Trident') === -1;\n}\n/**\n * Returns false if using go(n) with hash history causes a full page reload.\n */\n\nfunction supportsGoWithoutReloadUsingHash() {\n return window.navigator.userAgent.indexOf('Firefox') === -1;\n}\n/**\n * Returns true if a given popstate event is an extraneous WebKit event.\n * Accounts for the fact that Chrome on iOS fires real popstate events\n * containing undefined state when pressing the back button.\n */\n\nfunction isExtraneousPopstateEvent(event) {\n return event.state === undefined && navigator.userAgent.indexOf('CriOS') === -1;\n}\n\nvar PopStateEvent = 'popstate';\nvar HashChangeEvent = 'hashchange';\n\nfunction getHistoryState() {\n try {\n return window.history.state || {};\n } catch (e) {\n // IE 11 sometimes throws when accessing window.history.state\n // See https://github.com/ReactTraining/history/pull/289\n return {};\n }\n}\n/**\n * Creates a history object that uses the HTML5 history API including\n * pushState, replaceState, and the popstate event.\n */\n\n\nfunction createBrowserHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Browser history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canUseHistory = supportsHistory();\n var needsHashChangeListener = !supportsPopStateOnHashChange();\n var _props = props,\n _props$forceRefresh = _props.forceRefresh,\n forceRefresh = _props$forceRefresh === void 0 ? false : _props$forceRefresh,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n\n function getDOMLocation(historyState) {\n var _ref = historyState || {},\n key = _ref.key,\n state = _ref.state;\n\n var _window$location = window.location,\n pathname = _window$location.pathname,\n search = _window$location.search,\n hash = _window$location.hash;\n var path = pathname + search + hash;\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path, state, key);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function handlePopState(event) {\n // Ignore extraneous popstate events in WebKit.\n if (isExtraneousPopstateEvent(event)) return;\n handlePop(getDOMLocation(event.state));\n }\n\n function handleHashChange() {\n handlePop(getDOMLocation(getHistoryState()));\n }\n\n var forceNextPop = false;\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of keys we've seen in sessionStorage.\n // Instead, we just default to 0 for keys we don't know.\n\n var toIndex = allKeys.indexOf(toLocation.key);\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allKeys.indexOf(fromLocation.key);\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n }\n\n var initialLocation = getDOMLocation(getHistoryState());\n var allKeys = [initialLocation.key]; // Public interface\n\n function createHref(location) {\n return basename + createPath(location);\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.pushState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.href = href;\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n var nextKeys = allKeys.slice(0, prevIndex + 1);\n nextKeys.push(location.key);\n allKeys = nextKeys;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot push state in browsers that do not support HTML5 history') : void 0;\n window.location.href = href;\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.replaceState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.replace(href);\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n if (prevIndex !== -1) allKeys[prevIndex] = location.key;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot replace state in browsers that do not support HTML5 history') : void 0;\n window.location.replace(href);\n }\n });\n }\n\n function go(n) {\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.addEventListener(HashChangeEvent, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.removeEventListener(HashChangeEvent, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nvar HashChangeEvent$1 = 'hashchange';\nvar HashPathCoders = {\n hashbang: {\n encodePath: function encodePath(path) {\n return path.charAt(0) === '!' ? path : '!/' + stripLeadingSlash(path);\n },\n decodePath: function decodePath(path) {\n return path.charAt(0) === '!' ? path.substr(1) : path;\n }\n },\n noslash: {\n encodePath: stripLeadingSlash,\n decodePath: addLeadingSlash\n },\n slash: {\n encodePath: addLeadingSlash,\n decodePath: addLeadingSlash\n }\n};\n\nfunction stripHash(url) {\n var hashIndex = url.indexOf('#');\n return hashIndex === -1 ? url : url.slice(0, hashIndex);\n}\n\nfunction getHashPath() {\n // We can't use window.location.hash here because it's not\n // consistent across browsers - Firefox will pre-decode it!\n var href = window.location.href;\n var hashIndex = href.indexOf('#');\n return hashIndex === -1 ? '' : href.substring(hashIndex + 1);\n}\n\nfunction pushHashPath(path) {\n window.location.hash = path;\n}\n\nfunction replaceHashPath(path) {\n window.location.replace(stripHash(window.location.href) + '#' + path);\n}\n\nfunction createHashHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Hash history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canGoWithoutReload = supportsGoWithoutReloadUsingHash();\n var _props = props,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$hashType = _props.hashType,\n hashType = _props$hashType === void 0 ? 'slash' : _props$hashType;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n var _HashPathCoders$hashT = HashPathCoders[hashType],\n encodePath = _HashPathCoders$hashT.encodePath,\n decodePath = _HashPathCoders$hashT.decodePath;\n\n function getDOMLocation() {\n var path = decodePath(getHashPath());\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n var forceNextPop = false;\n var ignorePath = null;\n\n function locationsAreEqual$$1(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash;\n }\n\n function handleHashChange() {\n var path = getHashPath();\n var encodedPath = encodePath(path);\n\n if (path !== encodedPath) {\n // Ensure we always have a properly-encoded hash.\n replaceHashPath(encodedPath);\n } else {\n var location = getDOMLocation();\n var prevLocation = history.location;\n if (!forceNextPop && locationsAreEqual$$1(prevLocation, location)) return; // A hashchange doesn't always == location change.\n\n if (ignorePath === createPath(location)) return; // Ignore this change; we already setState in push/replace.\n\n ignorePath = null;\n handlePop(location);\n }\n }\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of paths we've seen in sessionStorage.\n // Instead, we just default to 0 for paths we don't know.\n\n var toIndex = allPaths.lastIndexOf(createPath(toLocation));\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allPaths.lastIndexOf(createPath(fromLocation));\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n } // Ensure the hash is encoded properly before doing anything else.\n\n\n var path = getHashPath();\n var encodedPath = encodePath(path);\n if (path !== encodedPath) replaceHashPath(encodedPath);\n var initialLocation = getDOMLocation();\n var allPaths = [createPath(initialLocation)]; // Public interface\n\n function createHref(location) {\n var baseTag = document.querySelector('base');\n var href = '';\n\n if (baseTag && baseTag.getAttribute('href')) {\n href = stripHash(window.location.href);\n }\n\n return href + '#' + encodePath(basename + createPath(location));\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot push state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a PUSH, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n pushHashPath(encodedPath);\n var prevIndex = allPaths.lastIndexOf(createPath(history.location));\n var nextPaths = allPaths.slice(0, prevIndex + 1);\n nextPaths.push(path);\n allPaths = nextPaths;\n setState({\n action: action,\n location: location\n });\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'Hash history cannot PUSH the same path; a new entry will not be added to the history stack') : void 0;\n setState();\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot replace state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a REPLACE, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n replaceHashPath(encodedPath);\n }\n\n var prevIndex = allPaths.indexOf(createPath(history.location));\n if (prevIndex !== -1) allPaths[prevIndex] = path;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n process.env.NODE_ENV !== \"production\" ? warning(canGoWithoutReload, 'Hash history go(n) causes a full page reload in this browser') : void 0;\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(HashChangeEvent$1, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(HashChangeEvent$1, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nfunction clamp(n, lowerBound, upperBound) {\n return Math.min(Math.max(n, lowerBound), upperBound);\n}\n/**\n * Creates a history object that stores locations in memory.\n */\n\n\nfunction createMemoryHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n var _props = props,\n getUserConfirmation = _props.getUserConfirmation,\n _props$initialEntries = _props.initialEntries,\n initialEntries = _props$initialEntries === void 0 ? ['/'] : _props$initialEntries,\n _props$initialIndex = _props.initialIndex,\n initialIndex = _props$initialIndex === void 0 ? 0 : _props$initialIndex,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = history.entries.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var index = clamp(initialIndex, 0, initialEntries.length - 1);\n var entries = initialEntries.map(function (entry) {\n return typeof entry === 'string' ? createLocation(entry, undefined, createKey()) : createLocation(entry, undefined, entry.key || createKey());\n }); // Public interface\n\n var createHref = createPath;\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var prevIndex = history.index;\n var nextIndex = prevIndex + 1;\n var nextEntries = history.entries.slice(0);\n\n if (nextEntries.length > nextIndex) {\n nextEntries.splice(nextIndex, nextEntries.length - nextIndex, location);\n } else {\n nextEntries.push(location);\n }\n\n setState({\n action: action,\n location: location,\n index: nextIndex,\n entries: nextEntries\n });\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n history.entries[history.index] = location;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n var nextIndex = clamp(history.index + n, 0, history.entries.length - 1);\n var action = 'POP';\n var location = history.entries[nextIndex];\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location,\n index: nextIndex\n });\n } else {\n // Mimic the behavior of DOM histories by\n // causing a render after a cancelled POP.\n setState();\n }\n });\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n function canGo(n) {\n var nextIndex = history.index + n;\n return nextIndex >= 0 && nextIndex < history.entries.length;\n }\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n return transitionManager.setPrompt(prompt);\n }\n\n function listen(listener) {\n return transitionManager.appendListener(listener);\n }\n\n var history = {\n length: entries.length,\n action: 'POP',\n location: entries[index],\n index: index,\n entries: entries,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n canGo: canGo,\n block: block,\n listen: listen\n };\n return history;\n}\n\nexport { createBrowserHistory, createHashHistory, createMemoryHistory, createLocation, locationsAreEqual, parsePath, createPath };\n","/**\n * @license React\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var b=Symbol.for(\"react.element\"),c=Symbol.for(\"react.portal\"),d=Symbol.for(\"react.fragment\"),e=Symbol.for(\"react.strict_mode\"),f=Symbol.for(\"react.profiler\"),g=Symbol.for(\"react.provider\"),h=Symbol.for(\"react.context\"),k=Symbol.for(\"react.server_context\"),l=Symbol.for(\"react.forward_ref\"),m=Symbol.for(\"react.suspense\"),n=Symbol.for(\"react.suspense_list\"),p=Symbol.for(\"react.memo\"),q=Symbol.for(\"react.lazy\"),t=Symbol.for(\"react.offscreen\"),u;u=Symbol.for(\"react.module.reference\");\nfunction v(a){if(\"object\"===typeof a&&null!==a){var r=a.$$typeof;switch(r){case b:switch(a=a.type,a){case d:case f:case e:case m:case n:return a;default:switch(a=a&&a.$$typeof,a){case k:case h:case l:case q:case p:case g:return a;default:return r}}case c:return r}}}exports.ContextConsumer=h;exports.ContextProvider=g;exports.Element=b;exports.ForwardRef=l;exports.Fragment=d;exports.Lazy=q;exports.Memo=p;exports.Portal=c;exports.Profiler=f;exports.StrictMode=e;exports.Suspense=m;\nexports.SuspenseList=n;exports.isAsyncMode=function(){return!1};exports.isConcurrentMode=function(){return!1};exports.isContextConsumer=function(a){return v(a)===h};exports.isContextProvider=function(a){return v(a)===g};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===b};exports.isForwardRef=function(a){return v(a)===l};exports.isFragment=function(a){return v(a)===d};exports.isLazy=function(a){return v(a)===q};exports.isMemo=function(a){return v(a)===p};\nexports.isPortal=function(a){return v(a)===c};exports.isProfiler=function(a){return v(a)===f};exports.isStrictMode=function(a){return v(a)===e};exports.isSuspense=function(a){return v(a)===m};exports.isSuspenseList=function(a){return v(a)===n};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===d||a===f||a===e||a===m||a===n||a===t||\"object\"===typeof a&&null!==a&&(a.$$typeof===q||a.$$typeof===p||a.$$typeof===g||a.$$typeof===h||a.$$typeof===l||a.$$typeof===u||void 0!==a.getModuleId)?!0:!1};exports.typeOf=v;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","// Default to a dummy \"batch\" implementation that just runs the callback\nfunction defaultNoopBatch(callback) {\n callback();\n}\n\nlet batch = defaultNoopBatch; // Allow injecting another batching function later\n\nexport const setBatch = newBatch => batch = newBatch; // Supply a getter just to skip dealing with ESM bindings\n\nexport const getBatch = () => batch;","import React from 'react';\nexport const ReactReduxContext = /*#__PURE__*/React.createContext(null);\n\nif (process.env.NODE_ENV !== 'production') {\n ReactReduxContext.displayName = 'ReactRedux';\n}\n\nexport default ReactReduxContext;","import { useContext } from 'react';\nimport { ReactReduxContext } from '../components/Context';\n\n/**\r\n * A hook to access the value of the `ReactReduxContext`. This is a low-level\r\n * hook that you should usually not need to call directly.\r\n *\r\n * @returns {any} the value of the `ReactReduxContext`\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useReduxContext } from 'react-redux'\r\n *\r\n * export const CounterComponent = () => {\r\n * const { store } = useReduxContext()\r\n * return
{store.getState()}
\r\n * }\r\n */\nexport function useReduxContext() {\n const contextValue = useContext(ReactReduxContext);\n\n if (process.env.NODE_ENV !== 'production' && !contextValue) {\n throw new Error('could not find react-redux context value; please ensure the component is wrapped in a ');\n }\n\n return contextValue;\n}","import { useContext, useDebugValue } from 'react';\nimport { useReduxContext as useDefaultReduxContext } from './useReduxContext';\nimport { ReactReduxContext } from '../components/Context';\nimport { notInitialized } from '../utils/useSyncExternalStore';\nlet useSyncExternalStoreWithSelector = notInitialized;\nexport const initializeUseSelector = fn => {\n useSyncExternalStoreWithSelector = fn;\n};\n\nconst refEquality = (a, b) => a === b;\n/**\r\n * Hook factory, which creates a `useSelector` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useSelector` hook bound to the specified context.\r\n */\n\n\nexport function createSelectorHook(context = ReactReduxContext) {\n const useReduxContext = context === ReactReduxContext ? useDefaultReduxContext : () => useContext(context);\n return function useSelector(selector, equalityFn = refEquality) {\n if (process.env.NODE_ENV !== 'production') {\n if (!selector) {\n throw new Error(`You must pass a selector to useSelector`);\n }\n\n if (typeof selector !== 'function') {\n throw new Error(`You must pass a function as a selector to useSelector`);\n }\n\n if (typeof equalityFn !== 'function') {\n throw new Error(`You must pass a function as an equality function to useSelector`);\n }\n }\n\n const {\n store,\n subscription,\n getServerState\n } = useReduxContext();\n const selectedState = useSyncExternalStoreWithSelector(subscription.addNestedSub, store.getState, getServerState || store.getState, selector, equalityFn);\n useDebugValue(selectedState);\n return selectedState;\n };\n}\n/**\r\n * A hook to access the redux store's state. This hook takes a selector function\r\n * as an argument. The selector is called with the store state.\r\n *\r\n * This hook takes an optional equality comparison function as the second parameter\r\n * that allows you to customize the way the selected state is compared to determine\r\n * whether the component needs to be re-rendered.\r\n *\r\n * @param {Function} selector the selector function\r\n * @param {Function=} equalityFn the function that will be used to determine equality\r\n *\r\n * @returns {any} the selected state\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useSelector } from 'react-redux'\r\n *\r\n * export const CounterComponent = () => {\r\n * const counter = useSelector(state => state.counter)\r\n * return
{counter}
\r\n * }\r\n */\n\nexport const useSelector = /*#__PURE__*/createSelectorHook();","export const notInitialized = () => {\n throw new Error('uSES not initialized!');\n};","import { getBatch } from './batch'; // encapsulates the subscription logic for connecting a component to the redux store, as\n// well as nesting subscriptions of descendant components, so that we can ensure the\n// ancestor components re-render before descendants\n\nfunction createListenerCollection() {\n const batch = getBatch();\n let first = null;\n let last = null;\n return {\n clear() {\n first = null;\n last = null;\n },\n\n notify() {\n batch(() => {\n let listener = first;\n\n while (listener) {\n listener.callback();\n listener = listener.next;\n }\n });\n },\n\n get() {\n let listeners = [];\n let listener = first;\n\n while (listener) {\n listeners.push(listener);\n listener = listener.next;\n }\n\n return listeners;\n },\n\n subscribe(callback) {\n let isSubscribed = true;\n let listener = last = {\n callback,\n next: null,\n prev: last\n };\n\n if (listener.prev) {\n listener.prev.next = listener;\n } else {\n first = listener;\n }\n\n return function unsubscribe() {\n if (!isSubscribed || first === null) return;\n isSubscribed = false;\n\n if (listener.next) {\n listener.next.prev = listener.prev;\n } else {\n last = listener.prev;\n }\n\n if (listener.prev) {\n listener.prev.next = listener.next;\n } else {\n first = listener.next;\n }\n };\n }\n\n };\n}\n\nconst nullListeners = {\n notify() {},\n\n get: () => []\n};\nexport function createSubscription(store, parentSub) {\n let unsubscribe;\n let listeners = nullListeners;\n\n function addNestedSub(listener) {\n trySubscribe();\n return listeners.subscribe(listener);\n }\n\n function notifyNestedSubs() {\n listeners.notify();\n }\n\n function handleChangeWrapper() {\n if (subscription.onStateChange) {\n subscription.onStateChange();\n }\n }\n\n function isSubscribed() {\n return Boolean(unsubscribe);\n }\n\n function trySubscribe() {\n if (!unsubscribe) {\n unsubscribe = parentSub ? parentSub.addNestedSub(handleChangeWrapper) : store.subscribe(handleChangeWrapper);\n listeners = createListenerCollection();\n }\n }\n\n function tryUnsubscribe() {\n if (unsubscribe) {\n unsubscribe();\n unsubscribe = undefined;\n listeners.clear();\n listeners = nullListeners;\n }\n }\n\n const subscription = {\n addNestedSub,\n notifyNestedSubs,\n handleChangeWrapper,\n isSubscribed,\n trySubscribe,\n tryUnsubscribe,\n getListeners: () => listeners\n };\n return subscription;\n}","import { useEffect, useLayoutEffect } from 'react'; // React currently throws a warning when using useLayoutEffect on the server.\n// To get around it, we can conditionally useEffect on the server (no-op) and\n// useLayoutEffect in the browser. We need useLayoutEffect to ensure the store\n// subscription callback always has the selector from the latest render commit\n// available, otherwise a store update may happen between render and the effect,\n// which may cause missed updates; we also must ensure the store subscription\n// is created synchronously, otherwise a store update may occur before the\n// subscription is created and an inconsistent state may be observed\n// Matches logic in React's `shared/ExecutionEnvironment` file\n\nexport const canUseDOM = !!(typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined');\nexport const useIsomorphicLayoutEffect = canUseDOM ? useLayoutEffect : useEffect;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"reactReduxForwardedRef\"];\n\n/* eslint-disable valid-jsdoc, @typescript-eslint/no-unused-vars */\nimport hoistStatics from 'hoist-non-react-statics';\nimport React, { useContext, useMemo, useRef } from 'react';\nimport { isValidElementType, isContextConsumer } from 'react-is';\nimport defaultSelectorFactory from '../connect/selectorFactory';\nimport { mapDispatchToPropsFactory } from '../connect/mapDispatchToProps';\nimport { mapStateToPropsFactory } from '../connect/mapStateToProps';\nimport { mergePropsFactory } from '../connect/mergeProps';\nimport { createSubscription } from '../utils/Subscription';\nimport { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect';\nimport shallowEqual from '../utils/shallowEqual';\nimport warning from '../utils/warning';\nimport { ReactReduxContext } from './Context';\nimport { notInitialized } from '../utils/useSyncExternalStore';\nlet useSyncExternalStore = notInitialized;\nexport const initializeConnect = fn => {\n useSyncExternalStore = fn;\n}; // Define some constant arrays just to avoid re-creating these\n\nconst EMPTY_ARRAY = [null, 0];\nconst NO_SUBSCRIPTION_ARRAY = [null, null]; // Attempts to stringify whatever not-really-a-component value we were given\n// for logging in an error message\n\nconst stringifyComponent = Comp => {\n try {\n return JSON.stringify(Comp);\n } catch (err) {\n return String(Comp);\n }\n};\n\n// This is \"just\" a `useLayoutEffect`, but with two modifications:\n// - we need to fall back to `useEffect` in SSR to avoid annoying warnings\n// - we extract this to a separate function to avoid closing over values\n// and causing memory leaks\nfunction useIsomorphicLayoutEffectWithArgs(effectFunc, effectArgs, dependencies) {\n useIsomorphicLayoutEffect(() => effectFunc(...effectArgs), dependencies);\n} // Effect callback, extracted: assign the latest props values to refs for later usage\n\n\nfunction captureWrapperProps(lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, // actualChildProps: unknown,\nchildPropsFromStoreUpdate, notifyNestedSubs) {\n // We want to capture the wrapper props and child props we used for later comparisons\n lastWrapperProps.current = wrapperProps;\n renderIsScheduled.current = false; // If the render was from a store update, clear out that reference and cascade the subscriber update\n\n if (childPropsFromStoreUpdate.current) {\n childPropsFromStoreUpdate.current = null;\n notifyNestedSubs();\n }\n} // Effect callback, extracted: subscribe to the Redux store or nearest connected ancestor,\n// check for updates after dispatched actions, and trigger re-renders.\n\n\nfunction subscribeUpdates(shouldHandleStateChanges, store, subscription, childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, isMounted, childPropsFromStoreUpdate, notifyNestedSubs, // forceComponentUpdateDispatch: React.Dispatch,\nadditionalSubscribeListener) {\n // If we're not subscribed to the store, nothing to do here\n if (!shouldHandleStateChanges) return () => {}; // Capture values for checking if and when this component unmounts\n\n let didUnsubscribe = false;\n let lastThrownError = null; // We'll run this callback every time a store subscription update propagates to this component\n\n const checkForUpdates = () => {\n if (didUnsubscribe || !isMounted.current) {\n // Don't run stale listeners.\n // Redux doesn't guarantee unsubscriptions happen until next dispatch.\n return;\n } // TODO We're currently calling getState ourselves here, rather than letting `uSES` do it\n\n\n const latestStoreState = store.getState();\n let newChildProps, error;\n\n try {\n // Actually run the selector with the most recent store state and wrapper props\n // to determine what the child props should be\n newChildProps = childPropsSelector(latestStoreState, lastWrapperProps.current);\n } catch (e) {\n error = e;\n lastThrownError = e;\n }\n\n if (!error) {\n lastThrownError = null;\n } // If the child props haven't changed, nothing to do here - cascade the subscription update\n\n\n if (newChildProps === lastChildProps.current) {\n if (!renderIsScheduled.current) {\n notifyNestedSubs();\n }\n } else {\n // Save references to the new child props. Note that we track the \"child props from store update\"\n // as a ref instead of a useState/useReducer because we need a way to determine if that value has\n // been processed. If this went into useState/useReducer, we couldn't clear out the value without\n // forcing another re-render, which we don't want.\n lastChildProps.current = newChildProps;\n childPropsFromStoreUpdate.current = newChildProps;\n renderIsScheduled.current = true; // TODO This is hacky and not how `uSES` is meant to be used\n // Trigger the React `useSyncExternalStore` subscriber\n\n additionalSubscribeListener();\n }\n }; // Actually subscribe to the nearest connected ancestor (or store)\n\n\n subscription.onStateChange = checkForUpdates;\n subscription.trySubscribe(); // Pull data from the store after first render in case the store has\n // changed since we began.\n\n checkForUpdates();\n\n const unsubscribeWrapper = () => {\n didUnsubscribe = true;\n subscription.tryUnsubscribe();\n subscription.onStateChange = null;\n\n if (lastThrownError) {\n // It's possible that we caught an error due to a bad mapState function, but the\n // parent re-rendered without this component and we're about to unmount.\n // This shouldn't happen as long as we do top-down subscriptions correctly, but\n // if we ever do those wrong, this throw will surface the error in our tests.\n // In that case, throw the error from here so it doesn't get lost.\n throw lastThrownError;\n }\n };\n\n return unsubscribeWrapper;\n} // Reducer initial state creation for our update reducer\n\n\nconst initStateUpdates = () => EMPTY_ARRAY;\n\nfunction strictEqual(a, b) {\n return a === b;\n}\n/**\r\n * Infers the type of props that a connector will inject into a component.\r\n */\n\n\nlet hasWarnedAboutDeprecatedPureOption = false;\n/**\r\n * Connects a React component to a Redux store.\r\n *\r\n * - Without arguments, just wraps the component, without changing the behavior / props\r\n *\r\n * - If 2 params are passed (3rd param, mergeProps, is skipped), default behavior\r\n * is to override ownProps (as stated in the docs), so what remains is everything that's\r\n * not a state or dispatch prop\r\n *\r\n * - When 3rd param is passed, we don't know if ownProps propagate and whether they\r\n * should be valid component props, because it depends on mergeProps implementation.\r\n * As such, it is the user's responsibility to extend ownProps interface from state or\r\n * dispatch props or both when applicable\r\n *\r\n * @param mapStateToProps A function that extracts values from state\r\n * @param mapDispatchToProps Setup for dispatching actions\r\n * @param mergeProps Optional callback to merge state and dispatch props together\r\n * @param options Options for configuring the connection\r\n *\r\n */\n\nfunction connect(mapStateToProps, mapDispatchToProps, mergeProps, {\n // The `pure` option has been removed, so TS doesn't like us destructuring this to check its existence.\n // @ts-ignore\n pure,\n areStatesEqual = strictEqual,\n areOwnPropsEqual = shallowEqual,\n areStatePropsEqual = shallowEqual,\n areMergedPropsEqual = shallowEqual,\n // use React's forwardRef to expose a ref of the wrapped component\n forwardRef = false,\n // the context consumer to use\n context = ReactReduxContext\n} = {}) {\n if (process.env.NODE_ENV !== 'production') {\n if (pure !== undefined && !hasWarnedAboutDeprecatedPureOption) {\n hasWarnedAboutDeprecatedPureOption = true;\n warning('The `pure` option has been removed. `connect` is now always a \"pure/memoized\" component');\n }\n }\n\n const Context = context;\n const initMapStateToProps = mapStateToPropsFactory(mapStateToProps);\n const initMapDispatchToProps = mapDispatchToPropsFactory(mapDispatchToProps);\n const initMergeProps = mergePropsFactory(mergeProps);\n const shouldHandleStateChanges = Boolean(mapStateToProps);\n\n const wrapWithConnect = WrappedComponent => {\n if (process.env.NODE_ENV !== 'production' && !isValidElementType(WrappedComponent)) {\n throw new Error(`You must pass a component to the function returned by connect. Instead received ${stringifyComponent(WrappedComponent)}`);\n }\n\n const wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\n const displayName = `Connect(${wrappedComponentName})`;\n const selectorFactoryOptions = {\n shouldHandleStateChanges,\n displayName,\n wrappedComponentName,\n WrappedComponent,\n // @ts-ignore\n initMapStateToProps,\n // @ts-ignore\n initMapDispatchToProps,\n initMergeProps,\n areStatesEqual,\n areStatePropsEqual,\n areOwnPropsEqual,\n areMergedPropsEqual\n };\n\n function ConnectFunction(props) {\n const [propsContext, reactReduxForwardedRef, wrapperProps] = useMemo(() => {\n // Distinguish between actual \"data\" props that were passed to the wrapper component,\n // and values needed to control behavior (forwarded refs, alternate context instances).\n // To maintain the wrapperProps object reference, memoize this destructuring.\n const {\n reactReduxForwardedRef\n } = props,\n wrapperProps = _objectWithoutPropertiesLoose(props, _excluded);\n\n return [props.context, reactReduxForwardedRef, wrapperProps];\n }, [props]);\n const ContextToUse = useMemo(() => {\n // Users may optionally pass in a custom context instance to use instead of our ReactReduxContext.\n // Memoize the check that determines which context instance we should use.\n return propsContext && propsContext.Consumer && // @ts-ignore\n isContextConsumer( /*#__PURE__*/React.createElement(propsContext.Consumer, null)) ? propsContext : Context;\n }, [propsContext, Context]); // Retrieve the store and ancestor subscription via context, if available\n\n const contextValue = useContext(ContextToUse); // The store _must_ exist as either a prop or in context.\n // We'll check to see if it _looks_ like a Redux store first.\n // This allows us to pass through a `store` prop that is just a plain value.\n\n const didStoreComeFromProps = Boolean(props.store) && Boolean(props.store.getState) && Boolean(props.store.dispatch);\n const didStoreComeFromContext = Boolean(contextValue) && Boolean(contextValue.store);\n\n if (process.env.NODE_ENV !== 'production' && !didStoreComeFromProps && !didStoreComeFromContext) {\n throw new Error(`Could not find \"store\" in the context of ` + `\"${displayName}\". Either wrap the root component in a , ` + `or pass a custom React context provider to and the corresponding ` + `React context consumer to ${displayName} in connect options.`);\n } // Based on the previous check, one of these must be true\n\n\n const store = didStoreComeFromProps ? props.store : contextValue.store;\n const getServerState = didStoreComeFromContext ? contextValue.getServerState : store.getState;\n const childPropsSelector = useMemo(() => {\n // The child props selector needs the store reference as an input.\n // Re-create this selector whenever the store changes.\n return defaultSelectorFactory(store.dispatch, selectorFactoryOptions);\n }, [store]);\n const [subscription, notifyNestedSubs] = useMemo(() => {\n if (!shouldHandleStateChanges) return NO_SUBSCRIPTION_ARRAY; // This Subscription's source should match where store came from: props vs. context. A component\n // connected to the store via props shouldn't use subscription from context, or vice versa.\n\n const subscription = createSubscription(store, didStoreComeFromProps ? undefined : contextValue.subscription); // `notifyNestedSubs` is duplicated to handle the case where the component is unmounted in\n // the middle of the notification loop, where `subscription` will then be null. This can\n // probably be avoided if Subscription's listeners logic is changed to not call listeners\n // that have been unsubscribed in the middle of the notification loop.\n\n const notifyNestedSubs = subscription.notifyNestedSubs.bind(subscription);\n return [subscription, notifyNestedSubs];\n }, [store, didStoreComeFromProps, contextValue]); // Determine what {store, subscription} value should be put into nested context, if necessary,\n // and memoize that value to avoid unnecessary context updates.\n\n const overriddenContextValue = useMemo(() => {\n if (didStoreComeFromProps) {\n // This component is directly subscribed to a store from props.\n // We don't want descendants reading from this store - pass down whatever\n // the existing context value is from the nearest connected ancestor.\n return contextValue;\n } // Otherwise, put this component's subscription instance into context, so that\n // connected descendants won't update until after this component is done\n\n\n return _extends({}, contextValue, {\n subscription\n });\n }, [didStoreComeFromProps, contextValue, subscription]); // Set up refs to coordinate values between the subscription effect and the render logic\n\n const lastChildProps = useRef();\n const lastWrapperProps = useRef(wrapperProps);\n const childPropsFromStoreUpdate = useRef();\n const renderIsScheduled = useRef(false);\n const isProcessingDispatch = useRef(false);\n const isMounted = useRef(false);\n const latestSubscriptionCallbackError = useRef();\n useIsomorphicLayoutEffect(() => {\n isMounted.current = true;\n return () => {\n isMounted.current = false;\n };\n }, []);\n const actualChildPropsSelector = useMemo(() => {\n const selector = () => {\n // Tricky logic here:\n // - This render may have been triggered by a Redux store update that produced new child props\n // - However, we may have gotten new wrapper props after that\n // If we have new child props, and the same wrapper props, we know we should use the new child props as-is.\n // But, if we have new wrapper props, those might change the child props, so we have to recalculate things.\n // So, we'll use the child props from store update only if the wrapper props are the same as last time.\n if (childPropsFromStoreUpdate.current && wrapperProps === lastWrapperProps.current) {\n return childPropsFromStoreUpdate.current;\n } // TODO We're reading the store directly in render() here. Bad idea?\n // This will likely cause Bad Things (TM) to happen in Concurrent Mode.\n // Note that we do this because on renders _not_ caused by store updates, we need the latest store state\n // to determine what the child props should be.\n\n\n return childPropsSelector(store.getState(), wrapperProps);\n };\n\n return selector;\n }, [store, wrapperProps]); // We need this to execute synchronously every time we re-render. However, React warns\n // about useLayoutEffect in SSR, so we try to detect environment and fall back to\n // just useEffect instead to avoid the warning, since neither will run anyway.\n\n const subscribeForReact = useMemo(() => {\n const subscribe = reactListener => {\n if (!subscription) {\n return () => {};\n }\n\n return subscribeUpdates(shouldHandleStateChanges, store, subscription, // @ts-ignore\n childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, isMounted, childPropsFromStoreUpdate, notifyNestedSubs, reactListener);\n };\n\n return subscribe;\n }, [subscription]);\n useIsomorphicLayoutEffectWithArgs(captureWrapperProps, [lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, childPropsFromStoreUpdate, notifyNestedSubs]);\n let actualChildProps;\n\n try {\n actualChildProps = useSyncExternalStore( // TODO We're passing through a big wrapper that does a bunch of extra side effects besides subscribing\n subscribeForReact, // TODO This is incredibly hacky. We've already processed the store update and calculated new child props,\n // TODO and we're just passing that through so it triggers a re-render for us rather than relying on `uSES`.\n actualChildPropsSelector, getServerState ? () => childPropsSelector(getServerState(), wrapperProps) : actualChildPropsSelector);\n } catch (err) {\n if (latestSubscriptionCallbackError.current) {\n ;\n err.message += `\\nThe error may be correlated with this previous error:\\n${latestSubscriptionCallbackError.current.stack}\\n\\n`;\n }\n\n throw err;\n }\n\n useIsomorphicLayoutEffect(() => {\n latestSubscriptionCallbackError.current = undefined;\n childPropsFromStoreUpdate.current = undefined;\n lastChildProps.current = actualChildProps;\n }); // Now that all that's done, we can finally try to actually render the child component.\n // We memoize the elements for the rendered child component as an optimization.\n\n const renderedWrappedComponent = useMemo(() => {\n return (\n /*#__PURE__*/\n // @ts-ignore\n React.createElement(WrappedComponent, _extends({}, actualChildProps, {\n ref: reactReduxForwardedRef\n }))\n );\n }, [reactReduxForwardedRef, WrappedComponent, actualChildProps]); // If React sees the exact same element reference as last time, it bails out of re-rendering\n // that child, same as if it was wrapped in React.memo() or returned false from shouldComponentUpdate.\n\n const renderedChild = useMemo(() => {\n if (shouldHandleStateChanges) {\n // If this component is subscribed to store updates, we need to pass its own\n // subscription instance down to our descendants. That means rendering the same\n // Context instance, and putting a different value into the context.\n return /*#__PURE__*/React.createElement(ContextToUse.Provider, {\n value: overriddenContextValue\n }, renderedWrappedComponent);\n }\n\n return renderedWrappedComponent;\n }, [ContextToUse, renderedWrappedComponent, overriddenContextValue]);\n return renderedChild;\n }\n\n const _Connect = React.memo(ConnectFunction);\n\n // Add a hacky cast to get the right output type\n const Connect = _Connect;\n Connect.WrappedComponent = WrappedComponent;\n Connect.displayName = ConnectFunction.displayName = displayName;\n\n if (forwardRef) {\n const _forwarded = React.forwardRef(function forwardConnectRef(props, ref) {\n // @ts-ignore\n return /*#__PURE__*/React.createElement(Connect, _extends({}, props, {\n reactReduxForwardedRef: ref\n }));\n });\n\n const forwarded = _forwarded;\n forwarded.displayName = displayName;\n forwarded.WrappedComponent = WrappedComponent;\n return hoistStatics(forwarded, WrappedComponent);\n }\n\n return hoistStatics(Connect, WrappedComponent);\n };\n\n return wrapWithConnect;\n}\n\nexport default connect;","import React, { useMemo } from 'react';\nimport { ReactReduxContext } from './Context';\nimport { createSubscription } from '../utils/Subscription';\nimport { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect';\n\nfunction Provider({\n store,\n context,\n children,\n serverState\n}) {\n const contextValue = useMemo(() => {\n const subscription = createSubscription(store);\n return {\n store,\n subscription,\n getServerState: serverState ? () => serverState : undefined\n };\n }, [store, serverState]);\n const previousState = useMemo(() => store.getState(), [store]);\n useIsomorphicLayoutEffect(() => {\n const {\n subscription\n } = contextValue;\n subscription.onStateChange = subscription.notifyNestedSubs;\n subscription.trySubscribe();\n\n if (previousState !== store.getState()) {\n subscription.notifyNestedSubs();\n }\n\n return () => {\n subscription.tryUnsubscribe();\n subscription.onStateChange = undefined;\n };\n }, [contextValue, previousState]);\n const Context = context || ReactReduxContext; // @ts-ignore 'AnyAction' is assignable to the constraint of type 'A', but 'A' could be instantiated with a different subtype\n\n return /*#__PURE__*/React.createElement(Context.Provider, {\n value: contextValue\n }, children);\n}\n\nexport default Provider;","import { useContext } from 'react';\nimport { ReactReduxContext } from '../components/Context';\nimport { useReduxContext as useDefaultReduxContext } from './useReduxContext';\n/**\r\n * Hook factory, which creates a `useStore` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useStore` hook bound to the specified context.\r\n */\n\nexport function createStoreHook(context = ReactReduxContext) {\n const useReduxContext = // @ts-ignore\n context === ReactReduxContext ? useDefaultReduxContext : () => useContext(context);\n return function useStore() {\n const {\n store\n } = useReduxContext(); // @ts-ignore\n\n return store;\n };\n}\n/**\r\n * A hook to access the redux store.\r\n *\r\n * @returns {any} the redux store\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useStore } from 'react-redux'\r\n *\r\n * export const ExampleComponent = () => {\r\n * const store = useStore()\r\n * return
{store.getState()}
\r\n * }\r\n */\n\nexport const useStore = /*#__PURE__*/createStoreHook();","import { ReactReduxContext } from '../components/Context';\nimport { useStore as useDefaultStore, createStoreHook } from './useStore';\n/**\r\n * Hook factory, which creates a `useDispatch` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useDispatch` hook bound to the specified context.\r\n */\n\nexport function createDispatchHook(context = ReactReduxContext) {\n const useStore = // @ts-ignore\n context === ReactReduxContext ? useDefaultStore : createStoreHook(context);\n return function useDispatch() {\n const store = useStore(); // @ts-ignore\n\n return store.dispatch;\n };\n}\n/**\r\n * A hook to access the redux `dispatch` function.\r\n *\r\n * @returns {any|function} redux store's `dispatch` function\r\n *\r\n * @example\r\n *\r\n * import React, { useCallback } from 'react'\r\n * import { useDispatch } from 'react-redux'\r\n *\r\n * export const CounterComponent = ({ value }) => {\r\n * const dispatch = useDispatch()\r\n * const increaseCounter = useCallback(() => dispatch({ type: 'increase-counter' }), [])\r\n * return (\r\n *
\r\n * {value}\r\n * \r\n *
\r\n * )\r\n * }\r\n */\n\nexport const useDispatch = /*#__PURE__*/createDispatchHook();","// The primary entry point assumes we're working with standard ReactDOM/RN, but\n// older versions that do not include `useSyncExternalStore` (React 16.9 - 17.x).\n// Because of that, the useSyncExternalStore compat shim is needed.\nimport { useSyncExternalStore } from 'use-sync-external-store/shim';\nimport { useSyncExternalStoreWithSelector } from 'use-sync-external-store/shim/with-selector';\nimport { unstable_batchedUpdates as batch } from './utils/reactBatchedUpdates';\nimport { setBatch } from './utils/batch';\nimport { initializeUseSelector } from './hooks/useSelector';\nimport { initializeConnect } from './components/connect';\ninitializeUseSelector(useSyncExternalStoreWithSelector);\ninitializeConnect(useSyncExternalStore); // Enable batched updates in our subscriptions for use\n// with standard React renderers (ReactDOM, React Native)\n\nsetBatch(batch);\nexport { batch };\nexport * from './exports';","/**\n * @license React\n * use-sync-external-store-shim.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var e=require(\"react\");function h(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var k=\"function\"===typeof Object.is?Object.is:h,l=e.useState,m=e.useEffect,n=e.useLayoutEffect,p=e.useDebugValue;function q(a,b){var d=b(),f=l({inst:{value:d,getSnapshot:b}}),c=f[0].inst,g=f[1];n(function(){c.value=d;c.getSnapshot=b;r(c)&&g({inst:c})},[a,d,b]);m(function(){r(c)&&g({inst:c});return a(function(){r(c)&&g({inst:c})})},[a]);p(d);return d}\nfunction r(a){var b=a.getSnapshot;a=a.value;try{var d=b();return!k(a,d)}catch(f){return!0}}function t(a,b){return b()}var u=\"undefined\"===typeof window||\"undefined\"===typeof window.document||\"undefined\"===typeof window.document.createElement?t:q;exports.useSyncExternalStore=void 0!==e.useSyncExternalStore?e.useSyncExternalStore:u;\n","/**\n * @license React\n * use-sync-external-store-shim/with-selector.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var h=require(\"react\"),n=require(\"use-sync-external-store/shim\");function p(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var q=\"function\"===typeof Object.is?Object.is:p,r=n.useSyncExternalStore,t=h.useRef,u=h.useEffect,v=h.useMemo,w=h.useDebugValue;\nexports.useSyncExternalStoreWithSelector=function(a,b,e,l,g){var c=t(null);if(null===c.current){var f={hasValue:!1,value:null};c.current=f}else f=c.current;c=v(function(){function a(a){if(!c){c=!0;d=a;a=l(a);if(void 0!==g&&f.hasValue){var b=f.value;if(g(b,a))return k=b}return k=a}b=k;if(q(d,a))return b;var e=l(a);if(void 0!==g&&g(b,e))return b;d=a;return k=e}var c=!1,d,k,m=void 0===e?null:e;return[function(){return a(b())},null===m?void 0:function(){return a(m())}]},[b,e,l,g]);var d=r(a,c[0],c[1]);\nu(function(){f.hasValue=!0;f.value=d},[d]);w(d);return d};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.min.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.production.min.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.development.js');\n}\n","var isProduction = process.env.NODE_ENV === 'production';\nvar prefix = 'Invariant failed';\nfunction invariant(condition, message) {\n if (condition) {\n return;\n }\n if (isProduction) {\n throw new Error(prefix);\n }\n var provided = typeof message === 'function' ? message() : message;\n var value = provided ? \"\".concat(prefix, \": \").concat(provided) : prefix;\n throw new Error(value);\n}\n\nexport { invariant as default };\n"],"names":["isAbsolute","pathname","charAt","spliceOne","list","index","i","k","n","length","pop","to","from","undefined","hasTrailingSlash","toParts","split","fromParts","isToAbs","isFromAbs","mustEndAbs","concat","last","up","part","unshift","result","join","substr","obj","valueOf","Object","prototype","call","valueEqual","a","b","Array","isArray","every","item","aValue","bValue","keys","assign","key","addLeadingSlash","path","stripLeadingSlash","stripBasename","prefix","toLowerCase","indexOf","hasBasename","stripTrailingSlash","slice","parsePath","search","hash","hashIndex","searchIndex","createPath","location","createLocation","state","currentLocation","decodeURI","e","URIError","locationsAreEqual","createTransitionManager","prompt","listeners","setPrompt","nextPrompt","confirmTransitionTo","action","getUserConfirmation","callback","appendListener","fn","isActive","listener","apply","arguments","push","filter","notifyListeners","_len","args","_key","forEach","canUseDOM","window","document","createElement","getConfirmation","message","confirm","PopStateEvent","HashChangeEvent","getHistoryState","history","createBrowserHistory","props","ua","globalHistory","canUseHistory","navigator","userAgent","needsHashChangeListener","_props","_props$forceRefresh","forceRefresh","_props$getUserConfirm","_props$keyLength","keyLength","basename","getDOMLocation","historyState","_ref","_window$location","createKey","Math","random","toString","transitionManager","setState","nextState","handlePopState","event","isExtraneousPopstateEvent","handlePop","handleHashChange","forceNextPop","ok","fromLocation","toLocation","toIndex","allKeys","fromIndex","delta","go","revertPop","initialLocation","createHref","listenerCount","checkDOMListeners","addEventListener","removeEventListener","isBlocked","href","pushState","prevIndex","nextKeys","replace","replaceState","goBack","goForward","block","unblock","listen","unlisten","HashChangeEvent$1","HashPathCoders","hashbang","encodePath","decodePath","noslash","slash","stripHash","url","getHashPath","substring","replaceHashPath","createHashHistory","_props$hashType","hashType","_HashPathCoders$hashT","ignorePath","encodedPath","prevLocation","allPaths","lastIndexOf","baseTag","querySelector","getAttribute","pushHashPath","nextPaths","clamp","lowerBound","upperBound","min","max","createMemoryHistory","_props$initialEntries","initialEntries","_props$initialIndex","initialIndex","entries","map","entry","nextIndex","nextEntries","splice","canGo","u","Symbol","for","c","d","f","g","h","l","m","p","q","t","v","r","$$typeof","type","exports","isValidElementType","getModuleId","typeOf","module","batch","getBatch","useContext","useSyncExternalStoreWithSelector","Error","refEquality","createSelectorHook","context","useReduxContext","selector","equalityFn","store","subscription","getServerState","selectedState","addNestedSub","getState","useDebugValue","useSelector","nullListeners","notify","get","parentSub","unsubscribe","handleChangeWrapper","onStateChange","trySubscribe","subscribe","first","clear","next","isSubscribed","prev","createListenerCollection","notifyNestedSubs","Boolean","tryUnsubscribe","getListeners","useLayoutEffect","useEffect","useSyncExternalStore","children","serverState","contextValue","useMemo","previousState","Context","Provider","value","createStoreHook","createDispatchHook","useStore","dispatch","useDispatch","newBatch","initializeConnect","is","useState","getSnapshot","inst","useRef","w","current","hasValue","isProduction","invariant","condition","provided"],"sourceRoot":""}