reactish-state 0.5.0 → 0.5.2
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/dist/cjs/index.js +16 -2
- package/dist/es/vanilla.js +16 -2
- package/package.json +1 -1
- package/types/vanilla.d.ts +7 -7
package/dist/cjs/index.js
CHANGED
|
@@ -29,6 +29,12 @@ var state = function state(initialValue, actionCreator) {
|
|
|
29
29
|
actions: actionCreator && actionCreator(set, get)
|
|
30
30
|
};
|
|
31
31
|
};
|
|
32
|
+
var isEqual = function isEqual(args1, args2) {
|
|
33
|
+
for (var i = 0; i < args1.length; i++) {
|
|
34
|
+
if (!Object.is(args1[i], args2[i])) return false;
|
|
35
|
+
}
|
|
36
|
+
return true;
|
|
37
|
+
};
|
|
32
38
|
var selector = function selector() {
|
|
33
39
|
for (var _len = arguments.length, items = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
34
40
|
items[_key] = arguments[_key];
|
|
@@ -36,11 +42,19 @@ var selector = function selector() {
|
|
|
36
42
|
var lastIndex = items.length - 1;
|
|
37
43
|
var selectorFunc = items[lastIndex];
|
|
38
44
|
items.length = lastIndex;
|
|
45
|
+
var cache;
|
|
39
46
|
return {
|
|
40
47
|
get: function get() {
|
|
41
|
-
|
|
48
|
+
var args = items.map(function (item) {
|
|
42
49
|
return item.get();
|
|
43
|
-
})
|
|
50
|
+
});
|
|
51
|
+
if (cache && isEqual(args, cache.args)) return cache.ret;
|
|
52
|
+
var ret = selectorFunc.apply(void 0, args);
|
|
53
|
+
cache = {
|
|
54
|
+
args: args,
|
|
55
|
+
ret: ret
|
|
56
|
+
};
|
|
57
|
+
return ret;
|
|
44
58
|
},
|
|
45
59
|
subscribe: function subscribe(listener) {
|
|
46
60
|
var unsubscribers = items.map(function (item) {
|
package/dist/es/vanilla.js
CHANGED
|
@@ -25,6 +25,12 @@ var state = function state(initialValue, actionCreator) {
|
|
|
25
25
|
actions: actionCreator && actionCreator(set, get)
|
|
26
26
|
};
|
|
27
27
|
};
|
|
28
|
+
var isEqual = function isEqual(args1, args2) {
|
|
29
|
+
for (var i = 0; i < args1.length; i++) {
|
|
30
|
+
if (!Object.is(args1[i], args2[i])) return false;
|
|
31
|
+
}
|
|
32
|
+
return true;
|
|
33
|
+
};
|
|
28
34
|
var selector = function selector() {
|
|
29
35
|
for (var _len = arguments.length, items = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
30
36
|
items[_key] = arguments[_key];
|
|
@@ -32,11 +38,19 @@ var selector = function selector() {
|
|
|
32
38
|
var lastIndex = items.length - 1;
|
|
33
39
|
var selectorFunc = items[lastIndex];
|
|
34
40
|
items.length = lastIndex;
|
|
41
|
+
var cache;
|
|
35
42
|
return {
|
|
36
43
|
get: function get() {
|
|
37
|
-
|
|
44
|
+
var args = items.map(function (item) {
|
|
38
45
|
return item.get();
|
|
39
|
-
})
|
|
46
|
+
});
|
|
47
|
+
if (cache && isEqual(args, cache.args)) return cache.ret;
|
|
48
|
+
var ret = selectorFunc.apply(void 0, args);
|
|
49
|
+
cache = {
|
|
50
|
+
args: args,
|
|
51
|
+
ret: ret
|
|
52
|
+
};
|
|
53
|
+
return ret;
|
|
40
54
|
},
|
|
41
55
|
subscribe: function subscribe(listener) {
|
|
42
56
|
var unsubscribers = items.map(function (item) {
|
package/package.json
CHANGED
package/types/vanilla.d.ts
CHANGED
|
@@ -1,22 +1,22 @@
|
|
|
1
1
|
declare type Listener = () => void;
|
|
2
2
|
declare type Setter<T> = (newValue: T | ((value: T) => T)) => void;
|
|
3
|
-
declare type ActionCreator<T, A> = (set: Setter<T>, get: () => T) => A;
|
|
3
|
+
declare type ActionCreator<T, A> = ((set: Setter<T>, get: () => T) => A) | undefined;
|
|
4
4
|
interface Reactish<T> {
|
|
5
5
|
get: () => T;
|
|
6
6
|
subscribe: (listener: Listener) => () => void;
|
|
7
7
|
}
|
|
8
|
-
interface State<T, A = unknown> extends Reactish<T> {
|
|
8
|
+
interface State<T, A = unknown, C extends ActionCreator<T, A> = undefined> extends Reactish<T> {
|
|
9
9
|
set: Setter<T>;
|
|
10
|
-
actions
|
|
10
|
+
actions: C extends undefined ? never : A;
|
|
11
11
|
}
|
|
12
|
-
declare const state: <T, A>(initialValue: T, actionCreator?: ActionCreator<T, A>) => State<T, A
|
|
12
|
+
declare const state: <T, A>(initialValue: T, actionCreator?: ActionCreator<T, A>) => State<T, A, ActionCreator<T, A>>;
|
|
13
13
|
declare type ReactishArray = Reactish<unknown>[];
|
|
14
14
|
declare type ReactishValueArray<R extends ReactishArray> = {
|
|
15
15
|
[index in keyof R]: ReturnType<R[index]['get']>;
|
|
16
16
|
};
|
|
17
|
-
declare type SelectorFunc<R extends ReactishArray,
|
|
18
|
-
declare const selector: <R extends ReactishArray,
|
|
19
|
-
get: () =>
|
|
17
|
+
declare type SelectorFunc<R extends ReactishArray, T> = (...args: ReactishValueArray<R>) => T;
|
|
18
|
+
declare const selector: <R extends ReactishArray, T>(...items: [...R, SelectorFunc<R, T>]) => {
|
|
19
|
+
get: () => T;
|
|
20
20
|
subscribe: (listener: Listener) => () => void;
|
|
21
21
|
};
|
|
22
22
|
export { Reactish, state, selector };
|