diff --git a/docs/data/base/components/slider/DiscreteSlider.js b/docs/data/base/components/slider/DiscreteSlider.js deleted file mode 100644 index f412bbfb40..0000000000 --- a/docs/data/base/components/slider/DiscreteSlider.js +++ /dev/null @@ -1,163 +0,0 @@ -import * as React from 'react'; -import PropTypes from 'prop-types'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; - -export default function DiscreteSlider() { - return ( - - - - ); -} - -function SliderValueLabel({ children }) { - return {children}; -} - -SliderValueLabel.propTypes = { - children: PropTypes.element.isRequired, -}; - -function valuetext(value) { - return `${value}°C`; -} - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - -const grey = { - 50: '#F3F6F9', - 100: '#E5EAF2', - 200: '#DAE2ED', - 300: '#C7D0DD', - 400: '#B0B8C4', - 500: '#9DA8B7', - 600: '#6B7A90', - 700: '#434D5B', - 800: '#303740', - 900: '#1C2025', -}; - -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; - width: 100%; - padding: 16px 0; - display: inline-flex; - align-items: center; - position: relative; - cursor: pointer; - touch-action: none; - -webkit-tap-highlight-color: transparent; - - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; - } - - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; - } - - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; - } - - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } - } - - & .${sliderClasses.mark} { - position: absolute; - width: 10px; - height: 10px; - border-radius: 99%; - background-color: ${theme.palette.mode === 'light' ? blue[200] : blue[700]}; - transform: translateX(-50%); - } - - & .${sliderClasses.markActive} { - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - } - - & .valueLabel { - font-family: IBM Plex Sans; - font-weight: 600; - font-size: 12px; - position: relative; - top: -2em; - text-align: center; - align-self: center; - } -`, -); diff --git a/docs/data/base/components/slider/DiscreteSlider.tsx b/docs/data/base/components/slider/DiscreteSlider.tsx deleted file mode 100644 index 28af59a202..0000000000 --- a/docs/data/base/components/slider/DiscreteSlider.tsx +++ /dev/null @@ -1,162 +0,0 @@ -import * as React from 'react'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; - -export default function DiscreteSlider() { - return ( - - - - ); -} - -interface SliderValueLabelProps { - children: React.ReactElement; -} - -function SliderValueLabel({ children }: SliderValueLabelProps) { - return {children}; -} - -function valuetext(value: number) { - return `${value}°C`; -} - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - -const grey = { - 50: '#F3F6F9', - 100: '#E5EAF2', - 200: '#DAE2ED', - 300: '#C7D0DD', - 400: '#B0B8C4', - 500: '#9DA8B7', - 600: '#6B7A90', - 700: '#434D5B', - 800: '#303740', - 900: '#1C2025', -}; - -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; - width: 100%; - padding: 16px 0; - display: inline-flex; - align-items: center; - position: relative; - cursor: pointer; - touch-action: none; - -webkit-tap-highlight-color: transparent; - - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; - } - - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; - } - - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; - } - - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } - } - - & .${sliderClasses.mark} { - position: absolute; - width: 10px; - height: 10px; - border-radius: 99%; - background-color: ${theme.palette.mode === 'light' ? blue[200] : blue[700]}; - transform: translateX(-50%); - } - - & .${sliderClasses.markActive} { - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - } - - & .valueLabel { - font-family: IBM Plex Sans; - font-weight: 600; - font-size: 12px; - position: relative; - top: -2em; - text-align: center; - align-self: center; - } -`, -); diff --git a/docs/data/base/components/slider/DiscreteSlider.tsx.preview b/docs/data/base/components/slider/DiscreteSlider.tsx.preview deleted file mode 100644 index 1d0ad0d7b2..0000000000 --- a/docs/data/base/components/slider/DiscreteSlider.tsx.preview +++ /dev/null @@ -1,11 +0,0 @@ - \ No newline at end of file diff --git a/docs/data/base/components/slider/DiscreteSliderMarks.js b/docs/data/base/components/slider/DiscreteSliderMarks.js deleted file mode 100644 index 8a63200dda..0000000000 --- a/docs/data/base/components/slider/DiscreteSliderMarks.js +++ /dev/null @@ -1,168 +0,0 @@ -import * as React from 'react'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; - -export default function DiscreteSliderMarks() { - return ( - - - - ); -} - -const marks = [ - { - value: 0, - label: '0°C', - }, - { - value: 20, - label: '20°C', - }, - { - value: 37, - label: '37°C', - }, - { - value: 100, - label: '100°C', - }, -]; - -function valuetext(value) { - return `${value}°C`; -} - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - -const grey = { - 50: '#F3F6F9', - 100: '#E5EAF2', - 200: '#DAE2ED', - 300: '#C7D0DD', - 400: '#B0B8C4', - 500: '#9DA8B7', - 600: '#6B7A90', - 700: '#434D5B', - 800: '#303740', - 900: '#1C2025', -}; - -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; - width: 100%; - padding: 16px 0; - display: inline-flex; - align-items: center; - position: relative; - cursor: pointer; - touch-action: none; - -webkit-tap-highlight-color: transparent; - - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; - } - - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; - } - - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; - } - - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } - } - - & .${sliderClasses.mark} { - position: absolute; - width: 10px; - height: 10px; - border-radius: 99%; - background-color: ${theme.palette.mode === 'light' ? blue[200] : blue[900]}; - transform: translateX(-50%); - } - - & .${sliderClasses.markActive} { - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - } - - & .${sliderClasses.markLabel} { - font-family: IBM Plex Sans; - font-weight: 600; - font-size: 12px; - position: absolute; - top: 24px; - transform: translateX(-50%); - margin-top: 8px; - } -`, -); diff --git a/docs/data/base/components/slider/DiscreteSliderMarks.tsx b/docs/data/base/components/slider/DiscreteSliderMarks.tsx deleted file mode 100644 index 67d0d0041e..0000000000 --- a/docs/data/base/components/slider/DiscreteSliderMarks.tsx +++ /dev/null @@ -1,168 +0,0 @@ -import * as React from 'react'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; - -export default function DiscreteSliderMarks() { - return ( - - - - ); -} - -const marks = [ - { - value: 0, - label: '0°C', - }, - { - value: 20, - label: '20°C', - }, - { - value: 37, - label: '37°C', - }, - { - value: 100, - label: '100°C', - }, -]; - -function valuetext(value: number) { - return `${value}°C`; -} - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - -const grey = { - 50: '#F3F6F9', - 100: '#E5EAF2', - 200: '#DAE2ED', - 300: '#C7D0DD', - 400: '#B0B8C4', - 500: '#9DA8B7', - 600: '#6B7A90', - 700: '#434D5B', - 800: '#303740', - 900: '#1C2025', -}; - -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; - width: 100%; - padding: 16px 0; - display: inline-flex; - align-items: center; - position: relative; - cursor: pointer; - touch-action: none; - -webkit-tap-highlight-color: transparent; - - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; - } - - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; - } - - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; - } - - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } - } - - & .${sliderClasses.mark} { - position: absolute; - width: 10px; - height: 10px; - border-radius: 99%; - background-color: ${theme.palette.mode === 'light' ? blue[200] : blue[900]}; - transform: translateX(-50%); - } - - & .${sliderClasses.markActive} { - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - } - - & .${sliderClasses.markLabel} { - font-family: IBM Plex Sans; - font-weight: 600; - font-size: 12px; - position: absolute; - top: 24px; - transform: translateX(-50%); - margin-top: 8px; - } -`, -); diff --git a/docs/data/base/components/slider/DiscreteSliderMarks.tsx.preview b/docs/data/base/components/slider/DiscreteSliderMarks.tsx.preview deleted file mode 100644 index 32bef2b878..0000000000 --- a/docs/data/base/components/slider/DiscreteSliderMarks.tsx.preview +++ /dev/null @@ -1,6 +0,0 @@ - \ No newline at end of file diff --git a/docs/data/base/components/slider/DiscreteSliderValues.js b/docs/data/base/components/slider/DiscreteSliderValues.js deleted file mode 100644 index 71f32e7f4c..0000000000 --- a/docs/data/base/components/slider/DiscreteSliderValues.js +++ /dev/null @@ -1,169 +0,0 @@ -import * as React from 'react'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; - -export default function DiscreteSliderValues() { - return ( - - - - ); -} - -const marks = [ - { - value: 0, - label: '0°C', - }, - { - value: 20, - label: '20°C', - }, - { - value: 37, - label: '37°C', - }, - { - value: 100, - label: '100°C', - }, -]; - -function valuetext(value) { - return `${value}°C`; -} - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - -const grey = { - 50: '#F3F6F9', - 100: '#E5EAF2', - 200: '#DAE2ED', - 300: '#C7D0DD', - 400: '#B0B8C4', - 500: '#9DA8B7', - 600: '#6B7A90', - 700: '#434D5B', - 800: '#303740', - 900: '#1C2025', -}; - -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; - width: 100%; - padding: 16px 0; - display: inline-flex; - align-items: center; - position: relative; - cursor: pointer; - touch-action: none; - -webkit-tap-highlight-color: transparent; - - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; - } - - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; - } - - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; - } - - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } - } - - & .${sliderClasses.mark} { - position: absolute; - width: 10px; - height: 10px; - border-radius: 99%; - background-color: ${theme.palette.mode === 'light' ? blue[200] : blue[900]}; - transform: translateX(-50%); - } - - & .${sliderClasses.markActive} { - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - } - - & .${sliderClasses.markLabel} { - font-family: IBM Plex Sans; - font-weight: 600; - font-size: 12px; - position: absolute; - top: 24px; - transform: translateX(-50%); - margin-top: 8px; - } -`, -); diff --git a/docs/data/base/components/slider/DiscreteSliderValues.tsx b/docs/data/base/components/slider/DiscreteSliderValues.tsx deleted file mode 100644 index dd26e68159..0000000000 --- a/docs/data/base/components/slider/DiscreteSliderValues.tsx +++ /dev/null @@ -1,169 +0,0 @@ -import * as React from 'react'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; - -export default function DiscreteSliderValues() { - return ( - - - - ); -} - -const marks = [ - { - value: 0, - label: '0°C', - }, - { - value: 20, - label: '20°C', - }, - { - value: 37, - label: '37°C', - }, - { - value: 100, - label: '100°C', - }, -]; - -function valuetext(value: number) { - return `${value}°C`; -} - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - -const grey = { - 50: '#F3F6F9', - 100: '#E5EAF2', - 200: '#DAE2ED', - 300: '#C7D0DD', - 400: '#B0B8C4', - 500: '#9DA8B7', - 600: '#6B7A90', - 700: '#434D5B', - 800: '#303740', - 900: '#1C2025', -}; - -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; - width: 100%; - padding: 16px 0; - display: inline-flex; - align-items: center; - position: relative; - cursor: pointer; - touch-action: none; - -webkit-tap-highlight-color: transparent; - - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; - } - - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; - } - - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; - } - - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } - } - - & .${sliderClasses.mark} { - position: absolute; - width: 10px; - height: 10px; - border-radius: 99%; - background-color: ${theme.palette.mode === 'light' ? blue[200] : blue[900]}; - transform: translateX(-50%); - } - - & .${sliderClasses.markActive} { - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - } - - & .${sliderClasses.markLabel} { - font-family: IBM Plex Sans; - font-weight: 600; - font-size: 12px; - position: absolute; - top: 24px; - transform: translateX(-50%); - margin-top: 8px; - } -`, -); diff --git a/docs/data/base/components/slider/DiscreteSliderValues.tsx.preview b/docs/data/base/components/slider/DiscreteSliderValues.tsx.preview deleted file mode 100644 index f5e963865b..0000000000 --- a/docs/data/base/components/slider/DiscreteSliderValues.tsx.preview +++ /dev/null @@ -1,7 +0,0 @@ - \ No newline at end of file diff --git a/docs/data/base/components/slider/LabeledValuesSlider.js b/docs/data/base/components/slider/LabeledValuesSlider.js deleted file mode 100644 index 7727e6b1b5..0000000000 --- a/docs/data/base/components/slider/LabeledValuesSlider.js +++ /dev/null @@ -1,161 +0,0 @@ -import * as React from 'react'; -import PropTypes from 'prop-types'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; - -export default function LabeledValuesSlider() { - return ( - - - - ); -} - -function SliderValueLabel({ children }) { - return ( - -
{children}
-
- ); -} - -SliderValueLabel.propTypes = { - children: PropTypes.element.isRequired, -}; - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - -const grey = { - 50: '#F3F6F9', - 100: '#E5EAF2', - 200: '#DAE2ED', - 300: '#C7D0DD', - 400: '#B0B8C4', - 500: '#9DA8B7', - 600: '#6B7A90', - 700: '#434D5B', - 800: '#303740', - 900: '#1C2025', -}; - -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; - width: 100%; - padding: 16px 0; - display: inline-flex; - align-items: center; - position: relative; - cursor: pointer; - touch-action: none; - -webkit-tap-highlight-color: transparent; - - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; - } - - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; - } - - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; - } - - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } - } - - & .label { - font-family: IBM Plex Sans; - font-weight: 600; - font-size: 14px; - background: unset; - background-color: ${theme.palette.mode === 'light' ? blue[600] : blue[900]}; - width: 32px; - height: 32px; - padding: 0px; - visibility: hidden; - color: #fff; - border-radius: 50% 50% 50% 0; - position: absolute; - transform: translate(0%, -140%) rotate(-45deg) scale(0); - transition: transform 0.2s ease; - display: flex; - align-items: center; - justify-content: center; - } - - :hover .label { - visibility: visible; - transform: translate(0%, -140%) rotate(-45deg) scale(1); - } - - :hover .value { - transform: rotate(45deg); - text-align: center; - } - } -`, -); diff --git a/docs/data/base/components/slider/LabeledValuesSlider.tsx b/docs/data/base/components/slider/LabeledValuesSlider.tsx deleted file mode 100644 index a845927d13..0000000000 --- a/docs/data/base/components/slider/LabeledValuesSlider.tsx +++ /dev/null @@ -1,160 +0,0 @@ -import * as React from 'react'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; - -export default function LabeledValuesSlider() { - return ( - - - - ); -} - -interface SliderValueLabelProps { - children: React.ReactElement; -} - -function SliderValueLabel({ children }: SliderValueLabelProps) { - return ( - -
{children}
-
- ); -} - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - -const grey = { - 50: '#F3F6F9', - 100: '#E5EAF2', - 200: '#DAE2ED', - 300: '#C7D0DD', - 400: '#B0B8C4', - 500: '#9DA8B7', - 600: '#6B7A90', - 700: '#434D5B', - 800: '#303740', - 900: '#1C2025', -}; - -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; - width: 100%; - padding: 16px 0; - display: inline-flex; - align-items: center; - position: relative; - cursor: pointer; - touch-action: none; - -webkit-tap-highlight-color: transparent; - - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; - } - - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; - } - - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; - } - - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } - } - - & .label { - font-family: IBM Plex Sans; - font-weight: 600; - font-size: 14px; - background: unset; - background-color: ${theme.palette.mode === 'light' ? blue[600] : blue[900]}; - width: 32px; - height: 32px; - padding: 0px; - visibility: hidden; - color: #fff; - border-radius: 50% 50% 50% 0; - position: absolute; - transform: translate(0%, -140%) rotate(-45deg) scale(0); - transition: transform 0.2s ease; - display: flex; - align-items: center; - justify-content: center; - } - - :hover .label { - visibility: visible; - transform: translate(0%, -140%) rotate(-45deg) scale(1); - } - - :hover .value { - transform: rotate(45deg); - text-align: center; - } - } -`, -); diff --git a/docs/data/base/components/slider/LabeledValuesSlider.tsx.preview b/docs/data/base/components/slider/LabeledValuesSlider.tsx.preview deleted file mode 100644 index ab77eaafc1..0000000000 --- a/docs/data/base/components/slider/LabeledValuesSlider.tsx.preview +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/docs/data/base/components/slider/RangeSlider.js b/docs/data/base/components/slider/RangeSlider.js index 074b00a9e4..a885433689 100644 --- a/docs/data/base/components/slider/RangeSlider.js +++ b/docs/data/base/components/slider/RangeSlider.js @@ -1,52 +1,49 @@ import * as React from 'react'; -import { styled, alpha, Box } from '@mui/system'; -import { Slider as BaseSlider, sliderClasses } from '@base_ui/react/Slider'; +import { styled, useTheme, Box } from '@mui/system'; +import * as BaseSlider from '@base_ui/react/Slider'; export default function RangeSlider() { + // Replace this with your app logic for determining dark mode + const isDarkMode = useIsDarkMode(); const [value, setValue] = React.useState([20, 37]); - const handleChange = (event, newValue) => { - setValue(newValue); - }; - return ( - + {/* controlled: */} 'Temperature range'} - getAriaValueText={valuetext} - min={0} - max={100} - /> + onValueChange={setValue} + aria-labelledby="ControlledRangeLabel" + > + + + + + + + + + + {/* uncontrolled: */} - 'Temperature range'} - getAriaValueText={valuetext} - min={0} - max={100} - /> + + + + + + + + + + + ); } -function valuetext(value) { - return `${value}°C`; -} - -const blue = { - 100: '#DAECFF', - 200: '#99CCF3', - 400: '#3399FF', - 300: '#66B2FF', - 500: '#007FFF', - 600: '#0072E5', - 700: '#0059B3', - 900: '#003A75', -}; - const grey = { 50: '#F3F6F9', 100: '#E5EAF2', @@ -60,98 +57,111 @@ const grey = { 900: '#1C2025', }; -const Slider = styled(BaseSlider)( - ({ theme }) => ` - color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - height: 6px; +function useIsDarkMode() { + const theme = useTheme(); + return theme.palette.mode === 'dark'; +} + +const Slider = styled(BaseSlider.Root)` + font-family: 'IBM Plex Sans', sans-serif; + font-size: 1rem; width: 100%; - padding: 16px 0; - display: inline-flex; align-items: center; position: relative; - cursor: pointer; - touch-action: none; -webkit-tap-highlight-color: transparent; + display: grid; + grid-template-columns: 1fr 1fr; + gap: 1rem; +`; + +const SliderOutput = styled(BaseSlider.Output)` + text-align: right; +`; + +const SliderControl = styled(BaseSlider.Control)` + grid-column: 1/3; + display: flex; + align-items: center; + position: relative; + width: 100%; + height: 16px; + border-radius: 9999px; + touch-action: none; - &.${sliderClasses.disabled} { - pointer-events: none; - cursor: default; - color: ${theme.palette.mode === 'light' ? grey[300] : grey[600]}; - opacity: 0.4; + &[data-disabled] { + cursor: not-allowed; } +`; - & .${sliderClasses.rail} { - display: block; - position: absolute; - width: 100%; - height: 4px; - border-radius: 6px; - background-color: currentColor; - opacity: 0.3; +const SliderTrack = styled(BaseSlider.Track)` + width: 100%; + height: 2px; + border-radius: 9999px; + background-color: ${grey[400]}; + touch-action: none; + + .dark & { + background-color: ${grey[700]}; + } +`; + +const SliderIndicator = styled(BaseSlider.Indicator)` + border-radius: 9999px; + background-color: black; + + .dark & { + background-color: ${grey[100]}; + } +`; + +const SliderThumb = styled(BaseSlider.Thumb)` + position: absolute; + width: 16px; + height: 16px; + box-sizing: border-box; + border-radius: 50%; + background-color: black; + transform: translateX(-50%); + touch-action: none; + + &:focus-visible { + outline: 2px solid black; + outline-offset: 2px; } - & .${sliderClasses.track} { - display: block; - position: absolute; - height: 4px; - border-radius: 6px; - background-color: currentColor; + .dark & { + background-color: ${grey[300]}; } - & .${sliderClasses.thumb} { - display: flex; - align-items: center; - justify-content: center; - position: absolute; - margin-left: -6px; - width: 20px; - height: 20px; - box-sizing: border-box; - border-radius: 50%; - outline: 0; - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; - transition-property: box-shadow, transform; - transition-timing-function: ease; - transition-duration: 120ms; - transform-origin: center; - - &:hover { - box-shadow: 0 0 0 6px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[300], - 0.3, - )}; - } - - &.${sliderClasses.focusVisible} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - } - - &.${sliderClasses.active} { - box-shadow: 0 0 0 8px ${alpha( - theme.palette.mode === 'light' ? blue[200] : blue[400], - 0.5, - )}; - outline: none; - transform: scale(1.2); - } + .dark &:focus-visible { + outline-color: ${grey[300]}; + outline-width: 1px; + outline-offset: 3px; } - & .${sliderClasses.mark} { - position: absolute; - width: 10px; - height: 10px; - border-radius: 99%; - background-color: ${theme.palette.mode === 'light' ? blue[200] : blue[900]}; - top: 44%; - transform: translateX(-50%); + &[data-dragging='true'] { + background-color: pink; } - & .${sliderClasses.markActive} { - background-color: ${theme.palette.mode === 'light' ? blue[500] : blue[400]}; + &[data-disabled], + .dark &[data-disabled] { + background-color: ${grey[600]}; + } + + .dark &[data-dragging='true'] { + background-color: pink; + } +`; + +// we can't use a