@itwin/itwinui-react 3.20.0 → 3.20.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/CHANGELOG.md +13 -0
- package/DEV-cjs/core/Menu/Menu.js +3 -3
- package/DEV-cjs/core/Popover/Popover.js +25 -4
- package/DEV-cjs/core/Table/TableCell.js +1 -1
- package/DEV-cjs/core/Tooltip/Tooltip.js +23 -5
- package/DEV-cjs/styles.js +1 -1
- package/DEV-cjs/utils/hooks/index.js +1 -0
- package/DEV-cjs/utils/hooks/useStableCallback.js +20 -0
- package/DEV-esm/core/Menu/Menu.js +3 -3
- package/DEV-esm/core/Popover/Popover.js +26 -4
- package/DEV-esm/core/Table/TableCell.js +1 -1
- package/DEV-esm/core/Tooltip/Tooltip.js +24 -5
- package/DEV-esm/styles.js +1 -1
- package/DEV-esm/utils/hooks/index.js +1 -0
- package/DEV-esm/utils/hooks/useStableCallback.js +9 -0
- package/LICENSE.md +1 -1
- package/cjs/core/Menu/Menu.js +3 -3
- package/cjs/core/Popover/Popover.d.ts +8 -6
- package/cjs/core/Popover/Popover.js +25 -4
- package/cjs/core/Table/TableCell.js +1 -1
- package/cjs/core/Tooltip/Tooltip.js +23 -5
- package/cjs/styles.js +1 -1
- package/cjs/utils/hooks/index.d.ts +1 -0
- package/cjs/utils/hooks/index.js +1 -0
- package/cjs/utils/hooks/useStableCallback.d.ts +12 -0
- package/cjs/utils/hooks/useStableCallback.js +20 -0
- package/esm/core/Menu/Menu.js +3 -3
- package/esm/core/Popover/Popover.d.ts +8 -6
- package/esm/core/Popover/Popover.js +26 -4
- package/esm/core/Table/TableCell.js +1 -1
- package/esm/core/Tooltip/Tooltip.js +24 -5
- package/esm/styles.js +1 -1
- package/esm/utils/hooks/index.d.ts +1 -0
- package/esm/utils/hooks/index.js +1 -0
- package/esm/utils/hooks/useStableCallback.d.ts +12 -0
- package/esm/utils/hooks/useStableCallback.js +9 -0
- package/package.json +1 -1
- package/styles.css +10 -10
|
@@ -93,7 +93,7 @@ export const TableCell = (props) => {
|
|
|
93
93
|
);
|
|
94
94
|
let defaultCellRendererChildren = React.useMemo(
|
|
95
95
|
() =>
|
|
96
|
-
React.createElement(React.Fragment, null,
|
|
96
|
+
React.createElement(React.Fragment, null, expander, cellContent, shadows),
|
|
97
97
|
[cellContent, expander, shadows],
|
|
98
98
|
);
|
|
99
99
|
let cellRendererProps = React.useMemo(
|
|
@@ -23,6 +23,7 @@ import {
|
|
|
23
23
|
cloneElementWithRef,
|
|
24
24
|
useControlledState,
|
|
25
25
|
useId,
|
|
26
|
+
useStableCallback,
|
|
26
27
|
useMergedRefs,
|
|
27
28
|
} from '../../utils/index.js';
|
|
28
29
|
export const defaultTooltipDelay = {
|
|
@@ -185,6 +186,18 @@ let useTooltip = (options = {}) => {
|
|
|
185
186
|
}),
|
|
186
187
|
[interactions, props, id, open],
|
|
187
188
|
);
|
|
189
|
+
let _setFloating = useStableCallback(floating.refs.setFloating);
|
|
190
|
+
let setFloating = React.useCallback(
|
|
191
|
+
(element) => {
|
|
192
|
+
_setFloating(element);
|
|
193
|
+
syncWithControlledState(element);
|
|
194
|
+
},
|
|
195
|
+
[_setFloating, syncWithControlledState],
|
|
196
|
+
);
|
|
197
|
+
let setReference = useStableCallback(floating.refs.setReference);
|
|
198
|
+
let setPositionReference = useStableCallback(
|
|
199
|
+
floating.refs.setPositionReference,
|
|
200
|
+
);
|
|
188
201
|
return React.useMemo(
|
|
189
202
|
() => ({
|
|
190
203
|
getReferenceProps,
|
|
@@ -192,14 +205,20 @@ let useTooltip = (options = {}) => {
|
|
|
192
205
|
...floating,
|
|
193
206
|
refs: {
|
|
194
207
|
...floating.refs,
|
|
195
|
-
setFloating
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
},
|
|
208
|
+
setFloating,
|
|
209
|
+
setReference,
|
|
210
|
+
setPositionReference,
|
|
199
211
|
},
|
|
200
212
|
floatingStyles: floating.context.open ? floating.floatingStyles : {},
|
|
201
213
|
}),
|
|
202
|
-
[
|
|
214
|
+
[
|
|
215
|
+
getReferenceProps,
|
|
216
|
+
floatingProps,
|
|
217
|
+
floating,
|
|
218
|
+
setFloating,
|
|
219
|
+
setReference,
|
|
220
|
+
setPositionReference,
|
|
221
|
+
],
|
|
203
222
|
);
|
|
204
223
|
};
|
|
205
224
|
export const Tooltip = React.forwardRef((props, forwardedRef) => {
|
package/esm/styles.js
CHANGED
package/esm/utils/hooks/index.js
CHANGED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook that "memoizes" a function by skipping reactivity, similar to `React.useEffectEvent`,
|
|
3
|
+
* except it returns a stable reference. Under the hood, it combines `useLatestRef` and `React.useCallback`.
|
|
4
|
+
*
|
|
5
|
+
* @private
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```ts
|
|
9
|
+
* const onClick = useStableCallback(props.onClick);
|
|
10
|
+
* ```
|
|
11
|
+
*/
|
|
12
|
+
export declare function useStableCallback<T extends (...args: any) => any>(callback: T | undefined): T;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { useLatestRef } from './useLatestRef.js';
|
|
3
|
+
export function useStableCallback(callback) {
|
|
4
|
+
let latestCallback = useLatestRef(callback);
|
|
5
|
+
return React.useCallback(
|
|
6
|
+
(...args) => latestCallback.current?.(...args),
|
|
7
|
+
[latestCallback],
|
|
8
|
+
);
|
|
9
|
+
}
|