createSlider

function

createSlider(props?): SliderWidget

Create a Slider with given config props

Parameters
props?

PropsConfig<SliderProps>

Returns

SliderWidget

a SliderWidget


getSliderDefaultConfig

function

getSliderDefaultConfig(): SliderProps

Retrieve a shallow copy of the default Slider config

Returns

SliderProps

the default Slider config


HandleDisplayOptions

interface

Options for displaying a handle in a slider component.

Properties
left

left: null | number

Left offset of the handle in %


top

top: null | number

Top offset of the handle in %


ProgressDisplayOptions

interface

Options for displaying progress in a slider component.

Properties
bottom

bottom: null | number

Bottom offset of the progress in %


height

height: number

Height of the progress in %


id

id: number

Id of the progress


left

left: null | number

Right offset of the progress in %


right

right: null | number

Left offset of the progress in %


top

top: null | number

Top offset of the progress in %


width

width: number

Width of the progress in %


SliderContext

interface

Represents the context for a Slider component. This type is an alias for WidgetSlotContext<SliderWidget>.

Extended by
Properties
api

api: object

all the api functions to interact with the widget


directives

directives: SliderDirectives

directives to be used on html elements in the template of the widget or in the slots


state

state: SliderState

the state of the widget


SliderDirectives

interface

Interface representing various directives used in the slider component.

Properties
clickableAreaDirective

clickableAreaDirective: Directive

Directive to apply to the slider clickable area, to directly move the handle to a given specific position


combinedHandleLabelDisplayDirective

combinedHandleLabelDisplayDirective: Directive

Directive to apply to the handle when combined label display is active


handleDirective

handleDirective: Directive<{ item: SliderHandle; }>

Directive to apply to the slider handle if any


handleEventsDirective

handleEventsDirective: Directive<{ item: { id: number; }; }>

Directive to apply handle events handlers


handleLabelDisplayDirective

handleLabelDisplayDirective: Directive<{ index: number; }>

Directive to apply to the handle when combined label display is not active


maxLabelDirective

maxLabelDirective: Directive

Directive to get the maxLabel elementRef


minLabelDirective

minLabelDirective: Directive

Directive to get the minLabel elementRef


progressDisplayDirective

progressDisplayDirective: Directive<{ option: ProgressDisplayOptions; }>

Directive used to style the progress display for each handle


sliderDirective

sliderDirective: Directive

Directive to get the slider component elementRef


SliderHandle

interface

Represents a handle in a slider component.

Properties
ariaLabel

ariaLabel: undefined | string

ariaLabel of the handle


ariaLabelledBy

ariaLabelledBy: undefined | string

aria-labelledBy of the handle


ariaValueText

ariaValueText: undefined | string

ariaValueText of the handle


id

id: number

Handle id


value

value: number

Value of the handle


SliderProps

interface

Represents the properties for the Slider component.

Properties
ariaLabel

ariaLabel: (sortedIndex) => string

Return the value for the 'aria-label' attribute for the handle

Parameters
sortedIndex

number

index of the handle in the sorted list

Returns

string

Default Value
() => 'Value'

ariaLabelledBy

ariaLabelledBy: (sortedIndex) => string

Return the value for the 'aria-labelledBy' attribute for the handle

Parameters
sortedIndex

number

index of the handle in the sorted list

Returns

string

Default Value
() => ''

ariaValueText

ariaValueText: (value, sortedIndex) => string

Return the value for the 'aria-valuetext' attribute for the handle

Parameters
value

number

value of the handle

sortedIndex

number

index of the handle in the sorted list

Returns

string

Default Value
(value: number) => ''

className

className: string

CSS classes to be applied on the widget main container

Default Value

''


disabled

disabled: boolean

If true slider value cannot be changed and the slider cannot be focused

Default Value

false


handle

handle: SlotContent<SliderSlotHandleContext>

Slot to change the handlers


label

label: SlotContent<SliderSlotLabelContext>

Slot to change the default labels of the slider

Default Value
({value}: SliderSlotLabelContext) => '' + value

max

max: number

Maximum value that can be assigned to the slider

Default Value

100


min

min: number

Minimum value that can be assigned to the slider

Default Value

0


onValuesChange

onValuesChange: (values) => void

An event emitted when slider values are changed

Event payload equals to the updated slider values

Parameters
values

number[]

Returns

void

Default Value
() => {}

readonly

readonly: boolean

If true slider value cannot be changed but the slider is still focusable

Default Value

false


rtl

rtl: boolean

It true slider display is inversed

Default Value

false


showMinMaxLabels

showMinMaxLabels: boolean

If true the min and max labels are displayed on the slider

Default Value

true


showValueLabels

showValueLabels: boolean

If true the value labels are displayed on the slider

Default Value

true


stepSize

stepSize: number

Unit value between slider steps

Default Value

1


structure

structure: SlotContent<SliderContext>

Slot to change the default display of the slider


values

values: number[]

Current slider values

Default Value

[0]


vertical

vertical: boolean

If true is vertically positioned otherwise it is horizontal

Default Value

false


SliderSlotHandleContext

interface

Represents the context for a slider slot handle. This type extends the SliderContext and includes an additional item property of type SliderHandle.

Properties
api

api: object

all the api functions to interact with the widget


directives

directives: SliderDirectives

directives to be used on html elements in the template of the widget or in the slots


item

item: SliderHandle

the handle context


state

state: SliderState

the state of the widget


SliderSlotLabelContext

interface

Represents the context for a slider slot label, extending the base SliderContext with an additional value property.

Properties
api

api: object

all the api functions to interact with the widget


directives

directives: SliderDirectives

directives to be used on html elements in the template of the widget or in the slots


state

state: SliderState

the state of the widget


value

value: number

the value of the handle the label is attached to


SliderState

interface

Represents the state of a slider component.

Properties
className

className: string

CSS classes to be applied on the widget main container

Default Value

''


combinedLabelDisplay

combinedLabelDisplay: boolean

If true, the label when the handles are close is visible


combinedLabelPositionLeft

combinedLabelPositionLeft: number

Combined label left offset in %


combinedLabelPositionTop

combinedLabelPositionTop: number

Combined label top offset in %


disabled

disabled: boolean

If true slider value cannot be changed and the slider cannot be focused

Default Value

false


handle

handle: SlotContent<SliderSlotHandleContext>

Slot to change the handlers


handleDisplayOptions

handleDisplayOptions: HandleDisplayOptions[]

Array of objects representing handle display options


interactive

interactive: boolean

Check if the slider is interactive, meaning it is not disabled or readonly


label

label: SlotContent<SliderSlotLabelContext>

Slot to change the default labels of the slider

Default Value
({value}: SliderSlotLabelContext) => '' + value

max

max: number

Maximum value that can be assigned to the slider

Default Value

100


maxValueLabelDisplay

maxValueLabelDisplay: boolean

If true, the maximum label will be visible


min

min: number

Minimum value that can be assigned to the slider

Default Value

0


minValueLabelDisplay

minValueLabelDisplay: boolean

If true, the minimum label will be visible


progressDisplayOptions

progressDisplayOptions: ProgressDisplayOptions[]

Array of objects representing progress display options


readonly

readonly: boolean

If true slider value cannot be changed but the slider is still focusable

Default Value

false


rtl

rtl: boolean

It true slider display is inversed

Default Value

false


showMinMaxLabels

showMinMaxLabels: boolean

If true the min and max labels are displayed on the slider

Default Value

true


showValueLabels

showValueLabels: boolean

If true the value labels are displayed on the slider

Default Value

true


sortedHandles

sortedHandles: SliderHandle[]

Array of the sorted handles to display


sortedValues

sortedValues: number[]

Sorted slider values


stepSize

stepSize: number

Unit value between slider steps

Default Value

1


structure

structure: SlotContent<SliderContext>

Slot to change the default display of the slider


values

values: number[]

Current slider values

Default Value

[0]


vertical

vertical: boolean

If true is vertically positioned otherwise it is horizontal

Default Value

false


SliderWidget

type alias

SliderWidget: Widget<SliderProps, SliderState, object, SliderDirectives>

Represents a slider widget component.