Skip to content

Commit

Permalink
fix: Add gap to overflow calculations (#3029)
Browse files Browse the repository at this point in the history
Adds the setting of the container gap to the `useOverflowListMeasure` hook

[category:Components]
  • Loading branch information
NicholasBoll authored Nov 4, 2024
1 parent a46b224 commit e5cb5dd
Showing 1 changed file with 18 additions and 4 deletions.
22 changes: 18 additions & 4 deletions modules/react/collection/lib/useOverflowListMeasure.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
import * as React from 'react';

import {createElemPropsHook, useForkRef, useResizeObserver} from '@workday/canvas-kit-react/common';
import {
createElemPropsHook,
useMountLayout,
useResizeObserver,
useLocalRef,
} from '@workday/canvas-kit-react/common';

import {useOverflowListModel} from './useOverflowListModel';

Expand All @@ -9,12 +14,21 @@ import {useOverflowListModel} from './useOverflowListModel';
* overflow detection.
*/
export const useOverflowListMeasure = createElemPropsHook(useOverflowListModel)((model, ref) => {
const localRef = React.useRef(null);
const {ref: resizeRef} = useResizeObserver({
const {elementRef, localRef} = useLocalRef(ref as React.Ref<HTMLElement>);
const gapProperty = model.state.orientation === 'horizontal' ? 'columnGap' : 'rowGap';

useResizeObserver({
ref: localRef,
onResize: model.events.setContainerWidth,
});
const elementRef = useForkRef(ref, resizeRef);
useMountLayout(() => {
if (localRef.current) {
const styles = getComputedStyle(localRef.current);
model.events.setContainerGap({
size: styles.gap === 'normal' ? 0 : Number(styles[gapProperty].replace('px', '')),
});
}
});

return {
ref: elementRef,
Expand Down

0 comments on commit e5cb5dd

Please sign in to comment.