Skip to main content
Since Shoelace 2.0 Code stable Pattern Tentative Figma Needed

Range

<sl-range> | SlRange

Ranges allow the user to select a single value within a given range using a slider.

Examples

Basic Range

<sl-range></sl-range>
sl-range
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => <SlRange />;

Labels

Use the label attribute to give the range an accessible label. For labels that contain HTML, use the label slot instead.

<sl-range label="Volume" min="0" max="100"></sl-range>
sl-range label="Volume" min="0" max="100"
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => <SlRange label="Volume" min={0} max={100} />;

Help Text

Add descriptive help text to a range with the help-text attribute. For help texts that contain HTML, use the help-text slot instead.

<sl-range label="Volume" help-text="Controls the volume of the current song." min="0" max="100"></sl-range>
sl-range label="Volume" help-text="Controls the volume of the current song." min="0" max="100"
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => <SlRange label="Volume" help-text="Controls the volume of the current song." min={0} max={100} />;

Min, Max, and Step

Use the min and max attributes to set the range’s minimum and maximum values, respectively. The step attribute determines the value’s interval when increasing and decreasing.

<sl-range min="0" max="10" step="1"></sl-range>
sl-range min="0" max="10" step="1"
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => <SlRange min={0} max={10} step={1} />;

Disabled

Use the disabled attribute to disable a slider.

<sl-range disabled></sl-range>
sl-range disabled="true"
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => <SlRange disabled />;

Tooltip Placement

By default, the tooltip is shown on top. Set tooltip to bottom to show it below the slider.

<sl-range tooltip="bottom"></sl-range>
sl-range tooltip="bottom"
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => <SlRange tooltip="bottom" />;

Disable the Tooltip

To disable the tooltip, set tooltip to none.

<sl-range tooltip="none"></sl-range>
sl-range tooltip="none"
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => <SlRange tooltip="none" />;

Custom Track Colors

You can customize the active and inactive portions of the track using the --track-color-active and --track-color-inactive custom properties.

<sl-range
  style="
  --track-color-active: var(--sl-color-primary-600);
  --track-color-inactive: var(--sl-color-primary-100);
"
></sl-range>
sl-range[style="
  --track-color-active: var(--sl-color-primary-600);
  --track-color-inactive: var(--sl-color-primary-100);
"]
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => (
  <SlRange
    style={{
      '--track-color-active': 'var(--sl-color-primary-600)',
      '--track-color-inactive': 'var(--sl-color-primary-200)'
    }}
  />
);

Custom Track Offset

You can customize the initial offset of the active track using the --track-active-offset custom property.

<sl-range
  min="-100"
  max="100"
  style="
  --track-color-active: var(--sl-color-primary-600);
  --track-color-inactive: var(--sl-color-primary-100);
  --track-active-offset: 50%;
"
></sl-range>
sl-range[min="-100" max="100" style="
  --track-color-active: var(--sl-color-primary-600);
  --track-color-inactive: var(--sl-color-primary-100);
  --track-active-offset: 50%;
"]
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => (
  <SlRange
    min={-100}
    max={100}
    style={{
      '--track-color-active': 'var(--sl-color-primary-600)',
      '--track-color-inactive': 'var(--sl-color-primary-200)',
      '--track-active-offset': '50%'
    }}
  />
);

Custom Tooltip Formatter

You can change the tooltip’s content by setting the tooltipFormatter property to a function that accepts the range’s value as an argument.

<sl-range min="0" max="100" step="1" class="range-with-custom-formatter"></sl-range>

<script>
  const range = document.querySelector('.range-with-custom-formatter');
  range.tooltipFormatter = value => `Total - ${value}%`;
</script>
sl-range.range-with-custom-formatter min="0" max="100" step="1"

javascript:
  const range = document.querySelector(.range-with-custom-formatter);
  range.tooltipFormatter = value => `Total - ${value}%`;
import SlRange from '@teamshares/shoelace/dist/react/range';

const App = () => <SlRange min={0} max={100} step={1} tooltipFormatter={value => `Total - ${value}%`} />;

Component Props

Property Default Details
name ''

string

The name of the range, submitted as a name/value pair with form data.

value 0

number

The current value of the range, submitted as a name/value pair with form data.

label ''

string

The range’s label. If you need to display HTML, use the label slot instead.

helpText
help-text
''

string

The range’s help text. If you need to display HTML, use the help-text slot instead.

disabled false

boolean

Disables the range.

min 0

number

The minimum acceptable value of the range.

max 100

number

The maximum acceptable value of the range.

step 1

number

The interval at which the range will increase and decrease.

tooltip 'top'

'top' | 'bottom' | 'none'

The preferred placement of the range’s tooltip.

tooltipFormatter

(value: number) => string

A function used to format the tooltip’s value. The range’s value is passed as the first and only argument. The function should return a string to display in the tooltip.

form ''

string

By default, form controls are associated with the nearest containing <form> element. This attribute allows you to place the form control outside of a form and associate it with the form that has this id. The form must be in the same document or shadow root for this to work.

defaultValue 0

number

The default value of the form control. Primarily used for resetting the form control.

validity

Gets the validity state object

validationMessage

Gets the validation message

updateComplete A read-only promise that resolves when the component has finished updating.

Learn more about attributes and properties.

Slots

Name Details
label The range’s label. Alternatively, you can use the label attribute.
help-text Text that describes how to use the input. Alternatively, you can use the help-text attribute.

Learn more about using slots.

Events

Name Name React Event Details
sl-blur sl-blur onSlBlur

Emitted when the control loses focus.

sl-change sl-change onSlChange

Emitted when an alteration to the control’s value is committed by the user.

sl-focus sl-focus onSlFocus

Emitted when the control gains focus.

sl-input sl-input onSlInput

Emitted when the control receives input.

sl-invalid sl-invalid onSlInvalid

Emitted when the form control has been checked for validity and its constraints aren’t satisfied.

Learn more about events.

Methods

Name Details
focus()

options: FocusOptions

Sets focus on the range.

blur()

Removes focus from the range.

stepUp()

Increments the value of the range by the value of the step attribute.

stepDown()

Decrements the value of the range by the value of the step attribute.

checkValidity()

Checks for validity but does not show a validation message. Returns true when valid and false when invalid.

getForm()

Gets the associated form, if one exists.

reportValidity()

Checks for validity and shows the browser’s validation message if the control is invalid.

setCustomValidity()

message: string

Sets a custom validation message. Pass an empty string to restore validity.

Learn more about methods.

Custom Properties

Name Details
--thumb-size

The size of the thumb.

--tooltip-offset

The vertical distance the tooltip is offset from the track.

--track-color-active

The color of the portion of the track that represents the current value.

--track-color-inactive

The of the portion of the track that represents the remaining value.

--track-height

The height of the track.

--track-active-offset

The point of origin of the active track.

Learn more about customizing CSS custom properties.

CSS Parts

Name Description
form-control The form control that wraps the label, input, and help text.
form-control-label The label’s wrapper.
form-control-input The range’s wrapper.
form-control-help-text The help text’s wrapper.
base The component’s base wrapper.
input The internal <input> element.
tooltip The range’s tooltip.

Learn more about customizing CSS parts.