@legendapp/state 0.11.0-next.3 → 0.11.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/trace.mjs ADDED
@@ -0,0 +1,40 @@
1
+ import { tracking } from '@legendapp/state';
2
+
3
+ function getNodePath(node) {
4
+ const arr = [];
5
+ let n = node;
6
+ while ((n === null || n === void 0 ? void 0 : n.key) !== undefined) {
7
+ arr.splice(0, 0, n.key);
8
+ n = n.parent;
9
+ }
10
+ return arr.join('.');
11
+ }
12
+
13
+ function traceListeners(name) {
14
+ tracking.listeners = traceNodes.bind(this, name);
15
+ }
16
+ function traceNodes(name, nodes) {
17
+ tracking.listeners = undefined;
18
+ const arr = [];
19
+ for (let tracked of nodes) {
20
+ const { node, shallow } = tracked[1];
21
+ arr.push(`${arr.length + 1}: ${getNodePath(node)}${shallow ? ' (shallow)' : ''}`);
22
+ }
23
+ console.log(`[legend-state] ${name ? name + ' ' : ''}tracking ${arr.length} observable${arr.length > 1 ? 's' : ''}:\n${arr.join('\n')}`);
24
+ }
25
+
26
+ function traceUpdates(name) {
27
+ tracking.updates = replaceUpdateFn.bind(this, name);
28
+ }
29
+ function replaceUpdateFn(name, updateFn) {
30
+ return onChange.bind(this, name, updateFn);
31
+ }
32
+ function onChange(name, updateFn, value, getPrevious, path, valueAtPath, prevAtPath, node) {
33
+ console.log(`[legend-state] Rendering ${name ? name + ' ' : ''}because "${getNodePath(node)}" changed:
34
+ from: ${JSON.stringify(getPrevious())}
35
+ to: ${JSON.stringify(value)}`);
36
+ updateFn();
37
+ }
38
+
39
+ export { traceListeners, traceUpdates };
40
+ //# sourceMappingURL=trace.mjs.map
package/trace.mjs.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trace.mjs","sources":["../../src/trace/traceHelpers.ts","../../src/trace/traceListeners.ts","../../src/trace/traceUpdates.ts"],"sourcesContent":[null,null,null],"names":[],"mappings":";;AAEM,SAAU,WAAW,CAAC,IAAe,EAAA;IACvC,MAAM,GAAG,GAAwB,EAAE,CAAC;IACpC,IAAI,CAAC,GAAG,IAAI,CAAC;IACb,OAAO,CAAA,CAAC,KAAA,IAAA,IAAD,CAAC,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAD,CAAC,CAAE,GAAG,MAAK,SAAS,EAAE;QACzB,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACxB,QAAA,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;AAChB,KAAA;AACD,IAAA,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACzB;;ACPM,SAAU,cAAc,CAAC,IAAa,EAAA;IACxC,QAAQ,CAAC,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AACrD,CAAC;AAED,SAAS,UAAU,CAAC,IAAY,EAAE,KAAgC,EAAA;AAC9D,IAAA,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC;IAC/B,MAAM,GAAG,GAAa,EAAE,CAAC;AACzB,IAAA,KAAK,IAAI,OAAO,IAAI,KAAK,EAAE;QACvB,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QACrC,GAAG,CAAC,IAAI,CAAC,CAAG,EAAA,GAAG,CAAC,MAAM,GAAG,CAAC,CAAK,EAAA,EAAA,WAAW,CAAC,IAAI,CAAC,CAAG,EAAA,OAAO,GAAG,YAAY,GAAG,EAAE,CAAE,CAAA,CAAC,CAAC;AACrF,KAAA;AAED,IAAA,OAAO,CAAC,GAAG,CACP,kBAAkB,IAAI,GAAG,IAAI,GAAG,GAAG,GAAG,EAAE,YAAY,GAAG,CAAC,MAAM,CAC1D,WAAA,EAAA,GAAG,CAAC,MAAM,GAAG,CAAC,GAAG,GAAG,GAAG,EAC3B,CAAM,GAAA,EAAA,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA,CAAE,CACzB,CAAC;AACN;;ACjBM,SAAU,YAAY,CAAC,IAAa,EAAA;IACtC,QAAQ,CAAC,OAAO,GAAG,eAAe,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AACxD,CAAC;AAED,SAAS,eAAe,CAAC,IAAY,EAAE,QAAoB,EAAA;IACvD,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC;AAC/C,CAAC;AAED,SAAS,QAAQ,CACb,IAAY,EACZ,QAAoB,EACpB,KAAU,EACV,WAAsB,EACtB,IAAyB,EACzB,WAAgB,EAChB,UAAe,EACf,IAAe,EAAA;AAEf,IAAA,OAAO,CAAC,GAAG,CAAC,4BAA4B,IAAI,GAAG,IAAI,GAAG,GAAG,GAAG,EAAE,YAAY,WAAW,CAAC,IAAI,CAAC,CAAA;AACvF,MAAA,EAAA,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAA;AAC/B,IAAA,EAAA,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA,CAAE,CAAC,CAAC;AAC3B,IAAA,QAAQ,EAAE,CAAC;AACf;;;;"}
package/types.d.ts ADDED
@@ -0,0 +1,13 @@
1
+ declare namespace React {
2
+ interface DOMAttributes<T> {
3
+ isolate?: boolean;
4
+ memo?: boolean;
5
+ }
6
+ }
7
+
8
+ declare module 'react-native' {
9
+ interface ViewProps {
10
+ isolate?: boolean;
11
+ memo?: boolean;
12
+ }
13
+ }
@@ -1,2 +0,0 @@
1
- import { ObservableListenerDispose } from '@legendapp/state';
2
- export declare function listenWhileCalling<T>(fn: () => T, listeners: Set<ObservableListenerDispose>, updateFn: () => void): T;
package/src/state.d.ts DELETED
@@ -1,5 +0,0 @@
1
- import type { NodeValue, TrackingNode } from './observableInterfaces';
2
- export declare const tracking: {
3
- nodes: TrackingNode[];
4
- };
5
- export declare function updateTracking(node: NodeValue, shallow?: boolean): void;