@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.
Files changed (38) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/DEV-cjs/core/Menu/Menu.js +3 -3
  3. package/DEV-cjs/core/Popover/Popover.js +25 -4
  4. package/DEV-cjs/core/Table/TableCell.js +1 -1
  5. package/DEV-cjs/core/Tooltip/Tooltip.js +23 -5
  6. package/DEV-cjs/styles.js +1 -1
  7. package/DEV-cjs/utils/hooks/index.js +1 -0
  8. package/DEV-cjs/utils/hooks/useStableCallback.js +20 -0
  9. package/DEV-esm/core/Menu/Menu.js +3 -3
  10. package/DEV-esm/core/Popover/Popover.js +26 -4
  11. package/DEV-esm/core/Table/TableCell.js +1 -1
  12. package/DEV-esm/core/Tooltip/Tooltip.js +24 -5
  13. package/DEV-esm/styles.js +1 -1
  14. package/DEV-esm/utils/hooks/index.js +1 -0
  15. package/DEV-esm/utils/hooks/useStableCallback.js +9 -0
  16. package/LICENSE.md +1 -1
  17. package/cjs/core/Menu/Menu.js +3 -3
  18. package/cjs/core/Popover/Popover.d.ts +8 -6
  19. package/cjs/core/Popover/Popover.js +25 -4
  20. package/cjs/core/Table/TableCell.js +1 -1
  21. package/cjs/core/Tooltip/Tooltip.js +23 -5
  22. package/cjs/styles.js +1 -1
  23. package/cjs/utils/hooks/index.d.ts +1 -0
  24. package/cjs/utils/hooks/index.js +1 -0
  25. package/cjs/utils/hooks/useStableCallback.d.ts +12 -0
  26. package/cjs/utils/hooks/useStableCallback.js +20 -0
  27. package/esm/core/Menu/Menu.js +3 -3
  28. package/esm/core/Popover/Popover.d.ts +8 -6
  29. package/esm/core/Popover/Popover.js +26 -4
  30. package/esm/core/Table/TableCell.js +1 -1
  31. package/esm/core/Tooltip/Tooltip.js +24 -5
  32. package/esm/styles.js +1 -1
  33. package/esm/utils/hooks/index.d.ts +1 -0
  34. package/esm/utils/hooks/index.js +1 -0
  35. package/esm/utils/hooks/useStableCallback.d.ts +12 -0
  36. package/esm/utils/hooks/useStableCallback.js +9 -0
  37. package/package.json +1 -1
  38. 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, cellContent, expander, shadows),
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: (element) => {
196
- floating.refs.setFloating(element);
197
- syncWithControlledState(element);
198
- },
208
+ setFloating,
209
+ setReference,
210
+ setPositionReference,
199
211
  },
200
212
  floatingStyles: floating.context.open ? floating.floatingStyles : {},
201
213
  }),
202
- [getReferenceProps, floatingProps, floating, syncWithControlledState],
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
@@ -1,4 +1,4 @@
1
- const t = '3.20.0';
1
+ const t = '3.20.2';
2
2
  const u = new Proxy(
3
3
  {},
4
4
  {
@@ -15,3 +15,4 @@ export * from './useSyncExternalStore.js';
15
15
  export * from './useVirtualScroll.js';
16
16
  export * from './useInstance.js';
17
17
  export * from './useWarningLogger.js';
18
+ export * from './useStableCallback.js';
@@ -15,3 +15,4 @@ export * from './useSyncExternalStore.js';
15
15
  export * from './useVirtualScroll.js';
16
16
  export * from './useInstance.js';
17
17
  export * from './useWarningLogger.js';
18
+ export * from './useStableCallback.js';
@@ -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
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@itwin/itwinui-react",
3
- "version": "3.20.0",
3
+ "version": "3.20.2",
4
4
  "author": "Bentley Systems",
5
5
  "license": "MIT",
6
6
  "type": "module",