@dxos/react-hooks 0.8.3 → 0.8.4-main.84f28bd
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/lib/browser/index.mjs +76 -36
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/node-esm/index.mjs +76 -36
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/types/src/index.d.ts +2 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/useAsyncEffect.d.ts +1 -1
- package/dist/types/src/useAsyncState.d.ts.map +1 -1
- package/dist/types/src/useControlledState.d.ts +1 -1
- package/dist/types/src/useControlledState.d.ts.map +1 -1
- package/dist/types/src/useDefaultValue.d.ts.map +1 -1
- package/dist/types/src/useDefaults.d.ts +6 -0
- package/dist/types/src/useDefaults.d.ts.map +1 -0
- package/dist/types/src/useForwardedRef.d.ts +1 -1
- package/dist/types/src/useTimeout.d.ts +2 -0
- package/dist/types/src/useTimeout.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -3
- package/src/index.ts +2 -0
- package/src/useAsyncEffect.ts +1 -1
- package/src/useAsyncState.ts +2 -1
- package/src/useControlledState.ts +9 -1
- package/src/useDefaultValue.ts +0 -1
- package/src/useDefaults.ts +14 -0
- package/src/useForwardedRef.ts +1 -1
- package/src/useTimeout.ts +21 -0
- package/dist/lib/node/index.cjs +0 -413
- package/dist/lib/node/index.cjs.map +0 -7
- package/dist/lib/node/meta.json +0 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dxos/react-hooks",
|
|
3
|
-
"version": "0.8.
|
|
3
|
+
"version": "0.8.4-main.84f28bd",
|
|
4
4
|
"description": "React hooks supporting DXOS React primitives.",
|
|
5
5
|
"homepage": "https://dxos.org",
|
|
6
6
|
"bugs": "https://github.com/dxos/dxos/issues",
|
|
@@ -26,10 +26,12 @@
|
|
|
26
26
|
"dependencies": {
|
|
27
27
|
"@preact-signals/safe-react": "^0.9.0",
|
|
28
28
|
"alea": "^1.0.1",
|
|
29
|
-
"
|
|
30
|
-
"@dxos/
|
|
29
|
+
"lodash.defaultsdeep": "^4.6.1",
|
|
30
|
+
"@dxos/async": "0.8.4-main.84f28bd",
|
|
31
|
+
"@dxos/log": "0.8.4-main.84f28bd"
|
|
31
32
|
},
|
|
32
33
|
"devDependencies": {
|
|
34
|
+
"@types/lodash.defaultsdeep": "^4.6.6",
|
|
33
35
|
"@types/react": "~18.2.0",
|
|
34
36
|
"@types/react-dom": "~18.2.0",
|
|
35
37
|
"react": "~18.2.0",
|
package/src/index.ts
CHANGED
|
@@ -7,6 +7,7 @@ export * from './useAsyncState';
|
|
|
7
7
|
export * from './useControlledState';
|
|
8
8
|
export * from './useDebugReactDeps';
|
|
9
9
|
export * from './useDefaultValue';
|
|
10
|
+
export * from './useDefaults';
|
|
10
11
|
export * from './useDynamicRef';
|
|
11
12
|
export * from './useFileDownload';
|
|
12
13
|
export * from './useForwardedRef';
|
|
@@ -16,5 +17,6 @@ export * from './useMediaQuery';
|
|
|
16
17
|
export * from './useMulticastObservable';
|
|
17
18
|
export * from './useRefCallback';
|
|
18
19
|
export * from './useResize';
|
|
20
|
+
export * from './useTimeout';
|
|
19
21
|
export * from './useTrackProps';
|
|
20
22
|
export * from './useTransitions';
|
package/src/useAsyncEffect.ts
CHANGED
|
@@ -34,7 +34,7 @@ import { log } from '@dxos/log';
|
|
|
34
34
|
*
|
|
35
35
|
* NOTE: This effect does not cancel the async operation if the component is unmounted.
|
|
36
36
|
*
|
|
37
|
-
* @deprecated
|
|
37
|
+
* @deprecated Use useTimeout.
|
|
38
38
|
*/
|
|
39
39
|
export const useAsyncEffect = <T>(
|
|
40
40
|
callback: (isMounted: () => boolean) => Promise<T> | undefined,
|
package/src/useAsyncState.ts
CHANGED
|
@@ -14,7 +14,7 @@ export const useAsyncState = <T>(
|
|
|
14
14
|
const [value, setValue] = useState<T | undefined>();
|
|
15
15
|
useEffect(() => {
|
|
16
16
|
let disposed = false;
|
|
17
|
-
|
|
17
|
+
const t = setTimeout(async () => {
|
|
18
18
|
const data = await cb();
|
|
19
19
|
if (!disposed) {
|
|
20
20
|
setValue(data);
|
|
@@ -23,6 +23,7 @@ export const useAsyncState = <T>(
|
|
|
23
23
|
|
|
24
24
|
return () => {
|
|
25
25
|
disposed = true;
|
|
26
|
+
clearTimeout(t);
|
|
26
27
|
};
|
|
27
28
|
}, deps);
|
|
28
29
|
|
|
@@ -7,7 +7,11 @@ import { type Dispatch, type SetStateAction, useEffect, useState } from 'react';
|
|
|
7
7
|
/**
|
|
8
8
|
* A stateful hook with a controlled value.
|
|
9
9
|
*/
|
|
10
|
-
export const useControlledState = <T>(
|
|
10
|
+
export const useControlledState = <T>(
|
|
11
|
+
controlledValue: T,
|
|
12
|
+
onChange?: (value: T) => void,
|
|
13
|
+
...deps: any[]
|
|
14
|
+
): [T, Dispatch<SetStateAction<T>>] => {
|
|
11
15
|
const [value, setValue] = useState<T>(controlledValue);
|
|
12
16
|
useEffect(() => {
|
|
13
17
|
if (controlledValue !== undefined) {
|
|
@@ -15,5 +19,9 @@ export const useControlledState = <T>(controlledValue: T, ...deps: any[]): [T, D
|
|
|
15
19
|
}
|
|
16
20
|
}, [controlledValue, ...deps]);
|
|
17
21
|
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
onChange?.(value);
|
|
24
|
+
}, [value, onChange]);
|
|
25
|
+
|
|
18
26
|
return [value, setValue];
|
|
19
27
|
};
|
package/src/useDefaultValue.ts
CHANGED
|
@@ -21,7 +21,6 @@ export const useDefaultValue = <T>(reactiveValue: T | undefined | null, getDefau
|
|
|
21
21
|
// regardless of whether the defaultValue changes.
|
|
22
22
|
const stableDefaultValue = useMemo(getDefaultValue, []);
|
|
23
23
|
const [value, setValue] = useState(reactiveValue ?? stableDefaultValue);
|
|
24
|
-
|
|
25
24
|
useEffect(() => {
|
|
26
25
|
setValue(reactiveValue ?? stableDefaultValue);
|
|
27
26
|
}, [reactiveValue, stableDefaultValue]);
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import defaultsDeep from 'lodash.defaultsdeep';
|
|
6
|
+
import { useMemo } from 'react';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Returns a memo-ized deep-merged object of the default and value.
|
|
10
|
+
* If value is undefined or null, then returns the default.
|
|
11
|
+
*/
|
|
12
|
+
export const useDefaults = <T>(value: T | undefined | null, defaults: T): T => {
|
|
13
|
+
return useMemo(() => defaultsDeep({}, defaults, value), [value, defaults]);
|
|
14
|
+
};
|
package/src/useForwardedRef.ts
CHANGED
|
@@ -6,7 +6,7 @@ import { type ForwardedRef, useRef, useEffect } from 'react';
|
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* Combines a possibly undefined forwarded ref with a locally defined ref.
|
|
9
|
-
*
|
|
9
|
+
* @deprecated Use @radix-ui/react-compose-refs
|
|
10
10
|
*/
|
|
11
11
|
export const useForwardedRef = <T>(ref: ForwardedRef<T>) => {
|
|
12
12
|
const innerRef = useRef<T>(null);
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { useEffect, useRef } from 'react';
|
|
6
|
+
|
|
7
|
+
export const useTimeout = (callback: (() => Promise<void>) | undefined, delay = 0, deps: any[] = []) => {
|
|
8
|
+
const callbackRef = useRef(callback);
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
callbackRef.current = callback;
|
|
11
|
+
}, [callback]);
|
|
12
|
+
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
if (delay == null) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const timeout = setTimeout(() => callbackRef.current?.(), delay);
|
|
19
|
+
return () => clearTimeout(timeout);
|
|
20
|
+
}, [delay, ...deps]);
|
|
21
|
+
};
|
package/dist/lib/node/index.cjs
DELETED
|
@@ -1,413 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var node_exports = {};
|
|
30
|
-
__export(node_exports, {
|
|
31
|
-
makeId: () => makeId,
|
|
32
|
-
randomString: () => randomString,
|
|
33
|
-
useAsyncEffect: () => useAsyncEffect,
|
|
34
|
-
useAsyncState: () => useAsyncState,
|
|
35
|
-
useControlledState: () => useControlledState,
|
|
36
|
-
useDebugReactDeps: () => useDebugReactDeps,
|
|
37
|
-
useDefaultValue: () => useDefaultValue,
|
|
38
|
-
useDidTransition: () => useDidTransition,
|
|
39
|
-
useDynamicRef: () => useDynamicRef,
|
|
40
|
-
useFileDownload: () => useFileDownload,
|
|
41
|
-
useForwardedRef: () => useForwardedRef,
|
|
42
|
-
useId: () => useId,
|
|
43
|
-
useIsFocused: () => useIsFocused,
|
|
44
|
-
useMediaQuery: () => useMediaQuery,
|
|
45
|
-
useMulticastObservable: () => useMulticastObservable,
|
|
46
|
-
useOnTransition: () => useOnTransition,
|
|
47
|
-
useRefCallback: () => useRefCallback,
|
|
48
|
-
useResize: () => useResize,
|
|
49
|
-
useTrackProps: () => useTrackProps
|
|
50
|
-
});
|
|
51
|
-
module.exports = __toCommonJS(node_exports);
|
|
52
|
-
var import_react = require("react");
|
|
53
|
-
var import_log = require("@dxos/log");
|
|
54
|
-
var import_react2 = require("react");
|
|
55
|
-
var import_react3 = require("react");
|
|
56
|
-
var import_react4 = require("react");
|
|
57
|
-
var import_react5 = require("react");
|
|
58
|
-
var import_react6 = require("react");
|
|
59
|
-
var import_react7 = require("react");
|
|
60
|
-
var import_react8 = require("react");
|
|
61
|
-
var import_alea = __toESM(require("alea"));
|
|
62
|
-
var import_react9 = require("react");
|
|
63
|
-
var import_react10 = require("react");
|
|
64
|
-
var import_react11 = require("react");
|
|
65
|
-
var import_react12 = require("react");
|
|
66
|
-
var import_react13 = require("react");
|
|
67
|
-
var import_react14 = require("react");
|
|
68
|
-
var import_react15 = require("react");
|
|
69
|
-
var import_log2 = require("@dxos/log");
|
|
70
|
-
var import_react16 = require("react");
|
|
71
|
-
var useAsyncEffect = (callback, destructor, deps) => {
|
|
72
|
-
const [effectDestructor, effectDeps] = typeof destructor === "function" ? [
|
|
73
|
-
destructor,
|
|
74
|
-
deps
|
|
75
|
-
] : [
|
|
76
|
-
void 0,
|
|
77
|
-
destructor
|
|
78
|
-
];
|
|
79
|
-
(0, import_react.useEffect)(() => {
|
|
80
|
-
let mounted = true;
|
|
81
|
-
let value;
|
|
82
|
-
const asyncResult = callback(() => mounted);
|
|
83
|
-
void Promise.resolve(asyncResult).then((result) => {
|
|
84
|
-
value = result;
|
|
85
|
-
}).catch(import_log.log.catch);
|
|
86
|
-
return () => {
|
|
87
|
-
mounted = false;
|
|
88
|
-
effectDestructor?.(value);
|
|
89
|
-
};
|
|
90
|
-
}, effectDeps);
|
|
91
|
-
};
|
|
92
|
-
var useAsyncState = (cb, deps = []) => {
|
|
93
|
-
const [value, setValue] = (0, import_react2.useState)();
|
|
94
|
-
(0, import_react2.useEffect)(() => {
|
|
95
|
-
let disposed = false;
|
|
96
|
-
queueMicrotask(async () => {
|
|
97
|
-
const data = await cb();
|
|
98
|
-
if (!disposed) {
|
|
99
|
-
setValue(data);
|
|
100
|
-
}
|
|
101
|
-
});
|
|
102
|
-
return () => {
|
|
103
|
-
disposed = true;
|
|
104
|
-
};
|
|
105
|
-
}, deps);
|
|
106
|
-
return [
|
|
107
|
-
value,
|
|
108
|
-
setValue
|
|
109
|
-
];
|
|
110
|
-
};
|
|
111
|
-
var useControlledState = (controlledValue, ...deps) => {
|
|
112
|
-
const [value, setValue] = (0, import_react3.useState)(controlledValue);
|
|
113
|
-
(0, import_react3.useEffect)(() => {
|
|
114
|
-
if (controlledValue !== void 0) {
|
|
115
|
-
setValue(controlledValue);
|
|
116
|
-
}
|
|
117
|
-
}, [
|
|
118
|
-
controlledValue,
|
|
119
|
-
...deps
|
|
120
|
-
]);
|
|
121
|
-
return [
|
|
122
|
-
value,
|
|
123
|
-
setValue
|
|
124
|
-
];
|
|
125
|
-
};
|
|
126
|
-
var useDebugReactDeps = (deps = []) => {
|
|
127
|
-
const lastDeps = (0, import_react4.useRef)([]);
|
|
128
|
-
(0, import_react4.useEffect)(() => {
|
|
129
|
-
console.group("deps changed", {
|
|
130
|
-
old: lastDeps.current.length,
|
|
131
|
-
new: deps.length
|
|
132
|
-
});
|
|
133
|
-
for (let i = 0; i < Math.max(lastDeps.current.length ?? 0, deps.length ?? 0); i++) {
|
|
134
|
-
console.log(i, lastDeps.current[i] === deps[i] ? "SAME" : "CHANGED", {
|
|
135
|
-
previous: lastDeps.current[i],
|
|
136
|
-
current: deps[i]
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
console.groupEnd();
|
|
140
|
-
lastDeps.current = deps;
|
|
141
|
-
}, deps);
|
|
142
|
-
};
|
|
143
|
-
var useDefaultValue = (reactiveValue, getDefaultValue) => {
|
|
144
|
-
const stableDefaultValue = (0, import_react5.useMemo)(getDefaultValue, []);
|
|
145
|
-
const [value, setValue] = (0, import_react5.useState)(reactiveValue ?? stableDefaultValue);
|
|
146
|
-
(0, import_react5.useEffect)(() => {
|
|
147
|
-
setValue(reactiveValue ?? stableDefaultValue);
|
|
148
|
-
}, [
|
|
149
|
-
reactiveValue,
|
|
150
|
-
stableDefaultValue
|
|
151
|
-
]);
|
|
152
|
-
return value;
|
|
153
|
-
};
|
|
154
|
-
var useDynamicRef = (value) => {
|
|
155
|
-
const ref = (0, import_react6.useRef)(value);
|
|
156
|
-
(0, import_react6.useEffect)(() => {
|
|
157
|
-
ref.current = value;
|
|
158
|
-
}, [
|
|
159
|
-
value
|
|
160
|
-
]);
|
|
161
|
-
return ref;
|
|
162
|
-
};
|
|
163
|
-
var useFileDownload = () => {
|
|
164
|
-
return (0, import_react7.useMemo)(() => (data, filename) => {
|
|
165
|
-
const url = typeof data === "string" ? data : URL.createObjectURL(data);
|
|
166
|
-
const element = document.createElement("a");
|
|
167
|
-
element.setAttribute("href", url);
|
|
168
|
-
element.setAttribute("download", filename);
|
|
169
|
-
element.setAttribute("target", "download");
|
|
170
|
-
element.click();
|
|
171
|
-
}, []);
|
|
172
|
-
};
|
|
173
|
-
var useForwardedRef = (ref) => {
|
|
174
|
-
const innerRef = (0, import_react8.useRef)(null);
|
|
175
|
-
(0, import_react8.useEffect)(() => {
|
|
176
|
-
if (!ref) {
|
|
177
|
-
return;
|
|
178
|
-
}
|
|
179
|
-
if (typeof ref === "function") {
|
|
180
|
-
ref(innerRef.current);
|
|
181
|
-
} else {
|
|
182
|
-
ref.current = innerRef.current;
|
|
183
|
-
}
|
|
184
|
-
});
|
|
185
|
-
return innerRef;
|
|
186
|
-
};
|
|
187
|
-
var Alea = import_alea.default;
|
|
188
|
-
var prng = new Alea("@dxos/react-hooks");
|
|
189
|
-
var randomString = (n = 4) => prng().toString(16).slice(2, n + 2);
|
|
190
|
-
var useId = (namespace, propsId, opts) => (0, import_react9.useMemo)(() => makeId(namespace, propsId, opts), [
|
|
191
|
-
propsId
|
|
192
|
-
]);
|
|
193
|
-
var makeId = (namespace, propsId, opts) => propsId ?? `${namespace}-${randomString(opts?.n ?? 4)}`;
|
|
194
|
-
var useIsFocused = (inputRef) => {
|
|
195
|
-
const [isFocused, setIsFocused] = (0, import_react10.useState)(void 0);
|
|
196
|
-
const isFocusedRef = (0, import_react10.useRef)(isFocused);
|
|
197
|
-
isFocusedRef.current = isFocused;
|
|
198
|
-
(0, import_react10.useEffect)(() => {
|
|
199
|
-
const input = inputRef.current;
|
|
200
|
-
if (!input) {
|
|
201
|
-
return;
|
|
202
|
-
}
|
|
203
|
-
const onFocus = () => setIsFocused(true);
|
|
204
|
-
const onBlur = () => setIsFocused(false);
|
|
205
|
-
input.addEventListener("focus", onFocus);
|
|
206
|
-
input.addEventListener("blur", onBlur);
|
|
207
|
-
if (isFocusedRef.current === void 0) {
|
|
208
|
-
setIsFocused(document.activeElement === input);
|
|
209
|
-
}
|
|
210
|
-
return () => {
|
|
211
|
-
input.removeEventListener("focus", onFocus);
|
|
212
|
-
input.removeEventListener("blur", onBlur);
|
|
213
|
-
};
|
|
214
|
-
}, [
|
|
215
|
-
inputRef,
|
|
216
|
-
setIsFocused
|
|
217
|
-
]);
|
|
218
|
-
return isFocused;
|
|
219
|
-
};
|
|
220
|
-
var breakpointMediaQueries = {
|
|
221
|
-
sm: "(min-width: 640px)",
|
|
222
|
-
md: "(min-width: 768px)",
|
|
223
|
-
lg: "(min-width: 1024px)",
|
|
224
|
-
xl: "(min-width: 1280px)",
|
|
225
|
-
"2xl": "(min-width: 1536px)"
|
|
226
|
-
};
|
|
227
|
-
var useMediaQuery = (query, options = {}) => {
|
|
228
|
-
const { ssr = true, fallback } = options;
|
|
229
|
-
const queries = (Array.isArray(query) ? query : [
|
|
230
|
-
query
|
|
231
|
-
]).map((query2) => query2 in breakpointMediaQueries ? breakpointMediaQueries[query2] : query2);
|
|
232
|
-
let fallbackValues = Array.isArray(fallback) ? fallback : [
|
|
233
|
-
fallback
|
|
234
|
-
];
|
|
235
|
-
fallbackValues = fallbackValues.filter((v) => v != null);
|
|
236
|
-
const [value, setValue] = (0, import_react11.useState)(() => {
|
|
237
|
-
return queries.map((query2, index) => ({
|
|
238
|
-
media: query2,
|
|
239
|
-
matches: ssr ? !!fallbackValues[index] : document.defaultView?.matchMedia(query2).matches
|
|
240
|
-
}));
|
|
241
|
-
});
|
|
242
|
-
(0, import_react11.useEffect)(() => {
|
|
243
|
-
setValue(queries.map((query2) => ({
|
|
244
|
-
media: query2,
|
|
245
|
-
matches: document.defaultView?.matchMedia(query2).matches
|
|
246
|
-
})));
|
|
247
|
-
const mql = queries.map((query2) => document.defaultView?.matchMedia(query2));
|
|
248
|
-
const handler = (evt) => {
|
|
249
|
-
setValue((prev) => {
|
|
250
|
-
return prev.slice().map((item) => {
|
|
251
|
-
if (item.media === evt.media) {
|
|
252
|
-
return {
|
|
253
|
-
...item,
|
|
254
|
-
matches: evt.matches
|
|
255
|
-
};
|
|
256
|
-
}
|
|
257
|
-
return item;
|
|
258
|
-
});
|
|
259
|
-
});
|
|
260
|
-
};
|
|
261
|
-
mql.forEach((mql2) => {
|
|
262
|
-
if (typeof mql2?.addListener === "function") {
|
|
263
|
-
mql2?.addListener(handler);
|
|
264
|
-
} else {
|
|
265
|
-
mql2?.addEventListener("change", handler);
|
|
266
|
-
}
|
|
267
|
-
});
|
|
268
|
-
return () => {
|
|
269
|
-
mql.forEach((mql2) => {
|
|
270
|
-
if (typeof mql2?.removeListener === "function") {
|
|
271
|
-
mql2?.removeListener(handler);
|
|
272
|
-
} else {
|
|
273
|
-
mql2?.removeEventListener("change", handler);
|
|
274
|
-
}
|
|
275
|
-
});
|
|
276
|
-
};
|
|
277
|
-
}, [
|
|
278
|
-
document.defaultView
|
|
279
|
-
]);
|
|
280
|
-
return value.map((item) => !!item.matches);
|
|
281
|
-
};
|
|
282
|
-
var useMulticastObservable = (observable) => {
|
|
283
|
-
const subscribeFn = (0, import_react12.useMemo)(() => (listener) => {
|
|
284
|
-
const subscription = observable.subscribe(listener);
|
|
285
|
-
return () => subscription.unsubscribe();
|
|
286
|
-
}, [
|
|
287
|
-
observable
|
|
288
|
-
]);
|
|
289
|
-
return (0, import_react12.useSyncExternalStore)(subscribeFn, () => observable.get());
|
|
290
|
-
};
|
|
291
|
-
var useRefCallback = () => {
|
|
292
|
-
const [value, setValue] = (0, import_react13.useState)(null);
|
|
293
|
-
return {
|
|
294
|
-
refCallback: (value2) => setValue(value2),
|
|
295
|
-
value
|
|
296
|
-
};
|
|
297
|
-
};
|
|
298
|
-
var useResize = (handler, deps = [], delay = 800) => {
|
|
299
|
-
const debouncedHandler = (0, import_react14.useMemo)(() => {
|
|
300
|
-
let timeout;
|
|
301
|
-
return (event) => {
|
|
302
|
-
clearTimeout(timeout);
|
|
303
|
-
timeout = setTimeout(() => {
|
|
304
|
-
handler(event);
|
|
305
|
-
}, delay);
|
|
306
|
-
};
|
|
307
|
-
}, [
|
|
308
|
-
handler,
|
|
309
|
-
delay
|
|
310
|
-
]);
|
|
311
|
-
return (0, import_react14.useLayoutEffect)(() => {
|
|
312
|
-
window.visualViewport?.addEventListener("resize", debouncedHandler);
|
|
313
|
-
debouncedHandler();
|
|
314
|
-
return () => window.visualViewport?.removeEventListener("resize", debouncedHandler);
|
|
315
|
-
}, [
|
|
316
|
-
debouncedHandler,
|
|
317
|
-
...deps
|
|
318
|
-
]);
|
|
319
|
-
};
|
|
320
|
-
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/ui/primitives/react-hooks/src/useTrackProps.ts";
|
|
321
|
-
var useTrackProps = (props, componentName = "Component", active = true) => {
|
|
322
|
-
const prevProps = (0, import_react15.useRef)(props);
|
|
323
|
-
(0, import_react15.useEffect)(() => {
|
|
324
|
-
const changes = Object.entries(props).filter(([key]) => props[key] !== prevProps.current[key]);
|
|
325
|
-
if (changes.length > 0) {
|
|
326
|
-
if (active) {
|
|
327
|
-
import_log2.log.info("props changed", {
|
|
328
|
-
componentName,
|
|
329
|
-
keys: changes.map(([key]) => key).join(","),
|
|
330
|
-
props: Object.fromEntries(changes.map(([key]) => [
|
|
331
|
-
key,
|
|
332
|
-
{
|
|
333
|
-
from: prevProps.current[key],
|
|
334
|
-
to: props[key]
|
|
335
|
-
}
|
|
336
|
-
]))
|
|
337
|
-
}, {
|
|
338
|
-
F: __dxlog_file,
|
|
339
|
-
L: 22,
|
|
340
|
-
S: void 0,
|
|
341
|
-
C: (f, a) => f(...a)
|
|
342
|
-
});
|
|
343
|
-
}
|
|
344
|
-
}
|
|
345
|
-
prevProps.current = props;
|
|
346
|
-
});
|
|
347
|
-
};
|
|
348
|
-
var isFunction = (functionToCheck) => {
|
|
349
|
-
return functionToCheck instanceof Function;
|
|
350
|
-
};
|
|
351
|
-
var useDidTransition = (currentValue, fromValue, toValue) => {
|
|
352
|
-
const [hasTransitioned, setHasTransitioned] = (0, import_react16.useState)(false);
|
|
353
|
-
const previousValue = (0, import_react16.useRef)(currentValue);
|
|
354
|
-
(0, import_react16.useEffect)(() => {
|
|
355
|
-
const toValueValid = isFunction(toValue) ? toValue(currentValue) : toValue === currentValue;
|
|
356
|
-
const fromValueValid = isFunction(fromValue) ? fromValue(previousValue.current) : fromValue === previousValue.current;
|
|
357
|
-
if (fromValueValid && toValueValid && !hasTransitioned) {
|
|
358
|
-
setHasTransitioned(true);
|
|
359
|
-
} else if ((!fromValueValid || !toValueValid) && hasTransitioned) {
|
|
360
|
-
setHasTransitioned(false);
|
|
361
|
-
}
|
|
362
|
-
previousValue.current = currentValue;
|
|
363
|
-
}, [
|
|
364
|
-
currentValue,
|
|
365
|
-
fromValue,
|
|
366
|
-
toValue,
|
|
367
|
-
hasTransitioned
|
|
368
|
-
]);
|
|
369
|
-
return hasTransitioned;
|
|
370
|
-
};
|
|
371
|
-
var useOnTransition = (currentValue, fromValue, toValue, callback) => {
|
|
372
|
-
const dirty = (0, import_react16.useRef)(false);
|
|
373
|
-
const hasTransitioned = useDidTransition(currentValue, fromValue, toValue);
|
|
374
|
-
(0, import_react16.useEffect)(() => {
|
|
375
|
-
dirty.current = false;
|
|
376
|
-
}, [
|
|
377
|
-
currentValue,
|
|
378
|
-
dirty
|
|
379
|
-
]);
|
|
380
|
-
(0, import_react16.useEffect)(() => {
|
|
381
|
-
if (hasTransitioned && !dirty.current) {
|
|
382
|
-
callback();
|
|
383
|
-
dirty.current = true;
|
|
384
|
-
}
|
|
385
|
-
}, [
|
|
386
|
-
hasTransitioned,
|
|
387
|
-
dirty,
|
|
388
|
-
callback
|
|
389
|
-
]);
|
|
390
|
-
};
|
|
391
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
392
|
-
0 && (module.exports = {
|
|
393
|
-
makeId,
|
|
394
|
-
randomString,
|
|
395
|
-
useAsyncEffect,
|
|
396
|
-
useAsyncState,
|
|
397
|
-
useControlledState,
|
|
398
|
-
useDebugReactDeps,
|
|
399
|
-
useDefaultValue,
|
|
400
|
-
useDidTransition,
|
|
401
|
-
useDynamicRef,
|
|
402
|
-
useFileDownload,
|
|
403
|
-
useForwardedRef,
|
|
404
|
-
useId,
|
|
405
|
-
useIsFocused,
|
|
406
|
-
useMediaQuery,
|
|
407
|
-
useMulticastObservable,
|
|
408
|
-
useOnTransition,
|
|
409
|
-
useRefCallback,
|
|
410
|
-
useResize,
|
|
411
|
-
useTrackProps
|
|
412
|
-
});
|
|
413
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/useAsyncEffect.ts", "../../../src/useAsyncState.ts", "../../../src/useControlledState.ts", "../../../src/useDebugReactDeps.ts", "../../../src/useDefaultValue.ts", "../../../src/useDynamicRef.ts", "../../../src/useFileDownload.ts", "../../../src/useForwardedRef.ts", "../../../src/useId.ts", "../../../src/useIsFocused.ts", "../../../src/useMediaQuery.ts", "../../../src/useMulticastObservable.ts", "../../../src/useRefCallback.ts", "../../../src/useResize.ts", "../../../src/useTrackProps.ts", "../../../src/useTransitions.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport { useEffect } from 'react';\n\nimport { log } from '@dxos/log';\n\n/**\n * Process async event with optional non-async destructor.\n * Inspired by: https://github.com/rauldeheer/use-async-effect/blob/master/index.js\n *\n * ```tsx\n * useAsyncEffect(async () => {\n * await test();\n * }, []);\n * ```\n *\n * The callback may check of the component is still mounted before doing state updates.\n *\n * ```tsx\n * const [value, setValue] = useState<string>();\n * useAsyncEffect<string>(async (isMounted) => {\n * const value = await test();\n * if (!isMounted()) {\n * setValue(value);\n * }\n * }, () => console.log('Unmounted'), []);\n * ```\n *\n * @param callback Receives a getter function that determines if the component is still mounted.\n * @param destructor Receives the value returned from the callback.\n * @param deps\n *\n * NOTE: This effect does not cancel the async operation if the component is unmounted.\n *\n * @deprecated\n */\nexport const useAsyncEffect = <T>(\n callback: (isMounted: () => boolean) => Promise<T> | undefined,\n destructor?: ((value?: T) => void) | any[],\n deps?: any[],\n) => {\n const [effectDestructor, effectDeps] =\n typeof destructor === 'function' ? [destructor, deps] : [undefined, destructor];\n\n useEffect(() => {\n let mounted = true;\n let value: T | undefined;\n const asyncResult = callback(() => mounted);\n void Promise.resolve(asyncResult)\n .then((result) => {\n value = result;\n })\n .catch(log.catch);\n\n return () => {\n mounted = false;\n effectDestructor?.(value);\n };\n }, effectDeps);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Dispatch, type SetStateAction, useEffect, useState } from 'react';\n\n/**\n * NOTE: Use with care and when necessary to be able to cancel an async operation when unmounting.\n */\nexport const useAsyncState = <T>(\n cb: () => Promise<T | undefined>,\n deps: any[] = [],\n): [T | undefined, Dispatch<SetStateAction<T | undefined>>] => {\n const [value, setValue] = useState<T | undefined>();\n useEffect(() => {\n let disposed = false;\n queueMicrotask(async () => {\n const data = await cb();\n if (!disposed) {\n setValue(data);\n }\n });\n\n return () => {\n disposed = true;\n };\n }, deps);\n\n return [value, setValue];\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Dispatch, type SetStateAction, useEffect, useState } from 'react';\n\n/**\n * A stateful hook with a controlled value.\n */\nexport const useControlledState = <T>(controlledValue: T, ...deps: any[]): [T, Dispatch<SetStateAction<T>>] => {\n const [value, setValue] = useState<T>(controlledValue);\n useEffect(() => {\n if (controlledValue !== undefined) {\n setValue(controlledValue);\n }\n }, [controlledValue, ...deps]);\n\n return [value, setValue];\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n/* eslint-disable no-console */\n\nimport { type DependencyList, useEffect, useRef } from 'react';\n\n/**\n * Util to log deps that have changed.\n */\n// TODO(burdon): Move to react-hooks.\nexport const useDebugReactDeps = (deps: DependencyList = []) => {\n const lastDeps = useRef<DependencyList>([]);\n useEffect(() => {\n console.group('deps changed', { old: lastDeps.current.length, new: deps.length });\n for (let i = 0; i < Math.max(lastDeps.current.length ?? 0, deps.length ?? 0); i++) {\n console.log(i, lastDeps.current[i] === deps[i] ? 'SAME' : 'CHANGED', {\n previous: lastDeps.current[i],\n current: deps[i],\n });\n }\n\n console.groupEnd();\n lastDeps.current = deps;\n }, deps);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useEffect, useState, useMemo } from 'react';\n\n/**\n * A custom React hook that provides a stable default value for a potentially undefined reactive value.\n * The defaultValue is memoized upon component mount and remains unchanged until the component unmounts,\n * ensuring stability across all re-renders, even if the defaultValue prop changes.\n *\n * Note: The defaultValue is not reactive. It retains the same value from the component's mount to unmount.\n *\n * @param reactiveValue - The value that may change over time.\n * @param defaultValue - The initial value used when the reactiveValue is undefined. This value is not reactive.\n * @returns - The reactiveValue if it's defined, otherwise the defaultValue.\n */\nexport const useDefaultValue = <T>(reactiveValue: T | undefined | null, getDefaultValue: () => T): T => {\n // Memoize defaultValue with an empty dependency array.\n // This ensures that the defaultValue instance remains stable across all re-renders,\n // regardless of whether the defaultValue changes.\n const stableDefaultValue = useMemo(getDefaultValue, []);\n const [value, setValue] = useState(reactiveValue ?? stableDefaultValue);\n\n useEffect(() => {\n setValue(reactiveValue ?? stableDefaultValue);\n }, [reactiveValue, stableDefaultValue]);\n\n return value;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useEffect, useRef } from 'react';\n\n/**\n * Ref that is updated by a dependency.\n */\nexport const useDynamicRef = <T>(value: T) => {\n const ref = useRef<T>(value);\n useEffect(() => {\n ref.current = value;\n }, [value]);\n\n return ref;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\n/**\n * File download anchor.\n *\n * ```\n * const download = useDownload();\n * const handleDownload = (data: string) => {\n * download(new Blob([data], { type: 'text/plain' }), 'test.txt');\n * };\n * ```\n */\nexport const useFileDownload = (): ((data: Blob | string, filename: string) => void) => {\n return useMemo(\n () => (data: Blob | string, filename: string) => {\n const url = typeof data === 'string' ? data : URL.createObjectURL(data);\n const element = document.createElement('a');\n element.setAttribute('href', url);\n element.setAttribute('download', filename);\n element.setAttribute('target', 'download');\n element.click();\n },\n [],\n );\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { type ForwardedRef, useRef, useEffect } from 'react';\n\n/**\n * Combines a possibly undefined forwarded ref with a locally defined ref.\n * See also: react-merge-refs\n */\nexport const useForwardedRef = <T>(ref: ForwardedRef<T>) => {\n const innerRef = useRef<T>(null);\n useEffect(() => {\n if (!ref) {\n return;\n }\n\n if (typeof ref === 'function') {\n ref(innerRef.current);\n } else {\n ref.current = innerRef.current;\n }\n });\n\n return innerRef;\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport alea from 'alea';\nimport { useMemo } from 'react';\n\ninterface PrngFactory {\n new (seed?: string): () => number;\n}\n\nconst Alea: PrngFactory = alea as unknown as PrngFactory;\n\nconst prng = new Alea('@dxos/react-hooks');\n\n// TODO(burdon): Replace with PublicKey.random().\nexport const randomString = (n = 4) =>\n prng()\n .toString(16)\n .slice(2, n + 2);\n\nexport const useId = (namespace: string, propsId?: string, opts?: Partial<{ n: number }>) =>\n useMemo(() => makeId(namespace, propsId, opts), [propsId]);\n\nexport const makeId = (namespace: string, propsId?: string, opts?: Partial<{ n: number }>) =>\n propsId ?? `${namespace}-${randomString(opts?.n ?? 4)}`;\n", "//\n// Copyright 2022 DXOS.org\n//\n\n// Based upon the useIsFocused hook which is part of the `rci` project:\n/// https://github.com/leonardodino/rci/blob/main/packages/use-is-focused\n\nimport { useEffect, useRef, useState, type RefObject } from 'react';\n\nexport const useIsFocused = (inputRef: RefObject<HTMLInputElement>) => {\n const [isFocused, setIsFocused] = useState<boolean | undefined>(undefined);\n const isFocusedRef = useRef<boolean | undefined>(isFocused);\n\n isFocusedRef.current = isFocused;\n\n useEffect(() => {\n const input = inputRef.current;\n if (!input) {\n return;\n }\n\n const onFocus = () => setIsFocused(true);\n const onBlur = () => setIsFocused(false);\n input.addEventListener('focus', onFocus);\n input.addEventListener('blur', onBlur);\n\n if (isFocusedRef.current === undefined) {\n setIsFocused(document.activeElement === input);\n }\n\n return () => {\n input.removeEventListener('focus', onFocus);\n input.removeEventListener('blur', onBlur);\n };\n }, [inputRef, setIsFocused]);\n\n return isFocused;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\n// This hook is based on Chakra UI’s `useMediaQuery`: https://github.com/chakra-ui/chakra-ui/blob/main/packages/components/media-query/src/use-media-query.ts\n\nimport { useEffect, useState } from 'react';\n\nexport type UseMediaQueryOptions = {\n fallback?: boolean | boolean[];\n ssr?: boolean;\n};\n\n// TODO(thure): This should be derived from the same source of truth as the Tailwind theme config\nconst breakpointMediaQueries: Record<string, string> = {\n sm: '(min-width: 640px)',\n md: '(min-width: 768px)',\n lg: '(min-width: 1024px)',\n xl: '(min-width: 1280px)',\n '2xl': '(min-width: 1536px)',\n};\n\n/**\n * React hook that tracks state of a CSS media query\n *\n * @param query the media query to match, or a recognized breakpoint token\n * @param options the media query options { fallback, ssr }\n *\n * @see Docs https://chakra-ui.com/docs/hooks/use-media-query\n */\nexport const useMediaQuery = (query: string | string[], options: UseMediaQueryOptions = {}): boolean[] => {\n // TODO(wittjosiah): Why is the default here true?\n const { ssr = true, fallback } = options;\n\n const queries = (Array.isArray(query) ? query : [query]).map((query) =>\n query in breakpointMediaQueries ? breakpointMediaQueries[query] : query,\n );\n\n let fallbackValues = Array.isArray(fallback) ? fallback : [fallback];\n fallbackValues = fallbackValues.filter((v) => v != null) as boolean[];\n\n const [value, setValue] = useState(() => {\n return queries.map((query, index) => ({\n media: query,\n matches: ssr ? !!fallbackValues[index] : document.defaultView?.matchMedia(query).matches,\n }));\n });\n\n useEffect(() => {\n setValue(\n queries.map((query) => ({\n media: query,\n matches: document.defaultView?.matchMedia(query).matches,\n })),\n );\n\n const mql = queries.map((query) => document.defaultView?.matchMedia(query));\n\n const handler = (evt: MediaQueryListEvent) => {\n setValue((prev) => {\n return prev.slice().map((item) => {\n if (item.media === evt.media) {\n return { ...item, matches: evt.matches };\n }\n return item;\n });\n });\n };\n\n mql.forEach((mql) => {\n if (typeof mql?.addListener === 'function') {\n mql?.addListener(handler);\n } else {\n mql?.addEventListener('change', handler);\n }\n });\n\n return () => {\n mql.forEach((mql) => {\n if (typeof mql?.removeListener === 'function') {\n mql?.removeListener(handler);\n } else {\n mql?.removeEventListener('change', handler);\n }\n });\n };\n }, [document.defaultView]);\n\n return value.map((item) => !!item.matches);\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { useMemo, useSyncExternalStore } from 'react';\n\nimport { type MulticastObservable } from '@dxos/async';\n\n/**\n * Subscribe to a MulticastObservable and return the latest value.\n * @param observable the observable to subscribe to. Will resubscribe if the observable changes.\n */\n// TODO(burdon): Move to react-hooks.\nexport const useMulticastObservable = <T>(observable: MulticastObservable<T>): T => {\n // Make sure useSyncExternalStore is stable in respect to the observable.\n const subscribeFn = useMemo(\n () => (listener: () => void) => {\n const subscription = observable.subscribe(listener);\n return () => subscription.unsubscribe();\n },\n [observable],\n );\n\n // useSyncExternalStore will resubscribe to the observable and update the value if the subscribeFn changes.\n return useSyncExternalStore(subscribeFn, () => observable.get());\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type RefCallback, useState } from 'react';\n\n/**\n * Custom React Hook that creates a ref callback and a state variable.\n * The ref callback sets the state variable when the ref changes.\n *\n * @returns An object containing the ref callback and the current value of the ref.\n */\nexport const useRefCallback = <T = any>(): { refCallback: RefCallback<T>; value: T | null } => {\n const [value, setValue] = useState<T | null>(null);\n return { refCallback: (value: T) => setValue(value), value };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useLayoutEffect, useMemo } from 'react';\n\nexport const useResize = (\n handler: (event?: Event) => void,\n deps: Parameters<typeof useLayoutEffect>[1] = [],\n delay: number = 800,\n) => {\n const debouncedHandler = useMemo(() => {\n let timeout: ReturnType<typeof setTimeout>;\n return (event?: Event) => {\n clearTimeout(timeout);\n timeout = setTimeout(() => {\n handler(event);\n }, delay);\n };\n }, [handler, delay]);\n\n return useLayoutEffect(() => {\n window.visualViewport?.addEventListener('resize', debouncedHandler);\n debouncedHandler();\n return () => window.visualViewport?.removeEventListener('resize', debouncedHandler);\n }, [debouncedHandler, ...deps]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useRef, useEffect } from 'react';\n\nimport { log } from '@dxos/log';\n\n/**\n * Use to debug which props have changed to trigger re-renders in a React component.\n */\nexport const useTrackProps = <T extends Record<string, unknown>>(\n props: T,\n componentName = 'Component',\n active = true,\n) => {\n const prevProps = useRef<T>(props);\n useEffect(() => {\n const changes = Object.entries(props).filter(([key]) => props[key] !== prevProps.current[key]);\n if (changes.length > 0) {\n if (active) {\n log.info('props changed', {\n componentName,\n keys: changes.map(([key]) => key).join(','),\n props: Object.fromEntries(\n changes.map(([key]) => [\n key,\n {\n from: prevProps.current[key],\n to: props[key],\n },\n ]),\n ),\n });\n }\n }\n\n prevProps.current = props;\n });\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useRef, useEffect, useState } from 'react';\n\nconst isFunction = <T>(functionToCheck: any): functionToCheck is (value: T) => boolean => {\n return functionToCheck instanceof Function;\n};\n\n/**\n * This is an internal custom hook that checks if a value has transitioned from a specified 'from' value to a 'to' value.\n *\n * @param currentValue - The value that is being monitored for transitions.\n * @param fromValue - The *from* value or a predicate function that determines the start of the transition.\n * @param toValue - The *to* value or a predicate function that determines the end of the transition.\n * @returns A boolean indicating whether the transition from *fromValue* to *toValue* has occurred.\n *\n * @internal Consider using `useOnTransition` for handling transitions instead of this hook.\n */\nexport const useDidTransition = <T>(\n currentValue: T,\n fromValue: T | ((value: T) => boolean),\n toValue: T | ((value: T) => boolean),\n) => {\n const [hasTransitioned, setHasTransitioned] = useState(false);\n const previousValue = useRef<T>(currentValue);\n\n useEffect(() => {\n const toValueValid = isFunction<T>(toValue) ? toValue(currentValue) : toValue === currentValue;\n const fromValueValid = isFunction<T>(fromValue)\n ? fromValue(previousValue.current)\n : fromValue === previousValue.current;\n\n if (fromValueValid && toValueValid && !hasTransitioned) {\n setHasTransitioned(true);\n } else if ((!fromValueValid || !toValueValid) && hasTransitioned) {\n setHasTransitioned(false);\n }\n\n previousValue.current = currentValue;\n }, [currentValue, fromValue, toValue, hasTransitioned]);\n\n return hasTransitioned;\n};\n\n/**\n * Executes a callback function when a specified transition occurs in a value.\n *\n * This function utilizes the `useDidTransition` hook to monitor changes in `currentValue`.\n * When `currentValue` transitions from `fromValue` to `toValue`, the provided `callback` function is executed. */\nexport const useOnTransition = <T>(\n currentValue: T,\n fromValue: T | ((value: T) => boolean),\n toValue: T | ((value: T) => boolean),\n callback: () => void,\n) => {\n const dirty = useRef(false);\n const hasTransitioned = useDidTransition(currentValue, fromValue, toValue);\n\n useEffect(() => {\n dirty.current = false;\n }, [currentValue, dirty]);\n\n useEffect(() => {\n if (hasTransitioned && !dirty.current) {\n callback();\n dirty.current = true;\n }\n }, [hasTransitioned, dirty, callback]);\n};\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["import_react", "import_log", "useAsyncEffect", "callback", "destructor", "deps", "effectDestructor", "effectDeps", "undefined", "useEffect", "mounted", "value", "asyncResult", "Promise", "resolve", "then", "result", "catch", "log", "useAsyncState", "cb", "setValue", "useState", "disposed", "queueMicrotask", "data", "useControlledState", "controlledValue", "useDebugReactDeps", "lastDeps", "useRef", "console", "group", "old", "current", "length", "new", "i", "Math", "max", "previous", "groupEnd", "useDefaultValue", "reactiveValue", "getDefaultValue", "stableDefaultValue", "useMemo", "useDynamicRef", "ref", "useFileDownload", "filename", "url", "URL", "createObjectURL", "element", "document", "createElement", "setAttribute", "click", "useForwardedRef", "innerRef", "Alea", "alea", "prng", "randomString", "n", "toString", "slice", "useId", "namespace", "propsId", "opts", "makeId", "useIsFocused", "inputRef", "isFocused", "setIsFocused", "isFocusedRef", "input", "onFocus", "onBlur", "addEventListener", "activeElement", "removeEventListener", "breakpointMediaQueries", "sm", "md", "lg", "xl", "useMediaQuery", "query", "options", "ssr", "fallback", "queries", "Array", "isArray", "map", "fallbackValues", "filter", "v", "index", "media", "matches", "defaultView", "matchMedia", "mql", "handler", "evt", "prev", "item", "forEach", "addListener", "removeListener", "useMulticastObservable", "observable", "subscribeFn", "listener", "subscription", "subscribe", "unsubscribe", "useSyncExternalStore", "get", "useRefCallback", "refCallback", "useResize", "delay", "debouncedHandler", "timeout", "event", "clearTimeout", "setTimeout", "useLayoutEffect", "window", "visualViewport", "useTrackProps", "props", "componentName", "active", "prevProps", "changes", "Object", "entries", "key", "info", "keys", "join", "fromEntries", "from", "to", "isFunction", "functionToCheck", "Function", "useDidTransition", "currentValue", "fromValue", "toValue", "hasTransitioned", "setHasTransitioned", "previousValue", "toValueValid", "fromValueValid", "useOnTransition", "dirty"]
|
|
7
|
-
}
|
package/dist/lib/node/meta.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"inputs":{"packages/ui/primitives/react-hooks/src/useAsyncEffect.ts":{"bytes":4968,"imports":[{"path":"react","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useAsyncState.ts":{"bytes":2463,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useControlledState.ts":{"bytes":1980,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useDebugReactDeps.ts":{"bytes":3132,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useDefaultValue.ts":{"bytes":4050,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useDynamicRef.ts":{"bytes":1339,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useFileDownload.ts":{"bytes":2684,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useForwardedRef.ts":{"bytes":2016,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useId.ts":{"bytes":2479,"imports":[{"path":"alea","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useIsFocused.ts":{"bytes":3922,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useMediaQuery.ts":{"bytes":9409,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useMulticastObservable.ts":{"bytes":2985,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useRefCallback.ts":{"bytes":1831,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useResize.ts":{"bytes":2839,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useTrackProps.ts":{"bytes":4010,"imports":[{"path":"react","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/useTransitions.ts":{"bytes":7763,"imports":[{"path":"react","kind":"import-statement","external":true}],"format":"esm"},"packages/ui/primitives/react-hooks/src/index.ts":{"bytes":2052,"imports":[{"path":"packages/ui/primitives/react-hooks/src/useAsyncEffect.ts","kind":"import-statement","original":"./useAsyncEffect"},{"path":"packages/ui/primitives/react-hooks/src/useAsyncState.ts","kind":"import-statement","original":"./useAsyncState"},{"path":"packages/ui/primitives/react-hooks/src/useControlledState.ts","kind":"import-statement","original":"./useControlledState"},{"path":"packages/ui/primitives/react-hooks/src/useDebugReactDeps.ts","kind":"import-statement","original":"./useDebugReactDeps"},{"path":"packages/ui/primitives/react-hooks/src/useDefaultValue.ts","kind":"import-statement","original":"./useDefaultValue"},{"path":"packages/ui/primitives/react-hooks/src/useDynamicRef.ts","kind":"import-statement","original":"./useDynamicRef"},{"path":"packages/ui/primitives/react-hooks/src/useFileDownload.ts","kind":"import-statement","original":"./useFileDownload"},{"path":"packages/ui/primitives/react-hooks/src/useForwardedRef.ts","kind":"import-statement","original":"./useForwardedRef"},{"path":"packages/ui/primitives/react-hooks/src/useId.ts","kind":"import-statement","original":"./useId"},{"path":"packages/ui/primitives/react-hooks/src/useIsFocused.ts","kind":"import-statement","original":"./useIsFocused"},{"path":"packages/ui/primitives/react-hooks/src/useMediaQuery.ts","kind":"import-statement","original":"./useMediaQuery"},{"path":"packages/ui/primitives/react-hooks/src/useMulticastObservable.ts","kind":"import-statement","original":"./useMulticastObservable"},{"path":"packages/ui/primitives/react-hooks/src/useRefCallback.ts","kind":"import-statement","original":"./useRefCallback"},{"path":"packages/ui/primitives/react-hooks/src/useResize.ts","kind":"import-statement","original":"./useResize"},{"path":"packages/ui/primitives/react-hooks/src/useTrackProps.ts","kind":"import-statement","original":"./useTrackProps"},{"path":"packages/ui/primitives/react-hooks/src/useTransitions.ts","kind":"import-statement","original":"./useTransitions"}],"format":"esm"}},"outputs":{"packages/ui/primitives/react-hooks/dist/lib/node/index.cjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":28350},"packages/ui/primitives/react-hooks/dist/lib/node/index.cjs":{"imports":[{"path":"react","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"alea","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true}],"exports":["makeId","randomString","useAsyncEffect","useAsyncState","useControlledState","useDebugReactDeps","useDefaultValue","useDidTransition","useDynamicRef","useFileDownload","useForwardedRef","useId","useIsFocused","useMediaQuery","useMulticastObservable","useOnTransition","useRefCallback","useResize","useTrackProps"],"entryPoint":"packages/ui/primitives/react-hooks/src/index.ts","inputs":{"packages/ui/primitives/react-hooks/src/useAsyncEffect.ts":{"bytesInOutput":581},"packages/ui/primitives/react-hooks/src/index.ts":{"bytesInOutput":0},"packages/ui/primitives/react-hooks/src/useAsyncState.ts":{"bytesInOutput":418},"packages/ui/primitives/react-hooks/src/useControlledState.ts":{"bytesInOutput":372},"packages/ui/primitives/react-hooks/src/useDebugReactDeps.ts":{"bytesInOutput":567},"packages/ui/primitives/react-hooks/src/useDefaultValue.ts":{"bytesInOutput":422},"packages/ui/primitives/react-hooks/src/useDynamicRef.ts":{"bytesInOutput":217},"packages/ui/primitives/react-hooks/src/useFileDownload.ts":{"bytesInOutput":416},"packages/ui/primitives/react-hooks/src/useForwardedRef.ts":{"bytesInOutput":343},"packages/ui/primitives/react-hooks/src/useId.ts":{"bytesInOutput":403},"packages/ui/primitives/react-hooks/src/useIsFocused.ts":{"bytesInOutput":833},"packages/ui/primitives/react-hooks/src/useMediaQuery.ts":{"bytesInOutput":1940},"packages/ui/primitives/react-hooks/src/useMulticastObservable.ts":{"bytesInOutput":368},"packages/ui/primitives/react-hooks/src/useRefCallback.ts":{"bytesInOutput":197},"packages/ui/primitives/react-hooks/src/useResize.ts":{"bytesInOutput":619},"packages/ui/primitives/react-hooks/src/useTrackProps.ts":{"bytesInOutput":986},"packages/ui/primitives/react-hooks/src/useTransitions.ts":{"bytesInOutput":1406}},"bytes":11440}}}
|