Slider, horizontal range input.
Props
| Name | Type | Default | Description |
|---|---|---|---|
range | {number(), number()} | required | {min, max} numeric range. |
value | number() | required | Current slider value. |
step | number() | nil | Step increment. |
shift_step | number() | nil | Step increment when Shift is held. |
default | number() | nil | Default value (double-click resets to this). |
width | :fill | :shrink | {:fill_portion, pos_integer()} | number() | nil | Slider width. Default: fill. |
height | number() | nil | Slider track height in pixels. |
circular_handle | boolean() | nil | Use a circular handle. Default: false. |
handle_radius | number() | nil | Circular handle radius in pixels. Only used when circular_handle is true. |
rail_color | String.t() | nil | Color for the slider rail. |
rail_width | number() | nil | Rail thickness in pixels. |
| style | :default \| :primary \| :secondary \| :success \| :danger \| :warning \| :dark \| :weak \| :rounded_box \| term() | nil | Named preset or custom StyleMap. |
| label | String.t() \| atom() | nil | Accessible label for the slider. |
| event_rate | integer() | nil | Max events per second for coalescable events. |
| a11y | %Plushie.Type.A11y{} \| map() \| keyword() | %{role: :slider} | Accessibility annotations. |
Events
| Event | Type | Description |
|---|---|---|
:slide | value: number() | Emitted continuously while dragging. |
:slide_release | value: number() | Emitted when drag ends. |
Constructor
Slider.new(id, range, value)
Slider.new(id, range, value, opts)
Summary
Functions
Accessibility annotations.
Converts this widget struct to a ui_node() map.
Use a circular handle. Default: false.
Default value (double-click resets to this).
Max events per second for coalescable events.
Circular handle radius in pixels. Only used when circular_handle is true.
Slider track height in pixels.
Accessible label for the slider.
Creates a new widget struct with the given positional args and keyword options.
Color for the slider rail.
Rail thickness in pixels.
{min, max} numeric range.
Step increment when Shift is held.
Creates a :slider widget.
Step increment.
Named preset or custom StyleMap.
Current slider value.
Slider width. Default: fill.
Applies keyword options to an existing widget struct.
Types
@type option() :: ((((((((((({:step, number()} | {:shift_step, number()}) | {:default, number()}) | {:width, :fill | :shrink | {:fill_portion, pos_integer()} | number()}) | {:height, number()}) | {:circular_handle, boolean()}) | {:handle_radius, number()}) | {:rail_color, atom() | String.t() | map()}) | {:rail_width, number()}) | {:style, :default | :primary | :secondary | :success | :danger | :warning | :dark | :weak | :rounded_box | term()}) | {:label, String.t() | atom()}) | {:event_rate, integer()}) | {:a11y, %Plushie.Type.A11y{ active_descendant: term(), busy: term(), described_by: term(), description: term(), disabled: term(), error_message: term(), expanded: term(), has_popup: term(), hidden: term(), invalid: term(), label: term(), label_from: term(), labelled_by: term(), level: term(), live: term(), mnemonic: term(), modal: term(), orientation: term(), position_in_set: term(), radio_group: term(), read_only: term(), required: term(), role: term(), selected: term(), size_of_set: term(), toggled: term(), value: term() } | map() | keyword()}
@type t() :: %Plushie.Widget.Slider{ a11y: (%Plushie.Type.A11y{ active_descendant: term(), busy: term(), described_by: term(), description: term(), disabled: term(), error_message: term(), expanded: term(), has_popup: term(), hidden: term(), invalid: term(), label: term(), label_from: term(), labelled_by: term(), level: term(), live: term(), mnemonic: term(), modal: term(), orientation: term(), position_in_set: term(), radio_group: term(), read_only: term(), required: term(), role: term(), selected: term(), size_of_set: term(), toggled: term(), value: term() } | map() | keyword()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, circular_handle: boolean() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, default: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, event_rate: integer() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, handle_radius: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, height: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, id: String.t(), label: (String.t() | atom()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, rail_color: String.t() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, rail_width: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, range: {number(), number()} | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, shift_step: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, step: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, style: (:default | :primary | :secondary | :success | :danger | :warning | :dark | :weak | :rounded_box | term()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, value: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, width: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil }
Functions
@spec a11y( widget :: t(), value :: (%Plushie.Type.A11y{ active_descendant: term(), busy: term(), described_by: term(), description: term(), disabled: term(), error_message: term(), expanded: term(), has_popup: term(), hidden: term(), invalid: term(), label: term(), label_from: term(), labelled_by: term(), level: term(), live: term(), mnemonic: term(), modal: term(), orientation: term(), position_in_set: term(), radio_group: term(), read_only: term(), required: term(), role: term(), selected: term(), size_of_set: term(), toggled: term(), value: term() } | map() | keyword()) | nil ) :: t()
Accessibility annotations.
Accepts %Plushie.Type.A11y{} | map() | keyword().
@spec build(widget :: t()) :: Plushie.Widget.ui_node()
Converts this widget struct to a ui_node() map.
Use a circular handle. Default: false.
Accepts boolean().
Default value (double-click resets to this).
Accepts number().
Max events per second for coalescable events.
Accepts integer().
Circular handle radius in pixels. Only used when circular_handle is true.
Accepts number().
Slider track height in pixels.
Accepts number().
Accessible label for the slider.
Accepts String.t() | atom().
Creates a new widget struct with the given positional args and keyword options.
Arguments
id- unique widget identifierrange-{min, max}numeric range.value- Current slider value.opts- keyword list of optional props
Color for the slider rail.
Accepts String.t().
Rail thickness in pixels.
Accepts number().
{min, max} numeric range.
Accepts {number(), number()}.
Step increment when Shift is held.
Accepts number().
Creates a :slider widget.
Shorthand for new/2. Import this macro to use the widget name
directly in view functions:
import Plushie.Widget.Slider, only: [slider: 2]
slider("my-id", prop: value)
Step increment.
Accepts number().
@spec style( widget :: t(), value :: (:default | :primary | :secondary | :success | :danger | :warning | :dark | :weak | :rounded_box | term()) | nil ) :: t()
Named preset or custom StyleMap.
Accepts :default | :primary | :secondary | :success | :danger | :warning | :dark | :weak | :rounded_box | term().
Current slider value.
Accepts number().
@spec width( widget :: t(), value :: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | nil ) :: t()
Slider width. Default: fill.
Accepts :fill | :shrink | {:fill_portion, pos_integer()} | number().
Applies keyword options to an existing widget struct.