@assistant-ui/tap 0.1.3 → 0.1.5
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/hooks/tap-memo.js +4 -4
- package/dist/hooks/tap-memo.js.map +1 -1
- package/dist/hooks/tap-ref.d.ts +1 -1
- package/dist/hooks/tap-ref.d.ts.map +1 -1
- package/dist/hooks/tap-ref.js +1 -1
- package/dist/hooks/tap-ref.js.map +1 -1
- package/dist/react/use-resource.js +1 -1
- package/dist/react/use-resource.js.map +1 -1
- package/package.json +4 -4
package/dist/hooks/tap-memo.js
CHANGED
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
import { tapRef } from "./tap-ref.js";
|
|
3
3
|
import { depsShallowEqual } from "./depsShallowEqual.js";
|
|
4
4
|
var tapMemo = (fn, deps) => {
|
|
5
|
-
const dataRef = tapRef(
|
|
6
|
-
|
|
7
|
-
deps
|
|
8
|
-
}
|
|
5
|
+
const dataRef = tapRef();
|
|
6
|
+
if (!dataRef.current) {
|
|
7
|
+
dataRef.current = { value: fn(), deps };
|
|
8
|
+
}
|
|
9
9
|
if (!depsShallowEqual(dataRef.current.deps, deps)) {
|
|
10
10
|
dataRef.current.value = fn();
|
|
11
11
|
dataRef.current.deps = deps;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/hooks/tap-memo.ts"],"sourcesContent":["import { tapRef } from \"./tap-ref\";\nimport { depsShallowEqual } from \"./depsShallowEqual\";\n\nexport const tapMemo = <T>(fn: () => T, deps: readonly unknown[]) => {\n const dataRef = tapRef(()
|
|
1
|
+
{"version":3,"sources":["../../src/hooks/tap-memo.ts"],"sourcesContent":["import { tapRef } from \"./tap-ref\";\nimport { depsShallowEqual } from \"./depsShallowEqual\";\n\nexport const tapMemo = <T>(fn: () => T, deps: readonly unknown[]) => {\n const dataRef = tapRef<{ value: T; deps: readonly unknown[] }>();\n if (!dataRef.current) {\n dataRef.current = { value: fn(), deps };\n }\n\n if (!depsShallowEqual(dataRef.current.deps, deps)) {\n dataRef.current.value = fn();\n dataRef.current.deps = deps;\n }\n\n return dataRef.current.value;\n};\n"],"mappings":";AAAA,SAAS,cAAc;AACvB,SAAS,wBAAwB;AAE1B,IAAM,UAAU,CAAI,IAAa,SAA6B;AACnE,QAAM,UAAU,OAA+C;AAC/D,MAAI,CAAC,QAAQ,SAAS;AACpB,YAAQ,UAAU,EAAE,OAAO,GAAG,GAAG,KAAK;AAAA,EACxC;AAEA,MAAI,CAAC,iBAAiB,QAAQ,QAAQ,MAAM,IAAI,GAAG;AACjD,YAAQ,QAAQ,QAAQ,GAAG;AAC3B,YAAQ,QAAQ,OAAO;AAAA,EACzB;AAEA,SAAO,QAAQ,QAAQ;AACzB;","names":[]}
|
package/dist/hooks/tap-ref.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export interface RefObject<T> {
|
|
2
2
|
current: T;
|
|
3
3
|
}
|
|
4
|
-
export declare function tapRef<T>(initialValue: T
|
|
4
|
+
export declare function tapRef<T>(initialValue: T): RefObject<T>;
|
|
5
5
|
export declare function tapRef<T = undefined>(): RefObject<T | undefined>;
|
|
6
6
|
//# sourceMappingURL=tap-ref.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tap-ref.d.ts","sourceRoot":"","sources":["../../src/hooks/tap-ref.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,SAAS,CAAC,CAAC;IAC1B,OAAO,EAAE,CAAC,CAAC;CACZ;AAED,wBAAgB,MAAM,CAAC,CAAC,EAAE,YAAY,EAAE,CAAC,GAAG,
|
|
1
|
+
{"version":3,"file":"tap-ref.d.ts","sourceRoot":"","sources":["../../src/hooks/tap-ref.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,SAAS,CAAC,CAAC;IAC1B,OAAO,EAAE,CAAC,CAAC;CACZ;AAED,wBAAgB,MAAM,CAAC,CAAC,EAAE,YAAY,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;AACzD,wBAAgB,MAAM,CAAC,CAAC,GAAG,SAAS,KAAK,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC"}
|
package/dist/hooks/tap-ref.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { tapState } from "./tap-state.js";
|
|
3
3
|
function tapRef(initialValue) {
|
|
4
4
|
const [state] = tapState(() => ({
|
|
5
|
-
current: initialValue
|
|
5
|
+
current: initialValue
|
|
6
6
|
}));
|
|
7
7
|
return state;
|
|
8
8
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/hooks/tap-ref.ts"],"sourcesContent":["import { tapState } from \"./tap-state\";\n\nexport interface RefObject<T> {\n current: T;\n}\n\nexport function tapRef<T>(initialValue: T
|
|
1
|
+
{"version":3,"sources":["../../src/hooks/tap-ref.ts"],"sourcesContent":["import { tapState } from \"./tap-state\";\n\nexport interface RefObject<T> {\n current: T;\n}\n\nexport function tapRef<T>(initialValue: T): RefObject<T>;\nexport function tapRef<T = undefined>(): RefObject<T | undefined>;\nexport function tapRef<T>(initialValue?: T): RefObject<T | undefined> {\n const [state] = tapState(() => ({\n current: initialValue,\n }));\n return state;\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AAQlB,SAAS,OAAU,cAA4C;AACpE,QAAM,CAAC,KAAK,IAAI,SAAS,OAAO;AAAA,IAC9B,SAAS;AAAA,EACX,EAAE;AACF,SAAO;AACT;","names":[]}
|
|
@@ -12,7 +12,7 @@ function useResource(element) {
|
|
|
12
12
|
const [, rerender] = useState({});
|
|
13
13
|
const fiber = useMemo(
|
|
14
14
|
() => createResourceFiber(element.type, () => rerender({})),
|
|
15
|
-
[element.type]
|
|
15
|
+
[element.type, rerender]
|
|
16
16
|
);
|
|
17
17
|
const result = renderResource(fiber, element.props);
|
|
18
18
|
useIsomorphicLayoutEffect(() => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/react/use-resource.ts"],"sourcesContent":["import { useEffect, useLayoutEffect, useMemo, useState } from \"react\";\nimport { ResourceElement } from \"../core/types\";\nimport {\n createResourceFiber,\n unmountResource,\n renderResource,\n commitResource,\n} from \"../core/ResourceFiber\";\n\nconst shouldAvoidLayoutEffect =\n (globalThis as any).__ASSISTANT_UI_DISABLE_LAYOUT_EFFECT__ === true;\n\nconst useIsomorphicLayoutEffect = shouldAvoidLayoutEffect\n ? useEffect\n : useLayoutEffect;\n\nexport function useResource<R, P>(element: ResourceElement<R, P>): R {\n const [, rerender] = useState({});\n const fiber = useMemo(\n () => createResourceFiber(element.type, () => rerender({})),\n [element.type],\n );\n\n const result = renderResource(fiber, element.props);\n useIsomorphicLayoutEffect(() => {\n return () => unmountResource(fiber);\n }, []);\n useIsomorphicLayoutEffect(() => {\n commitResource(fiber, result);\n });\n\n return result.state;\n}\n"],"mappings":";AAAA,SAAS,WAAW,iBAAiB,SAAS,gBAAgB;AAE9D;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAEP,IAAM,0BACH,WAAmB,2CAA2C;AAEjE,IAAM,4BAA4B,0BAC9B,YACA;AAEG,SAAS,YAAkB,SAAmC;AACnE,QAAM,CAAC,EAAE,QAAQ,IAAI,SAAS,CAAC,CAAC;AAChC,QAAM,QAAQ;AAAA,IACZ,MAAM,oBAAoB,QAAQ,MAAM,MAAM,SAAS,CAAC,CAAC,CAAC;AAAA,IAC1D,CAAC,QAAQ,
|
|
1
|
+
{"version":3,"sources":["../../src/react/use-resource.ts"],"sourcesContent":["import { useEffect, useLayoutEffect, useMemo, useState } from \"react\";\nimport { ResourceElement } from \"../core/types\";\nimport {\n createResourceFiber,\n unmountResource,\n renderResource,\n commitResource,\n} from \"../core/ResourceFiber\";\n\nconst shouldAvoidLayoutEffect =\n (globalThis as any).__ASSISTANT_UI_DISABLE_LAYOUT_EFFECT__ === true;\n\nconst useIsomorphicLayoutEffect = shouldAvoidLayoutEffect\n ? useEffect\n : useLayoutEffect;\n\nexport function useResource<R, P>(element: ResourceElement<R, P>): R {\n const [, rerender] = useState({});\n const fiber = useMemo(\n () => createResourceFiber(element.type, () => rerender({})),\n [element.type, rerender],\n );\n\n const result = renderResource(fiber, element.props);\n useIsomorphicLayoutEffect(() => {\n return () => unmountResource(fiber);\n }, []);\n useIsomorphicLayoutEffect(() => {\n commitResource(fiber, result);\n });\n\n return result.state;\n}\n"],"mappings":";AAAA,SAAS,WAAW,iBAAiB,SAAS,gBAAgB;AAE9D;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAEP,IAAM,0BACH,WAAmB,2CAA2C;AAEjE,IAAM,4BAA4B,0BAC9B,YACA;AAEG,SAAS,YAAkB,SAAmC;AACnE,QAAM,CAAC,EAAE,QAAQ,IAAI,SAAS,CAAC,CAAC;AAChC,QAAM,QAAQ;AAAA,IACZ,MAAM,oBAAoB,QAAQ,MAAM,MAAM,SAAS,CAAC,CAAC,CAAC;AAAA,IAC1D,CAAC,QAAQ,MAAM,QAAQ;AAAA,EACzB;AAEA,QAAM,SAAS,eAAe,OAAO,QAAQ,KAAK;AAClD,4BAA0B,MAAM;AAC9B,WAAO,MAAM,gBAAgB,KAAK;AAAA,EACpC,GAAG,CAAC,CAAC;AACL,4BAA0B,MAAM;AAC9B,mBAAe,OAAO,MAAM;AAAA,EAC9B,CAAC;AAED,SAAO,OAAO;AAChB;","names":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@assistant-ui/tap",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.5",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "Zero-dependency reactive state management inspired by React hooks",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -18,12 +18,12 @@
|
|
|
18
18
|
}
|
|
19
19
|
},
|
|
20
20
|
"devDependencies": {
|
|
21
|
-
"@types/node": "^24.
|
|
21
|
+
"@types/node": "^24.10.0",
|
|
22
22
|
"@types/react": "*",
|
|
23
|
-
"@vitest/ui": "^
|
|
23
|
+
"@vitest/ui": "^4.0.6",
|
|
24
24
|
"tsx": "^4.20.6",
|
|
25
25
|
"typescript": "^5.9.3",
|
|
26
|
-
"vitest": "^
|
|
26
|
+
"vitest": "^4.0.6",
|
|
27
27
|
"@assistant-ui/x-buildutils": "0.0.1"
|
|
28
28
|
},
|
|
29
29
|
"exports": {
|