Row layout, arranges children horizontally.
Props
| Name | Type | Default | Description |
|---|---|---|---|
spacing | number() | nil | Horizontal space between children in pixels. Default: 0. |
padding | number() | {number(), number()} | %Plushie.Type.Padding{} | nil | Padding inside the row. |
width | :fill | :shrink | {:fill_portion, pos_integer()} | number() | nil | Width of the row. Default: shrink. |
height | :fill | :shrink | {:fill_portion, pos_integer()} | number() | nil | Height of the row. Default: shrink. |
max_width | number() | nil | Maximum width in pixels. |
align_y | :left | :center | :right | :top | :bottom | nil | Vertical alignment of children: :top, :center, :bottom. |
clip | boolean() | nil | Clip children that overflow. Default: false. |
wrap | boolean() | nil | Wrap children to next row when they overflow. Default: false. |
event_rate | integer() | nil | Max events per second for coalescable events. |
a11y | %Plushie.Type.A11y{} | map() | keyword() | nil | Accessibility annotations. |
Summary
Functions
Accessibility annotations.
Vertical alignment of children: :top, :center, :bottom.
Converts this widget struct to a ui_node() map.
Clip children that overflow. Default: false.
Max events per second for coalescable events.
Appends multiple children to the widget.
Height of the row. Default: shrink.
Maximum width in pixels.
Creates a new widget struct with the given ID and keyword options.
Padding inside the row.
Appends a child to the widget.
Creates a :row widget.
Horizontal space between children in pixels. Default: 0.
Width of the row. Default: shrink.
Applies keyword options to an existing widget struct.
Wrap children to next row when they overflow. Default: false.
Types
@type option() :: (((((((({:spacing, number()} | {:padding, number() | {number(), number()} | %Plushie.Type.Padding{ bottom: term(), left: term(), right: term(), top: term() }}) | {:width, :fill | :shrink | {:fill_portion, pos_integer()} | number()}) | {:height, :fill | :shrink | {:fill_portion, pos_integer()} | number()}) | {:max_width, number()}) | {:align_y, :left | :center | :right | :top | :bottom}) | {:clip, boolean()}) | {:wrap, boolean()}) | {: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.Row{ 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, align_y: (:left | :center | :right | :top | :bottom) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, children: [Plushie.Widget.ui_node()], clip: boolean() | 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, height: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, id: String.t(), max_width: number() | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, padding: (number() | {number(), number()} | %Plushie.Type.Padding{ bottom: term(), left: term(), right: term(), top: term() }) | Plushie.Animation.Transition.t() | Plushie.Animation.Spring.t() | Plushie.Animation.Sequence.t() | nil, spacing: 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, wrap: boolean() | 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().
Vertical alignment of children: :top, :center, :bottom.
Accepts :left | :center | :right | :top | :bottom.
@spec build(widget :: t()) :: Plushie.Widget.ui_node()
Converts this widget struct to a ui_node() map.
Clip children that overflow. Default: false.
Accepts boolean().
Max events per second for coalescable events.
Accepts integer().
@spec extend(widget :: t(), children :: [Plushie.Widget.child()]) :: t()
Appends multiple children to the widget.
@spec height( widget :: t(), value :: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | nil ) :: t()
Height of the row. Default: shrink.
Accepts :fill | :shrink | {:fill_portion, pos_integer()} | number().
Maximum width in pixels.
Accepts number().
Creates a new widget struct with the given ID and keyword options.
@spec padding( widget :: t(), value :: (number() | {number(), number()} | %Plushie.Type.Padding{ bottom: term(), left: term(), right: term(), top: term() }) | nil ) :: t()
Padding inside the row.
Accepts number() | {number(), number()} | %Plushie.Type.Padding{}.
@spec push(widget :: t(), child :: Plushie.Widget.child()) :: t()
Appends a child to the widget.
Creates a :row widget.
Shorthand for new/2. Import this macro to use the widget name
directly in view functions:
import Plushie.Widget.Row, only: [row: 2]
row("my-id", prop: value)
Horizontal space between children in pixels. Default: 0.
Accepts number().
@spec width( widget :: t(), value :: (:fill | :shrink | {:fill_portion, pos_integer()} | number()) | nil ) :: t()
Width of the row. Default: shrink.
Accepts :fill | :shrink | {:fill_portion, pos_integer()} | number().
Applies keyword options to an existing widget struct.
Wrap children to next row when they overflow. Default: false.
Accepts boolean().