{"version":3,"sources":["webpack://_N_E/./node_modules/recoil/es/recoil.js"],"names":["filterIterable","concatIterables","Recoil_nullthrows","x","message","Error","Recoil_recoverableViolation","projectName","error","Recoil_CopyOnWrite","set","v","next","Set","add","iterable","predicate","index","value","f","Recoil_filterIterable","gks","Map","Recoil_gkx","gk","_gks$get","get","setPass","setFail","Recoil_gkx_1","Recoil_mapIterable","callback","Recoil_expectationViolation","format","_defineProperty","obj","key","Object","defineProperty","enumerable","configurable","writable","AbstractRecoilValue","newKey","this","RecoilState","RecoilValueReadOnly","Recoil_RecoilValue","isRecoilValue","Recoil_RecoilValue_1","Recoil_RecoilValue_2","Recoil_RecoilValue_3","Recoil_RecoilValue_4","Recoil_RecoilValue$1","freeze","__proto__","DefaultValue","DEFAULT_VALUE","RecoilValueNotReady","nodes","recoilValues","NodeMissingError","configDeletionHandlers","getConfigDeletionHandler","Recoil_Node","registerNode","node","has","recoilValue","getNode","getNodeMaybe","deleteNodeConfigIfPossible","_node$shouldDeleteCon","_getConfigDeletionHan","shouldDeleteConfigOnRelease","call","setConfigDeletionHandler","fn","undefined","recoilValuesForKeys","keys","RetentionZone","Recoil_RetentionZone","setByAddingToSet$1","getNode$1","getNodeMaybe$1","recoilValuesForKeys$1","RetentionZone$1","emptySet","ReadOnlyRecoilValueError","initializeNodeIfNewToStore","store","treeState","trigger","storeState","getState","nodeCleanupFunctions","config","retentionCleanup","nodeKey","retainedBy","nodesRetainedByZone","retention","addToZone","zone","Array","isArray","deleteFromZone","size","initializeRetentionForNode","nodeCleanup","init","peekNodeLoadable","state","peek","getDownstreamNodes","visitedNodes","visitingNodes","from","graph","getGraph","version","pop","_graph$nodeToNodeSubs","nodeToNodeSubscriptions","downstreamNode","push","Recoil_FunctionalCore","newValue","_state$nodeCleanupFun","_node$invalidate","invalidate","atomValues","clone","nonvalidatedAtoms","dirtyAtoms","_graph$nodeDeps$get","_storeState$nodeToCom","_storeState$nodeToCom2","type","knownAtoms","knownSelectors","downstreamNodes","loadable","isActive","isSet","isModified","deps","nodeDeps","subscribers","components","nodeToComponentSubscriptions","values","name","getDownstreamNodes$1","getNodeLoadable$1","setNodeValue$1","getNodeMaybe$2","DefaultValue$1","RecoilValueNotReady$1","AbstractRecoilValue$1","RecoilState$1","RecoilValueReadOnly$1","isRecoilValue$1","applyAction","action","valueOrUpdater","current","contents","valueFromValueOrUpdater","entries","writeLoadableToTreeState","unvalidatedValue","applyActionsToStore","actions","replaceState","newState","copyTreeState","invalidateDownstreams","queueOrPerformStateUpdate","batchStack","length","actionsByStore","_getNodeMaybe","_getNodeMaybe$invalid","setRecoilValue","subscriptionID","Recoil_RecoilValueInterface","getRecoilValueAsLoadable","_storeState$nextTree","_storeState$previousT","currentTree","nextTree","previousTree","setRecoilValueLoadable","markRecoilValueModified","setUnvalidatedRecoilValue","subscribeToRecoilValue","componentDebugName","subID","release","subs","applyAtomValueWrites","writes","result","forEach","k","batchStart","invalidateDownstreams_FOR_TESTING","unstable_batchedUpdates","reactDom","batchStart$1","batcher","Recoil_Batching","newBatcher","batchEnd","Recoil_Queue","enqueueExecution","s","Recoil_differenceSets","ret","setsWithValuesToRemove","FIRST","otherSet","Recoil_mapMap","map","mergeDependencyMapIntoGraph","olderGraph","upstreams","downstream","existingUpstreams","upstream","existing","Recoil_Graph","dependencyMap","_storeState$previousT2","_storeState$previousT3","_storeState$nextTree2","nextVersion","hamt_1","module","exports","createCommonjsModule","_typeof","Symbol","iterator","constructor","prototype","hamt","BUCKET_SIZE","Math","pow","MASK","MAX_INDEX_NODE","MIN_ARRAY_NODE","nothing","constant","hash","str","i","len","charCodeAt","hashFragment","shift","h","toBitmap","fromBitmap","bitmap","bit","arrayUpdate","mutate","at","arr","out","arraySpliceOut","newLen","g","empty","__hamt_isEmpty","isEmptyNode","Leaf","edit","_modify","Leaf__modify","Collision","children","Collision__modify","IndexedNode","mask","IndexedNode__modify","ArrayNode","ArrayNode__modify","mergeLeaves","h1","n1","h2","n2","subH1","subH2","canEditNode","keyEq","_v","list","child","_newValue","updateCollisionList","frag","indx","exists","canEdit","newChildren","subNodes","count","expand","_i","arraySpliceIn","newChild","removed","elements","elem","pack","editable","root","_editable","_edit","_config","_root","_size","setTree","newRoot","newSize","tryGetHash","alt","tryGet","getHash","hasHash","defKeyCompare","y","make","isEmpty","modifyHash","NaN","modify","setHash","del","removeHash","deleteHash","remove","beginMutation","endMutation","transient","appk","lazyVisitChildren","lazyVisit","rest","DONE","done","MapIterator","v0","visit","buildPairs","buildKeys","buildValues","fold","z","m","toVisit","_","BuiltInMap","_map","persistentMap","HashArrayMappedTrieMap","_hamt","Recoil_PersistentMap_1","graph$1","persistentMap$1","nextTreeStateVersion","getNextTreeStateVersion","makeEmptyTreeState","stateID","transactionMetadata","Recoil_State","transactionSubscriptions","nodeTransactionSubscriptions","queuedComponentCallbacks_DEPRECATED","suspendedComponentResolvers","graphsByVersion","versionsUsedByComponent","referenceCounts","retainablesToCheckForRelease","Recoil_unionSets","sets","Recoil_someSet","context","entry","cleanUpNode$1","deleteNodeConfigIfPossible$1","getNode$2","RetentionZone$2","emptySet$1","releaseRetainablesNowOnCurrentTree","retainables","r","n","releasableNodes","searchFromNodes","nonReleasableNodes","findReleasableNodesInner","releasableNodesFoundThisIteration","downstreams","doNotDescendInto1","doNotDescendInto2","answer","visited","getDownstreamNodesInTopologicalOrder","_storeState$retention","zonesThatCouldRetainNode","some","nodeChildren","parents","parent","findReleasableNodes","releaseNode","_storeState$retention2","dep","_storeState$retention3","Recoil_Retention","retainable","delta","_map$get","newCount","scheduleOrPerformPossibleReleaseOfRetainable","clear","iters","iter","val","Recoil_concatIterables","Recoil_Environment","isSSR","isReactNative","navigator","product","isSSR$1","batchUpdates$1","initializeNodeIfNewToStore$1","peekNodeInfo$1","graph$2","DEFAULT_VALUE$1","recoilValues$1","recoilValuesForKeys$2","AbstractRecoilValue$2","getRecoilValueAsLoadable$1","setRecoilValue$1","setUnvalidatedRecoilValue$1","getNextTreeStateVersion$1","makeEmptyStoreState$1","Snapshot","checkRefCount_INTERNAL","_store","getLoadable","toPromise","opt","isInitialized","mapper","mutableSnapshot","MutableSnapshot","cloneSnapshot","getStore_INTERNAL","replacer","graphs","newGraph","subscribeToTransactions","addTransactionMetadata","retain","autorelease","_refCount","released","window","setTimeout","getID_INTERNAL","cloneStoreState","bumpVersion","snapshot","recoilState","newValueOrUpdater","Recoil_Snapshot","freshSnapshot","initializeState","Recoil_Snapshot_1","Recoil_Snapshot_2","Recoil_Snapshot_3","Recoil_Snapshot_4","Recoil_Snapshot$1","getNextTreeStateVersion$2","makeEmptyStoreState$2","cleanUpNode$2","getDownstreamNodes$2","setNodeValue$2","setUnvalidatedAtomValue_DEPRECATED$1","graph$3","cloneGraph$1","applyAtomValueWrites$1","releaseScheduledRetainablesNow$1","freshSnapshot$1","useCallback","react","useContext","useEffect","useMemo","useRef","useState","notInAContext","defaultStore","stateReplacerIsBeingExecuted","startNextTreeIfNeeded","AppContext","createContext","useStoreRef","MutableSourceContext","sendEndOfBatchNotifications","subscriptions","subscription","comps","cb","splice","Batcher","setNotifyBatcherOfChange","storeRef","setState","discardedVersion","nextID","Recoil_RecoilRoot_react","mutableSource","_createMutableSource","initializeState_DEPRECATED","storeProp","store_INTERNAL","notifyBatcherOfChange","createMutableSource","unstable_createMutableSource","replaced","id","metadata","initial","atom","writtenNodes","setUnvalidatedAtomValues","initialStoreState_DEPRECATED","initialStoreState","atomKey","createElement","Provider","Recoil_filterMap","Recoil_filterSet","Recoil_invariant","condition","_useMutableSource","Recoil_mergeMaps","maps","nextKey","useMutableSource","unstable_useMutableSource","Recoil_mutableSource","mutableSourceExists","$disableRecoilValueMutableSource_TEMP_HACK_DO_NOT_USE","Recoil_shallowArrayEqual","a","b","l","useRef$1","Recoil_useComponentName","batchUpdates$2","DEFAULT_VALUE$2","getNode$3","nodes$1","useRecoilMutableSource$1","useStoreRef$1","AbstractRecoilValue$3","getRecoilValueAsLoadable$2","setRecoilValue$2","setRecoilValueLoadable$1","setUnvalidatedRecoilValue$2","subscribeToRecoilValue$1","updateRetainCount$1","RetentionZone$3","cloneSnapshot$1","isSSR$2","mutableSourceExists$1","useMutableSource$1","useCallback$1","useEffect$1","useRef$2","useState$1","SUSPENSE_TIMEOUT_MS","handleLoadable","Promise","resolve","useRecoilValueLoadable","useRetain","getLoadableWithTesting","componentName","subscribe","_storeState","newLoadable","prevLoadableRef","is","source","useRecoilValueLoadable_MUTABLESOURCE","forceUpdate","_state","_prevLoadableRef$curr","_prevLoadableRef$curr2","useRecoilValueLoadable_LEGACY","useRecoilValue","useSetRecoilState","useTransactionSubscription","externallyVisibleAtomValuesInState","toMap","persistedAtomContentsValues","persistence","persistence_UNSTABLE","usePrevious","ref","useGotoRecoilSnapshot","prev","keysToUpdate","_prev$atomValues$get","_next$atomValues$get","shouldRestoreFromSnapshots","Sentinel","SENTINEL","toRetain","timeoutID","clearTimeout","previousRetainables","useRetain_ACTUAL","Recoil_Hooks","gotoSnapshot","args","reset","errMsg","setSnapshot","previousSnapshot","previousAtomValues","atomInfo","_node$persistence_UNS","_node$persistence_UNS2","_node$persistence_UNS3","_node$persistence_UNS4","backButton","modifiedAtoms","peekNodeInfo$2","useStoreRef$2","Recoil_useGetRecoilValueInfo","RecoilRoot$1","useStoreRef$3","useMemo$2","Recoil_useRecoilBridgeAcrossReactRoots","Recoil_isPromise","p","then","Canceled","CANCELED","loadableAccessors","getValue","__value","reject","valueMaybe","valueOrThrow","errorMaybe","errorOrThrow","promiseMaybe","promiseOrThrow","other","loadableWithPromise","loadableWithValue","e","loadableWithError","promise","Recoil_Loadable","loadableLoading","loadableAll","inputs","every","find","all","stringify","includes","String","JSON","allowFunctions","_JSON$stringify","toString","toJSON","sort","localeCompare","filter","join","Recoil_stableStringify","TreeCache","options","_options$onHit","_options$onSet","_options$mapNodeValue","_numLeafs","_onHit","onHit","_onSet","onSet","_mapNodeValue","mapNodeValue","getNodeValue","handlers","_this$getLeafNode","getLeafNode","findLeaf","onNodeVisit","route","leafNode","addLeaf","nodeValue","pruneNodeFromTree","branches","countDownstreamLeaves","_handlers$onNodeVisit","branchKey","_handlers$onNodeVisit2","path","pruneUpstreamBranches","branchNode","reduce","sum","currNode","Recoil_TreeCache_1","Recoil_TreeCache$1","Recoil_LRUCache_1","LRUCache","_options$mapKey","_maxSize","maxSize","_head","_tail","_keyMapper","mapKey","mappedKey","head","right","left","_maybeDeleteLRU","deleteLru","tail","Recoil_LRUCache$1","LRUCache$1","TreeCache$1","Recoil_treeCacheLRU","lruCache","cache","lruNode","TreeCache$2","defaultPolicy","equality","eviction","Infinity","getValueMapper","getTreeCache","Recoil_treeCacheFromPolicy","valueMapper","treeCache","Recoil_PerformanceTimings","_id","CANCELED$1","Canceled$1","loadableWithError$1","loadableWithPromise$1","loadableWithValue$1","getNodeLoadable$2","peekNodeLoadable$1","setNodeValue$3","saveDependencyMapToStore$1","DEFAULT_VALUE$3","RecoilValueNotReady$2","getConfigDeletionHandler$1","registerNode$1","isRecoilValue$3","AbstractRecoilValue$4","setRecoilValueLoadable$2","retainedByOptionWithDefault$1","startPerfBlock$1","dependencyStack","waitingStores","getNewExecutionId","executionId","Recoil_selector","cachePolicy","cachePolicy_UNSTABLE","retainedBy_UNSTABLE","executionInfoMap","liveStoresCount","selectorIsLive","getExecutionInfo","depValuesDiscoveredSoFarDuringAsyncWork","latestLoadable","latestExecutionId","stateVersion","selectorInit","selectorShouldDeleteConfigOnRelease","notifyStoreWhenAsyncSettles","stores","getCachedNodeLoadable","isKeyPointingToSelector","wrapPendingPromise","depValues","clearExecutionInfo","maybeFreezeValue","setCache","depValuesToDepRoute","setDepsInStore","setLoadableInStoreToNotifyDeps","__key","errorOrPromise","isLatestExecution","updateExecutionInfoDepValues","wrapPendingDependencyPromise","existingDeps","resolvedDep","resolvedDepKey","depValue","bypassSelectorDepCacheOnReevaluation","evaluateSelectorGetter","maybeFreezeLoadableContents","setExecutionInfo","notifyStoresOfSettledAsync","_store$getState","_store$getState$curre","_store$getState2","_store$getState2$next","_store$getState$nextT","_store$getState3","_store$getState3$next","setNewDepInStore","newDepKey","bypassSelectorDepCache","endPerfBlock","resultIsError","getRecoilValue","depKey","depLoadable","errorOrDepPromise","getValFromRunningNewExecutionAndUpdatedDeps","newExecutionId","newDepValues","depRoute","maybeSetCacheWithLoadable","getSelectorValAndUpdatedDeps","cachedVal","depsAfterCacheDone","executionInfo","getValFromCacheAndUpdatedDownstreamDeps","inProgressExecutionInfo","_Array$from$find","_executionInfo$depVal","_mapOfCheckedVersions","oldDepValues","cachedDepValuesCheckedForThisVersion","mapOfCheckedVersions","isCachedVersionSame","nodeVal","oldVal","haveAsyncDepsChanged","getExecutionInfoOfInProgressExecution","cacheRoute","selectorPeek","selectorGet","slice","indexOf","detectCircularDependencies","invalidateSelector","syncSelectorSetFinished","setRecoilState","dangerouslyAllowMutability","loadableWithError$2","loadableWithPromise$2","loadableWithValue$2","DEFAULT_VALUE$4","DefaultValue$2","getConfigDeletionHandler$2","registerNode$2","setConfigDeletionHandler$1","isRecoilValue$4","markRecoilValueModified$1","setRecoilValue$3","setRecoilValueLoadable$3","retainedByOptionWithDefault$2","baseAtom","defaultLoadable","cachedAnswerForUnvalidatedValue","cleanupEffectsByStore","_ref","_state$atomValues$get3","_cachedAnswerForUnval","nonvalidatedValue","validatorResult","validator","validatedValueLoadable","initState","alreadyKnown","notifyDefaultSubscribers","_store$getState$nextT3","initValue","pendingSetSelf","effects_UNSTABLE","duringInit","setSelf","effect","currentValue","resetSelf","handler","currentStore","_pendingSetSelf3","_previousTree$atomVal","_pendingSetSelf","_pendingSetSelf2","oldLoadable","oldValue","_options$effects_UNST","cleanup","_store$getState$nextT4","initLoadable","wrappedPromise","_state$atomValues$get","_store$getState$nextT2","_state$atomValues$get2","_cleanupEffectsByStor","optionsDefault","restOptions","base","default","storedValue","sel","baseValue","atomWithFallback","Recoil_atom","Recoil_MapCache_1","MapCache","Recoil_MapCache$1","LRUCache$2","MapCache$1","defaultPolicy$1","getValueMapper$1","getCache","Recoil_cacheFromPolicy","setConfigDeletionHandler$2","nextIndex","Recoil_selectorFamily","_options$cachePolicyF","selectorCache","cachePolicyForParams_UNSTABLE","params","_stableStringify","cachedSelector","newSelector","myKey","myGet","callbacks","myCachePolicy","DEFAULT_VALUE$5","DefaultValue$3","setConfigDeletionHandler$3","Recoil_atomFamily","legacyAtom","atomCache","legacyAtomOptions","atomFamilyDefault","param","legacyValue","cachedAtom","atomOptions","newAtom","constantSelector","Recoil_constSelector","throwingSelector","Recoil_errorSelector","Recoil_readOnlySelector","loadableWithError$3","loadableWithPromise$3","loadableWithValue$3","concurrentRequests","results","fill","exceptions","isError","exp","unwrapDependencies","dependencies","getOwnPropertyNames","getValueFromLoadablePromiseResult","hasOwnProperty","wrapResults","idx","wrapLoadables","exception","Recoil_WaitFor","waitForNone","waitForAny","waitForAll","exceptionResults","syncResults","asyncResults","waitForAllSettled","noWait","dependency","batchUpdates$3","setBatcher$1","DefaultValue$4","RecoilRoot$2","isRecoilValue$5","retentionZone$1","freshSnapshot$2","Recoil_index","RecoilRoot","useRecoilBridgeAcrossReactRoots_UNSTABLE","selector","retentionZone","atomFamily","selectorFamily","constSelector","errorSelector","readOnlySelector","useRecoilState","useRecoilStateLoadable","useResetRecoilState","useGetRecoilValueInfo_UNSTABLE","useRecoilCallback","useRecoilSnapshot","useRecoilTransactionObserver_UNSTABLE","useTransactionObservation_UNSTABLE","useSetUnvalidatedAtomValues_UNSTABLE","batchUpdates","setBatcher","snapshot_UNSTABLE","Recoil_index_1","Recoil_index_2","Recoil_index_3","Recoil_index_4","Recoil_index_5","Recoil_index_6","Recoil_index_7","Recoil_index_8","Recoil_index_9","Recoil_index_10","Recoil_index_11","Recoil_index_12","Recoil_index_13","Recoil_index_14","Recoil_index_15","Recoil_index_16","Recoil_index_17","Recoil_index_18","Recoil_index_19","Recoil_index_20","Recoil_index_21","Recoil_index_22","Recoil_index_23","Recoil_index_24","Recoil_index_25","Recoil_index_26","Recoil_index_27","Recoil_index_28","Recoil_index_29","Recoil_index_30","Recoil_index_31","Recoil_index_32","Recoil_index_33","Recoil_index_34"],"mappings":"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","file":"static/chunks/0a301732.c343bdc245979e2ae55f.js","sourcesContent":["import reactDom from 'react-dom';\nimport react from 'react';\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction nullthrows(x, message) {\n if (x != null) {\n return x;\n }\n\n throw new Error(message !== null && message !== void 0 ? message : 'Got unexpected null or undefined');\n}\n\nvar Recoil_nullthrows = nullthrows;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction recoverableViolation(message, projectName, {\n error\n} = {}) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(message, error);\n }\n\n return null;\n}\n\nvar recoverableViolation_1 = recoverableViolation;\n\n// @oss-only\n\n\nvar Recoil_recoverableViolation = recoverableViolation_1;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * Utilities for working with built-in Maps and Sets without mutating them.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction setByAddingToSet(set, v) {\n const next = new Set(set);\n next.add(v);\n return next;\n}\n\nfunction setByDeletingFromSet(set, v) {\n const next = new Set(set);\n next.delete(v);\n return next;\n}\n\nfunction mapBySettingInMap(map, k, v) {\n const next = new Map(map);\n next.set(k, v);\n return next;\n}\n\nfunction mapByUpdatingInMap(map, k, updater) {\n const next = new Map(map);\n next.set(k, updater(next.get(k)));\n return next;\n}\n\nfunction mapByDeletingFromMap(map, k) {\n const next = new Map(map);\n next.delete(k);\n return next;\n}\n\nfunction mapByDeletingMultipleFromMap(map, ks) {\n const next = new Map(map);\n ks.forEach(k => next.delete(k));\n return next;\n}\n\nvar Recoil_CopyOnWrite = {\n setByAddingToSet,\n setByDeletingFromSet,\n mapBySettingInMap,\n mapByUpdatingInMap,\n mapByDeletingFromMap,\n mapByDeletingMultipleFromMap\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n/**\n * Creates a new iterable whose output is generated by passing the input\n * iterable's values through the filter function.\n */\n\nfunction* filterIterable(iterable, predicate) {\n // Use generator to create iterable/iterator\n let index = 0;\n\n for (const value of iterable) {\n if (predicate(value, index++)) {\n yield value;\n }\n }\n}\n\nvar Recoil_filterIterable = filterIterable;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nconst gks = new Map().set('recoil_hamt_2020', true);\n\nfunction Recoil_gkx(gk) {\n var _gks$get;\n\n return (_gks$get = gks.get(gk)) !== null && _gks$get !== void 0 ? _gks$get : false;\n}\n\nRecoil_gkx.setPass = gk => {\n gks.set(gk, true);\n};\n\nRecoil_gkx.setFail = gk => {\n gks.set(gk, false);\n};\n\nvar Recoil_gkx_1 = Recoil_gkx; // @oss-only\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n/**\n * Creates a new iterable whose output is generated by passing the input\n * iterable's values through the mapper function.\n */\n\nfunction mapIterable(iterable, callback) {\n // Use generator to create iterable/iterator\n return function* () {\n let index = 0;\n\n for (const value of iterable) {\n yield callback(value, index++);\n }\n }();\n}\n\nvar Recoil_mapIterable = mapIterable;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction sprintf(format, ...args) {\n let index = 0;\n return format.replace(/%s/g, () => String(args[index++]));\n}\n\nvar sprintf_1 = sprintf;\n\nfunction expectationViolation(format, ...args) {\n if (process.env.NODE_ENV !== \"production\") {\n const message = sprintf_1.call(null, format, ...args);\n const error = new Error(message);\n error.name = 'Expectation Violation';\n console.error(error);\n }\n}\n\nvar expectationViolation_1 = expectationViolation;\n\n// @oss-only\n\n\nvar Recoil_expectationViolation = expectationViolation_1;\n\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\n// eslint-disable-next-line no-unused-vars\nclass AbstractRecoilValue {\n constructor(newKey) {\n _defineProperty(this, \"key\", void 0);\n\n this.key = newKey;\n }\n\n}\n\nclass RecoilState extends AbstractRecoilValue {}\n\nclass RecoilValueReadOnly extends AbstractRecoilValue {}\n\nfunction isRecoilValue(x) {\n return x instanceof RecoilState || x instanceof RecoilValueReadOnly;\n}\n\nvar Recoil_RecoilValue = {\n AbstractRecoilValue,\n RecoilState,\n RecoilValueReadOnly,\n isRecoilValue\n};\n\nvar Recoil_RecoilValue_1 = Recoil_RecoilValue.AbstractRecoilValue;\nvar Recoil_RecoilValue_2 = Recoil_RecoilValue.RecoilState;\nvar Recoil_RecoilValue_3 = Recoil_RecoilValue.RecoilValueReadOnly;\nvar Recoil_RecoilValue_4 = Recoil_RecoilValue.isRecoilValue;\n\nvar Recoil_RecoilValue$1 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n AbstractRecoilValue: Recoil_RecoilValue_1,\n RecoilState: Recoil_RecoilValue_2,\n RecoilValueReadOnly: Recoil_RecoilValue_3,\n isRecoilValue: Recoil_RecoilValue_4\n});\n\nclass DefaultValue {}\n\nconst DEFAULT_VALUE = new DefaultValue();\n\nclass RecoilValueNotReady extends Error {\n constructor(key) {\n super(`Tried to set the value of Recoil selector ${key} using an updater function, but it is an async selector in a pending or error state; this is not supported.`);\n }\n\n}\n\n// flowlint-next-line unclear-type:off\nconst nodes = new Map(); // flowlint-next-line unclear-type:off\n\nconst recoilValues = new Map();\n/* eslint-disable no-redeclare */\n\nfunction recoilValuesForKeys(keys) {\n return Recoil_mapIterable(keys, key => Recoil_nullthrows(recoilValues.get(key)));\n}\n\nfunction registerNode(node) {\n if (nodes.has(node.key)) {\n const message = `Duplicate atom key \"${node.key}\". This is a FATAL ERROR in\n production. But it is safe to ignore this warning if it occurred because of\n hot module replacement.`; // TODO Need to figure out if there is a standard/open-source equivalent to see if hot module replacement is happening:\n // prettier-ignore\n // @fb-only: if (__DEV__) {\n // @fb-only: const isAcceptingUpdate = require('__debug').isAcceptingUpdate;\n // prettier-ignore\n // @fb-only: if (typeof isAcceptingUpdate !== 'function' || !isAcceptingUpdate()) {\n // @fb-only: expectationViolation(message, 'recoil');\n // @fb-only: }\n // prettier-ignore\n // @fb-only: } else {\n // @fb-only: recoverableViolation(message, 'recoil');\n // @fb-only: }\n\n console.warn(message); // @oss-only\n }\n\n nodes.set(node.key, node);\n const recoilValue = node.set == null ? new Recoil_RecoilValue$1.RecoilValueReadOnly(node.key) : new Recoil_RecoilValue$1.RecoilState(node.key);\n recoilValues.set(node.key, recoilValue);\n return recoilValue;\n}\n/* eslint-enable no-redeclare */\n\n\nclass NodeMissingError extends Error {} // flowlint-next-line unclear-type:off\n\n\nfunction getNode(key) {\n const node = nodes.get(key);\n\n if (node == null) {\n throw new NodeMissingError(`Missing definition for RecoilValue: \"${key}\"\"`);\n }\n\n return node;\n} // flowlint-next-line unclear-type:off\n\n\nfunction getNodeMaybe(key) {\n return nodes.get(key);\n}\n\nconst configDeletionHandlers = new Map();\n\nfunction deleteNodeConfigIfPossible(key) {\n var _node$shouldDeleteCon;\n\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n }\n\n const node = nodes.get(key);\n\n if (node === null || node === void 0 ? void 0 : (_node$shouldDeleteCon = node.shouldDeleteConfigOnRelease) === null || _node$shouldDeleteCon === void 0 ? void 0 : _node$shouldDeleteCon.call(node)) {\n var _getConfigDeletionHan;\n\n nodes.delete(key);\n (_getConfigDeletionHan = getConfigDeletionHandler(key)) === null || _getConfigDeletionHan === void 0 ? void 0 : _getConfigDeletionHan();\n configDeletionHandlers.delete(key);\n }\n}\n\nfunction setConfigDeletionHandler(key, fn) {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n }\n\n if (fn === undefined) {\n configDeletionHandlers.delete(key);\n } else {\n configDeletionHandlers.set(key, fn);\n }\n}\n\nfunction getConfigDeletionHandler(key) {\n return configDeletionHandlers.get(key);\n}\n\nvar Recoil_Node = {\n nodes,\n recoilValues,\n registerNode,\n getNode,\n getNodeMaybe,\n deleteNodeConfigIfPossible,\n setConfigDeletionHandler,\n getConfigDeletionHandler,\n recoilValuesForKeys,\n NodeMissingError,\n DefaultValue,\n DEFAULT_VALUE,\n RecoilValueNotReady\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nclass RetentionZone {}\n\nfunction retentionZone() {\n return new RetentionZone();\n}\n\nvar Recoil_RetentionZone = {\n RetentionZone,\n retentionZone\n};\n\nconst {\n setByAddingToSet: setByAddingToSet$1\n} = Recoil_CopyOnWrite;\n\n\n\n\n\n\n\nconst {\n getNode: getNode$1,\n getNodeMaybe: getNodeMaybe$1,\n recoilValuesForKeys: recoilValuesForKeys$1\n} = Recoil_Node;\n\nconst {\n RetentionZone: RetentionZone$1\n} = Recoil_RetentionZone; // flowlint-next-line unclear-type:off\n\n\nconst emptySet = Object.freeze(new Set());\n\nclass ReadOnlyRecoilValueError extends Error {}\n\nfunction initializeRetentionForNode(store, nodeKey, retainedBy) {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return () => undefined;\n }\n\n const {\n nodesRetainedByZone\n } = store.getState().retention;\n\n function addToZone(zone) {\n let set = nodesRetainedByZone.get(zone);\n\n if (!set) {\n nodesRetainedByZone.set(zone, set = new Set());\n }\n\n set.add(nodeKey);\n }\n\n if (retainedBy instanceof RetentionZone$1) {\n addToZone(retainedBy);\n } else if (Array.isArray(retainedBy)) {\n for (const zone of retainedBy) {\n addToZone(zone);\n }\n }\n\n return () => {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n }\n\n const nodesRetainedByZone = store.getState().retention.nodesRetainedByZone;\n\n function deleteFromZone(zone) {\n const set = nodesRetainedByZone.get(zone);\n\n if (set) {\n set.delete(nodeKey);\n }\n\n if (set && set.size === 0) {\n nodesRetainedByZone.delete(zone);\n }\n }\n\n if (retainedBy instanceof RetentionZone$1) {\n deleteFromZone(retainedBy);\n } else if (Array.isArray(retainedBy)) {\n for (const zone of retainedBy) {\n deleteFromZone(zone);\n }\n }\n };\n}\n\nfunction initializeNodeIfNewToStore(store, treeState, key, trigger) {\n const storeState = store.getState();\n\n if (storeState.nodeCleanupFunctions.has(key)) {\n return;\n }\n\n const config = getNode$1(key);\n const retentionCleanup = initializeRetentionForNode(store, key, config.retainedBy);\n const nodeCleanup = config.init(store, treeState, trigger);\n storeState.nodeCleanupFunctions.set(key, () => {\n nodeCleanup();\n retentionCleanup();\n });\n}\n\nfunction cleanUpNode(store, key) {\n var _state$nodeCleanupFun;\n\n const state = store.getState();\n (_state$nodeCleanupFun = state.nodeCleanupFunctions.get(key)) === null || _state$nodeCleanupFun === void 0 ? void 0 : _state$nodeCleanupFun();\n state.nodeCleanupFunctions.delete(key);\n} // Get the current value loadable of a node and update the state.\n// Update dependencies and subscriptions for selectors.\n// Update saved value validation for atoms.\n\n\nfunction getNodeLoadable(store, state, key) {\n initializeNodeIfNewToStore(store, state, key, 'get');\n return getNode$1(key).get(store, state);\n} // Peek at the current value loadable for a node without any evaluation or state change\n\n\nfunction peekNodeLoadable(store, state, key) {\n return getNode$1(key).peek(store, state);\n} // Write value directly to state bypassing the Node interface as the node\n// definitions may not have been loaded yet when processing the initial snapshot.\n\n\nfunction setUnvalidatedAtomValue_DEPRECATED(state, key, newValue) {\n var _node$invalidate;\n\n const node = getNodeMaybe$1(key);\n node === null || node === void 0 ? void 0 : (_node$invalidate = node.invalidate) === null || _node$invalidate === void 0 ? void 0 : _node$invalidate.call(node, state);\n return { ...state,\n atomValues: state.atomValues.clone().delete(key),\n nonvalidatedAtoms: state.nonvalidatedAtoms.clone().set(key, newValue),\n dirtyAtoms: setByAddingToSet$1(state.dirtyAtoms, key)\n };\n} // Return the discovered dependencies and values to be written by setting\n// a node value. (Multiple values may be written due to selectors getting to\n// set upstreams; deps may be discovered because of reads in updater functions.)\n\n\nfunction setNodeValue(store, state, key, newValue) {\n const node = getNode$1(key);\n\n if (node.set == null) {\n throw new ReadOnlyRecoilValueError(`Attempt to set read-only RecoilValue: ${key}`);\n }\n\n const set = node.set; // so flow doesn't lose the above refinement.\n\n initializeNodeIfNewToStore(store, state, key, 'set');\n return set(store, state, newValue);\n}\n\nfunction peekNodeInfo(store, state, key) {\n var _graph$nodeDeps$get, _storeState$nodeToCom, _storeState$nodeToCom2;\n\n const storeState = store.getState();\n const graph = store.getGraph(state.version);\n const type = storeState.knownAtoms.has(key) ? 'atom' : storeState.knownSelectors.has(key) ? 'selector' : undefined;\n const downstreamNodes = Recoil_filterIterable(getDownstreamNodes(store, state, new Set([key])), nodeKey => nodeKey !== key);\n return {\n loadable: peekNodeLoadable(store, state, key),\n isActive: storeState.knownAtoms.has(key) || storeState.knownSelectors.has(key),\n isSet: type === 'selector' ? false : state.atomValues.has(key),\n isModified: state.dirtyAtoms.has(key),\n type,\n // Report current dependencies. If the node hasn't been evaluated, then\n // dependencies may be missing based on the current state.\n deps: recoilValuesForKeys$1((_graph$nodeDeps$get = graph.nodeDeps.get(key)) !== null && _graph$nodeDeps$get !== void 0 ? _graph$nodeDeps$get : []),\n // Reportsall \"current\" subscribers. Evaluating other nodes or\n // previous in-progress async evaluations may introduce new subscribers.\n subscribers: {\n nodes: recoilValuesForKeys$1(downstreamNodes),\n components: Recoil_mapIterable((_storeState$nodeToCom = (_storeState$nodeToCom2 = storeState.nodeToComponentSubscriptions.get(key)) === null || _storeState$nodeToCom2 === void 0 ? void 0 : _storeState$nodeToCom2.values()) !== null && _storeState$nodeToCom !== void 0 ? _storeState$nodeToCom : [], ([name]) => ({\n name\n }))\n }\n };\n} // Find all of the recursively dependent nodes\n\n\nfunction getDownstreamNodes(store, state, keys) {\n const visitedNodes = new Set();\n const visitingNodes = Array.from(keys);\n const graph = store.getGraph(state.version);\n\n for (let key = visitingNodes.pop(); key; key = visitingNodes.pop()) {\n var _graph$nodeToNodeSubs;\n\n visitedNodes.add(key);\n const subscribedNodes = (_graph$nodeToNodeSubs = graph.nodeToNodeSubscriptions.get(key)) !== null && _graph$nodeToNodeSubs !== void 0 ? _graph$nodeToNodeSubs : emptySet;\n\n for (const downstreamNode of subscribedNodes) {\n if (!visitedNodes.has(downstreamNode)) {\n visitingNodes.push(downstreamNode);\n }\n }\n }\n\n return visitedNodes;\n}\n\nvar Recoil_FunctionalCore = {\n getNodeLoadable,\n peekNodeLoadable,\n setNodeValue,\n cleanUpNode,\n setUnvalidatedAtomValue_DEPRECATED,\n peekNodeInfo,\n getDownstreamNodes,\n initializeNodeIfNewToStore\n};\n\nconst {\n getDownstreamNodes: getDownstreamNodes$1,\n getNodeLoadable: getNodeLoadable$1,\n setNodeValue: setNodeValue$1\n} = Recoil_FunctionalCore;\n\nconst {\n getNodeMaybe: getNodeMaybe$2\n} = Recoil_Node;\n\nconst {\n DefaultValue: DefaultValue$1,\n RecoilValueNotReady: RecoilValueNotReady$1\n} = Recoil_Node;\n\nconst {\n AbstractRecoilValue: AbstractRecoilValue$1,\n RecoilState: RecoilState$1,\n RecoilValueReadOnly: RecoilValueReadOnly$1,\n isRecoilValue: isRecoilValue$1\n} = Recoil_RecoilValue$1;\n\nfunction getRecoilValueAsLoadable(store, {\n key\n}, treeState = store.getState().currentTree) {\n var _storeState$nextTree, _storeState$previousT;\n\n // Reading from an older tree can cause bugs because the dependencies that we\n // discover during the read are lost.\n const storeState = store.getState();\n\n if (!(treeState.version === storeState.currentTree.version || treeState.version === ((_storeState$nextTree = storeState.nextTree) === null || _storeState$nextTree === void 0 ? void 0 : _storeState$nextTree.version) || treeState.version === ((_storeState$previousT = storeState.previousTree) === null || _storeState$previousT === void 0 ? void 0 : _storeState$previousT.version))) {\n Recoil_recoverableViolation('Tried to read from a discarded tree');\n }\n\n const loadable = getNodeLoadable$1(store, treeState, key);\n return loadable;\n}\n\nfunction applyAtomValueWrites(atomValues, writes) {\n const result = atomValues.clone();\n writes.forEach((v, k) => {\n if (v.state === 'hasValue' && v.contents instanceof DefaultValue$1) {\n result.delete(k);\n } else {\n result.set(k, v);\n }\n });\n return result;\n}\n\nfunction valueFromValueOrUpdater(store, state, {\n key\n}, valueOrUpdater) {\n if (typeof valueOrUpdater === 'function') {\n // Updater form: pass in the current value. Throw if the current value\n // is unavailable (namely when updating an async selector that's\n // pending or errored):\n const current = getNodeLoadable$1(store, state, key);\n\n if (current.state === 'loading') {\n throw new RecoilValueNotReady$1(key);\n } else if (current.state === 'hasError') {\n throw current.contents;\n } // T itself may be a function, so our refinement is not sufficient:\n\n\n return valueOrUpdater(current.contents); // flowlint-line unclear-type:off\n } else {\n return valueOrUpdater;\n }\n}\n\nfunction applyAction(store, state, action) {\n if (action.type === 'set') {\n const {\n recoilValue,\n valueOrUpdater\n } = action;\n const newValue = valueFromValueOrUpdater(store, state, recoilValue, valueOrUpdater);\n const writes = setNodeValue$1(store, state, recoilValue.key, newValue);\n\n for (const [key, loadable] of writes.entries()) {\n writeLoadableToTreeState(state, key, loadable);\n }\n } else if (action.type === 'setLoadable') {\n const {\n recoilValue: {\n key\n },\n loadable\n } = action;\n writeLoadableToTreeState(state, key, loadable);\n } else if (action.type === 'markModified') {\n const {\n recoilValue: {\n key\n }\n } = action;\n state.dirtyAtoms.add(key);\n } else if (action.type === 'setUnvalidated') {\n var _node$invalidate;\n\n // Write value directly to state bypassing the Node interface as the node\n // definitions may not have been loaded yet when processing the initial snapshot.\n const {\n recoilValue: {\n key\n },\n unvalidatedValue\n } = action;\n const node = getNodeMaybe$2(key);\n node === null || node === void 0 ? void 0 : (_node$invalidate = node.invalidate) === null || _node$invalidate === void 0 ? void 0 : _node$invalidate.call(node, state);\n state.atomValues.delete(key);\n state.nonvalidatedAtoms.set(key, unvalidatedValue);\n state.dirtyAtoms.add(key);\n } else {\n Recoil_recoverableViolation(`Unknown action ${action.type}`);\n }\n}\n\nfunction writeLoadableToTreeState(state, key, loadable) {\n if (loadable.state === 'hasValue' && loadable.contents instanceof DefaultValue$1) {\n state.atomValues.delete(key);\n } else {\n state.atomValues.set(key, loadable);\n }\n\n state.dirtyAtoms.add(key);\n state.nonvalidatedAtoms.delete(key);\n}\n\nfunction applyActionsToStore(store, actions) {\n store.replaceState(state => {\n const newState = copyTreeState(state);\n\n for (const action of actions) {\n applyAction(store, newState, action);\n }\n\n invalidateDownstreams(store, newState);\n return newState;\n });\n}\n\nfunction queueOrPerformStateUpdate(store, action) {\n if (batchStack.length) {\n const actionsByStore = batchStack[batchStack.length - 1];\n let actions = actionsByStore.get(store);\n\n if (!actions) {\n actionsByStore.set(store, actions = []);\n }\n\n actions.push(action);\n } else {\n applyActionsToStore(store, [action]);\n }\n}\n\nconst batchStack = [];\n\nfunction batchStart() {\n const actionsByStore = new Map();\n batchStack.push(actionsByStore);\n return () => {\n for (const [store, actions] of actionsByStore) {\n applyActionsToStore(store, actions);\n }\n\n const popped = batchStack.pop();\n\n if (popped !== actionsByStore) {\n Recoil_recoverableViolation('Incorrect order of batch popping');\n }\n };\n}\n\nfunction copyTreeState(state) {\n return { ...state,\n atomValues: state.atomValues.clone(),\n nonvalidatedAtoms: state.nonvalidatedAtoms.clone(),\n dirtyAtoms: new Set(state.dirtyAtoms)\n };\n}\n\nfunction invalidateDownstreams(store, state) {\n // Inform any nodes that were changed or downstream of changes so that they\n // can clear out any caches as needed due to the update:\n const downstreams = getDownstreamNodes$1(store, state, state.dirtyAtoms);\n\n for (const key of downstreams) {\n var _getNodeMaybe, _getNodeMaybe$invalid;\n\n (_getNodeMaybe = getNodeMaybe$2(key)) === null || _getNodeMaybe === void 0 ? void 0 : (_getNodeMaybe$invalid = _getNodeMaybe.invalidate) === null || _getNodeMaybe$invalid === void 0 ? void 0 : _getNodeMaybe$invalid.call(_getNodeMaybe, state);\n }\n}\n\nfunction setRecoilValue(store, recoilValue, valueOrUpdater) {\n queueOrPerformStateUpdate(store, {\n type: 'set',\n recoilValue,\n valueOrUpdater\n });\n}\n\nfunction setRecoilValueLoadable(store, recoilValue, loadable) {\n if (loadable instanceof DefaultValue$1) {\n return setRecoilValue(store, recoilValue, loadable);\n }\n\n queueOrPerformStateUpdate(store, {\n type: 'setLoadable',\n recoilValue,\n loadable\n });\n}\n\nfunction markRecoilValueModified(store, recoilValue) {\n queueOrPerformStateUpdate(store, {\n type: 'markModified',\n recoilValue\n });\n}\n\nfunction setUnvalidatedRecoilValue(store, recoilValue, unvalidatedValue) {\n queueOrPerformStateUpdate(store, {\n type: 'setUnvalidated',\n recoilValue,\n unvalidatedValue\n });\n}\n\nlet subscriptionID = 0;\n\nfunction subscribeToRecoilValue(store, {\n key\n}, callback, componentDebugName = null) {\n const subID = subscriptionID++;\n const storeState = store.getState();\n\n if (!storeState.nodeToComponentSubscriptions.has(key)) {\n storeState.nodeToComponentSubscriptions.set(key, new Map());\n }\n\n Recoil_nullthrows(storeState.nodeToComponentSubscriptions.get(key)).set(subID, [componentDebugName !== null && componentDebugName !== void 0 ? componentDebugName : '', callback]);\n return {\n release: () => {\n const storeState = store.getState();\n const subs = storeState.nodeToComponentSubscriptions.get(key);\n\n if (subs === undefined || !subs.has(subID)) {\n Recoil_recoverableViolation(`Subscription missing at release time for atom ${key}. This is a bug in Recoil.`);\n return;\n }\n\n subs.delete(subID);\n\n if (subs.size === 0) {\n storeState.nodeToComponentSubscriptions.delete(key);\n }\n }\n };\n}\n\nvar Recoil_RecoilValueInterface = {\n RecoilValueReadOnly: RecoilValueReadOnly$1,\n AbstractRecoilValue: AbstractRecoilValue$1,\n RecoilState: RecoilState$1,\n getRecoilValueAsLoadable,\n setRecoilValue,\n setRecoilValueLoadable,\n markRecoilValueModified,\n setUnvalidatedRecoilValue,\n subscribeToRecoilValue,\n isRecoilValue: isRecoilValue$1,\n applyAtomValueWrites,\n // TODO Remove export when deprecating initialStoreState_DEPRECATED in RecoilRoot\n batchStart,\n invalidateDownstreams_FOR_TESTING: invalidateDownstreams\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n *\n * This is to export esstiential functions from react-dom\n * for our web build\n */\nconst {\n unstable_batchedUpdates\n} = reactDom;\n\nvar ReactBatchedUpdates = {\n unstable_batchedUpdates\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n *\n * This is to export esstiential functions from react-dom\n * for our web build\n */\n// @fb-only: const {unstable_batchedUpdates} = require('ReactDOMComet');\nconst {\n unstable_batchedUpdates: unstable_batchedUpdates$1\n} = ReactBatchedUpdates; // @oss-only\n\n\nvar Recoil_ReactBatchedUpdates = {\n unstable_batchedUpdates: unstable_batchedUpdates$1\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\nconst {\n batchStart: batchStart$1\n} = Recoil_RecoilValueInterface;\n\nconst {\n unstable_batchedUpdates: unstable_batchedUpdates$2\n} = Recoil_ReactBatchedUpdates;\n\nlet batcher = unstable_batchedUpdates$2; // flowlint-next-line unclear-type:off\n\n/**\n * Sets the provided batcher function as the batcher function used by Recoil.\n *\n * Set the batcher to a custom batcher for your renderer,\n * if you use a renderer other than React DOM or React Native.\n */\nconst setBatcher = newBatcher => {\n batcher = newBatcher;\n};\n/**\n * Returns the current batcher function.\n */\n\n\nconst getBatcher = () => batcher;\n/**\n * Calls the current batcher function and passes the\n * provided callback function.\n */\n\n\nconst batchUpdates = callback => {\n batcher(() => {\n let batchEnd = () => undefined;\n\n try {\n batchEnd = batchStart$1();\n callback();\n } finally {\n batchEnd();\n }\n });\n};\n\nvar Recoil_Batching = {\n getBatcher,\n setBatcher,\n batchUpdates\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction enqueueExecution(s, f) {\n f();\n}\n\nvar Recoil_Queue = {\n enqueueExecution\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n/**\n * Returns a set containing all of the values from the first set that are not\n * present in any of the subsequent sets.\n *\n * Note: this is written procedurally (i.e., without filterSet) for performant\n * use in tight loops.\n */\n\nfunction differenceSets(set, ...setsWithValuesToRemove) {\n const ret = new Set();\n\n FIRST: for (const value of set) {\n for (const otherSet of setsWithValuesToRemove) {\n if (otherSet.has(value)) {\n continue FIRST;\n }\n }\n\n ret.add(value);\n }\n\n return ret;\n}\n\nvar Recoil_differenceSets = differenceSets;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n/**\n * Returns a new Map object with the same keys as the original, but with the\n * values replaced with the output of the given callback function.\n */\n\nfunction mapMap(map, callback) {\n const result = new Map();\n map.forEach((value, key) => {\n result.set(key, callback(value, key));\n });\n return result;\n}\n\nvar Recoil_mapMap = mapMap;\n\nfunction graph() {\n return {\n nodeDeps: new Map(),\n nodeToNodeSubscriptions: new Map()\n };\n}\n\nfunction cloneGraph(graph) {\n return {\n nodeDeps: Recoil_mapMap(graph.nodeDeps, s => new Set(s)),\n nodeToNodeSubscriptions: Recoil_mapMap(graph.nodeToNodeSubscriptions, s => new Set(s))\n };\n} // Note that this overwrites the deps of existing nodes, rather than unioning\n// the new deps with the old deps.\n\n\nfunction mergeDependencyMapIntoGraph(deps, graph, // If olderGraph is given then we will not overwrite changes made to the given\n// graph compared with olderGraph:\nolderGraph) {\n const {\n nodeDeps,\n nodeToNodeSubscriptions\n } = graph;\n deps.forEach((upstreams, downstream) => {\n const existingUpstreams = nodeDeps.get(downstream);\n\n if (existingUpstreams && olderGraph && existingUpstreams !== olderGraph.nodeDeps.get(downstream)) {\n return;\n } // Update nodeDeps:\n\n\n nodeDeps.set(downstream, new Set(upstreams)); // Add new deps to nodeToNodeSubscriptions:\n\n const addedUpstreams = existingUpstreams == null ? upstreams : Recoil_differenceSets(upstreams, existingUpstreams);\n addedUpstreams.forEach(upstream => {\n if (!nodeToNodeSubscriptions.has(upstream)) {\n nodeToNodeSubscriptions.set(upstream, new Set());\n }\n\n const existing = Recoil_nullthrows(nodeToNodeSubscriptions.get(upstream));\n existing.add(downstream);\n }); // Remove removed deps from nodeToNodeSubscriptions:\n\n if (existingUpstreams) {\n const removedUpstreams = Recoil_differenceSets(existingUpstreams, upstreams);\n removedUpstreams.forEach(upstream => {\n if (!nodeToNodeSubscriptions.has(upstream)) {\n return;\n }\n\n const existing = Recoil_nullthrows(nodeToNodeSubscriptions.get(upstream));\n existing.delete(downstream);\n\n if (existing.size === 0) {\n nodeToNodeSubscriptions.delete(upstream);\n }\n });\n }\n });\n}\n\nfunction saveDependencyMapToStore(dependencyMap, store, version) {\n var _storeState$nextTree, _storeState$previousT, _storeState$previousT2, _storeState$previousT3;\n\n const storeState = store.getState();\n\n if (!(version === storeState.currentTree.version || version === ((_storeState$nextTree = storeState.nextTree) === null || _storeState$nextTree === void 0 ? void 0 : _storeState$nextTree.version) || version === ((_storeState$previousT = storeState.previousTree) === null || _storeState$previousT === void 0 ? void 0 : _storeState$previousT.version))) {\n Recoil_recoverableViolation('Tried to save dependencies to a discarded tree');\n } // Merge the dependencies discovered into the store's dependency map\n // for the version that was read:\n\n\n const graph = store.getGraph(version);\n mergeDependencyMapIntoGraph(dependencyMap, graph); // If this version is not the latest version, also write these dependencies\n // into later versions if they don't already have their own:\n\n if (version === ((_storeState$previousT2 = storeState.previousTree) === null || _storeState$previousT2 === void 0 ? void 0 : _storeState$previousT2.version)) {\n const currentGraph = store.getGraph(storeState.currentTree.version);\n mergeDependencyMapIntoGraph(dependencyMap, currentGraph, graph);\n }\n\n if (version === ((_storeState$previousT3 = storeState.previousTree) === null || _storeState$previousT3 === void 0 ? void 0 : _storeState$previousT3.version) || version === storeState.currentTree.version) {\n var _storeState$nextTree2;\n\n const nextVersion = (_storeState$nextTree2 = storeState.nextTree) === null || _storeState$nextTree2 === void 0 ? void 0 : _storeState$nextTree2.version;\n\n if (nextVersion !== undefined) {\n const nextGraph = store.getGraph(nextVersion);\n mergeDependencyMapIntoGraph(dependencyMap, nextGraph, graph);\n }\n }\n}\n\nfunction mergeDepsIntoDependencyMap(from, into) {\n from.forEach((upstreamDeps, downstreamNode) => {\n if (!into.has(downstreamNode)) {\n into.set(downstreamNode, new Set());\n }\n\n const deps = Recoil_nullthrows(into.get(downstreamNode));\n upstreamDeps.forEach(dep => deps.add(dep));\n });\n}\n\nfunction addToDependencyMap(downstream, upstream, dependencyMap) {\n if (!dependencyMap.has(downstream)) {\n dependencyMap.set(downstream, new Set());\n }\n\n Recoil_nullthrows(dependencyMap.get(downstream)).add(upstream);\n}\n\nvar Recoil_Graph = {\n addToDependencyMap,\n cloneGraph,\n graph,\n mergeDepsIntoDependencyMap,\n saveDependencyMapToStore\n};\n\nfunction createCommonjsModule(fn, module) {\n\treturn module = { exports: {} }, fn(module, module.exports), module.exports;\n}\n\nvar hamt_1 = createCommonjsModule(function (module) {\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n return typeof obj;\n} : function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n};\n/**\n @fileOverview Hash Array Mapped Trie.\n\n Code based on: https://github.com/exclipy/pdata\n*/\n\n\nvar hamt = {}; // export\n\n/* Configuration\n ******************************************************************************/\n\nvar SIZE = 5;\nvar BUCKET_SIZE = Math.pow(2, SIZE);\nvar MASK = BUCKET_SIZE - 1;\nvar MAX_INDEX_NODE = BUCKET_SIZE / 2;\nvar MIN_ARRAY_NODE = BUCKET_SIZE / 4;\n/*\n ******************************************************************************/\n\nvar nothing = {};\n\nvar constant = function constant(x) {\n return function () {\n return x;\n };\n};\n/**\n Get 32 bit hash of string.\n\n Based on:\n http://stackoverflow.com/questions/7616461/generate-a-hash-from-string-in-javascript-jquery\n*/\n\n\nvar hash = hamt.hash = function (str) {\n var type = typeof str === 'undefined' ? 'undefined' : _typeof(str);\n if (type === 'number') return str;\n if (type !== 'string') str += '';\n var hash = 0;\n\n for (var i = 0, len = str.length; i < len; ++i) {\n var c = str.charCodeAt(i);\n hash = (hash << 5) - hash + c | 0;\n }\n\n return hash;\n};\n/* Bit Ops\n ******************************************************************************/\n\n/**\n Hamming weight.\n\n Taken from: http://jsperf.com/hamming-weight\n*/\n\n\nvar popcount = function popcount(x) {\n x -= x >> 1 & 0x55555555;\n x = (x & 0x33333333) + (x >> 2 & 0x33333333);\n x = x + (x >> 4) & 0x0f0f0f0f;\n x += x >> 8;\n x += x >> 16;\n return x & 0x7f;\n};\n\nvar hashFragment = function hashFragment(shift, h) {\n return h >>> shift & MASK;\n};\n\nvar toBitmap = function toBitmap(x) {\n return 1 << x;\n};\n\nvar fromBitmap = function fromBitmap(bitmap, bit) {\n return popcount(bitmap & bit - 1);\n};\n/* Array Ops\n ******************************************************************************/\n\n/**\n Set a value in an array.\n\n @param mutate Should the input array be mutated?\n @param at Index to change.\n @param v New value\n @param arr Array.\n*/\n\n\nvar arrayUpdate = function arrayUpdate(mutate, at, v, arr) {\n var out = arr;\n\n if (!mutate) {\n var len = arr.length;\n out = new Array(len);\n\n for (var i = 0; i < len; ++i) {\n out[i] = arr[i];\n }\n }\n\n out[at] = v;\n return out;\n};\n/**\n Remove a value from an array.\n\n @param mutate Should the input array be mutated?\n @param at Index to remove.\n @param arr Array.\n*/\n\n\nvar arraySpliceOut = function arraySpliceOut(mutate, at, arr) {\n var newLen = arr.length - 1;\n var i = 0;\n var g = 0;\n var out = arr;\n\n if (mutate) {\n i = g = at;\n } else {\n out = new Array(newLen);\n\n while (i < at) {\n out[g++] = arr[i++];\n }\n }\n\n ++i;\n\n while (i <= newLen) {\n out[g++] = arr[i++];\n }\n\n if (mutate) {\n out.length = newLen;\n }\n\n return out;\n};\n/**\n Insert a value into an array.\n\n @param mutate Should the input array be mutated?\n @param at Index to insert at.\n @param v Value to insert,\n @param arr Array.\n*/\n\n\nvar arraySpliceIn = function arraySpliceIn(mutate, at, v, arr) {\n var len = arr.length;\n\n if (mutate) {\n var _i = len;\n\n while (_i >= at) {\n arr[_i--] = arr[_i];\n }\n\n arr[at] = v;\n return arr;\n }\n\n var i = 0,\n g = 0;\n var out = new Array(len + 1);\n\n while (i < at) {\n out[g++] = arr[i++];\n }\n\n out[at] = v;\n\n while (i < len) {\n out[++g] = arr[i++];\n }\n\n return out;\n};\n/* Node Structures\n ******************************************************************************/\n\n\nvar LEAF = 1;\nvar COLLISION = 2;\nvar INDEX = 3;\nvar ARRAY = 4;\n/**\n Empty node.\n*/\n\nvar empty = {\n __hamt_isEmpty: true\n};\n\nvar isEmptyNode = function isEmptyNode(x) {\n return x === empty || x && x.__hamt_isEmpty;\n};\n/**\n Leaf holding a value.\n\n @member edit Edit of the node.\n @member hash Hash of key.\n @member key Key.\n @member value Value stored.\n*/\n\n\nvar Leaf = function Leaf(edit, hash, key, value) {\n return {\n type: LEAF,\n edit: edit,\n hash: hash,\n key: key,\n value: value,\n _modify: Leaf__modify\n };\n};\n/**\n Leaf holding multiple values with the same hash but different keys.\n\n @member edit Edit of the node.\n @member hash Hash of key.\n @member children Array of collision children node.\n*/\n\n\nvar Collision = function Collision(edit, hash, children) {\n return {\n type: COLLISION,\n edit: edit,\n hash: hash,\n children: children,\n _modify: Collision__modify\n };\n};\n/**\n Internal node with a sparse set of children.\n\n Uses a bitmap and array to pack children.\n\n @member edit Edit of the node.\n @member mask Bitmap that encode the positions of children in the array.\n @member children Array of child nodes.\n*/\n\n\nvar IndexedNode = function IndexedNode(edit, mask, children) {\n return {\n type: INDEX,\n edit: edit,\n mask: mask,\n children: children,\n _modify: IndexedNode__modify\n };\n};\n/**\n Internal node with many children.\n\n @member edit Edit of the node.\n @member size Number of children.\n @member children Array of child nodes.\n*/\n\n\nvar ArrayNode = function ArrayNode(edit, size, children) {\n return {\n type: ARRAY,\n edit: edit,\n size: size,\n children: children,\n _modify: ArrayNode__modify\n };\n};\n/**\n Is `node` a leaf node?\n*/\n\n\nvar isLeaf = function isLeaf(node) {\n return node === empty || node.type === LEAF || node.type === COLLISION;\n};\n/* Internal node operations.\n ******************************************************************************/\n\n/**\n Expand an indexed node into an array node.\n\n @param edit Current edit.\n @param frag Index of added child.\n @param child Added child.\n @param mask Index node mask before child added.\n @param subNodes Index node children before child added.\n*/\n\n\nvar expand = function expand(edit, frag, child, bitmap, subNodes) {\n var arr = [];\n var bit = bitmap;\n var count = 0;\n\n for (var i = 0; bit; ++i) {\n if (bit & 1) arr[i] = subNodes[count++];\n bit >>>= 1;\n }\n\n arr[frag] = child;\n return ArrayNode(edit, count + 1, arr);\n};\n/**\n Collapse an array node into a indexed node.\n\n @param edit Current edit.\n @param count Number of elements in new array.\n @param removed Index of removed element.\n @param elements Array node children before remove.\n*/\n\n\nvar pack = function pack(edit, count, removed, elements) {\n var children = new Array(count - 1);\n var g = 0;\n var bitmap = 0;\n\n for (var i = 0, len = elements.length; i < len; ++i) {\n if (i !== removed) {\n var elem = elements[i];\n\n if (elem && !isEmptyNode(elem)) {\n children[g++] = elem;\n bitmap |= 1 << i;\n }\n }\n }\n\n return IndexedNode(edit, bitmap, children);\n};\n/**\n Merge two leaf nodes.\n\n @param shift Current shift.\n @param h1 Node 1 hash.\n @param n1 Node 1.\n @param h2 Node 2 hash.\n @param n2 Node 2.\n*/\n\n\nvar mergeLeaves = function mergeLeaves(edit, shift, h1, n1, h2, n2) {\n if (h1 === h2) return Collision(edit, h1, [n2, n1]);\n var subH1 = hashFragment(shift, h1);\n var subH2 = hashFragment(shift, h2);\n return IndexedNode(edit, toBitmap(subH1) | toBitmap(subH2), subH1 === subH2 ? [mergeLeaves(edit, shift + SIZE, h1, n1, h2, n2)] : subH1 < subH2 ? [n1, n2] : [n2, n1]);\n};\n/**\n Update an entry in a collision list.\n\n @param mutate Should mutation be used?\n @param edit Current edit.\n @param keyEq Key compare function.\n @param hash Hash of collision.\n @param list Collision list.\n @param f Update function.\n @param k Key to update.\n @param size Size ref.\n*/\n\n\nvar updateCollisionList = function updateCollisionList(mutate, edit, keyEq, h, list, f, k, size) {\n var len = list.length;\n\n for (var i = 0; i < len; ++i) {\n var child = list[i];\n\n if (keyEq(k, child.key)) {\n var value = child.value;\n\n var _newValue = f(value);\n\n if (_newValue === value) return list;\n\n if (_newValue === nothing) {\n --size.value;\n return arraySpliceOut(mutate, i, list);\n }\n\n return arrayUpdate(mutate, i, Leaf(edit, h, k, _newValue), list);\n }\n }\n\n var newValue = f();\n if (newValue === nothing) return list;\n ++size.value;\n return arrayUpdate(mutate, len, Leaf(edit, h, k, newValue), list);\n};\n\nvar canEditNode = function canEditNode(edit, node) {\n return edit === node.edit;\n};\n/* Editing\n ******************************************************************************/\n\n\nvar Leaf__modify = function Leaf__modify(edit, keyEq, shift, f, h, k, size) {\n if (keyEq(k, this.key)) {\n var _v = f(this.value);\n\n if (_v === this.value) return this;else if (_v === nothing) {\n --size.value;\n return empty;\n }\n\n if (canEditNode(edit, this)) {\n this.value = _v;\n return this;\n }\n\n return Leaf(edit, h, k, _v);\n }\n\n var v = f();\n if (v === nothing) return this;\n ++size.value;\n return mergeLeaves(edit, shift, this.hash, this, h, Leaf(edit, h, k, v));\n};\n\nvar Collision__modify = function Collision__modify(edit, keyEq, shift, f, h, k, size) {\n if (h === this.hash) {\n var canEdit = canEditNode(edit, this);\n var list = updateCollisionList(canEdit, edit, keyEq, this.hash, this.children, f, k, size);\n if (list === this.children) return this;\n return list.length > 1 ? Collision(edit, this.hash, list) : list[0]; // collapse single element collision list\n }\n\n var v = f();\n if (v === nothing) return this;\n ++size.value;\n return mergeLeaves(edit, shift, this.hash, this, h, Leaf(edit, h, k, v));\n};\n\nvar IndexedNode__modify = function IndexedNode__modify(edit, keyEq, shift, f, h, k, size) {\n var mask = this.mask;\n var children = this.children;\n var frag = hashFragment(shift, h);\n var bit = toBitmap(frag);\n var indx = fromBitmap(mask, bit);\n var exists = mask & bit;\n var current = exists ? children[indx] : empty;\n\n var child = current._modify(edit, keyEq, shift + SIZE, f, h, k, size);\n\n if (current === child) return this;\n var canEdit = canEditNode(edit, this);\n var bitmap = mask;\n var newChildren = void 0;\n\n if (exists && isEmptyNode(child)) {\n // remove\n bitmap &= ~bit;\n if (!bitmap) return empty;\n if (children.length <= 2 && isLeaf(children[indx ^ 1])) return children[indx ^ 1]; // collapse\n\n newChildren = arraySpliceOut(canEdit, indx, children);\n } else if (!exists && !isEmptyNode(child)) {\n // add\n if (children.length >= MAX_INDEX_NODE) return expand(edit, frag, child, mask, children);\n bitmap |= bit;\n newChildren = arraySpliceIn(canEdit, indx, child, children);\n } else {\n // modify\n newChildren = arrayUpdate(canEdit, indx, child, children);\n }\n\n if (canEdit) {\n this.mask = bitmap;\n this.children = newChildren;\n return this;\n }\n\n return IndexedNode(edit, bitmap, newChildren);\n};\n\nvar ArrayNode__modify = function ArrayNode__modify(edit, keyEq, shift, f, h, k, size) {\n var count = this.size;\n var children = this.children;\n var frag = hashFragment(shift, h);\n var child = children[frag];\n\n var newChild = (child || empty)._modify(edit, keyEq, shift + SIZE, f, h, k, size);\n\n if (child === newChild) return this;\n var canEdit = canEditNode(edit, this);\n var newChildren = void 0;\n\n if (isEmptyNode(child) && !isEmptyNode(newChild)) {\n // add\n ++count;\n newChildren = arrayUpdate(canEdit, frag, newChild, children);\n } else if (!isEmptyNode(child) && isEmptyNode(newChild)) {\n // remove\n --count;\n if (count <= MIN_ARRAY_NODE) return pack(edit, count, frag, children);\n newChildren = arrayUpdate(canEdit, frag, empty, children);\n } else {\n // modify\n newChildren = arrayUpdate(canEdit, frag, newChild, children);\n }\n\n if (canEdit) {\n this.size = count;\n this.children = newChildren;\n return this;\n }\n\n return ArrayNode(edit, count, newChildren);\n};\n\nempty._modify = function (edit, keyEq, shift, f, h, k, size) {\n var v = f();\n if (v === nothing) return empty;\n ++size.value;\n return Leaf(edit, h, k, v);\n};\n/*\n ******************************************************************************/\n\n\nfunction Map(editable, edit, config, root, size) {\n this._editable = editable;\n this._edit = edit;\n this._config = config;\n this._root = root;\n this._size = size;\n}\n\nMap.prototype.setTree = function (newRoot, newSize) {\n if (this._editable) {\n this._root = newRoot;\n this._size = newSize;\n return this;\n }\n\n return newRoot === this._root ? this : new Map(this._editable, this._edit, this._config, newRoot, newSize);\n};\n/* Queries\n ******************************************************************************/\n\n/**\n Lookup the value for `key` in `map` using a custom `hash`.\n\n Returns the value or `alt` if none.\n*/\n\n\nvar tryGetHash = hamt.tryGetHash = function (alt, hash, key, map) {\n var node = map._root;\n var shift = 0;\n var keyEq = map._config.keyEq;\n\n while (true) {\n switch (node.type) {\n case LEAF:\n {\n return keyEq(key, node.key) ? node.value : alt;\n }\n\n case COLLISION:\n {\n if (hash === node.hash) {\n var children = node.children;\n\n for (var i = 0, len = children.length; i < len; ++i) {\n var child = children[i];\n if (keyEq(key, child.key)) return child.value;\n }\n }\n\n return alt;\n }\n\n case INDEX:\n {\n var frag = hashFragment(shift, hash);\n var bit = toBitmap(frag);\n\n if (node.mask & bit) {\n node = node.children[fromBitmap(node.mask, bit)];\n shift += SIZE;\n break;\n }\n\n return alt;\n }\n\n case ARRAY:\n {\n node = node.children[hashFragment(shift, hash)];\n\n if (node) {\n shift += SIZE;\n break;\n }\n\n return alt;\n }\n\n default:\n return alt;\n }\n }\n};\n\nMap.prototype.tryGetHash = function (alt, hash, key) {\n return tryGetHash(alt, hash, key, this);\n};\n/**\n Lookup the value for `key` in `map` using internal hash function.\n\n @see `tryGetHash`\n*/\n\n\nvar tryGet = hamt.tryGet = function (alt, key, map) {\n return tryGetHash(alt, map._config.hash(key), key, map);\n};\n\nMap.prototype.tryGet = function (alt, key) {\n return tryGet(alt, key, this);\n};\n/**\n Lookup the value for `key` in `map` using a custom `hash`.\n\n Returns the value or `undefined` if none.\n*/\n\n\nvar getHash = hamt.getHash = function (hash, key, map) {\n return tryGetHash(undefined, hash, key, map);\n};\n\nMap.prototype.getHash = function (hash, key) {\n return getHash(hash, key, this);\n};\n/**\n Lookup the value for `key` in `map` using internal hash function.\n\n @see `get`\n*/\n\n\nvar get = hamt.get = function (key, map) {\n return tryGetHash(undefined, map._config.hash(key), key, map);\n};\n\nMap.prototype.get = function (key, alt) {\n return tryGet(alt, key, this);\n};\n/**\n Does an entry exist for `key` in `map`? Uses custom `hash`.\n*/\n\n\nvar hasHash = hamt.has = function (hash, key, map) {\n return tryGetHash(nothing, hash, key, map) !== nothing;\n};\n\nMap.prototype.hasHash = function (hash, key) {\n return hasHash(hash, key, this);\n};\n/**\n Does an entry exist for `key` in `map`? Uses internal hash function.\n*/\n\n\nvar has = hamt.has = function (key, map) {\n return hasHash(map._config.hash(key), key, map);\n};\n\nMap.prototype.has = function (key) {\n return has(key, this);\n};\n\nvar defKeyCompare = function defKeyCompare(x, y) {\n return x === y;\n};\n/**\n Create an empty map.\n\n @param config Configuration.\n*/\n\n\nhamt.make = function (config) {\n return new Map(0, 0, {\n keyEq: config && config.keyEq || defKeyCompare,\n hash: config && config.hash || hash\n }, empty, 0);\n};\n/**\n Empty map.\n*/\n\n\nhamt.empty = hamt.make();\n/**\n Does `map` contain any elements?\n*/\n\nvar isEmpty = hamt.isEmpty = function (map) {\n return map && !!isEmptyNode(map._root);\n};\n\nMap.prototype.isEmpty = function () {\n return isEmpty(this);\n};\n/* Updates\n ******************************************************************************/\n\n/**\n Alter the value stored for `key` in `map` using function `f` using\n custom hash.\n\n `f` is invoked with the current value for `k` if it exists,\n or no arguments if no such value exists. `modify` will always either\n update or insert a value into the map.\n\n Returns a map with the modified value. Does not alter `map`.\n*/\n\n\nvar modifyHash = hamt.modifyHash = function (f, hash, key, map) {\n var size = {\n value: map._size\n };\n\n var newRoot = map._root._modify(map._editable ? map._edit : NaN, map._config.keyEq, 0, f, hash, key, size);\n\n return map.setTree(newRoot, size.value);\n};\n\nMap.prototype.modifyHash = function (hash, key, f) {\n return modifyHash(f, hash, key, this);\n};\n/**\n Alter the value stored for `key` in `map` using function `f` using\n internal hash function.\n\n @see `modifyHash`\n*/\n\n\nvar modify = hamt.modify = function (f, key, map) {\n return modifyHash(f, map._config.hash(key), key, map);\n};\n\nMap.prototype.modify = function (key, f) {\n return modify(f, key, this);\n};\n/**\n Store `value` for `key` in `map` using custom `hash`.\n\n Returns a map with the modified value. Does not alter `map`.\n*/\n\n\nvar setHash = hamt.setHash = function (hash, key, value, map) {\n return modifyHash(constant(value), hash, key, map);\n};\n\nMap.prototype.setHash = function (hash, key, value) {\n return setHash(hash, key, value, this);\n};\n/**\n Store `value` for `key` in `map` using internal hash function.\n\n @see `setHash`\n*/\n\n\nvar set = hamt.set = function (key, value, map) {\n return setHash(map._config.hash(key), key, value, map);\n};\n\nMap.prototype.set = function (key, value) {\n return set(key, value, this);\n};\n/**\n Remove the entry for `key` in `map`.\n\n Returns a map with the value removed. Does not alter `map`.\n*/\n\n\nvar del = constant(nothing);\n\nvar removeHash = hamt.removeHash = function (hash, key, map) {\n return modifyHash(del, hash, key, map);\n};\n\nMap.prototype.removeHash = Map.prototype.deleteHash = function (hash, key) {\n return removeHash(hash, key, this);\n};\n/**\n Remove the entry for `key` in `map` using internal hash function.\n\n @see `removeHash`\n*/\n\n\nvar remove = hamt.remove = function (key, map) {\n return removeHash(map._config.hash(key), key, map);\n};\n\nMap.prototype.remove = Map.prototype.delete = function (key) {\n return remove(key, this);\n};\n/* Mutation\n ******************************************************************************/\n\n/**\n Mark `map` as mutable.\n */\n\n\nvar beginMutation = hamt.beginMutation = function (map) {\n return new Map(map._editable + 1, map._edit + 1, map._config, map._root, map._size);\n};\n\nMap.prototype.beginMutation = function () {\n return beginMutation(this);\n};\n/**\n Mark `map` as immutable.\n */\n\n\nvar endMutation = hamt.endMutation = function (map) {\n map._editable = map._editable && map._editable - 1;\n return map;\n};\n\nMap.prototype.endMutation = function () {\n return endMutation(this);\n};\n/**\n Mutate `map` within the context of `f`.\n @param f\n @param map HAMT\n*/\n\n\nvar mutate = hamt.mutate = function (f, map) {\n var transient = beginMutation(map);\n f(transient);\n return endMutation(transient);\n};\n\nMap.prototype.mutate = function (f) {\n return mutate(f, this);\n};\n/* Traversal\n ******************************************************************************/\n\n/**\n Apply a continuation.\n*/\n\n\nvar appk = function appk(k) {\n return k && lazyVisitChildren(k[0], k[1], k[2], k[3], k[4]);\n};\n/**\n Recursively visit all values stored in an array of nodes lazily.\n*/\n\n\nvar lazyVisitChildren = function lazyVisitChildren(len, children, i, f, k) {\n while (i < len) {\n var child = children[i++];\n if (child && !isEmptyNode(child)) return lazyVisit(child, f, [len, children, i, f, k]);\n }\n\n return appk(k);\n};\n/**\n Recursively visit all values stored in `node` lazily.\n*/\n\n\nvar lazyVisit = function lazyVisit(node, f, k) {\n switch (node.type) {\n case LEAF:\n return {\n value: f(node),\n rest: k\n };\n\n case COLLISION:\n case ARRAY:\n case INDEX:\n var children = node.children;\n return lazyVisitChildren(children.length, children, 0, f, k);\n\n default:\n return appk(k);\n }\n};\n\nvar DONE = {\n done: true\n};\n/**\n Javascript iterator over a map.\n*/\n\nfunction MapIterator(v) {\n this.v = v;\n}\n\nMapIterator.prototype.next = function () {\n if (!this.v) return DONE;\n var v0 = this.v;\n this.v = appk(v0.rest);\n return v0;\n};\n\nMapIterator.prototype[Symbol.iterator] = function () {\n return this;\n};\n/**\n Lazily visit each value in map with function `f`.\n*/\n\n\nvar visit = function visit(map, f) {\n return new MapIterator(lazyVisit(map._root, f));\n};\n/**\n Get a Javascsript iterator of `map`.\n\n Iterates over `[key, value]` arrays.\n*/\n\n\nvar buildPairs = function buildPairs(x) {\n return [x.key, x.value];\n};\n\nvar entries = hamt.entries = function (map) {\n return visit(map, buildPairs);\n};\n\nMap.prototype.entries = Map.prototype[Symbol.iterator] = function () {\n return entries(this);\n};\n/**\n Get array of all keys in `map`.\n\n Order is not guaranteed.\n*/\n\n\nvar buildKeys = function buildKeys(x) {\n return x.key;\n};\n\nvar keys = hamt.keys = function (map) {\n return visit(map, buildKeys);\n};\n\nMap.prototype.keys = function () {\n return keys(this);\n};\n/**\n Get array of all values in `map`.\n\n Order is not guaranteed, duplicates are preserved.\n*/\n\n\nvar buildValues = function buildValues(x) {\n return x.value;\n};\n\nvar values = hamt.values = Map.prototype.values = function (map) {\n return visit(map, buildValues);\n};\n\nMap.prototype.values = function () {\n return values(this);\n};\n/* Fold\n ******************************************************************************/\n\n/**\n Visit every entry in the map, aggregating data.\n\n Order of nodes is not guaranteed.\n\n @param f Function mapping accumulated value, value, and key to new value.\n @param z Starting value.\n @param m HAMT\n*/\n\n\nvar fold = hamt.fold = function (f, z, m) {\n var root = m._root;\n if (root.type === LEAF) return f(z, root.value, root.key);\n var toVisit = [root.children];\n var children = void 0;\n\n while (children = toVisit.pop()) {\n for (var i = 0, len = children.length; i < len;) {\n var child = children[i++];\n\n if (child && child.type) {\n if (child.type === LEAF) z = f(z, child.value, child.key);else toVisit.push(child.children);\n }\n }\n }\n\n return z;\n};\n\nMap.prototype.fold = function (f, z) {\n return fold(f, z, this);\n};\n/**\n Visit every entry in the map, aggregating data.\n\n Order of nodes is not guaranteed.\n\n @param f Function invoked with value and key\n @param map HAMT\n*/\n\n\nvar forEach = hamt.forEach = function (f, map) {\n return fold(function (_, value, key) {\n return f(value, key, map);\n }, null, map);\n};\n\nMap.prototype.forEach = function (f) {\n return forEach(f, this);\n};\n/* Aggregate\n ******************************************************************************/\n\n/**\n Get the number of entries in `map`.\n*/\n\n\nvar count = hamt.count = function (map) {\n return map._size;\n};\n\nMap.prototype.count = function () {\n return count(this);\n};\n\nObject.defineProperty(Map.prototype, 'size', {\n get: Map.prototype.count\n});\n/* Export\n ******************************************************************************/\n\nif ( module.exports) {\n module.exports = hamt;\n} else {\n undefined.hamt = hamt;\n}\n});\n\nclass BuiltInMap {\n constructor(existing) {\n _defineProperty(this, \"_map\", void 0);\n\n this._map = new Map(existing === null || existing === void 0 ? void 0 : existing.entries());\n }\n\n keys() {\n return this._map.keys();\n }\n\n entries() {\n return this._map.entries();\n }\n\n get(k) {\n return this._map.get(k);\n }\n\n has(k) {\n return this._map.has(k);\n }\n\n set(k, v) {\n this._map.set(k, v);\n\n return this;\n }\n\n delete(k) {\n this._map.delete(k);\n\n return this;\n }\n\n clone() {\n return persistentMap(this);\n }\n\n toMap() {\n return new Map(this._map);\n }\n\n}\n\nclass HashArrayMappedTrieMap {\n // Because hamt.empty is not a function there is no way to introduce type\n // parameters on it, so empty is typed as HAMTPlusMap.\n // flowlint-next-line unclear-type:off\n constructor(existing) {\n _defineProperty(this, \"_hamt\", hamt_1.empty.beginMutation());\n\n if (existing instanceof HashArrayMappedTrieMap) {\n const h = existing._hamt.endMutation();\n\n existing._hamt = h.beginMutation();\n this._hamt = h.beginMutation();\n } else if (existing) {\n for (const [k, v] of existing.entries()) {\n this._hamt.set(k, v);\n }\n }\n }\n\n keys() {\n return this._hamt.keys();\n }\n\n entries() {\n return this._hamt.entries();\n }\n\n get(k) {\n return this._hamt.get(k);\n }\n\n has(k) {\n return this._hamt.has(k);\n }\n\n set(k, v) {\n this._hamt.set(k, v);\n\n return this;\n }\n\n delete(k) {\n this._hamt.delete(k);\n\n return this;\n }\n\n clone() {\n return persistentMap(this);\n }\n\n toMap() {\n return new Map(this._hamt);\n }\n\n}\n\nfunction persistentMap(existing) {\n if (Recoil_gkx_1('recoil_hamt_2020')) {\n return new HashArrayMappedTrieMap(existing);\n } else {\n return new BuiltInMap(existing);\n }\n}\n\nvar Recoil_PersistentMap = {\n persistentMap\n};\n\nvar Recoil_PersistentMap_1 = Recoil_PersistentMap.persistentMap;\n\nvar Recoil_PersistentMap$1 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n persistentMap: Recoil_PersistentMap_1\n});\n\nconst {\n graph: graph$1\n} = Recoil_Graph;\n\nconst {\n persistentMap: persistentMap$1\n} = Recoil_PersistentMap$1; // flowlint-next-line unclear-type:off\n\n\nlet nextTreeStateVersion = 0;\n\nconst getNextTreeStateVersion = () => nextTreeStateVersion++;\n\nfunction makeEmptyTreeState() {\n const version = getNextTreeStateVersion();\n return {\n version,\n stateID: version,\n transactionMetadata: {},\n dirtyAtoms: new Set(),\n atomValues: persistentMap$1(),\n nonvalidatedAtoms: persistentMap$1()\n };\n}\n\nfunction makeEmptyStoreState() {\n const currentTree = makeEmptyTreeState();\n return {\n currentTree,\n nextTree: null,\n previousTree: null,\n knownAtoms: new Set(),\n knownSelectors: new Set(),\n transactionSubscriptions: new Map(),\n nodeTransactionSubscriptions: new Map(),\n nodeToComponentSubscriptions: new Map(),\n queuedComponentCallbacks_DEPRECATED: [],\n suspendedComponentResolvers: new Set(),\n graphsByVersion: new Map().set(currentTree.version, graph$1()),\n versionsUsedByComponent: new Map(),\n retention: {\n referenceCounts: new Map(),\n nodesRetainedByZone: new Map(),\n retainablesToCheckForRelease: new Set()\n },\n nodeCleanupFunctions: new Map()\n };\n}\n\nvar Recoil_State = {\n makeEmptyTreeState,\n makeEmptyStoreState,\n getNextTreeStateVersion\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction unionSets(...sets) {\n const result = new Set();\n\n for (const set of sets) {\n for (const value of set) {\n result.add(value);\n }\n }\n\n return result;\n}\n\nvar Recoil_unionSets = unionSets;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n/**\n * The someSet() method tests whether some elements in the given Set pass the\n * test implemented by the provided function.\n */\n\nfunction someSet(set, callback, context) {\n const iterator = set.entries();\n let current = iterator.next();\n\n while (!current.done) {\n const entry = current.value;\n\n if (callback.call(context, entry[1], entry[0], set)) {\n return true;\n }\n\n current = iterator.next();\n }\n\n return false;\n}\n\nvar Recoil_someSet = someSet;\n\nconst {\n cleanUpNode: cleanUpNode$1\n} = Recoil_FunctionalCore;\n\nconst {\n deleteNodeConfigIfPossible: deleteNodeConfigIfPossible$1,\n getNode: getNode$2\n} = Recoil_Node;\n\nconst {\n RetentionZone: RetentionZone$2\n} = Recoil_RetentionZone;\n\nconst emptySet$1 = new Set();\n\nfunction releaseRetainablesNowOnCurrentTree(store, retainables) {\n const storeState = store.getState();\n const treeState = storeState.currentTree;\n\n if (storeState.nextTree) {\n Recoil_recoverableViolation('releaseNodesNowOnCurrentTree should only be called at the end of a batch');\n return; // leak memory rather than erase something that's about to be used.\n }\n\n const nodes = new Set();\n\n for (const r of retainables) {\n if (r instanceof RetentionZone$2) {\n for (const n of nodesRetainedByZone(storeState, r)) {\n nodes.add(n);\n }\n } else {\n nodes.add(r);\n }\n }\n\n const releasableNodes = findReleasableNodes(store, nodes);\n\n for (const node of releasableNodes) {\n releaseNode(store, treeState, node);\n }\n}\n\nfunction findReleasableNodes(store, searchFromNodes) {\n const storeState = store.getState();\n const treeState = storeState.currentTree;\n const graph = store.getGraph(treeState.version);\n const releasableNodes = new Set(); // mutated to collect answer\n\n const nonReleasableNodes = new Set();\n findReleasableNodesInner(searchFromNodes);\n return releasableNodes;\n\n function findReleasableNodesInner(searchFromNodes) {\n const releasableNodesFoundThisIteration = new Set();\n const downstreams = getDownstreamNodesInTopologicalOrder(store, treeState, searchFromNodes, releasableNodes, // don't descend into these\n nonReleasableNodes // don't descend into these\n ); // Find which of the downstream nodes are releasable and which are not:\n\n for (const node of downstreams) {\n var _storeState$retention;\n\n // Not releasable if configured to be retained forever:\n if (getNode$2(node).retainedBy === 'recoilRoot') {\n nonReleasableNodes.add(node);\n continue;\n } // Not releasable if retained directly by a component:\n\n\n if (((_storeState$retention = storeState.retention.referenceCounts.get(node)) !== null && _storeState$retention !== void 0 ? _storeState$retention : 0) > 0) {\n nonReleasableNodes.add(node);\n continue;\n } // Not releasable if retained by a zone:\n\n\n if (zonesThatCouldRetainNode(node).some(z => storeState.retention.referenceCounts.get(z))) {\n nonReleasableNodes.add(node);\n continue;\n } // Not releasable if it has a non-releasable child (which will already be in\n // nonReleasableNodes because we are going in topological order):\n\n\n const nodeChildren = graph.nodeToNodeSubscriptions.get(node);\n\n if (nodeChildren && Recoil_someSet(nodeChildren, child => nonReleasableNodes.has(child))) {\n nonReleasableNodes.add(node);\n continue;\n }\n\n releasableNodes.add(node);\n releasableNodesFoundThisIteration.add(node);\n } // If we found any releasable nodes, we need to walk UP from those nodes to\n // find whether their parents can now be released as well:\n\n\n const parents = new Set();\n\n for (const node of releasableNodesFoundThisIteration) {\n for (const parent of (_graph$nodeDeps$get = graph.nodeDeps.get(node)) !== null && _graph$nodeDeps$get !== void 0 ? _graph$nodeDeps$get : emptySet$1) {\n var _graph$nodeDeps$get;\n\n if (!releasableNodes.has(parent)) {\n parents.add(parent);\n }\n }\n }\n\n if (parents.size) {\n findReleasableNodesInner(parents);\n }\n }\n} // Children before parents\n\n\nfunction getDownstreamNodesInTopologicalOrder(store, treeState, nodes, // Mutable set is destroyed in place\ndoNotDescendInto1, doNotDescendInto2) {\n const graph = store.getGraph(treeState.version);\n const answer = [];\n const visited = new Set();\n\n while (nodes.size > 0) {\n visit(Recoil_nullthrows(nodes.values().next().value));\n }\n\n return answer;\n\n function visit(node) {\n if (doNotDescendInto1.has(node) || doNotDescendInto2.has(node)) {\n nodes.delete(node);\n return;\n }\n\n if (visited.has(node)) {\n return;\n }\n\n const children = graph.nodeToNodeSubscriptions.get(node);\n\n if (children) {\n for (const child of children) {\n visit(child);\n }\n }\n\n visited.add(node);\n nodes.delete(node);\n answer.push(node);\n }\n}\n\nfunction releaseNode(store, treeState, node) {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n } // Atom effects, in-closure caches, etc.:\n\n\n cleanUpNode$1(store, node); // Delete from store state:\n\n const storeState = store.getState();\n storeState.knownAtoms.delete(node);\n storeState.knownSelectors.delete(node);\n storeState.nodeTransactionSubscriptions.delete(node);\n storeState.retention.referenceCounts.delete(node);\n const zones = zonesThatCouldRetainNode(node);\n\n for (const zone of zones) {\n var _storeState$retention2;\n\n (_storeState$retention2 = storeState.retention.nodesRetainedByZone.get(zone)) === null || _storeState$retention2 === void 0 ? void 0 : _storeState$retention2.delete(node);\n } // Note that we DO NOT delete from nodeToComponentSubscriptions because this\n // already happens when the last component that was retaining the node unmounts,\n // and this could happen either before or after that.\n // Delete from TreeState and dep graph:\n\n\n treeState.atomValues.delete(node);\n treeState.dirtyAtoms.delete(node);\n treeState.nonvalidatedAtoms.delete(node);\n const graph = storeState.graphsByVersion.get(treeState.version);\n\n if (graph) {\n const deps = graph.nodeDeps.get(node);\n\n if (deps !== undefined) {\n graph.nodeDeps.delete(node);\n\n for (const dep of deps) {\n var _graph$nodeToNodeSubs;\n\n (_graph$nodeToNodeSubs = graph.nodeToNodeSubscriptions.get(dep)) === null || _graph$nodeToNodeSubs === void 0 ? void 0 : _graph$nodeToNodeSubs.delete(node);\n }\n } // No need to delete sub's deps as there should be no subs at this point.\n // But an invariant would require deleting nodes in topological order.\n\n\n graph.nodeToNodeSubscriptions.delete(node);\n } // Node config (for family members only as their configs can be recreated, and\n // only if they are not retained within any other Stores):\n\n\n deleteNodeConfigIfPossible$1(node);\n}\n\nfunction nodesRetainedByZone(storeState, zone) {\n var _storeState$retention3;\n\n return (_storeState$retention3 = storeState.retention.nodesRetainedByZone.get(zone)) !== null && _storeState$retention3 !== void 0 ? _storeState$retention3 : emptySet$1;\n}\n\nfunction zonesThatCouldRetainNode(node) {\n const retainedBy = getNode$2(node).retainedBy;\n\n if (retainedBy === undefined || retainedBy === 'components' || retainedBy === 'recoilRoot') {\n return [];\n } else if (retainedBy instanceof RetentionZone$2) {\n return [retainedBy];\n } else {\n return retainedBy; // it's an array of zones\n }\n}\n\nfunction scheduleOrPerformPossibleReleaseOfRetainable(store, retainable) {\n const state = store.getState();\n\n if (state.nextTree) {\n state.retention.retainablesToCheckForRelease.add(retainable);\n } else {\n releaseRetainablesNowOnCurrentTree(store, new Set([retainable]));\n }\n}\n\nfunction updateRetainCount(store, retainable, delta) {\n var _map$get;\n\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n }\n\n const map = store.getState().retention.referenceCounts;\n const newCount = ((_map$get = map.get(retainable)) !== null && _map$get !== void 0 ? _map$get : 0) + delta;\n\n if (newCount === 0) {\n map.delete(retainable);\n scheduleOrPerformPossibleReleaseOfRetainable(store, retainable);\n } else {\n map.set(retainable, newCount);\n }\n}\n\nfunction releaseScheduledRetainablesNow(store) {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n }\n\n const state = store.getState();\n releaseRetainablesNowOnCurrentTree(store, state.retention.retainablesToCheckForRelease);\n state.retention.retainablesToCheckForRelease.clear();\n}\n\nfunction retainedByOptionWithDefault(r) {\n // The default will change from 'recoilRoot' to 'components' in the future.\n return r === undefined ? 'recoilRoot' : r;\n}\n\nvar Recoil_Retention = {\n updateRetainCount,\n releaseScheduledRetainablesNow,\n retainedByOptionWithDefault\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n/**\n * Combines multiple Iterables into a single Iterable.\n * Traverses the input Iterables in the order provided and maintains the order\n * of their elements.\n *\n * Example:\n * ```\n * const r = Array.from(concatIterables(['a', 'b'], ['c'], ['d', 'e', 'f']));\n * r == ['a', 'b', 'c', 'd', 'e', 'f'];\n * ```\n */\n\nfunction* concatIterables(iters) {\n for (const iter of iters) {\n for (const val of iter) {\n yield val;\n }\n }\n}\n\nvar Recoil_concatIterables = concatIterables;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nconst isSSR = typeof window === 'undefined';\nconst isReactNative = typeof navigator !== 'undefined' && navigator.product === 'ReactNative'; // eslint-disable-line fb-www/typeof-undefined\n\nvar Recoil_Environment = {\n isSSR,\n isReactNative\n};\n\nconst {\n isSSR: isSSR$1\n} = Recoil_Environment;\n\n\n\n\n\n\n\n\n\nconst {\n batchUpdates: batchUpdates$1\n} = Recoil_Batching;\n\nconst {\n initializeNodeIfNewToStore: initializeNodeIfNewToStore$1,\n peekNodeInfo: peekNodeInfo$1\n} = Recoil_FunctionalCore;\n\nconst {\n graph: graph$2\n} = Recoil_Graph;\n\nconst {\n DEFAULT_VALUE: DEFAULT_VALUE$1,\n recoilValues: recoilValues$1,\n recoilValuesForKeys: recoilValuesForKeys$2\n} = Recoil_Node;\n\nconst {\n AbstractRecoilValue: AbstractRecoilValue$2,\n getRecoilValueAsLoadable: getRecoilValueAsLoadable$1,\n setRecoilValue: setRecoilValue$1,\n setUnvalidatedRecoilValue: setUnvalidatedRecoilValue$1\n} = Recoil_RecoilValueInterface;\n\nconst {\n getNextTreeStateVersion: getNextTreeStateVersion$1,\n makeEmptyStoreState: makeEmptyStoreState$1\n} = Recoil_State; // Opaque at this surface because it's part of the public API from here.\n\n\n// A \"Snapshot\" is \"read-only\" and captures a specific set of values of atoms.\n// However, the data-flow-graph and selector values may evolve as selector\n// evaluation functions are executed and async selectors resolve.\nclass Snapshot {\n constructor(storeState) {\n _defineProperty(this, \"_store\", void 0);\n\n _defineProperty(this, \"_refCount\", 0);\n\n _defineProperty(this, \"getLoadable\", recoilValue => {\n this.checkRefCount_INTERNAL();\n return getRecoilValueAsLoadable$1(this._store, recoilValue);\n });\n\n _defineProperty(this, \"getPromise\", recoilValue => {\n this.checkRefCount_INTERNAL();\n return this.getLoadable(recoilValue).toPromise();\n });\n\n _defineProperty(this, \"getNodes_UNSTABLE\", opt => {\n this.checkRefCount_INTERNAL(); // TODO Deal with modified selectors\n\n if ((opt === null || opt === void 0 ? void 0 : opt.isModified) === true) {\n if ((opt === null || opt === void 0 ? void 0 : opt.isInitialized) === false) {\n return [];\n }\n\n const state = this._store.getState().currentTree;\n\n return recoilValuesForKeys$2(state.dirtyAtoms);\n }\n\n const knownAtoms = this._store.getState().knownAtoms;\n\n const knownSelectors = this._store.getState().knownSelectors;\n\n return (opt === null || opt === void 0 ? void 0 : opt.isInitialized) == null ? recoilValues$1.values() : opt.isInitialized === true ? recoilValuesForKeys$2(Recoil_concatIterables([this._store.getState().knownAtoms, this._store.getState().knownSelectors])) : Recoil_filterIterable(recoilValues$1.values(), ({\n key\n }) => !knownAtoms.has(key) && !knownSelectors.has(key));\n });\n\n _defineProperty(this, \"getInfo_UNSTABLE\", ({\n key\n }) => {\n this.checkRefCount_INTERNAL();\n return peekNodeInfo$1(this._store, this._store.getState().currentTree, key);\n });\n\n _defineProperty(this, \"map\", mapper => {\n this.checkRefCount_INTERNAL();\n const mutableSnapshot = new MutableSnapshot(this);\n mapper(mutableSnapshot); // if removing batchUpdates from `set` add it here\n\n return cloneSnapshot(mutableSnapshot.getStore_INTERNAL());\n });\n\n _defineProperty(this, \"asyncMap\", async mapper => {\n this.checkRefCount_INTERNAL();\n const mutableSnapshot = new MutableSnapshot(this);\n await mapper(mutableSnapshot);\n return cloneSnapshot(mutableSnapshot.getStore_INTERNAL());\n });\n\n this._store = {\n getState: () => storeState,\n replaceState: replacer => {\n storeState.currentTree = replacer(storeState.currentTree); // no batching so nextTree is never active\n },\n getGraph: version => {\n const graphs = storeState.graphsByVersion;\n\n if (graphs.has(version)) {\n return Recoil_nullthrows(graphs.get(version));\n }\n\n const newGraph = graph$2();\n graphs.set(version, newGraph);\n return newGraph;\n },\n subscribeToTransactions: () => ({\n release: () => {}\n }),\n addTransactionMetadata: () => {\n throw new Error('Cannot subscribe to Snapshots');\n }\n }; // Initialize any nodes that are live in the parent store (primarily so that this\n // snapshot gets counted towards the node's live stores count).\n\n for (const nodeKey of this._store.getState().nodeCleanupFunctions.keys()) {\n initializeNodeIfNewToStore$1(this._store, storeState.currentTree, nodeKey, 'get');\n }\n\n this.retain();\n this.autorelease();\n }\n\n retain() {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return () => undefined;\n }\n\n this._refCount++;\n let released = false;\n return () => {\n if (!released) {\n released = true;\n this.release();\n }\n };\n }\n\n autorelease() {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n }\n\n if (!isSSR$1) {\n window.setTimeout(() => this.release(), 0);\n }\n }\n\n release() {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n }\n\n this._refCount--;\n\n if (this._refCount === 0) ;\n }\n\n checkRefCount_INTERNAL() {\n if (Recoil_gkx_1('recoil_memory_managament_2020') && this._refCount <= 0) {\n if (process.env.NODE_ENV !== \"production\") {\n Recoil_recoverableViolation('Recoil Snapshots only last for the duration of the callback they are provided to. To keep a Snapshot longer, call its retain() method (and then call release() when you are done with it). This is currently a DEV-only warning but will become a real error soon. Please reach out to Dave McCabe for help fixing this. To temporarily suppress this warning add gk_disable=recoil_memory_managament_2020 to the URL.');\n } // What we will ship later:\n // throw new Error(\n // 'Recoil Snapshots only last for the duration of the callback they are provided to. To keep a Snapshot longer, call its retain() method (and then call release() when you are done with it).',\n // );\n\n }\n }\n\n getStore_INTERNAL() {\n this.checkRefCount_INTERNAL();\n return this._store;\n }\n\n getID() {\n this.checkRefCount_INTERNAL();\n return this.getID_INTERNAL();\n }\n\n getID_INTERNAL() {\n this.checkRefCount_INTERNAL();\n return this._store.getState().currentTree.stateID;\n } // We want to allow the methods to be destructured and used as accessors\n // eslint-disable-next-line fb-www/extra-arrow-initializer\n\n\n}\n\nfunction cloneStoreState(store, treeState, bumpVersion = false) {\n const storeState = store.getState();\n const version = bumpVersion ? getNextTreeStateVersion$1() : treeState.version;\n return {\n currentTree: bumpVersion ? {\n // TODO snapshots shouldn't really have versions because a new version number\n // is always assigned when the snapshot is gone to.\n version,\n stateID: version,\n transactionMetadata: { ...treeState.transactionMetadata\n },\n dirtyAtoms: new Set(treeState.dirtyAtoms),\n atomValues: treeState.atomValues.clone(),\n nonvalidatedAtoms: treeState.nonvalidatedAtoms.clone()\n } : treeState,\n nextTree: null,\n previousTree: null,\n knownAtoms: new Set(storeState.knownAtoms),\n // FIXME here's a copy\n knownSelectors: new Set(storeState.knownSelectors),\n // FIXME here's a copy\n transactionSubscriptions: new Map(),\n nodeTransactionSubscriptions: new Map(),\n nodeToComponentSubscriptions: new Map(),\n queuedComponentCallbacks_DEPRECATED: [],\n suspendedComponentResolvers: new Set(),\n graphsByVersion: new Map().set(version, store.getGraph(treeState.version)),\n versionsUsedByComponent: new Map(),\n retention: {\n referenceCounts: new Map(),\n nodesRetainedByZone: new Map(),\n retainablesToCheckForRelease: new Set()\n },\n nodeCleanupFunctions: new Map()\n };\n} // Factory to build a fresh snapshot\n\n\nfunction freshSnapshot(initializeState) {\n const snapshot = new Snapshot(makeEmptyStoreState$1());\n return initializeState != null ? snapshot.map(initializeState) : snapshot;\n} // Factory to clone a snapahot state\n\n\nfunction cloneSnapshot(store, version = 'current') {\n const storeState = store.getState();\n const treeState = version === 'current' ? storeState.currentTree : Recoil_nullthrows(storeState.previousTree);\n return new Snapshot(cloneStoreState(store, treeState));\n}\n\nclass MutableSnapshot extends Snapshot {\n constructor(snapshot) {\n super(cloneStoreState(snapshot.getStore_INTERNAL(), snapshot.getStore_INTERNAL().getState().currentTree, true));\n\n _defineProperty(this, \"set\", (recoilState, newValueOrUpdater) => {\n this.checkRefCount_INTERNAL(); // This batchUpdates ensures this `set` is applied immediately and you can\n // read the written value after calling `set`. I would like to remove this\n // behavior and only batch in `Snapshot.map`, but this would be a breaking\n // change potentially.\n\n batchUpdates$1(() => {\n setRecoilValue$1(this.getStore_INTERNAL(), recoilState, newValueOrUpdater);\n });\n });\n\n _defineProperty(this, \"reset\", recoilState => {\n this.checkRefCount_INTERNAL(); // See note at `set` about batched updates.\n\n batchUpdates$1(() => setRecoilValue$1(this.getStore_INTERNAL(), recoilState, DEFAULT_VALUE$1));\n });\n\n _defineProperty(this, \"setUnvalidatedAtomValues_DEPRECATED\", values => {\n this.checkRefCount_INTERNAL();\n const store = this.getStore_INTERNAL();\n batchUpdates$1(() => {\n for (const [k, v] of values.entries()) {\n setUnvalidatedRecoilValue$1(store, new AbstractRecoilValue$2(k), v);\n }\n });\n });\n } // We want to allow the methods to be destructured and used as accessors\n // eslint-disable-next-line fb-www/extra-arrow-initializer\n\n\n}\n\nvar Recoil_Snapshot = {\n Snapshot,\n MutableSnapshot,\n freshSnapshot,\n cloneSnapshot\n};\n\nvar Recoil_Snapshot_1 = Recoil_Snapshot.Snapshot;\nvar Recoil_Snapshot_2 = Recoil_Snapshot.MutableSnapshot;\nvar Recoil_Snapshot_3 = Recoil_Snapshot.freshSnapshot;\nvar Recoil_Snapshot_4 = Recoil_Snapshot.cloneSnapshot;\n\nvar Recoil_Snapshot$1 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n Snapshot: Recoil_Snapshot_1,\n MutableSnapshot: Recoil_Snapshot_2,\n freshSnapshot: Recoil_Snapshot_3,\n cloneSnapshot: Recoil_Snapshot_4\n});\n\n// @fb-only: const RecoilusagelogEvent = require('RecoilusagelogEvent');\n// @fb-only: const RecoilUsageLogFalcoEvent = require('RecoilUsageLogFalcoEvent');\n// @fb-only: const URI = require('URI');\n\n\nconst {\n getNextTreeStateVersion: getNextTreeStateVersion$2,\n makeEmptyStoreState: makeEmptyStoreState$2\n} = Recoil_State;\n\n\n\n\n\n // @fb-only: const recoverableViolation = require('../util/Recoil_recoverableViolation');\n\n\n\n\nconst {\n cleanUpNode: cleanUpNode$2,\n getDownstreamNodes: getDownstreamNodes$2,\n setNodeValue: setNodeValue$2,\n setUnvalidatedAtomValue_DEPRECATED: setUnvalidatedAtomValue_DEPRECATED$1\n} = Recoil_FunctionalCore;\n\nconst {\n graph: graph$3\n} = Recoil_Graph;\n\nconst {\n cloneGraph: cloneGraph$1\n} = Recoil_Graph;\n\nconst {\n applyAtomValueWrites: applyAtomValueWrites$1\n} = Recoil_RecoilValueInterface;\n\nconst {\n releaseScheduledRetainablesNow: releaseScheduledRetainablesNow$1\n} = Recoil_Retention;\n\nconst {\n freshSnapshot: freshSnapshot$1\n} = Recoil_Snapshot$1;\n\n\n\nconst {\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useRef,\n useState\n} = react;\n\nfunction notInAContext() {\n throw new Error('This component must be used inside a component.');\n}\n\nconst defaultStore = Object.freeze({\n getState: notInAContext,\n replaceState: notInAContext,\n getGraph: notInAContext,\n subscribeToTransactions: notInAContext,\n addTransactionMetadata: notInAContext\n});\nlet stateReplacerIsBeingExecuted = false;\n\nfunction startNextTreeIfNeeded(storeState) {\n if (stateReplacerIsBeingExecuted) {\n throw new Error('An atom update was triggered within the execution of a state updater function. State updater functions provided to Recoil must be pure functions.');\n }\n\n if (storeState.nextTree === null) {\n const version = storeState.currentTree.version;\n const nextVersion = getNextTreeStateVersion$2();\n storeState.nextTree = { ...storeState.currentTree,\n version: nextVersion,\n stateID: nextVersion,\n dirtyAtoms: new Set(),\n transactionMetadata: {}\n };\n storeState.graphsByVersion.set(nextVersion, cloneGraph$1(Recoil_nullthrows(storeState.graphsByVersion.get(version))));\n }\n}\n\nconst AppContext = react.createContext({\n current: defaultStore\n});\n\nconst useStoreRef = () => useContext(AppContext);\n\nconst MutableSourceContext = react.createContext(null); // TODO T2710559282599660\n\nfunction useRecoilMutableSource() {\n const mutableSource = useContext(MutableSourceContext);\n\n if (mutableSource == null) {\n Recoil_expectationViolation('Attempted to use a Recoil hook outside of a . ' + ' must be an ancestor of any component that uses ' + 'Recoil hooks.');\n }\n\n return mutableSource;\n}\n\nfunction sendEndOfBatchNotifications(store) {\n const storeState = store.getState();\n const treeState = storeState.currentTree; // Inform transaction subscribers of the transaction:\n\n const dirtyAtoms = treeState.dirtyAtoms;\n\n if (dirtyAtoms.size) {\n // Execute Node-specific subscribers before global subscribers\n for (const [key, subscriptions] of storeState.nodeTransactionSubscriptions) {\n if (dirtyAtoms.has(key)) {\n for (const [_, subscription] of subscriptions) {\n subscription(store);\n }\n }\n }\n\n for (const [_, subscription] of storeState.transactionSubscriptions) {\n subscription(store);\n } // Components that are subscribed to the dirty atom:\n\n\n const dependentNodes = getDownstreamNodes$2(store, treeState, dirtyAtoms);\n\n for (const key of dependentNodes) {\n const comps = storeState.nodeToComponentSubscriptions.get(key);\n\n if (comps) {\n for (const [_subID, [_debugName, callback]] of comps) {\n callback(treeState);\n }\n }\n } // Wake all suspended components so the right one(s) can try to re-render.\n // We need to wake up components not just when some asynchronous selector\n // resolved, but also when changing synchronous values because this may cause\n // a selector to change from asynchronous to synchronous, in which case there\n // would be no follow-up asynchronous resolution to wake us up.\n // TODO OPTIMIZATION Only wake up related downstream components\n\n\n storeState.suspendedComponentResolvers.forEach(cb => cb());\n } // Special behavior ONLY invoked by useInterface.\n // FIXME delete queuedComponentCallbacks_DEPRECATED when deleting useInterface.\n\n\n storeState.queuedComponentCallbacks_DEPRECATED.forEach(cb => cb(treeState));\n storeState.queuedComponentCallbacks_DEPRECATED.splice(0, storeState.queuedComponentCallbacks_DEPRECATED.length);\n}\n/*\n * The purpose of the Batcher is to observe when React batches end so that\n * Recoil state changes can be batched. Whenever Recoil state changes, we call\n * setState on the batcher. Then we wait for that change to be committed, which\n * signifies the end of the batch. That's when we respond to the Recoil change.\n */\n\n\nfunction Batcher({\n setNotifyBatcherOfChange\n}) {\n const storeRef = useStoreRef();\n const [_, setState] = useState([]);\n setNotifyBatcherOfChange(() => setState({}));\n useEffect(() => {\n // enqueueExecution runs this function immediately; it is only used to\n // manipulate the order of useEffects during tests, since React seems to\n // call useEffect in an unpredictable order sometimes.\n Recoil_Queue.enqueueExecution('Batcher', () => {\n const storeState = storeRef.current.getState();\n const {\n nextTree\n } = storeState; // Ignore commits that are not because of Recoil transactions -- namely,\n // because something above RecoilRoot re-rendered:\n\n if (nextTree === null) {\n return;\n } // nextTree is now committed -- note that copying and reset occurs when\n // a transaction begins, in startNextTreeIfNeeded:\n\n\n storeState.previousTree = storeState.currentTree;\n storeState.currentTree = nextTree;\n storeState.nextTree = null;\n sendEndOfBatchNotifications(storeRef.current);\n const discardedVersion = Recoil_nullthrows(storeState.previousTree).version;\n storeState.graphsByVersion.delete(discardedVersion);\n storeState.previousTree = null;\n\n if (Recoil_gkx_1('recoil_memory_managament_2020')) {\n releaseScheduledRetainablesNow$1(storeRef.current);\n }\n });\n }); // If an asynchronous selector resolves after the Batcher is unmounted,\n // notifyBatcherOfChange will still be called. An error gets thrown whenever\n // setState is called after a component is already unmounted, so this sets\n // notifyBatcherOfChange to be a no-op.\n\n useEffect(() => {\n return () => {\n setNotifyBatcherOfChange(() => {});\n };\n }, [setNotifyBatcherOfChange]);\n return null;\n}\n\nif (process.env.NODE_ENV !== \"production\") {\n if (typeof window !== 'undefined' && !window.$recoilDebugStates) {\n window.$recoilDebugStates = [];\n }\n} // When removing this deprecated function, remove stateBySettingRecoilValue\n// which will no longer be needed.\n\n\nfunction initialStoreState_DEPRECATED(store, initializeState) {\n const initial = makeEmptyStoreState$2();\n initializeState({\n // $FlowFixMe[escaped-generic]\n set: (atom, value) => {\n const state = initial.currentTree;\n const writes = setNodeValue$2(store, state, atom.key, value);\n const writtenNodes = new Set(writes.keys());\n const nonvalidatedAtoms = state.nonvalidatedAtoms.clone();\n\n for (const n of writtenNodes) {\n nonvalidatedAtoms.delete(n);\n }\n\n initial.currentTree = { ...state,\n dirtyAtoms: Recoil_unionSets(state.dirtyAtoms, writtenNodes),\n atomValues: applyAtomValueWrites$1(state.atomValues, writes),\n // NB: PLEASE un-export applyAtomValueWrites when deleting this code\n nonvalidatedAtoms\n };\n },\n setUnvalidatedAtomValues: atomValues => {\n // FIXME replace this with a mutative loop\n atomValues.forEach((v, k) => {\n initial.currentTree = setUnvalidatedAtomValue_DEPRECATED$1(initial.currentTree, k, v);\n });\n }\n });\n return initial;\n}\n\nfunction initialStoreState(initializeState) {\n const snapshot = freshSnapshot$1().map(initializeState);\n return snapshot.getStore_INTERNAL().getState();\n}\n\nlet nextID = 0;\n\nfunction RecoilRoot({\n initializeState_DEPRECATED,\n initializeState,\n store_INTERNAL: storeProp,\n // For use with React \"context bridging\"\n children\n}) {\n var _createMutableSource;\n\n // prettier-ignore\n // @fb-only: useEffect(() => {\n // @fb-only: if (gkx('recoil_usage_logging')) {\n // @fb-only: try {\n // @fb-only: RecoilUsageLogFalcoEvent.log(() => ({\n // @fb-only: type: RecoilusagelogEvent.RECOIL_ROOT_MOUNTED,\n // @fb-only: path: URI.getRequestURI().getPath(),\n // @fb-only: }));\n // @fb-only: } catch {\n // @fb-only: recoverableViolation(\n // @fb-only: 'Error when logging Recoil Usage event',\n // @fb-only: 'recoil',\n // @fb-only: );\n // @fb-only: }\n // @fb-only: }\n // @fb-only: }, []);\n let storeState; // eslint-disable-line prefer-const\n\n const getGraph = version => {\n const graphs = storeState.current.graphsByVersion;\n\n if (graphs.has(version)) {\n return Recoil_nullthrows(graphs.get(version));\n }\n\n const newGraph = graph$3();\n graphs.set(version, newGraph);\n return newGraph;\n };\n\n const subscribeToTransactions = (callback, key) => {\n if (key == null) {\n // Global transaction subscriptions\n const {\n transactionSubscriptions\n } = storeRef.current.getState();\n const id = nextID++;\n transactionSubscriptions.set(id, callback);\n return {\n release: () => {\n transactionSubscriptions.delete(id);\n }\n };\n } else {\n // Node-specific transaction subscriptions:\n const {\n nodeTransactionSubscriptions\n } = storeRef.current.getState();\n\n if (!nodeTransactionSubscriptions.has(key)) {\n nodeTransactionSubscriptions.set(key, new Map());\n }\n\n const id = nextID++;\n Recoil_nullthrows(nodeTransactionSubscriptions.get(key)).set(id, callback);\n return {\n release: () => {\n const subs = nodeTransactionSubscriptions.get(key);\n\n if (subs) {\n subs.delete(id);\n\n if (subs.size === 0) {\n nodeTransactionSubscriptions.delete(key);\n }\n }\n }\n };\n }\n };\n\n const addTransactionMetadata = metadata => {\n startNextTreeIfNeeded(storeRef.current.getState());\n\n for (const k of Object.keys(metadata)) {\n Recoil_nullthrows(storeRef.current.getState().nextTree).transactionMetadata[k] = metadata[k];\n }\n };\n\n const replaceState = replacer => {\n const storeState = storeRef.current.getState();\n startNextTreeIfNeeded(storeState); // Use replacer to get the next state:\n\n const nextTree = Recoil_nullthrows(storeState.nextTree);\n let replaced;\n\n try {\n stateReplacerIsBeingExecuted = true;\n replaced = replacer(nextTree);\n } finally {\n stateReplacerIsBeingExecuted = false;\n }\n\n if (replaced === nextTree) {\n return;\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof window !== 'undefined') {\n window.$recoilDebugStates.push(replaced); // TODO this shouldn't happen here because it's not batched\n }\n } // Save changes to nextTree and schedule a React update:\n\n\n storeState.nextTree = replaced;\n Recoil_nullthrows(notifyBatcherOfChange.current)();\n };\n\n const notifyBatcherOfChange = useRef(null);\n const setNotifyBatcherOfChange = useCallback(x => {\n notifyBatcherOfChange.current = x;\n }, [notifyBatcherOfChange]); // FIXME T2710559282599660\n\n const createMutableSource = (_createMutableSource = react.createMutableSource) !== null && _createMutableSource !== void 0 ? _createMutableSource : // flowlint-line unclear-type:off\n react.unstable_createMutableSource; // flowlint-line unclear-type:off\n\n const store = storeProp !== null && storeProp !== void 0 ? storeProp : {\n getState: () => storeState.current,\n replaceState,\n getGraph,\n subscribeToTransactions,\n addTransactionMetadata\n };\n const storeRef = useRef(store);\n storeState = useRef(initializeState_DEPRECATED != null ? initialStoreState_DEPRECATED(store, initializeState_DEPRECATED) : initializeState != null ? initialStoreState(initializeState) : makeEmptyStoreState$2());\n const mutableSource = useMemo(() => createMutableSource ? createMutableSource(storeState, () => storeState.current.currentTree.version) : null, [createMutableSource, storeState]); // Cleanup when the is unmounted\n\n useEffect(() => () => {\n for (const atomKey of storeRef.current.getState().knownAtoms) {\n cleanUpNode$2(storeRef.current, atomKey);\n }\n }, []);\n return /*#__PURE__*/react.createElement(AppContext.Provider, {\n value: storeRef\n }, /*#__PURE__*/react.createElement(MutableSourceContext.Provider, {\n value: mutableSource\n }, /*#__PURE__*/react.createElement(Batcher, {\n setNotifyBatcherOfChange: setNotifyBatcherOfChange\n }), children));\n}\n\nvar Recoil_RecoilRoot_react = {\n useStoreRef,\n useRecoilMutableSource,\n RecoilRoot,\n sendEndOfBatchNotifications_FOR_TESTING: sendEndOfBatchNotifications\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n/**\n * Returns a map containing all of the keys + values from the original map where\n * the given callback returned true.\n */\n\nfunction filterMap(map, callback) {\n const result = new Map();\n\n for (const [key, value] of map) {\n if (callback(value, key)) {\n result.set(key, value);\n }\n }\n\n return result;\n}\n\nvar Recoil_filterMap = filterMap;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n/**\n * Returns a set containing all of the values from the original set where\n * the given callback returned true.\n */\n\nfunction filterSet(set, callback) {\n const result = new Set();\n\n for (const value of set) {\n if (callback(value)) {\n result.add(value);\n }\n }\n\n return result;\n}\n\nvar Recoil_filterSet = filterSet;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction invariant(condition, message) {\n if (!condition) {\n throw new Error(message);\n }\n}\n\nvar invariant_1 = invariant;\n\n// @oss-only\n\n\nvar Recoil_invariant = invariant_1;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction mergeMaps(...maps) {\n const result = new Map();\n\n for (let i = 0; i < maps.length; i++) {\n const iterator = maps[i].keys();\n let nextKey;\n\n while (!(nextKey = iterator.next()).done) {\n // $FlowFixMe[incompatible-call] - map/iterator knows nothing about flow types\n result.set(nextKey.value, maps[i].get(nextKey.value));\n }\n }\n /* $FlowFixMe[incompatible-return] (>=0.66.0 site=www,mobile) This comment\n * suppresses an error found when Flow v0.66 was deployed. To see the error\n * delete this comment and run Flow. */\n\n\n return result;\n}\n\nvar Recoil_mergeMaps = mergeMaps;\n\nvar _useMutableSource;\n\n // FIXME T2710559282599660\n\n\nconst useMutableSource = // flowlint-line unclear-type:off\n(_useMutableSource = react.useMutableSource) !== null && _useMutableSource !== void 0 ? _useMutableSource : react.unstable_useMutableSource; // flowlint-line unclear-type:off\n\nfunction mutableSourceExists() {\n return useMutableSource && !(typeof window !== 'undefined' && window.$disableRecoilValueMutableSource_TEMP_HACK_DO_NOT_USE);\n}\n\nvar Recoil_mutableSource = {\n mutableSourceExists,\n useMutableSource\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction shallowArrayEqual(a, b) {\n if (a === b) {\n return true;\n }\n\n if (a.length !== b.length) {\n return false;\n }\n\n for (let i = 0, l = a.length; i < l; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nvar Recoil_shallowArrayEqual = shallowArrayEqual;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * MIT License\n *\n * Copyright (c) 2014-2019 Georg Tavonius\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nconst UNKNOWN_FUNCTION = '';\n/**\n * This parses the different stack traces and puts them into one format\n * This borrows heavily from TraceKit (https://github.com/csnover/TraceKit)\n */\n\nfunction stackTraceParser(stackString) {\n const lines = stackString.split('\\n');\n return lines.reduce((stack, line) => {\n const parseResult = parseChrome(line) || parseWinjs(line) || parseGecko(line) || parseNode(line) || parseJSC(line);\n\n if (parseResult) {\n stack.push(parseResult);\n }\n\n return stack;\n }, []);\n}\n\nconst chromeRe = /^\\s*at (.*?) ?\\(((?:file|https?|blob|chrome-extension|native|eval|webpack||\\/|[a-z]:\\\\|\\\\\\\\).*?)(?::(\\d+))?(?::(\\d+))?\\)?\\s*$/i;\nconst chromeEvalRe = /\\((\\S*)(?::(\\d+))(?::(\\d+))\\)/;\n\nfunction parseChrome(line) {\n const parts = chromeRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n const isNative = parts[2] && parts[2].indexOf('native') === 0; // start of line\n\n const isEval = parts[2] && parts[2].indexOf('eval') === 0; // start of line\n\n const submatch = chromeEvalRe.exec(parts[2]);\n\n if (isEval && submatch != null) {\n // throw out eval line/column and use top-most line/column number\n parts[2] = submatch[1]; // url\n\n parts[3] = submatch[2]; // line\n\n parts[4] = submatch[3]; // column\n }\n\n return {\n file: !isNative ? parts[2] : null,\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: isNative ? [parts[2]] : [],\n lineNumber: parts[3] ? +parts[3] : null,\n column: parts[4] ? +parts[4] : null\n };\n}\n\nconst winjsRe = /^\\s*at (?:((?:\\[object object\\])?.+) )?\\(?((?:file|ms-appx|https?|webpack|blob):.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nfunction parseWinjs(line) {\n const parts = winjsRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[2],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[3],\n column: parts[4] ? +parts[4] : null\n };\n}\n\nconst geckoRe = /^\\s*(.*?)(?:\\((.*?)\\))?(?:^|@)((?:file|https?|blob|chrome|webpack|resource|\\[native).*?|[^@]*bundle)(?::(\\d+))?(?::(\\d+))?\\s*$/i;\nconst geckoEvalRe = /(\\S+) line (\\d+)(?: > eval line \\d+)* > eval/i;\n\nfunction parseGecko(line) {\n const parts = geckoRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n const isEval = parts[3] && parts[3].indexOf(' > eval') > -1;\n const submatch = geckoEvalRe.exec(parts[3]);\n\n if (isEval && submatch != null) {\n // throw out eval line/column and use top-most line number\n parts[3] = submatch[1];\n parts[4] = submatch[2];\n parts[5] = null; // no column when eval\n }\n\n return {\n file: parts[3],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: parts[2] ? parts[2].split(',') : [],\n lineNumber: parts[4] ? +parts[4] : null,\n column: parts[5] ? +parts[5] : null\n };\n}\n\nconst javaScriptCoreRe = /^\\s*(?:([^@]*)(?:\\((.*?)\\))?@)?(\\S.*?):(\\d+)(?::(\\d+))?\\s*$/i;\n\nfunction parseJSC(line) {\n const parts = javaScriptCoreRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[3],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[4],\n column: parts[5] ? +parts[5] : null\n };\n}\n\nconst nodeRe = /^\\s*at (?:((?:\\[object object\\])?[^\\\\/]+(?: \\[as \\S+\\])?) )?\\(?(.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nfunction parseNode(line) {\n const parts = nodeRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[2],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[3],\n column: parts[4] ? +parts[4] : null\n };\n}\n\nvar Recoil_stackTraceParser = stackTraceParser;\n\nconst {\n useRef: useRef$1\n} = react;\n\nfunction useComponentName() {\n const nameRef = useRef$1();\n\n if (process.env.NODE_ENV !== \"production\") {\n if (Recoil_gkx_1('recoil_infer_component_names')) {\n var _nameRef$current;\n\n if (nameRef.current === undefined) {\n // There is no blessed way to determine the calling React component from\n // within a hook. This hack uses the fact that hooks must start with 'use'\n // and that hooks are either called by React Components or other hooks. It\n // follows therefore, that to find the calling component, you simply need\n // to look down the stack and find the first function which doesn't start\n // with 'use'. We are only enabling this in dev for now, since once the\n // codebase is minified, the naming assumptions no longer hold true.\n const frames = Recoil_stackTraceParser(new Error().stack);\n\n for (const {\n methodName\n } of frames) {\n // I observed cases where the frame was of the form 'Object.useXXX'\n // hence why I'm searching for hooks following a word boundary\n if (!methodName.match(/\\buse[^\\b]+$/)) {\n return nameRef.current = methodName;\n }\n }\n\n nameRef.current = null;\n }\n\n return (_nameRef$current = nameRef.current) !== null && _nameRef$current !== void 0 ? _nameRef$current : '';\n }\n } // @fb-only: return \"\";\n\n\n return ''; // @oss-only\n}\n\nvar Recoil_useComponentName = useComponentName;\n\nconst {\n batchUpdates: batchUpdates$2\n} = Recoil_Batching;\n\nconst {\n DEFAULT_VALUE: DEFAULT_VALUE$2,\n getNode: getNode$3,\n nodes: nodes$1\n} = Recoil_Node;\n\nconst {\n useRecoilMutableSource: useRecoilMutableSource$1,\n useStoreRef: useStoreRef$1\n} = Recoil_RecoilRoot_react;\n\nconst {\n isRecoilValue: isRecoilValue$2\n} = Recoil_RecoilValue$1;\n\nconst {\n AbstractRecoilValue: AbstractRecoilValue$3,\n getRecoilValueAsLoadable: getRecoilValueAsLoadable$2,\n setRecoilValue: setRecoilValue$2,\n setRecoilValueLoadable: setRecoilValueLoadable$1,\n setUnvalidatedRecoilValue: setUnvalidatedRecoilValue$2,\n subscribeToRecoilValue: subscribeToRecoilValue$1\n} = Recoil_RecoilValueInterface;\n\nconst {\n updateRetainCount: updateRetainCount$1\n} = Recoil_Retention;\n\nconst {\n RetentionZone: RetentionZone$3\n} = Recoil_RetentionZone;\n\nconst {\n Snapshot: Snapshot$1,\n cloneSnapshot: cloneSnapshot$1\n} = Recoil_Snapshot$1;\n\nconst {\n setByAddingToSet: setByAddingToSet$2\n} = Recoil_CopyOnWrite;\n\n\n\nconst {\n isSSR: isSSR$2\n} = Recoil_Environment;\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst {\n mutableSourceExists: mutableSourceExists$1,\n useMutableSource: useMutableSource$1\n} = Recoil_mutableSource;\n\n\n\n\n\n\n\n\n\nconst {\n useCallback: useCallback$1,\n useEffect: useEffect$1,\n useMemo: useMemo$1,\n useRef: useRef$2,\n useState: useState$1\n} = react; // Components that aren't mounted after suspending for this long will be assumed\n// to be discarded and their resources released.\n\n\nconst SUSPENSE_TIMEOUT_MS = 120000;\n\nfunction handleLoadable(loadable, atom, storeRef) {\n // We can't just throw the promise we are waiting on to Suspense. If the\n // upstream dependencies change it may produce a state in which the component\n // can render, but it would still be suspended on a Promise that may never resolve.\n if (loadable.state === 'hasValue') {\n return loadable.contents;\n } else if (loadable.state === 'loading') {\n const promise = new Promise(resolve => {\n storeRef.current.getState().suspendedComponentResolvers.add(resolve);\n });\n throw promise;\n } else if (loadable.state === 'hasError') {\n throw loadable.contents;\n } else {\n throw new Error(`Invalid value of loadable atom \"${atom.key}\"`);\n }\n}\n\nfunction validateRecoilValue(recoilValue, hookName) {\n if (!isRecoilValue$2(recoilValue)) {\n throw new Error(`Invalid argument to ${hookName}: expected an atom or selector but got ${String(recoilValue)}`);\n }\n}\n\n/**\n * Various things are broken with useRecoilInterface, particularly concurrent mode\n * and memory management. They will not be fixed.\n * */\nfunction useRecoilInterface_DEPRECATED() {\n const storeRef = useStoreRef$1();\n const [_, forceUpdate] = useState$1([]);\n const recoilValuesUsed = useRef$2(new Set());\n recoilValuesUsed.current = new Set(); // Track the RecoilValues used just during this render\n\n const previousSubscriptions = useRef$2(new Set());\n const subscriptions = useRef$2(new Map());\n const unsubscribeFrom = useCallback$1(key => {\n const sub = subscriptions.current.get(key);\n\n if (sub) {\n sub.release();\n subscriptions.current.delete(key);\n }\n }, [subscriptions]);\n const componentName = Recoil_useComponentName();\n useEffect$1(() => {\n const store = storeRef.current;\n\n function updateState(_state, key) {\n if (!subscriptions.current.has(key)) {\n return;\n }\n\n forceUpdate([]);\n }\n\n Recoil_differenceSets(recoilValuesUsed.current, previousSubscriptions.current).forEach(key => {\n if (subscriptions.current.has(key)) {\n Recoil_expectationViolation(`Double subscription to RecoilValue \"${key}\"`);\n return;\n }\n\n const sub = subscribeToRecoilValue$1(store, new AbstractRecoilValue$3(key), state => {\n updateState(state, key);\n }, componentName);\n subscriptions.current.set(key, sub);\n /**\n * Since we're subscribing in an effect we need to update to the latest\n * value of the atom since it may have changed since we rendered. We can\n * go ahead and do that now, unless we're in the middle of a batch --\n * in which case we should do it at the end of the batch, due to the\n * following edge case: Suppose an atom is updated in another useEffect\n * of this same component. Then the following sequence of events occur:\n * 1. Atom is updated and subs fired (but we may not be subscribed\n * yet depending on order of effects, so we miss this) Updated value\n * is now in nextTree, but not currentTree.\n * 2. This effect happens. We subscribe and update.\n * 3. From the update we re-render and read currentTree, with old value.\n * 4. Batcher's effect sets currentTree to nextTree.\n * In this sequence we miss the update. To avoid that, add the update\n * to queuedComponentCallback if a batch is in progress.\n */\n // FIXME delete queuedComponentCallbacks_DEPRECATED when deleting useInterface.\n\n const state = store.getState();\n\n if (state.nextTree) {\n store.getState().queuedComponentCallbacks_DEPRECATED.push(() => {\n updateState(store.getState(), key);\n });\n } else {\n updateState(store.getState(), key);\n }\n });\n Recoil_differenceSets(previousSubscriptions.current, recoilValuesUsed.current).forEach(key => {\n unsubscribeFrom(key);\n });\n previousSubscriptions.current = recoilValuesUsed.current;\n });\n useEffect$1(() => {\n const subs = subscriptions.current;\n return () => subs.forEach((_, key) => unsubscribeFrom(key));\n }, [unsubscribeFrom]);\n return useMemo$1(() => {\n function useSetRecoilState(recoilState) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilState, 'useSetRecoilState');\n }\n\n return newValueOrUpdater => {\n setRecoilValue$2(storeRef.current, recoilState, newValueOrUpdater);\n };\n }\n\n function useResetRecoilState(recoilState) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilState, 'useResetRecoilState');\n }\n\n return () => setRecoilValue$2(storeRef.current, recoilState, DEFAULT_VALUE$2);\n }\n\n function useRecoilValueLoadable(recoilValue) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilValue, 'useRecoilValueLoadable');\n }\n\n if (!recoilValuesUsed.current.has(recoilValue.key)) {\n recoilValuesUsed.current = setByAddingToSet$2(recoilValuesUsed.current, recoilValue.key);\n } // TODO Restore optimization to memoize lookup\n\n\n return getRecoilValueAsLoadable$2(storeRef.current, recoilValue);\n }\n\n function useRecoilValue(recoilValue) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilValue, 'useRecoilValue');\n }\n\n const loadable = useRecoilValueLoadable(recoilValue); // $FlowFixMe[escaped-generic]\n\n return handleLoadable(loadable, recoilValue, storeRef);\n }\n\n function useRecoilState(recoilState) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilState, 'useRecoilState');\n }\n\n return [useRecoilValue(recoilState), useSetRecoilState(recoilState)];\n }\n\n function useRecoilStateLoadable(recoilState) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilState, 'useRecoilStateLoadable');\n }\n\n return [useRecoilValueLoadable(recoilState), useSetRecoilState(recoilState)];\n }\n\n return {\n getRecoilValue: useRecoilValue,\n getRecoilValueLoadable: useRecoilValueLoadable,\n getRecoilState: useRecoilState,\n getRecoilStateLoadable: useRecoilStateLoadable,\n getSetRecoilState: useSetRecoilState,\n getResetRecoilState: useResetRecoilState\n };\n }, [recoilValuesUsed, storeRef]);\n}\n\nconst recoilComponentGetRecoilValueCount_FOR_TESTING = {\n current: 0\n};\n\nfunction useRecoilValueLoadable_MUTABLESOURCE(recoilValue) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilValue, 'useRecoilValueLoadable');\n }\n\n const storeRef = useStoreRef$1();\n const getLoadable = useCallback$1(() => {\n const store = storeRef.current;\n const treeState = store.getState().currentTree;\n return getRecoilValueAsLoadable$2(store, recoilValue, treeState);\n }, [storeRef, recoilValue]);\n const getLoadableWithTesting = useCallback$1(() => {\n if (process.env.NODE_ENV !== \"production\") {\n recoilComponentGetRecoilValueCount_FOR_TESTING.current++;\n }\n\n return getLoadable();\n }, [getLoadable]);\n const componentName = Recoil_useComponentName();\n const subscribe = useCallback$1((_storeState, callback) => {\n const store = storeRef.current;\n const subscription = subscribeToRecoilValue$1(store, recoilValue, () => {\n if (!Recoil_gkx_1('recoil_suppress_rerender_in_callback')) {\n return callback();\n } // Only re-render if the value has changed.\n // This will evaluate the atom/selector now as well as when the\n // component renders, but that may help with prefetching.\n\n\n const newLoadable = getLoadable();\n\n if (!prevLoadableRef.current.is(newLoadable)) {\n callback();\n }\n }, componentName);\n return subscription.release;\n }, [storeRef, recoilValue, componentName, getLoadable]);\n const source = useRecoilMutableSource$1();\n const loadable = useMutableSource$1(source, getLoadableWithTesting, subscribe);\n const prevLoadableRef = useRef$2(loadable);\n useEffect$1(() => {\n prevLoadableRef.current = loadable;\n });\n return loadable;\n}\n\nfunction useRecoilValueLoadable_LEGACY(recoilValue) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilValue, 'useRecoilValueLoadable');\n }\n\n const storeRef = useStoreRef$1();\n const [_, forceUpdate] = useState$1([]);\n const componentName = Recoil_useComponentName();\n useEffect$1(() => {\n const store = storeRef.current;\n const storeState = store.getState();\n const subscription = subscribeToRecoilValue$1(store, recoilValue, _state => {\n var _prevLoadableRef$curr;\n\n if (!Recoil_gkx_1('recoil_suppress_rerender_in_callback')) {\n return forceUpdate([]);\n }\n\n const newLoadable = getRecoilValueAsLoadable$2(store, recoilValue, store.getState().currentTree);\n\n if (!((_prevLoadableRef$curr = prevLoadableRef.current) === null || _prevLoadableRef$curr === void 0 ? void 0 : _prevLoadableRef$curr.is(newLoadable))) {\n forceUpdate(newLoadable);\n }\n }, componentName);\n /**\n * Since we're subscribing in an effect we need to update to the latest\n * value of the atom since it may have changed since we rendered. We can\n * go ahead and do that now, unless we're in the middle of a batch --\n * in which case we should do it at the end of the batch, due to the\n * following edge case: Suppose an atom is updated in another useEffect\n * of this same component. Then the following sequence of events occur:\n * 1. Atom is updated and subs fired (but we may not be subscribed\n * yet depending on order of effects, so we miss this) Updated value\n * is now in nextTree, but not currentTree.\n * 2. This effect happens. We subscribe and update.\n * 3. From the update we re-render and read currentTree, with old value.\n * 4. Batcher's effect sets currentTree to nextTree.\n * In this sequence we miss the update. To avoid that, add the update\n * to queuedComponentCallback if a batch is in progress.\n */\n\n if (storeState.nextTree) {\n store.getState().queuedComponentCallbacks_DEPRECATED.push(() => {\n prevLoadableRef.current = null;\n forceUpdate([]);\n });\n } else {\n var _prevLoadableRef$curr2;\n\n if (!Recoil_gkx_1('recoil_suppress_rerender_in_callback')) {\n return forceUpdate([]);\n }\n\n const newLoadable = getRecoilValueAsLoadable$2(store, recoilValue, store.getState().currentTree);\n\n if (!((_prevLoadableRef$curr2 = prevLoadableRef.current) === null || _prevLoadableRef$curr2 === void 0 ? void 0 : _prevLoadableRef$curr2.is(newLoadable))) {\n forceUpdate(newLoadable);\n }\n }\n\n return subscription.release;\n }, [componentName, recoilValue, storeRef]);\n const loadable = getRecoilValueAsLoadable$2(storeRef.current, recoilValue);\n const prevLoadableRef = useRef$2(loadable);\n useEffect$1(() => {\n prevLoadableRef.current = loadable;\n });\n return loadable;\n}\n/**\n Like useRecoilValue(), but either returns the value if available or\n just undefined if not available for any reason, such as pending or error.\n*/\n\n\nfunction useRecoilValueLoadable(recoilValue) {\n if (Recoil_gkx_1('recoil_memory_managament_2020')) {\n // eslint-disable-next-line fb-www/react-hooks\n useRetain(recoilValue);\n }\n\n if (mutableSourceExists$1()) {\n // eslint-disable-next-line fb-www/react-hooks\n return useRecoilValueLoadable_MUTABLESOURCE(recoilValue);\n } else {\n // eslint-disable-next-line fb-www/react-hooks\n return useRecoilValueLoadable_LEGACY(recoilValue);\n }\n}\n/**\n Returns the value represented by the RecoilValue.\n If the value is pending, it will throw a Promise to suspend the component,\n if the value is an error it will throw it for the nearest React error boundary.\n This will also subscribe the component for any updates in the value.\n */\n\n\nfunction useRecoilValue(recoilValue) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilValue, 'useRecoilValue');\n }\n\n const storeRef = useStoreRef$1();\n const loadable = useRecoilValueLoadable(recoilValue); // $FlowFixMe[escaped-generic]\n\n return handleLoadable(loadable, recoilValue, storeRef);\n}\n/**\n Returns a function that allows the value of a RecoilState to be updated, but does\n not subscribe the component to changes to that RecoilState.\n*/\n\n\nfunction useSetRecoilState(recoilState) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilState, 'useSetRecoilState');\n }\n\n const storeRef = useStoreRef$1();\n return useCallback$1(newValueOrUpdater => {\n setRecoilValue$2(storeRef.current, recoilState, newValueOrUpdater);\n }, [storeRef, recoilState]);\n}\n/**\n Returns a function that will reset the value of a RecoilState to its default\n*/\n\n\nfunction useResetRecoilState(recoilState) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilState, 'useResetRecoilState');\n }\n\n const storeRef = useStoreRef$1();\n return useCallback$1(() => {\n setRecoilValue$2(storeRef.current, recoilState, DEFAULT_VALUE$2);\n }, [storeRef, recoilState]);\n}\n/**\n Equivalent to useState(). Allows the value of the RecoilState to be read and written.\n Subsequent updates to the RecoilState will cause the component to re-render. If the\n RecoilState is pending, this will suspend the component and initiate the\n retrieval of the value. If evaluating the RecoilState resulted in an error, this will\n throw the error so that the nearest React error boundary can catch it.\n*/\n\n\nfunction useRecoilState(recoilState) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilState, 'useRecoilState');\n }\n\n return [useRecoilValue(recoilState), useSetRecoilState(recoilState)];\n}\n/**\n Like useRecoilState(), but does not cause Suspense or React error handling. Returns\n an object that indicates whether the RecoilState is available, pending, or\n unavailable due to an error.\n*/\n\n\nfunction useRecoilStateLoadable(recoilState) {\n if (process.env.NODE_ENV !== \"production\") {\n // $FlowFixMe[escaped-generic]\n validateRecoilValue(recoilState, 'useRecoilStateLoadable');\n }\n\n return [useRecoilValueLoadable(recoilState), useSetRecoilState(recoilState)];\n}\n\nfunction useTransactionSubscription(callback) {\n const storeRef = useStoreRef$1();\n useEffect$1(() => {\n const sub = storeRef.current.subscribeToTransactions(callback);\n return sub.release;\n }, [callback, storeRef]);\n}\n\nfunction externallyVisibleAtomValuesInState(state) {\n const atomValues = state.atomValues.toMap();\n const persistedAtomContentsValues = Recoil_mapMap(Recoil_filterMap(atomValues, (v, k) => {\n const node = getNode$3(k);\n const persistence = node.persistence_UNSTABLE;\n return persistence != null && persistence.type !== 'none' && v.state === 'hasValue';\n }), v => v.contents); // Merge in nonvalidated atoms; we may not have defs for them but they will\n // all have persistence on or they wouldn't be there in the first place.\n\n return Recoil_mergeMaps(state.nonvalidatedAtoms.toMap(), persistedAtomContentsValues);\n}\n\n/**\n Calls the given callback after any atoms have been modified and the consequent\n component re-renders have been committed. This is intended for persisting\n the values of the atoms to storage. The stored values can then be restored\n using the useSetUnvalidatedAtomValues hook.\n\n The callback receives the following info:\n\n atomValues: The current value of every atom that is both persistable (persistence\n type not set to 'none') and whose value is available (not in an\n error or loading state).\n\n previousAtomValues: The value of every persistable and available atom before\n the transaction began.\n\n atomInfo: A map containing the persistence settings for each atom. Every key\n that exists in atomValues will also exist in atomInfo.\n\n modifiedAtoms: The set of atoms that were written to during the transaction.\n\n transactionMetadata: Arbitrary information that was added via the\n useSetUnvalidatedAtomValues hook. Useful for ignoring the useSetUnvalidatedAtomValues\n transaction, to avoid loops.\n*/\nfunction useTransactionObservation_DEPRECATED(callback) {\n useTransactionSubscription(useCallback$1(store => {\n let previousTree = store.getState().previousTree;\n const currentTree = store.getState().currentTree;\n\n if (!previousTree) {\n Recoil_recoverableViolation('Transaction subscribers notified without a previous tree being present -- this is a bug in Recoil');\n previousTree = store.getState().currentTree; // attempt to trundle on\n }\n\n const atomValues = externallyVisibleAtomValuesInState(currentTree);\n const previousAtomValues = externallyVisibleAtomValuesInState(previousTree);\n const atomInfo = Recoil_mapMap(nodes$1, node => {\n var _node$persistence_UNS, _node$persistence_UNS2, _node$persistence_UNS3, _node$persistence_UNS4;\n\n return {\n persistence_UNSTABLE: {\n type: (_node$persistence_UNS = (_node$persistence_UNS2 = node.persistence_UNSTABLE) === null || _node$persistence_UNS2 === void 0 ? void 0 : _node$persistence_UNS2.type) !== null && _node$persistence_UNS !== void 0 ? _node$persistence_UNS : 'none',\n backButton: (_node$persistence_UNS3 = (_node$persistence_UNS4 = node.persistence_UNSTABLE) === null || _node$persistence_UNS4 === void 0 ? void 0 : _node$persistence_UNS4.backButton) !== null && _node$persistence_UNS3 !== void 0 ? _node$persistence_UNS3 : false\n }\n };\n }); // Filter on existance in atomValues so that externally-visible rules\n // are also applied to modified atoms (specifically exclude selectors):\n\n const modifiedAtoms = Recoil_filterSet(currentTree.dirtyAtoms, k => atomValues.has(k) || previousAtomValues.has(k));\n callback({\n atomValues,\n previousAtomValues,\n atomInfo,\n modifiedAtoms,\n transactionMetadata: { ...currentTree.transactionMetadata\n }\n });\n }, [callback]));\n}\n\nfunction useRecoilTransactionObserver(callback) {\n useTransactionSubscription(useCallback$1(store => {\n const snapshot = cloneSnapshot$1(store, 'current');\n const previousSnapshot = cloneSnapshot$1(store, 'previous');\n callback({\n snapshot,\n previousSnapshot\n });\n }, [callback]));\n}\n\nfunction usePrevious(value) {\n const ref = useRef$2();\n useEffect$1(() => {\n ref.current = value;\n });\n return ref.current;\n} // Return a snapshot of the current state and subscribe to all state changes\n\n\nfunction useRecoilSnapshot() {\n const storeRef = useStoreRef$1();\n const [snapshot, setSnapshot] = useState$1(() => cloneSnapshot$1(storeRef.current));\n const previousSnapshot = usePrevious(snapshot);\n const timeoutID = useRef$2();\n useEffect$1(() => {\n if (timeoutID.current && !isSSR$2) {\n window.clearTimeout(timeoutID.current);\n }\n\n return snapshot.retain();\n }, [snapshot]);\n useTransactionSubscription(useCallback$1(store => setSnapshot(cloneSnapshot$1(store)), []));\n\n if (previousSnapshot !== snapshot && !isSSR$2) {\n if (timeoutID.current) {\n previousSnapshot === null || previousSnapshot === void 0 ? void 0 : previousSnapshot.release();\n window.clearTimeout(timeoutID.current);\n }\n\n snapshot.retain();\n timeoutID.current = window.setTimeout(() => {\n snapshot.release();\n timeoutID.current = null;\n }, SUSPENSE_TIMEOUT_MS);\n }\n\n return snapshot;\n}\n\nfunction useGotoRecoilSnapshot() {\n const storeRef = useStoreRef$1();\n return useCallback$1(snapshot => {\n var _storeState$nextTree;\n\n const storeState = storeRef.current.getState();\n const prev = (_storeState$nextTree = storeState.nextTree) !== null && _storeState$nextTree !== void 0 ? _storeState$nextTree : storeState.currentTree;\n const next = snapshot.getStore_INTERNAL().getState().currentTree;\n batchUpdates$2(() => {\n const keysToUpdate = new Set();\n\n for (const keys of [prev.atomValues.keys(), next.atomValues.keys()]) {\n for (const key of keys) {\n var _prev$atomValues$get, _next$atomValues$get;\n\n if (((_prev$atomValues$get = prev.atomValues.get(key)) === null || _prev$atomValues$get === void 0 ? void 0 : _prev$atomValues$get.contents) !== ((_next$atomValues$get = next.atomValues.get(key)) === null || _next$atomValues$get === void 0 ? void 0 : _next$atomValues$get.contents) && getNode$3(key).shouldRestoreFromSnapshots) {\n keysToUpdate.add(key);\n }\n }\n }\n\n keysToUpdate.forEach(key => {\n setRecoilValueLoadable$1(storeRef.current, new AbstractRecoilValue$3(key), next.atomValues.has(key) ? Recoil_nullthrows(next.atomValues.get(key)) : DEFAULT_VALUE$2);\n });\n storeRef.current.replaceState(state => {\n return { ...state,\n stateID: snapshot.getID_INTERNAL()\n };\n });\n });\n }, [storeRef]);\n}\n\nfunction useSetUnvalidatedAtomValues() {\n const storeRef = useStoreRef$1();\n return (values, transactionMetadata = {}) => {\n batchUpdates$2(() => {\n storeRef.current.addTransactionMetadata(transactionMetadata);\n values.forEach((value, key) => setUnvalidatedRecoilValue$2(storeRef.current, new AbstractRecoilValue$3(key), value));\n });\n };\n}\n\nclass Sentinel {}\n\nconst SENTINEL = new Sentinel();\n\nfunction useRecoilCallback(fn, deps) {\n const storeRef = useStoreRef$1();\n const gotoSnapshot = useGotoRecoilSnapshot();\n return useCallback$1((...args) => {\n function set(recoilState, newValueOrUpdater) {\n setRecoilValue$2(storeRef.current, recoilState, newValueOrUpdater);\n }\n\n function reset(recoilState) {\n setRecoilValue$2(storeRef.current, recoilState, DEFAULT_VALUE$2);\n } // Use currentTree for the snapshot to show the currently committed state\n\n\n const snapshot = cloneSnapshot$1(storeRef.current);\n let ret = SENTINEL;\n batchUpdates$2(() => {\n const errMsg = 'useRecoilCallback expects a function that returns a function: ' + 'it accepts a function of the type (RecoilInterface) => T = R ' + 'and returns a callback function T => R, where RecoilInterface is an ' + 'object {snapshot, set, ...} and T and R are the argument and return ' + 'types of the callback you want to create. Please see the docs ' + 'at recoiljs.org for details.';\n\n if (typeof fn !== 'function') {\n throw new Error(errMsg);\n } // flowlint-next-line unclear-type:off\n\n\n const cb = fn({\n set,\n reset,\n snapshot,\n gotoSnapshot\n });\n\n if (typeof cb !== 'function') {\n throw new Error(errMsg);\n }\n\n ret = cb(...args);\n });\n !!(ret instanceof Sentinel) ? process.env.NODE_ENV !== \"production\" ? Recoil_invariant(false, 'batchUpdates should return immediately') : Recoil_invariant(false) : void 0;\n return ret;\n }, deps != null ? [...deps, storeRef] : undefined // eslint-disable-line fb-www/react-hooks-deps\n );\n} // I don't see a way to avoid the any type here because we want to accept readable\n// and writable values with any type parameter, but normally with writable ones\n// RecoilState is not a subtype of RecoilState.\n\n\n// flowlint-line unclear-type:off\nfunction useRetain(toRetain) {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n } // eslint-disable-next-line fb-www/react-hooks\n\n\n return useRetain_ACTUAL(toRetain);\n}\n\nfunction useRetain_ACTUAL(toRetain) {\n const array = Array.isArray(toRetain) ? toRetain : [toRetain];\n const retainables = array.map(a => a instanceof RetentionZone$3 ? a : a.key);\n const storeRef = useStoreRef$1();\n useEffect$1(() => {\n if (!Recoil_gkx_1('recoil_memory_managament_2020')) {\n return;\n }\n\n const store = storeRef.current;\n\n if (timeoutID.current && !isSSR$2) {\n // Already performed a temporary retain on render, simply cancel the release\n // of that temporary retain.\n window.clearTimeout(timeoutID.current);\n timeoutID.current = null;\n } else {\n // Log this since it's not clear that there's any scenario where it should happen.\n Recoil_recoverableViolation('Did not retain recoil value on render, or committed after timeout elapsed. This is fine, but odd.');\n\n for (const r of retainables) {\n updateRetainCount$1(store, r, 1);\n }\n }\n\n return () => {\n for (const r of retainables) {\n updateRetainCount$1(store, r, -1);\n }\n }; // eslint-disable-next-line fb-www/react-hooks-deps\n }, [storeRef, ...retainables]); // We want to retain if the component suspends. This is terrible but the Suspense\n // API affords us no better option. If we suspend and never commit after some\n // seconds, then release. The 'actual' retain/release in the effect above\n // cancels this.\n\n const timeoutID = useRef$2();\n const previousRetainables = usePrevious(retainables);\n\n if (!isSSR$2 && (previousRetainables === undefined || !Recoil_shallowArrayEqual(previousRetainables, retainables))) {\n const store = storeRef.current;\n\n for (const r of retainables) {\n updateRetainCount$1(store, r, 1);\n }\n\n if (previousRetainables) {\n for (const r of previousRetainables) {\n updateRetainCount$1(store, r, -1);\n }\n }\n\n if (timeoutID.current) {\n window.clearTimeout(timeoutID.current);\n }\n\n timeoutID.current = window.setTimeout(() => {\n timeoutID.current = null;\n\n for (const r of retainables) {\n updateRetainCount$1(store, r, -1);\n }\n }, SUSPENSE_TIMEOUT_MS);\n }\n}\n\nvar Recoil_Hooks = {\n recoilComponentGetRecoilValueCount_FOR_TESTING,\n useGotoRecoilSnapshot,\n useRecoilCallback,\n useRecoilInterface: useRecoilInterface_DEPRECATED,\n useRecoilSnapshot,\n useRecoilState,\n useRecoilStateLoadable,\n useRecoilTransactionObserver,\n useRecoilValue,\n useRecoilValueLoadable,\n useRetain,\n useResetRecoilState,\n useSetRecoilState,\n useSetUnvalidatedAtomValues,\n useTransactionObservation_DEPRECATED,\n useTransactionSubscription_DEPRECATED: useTransactionSubscription\n};\n\nconst {\n peekNodeInfo: peekNodeInfo$2\n} = Recoil_FunctionalCore;\n\nconst {\n useStoreRef: useStoreRef$2\n} = Recoil_RecoilRoot_react;\n\nfunction useGetRecoilValueInfo() {\n const storeRef = useStoreRef$2();\n return ({\n key\n }) => peekNodeInfo$2(storeRef.current, storeRef.current.getState().currentTree, key);\n}\n\nvar Recoil_useGetRecoilValueInfo = useGetRecoilValueInfo;\n\nconst {\n RecoilRoot: RecoilRoot$1,\n useStoreRef: useStoreRef$3\n} = Recoil_RecoilRoot_react;\n\n\n\nconst {\n useMemo: useMemo$2\n} = react;\n\nfunction useRecoilBridgeAcrossReactRoots() {\n const store = useStoreRef$3().current;\n return useMemo$2(() => {\n function RecoilBridge({\n children\n }) {\n return /*#__PURE__*/react.createElement(RecoilRoot$1, {\n store_INTERNAL: store\n }, children);\n }\n\n return RecoilBridge;\n }, [store]);\n}\n\nvar Recoil_useRecoilBridgeAcrossReactRoots = useRecoilBridgeAcrossReactRoots;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\n// Split declaration and implementation to allow this function to pretend to\n// check for actual instance of Promise instead of something with a `then`\n// method.\n// eslint-disable-next-line no-redeclare\nfunction isPromise(p) {\n return !!p && typeof p.then === 'function';\n}\n\nvar Recoil_isPromise = isPromise;\n\n// TODO Convert Loadable to a Class to allow for runtime type detection.\n// Containing static factories of withValue(), withError(), withPromise(), and all()\n\n\nclass Canceled {}\n\nconst CANCELED = new Canceled();\nconst loadableAccessors = {\n /**\n * if loadable has a value (state === 'hasValue'), return that value.\n * Otherwise, throw the (unwrapped) promise or the error.\n */\n getValue() {\n if (this.state === 'loading') {\n throw this.contents.then(({\n __value\n }) => __value);\n }\n\n if (this.state !== 'hasValue') {\n throw this.contents;\n }\n\n return this.contents;\n },\n\n toPromise() {\n return this.state === 'hasValue' ? Promise.resolve(this.contents) : this.state === 'hasError' ? Promise.reject(this.contents) : this.contents.then(({\n __value\n }) => __value);\n },\n\n valueMaybe() {\n return this.state === 'hasValue' ? this.contents : undefined;\n },\n\n valueOrThrow() {\n if (this.state !== 'hasValue') {\n const error = new Error(`Loadable expected value, but in \"${this.state}\" state`); // V8 keeps closures alive until stack is accessed, this prevents a memory leak\n throw error;\n }\n\n return this.contents;\n },\n\n errorMaybe() {\n return this.state === 'hasError' ? this.contents : undefined;\n },\n\n errorOrThrow() {\n if (this.state !== 'hasError') {\n const error = new Error(`Loadable expected error, but in \"${this.state}\" state`); // V8 keeps closures alive until stack is accessed, this prevents a memory leak\n throw error;\n }\n\n return this.contents;\n },\n\n promiseMaybe() {\n return this.state === 'loading' ? this.contents.then(({\n __value\n }) => __value) : undefined;\n },\n\n promiseOrThrow() {\n if (this.state !== 'loading') {\n const error = new Error(`Loadable expected promise, but in \"${this.state}\" state`); // V8 keeps closures alive until stack is accessed, this prevents a memory leak\n throw error;\n }\n\n return this.contents.then(({\n __value\n }) => __value);\n },\n\n is(other) {\n return other.state === this.state && other.contents === this.contents;\n },\n\n // TODO Unit tests\n // TODO Convert Loadable to a Class to better support chaining\n // by returning a Loadable from a map function\n map(map) {\n if (this.state === 'hasError') {\n return this;\n }\n\n if (this.state === 'hasValue') {\n try {\n const next = map(this.contents); // TODO if next instanceof Loadable, then return next\n\n return Recoil_isPromise(next) ? loadableWithPromise(next) : loadableWithValue(next);\n } catch (e) {\n return Recoil_isPromise(e) ? // If we \"suspended\", then try again.\n // errors and subsequent retries will be handled in 'loading' case\n loadableWithPromise(e.next(() => map(this.contents))) : loadableWithError(e);\n }\n }\n\n if (this.state === 'loading') {\n return loadableWithPromise(this.contents // TODO if map returns a loadable, then return the value or promise or throw the error\n .then(map).catch(e => {\n if (Recoil_isPromise(e)) {\n // we were \"suspended,\" try again\n return e.then(() => map(this.contents));\n }\n\n throw e;\n }));\n }\n\n const error = new Error('Invalid Loadable state'); // V8 keeps closures alive until stack is accessed, this prevents a memory leak\n throw error;\n }\n\n};\n\nfunction loadableWithValue(value) {\n // Build objects this way since Flow doesn't support disjoint unions for class properties\n return Object.freeze({\n state: 'hasValue',\n contents: value,\n ...loadableAccessors\n });\n}\n\nfunction loadableWithError(error) {\n return Object.freeze({\n state: 'hasError',\n contents: error,\n ...loadableAccessors\n });\n}\n\nfunction loadableWithPromise(promise) {\n return Object.freeze({\n state: 'loading',\n contents: promise,\n ...loadableAccessors\n });\n}\n\nfunction loadableLoading() {\n return loadableWithPromise(new Promise(() => {}));\n}\n\nfunction loadableAll(inputs) {\n return inputs.every(i => i.state === 'hasValue') ? loadableWithValue(inputs.map(i => i.contents)) : inputs.some(i => i.state === 'hasError') ? loadableWithError(Recoil_nullthrows(inputs.find(i => i.state === 'hasError'), 'Invalid loadable passed to loadableAll').contents) : loadableWithPromise(Promise.all(inputs.map(i => i.contents)).then(value => ({\n __value: value\n })));\n}\n\nvar Recoil_Loadable = {\n loadableWithValue,\n loadableWithError,\n loadableWithPromise,\n loadableLoading,\n loadableAll,\n Canceled,\n CANCELED\n};\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction isNode(object) {\n var _ownerDocument, _doc$defaultView;\n\n if (typeof window === 'undefined') {\n return false;\n }\n\n const doc = object != null ? (_ownerDocument = object.ownerDocument) !== null && _ownerDocument !== void 0 ? _ownerDocument : object : document;\n const defaultView = (_doc$defaultView = doc.defaultView) !== null && _doc$defaultView !== void 0 ? _doc$defaultView : window;\n return !!(object != null && (typeof defaultView.Node === 'function' ? object instanceof defaultView.Node : typeof object === 'object' && typeof object.nodeType === 'number' && typeof object.nodeName === 'string'));\n}\n\nvar Recoil_isNode = isNode;\n\nconst {\n isReactNative: isReactNative$1,\n isSSR: isSSR$3\n} = Recoil_Environment;\n\n\n\n\n\nfunction shouldNotBeFrozen(value) {\n // Primitives and functions:\n if (value === null || typeof value !== 'object') {\n return true;\n } // React elements:\n\n\n switch (typeof value.$$typeof) {\n case 'symbol':\n return true;\n\n case 'number':\n return true;\n } // Immutable structures:\n\n\n if (value['@@__IMMUTABLE_ITERABLE__@@'] != null || value['@@__IMMUTABLE_KEYED__@@'] != null || value['@@__IMMUTABLE_INDEXED__@@'] != null || value['@@__IMMUTABLE_ORDERED__@@'] != null || value['@@__IMMUTABLE_RECORD__@@'] != null) {\n return true;\n } // DOM nodes:\n\n\n if (Recoil_isNode(value)) {\n return true;\n }\n\n if (Recoil_isPromise(value)) {\n return true;\n }\n\n if (value instanceof Error) {\n return true;\n }\n\n if (ArrayBuffer.isView(value)) {\n return true;\n } // Some environments, just as Jest, don't work with the instanceof check\n\n\n if (!isSSR$3 && !isReactNative$1 && ( // $FlowFixMe(site=recoil) Window does not have a FlowType definition https://github.com/facebook/flow/issues/6709\n value === window || value instanceof Window)) {\n return true;\n }\n\n return false;\n} // Recursively freeze a value to enforce it is read-only.\n// This may also have minimal performance improvements for enumerating\n// objects (based on browser implementations, of course)\n\n\nfunction deepFreezeValue(value) {\n if (typeof value !== 'object' || shouldNotBeFrozen(value)) {\n return;\n }\n\n Object.freeze(value); // Make all properties read-only\n\n for (const key in value) {\n if (Object.prototype.hasOwnProperty.call(value, key)) {\n const prop = value[key]; // Prevent infinite recurssion for circular references.\n\n if (typeof prop === 'object' && prop != null && !Object.isFrozen(prop)) {\n deepFreezeValue(prop);\n }\n }\n }\n\n Object.seal(value); // This also makes existing properties non-configurable.\n}\n\nvar Recoil_deepFreezeValue = deepFreezeValue;\n\nconst TIME_WARNING_THRESHOLD_MS = 15;\n\nfunction stringify(x, opt, key) {\n // A optimization to avoid the more expensive JSON.stringify() for simple strings\n // This may lose protection for u2028 and u2029, though.\n if (typeof x === 'string' && !x.includes('\"') && !x.includes('\\\\')) {\n return `\"${x}\"`;\n } // Handle primitive types\n\n\n switch (typeof x) {\n case 'undefined':\n return '';\n // JSON.stringify(undefined) returns undefined, but we always want to return a string\n\n case 'boolean':\n return x ? 'true' : 'false';\n\n case 'number':\n case 'symbol':\n // case 'bigint': // BigInt is not supported in www\n return String(x);\n\n case 'string':\n // Add surrounding quotes and escape internal quotes\n return JSON.stringify(x);\n\n case 'function':\n if ((opt === null || opt === void 0 ? void 0 : opt.allowFunctions) !== true) {\n throw new Error('Attempt to serialize function in a Recoil cache key');\n }\n\n return `__FUNCTION(${x.name})__`;\n }\n\n if (x === null) {\n return 'null';\n } // Fallback case for unknown types\n\n\n if (typeof x !== 'object') {\n var _JSON$stringify;\n\n return (_JSON$stringify = JSON.stringify(x)) !== null && _JSON$stringify !== void 0 ? _JSON$stringify : '';\n } // Deal with all promises as equivalent for now.\n\n\n if (Recoil_isPromise(x)) {\n return '__PROMISE__';\n } // Arrays handle recursive stringification\n\n\n if (Array.isArray(x)) {\n return `[${x.map((v, i) => stringify(v, opt, i.toString()))}]`;\n } // If an object defines a toJSON() method, then use that to override the\n // serialization. This matches the behavior of JSON.stringify().\n // Pass the key for compatibility.\n // Immutable.js collections define this method to allow us to serialize them.\n\n\n if (typeof x.toJSON === 'function') {\n // flowlint-next-line unclear-type: off\n return stringify(x.toJSON(key), opt, key);\n } // For built-in Maps, sort the keys in a stable order instead of the\n // default insertion order. Support non-string keys.\n\n\n if (x instanceof Map) {\n const obj = {};\n\n for (const [k, v] of x) {\n // Stringify will escape any nested quotes\n obj[typeof k === 'string' ? k : stringify(k, opt)] = v;\n }\n\n return stringify(obj, opt, key);\n } // For built-in Sets, sort the keys in a stable order instead of the\n // default insertion order.\n\n\n if (x instanceof Set) {\n return stringify(Array.from(x).sort((a, b) => stringify(a, opt).localeCompare(stringify(b, opt))), opt, key);\n } // Anything else that is iterable serialize as an Array.\n\n\n if (Symbol !== undefined && x[Symbol.iterator] != null && typeof x[Symbol.iterator] === 'function') {\n // flowlint-next-line unclear-type: off\n return stringify(Array.from(x), opt, key);\n } // For all other Objects, sort the keys in a stable order.\n\n\n return `{${Object.keys(x).filter(key => x[key] !== undefined).sort() // stringify the key to add quotes and escape any nested slashes or quotes.\n .map(key => `${stringify(key, opt)}:${stringify(x[key], opt, key)}`).join(',')}}`;\n} // Utility similar to JSON.stringify() except:\n// * Serialize built-in Sets as an Array\n// * Serialize built-in Maps as an Object. Supports non-string keys.\n// * Serialize other iterables as arrays\n// * Sort the keys of Objects and Maps to have a stable order based on string conversion.\n// This overrides their default insertion order.\n// * Still uses toJSON() of any object to override serialization\n// * Support Symbols (though don't guarantee uniqueness)\n// * We could support BigInt, but Flow doesn't seem to like it.\n// See Recoil_stableStringify-test.js for examples\n\n\nfunction stableStringify(x, opt = {\n allowFunctions: false\n}) {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof window !== 'undefined') {\n const startTime = window.performance ? window.performance.now() : 0;\n const str = stringify(x, opt);\n const endTime = window.performance ? window.performance.now() : 0;\n\n if (endTime - startTime > TIME_WARNING_THRESHOLD_MS) {\n /* eslint-disable fb-www/no-console */\n console.groupCollapsed(`Recoil: Spent ${endTime - startTime}ms computing a cache key`);\n console.warn(x, str);\n console.groupEnd();\n /* eslint-enable fb-www/no-console */\n }\n\n return str;\n }\n }\n\n return stringify(x, opt);\n}\n\nvar Recoil_stableStringify = stableStringify;\n\nclass TreeCache {\n constructor(options) {\n var _options$onHit, _options$onSet, _options$mapNodeValue;\n\n _defineProperty(this, \"_numLeafs\", void 0);\n\n _defineProperty(this, \"_root\", void 0);\n\n _defineProperty(this, \"_onHit\", void 0);\n\n _defineProperty(this, \"_onSet\", void 0);\n\n _defineProperty(this, \"_mapNodeValue\", void 0);\n\n this._numLeafs = 0;\n this._root = null;\n this._onHit = (_options$onHit = options === null || options === void 0 ? void 0 : options.onHit) !== null && _options$onHit !== void 0 ? _options$onHit : () => {};\n this._onSet = (_options$onSet = options === null || options === void 0 ? void 0 : options.onSet) !== null && _options$onSet !== void 0 ? _options$onSet : () => {};\n this._mapNodeValue = (_options$mapNodeValue = options === null || options === void 0 ? void 0 : options.mapNodeValue) !== null && _options$mapNodeValue !== void 0 ? _options$mapNodeValue : val => val;\n }\n\n size() {\n return this._numLeafs;\n } // TODO: nodeCount(): number\n\n\n root() {\n return this._root;\n }\n\n get(getNodeValue, handlers) {\n var _this$getLeafNode;\n\n return (_this$getLeafNode = this.getLeafNode(getNodeValue, handlers)) === null || _this$getLeafNode === void 0 ? void 0 : _this$getLeafNode.value;\n }\n\n getLeafNode(getNodeValue, handlers) {\n return findLeaf(this.root(), nodeKey => this._mapNodeValue(getNodeValue(nodeKey)), {\n onNodeVisit: node => {\n handlers === null || handlers === void 0 ? void 0 : handlers.onNodeVisit(node);\n\n if (node.type === 'leaf') {\n this._onHit(node);\n }\n }\n });\n }\n\n set(route, value, handlers) {\n let leafNode;\n const newRoot = addLeaf(this.root(), route.map(([nodeKey, nodeValue]) => [nodeKey, this._mapNodeValue(nodeValue)]), null, value, null, {\n onNodeVisit: node => {\n handlers === null || handlers === void 0 ? void 0 : handlers.onNodeVisit(node);\n\n if (node.type === 'leaf') {\n leafNode = node;\n }\n }\n });\n\n if (!this.root()) {\n this._root = newRoot;\n }\n\n this._numLeafs++;\n\n this._onSet(Recoil_nullthrows(leafNode));\n }\n\n delete(node) {\n if (!this.root()) {\n return false;\n }\n\n const root = Recoil_nullthrows(this.root());\n const existsInTree = pruneNodeFromTree(root, node, node.parent);\n\n if (!existsInTree) {\n return false;\n }\n\n if (node === root || root.type === 'branch' && !root.branches.size) {\n this._root = null;\n this._numLeafs = 0;\n return true;\n }\n\n this._numLeafs -= countDownstreamLeaves(node);\n return true;\n }\n\n clear() {\n this._numLeafs = 0;\n this._root = null;\n }\n\n}\n\nconst findLeaf = (root, getNodeValue, handlers) => {\n var _handlers$onNodeVisit;\n\n if (root == null) {\n return undefined;\n }\n\n handlers === null || handlers === void 0 ? void 0 : (_handlers$onNodeVisit = handlers.onNodeVisit) === null || _handlers$onNodeVisit === void 0 ? void 0 : _handlers$onNodeVisit.call(handlers, root);\n\n if (root.type === 'leaf') {\n return root;\n }\n\n const nodeValue = getNodeValue(root.nodeKey);\n return findLeaf(root.branches.get(nodeValue), getNodeValue, handlers);\n};\n\nconst addLeaf = (root, route, parent, value, branchKey, handlers) => {\n var _handlers$onNodeVisit2;\n\n let node;\n\n if (root == null) {\n if (route.length === 0) {\n node = {\n type: 'leaf',\n value,\n parent,\n branchKey\n };\n } else {\n const [path, ...rest] = route;\n const [nodeKey, nodeValue] = path;\n node = {\n type: 'branch',\n nodeKey,\n parent,\n branches: new Map(),\n branchKey\n };\n node.branches.set(nodeValue, addLeaf(null, rest, node, value, nodeValue, handlers));\n }\n } else {\n node = root;\n\n if (route.length) {\n const [path, ...rest] = route;\n const [nodeKey, nodeValue] = path;\n !(root.type === 'branch' && root.nodeKey === nodeKey) ? process.env.NODE_ENV !== \"production\" ? Recoil_invariant(false, 'Existing cache must have a branch midway through the route with matching node key') : Recoil_invariant(false) : void 0;\n root.branches.set(nodeValue, addLeaf(root.branches.get(nodeValue), rest, root, value, nodeValue, handlers));\n }\n }\n\n handlers === null || handlers === void 0 ? void 0 : (_handlers$onNodeVisit2 = handlers.onNodeVisit) === null || _handlers$onNodeVisit2 === void 0 ? void 0 : _handlers$onNodeVisit2.call(handlers, node);\n return node;\n};\n\nconst pruneNodeFromTree = (root, node, parent) => {\n if (!parent) {\n return root === node;\n }\n\n parent.branches.delete(node.branchKey);\n return pruneUpstreamBranches(root, parent, parent.parent);\n};\n\nconst pruneUpstreamBranches = (root, branchNode, parent) => {\n if (!parent) {\n return root === branchNode;\n }\n\n if (branchNode.branches.size === 0) {\n parent.branches.delete(branchNode.branchKey);\n }\n\n return pruneUpstreamBranches(root, parent, parent.parent);\n};\n\nconst countDownstreamLeaves = node => node.type === 'leaf' ? 1 : Array.from(node.branches.values()).reduce((sum, currNode) => sum + countDownstreamLeaves(currNode), 0);\n\nvar Recoil_TreeCache = {\n TreeCache\n};\n\nvar Recoil_TreeCache_1 = Recoil_TreeCache.TreeCache;\n\nvar Recoil_TreeCache$1 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n TreeCache: Recoil_TreeCache_1\n});\n\nclass LRUCache {\n constructor(options) {\n var _options$mapKey;\n\n _defineProperty(this, \"_maxSize\", void 0);\n\n _defineProperty(this, \"_size\", void 0);\n\n _defineProperty(this, \"_head\", void 0);\n\n _defineProperty(this, \"_tail\", void 0);\n\n _defineProperty(this, \"_map\", void 0);\n\n _defineProperty(this, \"_keyMapper\", void 0);\n\n this._maxSize = options.maxSize;\n this._size = 0;\n this._head = null;\n this._tail = null;\n this._map = new Map();\n this._keyMapper = (_options$mapKey = options.mapKey) !== null && _options$mapKey !== void 0 ? _options$mapKey : v => v;\n }\n\n head() {\n return this._head;\n }\n\n tail() {\n return this._tail;\n }\n\n size() {\n return this._size;\n }\n\n maxSize() {\n return this._maxSize;\n }\n\n has(key) {\n return this._map.has(this._keyMapper(key));\n }\n\n get(key) {\n const mappedKey = this._keyMapper(key);\n\n const node = this._map.get(mappedKey);\n\n if (!node) {\n return undefined;\n }\n\n this.set(key, node.value);\n return node.value;\n }\n\n set(key, val) {\n const mappedKey = this._keyMapper(key);\n\n const existingNode = this._map.get(mappedKey);\n\n if (existingNode) {\n this.delete(key);\n }\n\n const head = this.head();\n const node = {\n key,\n right: head,\n left: null,\n value: val\n };\n\n if (head) {\n head.left = node;\n } else {\n this._tail = node;\n }\n\n this._map.set(mappedKey, node);\n\n this._head = node;\n this._size++;\n\n this._maybeDeleteLRU();\n }\n\n _maybeDeleteLRU() {\n if (this.size() > this.maxSize()) {\n this.deleteLru();\n }\n }\n\n deleteLru() {\n const tail = this.tail();\n\n if (tail) {\n this.delete(tail.key);\n }\n }\n\n delete(key) {\n const mappedKey = this._keyMapper(key);\n\n if (!this._size || !this._map.has(mappedKey)) {\n return;\n }\n\n const node = Recoil_nullthrows(this._map.get(mappedKey));\n const right = node.right;\n const left = node.left;\n\n if (right) {\n right.left = node.left;\n }\n\n if (left) {\n left.right = node.right;\n }\n\n if (node === this.head()) {\n this._head = right;\n }\n\n if (node === this.tail()) {\n this._tail = left;\n }\n\n this._map.delete(mappedKey);\n\n this._size--;\n }\n\n clear() {\n this._size = 0;\n this._head = null;\n this._tail = null;\n this._map = new Map();\n }\n\n}\n\nvar Recoil_LRUCache = {\n LRUCache\n};\n\nvar Recoil_LRUCache_1 = Recoil_LRUCache.LRUCache;\n\nvar Recoil_LRUCache$1 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n LRUCache: Recoil_LRUCache_1\n});\n\nconst {\n LRUCache: LRUCache$1\n} = Recoil_LRUCache$1;\n\nconst {\n TreeCache: TreeCache$1\n} = Recoil_TreeCache$1;\n\nfunction treeCacheLRU(maxSize, mapNodeValue = v => v) {\n const lruCache = new LRUCache$1({\n maxSize\n });\n const cache = new TreeCache$1({\n mapNodeValue,\n onHit: node => {\n lruCache.set(node, true);\n },\n onSet: node => {\n const lruNode = lruCache.tail();\n lruCache.set(node, true);\n\n if (lruNode && cache.size() > maxSize) {\n cache.delete(lruNode.key);\n }\n }\n });\n return cache;\n}\n\nvar Recoil_treeCacheLRU = treeCacheLRU;\n\nconst {\n TreeCache: TreeCache$2\n} = Recoil_TreeCache$1;\n\n\n\nconst defaultPolicy = {\n equality: 'reference',\n eviction: 'none',\n maxSize: Infinity\n};\n\nfunction treeCacheFromPolicy({\n equality = defaultPolicy.equality,\n eviction = defaultPolicy.eviction,\n maxSize = defaultPolicy.maxSize\n} = defaultPolicy) {\n const valueMapper = getValueMapper(equality);\n const treeCache = getTreeCache(eviction, maxSize, valueMapper);\n return treeCache;\n}\n\nfunction getValueMapper(equality) {\n switch (equality) {\n case 'reference':\n return val => val;\n\n case 'value':\n return val => Recoil_stableStringify(val);\n }\n\n throw new Error(`Unrecognized equality policy ${equality}`);\n}\n\nfunction getTreeCache(eviction, maxSize, mapNodeValue) {\n switch (eviction) {\n case 'none':\n return new TreeCache$2({\n mapNodeValue\n });\n\n case 'lru':\n return Recoil_treeCacheLRU(Recoil_nullthrows(maxSize), mapNodeValue);\n }\n\n throw new Error(`Unrecognized eviction policy ${eviction}`);\n}\n\nvar Recoil_treeCacheFromPolicy = treeCacheFromPolicy;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @emails oncall+recoil\n * \n * @format\n *\n * This is a stub for some integration into FB internal stuff\n */\nfunction startPerfBlock(_id) {\n return () => null;\n}\n\nvar Recoil_PerformanceTimings = {\n startPerfBlock\n};\n\nconst {\n CANCELED: CANCELED$1,\n Canceled: Canceled$1,\n loadableWithError: loadableWithError$1,\n loadableWithPromise: loadableWithPromise$1,\n loadableWithValue: loadableWithValue$1\n} = Recoil_Loadable;\n\n\n\nconst {\n getNodeLoadable: getNodeLoadable$2,\n peekNodeLoadable: peekNodeLoadable$1,\n setNodeValue: setNodeValue$3\n} = Recoil_FunctionalCore;\n\nconst {\n saveDependencyMapToStore: saveDependencyMapToStore$1\n} = Recoil_Graph;\n\nconst {\n DEFAULT_VALUE: DEFAULT_VALUE$3,\n RecoilValueNotReady: RecoilValueNotReady$2,\n getConfigDeletionHandler: getConfigDeletionHandler$1,\n registerNode: registerNode$1\n} = Recoil_Node;\n\nconst {\n isRecoilValue: isRecoilValue$3\n} = Recoil_RecoilValue$1;\n\nconst {\n AbstractRecoilValue: AbstractRecoilValue$4\n} = Recoil_RecoilValue$1;\n\nconst {\n setRecoilValueLoadable: setRecoilValueLoadable$2\n} = Recoil_RecoilValueInterface;\n\nconst {\n retainedByOptionWithDefault: retainedByOptionWithDefault$1\n} = Recoil_Retention;\n\n\n\n\n\n\n\n\n\n\n\nconst {\n startPerfBlock: startPerfBlock$1\n} = Recoil_PerformanceTimings;\n\n\n\nconst dependencyStack = []; // for detecting circular dependencies.\n\nconst waitingStores = new Map();\n/* eslint-disable no-redeclare */\n\nconst getNewExecutionId = (() => {\n let executionId = 0;\n return () => executionId++;\n})();\n\nfunction getInitialExecutionInfo() {\n return {\n depValuesDiscoveredSoFarDuringAsyncWork: null,\n latestLoadable: null,\n latestExecutionId: null,\n stateVersion: null\n };\n}\n\nfunction selector(options) {\n const {\n key,\n get,\n cachePolicy_UNSTABLE: cachePolicy\n } = options;\n const set = options.set != null ? options.set : undefined; // flow\n\n const cache = Recoil_treeCacheFromPolicy(cachePolicy !== null && cachePolicy !== void 0 ? cachePolicy : {\n equality: 'reference',\n eviction: 'none'\n });\n const retainedBy = retainedByOptionWithDefault$1(options.retainedBy_UNSTABLE);\n const executionInfoMap = new Map();\n let liveStoresCount = 0;\n\n function selectorIsLive() {\n return !Recoil_gkx_1('recoil_memory_managament_2020') || liveStoresCount > 0;\n }\n\n function getExecutionInfo(store) {\n if (!executionInfoMap.has(store)) {\n executionInfoMap.set(store, getInitialExecutionInfo());\n }\n\n return Recoil_nullthrows(executionInfoMap.get(store));\n }\n\n function selectorInit(store) {\n liveStoresCount++;\n store.getState().knownSelectors.add(key); // FIXME remove knownSelectors?\n\n return () => {\n liveStoresCount--;\n store.getState().knownSelectors.delete(key);\n executionInfoMap.delete(store);\n };\n }\n\n function selectorShouldDeleteConfigOnRelease() {\n return getConfigDeletionHandler$1(key) !== undefined && !selectorIsLive();\n }\n\n function notifyStoreWhenAsyncSettles(store, loadable, executionId) {\n if (loadable.state === 'loading') {\n let stores = waitingStores.get(executionId);\n\n if (stores == null) {\n waitingStores.set(executionId, stores = new Set());\n }\n\n stores.add(store);\n }\n }\n\n function notifyStoresOfSettledAsync(newLoadable, executionId) {\n const stores = waitingStores.get(executionId);\n\n if (stores !== undefined) {\n for (const store of stores) {\n setRecoilValueLoadable$2(store, new AbstractRecoilValue$4(key), newLoadable);\n }\n\n waitingStores.delete(executionId);\n }\n }\n\n function getCachedNodeLoadable(store, state, key) {\n if (state.atomValues.has(key)) {\n return Recoil_nullthrows(state.atomValues.get(key));\n }\n\n const loadable = getNodeLoadable$2(store, state, key);\n const isKeyPointingToSelector = store.getState().knownSelectors.has(key);\n\n if (loadable.state !== 'loading' && isKeyPointingToSelector) {\n state.atomValues.set(key, loadable);\n }\n\n return loadable;\n }\n /**\n * This function attaches a then() and a catch() to a promise that was\n * returned from a selector's get() (either explicitly or implicitly by\n * running a function that uses the \"async\" keyword). If a selector's get()\n * returns a promise, we have two possibilities:\n *\n * 1. The promise will resolve, in which case it will have completely finished\n * executing without any remaining pending dependencies. No more retries\n * are needed and we can proceed with updating the cache and notifying\n * subscribers (if it is the latest execution, otherwise only the cache\n * will be updated and subscriptions will not be fired). This is the case\n * handled by the attached then() handler.\n *\n * 2. The promise will throw because it either has an error or it came across\n * an async dependency that has not yet resolved, in which case we will\n * call wrapDepdencyPromise(), whose responsibility is to handle dependency\n * promises. This case is handled by the attached catch() handler.\n *\n * Both branches will eventually resolve to the final result of the selector\n * (or an error if a real error occurred).\n *\n * The execution will run to completion even if it is stale, and its value\n * will be cached. But stale executions will not update global state or update\n * executionInfo as that is the responsibility of the 'latest' execution.\n *\n * Note this function should not be passed a promise that was thrown--AKA a\n * dependency promise. Dependency promises should be passed to\n * wrapPendingDependencyPromise()).\n */\n\n\n function wrapPendingPromise(store, promise, state, depValues, executionId) {\n return promise.then(value => {\n if (!selectorIsLive()) {\n // The selector was released since the request began; ignore the response.\n clearExecutionInfo(store, executionId);\n return CANCELED$1;\n }\n\n const loadable = loadableWithValue$1(value);\n maybeFreezeValue(value);\n setCache(state, depValuesToDepRoute(depValues), loadable);\n setDepsInStore(store, state, new Set(depValues.keys()), executionId);\n setLoadableInStoreToNotifyDeps(store, loadable, executionId);\n return {\n __value: value,\n __key: key\n };\n }).catch(errorOrPromise => {\n if (!selectorIsLive()) {\n // The selector was released since the request began; ignore the response.\n clearExecutionInfo(store, executionId);\n return CANCELED$1;\n }\n\n if (isLatestExecution(store, executionId)) {\n updateExecutionInfoDepValues(depValues, store, executionId);\n }\n\n if (Recoil_isPromise(errorOrPromise)) {\n return wrapPendingDependencyPromise(store, errorOrPromise, state, depValues, executionId);\n }\n\n const loadable = loadableWithError$1(errorOrPromise);\n maybeFreezeValue(errorOrPromise);\n setCache(state, depValuesToDepRoute(depValues), loadable);\n setDepsInStore(store, state, new Set(depValues.keys()), executionId);\n setLoadableInStoreToNotifyDeps(store, loadable, executionId);\n throw errorOrPromise;\n });\n }\n /**\n * This function attaches a then() and a catch() to a promise that was\n * thrown from a selector's get(). If a selector's get() throws a promise,\n * we have two possibilities:\n *\n * 1. The promise will resolve, meaning one of our selector's dependencies is\n * now available and we should \"retry\" our get() by running it again. This\n * is the case handled by the attached then() handler.\n *\n * 2. The promise will throw because something went wrong with the dependency\n * promise (in other words a real error occurred). This case is handled by\n * the attached catch() handler. If the dependency promise throws, it is\n * _always_ a real error and not another dependency promise (any dependency\n * promises would have been handled upstream).\n *\n * The then() branch will eventually resolve to the final result of the\n * selector (or an error if a real error occurs), and the catch() will always\n * resolve to an error because the dependency promise is a promise that was\n * wrapped upstream, meaning it will only resolve to its real value or to a\n * real error.\n *\n * The execution will run to completion even if it is stale, and its value\n * will be cached. But stale executions will not update global state or update\n * executionInfo as that is the responsibility of the 'latest' execution.\n *\n * Note this function should not be passed a promise that was returned from\n * get(). The intention is that this function is only passed promises that\n * were thrown due to a pending dependency. Promises returned by get() should\n * be passed to wrapPendingPromise() instead.\n */\n\n\n function wrapPendingDependencyPromise(store, promise, state, existingDeps, executionId) {\n return promise.then(resolvedDep => {\n if (!selectorIsLive()) {\n // The selector was released since the request began; ignore the response.\n clearExecutionInfo(store, executionId);\n return CANCELED$1;\n }\n\n if (resolvedDep instanceof Canceled$1) {\n Recoil_recoverableViolation('Selector was released while it had dependencies');\n return CANCELED$1;\n }\n\n const {\n __key: resolvedDepKey,\n __value: depValue\n } = resolvedDep !== null && resolvedDep !== void 0 ? resolvedDep : {};\n /**\n * We need to bypass the selector dep cache if the resolved dep was a\n * user-thrown promise because the selector dep cache will contain the\n * stale values of dependencies, causing an infinite evaluation loop.\n */\n\n let bypassSelectorDepCacheOnReevaluation = true;\n\n if (resolvedDepKey != null) {\n /**\n * Note for async atoms, this means we are changing the atom's value\n * in the store for the given version. This should be alright because\n * the version of state is now stale and a new version will have\n * already been triggered by the atom being resolved (see this logic\n * in Recoil_atom.js)\n */\n state.atomValues.set(resolvedDepKey, loadableWithValue$1(depValue));\n /**\n * We've added the resolved dependency to the selector dep cache, so\n * there's no need to bypass the cache\n */\n\n bypassSelectorDepCacheOnReevaluation = false;\n }\n\n const [loadable, depValues] = evaluateSelectorGetter(store, state, executionId, bypassSelectorDepCacheOnReevaluation);\n\n if (isLatestExecution(store, executionId)) {\n updateExecutionInfoDepValues(depValues, store, executionId);\n }\n\n maybeFreezeLoadableContents(loadable);\n\n if (loadable.state !== 'loading') {\n setCache(state, depValuesToDepRoute(depValues), loadable);\n setDepsInStore(store, state, new Set(depValues.keys()), executionId);\n setLoadableInStoreToNotifyDeps(store, loadable, executionId);\n }\n\n if (loadable.state === 'hasError') {\n throw loadable.contents;\n }\n\n if (loadable.state === 'hasValue') {\n return {\n __value: loadable.contents,\n __key: key\n };\n }\n /**\n * Returning promise here without wrapping as the wrapepr logic was\n * already done when we called evaluateSelectorGetter() to get this\n * loadable\n */\n\n\n return loadable.contents;\n }).catch(error => {\n if (!selectorIsLive()) {\n // The selector was released since the request began; ignore the response.\n clearExecutionInfo(store, executionId);\n return CANCELED$1;\n }\n\n const loadable = loadableWithError$1(error);\n maybeFreezeValue(error);\n setCache(state, depValuesToDepRoute(existingDeps), loadableWithError$1(error));\n setDepsInStore(store, state, new Set(existingDeps.keys()), executionId);\n setLoadableInStoreToNotifyDeps(store, loadable, executionId);\n throw error;\n });\n }\n\n function setLoadableInStoreToNotifyDeps(store, loadable, executionId) {\n if (isLatestExecution(store, executionId)) {\n setExecutionInfo(loadable, store);\n notifyStoresOfSettledAsync(loadable, executionId);\n }\n }\n\n function setDepsInStore(store, state, deps, executionId) {\n var _store$getState, _store$getState$curre, _store$getState2, _store$getState2$next;\n\n if (isLatestExecution(store, executionId) || state.version === ((_store$getState = store.getState()) === null || _store$getState === void 0 ? void 0 : (_store$getState$curre = _store$getState.currentTree) === null || _store$getState$curre === void 0 ? void 0 : _store$getState$curre.version) || state.version === ((_store$getState2 = store.getState()) === null || _store$getState2 === void 0 ? void 0 : (_store$getState2$next = _store$getState2.nextTree) === null || _store$getState2$next === void 0 ? void 0 : _store$getState2$next.version)) {\n var _store$getState$nextT, _store$getState3, _store$getState3$next;\n\n saveDependencyMapToStore$1(new Map([[key, deps]]), store, (_store$getState$nextT = (_store$getState3 = store.getState()) === null || _store$getState3 === void 0 ? void 0 : (_store$getState3$next = _store$getState3.nextTree) === null || _store$getState3$next === void 0 ? void 0 : _store$getState3$next.version) !== null && _store$getState$nextT !== void 0 ? _store$getState$nextT : store.getState().currentTree.version);\n }\n }\n\n function setNewDepInStore(store, state, deps, newDepKey, executionId) {\n deps.add(newDepKey);\n setDepsInStore(store, state, deps, executionId);\n }\n\n function evaluateSelectorGetter(store, state, executionId, bypassSelectorDepCache = false) {\n const endPerfBlock = startPerfBlock$1(key); // TODO T63965866: use execution ID here\n\n let result;\n let resultIsError = false;\n let loadable;\n const depValues = new Map();\n /**\n * Starting a fresh set of deps that we'll be using to update state. We're\n * starting a new set versus adding it in existing state deps because\n * the version of state that we update deps for may be a more recent version\n * than the version the selector was called with. This is because the latest\n * execution will update the deps of the current/latest version of state (\n * this is safe to do because the fact that the selector is the latest\n * execution means the deps we discover below are our best guess at the\n * deps for the current/latest state in the store)\n */\n\n const deps = new Set();\n setDepsInStore(store, state, deps, executionId);\n\n function getRecoilValue(recoilValue) {\n const {\n key: depKey\n } = recoilValue;\n setNewDepInStore(store, state, deps, depKey, executionId);\n const depLoadable = bypassSelectorDepCache ? getNodeLoadable$2(store, state, depKey) : getCachedNodeLoadable(store, state, depKey);\n depValues.set(depKey, depLoadable);\n\n if (depLoadable.state === 'hasValue') {\n return depLoadable.contents;\n }\n\n throw depLoadable.contents;\n }\n\n try {\n result = get({\n get: getRecoilValue\n });\n result = isRecoilValue$3(result) ? getRecoilValue(result) : result;\n\n if (Recoil_isPromise(result)) {\n result = wrapPendingPromise(store, // $FlowFixMe[incompatible-call]\n result, state, depValues, executionId).finally(endPerfBlock);\n } else {\n endPerfBlock();\n }\n } catch (errorOrDepPromise) {\n result = errorOrDepPromise;\n\n if (Recoil_isPromise(result)) {\n result = wrapPendingDependencyPromise(store, // $FlowFixMe[incompatible-call]\n result, state, depValues, executionId).finally(endPerfBlock);\n } else {\n resultIsError = true;\n endPerfBlock();\n }\n }\n\n if (resultIsError) {\n loadable = loadableWithError$1(result);\n } else if (Recoil_isPromise(result)) {\n // $FlowFixMe[incompatible-call]\n loadable = loadableWithPromise$1(result);\n } else {\n // $FlowFixMe[incompatible-call]\n loadable = loadableWithValue$1(result);\n }\n\n maybeFreezeLoadableContents(loadable);\n return [loadable, depValues];\n }\n\n function getValFromCacheAndUpdatedDownstreamDeps(store, state) {\n const depsAfterCacheDone = new Set();\n const executionInfo = getExecutionInfo(store);\n const cachedVal = cache.get(nodeKey => {\n !(typeof nodeKey === 'string') ? process.env.NODE_ENV !== \"production\" ? Recoil_invariant(false, 'Cache nodeKey is type string') : Recoil_invariant(false) : void 0;\n const loadable = getCachedNodeLoadable(store, state, nodeKey);\n return loadable.contents;\n }, {\n onNodeVisit: node => {\n if (node.type === 'branch' && node.nodeKey !== key && typeof node.nodeKey === 'string') {\n depsAfterCacheDone.add(node.nodeKey);\n }\n }\n });\n /**\n * Ensure store contains correct dependencies if we hit the cache so that\n * the store deps and cache are in sync for a given state. This is important\n * because store deps are normally updated when new executions are created,\n * but cache hits don't trigger new executions but they still _may_ signifiy\n * a change in deps in the store if the store deps for this state are empty\n * or stale.\n */\n\n if (cachedVal) {\n setDepsInStore(store, state, depsAfterCacheDone, executionInfo.latestExecutionId);\n }\n\n return cachedVal;\n }\n /**\n * FIXME: dep keys should take into account the state of the loadable to\n * prevent the edge case where a loadable with an error and a loadable with\n * an error as a value are treated as the same thing incorrectly. For example\n * these two should be treated differently:\n *\n * selector({key: '', get: () => new Error('hi')});\n * selector({key: '', get () => {throw new Error('hi')}});\n *\n * With current implementation they are treated the same\n */\n\n\n function depValuesToDepRoute(depValues) {\n return Array.from(depValues.entries()).map(([key, valLoadable]) => [key, valLoadable.contents]);\n }\n\n function getValFromRunningNewExecutionAndUpdatedDeps(store, state) {\n const newExecutionId = getNewExecutionId();\n const [loadable, newDepValues] = evaluateSelectorGetter(store, state, newExecutionId);\n setExecutionInfo(loadable, store, newDepValues, newExecutionId, state);\n maybeSetCacheWithLoadable(state, depValuesToDepRoute(newDepValues), loadable);\n notifyStoreWhenAsyncSettles(store, loadable, newExecutionId);\n return loadable;\n }\n /**\n * Given a tree state, this function returns the \"selector result\", which is\n * defined as a size-2 tuple of [DependencyMap, Loadable].\n *\n * The selector's get() function will only be re-evaluated if _both_ of the\n * following statements are true:\n *\n * 1. The current dep values from the given state produced a cache key that\n * was not found in the cache.\n * 2. There is no currently running async execution OR there is an\n * async execution that is running, but after comparing the dep values in\n * the given state with the dep values that the execution has discovered so\n * far we find that at least one dep value has changed, in which case we\n * start a new execution (the previously running execution will continue to\n * run to completion, but only the new execution will be deemed the\n * 'latest' execution, meaning it will be the only execution that will\n * update global state when it is finished. Any non-latest executions will\n * run to completion and update the selector cache but not global state).\n */\n\n\n function getSelectorValAndUpdatedDeps(store, state) {\n const cachedVal = getValFromCacheAndUpdatedDownstreamDeps(store, state);\n\n if (cachedVal != null) {\n setExecutionInfo(cachedVal, store);\n return cachedVal;\n }\n\n const inProgressExecutionInfo = getExecutionInfoOfInProgressExecution(store, state); // FIXME: this won't work with custom caching b/c it uses separate cache\n\n if (inProgressExecutionInfo) {\n const executionInfo = inProgressExecutionInfo;\n notifyStoreWhenAsyncSettles(store, Recoil_nullthrows(executionInfo.latestLoadable), Recoil_nullthrows(executionInfo.latestExecutionId)); // FIXME: check after the fact to see if we made the right choice by waiting\n\n return Recoil_nullthrows(executionInfo.latestLoadable);\n }\n\n return getValFromRunningNewExecutionAndUpdatedDeps(store, state);\n }\n /**\n * Searches execution info across all stores to see if there is an in-progress\n * execution whose dependency values match the values of the requesting store.\n */\n\n\n function getExecutionInfoOfInProgressExecution(store, state) {\n var _Array$from$find;\n\n const [, executionInfo] = (_Array$from$find = Array.from(executionInfoMap.entries()).find(([, executionInfo]) => {\n return executionInfo.latestLoadable != null && executionInfo.latestExecutionId != null && !haveAsyncDepsChanged(store, state);\n })) !== null && _Array$from$find !== void 0 ? _Array$from$find : [];\n return executionInfo;\n }\n\n const mapOfCheckedVersions = new Map();\n\n function haveAsyncDepsChanged(store, state) {\n var _executionInfo$depVal, _mapOfCheckedVersions;\n\n const executionInfo = getExecutionInfo(store);\n const oldDepValues = (_executionInfo$depVal = executionInfo.depValuesDiscoveredSoFarDuringAsyncWork) !== null && _executionInfo$depVal !== void 0 ? _executionInfo$depVal : new Map();\n const cachedDepValuesCheckedForThisVersion = Array(((_mapOfCheckedVersions = mapOfCheckedVersions.get(state.version)) !== null && _mapOfCheckedVersions !== void 0 ? _mapOfCheckedVersions : new Map()).entries());\n const isCachedVersionSame = mapOfCheckedVersions.has(state.version) && cachedDepValuesCheckedForThisVersion.length === oldDepValues.size && cachedDepValuesCheckedForThisVersion.every(([nodeKey, nodeVal]) => {\n return oldDepValues.get(nodeKey) === nodeVal;\n });\n\n if (oldDepValues == null || state.version === executionInfo.stateVersion || isCachedVersionSame) {\n return false;\n }\n\n mapOfCheckedVersions.set(state.version, new Map(oldDepValues));\n return Array.from(oldDepValues).some(([nodeKey, oldVal]) => {\n const loadable = getCachedNodeLoadable(store, state, nodeKey);\n return loadable.contents !== oldVal.contents &&\n /**\n * FIXME: in the condition below we're making the assumption that a\n * dependency that goes from loading to having a value is always because\n * the dependency resolved to that value, so we don't count it as a dep\n * change as the normal retry loop will handle retrying in response to a\n * resolved async dep. This is an incorrect assumption for the edge case\n * where there is an async selector that is loading, and while it is\n * loading one of its dependencies changes, triggering a new execution,\n * and that new execution produces a value synchronously (we don't make\n * that assumption for asynchronous work b/c it's guaranteed that a\n * loadable that goes from 'loading' to 'loading' in a new loadable is\n * a dep change).\n */\n !(oldVal.state === 'loading' && loadable.state !== 'loading');\n });\n }\n /**\n * This function will update the selector's execution info when the selector\n * has either finished running an execution or has started a new execution. If\n * the given loadable is in a 'loading' state, the intention is that a new\n * execution has started. Otherwise, the intention is that an execution has\n * just finished.\n */\n\n\n function setExecutionInfo(loadable, store, depValues, newExecutionId, state) {\n const executionInfo = getExecutionInfo(store);\n\n if (loadable.state === 'loading') {\n executionInfo.depValuesDiscoveredSoFarDuringAsyncWork = depValues;\n executionInfo.latestExecutionId = newExecutionId;\n executionInfo.latestLoadable = loadable;\n executionInfo.stateVersion = state === null || state === void 0 ? void 0 : state.version;\n } else {\n executionInfo.depValuesDiscoveredSoFarDuringAsyncWork = null;\n executionInfo.latestExecutionId = null;\n executionInfo.latestLoadable = null;\n executionInfo.stateVersion = null;\n }\n }\n /**\n * Conditionally updates the cache with a given loadable.\n *\n * We only cache loadables that are not loading because our cache keys are\n * based on dep values, which are in an unfinished state for loadables that\n * have a 'loading' state (new deps may be discovered while the selector\n * runs its async code). We never want to cache partial dependencies b/c it\n * could lead to errors, such as prematurely returning the result based on a\n * partial list of deps-- we need the full list of deps to ensure that we\n * are returning the correct result from cache.\n */\n\n\n function maybeSetCacheWithLoadable(state, depRoute, loadable) {\n if (loadable.state !== 'loading') {\n setCache(state, depRoute, loadable);\n }\n }\n\n function updateExecutionInfoDepValues(depValues, store, executionId) {\n const executionInfo = getExecutionInfo(store);\n\n if (isLatestExecution(store, executionId)) {\n executionInfo.depValuesDiscoveredSoFarDuringAsyncWork = depValues;\n }\n }\n\n function clearExecutionInfo(store, executionId) {\n if (isLatestExecution(store, executionId)) {\n executionInfoMap.delete(store);\n }\n }\n\n function isLatestExecution(store, executionId) {\n const executionInfo = getExecutionInfo(store);\n return executionId === executionInfo.latestExecutionId;\n }\n\n function maybeFreezeLoadableContents(loadable) {\n if (loadable.state !== 'loading') {\n maybeFreezeValue(loadable.contents);\n }\n }\n\n function maybeFreezeValue(val) {\n if (process.env.NODE_ENV !== \"production\") {\n if (Boolean(options.dangerouslyAllowMutability) === false) {\n Recoil_deepFreezeValue(val);\n }\n }\n }\n\n function setCache(state, cacheRoute, loadable) {\n state.atomValues.set(key, loadable);\n cache.set(cacheRoute, loadable);\n }\n\n function detectCircularDependencies(fn) {\n if (dependencyStack.includes(key)) {\n const message = `Recoil selector has circular dependencies: ${dependencyStack.slice(dependencyStack.indexOf(key)).join(' \\u2192 ')}`;\n return loadableWithError$1(new Error(message));\n }\n\n dependencyStack.push(key);\n\n try {\n return fn();\n } finally {\n dependencyStack.pop();\n }\n }\n\n function selectorPeek(store, state) {\n const cacheVal = cache.get(nodeKey => {\n !(typeof nodeKey === 'string') ? process.env.NODE_ENV !== \"production\" ? Recoil_invariant(false, 'Cache nodeKey is type string') : Recoil_invariant(false) : void 0;\n const peek = peekNodeLoadable$1(store, state, nodeKey);\n return peek === null || peek === void 0 ? void 0 : peek.contents;\n });\n return cacheVal;\n }\n\n function selectorGet(store, state) {\n return detectCircularDependencies(() => getSelectorValAndUpdatedDeps(store, state));\n }\n\n function invalidateSelector(state) {\n state.atomValues.delete(key);\n }\n\n if (set != null) {\n function selectorSet(store, state, newValue) {\n let syncSelectorSetFinished = false;\n const writes = new Map();\n\n function getRecoilValue({\n key\n }) {\n if (syncSelectorSetFinished) {\n throw new Error('Recoil: Async selector sets are not currently supported.');\n }\n\n const loadable = getCachedNodeLoadable(store, state, key);\n\n if (loadable.state === 'hasValue') {\n return loadable.contents;\n } else if (loadable.state === 'loading') {\n throw new RecoilValueNotReady$2(key);\n } else {\n throw loadable.contents;\n }\n }\n\n function setRecoilState(recoilState, valueOrUpdater) {\n if (syncSelectorSetFinished) {\n throw new Error('Recoil: Async selector sets are not currently supported.');\n }\n\n const newValue = typeof valueOrUpdater === 'function' ? // cast to any because we can't restrict type S from being a function itself without losing support for opaque types\n // flowlint-next-line unclear-type:off\n valueOrUpdater(getRecoilValue(recoilState)) : valueOrUpdater;\n const upstreamWrites = setNodeValue$3(store, state, recoilState.key, newValue);\n upstreamWrites.forEach((v, k) => writes.set(k, v));\n }\n\n function resetRecoilState(recoilState) {\n setRecoilState(recoilState, DEFAULT_VALUE$3);\n }\n\n const ret = set({\n set: setRecoilState,\n get: getRecoilValue,\n reset: resetRecoilState\n }, newValue); // set should be a void method, but if the user makes it `async`, then it\n // will return a Promise, which we don't currently support.\n\n if (ret !== undefined) {\n throw Recoil_isPromise(ret) ? new Error('Recoil: Async selector sets are not currently supported.') : new Error('Recoil: selector set should be a void function.');\n }\n\n syncSelectorSetFinished = true;\n return writes;\n }\n\n return registerNode$1({\n key,\n peek: selectorPeek,\n get: selectorGet,\n set: selectorSet,\n init: selectorInit,\n invalidate: invalidateSelector,\n shouldDeleteConfigOnRelease: selectorShouldDeleteConfigOnRelease,\n dangerouslyAllowMutability: options.dangerouslyAllowMutability,\n shouldRestoreFromSnapshots: false,\n retainedBy\n });\n } else {\n return registerNode$1({\n key,\n peek: selectorPeek,\n get: selectorGet,\n init: selectorInit,\n invalidate: invalidateSelector,\n shouldDeleteConfigOnRelease: selectorShouldDeleteConfigOnRelease,\n dangerouslyAllowMutability: options.dangerouslyAllowMutability,\n shouldRestoreFromSnapshots: false,\n retainedBy\n });\n }\n}\n/* eslint-enable no-redeclare */\n\n\nvar Recoil_selector = selector;\n\n// @fb-only: const {scopedAtom} = require('Recoil_ScopedAtom');\nconst {\n loadableWithError: loadableWithError$2,\n loadableWithPromise: loadableWithPromise$2,\n loadableWithValue: loadableWithValue$2\n} = Recoil_Loadable;\n\nconst {\n DEFAULT_VALUE: DEFAULT_VALUE$4,\n DefaultValue: DefaultValue$2,\n getConfigDeletionHandler: getConfigDeletionHandler$2,\n registerNode: registerNode$2,\n setConfigDeletionHandler: setConfigDeletionHandler$1\n} = Recoil_Node;\n\nconst {\n isRecoilValue: isRecoilValue$4\n} = Recoil_RecoilValue$1;\n\nconst {\n markRecoilValueModified: markRecoilValueModified$1,\n setRecoilValue: setRecoilValue$3,\n setRecoilValueLoadable: setRecoilValueLoadable$3\n} = Recoil_RecoilValueInterface;\n\nconst {\n retainedByOptionWithDefault: retainedByOptionWithDefault$2\n} = Recoil_Retention;\n\n\n\n\n\n\n\n\n\n\n\n\n\nfunction baseAtom(options) {\n const {\n key,\n persistence_UNSTABLE: persistence\n } = options;\n const retainedBy = retainedByOptionWithDefault$2(options.retainedBy_UNSTABLE);\n let liveStoresCount = 0;\n let defaultLoadable = Recoil_isPromise(options.default) ? loadableWithPromise$2(options.default.then(value => {\n defaultLoadable = loadableWithValue$2(value); // TODO Temporary disable Flow due to pending selector_NEW refactor\n\n const promiseInfo = {\n __key: key,\n __value: value\n };\n return promiseInfo;\n }).catch(error => {\n defaultLoadable = loadableWithError$2(error);\n throw error;\n })) : loadableWithValue$2(options.default);\n let cachedAnswerForUnvalidatedValue = undefined; // Cleanup handlers for this atom\n // Rely on stable reference equality of the store to use it as a key per \n\n const cleanupEffectsByStore = new Map();\n\n function wrapPendingPromise(store, promise) {\n const wrappedPromise = promise.then(value => {\n var _store$getState$nextT, _state$atomValues$get;\n\n const state = (_store$getState$nextT = store.getState().nextTree) !== null && _store$getState$nextT !== void 0 ? _store$getState$nextT : store.getState().currentTree;\n\n if (((_state$atomValues$get = state.atomValues.get(key)) === null || _state$atomValues$get === void 0 ? void 0 : _state$atomValues$get.contents) === wrappedPromise) {\n setRecoilValue$3(store, node, value);\n }\n\n return {\n __key: key,\n __value: value\n };\n }).catch(error => {\n var _store$getState$nextT2, _state$atomValues$get2;\n\n const state = (_store$getState$nextT2 = store.getState().nextTree) !== null && _store$getState$nextT2 !== void 0 ? _store$getState$nextT2 : store.getState().currentTree;\n\n if (((_state$atomValues$get2 = state.atomValues.get(key)) === null || _state$atomValues$get2 === void 0 ? void 0 : _state$atomValues$get2.contents) === wrappedPromise) {\n setRecoilValueLoadable$3(store, node, loadableWithError$2(error));\n }\n\n throw error;\n });\n return wrappedPromise;\n }\n\n function initAtom(store, initState, trigger) {\n liveStoresCount++;\n const alreadyKnown = store.getState().knownAtoms.has(key);\n store.getState().knownAtoms.add(key); // Setup async defaults to notify subscribers when they resolve\n\n if (defaultLoadable.state === 'loading') {\n const notifyDefaultSubscribers = () => {\n var _store$getState$nextT3;\n\n const state = (_store$getState$nextT3 = store.getState().nextTree) !== null && _store$getState$nextT3 !== void 0 ? _store$getState$nextT3 : store.getState().currentTree;\n\n if (!state.atomValues.has(key)) {\n markRecoilValueModified$1(store, node);\n }\n };\n\n defaultLoadable.contents.then(notifyDefaultSubscribers).catch(notifyDefaultSubscribers);\n } // Run Atom Effects\n // This state is scoped by Store, since this is in the initAtom() closure\n\n\n let initValue = DEFAULT_VALUE$4;\n let pendingSetSelf = null;\n\n if (options.effects_UNSTABLE != null && !alreadyKnown) {\n let duringInit = true;\n\n const setSelf = effect => valueOrUpdater => {\n if (duringInit) {\n const currentValue = initValue instanceof DefaultValue$2 || Recoil_isPromise(initValue) ? defaultLoadable.state === 'hasValue' ? defaultLoadable.contents : DEFAULT_VALUE$4 : initValue;\n initValue = typeof valueOrUpdater === 'function' ? // cast to any because we can't restrict T from being a function without losing support for opaque types\n valueOrUpdater(currentValue) // flowlint-line unclear-type:off\n : valueOrUpdater;\n } else {\n if (Recoil_isPromise(valueOrUpdater)) {\n throw new Error('Setting atoms to async values is not implemented.');\n }\n\n if (typeof valueOrUpdater !== 'function') {\n pendingSetSelf = {\n effect,\n value: valueOrUpdater\n };\n }\n\n setRecoilValue$3(store, node, typeof valueOrUpdater === 'function' ? currentValue => {\n const newValue = // cast to any because we can't restrict T from being a function without losing support for opaque types\n valueOrUpdater(currentValue); // flowlint-line unclear-type:off\n\n pendingSetSelf = {\n effect,\n value: newValue\n };\n return newValue;\n } : valueOrUpdater);\n }\n };\n\n const resetSelf = effect => () => setSelf(effect)(DEFAULT_VALUE$4);\n\n const onSet = effect => handler => {\n store.subscribeToTransactions(currentStore => {\n var _pendingSetSelf3;\n\n // eslint-disable-next-line prefer-const\n let {\n currentTree,\n previousTree\n } = currentStore.getState();\n\n if (!previousTree) {\n Recoil_recoverableViolation('Transaction subscribers notified without a next tree being present -- this is a bug in Recoil');\n previousTree = currentTree; // attempt to trundle on\n }\n\n const newLoadable = currentTree.atomValues.get(key);\n\n if (newLoadable == null || newLoadable.state === 'hasValue') {\n var _previousTree$atomVal, _pendingSetSelf, _pendingSetSelf2;\n\n const newValue = newLoadable != null ? newLoadable.contents : DEFAULT_VALUE$4;\n const oldLoadable = (_previousTree$atomVal = previousTree.atomValues.get(key)) !== null && _previousTree$atomVal !== void 0 ? _previousTree$atomVal : defaultLoadable;\n const oldValue = oldLoadable.state === 'hasValue' ? oldLoadable.contents : DEFAULT_VALUE$4; // TODO This isn't actually valid, use as a placeholder for now.\n // Ignore atom value changes that were set via setSelf() in the same effect.\n // We will still properly call the handler if there was a subsequent\n // set from something other than an atom effect which was batched\n // with the `setSelf()` call. However, we may incorrectly ignore\n // the handler if the subsequent batched call happens to set the\n // atom to the exact same value as the `setSelf()`. But, in that\n // case, it was kind of a noop, so the semantics are debatable..\n\n if (((_pendingSetSelf = pendingSetSelf) === null || _pendingSetSelf === void 0 ? void 0 : _pendingSetSelf.effect) !== effect || ((_pendingSetSelf2 = pendingSetSelf) === null || _pendingSetSelf2 === void 0 ? void 0 : _pendingSetSelf2.value) !== newValue) {\n handler(newValue, oldValue);\n }\n }\n\n if (((_pendingSetSelf3 = pendingSetSelf) === null || _pendingSetSelf3 === void 0 ? void 0 : _pendingSetSelf3.effect) === effect) {\n pendingSetSelf = null;\n }\n }, key);\n };\n\n for (const effect of (_options$effects_UNST = options.effects_UNSTABLE) !== null && _options$effects_UNST !== void 0 ? _options$effects_UNST : []) {\n var _options$effects_UNST;\n\n const cleanup = effect({\n node,\n trigger,\n setSelf: setSelf(effect),\n resetSelf: resetSelf(effect),\n onSet: onSet(effect)\n });\n\n if (cleanup != null) {\n cleanupEffectsByStore.set(store, cleanup);\n }\n }\n\n duringInit = false;\n } // Mutate initial state in place since we know there are no other subscribers\n // since we are the ones initializing on first use.\n\n\n if (!(initValue instanceof DefaultValue$2)) {\n var _store$getState$nextT4;\n\n const initLoadable = Recoil_isPromise(initValue) ? loadableWithPromise$2(wrapPendingPromise(store, initValue)) : loadableWithValue$2(initValue);\n initState.atomValues.set(key, initLoadable); // If there is a pending transaction, then also mutate the next state tree.\n // This could happen if the atom was first initialized in an action that\n // also updated some other atom's state.\n\n (_store$getState$nextT4 = store.getState().nextTree) === null || _store$getState$nextT4 === void 0 ? void 0 : _store$getState$nextT4.atomValues.set(key, initLoadable);\n }\n\n return () => {\n var _cleanupEffectsByStor;\n\n liveStoresCount--;\n (_cleanupEffectsByStor = cleanupEffectsByStore.get(store)) === null || _cleanupEffectsByStor === void 0 ? void 0 : _cleanupEffectsByStor();\n cleanupEffectsByStore.delete(store);\n store.getState().knownAtoms.delete(key); // FIXME remove knownAtoms?\n };\n }\n\n function peekAtom(_store, state) {\n var _ref, _state$atomValues$get3, _cachedAnswerForUnval;\n\n return (_ref = (_state$atomValues$get3 = state.atomValues.get(key)) !== null && _state$atomValues$get3 !== void 0 ? _state$atomValues$get3 : (_cachedAnswerForUnval = cachedAnswerForUnvalidatedValue) === null || _cachedAnswerForUnval === void 0 ? void 0 : _cachedAnswerForUnval[1]) !== null && _ref !== void 0 ? _ref : defaultLoadable;\n }\n\n function getAtom(_store, state) {\n if (state.atomValues.has(key)) {\n // Atom value is stored in state:\n return Recoil_nullthrows(state.atomValues.get(key));\n } else if (state.nonvalidatedAtoms.has(key)) {\n // Atom value is stored but needs validation before use.\n // We might have already validated it and have a cached validated value:\n if (cachedAnswerForUnvalidatedValue != null) {\n return cachedAnswerForUnvalidatedValue;\n }\n\n if (persistence == null) {\n Recoil_expectationViolation(`Tried to restore a persisted value for atom ${key} but it has no persistence settings.`);\n return defaultLoadable;\n }\n\n const nonvalidatedValue = state.nonvalidatedAtoms.get(key);\n const validatorResult = persistence.validator(nonvalidatedValue, DEFAULT_VALUE$4);\n const validatedValueLoadable = validatorResult instanceof DefaultValue$2 ? defaultLoadable : loadableWithValue$2(validatorResult);\n cachedAnswerForUnvalidatedValue = validatedValueLoadable;\n return cachedAnswerForUnvalidatedValue;\n } else {\n return defaultLoadable;\n }\n }\n\n function invalidateAtom() {\n cachedAnswerForUnvalidatedValue = undefined;\n }\n\n function setAtom(_store, state, newValue) {\n // Bail out if we're being set to the existing value, or if we're being\n // reset but have no stored value (validated or unvalidated) to reset from:\n if (state.atomValues.has(key)) {\n const existing = Recoil_nullthrows(state.atomValues.get(key));\n\n if (existing.state === 'hasValue' && newValue === existing.contents) {\n return new Map();\n }\n } else if (!state.nonvalidatedAtoms.has(key) && newValue instanceof DefaultValue$2) {\n return new Map();\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n if (options.dangerouslyAllowMutability !== true) {\n Recoil_deepFreezeValue(newValue);\n }\n }\n\n cachedAnswerForUnvalidatedValue = undefined; // can be released now if it was previously in use\n\n return new Map().set(key, loadableWithValue$2(newValue));\n }\n\n function shouldDeleteConfigOnReleaseAtom() {\n return getConfigDeletionHandler$2(key) !== undefined && liveStoresCount <= 0;\n }\n\n const node = registerNode$2({\n key,\n peek: peekAtom,\n get: getAtom,\n set: setAtom,\n init: initAtom,\n invalidate: invalidateAtom,\n shouldDeleteConfigOnRelease: shouldDeleteConfigOnReleaseAtom,\n dangerouslyAllowMutability: options.dangerouslyAllowMutability,\n persistence_UNSTABLE: options.persistence_UNSTABLE ? {\n type: options.persistence_UNSTABLE.type,\n backButton: options.persistence_UNSTABLE.backButton\n } : undefined,\n shouldRestoreFromSnapshots: true,\n retainedBy\n });\n return node;\n} // prettier-ignore\n\n\nfunction atom(options) {\n const {\n default: optionsDefault,\n // @fb-only: scopeRules_APPEND_ONLY_READ_THE_DOCS,\n ...restOptions\n } = options;\n\n if (isRecoilValue$4(optionsDefault) // Continue to use atomWithFallback for promise defaults for scoped atoms\n // for now, since scoped atoms don't support async defaults\n // @fb-only: || (isPromise(optionsDefault) && scopeRules_APPEND_ONLY_READ_THE_DOCS)\n ) {\n return atomWithFallback({ ...restOptions,\n default: optionsDefault // @fb-only: scopeRules_APPEND_ONLY_READ_THE_DOCS,\n\n }); // @fb-only: } else if (scopeRules_APPEND_ONLY_READ_THE_DOCS && !isPromise(optionsDefault)) {\n // @fb-only: return scopedAtom({\n // @fb-only: ...restOptions,\n // @fb-only: default: optionsDefault,\n // @fb-only: scopeRules_APPEND_ONLY_READ_THE_DOCS,\n // @fb-only: });\n } else {\n return baseAtom({ ...restOptions,\n default: optionsDefault\n });\n }\n}\n\nfunction atomWithFallback(options) {\n const base = atom({ ...options,\n default: DEFAULT_VALUE$4,\n persistence_UNSTABLE: options.persistence_UNSTABLE === undefined ? undefined : { ...options.persistence_UNSTABLE,\n validator: storedValue => storedValue instanceof DefaultValue$2 ? storedValue : Recoil_nullthrows(options.persistence_UNSTABLE).validator(storedValue, DEFAULT_VALUE$4)\n },\n // TODO Hack for now.\n // flowlint-next-line unclear-type: off\n effects_UNSTABLE: options.effects_UNSTABLE\n });\n const sel = Recoil_selector({\n key: `${options.key}__withFallback`,\n get: ({\n get\n }) => {\n const baseValue = get(base);\n return baseValue instanceof DefaultValue$2 ? options.default : baseValue;\n },\n set: ({\n set\n }, newValue) => set(base, newValue),\n dangerouslyAllowMutability: options.dangerouslyAllowMutability\n });\n setConfigDeletionHandler$1(sel.key, getConfigDeletionHandler$2(options.key));\n return sel;\n}\n\nvar Recoil_atom = atom;\n\n/**\n * (c) Facebook, Inc. and its affiliates. Confidential and proprietary.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nclass MapCache {\n constructor(options) {\n var _options$mapKey;\n\n _defineProperty(this, \"_map\", void 0);\n\n _defineProperty(this, \"_keyMapper\", void 0);\n\n this._map = new Map();\n this._keyMapper = (_options$mapKey = options === null || options === void 0 ? void 0 : options.mapKey) !== null && _options$mapKey !== void 0 ? _options$mapKey : v => v;\n }\n\n size() {\n return this._map.size;\n }\n\n has(key) {\n return this._map.has(this._keyMapper(key));\n }\n\n get(key) {\n return this._map.get(this._keyMapper(key));\n }\n\n set(key, val) {\n this._map.set(this._keyMapper(key), val);\n }\n\n delete(key) {\n this._map.delete(this._keyMapper(key));\n }\n\n clear() {\n this._map.clear();\n }\n\n}\n\nvar Recoil_MapCache = {\n MapCache\n};\n\nvar Recoil_MapCache_1 = Recoil_MapCache.MapCache;\n\nvar Recoil_MapCache$1 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n MapCache: Recoil_MapCache_1\n});\n\nconst {\n LRUCache: LRUCache$2\n} = Recoil_LRUCache$1;\n\nconst {\n MapCache: MapCache$1\n} = Recoil_MapCache$1;\n\nconst defaultPolicy$1 = {\n equality: 'reference',\n eviction: 'none',\n maxSize: Infinity\n};\n\nfunction cacheFromPolicy({\n equality = defaultPolicy$1.equality,\n eviction = defaultPolicy$1.eviction,\n maxSize = defaultPolicy$1.maxSize\n} = defaultPolicy$1) {\n const valueMapper = getValueMapper$1(equality);\n const cache = getCache(eviction, maxSize, valueMapper);\n return cache;\n}\n\nfunction getValueMapper$1(equality) {\n switch (equality) {\n case 'reference':\n return val => val;\n\n case 'value':\n return val => Recoil_stableStringify(val);\n }\n\n throw new Error(`Unrecognized equality policy ${equality}`);\n}\n\nfunction getCache(eviction, maxSize, mapKey) {\n switch (eviction) {\n case 'none':\n return new MapCache$1({\n mapKey\n });\n\n case 'lru':\n return new LRUCache$2({\n mapKey,\n maxSize: Recoil_nullthrows(maxSize)\n });\n }\n\n throw new Error(`Unrecognized eviction policy ${eviction}`);\n}\n\nvar Recoil_cacheFromPolicy = cacheFromPolicy;\n\nconst {\n setConfigDeletionHandler: setConfigDeletionHandler$2\n} = Recoil_Node;\n\n\n\n // Keep in mind the parameter needs to be serializable as a cahche key\n// using Recoil_stableStringify\n\n\n// Add a unique index to each selector in case the cache implementation allows\n// duplicate keys based on equivalent stringified parameters\nlet nextIndex = 0;\n/* eslint-disable no-redeclare */\n\n// Return a function that returns members of a family of selectors of the same type\n// E.g.,\n//\n// const s = selectorFamily(...);\n// s({a: 1}) => a selector\n// s({a: 2}) => a different selector\n//\n// By default, the selectors are distinguished by distinct values of the\n// parameter based on value equality, not reference equality. This allows using\n// object literals or other equivalent objects at callsites to not create\n// duplicate cache entries. This behavior may be overridden with the\n// cacheImplementationForParams option.\nfunction selectorFamily(options) {\n var _options$cachePolicyF;\n\n const selectorCache = Recoil_cacheFromPolicy((_options$cachePolicyF = options.cachePolicyForParams_UNSTABLE) !== null && _options$cachePolicyF !== void 0 ? _options$cachePolicyF : {\n equality: 'value',\n eviction: 'none'\n });\n return params => {\n var _stableStringify;\n\n const cachedSelector = selectorCache.get(params);\n\n if (cachedSelector != null) {\n return cachedSelector;\n }\n\n const myKey = `${options.key}__selectorFamily/${(_stableStringify = Recoil_stableStringify(params, {\n // It is possible to use functions in parameters if the user uses\n // a cache with reference equality thanks to the incrementing index.\n allowFunctions: true\n })) !== null && _stableStringify !== void 0 ? _stableStringify : 'void'}/${nextIndex++}`; // Append index in case values serialize to the same key string\n\n const myGet = callbacks => options.get(params)(callbacks);\n\n const myCachePolicy = options.cachePolicy_UNSTABLE;\n const retainedBy = typeof options.retainedBy_UNSTABLE === 'function' ? options.retainedBy_UNSTABLE(params) : options.retainedBy_UNSTABLE;\n let newSelector;\n\n if (options.set != null) {\n const set = options.set;\n\n const mySet = (callbacks, newValue) => set(params)(callbacks, newValue);\n\n newSelector = Recoil_selector({\n key: myKey,\n get: myGet,\n set: mySet,\n cachePolicy_UNSTABLE: myCachePolicy,\n dangerouslyAllowMutability: options.dangerouslyAllowMutability,\n retainedBy_UNSTABLE: retainedBy\n });\n } else {\n newSelector = Recoil_selector({\n key: myKey,\n get: myGet,\n cachePolicy_UNSTABLE: myCachePolicy,\n dangerouslyAllowMutability: options.dangerouslyAllowMutability,\n retainedBy_UNSTABLE: retainedBy\n });\n }\n\n selectorCache.set(params, newSelector);\n setConfigDeletionHandler$2(newSelector.key, () => {\n selectorCache.delete(params);\n });\n return newSelector;\n };\n}\n/* eslint-enable no-redeclare */\n\n\nvar Recoil_selectorFamily = selectorFamily;\n\n// @fb-only: const {parameterizedScopedAtomLegacy} = require('Recoil_ScopedAtom');\n\n\nconst {\n DEFAULT_VALUE: DEFAULT_VALUE$5,\n DefaultValue: DefaultValue$3,\n setConfigDeletionHandler: setConfigDeletionHandler$3\n} = Recoil_Node;\n/*\nA function which returns an atom based on the input parameter.\n\nEach unique parameter returns a unique atom. E.g.,\n\n const f = atomFamily(...);\n f({a: 1}) => an atom\n f({a: 2}) => a different atom\n\nThis allows components to persist local, private state using atoms. Each\ninstance of the component may have a different key, which it uses as the\nparameter for a family of atoms; in this way, each component will have\nits own atom not shared by other instances. These state keys may be composed\ninto children's state keys as well.\n*/\n\n\nfunction atomFamily(options) {\n var _options$cachePolicyF;\n\n const atomCache = Recoil_cacheFromPolicy((_options$cachePolicyF = options.cachePolicyForParams_UNSTABLE) !== null && _options$cachePolicyF !== void 0 ? _options$cachePolicyF : {\n equality: 'value',\n eviction: 'none'\n }); // An atom to represent any legacy atoms that we can upgrade to an atomFamily\n\n const legacyAtomOptions = {\n key: options.key,\n // Legacy atoms just used the plain key directly\n default: DEFAULT_VALUE$5,\n persistence_UNSTABLE: options.persistence_UNSTABLE\n };\n let legacyAtom; // prettier-ignore\n // @fb-only: if (\n // @fb-only: options.scopeRules_APPEND_ONLY_READ_THE_DOCS\n // @fb-only: ) {\n // @fb-only: legacyAtom = parameterizedScopedAtomLegacy({\n // @fb-only: ...legacyAtomOptions,\n // @fb-only: scopeRules_APPEND_ONLY_READ_THE_DOCS:\n // @fb-only: options.scopeRules_APPEND_ONLY_READ_THE_DOCS,\n // @fb-only: });\n // @fb-only: } else {\n\n legacyAtom = Recoil_atom(legacyAtomOptions); // @fb-only: }\n // Selector to calculate the default value based on any persisted legacy atoms\n // that were upgraded to a atomFamily\n\n const atomFamilyDefault = Recoil_selectorFamily({\n key: `${options.key}__atomFamily/Default`,\n get: param => ({\n get\n }) => {\n const legacyValue = get(typeof legacyAtom === 'function' ? legacyAtom(param) : legacyAtom); // Atom was upgraded from a non-parameterized atom\n\n if (!(legacyValue instanceof DefaultValue$3)) {\n return legacyValue;\n } // There's no legacy atom value, so use the user-specified default\n\n\n return typeof options.default === 'function' ? // The default was parameterized\n // Flow doesn't know that T isn't a function, so we need to case to any\n options.default(param) // flowlint-line unclear-type:off\n : // Default may be a static value, promise, or RecoilValue\n options.default;\n },\n dangerouslyAllowMutability: options.dangerouslyAllowMutability,\n retainedBy_UNSTABLE: options.retainedBy_UNSTABLE\n }); // Simple atomFamily implementation to cache individual atoms based\n // on the parameter value equality.\n\n return params => {\n var _stableStringify;\n\n const cachedAtom = atomCache.get(params);\n\n if (cachedAtom != null) {\n return cachedAtom;\n }\n\n const {\n cachePolicyForParams_UNSTABLE,\n ...atomOptions\n } = options;\n const newAtom = Recoil_atom({ ...atomOptions,\n key: `${options.key}__${(_stableStringify = Recoil_stableStringify(params)) !== null && _stableStringify !== void 0 ? _stableStringify : 'void'}`,\n default: atomFamilyDefault(params),\n retainedBy_UNSTABLE: typeof options.retainedBy_UNSTABLE === 'function' ? options.retainedBy_UNSTABLE(params) : options.retainedBy_UNSTABLE,\n effects_UNSTABLE: typeof options.effects_UNSTABLE === 'function' ? options.effects_UNSTABLE(params) : options.effects_UNSTABLE // prettier-ignore\n // @fb-only: scopeRules_APPEND_ONLY_READ_THE_DOCS: mapScopeRules(\n // @fb-only: options.scopeRules_APPEND_ONLY_READ_THE_DOCS,\n // @fb-only: params,\n // @fb-only: ),\n\n });\n atomCache.set(params, newAtom);\n setConfigDeletionHandler$3(newAtom.key, () => {\n atomCache.delete(params);\n });\n return newAtom;\n };\n}\n\nvar Recoil_atomFamily = atomFamily;\n\n// flowlint-next-line unclear-type:off\n\n\nconst constantSelector = Recoil_selectorFamily({\n key: '__constant',\n get: constant => () => constant,\n cachePolicyForParams_UNSTABLE: {\n equality: 'reference'\n }\n}); // Function that returns a selector which always produces the\n// same constant value. It may be called multiple times with the\n// same value, based on reference equality, and will provide the\n// same selector.\n\nfunction constSelector(constant) {\n return constantSelector(constant);\n}\n\nvar Recoil_constSelector = constSelector;\n\n// flowlint-next-line unclear-type:off\n\n\nconst throwingSelector = Recoil_selectorFamily({\n key: '__error',\n get: message => () => {\n throw new Error(message);\n },\n cachePolicyForParams_UNSTABLE: {\n equality: 'reference'\n }\n}); // Function that returns a selector which always throws an error\n// with the provided message.\n\nfunction errorSelector(message) {\n return throwingSelector(message);\n}\n\nvar Recoil_errorSelector = errorSelector;\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * Wraps another recoil value and prevents writing to it.\n *\n * @emails oncall+recoil\n * \n * @format\n */\n\nfunction readOnlySelector(atom) {\n // flowlint-next-line unclear-type: off\n return atom;\n}\n\nvar Recoil_readOnlySelector = readOnlySelector;\n\nconst {\n loadableWithError: loadableWithError$3,\n loadableWithPromise: loadableWithPromise$3,\n loadableWithValue: loadableWithValue$3\n} = Recoil_Loadable;\n\n\n\n /////////////////\n// TRUTH TABLE\n/////////////////\n// Dependencies waitForNone waitForAny waitForAll waitForAllSettled\n// [loading, loading] [Promise, Promise] Promise Promise Promise\n// [value, loading] [value, Promise] [value, Promise] Promise Promise\n// [value, value] [value, value] [value, value] [value, value] [value, value]\n//\n// [error, loading] [Error, Promise] [Error, Promise] Error Promise\n// [error, error] [Error, Error] [Error, Error] Error [error, error]\n// [value, error] [value, Error] [value, Error] Error [value, error]\n// Issue parallel requests for all dependencies and return the current\n// status if they have results, have some error, or are still pending.\n\n\nfunction concurrentRequests(getRecoilValue, deps) {\n const results = Array(deps.length).fill(undefined);\n const exceptions = Array(deps.length).fill(undefined);\n\n for (const [i, dep] of deps.entries()) {\n try {\n results[i] = getRecoilValue(dep);\n } catch (e) {\n // exceptions can either be Promises of pending results or real errors\n exceptions[i] = e;\n }\n }\n\n return [results, exceptions];\n}\n\nfunction isError(exp) {\n return exp != null && !Recoil_isPromise(exp);\n}\n\nfunction unwrapDependencies(dependencies) {\n return Array.isArray(dependencies) ? dependencies : Object.getOwnPropertyNames(dependencies).map(key => dependencies[key]);\n}\n\nfunction getValueFromLoadablePromiseResult(result) {\n if (result != null && typeof result === 'object' && result.hasOwnProperty('__value')) {\n return result.__value;\n }\n\n return result;\n}\n\nfunction wrapResults(dependencies, results) {\n return Array.isArray(dependencies) ? results : // Object.getOwnPropertyNames() has consistent key ordering with ES6\n Object.getOwnPropertyNames(dependencies).reduce((out, key, idx) => ({ ...out,\n [key]: results[idx]\n }), {});\n}\n\nfunction wrapLoadables(dependencies, results, exceptions) {\n const output = exceptions.map((exception, idx) => exception == null ? loadableWithValue$3(results[idx]) : Recoil_isPromise(exception) ? loadableWithPromise$3(exception) : loadableWithError$3(exception));\n return wrapResults(dependencies, output);\n}\n\nfunction combineAsyncResultsWithSyncResults(syncResults, asyncResults) {\n return asyncResults.map((result, idx) =>\n /**\n * it's important we use === undefined as opposed to == null, because the\n * resolved value of the async promise could be `null`, in which case we\n * don't want to use syncResults[idx], which would be undefined. If async\n * promise resolves to `undefined`, that's ok because `syncResults[idx]`\n * will also be `undefined`. That's a little hacky, but it works.\n */\n result === undefined ? syncResults[idx] : result);\n} // Selector that requests all dependencies in parallel and immediately returns\n// current results without waiting.\n\n\nconst waitForNone = Recoil_selectorFamily({\n key: '__waitForNone',\n get: dependencies => ({\n get\n }) => {\n // Issue requests for all dependencies in parallel.\n const deps = unwrapDependencies(dependencies);\n const [results, exceptions] = concurrentRequests(get, deps); // Always return the current status of the results; never block.\n\n return wrapLoadables(dependencies, results, exceptions);\n }\n}); // Selector that requests all dependencies in parallel and waits for at least\n// one to be available before returning results. It will only error if all\n// dependencies have errors.\n\nconst waitForAny = Recoil_selectorFamily({\n key: '__waitForAny',\n get: dependencies => ({\n get\n }) => {\n // Issue requests for all dependencies in parallel.\n // Exceptions can either be Promises of pending results or real errors\n const deps = unwrapDependencies(dependencies);\n const [results, exceptions] = concurrentRequests(get, deps); // If any results are available, value or error, return the current status\n\n if (exceptions.some(exp => !Recoil_isPromise(exp))) {\n return wrapLoadables(dependencies, results, exceptions);\n } // Otherwise, return a promise that will resolve when the next result is\n // available, whichever one happens to be next. But, if all pending\n // dependencies end up with errors, then reject the promise.\n\n\n return new Promise(resolve => {\n for (const [i, exp] of exceptions.entries()) {\n if (Recoil_isPromise(exp)) {\n exp.then(result => {\n results[i] = getValueFromLoadablePromiseResult(result);\n exceptions[i] = undefined;\n resolve(wrapLoadables(dependencies, results, exceptions));\n }).catch(error => {\n exceptions[i] = error;\n resolve(wrapLoadables(dependencies, results, exceptions));\n });\n }\n }\n });\n }\n}); // Selector that requests all dependencies in parallel and waits for all to be\n// available before returning a value. It will error if any dependencies error.\n\nconst waitForAll = Recoil_selectorFamily({\n key: '__waitForAll',\n get: dependencies => ({\n get\n }) => {\n // Issue requests for all dependencies in parallel.\n // Exceptions can either be Promises of pending results or real errors\n const deps = unwrapDependencies(dependencies);\n const [results, exceptions] = concurrentRequests(get, deps); // If all results are available, return the results\n\n if (exceptions.every(exp => exp == null)) {\n return wrapResults(dependencies, results);\n } // If we have any errors, throw the first error\n\n\n const error = exceptions.find(isError);\n\n if (error != null) {\n throw error;\n } // Otherwise, return a promise that will resolve when all results are available\n\n\n return Promise.all(exceptions).then(exceptionResults => wrapResults(dependencies, combineAsyncResultsWithSyncResults(results, exceptionResults).map(getValueFromLoadablePromiseResult)));\n }\n});\nconst waitForAllSettled = Recoil_selectorFamily({\n key: '__waitForAllSettled',\n get: dependencies => ({\n get\n }) => {\n // Issue requests for all dependencies in parallel.\n // Exceptions can either be Promises of pending results or real errors\n const deps = unwrapDependencies(dependencies);\n const [results, exceptions] = concurrentRequests(get, deps); // If all results are available, return the results\n\n if (exceptions.every(exp => !Recoil_isPromise(exp))) {\n return wrapLoadables(dependencies, results, exceptions);\n } // Wait for all results to settle\n\n\n return Promise.all(exceptions.map((exp, i) => Recoil_isPromise(exp) ? exp.then(result => {\n results[i] = getValueFromLoadablePromiseResult(result);\n exceptions[i] = undefined;\n }).catch(error => {\n results[i] = undefined;\n exceptions[i] = error;\n }) : null)) // Then wrap them as loadables\n .then(() => wrapLoadables(dependencies, results, exceptions));\n }\n});\nconst noWait = Recoil_selectorFamily({\n key: '__noWait',\n get: dependency => ({\n get\n }) => {\n try {\n return loadableWithValue$3(get(dependency));\n } catch (exception) {\n return Recoil_isPromise(exception) ? loadableWithPromise$3(exception) : loadableWithError$3(exception);\n }\n }\n});\nvar Recoil_WaitFor = {\n waitForNone,\n waitForAny,\n waitForAll,\n waitForAllSettled,\n noWait\n};\n\nconst {\n batchUpdates: batchUpdates$3,\n setBatcher: setBatcher$1\n} = Recoil_Batching;\n\nconst {\n DefaultValue: DefaultValue$4\n} = Recoil_Node;\n\nconst {\n RecoilRoot: RecoilRoot$2\n} = Recoil_RecoilRoot_react;\n\nconst {\n isRecoilValue: isRecoilValue$5\n} = Recoil_RecoilValue$1;\n\nconst {\n retentionZone: retentionZone$1\n} = Recoil_RetentionZone;\n\nconst {\n freshSnapshot: freshSnapshot$2\n} = Recoil_Snapshot$1;\n\nconst {\n useGotoRecoilSnapshot: useGotoRecoilSnapshot$1,\n useRecoilCallback: useRecoilCallback$1,\n useRecoilSnapshot: useRecoilSnapshot$1,\n useRecoilState: useRecoilState$1,\n useRecoilStateLoadable: useRecoilStateLoadable$1,\n useRecoilTransactionObserver: useRecoilTransactionObserver$1,\n useRecoilValue: useRecoilValue$1,\n useRecoilValueLoadable: useRecoilValueLoadable$1,\n useResetRecoilState: useResetRecoilState$1,\n useRetain: useRetain$1,\n useSetRecoilState: useSetRecoilState$1,\n useSetUnvalidatedAtomValues: useSetUnvalidatedAtomValues$1,\n useTransactionObservation_DEPRECATED: useTransactionObservation_DEPRECATED$1\n} = Recoil_Hooks;\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst {\n noWait: noWait$1,\n waitForAll: waitForAll$1,\n waitForAllSettled: waitForAllSettled$1,\n waitForAny: waitForAny$1,\n waitForNone: waitForNone$1\n} = Recoil_WaitFor;\n\nvar Recoil_index = {\n // Types\n DefaultValue: DefaultValue$4,\n // Components\n RecoilRoot: RecoilRoot$2,\n useRecoilBridgeAcrossReactRoots_UNSTABLE: Recoil_useRecoilBridgeAcrossReactRoots,\n // RecoilValues\n atom: Recoil_atom,\n selector: Recoil_selector,\n // Other factories\n retentionZone: retentionZone$1,\n // Convenience RecoilValues\n atomFamily: Recoil_atomFamily,\n selectorFamily: Recoil_selectorFamily,\n constSelector: Recoil_constSelector,\n errorSelector: Recoil_errorSelector,\n readOnlySelector: Recoil_readOnlySelector,\n // Hooks that accept RecoilValues\n useRecoilValue: useRecoilValue$1,\n useRecoilValueLoadable: useRecoilValueLoadable$1,\n useRecoilState: useRecoilState$1,\n useRecoilStateLoadable: useRecoilStateLoadable$1,\n useSetRecoilState: useSetRecoilState$1,\n useResetRecoilState: useResetRecoilState$1,\n useGetRecoilValueInfo_UNSTABLE: Recoil_useGetRecoilValueInfo,\n useRetain: useRetain$1,\n // Hooks for asynchronous Recoil\n useRecoilCallback: useRecoilCallback$1,\n // Hooks for Snapshots\n useGotoRecoilSnapshot: useGotoRecoilSnapshot$1,\n useRecoilSnapshot: useRecoilSnapshot$1,\n useRecoilTransactionObserver_UNSTABLE: useRecoilTransactionObserver$1,\n useTransactionObservation_UNSTABLE: useTransactionObservation_DEPRECATED$1,\n useSetUnvalidatedAtomValues_UNSTABLE: useSetUnvalidatedAtomValues$1,\n // Concurrency Helpers\n noWait: noWait$1,\n waitForNone: waitForNone$1,\n waitForAny: waitForAny$1,\n waitForAll: waitForAll$1,\n waitForAllSettled: waitForAllSettled$1,\n // Other functions\n isRecoilValue: isRecoilValue$5,\n // Batching\n batchUpdates: batchUpdates$3,\n setBatcher: setBatcher$1,\n // Snapshot Utils\n snapshot_UNSTABLE: freshSnapshot$2\n};\nvar Recoil_index_1 = Recoil_index.DefaultValue;\nvar Recoil_index_2 = Recoil_index.RecoilRoot;\nvar Recoil_index_3 = Recoil_index.useRecoilBridgeAcrossReactRoots_UNSTABLE;\nvar Recoil_index_4 = Recoil_index.atom;\nvar Recoil_index_5 = Recoil_index.selector;\nvar Recoil_index_6 = Recoil_index.retentionZone;\nvar Recoil_index_7 = Recoil_index.atomFamily;\nvar Recoil_index_8 = Recoil_index.selectorFamily;\nvar Recoil_index_9 = Recoil_index.constSelector;\nvar Recoil_index_10 = Recoil_index.errorSelector;\nvar Recoil_index_11 = Recoil_index.readOnlySelector;\nvar Recoil_index_12 = Recoil_index.useRecoilValue;\nvar Recoil_index_13 = Recoil_index.useRecoilValueLoadable;\nvar Recoil_index_14 = Recoil_index.useRecoilState;\nvar Recoil_index_15 = Recoil_index.useRecoilStateLoadable;\nvar Recoil_index_16 = Recoil_index.useSetRecoilState;\nvar Recoil_index_17 = Recoil_index.useResetRecoilState;\nvar Recoil_index_18 = Recoil_index.useGetRecoilValueInfo_UNSTABLE;\nvar Recoil_index_19 = Recoil_index.useRetain;\nvar Recoil_index_20 = Recoil_index.useRecoilCallback;\nvar Recoil_index_21 = Recoil_index.useGotoRecoilSnapshot;\nvar Recoil_index_22 = Recoil_index.useRecoilSnapshot;\nvar Recoil_index_23 = Recoil_index.useRecoilTransactionObserver_UNSTABLE;\nvar Recoil_index_24 = Recoil_index.useTransactionObservation_UNSTABLE;\nvar Recoil_index_25 = Recoil_index.useSetUnvalidatedAtomValues_UNSTABLE;\nvar Recoil_index_26 = Recoil_index.noWait;\nvar Recoil_index_27 = Recoil_index.waitForNone;\nvar Recoil_index_28 = Recoil_index.waitForAny;\nvar Recoil_index_29 = Recoil_index.waitForAll;\nvar Recoil_index_30 = Recoil_index.waitForAllSettled;\nvar Recoil_index_31 = Recoil_index.isRecoilValue;\nvar Recoil_index_32 = Recoil_index.batchUpdates;\nvar Recoil_index_33 = Recoil_index.setBatcher;\nvar Recoil_index_34 = Recoil_index.snapshot_UNSTABLE;\n\nexport default Recoil_index;\nexport { Recoil_index_1 as DefaultValue, Recoil_index_2 as RecoilRoot, Recoil_index_4 as atom, Recoil_index_7 as atomFamily, Recoil_index_32 as batchUpdates, Recoil_index_9 as constSelector, Recoil_index_10 as errorSelector, Recoil_index_31 as isRecoilValue, Recoil_index_26 as noWait, Recoil_index_11 as readOnlySelector, Recoil_index_6 as retentionZone, Recoil_index_5 as selector, Recoil_index_8 as selectorFamily, Recoil_index_33 as setBatcher, Recoil_index_34 as snapshot_UNSTABLE, Recoil_index_18 as useGetRecoilValueInfo_UNSTABLE, Recoil_index_21 as useGotoRecoilSnapshot, Recoil_index_3 as useRecoilBridgeAcrossReactRoots_UNSTABLE, Recoil_index_20 as useRecoilCallback, Recoil_index_22 as useRecoilSnapshot, Recoil_index_14 as useRecoilState, Recoil_index_15 as useRecoilStateLoadable, Recoil_index_23 as useRecoilTransactionObserver_UNSTABLE, Recoil_index_12 as useRecoilValue, Recoil_index_13 as useRecoilValueLoadable, Recoil_index_17 as useResetRecoilState, Recoil_index_19 as useRetain, Recoil_index_16 as useSetRecoilState, Recoil_index_25 as useSetUnvalidatedAtomValues_UNSTABLE, Recoil_index_24 as useTransactionObservation_UNSTABLE, Recoil_index_29 as waitForAll, Recoil_index_30 as waitForAllSettled, Recoil_index_28 as waitForAny, Recoil_index_27 as waitForNone };\n"],"sourceRoot":""}