From fb30c0fe924d778bfdb3dd1f670e991c3dadade0 Mon Sep 17 00:00:00 2001 From: Tobias Date: Fri, 26 Aug 2022 09:51:34 +0200 Subject: [PATCH] fix(Slider): use numbers instead of css reverse when reversing slider --- .../src/components/slider/SliderHelpers.tsx | 7 +-- .../src/components/slider/SliderInstance.tsx | 23 +++++++-- .../src/components/slider/SliderProvider.tsx | 4 ++ .../src/components/slider/SliderThumb.tsx | 9 +++- .../src/components/slider/SliderTrack.tsx | 9 ++-- .../__snapshots__/Slider.test.tsx.snap | 6 +-- .../slider/hooks/useSliderEvents.tsx | 10 +--- .../slider/stories/Slider.stories.tsx | 49 +++++++++++++------ .../src/components/slider/style/_slider.scss | 8 +-- 9 files changed, 78 insertions(+), 47 deletions(-) diff --git a/packages/dnb-eufemia/src/components/slider/SliderHelpers.tsx b/packages/dnb-eufemia/src/components/slider/SliderHelpers.tsx index e08d55cc084..e483012b768 100644 --- a/packages/dnb-eufemia/src/components/slider/SliderHelpers.tsx +++ b/packages/dnb-eufemia/src/components/slider/SliderHelpers.tsx @@ -14,12 +14,14 @@ export const percentToValue = ( min: number, max: number ) => { + // Deprecated, can be removed in v10 if (typeof min === 'string') { min = parseFloat(min) } if (typeof max === 'string') { max = parseFloat(max) } + return ((max - min) * percent) / 100 + min } @@ -56,8 +58,7 @@ export const getMousePosition = (event: MouseEvent & TouchEvent) => { export const calculatePercent = ( node: HTMLElement, event: MouseEvent | TouchEvent, - isVertical: boolean, - isReverted: boolean + isVertical: boolean ) => { const { width, height } = node.getBoundingClientRect() const { top, left } = getOffset(node) @@ -66,7 +67,7 @@ export const calculatePercent = ( const value = isVertical ? y - top : x - left const onePercent = (isVertical ? height : width) / 100 - return Math.abs((isReverted ? 100 : 0) - clamp(value / onePercent)) + return Math.abs(clamp(value / onePercent)) } export const clamp = (value: number, min = 0, max = 100) => diff --git a/packages/dnb-eufemia/src/components/slider/SliderInstance.tsx b/packages/dnb-eufemia/src/components/slider/SliderInstance.tsx index 14d395140ab..b2d60958c24 100644 --- a/packages/dnb-eufemia/src/components/slider/SliderInstance.tsx +++ b/packages/dnb-eufemia/src/components/slider/SliderInstance.tsx @@ -53,7 +53,6 @@ export function SliderInstance() { const mainParams = { className: classnames( 'dnb-slider', - isReverse && 'dnb-slider--reverse', isVertical && 'dnb-slider--vertical', disabled && 'dnb-slider__state--disabled', !showButtons && 'dnb-slider--no-buttons', @@ -137,7 +136,8 @@ function SliderSuffix() { } function SubtractButton() { - const { emitChange, value, attributes, allProps } = useSliderProps() + const { emitChange, value, isReverse, attributes, allProps } = + useSliderProps() const { step, min, @@ -149,7 +149,13 @@ function SubtractButton() { } = allProps const onSubtractClickHandler = (event: MouseEvent | TouchEvent) => { - emitChange(event, clamp((value as number) - (step || 1), min, max)) + let newValue = clamp((value as number) - (step || 1), min, max) + + if (isReverse) { + newValue = max - newValue + } + + emitChange(event, newValue) } const subtractParams = {} @@ -176,12 +182,19 @@ function SubtractButton() { } function AddButton() { - const { emitChange, value, attributes, allProps } = useSliderProps() + const { emitChange, value, isReverse, attributes, allProps } = + useSliderProps() const { step, min, max, disabled, skeleton, addTitle, numberFormat } = allProps const onAddClickHandler = (event: MouseEvent | TouchEvent) => { - emitChange(event, clamp((value as number) + (step || 1), min, max)) + let newValue = clamp((value as number) + (step || 1), min, max) + + if (isReverse) { + newValue = max - newValue + } + + emitChange(event, newValue) } const addParams = {} diff --git a/packages/dnb-eufemia/src/components/slider/SliderProvider.tsx b/packages/dnb-eufemia/src/components/slider/SliderProvider.tsx index 52094c6ee4d..48bbb27cd55 100644 --- a/packages/dnb-eufemia/src/components/slider/SliderProvider.tsx +++ b/packages/dnb-eufemia/src/components/slider/SliderProvider.tsx @@ -150,6 +150,10 @@ export function SliderProvider(localProps: SliderProps) { return } + if (isReverse) { + rawValue = max - rawValue + } + let numberValue = roundValue(rawValue, step) let multiValues: ValueTypes = numberValue diff --git a/packages/dnb-eufemia/src/components/slider/SliderThumb.tsx b/packages/dnb-eufemia/src/components/slider/SliderThumb.tsx index 0d389d7ba46..52df9883ea5 100644 --- a/packages/dnb-eufemia/src/components/slider/SliderThumb.tsx +++ b/packages/dnb-eufemia/src/components/slider/SliderThumb.tsx @@ -14,6 +14,7 @@ export function SliderThumb() { values, thumbIndex, isVertical, + isReverse, showStatus, attributes, allProps, @@ -70,7 +71,13 @@ export function SliderThumb() { <> {values.map((value, i) => { const index = thumbIndex.current - const percent = clamp(((value - min) * 100) / (max - min)) + let percent = clamp( + ((value - (isReverse ? 0 : min)) * 100) / (max - min) + ) + + if (isReverse) { + percent = 100 - percent + } const style: React.CSSProperties = { zIndex: index === i ? 4 : 3, diff --git a/packages/dnb-eufemia/src/components/slider/SliderTrack.tsx b/packages/dnb-eufemia/src/components/slider/SliderTrack.tsx index 8825bddb1e5..2eef2affcb2 100644 --- a/packages/dnb-eufemia/src/components/slider/SliderTrack.tsx +++ b/packages/dnb-eufemia/src/components/slider/SliderTrack.tsx @@ -70,6 +70,7 @@ export function SliderTrackBefore() { const { values: origValues, isVertical, + isReverse, thumbIndex, allProps: { min, max }, } = useSliderProps() @@ -84,13 +85,13 @@ export function SliderTrackBefore() { const index = thumbIndex.current const upperValue = values[isBetween ? 0 : index > -1 ? index : 0] const upperPercent = isBetween - ? clamp(((upperValue - min) * 100) / (max - min)) + ? clamp(((upperValue - (isReverse ? 0 : min)) * 100) / (max - min)) : 0 const lowerValue = values[isBetween ? values.length - 1 : index > -1 ? index : 0] const lowerPercent = - 100 - clamp(((lowerValue - min) * 100) / (max - min)) + 100 - clamp(((lowerValue - (isReverse ? 0 : min)) * 100) / (max - min)) const units = [ trackObj[isVertical ? 1 : 0][0], @@ -98,8 +99,8 @@ export function SliderTrackBefore() { ] const style: React.CSSProperties = {} - style[units[0]] = `${lowerPercent}%` - style[units[1]] = `${upperPercent}%` + style[units[isReverse ? 1 : 0]] = `${lowerPercent}%` + style[units[isReverse ? 0 : 1]] = `${upperPercent}%` return ( { - const percent = calculatePercent( - trackRef.current, - event, - isVertical, - isReverse - ) + const percent = calculatePercent(trackRef.current, event, isVertical) emitChange(event, percentToValue(percent, min, max)) setJumpedState() @@ -125,7 +119,7 @@ export function useSliderEvents() { } if (elem) { - const percent = calculatePercent(elem, event, isVertical, isReverse) + const percent = calculatePercent(elem, event, isVertical) emitChange(event, percentToValue(percent, min, max)) } } diff --git a/packages/dnb-eufemia/src/components/slider/stories/Slider.stories.tsx b/packages/dnb-eufemia/src/components/slider/stories/Slider.stories.tsx index 586df57640a..9d66e907b9e 100644 --- a/packages/dnb-eufemia/src/components/slider/stories/Slider.stories.tsx +++ b/packages/dnb-eufemia/src/components/slider/stories/Slider.stories.tsx @@ -7,14 +7,7 @@ import React from 'react' import { Wrapper, Box } from 'storybook-utils/helpers' import styled from '@emotion/styled' -import { - Slider, - ToggleButton, - Input, - FormRow, - FormLabel, - Tooltip, -} from '../../' +import { Slider, ToggleButton, Input, FormRow, FormLabel } from '../../' import '../../slider/style/dnb-range.scss' @@ -45,17 +38,24 @@ const FixedSizeWrapper = styled.div` ` export function MultiButtons() { - const [value, setValue] = React.useState>([10, 40, 80]) + const [value, setValue] = React.useState>([100, 400, 800]) + const [valueSecond, setValueSecond] = React.useState(800) return ( <> - - Tooltip - { @@ -67,7 +67,28 @@ export function MultiButtons() { - + { + console.log('onChange:', value, number) + setValueSecond(value as number) + }} + /> + {valueSecond} ) diff --git a/packages/dnb-eufemia/src/components/slider/style/_slider.scss b/packages/dnb-eufemia/src/components/slider/style/_slider.scss index ba6cb418712..bfac27c8efe 100644 --- a/packages/dnb-eufemia/src/components/slider/style/_slider.scss +++ b/packages/dnb-eufemia/src/components/slider/style/_slider.scss @@ -101,12 +101,6 @@ min-width: inherit; min-height: inherit; } - &--reverse &__track { - transform: scaleX(-1); - } - &--reverse#{&}--vertical &__track { - transform: scaleY(-1); - } &__line { position: absolute; @@ -180,7 +174,7 @@ line-height: var(--slider-button-size); transform: translateY(0.25rem); - z-index: 5; + z-index: 2; } &--vertical &__button.dnb-button--size-small { transform: translateX(0.25rem);