jotai
Version:
👻 Next gen state management that will spook you
1,242 lines (1,220 loc) • 42.5 kB
JavaScript
var jotai = require('jotai');
var utils = require('jotai/vanilla/utils');
var react = require('react');
function atomWithReset(initialValue) {
var anAtom = jotai.atom(initialValue, function (get, set, update) {
var nextValue = typeof update === 'function' ? update(get(anAtom)) : update;
set(anAtom, nextValue === utils.RESET ? initialValue : nextValue);
});
return anAtom;
}
function _regeneratorRuntime() {
_regeneratorRuntime = function () {
return exports;
};
var exports = {},
Op = Object.prototype,
hasOwn = Op.hasOwnProperty,
defineProperty = Object.defineProperty || function (obj, key, desc) {
obj[key] = desc.value;
},
$Symbol = "function" == typeof Symbol ? Symbol : {},
iteratorSymbol = $Symbol.iterator || "@@iterator",
asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator",
toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag";
function define(obj, key, value) {
return Object.defineProperty(obj, key, {
value: value,
enumerable: !0,
configurable: !0,
writable: !0
}), obj[key];
}
try {
define({}, "");
} catch (err) {
define = function (obj, key, value) {
return obj[key] = value;
};
}
function wrap(innerFn, outerFn, self, tryLocsList) {
var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator,
generator = Object.create(protoGenerator.prototype),
context = new Context(tryLocsList || []);
return defineProperty(generator, "_invoke", {
value: makeInvokeMethod(innerFn, self, context)
}), generator;
}
function tryCatch(fn, obj, arg) {
try {
return {
type: "normal",
arg: fn.call(obj, arg)
};
} catch (err) {
return {
type: "throw",
arg: err
};
}
}
exports.wrap = wrap;
var ContinueSentinel = {};
function Generator() {}
function GeneratorFunction() {}
function GeneratorFunctionPrototype() {}
var IteratorPrototype = {};
define(IteratorPrototype, iteratorSymbol, function () {
return this;
});
var getProto = Object.getPrototypeOf,
NativeIteratorPrototype = getProto && getProto(getProto(values([])));
NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype);
var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);
function defineIteratorMethods(prototype) {
["next", "throw", "return"].forEach(function (method) {
define(prototype, method, function (arg) {
return this._invoke(method, arg);
});
});
}
function AsyncIterator(generator, PromiseImpl) {
function invoke(method, arg, resolve, reject) {
var record = tryCatch(generator[method], generator, arg);
if ("throw" !== record.type) {
var result = record.arg,
value = result.value;
return value && "object" == typeof value && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) {
invoke("next", value, resolve, reject);
}, function (err) {
invoke("throw", err, resolve, reject);
}) : PromiseImpl.resolve(value).then(function (unwrapped) {
result.value = unwrapped, resolve(result);
}, function (error) {
return invoke("throw", error, resolve, reject);
});
}
reject(record.arg);
}
var previousPromise;
defineProperty(this, "_invoke", {
value: function (method, arg) {
function callInvokeWithMethodAndArg() {
return new PromiseImpl(function (resolve, reject) {
invoke(method, arg, resolve, reject);
});
}
return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();
}
});
}
function makeInvokeMethod(innerFn, self, context) {
var state = "suspendedStart";
return function (method, arg) {
if ("executing" === state) throw new Error("Generator is already running");
if ("completed" === state) {
if ("throw" === method) throw arg;
return doneResult();
}
for (context.method = method, context.arg = arg;;) {
var delegate = context.delegate;
if (delegate) {
var delegateResult = maybeInvokeDelegate(delegate, context);
if (delegateResult) {
if (delegateResult === ContinueSentinel) continue;
return delegateResult;
}
}
if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) {
if ("suspendedStart" === state) throw state = "completed", context.arg;
context.dispatchException(context.arg);
} else "return" === context.method && context.abrupt("return", context.arg);
state = "executing";
var record = tryCatch(innerFn, self, context);
if ("normal" === record.type) {
if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue;
return {
value: record.arg,
done: context.done
};
}
"throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg);
}
};
}
function maybeInvokeDelegate(delegate, context) {
var methodName = context.method,
method = delegate.iterator[methodName];
if (undefined === method) return context.delegate = null, "throw" === methodName && delegate.iterator.return && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method) || "return" !== methodName && (context.method = "throw", context.arg = new TypeError("The iterator does not provide a '" + methodName + "' method")), ContinueSentinel;
var record = tryCatch(method, delegate.iterator, context.arg);
if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel;
var info = record.arg;
return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel);
}
function pushTryEntry(locs) {
var entry = {
tryLoc: locs[0]
};
1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry);
}
function resetTryEntry(entry) {
var record = entry.completion || {};
record.type = "normal", delete record.arg, entry.completion = record;
}
function Context(tryLocsList) {
this.tryEntries = [{
tryLoc: "root"
}], tryLocsList.forEach(pushTryEntry, this), this.reset(!0);
}
function values(iterable) {
if (iterable) {
var iteratorMethod = iterable[iteratorSymbol];
if (iteratorMethod) return iteratorMethod.call(iterable);
if ("function" == typeof iterable.next) return iterable;
if (!isNaN(iterable.length)) {
var i = -1,
next = function next() {
for (; ++i < iterable.length;) if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next;
return next.value = undefined, next.done = !0, next;
};
return next.next = next;
}
}
return {
next: doneResult
};
}
function doneResult() {
return {
value: undefined,
done: !0
};
}
return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", {
value: GeneratorFunctionPrototype,
configurable: !0
}), defineProperty(GeneratorFunctionPrototype, "constructor", {
value: GeneratorFunction,
configurable: !0
}), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) {
var ctor = "function" == typeof genFun && genFun.constructor;
return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name));
}, exports.mark = function (genFun) {
return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun;
}, exports.awrap = function (arg) {
return {
__await: arg
};
}, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () {
return this;
}), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) {
void 0 === PromiseImpl && (PromiseImpl = Promise);
var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);
return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) {
return result.done ? result.value : iter.next();
});
}, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () {
return this;
}), define(Gp, "toString", function () {
return "[object Generator]";
}), exports.keys = function (val) {
var object = Object(val),
keys = [];
for (var key in object) keys.push(key);
return keys.reverse(), function next() {
for (; keys.length;) {
var key = keys.pop();
if (key in object) return next.value = key, next.done = !1, next;
}
return next.done = !0, next;
};
}, exports.values = values, Context.prototype = {
constructor: Context,
reset: function (skipTempReset) {
if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined);
},
stop: function () {
this.done = !0;
var rootRecord = this.tryEntries[0].completion;
if ("throw" === rootRecord.type) throw rootRecord.arg;
return this.rval;
},
dispatchException: function (exception) {
if (this.done) throw exception;
var context = this;
function handle(loc, caught) {
return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught;
}
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
var entry = this.tryEntries[i],
record = entry.completion;
if ("root" === entry.tryLoc) return handle("end");
if (entry.tryLoc <= this.prev) {
var hasCatch = hasOwn.call(entry, "catchLoc"),
hasFinally = hasOwn.call(entry, "finallyLoc");
if (hasCatch && hasFinally) {
if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);
if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);
} else if (hasCatch) {
if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);
} else {
if (!hasFinally) throw new Error("try statement without catch or finally");
if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);
}
}
}
},
abrupt: function (type, arg) {
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
var entry = this.tryEntries[i];
if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) {
var finallyEntry = entry;
break;
}
}
finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null);
var record = finallyEntry ? finallyEntry.completion : {};
return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record);
},
complete: function (record, afterLoc) {
if ("throw" === record.type) throw record.arg;
return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel;
},
finish: function (finallyLoc) {
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
var entry = this.tryEntries[i];
if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel;
}
},
catch: function (tryLoc) {
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
var entry = this.tryEntries[i];
if (entry.tryLoc === tryLoc) {
var record = entry.completion;
if ("throw" === record.type) {
var thrown = record.arg;
resetTryEntry(entry);
}
return thrown;
}
}
throw new Error("illegal catch attempt");
},
delegateYield: function (iterable, resultName, nextLoc) {
return this.delegate = {
iterator: values(iterable),
resultName: resultName,
nextLoc: nextLoc
}, "next" === this.method && (this.arg = undefined), ContinueSentinel;
}
}, exports;
}
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
try {
var info = gen[key](arg);
var value = info.value;
} catch (error) {
reject(error);
return;
}
if (info.done) {
resolve(value);
} else {
Promise.resolve(value).then(_next, _throw);
}
}
function _asyncToGenerator(fn) {
return function () {
var self = this,
args = arguments;
return new Promise(function (resolve, reject) {
var gen = fn.apply(self, args);
function _next(value) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
}
function _throw(err) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
}
_next(undefined);
});
};
}
function _extends() {
_extends = Object.assign ? Object.assign.bind() : function (target) {
for (var i = 1; i < arguments.length; i++) {
var source = arguments[i];
for (var key in source) {
if (Object.prototype.hasOwnProperty.call(source, key)) {
target[key] = source[key];
}
}
}
return target;
};
return _extends.apply(this, arguments);
}
function _unsupportedIterableToArray(o, minLen) {
if (!o) return;
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
var n = Object.prototype.toString.call(o).slice(8, -1);
if (n === "Object" && o.constructor) n = o.constructor.name;
if (n === "Map" || n === "Set") return Array.from(o);
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
}
function _arrayLikeToArray(arr, len) {
if (len == null || len > arr.length) len = arr.length;
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
return arr2;
}
function _createForOfIteratorHelperLoose(o, allowArrayLike) {
var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
if (it) return (it = it.call(o)).next.bind(it);
if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
if (it) o = it;
var i = 0;
return function () {
if (i >= o.length) return {
done: true
};
return {
done: false,
value: o[i++]
};
};
}
throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
var WRITE_ATOM = 'w';
var RESTORE_ATOMS = 'h';
function useResetAtom(anAtom, scope) {
var ScopeContext = jotai.SECRET_INTERNAL_getScopeContext(scope);
var store = react.useContext(ScopeContext).s;
var setAtom = react.useCallback(function () {
return store[WRITE_ATOM](anAtom, utils.RESET);
}, [store, anAtom]);
return setAtom;
}
function useReducerAtom(anAtom, reducer, scope) {
var _useAtom = jotai.useAtom(anAtom, scope),
state = _useAtom[0],
setState = _useAtom[1];
var dispatch = react.useCallback(function (action) {
setState(function (prev) {
return reducer(prev, action);
});
}, [setState, reducer]);
return [state, dispatch];
}
function atomWithReducer(initialValue, reducer) {
var anAtom = jotai.atom(initialValue, function (get, set, action) {
return set(anAtom, reducer(get(anAtom), action));
});
return anAtom;
}
function atomFamily(initializeAtom, areEqual) {
var shouldRemove = null;
var atoms = new Map();
var createAtom = function createAtom(param) {
var item;
if (areEqual === undefined) {
item = atoms.get(param);
} else {
for (var _iterator = _createForOfIteratorHelperLoose(atoms), _step; !(_step = _iterator()).done;) {
var _step$value = _step.value,
key = _step$value[0],
value = _step$value[1];
if (areEqual(key, param)) {
item = value;
break;
}
}
}
if (item !== undefined) {
if (shouldRemove != null && shouldRemove(item[1], param)) {
createAtom.remove(param);
} else {
return item[0];
}
}
var newAtom = initializeAtom(param);
atoms.set(param, [newAtom, Date.now()]);
return newAtom;
};
createAtom.remove = function (param) {
if (areEqual === undefined) {
atoms.delete(param);
} else {
for (var _iterator2 = _createForOfIteratorHelperLoose(atoms), _step2; !(_step2 = _iterator2()).done;) {
var _step2$value = _step2.value,
key = _step2$value[0];
if (areEqual(key, param)) {
atoms.delete(key);
break;
}
}
}
};
createAtom.setShouldRemove = function (fn) {
shouldRemove = fn;
if (!shouldRemove) return;
for (var _iterator3 = _createForOfIteratorHelperLoose(atoms), _step3; !(_step3 = _iterator3()).done;) {
var _step3$value = _step3.value,
key = _step3$value[0],
value = _step3$value[1];
if (shouldRemove(value[1], key)) {
atoms.delete(key);
}
}
};
return createAtom;
}
var getWeakCacheItem = function getWeakCacheItem(cache, deps) {
do {
var _deps = deps,
dep = _deps[0],
rest = _deps.slice(1);
var entry = cache.get(dep);
if (!entry) {
return;
}
if (!rest.length) {
return entry[1];
}
cache = entry[0];
deps = rest;
} while (deps.length);
};
var setWeakCacheItem = function setWeakCacheItem(cache, deps, item) {
do {
var _deps2 = deps,
dep = _deps2[0],
rest = _deps2.slice(1);
var entry = cache.get(dep);
if (!entry) {
entry = [new WeakMap()];
cache.set(dep, entry);
}
if (!rest.length) {
entry[1] = item;
return;
}
cache = entry[0];
deps = rest;
} while (deps.length);
};
var createMemoizeAtom = function createMemoizeAtom() {
var cache = new WeakMap();
var memoizeAtom = function memoizeAtom(createAtom, deps) {
var cachedAtom = getWeakCacheItem(cache, deps);
if (cachedAtom) {
return cachedAtom;
}
var createdAtom = createAtom();
setWeakCacheItem(cache, deps, createdAtom);
return createdAtom;
};
return memoizeAtom;
};
var memoizeAtom$4 = createMemoizeAtom();
function selectAtom(anAtom, selector, equalityFn) {
if (equalityFn === void 0) {
equalityFn = Object.is;
}
return memoizeAtom$4(function () {
var refAtom = jotai.atom(function () {
return {};
});
var derivedAtom = jotai.atom(function (get) {
var slice = selector(get(anAtom));
var ref = get(refAtom);
if ('prev' in ref && equalityFn(ref.prev, slice)) {
return ref.prev;
}
ref.prev = slice;
return slice;
});
return derivedAtom;
}, [anAtom, selector, equalityFn]);
}
function useAtomCallback(callback, scope) {
var anAtom = react.useMemo(function () {
return jotai.atom(null, function (get, set, _ref) {
var arg = _ref[0],
resolve = _ref[1],
reject = _ref[2];
try {
resolve(callback(get, set, arg));
} catch (e) {
reject(e);
}
});
}, [callback]);
var invoke = jotai.useSetAtom(anAtom, scope);
return react.useCallback(function (arg) {
var isSync = true;
var settled = {};
var promise = new Promise(function (resolve, reject) {
invoke([arg, function (v) {
if (isSync) {
settled = {
v: v
};
} else {
resolve(v);
}
}, function (e) {
if (isSync) {
settled = {
e: e
};
} else {
reject(e);
}
}]);
});
isSync = false;
if ('e' in settled) {
throw settled.e;
}
if ('v' in settled) {
return settled.v;
}
return promise;
}, [invoke]);
}
var memoizeAtom$3 = createMemoizeAtom();
var deepFreeze = function deepFreeze(obj) {
if (typeof obj !== 'object' || obj === null) return;
Object.freeze(obj);
var propNames = Object.getOwnPropertyNames(obj);
for (var _iterator = _createForOfIteratorHelperLoose(propNames), _step; !(_step = _iterator()).done;) {
var name = _step.value;
var value = obj[name];
deepFreeze(value);
}
return obj;
};
function freezeAtom(anAtom) {
return memoizeAtom$3(function () {
var frozenAtom = jotai.atom(function (get) {
return deepFreeze(get(anAtom));
}, function (_get, set, arg) {
return set(anAtom, arg);
});
return frozenAtom;
}, [anAtom]);
}
function freezeAtomCreator(createAtom) {
return function () {
var anAtom = createAtom.apply(void 0, arguments);
var origRead = anAtom.read;
anAtom.read = function (get) {
return deepFreeze(origRead(get));
};
return anAtom;
};
}
var memoizeAtom$2 = createMemoizeAtom();
var isWritable = function isWritable(atom) {
return !!atom.write;
};
var isFunction = function isFunction(x) {
return typeof x === 'function';
};
function splitAtom(arrAtom, keyExtractor) {
return memoizeAtom$2(function () {
var mappingCache = new WeakMap();
var getMapping = function getMapping(arr, prev) {
var mapping = mappingCache.get(arr);
if (mapping) {
return mapping;
}
var prevMapping = prev && mappingCache.get(prev);
var atomList = [];
var keyList = [];
arr.forEach(function (item, index) {
var key = keyExtractor ? keyExtractor(item) : index;
keyList[index] = key;
var cachedAtom = prevMapping && prevMapping.atomList[prevMapping.keyList.indexOf(key)];
if (cachedAtom) {
atomList[index] = cachedAtom;
return;
}
var read = function read(get) {
var ref = get(refAtom);
var currArr = get(arrAtom);
var mapping = getMapping(currArr, ref.prev);
var index = mapping.keyList.indexOf(key);
if (index < 0 || index >= currArr.length) {
var prevItem = arr[getMapping(arr).keyList.indexOf(key)];
if (prevItem) {
return prevItem;
}
throw new Error('splitAtom: index out of bounds for read');
}
return currArr[index];
};
var write = function write(get, set, update) {
var ref = get(refAtom);
var arr = get(arrAtom);
var mapping = getMapping(arr, ref.prev);
var index = mapping.keyList.indexOf(key);
if (index < 0 || index >= arr.length) {
throw new Error('splitAtom: index out of bounds for write');
}
var nextItem = isFunction(update) ? update(arr[index]) : update;
set(arrAtom, [].concat(arr.slice(0, index), [nextItem], arr.slice(index + 1)));
};
atomList[index] = isWritable(arrAtom) ? jotai.atom(read, write) : jotai.atom(read);
});
if (prevMapping && prevMapping.keyList.length === keyList.length && prevMapping.keyList.every(function (x, i) {
return x === keyList[i];
})) {
mapping = prevMapping;
} else {
mapping = {
atomList: atomList,
keyList: keyList
};
}
mappingCache.set(arr, mapping);
return mapping;
};
var refAtom = jotai.atom(function () {
return {};
});
var read = function read(get) {
var ref = get(refAtom);
var arr = get(arrAtom);
var mapping = getMapping(arr, ref.prev);
ref.prev = arr;
return mapping.atomList;
};
var write = function write(get, set, action) {
if ('read' in action) {
console.warn('atomToRemove is deprecated. use action with type');
action = {
type: 'remove',
atom: action
};
}
switch (action.type) {
case 'remove':
{
var index = get(splittedAtom).indexOf(action.atom);
if (index >= 0) {
var arr = get(arrAtom);
set(arrAtom, [].concat(arr.slice(0, index), arr.slice(index + 1)));
}
break;
}
case 'insert':
{
var _index = action.before ? get(splittedAtom).indexOf(action.before) : get(splittedAtom).length;
if (_index >= 0) {
var _arr = get(arrAtom);
set(arrAtom, [].concat(_arr.slice(0, _index), [action.value], _arr.slice(_index)));
}
break;
}
case 'move':
{
var index1 = get(splittedAtom).indexOf(action.atom);
var index2 = action.before ? get(splittedAtom).indexOf(action.before) : get(splittedAtom).length;
if (index1 >= 0 && index2 >= 0) {
var _arr2 = get(arrAtom);
if (index1 < index2) {
set(arrAtom, [].concat(_arr2.slice(0, index1), _arr2.slice(index1 + 1, index2), [_arr2[index1]], _arr2.slice(index2)));
} else {
set(arrAtom, [].concat(_arr2.slice(0, index2), [_arr2[index1]], _arr2.slice(index2, index1), _arr2.slice(index1 + 1)));
}
}
break;
}
}
};
var splittedAtom = isWritable(arrAtom) ? jotai.atom(read, write) : jotai.atom(read);
return splittedAtom;
}, keyExtractor ? [arrAtom, keyExtractor] : [arrAtom]);
}
function atomWithDefault(getDefault) {
var EMPTY = Symbol();
var overwrittenAtom = jotai.atom(EMPTY);
var anAtom = jotai.atom(function (get) {
var overwritten = get(overwrittenAtom);
if (overwritten !== EMPTY) {
return overwritten;
}
return getDefault(get);
}, function (get, set, update) {
if (update === utils.RESET) {
return set(overwrittenAtom, EMPTY);
}
return set(overwrittenAtom, typeof update === 'function' ? update(get(anAtom)) : update);
});
return anAtom;
}
var memoizeAtom$1 = createMemoizeAtom();
var emptyArrayAtom = jotai.atom(function () {
return [];
});
function waitForAll(atoms) {
var createAtom = function createAtom() {
var unwrappedAtoms = unwrapAtoms(atoms);
var derivedAtom = jotai.atom(function (get) {
var promises = [];
var values = unwrappedAtoms.map(function (anAtom, index) {
try {
return get(anAtom);
} catch (e) {
if (e instanceof Promise) {
promises[index] = e;
} else {
throw e;
}
}
});
if (promises.length) {
throw Promise.all(promises);
}
return wrapResults(atoms, values);
});
return derivedAtom;
};
if (Array.isArray(atoms)) {
if (atoms.length) {
return memoizeAtom$1(createAtom, atoms);
}
return emptyArrayAtom;
}
return createAtom();
}
var unwrapAtoms = function unwrapAtoms(atoms) {
return Array.isArray(atoms) ? atoms : Object.getOwnPropertyNames(atoms).map(function (key) {
return atoms[key];
});
};
var wrapResults = function wrapResults(atoms, results) {
return Array.isArray(atoms) ? results : Object.getOwnPropertyNames(atoms).reduce(function (out, key, idx) {
var _extends2;
return _extends({}, out, (_extends2 = {}, _extends2[key] = results[idx], _extends2));
}, {});
};
function createJSONStorage(getStringStorage) {
var lastStr;
var lastValue;
var storage = {
getItem: function getItem(key) {
var _getStringStorage$get, _getStringStorage;
var parse = function parse(str) {
str = str || '';
if (lastStr !== str) {
try {
lastValue = JSON.parse(str);
} catch (_unused) {
return utils.unstable_NO_STORAGE_VALUE;
}
lastStr = str;
}
return lastValue;
};
var str = (_getStringStorage$get = (_getStringStorage = getStringStorage()) == null ? void 0 : _getStringStorage.getItem(key)) != null ? _getStringStorage$get : null;
if (str instanceof Promise) {
return str.then(parse);
}
return parse(str);
},
setItem: function setItem(key, newValue) {
var _getStringStorage2;
return (_getStringStorage2 = getStringStorage()) == null ? void 0 : _getStringStorage2.setItem(key, JSON.stringify(newValue));
},
removeItem: function removeItem(key) {
var _getStringStorage3;
return (_getStringStorage3 = getStringStorage()) == null ? void 0 : _getStringStorage3.removeItem(key);
}
};
if (typeof window !== 'undefined' && typeof window.addEventListener === 'function') {
storage.subscribe = function (key, callback) {
var storageEventCallback = function storageEventCallback(e) {
if (e.key === key && e.newValue) {
callback(JSON.parse(e.newValue));
}
};
window.addEventListener('storage', storageEventCallback);
return function () {
window.removeEventListener('storage', storageEventCallback);
};
};
}
return storage;
}
var defaultStorage = createJSONStorage(function () {
return typeof window !== 'undefined' ? window.localStorage : undefined;
});
function atomWithStorage(key, initialValue, storage) {
if (storage === void 0) {
storage = defaultStorage;
}
var getInitialValue = function getInitialValue() {
var value = storage.getItem(key);
if (value instanceof Promise) {
return value.then(function (v) {
return v === utils.unstable_NO_STORAGE_VALUE ? initialValue : v;
});
}
return value === utils.unstable_NO_STORAGE_VALUE ? initialValue : value;
};
var baseAtom = jotai.atom(storage.delayInit ? initialValue : getInitialValue());
baseAtom.onMount = function (setAtom) {
var unsub;
if (storage.subscribe) {
unsub = storage.subscribe(key, setAtom);
setAtom(getInitialValue());
}
if (storage.delayInit) {
var _value = getInitialValue();
if (_value instanceof Promise) {
_value.then(setAtom);
} else {
setAtom(_value);
}
}
return unsub;
};
var anAtom = jotai.atom(function (get) {
return get(baseAtom);
}, function (get, set, update) {
var nextValue = typeof update === 'function' ? update(get(baseAtom)) : update;
if (nextValue === utils.RESET) {
set(baseAtom, initialValue);
return storage.removeItem(key);
}
set(baseAtom, nextValue);
return storage.setItem(key, nextValue);
});
return anAtom;
}
function atomWithHash(key, initialValue, options) {
var serialize = (options == null ? void 0 : options.serialize) || JSON.stringify;
var deserialize = (options == null ? void 0 : options.deserialize) || function (str) {
try {
return JSON.parse(str || '');
} catch (_unused2) {
return utils.unstable_NO_STORAGE_VALUE;
}
};
var _subscribe = (options == null ? void 0 : options.subscribe) || function (callback) {
window.addEventListener('hashchange', callback);
return function () {
window.removeEventListener('hashchange', callback);
};
};
var hashStorage = _extends({
getItem: function getItem(key) {
if (typeof location === 'undefined') {
return utils.unstable_NO_STORAGE_VALUE;
}
var searchParams = new URLSearchParams(location.hash.slice(1));
var storedValue = searchParams.get(key);
return deserialize(storedValue);
},
setItem: function setItem(key, newValue) {
var searchParams = new URLSearchParams(location.hash.slice(1));
searchParams.set(key, serialize(newValue));
if (options != null && options.replaceState) {
history.replaceState(null, '', location.pathname + location.search + '#' + searchParams.toString());
} else {
location.hash = searchParams.toString();
}
},
removeItem: function removeItem(key) {
var searchParams = new URLSearchParams(location.hash.slice(1));
searchParams.delete(key);
if (options != null && options.replaceState) {
history.replaceState(null, '', location.pathname + location.search + '#' + searchParams.toString());
} else {
location.hash = searchParams.toString();
}
}
}, (options == null ? void 0 : options.delayInit) && {
delayInit: true
}, {
subscribe: function subscribe(key, setValue) {
var callback = function callback() {
var searchParams = new URLSearchParams(location.hash.slice(1));
var str = searchParams.get(key);
if (str !== null) {
setValue(deserialize(str));
} else {
setValue(initialValue);
}
};
return _subscribe(callback);
}
});
return atomWithStorage(key, initialValue, hashStorage);
}
function atomWithObservable(getObservable, options) {
var observableResultAtom = jotai.atom(function (get) {
var _observable$Symbol$ob, _observable;
var observable = getObservable(get);
var itself = (_observable$Symbol$ob = (_observable = observable)[Symbol.observable]) == null ? void 0 : _observable$Symbol$ob.call(_observable);
if (itself) {
observable = itself;
}
var resolve;
var makePending = function makePending() {
return new Promise(function (r) {
resolve = r;
});
};
var initialResult = options && 'initialValue' in options ? {
d: typeof options.initialValue === 'function' ? options.initialValue() : options.initialValue
} : makePending();
var setResult;
var lastResult;
var listener = function listener(result) {
lastResult = result;
resolve == null ? void 0 : resolve(result);
setResult == null ? void 0 : setResult(result);
};
var subscription;
var timer;
var isNotMounted = function isNotMounted() {
return !setResult;
};
var start = function start() {
if (subscription) {
clearTimeout(timer);
subscription.unsubscribe();
}
subscription = observable.subscribe({
next: function next(d) {
return listener({
d: d
});
},
error: function error(e) {
return listener({
e: e
});
},
complete: function complete() {}
});
if (isNotMounted() && options != null && options.unstable_timeout) {
timer = setTimeout(function () {
if (subscription) {
subscription.unsubscribe();
subscription = undefined;
}
}, options.unstable_timeout);
}
};
start();
var resultAtom = jotai.atom(lastResult || initialResult);
resultAtom.onMount = function (update) {
setResult = update;
if (lastResult) {
update(lastResult);
}
if (subscription) {
clearTimeout(timer);
} else {
start();
}
return function () {
setResult = undefined;
if (subscription) {
subscription.unsubscribe();
subscription = undefined;
}
};
};
return [resultAtom, observable, makePending, start, isNotMounted];
});
var observableAtom = jotai.atom(function (get) {
var _get = get(observableResultAtom),
resultAtom = _get[0];
var result = get(resultAtom);
if ('e' in result) {
throw result.e;
}
return result.d;
}, function (get, set, data) {
var _get2 = get(observableResultAtom),
resultAtom = _get2[0],
observable = _get2[1],
makePending = _get2[2],
start = _get2[3],
isNotMounted = _get2[4];
if ('next' in observable) {
if (isNotMounted()) {
set(resultAtom, makePending());
start();
}
observable.next(data);
} else {
throw new Error('observable is not subject');
}
});
return observableAtom;
}
var hydratedMap = new WeakMap();
function useHydrateAtoms(values, scope) {
var ScopeContext = jotai.SECRET_INTERNAL_getScopeContext(scope);
var scopeContainer = react.useContext(ScopeContext);
var store = scopeContainer.s;
var hydratedSet = getHydratedSet(scopeContainer);
var tuplesToRestore = [];
for (var _iterator = _createForOfIteratorHelperLoose(values), _step; !(_step = _iterator()).done;) {
var tuple = _step.value;
var atom = tuple[0];
if (!hydratedSet.has(atom)) {
hydratedSet.add(atom);
tuplesToRestore.push(tuple);
}
}
if (tuplesToRestore.length) {
store[RESTORE_ATOMS](tuplesToRestore);
}
}
function getHydratedSet(scopeContainer) {
var hydratedSet = hydratedMap.get(scopeContainer);
if (!hydratedSet) {
hydratedSet = new WeakSet();
hydratedMap.set(scopeContainer, hydratedSet);
}
return hydratedSet;
}
var memoizeAtom = createMemoizeAtom();
var LOADING = {
state: 'loading'
};
function loadable(anAtom) {
return memoizeAtom(function () {
var loadableAtomCache = new WeakMap();
var catchAtom = jotai.atom(function (get) {
var promise;
try {
var data = get(anAtom);
var _loadableAtom = jotai.atom({
state: 'hasData',
data: data
});
return _loadableAtom;
} catch (error) {
if (error instanceof Promise) {
promise = error;
} else {
var _loadableAtom2 = jotai.atom({
state: 'hasError',
error: error
});
return _loadableAtom2;
}
}
var cached = loadableAtomCache.get(promise);
if (cached) {
return cached;
}
var loadableAtom = jotai.atom(LOADING, function () {
var _ref = _asyncToGenerator(_regeneratorRuntime().mark(function _callee(get, set) {
var _data;
return _regeneratorRuntime().wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.prev = 0;
_context.next = 3;
return get(anAtom, {
unstable_promise: true
});
case 3:
_data = _context.sent;
set(loadableAtom, {
state: 'hasData',
data: _data
});
_context.next = 10;
break;
case 7:
_context.prev = 7;
_context.t0 = _context["catch"](0);
set(loadableAtom, {
state: 'hasError',
error: _context.t0
});
case 10:
case "end":
return _context.stop();
}
}
}, _callee, null, [[0, 7]]);
}));
return function (_x, _x2) {
return _ref.apply(this, arguments);
};
}());
loadableAtom.onMount = function (init) {
init();
};
loadableAtomCache.set(promise, loadableAtom);
return loadableAtom;
});
var derivedAtom = jotai.atom(function (get) {
var loadableAtom = get(catchAtom);
return get(loadableAtom);
});
return derivedAtom;
}, [anAtom]);
}
function abortableAtom(read, write) {
return jotai.atom(function (get) {
var controller = new AbortController();
var promise = read(get, {
signal: controller.signal
});
if (promise instanceof Promise) {
jotai.SECRET_INTERNAL_registerPromiseAbort(promise, function () {
return controller.abort();
});
}
return promise;
}, write);
}
Object.defineProperty(exports, 'useAtomValue', {
enumerable: true,
get: function () { return jotai.useAtomValue; }
});
Object.defineProperty(exports, 'useUpdateAtom', {
enumerable: true,
get: function () { return jotai.useSetAtom; }
});
Object.defineProperty(exports, 'RESET', {
enumerable: true,
get: function () { return utils.RESET; }
});
Object.defineProperty(exports, 'unstable_NO_STORAGE_VALUE', {
enumerable: true,
get: function () { return utils.unstable_NO_STORAGE_VALUE; }
});
exports.abortableAtom = abortableAtom;
exports.atomFamily = atomFamily;
exports.atomWithDefault = atomWithDefault;
exports.atomWithHash = atomWithHash;
exports.atomWithObservable = atomWithObservable;
exports.atomWithReducer = atomWithReducer;
exports.atomWithReset = atomWithReset;
exports.atomWithStorage = atomWithStorage;
exports.createJSONStorage = createJSONStorage;
exports.freezeAtom = freezeAtom;
exports.freezeAtomCreator = freezeAtomCreator;
exports.loadable = loadable;
exports.selectAtom = selectAtom;
exports.splitAtom = splitAtom;
exports.useAtomCallback = useAtomCallback;
exports.useHydrateAtoms = useHydrateAtoms;
exports.useReducerAtom = useReducerAtom;
exports.useResetAtom = useResetAtom;
exports.waitForAll = waitForAll;
;