ccstate 2.0.0 → 2.2.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.
- package/README.md +405 -201
- package/debug/index.cjs +29 -4
- package/debug/index.d.cts +2 -1
- package/debug/index.d.ts +2 -1
- package/debug/index.js +29 -5
- package/index.cjs +39 -36
- package/index.d.cts +2 -1
- package/index.d.ts +2 -1
- package/index.js +39 -37
- package/package.json +7 -2
- package/react/index.cjs +10 -32
- package/react/index.js +10 -32
- package/vue/index.cjs +71 -0
- package/vue/index.d.cts +53 -0
- package/vue/index.d.ts +53 -0
- package/vue/index.js +66 -0
package/vue/index.d.cts
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { ShallowRef } from 'vue';
|
|
2
|
+
|
|
3
|
+
type Updater<T> = (current: T) => T;
|
|
4
|
+
interface Setter {
|
|
5
|
+
<T>(state: State<T>, val: T | Updater<T>): void;
|
|
6
|
+
<T, Args extends unknown[]>(command: Command<T, Args>, ...args: Args): T;
|
|
7
|
+
}
|
|
8
|
+
type Getter = <T>(readable: ReadableAtom<T>) => T;
|
|
9
|
+
interface GetterOptions {
|
|
10
|
+
signal: AbortSignal;
|
|
11
|
+
}
|
|
12
|
+
type Read<T> = (get: Getter, options: GetterOptions) => T;
|
|
13
|
+
type Write<T, Args extends unknown[]> = (visitor: {
|
|
14
|
+
get: Getter;
|
|
15
|
+
set: Setter;
|
|
16
|
+
}, ...args: Args) => T;
|
|
17
|
+
interface State<T> {
|
|
18
|
+
init: T;
|
|
19
|
+
debugLabel?: string;
|
|
20
|
+
toString: () => string;
|
|
21
|
+
}
|
|
22
|
+
interface Computed<T> {
|
|
23
|
+
read: Read<T>;
|
|
24
|
+
debugLabel?: string;
|
|
25
|
+
toString: () => string;
|
|
26
|
+
}
|
|
27
|
+
interface Command<T, Args extends unknown[]> {
|
|
28
|
+
write: Write<T, Args>;
|
|
29
|
+
debugLabel?: string;
|
|
30
|
+
toString: () => string;
|
|
31
|
+
}
|
|
32
|
+
type ReadableAtom<T> = State<T> | Computed<T>;
|
|
33
|
+
|
|
34
|
+
interface Store {
|
|
35
|
+
get: Getter;
|
|
36
|
+
set: Setter;
|
|
37
|
+
sub: Subscribe;
|
|
38
|
+
}
|
|
39
|
+
interface SubscribeOptions {
|
|
40
|
+
signal?: AbortSignal;
|
|
41
|
+
}
|
|
42
|
+
type CallbackFunc<T> = Command<T, []>;
|
|
43
|
+
type Subscribe = (atoms$: ReadableAtom<unknown>[] | ReadableAtom<unknown>, callback: CallbackFunc<unknown>, options?: SubscribeOptions) => () => void;
|
|
44
|
+
|
|
45
|
+
declare const provideStore: (store: Store) => void;
|
|
46
|
+
declare const useStore: () => Store;
|
|
47
|
+
|
|
48
|
+
declare function useGet<Value>(atom: Computed<Value> | State<Value>): Readonly<ShallowRef<Value>>;
|
|
49
|
+
|
|
50
|
+
declare function useSet<T>(atom: State<T>): (value: T | Updater<T>) => void;
|
|
51
|
+
declare function useSet<T, ARGS extends unknown[]>(atom: Command<T, ARGS>): (...args: ARGS) => T;
|
|
52
|
+
|
|
53
|
+
export { provideStore, useGet, useSet, useStore };
|
package/vue/index.d.ts
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { ShallowRef } from 'vue';
|
|
2
|
+
|
|
3
|
+
type Updater<T> = (current: T) => T;
|
|
4
|
+
interface Setter {
|
|
5
|
+
<T>(state: State<T>, val: T | Updater<T>): void;
|
|
6
|
+
<T, Args extends unknown[]>(command: Command<T, Args>, ...args: Args): T;
|
|
7
|
+
}
|
|
8
|
+
type Getter = <T>(readable: ReadableAtom<T>) => T;
|
|
9
|
+
interface GetterOptions {
|
|
10
|
+
signal: AbortSignal;
|
|
11
|
+
}
|
|
12
|
+
type Read<T> = (get: Getter, options: GetterOptions) => T;
|
|
13
|
+
type Write<T, Args extends unknown[]> = (visitor: {
|
|
14
|
+
get: Getter;
|
|
15
|
+
set: Setter;
|
|
16
|
+
}, ...args: Args) => T;
|
|
17
|
+
interface State<T> {
|
|
18
|
+
init: T;
|
|
19
|
+
debugLabel?: string;
|
|
20
|
+
toString: () => string;
|
|
21
|
+
}
|
|
22
|
+
interface Computed<T> {
|
|
23
|
+
read: Read<T>;
|
|
24
|
+
debugLabel?: string;
|
|
25
|
+
toString: () => string;
|
|
26
|
+
}
|
|
27
|
+
interface Command<T, Args extends unknown[]> {
|
|
28
|
+
write: Write<T, Args>;
|
|
29
|
+
debugLabel?: string;
|
|
30
|
+
toString: () => string;
|
|
31
|
+
}
|
|
32
|
+
type ReadableAtom<T> = State<T> | Computed<T>;
|
|
33
|
+
|
|
34
|
+
interface Store {
|
|
35
|
+
get: Getter;
|
|
36
|
+
set: Setter;
|
|
37
|
+
sub: Subscribe;
|
|
38
|
+
}
|
|
39
|
+
interface SubscribeOptions {
|
|
40
|
+
signal?: AbortSignal;
|
|
41
|
+
}
|
|
42
|
+
type CallbackFunc<T> = Command<T, []>;
|
|
43
|
+
type Subscribe = (atoms$: ReadableAtom<unknown>[] | ReadableAtom<unknown>, callback: CallbackFunc<unknown>, options?: SubscribeOptions) => () => void;
|
|
44
|
+
|
|
45
|
+
declare const provideStore: (store: Store) => void;
|
|
46
|
+
declare const useStore: () => Store;
|
|
47
|
+
|
|
48
|
+
declare function useGet<Value>(atom: Computed<Value> | State<Value>): Readonly<ShallowRef<Value>>;
|
|
49
|
+
|
|
50
|
+
declare function useSet<T>(atom: State<T>): (value: T | Updater<T>) => void;
|
|
51
|
+
declare function useSet<T, ARGS extends unknown[]>(atom: Command<T, ARGS>): (...args: ARGS) => T;
|
|
52
|
+
|
|
53
|
+
export { provideStore, useGet, useSet, useStore };
|
package/vue/index.js
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { provide, inject, shallowRef, getCurrentInstance, onScopeDispose, shallowReadonly } from 'vue';
|
|
2
|
+
|
|
3
|
+
var StoreKey = Symbol('ccstate-vue-store');
|
|
4
|
+
var provideStore = function provideStore(store) {
|
|
5
|
+
provide(StoreKey, store);
|
|
6
|
+
};
|
|
7
|
+
var useStore = function useStore() {
|
|
8
|
+
var store = inject(StoreKey);
|
|
9
|
+
if (store === undefined) {
|
|
10
|
+
throw new Error('Store context not found - did you forget to wrap your app with StoreProvider?');
|
|
11
|
+
}
|
|
12
|
+
return store;
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
var globalId = 0;
|
|
16
|
+
var generateToString = function generateToString(prefix, debugLabel) {
|
|
17
|
+
var id = globalId++;
|
|
18
|
+
var label = "".concat(prefix).concat(String(id)).concat('');
|
|
19
|
+
return function () {
|
|
20
|
+
return label;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
function command(write, options) {
|
|
24
|
+
var ret = {
|
|
25
|
+
write: write,
|
|
26
|
+
toString: generateToString('F')
|
|
27
|
+
};
|
|
28
|
+
return ret;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function useGet(atom) {
|
|
32
|
+
var store = useStore();
|
|
33
|
+
var initialValue = store.get(atom);
|
|
34
|
+
var vueState = shallowRef(initialValue);
|
|
35
|
+
var controller = new AbortController();
|
|
36
|
+
store.sub(atom, command(function () {
|
|
37
|
+
var nextValue = store.get(atom);
|
|
38
|
+
vueState.value = nextValue;
|
|
39
|
+
}), {
|
|
40
|
+
signal: controller.signal
|
|
41
|
+
});
|
|
42
|
+
if (getCurrentInstance()) {
|
|
43
|
+
onScopeDispose(function () {
|
|
44
|
+
controller.abort();
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
return shallowReadonly(vueState);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
function useSet(atom) {
|
|
51
|
+
var store = useStore();
|
|
52
|
+
if ('write' in atom) {
|
|
53
|
+
return function () {
|
|
54
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
55
|
+
args[_key] = arguments[_key];
|
|
56
|
+
}
|
|
57
|
+
var ret = store.set.apply(store, [atom].concat(args));
|
|
58
|
+
return ret;
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
return function (value) {
|
|
62
|
+
store.set(atom, value);
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
export { provideStore, useGet, useSet, useStore };
|