@tamagui/use-store 1.57.1 → 1.57.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/package.json +3 -3
- package/dist/cjs/Store.js +0 -101
- package/dist/cjs/Store.js.map +0 -6
- package/dist/cjs/reaction.js +0 -82
- package/dist/cjs/reaction.js.map +0 -6
- package/dist/cjs/selector.js +0 -103
- package/dist/cjs/selector.js.map +0 -6
- package/dist/cjs/useAsyncExternalStore.js +0 -42
- package/dist/cjs/useAsyncExternalStore.js.map +0 -6
- package/dist/esm/Store.js +0 -71
- package/dist/esm/Store.js.map +0 -6
- package/dist/esm/reaction.js +0 -57
- package/dist/esm/reaction.js.map +0 -6
- package/dist/esm/selector.js +0 -79
- package/dist/esm/selector.js.map +0 -6
- package/dist/esm/useAsyncExternalStore.js +0 -18
- package/dist/esm/useAsyncExternalStore.js.map +0 -6
- package/types/Store.d.ts +0 -23
- package/types/Store.d.ts.map +0 -1
- package/types/reaction.d.ts +0 -1
- package/types/reaction.d.ts.map +0 -1
- package/types/selector.d.ts +0 -6
- package/types/selector.d.ts.map +0 -1
- package/types/useAsyncExternalStore.d.ts +0 -2
- package/types/useAsyncExternalStore.d.ts.map +0 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tamagui/use-store",
|
|
3
|
-
"version": "1.57.
|
|
3
|
+
"version": "1.57.2",
|
|
4
4
|
"types": "./types/index.d.ts",
|
|
5
5
|
"main": "dist/cjs",
|
|
6
6
|
"module": "dist/esm",
|
|
@@ -27,10 +27,10 @@
|
|
|
27
27
|
}
|
|
28
28
|
},
|
|
29
29
|
"dependencies": {
|
|
30
|
-
"@tamagui/simple-hash": "1.57.
|
|
30
|
+
"@tamagui/simple-hash": "1.57.2"
|
|
31
31
|
},
|
|
32
32
|
"devDependencies": {
|
|
33
|
-
"@tamagui/build": "1.57.
|
|
33
|
+
"@tamagui/build": "1.57.2",
|
|
34
34
|
"@testing-library/react": "^13.4.0",
|
|
35
35
|
"react": "^18.2.0",
|
|
36
36
|
"vitest": "^0.26.3"
|
package/dist/cjs/Store.js
DELETED
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var Store_exports = {};
|
|
20
|
-
__export(Store_exports, {
|
|
21
|
-
ADD_TRACKER: () => ADD_TRACKER,
|
|
22
|
-
SHOULD_DEBUG: () => SHOULD_DEBUG,
|
|
23
|
-
Store: () => Store,
|
|
24
|
-
TRACK: () => TRACK,
|
|
25
|
-
TRIGGER_UPDATE: () => TRIGGER_UPDATE,
|
|
26
|
-
disableTracking: () => disableTracking,
|
|
27
|
-
setDisableStoreTracking: () => setDisableStoreTracking
|
|
28
|
-
});
|
|
29
|
-
module.exports = __toCommonJS(Store_exports);
|
|
30
|
-
var import_constants = require("./constants");
|
|
31
|
-
var import_useStoreDebug = require("./useStoreDebug");
|
|
32
|
-
const TRIGGER_UPDATE = Symbol();
|
|
33
|
-
const ADD_TRACKER = Symbol();
|
|
34
|
-
const TRACK = Symbol();
|
|
35
|
-
const SHOULD_DEBUG = Symbol();
|
|
36
|
-
const disableTracking = /* @__PURE__ */ new WeakMap();
|
|
37
|
-
const setDisableStoreTracking = (storeInstance, val) => {
|
|
38
|
-
const store = storeInstance[import_constants.UNWRAP_PROXY] ?? storeInstance;
|
|
39
|
-
disableTracking.set(store, val);
|
|
40
|
-
};
|
|
41
|
-
class Store {
|
|
42
|
-
constructor(props) {
|
|
43
|
-
this.props = props;
|
|
44
|
-
this._listeners = /* @__PURE__ */ new Set();
|
|
45
|
-
this._trackers = /* @__PURE__ */ new Set();
|
|
46
|
-
this._version = 0;
|
|
47
|
-
this.subscribe = (onChanged) => {
|
|
48
|
-
this._listeners.add(onChanged);
|
|
49
|
-
return () => {
|
|
50
|
-
this._listeners.delete(onChanged);
|
|
51
|
-
};
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
[TRIGGER_UPDATE]() {
|
|
55
|
-
this._version = (this._version + 1) % Number.MAX_SAFE_INTEGER;
|
|
56
|
-
for (const cb of this._listeners) {
|
|
57
|
-
cb();
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
// [ADD_TRACKER](tracker: StoreTracker) {
|
|
61
|
-
// this._trackers.add(tracker)
|
|
62
|
-
// return () => {
|
|
63
|
-
// this._trackers.delete(tracker)
|
|
64
|
-
// }
|
|
65
|
-
// }
|
|
66
|
-
// [TRACK](key: string, debug?: boolean) {
|
|
67
|
-
// if (key[0] === '_' || key[0] === '$' || key === 'props' || key === 'toJSON') {
|
|
68
|
-
// return
|
|
69
|
-
// }
|
|
70
|
-
// if (debug) {
|
|
71
|
-
// // rome-ignore lint/nursery/noConsoleLog: <explanation>
|
|
72
|
-
// console.log('(debug) CHECK TRACKERS FOR', key)
|
|
73
|
-
// }
|
|
74
|
-
// for (const tracker of this._trackers) {
|
|
75
|
-
// if (tracker.isTracking) {
|
|
76
|
-
// tracker.tracked.add(key)
|
|
77
|
-
// if (debug) {
|
|
78
|
-
// // rome-ignore lint/nursery/noConsoleLog: <explanation>
|
|
79
|
-
// console.log('(debug) TRACK', key, tracker)
|
|
80
|
-
// }
|
|
81
|
-
// }
|
|
82
|
-
// }
|
|
83
|
-
// }
|
|
84
|
-
[SHOULD_DEBUG]() {
|
|
85
|
-
const info = { storeInstance: this };
|
|
86
|
-
return [...this._trackers].some(
|
|
87
|
-
(tracker) => tracker.component && (0, import_useStoreDebug.shouldDebug)(tracker.component, info)
|
|
88
|
-
);
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
92
|
-
0 && (module.exports = {
|
|
93
|
-
ADD_TRACKER,
|
|
94
|
-
SHOULD_DEBUG,
|
|
95
|
-
Store,
|
|
96
|
-
TRACK,
|
|
97
|
-
TRIGGER_UPDATE,
|
|
98
|
-
disableTracking,
|
|
99
|
-
setDisableStoreTracking
|
|
100
|
-
});
|
|
101
|
-
//# sourceMappingURL=Store.js.map
|
package/dist/cjs/Store.js.map
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/Store.tsx"],
|
|
4
|
-
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,uBAA6B;AAC7B,2BAA4B;AAErB,MAAM,iBAAiB,OAAO;AAC9B,MAAM,cAAc,OAAO;AAC3B,MAAM,QAAQ,OAAO;AACrB,MAAM,eAAe,OAAO;AAS5B,MAAM,kBAAkB,oBAAI,QAAQ;AAEpC,MAAM,0BAA0B,CAAC,eAAoB,QAAiB;AAC3E,QAAM,QAAQ,cAAc,6BAAY,KAAK;AAC7C,kBAAgB,IAAI,OAAO,GAAG;AAChC;AAEO,MAAM,MAAiC;AAAA,EAK5C,YAAmB,OAAc;AAAd;AAJnB,SAAQ,aAAa,oBAAI,IAAc;AACvC,SAAQ,YAAY,oBAAI,IAAkB;AAC1C,oBAAW;AAIX,qBAAY,CAAC,cAAwB;AACnC,WAAK,WAAW,IAAI,SAAS;AAC7B,aAAO,MAAM;AACX,aAAK,WAAW,OAAO,SAAS;AAAA,MAClC;AAAA,IACF;AAAA,EAPkC;AAAA,EASlC,CAAC,cAAc,IAAI;AACjB,SAAK,YAAY,KAAK,WAAW,KAAK,OAAO;AAC7C,eAAW,MAAM,KAAK,YAAY;AAChC,SAAG;AAAA,IACL;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA4BA,CAAC,YAAY,IAAI;AACf,UAAM,OAAO,EAAE,eAAe,KAAK;AACnC,WAAO,CAAC,GAAG,KAAK,SAAS,EAAE;AAAA,MACzB,CAAC,YAAY,QAAQ,iBAAa,kCAAY,QAAQ,WAAW,IAAI;AAAA,IACvE;AAAA,EACF;AACF;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
package/dist/cjs/reaction.js
DELETED
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var reaction_exports = {};
|
|
20
|
-
__export(reaction_exports, {
|
|
21
|
-
reaction: () => reaction,
|
|
22
|
-
useReaction: () => useReaction
|
|
23
|
-
});
|
|
24
|
-
module.exports = __toCommonJS(reaction_exports);
|
|
25
|
-
var import_react = require("react");
|
|
26
|
-
var import_comparators = require("./comparators");
|
|
27
|
-
var import_constants = require("./constants");
|
|
28
|
-
var import_useStore = require("./useStore");
|
|
29
|
-
const dispose = (d) => {
|
|
30
|
-
if (typeof d === "function") {
|
|
31
|
-
d();
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
function useReaction(store, selector, receiver, props, equalityFn = import_comparators.isEqualSubsetShallow, memoArgs) {
|
|
35
|
-
const storeInfo = (0, import_useStore.getStoreInfo)(store, props);
|
|
36
|
-
return (0, import_react.useMemo)(
|
|
37
|
-
() => reaction(storeInfo, selector, receiver, equalityFn),
|
|
38
|
-
[memoArgs]
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
function reaction({ store, subscribe }, selector, receiver, equalityFn = import_comparators.isEqualSubsetShallow) {
|
|
42
|
-
let last = void 0;
|
|
43
|
-
let innerDispose;
|
|
44
|
-
function updateReaction() {
|
|
45
|
-
var _a;
|
|
46
|
-
try {
|
|
47
|
-
(0, import_useStore.setIsInReaction)(true);
|
|
48
|
-
const storeInstance = store[import_constants.UNWRAP_PROXY] || store;
|
|
49
|
-
const next = selector(storeInstance);
|
|
50
|
-
if (!equalityFn(last, next)) {
|
|
51
|
-
if (process.env.NODE_ENV === "development") {
|
|
52
|
-
console.groupCollapsed(
|
|
53
|
-
`\u{1F311} \u23ED %c${receiver.name.padStart(24)} (${storeInstance.constructor.name}${((_a = store.props) == null ? void 0 : _a.id) ? `:${store.props.id}` : ""}) ${last} => ${next}`,
|
|
54
|
-
"color: chocolate;"
|
|
55
|
-
);
|
|
56
|
-
console.groupCollapsed("trace >");
|
|
57
|
-
console.trace();
|
|
58
|
-
console.groupEnd();
|
|
59
|
-
console.log(" ARG", next);
|
|
60
|
-
console.groupEnd();
|
|
61
|
-
}
|
|
62
|
-
dispose(innerDispose);
|
|
63
|
-
last = next;
|
|
64
|
-
innerDispose = receiver(next);
|
|
65
|
-
}
|
|
66
|
-
} finally {
|
|
67
|
-
(0, import_useStore.setIsInReaction)(false);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
const disposeSubscribe = subscribe(updateReaction);
|
|
71
|
-
updateReaction();
|
|
72
|
-
return () => {
|
|
73
|
-
disposeSubscribe();
|
|
74
|
-
dispose(innerDispose);
|
|
75
|
-
};
|
|
76
|
-
}
|
|
77
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
78
|
-
0 && (module.exports = {
|
|
79
|
-
reaction,
|
|
80
|
-
useReaction
|
|
81
|
-
});
|
|
82
|
-
//# sourceMappingURL=reaction.js.map
|
package/dist/cjs/reaction.js.map
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/reaction.tsx"],
|
|
4
|
-
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAwB;AAExB,yBAAqC;AACrC,uBAA6B;AAE7B,sBAA8C;AAE9C,MAAM,UAAU,CAAC,MAAW;AAC1B,MAAI,OAAO,MAAM,YAAY;AAC3B,MAAE;AAAA,EACJ;AACF;AAEO,SAAS,YACd,OACA,UACA,UAGA,OACA,aAA0C,yCAC1C,UACA;AACA,QAAM,gBAAY,8BAAa,OAAO,KAAK;AAC3C,aAAO;AAAA,IACL,MAAM,SAAS,WAAW,UAAiB,UAAU,UAAU;AAAA,IAC/D,CAAC,QAAQ;AAAA,EACX;AACF;AAEO,SAAS,SAId,EAAE,OAAO,UAAU,GACnB,UACA,UAGA,aAA0C,yCAC1C;AACA,MAAI,OAAY;AAChB,MAAI;AAEJ,WAAS,iBAAiB;AA5C5B;AA6CI,QAAI;AACF,2CAAgB,IAAI;AACpB,YAAM,gBAAgB,MAAM,6BAAY,KAAK;AAC7C,YAAM,OAAO,SAAS,aAAa;AACnC,UAAI,CAAC,WAAW,MAAM,IAAI,GAAG;AAC3B,YAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,kBAAQ;AAAA,YACN,uBAAW,SAAS,KAAK,SAAS,EAAE,CAAC,KAAK,cAAc,YAAY,IAAI,KACtE,WAAM,UAAN,mBAAa,MAAK,IAAI,MAAM,MAAM,EAAE,KAAK,EAC3C,KAAK,IAAI,OAAO,IAAI;AAAA,YACpB;AAAA,UACF;AACA,kBAAQ,eAAe,SAAS;AAChC,kBAAQ,MAAM;AACd,kBAAQ,SAAS;AAEjB,kBAAQ,IAAI,SAAS,IAAI;AACzB,kBAAQ,SAAS;AAAA,QACnB;AACA,gBAAQ,YAAY;AACpB,eAAO;AACP,uBAAe,SAAS,IAAI;AAAA,MAC9B;AAAA,IACF,UAAE;AACA,2CAAgB,KAAK;AAAA,IACvB;AAAA,EACF;AAEA,QAAM,mBAAmB,UAAU,cAAc;AACjD,iBAAe;AAEf,SAAO,MAAM;AACX,qBAAiB;AACjB,YAAQ,YAAY;AAAA,EACtB;AACF;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
package/dist/cjs/selector.js
DELETED
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var selector_exports = {};
|
|
20
|
-
__export(selector_exports, {
|
|
21
|
-
useSelector: () => useSelector
|
|
22
|
-
});
|
|
23
|
-
module.exports = __toCommonJS(selector_exports);
|
|
24
|
-
var import_react = require("react");
|
|
25
|
-
var import_comparators = require("./comparators");
|
|
26
|
-
var import_constants = require("./constants");
|
|
27
|
-
var import_useStore = require("./useStore");
|
|
28
|
-
const logUpdate = process.env.NODE_ENV === "development" ? (fn, stores, last, next) => {
|
|
29
|
-
const getStoreLogName = (store) => {
|
|
30
|
-
var _a;
|
|
31
|
-
const str = store[import_constants.UNWRAP_PROXY] ?? store;
|
|
32
|
-
return `${str.constructor.name}${((_a = store.props) == null ? void 0 : _a.id) ? `:${store.props.id}` : ""}`;
|
|
33
|
-
};
|
|
34
|
-
const storeNames = stores.map(getStoreLogName).join(", ");
|
|
35
|
-
const name = `\u{1F311} \u25B6\uFE0F %c${fn.name} ${storeNames} () ${last} => ${next}`;
|
|
36
|
-
console.groupCollapsed(name, "color: tomato;");
|
|
37
|
-
console.groupCollapsed("trace >");
|
|
38
|
-
console.trace();
|
|
39
|
-
console.groupEnd();
|
|
40
|
-
console.log(" next", next);
|
|
41
|
-
console.groupEnd();
|
|
42
|
-
} : null;
|
|
43
|
-
function useSelector(fn) {
|
|
44
|
-
const [state, setState] = (0, import_react.useState)(() => {
|
|
45
|
-
return runStoreSelector(fn);
|
|
46
|
-
});
|
|
47
|
-
(0, import_react.useEffect)(() => {
|
|
48
|
-
let dispose;
|
|
49
|
-
const unsub = subscribeToStores([...state.storeInfos], () => {
|
|
50
|
-
dispose == null ? void 0 : dispose();
|
|
51
|
-
const next = runStoreSelector(fn);
|
|
52
|
-
const nextStoreInfos = [...next.storeInfos];
|
|
53
|
-
const prevStoreInfos = [...state.storeInfos];
|
|
54
|
-
if (typeof next.value === "function") {
|
|
55
|
-
if (process.env.NODE_ENV === "development") {
|
|
56
|
-
logUpdate(fn, nextStoreInfos, "(fn)", "(fn)");
|
|
57
|
-
}
|
|
58
|
-
dispose = next.value;
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
setState((prev) => {
|
|
62
|
-
if ((0, import_comparators.isEqualSubsetShallow)(prevStoreInfos, nextStoreInfos) && (0, import_comparators.isEqualSubsetShallow)(prev.value, next.value)) {
|
|
63
|
-
return prev;
|
|
64
|
-
}
|
|
65
|
-
if (process.env.NODE_ENV === "development") {
|
|
66
|
-
logUpdate(fn, nextStoreInfos, prev.value, next.value);
|
|
67
|
-
}
|
|
68
|
-
return next;
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
return () => {
|
|
72
|
-
unsub();
|
|
73
|
-
dispose == null ? void 0 : dispose();
|
|
74
|
-
};
|
|
75
|
-
}, [[...state.storeInfos].map((i) => i.uid).join(",")]);
|
|
76
|
-
return state.value;
|
|
77
|
-
}
|
|
78
|
-
function runStoreSelector(selector) {
|
|
79
|
-
const storeInfos = /* @__PURE__ */ new Set();
|
|
80
|
-
const dispose = (0, import_useStore.trackStoresAccess)((storeInfo) => {
|
|
81
|
-
storeInfos.add(storeInfo);
|
|
82
|
-
});
|
|
83
|
-
const value = selector();
|
|
84
|
-
dispose();
|
|
85
|
-
return {
|
|
86
|
-
value,
|
|
87
|
-
storeInfos
|
|
88
|
-
};
|
|
89
|
-
}
|
|
90
|
-
function subscribeToStores(stores, onUpdate) {
|
|
91
|
-
const disposes = [];
|
|
92
|
-
for (const store of stores) {
|
|
93
|
-
disposes.push(store.subscribe(onUpdate));
|
|
94
|
-
}
|
|
95
|
-
return () => {
|
|
96
|
-
disposes.forEach((x) => x());
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
100
|
-
0 && (module.exports = {
|
|
101
|
-
useSelector
|
|
102
|
-
});
|
|
103
|
-
//# sourceMappingURL=selector.js.map
|
package/dist/cjs/selector.js.map
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/selector.tsx"],
|
|
4
|
-
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAoC;AAEpC,yBAAqC;AACrC,uBAA6B;AAE7B,sBAAkC;AAIlC,MAAM,YACJ,QAAQ,IAAI,aAAa,gBACrB,CAAC,IAAS,QAAe,MAAW,SAAc;AAChD,QAAM,kBAAkB,CAAC,UAAe;AAZhD;AAaU,UAAM,MAAM,MAAM,6BAAY,KAAK;AACnC,WAAO,GAAG,IAAI,YAAY,IAAI,KAAG,WAAM,UAAN,mBAAa,MAAK,IAAI,MAAM,MAAM,EAAE,KAAK,EAAE;AAAA,EAC9E;AACA,QAAM,aAAa,OAAO,IAAI,eAAe,EAAE,KAAK,IAAI;AACxD,QAAM,OAAO,6BAAY,GAAG,IAAI,IAAI,UAAU,OAAO,IAAI,OAAO,IAAI;AACpE,UAAQ,eAAe,MAAM,gBAAgB;AAC7C,UAAQ,eAAe,SAAS;AAChC,UAAQ,MAAM;AACd,UAAQ,SAAS;AAEjB,UAAQ,IAAI,UAAU,IAAI;AAC1B,UAAQ,SAAS;AACnB,IACA;AA2CC,SAAS,YAAe,IAAgB;AAC7C,QAAM,CAAC,OAAO,QAAQ,QAAI,uBAAS,MAAM;AACvC,WAAO,iBAAiB,EAAE;AAAA,EAC5B,CAAC;AAED,8BAAU,MAAM;AACd,QAAI;AACJ,UAAM,QAAQ,kBAAkB,CAAC,GAAG,MAAM,UAAU,GAAG,MAAM;AAC3D;AACA,YAAM,OAAO,iBAAiB,EAAE;AAEhC,YAAM,iBAAiB,CAAC,GAAG,KAAK,UAAU;AAC1C,YAAM,iBAAiB,CAAC,GAAG,MAAM,UAAU;AAG3C,UAAI,OAAO,KAAK,UAAU,YAAY;AACpC,YAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,oBAAW,IAAI,gBAAgB,QAAQ,MAAM;AAAA,QAC/C;AACA,kBAAU,KAAK;AACf;AAAA,MACF;AACA,eAAS,CAAC,SAAS;AACjB,gBACE,yCAAqB,gBAAgB,cAAc,SACnD,yCAAqB,KAAK,OAAO,KAAK,KAAK,GAC3C;AACA,iBAAO;AAAA,QACT;AACA,YAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,oBAAW,IAAI,gBAAgB,KAAK,OAAO,KAAK,KAAK;AAAA,QACvD;AACA,eAAO;AAAA,MACT,CAAC;AAAA,IACH,CAAC;AACD,WAAO,MAAM;AACX,YAAM;AACN;AAAA,IACF;AAAA,EACF,GAAG,CAAC,CAAC,GAAG,MAAM,UAAU,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK,GAAG,CAAC,CAAC;AAEtD,SAAO,MAAM;AACf;AAEA,SAAS,iBAAoB,UAG3B;AACA,QAAM,aAAa,oBAAI,IAAe;AACtC,QAAM,cAAU,mCAAkB,CAAC,cAAc;AAC/C,eAAW,IAAI,SAAS;AAAA,EAC1B,CAAC;AACD,QAAM,QAAQ,SAAS;AACvB,UAAQ;AACR,SAAO;AAAA,IACL;AAAA,IACA;AAAA,EACF;AACF;AAEA,SAAS,kBAAkB,QAAqB,UAAqB;AACnE,QAAM,WAAuB,CAAC;AAC9B,aAAW,SAAS,QAAQ;AAC1B,aAAS,KAAK,MAAM,UAAU,QAAQ,CAAC;AAAA,EACzC;AACA,SAAO,MAAM;AACX,aAAS,QAAQ,CAAC,MAAM,EAAE,CAAC;AAAA,EAC7B;AACF;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var useAsyncExternalStore_exports = {};
|
|
20
|
-
__export(useAsyncExternalStore_exports, {
|
|
21
|
-
useAsyncExternalStore: () => useAsyncExternalStore
|
|
22
|
-
});
|
|
23
|
-
module.exports = __toCommonJS(useAsyncExternalStore_exports);
|
|
24
|
-
var import_react = require("react");
|
|
25
|
-
function useAsyncExternalStore(subscribe, getSnapshot, getServerSnapshot) {
|
|
26
|
-
const [storeState, setStoreState] = (0, import_react.useState)(getServerSnapshot);
|
|
27
|
-
if (typeof document !== "undefined") {
|
|
28
|
-
(0, import_react.useLayoutEffect)(() => {
|
|
29
|
-
return subscribe((next) => {
|
|
30
|
-
(0, import_react.startTransition)(() => {
|
|
31
|
-
setStoreState(getSnapshot(next));
|
|
32
|
-
});
|
|
33
|
-
});
|
|
34
|
-
}, [subscribe]);
|
|
35
|
-
}
|
|
36
|
-
return storeState;
|
|
37
|
-
}
|
|
38
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
39
|
-
0 && (module.exports = {
|
|
40
|
-
useAsyncExternalStore
|
|
41
|
-
});
|
|
42
|
-
//# sourceMappingURL=useAsyncExternalStore.js.map
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/useAsyncExternalStore.tsx"],
|
|
4
|
-
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAA2D;AAEpD,SAAS,sBACd,WACA,aACA,mBACA;AACA,QAAM,CAAC,YAAY,aAAa,QAAI,uBAAS,iBAAiB;AAE9D,MAAI,OAAO,aAAa,aAAa;AACnC,sCAAgB,MAAM;AACpB,aAAO,UAAU,CAAC,SAAc;AAC9B,0CAAgB,MAAM;AACpB,wBAAc,YAAY,IAAI,CAAC;AAAA,QACjC,CAAC;AAAA,MACH,CAAC;AAAA,IACH,GAAG,CAAC,SAAS,CAAC;AAAA,EAChB;AAEA,SAAO;AACT;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
package/dist/esm/Store.js
DELETED
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import { UNWRAP_PROXY } from "./constants";
|
|
2
|
-
import { shouldDebug } from "./useStoreDebug";
|
|
3
|
-
const TRIGGER_UPDATE = Symbol();
|
|
4
|
-
const ADD_TRACKER = Symbol();
|
|
5
|
-
const TRACK = Symbol();
|
|
6
|
-
const SHOULD_DEBUG = Symbol();
|
|
7
|
-
const disableTracking = /* @__PURE__ */ new WeakMap();
|
|
8
|
-
const setDisableStoreTracking = (storeInstance, val) => {
|
|
9
|
-
const store = storeInstance[UNWRAP_PROXY] ?? storeInstance;
|
|
10
|
-
disableTracking.set(store, val);
|
|
11
|
-
};
|
|
12
|
-
class Store {
|
|
13
|
-
constructor(props) {
|
|
14
|
-
this.props = props;
|
|
15
|
-
this._listeners = /* @__PURE__ */ new Set();
|
|
16
|
-
this._trackers = /* @__PURE__ */ new Set();
|
|
17
|
-
this._version = 0;
|
|
18
|
-
this.subscribe = (onChanged) => {
|
|
19
|
-
this._listeners.add(onChanged);
|
|
20
|
-
return () => {
|
|
21
|
-
this._listeners.delete(onChanged);
|
|
22
|
-
};
|
|
23
|
-
};
|
|
24
|
-
}
|
|
25
|
-
[TRIGGER_UPDATE]() {
|
|
26
|
-
this._version = (this._version + 1) % Number.MAX_SAFE_INTEGER;
|
|
27
|
-
for (const cb of this._listeners) {
|
|
28
|
-
cb();
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
// [ADD_TRACKER](tracker: StoreTracker) {
|
|
32
|
-
// this._trackers.add(tracker)
|
|
33
|
-
// return () => {
|
|
34
|
-
// this._trackers.delete(tracker)
|
|
35
|
-
// }
|
|
36
|
-
// }
|
|
37
|
-
// [TRACK](key: string, debug?: boolean) {
|
|
38
|
-
// if (key[0] === '_' || key[0] === '$' || key === 'props' || key === 'toJSON') {
|
|
39
|
-
// return
|
|
40
|
-
// }
|
|
41
|
-
// if (debug) {
|
|
42
|
-
// // rome-ignore lint/nursery/noConsoleLog: <explanation>
|
|
43
|
-
// console.log('(debug) CHECK TRACKERS FOR', key)
|
|
44
|
-
// }
|
|
45
|
-
// for (const tracker of this._trackers) {
|
|
46
|
-
// if (tracker.isTracking) {
|
|
47
|
-
// tracker.tracked.add(key)
|
|
48
|
-
// if (debug) {
|
|
49
|
-
// // rome-ignore lint/nursery/noConsoleLog: <explanation>
|
|
50
|
-
// console.log('(debug) TRACK', key, tracker)
|
|
51
|
-
// }
|
|
52
|
-
// }
|
|
53
|
-
// }
|
|
54
|
-
// }
|
|
55
|
-
[SHOULD_DEBUG]() {
|
|
56
|
-
const info = { storeInstance: this };
|
|
57
|
-
return [...this._trackers].some(
|
|
58
|
-
(tracker) => tracker.component && shouldDebug(tracker.component, info)
|
|
59
|
-
);
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
export {
|
|
63
|
-
ADD_TRACKER,
|
|
64
|
-
SHOULD_DEBUG,
|
|
65
|
-
Store,
|
|
66
|
-
TRACK,
|
|
67
|
-
TRIGGER_UPDATE,
|
|
68
|
-
disableTracking,
|
|
69
|
-
setDisableStoreTracking
|
|
70
|
-
};
|
|
71
|
-
//# sourceMappingURL=Store.js.map
|
package/dist/esm/Store.js.map
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/Store.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAS,oBAAoB;AAC7B,SAAS,mBAAmB;AAErB,MAAM,iBAAiB,OAAO;AAC9B,MAAM,cAAc,OAAO;AAC3B,MAAM,QAAQ,OAAO;AACrB,MAAM,eAAe,OAAO;AAS5B,MAAM,kBAAkB,oBAAI,QAAQ;AAEpC,MAAM,0BAA0B,CAAC,eAAoB,QAAiB;AAC3E,QAAM,QAAQ,cAAc,YAAY,KAAK;AAC7C,kBAAgB,IAAI,OAAO,GAAG;AAChC;AAEO,MAAM,MAAiC;AAAA,EAK5C,YAAmB,OAAc;AAAd;AAJnB,SAAQ,aAAa,oBAAI,IAAc;AACvC,SAAQ,YAAY,oBAAI,IAAkB;AAC1C,oBAAW;AAIX,qBAAY,CAAC,cAAwB;AACnC,WAAK,WAAW,IAAI,SAAS;AAC7B,aAAO,MAAM;AACX,aAAK,WAAW,OAAO,SAAS;AAAA,MAClC;AAAA,IACF;AAAA,EAPkC;AAAA,EASlC,CAAC,cAAc,IAAI;AACjB,SAAK,YAAY,KAAK,WAAW,KAAK,OAAO;AAC7C,eAAW,MAAM,KAAK,YAAY;AAChC,SAAG;AAAA,IACL;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA4BA,CAAC,YAAY,IAAI;AACf,UAAM,OAAO,EAAE,eAAe,KAAK;AACnC,WAAO,CAAC,GAAG,KAAK,SAAS,EAAE;AAAA,MACzB,CAAC,YAAY,QAAQ,aAAa,YAAY,QAAQ,WAAW,IAAI;AAAA,IACvE;AAAA,EACF;AACF;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
package/dist/esm/reaction.js
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { useMemo } from "react";
|
|
2
|
-
import { isEqualSubsetShallow } from "./comparators";
|
|
3
|
-
import { UNWRAP_PROXY } from "./constants";
|
|
4
|
-
import { getStoreInfo, setIsInReaction } from "./useStore";
|
|
5
|
-
const dispose = (d) => {
|
|
6
|
-
if (typeof d === "function") {
|
|
7
|
-
d();
|
|
8
|
-
}
|
|
9
|
-
};
|
|
10
|
-
function useReaction(store, selector, receiver, props, equalityFn = isEqualSubsetShallow, memoArgs) {
|
|
11
|
-
const storeInfo = getStoreInfo(store, props);
|
|
12
|
-
return useMemo(
|
|
13
|
-
() => reaction(storeInfo, selector, receiver, equalityFn),
|
|
14
|
-
[memoArgs]
|
|
15
|
-
);
|
|
16
|
-
}
|
|
17
|
-
function reaction({ store, subscribe }, selector, receiver, equalityFn = isEqualSubsetShallow) {
|
|
18
|
-
let last = void 0;
|
|
19
|
-
let innerDispose;
|
|
20
|
-
function updateReaction() {
|
|
21
|
-
var _a;
|
|
22
|
-
try {
|
|
23
|
-
setIsInReaction(true);
|
|
24
|
-
const storeInstance = store[UNWRAP_PROXY] || store;
|
|
25
|
-
const next = selector(storeInstance);
|
|
26
|
-
if (!equalityFn(last, next)) {
|
|
27
|
-
if (process.env.NODE_ENV === "development") {
|
|
28
|
-
console.groupCollapsed(
|
|
29
|
-
`\u{1F311} \u23ED %c${receiver.name.padStart(24)} (${storeInstance.constructor.name}${((_a = store.props) == null ? void 0 : _a.id) ? `:${store.props.id}` : ""}) ${last} => ${next}`,
|
|
30
|
-
"color: chocolate;"
|
|
31
|
-
);
|
|
32
|
-
console.groupCollapsed("trace >");
|
|
33
|
-
console.trace();
|
|
34
|
-
console.groupEnd();
|
|
35
|
-
console.log(" ARG", next);
|
|
36
|
-
console.groupEnd();
|
|
37
|
-
}
|
|
38
|
-
dispose(innerDispose);
|
|
39
|
-
last = next;
|
|
40
|
-
innerDispose = receiver(next);
|
|
41
|
-
}
|
|
42
|
-
} finally {
|
|
43
|
-
setIsInReaction(false);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
const disposeSubscribe = subscribe(updateReaction);
|
|
47
|
-
updateReaction();
|
|
48
|
-
return () => {
|
|
49
|
-
disposeSubscribe();
|
|
50
|
-
dispose(innerDispose);
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
export {
|
|
54
|
-
reaction,
|
|
55
|
-
useReaction
|
|
56
|
-
};
|
|
57
|
-
//# sourceMappingURL=reaction.js.map
|
package/dist/esm/reaction.js.map
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/reaction.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAS,eAAe;AAExB,SAAS,4BAA4B;AACrC,SAAS,oBAAoB;AAE7B,SAAS,cAAc,uBAAuB;AAE9C,MAAM,UAAU,CAAC,MAAW;AAC1B,MAAI,OAAO,MAAM,YAAY;AAC3B,MAAE;AAAA,EACJ;AACF;AAEO,SAAS,YACd,OACA,UACA,UAGA,OACA,aAA0C,sBAC1C,UACA;AACA,QAAM,YAAY,aAAa,OAAO,KAAK;AAC3C,SAAO;AAAA,IACL,MAAM,SAAS,WAAW,UAAiB,UAAU,UAAU;AAAA,IAC/D,CAAC,QAAQ;AAAA,EACX;AACF;AAEO,SAAS,SAId,EAAE,OAAO,UAAU,GACnB,UACA,UAGA,aAA0C,sBAC1C;AACA,MAAI,OAAY;AAChB,MAAI;AAEJ,WAAS,iBAAiB;AA5C5B;AA6CI,QAAI;AACF,sBAAgB,IAAI;AACpB,YAAM,gBAAgB,MAAM,YAAY,KAAK;AAC7C,YAAM,OAAO,SAAS,aAAa;AACnC,UAAI,CAAC,WAAW,MAAM,IAAI,GAAG;AAC3B,YAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,kBAAQ;AAAA,YACN,uBAAW,SAAS,KAAK,SAAS,EAAE,CAAC,KAAK,cAAc,YAAY,IAAI,KACtE,WAAM,UAAN,mBAAa,MAAK,IAAI,MAAM,MAAM,EAAE,KAAK,EAC3C,KAAK,IAAI,OAAO,IAAI;AAAA,YACpB;AAAA,UACF;AACA,kBAAQ,eAAe,SAAS;AAChC,kBAAQ,MAAM;AACd,kBAAQ,SAAS;AAEjB,kBAAQ,IAAI,SAAS,IAAI;AACzB,kBAAQ,SAAS;AAAA,QACnB;AACA,gBAAQ,YAAY;AACpB,eAAO;AACP,uBAAe,SAAS,IAAI;AAAA,MAC9B;AAAA,IACF,UAAE;AACA,sBAAgB,KAAK;AAAA,IACvB;AAAA,EACF;AAEA,QAAM,mBAAmB,UAAU,cAAc;AACjD,iBAAe;AAEf,SAAO,MAAM;AACX,qBAAiB;AACjB,YAAQ,YAAY;AAAA,EACtB;AACF;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
package/dist/esm/selector.js
DELETED
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import { useEffect, useState } from "react";
|
|
2
|
-
import { isEqualSubsetShallow } from "./comparators";
|
|
3
|
-
import { UNWRAP_PROXY } from "./constants";
|
|
4
|
-
import { trackStoresAccess } from "./useStore";
|
|
5
|
-
const logUpdate = process.env.NODE_ENV === "development" ? (fn, stores, last, next) => {
|
|
6
|
-
const getStoreLogName = (store) => {
|
|
7
|
-
var _a;
|
|
8
|
-
const str = store[UNWRAP_PROXY] ?? store;
|
|
9
|
-
return `${str.constructor.name}${((_a = store.props) == null ? void 0 : _a.id) ? `:${store.props.id}` : ""}`;
|
|
10
|
-
};
|
|
11
|
-
const storeNames = stores.map(getStoreLogName).join(", ");
|
|
12
|
-
const name = `\u{1F311} \u25B6\uFE0F %c${fn.name} ${storeNames} () ${last} => ${next}`;
|
|
13
|
-
console.groupCollapsed(name, "color: tomato;");
|
|
14
|
-
console.groupCollapsed("trace >");
|
|
15
|
-
console.trace();
|
|
16
|
-
console.groupEnd();
|
|
17
|
-
console.log(" next", next);
|
|
18
|
-
console.groupEnd();
|
|
19
|
-
} : null;
|
|
20
|
-
function useSelector(fn) {
|
|
21
|
-
const [state, setState] = useState(() => {
|
|
22
|
-
return runStoreSelector(fn);
|
|
23
|
-
});
|
|
24
|
-
useEffect(() => {
|
|
25
|
-
let dispose;
|
|
26
|
-
const unsub = subscribeToStores([...state.storeInfos], () => {
|
|
27
|
-
dispose == null ? void 0 : dispose();
|
|
28
|
-
const next = runStoreSelector(fn);
|
|
29
|
-
const nextStoreInfos = [...next.storeInfos];
|
|
30
|
-
const prevStoreInfos = [...state.storeInfos];
|
|
31
|
-
if (typeof next.value === "function") {
|
|
32
|
-
if (process.env.NODE_ENV === "development") {
|
|
33
|
-
logUpdate(fn, nextStoreInfos, "(fn)", "(fn)");
|
|
34
|
-
}
|
|
35
|
-
dispose = next.value;
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
setState((prev) => {
|
|
39
|
-
if (isEqualSubsetShallow(prevStoreInfos, nextStoreInfos) && isEqualSubsetShallow(prev.value, next.value)) {
|
|
40
|
-
return prev;
|
|
41
|
-
}
|
|
42
|
-
if (process.env.NODE_ENV === "development") {
|
|
43
|
-
logUpdate(fn, nextStoreInfos, prev.value, next.value);
|
|
44
|
-
}
|
|
45
|
-
return next;
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
return () => {
|
|
49
|
-
unsub();
|
|
50
|
-
dispose == null ? void 0 : dispose();
|
|
51
|
-
};
|
|
52
|
-
}, [[...state.storeInfos].map((i) => i.uid).join(",")]);
|
|
53
|
-
return state.value;
|
|
54
|
-
}
|
|
55
|
-
function runStoreSelector(selector) {
|
|
56
|
-
const storeInfos = /* @__PURE__ */ new Set();
|
|
57
|
-
const dispose = trackStoresAccess((storeInfo) => {
|
|
58
|
-
storeInfos.add(storeInfo);
|
|
59
|
-
});
|
|
60
|
-
const value = selector();
|
|
61
|
-
dispose();
|
|
62
|
-
return {
|
|
63
|
-
value,
|
|
64
|
-
storeInfos
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
function subscribeToStores(stores, onUpdate) {
|
|
68
|
-
const disposes = [];
|
|
69
|
-
for (const store of stores) {
|
|
70
|
-
disposes.push(store.subscribe(onUpdate));
|
|
71
|
-
}
|
|
72
|
-
return () => {
|
|
73
|
-
disposes.forEach((x) => x());
|
|
74
|
-
};
|
|
75
|
-
}
|
|
76
|
-
export {
|
|
77
|
-
useSelector
|
|
78
|
-
};
|
|
79
|
-
//# sourceMappingURL=selector.js.map
|
package/dist/esm/selector.js.map
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/selector.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAS,WAAW,gBAAgB;AAEpC,SAAS,4BAA4B;AACrC,SAAS,oBAAoB;AAE7B,SAAS,yBAAyB;AAIlC,MAAM,YACJ,QAAQ,IAAI,aAAa,gBACrB,CAAC,IAAS,QAAe,MAAW,SAAc;AAChD,QAAM,kBAAkB,CAAC,UAAe;AAZhD;AAaU,UAAM,MAAM,MAAM,YAAY,KAAK;AACnC,WAAO,GAAG,IAAI,YAAY,IAAI,KAAG,WAAM,UAAN,mBAAa,MAAK,IAAI,MAAM,MAAM,EAAE,KAAK,EAAE;AAAA,EAC9E;AACA,QAAM,aAAa,OAAO,IAAI,eAAe,EAAE,KAAK,IAAI;AACxD,QAAM,OAAO,6BAAY,GAAG,IAAI,IAAI,UAAU,OAAO,IAAI,OAAO,IAAI;AACpE,UAAQ,eAAe,MAAM,gBAAgB;AAC7C,UAAQ,eAAe,SAAS;AAChC,UAAQ,MAAM;AACd,UAAQ,SAAS;AAEjB,UAAQ,IAAI,UAAU,IAAI;AAC1B,UAAQ,SAAS;AACnB,IACA;AA2CC,SAAS,YAAe,IAAgB;AAC7C,QAAM,CAAC,OAAO,QAAQ,IAAI,SAAS,MAAM;AACvC,WAAO,iBAAiB,EAAE;AAAA,EAC5B,CAAC;AAED,YAAU,MAAM;AACd,QAAI;AACJ,UAAM,QAAQ,kBAAkB,CAAC,GAAG,MAAM,UAAU,GAAG,MAAM;AAC3D;AACA,YAAM,OAAO,iBAAiB,EAAE;AAEhC,YAAM,iBAAiB,CAAC,GAAG,KAAK,UAAU;AAC1C,YAAM,iBAAiB,CAAC,GAAG,MAAM,UAAU;AAG3C,UAAI,OAAO,KAAK,UAAU,YAAY;AACpC,YAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,oBAAW,IAAI,gBAAgB,QAAQ,MAAM;AAAA,QAC/C;AACA,kBAAU,KAAK;AACf;AAAA,MACF;AACA,eAAS,CAAC,SAAS;AACjB,YACE,qBAAqB,gBAAgB,cAAc,KACnD,qBAAqB,KAAK,OAAO,KAAK,KAAK,GAC3C;AACA,iBAAO;AAAA,QACT;AACA,YAAI,QAAQ,IAAI,aAAa,eAAe;AAC1C,oBAAW,IAAI,gBAAgB,KAAK,OAAO,KAAK,KAAK;AAAA,QACvD;AACA,eAAO;AAAA,MACT,CAAC;AAAA,IACH,CAAC;AACD,WAAO,MAAM;AACX,YAAM;AACN;AAAA,IACF;AAAA,EACF,GAAG,CAAC,CAAC,GAAG,MAAM,UAAU,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK,GAAG,CAAC,CAAC;AAEtD,SAAO,MAAM;AACf;AAEA,SAAS,iBAAoB,UAG3B;AACA,QAAM,aAAa,oBAAI,IAAe;AACtC,QAAM,UAAU,kBAAkB,CAAC,cAAc;AAC/C,eAAW,IAAI,SAAS;AAAA,EAC1B,CAAC;AACD,QAAM,QAAQ,SAAS;AACvB,UAAQ;AACR,SAAO;AAAA,IACL;AAAA,IACA;AAAA,EACF;AACF;AAEA,SAAS,kBAAkB,QAAqB,UAAqB;AACnE,QAAM,WAAuB,CAAC;AAC9B,aAAW,SAAS,QAAQ;AAC1B,aAAS,KAAK,MAAM,UAAU,QAAQ,CAAC;AAAA,EACzC;AACA,SAAO,MAAM;AACX,aAAS,QAAQ,CAAC,MAAM,EAAE,CAAC;AAAA,EAC7B;AACF;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { startTransition, useLayoutEffect, useState } from "react";
|
|
2
|
-
function useAsyncExternalStore(subscribe, getSnapshot, getServerSnapshot) {
|
|
3
|
-
const [storeState, setStoreState] = useState(getServerSnapshot);
|
|
4
|
-
if (typeof document !== "undefined") {
|
|
5
|
-
useLayoutEffect(() => {
|
|
6
|
-
return subscribe((next) => {
|
|
7
|
-
startTransition(() => {
|
|
8
|
-
setStoreState(getSnapshot(next));
|
|
9
|
-
});
|
|
10
|
-
});
|
|
11
|
-
}, [subscribe]);
|
|
12
|
-
}
|
|
13
|
-
return storeState;
|
|
14
|
-
}
|
|
15
|
-
export {
|
|
16
|
-
useAsyncExternalStore
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=useAsyncExternalStore.js.map
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/useAsyncExternalStore.tsx"],
|
|
4
|
-
"mappings": "AAAA,SAAS,iBAAiB,iBAAiB,gBAAgB;AAEpD,SAAS,sBACd,WACA,aACA,mBACA;AACA,QAAM,CAAC,YAAY,aAAa,IAAI,SAAS,iBAAiB;AAE9D,MAAI,OAAO,aAAa,aAAa;AACnC,oBAAgB,MAAM;AACpB,aAAO,UAAU,CAAC,SAAc;AAC9B,wBAAgB,MAAM;AACpB,wBAAc,YAAY,IAAI,CAAC;AAAA,QACjC,CAAC;AAAA,MACH,CAAC;AAAA,IACH,GAAG,CAAC,SAAS,CAAC;AAAA,EAChB;AAEA,SAAO;AACT;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
package/types/Store.d.ts
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
export declare const TRIGGER_UPDATE: unique symbol;
|
|
2
|
-
export declare const ADD_TRACKER: unique symbol;
|
|
3
|
-
export declare const TRACK: unique symbol;
|
|
4
|
-
export declare const SHOULD_DEBUG: unique symbol;
|
|
5
|
-
export type StoreTracker = {
|
|
6
|
-
tracked: Set<string>;
|
|
7
|
-
component?: any;
|
|
8
|
-
last?: any;
|
|
9
|
-
lastKeys?: any;
|
|
10
|
-
};
|
|
11
|
-
export declare const disableTracking: WeakMap<object, any>;
|
|
12
|
-
export declare const setDisableStoreTracking: (storeInstance: any, val: boolean) => void;
|
|
13
|
-
export declare class Store<Props extends Object = {}> {
|
|
14
|
-
props: Props;
|
|
15
|
-
private _listeners;
|
|
16
|
-
private _trackers;
|
|
17
|
-
_version: number;
|
|
18
|
-
constructor(props: Props);
|
|
19
|
-
subscribe: (onChanged: Function) => () => void;
|
|
20
|
-
[TRIGGER_UPDATE](): void;
|
|
21
|
-
[SHOULD_DEBUG](): boolean;
|
|
22
|
-
}
|
|
23
|
-
//# sourceMappingURL=Store.d.ts.map
|
package/types/Store.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Store.d.ts","sourceRoot":"","sources":["../src/Store.tsx"],"names":[],"mappings":"AAGA,eAAO,MAAM,cAAc,eAAW,CAAA;AACtC,eAAO,MAAM,WAAW,eAAW,CAAA;AACnC,eAAO,MAAM,KAAK,eAAW,CAAA;AAC7B,eAAO,MAAM,YAAY,eAAW,CAAA;AAEpC,MAAM,MAAM,YAAY,GAAG;IACzB,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IACpB,SAAS,CAAC,EAAE,GAAG,CAAA;IACf,IAAI,CAAC,EAAE,GAAG,CAAA;IACV,QAAQ,CAAC,EAAE,GAAG,CAAA;CACf,CAAA;AAED,eAAO,MAAM,eAAe,sBAAgB,CAAA;AAE5C,eAAO,MAAM,uBAAuB,kBAAmB,GAAG,OAAO,OAAO,SAGvE,CAAA;AAED,qBAAa,KAAK,CAAC,KAAK,SAAS,MAAM,GAAG,EAAE;IAKvB,KAAK,EAAE,KAAK;IAJ/B,OAAO,CAAC,UAAU,CAAsB;IACxC,OAAO,CAAC,SAAS,CAA0B;IAC3C,QAAQ,SAAI;gBAEO,KAAK,EAAE,KAAK;IAE/B,SAAS,cAAe,QAAQ,gBAK9B;IAEF,CAAC,cAAc,CAAC;IAOhB,CAAC,YAAY,CAAC;CAMf"}
|
package/types/reaction.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=reaction.d.ts.map
|
package/types/reaction.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"reaction.d.ts","sourceRoot":"","sources":["../src/reaction.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAA;AASxC,wBAAgB,WAAW,CAAC,aAAa,EAAE,QAAQ,SAAS,CAAC,CAAC,EAAE,aAAa,KAAK,GAAG,EACnF,KAAK,EAAE,aAAa,EACpB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,SAAS,CAAC,CAAC,EAAE,aAAa,KAAK,MAAM,OAAO,GAC1D,CAAC,CAAC,EAAE,OAAO,KAAK,GAAG,GACnB,OAAO,EACX,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC3B,UAAU,GAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,KAAK,OAA8B,EAC9D,QAAQ,CAAC,EAAE,GAAG,EAAE,cAOjB;AAED,wBAAgB,QAAQ,CACtB,aAAa,SAAS,SAAS,EAC/B,QAAQ,SAAS,CAAC,CAAC,EAAE,aAAa,KAAK,GAAG,EAE1C,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,aAAa,EACnC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,SAAS,CAAC,CAAC,EAAE,aAAa,KAAK,MAAM,OAAO,GAC1D,CAAC,CAAC,EAAE,OAAO,KAAK,GAAG,GACnB,OAAO,EACX,UAAU,GAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,KAAK,OAA8B,cAyC/D"}
|
package/types/selector.d.ts
DELETED
package/types/selector.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"selector.d.ts","sourceRoot":"","sources":["../src/selector.tsx"],"names":[],"mappings":"AAqEA,wBAAgB,WAAW,CAAC,CAAC,EAAE,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,CA0C7C"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useAsyncExternalStore.d.ts","sourceRoot":"","sources":["../src/useAsyncExternalStore.tsx"],"names":[],"mappings":"AAEA,wBAAgB,qBAAqB,CACnC,SAAS,EAAE,CAAC,EAAE,EAAE,QAAQ,KAAK,MAAM,IAAI,EACvC,WAAW,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,GAAG,EAChC,iBAAiB,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,GAAG,OAexC"}
|