{"version":3,"file":"static/js/4417.06b2b6a0.js","mappings":"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","sources":["../node_modules/@redux-saga/symbols/dist/redux-saga-symbols.esm.js","../node_modules/redux-ignore/lib/index.js","../node_modules/@redux-saga/core/dist/redux-saga-effects.esm.js","../node_modules/@redux-saga/deferred/dist/redux-saga-deferred.esm.js","../node_modules/@redux-saga/core/dist/redux-saga-core.esm.js","../node_modules/redux-saga/dist/redux-saga-core-npm-proxy.esm.js","../node_modules/redux/src/utils/formatProdErrorMessage.ts","../node_modules/redux/src/utils/symbol-observable.ts","../node_modules/redux/src/utils/actionTypes.ts","../node_modules/redux/src/utils/isPlainObject.ts","../node_modules/redux/src/createStore.ts","../node_modules/redux/src/combineReducers.ts","../node_modules/redux/src/compose.ts","../node_modules/redux/src/applyMiddleware.ts","../node_modules/react/index.js","../node_modules/react/jsx-runtime.js","../node_modules/redux-thunk/dist/redux-thunk.mjs","../node_modules/@redux-saga/is/dist/redux-saga-is.esm.js","../node_modules/@redux-saga/delay-p/dist/redux-saga-delay-p.esm.js","../node_modules/@redux-saga/core/dist/io-22ea0cf9.js"],"sourcesContent":["var createSymbol = function createSymbol(name) {\n return \"@@redux-saga/\" + name;\n};\n\nvar CANCEL =\n/*#__PURE__*/\ncreateSymbol('CANCEL_PROMISE');\nvar CHANNEL_END_TYPE =\n/*#__PURE__*/\ncreateSymbol('CHANNEL_END');\nvar IO =\n/*#__PURE__*/\ncreateSymbol('IO');\nvar MATCH =\n/*#__PURE__*/\ncreateSymbol('MATCH');\nvar MULTICAST =\n/*#__PURE__*/\ncreateSymbol('MULTICAST');\nvar SAGA_ACTION =\n/*#__PURE__*/\ncreateSymbol('SAGA_ACTION');\nvar SELF_CANCELLATION =\n/*#__PURE__*/\ncreateSymbol('SELF_CANCELLATION');\nvar TASK =\n/*#__PURE__*/\ncreateSymbol('TASK');\nvar TASK_CANCEL =\n/*#__PURE__*/\ncreateSymbol('TASK_CANCEL');\nvar TERMINATE =\n/*#__PURE__*/\ncreateSymbol('TERMINATE');\nvar SAGA_LOCATION =\n/*#__PURE__*/\ncreateSymbol('LOCATION');\n\nexport { CANCEL, CHANNEL_END_TYPE, IO, MATCH, MULTICAST, SAGA_ACTION, SAGA_LOCATION, SELF_CANCELLATION, TASK, TASK_CANCEL, TERMINATE };\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nfunction isFunction(obj) {\n return !!(obj && obj.constructor && obj.call && obj.apply);\n}\n\nfunction createActionHandler(ignore) {\n // redux-ignore higher order reducer\n return function handleAction(reducer) {\n var actions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];\n\n var predicate = isFunction(actions) ? actions : function (action) {\n return actions.indexOf(action.type) >= 0;\n };\n\n var initialState = reducer(undefined, {});\n\n return function () {\n var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;\n var action = arguments[1];\n\n if (predicate(action)) {\n return ignore ? state : reducer(state, action);\n }\n\n return ignore ? reducer(state, action) : state;\n };\n };\n}\n\nvar ignoreActions = exports.ignoreActions = createActionHandler(true);\nvar filterActions = exports.filterActions = createActionHandler(false);\n\nexports.default = ignoreActions;\n// /redux-ignore","import '@redux-saga/symbols';\nimport '@babel/runtime/helpers/esm/extends';\nimport { channel, stringableFunc, func, notUndef } from '@redux-saga/is';\nimport { q as makeIterator, L as take, M as fork, N as cancel, O as call, Q as delay, U as actionChannel, V as sliding, W as race, c as check } from './io-22ea0cf9.js';\nexport { U as actionChannel, $ as all, a0 as apply, O as call, N as cancel, a5 as cancelled, a1 as cps, Q as delay, X as effectTypes, a6 as flush, M as fork, a7 as getContext, a3 as join, Z as put, _ as putResolve, W as race, a4 as select, a8 as setContext, a2 as spawn, L as take, Y as takeMaybe } from './io-22ea0cf9.js';\nimport '@redux-saga/delay-p';\n\nvar done = function done(value) {\n return {\n done: true,\n value: value\n };\n};\n\nvar qEnd = {};\nfunction safeName(patternOrChannel) {\n if (channel(patternOrChannel)) {\n return 'channel';\n }\n\n if (stringableFunc(patternOrChannel)) {\n return String(patternOrChannel);\n }\n\n if (func(patternOrChannel)) {\n return patternOrChannel.name;\n }\n\n return String(patternOrChannel);\n}\nfunction fsmIterator(fsm, startState, name) {\n var stateUpdater,\n errorState,\n effect,\n nextState = startState;\n\n function next(arg, error) {\n if (nextState === qEnd) {\n return done(arg);\n }\n\n if (error && !errorState) {\n nextState = qEnd;\n throw error;\n } else {\n stateUpdater && stateUpdater(arg);\n var currentState = error ? fsm[errorState](error) : fsm[nextState]();\n nextState = currentState.nextState;\n effect = currentState.effect;\n stateUpdater = currentState.stateUpdater;\n errorState = currentState.errorState;\n return nextState === qEnd ? done(arg) : effect;\n }\n }\n\n return makeIterator(next, function (error) {\n return next(null, error);\n }, name);\n}\n\nfunction takeEvery(patternOrChannel, worker) {\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n\n var yTake = {\n done: false,\n value: take(patternOrChannel)\n };\n\n var yFork = function yFork(ac) {\n return {\n done: false,\n value: fork.apply(void 0, [worker].concat(args, [ac]))\n };\n };\n\n var action,\n setAction = function setAction(ac) {\n return action = ac;\n };\n\n return fsmIterator({\n q1: function q1() {\n return {\n nextState: 'q2',\n effect: yTake,\n stateUpdater: setAction\n };\n },\n q2: function q2() {\n return {\n nextState: 'q1',\n effect: yFork(action)\n };\n }\n }, 'q1', \"takeEvery(\" + safeName(patternOrChannel) + \", \" + worker.name + \")\");\n}\n\nfunction takeLatest(patternOrChannel, worker) {\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n\n var yTake = {\n done: false,\n value: take(patternOrChannel)\n };\n\n var yFork = function yFork(ac) {\n return {\n done: false,\n value: fork.apply(void 0, [worker].concat(args, [ac]))\n };\n };\n\n var yCancel = function yCancel(task) {\n return {\n done: false,\n value: cancel(task)\n };\n };\n\n var task, action;\n\n var setTask = function setTask(t) {\n return task = t;\n };\n\n var setAction = function setAction(ac) {\n return action = ac;\n };\n\n return fsmIterator({\n q1: function q1() {\n return {\n nextState: 'q2',\n effect: yTake,\n stateUpdater: setAction\n };\n },\n q2: function q2() {\n return task ? {\n nextState: 'q3',\n effect: yCancel(task)\n } : {\n nextState: 'q1',\n effect: yFork(action),\n stateUpdater: setTask\n };\n },\n q3: function q3() {\n return {\n nextState: 'q1',\n effect: yFork(action),\n stateUpdater: setTask\n };\n }\n }, 'q1', \"takeLatest(\" + safeName(patternOrChannel) + \", \" + worker.name + \")\");\n}\n\nfunction takeLeading(patternOrChannel, worker) {\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n\n var yTake = {\n done: false,\n value: take(patternOrChannel)\n };\n\n var yCall = function yCall(ac) {\n return {\n done: false,\n value: call.apply(void 0, [worker].concat(args, [ac]))\n };\n };\n\n var action;\n\n var setAction = function setAction(ac) {\n return action = ac;\n };\n\n return fsmIterator({\n q1: function q1() {\n return {\n nextState: 'q2',\n effect: yTake,\n stateUpdater: setAction\n };\n },\n q2: function q2() {\n return {\n nextState: 'q1',\n effect: yCall(action)\n };\n }\n }, 'q1', \"takeLeading(\" + safeName(patternOrChannel) + \", \" + worker.name + \")\");\n}\n\nfunction throttle(delayLength, patternOrChannel, worker) {\n for (var _len = arguments.length, args = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {\n args[_key - 3] = arguments[_key];\n }\n\n var action, channel$1;\n\n var yTake = function yTake() {\n return {\n done: false,\n value: take(channel$1)\n };\n };\n\n var yFork = function yFork(ac) {\n return {\n done: false,\n value: fork.apply(void 0, [worker].concat(args, [ac]))\n };\n };\n\n var yDelay = {\n done: false,\n value: delay(delayLength)\n };\n\n var setAction = function setAction(ac) {\n return action = ac;\n };\n\n var setChannel = function setChannel(ch) {\n return channel$1 = ch;\n };\n\n var needsChannel = !channel(patternOrChannel);\n\n if (!needsChannel) {\n setChannel(patternOrChannel);\n }\n\n return fsmIterator({\n q1: function q1() {\n var yActionChannel = {\n done: false,\n value: actionChannel(patternOrChannel, sliding(1))\n };\n return {\n nextState: 'q2',\n effect: yActionChannel,\n stateUpdater: setChannel\n };\n },\n q2: function q2() {\n return {\n nextState: 'q3',\n effect: yTake(),\n stateUpdater: setAction\n };\n },\n q3: function q3() {\n return {\n nextState: 'q4',\n effect: yFork(action)\n };\n },\n q4: function q4() {\n return {\n nextState: 'q2',\n effect: yDelay\n };\n }\n }, needsChannel ? 'q1' : 'q2', \"throttle(\" + safeName(patternOrChannel) + \", \" + worker.name + \")\");\n}\n\nfunction retry(maxTries, delayLength, fn) {\n var counter = maxTries;\n\n for (var _len = arguments.length, args = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {\n args[_key - 3] = arguments[_key];\n }\n\n var yCall = {\n done: false,\n value: call.apply(void 0, [fn].concat(args))\n };\n var yDelay = {\n done: false,\n value: delay(delayLength)\n };\n return fsmIterator({\n q1: function q1() {\n return {\n nextState: 'q2',\n effect: yCall,\n errorState: 'q10'\n };\n },\n q2: function q2() {\n return {\n nextState: qEnd\n };\n },\n q10: function q10(error) {\n counter -= 1;\n\n if (counter <= 0) {\n throw error;\n }\n\n return {\n nextState: 'q1',\n effect: yDelay\n };\n }\n }, 'q1', \"retry(\" + fn.name + \")\");\n}\n\nfunction debounceHelper(delayLength, patternOrChannel, worker) {\n for (var _len = arguments.length, args = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {\n args[_key - 3] = arguments[_key];\n }\n\n var action, raceOutput;\n var yTake = {\n done: false,\n value: take(patternOrChannel)\n };\n var yRace = {\n done: false,\n value: race({\n action: take(patternOrChannel),\n debounce: delay(delayLength)\n })\n };\n\n var yFork = function yFork(ac) {\n return {\n done: false,\n value: fork.apply(void 0, [worker].concat(args, [ac]))\n };\n };\n\n var yNoop = function yNoop(value) {\n return {\n done: false,\n value: value\n };\n };\n\n var setAction = function setAction(ac) {\n return action = ac;\n };\n\n var setRaceOutput = function setRaceOutput(ro) {\n return raceOutput = ro;\n };\n\n return fsmIterator({\n q1: function q1() {\n return {\n nextState: 'q2',\n effect: yTake,\n stateUpdater: setAction\n };\n },\n q2: function q2() {\n return {\n nextState: 'q3',\n effect: yRace,\n stateUpdater: setRaceOutput\n };\n },\n q3: function q3() {\n return raceOutput.debounce ? {\n nextState: 'q1',\n effect: yFork(action)\n } : {\n nextState: 'q2',\n effect: yNoop(raceOutput.action),\n stateUpdater: setAction\n };\n }\n }, 'q1', \"debounce(\" + safeName(patternOrChannel) + \", \" + worker.name + \")\");\n}\n\nvar validateTakeEffect = function validateTakeEffect(fn, patternOrChannel, worker) {\n check(patternOrChannel, notUndef, fn.name + \" requires a pattern or channel\");\n check(worker, notUndef, fn.name + \" requires a saga parameter\");\n};\n\nfunction takeEvery$1(patternOrChannel, worker) {\n if (process.env.NODE_ENV !== 'production') {\n validateTakeEffect(takeEvery$1, patternOrChannel, worker);\n }\n\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n\n return fork.apply(void 0, [takeEvery, patternOrChannel, worker].concat(args));\n}\nfunction takeLatest$1(patternOrChannel, worker) {\n if (process.env.NODE_ENV !== 'production') {\n validateTakeEffect(takeLatest$1, patternOrChannel, worker);\n }\n\n for (var _len2 = arguments.length, args = new Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {\n args[_key2 - 2] = arguments[_key2];\n }\n\n return fork.apply(void 0, [takeLatest, patternOrChannel, worker].concat(args));\n}\nfunction takeLeading$1(patternOrChannel, worker) {\n if (process.env.NODE_ENV !== 'production') {\n validateTakeEffect(takeLeading$1, patternOrChannel, worker);\n }\n\n for (var _len3 = arguments.length, args = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {\n args[_key3 - 2] = arguments[_key3];\n }\n\n return fork.apply(void 0, [takeLeading, patternOrChannel, worker].concat(args));\n}\nfunction throttle$1(ms, patternOrChannel, worker) {\n if (process.env.NODE_ENV !== 'production') {\n check(patternOrChannel, notUndef, \"throttle requires a pattern or channel\");\n check(worker, notUndef, 'throttle requires a saga parameter');\n }\n\n for (var _len4 = arguments.length, args = new Array(_len4 > 3 ? _len4 - 3 : 0), _key4 = 3; _key4 < _len4; _key4++) {\n args[_key4 - 3] = arguments[_key4];\n }\n\n return fork.apply(void 0, [throttle, ms, patternOrChannel, worker].concat(args));\n}\nfunction retry$1(maxTries, delayLength, worker) {\n for (var _len5 = arguments.length, args = new Array(_len5 > 3 ? _len5 - 3 : 0), _key5 = 3; _key5 < _len5; _key5++) {\n args[_key5 - 3] = arguments[_key5];\n }\n\n return call.apply(void 0, [retry, maxTries, delayLength, worker].concat(args));\n}\nfunction debounce(delayLength, pattern, worker) {\n for (var _len6 = arguments.length, args = new Array(_len6 > 3 ? _len6 - 3 : 0), _key6 = 3; _key6 < _len6; _key6++) {\n args[_key6 - 3] = arguments[_key6];\n }\n\n return fork.apply(void 0, [debounceHelper, delayLength, pattern, worker].concat(args));\n}\n\nexport { debounce, retry$1 as retry, takeEvery$1 as takeEvery, takeLatest$1 as takeLatest, takeLeading$1 as takeLeading, throttle$1 as throttle };\n","function deferred() {\n var def = {};\n def.promise = new Promise(function (resolve, reject) {\n def.resolve = resolve;\n def.reject = reject;\n });\n return def;\n}\nfunction arrayOfDeferred(length) {\n var arr = [];\n\n for (var i = 0; i < length; i++) {\n arr.push(deferred());\n }\n\n return arr;\n}\n\nexport default deferred;\nexport { arrayOfDeferred };\n","import { CHANNEL_END_TYPE, MULTICAST, MATCH, SAGA_ACTION, CANCEL, SELF_CANCELLATION, TERMINATE, TASK, TASK_CANCEL, IO } from '@redux-saga/symbols';\nexport { CANCEL, SAGA_LOCATION } from '@redux-saga/symbols';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\nimport { string as string$1, array as array$1, stringableFunc, func, symbol as symbol$1, buffer, notUndef, promise, iterator, undef, object, channel as channel$1 } from '@redux-saga/is';\nimport { k as kTrue, e as expanding, c as check, o as once, r as remove, n as none, i as internalErr, T as TAKE, P as PUT, A as ALL, R as RACE, C as CALL, a as CPS, F as FORK, J as JOIN, b as CANCEL$1, S as SELECT, d as ACTION_CHANNEL, f as CANCELLED$1, g as FLUSH, G as GET_CONTEXT, h as SET_CONTEXT, j as getMetaInfo, l as createAllStyleChildCallbacks, m as createEmptyArray, p as assignWithSymbols, q as makeIterator, s as shouldComplete, t as noop, u as flatMap, v as getLocation, w as createSetContextWarning, x as asyncIteratorSymbol, y as shouldCancel, z as shouldTerminate, B as compose, D as logError, E as wrapSagaDispatch, H as identity } from './io-22ea0cf9.js';\nexport { I as buffers, K as detach } from './io-22ea0cf9.js';\nimport deferred from '@redux-saga/deferred';\nimport '@redux-saga/delay-p';\n\nvar queue = [];\n/**\n Variable to hold a counting semaphore\n - Incrementing adds a lock and puts the scheduler in a `suspended` state (if it's not\n already suspended)\n - Decrementing releases a lock. Zero locks puts the scheduler in a `released` state. This\n triggers flushing the queued tasks.\n**/\n\nvar semaphore = 0;\n/**\n Executes a task 'atomically'. Tasks scheduled during this execution will be queued\n and flushed after this task has finished (assuming the scheduler endup in a released\n state).\n**/\n\nfunction exec(task) {\n try {\n suspend();\n task();\n } finally {\n release();\n }\n}\n/**\n Executes or queues a task depending on the state of the scheduler (`suspended` or `released`)\n**/\n\n\nfunction asap(task) {\n queue.push(task);\n\n if (!semaphore) {\n suspend();\n flush();\n }\n}\n/**\n * Puts the scheduler in a `suspended` state and executes a task immediately.\n */\n\nfunction immediately(task) {\n try {\n suspend();\n return task();\n } finally {\n flush();\n }\n}\n/**\n Puts the scheduler in a `suspended` state. Scheduled tasks will be queued until the\n scheduler is released.\n**/\n\nfunction suspend() {\n semaphore++;\n}\n/**\n Puts the scheduler in a `released` state.\n**/\n\n\nfunction release() {\n semaphore--;\n}\n/**\n Releases the current lock. Executes all queued tasks if the scheduler is in the released state.\n**/\n\n\nfunction flush() {\n release();\n var task;\n\n while (!semaphore && (task = queue.shift()) !== undefined) {\n exec(task);\n }\n}\n\nvar array = function array(patterns) {\n return function (input) {\n return patterns.some(function (p) {\n return matcher(p)(input);\n });\n };\n};\nvar predicate = function predicate(_predicate) {\n return function (input) {\n return _predicate(input);\n };\n};\nvar string = function string(pattern) {\n return function (input) {\n return input.type === String(pattern);\n };\n};\nvar symbol = function symbol(pattern) {\n return function (input) {\n return input.type === pattern;\n };\n};\nvar wildcard = function wildcard() {\n return kTrue;\n};\nfunction matcher(pattern) {\n // prettier-ignore\n var matcherCreator = pattern === '*' ? wildcard : string$1(pattern) ? string : array$1(pattern) ? array : stringableFunc(pattern) ? string : func(pattern) ? predicate : symbol$1(pattern) ? symbol : null;\n\n if (matcherCreator === null) {\n throw new Error(\"invalid pattern: \" + pattern);\n }\n\n return matcherCreator(pattern);\n}\n\nvar END = {\n type: CHANNEL_END_TYPE\n};\nvar isEnd = function isEnd(a) {\n return a && a.type === CHANNEL_END_TYPE;\n};\nvar CLOSED_CHANNEL_WITH_TAKERS = 'Cannot have a closed channel with pending takers';\nvar INVALID_BUFFER = 'invalid buffer passed to channel factory function';\nvar UNDEFINED_INPUT_ERROR = \"Saga or channel was provided with an undefined action\\nHints:\\n - check that your Action Creator returns a non-undefined value\\n - if the Saga was started using runSaga, check that your subscribe source provides the action to its listeners\";\nfunction channel(buffer$1) {\n if (buffer$1 === void 0) {\n buffer$1 = expanding();\n }\n\n var closed = false;\n var takers = [];\n\n if (process.env.NODE_ENV !== 'production') {\n check(buffer$1, buffer, INVALID_BUFFER);\n }\n\n function checkForbiddenStates() {\n if (closed && takers.length) {\n throw internalErr(CLOSED_CHANNEL_WITH_TAKERS);\n }\n\n if (takers.length && !buffer$1.isEmpty()) {\n throw internalErr('Cannot have pending takers with non empty buffer');\n }\n }\n\n function put(input) {\n if (process.env.NODE_ENV !== 'production') {\n checkForbiddenStates();\n check(input, notUndef, UNDEFINED_INPUT_ERROR);\n }\n\n if (closed) {\n return;\n }\n\n if (takers.length === 0) {\n return buffer$1.put(input);\n }\n\n var cb = takers.shift();\n cb(input);\n }\n\n function take(cb) {\n if (process.env.NODE_ENV !== 'production') {\n checkForbiddenStates();\n check(cb, func, \"channel.take's callback must be a function\");\n }\n\n if (closed && buffer$1.isEmpty()) {\n cb(END);\n } else if (!buffer$1.isEmpty()) {\n cb(buffer$1.take());\n } else {\n takers.push(cb);\n\n cb.cancel = function () {\n remove(takers, cb);\n };\n }\n }\n\n function flush(cb) {\n if (process.env.NODE_ENV !== 'production') {\n checkForbiddenStates();\n check(cb, func, \"channel.flush' callback must be a function\");\n }\n\n if (closed && buffer$1.isEmpty()) {\n cb(END);\n return;\n }\n\n cb(buffer$1.flush());\n }\n\n function close() {\n if (process.env.NODE_ENV !== 'production') {\n checkForbiddenStates();\n }\n\n if (closed) {\n return;\n }\n\n closed = true;\n var arr = takers;\n takers = [];\n\n for (var i = 0, len = arr.length; i < len; i++) {\n var taker = arr[i];\n taker(END);\n }\n }\n\n return {\n take: take,\n put: put,\n flush: flush,\n close: close\n };\n}\nfunction eventChannel(subscribe, buffer) {\n if (buffer === void 0) {\n buffer = none();\n }\n\n var closed = false;\n var unsubscribe;\n var chan = channel(buffer);\n\n var close = function close() {\n if (closed) {\n return;\n }\n\n closed = true;\n\n if (func(unsubscribe)) {\n unsubscribe();\n }\n\n chan.close();\n };\n\n unsubscribe = subscribe(function (input) {\n if (isEnd(input)) {\n close();\n return;\n }\n\n chan.put(input);\n });\n\n if (process.env.NODE_ENV !== 'production') {\n check(unsubscribe, func, 'in eventChannel: subscribe should return a function to unsubscribe');\n }\n\n unsubscribe = once(unsubscribe);\n\n if (closed) {\n unsubscribe();\n }\n\n return {\n take: chan.take,\n flush: chan.flush,\n close: close\n };\n}\nfunction multicastChannel() {\n var _ref;\n\n var closed = false;\n var currentTakers = [];\n var nextTakers = currentTakers;\n\n function checkForbiddenStates() {\n if (closed && nextTakers.length) {\n throw internalErr(CLOSED_CHANNEL_WITH_TAKERS);\n }\n }\n\n var ensureCanMutateNextTakers = function ensureCanMutateNextTakers() {\n if (nextTakers !== currentTakers) {\n return;\n }\n\n nextTakers = currentTakers.slice();\n };\n\n var close = function close() {\n if (process.env.NODE_ENV !== 'production') {\n checkForbiddenStates();\n }\n\n closed = true;\n var takers = currentTakers = nextTakers;\n nextTakers = [];\n takers.forEach(function (taker) {\n taker(END);\n });\n };\n\n return _ref = {}, _ref[MULTICAST] = true, _ref.put = function put(input) {\n if (process.env.NODE_ENV !== 'production') {\n checkForbiddenStates();\n check(input, notUndef, UNDEFINED_INPUT_ERROR);\n }\n\n if (closed) {\n return;\n }\n\n if (isEnd(input)) {\n close();\n return;\n }\n\n var takers = currentTakers = nextTakers;\n\n for (var i = 0, len = takers.length; i < len; i++) {\n var taker = takers[i];\n\n if (taker[MATCH](input)) {\n taker.cancel();\n taker(input);\n }\n }\n }, _ref.take = function take(cb, matcher) {\n if (matcher === void 0) {\n matcher = wildcard;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n checkForbiddenStates();\n }\n\n if (closed) {\n cb(END);\n return;\n }\n\n cb[MATCH] = matcher;\n ensureCanMutateNextTakers();\n nextTakers.push(cb);\n cb.cancel = once(function () {\n ensureCanMutateNextTakers();\n remove(nextTakers, cb);\n });\n }, _ref.close = close, _ref;\n}\nfunction stdChannel() {\n var chan = multicastChannel();\n var put = chan.put;\n\n chan.put = function (input) {\n if (input[SAGA_ACTION]) {\n put(input);\n return;\n }\n\n asap(function () {\n put(input);\n });\n };\n\n return chan;\n}\n\nvar RUNNING = 0;\nvar CANCELLED = 1;\nvar ABORTED = 2;\nvar DONE = 3;\n\nfunction resolvePromise(promise, cb) {\n var cancelPromise = promise[CANCEL];\n\n if (func(cancelPromise)) {\n cb.cancel = cancelPromise;\n }\n\n promise.then(cb, function (error) {\n cb(error, true);\n });\n}\n\nvar current = 0;\nvar nextSagaId = (function () {\n return ++current;\n});\n\nvar _effectRunnerMap;\n\nfunction getIteratorMetaInfo(iterator, fn) {\n if (iterator.isSagaIterator) {\n return {\n name: iterator.meta.name\n };\n }\n\n return getMetaInfo(fn);\n}\n\nfunction createTaskIterator(_ref) {\n var context = _ref.context,\n fn = _ref.fn,\n args = _ref.args;\n\n // catch synchronous failures; see #152 and #441\n try {\n var result = fn.apply(context, args); // i.e. a generator function returns an iterator\n\n if (iterator(result)) {\n return result;\n }\n\n var resolved = false;\n\n var next = function next(arg) {\n if (!resolved) {\n resolved = true; // Only promises returned from fork will be interpreted. See #1573\n\n return {\n value: result,\n done: !promise(result)\n };\n } else {\n return {\n value: arg,\n done: true\n };\n }\n };\n\n return makeIterator(next);\n } catch (err) {\n // do not bubble up synchronous failures for detached forks\n // instead create a failed task. See #152 and #441\n return makeIterator(function () {\n throw err;\n });\n }\n}\n\nfunction runPutEffect(env, _ref2, cb) {\n var channel = _ref2.channel,\n action = _ref2.action,\n resolve = _ref2.resolve;\n\n /**\n Schedule the put in case another saga is holding a lock.\n The put will be executed atomically. ie nested puts will execute after\n this put has terminated.\n **/\n asap(function () {\n var result;\n\n try {\n result = (channel ? channel.put : env.dispatch)(action);\n } catch (error) {\n cb(error, true);\n return;\n }\n\n if (resolve && promise(result)) {\n resolvePromise(result, cb);\n } else {\n cb(result);\n }\n }); // Put effects are non cancellables\n}\n\nfunction runTakeEffect(env, _ref3, cb) {\n var _ref3$channel = _ref3.channel,\n channel = _ref3$channel === void 0 ? env.channel : _ref3$channel,\n pattern = _ref3.pattern,\n maybe = _ref3.maybe;\n\n var takeCb = function takeCb(input) {\n if (input instanceof Error) {\n cb(input, true);\n return;\n }\n\n if (isEnd(input) && !maybe) {\n cb(TERMINATE);\n return;\n }\n\n cb(input);\n };\n\n try {\n channel.take(takeCb, notUndef(pattern) ? matcher(pattern) : null);\n } catch (err) {\n cb(err, true);\n return;\n }\n\n cb.cancel = takeCb.cancel;\n}\n\nfunction runCallEffect(env, _ref4, cb, _ref5) {\n var context = _ref4.context,\n fn = _ref4.fn,\n args = _ref4.args;\n var task = _ref5.task;\n\n // catch synchronous failures; see #152\n try {\n var result = fn.apply(context, args);\n\n if (promise(result)) {\n resolvePromise(result, cb);\n return;\n }\n\n if (iterator(result)) {\n // resolve iterator\n proc(env, result, task.context, current, getMetaInfo(fn),\n /* isRoot */\n false, cb);\n return;\n }\n\n cb(result);\n } catch (error) {\n cb(error, true);\n }\n}\n\nfunction runCPSEffect(env, _ref6, cb) {\n var context = _ref6.context,\n fn = _ref6.fn,\n args = _ref6.args;\n\n // CPS (ie node style functions) can define their own cancellation logic\n // by setting cancel field on the cb\n // catch synchronous failures; see #152\n try {\n var cpsCb = function cpsCb(err, res) {\n if (undef(err)) {\n cb(res);\n } else {\n cb(err, true);\n }\n };\n\n fn.apply(context, args.concat(cpsCb));\n\n if (cpsCb.cancel) {\n cb.cancel = cpsCb.cancel;\n }\n } catch (error) {\n cb(error, true);\n }\n}\n\nfunction runForkEffect(env, _ref7, cb, _ref8) {\n var context = _ref7.context,\n fn = _ref7.fn,\n args = _ref7.args,\n detached = _ref7.detached;\n var parent = _ref8.task;\n var taskIterator = createTaskIterator({\n context: context,\n fn: fn,\n args: args\n });\n var meta = getIteratorMetaInfo(taskIterator, fn);\n immediately(function () {\n var child = proc(env, taskIterator, parent.context, current, meta, detached, undefined);\n\n if (detached) {\n cb(child);\n } else {\n if (child.isRunning()) {\n parent.queue.addTask(child);\n cb(child);\n } else if (child.isAborted()) {\n parent.queue.abort(child.error());\n } else {\n cb(child);\n }\n }\n }); // Fork effects are non cancellables\n}\n\nfunction runJoinEffect(env, taskOrTasks, cb, _ref9) {\n var task = _ref9.task;\n\n var joinSingleTask = function joinSingleTask(taskToJoin, cb) {\n if (taskToJoin.isRunning()) {\n var joiner = {\n task: task,\n cb: cb\n };\n\n cb.cancel = function () {\n if (taskToJoin.isRunning()) remove(taskToJoin.joiners, joiner);\n };\n\n taskToJoin.joiners.push(joiner);\n } else {\n if (taskToJoin.isAborted()) {\n cb(taskToJoin.error(), true);\n } else {\n cb(taskToJoin.result());\n }\n }\n };\n\n if (array$1(taskOrTasks)) {\n if (taskOrTasks.length === 0) {\n cb([]);\n return;\n }\n\n var childCallbacks = createAllStyleChildCallbacks(taskOrTasks, cb);\n taskOrTasks.forEach(function (t, i) {\n joinSingleTask(t, childCallbacks[i]);\n });\n } else {\n joinSingleTask(taskOrTasks, cb);\n }\n}\n\nfunction cancelSingleTask(taskToCancel) {\n if (taskToCancel.isRunning()) {\n taskToCancel.cancel();\n }\n}\n\nfunction runCancelEffect(env, taskOrTasks, cb, _ref10) {\n var task = _ref10.task;\n\n if (taskOrTasks === SELF_CANCELLATION) {\n cancelSingleTask(task);\n } else if (array$1(taskOrTasks)) {\n taskOrTasks.forEach(cancelSingleTask);\n } else {\n cancelSingleTask(taskOrTasks);\n }\n\n cb(); // cancel effects are non cancellables\n}\n\nfunction runAllEffect(env, effects, cb, _ref11) {\n var digestEffect = _ref11.digestEffect;\n var effectId = current;\n var keys = Object.keys(effects);\n\n if (keys.length === 0) {\n cb(array$1(effects) ? [] : {});\n return;\n }\n\n var childCallbacks = createAllStyleChildCallbacks(effects, cb);\n keys.forEach(function (key) {\n digestEffect(effects[key], effectId, childCallbacks[key], key);\n });\n}\n\nfunction runRaceEffect(env, effects, cb, _ref12) {\n var digestEffect = _ref12.digestEffect;\n var effectId = current;\n var keys = Object.keys(effects);\n var response = array$1(effects) ? createEmptyArray(keys.length) : {};\n var childCbs = {};\n var completed = false;\n keys.forEach(function (key) {\n var chCbAtKey = function chCbAtKey(res, isErr) {\n if (completed) {\n return;\n }\n\n if (isErr || shouldComplete(res)) {\n // Race Auto cancellation\n cb.cancel();\n cb(res, isErr);\n } else {\n cb.cancel();\n completed = true;\n response[key] = res;\n cb(response);\n }\n };\n\n chCbAtKey.cancel = noop;\n childCbs[key] = chCbAtKey;\n });\n\n cb.cancel = function () {\n // prevents unnecessary cancellation\n if (!completed) {\n completed = true;\n keys.forEach(function (key) {\n return childCbs[key].cancel();\n });\n }\n };\n\n keys.forEach(function (key) {\n if (completed) {\n return;\n }\n\n digestEffect(effects[key], effectId, childCbs[key], key);\n });\n}\n\nfunction runSelectEffect(env, _ref13, cb) {\n var selector = _ref13.selector,\n args = _ref13.args;\n\n try {\n var state = selector.apply(void 0, [env.getState()].concat(args));\n cb(state);\n } catch (error) {\n cb(error, true);\n }\n}\n\nfunction runChannelEffect(env, _ref14, cb) {\n var pattern = _ref14.pattern,\n buffer = _ref14.buffer;\n var chan = channel(buffer);\n var match = matcher(pattern);\n\n var taker = function taker(action) {\n if (!isEnd(action)) {\n env.channel.take(taker, match);\n }\n\n chan.put(action);\n };\n\n var close = chan.close;\n\n chan.close = function () {\n taker.cancel();\n close();\n };\n\n env.channel.take(taker, match);\n cb(chan);\n}\n\nfunction runCancelledEffect(env, data, cb, _ref15) {\n var task = _ref15.task;\n cb(task.isCancelled());\n}\n\nfunction runFlushEffect(env, channel, cb) {\n channel.flush(cb);\n}\n\nfunction runGetContextEffect(env, prop, cb, _ref16) {\n var task = _ref16.task;\n cb(task.context[prop]);\n}\n\nfunction runSetContextEffect(env, props, cb, _ref17) {\n var task = _ref17.task;\n assignWithSymbols(task.context, props);\n cb();\n}\n\nvar effectRunnerMap = (_effectRunnerMap = {}, _effectRunnerMap[TAKE] = runTakeEffect, _effectRunnerMap[PUT] = runPutEffect, _effectRunnerMap[ALL] = runAllEffect, _effectRunnerMap[RACE] = runRaceEffect, _effectRunnerMap[CALL] = runCallEffect, _effectRunnerMap[CPS] = runCPSEffect, _effectRunnerMap[FORK] = runForkEffect, _effectRunnerMap[JOIN] = runJoinEffect, _effectRunnerMap[CANCEL$1] = runCancelEffect, _effectRunnerMap[SELECT] = runSelectEffect, _effectRunnerMap[ACTION_CHANNEL] = runChannelEffect, _effectRunnerMap[CANCELLED$1] = runCancelledEffect, _effectRunnerMap[FLUSH] = runFlushEffect, _effectRunnerMap[GET_CONTEXT] = runGetContextEffect, _effectRunnerMap[SET_CONTEXT] = runSetContextEffect, _effectRunnerMap);\n\n/**\n Used to track a parent task and its forks\n In the fork model, forked tasks are attached by default to their parent\n We model this using the concept of Parent task && main Task\n main task is the main flow of the current Generator, the parent tasks is the\n aggregation of the main tasks + all its forked tasks.\n Thus the whole model represents an execution tree with multiple branches (vs the\n linear execution tree in sequential (non parallel) programming)\n\n A parent tasks has the following semantics\n - It completes if all its forks either complete or all cancelled\n - If it's cancelled, all forks are cancelled as well\n - It aborts if any uncaught error bubbles up from forks\n - If it completes, the return value is the one returned by the main task\n **/\n\nfunction forkQueue(mainTask, onAbort, cont) {\n var tasks = [];\n var result;\n var completed = false;\n addTask(mainTask);\n\n var getTasks = function getTasks() {\n return tasks;\n };\n\n function abort(err) {\n onAbort();\n cancelAll();\n cont(err, true);\n }\n\n function addTask(task) {\n tasks.push(task);\n\n task.cont = function (res, isErr) {\n if (completed) {\n return;\n }\n\n remove(tasks, task);\n task.cont = noop;\n\n if (isErr) {\n abort(res);\n } else {\n if (task === mainTask) {\n result = res;\n }\n\n if (!tasks.length) {\n completed = true;\n cont(result);\n }\n }\n };\n }\n\n function cancelAll() {\n if (completed) {\n return;\n }\n\n completed = true;\n tasks.forEach(function (t) {\n t.cont = noop;\n t.cancel();\n });\n tasks = [];\n }\n\n return {\n addTask: addTask,\n cancelAll: cancelAll,\n abort: abort,\n getTasks: getTasks\n };\n}\n\n// there can be only a single saga error created at any given moment\n\nfunction formatLocation(fileName, lineNumber) {\n return fileName + \"?\" + lineNumber;\n}\n\nfunction effectLocationAsString(effect) {\n var location = getLocation(effect);\n\n if (location) {\n var code = location.code,\n fileName = location.fileName,\n lineNumber = location.lineNumber;\n var source = code + \" \" + formatLocation(fileName, lineNumber);\n return source;\n }\n\n return '';\n}\n\nfunction sagaLocationAsString(sagaMeta) {\n var name = sagaMeta.name,\n location = sagaMeta.location;\n\n if (location) {\n return name + \" \" + formatLocation(location.fileName, location.lineNumber);\n }\n\n return name;\n}\n\nfunction cancelledTasksAsString(sagaStack) {\n var cancelledTasks = flatMap(function (i) {\n return i.cancelledTasks;\n }, sagaStack);\n\n if (!cancelledTasks.length) {\n return '';\n }\n\n return ['Tasks cancelled due to error:'].concat(cancelledTasks).join('\\n');\n}\n\nvar crashedEffect = null;\nvar sagaStack = [];\nvar addSagaFrame = function addSagaFrame(frame) {\n frame.crashedEffect = crashedEffect;\n sagaStack.push(frame);\n};\nvar clear = function clear() {\n crashedEffect = null;\n sagaStack.length = 0;\n}; // this sets crashed effect for the soon-to-be-reported saga frame\n// this slightly streatches the singleton nature of this module into wrong direction\n// as it's even less obvious what's the data flow here, but it is what it is for now\n\nvar setCrashedEffect = function setCrashedEffect(effect) {\n crashedEffect = effect;\n};\n/**\n @returns {string}\n\n @example\n The above error occurred in task errorInPutSaga {pathToFile}\n when executing effect put({type: 'REDUCER_ACTION_ERROR_IN_PUT'}) {pathToFile}\n created by fetchSaga {pathToFile}\n created by rootSaga {pathToFile}\n*/\n\nvar toString = function toString() {\n var firstSaga = sagaStack[0],\n otherSagas = sagaStack.slice(1);\n var crashedEffectLocation = firstSaga.crashedEffect ? effectLocationAsString(firstSaga.crashedEffect) : null;\n var errorMessage = \"The above error occurred in task \" + sagaLocationAsString(firstSaga.meta) + (crashedEffectLocation ? \" \\n when executing effect \" + crashedEffectLocation : '');\n return [errorMessage].concat(otherSagas.map(function (s) {\n return \" created by \" + sagaLocationAsString(s.meta);\n }), [cancelledTasksAsString(sagaStack)]).join('\\n');\n};\n\nfunction newTask(env, mainTask, parentContext, parentEffectId, meta, isRoot, cont) {\n var _task;\n\n if (cont === void 0) {\n cont = noop;\n }\n\n var status = RUNNING;\n var taskResult;\n var taskError;\n var deferredEnd = null;\n var cancelledDueToErrorTasks = [];\n var context = Object.create(parentContext);\n var queue = forkQueue(mainTask, function onAbort() {\n cancelledDueToErrorTasks.push.apply(cancelledDueToErrorTasks, queue.getTasks().map(function (t) {\n return t.meta.name;\n }));\n }, end);\n /**\n This may be called by a parent generator to trigger/propagate cancellation\n cancel all pending tasks (including the main task), then end the current task.\n Cancellation propagates down to the whole execution tree held by this Parent task\n It's also propagated to all joiners of this task and their execution tree/joiners\n Cancellation is noop for terminated/Cancelled tasks tasks\n **/\n\n function cancel() {\n if (status === RUNNING) {\n // Setting status to CANCELLED does not necessarily mean that the task/iterators are stopped\n // effects in the iterator's finally block will still be executed\n status = CANCELLED;\n queue.cancelAll(); // Ending with a TASK_CANCEL will propagate the Cancellation to all joiners\n\n end(TASK_CANCEL, false);\n }\n }\n\n function end(result, isErr) {\n if (!isErr) {\n // The status here may be RUNNING or CANCELLED\n // If the status is CANCELLED, then we do not need to change it here\n if (result === TASK_CANCEL) {\n status = CANCELLED;\n } else if (status !== CANCELLED) {\n status = DONE;\n }\n\n taskResult = result;\n deferredEnd && deferredEnd.resolve(result);\n } else {\n status = ABORTED;\n addSagaFrame({\n meta: meta,\n cancelledTasks: cancelledDueToErrorTasks\n });\n\n if (task.isRoot) {\n var sagaStack = toString(); // we've dumped the saga stack to string and are passing it to user's code\n // we know that it won't be needed anymore and we need to clear it\n\n clear();\n env.onError(result, {\n sagaStack: sagaStack\n });\n }\n\n taskError = result;\n deferredEnd && deferredEnd.reject(result);\n }\n\n task.cont(result, isErr);\n task.joiners.forEach(function (joiner) {\n joiner.cb(result, isErr);\n });\n task.joiners = null;\n }\n\n function setContext(props) {\n if (process.env.NODE_ENV !== 'production') {\n check(props, object, createSetContextWarning('task', props));\n }\n\n assignWithSymbols(context, props);\n }\n\n function toPromise() {\n if (deferredEnd) {\n return deferredEnd.promise;\n }\n\n deferredEnd = deferred();\n\n if (status === ABORTED) {\n deferredEnd.reject(taskError);\n } else if (status !== RUNNING) {\n deferredEnd.resolve(taskResult);\n }\n\n return deferredEnd.promise;\n }\n\n var task = (_task = {}, _task[TASK] = true, _task.id = parentEffectId, _task.meta = meta, _task.isRoot = isRoot, _task.context = context, _task.joiners = [], _task.queue = queue, _task.cancel = cancel, _task.cont = cont, _task.end = end, _task.setContext = setContext, _task.toPromise = toPromise, _task.isRunning = function isRunning() {\n return status === RUNNING;\n }, _task.isCancelled = function isCancelled() {\n return status === CANCELLED || status === RUNNING && mainTask.status === CANCELLED;\n }, _task.isAborted = function isAborted() {\n return status === ABORTED;\n }, _task.result = function result() {\n return taskResult;\n }, _task.error = function error() {\n return taskError;\n }, _task);\n return task;\n}\n\nfunction proc(env, iterator$1, parentContext, parentEffectId, meta, isRoot, cont) {\n if (process.env.NODE_ENV !== 'production' && iterator$1[asyncIteratorSymbol]) {\n throw new Error(\"redux-saga doesn't support async generators, please use only regular ones\");\n }\n\n var finalRunEffect = env.finalizeRunEffect(runEffect);\n /**\n Tracks the current effect cancellation\n Each time the generator progresses. calling runEffect will set a new value\n on it. It allows propagating cancellation to child effects\n **/\n\n next.cancel = noop;\n /** Creates a main task to track the main flow */\n\n var mainTask = {\n meta: meta,\n cancel: cancelMain,\n status: RUNNING\n };\n /**\n Creates a new task descriptor for this generator.\n A task is the aggregation of it's mainTask and all it's forked tasks.\n **/\n\n var task = newTask(env, mainTask, parentContext, parentEffectId, meta, isRoot, cont);\n var executingContext = {\n task: task,\n digestEffect: digestEffect\n };\n /**\n cancellation of the main task. We'll simply resume the Generator with a TASK_CANCEL\n **/\n\n function cancelMain() {\n if (mainTask.status === RUNNING) {\n mainTask.status = CANCELLED;\n next(TASK_CANCEL);\n }\n }\n /**\n attaches cancellation logic to this task's continuation\n this will permit cancellation to propagate down the call chain\n **/\n\n\n if (cont) {\n cont.cancel = task.cancel;\n } // kicks up the generator\n\n\n next(); // then return the task descriptor to the caller\n\n return task;\n /**\n * This is the generator driver\n * It's a recursive async/continuation function which calls itself\n * until the generator terminates or throws\n * @param {internal commands(TASK_CANCEL | TERMINATE) | any} arg - value, generator will be resumed with.\n * @param {boolean} isErr - the flag shows if effect finished with an error\n *\n * receives either (command | effect result, false) or (any thrown thing, true)\n */\n\n function next(arg, isErr) {\n try {\n var result;\n\n if (isErr) {\n result = iterator$1.throw(arg); // user handled the error, we can clear bookkept values\n\n clear();\n } else if (shouldCancel(arg)) {\n /**\n getting TASK_CANCEL automatically cancels the main task\n We can get this value here\n - By cancelling the parent task manually\n - By joining a Cancelled task\n **/\n mainTask.status = CANCELLED;\n /**\n Cancels the current effect; this will propagate the cancellation down to any called tasks\n **/\n\n next.cancel();\n /**\n If this Generator has a `return` method then invokes it\n This will jump to the finally block\n **/\n\n result = func(iterator$1.return) ? iterator$1.return(TASK_CANCEL) : {\n done: true,\n value: TASK_CANCEL\n };\n } else if (shouldTerminate(arg)) {\n // We get TERMINATE flag, i.e. by taking from a channel that ended using `take` (and not `takem` used to trap End of channels)\n result = func(iterator$1.return) ? iterator$1.return() : {\n done: true\n };\n } else {\n result = iterator$1.next(arg);\n }\n\n if (!result.done) {\n digestEffect(result.value, parentEffectId, next);\n } else {\n /**\n This Generator has ended, terminate the main task and notify the fork queue\n **/\n if (mainTask.status !== CANCELLED) {\n mainTask.status = DONE;\n }\n\n mainTask.cont(result.value);\n }\n } catch (error) {\n if (mainTask.status === CANCELLED) {\n throw error;\n }\n\n mainTask.status = ABORTED;\n mainTask.cont(error, true);\n }\n }\n\n function runEffect(effect, effectId, currCb) {\n /**\n each effect runner must attach its own logic of cancellation to the provided callback\n it allows this generator to propagate cancellation downward.\n ATTENTION! effect runners must setup the cancel logic by setting cb.cancel = [cancelMethod]\n And the setup must occur before calling the callback\n This is a sort of inversion of control: called async functions are responsible\n of completing the flow by calling the provided continuation; while caller functions\n are responsible for aborting the current flow by calling the attached cancel function\n Library users can attach their own cancellation logic to promises by defining a\n promise[CANCEL] method in their returned promises\n ATTENTION! calling cancel must have no effect on an already completed or cancelled effect\n **/\n if (promise(effect)) {\n resolvePromise(effect, currCb);\n } else if (iterator(effect)) {\n // resolve iterator\n proc(env, effect, task.context, effectId, meta,\n /* isRoot */\n false, currCb);\n } else if (effect && effect[IO]) {\n var effectRunner = effectRunnerMap[effect.type];\n effectRunner(env, effect.payload, currCb, executingContext);\n } else {\n // anything else returned as is\n currCb(effect);\n }\n }\n\n function digestEffect(effect, parentEffectId, cb, label) {\n if (label === void 0) {\n label = '';\n }\n\n var effectId = nextSagaId();\n env.sagaMonitor && env.sagaMonitor.effectTriggered({\n effectId: effectId,\n parentEffectId: parentEffectId,\n label: label,\n effect: effect\n });\n /**\n completion callback and cancel callback are mutually exclusive\n We can't cancel an already completed effect\n And We can't complete an already cancelled effectId\n **/\n\n var effectSettled; // Completion callback passed to the appropriate effect runner\n\n function currCb(res, isErr) {\n if (effectSettled) {\n return;\n }\n\n effectSettled = true;\n cb.cancel = noop; // defensive measure\n\n if (env.sagaMonitor) {\n if (isErr) {\n env.sagaMonitor.effectRejected(effectId, res);\n } else {\n env.sagaMonitor.effectResolved(effectId, res);\n }\n }\n\n if (isErr) {\n setCrashedEffect(effect);\n }\n\n cb(res, isErr);\n } // tracks down the current cancel\n\n\n currCb.cancel = noop; // setup cancellation logic on the parent cb\n\n cb.cancel = function () {\n // prevents cancelling an already completed effect\n if (effectSettled) {\n return;\n }\n\n effectSettled = true;\n currCb.cancel(); // propagates cancel downward\n\n currCb.cancel = noop; // defensive measure\n\n env.sagaMonitor && env.sagaMonitor.effectCancelled(effectId);\n };\n\n finalRunEffect(effect, effectId, currCb);\n }\n}\n\nvar RUN_SAGA_SIGNATURE = 'runSaga(options, saga, ...args)';\nvar NON_GENERATOR_ERR = RUN_SAGA_SIGNATURE + \": saga argument must be a Generator function!\";\nfunction runSaga(_ref, saga) {\n var _ref$channel = _ref.channel,\n channel = _ref$channel === void 0 ? stdChannel() : _ref$channel,\n dispatch = _ref.dispatch,\n getState = _ref.getState,\n _ref$context = _ref.context,\n context = _ref$context === void 0 ? {} : _ref$context,\n sagaMonitor = _ref.sagaMonitor,\n effectMiddlewares = _ref.effectMiddlewares,\n _ref$onError = _ref.onError,\n onError = _ref$onError === void 0 ? logError : _ref$onError;\n\n if (process.env.NODE_ENV !== 'production') {\n check(saga, func, NON_GENERATOR_ERR);\n }\n\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n\n var iterator$1 = saga.apply(void 0, args);\n\n if (process.env.NODE_ENV !== 'production') {\n check(iterator$1, iterator, NON_GENERATOR_ERR);\n }\n\n var effectId = nextSagaId();\n\n if (sagaMonitor) {\n // monitors are expected to have a certain interface, let's fill-in any missing ones\n sagaMonitor.rootSagaStarted = sagaMonitor.rootSagaStarted || noop;\n sagaMonitor.effectTriggered = sagaMonitor.effectTriggered || noop;\n sagaMonitor.effectResolved = sagaMonitor.effectResolved || noop;\n sagaMonitor.effectRejected = sagaMonitor.effectRejected || noop;\n sagaMonitor.effectCancelled = sagaMonitor.effectCancelled || noop;\n sagaMonitor.actionDispatched = sagaMonitor.actionDispatched || noop;\n sagaMonitor.rootSagaStarted({\n effectId: effectId,\n saga: saga,\n args: args\n });\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (notUndef(dispatch)) {\n check(dispatch, func, 'dispatch must be a function');\n }\n\n if (notUndef(getState)) {\n check(getState, func, 'getState must be a function');\n }\n\n if (notUndef(effectMiddlewares)) {\n var MIDDLEWARE_TYPE_ERROR = 'effectMiddlewares must be an array of functions';\n check(effectMiddlewares, array$1, MIDDLEWARE_TYPE_ERROR);\n effectMiddlewares.forEach(function (effectMiddleware) {\n return check(effectMiddleware, func, MIDDLEWARE_TYPE_ERROR);\n });\n }\n\n check(onError, func, 'onError passed to the redux-saga is not a function!');\n }\n\n var finalizeRunEffect;\n\n if (effectMiddlewares) {\n var middleware = compose.apply(void 0, effectMiddlewares);\n\n finalizeRunEffect = function finalizeRunEffect(runEffect) {\n return function (effect, effectId, currCb) {\n var plainRunEffect = function plainRunEffect(eff) {\n return runEffect(eff, effectId, currCb);\n };\n\n return middleware(plainRunEffect)(effect);\n };\n };\n } else {\n finalizeRunEffect = identity;\n }\n\n var env = {\n channel: channel,\n dispatch: wrapSagaDispatch(dispatch),\n getState: getState,\n sagaMonitor: sagaMonitor,\n onError: onError,\n finalizeRunEffect: finalizeRunEffect\n };\n return immediately(function () {\n var task = proc(env, iterator$1, context, effectId, getMetaInfo(saga),\n /* isRoot */\n true, undefined);\n\n if (sagaMonitor) {\n sagaMonitor.effectResolved(effectId, task);\n }\n\n return task;\n });\n}\n\nfunction sagaMiddlewareFactory(_temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n _ref$context = _ref.context,\n context = _ref$context === void 0 ? {} : _ref$context,\n _ref$channel = _ref.channel,\n channel = _ref$channel === void 0 ? stdChannel() : _ref$channel,\n sagaMonitor = _ref.sagaMonitor,\n options = _objectWithoutPropertiesLoose(_ref, [\"context\", \"channel\", \"sagaMonitor\"]);\n\n var boundRunSaga;\n\n if (process.env.NODE_ENV !== 'production') {\n check(channel, channel$1, 'options.channel passed to the Saga middleware is not a channel');\n }\n\n function sagaMiddleware(_ref2) {\n var getState = _ref2.getState,\n dispatch = _ref2.dispatch;\n boundRunSaga = runSaga.bind(null, _extends({}, options, {\n context: context,\n channel: channel,\n dispatch: dispatch,\n getState: getState,\n sagaMonitor: sagaMonitor\n }));\n return function (next) {\n return function (action) {\n if (sagaMonitor && sagaMonitor.actionDispatched) {\n sagaMonitor.actionDispatched(action);\n }\n\n var result = next(action); // hit reducers\n\n channel.put(action);\n return result;\n };\n };\n }\n\n sagaMiddleware.run = function () {\n if (process.env.NODE_ENV !== 'production' && !boundRunSaga) {\n throw new Error('Before running a Saga, you must mount the Saga middleware on the Store using applyMiddleware');\n }\n\n return boundRunSaga.apply(void 0, arguments);\n };\n\n sagaMiddleware.setContext = function (props) {\n if (process.env.NODE_ENV !== 'production') {\n check(props, object, createSetContextWarning('sagaMiddleware', props));\n }\n\n assignWithSymbols(context, props);\n };\n\n return sagaMiddleware;\n}\n\nexport default sagaMiddlewareFactory;\nexport { END, channel, eventChannel, isEnd, multicastChannel, runSaga, stdChannel };\n","import createSagaMiddleware__default from '@redux-saga/core';\nexport * from '@redux-saga/core';\n\n\n\nexport default createSagaMiddleware__default;\n","/**\n * Adapted from React: https://github.com/facebook/react/blob/master/packages/shared/formatProdErrorMessage.js\n *\n * Do not require this module directly! Use normal throw error calls. These messages will be replaced with error codes\n * during build.\n * @param {number} code\n */\nexport function formatProdErrorMessage(code: number) {\n return `Minified Redux error #${code}; visit https://redux.js.org/Errors?code=${code} for the full message or ` + 'use the non-minified dev environment for full errors. ';\n}","declare global {\n interface SymbolConstructor {\n readonly observable: symbol;\n }\n}\nconst $$observable = /* #__PURE__ */(() => typeof Symbol === 'function' && Symbol.observable || '@@observable')();\nexport default $$observable;","/**\n * These are private action types reserved by Redux.\n * For any unknown actions, you must return the current state.\n * If the current state is undefined, you must return the initial state.\n * Do not reference these action types directly in your code.\n */\n\nconst randomString = () => Math.random().toString(36).substring(7).split('').join('.');\nconst ActionTypes = {\n INIT: `@@redux/INIT${/* #__PURE__ */randomString()}`,\n REPLACE: `@@redux/REPLACE${/* #__PURE__ */randomString()}`,\n PROBE_UNKNOWN_ACTION: () => `@@redux/PROBE_UNKNOWN_ACTION${randomString()}`\n};\nexport default ActionTypes;","/**\n * @param obj The object to inspect.\n * @returns True if the argument appears to be a plain object.\n */\nexport default function isPlainObject(obj: any): obj is object {\n if (typeof obj !== 'object' || obj === null) return false;\n let proto = obj;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(obj) === proto || Object.getPrototypeOf(obj) === null;\n}","import { formatProdErrorMessage as _formatProdErrorMessage13 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage12 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage11 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage10 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage9 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage8 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage7 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage6 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage5 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage4 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage3 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage2 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage } from \"src/utils/formatProdErrorMessage\";\nimport $$observable from './utils/symbol-observable';\nimport { Store, StoreEnhancer, Dispatch, Observer, ListenerCallback, UnknownIfNonSpecific } from './types/store';\nimport { Action } from './types/actions';\nimport { Reducer } from './types/reducers';\nimport ActionTypes from './utils/actionTypes';\nimport isPlainObject from './utils/isPlainObject';\nimport { kindOf } from './utils/kindOf';\n\n/**\n * @deprecated\n *\n * **We recommend using the `configureStore` method\n * of the `@reduxjs/toolkit` package**, which replaces `createStore`.\n *\n * Redux Toolkit is our recommended approach for writing Redux logic today,\n * including store setup, reducers, data fetching, and more.\n *\n * **For more details, please read this Redux docs page:**\n * **https://redux.js.org/introduction/why-rtk-is-redux-today**\n *\n * `configureStore` from Redux Toolkit is an improved version of `createStore` that\n * simplifies setup and helps avoid common bugs.\n *\n * You should not be using the `redux` core package by itself today, except for learning purposes.\n * The `createStore` method from the core `redux` package will not be removed, but we encourage\n * all users to migrate to using Redux Toolkit for all Redux code.\n *\n * If you want to use `createStore` without this visual deprecation warning, use\n * the `legacy_createStore` import instead:\n *\n * `import { legacy_createStore as createStore} from 'redux'`\n *\n */\nexport function createStore(reducer: Reducer, enhancer?: StoreEnhancer): Store> & Ext;\n/**\n * @deprecated\n *\n * **We recommend using the `configureStore` method\n * of the `@reduxjs/toolkit` package**, which replaces `createStore`.\n *\n * Redux Toolkit is our recommended approach for writing Redux logic today,\n * including store setup, reducers, data fetching, and more.\n *\n * **For more details, please read this Redux docs page:**\n * **https://redux.js.org/introduction/why-rtk-is-redux-today**\n *\n * `configureStore` from Redux Toolkit is an improved version of `createStore` that\n * simplifies setup and helps avoid common bugs.\n *\n * You should not be using the `redux` core package by itself today, except for learning purposes.\n * The `createStore` method from the core `redux` package will not be removed, but we encourage\n * all users to migrate to using Redux Toolkit for all Redux code.\n *\n * If you want to use `createStore` without this visual deprecation warning, use\n * the `legacy_createStore` import instead:\n *\n * `import { legacy_createStore as createStore} from 'redux'`\n *\n */\nexport function createStore(reducer: Reducer, preloadedState?: PreloadedState | undefined, enhancer?: StoreEnhancer): Store> & Ext;\nexport function createStore(reducer: Reducer, preloadedState?: PreloadedState | StoreEnhancer | undefined, enhancer?: StoreEnhancer): Store> & Ext {\n if (typeof reducer !== 'function') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage(2) : `Expected the root reducer to be a function. Instead, received: '${kindOf(reducer)}'`);\n }\n if (typeof preloadedState === 'function' && typeof enhancer === 'function' || typeof enhancer === 'function' && typeof arguments[3] === 'function') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage2(0) : 'It looks like you are passing several store enhancers to ' + 'createStore(). This is not supported. Instead, compose them ' + 'together to a single function. See https://redux.js.org/tutorials/fundamentals/part-4-store#creating-a-store-with-enhancers for an example.');\n }\n if (typeof preloadedState === 'function' && typeof enhancer === 'undefined') {\n enhancer = (preloadedState as StoreEnhancer);\n preloadedState = undefined;\n }\n if (typeof enhancer !== 'undefined') {\n if (typeof enhancer !== 'function') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage3(1) : `Expected the enhancer to be a function. Instead, received: '${kindOf(enhancer)}'`);\n }\n return enhancer(createStore)(reducer, (preloadedState as PreloadedState | undefined));\n }\n let currentReducer = reducer;\n let currentState: S | PreloadedState | undefined = (preloadedState as PreloadedState | undefined);\n let currentListeners: Map | null = new Map();\n let nextListeners = currentListeners;\n let listenerIdCounter = 0;\n let isDispatching = false;\n\n /**\n * This makes a shallow copy of currentListeners so we can use\n * nextListeners as a temporary list while dispatching.\n *\n * This prevents any bugs around consumers calling\n * subscribe/unsubscribe in the middle of a dispatch.\n */\n function ensureCanMutateNextListeners() {\n if (nextListeners === currentListeners) {\n nextListeners = new Map();\n currentListeners.forEach((listener, key) => {\n nextListeners.set(key, listener);\n });\n }\n }\n\n /**\n * Reads the state tree managed by the store.\n *\n * @returns The current state tree of your application.\n */\n function getState(): S {\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage4(3) : 'You may not call store.getState() while the reducer is executing. ' + 'The reducer has already received the state as an argument. ' + 'Pass it down from the top reducer instead of reading it from the store.');\n }\n return (currentState as S);\n }\n\n /**\n * Adds a change listener. It will be called any time an action is dispatched,\n * and some part of the state tree may potentially have changed. You may then\n * call `getState()` to read the current state tree inside the callback.\n *\n * You may call `dispatch()` from a change listener, with the following\n * caveats:\n *\n * 1. The subscriptions are snapshotted just before every `dispatch()` call.\n * If you subscribe or unsubscribe while the listeners are being invoked, this\n * will not have any effect on the `dispatch()` that is currently in progress.\n * However, the next `dispatch()` call, whether nested or not, will use a more\n * recent snapshot of the subscription list.\n *\n * 2. The listener should not expect to see all state changes, as the state\n * might have been updated multiple times during a nested `dispatch()` before\n * the listener is called. It is, however, guaranteed that all subscribers\n * registered before the `dispatch()` started will be called with the latest\n * state by the time it exits.\n *\n * @param listener A callback to be invoked on every dispatch.\n * @returns A function to remove this change listener.\n */\n function subscribe(listener: () => void) {\n if (typeof listener !== 'function') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage5(4) : `Expected the listener to be a function. Instead, received: '${kindOf(listener)}'`);\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage6(5) : 'You may not call store.subscribe() while the reducer is executing. ' + 'If you would like to be notified after the store has been updated, subscribe from a ' + 'component and invoke store.getState() in the callback to access the latest state. ' + 'See https://redux.js.org/api/store#subscribelistener for more details.');\n }\n let isSubscribed = true;\n ensureCanMutateNextListeners();\n const listenerId = listenerIdCounter++;\n nextListeners.set(listenerId, listener);\n return function unsubscribe() {\n if (!isSubscribed) {\n return;\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage7(6) : 'You may not unsubscribe from a store listener while the reducer is executing. ' + 'See https://redux.js.org/api/store#subscribelistener for more details.');\n }\n isSubscribed = false;\n ensureCanMutateNextListeners();\n nextListeners.delete(listenerId);\n currentListeners = null;\n };\n }\n\n /**\n * Dispatches an action. It is the only way to trigger a state change.\n *\n * The `reducer` function, used to create the store, will be called with the\n * current state tree and the given `action`. Its return value will\n * be considered the **next** state of the tree, and the change listeners\n * will be notified.\n *\n * The base implementation only supports plain object actions. If you want to\n * dispatch a Promise, an Observable, a thunk, or something else, you need to\n * wrap your store creating function into the corresponding middleware. For\n * example, see the documentation for the `redux-thunk` package. Even the\n * middleware will eventually dispatch plain object actions using this method.\n *\n * @param action A plain object representing “what changed”. It is\n * a good idea to keep actions serializable so you can record and replay user\n * sessions, or use the time travelling `redux-devtools`. An action must have\n * a `type` property which may not be `undefined`. It is a good idea to use\n * string constants for action types.\n *\n * @returns For convenience, the same action object you dispatched.\n *\n * Note that, if you use a custom middleware, it may wrap `dispatch()` to\n * return something else (for example, a Promise you can await).\n */\n function dispatch(action: A) {\n if (!isPlainObject(action)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage8(7) : `Actions must be plain objects. Instead, the actual type was: '${kindOf(action)}'. You may need to add middleware to your store setup to handle dispatching other values, such as 'redux-thunk' to handle dispatching functions. See https://redux.js.org/tutorials/fundamentals/part-4-store#middleware and https://redux.js.org/tutorials/fundamentals/part-6-async-logic#using-the-redux-thunk-middleware for examples.`);\n }\n if (typeof action.type === 'undefined') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage9(8) : 'Actions may not have an undefined \"type\" property. You may have misspelled an action type string constant.');\n }\n if (typeof action.type !== 'string') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage10(17) : `Action \"type\" property must be a string. Instead, the actual type was: '${kindOf(action.type)}'. Value was: '${action.type}' (stringified)`);\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage11(9) : 'Reducers may not dispatch actions.');\n }\n try {\n isDispatching = true;\n currentState = currentReducer(currentState, action);\n } finally {\n isDispatching = false;\n }\n const listeners = currentListeners = nextListeners;\n listeners.forEach(listener => {\n listener();\n });\n return action;\n }\n\n /**\n * Replaces the reducer currently used by the store to calculate the state.\n *\n * You might need this if your app implements code splitting and you want to\n * load some of the reducers dynamically. You might also need this if you\n * implement a hot reloading mechanism for Redux.\n *\n * @param nextReducer The reducer for the store to use instead.\n */\n function replaceReducer(nextReducer: Reducer): void {\n if (typeof nextReducer !== 'function') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage12(10) : `Expected the nextReducer to be a function. Instead, received: '${kindOf(nextReducer)}`);\n }\n currentReducer = ((nextReducer as unknown) as Reducer);\n\n // This action has a similar effect to ActionTypes.INIT.\n // Any reducers that existed in both the new and old rootReducer\n // will receive the previous state. This effectively populates\n // the new state tree with any relevant data from the old one.\n dispatch(({\n type: ActionTypes.REPLACE\n } as A));\n }\n\n /**\n * Interoperability point for observable/reactive libraries.\n * @returns A minimal observable of state changes.\n * For more information, see the observable proposal:\n * https://github.com/tc39/proposal-observable\n */\n function observable() {\n const outerSubscribe = subscribe;\n return {\n /**\n * The minimal observable subscription method.\n * @param observer Any object that can be used as an observer.\n * The observer object should have a `next` method.\n * @returns An object with an `unsubscribe` method that can\n * be used to unsubscribe the observable from the store, and prevent further\n * emission of values from the observable.\n */\n subscribe(observer: unknown) {\n if (typeof observer !== 'object' || observer === null) {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage13(11) : `Expected the observer to be an object. Instead, received: '${kindOf(observer)}'`);\n }\n function observeState() {\n const observerAsObserver = (observer as Observer);\n if (observerAsObserver.next) {\n observerAsObserver.next(getState());\n }\n }\n observeState();\n const unsubscribe = outerSubscribe(observeState);\n return {\n unsubscribe\n };\n },\n [$$observable]() {\n return this;\n }\n };\n }\n\n // When a store is created, an \"INIT\" action is dispatched so that every\n // reducer returns their initial state. This effectively populates\n // the initial state tree.\n dispatch(({\n type: ActionTypes.INIT\n } as A));\n const store = (({\n dispatch: (dispatch as Dispatch),\n subscribe,\n getState,\n replaceReducer,\n [$$observable]: observable\n } as unknown) as Store & Ext);\n return store;\n}\n\n/**\n * Creates a Redux store that holds the state tree.\n *\n * **We recommend using `configureStore` from the\n * `@reduxjs/toolkit` package**, which replaces `createStore`:\n * **https://redux.js.org/introduction/why-rtk-is-redux-today**\n *\n * The only way to change the data in the store is to call `dispatch()` on it.\n *\n * There should only be a single store in your app. To specify how different\n * parts of the state tree respond to actions, you may combine several reducers\n * into a single reducer function by using `combineReducers`.\n *\n * @param {Function} reducer A function that returns the next state tree, given\n * the current state tree and the action to handle.\n *\n * @param {any} [preloadedState] The initial state. You may optionally specify it\n * to hydrate the state from the server in universal apps, or to restore a\n * previously serialized user session.\n * If you use `combineReducers` to produce the root reducer function, this must be\n * an object with the same shape as `combineReducers` keys.\n *\n * @param {Function} [enhancer] The store enhancer. You may optionally specify it\n * to enhance the store with third-party capabilities such as middleware,\n * time travel, persistence, etc. The only store enhancer that ships with Redux\n * is `applyMiddleware()`.\n *\n * @returns {Store} A Redux store that lets you read the state, dispatch actions\n * and subscribe to changes.\n */\nexport function legacy_createStore(reducer: Reducer, enhancer?: StoreEnhancer): Store> & Ext;\n/**\n * Creates a Redux store that holds the state tree.\n *\n * **We recommend using `configureStore` from the\n * `@reduxjs/toolkit` package**, which replaces `createStore`:\n * **https://redux.js.org/introduction/why-rtk-is-redux-today**\n *\n * The only way to change the data in the store is to call `dispatch()` on it.\n *\n * There should only be a single store in your app. To specify how different\n * parts of the state tree respond to actions, you may combine several reducers\n * into a single reducer function by using `combineReducers`.\n *\n * @param {Function} reducer A function that returns the next state tree, given\n * the current state tree and the action to handle.\n *\n * @param {any} [preloadedState] The initial state. You may optionally specify it\n * to hydrate the state from the server in universal apps, or to restore a\n * previously serialized user session.\n * If you use `combineReducers` to produce the root reducer function, this must be\n * an object with the same shape as `combineReducers` keys.\n *\n * @param {Function} [enhancer] The store enhancer. You may optionally specify it\n * to enhance the store with third-party capabilities such as middleware,\n * time travel, persistence, etc. The only store enhancer that ships with Redux\n * is `applyMiddleware()`.\n *\n * @returns {Store} A Redux store that lets you read the state, dispatch actions\n * and subscribe to changes.\n */\nexport function legacy_createStore(reducer: Reducer, preloadedState?: PreloadedState | undefined, enhancer?: StoreEnhancer): Store> & Ext;\nexport function legacy_createStore(reducer: Reducer, preloadedState?: PreloadedState | StoreEnhancer | undefined, enhancer?: StoreEnhancer): Store> & Ext {\n return createStore(reducer, (preloadedState as any), enhancer);\n}","import { formatProdErrorMessage as _formatProdErrorMessage3 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage2 } from \"src/utils/formatProdErrorMessage\";\nimport { formatProdErrorMessage as _formatProdErrorMessage } from \"src/utils/formatProdErrorMessage\";\nimport { Action } from './types/actions';\nimport { ActionFromReducersMapObject, PreloadedStateShapeFromReducersMapObject, Reducer, StateFromReducersMapObject } from './types/reducers';\nimport ActionTypes from './utils/actionTypes';\nimport isPlainObject from './utils/isPlainObject';\nimport warning from './utils/warning';\nimport { kindOf } from './utils/kindOf';\nfunction getUnexpectedStateShapeWarningMessage(inputState: object, reducers: {\n [key: string]: Reducer;\n}, action: Action, unexpectedKeyCache: {\n [key: string]: true;\n}) {\n const reducerKeys = Object.keys(reducers);\n const argumentName = action && action.type === ActionTypes.INIT ? 'preloadedState argument passed to createStore' : 'previous state received by the reducer';\n if (reducerKeys.length === 0) {\n return 'Store does not have a valid reducer. Make sure the argument passed ' + 'to combineReducers is an object whose values are reducers.';\n }\n if (!isPlainObject(inputState)) {\n return `The ${argumentName} has unexpected type of \"${kindOf(inputState)}\". Expected argument to be an object with the following ` + `keys: \"${reducerKeys.join('\", \"')}\"`;\n }\n const unexpectedKeys = Object.keys(inputState).filter(key => !reducers.hasOwnProperty(key) && !unexpectedKeyCache[key]);\n unexpectedKeys.forEach(key => {\n unexpectedKeyCache[key] = true;\n });\n if (action && action.type === ActionTypes.REPLACE) return;\n if (unexpectedKeys.length > 0) {\n return `Unexpected ${unexpectedKeys.length > 1 ? 'keys' : 'key'} ` + `\"${unexpectedKeys.join('\", \"')}\" found in ${argumentName}. ` + `Expected to find one of the known reducer keys instead: ` + `\"${reducerKeys.join('\", \"')}\". Unexpected keys will be ignored.`;\n }\n}\nfunction assertReducerShape(reducers: {\n [key: string]: Reducer;\n}) {\n Object.keys(reducers).forEach(key => {\n const reducer = reducers[key];\n const initialState = reducer(undefined, {\n type: ActionTypes.INIT\n });\n if (typeof initialState === 'undefined') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage(12) : `The slice reducer for key \"${key}\" returned undefined during initialization. ` + `If the state passed to the reducer is undefined, you must ` + `explicitly return the initial state. The initial state may ` + `not be undefined. If you don't want to set a value for this reducer, ` + `you can use null instead of undefined.`);\n }\n if (typeof reducer(undefined, {\n type: ActionTypes.PROBE_UNKNOWN_ACTION()\n }) === 'undefined') {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage2(13) : `The slice reducer for key \"${key}\" returned undefined when probed with a random type. ` + `Don't try to handle '${ActionTypes.INIT}' or other actions in \"redux/*\" ` + `namespace. They are considered private. Instead, you must return the ` + `current state for any unknown actions, unless it is undefined, ` + `in which case you must return the initial state, regardless of the ` + `action type. The initial state may not be undefined, but can be null.`);\n }\n });\n}\n\n/**\n * Turns an object whose values are different reducer functions, into a single\n * reducer function. It will call every child reducer, and gather their results\n * into a single state object, whose keys correspond to the keys of the passed\n * reducer functions.\n *\n * @template S Combined state object type.\n *\n * @param reducers An object whose values correspond to different reducer\n * functions that need to be combined into one. One handy way to obtain it\n * is to use `import * as reducers` syntax. The reducers may never\n * return undefined for any action. Instead, they should return their\n * initial state if the state passed to them was undefined, and the current\n * state for any unrecognized action.\n *\n * @returns A reducer function that invokes every reducer inside the passed\n * object, and builds a state object with the same shape.\n */\nexport default function combineReducers(reducers: M): M[keyof M] extends Reducer | undefined ? Reducer, ActionFromReducersMapObject, Partial>> : never;\nexport default function combineReducers(reducers: {\n [key: string]: Reducer;\n}) {\n const reducerKeys = Object.keys(reducers);\n const finalReducers: {\n [key: string]: Reducer;\n } = {};\n for (let i = 0; i < reducerKeys.length; i++) {\n const key = reducerKeys[i];\n if (process.env.NODE_ENV !== 'production') {\n if (typeof reducers[key] === 'undefined') {\n warning(`No reducer provided for key \"${key}\"`);\n }\n }\n if (typeof reducers[key] === 'function') {\n finalReducers[key] = reducers[key];\n }\n }\n const finalReducerKeys = Object.keys(finalReducers);\n\n // This is used to make sure we don't warn about the same\n // keys multiple times.\n let unexpectedKeyCache: {\n [key: string]: true;\n };\n if (process.env.NODE_ENV !== 'production') {\n unexpectedKeyCache = {};\n }\n let shapeAssertionError: unknown;\n try {\n assertReducerShape(finalReducers);\n } catch (e) {\n shapeAssertionError = e;\n }\n return function combination(state: StateFromReducersMapObject = {}, action: Action) {\n if (shapeAssertionError) {\n throw shapeAssertionError;\n }\n if (process.env.NODE_ENV !== 'production') {\n const warningMessage = getUnexpectedStateShapeWarningMessage(state, finalReducers, action, unexpectedKeyCache);\n if (warningMessage) {\n warning(warningMessage);\n }\n }\n let hasChanged = false;\n const nextState: StateFromReducersMapObject = {};\n for (let i = 0; i < finalReducerKeys.length; i++) {\n const key = finalReducerKeys[i];\n const reducer = finalReducers[key];\n const previousStateForKey = state[key];\n const nextStateForKey = reducer(previousStateForKey, action);\n if (typeof nextStateForKey === 'undefined') {\n const actionType = action && action.type;\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage3(14) : `When called with an action of type ${actionType ? `\"${String(actionType)}\"` : '(unknown type)'}, the slice reducer for key \"${key}\" returned undefined. ` + `To ignore an action, you must explicitly return the previous state. ` + `If you want this reducer to hold no value, you can return null instead of undefined.`);\n }\n nextState[key] = nextStateForKey;\n hasChanged = hasChanged || nextStateForKey !== previousStateForKey;\n }\n hasChanged = hasChanged || finalReducerKeys.length !== Object.keys(state).length;\n return hasChanged ? nextState : state;\n };\n}","type Func = (...a: T) => R;\n\n/**\n * Composes single-argument functions from right to left. The rightmost\n * function can take multiple arguments as it provides the signature for the\n * resulting composite function.\n *\n * @param funcs The functions to compose.\n * @returns A function obtained by composing the argument functions from right\n * to left. For example, `compose(f, g, h)` is identical to doing\n * `(...args) => f(g(h(...args)))`.\n */\nexport default function compose(): (a: R) => R;\nexport default function compose(f: F): F;\n\n/* two functions */\nexport default function compose(f1: (a: A) => R, f2: Func): Func;\n\n/* three functions */\nexport default function compose(f1: (b: B) => R, f2: (a: A) => B, f3: Func): Func;\n\n/* four functions */\nexport default function compose(f1: (c: C) => R, f2: (b: B) => C, f3: (a: A) => B, f4: Func): Func;\n\n/* rest */\nexport default function compose(f1: (a: any) => R, ...funcs: Function[]): (...args: any[]) => R;\nexport default function compose(...funcs: Function[]): (...args: any[]) => R;\nexport default function compose(...funcs: Function[]) {\n if (funcs.length === 0) {\n // infer the argument type so it is usable in inference down the line\n return (arg: T) => arg;\n }\n if (funcs.length === 1) {\n return funcs[0];\n }\n return funcs.reduce((a, b) => (...args: any) => a(b(...args)));\n}","import { formatProdErrorMessage as _formatProdErrorMessage } from \"src/utils/formatProdErrorMessage\";\nimport compose from './compose';\nimport { Middleware, MiddlewareAPI } from './types/middleware';\nimport { StoreEnhancer, Dispatch } from './types/store';\n\n/**\n * Creates a store enhancer that applies middleware to the dispatch method\n * of the Redux store. This is handy for a variety of tasks, such as expressing\n * asynchronous actions in a concise manner, or logging every action payload.\n *\n * See `redux-thunk` package as an example of the Redux middleware.\n *\n * Because middleware is potentially asynchronous, this should be the first\n * store enhancer in the composition chain.\n *\n * Note that each middleware will be given the `dispatch` and `getState` functions\n * as named arguments.\n *\n * @param middlewares The middleware chain to be applied.\n * @returns A store enhancer applying the middleware.\n *\n * @template Ext Dispatch signature added by a middleware.\n * @template S The type of the state supported by a middleware.\n */\nexport default function applyMiddleware(): StoreEnhancer;\nexport default function applyMiddleware(middleware1: Middleware): StoreEnhancer<{\n dispatch: Ext1;\n}>;\nexport default function applyMiddleware(middleware1: Middleware, middleware2: Middleware): StoreEnhancer<{\n dispatch: Ext1 & Ext2;\n}>;\nexport default function applyMiddleware(middleware1: Middleware, middleware2: Middleware, middleware3: Middleware): StoreEnhancer<{\n dispatch: Ext1 & Ext2 & Ext3;\n}>;\nexport default function applyMiddleware(middleware1: Middleware, middleware2: Middleware, middleware3: Middleware, middleware4: Middleware): StoreEnhancer<{\n dispatch: Ext1 & Ext2 & Ext3 & Ext4;\n}>;\nexport default function applyMiddleware(middleware1: Middleware, middleware2: Middleware, middleware3: Middleware, middleware4: Middleware, middleware5: Middleware): StoreEnhancer<{\n dispatch: Ext1 & Ext2 & Ext3 & Ext4 & Ext5;\n}>;\nexport default function applyMiddleware(...middlewares: Middleware[]): StoreEnhancer<{\n dispatch: Ext;\n}>;\nexport default function applyMiddleware(...middlewares: Middleware[]): StoreEnhancer {\n return createStore => (reducer, preloadedState) => {\n const store = createStore(reducer, preloadedState);\n let dispatch: Dispatch = () => {\n throw new Error(process.env.NODE_ENV === \"production\" ? _formatProdErrorMessage(15) : 'Dispatching while constructing your middleware is not allowed. ' + 'Other middleware would not be applied to this dispatch.');\n };\n const middlewareAPI: MiddlewareAPI = {\n getState: store.getState,\n dispatch: (action, ...args) => dispatch(action, ...args)\n };\n const chain = middlewares.map(middleware => middleware(middlewareAPI));\n dispatch = compose(...chain)(store.dispatch);\n return {\n ...store,\n dispatch\n };\n };\n}","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.min.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\n","// src/index.ts\nfunction createThunkMiddleware(extraArgument) {\n const middleware = ({ dispatch, getState }) => (next) => (action) => {\n if (typeof action === \"function\") {\n return action(dispatch, getState, extraArgument);\n }\n return next(action);\n };\n return middleware;\n}\nvar thunk = createThunkMiddleware();\nvar withExtraArgument = createThunkMiddleware;\nexport {\n thunk,\n withExtraArgument\n};\n","import { TASK, SAGA_ACTION, MULTICAST, IO } from '@redux-saga/symbols';\n\nvar undef = function undef(v) {\n return v === null || v === undefined;\n};\nvar notUndef = function notUndef(v) {\n return v !== null && v !== undefined;\n};\nvar func = function func(f) {\n return typeof f === 'function';\n};\nvar number = function number(n) {\n return typeof n === 'number';\n};\nvar string = function string(s) {\n return typeof s === 'string';\n};\nvar array = Array.isArray;\nvar object = function object(obj) {\n return obj && !array(obj) && typeof obj === 'object';\n};\nvar promise = function promise(p) {\n return p && func(p.then);\n};\nvar iterator = function iterator(it) {\n return it && func(it.next) && func(it.throw);\n};\nvar iterable = function iterable(it) {\n return it && func(Symbol) ? func(it[Symbol.iterator]) : array(it);\n};\nvar task = function task(t) {\n return t && t[TASK];\n};\nvar sagaAction = function sagaAction(a) {\n return Boolean(a && a[SAGA_ACTION]);\n};\nvar observable = function observable(ob) {\n return ob && func(ob.subscribe);\n};\nvar buffer = function buffer(buf) {\n return buf && func(buf.isEmpty) && func(buf.take) && func(buf.put);\n};\nvar pattern = function pattern(pat) {\n return pat && (string(pat) || symbol(pat) || func(pat) || array(pat) && pat.every(pattern));\n};\nvar channel = function channel(ch) {\n return ch && func(ch.take) && func(ch.close);\n};\nvar stringableFunc = function stringableFunc(f) {\n return func(f) && f.hasOwnProperty('toString');\n};\nvar symbol = function symbol(sym) {\n return Boolean(sym) && typeof Symbol === 'function' && sym.constructor === Symbol && sym !== Symbol.prototype;\n};\nvar multicast = function multicast(ch) {\n return channel(ch) && ch[MULTICAST];\n};\nvar effect = function effect(eff) {\n return eff && eff[IO];\n};\n\nexport { array, buffer, channel, effect, func, iterable, iterator, multicast, notUndef, number, object, observable, pattern, promise, sagaAction, string, stringableFunc, symbol, task, undef };\n","import { CANCEL } from '@redux-saga/symbols';\n\nvar MAX_SIGNED_INT = 2147483647;\nfunction delayP(ms, val) {\n if (val === void 0) {\n val = true;\n }\n\n // https://developer.mozilla.org/en-US/docs/Web/API/setTimeout#maximum_delay_value\n if (process.env.NODE_ENV !== 'production' && ms > MAX_SIGNED_INT) {\n throw new Error('delay only supports a maximum value of ' + MAX_SIGNED_INT + 'ms');\n }\n\n var timeoutId;\n var promise = new Promise(function (resolve) {\n timeoutId = setTimeout(resolve, Math.min(MAX_SIGNED_INT, ms), val);\n });\n\n promise[CANCEL] = function () {\n clearTimeout(timeoutId);\n };\n\n return promise;\n}\n\nexport default delayP;\n","import { TASK_CANCEL, TERMINATE, SAGA_LOCATION, SAGA_ACTION, IO, SELF_CANCELLATION } from '@redux-saga/symbols';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport { array, notUndef, pattern, multicast, channel, undef, effect, task, func, buffer, string, object } from '@redux-saga/is';\nimport delayP from '@redux-saga/delay-p';\n\nvar konst = function konst(v) {\n return function () {\n return v;\n };\n};\nvar kTrue =\n/*#__PURE__*/\nkonst(true);\n\nvar noop = function noop() {};\n\nif (process.env.NODE_ENV !== 'production' && typeof Proxy !== 'undefined') {\n noop =\n /*#__PURE__*/\n new Proxy(noop, {\n set: function set() {\n throw internalErr('There was an attempt to assign a property to internal `noop` function.');\n }\n });\n}\nvar identity = function identity(v) {\n return v;\n};\nvar hasSymbol = typeof Symbol === 'function';\nvar asyncIteratorSymbol = hasSymbol && Symbol.asyncIterator ? Symbol.asyncIterator : '@@asyncIterator';\nfunction check(value, predicate, error) {\n if (!predicate(value)) {\n throw new Error(error);\n }\n}\nvar assignWithSymbols = function assignWithSymbols(target, source) {\n _extends(target, source);\n\n if (Object.getOwnPropertySymbols) {\n Object.getOwnPropertySymbols(source).forEach(function (s) {\n target[s] = source[s];\n });\n }\n};\nvar flatMap = function flatMap(mapper, arr) {\n var _ref;\n\n return (_ref = []).concat.apply(_ref, arr.map(mapper));\n};\nfunction remove(array, item) {\n var index = array.indexOf(item);\n\n if (index >= 0) {\n array.splice(index, 1);\n }\n}\nfunction once(fn) {\n var called = false;\n return function () {\n if (called) {\n return;\n }\n\n called = true;\n fn();\n };\n}\n\nvar kThrow = function kThrow(err) {\n throw err;\n};\n\nvar kReturn = function kReturn(value) {\n return {\n value: value,\n done: true\n };\n};\n\nfunction makeIterator(next, thro, name) {\n if (thro === void 0) {\n thro = kThrow;\n }\n\n if (name === void 0) {\n name = 'iterator';\n }\n\n var iterator = {\n meta: {\n name: name\n },\n next: next,\n throw: thro,\n return: kReturn,\n isSagaIterator: true\n };\n\n if (typeof Symbol !== 'undefined') {\n iterator[Symbol.iterator] = function () {\n return iterator;\n };\n }\n\n return iterator;\n}\nfunction logError(error, _ref2) {\n var sagaStack = _ref2.sagaStack;\n\n /*eslint-disable no-console*/\n console.error(error);\n console.error(sagaStack);\n}\nvar internalErr = function internalErr(err) {\n return new Error(\"\\n redux-saga: Error checking hooks detected an inconsistent state. This is likely a bug\\n in redux-saga code and not yours. Thanks for reporting this in the project's github repo.\\n Error: \" + err + \"\\n\");\n};\nvar createSetContextWarning = function createSetContextWarning(ctx, props) {\n return (ctx ? ctx + '.' : '') + \"setContext(props): argument \" + props + \" is not a plain object\";\n};\nvar FROZEN_ACTION_ERROR = \"You can't put (a.k.a. dispatch from saga) frozen actions.\\nWe have to define a special non-enumerable property on those actions for scheduling purposes.\\nOtherwise you wouldn't be able to communicate properly between sagas & other subscribers (action ordering would become far less predictable).\\nIf you are using redux and you care about this behaviour (frozen actions),\\nthen you might want to switch to freezing actions in a middleware rather than in action creator.\\nExample implementation:\\n\\nconst freezeActions = store => next => action => next(Object.freeze(action))\\n\"; // creates empty, but not-holey array\n\nvar createEmptyArray = function createEmptyArray(n) {\n return Array.apply(null, new Array(n));\n};\nvar wrapSagaDispatch = function wrapSagaDispatch(dispatch) {\n return function (action) {\n if (process.env.NODE_ENV !== 'production') {\n check(action, function (ac) {\n return !Object.isFrozen(ac);\n }, FROZEN_ACTION_ERROR);\n }\n\n return dispatch(Object.defineProperty(action, SAGA_ACTION, {\n value: true\n }));\n };\n};\nvar shouldTerminate = function shouldTerminate(res) {\n return res === TERMINATE;\n};\nvar shouldCancel = function shouldCancel(res) {\n return res === TASK_CANCEL;\n};\nvar shouldComplete = function shouldComplete(res) {\n return shouldTerminate(res) || shouldCancel(res);\n};\nfunction createAllStyleChildCallbacks(shape, parentCallback) {\n var keys = Object.keys(shape);\n var totalCount = keys.length;\n\n if (process.env.NODE_ENV !== 'production') {\n check(totalCount, function (c) {\n return c > 0;\n }, 'createAllStyleChildCallbacks: get an empty array or object');\n }\n\n var completedCount = 0;\n var completed;\n var results = array(shape) ? createEmptyArray(totalCount) : {};\n var childCallbacks = {};\n\n function checkEnd() {\n if (completedCount === totalCount) {\n completed = true;\n parentCallback(results);\n }\n }\n\n keys.forEach(function (key) {\n var chCbAtKey = function chCbAtKey(res, isErr) {\n if (completed) {\n return;\n }\n\n if (isErr || shouldComplete(res)) {\n parentCallback.cancel();\n parentCallback(res, isErr);\n } else {\n results[key] = res;\n completedCount++;\n checkEnd();\n }\n };\n\n chCbAtKey.cancel = noop;\n childCallbacks[key] = chCbAtKey;\n });\n\n parentCallback.cancel = function () {\n if (!completed) {\n completed = true;\n keys.forEach(function (key) {\n return childCallbacks[key].cancel();\n });\n }\n };\n\n return childCallbacks;\n}\nfunction getMetaInfo(fn) {\n return {\n name: fn.name || 'anonymous',\n location: getLocation(fn)\n };\n}\nfunction getLocation(instrumented) {\n return instrumented[SAGA_LOCATION];\n}\nfunction compose() {\n for (var _len = arguments.length, funcs = new Array(_len), _key = 0; _key < _len; _key++) {\n funcs[_key] = arguments[_key];\n }\n\n if (funcs.length === 0) {\n return function (arg) {\n return arg;\n };\n }\n\n if (funcs.length === 1) {\n return funcs[0];\n }\n\n return funcs.reduce(function (a, b) {\n return function () {\n return a(b.apply(void 0, arguments));\n };\n });\n}\n\nvar BUFFER_OVERFLOW = \"Channel's Buffer overflow!\";\nvar ON_OVERFLOW_THROW = 1;\nvar ON_OVERFLOW_DROP = 2;\nvar ON_OVERFLOW_SLIDE = 3;\nvar ON_OVERFLOW_EXPAND = 4;\nvar zeroBuffer = {\n isEmpty: kTrue,\n put: noop,\n take: noop\n};\n\nfunction ringBuffer(limit, overflowAction) {\n if (limit === void 0) {\n limit = 10;\n }\n\n var arr = new Array(limit);\n var length = 0;\n var pushIndex = 0;\n var popIndex = 0;\n\n var push = function push(it) {\n arr[pushIndex] = it;\n pushIndex = (pushIndex + 1) % limit;\n length++;\n };\n\n var take = function take() {\n if (length != 0) {\n var it = arr[popIndex];\n arr[popIndex] = null;\n length--;\n popIndex = (popIndex + 1) % limit;\n return it;\n }\n };\n\n var flush = function flush() {\n var items = [];\n\n while (length) {\n items.push(take());\n }\n\n return items;\n };\n\n return {\n isEmpty: function isEmpty() {\n return length == 0;\n },\n put: function put(it) {\n if (length < limit) {\n push(it);\n } else {\n var doubledLimit;\n\n switch (overflowAction) {\n case ON_OVERFLOW_THROW:\n throw new Error(BUFFER_OVERFLOW);\n\n case ON_OVERFLOW_SLIDE:\n arr[pushIndex] = it;\n pushIndex = (pushIndex + 1) % limit;\n popIndex = pushIndex;\n break;\n\n case ON_OVERFLOW_EXPAND:\n doubledLimit = 2 * limit;\n arr = flush();\n length = arr.length;\n pushIndex = arr.length;\n popIndex = 0;\n arr.length = doubledLimit;\n limit = doubledLimit;\n push(it);\n break;\n\n default: // DROP\n\n }\n }\n },\n take: take,\n flush: flush\n };\n}\n\nvar none = function none() {\n return zeroBuffer;\n};\nvar fixed = function fixed(limit) {\n return ringBuffer(limit, ON_OVERFLOW_THROW);\n};\nvar dropping = function dropping(limit) {\n return ringBuffer(limit, ON_OVERFLOW_DROP);\n};\nvar sliding = function sliding(limit) {\n return ringBuffer(limit, ON_OVERFLOW_SLIDE);\n};\nvar expanding = function expanding(initialSize) {\n return ringBuffer(initialSize, ON_OVERFLOW_EXPAND);\n};\n\nvar buffers = /*#__PURE__*/Object.freeze({\n __proto__: null,\n none: none,\n fixed: fixed,\n dropping: dropping,\n sliding: sliding,\n expanding: expanding\n});\n\nvar TAKE = 'TAKE';\nvar PUT = 'PUT';\nvar ALL = 'ALL';\nvar RACE = 'RACE';\nvar CALL = 'CALL';\nvar CPS = 'CPS';\nvar FORK = 'FORK';\nvar JOIN = 'JOIN';\nvar CANCEL = 'CANCEL';\nvar SELECT = 'SELECT';\nvar ACTION_CHANNEL = 'ACTION_CHANNEL';\nvar CANCELLED = 'CANCELLED';\nvar FLUSH = 'FLUSH';\nvar GET_CONTEXT = 'GET_CONTEXT';\nvar SET_CONTEXT = 'SET_CONTEXT';\n\nvar effectTypes = /*#__PURE__*/Object.freeze({\n __proto__: null,\n TAKE: TAKE,\n PUT: PUT,\n ALL: ALL,\n RACE: RACE,\n CALL: CALL,\n CPS: CPS,\n FORK: FORK,\n JOIN: JOIN,\n CANCEL: CANCEL,\n SELECT: SELECT,\n ACTION_CHANNEL: ACTION_CHANNEL,\n CANCELLED: CANCELLED,\n FLUSH: FLUSH,\n GET_CONTEXT: GET_CONTEXT,\n SET_CONTEXT: SET_CONTEXT\n});\n\nvar TEST_HINT = '\\n(HINT: if you are getting these errors in tests, consider using createMockTask from @redux-saga/testing-utils)';\n\nvar makeEffect = function makeEffect(type, payload) {\n var _ref;\n\n return _ref = {}, _ref[IO] = true, _ref.combinator = false, _ref.type = type, _ref.payload = payload, _ref;\n};\n\nvar isForkEffect = function isForkEffect(eff) {\n return effect(eff) && eff.type === FORK;\n};\n\nvar detach = function detach(eff) {\n if (process.env.NODE_ENV !== 'production') {\n check(eff, isForkEffect, 'detach(eff): argument must be a fork effect');\n }\n\n return makeEffect(FORK, _extends({}, eff.payload, {\n detached: true\n }));\n};\nfunction take(patternOrChannel, multicastPattern) {\n if (patternOrChannel === void 0) {\n patternOrChannel = '*';\n }\n\n if (process.env.NODE_ENV !== 'production' && arguments.length) {\n check(arguments[0], notUndef, 'take(patternOrChannel): patternOrChannel is undefined');\n }\n\n if (pattern(patternOrChannel)) {\n if (notUndef(multicastPattern)) {\n /* eslint-disable no-console */\n console.warn(\"take(pattern) takes one argument but two were provided. Consider passing an array for listening to several action types\");\n }\n\n return makeEffect(TAKE, {\n pattern: patternOrChannel\n });\n }\n\n if (multicast(patternOrChannel) && notUndef(multicastPattern) && pattern(multicastPattern)) {\n return makeEffect(TAKE, {\n channel: patternOrChannel,\n pattern: multicastPattern\n });\n }\n\n if (channel(patternOrChannel)) {\n if (notUndef(multicastPattern)) {\n /* eslint-disable no-console */\n console.warn(\"take(channel) takes one argument but two were provided. Second argument is ignored.\");\n }\n\n return makeEffect(TAKE, {\n channel: patternOrChannel\n });\n }\n\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(\"take(patternOrChannel): argument \" + patternOrChannel + \" is not valid channel or a valid pattern\");\n }\n}\nvar takeMaybe = function takeMaybe() {\n var eff = take.apply(void 0, arguments);\n eff.payload.maybe = true;\n return eff;\n};\nfunction put(channel$1, action) {\n if (process.env.NODE_ENV !== 'production') {\n if (arguments.length > 1) {\n check(channel$1, notUndef, 'put(channel, action): argument channel is undefined');\n check(channel$1, channel, \"put(channel, action): argument \" + channel$1 + \" is not a valid channel\");\n check(action, notUndef, 'put(channel, action): argument action is undefined');\n } else {\n check(channel$1, notUndef, 'put(action): argument action is undefined');\n }\n }\n\n if (undef(action)) {\n action = channel$1; // `undefined` instead of `null` to make default parameter work\n\n channel$1 = undefined;\n }\n\n return makeEffect(PUT, {\n channel: channel$1,\n action: action\n });\n}\nvar putResolve = function putResolve() {\n var eff = put.apply(void 0, arguments);\n eff.payload.resolve = true;\n return eff;\n};\nfunction all(effects) {\n var eff = makeEffect(ALL, effects);\n eff.combinator = true;\n return eff;\n}\nfunction race(effects) {\n var eff = makeEffect(RACE, effects);\n eff.combinator = true;\n return eff;\n} // this match getFnCallDescriptor logic\n\nvar validateFnDescriptor = function validateFnDescriptor(effectName, fnDescriptor) {\n check(fnDescriptor, notUndef, effectName + \": argument fn is undefined or null\");\n\n if (func(fnDescriptor)) {\n return;\n }\n\n var context = null;\n var fn;\n\n if (array(fnDescriptor)) {\n context = fnDescriptor[0];\n fn = fnDescriptor[1];\n check(fn, notUndef, effectName + \": argument of type [context, fn] has undefined or null `fn`\");\n } else if (object(fnDescriptor)) {\n context = fnDescriptor.context;\n fn = fnDescriptor.fn;\n check(fn, notUndef, effectName + \": argument of type {context, fn} has undefined or null `fn`\");\n } else {\n check(fnDescriptor, func, effectName + \": argument fn is not function\");\n return;\n }\n\n if (context && string(fn)) {\n check(context[fn], func, effectName + \": context arguments has no such method - \\\"\" + fn + \"\\\"\");\n return;\n }\n\n check(fn, func, effectName + \": unpacked fn argument (from [context, fn] or {context, fn}) is not a function\");\n};\n\nfunction getFnCallDescriptor(fnDescriptor, args) {\n var context = null;\n var fn;\n\n if (func(fnDescriptor)) {\n fn = fnDescriptor;\n } else {\n if (array(fnDescriptor)) {\n context = fnDescriptor[0];\n fn = fnDescriptor[1];\n } else {\n context = fnDescriptor.context;\n fn = fnDescriptor.fn;\n }\n\n if (context && string(fn) && func(context[fn])) {\n fn = context[fn];\n }\n }\n\n return {\n context: context,\n fn: fn,\n args: args\n };\n}\n\nvar isNotDelayEffect = function isNotDelayEffect(fn) {\n return fn !== delay;\n};\n\nfunction call(fnDescriptor) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n if (process.env.NODE_ENV !== 'production') {\n var arg0 = typeof args[0] === 'number' ? args[0] : 'ms';\n check(fnDescriptor, isNotDelayEffect, \"instead of writing `yield call(delay, \" + arg0 + \")` where delay is an effect from `redux-saga/effects` you should write `yield delay(\" + arg0 + \")`\");\n validateFnDescriptor('call', fnDescriptor);\n }\n\n return makeEffect(CALL, getFnCallDescriptor(fnDescriptor, args));\n}\nfunction apply(context, fn, args) {\n if (args === void 0) {\n args = [];\n }\n\n var fnDescriptor = [context, fn];\n\n if (process.env.NODE_ENV !== 'production') {\n validateFnDescriptor('apply', fnDescriptor);\n }\n\n return makeEffect(CALL, getFnCallDescriptor([context, fn], args));\n}\nfunction cps(fnDescriptor) {\n if (process.env.NODE_ENV !== 'production') {\n validateFnDescriptor('cps', fnDescriptor);\n }\n\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n\n return makeEffect(CPS, getFnCallDescriptor(fnDescriptor, args));\n}\nfunction fork(fnDescriptor) {\n if (process.env.NODE_ENV !== 'production') {\n validateFnDescriptor('fork', fnDescriptor);\n check(fnDescriptor, function (arg) {\n return !effect(arg);\n }, 'fork: argument must not be an effect');\n }\n\n for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {\n args[_key3 - 1] = arguments[_key3];\n }\n\n return makeEffect(FORK, getFnCallDescriptor(fnDescriptor, args));\n}\nfunction spawn(fnDescriptor) {\n if (process.env.NODE_ENV !== 'production') {\n validateFnDescriptor('spawn', fnDescriptor);\n }\n\n for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {\n args[_key4 - 1] = arguments[_key4];\n }\n\n return detach(fork.apply(void 0, [fnDescriptor].concat(args)));\n}\nfunction join(taskOrTasks) {\n if (process.env.NODE_ENV !== 'production') {\n if (arguments.length > 1) {\n throw new Error('join(...tasks) is not supported any more. Please use join([...tasks]) to join multiple tasks.');\n }\n\n if (array(taskOrTasks)) {\n taskOrTasks.forEach(function (t) {\n check(t, task, \"join([...tasks]): argument \" + t + \" is not a valid Task object \" + TEST_HINT);\n });\n } else {\n check(taskOrTasks, task, \"join(task): argument \" + taskOrTasks + \" is not a valid Task object \" + TEST_HINT);\n }\n }\n\n return makeEffect(JOIN, taskOrTasks);\n}\nfunction cancel(taskOrTasks) {\n if (taskOrTasks === void 0) {\n taskOrTasks = SELF_CANCELLATION;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (arguments.length > 1) {\n throw new Error('cancel(...tasks) is not supported any more. Please use cancel([...tasks]) to cancel multiple tasks.');\n }\n\n if (array(taskOrTasks)) {\n taskOrTasks.forEach(function (t) {\n check(t, task, \"cancel([...tasks]): argument \" + t + \" is not a valid Task object \" + TEST_HINT);\n });\n } else if (taskOrTasks !== SELF_CANCELLATION && notUndef(taskOrTasks)) {\n check(taskOrTasks, task, \"cancel(task): argument \" + taskOrTasks + \" is not a valid Task object \" + TEST_HINT);\n }\n }\n\n return makeEffect(CANCEL, taskOrTasks);\n}\nfunction select(selector) {\n if (selector === void 0) {\n selector = identity;\n }\n\n for (var _len5 = arguments.length, args = new Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) {\n args[_key5 - 1] = arguments[_key5];\n }\n\n if (process.env.NODE_ENV !== 'production' && arguments.length) {\n check(arguments[0], notUndef, 'select(selector, [...]): argument selector is undefined');\n check(selector, func, \"select(selector, [...]): argument \" + selector + \" is not a function\");\n }\n\n return makeEffect(SELECT, {\n selector: selector,\n args: args\n });\n}\n/**\n channel(pattern, [buffer]) => creates a proxy channel for store actions\n**/\n\nfunction actionChannel(pattern$1, buffer$1) {\n if (process.env.NODE_ENV !== 'production') {\n check(pattern$1, pattern, 'actionChannel(pattern,...): argument pattern is not valid');\n\n if (arguments.length > 1) {\n check(buffer$1, notUndef, 'actionChannel(pattern, buffer): argument buffer is undefined');\n check(buffer$1, buffer, \"actionChannel(pattern, buffer): argument \" + buffer$1 + \" is not a valid buffer\");\n }\n }\n\n return makeEffect(ACTION_CHANNEL, {\n pattern: pattern$1,\n buffer: buffer$1\n });\n}\nfunction cancelled() {\n return makeEffect(CANCELLED, {});\n}\nfunction flush(channel$1) {\n if (process.env.NODE_ENV !== 'production') {\n check(channel$1, channel, \"flush(channel): argument \" + channel$1 + \" is not valid channel\");\n }\n\n return makeEffect(FLUSH, channel$1);\n}\nfunction getContext(prop) {\n if (process.env.NODE_ENV !== 'production') {\n check(prop, string, \"getContext(prop): argument \" + prop + \" is not a string\");\n }\n\n return makeEffect(GET_CONTEXT, prop);\n}\nfunction setContext(props) {\n if (process.env.NODE_ENV !== 'production') {\n check(props, object, createSetContextWarning(null, props));\n }\n\n return makeEffect(SET_CONTEXT, props);\n}\nvar delay =\n/*#__PURE__*/\ncall.bind(null, delayP);\n\nexport { all as $, ALL as A, compose as B, CALL as C, logError as D, wrapSagaDispatch as E, FORK as F, GET_CONTEXT as G, identity as H, buffers as I, JOIN as J, detach as K, take as L, fork as M, cancel as N, call as O, PUT as P, delay as Q, RACE as R, SELECT as S, TAKE as T, actionChannel as U, sliding as V, race as W, effectTypes as X, takeMaybe as Y, put as Z, putResolve as _, CPS as a, apply as a0, cps as a1, spawn as a2, join as a3, select as a4, cancelled as a5, flush as a6, getContext as a7, setContext as a8, CANCEL as b, check as c, ACTION_CHANNEL as d, expanding as e, CANCELLED as f, FLUSH as g, SET_CONTEXT as h, internalErr as i, getMetaInfo as j, kTrue as k, createAllStyleChildCallbacks as l, createEmptyArray as m, none as n, once as o, assignWithSymbols as p, makeIterator as q, remove as r, shouldComplete as s, noop as t, flatMap as u, getLocation as v, createSetContextWarning as w, asyncIteratorSymbol as x, shouldCancel as y, shouldTerminate as z };\n"],"names":["createSymbol","name","CANCEL","CHANNEL_END_TYPE","IO","MATCH","MULTICAST","SAGA_ACTION","SELF_CANCELLATION","TASK","TASK_CANCEL","TERMINATE","SAGA_LOCATION","createActionHandler","ignore","reducer","obj","actions","arguments","length","undefined","predicate","constructor","call","apply","action","indexOf","type","initialState","state","ignoreActions","exports","done","value","qEnd","safeName","patternOrChannel","channel","stringableFunc","String","func","fsmIterator","fsm","startState","stateUpdater","errorState","effect","nextState","next","arg","error","currentState","makeIterator","takeEvery","worker","_len","args","Array","_key","yTake","take","setAction","ac","q1","q2","fork","concat","takeLatest","task","yFork","yCancel","cancel","setTask","t","q3","takeEvery$1","takeLatest$1","_len2","_key2","deferred","def","promise","Promise","resolve","reject","queue","semaphore","exec","suspend","release","asap","push","flush","immediately","shift","array","patterns","input","some","p","matcher","_predicate","string","pattern","symbol","wildcard","kTrue","matcherCreator","string$1","array$1","symbol$1","Error","END","isEnd","a","buffer$1","expanding","closed","takers","cb","isEmpty","remove","put","close","arr","i","len","taker","stdChannel","chan","_ref","currentTakers","nextTakers","ensureCanMutateNextTakers","slice","forEach","once","multicastChannel","resolvePromise","cancelPromise","then","_effectRunnerMap","current","nextSagaId","cancelSingleTask","taskToCancel","isRunning","effectRunnerMap","TAKE","env","_ref3","_ref3$channel","maybe","takeCb","notUndef","err","PUT","_ref2","result","dispatch","ALL","effects","_ref11","digestEffect","effectId","keys","Object","childCallbacks","createAllStyleChildCallbacks","key","RACE","_ref12","response","createEmptyArray","childCbs","completed","chCbAtKey","res","isErr","shouldComplete","noop","CALL","_ref4","_ref5","context","fn","iterator","proc","getMetaInfo","CPS","_ref6","cpsCb","undef","FORK","_ref7","_ref8","detached","parent","taskIterator","resolved","createTaskIterator","meta","isSagaIterator","getIteratorMetaInfo","child","addTask","isAborted","abort","JOIN","taskOrTasks","_ref9","joinSingleTask","taskToJoin","joiner","joiners","CANCEL$1","_ref10","SELECT","_ref13","selector","getState","ACTION_CHANNEL","_ref14","buffer","match","CANCELLED$1","data","_ref15","isCancelled","FLUSH","GET_CONTEXT","prop","_ref16","SET_CONTEXT","props","_ref17","assignWithSymbols","formatLocation","fileName","lineNumber","sagaLocationAsString","sagaMeta","location","cancelledTasksAsString","sagaStack","cancelledTasks","flatMap","join","crashedEffect","addSagaFrame","frame","clear","setCrashedEffect","toString","firstSaga","otherSagas","crashedEffectLocation","getLocation","code","effectLocationAsString","map","s","newTask","mainTask","parentContext","parentEffectId","isRoot","cont","_task","taskResult","taskError","status","deferredEnd","cancelledDueToErrorTasks","create","onAbort","tasks","cancelAll","getTasks","forkQueue","end","onError","id","setContext","toPromise","iterator$1","finalRunEffect","finalizeRunEffect","currCb","effectRunner","payload","executingContext","throw","shouldCancel","return","shouldTerminate","label","effectSettled","sagaMonitor","effectRejected","effectResolved","effectTriggered","effectCancelled","runSaga","saga","_ref$channel","_ref$context","effectMiddlewares","_ref$onError","logError","rootSagaStarted","actionDispatched","middleware","compose","runEffect","eff","identity","wrapSagaDispatch","_temp","boundRunSaga","options","_objectWithoutPropertiesLoose","sagaMiddleware","bind","_extends","run","formatProdErrorMessage","symbol_observable_default","Symbol","observable","randomString","Math","random","substring","split","actionTypes_default","INIT","REPLACE","PROBE_UNKNOWN_ACTION","isPlainObject","proto","getPrototypeOf","createStore","preloadedState","enhancer","currentReducer","currentListeners","Map","nextListeners","listenerIdCounter","isDispatching","ensureCanMutateNextListeners","listener","set","subscribe","isSubscribed","listenerId","delete","_defineProperty","replaceReducer","nextReducer","outerSubscribe","observer","observeState","observerAsObserver","unsubscribe","this","combineReducers","reducers","reducerKeys","finalReducers","process","shapeAssertionError","finalReducerKeys","assertReducerShape","e","hasChanged","previousStateForKey","nextStateForKey","funcs","_key3","reduce","b","applyMiddleware","_len3","middlewares","_key4","createStore2","store","middlewareAPI","_len4","_key5","chain","_toConsumableArray","_objectSpread","module","createThunkMiddleware","extraArgument","thunk","v","f","isArray","it","pat","every","ch","hasOwnProperty","sym","Boolean","prototype","multicast","ms","val","timeoutId","setTimeout","min","clearTimeout","konst","asyncIterator","target","source","getOwnPropertySymbols","mapper","item","index","splice","called","kThrow","kReturn","thro","console","internalErr","n","defineProperty","shape","parentCallback","totalCount","completedCount","results","instrumented","ringBuffer","limit","overflowAction","pushIndex","popIndex","items","doubledLimit","initialSize","CANCELLED","makeEffect","combinator","multicastPattern","warn","channel$1","all","getFnCallDescriptor","fnDescriptor","select","_len5","delay","delayP"],"sourceRoot":""}