atomirx 0.0.7 → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (138) hide show
  1. package/README.md +198 -2234
  2. package/bin/cli.js +90 -0
  3. package/dist/core/derived.d.ts +2 -2
  4. package/dist/core/effect.d.ts +3 -2
  5. package/dist/core/onCreateHook.d.ts +15 -2
  6. package/dist/core/onErrorHook.d.ts +4 -1
  7. package/dist/core/pool.d.ts +78 -0
  8. package/dist/core/pool.test.d.ts +1 -0
  9. package/dist/core/select-boolean.test.d.ts +1 -0
  10. package/dist/core/select-pool.test.d.ts +1 -0
  11. package/dist/core/select.d.ts +278 -86
  12. package/dist/core/types.d.ts +233 -1
  13. package/dist/core/withAbort.d.ts +95 -0
  14. package/dist/core/withReady.d.ts +3 -3
  15. package/dist/devtools/constants.d.ts +41 -0
  16. package/dist/devtools/index.cjs +1 -0
  17. package/dist/devtools/index.d.ts +29 -0
  18. package/dist/devtools/index.js +429 -0
  19. package/dist/devtools/registry.d.ts +98 -0
  20. package/dist/devtools/registry.test.d.ts +1 -0
  21. package/dist/devtools/setup.d.ts +61 -0
  22. package/dist/devtools/types.d.ts +311 -0
  23. package/dist/index-BZEnfIcB.cjs +1 -0
  24. package/dist/index-BbPZhsDl.js +1653 -0
  25. package/dist/index.cjs +1 -1
  26. package/dist/index.d.ts +4 -3
  27. package/dist/index.js +18 -14
  28. package/dist/onDispatchHook-C8yLzr-o.cjs +1 -0
  29. package/dist/onDispatchHook-SKbiIUaJ.js +5 -0
  30. package/dist/onErrorHook-BGGy3tqK.js +38 -0
  31. package/dist/onErrorHook-DHBASmYw.cjs +1 -0
  32. package/dist/react/index.cjs +1 -30
  33. package/dist/react/index.js +206 -791
  34. package/dist/react/onDispatchHook.d.ts +106 -0
  35. package/dist/react/useAction.d.ts +4 -1
  36. package/dist/react-devtools/DevToolsPanel.d.ts +93 -0
  37. package/dist/react-devtools/EntityDetails.d.ts +10 -0
  38. package/dist/react-devtools/EntityList.d.ts +15 -0
  39. package/dist/react-devtools/LogList.d.ts +12 -0
  40. package/dist/react-devtools/hooks.d.ts +50 -0
  41. package/dist/react-devtools/index.cjs +1 -0
  42. package/dist/react-devtools/index.d.ts +31 -0
  43. package/dist/react-devtools/index.js +1589 -0
  44. package/dist/react-devtools/styles.d.ts +148 -0
  45. package/package.json +26 -2
  46. package/skills/atomirx/SKILL.md +456 -0
  47. package/skills/atomirx/references/async-patterns.md +188 -0
  48. package/skills/atomirx/references/atom-patterns.md +238 -0
  49. package/skills/atomirx/references/deferred-loading.md +191 -0
  50. package/skills/atomirx/references/derived-patterns.md +428 -0
  51. package/skills/atomirx/references/effect-patterns.md +426 -0
  52. package/skills/atomirx/references/error-handling.md +140 -0
  53. package/skills/atomirx/references/hooks.md +322 -0
  54. package/skills/atomirx/references/pool-patterns.md +229 -0
  55. package/skills/atomirx/references/react-integration.md +411 -0
  56. package/skills/atomirx/references/rules.md +407 -0
  57. package/skills/atomirx/references/select-context.md +309 -0
  58. package/skills/atomirx/references/service-template.md +172 -0
  59. package/skills/atomirx/references/store-template.md +205 -0
  60. package/skills/atomirx/references/testing-patterns.md +431 -0
  61. package/coverage/base.css +0 -224
  62. package/coverage/block-navigation.js +0 -87
  63. package/coverage/clover.xml +0 -1440
  64. package/coverage/coverage-final.json +0 -14
  65. package/coverage/favicon.png +0 -0
  66. package/coverage/index.html +0 -131
  67. package/coverage/prettify.css +0 -1
  68. package/coverage/prettify.js +0 -2
  69. package/coverage/sort-arrow-sprite.png +0 -0
  70. package/coverage/sorter.js +0 -210
  71. package/coverage/src/core/atom.ts.html +0 -889
  72. package/coverage/src/core/batch.ts.html +0 -223
  73. package/coverage/src/core/define.ts.html +0 -805
  74. package/coverage/src/core/emitter.ts.html +0 -919
  75. package/coverage/src/core/equality.ts.html +0 -631
  76. package/coverage/src/core/hook.ts.html +0 -460
  77. package/coverage/src/core/index.html +0 -281
  78. package/coverage/src/core/isAtom.ts.html +0 -100
  79. package/coverage/src/core/isPromiseLike.ts.html +0 -133
  80. package/coverage/src/core/onCreateHook.ts.html +0 -138
  81. package/coverage/src/core/scheduleNotifyHook.ts.html +0 -94
  82. package/coverage/src/core/types.ts.html +0 -523
  83. package/coverage/src/core/withUse.ts.html +0 -253
  84. package/coverage/src/index.html +0 -116
  85. package/coverage/src/index.ts.html +0 -106
  86. package/dist/index-CBVj1kSj.js +0 -1350
  87. package/dist/index-Cxk9v0um.cjs +0 -1
  88. package/scripts/publish.js +0 -198
  89. package/src/core/atom.test.ts +0 -633
  90. package/src/core/atom.ts +0 -311
  91. package/src/core/atomState.test.ts +0 -342
  92. package/src/core/atomState.ts +0 -256
  93. package/src/core/batch.test.ts +0 -257
  94. package/src/core/batch.ts +0 -172
  95. package/src/core/define.test.ts +0 -343
  96. package/src/core/define.ts +0 -243
  97. package/src/core/derived.test.ts +0 -1215
  98. package/src/core/derived.ts +0 -450
  99. package/src/core/effect.test.ts +0 -802
  100. package/src/core/effect.ts +0 -188
  101. package/src/core/emitter.test.ts +0 -364
  102. package/src/core/emitter.ts +0 -392
  103. package/src/core/equality.test.ts +0 -392
  104. package/src/core/equality.ts +0 -182
  105. package/src/core/getAtomState.ts +0 -69
  106. package/src/core/hook.test.ts +0 -227
  107. package/src/core/hook.ts +0 -177
  108. package/src/core/isAtom.ts +0 -27
  109. package/src/core/isPromiseLike.test.ts +0 -72
  110. package/src/core/isPromiseLike.ts +0 -16
  111. package/src/core/onCreateHook.ts +0 -107
  112. package/src/core/onErrorHook.test.ts +0 -350
  113. package/src/core/onErrorHook.ts +0 -52
  114. package/src/core/promiseCache.test.ts +0 -241
  115. package/src/core/promiseCache.ts +0 -284
  116. package/src/core/scheduleNotifyHook.ts +0 -53
  117. package/src/core/select.ts +0 -729
  118. package/src/core/selector.test.ts +0 -799
  119. package/src/core/types.ts +0 -389
  120. package/src/core/withReady.test.ts +0 -534
  121. package/src/core/withReady.ts +0 -191
  122. package/src/core/withUse.test.ts +0 -249
  123. package/src/core/withUse.ts +0 -56
  124. package/src/index.test.ts +0 -80
  125. package/src/index.ts +0 -65
  126. package/src/react/index.ts +0 -21
  127. package/src/react/rx.test.tsx +0 -571
  128. package/src/react/rx.tsx +0 -531
  129. package/src/react/strictModeTest.tsx +0 -71
  130. package/src/react/useAction.test.ts +0 -987
  131. package/src/react/useAction.ts +0 -607
  132. package/src/react/useSelector.test.ts +0 -182
  133. package/src/react/useSelector.ts +0 -292
  134. package/src/react/useStable.test.ts +0 -553
  135. package/src/react/useStable.ts +0 -288
  136. package/tsconfig.json +0 -9
  137. package/v2.md +0 -725
  138. package/vite.config.ts +0 -39
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./index-Cxk9v0um.cjs");exports.AllAtomsRejectedError=e.AllAtomsRejectedError;exports.atom=e.atom;exports.batch=e.batch;exports.define=e.define;exports.derived=e.derived;exports.effect=e.effect;exports.emitter=e.emitter;exports.getAtomState=e.getAtomState;exports.isAtom=e.isAtom;exports.isDerived=e.isDerived;exports.isFulfilled=e.isFulfilled;exports.isPending=e.isPending;exports.isRejected=e.isRejected;exports.onCreateHook=e.onCreateHook;exports.onErrorHook=e.onErrorHook;exports.promisesEqual=e.promisesEqual;exports.readonly=e.readonly;exports.select=e.select;exports.trackPromise=e.trackPromise;exports.unwrap=e.unwrap;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./index-BZEnfIcB.cjs"),o=require("./onErrorHook-DHBASmYw.cjs");exports.AllAtomsRejectedError=e.AllAtomsRejectedError;exports.atom=e.atom;exports.batch=e.batch;exports.define=e.define;exports.derived=e.derived;exports.effect=e.effect;exports.emitter=e.emitter;exports.getAtomState=e.getAtomState;exports.isAtom=e.isAtom;exports.isDerived=e.isDerived;exports.isFulfilled=e.isFulfilled;exports.isPending=e.isPending;exports.isPool=e.isPool;exports.isRejected=e.isRejected;exports.isScopedAtom=e.isScopedAtom;exports.pool=e.pool;exports.promisesEqual=e.promisesEqual;exports.readonly=e.readonly;exports.select=e.select;exports.trackPromise=e.trackPromise;exports.unwrap=e.unwrap;exports.onCreateHook=o.onCreateHook;exports.onErrorHook=o.onErrorHook;
package/dist/index.d.ts CHANGED
@@ -5,14 +5,15 @@ export { derived, type DerivedContext } from './core/derived';
5
5
  export { effect, type EffectContext } from './core/effect';
6
6
  export { emitter } from './core/emitter';
7
7
  export { isAtom, isDerived } from './core/isAtom';
8
- export { select, AllAtomsRejectedError } from './core/select';
8
+ export { pool, isPool } from './core/pool';
9
+ export { select, AllAtomsRejectedError, isScopedAtom, type Condition, } from './core/select';
9
10
  export { getAtomState } from './core/getAtomState';
10
11
  export { isPending, isFulfilled, isRejected, trackPromise, unwrap, } from './core/promiseCache';
11
- export type { Atom, AtomMeta, AtomOptions, AtomState, AtomValue, AnyAtom, DerivedAtom, DerivedAtomMeta, DerivedOptions, EffectOptions, Equality, EqualityShorthand, Getter, KeyedResult, MutableAtom, MutableAtomMeta, Pipeable, SelectStateResult, SettledResult, } from './core/types';
12
+ export type { Atom, AtomMeta, AtomOptions, AtomState, AtomValue, AnyAtom, DerivedAtom, DerivedAtomMeta, DerivedOptions, EffectOptions, Equality, EqualityShorthand, Getter, KeyedResult, MutableAtom, MutableAtomMeta, Pipeable, Pool, PoolEvent, PoolMeta, PoolOptions, SelectStateResult, SettledResult, ScopedAtom, } from './core/types';
12
13
  export { onCreateHook } from './core/onCreateHook';
13
14
  export type { CreateInfo, MutableInfo, DerivedInfo, EffectInfo, ModuleInfo, } from './core/onCreateHook';
14
15
  export { onErrorHook } from './core/onErrorHook';
15
16
  export type { ErrorInfo } from './core/onErrorHook';
16
- export type { SelectContext, SelectResult, ReactiveSelector as ContextSelectorFn, SafeResult, } from './core/select';
17
+ export type { SelectContext, SelectOutput, SelectResult, ReactiveSelector as ContextSelectorFn, SafeResult, } from './core/select';
17
18
  export type { PromiseState, CombinedPromiseMeta } from './core/promiseCache';
18
19
  export { promisesEqual } from './core/promiseCache';
package/dist/index.js CHANGED
@@ -1,23 +1,27 @@
1
- import { A as a, c as o, e as r, f as t, g as i, h as d, j as l, l as m, i as n, k as c, n as f, m as A, o as k, q as p, v as u, x as g, d as j, s as v, p as E, u as h } from "./index-CBVj1kSj.js";
1
+ import { A as e, c as o, f as r, g as t, h as i, j as l, k as m, o as d, i as c, l as n, u as f, q as p, m as A, v as k, n as u, p as g, z as j, e as v, s as x, x as E, y as P } from "./index-BbPZhsDl.js";
2
+ import { o as q, a as y } from "./onErrorHook-BGGy3tqK.js";
2
3
  export {
3
- a as AllAtomsRejectedError,
4
+ e as AllAtomsRejectedError,
4
5
  o as atom,
5
6
  r as batch,
6
7
  t as define,
7
8
  i as derived,
8
- d as effect,
9
- l as emitter,
10
- m as getAtomState,
11
- n as isAtom,
12
- c as isDerived,
9
+ l as effect,
10
+ m as emitter,
11
+ d as getAtomState,
12
+ c as isAtom,
13
+ n as isDerived,
13
14
  f as isFulfilled,
14
- A as isPending,
15
+ p as isPending,
16
+ A as isPool,
15
17
  k as isRejected,
16
- p as onCreateHook,
17
- u as onErrorHook,
18
- g as promisesEqual,
19
- j as readonly,
20
- v as select,
18
+ u as isScopedAtom,
19
+ q as onCreateHook,
20
+ y as onErrorHook,
21
+ g as pool,
22
+ j as promisesEqual,
23
+ v as readonly,
24
+ x as select,
21
25
  E as trackPromise,
22
- h as unwrap
26
+ P as unwrap
23
27
  };
@@ -0,0 +1 @@
1
+ "use strict";const o=require("./onErrorHook-DHBASmYw.cjs"),r=o.hook();exports.onDispatchHook=r;
@@ -0,0 +1,5 @@
1
+ import { h as o } from "./onErrorHook-BGGy3tqK.js";
2
+ const t = o();
3
+ export {
4
+ t as o
5
+ };
@@ -0,0 +1,38 @@
1
+ function s(t) {
2
+ const r = Object.assign(
3
+ (e) => () => {
4
+ const o = r.current;
5
+ return r.current = e(o), () => {
6
+ r.current = o;
7
+ };
8
+ },
9
+ {
10
+ current: t,
11
+ // Override method for direct mutation using reducer
12
+ override: (e) => {
13
+ r.current = e(r.current);
14
+ },
15
+ reset: () => {
16
+ r.current = t;
17
+ }
18
+ }
19
+ );
20
+ return r;
21
+ }
22
+ function c(t, r) {
23
+ const e = [];
24
+ for (const o of t)
25
+ e.push(o());
26
+ try {
27
+ return r();
28
+ } finally {
29
+ for (const o of e.reverse())
30
+ o();
31
+ }
32
+ }
33
+ const n = Object.assign(s, { use: c }), u = n(), a = n();
34
+ export {
35
+ a,
36
+ n as h,
37
+ u as o
38
+ };
@@ -0,0 +1 @@
1
+ "use strict";function s(t){const r=Object.assign(e=>()=>{const o=r.current;return r.current=e(o),()=>{r.current=o}},{current:t,override:e=>{r.current=e(r.current)},reset:()=>{r.current=t}});return r}function c(t,r){const e=[];for(const o of t)e.push(o());try{return r()}finally{for(const o of e.reverse())o()}}const n=Object.assign(s,{use:c}),u=n(),a=n();exports.hook=n;exports.onCreateHook=u;exports.onErrorHook=a;
@@ -1,30 +1 @@
1
- "use strict";var br=Object.defineProperty;var Rr=(n,o,f)=>o in n?br(n,o,{enumerable:!0,configurable:!0,writable:!0,value:f}):n[o]=f;var Pe=(n,o,f)=>Rr(n,typeof o!="symbol"?o+"":o,f);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const R=require("react"),u=require("../index-Cxk9v0um.cjs");function oe(n,o){const f=u.isAtom(n)?({read:v})=>v(n):n,E=u.resolveEquality(o??"shallow"),S=R.useRef(f),j=R.useRef(E);S.current=f,j.current=E;const h=R.useRef(new Map),p=R.useRef(new Set),i=R.useRef({value:void 0,initialized:!1}),T=R.useCallback(()=>{const v=u.select(S.current);if(p.current=v.dependencies,v.promise!==void 0)throw v.promise;if(v.error!==void 0)throw v.error;const m=v.value;return(!i.current.initialized||!j.current(m,i.current.value))&&(i.current={value:m,initialized:!0}),i.current.value},[]),d=R.useCallback(v=>{const m=h.current,k=()=>{const F=p.current;for(const[D,y]of m)F.has(D)||(y(),m.delete(D));for(const D of F)if(!m.has(D)){const y=D.on(()=>{const w=u.select(S.current);p.current=w.dependencies,k(),v()});m.set(D,y)}};return k(),()=>{for(const F of m.values())F();m.clear()}},[]);return R.useSyncExternalStore(d,T,T)}function Er(n){return n==null?"strict":Array.isArray(n)?"shallow":n instanceof Date?"deep":typeof n=="object"?"shallow":"strict"}function hr(n,o){const f=R.useRef({}),E=R.useRef(null);E.current===null&&(E.current={});const S=f.current,j=E.current;for(const h of Object.keys(n)){const p=n[h],i=S[h];if(typeof p=="function"){const[m]=u.tryStabilize(i,p,()=>!1);S[h]={value:m},j[h]=m;continue}const T=o==null?void 0:o[h],d=T?u.resolveEquality(T):u.resolveEquality(Er(p)),[v]=u.tryStabilize(i,p,d);S[h]={value:v},j[h]=v}for(const h of Object.keys(S))h in n||(delete S[h],delete j[h]);return j}const Fe={status:"idle",result:void 0,error:void 0},Ie={status:"loading",result:void 0,error:void 0};function mr(n,o){switch(o.type){case"START":return Ie;case"SUCCESS":return{status:"success",result:o.result,error:void 0};case"ERROR":return{status:"error",result:void 0,error:o.error};case"RESET":return Fe;default:return n}}function yr(n,o={}){const{lazy:f=!0,exclusive:E=!0,deps:S=[]}=o,j=f?Fe:Ie,[h,p]=R.useReducer(mr,j),i=R.useRef(null),T=R.useRef(n);T.current=n;const d=R.useCallback(()=>{const y=i.current;return y?(y.abort(),i.current=null,!0):!1},[]),v=(f?[]:S??[]).filter(u.isAtom),m=oe(({read:y})=>v.map(w=>y(w))),k=R.useCallback(()=>{E&&d();const y=new AbortController;i.current=y,p({type:"START"});let w;try{w=T.current(u.withUse({signal:y.signal}))}catch(g){return p({type:"ERROR",error:g}),Object.assign(Promise.reject(g),{abort:()=>y.abort()})}if(u.isPromiseLike(w)){const g=w;return g.then(I=>{i.current===y&&p({type:"SUCCESS",result:I})},I=>{if(I instanceof DOMException&&I.name==="AbortError"){(i.current===null||i.current===y)&&p({type:"ERROR",error:I});return}i.current===y&&p({type:"ERROR",error:I})}),Object.assign(g,{abort:()=>{y.abort(),i.current===y&&(i.current=null)}})}return p({type:"SUCCESS",result:w}),Object.assign(Promise.resolve(w),{abort:()=>y.abort()})},[E,d]),F=(S??[]).filter(y=>!u.isAtom(y));R.useEffect(()=>{f||k()},[f,...m,...F]),R.useEffect(()=>()=>{E&&d()},[E,d]);const D=R.useCallback(()=>{E&&d(),p({type:"RESET"})},[E,d]);return Object.assign(k,{...h,abort:d,reset:D})}var ne={exports:{}},M={};/**
2
- * @license React
3
- * react-jsx-runtime.production.min.js
4
- *
5
- * Copyright (c) Facebook, Inc. and its affiliates.
6
- *
7
- * This source code is licensed under the MIT license found in the
8
- * LICENSE file in the root directory of this source tree.
9
- */var ke;function gr(){if(ke)return M;ke=1;var n=R,o=Symbol.for("react.element"),f=Symbol.for("react.fragment"),E=Object.prototype.hasOwnProperty,S=n.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,j={key:!0,ref:!0,__self:!0,__source:!0};function h(p,i,T){var d,v={},m=null,k=null;T!==void 0&&(m=""+T),i.key!==void 0&&(m=""+i.key),i.ref!==void 0&&(k=i.ref);for(d in i)E.call(i,d)&&!j.hasOwnProperty(d)&&(v[d]=i[d]);if(p&&p.defaultProps)for(d in i=p.defaultProps,i)v[d]===void 0&&(v[d]=i[d]);return{$$typeof:o,type:p,key:m,ref:k,props:v,_owner:S.current}}return M.Fragment=f,M.jsx=h,M.jsxs=h,M}var z={};/**
10
- * @license React
11
- * react-jsx-runtime.development.js
12
- *
13
- * Copyright (c) Facebook, Inc. and its affiliates.
14
- *
15
- * This source code is licensed under the MIT license found in the
16
- * LICENSE file in the root directory of this source tree.
17
- */var De;function _r(){return De||(De=1,process.env.NODE_ENV!=="production"&&function(){var n=R,o=Symbol.for("react.element"),f=Symbol.for("react.portal"),E=Symbol.for("react.fragment"),S=Symbol.for("react.strict_mode"),j=Symbol.for("react.profiler"),h=Symbol.for("react.provider"),p=Symbol.for("react.context"),i=Symbol.for("react.forward_ref"),T=Symbol.for("react.suspense"),d=Symbol.for("react.suspense_list"),v=Symbol.for("react.memo"),m=Symbol.for("react.lazy"),k=Symbol.for("react.offscreen"),F=Symbol.iterator,D="@@iterator";function y(e){if(e===null||typeof e!="object")return null;var r=F&&e[F]||e[D];return typeof r=="function"?r:null}var w=n.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function g(e){{for(var r=arguments.length,t=new Array(r>1?r-1:0),a=1;a<r;a++)t[a-1]=arguments[a];I("error",e,t)}}function I(e,r,t){{var a=w.ReactDebugCurrentFrame,l=a.getStackAddendum();l!==""&&(r+="%s",t=t.concat([l]));var b=t.map(function(c){return String(c)});b.unshift("Warning: "+r),Function.prototype.apply.call(console[e],console,b)}}var ae=!1,We=!1,$e=!1,qe=!1,Ye=!1,ie;ie=Symbol.for("react.module.reference");function Le(e){return!!(typeof e=="string"||typeof e=="function"||e===E||e===j||Ye||e===S||e===T||e===d||qe||e===k||ae||We||$e||typeof e=="object"&&e!==null&&(e.$$typeof===m||e.$$typeof===v||e.$$typeof===h||e.$$typeof===p||e.$$typeof===i||e.$$typeof===ie||e.getModuleId!==void 0))}function Ue(e,r,t){var a=e.displayName;if(a)return a;var l=r.displayName||r.name||"";return l!==""?t+"("+l+")":t}function se(e){return e.displayName||"Context"}function W(e){if(e==null)return null;if(typeof e.tag=="number"&&g("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case E:return"Fragment";case f:return"Portal";case j:return"Profiler";case S:return"StrictMode";case T:return"Suspense";case d:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case p:var r=e;return se(r)+".Consumer";case h:var t=e;return se(t._context)+".Provider";case i:return Ue(e,e.render,"ForwardRef");case v:var a=e.displayName||null;return a!==null?a:W(e.type)||"Memo";case m:{var l=e,b=l._payload,c=l._init;try{return W(c(b))}catch{return null}}}return null}var $=Object.assign,U=0,ue,ce,le,fe,de,ve,pe;function be(){}be.__reactDisabledLog=!0;function Ve(){{if(U===0){ue=console.log,ce=console.info,le=console.warn,fe=console.error,de=console.group,ve=console.groupCollapsed,pe=console.groupEnd;var e={configurable:!0,enumerable:!0,value:be,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}U++}}function Me(){{if(U--,U===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:$({},e,{value:ue}),info:$({},e,{value:ce}),warn:$({},e,{value:le}),error:$({},e,{value:fe}),group:$({},e,{value:de}),groupCollapsed:$({},e,{value:ve}),groupEnd:$({},e,{value:pe})})}U<0&&g("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var G=w.ReactCurrentDispatcher,H;function N(e,r,t){{if(H===void 0)try{throw Error()}catch(l){var a=l.stack.trim().match(/\n( *(at )?)/);H=a&&a[1]||""}return`
18
- `+H+e}}var X=!1,B;{var ze=typeof WeakMap=="function"?WeakMap:Map;B=new ze}function Re(e,r){if(!e||X)return"";{var t=B.get(e);if(t!==void 0)return t}var a;X=!0;var l=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var b;b=G.current,G.current=null,Ve();try{if(r){var c=function(){throw Error()};if(Object.defineProperty(c.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(c,[])}catch(A){a=A}Reflect.construct(e,[],c)}else{try{c.call()}catch(A){a=A}e.call(c.prototype)}}else{try{throw Error()}catch(A){a=A}e()}}catch(A){if(A&&a&&typeof A.stack=="string"){for(var s=A.stack.split(`
19
- `),x=a.stack.split(`
20
- `),_=s.length-1,O=x.length-1;_>=1&&O>=0&&s[_]!==x[O];)O--;for(;_>=1&&O>=0;_--,O--)if(s[_]!==x[O]){if(_!==1||O!==1)do if(_--,O--,O<0||s[_]!==x[O]){var P=`
21
- `+s[_].replace(" at new "," at ");return e.displayName&&P.includes("<anonymous>")&&(P=P.replace("<anonymous>",e.displayName)),typeof e=="function"&&B.set(e,P),P}while(_>=1&&O>=0);break}}}finally{X=!1,G.current=b,Me(),Error.prepareStackTrace=l}var L=e?e.displayName||e.name:"",q=L?N(L):"";return typeof e=="function"&&B.set(e,q),q}function Ne(e,r,t){return Re(e,!1)}function Be(e){var r=e.prototype;return!!(r&&r.isReactComponent)}function J(e,r,t){if(e==null)return"";if(typeof e=="function")return Re(e,Be(e));if(typeof e=="string")return N(e);switch(e){case T:return N("Suspense");case d:return N("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case i:return Ne(e.render);case v:return J(e.type,r,t);case m:{var a=e,l=a._payload,b=a._init;try{return J(b(l),r,t)}catch{}}}return""}var V=Object.prototype.hasOwnProperty,Ee={},he=w.ReactDebugCurrentFrame;function K(e){if(e){var r=e._owner,t=J(e.type,e._source,r?r.type:null);he.setExtraStackFrame(t)}else he.setExtraStackFrame(null)}function Je(e,r,t,a,l){{var b=Function.call.bind(V);for(var c in e)if(b(e,c)){var s=void 0;try{if(typeof e[c]!="function"){var x=Error((a||"React class")+": "+t+" type `"+c+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[c]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw x.name="Invariant Violation",x}s=e[c](r,c,a,t,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(_){s=_}s&&!(s instanceof Error)&&(K(l),g("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).",a||"React class",t,c,typeof s),K(null)),s instanceof Error&&!(s.message in Ee)&&(Ee[s.message]=!0,K(l),g("Failed %s type: %s",t,s.message),K(null))}}}var Ke=Array.isArray;function Z(e){return Ke(e)}function Ge(e){{var r=typeof Symbol=="function"&&Symbol.toStringTag,t=r&&e[Symbol.toStringTag]||e.constructor.name||"Object";return t}}function He(e){try{return me(e),!1}catch{return!0}}function me(e){return""+e}function ye(e){if(He(e))return g("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",Ge(e)),me(e)}var ge=w.ReactCurrentOwner,Xe={key:!0,ref:!0,__self:!0,__source:!0},_e,Se;function Ze(e){if(V.call(e,"ref")){var r=Object.getOwnPropertyDescriptor(e,"ref").get;if(r&&r.isReactWarning)return!1}return e.ref!==void 0}function Qe(e){if(V.call(e,"key")){var r=Object.getOwnPropertyDescriptor(e,"key").get;if(r&&r.isReactWarning)return!1}return e.key!==void 0}function er(e,r){typeof e.ref=="string"&&ge.current}function rr(e,r){{var t=function(){_e||(_e=!0,g("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",r))};t.isReactWarning=!0,Object.defineProperty(e,"key",{get:t,configurable:!0})}}function tr(e,r){{var t=function(){Se||(Se=!0,g("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",r))};t.isReactWarning=!0,Object.defineProperty(e,"ref",{get:t,configurable:!0})}}var nr=function(e,r,t,a,l,b,c){var s={$$typeof:o,type:e,key:r,ref:t,props:c,_owner:b};return s._store={},Object.defineProperty(s._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(s,"_self",{configurable:!1,enumerable:!1,writable:!1,value:a}),Object.defineProperty(s,"_source",{configurable:!1,enumerable:!1,writable:!1,value:l}),Object.freeze&&(Object.freeze(s.props),Object.freeze(s)),s};function or(e,r,t,a,l){{var b,c={},s=null,x=null;t!==void 0&&(ye(t),s=""+t),Qe(r)&&(ye(r.key),s=""+r.key),Ze(r)&&(x=r.ref,er(r,l));for(b in r)V.call(r,b)&&!Xe.hasOwnProperty(b)&&(c[b]=r[b]);if(e&&e.defaultProps){var _=e.defaultProps;for(b in _)c[b]===void 0&&(c[b]=_[b])}if(s||x){var O=typeof e=="function"?e.displayName||e.name||"Unknown":e;s&&rr(c,O),x&&tr(c,O)}return nr(e,s,x,l,a,ge.current,c)}}var Q=w.ReactCurrentOwner,Oe=w.ReactDebugCurrentFrame;function Y(e){if(e){var r=e._owner,t=J(e.type,e._source,r?r.type:null);Oe.setExtraStackFrame(t)}else Oe.setExtraStackFrame(null)}var ee;ee=!1;function re(e){return typeof e=="object"&&e!==null&&e.$$typeof===o}function Te(){{if(Q.current){var e=W(Q.current.type);if(e)return`
22
-
23
- Check the render method of \``+e+"`."}return""}}function ar(e){return""}var Ce={};function ir(e){{var r=Te();if(!r){var t=typeof e=="string"?e:e.displayName||e.name;t&&(r=`
24
-
25
- Check the top-level render call using <`+t+">.")}return r}}function je(e,r){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var t=ir(r);if(Ce[t])return;Ce[t]=!0;var a="";e&&e._owner&&e._owner!==Q.current&&(a=" It was passed a child from "+W(e._owner.type)+"."),Y(e),g('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',t,a),Y(null)}}function we(e,r){{if(typeof e!="object")return;if(Z(e))for(var t=0;t<e.length;t++){var a=e[t];re(a)&&je(a,r)}else if(re(e))e._store&&(e._store.validated=!0);else if(e){var l=y(e);if(typeof l=="function"&&l!==e.entries)for(var b=l.call(e),c;!(c=b.next()).done;)re(c.value)&&je(c.value,r)}}}function sr(e){{var r=e.type;if(r==null||typeof r=="string")return;var t;if(typeof r=="function")t=r.propTypes;else if(typeof r=="object"&&(r.$$typeof===i||r.$$typeof===v))t=r.propTypes;else return;if(t){var a=W(r);Je(t,e.props,"prop",a,e)}else if(r.PropTypes!==void 0&&!ee){ee=!0;var l=W(r);g("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",l||"Unknown")}typeof r.getDefaultProps=="function"&&!r.getDefaultProps.isReactClassApproved&&g("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function ur(e){{for(var r=Object.keys(e.props),t=0;t<r.length;t++){var a=r[t];if(a!=="children"&&a!=="key"){Y(e),g("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",a),Y(null);break}}e.ref!==null&&(Y(e),g("Invalid attribute `ref` supplied to `React.Fragment`."),Y(null))}}var xe={};function Ae(e,r,t,a,l,b){{var c=Le(e);if(!c){var s="";(e===void 0||typeof e=="object"&&e!==null&&Object.keys(e).length===0)&&(s+=" You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");var x=ar();x?s+=x:s+=Te();var _;e===null?_="null":Z(e)?_="array":e!==void 0&&e.$$typeof===o?(_="<"+(W(e.type)||"Unknown")+" />",s=" Did you accidentally export a JSX literal instead of a component?"):_=typeof e,g("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",_,s)}var O=or(e,r,t,l,b);if(O==null)return O;if(c){var P=r.children;if(P!==void 0)if(a)if(Z(P)){for(var L=0;L<P.length;L++)we(P[L],e);Object.freeze&&Object.freeze(P)}else g("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else we(P,e)}if(V.call(r,"key")){var q=W(e),A=Object.keys(r).filter(function(pr){return pr!=="key"}),te=A.length>0?"{key: someKey, "+A.join(": ..., ")+": ...}":"{key: someKey}";if(!xe[q+te]){var vr=A.length>0?"{"+A.join(": ..., ")+": ...}":"{}";g(`A props object containing a "key" prop is being spread into JSX:
26
- let props = %s;
27
- <%s {...props} />
28
- React keys must be passed directly to JSX without using spread:
29
- let props = %s;
30
- <%s key={someKey} {...props} />`,te,q,vr,q),xe[q+te]=!0}}return e===E?ur(O):sr(O),O}}function cr(e,r,t){return Ae(e,r,t,!0)}function lr(e,r,t){return Ae(e,r,t,!1)}var fr=lr,dr=cr;z.Fragment=E,z.jsx=fr,z.jsxs=dr}()),z}process.env.NODE_ENV==="production"?ne.exports=gr():ne.exports=_r();var C=ne.exports;function Sr(n,o){const f=o===void 0?void 0:typeof o=="object"&&o!==null&&!Array.isArray(o)&&("equals"in o||"loading"in o||"error"in o)?o:{equals:o};return C.jsx(xr,{selectorOrAtom:n,options:f})}class Or extends R.Component{constructor(){super(...arguments);Pe(this,"state",{error:null})}static getDerivedStateFromError(f){return{error:f}}componentDidCatch(f,E){}render(){if(this.state.error!==null&&this.props.onError)return C.jsx(C.Fragment,{children:this.props.onError({error:this.state.error})});if(this.state.error!==null)throw this.state.error;return this.props.children}}function Tr(n){const o=oe(n.selector,n.equals);return C.jsx(C.Fragment,{children:o??null})}function Cr(n){return C.jsx(C.Fragment,{children:n.render()})}function jr(n){return n.fallback?C.jsx(R.Suspense,{fallback:C.jsx(Cr,{render:n.fallback}),children:n.children}):C.jsx(C.Fragment,{children:n.children})}function wr(n){return n.onError?C.jsx(Or,{onError:n.onError,children:n.children}):C.jsx(C.Fragment,{children:n.children})}const xr=R.memo(function(o){var p,i,T,d;const f=R.useRef(o.selectorOrAtom);f.current=o.selectorOrAtom;const E=u.isAtom(o.selectorOrAtom),S=(p=o.options)==null?void 0:p.deps,j=E?[o.selectorOrAtom,...S??[]]:S??[{}],h=R.useCallback(v=>u.isAtom(f.current)?v.read(f.current):f.current(v),j);return C.jsx(wr,{onError:(i=o.options)==null?void 0:i.error,children:C.jsx(jr,{fallback:(T=o.options)==null?void 0:T.loading,children:C.jsx(Tr,{selector:h,equals:(d=o.options)==null?void 0:d.equals})})})},(n,o)=>u.shallowEqual(n.selectorOrAtom,o.selectorOrAtom)&&u.shallowEqual(n.options,o.options));exports.AllAtomsRejectedError=u.AllAtomsRejectedError;exports.atom=u.atom;exports.batch=u.batch;exports.define=u.define;exports.derived=u.derived;exports.effect=u.effect;exports.emitter=u.emitter;exports.getAtomState=u.getAtomState;exports.isAtom=u.isAtom;exports.isDerived=u.isDerived;exports.isFulfilled=u.isFulfilled;exports.isPending=u.isPending;exports.isRejected=u.isRejected;exports.onCreateHook=u.onCreateHook;exports.onErrorHook=u.onErrorHook;exports.promisesEqual=u.promisesEqual;exports.readonly=u.readonly;exports.select=u.select;exports.trackPromise=u.trackPromise;exports.unwrap=u.unwrap;exports.rx=Sr;exports.useAction=yr;exports.useSelector=oe;exports.useStable=hr;
1
+ "use strict";var F=Object.defineProperty;var z=(r,e,n)=>e in r?F(r,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):r[e]=n;var w=(r,e,n)=>z(r,typeof e!="symbol"?e+"":e,n);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("react"),t=require("../index-BZEnfIcB.cjs"),y=require("../onDispatchHook-C8yLzr-o.cjs"),d=require("react/jsx-runtime"),H=require("../onErrorHook-DHBASmYw.cjs");function C(r,e){const n=t.isAtom(r)?({read:p})=>p(r):r,m=t.resolveEquality(e??"shallow"),s=o.useRef(n),R=o.useRef(m);s.current=n,R.current=m;const a=o.useRef(new Map),u=o.useRef(new Set),c=o.useRef([]),b=o.useRef(new Map),l=o.useRef({value:void 0,initialized:!1}),A=o.useCallback(()=>{const{result:p}=t.select(s.current);if(u.current=p._atomDeps,b.current=p._poolDeps,p.promise!==void 0)throw p.promise;if(p.error!==void 0)throw p.error;const E=p.value;return(!l.current.initialized||!R.current(E,l.current.value))&&(l.current={value:E,initialized:!0}),l.current.value},[]),k=o.useCallback(p=>{const E=a.current,g=()=>{const{result:f}=t.select(s.current);u.current=f._atomDeps,b.current=f._poolDeps,i(),p()},i=()=>{const f=u.current,v=b.current;for(const[h,D]of E)f.has(h)||(D(),E.delete(h));for(const h of f)E.has(h)||E.set(h,h.on(g));for(const h of c.current)h();c.current=[];for(const[h,D]of v)for(const x of D)c.current.push(h._onRemove(x,g))};return i(),()=>{for(const f of E.values())f();E.clear();for(const f of c.current)f();c.current=[]}},[]);return o.useSyncExternalStore(k,A,A)}function _(r){return r==null?Object.is:Array.isArray(r)?"shallow":r instanceof Date?t.deepEqual:typeof r=="object"?t.shallowEqual:Object.is}function I(r,e){const n=o.useRef({}),m=o.useRef(null);m.current===null&&(m.current={});const s=n.current,R=m.current;for(const a of Object.keys(r)){const u=r[a],c=s[a];if(typeof u=="function"){const[k]=t.tryStabilize(c,u,()=>!1);s[a]={value:k},R[a]=k;continue}const b=e==null?void 0:e[a],l=b?t.resolveEquality(b):t.resolveEquality(_(u)),[A]=t.tryStabilize(c,u,l);s[a]={value:A},R[a]=A}for(const a of Object.keys(s))a in r||(delete s[a],delete R[a]);return R}const P={status:"idle",result:void 0,error:void 0},T={status:"loading",result:void 0,error:void 0};function L(r,e){switch(e.type){case"START":return T;case"SUCCESS":return{status:"success",result:e.result,error:void 0};case"ERROR":return{status:"error",result:void 0,error:e.error};case"RESET":return P;default:return r}}function M(r,e={}){const{lazy:n=!0,exclusive:m=!0,deps:s=[]}=e,R=n?P:T,[a,u]=o.useReducer(L,R),c=o.useRef(null),b=o.useRef(r);b.current=r;const l=o.useCallback(()=>{const i=c.current;return i?(i.abort(),c.current=null,!0):!1},[]),A=(n?[]:s??[]).filter(t.isAtom),k=C(({read:i})=>A.map(f=>i(f))),p=o.useCallback(()=>{var v,h,D,x,q,O;m&&l();const i=new AbortController;c.current=i,u({type:"START"}),(h=(v=y.onDispatchHook).current)==null||h.call(v,{type:"start",meta:e.meta,deps:s});let f;try{f=b.current(t.withUse({signal:i.signal}))}catch(j){return u({type:"ERROR",error:j}),(x=(D=y.onDispatchHook).current)==null||x.call(D,{type:"error",meta:e.meta,deps:s,error:j}),Object.assign(Promise.reject(j),{abort:()=>i.abort()})}if(t.isPromiseLike(f)){const j=f;return(O=(q=y.onDispatchHook).current)==null||O.call(q,{type:"loading",meta:e.meta,deps:s}),j.then(S=>{c.current===i&&(u({type:"SUCCESS",result:S}),y.onDispatchHook.current&&y.onDispatchHook.current({type:"resolved",meta:e.meta,deps:s}))},S=>{if(S instanceof DOMException&&S.name==="AbortError"){(c.current===null||c.current===i)&&(u({type:"ERROR",error:S}),y.onDispatchHook.current&&y.onDispatchHook.current({type:"abort",meta:e.meta,deps:s,error:S}));return}c.current===i&&(u({type:"ERROR",error:S}),y.onDispatchHook.current&&y.onDispatchHook.current({type:"rejected",meta:e.meta,deps:s,error:S}))}),Object.assign(j,{abort:()=>{i.abort(),c.current===i&&(c.current=null)}})}else y.onDispatchHook.current&&y.onDispatchHook.current({type:"success",meta:e.meta,deps:s});return u({type:"SUCCESS",result:f}),Object.assign(Promise.resolve(f),{abort:()=>i.abort()})},[m,l]),E=(s??[]).filter(i=>!t.isAtom(i));o.useEffect(()=>{n||p()},[n,...k,...E]),o.useEffect(()=>()=>{m&&l()},[m,l]);const g=o.useCallback(()=>{m&&l(),u({type:"RESET"})},[m,l]);return Object.assign(p,{...a,abort:l,reset:g})}function U(r,e){const n=e===void 0?void 0:typeof e=="object"&&e!==null&&!Array.isArray(e)&&("equals"in e||"loading"in e||"error"in e)?e:{equals:e};return d.jsx(J,{selectorOrAtom:r,options:n})}class V extends o.Component{constructor(){super(...arguments);w(this,"state",{error:null})}static getDerivedStateFromError(n){return{error:n}}componentDidCatch(n,m){}render(){if(this.state.error!==null&&this.props.onError)return d.jsx(d.Fragment,{children:this.props.onError({error:this.state.error})});if(this.state.error!==null)throw this.state.error;return this.props.children}}function W(r){const e=C(r.selector,r.equals);return d.jsx(d.Fragment,{children:e??null})}function B(r){return d.jsx(d.Fragment,{children:r.render()})}function G(r){return r.fallback?d.jsx(o.Suspense,{fallback:d.jsx(B,{render:r.fallback}),children:r.children}):d.jsx(d.Fragment,{children:r.children})}function N(r){return r.onError?d.jsx(V,{onError:r.onError,children:r.children}):d.jsx(d.Fragment,{children:r.children})}const J=o.memo(function(e){var u,c,b,l;const n=o.useRef(e.selectorOrAtom);n.current=e.selectorOrAtom;const m=t.isAtom(e.selectorOrAtom),s=(u=e.options)==null?void 0:u.deps,R=m?[e.selectorOrAtom,...s??[]]:s??[{}],a=o.useCallback(A=>t.isAtom(n.current)?A.read(n.current):n.current(A),R);return d.jsx(N,{onError:(c=e.options)==null?void 0:c.error,children:d.jsx(G,{fallback:(b=e.options)==null?void 0:b.loading,children:d.jsx(W,{selector:a,equals:(l=e.options)==null?void 0:l.equals})})})},(r,e)=>t.shallowEqual(r.selectorOrAtom,e.selectorOrAtom)&&t.shallowEqual(r.options,e.options));exports.AllAtomsRejectedError=t.AllAtomsRejectedError;exports.atom=t.atom;exports.batch=t.batch;exports.define=t.define;exports.derived=t.derived;exports.effect=t.effect;exports.emitter=t.emitter;exports.getAtomState=t.getAtomState;exports.isAtom=t.isAtom;exports.isDerived=t.isDerived;exports.isFulfilled=t.isFulfilled;exports.isPending=t.isPending;exports.isPool=t.isPool;exports.isRejected=t.isRejected;exports.isScopedAtom=t.isScopedAtom;exports.pool=t.pool;exports.promisesEqual=t.promisesEqual;exports.readonly=t.readonly;exports.select=t.select;exports.trackPromise=t.trackPromise;exports.unwrap=t.unwrap;exports.onCreateHook=H.onCreateHook;exports.onErrorHook=H.onErrorHook;exports.rx=U;exports.useAction=M;exports.useSelector=C;exports.useStable=I;