atomaric 0.0.18 → 0.0.20
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.
- package/build/atomaric.js +131 -125
- package/build/atomaric.umd.cjs +1 -1
- package/package.json +1 -1
- package/types/model.d.ts +4 -1
package/build/atomaric.js
CHANGED
|
@@ -1,164 +1,170 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
1
|
+
const x = (e, t, r) => {
|
|
2
|
+
let u = null;
|
|
3
|
+
typeof e == "number" ? u = _(
|
|
4
|
+
{
|
|
5
|
+
increment: (s) => {
|
|
6
|
+
t.set(+t.get() + (s ?? 0));
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
) : typeof e == "boolean" ? u = _(
|
|
10
|
+
{
|
|
11
|
+
toggle: () => {
|
|
12
|
+
t.set(!t.get());
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
) : Array.isArray(e) ? u = _(
|
|
16
|
+
{
|
|
17
|
+
push: (...s) => {
|
|
18
|
+
t.set(t.get().concat(s));
|
|
19
|
+
},
|
|
20
|
+
unshift: (...s) => {
|
|
21
|
+
t.set(s.concat(t.get()));
|
|
22
|
+
},
|
|
23
|
+
update: (s) => {
|
|
24
|
+
const i = t.get().slice();
|
|
25
|
+
s(i), t.set(i);
|
|
26
|
+
},
|
|
27
|
+
filter: (s) => {
|
|
28
|
+
t.set(t.get().filter(s ?? J));
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
) : e instanceof Set && (u = _(
|
|
32
|
+
{
|
|
33
|
+
add: (s) => {
|
|
34
|
+
t.set(new Set(t.get()).add(s));
|
|
35
|
+
},
|
|
36
|
+
delete: (s) => {
|
|
37
|
+
const i = new Set(t.get());
|
|
38
|
+
i.delete(s), t.set(i);
|
|
39
|
+
},
|
|
40
|
+
clear: () => {
|
|
41
|
+
t.set(/* @__PURE__ */ new Set());
|
|
42
|
+
},
|
|
43
|
+
update: (s) => {
|
|
44
|
+
const i = new Set(t.get());
|
|
45
|
+
s(i), t.set(i);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
));
|
|
49
|
+
const a = typeof r == "object" && r != null && "do" in r ? r.do(
|
|
50
|
+
(s, i) => t.set(s, i),
|
|
51
|
+
() => t.get()
|
|
52
|
+
) : null, d = {};
|
|
53
|
+
return a && Object.keys(a).forEach((s) => Object.defineProperty(d, s, { get: () => a[s] })), u && Object.keys(u).forEach(
|
|
54
|
+
(s) => Object.defineProperty(d, s, { get: () => u[s] })
|
|
55
|
+
), d;
|
|
56
|
+
}, J = (e) => e, _ = (e, t) => e;
|
|
57
|
+
class F {
|
|
58
|
+
constructor(t, r) {
|
|
59
|
+
const u = (n) => i = n, a = () => i, d = /* @__PURE__ */ new Set(), s = (n) => n(g());
|
|
60
|
+
let i = t, b, j = () => {
|
|
61
|
+
}, g = () => a(), C = () => {
|
|
62
|
+
const n = x(t, this, r);
|
|
63
|
+
return C = () => n, n;
|
|
64
64
|
};
|
|
65
|
-
const
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
65
|
+
const p = new Proxy(this, {
|
|
66
|
+
get: (n, o) => o === "do" ? C() : n[o],
|
|
67
|
+
set: V
|
|
68
|
+
}), h = (n, o) => {
|
|
69
|
+
const f = typeof n == "function" ? n(g()) : n;
|
|
70
|
+
if (!(f === g() || f === void 0 || typeof f == "number" && isNaN(f))) {
|
|
71
|
+
u(f), d.forEach(s, this);
|
|
71
72
|
try {
|
|
72
|
-
|
|
73
|
+
E.postMessage({ key: l, value: a() });
|
|
73
74
|
} catch {
|
|
74
75
|
}
|
|
75
|
-
|
|
76
|
+
o !== !0 && j(f);
|
|
76
77
|
}
|
|
77
78
|
};
|
|
78
|
-
if (this.set = (
|
|
79
|
-
|
|
80
|
-
}, this.
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
79
|
+
if (this.set = (n, o) => h(n, o), this.get = () => g(), this.defaultValue = t, this.subscribe = (n) => (d.add(n), () => {
|
|
80
|
+
d.delete(n);
|
|
81
|
+
}), this.reset = () => {
|
|
82
|
+
h(t, !0), d.forEach(s, this);
|
|
83
|
+
}, this.setDeferred = (n, o = 500, f, T = !0) => {
|
|
84
|
+
T && b === void 0 && h(n, f), clearTimeout(b), b = setTimeout(() => {
|
|
85
|
+
h(n, f), b = void 0;
|
|
86
|
+
}, o);
|
|
87
|
+
}, r == null) return p;
|
|
88
|
+
let w = null, I = !0, v = !0, D = !1, y = t instanceof Set ? (n) => new Set(JSON.parse(n)) : (n) => JSON.parse(n), A = t instanceof Set ? (n) => {
|
|
89
|
+
if (n instanceof Set) return JSON.stringify(Array.from(n));
|
|
90
|
+
throw console.error(n), "The value is not Set instance";
|
|
91
|
+
} : (n) => JSON.stringify(n);
|
|
92
|
+
if (typeof r == "string" ? w = r : "storeKey" in r && (I = r.warnOnDuplicateStoreKey ?? I, v = r.listenStorageChanges ?? v, w = r.storeKey, y = r.parseValue ?? y, A = r.stringifyValue ?? A, D = r.unchangable ?? D), w === null) return p;
|
|
93
|
+
const l = `atom/${w}`;
|
|
91
94
|
let N = !0;
|
|
92
|
-
if (
|
|
93
|
-
if (
|
|
95
|
+
if (g = () => {
|
|
96
|
+
if (g = () => a(), N) {
|
|
94
97
|
N = !1;
|
|
95
98
|
try {
|
|
96
|
-
|
|
99
|
+
u(l in c ? y(c[l]) : t);
|
|
97
100
|
} catch {
|
|
98
101
|
console.warn("Invalid json value", c[l]);
|
|
99
102
|
}
|
|
100
103
|
}
|
|
101
|
-
return
|
|
102
|
-
},
|
|
103
|
-
if (
|
|
104
|
+
return a();
|
|
105
|
+
}, j = (n) => {
|
|
106
|
+
if (n === t) {
|
|
104
107
|
this.reset();
|
|
105
108
|
return;
|
|
106
109
|
}
|
|
107
|
-
c[l] =
|
|
110
|
+
c[l] = A(n);
|
|
108
111
|
}, this.reset = () => {
|
|
109
|
-
delete c[l],
|
|
110
|
-
},
|
|
111
|
-
if (
|
|
112
|
-
let
|
|
113
|
-
|
|
114
|
-
clearTimeout(
|
|
112
|
+
delete c[l], h(t, !0);
|
|
113
|
+
}, I && S[l] !== void 0 && console.warn("Duplicate Atom key", w), v)
|
|
114
|
+
if (D) {
|
|
115
|
+
let n = !1, o;
|
|
116
|
+
m[l] = this, S[l] = () => {
|
|
117
|
+
clearTimeout(o), o = setTimeout(() => n = !1, 10), !n && (n = !0, c[l] = A(a()));
|
|
115
118
|
};
|
|
116
119
|
} else
|
|
117
|
-
|
|
118
|
-
if (
|
|
120
|
+
S[l] = (n) => {
|
|
121
|
+
if (n.newValue === null) {
|
|
119
122
|
this.reset();
|
|
120
123
|
return;
|
|
121
124
|
}
|
|
122
125
|
try {
|
|
123
|
-
|
|
126
|
+
h(y(n.newValue));
|
|
124
127
|
} catch {
|
|
125
|
-
console.warn("Invalid json value",
|
|
128
|
+
console.warn("Invalid json value", n.newValue);
|
|
126
129
|
}
|
|
127
130
|
};
|
|
131
|
+
return p;
|
|
128
132
|
}
|
|
129
133
|
}
|
|
130
|
-
let
|
|
134
|
+
let E;
|
|
131
135
|
try {
|
|
132
|
-
|
|
133
|
-
var
|
|
134
|
-
(
|
|
136
|
+
E = new BroadcastChannel("updateHere"), E.addEventListener("message", (e) => {
|
|
137
|
+
var t;
|
|
138
|
+
(t = m[e.data.key]) == null || t.set(e.data.value, !0);
|
|
135
139
|
});
|
|
136
140
|
} catch {
|
|
137
141
|
}
|
|
138
|
-
const c = window.localStorage,
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
+
const c = window.localStorage, S = {}, m = {}, V = (e, t) => {
|
|
143
|
+
throw `${t} is readonly property`;
|
|
144
|
+
};
|
|
145
|
+
window.addEventListener("storage", (e) => {
|
|
146
|
+
var t;
|
|
147
|
+
e.key === null || e.newValue === e.oldValue || (t = S[e.key]) == null || t.call(S, e);
|
|
142
148
|
});
|
|
143
|
-
const
|
|
144
|
-
c.setItem = (
|
|
145
|
-
|
|
149
|
+
const H = c.setItem.bind(c), L = c.removeItem.bind(c);
|
|
150
|
+
c.setItem = (e, t) => {
|
|
151
|
+
m[e] === void 0 && H.call(c, e, t);
|
|
146
152
|
};
|
|
147
|
-
c.removeItem = (
|
|
148
|
-
|
|
153
|
+
c.removeItem = (e) => {
|
|
154
|
+
m[e] === void 0 && L.call(c, e);
|
|
149
155
|
};
|
|
150
|
-
let
|
|
156
|
+
let k = () => {
|
|
151
157
|
throw "call configureAtomaric() before all!";
|
|
152
158
|
};
|
|
153
|
-
const
|
|
159
|
+
const B = (e) => k = e.useSyncExternalStore, P = (e) => k(e.subscribe, e.get), $ = (e) => e.set, G = (e) => e.setDeferred, M = (e) => e.get, U = (e) => e.do, q = (e) => [P(e), $(e)], z = (e, t) => new F(e, t);
|
|
154
160
|
export {
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
161
|
+
F as Atom,
|
|
162
|
+
z as atom,
|
|
163
|
+
B as configureAtomaric,
|
|
164
|
+
q as useAtom,
|
|
165
|
+
U as useAtomDo,
|
|
166
|
+
M as useAtomGet,
|
|
167
|
+
$ as useAtomSet,
|
|
168
|
+
G as useAtomSetDeferred,
|
|
169
|
+
P as useAtomValue
|
|
164
170
|
};
|
package/build/atomaric.umd.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(
|
|
1
|
+
(function(i,A){typeof exports=="object"&&typeof module<"u"?A(exports):typeof define=="function"&&define.amd?define(["exports"],A):(i=typeof globalThis<"u"?globalThis:i||self,A(i.atomaric={}))})(this,function(i){"use strict";const A=(e,t,r)=>{let a=null;typeof e=="number"?a=m({increment:s=>{t.set(+t.get()+(s??0))}}):typeof e=="boolean"?a=m({toggle:()=>{t.set(!t.get())}}):Array.isArray(e)?a=m({push:(...s)=>{t.set(t.get().concat(s))},unshift:(...s)=>{t.set(s.concat(t.get()))},update:s=>{const c=t.get().slice();s(c),t.set(c)},filter:s=>{t.set(t.get().filter(s??H))}}):e instanceof Set&&(a=m({add:s=>{t.set(new Set(t.get()).add(s))},delete:s=>{const c=new Set(t.get());c.delete(s),t.set(c)},clear:()=>{t.set(new Set)},update:s=>{const c=new Set(t.get());s(c),t.set(c)}}));const f=typeof r=="object"&&r!=null&&"do"in r?r.do((s,c)=>t.set(s,c),()=>t.get()):null,g={};return f&&Object.keys(f).forEach(s=>Object.defineProperty(g,s,{get:()=>f[s]})),a&&Object.keys(a).forEach(s=>Object.defineProperty(g,s,{get:()=>a[s]})),g},H=e=>e,m=(e,t)=>e;class C{constructor(t,r){const a=n=>c=n,f=()=>c,g=new Set,s=n=>n(S());let c=t,_,V=()=>{},S=()=>f(),F=()=>{const n=A(t,this,r);return F=()=>n,n};const v=new Proxy(this,{get:(n,l)=>l==="do"?F():n[l],set:L}),w=(n,l)=>{const d=typeof n=="function"?n(S()):n;if(!(d===S()||d===void 0||typeof d=="number"&&isNaN(d))){a(d),g.forEach(s,this);try{j.postMessage({key:u,value:f()})}catch{}l!==!0&&V(d)}};if(this.set=(n,l)=>w(n,l),this.get=()=>S(),this.defaultValue=t,this.subscribe=n=>(g.add(n),()=>{g.delete(n)}),this.reset=()=>{w(t,!0),g.forEach(s,this)},this.setDeferred=(n,l=500,d,G=!0)=>{G&&_===void 0&&w(n,d),clearTimeout(_),_=setTimeout(()=>{w(n,d),_=void 0},l)},r==null)return v;let b=null,T=!0,p=!0,E=!1,D=t instanceof Set?n=>new Set(JSON.parse(n)):n=>JSON.parse(n),I=t instanceof Set?n=>{if(n instanceof Set)return JSON.stringify(Array.from(n));throw console.error(n),"The value is not Set instance"}:n=>JSON.stringify(n);if(typeof r=="string"?b=r:"storeKey"in r&&(T=r.warnOnDuplicateStoreKey??T,p=r.listenStorageChanges??p,b=r.storeKey,D=r.parseValue??D,I=r.stringifyValue??I,E=r.unchangable??E),b===null)return v;const u=`atom/${b}`;let P=!0;if(S=()=>{if(S=()=>f(),P){P=!1;try{a(u in o?D(o[u]):t)}catch{console.warn("Invalid json value",o[u])}}return f()},V=n=>{if(n===t){this.reset();return}o[u]=I(n)},this.reset=()=>{delete o[u],w(t,!0)},T&&h[u]!==void 0&&console.warn("Duplicate Atom key",b),p)if(E){let n=!1,l;y[u]=this,h[u]=()=>{clearTimeout(l),l=setTimeout(()=>n=!1,10),!n&&(n=!0,o[u]=I(f()))}}else h[u]=n=>{if(n.newValue===null){this.reset();return}try{w(D(n.newValue))}catch{console.warn("Invalid json value",n.newValue)}};return v}}let j;try{j=new BroadcastChannel("updateHere"),j.addEventListener("message",e=>{var t;(t=y[e.data.key])==null||t.set(e.data.value,!0)})}catch{}const o=window.localStorage,h={},y={},L=(e,t)=>{throw`${t} is readonly property`};window.addEventListener("storage",e=>{var t;e.key===null||e.newValue===e.oldValue||(t=h[e.key])==null||t.call(h,e)});const M=o.setItem.bind(o),$=o.removeItem.bind(o);o.setItem=(e,t)=>{y[e]===void 0&&M.call(o,e,t)},o.removeItem=e=>{y[e]===void 0&&$.call(o,e)};let N=()=>{throw"call configureAtomaric() before all!"};const B=e=>N=e.useSyncExternalStore,k=e=>N(e.subscribe,e.get),J=e=>e.set,U=e=>e.setDeferred,q=e=>e.get,z=e=>e.do,Q=e=>[k(e),J(e)],R=(e,t)=>new C(e,t);i.Atom=C,i.atom=R,i.configureAtomaric=B,i.useAtom=Q,i.useAtomDo=z,i.useAtomGet=q,i.useAtomSet=J,i.useAtomSetDeferred=U,i.useAtomValue=k,Object.defineProperty(i,Symbol.toStringTag,{value:"Module"})});
|
package/package.json
CHANGED
package/types/model.d.ts
CHANGED
|
@@ -22,7 +22,10 @@ export type AtomOptions<Value, Actions extends Record<string, Function> = {}> =
|
|
|
22
22
|
}
|
|
23
23
|
| {
|
|
24
24
|
/** declare your custom actions */
|
|
25
|
-
do: (
|
|
25
|
+
do: (
|
|
26
|
+
set: (value: Value | ((value: Value) => Value), isPreventSave?: boolean) => void,
|
|
27
|
+
get: () => Value,
|
|
28
|
+
) => Actions;
|
|
26
29
|
}
|
|
27
30
|
);
|
|
28
31
|
|