pub struct paragraph;
Expand description
paragraph
element let’s you build texts with different styles.
This used used with the text
element.
fn app() -> Element {
rsx!(
paragraph {
text {
font_size: "15",
"Hello, "
}
text {
font_size: "30",
"World!"
}
}
)
}
Implementations§
§impl paragraph
impl paragraph
pub const height: (&'static str, Option<&'static str>, bool) = _
pub const height: (&'static str, Option<&'static str>, bool) = _
Specify the width and height for the given element.
See syntax in Size Units
.
§Example
fn app() -> Element {
rsx!(
rect {
background: "red",
width: "15",
height: "50",
}
)
}
pub const width: (&'static str, Option<&'static str>, bool) = _
pub const min_height: (&'static str, Option<&'static str>, bool) = _
pub const min_height: (&'static str, Option<&'static str>, bool) = _
§min_width & min_height
rect
supports specifying a minimum width and height, this can be useful if you use it alongside a percentage for the target size.
See syntax for Size Units
.
§Usage
fn app() -> Element {
rsx!(
rect {
background: "red",
min_width: "100",
min_height: "100",
width: "50%",
height: "50%",
}
)
}
pub const min_width: (&'static str, Option<&'static str>, bool) = _
pub const max_height: (&'static str, Option<&'static str>, bool) = _
pub const max_height: (&'static str, Option<&'static str>, bool) = _
§max_width & max_height
rect
supports specifying a maximum width and height.
See syntax for Size Units
.
§Usage
fn app() -> Element {
rsx!(
rect {
background: "red",
max_width: "50%",
max_height: "50%",
width: "500",
height: "500",
}
)
}
pub const max_width: (&'static str, Option<&'static str>, bool) = _
pub const margin: (&'static str, Option<&'static str>, bool) = _
pub const margin: (&'static str, Option<&'static str>, bool) = _
Specify the margin of an element. You can do so by four different ways, just like in CSS.
§Example
fn app() -> Element {
rsx!(
rect {
margin: "25", // 25 in all sides
margin: "100 50", // 100 in top and bottom, and 50 in left and right
margin: "2 15 25", // 2 in top, 15 in left and right, and 25 in bottom
margin: "5 7 3 9" // 5 in top, 7 in right, 3 in bottom and 9 in left
}
)
}
pub const position: (&'static str, Option<&'static str>, bool) = _
pub const position: (&'static str, Option<&'static str>, bool) = _
Specify how you want the element to be positioned inside it’s parent area.
Accepted values:
stacked
(default)absolute
When using the absolute
mode, you can also combine it with the following attributes:
position_top
position_right
position_bottom
position_left
These only support pixels.
§Example
fn app() -> Element {
rsx!(
rect {
width: "100%",
height: "100%",
rect {
position: "absolute",
position_bottom: "15",
position_right: "15",
background: "black",
width: "100",
height: "100",
}
}
)
}
pub const position_top: (&'static str, Option<&'static str>, bool) = _
pub const position_right: (&'static str, Option<&'static str>, bool) = _
pub const position_bottom: (&'static str, Option<&'static str>, bool) = _
pub const position_left: (&'static str, Option<&'static str>, bool) = _
pub const layer: (&'static str, Option<&'static str>, bool) = _
pub const main_align: (&'static str, Option<&'static str>, bool) = _
pub const main_align: (&'static str, Option<&'static str>, bool) = _
§main_align & cross_align
Control how the inner elements are positioned inside the element. You can combine it with the direction
attribute to create complex flows.
Accepted values for main_align
:
start
(default): At the begining of the axiscenter
: At the center of the axisend
: At the end of the axisspace-between
(only formain_align
): Distributed among the available spacespace-around
(only formain_align
): Distributed among the available space with small margins in the sidesspace-evenly
(only formain_align
): Distributed among the available space with the same size of margins in the sides and in between the elements.
Accepted values for cross_align
:
start
(default): At the begining of the axis (same as inmain_align
)center
: At the center of the axis (same as inmain_align
)end
: At the end of the axis (same as inmain_align
)
When using the vertical
direction, main_align
will be the Y axis and cross_align
will be the X axis. But when using the horizontal
direction, the
main_align
will be the X axis and the cross_align
will be the Y axis.
Example on how to center the inner elements in both axis:
fn app() -> Element {
rsx!(
rect {
width: "100%",
height: "100%",
main_align: "center",
cross_align: "center",
rect {
width: "50%",
height: "50%",
background: "red"
},
}
)
}
pub const color: (&'static str, Option<&'static str>, bool) = _
pub const color: (&'static str, Option<&'static str>, bool) = _
The color
attribute lets you specify the color of the text.
You can learn about the syntax of this attribute in Color Syntax
.
§Example
fn app() -> Element {
rsx!(
label {
color: "green",
"Hello, World!"
}
)
}
Another example showing inheritance:
fn app() -> Element {
rsx!(
rect {
color: "blue",
label {
"Hello, World!"
}
}
)
}
pub const font_size: (&'static str, Option<&'static str>, bool) = _
pub const font_size: (&'static str, Option<&'static str>, bool) = _
You can specify the size of the text using font_size
.
§Example
fn app() -> Element {
rsx!(
label {
font_size: "50",
"Hellooooo!"
}
)
}
pub const font_family: (&'static str, Option<&'static str>, bool) = _
pub const font_family: (&'static str, Option<&'static str>, bool) = _
With the font_family
you can specify what font you want to use for the inner text.
Check out the custom font example to see how you can load your own fonts.
§Example
fn app() -> Element {
rsx!(
label {
font_family: "Inter",
"Hello, World!"
}
)
}
pub const font_style: (&'static str, Option<&'static str>, bool) = _
pub const font_style: (&'static str, Option<&'static str>, bool) = _
You can choose a style for a text using the font_style
attribute.
Accepted values:
upright
(default)italic
oblique
§Example
fn app() -> Element {
rsx!(
label {
font_style: "italic",
"Hello, italic World!"
}
)
}
You can also specify multiple fonts in order of priority, if one is not found it will fallback to the next one.
Example:
fn app() -> Element {
rsx!(
label {
font_family: "DoesntExist Font, Impact",
"Hello, World!"
}
)
}
pub const font_weight: (&'static str, Option<&'static str>, bool) = _
pub const font_weight: (&'static str, Option<&'static str>, bool) = _
You can choose a weight for text using the font_weight
attribute.
Accepted values:
invisible
thin
extra-light
light
normal
(default)medium
semi-bold
bold
extra-bold
black
extra-black
50
100
200
300
400
500
600
700
800
900
950
§Example
fn app() -> Element {
rsx!(
label {
font_weight: "bold",
"Hello, bold World!"
}
)
}
pub const font_width: (&'static str, Option<&'static str>, bool) = _
pub const font_width: (&'static str, Option<&'static str>, bool) = _
You can choose a width for a text using the font_width
attribute.
⚠️ Only fonts with variable widths will be affected.
Accepted values:
ultra-condensed
extra-condensed
condensed
normal
(default)semi-expanded
expanded
extra-expanded
ultra-expanded
§Example
fn app() -> Element {
rsx!(
label {
font_width: "ultra-expanded",
"Hello, wide World!"
}
)
}
pub const text_align: (&'static str, Option<&'static str>, bool) = _
pub const text_align: (&'static str, Option<&'static str>, bool) = _
You can change the alignment of the text using the text_align
attribute.
Accepted values:
center
end
justify
left
(default)right
start
§Example
fn app() -> Element {
rsx!(
label {
text_align: "right",
"Hello, World!"
}
)
}
pub const line_height: (&'static str, Option<&'static str>, bool) = _
pub const line_height: (&'static str, Option<&'static str>, bool) = _
pub const text_shadow: (&'static str, Option<&'static str>, bool) = _
pub const text_shadow: (&'static str, Option<&'static str>, bool) = _
Specify the shadow of a text.
Syntax: <x> <y> <size> <color>
§Example
fn app() -> Element {
rsx!(
label {
text_shadow: "0 18 12 rgb(0, 0, 0)",
"Hello, World!"
}
)
}
pub const max_lines: (&'static str, Option<&'static str>, bool) = _
pub const max_lines: (&'static str, Option<&'static str>, bool) = _
Determines the amount of lines that the text can have. It has unlimited lines by default.
§Example
fn app() -> Element {
rsx!(
label {
"Hello, World! \n Hello, World! \n Hello, world!" // Will show all three lines
}
label {
max_lines: "2",
"Hello, World! \n Hello, World! \n Hello, world!" // Will only show two lines
}
)
}
pub const decoration: (&'static str, Option<&'static str>, bool) = _
pub const decoration: (&'static str, Option<&'static str>, bool) = _
Specify the decoration in a text.
Accepted values:
underline
line-through
overline
§Example
fn app() -> Element {
rsx!(
label {
decoration: "line-through",
"Hello, World!"
}
)
}
pub const decoration_style: (&'static str, Option<&'static str>, bool) = _
pub const decoration_style: (&'static str, Option<&'static str>, bool) = _
Specify the decoration’s style in a text.
Accepted values:
solid
(default)double
dotted
dashed
wavy
§Example
fn app() -> Element {
rsx!(
label {
decoration: "line-through",
decoration_style: "dotted",
"Hello, World!"
}
)
}
pub const decoration_color: (&'static str, Option<&'static str>, bool) = _
pub const decoration_color: (&'static str, Option<&'static str>, bool) = _
Specify the decoration’s color in a text.
You can learn about the syntax of this attribute in Color Syntax
.
§Example
fn app() -> Element {
rsx!(
label {
decoration: "line-through",
decoration_color: "orange",
"Hello, World!"
}
)
}
pub const text_overflow: (&'static str, Option<&'static str>, bool) = _
pub const text_overflow: (&'static str, Option<&'static str>, bool) = _
Determines how text is treated when it exceeds its max_lines
count. By default uses the clip
mode, which will cut off any overflowing text, with ellipsis
mode it will show ...
at the end.
Accepted values:
clip
(default)ellipsis
§Example
fn app() -> Element {
rsx!(
label {
max_lines: "3",
text_overflow: "ellipsis",
"Looooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooong text"
}
)
}
pub const letter_spacing: (&'static str, Option<&'static str>, bool) = _
pub const letter_spacing: (&'static str, Option<&'static str>, bool) = _
Specify the spacing between characters of the text.
§Example
fn app() -> Element {
rsx!(
label {
letter_spacing: "10",
"Hello, World!"
}
)
}
pub const word_spacing: (&'static str, Option<&'static str>, bool) = _
pub const word_spacing: (&'static str, Option<&'static str>, bool) = _
Specify the spacing between words of the text.
§Example
fn app() -> Element {
rsx!(
label {
word_spacing: "10",
"Hello, World!"
}
)
}
pub const text_height: (&'static str, Option<&'static str>, bool) = _
pub const text_height: (&'static str, Option<&'static str>, bool) = _
Specify the text height behavior.
Accepted values:
disable-all
(default)all
disable-first-ascent
disable-least-ascent
§Example
fn app() -> Element {
rsx!(
label {
text_height: "disable-all",
"Hello, World!"
}
)
}
pub const opacity: (&'static str, Option<&'static str>, bool) = _
pub const opacity: (&'static str, Option<&'static str>, bool) = _
Specify the opacity of an element and all its descendants.
§Example
fn app() -> Element {
rsx!(
rect {
opacity: "0.5", // 50% visible
label {
"I am fading!"
}
}
)
}
pub const cursor_index: (&'static str, Option<&'static str>, bool) = _
pub const cursor_color: (&'static str, Option<&'static str>, bool) = _
pub const cursor_mode: (&'static str, Option<&'static str>, bool) = _
pub const cursor_id: (&'static str, Option<&'static str>, bool) = _
pub const highlights: (&'static str, Option<&'static str>, bool) = _
pub const highlight_color: (&'static str, Option<&'static str>, bool) = _
pub const highlight_mode: (&'static str, Option<&'static str>, bool) = _
pub const a11y_id: (&'static str, Option<&'static str>, bool) = _
pub const a11y_focusable: (&'static str, Option<&'static str>, bool) = _
pub const a11y_auto_focus: (&'static str, Option<&'static str>, bool) = _
pub const a11y_name: (&'static str, Option<&'static str>, bool) = _
pub const a11y_description: (&'static str, Option<&'static str>, bool) = _
pub const a11y_value: (&'static str, Option<&'static str>, bool) = _
pub const a11y_access_key: (&'static str, Option<&'static str>, bool) = _
pub const a11y_keyboard_shortcut: (&'static str, Option<&'static str>, bool) = _
pub const a11y_language: (&'static str, Option<&'static str>, bool) = _
pub const a11y_placeholder: (&'static str, Option<&'static str>, bool) = _
pub const a11y_role_description: (&'static str, Option<&'static str>, bool) = _
pub const a11y_state_description: (&'static str, Option<&'static str>, bool) = _
pub const a11y_tooltip: (&'static str, Option<&'static str>, bool) = _
pub const a11y_url: (&'static str, Option<&'static str>, bool) = _
pub const a11y_row_index_text: (&'static str, Option<&'static str>, bool) = _
pub const a11y_column_index_text: (&'static str, Option<&'static str>, bool) = _
pub const a11y_scroll_x: (&'static str, Option<&'static str>, bool) = _
pub const a11y_scroll_x_min: (&'static str, Option<&'static str>, bool) = _
pub const a11y_scroll_x_max: (&'static str, Option<&'static str>, bool) = _
pub const a11y_scroll_y: (&'static str, Option<&'static str>, bool) = _
pub const a11y_scroll_y_min: (&'static str, Option<&'static str>, bool) = _
pub const a11y_scroll_y_max: (&'static str, Option<&'static str>, bool) = _
pub const a11y_numeric_value: (&'static str, Option<&'static str>, bool) = _
pub const a11y_min_numeric_value: (&'static str, Option<&'static str>, bool) = _
pub const a11y_max_numeric_value: (&'static str, Option<&'static str>, bool) = _
pub const a11y_numeric_value_step: (&'static str, Option<&'static str>, bool) = _
pub const a11y_numeric_value_jump: (&'static str, Option<&'static str>, bool) = _
pub const a11y_row_count: (&'static str, Option<&'static str>, bool) = _
pub const a11y_column_count: (&'static str, Option<&'static str>, bool) = _
pub const a11y_row_index: (&'static str, Option<&'static str>, bool) = _
pub const a11y_column_index: (&'static str, Option<&'static str>, bool) = _
pub const a11y_row_span: (&'static str, Option<&'static str>, bool) = _
pub const a11y_column_span: (&'static str, Option<&'static str>, bool) = _
pub const a11y_level: (&'static str, Option<&'static str>, bool) = _
pub const a11y_size_of_set: (&'static str, Option<&'static str>, bool) = _
pub const a11y_position_in_set: (&'static str, Option<&'static str>, bool) = _
pub const a11y_color_value: (&'static str, Option<&'static str>, bool) = _
pub const a11y_expanded: (&'static str, Option<&'static str>, bool) = _
pub const a11y_selected: (&'static str, Option<&'static str>, bool) = _
pub const a11y_hovered: (&'static str, Option<&'static str>, bool) = _
pub const a11y_linked: (&'static str, Option<&'static str>, bool) = _
pub const a11y_multiselectable: (&'static str, Option<&'static str>, bool) = _
pub const a11y_required: (&'static str, Option<&'static str>, bool) = _
pub const a11y_visited: (&'static str, Option<&'static str>, bool) = _
pub const a11y_busy: (&'static str, Option<&'static str>, bool) = _
pub const a11y_live_atomic: (&'static str, Option<&'static str>, bool) = _
pub const a11y_modal: (&'static str, Option<&'static str>, bool) = _
pub const a11y_touch_transparent: (&'static str, Option<&'static str>, bool) = _
pub const a11y_read_only: (&'static str, Option<&'static str>, bool) = _
pub const a11y_disabled: (&'static str, Option<&'static str>, bool) = _
pub const a11y_is_spelling_error: (&'static str, Option<&'static str>, bool) = _
pub const a11y_is_grammar_error: (&'static str, Option<&'static str>, bool) = _
pub const a11y_is_search_match: (&'static str, Option<&'static str>, bool) = _
pub const a11y_is_suggestion: (&'static str, Option<&'static str>, bool) = _
pub const a11y_role: (&'static str, Option<&'static str>, bool) = _
pub const a11y_invalid: (&'static str, Option<&'static str>, bool) = _
pub const a11y_toggled: (&'static str, Option<&'static str>, bool) = _
pub const a11y_live: (&'static str, Option<&'static str>, bool) = _
pub const a11y_default_action_verb: (&'static str, Option<&'static str>, bool) = _
pub const a11y_orientation: (&'static str, Option<&'static str>, bool) = _
pub const a11y_sort_direction: (&'static str, Option<&'static str>, bool) = _
pub const a11y_current: (&'static str, Option<&'static str>, bool) = _
pub const a11y_auto_complete: (&'static str, Option<&'static str>, bool) = _
pub const a11y_has_popup: (&'static str, Option<&'static str>, bool) = _
pub const a11y_list_style: (&'static str, Option<&'static str>, bool) = _
pub const a11y_vertical_offset: (&'static str, Option<&'static str>, bool) = _
Auto Trait Implementations§
impl Freeze for paragraph
impl RefUnwindSafe for paragraph
impl Send for paragraph
impl Sync for paragraph
impl Unpin for paragraph
impl UnwindSafe for paragraph
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> InitializeFromFunction<T> for T
impl<T> InitializeFromFunction<T> for T
§fn initialize_from_function(f: fn() -> T) -> T
fn initialize_from_function(f: fn() -> T) -> T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more