Skip to content

Commit

Permalink
Remove debounced hover interactions
Browse files Browse the repository at this point in the history
This reflects the changes made in #44271 for the RangeControl.
  • Loading branch information
aaronrobertshaw committed Sep 23, 2022
1 parent 83a3cbc commit 82b8657
Show file tree
Hide file tree
Showing 5 changed files with 9 additions and 105 deletions.
13 changes: 0 additions & 13 deletions packages/components/src/slider-control/slider/hook.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ import * as styles from '../styles';
import { COLORS, CONFIG } from '../../utils';
import { useContextSystem, WordPressComponentProps } from '../../ui/context';
import { useControlledValue, useCx } from '../../utils/hooks';
import { useDebouncedHoverInteraction } from '../utils';
import { interpolate } from '../../utils/interpolate';
import { isValueNumeric } from '../../utils/values';

Expand All @@ -29,10 +28,6 @@ export function useSlider(
onBlur = noop,
onChange: onChangeProp = noop,
onFocus = noop,
onHideTooltip = noop,
onMouseLeave = noop,
onMouseMove = noop,
onShowTooltip = noop,
isFocused: isFocusedProp = false,
max = 100,
min = 0,
Expand Down Expand Up @@ -85,13 +80,6 @@ export function useSlider(
[ onFocus ]
);

const hoverInteractions = useDebouncedHoverInteraction( {
onHide: onHideTooltip,
onMouseLeave,
onMouseMove,
onShow: onShowTooltip,
} );

// Interpolate the current value between 0 and 100, so that it can be used
// to position the slider's thumb correctly.
const progressPercentage = interpolate(
Expand Down Expand Up @@ -131,7 +119,6 @@ export function useSlider(

return {
...otherProps,
...hoverInteractions,
className: classes,
max,
min,
Expand Down
11 changes: 6 additions & 5 deletions packages/components/src/slider-control/stories/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,11 @@ const meta: ComponentMeta< typeof SliderControl > = {
component: SliderControl,
argTypes: {
errorColor: { control: { type: 'color' } },
onBlur: { action: 'onBlur', control: { type: null } },
onChange: { action: 'onChange' },
onFocus: { action: 'onFocus', control: { type: null } },
onMouseLeave: { action: 'onMouseLeave', control: { type: null } },
onMouseMove: { action: 'onMouseMove', control: { type: null } },
onBlur: { control: { type: null } },
onChange: { control: { type: null } },
onFocus: { control: { type: null } },
onMouseLeave: { control: { type: null } },
onMouseMove: { control: { type: null } },
size: {
control: 'radio',
options: [ 'default', '__unstable-large' ],
Expand All @@ -34,6 +34,7 @@ const meta: ComponentMeta< typeof SliderControl > = {
value: { control: { type: null } },
},
parameters: {
actions: { argTypesRegex: '^on.*' },
controls: { expanded: true },
docs: { source: { state: 'open' } },
},
Expand Down
2 changes: 1 addition & 1 deletion packages/components/src/slider-control/tooltip/hook.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ function useTooltipPosition( { inputRef, tooltipPosition }: TooltipProps ) {
if ( inputRef && inputRef.current ) {
setPosition( tooltipPosition );
}
}, [ tooltipPosition ] );
}, [ tooltipPosition, inputRef ] );

useEffect( () => {
setTooltipPosition();
Expand Down
12 changes: 0 additions & 12 deletions packages/components/src/slider-control/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -64,12 +64,6 @@ export type SliderProps = SliderColors & {
* Callback function when the `value` is committed.
*/
onChange?: ( value: number ) => void;
/**
* Callback for when the element is hidden.
*
* @default () => void
*/
onHideTooltip?: () => void;
/**
* Callback for when mouse exits the `RangeControl`.
*
Expand All @@ -82,12 +76,6 @@ export type SliderProps = SliderColors & {
* @default () => void
*/
onMouseMove?: MouseEventHandler< HTMLInputElement >;
/**
* Callback for when the element is shown.
*
* @default () => void
*/
onShowTooltip?: () => void;
/**
* Toggles which sized height the slider is rendered at.
*
Expand Down
76 changes: 2 additions & 74 deletions packages/components/src/slider-control/utils.ts
Original file line number Diff line number Diff line change
@@ -1,25 +1,15 @@
/**
* External dependencies
*/
import type { MouseEventHandler } from 'react';

/**
* WordPress dependencies
*/
import { useCallback, useRef, useEffect, useState } from '@wordpress/element';
import { useCallback } from '@wordpress/element';

/**
* Internal dependencies
*/
import { useControlledState } from '../utils/hooks';
import { clamp } from '../utils/math';

import type {
UseControlledRangeValueArgs,
UseDebouncedHoverInteractionArgs,
} from './types';

const noop = () => {};
import type { UseControlledRangeValueArgs } from './types';

/**
* A float supported clamp function for a specific value.
Expand Down Expand Up @@ -68,65 +58,3 @@ export function useControlledRangeValue(
// `null` in `useControlledState`
return [ state as Exclude< typeof state, '' >, setState ] as const;
}

/**
* Hook to encapsulate the debouncing "hover" to better handle the showing
* and hiding of the Tooltip.
*
* @param settings
* @return Bound properties for use on a React.Node.
*/
export function useDebouncedHoverInteraction(
settings: UseDebouncedHoverInteractionArgs
) {
const {
onHide = noop,
onMouseLeave = noop as MouseEventHandler,
onMouseMove = noop as MouseEventHandler,
onShow = noop,
timeout = 300,
} = settings;

const [ show, setShow ] = useState( false );
const timeoutRef = useRef< number | undefined >();

const setDebouncedTimeout = useCallback(
( callback ) => {
window.clearTimeout( timeoutRef.current );

timeoutRef.current = window.setTimeout( callback, timeout );
},
[ timeout ]
);

const handleOnMouseMove = useCallback( ( event ) => {
onMouseMove( event );

setDebouncedTimeout( () => {
if ( ! show ) {
setShow( true );
onShow();
}
} );
}, [] );

const handleOnMouseLeave = useCallback( ( event ) => {
onMouseLeave( event );

setDebouncedTimeout( () => {
setShow( false );
onHide();
} );
}, [] );

useEffect( () => {
return () => {
window.clearTimeout( timeoutRef.current );
};
} );

return {
onMouseMove: handleOnMouseMove,
onMouseLeave: handleOnMouseLeave,
};
}

0 comments on commit 82b8657

Please sign in to comment.