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 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
- return selectorFunc.apply(void 0, items.map(function (item) {
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) {
@@ -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
- return selectorFunc.apply(void 0, items.map(function (item) {
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "reactish-state",
3
- "version": "0.5.0",
3
+ "version": "0.5.2",
4
4
  "description": "",
5
5
  "author": "Zheng Song",
6
6
  "license": "MIT",
@@ -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?: A;
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, V> = (...args: ReactishValueArray<R>) => V;
18
- declare const selector: <R extends ReactishArray, V>(...items: [...R, SelectorFunc<R, V>]) => {
19
- get: () => V;
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 };