From 8d29b188f33988eea6b98275c51d73df9118fec9 Mon Sep 17 00:00:00 2001 From: Kirill Revenkov Date: Mon, 10 Jun 2024 19:13:02 +0300 Subject: [PATCH 1/3] feat: refactor getInnerState --- src/components/Slider/utils.ts | 36 ++++++++++++++++++---------------- 1 file changed, 19 insertions(+), 17 deletions(-) diff --git a/src/components/Slider/utils.ts b/src/components/Slider/utils.ts index 6dd0d4c42b..057b2734d9 100644 --- a/src/components/Slider/utils.ts +++ b/src/components/Slider/utils.ts @@ -134,24 +134,26 @@ export function getInnerState({ state.marks = createMarks(calculateInfoPoints({count: marksCount, max, min})); } - if (value && Array.isArray(value)) { - state.range = true; - state.value = prepareArrayValue({min: state.min, max: state.max, value}); - } else if (defaultValue && Array.isArray(defaultValue)) { - state.range = true; - state.defaultValue = prepareArrayValue({ - min: state.min, - max: state.max, - value: defaultValue, - }); - } else if (value) { - state.value = prepareSingleValue({min: state.min, max: state.max, value}); + if (value === undefined) { + const isArray = Array.isArray(defaultValue); + state.range = isArray; + state.defaultValue = isArray + ? prepareArrayValue({ + min: state.min, + max: state.max, + value: defaultValue, + }) + : prepareSingleValue({ + min: state.min, + max: state.max, + value: defaultValue, + }); } else { - state.defaultValue = prepareSingleValue({ - min: state.min, - max: state.max, - value: defaultValue, - }); + const isArray = Array.isArray(value); + state.range = isArray; + state.value = isArray + ? prepareArrayValue({min: state.min, max: state.max, value}) + : prepareSingleValue({min: state.min, max: state.max, value}); } return state; From fda2088e99d1a3e60e63ddeda81874b3f70faaad Mon Sep 17 00:00:00 2001 From: Kirill Revenkov Date: Mon, 10 Jun 2024 19:13:44 +0300 Subject: [PATCH 2/3] chore: rename getInnerState-> prepareSliderInnerState and add to export --- src/components/Slider/Slider.tsx | 4 ++-- src/components/Slider/index.ts | 1 + src/components/Slider/utils.ts | 2 +- 3 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/components/Slider/Slider.tsx b/src/components/Slider/Slider.tsx index 204fbe9dca..15311bdd46 100644 --- a/src/components/Slider/Slider.tsx +++ b/src/components/Slider/Slider.tsx @@ -8,7 +8,7 @@ import {block} from '../utils/cn'; import {BaseSlider} from './BaseSlider/BaseSlider'; import {SliderTooltip} from './SliderTooltip/SliderTooltip'; import type {RcSliderValueType, SliderProps, SliderValue, StateModifiers} from './types'; -import {getInnerState} from './utils'; +import {prepareSliderInnerState} from './utils'; import './Slider.scss'; @@ -69,7 +69,7 @@ export const Slider = React.forwardRef(function Slider( }; }, [handleUpdate, handleUpdateComplete]); - const innerState = getInnerState({ + const innerState = prepareSliderInnerState({ availableValues, defaultValue, marksCount, diff --git a/src/components/Slider/index.ts b/src/components/Slider/index.ts index 05ecd5c22a..4551608dc1 100644 --- a/src/components/Slider/index.ts +++ b/src/components/Slider/index.ts @@ -1,2 +1,3 @@ export * from './Slider'; export type {SliderSize, SliderValue, SliderProps, BaseSliderRefType} from './types'; +export {prepareSliderInnerState} from './utils'; diff --git a/src/components/Slider/utils.ts b/src/components/Slider/utils.ts index 057b2734d9..7a6be6dc3b 100644 --- a/src/components/Slider/utils.ts +++ b/src/components/Slider/utils.ts @@ -88,7 +88,7 @@ function createMarks(points: number[]): RcSliderProps['marks'] { return marks; } -export function getInnerState({ +export function prepareSliderInnerState({ max = 100, min = 0, availableValues, From 143584fa5100fdf50b41a55846ab5e66581c9aec Mon Sep 17 00:00:00 2001 From: Kirill Revenkov Date: Tue, 11 Jun 2024 10:45:54 +0300 Subject: [PATCH 3/3] chore: add jsdoc annotation for prepareSliderInnerState --- src/components/Slider/utils.ts | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/components/Slider/utils.ts b/src/components/Slider/utils.ts index 7a6be6dc3b..b21ca33bfe 100644 --- a/src/components/Slider/utils.ts +++ b/src/components/Slider/utils.ts @@ -88,6 +88,10 @@ function createMarks(points: number[]): RcSliderProps['marks'] { return marks; } +/** + * Calculates the basic properties of the Slider component depending on the passed parameters + * @returns {SliderInnerState} Properties to pass to the Slider + */ export function prepareSliderInnerState({ max = 100, min = 0,