UNPKG

26.8 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, '__esModule', { value: true });
4
5var jotai = require('jotai');
6var react = require('react');
7
8var RESET = Symbol();
9
10function atomWithReset(initialValue) {
11 var anAtom = jotai.atom(initialValue, function (get, set, update) {
12 if (update === RESET) {
13 set(anAtom, initialValue);
14 } else {
15 set(anAtom, typeof update === 'function' ? update(get(anAtom)) : update);
16 }
17 });
18 return anAtom;
19}
20
21function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
22 try {
23 var info = gen[key](arg);
24 var value = info.value;
25 } catch (error) {
26 reject(error);
27 return;
28 }
29
30 if (info.done) {
31 resolve(value);
32 } else {
33 Promise.resolve(value).then(_next, _throw);
34 }
35}
36
37function _asyncToGenerator(fn) {
38 return function () {
39 var self = this,
40 args = arguments;
41 return new Promise(function (resolve, reject) {
42 var gen = fn.apply(self, args);
43
44 function _next(value) {
45 asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
46 }
47
48 function _throw(err) {
49 asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
50 }
51
52 _next(undefined);
53 });
54 };
55}
56
57function _extends() {
58 _extends = Object.assign || function (target) {
59 for (var i = 1; i < arguments.length; i++) {
60 var source = arguments[i];
61
62 for (var key in source) {
63 if (Object.prototype.hasOwnProperty.call(source, key)) {
64 target[key] = source[key];
65 }
66 }
67 }
68
69 return target;
70 };
71
72 return _extends.apply(this, arguments);
73}
74
75function _unsupportedIterableToArray(o, minLen) {
76 if (!o) return;
77 if (typeof o === "string") return _arrayLikeToArray(o, minLen);
78 var n = Object.prototype.toString.call(o).slice(8, -1);
79 if (n === "Object" && o.constructor) n = o.constructor.name;
80 if (n === "Map" || n === "Set") return Array.from(o);
81 if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
82}
83
84function _arrayLikeToArray(arr, len) {
85 if (len == null || len > arr.length) len = arr.length;
86
87 for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
88
89 return arr2;
90}
91
92function _createForOfIteratorHelperLoose(o, allowArrayLike) {
93 var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
94 if (it) return (it = it.call(o)).next.bind(it);
95
96 if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
97 if (it) o = it;
98 var i = 0;
99 return function () {
100 if (i >= o.length) return {
101 done: true
102 };
103 return {
104 done: false,
105 value: o[i++]
106 };
107 };
108 }
109
110 throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
111}
112
113var WRITE_ATOM = 'w';
114var RESTORE_ATOMS = 'h';
115
116function useResetAtom(anAtom, scope) {
117 var ScopeContext = jotai.SECRET_INTERNAL_getScopeContext(scope);
118 var store = react.useContext(ScopeContext).s;
119 var setAtom = react.useCallback(function () {
120 return store[WRITE_ATOM](anAtom, RESET);
121 }, [store, anAtom]);
122 return setAtom;
123}
124
125function useReducerAtom(anAtom, reducer, scope) {
126 var _useAtom = jotai.useAtom(anAtom, scope),
127 state = _useAtom[0],
128 setState = _useAtom[1];
129
130 var dispatch = react.useCallback(function (action) {
131 setState(function (prev) {
132 return reducer(prev, action);
133 });
134 }, [setState, reducer]);
135 return [state, dispatch];
136}
137
138function atomWithReducer(initialValue, reducer) {
139 var anAtom = jotai.atom(initialValue, function (get, set, action) {
140 return set(anAtom, reducer(get(anAtom), action));
141 });
142 return anAtom;
143}
144
145function atomFamily(initializeAtom, areEqual) {
146 var shouldRemove = null;
147 var atoms = new Map();
148
149 var createAtom = function createAtom(param) {
150 var item;
151
152 if (areEqual === undefined) {
153 item = atoms.get(param);
154 } else {
155 for (var _iterator = _createForOfIteratorHelperLoose(atoms), _step; !(_step = _iterator()).done;) {
156 var _step$value = _step.value,
157 key = _step$value[0],
158 value = _step$value[1];
159
160 if (areEqual(key, param)) {
161 item = value;
162 break;
163 }
164 }
165 }
166
167 if (item !== undefined) {
168 if (shouldRemove != null && shouldRemove(item[1], param)) {
169 atoms.delete(param);
170 } else {
171 return item[0];
172 }
173 }
174
175 var newAtom = initializeAtom(param);
176 atoms.set(param, [newAtom, Date.now()]);
177 return newAtom;
178 };
179
180 createAtom.remove = function (param) {
181 if (areEqual === undefined) {
182 atoms.delete(param);
183 } else {
184 for (var _iterator2 = _createForOfIteratorHelperLoose(atoms), _step2; !(_step2 = _iterator2()).done;) {
185 var _step2$value = _step2.value,
186 key = _step2$value[0];
187
188 if (areEqual(key, param)) {
189 atoms.delete(key);
190 break;
191 }
192 }
193 }
194 };
195
196 createAtom.setShouldRemove = function (fn) {
197 shouldRemove = fn;
198 if (!shouldRemove) return;
199
200 for (var _iterator3 = _createForOfIteratorHelperLoose(atoms), _step3; !(_step3 = _iterator3()).done;) {
201 var _step3$value = _step3.value,
202 key = _step3$value[0],
203 value = _step3$value[1];
204
205 if (shouldRemove(value[1], key)) {
206 atoms.delete(key);
207 }
208 }
209 };
210
211 return createAtom;
212}
213
214var getWeakCacheItem = function getWeakCacheItem(cache, deps) {
215 do {
216 var _deps = deps,
217 dep = _deps[0],
218 rest = _deps.slice(1);
219
220 var entry = cache.get(dep);
221
222 if (!entry) {
223 return;
224 }
225
226 if (!rest.length) {
227 return entry[1];
228 }
229
230 cache = entry[0];
231 deps = rest;
232 } while (deps.length);
233};
234
235var setWeakCacheItem = function setWeakCacheItem(cache, deps, item) {
236 do {
237 var _deps2 = deps,
238 dep = _deps2[0],
239 rest = _deps2.slice(1);
240
241 var entry = cache.get(dep);
242
243 if (!entry) {
244 entry = [new WeakMap()];
245 cache.set(dep, entry);
246 }
247
248 if (!rest.length) {
249 entry[1] = item;
250 return;
251 }
252
253 cache = entry[0];
254 deps = rest;
255 } while (deps.length);
256};
257
258var createMemoizeAtom = function createMemoizeAtom() {
259 var cache = new WeakMap();
260
261 var memoizeAtom = function memoizeAtom(createAtom, deps) {
262 var cachedAtom = getWeakCacheItem(cache, deps);
263
264 if (cachedAtom) {
265 return cachedAtom;
266 }
267
268 var createdAtom = createAtom();
269 setWeakCacheItem(cache, deps, createdAtom);
270 return createdAtom;
271 };
272
273 return memoizeAtom;
274};
275
276var memoizeAtom$4 = createMemoizeAtom();
277function selectAtom(anAtom, selector, equalityFn) {
278 if (equalityFn === void 0) {
279 equalityFn = Object.is;
280 }
281
282 return memoizeAtom$4(function () {
283 var refAtom = jotai.atom(function () {
284 return {};
285 });
286 var derivedAtom = jotai.atom(function (get) {
287 var slice = selector(get(anAtom));
288 var ref = get(refAtom);
289
290 if ('prev' in ref && equalityFn(ref.prev, slice)) {
291 return ref.prev;
292 }
293
294 ref.prev = slice;
295 return slice;
296 });
297 return derivedAtom;
298 }, [anAtom, selector, equalityFn]);
299}
300
301function useAtomCallback(callback, scope) {
302 var anAtom = react.useMemo(function () {
303 return jotai.atom(null, function (get, set, _ref) {
304 var arg = _ref[0],
305 resolve = _ref[1],
306 reject = _ref[2];
307
308 try {
309 resolve(callback(get, set, arg));
310 } catch (e) {
311 reject(e);
312 }
313 });
314 }, [callback]);
315 var invoke = jotai.useSetAtom(anAtom, scope);
316 return react.useCallback(function (arg) {
317 var isSync = true;
318 var settled = {};
319 var promise = new Promise(function (resolve, reject) {
320 invoke([arg, function (v) {
321 if (isSync) {
322 settled = {
323 v: v
324 };
325 } else {
326 resolve(v);
327 }
328 }, function (e) {
329 if (isSync) {
330 settled = {
331 e: e
332 };
333 } else {
334 reject(e);
335 }
336 }]);
337 });
338 isSync = false;
339
340 if ('e' in settled) {
341 throw settled.e;
342 }
343
344 if ('v' in settled) {
345 return settled.v;
346 }
347
348 return promise;
349 }, [invoke]);
350}
351
352var memoizeAtom$3 = createMemoizeAtom();
353
354var deepFreeze = function deepFreeze(obj) {
355 if (typeof obj !== 'object' || obj === null) return;
356 Object.freeze(obj);
357 var propNames = Object.getOwnPropertyNames(obj);
358
359 for (var _iterator = _createForOfIteratorHelperLoose(propNames), _step; !(_step = _iterator()).done;) {
360 var name = _step.value;
361 var value = obj[name];
362 deepFreeze(value);
363 }
364
365 return obj;
366};
367
368function freezeAtom(anAtom) {
369 return memoizeAtom$3(function () {
370 var frozenAtom = jotai.atom(function (get) {
371 return deepFreeze(get(anAtom));
372 }, function (_get, set, arg) {
373 return set(anAtom, arg);
374 });
375 return frozenAtom;
376 }, [anAtom]);
377}
378function freezeAtomCreator(createAtom) {
379 return function () {
380 var anAtom = createAtom.apply(void 0, arguments);
381 var origRead = anAtom.read;
382
383 anAtom.read = function (get) {
384 return deepFreeze(origRead(get));
385 };
386
387 return anAtom;
388 };
389}
390
391var memoizeAtom$2 = createMemoizeAtom();
392
393var isWritable = function isWritable(atom) {
394 return !!atom.write;
395};
396
397var isFunction = function isFunction(x) {
398 return typeof x === 'function';
399};
400
401function splitAtom(arrAtom, keyExtractor) {
402 return memoizeAtom$2(function () {
403 var mappingCache = new WeakMap();
404
405 var getMapping = function getMapping(arr, prev) {
406 var mapping = mappingCache.get(arr);
407
408 if (mapping) {
409 return mapping;
410 }
411
412 var prevMapping = prev && mappingCache.get(prev);
413 var atomList = [];
414 var keyList = [];
415 arr.forEach(function (item, index) {
416 var key = keyExtractor ? keyExtractor(item) : index;
417 keyList[index] = key;
418 var cachedAtom = prevMapping && prevMapping.atomList[prevMapping.keyList.indexOf(key)];
419
420 if (cachedAtom) {
421 atomList[index] = cachedAtom;
422 return;
423 }
424
425 var read = function read(get) {
426 var ref = get(refAtom);
427 var currArr = get(arrAtom);
428 var mapping = getMapping(currArr, ref.prev);
429 var index = mapping.keyList.indexOf(key);
430
431 if (index < 0 || index >= currArr.length) {
432 var prevItem = arr[getMapping(arr).keyList.indexOf(key)];
433
434 if (prevItem) {
435 return prevItem;
436 }
437
438 throw new Error('splitAtom: index out of bounds for read');
439 }
440
441 return currArr[index];
442 };
443
444 var write = function write(get, set, update) {
445 var ref = get(refAtom);
446 var arr = get(arrAtom);
447 var mapping = getMapping(arr, ref.prev);
448 var index = mapping.keyList.indexOf(key);
449
450 if (index < 0 || index >= arr.length) {
451 throw new Error('splitAtom: index out of bounds for write');
452 }
453
454 var nextItem = isFunction(update) ? update(arr[index]) : update;
455 set(arrAtom, [].concat(arr.slice(0, index), [nextItem], arr.slice(index + 1)));
456 };
457
458 atomList[index] = isWritable(arrAtom) ? jotai.atom(read, write) : jotai.atom(read);
459 });
460
461 if (prevMapping && prevMapping.keyList.length === keyList.length && prevMapping.keyList.every(function (x, i) {
462 return x === keyList[i];
463 })) {
464 mapping = prevMapping;
465 } else {
466 mapping = {
467 atomList: atomList,
468 keyList: keyList
469 };
470 }
471
472 mappingCache.set(arr, mapping);
473 return mapping;
474 };
475
476 var refAtom = jotai.atom(function () {
477 return {};
478 });
479
480 var read = function read(get) {
481 var ref = get(refAtom);
482 var arr = get(arrAtom);
483 var mapping = getMapping(arr, ref.prev);
484 ref.prev = arr;
485 return mapping.atomList;
486 };
487
488 var write = function write(get, set, action) {
489 if ('read' in action) {
490 console.warn('atomToRemove is deprecated. use action with type');
491 action = {
492 type: 'remove',
493 atom: action
494 };
495 }
496
497 switch (action.type) {
498 case 'remove':
499 {
500 var index = get(splittedAtom).indexOf(action.atom);
501
502 if (index >= 0) {
503 var arr = get(arrAtom);
504 set(arrAtom, [].concat(arr.slice(0, index), arr.slice(index + 1)));
505 }
506
507 break;
508 }
509
510 case 'insert':
511 {
512 var _index = action.before ? get(splittedAtom).indexOf(action.before) : get(splittedAtom).length;
513
514 if (_index >= 0) {
515 var _arr = get(arrAtom);
516
517 set(arrAtom, [].concat(_arr.slice(0, _index), [action.value], _arr.slice(_index)));
518 }
519
520 break;
521 }
522
523 case 'move':
524 {
525 var index1 = get(splittedAtom).indexOf(action.atom);
526 var index2 = action.before ? get(splittedAtom).indexOf(action.before) : get(splittedAtom).length;
527
528 if (index1 >= 0 && index2 >= 0) {
529 var _arr2 = get(arrAtom);
530
531 if (index1 < index2) {
532 set(arrAtom, [].concat(_arr2.slice(0, index1), _arr2.slice(index1 + 1, index2), [_arr2[index1]], _arr2.slice(index2)));
533 } else {
534 set(arrAtom, [].concat(_arr2.slice(0, index2), [_arr2[index1]], _arr2.slice(index2, index1), _arr2.slice(index1 + 1)));
535 }
536 }
537
538 break;
539 }
540 }
541 };
542
543 var splittedAtom = isWritable(arrAtom) ? jotai.atom(read, write) : jotai.atom(read);
544 return splittedAtom;
545 }, keyExtractor ? [arrAtom, keyExtractor] : [arrAtom]);
546}
547
548function atomWithDefault(getDefault) {
549 var EMPTY = Symbol();
550 var overwrittenAtom = jotai.atom(EMPTY);
551 var anAtom = jotai.atom(function (get) {
552 var overwritten = get(overwrittenAtom);
553
554 if (overwritten !== EMPTY) {
555 return overwritten;
556 }
557
558 return getDefault(get);
559 }, function (get, set, update) {
560 if (update === RESET) {
561 return set(overwrittenAtom, EMPTY);
562 }
563
564 return set(overwrittenAtom, typeof update === 'function' ? update(get(anAtom)) : update);
565 });
566 return anAtom;
567}
568
569var memoizeAtom$1 = createMemoizeAtom();
570function waitForAll(atoms) {
571 var createAtom = function createAtom() {
572 var unwrappedAtoms = unwrapAtoms(atoms);
573 var derivedAtom = jotai.atom(function (get) {
574 var promises = [];
575 var values = unwrappedAtoms.map(function (anAtom, index) {
576 try {
577 return get(anAtom);
578 } catch (e) {
579 if (e instanceof Promise) {
580 promises[index] = e;
581 } else {
582 throw e;
583 }
584 }
585 });
586
587 if (promises.length) {
588 throw Promise.all(promises);
589 }
590
591 return wrapResults(atoms, values);
592 });
593 return derivedAtom;
594 };
595
596 if (Array.isArray(atoms)) {
597 return memoizeAtom$1(createAtom, atoms);
598 }
599
600 return createAtom();
601}
602
603var unwrapAtoms = function unwrapAtoms(atoms) {
604 return Array.isArray(atoms) ? atoms : Object.getOwnPropertyNames(atoms).map(function (key) {
605 return atoms[key];
606 });
607};
608
609var wrapResults = function wrapResults(atoms, results) {
610 return Array.isArray(atoms) ? results : Object.getOwnPropertyNames(atoms).reduce(function (out, key, idx) {
611 var _extends2;
612
613 return _extends({}, out, (_extends2 = {}, _extends2[key] = results[idx], _extends2));
614 }, {});
615};
616
617function createJSONStorage(getStringStorage) {
618 var lastStr;
619 var lastValue;
620 return {
621 getItem: function getItem(key) {
622 var parse = function parse(str) {
623 str = str || '';
624
625 if (lastStr !== str) {
626 lastValue = JSON.parse(str);
627 lastStr = str;
628 }
629
630 return lastValue;
631 };
632
633 var str = getStringStorage().getItem(key);
634
635 if (str instanceof Promise) {
636 return str.then(parse);
637 }
638
639 return parse(str);
640 },
641 setItem: function setItem(key, newValue) {
642 return getStringStorage().setItem(key, JSON.stringify(newValue));
643 },
644 removeItem: function removeItem(key) {
645 return getStringStorage().removeItem(key);
646 }
647 };
648}
649var defaultStorage = createJSONStorage(function () {
650 return localStorage;
651});
652
653defaultStorage.subscribe = function (key, callback) {
654 var storageEventCallback = function storageEventCallback(e) {
655 if (e.key === key && e.newValue) {
656 callback(JSON.parse(e.newValue));
657 }
658 };
659
660 window.addEventListener('storage', storageEventCallback);
661 return function () {
662 window.removeEventListener('storage', storageEventCallback);
663 };
664};
665
666function atomWithStorage(key, initialValue, storage) {
667 if (storage === void 0) {
668 storage = defaultStorage;
669 }
670
671 var getInitialValue = function getInitialValue() {
672 try {
673 var _value = storage.getItem(key);
674
675 if (_value instanceof Promise) {
676 return _value.catch(function () {
677 return initialValue;
678 });
679 }
680
681 return _value;
682 } catch (_unused) {
683 return initialValue;
684 }
685 };
686
687 var baseAtom = jotai.atom(storage.delayInit ? initialValue : getInitialValue());
688
689 baseAtom.onMount = function (setAtom) {
690 var unsub;
691
692 if (storage.subscribe) {
693 unsub = storage.subscribe(key, setAtom);
694 setAtom(getInitialValue());
695 }
696
697 if (storage.delayInit) {
698 var _value2 = getInitialValue();
699
700 if (_value2 instanceof Promise) {
701 _value2.then(setAtom);
702 } else {
703 setAtom(_value2);
704 }
705 }
706
707 return unsub;
708 };
709
710 var anAtom = jotai.atom(function (get) {
711 return get(baseAtom);
712 }, function (get, set, update) {
713 if (update === RESET) {
714 set(baseAtom, initialValue);
715 return storage.removeItem(key);
716 }
717
718 var newValue = typeof update === 'function' ? update(get(baseAtom)) : update;
719 set(baseAtom, newValue);
720 return storage.setItem(key, newValue);
721 });
722 return anAtom;
723}
724function atomWithHash(key, initialValue, options) {
725 var serialize = (options == null ? void 0 : options.serialize) || JSON.stringify;
726 var deserialize = (options == null ? void 0 : options.deserialize) || JSON.parse;
727
728 var _subscribe = (options == null ? void 0 : options.subscribe) || function (callback) {
729 window.addEventListener('hashchange', callback);
730 return function () {
731 window.removeEventListener('hashchange', callback);
732 };
733 };
734
735 var hashStorage = _extends({
736 getItem: function getItem(key) {
737 var searchParams = new URLSearchParams(location.hash.slice(1));
738 var storedValue = searchParams.get(key);
739
740 if (storedValue === null) {
741 throw new Error('no value stored');
742 }
743
744 return deserialize(storedValue);
745 },
746 setItem: function setItem(key, newValue) {
747 var searchParams = new URLSearchParams(location.hash.slice(1));
748 searchParams.set(key, serialize(newValue));
749
750 if (options != null && options.replaceState) {
751 history.replaceState(null, '', '#' + searchParams.toString());
752 } else {
753 location.hash = searchParams.toString();
754 }
755 },
756 removeItem: function removeItem(key) {
757 var searchParams = new URLSearchParams(location.hash.slice(1));
758 searchParams.delete(key);
759
760 if (options != null && options.replaceState) {
761 history.replaceState(null, '', '#' + searchParams.toString());
762 } else {
763 location.hash = searchParams.toString();
764 }
765 }
766 }, (options == null ? void 0 : options.delayInit) && {
767 delayInit: true
768 }, {
769 subscribe: function subscribe(key, setValue) {
770 var callback = function callback() {
771 var searchParams = new URLSearchParams(location.hash.slice(1));
772 var str = searchParams.get(key);
773
774 if (str !== null) {
775 setValue(deserialize(str));
776 } else {
777 setValue(initialValue);
778 }
779 };
780
781 return _subscribe(callback);
782 }
783 });
784
785 return atomWithStorage(key, initialValue, hashStorage);
786}
787
788function atomWithObservable(createObservable, options) {
789 var observableResultAtom = jotai.atom(function (get) {
790 var _observable$Symbol$ob, _observable;
791
792 var observable = createObservable(get);
793 var itself = (_observable$Symbol$ob = (_observable = observable)[Symbol.observable]) == null ? void 0 : _observable$Symbol$ob.call(_observable);
794
795 if (itself) {
796 observable = itself;
797 }
798
799 var dataAtom = jotai.atom(options != null && options.initialValue ? getInitialValue(options) : firstValueFrom(observable));
800
801 var setData = function setData() {
802 throw new Error('setting data without mount');
803 };
804
805 var dataListener = function dataListener(data) {
806 setData(data);
807 };
808
809 var errorListener = function errorListener(error) {
810 setData(Promise.reject(error));
811 };
812
813 var subscription = null;
814
815 dataAtom.onMount = function (update) {
816 setData = update;
817
818 if (!subscription) {
819 subscription = observable.subscribe(dataListener, errorListener);
820 }
821
822 return function () {
823 var _subscription;
824
825 (_subscription = subscription) == null ? void 0 : _subscription.unsubscribe();
826 subscription = null;
827 };
828 };
829
830 return {
831 dataAtom: dataAtom,
832 observable: observable
833 };
834 });
835 var observableAtom = jotai.atom(function (get) {
836 var _get = get(observableResultAtom),
837 dataAtom = _get.dataAtom;
838
839 return get(dataAtom);
840 }, function (get, _set, data) {
841 var _get2 = get(observableResultAtom),
842 observable = _get2.observable;
843
844 if ('next' in observable) {
845 observable.next(data);
846 } else {
847 throw new Error('observable is not subject');
848 }
849 });
850 return observableAtom;
851}
852
853function getInitialValue(options) {
854 var initialValue = options.initialValue;
855 return initialValue instanceof Function ? initialValue() : initialValue;
856}
857
858function firstValueFrom(source) {
859 return new Promise(function (resolve, reject) {
860 var resolved = false;
861 var subscription = source.subscribe({
862 next: function next(value) {
863 resolve(value);
864 resolved = true;
865
866 if (subscription) {
867 subscription.unsubscribe();
868 }
869 },
870 error: reject,
871 complete: function complete() {
872 reject();
873 }
874 });
875
876 if (resolved) {
877 subscription.unsubscribe();
878 }
879 });
880}
881
882var hydratedMap = new WeakMap();
883function useHydrateAtoms(values, scope) {
884 var ScopeContext = jotai.SECRET_INTERNAL_getScopeContext(scope);
885 var scopeContainer = react.useContext(ScopeContext);
886 var store = scopeContainer.s;
887 var hydratedSet = getHydratedSet(scopeContainer);
888 var tuplesToRestore = [];
889
890 for (var _iterator = _createForOfIteratorHelperLoose(values), _step; !(_step = _iterator()).done;) {
891 var tuple = _step.value;
892 var atom = tuple[0];
893
894 if (!hydratedSet.has(atom)) {
895 hydratedSet.add(atom);
896 tuplesToRestore.push(tuple);
897 }
898 }
899
900 if (tuplesToRestore.length) {
901 store[RESTORE_ATOMS](tuplesToRestore);
902 }
903}
904
905function getHydratedSet(scopeContainer) {
906 var hydratedSet = hydratedMap.get(scopeContainer);
907
908 if (!hydratedSet) {
909 hydratedSet = new WeakSet();
910 hydratedMap.set(scopeContainer, hydratedSet);
911 }
912
913 return hydratedSet;
914}
915
916var memoizeAtom = createMemoizeAtom();
917var LOADING = {
918 state: 'loading'
919};
920function loadable(anAtom) {
921 return memoizeAtom(function () {
922 var loadableAtomCache = new WeakMap();
923 var catchAtom = jotai.atom(function (get) {
924 var promise;
925
926 try {
927 var data = get(anAtom);
928
929 var _loadableAtom = jotai.atom({
930 state: 'hasData',
931 data: data
932 });
933
934 return _loadableAtom;
935 } catch (error) {
936 if (error instanceof Promise) {
937 promise = error;
938 } else {
939 var _loadableAtom2 = jotai.atom({
940 state: 'hasError',
941 error: error
942 });
943
944 return _loadableAtom2;
945 }
946 }
947
948 var cached = loadableAtomCache.get(promise);
949
950 if (cached) {
951 return cached;
952 }
953
954 var loadableAtom = jotai.atom(LOADING, function () {
955 var _ref = _asyncToGenerator(regeneratorRuntime.mark(function _callee(get, set) {
956 var _data;
957
958 return regeneratorRuntime.wrap(function _callee$(_context) {
959 while (1) {
960 switch (_context.prev = _context.next) {
961 case 0:
962 _context.prev = 0;
963 _context.next = 3;
964 return get(anAtom, {
965 unstable_promise: true
966 });
967
968 case 3:
969 _data = _context.sent;
970 set(loadableAtom, {
971 state: 'hasData',
972 data: _data
973 });
974 _context.next = 10;
975 break;
976
977 case 7:
978 _context.prev = 7;
979 _context.t0 = _context["catch"](0);
980 set(loadableAtom, {
981 state: 'hasError',
982 error: _context.t0
983 });
984
985 case 10:
986 case "end":
987 return _context.stop();
988 }
989 }
990 }, _callee, null, [[0, 7]]);
991 }));
992
993 return function (_x, _x2) {
994 return _ref.apply(this, arguments);
995 };
996 }());
997
998 loadableAtom.onMount = function (init) {
999 init();
1000 };
1001
1002 loadableAtomCache.set(promise, loadableAtom);
1003 return loadableAtom;
1004 });
1005 var derivedAtom = jotai.atom(function (get) {
1006 var loadableAtom = get(catchAtom);
1007 return get(loadableAtom);
1008 });
1009 return derivedAtom;
1010 }, [anAtom]);
1011}
1012
1013Object.defineProperty(exports, 'useAtomValue', {
1014 enumerable: true,
1015 get: function () { return jotai.useAtomValue; }
1016});
1017Object.defineProperty(exports, 'useUpdateAtom', {
1018 enumerable: true,
1019 get: function () { return jotai.useSetAtom; }
1020});
1021exports.RESET = RESET;
1022exports.atomFamily = atomFamily;
1023exports.atomWithDefault = atomWithDefault;
1024exports.atomWithHash = atomWithHash;
1025exports.atomWithObservable = atomWithObservable;
1026exports.atomWithReducer = atomWithReducer;
1027exports.atomWithReset = atomWithReset;
1028exports.atomWithStorage = atomWithStorage;
1029exports.createJSONStorage = createJSONStorage;
1030exports.freezeAtom = freezeAtom;
1031exports.freezeAtomCreator = freezeAtomCreator;
1032exports.loadable = loadable;
1033exports.selectAtom = selectAtom;
1034exports.splitAtom = splitAtom;
1035exports.useAtomCallback = useAtomCallback;
1036exports.useHydrateAtoms = useHydrateAtoms;
1037exports.useReducerAtom = useReducerAtom;
1038exports.useResetAtom = useResetAtom;
1039exports.waitForAll = waitForAll;