{"version":3,"file":"chunks/31.64859b791185527e0e28.js","mappings":"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","sources":["webpack://@iqx-web/libs/../../node_modules/@redux-saga/deferred/dist/redux-saga-deferred.esm.js","webpack://@iqx-web/libs/../../node_modules/@redux-saga/core/dist/redux-saga-core.esm.js","webpack://@iqx-web/libs/../../node_modules/redux-saga/dist/redux-saga-core-npm-proxy.esm.js","webpack://@iqx-web/libs/../../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js"],"sourcesContent":["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","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}"],"names":["def","promise","Promise","resolve","reject","queue","semaphore","exec","task","suspend","release","asap","push","flush","immediately","undefined","shift","array","patterns","input","some","p","matcher","predicate","_predicate","string","pattern","type","String","symbol","wildcard","k","matcherCreator","stringableFunc","func","Error","END","CHANNEL_END_TYPE","isEnd","a","channel","buffer$1","e","closed","takers","take","cb","isEmpty","cancel","r","put","length","close","arr","i","len","taker","eventChannel","subscribe","buffer","n","unsubscribe","chan","o","multicastChannel","_ref","currentTakers","nextTakers","ensureCanMutateNextTakers","slice","forEach","MULTICAST","MATCH","stdChannel","SAGA_ACTION","RUNNING","CANCELLED","ABORTED","DONE","resolvePromise","cancelPromise","CANCEL","then","error","_effectRunnerMap","current","nextSagaId","cancelSingleTask","taskToCancel","isRunning","effectRunnerMap","T","env","_ref3","_ref3$channel","maybe","takeCb","TERMINATE","notUndef","err","P","_ref2","action","result","dispatch","A","effects","_ref11","digestEffect","effectId","keys","Object","childCallbacks","key","R","_ref12","response","childCbs","completed","chCbAtKey","res","isErr","s","C","_ref4","_ref5","context","fn","args","apply","iterator","proc","_ref6","cpsCb","undef","concat","F","_ref7","_ref8","detached","parent","taskIterator","resolved","arg","value","done","createTaskIterator","meta","isSagaIterator","name","getIteratorMetaInfo","child","addTask","isAborted","abort","J","taskOrTasks","_ref9","joinSingleTask","taskToJoin","joiner","joiners","t","_ref10","SELF_CANCELLATION","S","_ref13","selector","getState","_ref14","match","data","_ref15","isCancelled","G","prop","_ref16","props","_ref17","formatLocation","fileName","lineNumber","sagaLocationAsString","sagaMeta","location","cancelledTasksAsString","sagaStack","cancelledTasks","join","crashedEffect","addSagaFrame","frame","clear","setCrashedEffect","effect","firstSaga","otherSagas","crashedEffectLocation","code","map","iterator$1","parentContext","parentEffectId","isRoot","cont","finalRunEffect","finalizeRunEffect","currCb","IO","effectRunner","payload","executingContext","next","mainTask","status","TASK_CANCEL","_task","taskResult","taskError","deferredEnd","cancelledDueToErrorTasks","create","onAbort","tasks","cancelAll","getTasks","forkQueue","end","onError","TASK","id","setContext","toPromise","newTask","throw","return","label","effectSettled","sagaMonitor","effectRejected","effectResolved","effectTriggered","effectCancelled","runSaga","saga","_ref$channel","_ref$context","effectMiddlewares","_ref$onError","_len","arguments","Array","_key","rootSagaStarted","actionDispatched","middleware","runEffect","eff","_temp","boundRunSaga","options","sagaMiddleware","bind","run","_objectWithoutPropertiesLoose","source","excluded","target","sourceKeys","indexOf"],"sourceRoot":""}