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