freya_elements::elements

Struct svg

Source
pub struct svg;
Expand description

svg element let’s you display SVG code.

For dynamic SVGs you may use dynamic_bytes.

§Example

static FERRIS: &[u8] = include_bytes!("./ferris.svg");

fn app() -> Element {
    let ferris = static_bytes(FERRIS);
    rsx!(
        svg {
            svg_data: ferris,
            width: "100%", // You must specify size otherwhise it will default to 0
            height: "100%",
        }
    )
}

Implementations§

Source§

impl svg

Source

pub const height: AttributeDescription

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",
        }
    )
}
Source

pub const width: AttributeDescription

Source

pub const min_height: AttributeDescription

§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%",
        }
    )
}
Source

pub const min_width: AttributeDescription

Source

pub const max_height: AttributeDescription

§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",
        }
    )
}
Source

pub const max_width: AttributeDescription

Source

pub const margin: AttributeDescription

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
        }
    )
}
Source

pub const position: AttributeDescription

Specify how you want the element to be positioned inside it’s parent area.

Accepted values:

  • stacked (default)
  • absolute (Floating element relative to the parent element)
  • global (Floating element relative to the window)

When using the absolute or global modes, you can also combine them 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",
            }
        }
    )
}
Source

pub const position_top: AttributeDescription

Source

pub const position_right: AttributeDescription

Source

pub const position_bottom: AttributeDescription

Source

pub const position_left: AttributeDescription

Source

pub const layer: AttributeDescription

Source

pub const rotate: AttributeDescription

The rotate attribute let’s you rotate an element.

Compatible elements: all except text.

§Example
fn app() -> Element {
    rsx!(
        label {
            rotate: "180deg",
            "Hello, World!"
        }
    )
}
Source

pub const opacity: AttributeDescription

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!"
            }
        }
    )
}
Source

pub const color: AttributeDescription

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!"
            }
        }
    )
}
Source

pub const svg_data: AttributeDescription

Source

pub const svg_content: AttributeDescription

Source

pub const fill: AttributeDescription

The fill and stroke attributes allows you to specify the fill or stroke color for the svg.

You can learn about the syntax of this attribute in Color Syntax.

§Example
fn app() -> Element {
    let svg_content = include_str!("../../../examples/settings.svg");

    rsx!(
        svg {
            fill: "red",
            width: "100%",
            height: "100%",
            svg_content,
        }
    )
}
Source

pub const stroke: AttributeDescription

Source

pub const a11y_id: AttributeDescription

Source

pub const a11y_focusable: AttributeDescription

Source

pub const a11y_auto_focus: AttributeDescription

Source

pub const a11y_name: AttributeDescription

Source

pub const a11y_description: AttributeDescription

Source

pub const a11y_value: AttributeDescription

Source

pub const a11y_access_key: AttributeDescription

Source

pub const a11y_author_id: AttributeDescription

Source

pub const a11y_keyboard_shortcut: AttributeDescription

Source

pub const a11y_language: AttributeDescription

Source

pub const a11y_placeholder: AttributeDescription

Source

pub const a11y_role_description: AttributeDescription

Source

pub const a11y_state_description: AttributeDescription

Source

pub const a11y_tooltip: AttributeDescription

Source

pub const a11y_url: AttributeDescription

Source

pub const a11y_row_index_text: AttributeDescription

Source

pub const a11y_column_index_text: AttributeDescription

Source

pub const a11y_scroll_x: AttributeDescription

Source

pub const a11y_scroll_x_min: AttributeDescription

Source

pub const a11y_scroll_x_max: AttributeDescription

Source

pub const a11y_scroll_y: AttributeDescription

Source

pub const a11y_scroll_y_min: AttributeDescription

Source

pub const a11y_scroll_y_max: AttributeDescription

Source

pub const a11y_numeric_value: AttributeDescription

Source

pub const a11y_min_numeric_value: AttributeDescription

Source

pub const a11y_max_numeric_value: AttributeDescription

Source

pub const a11y_numeric_value_step: AttributeDescription

Source

pub const a11y_numeric_value_jump: AttributeDescription

Source

pub const a11y_row_count: AttributeDescription

Source

pub const a11y_column_count: AttributeDescription

Source

pub const a11y_row_index: AttributeDescription

Source

pub const a11y_column_index: AttributeDescription

Source

pub const a11y_row_span: AttributeDescription

Source

pub const a11y_column_span: AttributeDescription

Source

pub const a11y_level: AttributeDescription

Source

pub const a11y_size_of_set: AttributeDescription

Source

pub const a11y_position_in_set: AttributeDescription

Source

pub const a11y_color_value: AttributeDescription

Source

pub const a11y_expanded: AttributeDescription

Source

pub const a11y_selected: AttributeDescription

Source

pub const a11y_hovered: AttributeDescription

Source

pub const a11y_hidden: AttributeDescription

Source

pub const a11y_linked: AttributeDescription

Source

pub const a11y_multiselectable: AttributeDescription

Source

pub const a11y_required: AttributeDescription

Source

pub const a11y_visited: AttributeDescription

Source

pub const a11y_busy: AttributeDescription

Source

pub const a11y_live_atomic: AttributeDescription

Source

pub const a11y_modal: AttributeDescription

Source

pub const a11y_touch_transparent: AttributeDescription

Source

pub const a11y_read_only: AttributeDescription

Source

pub const a11y_disabled: AttributeDescription

Source

pub const a11y_is_spelling_error: AttributeDescription

Source

pub const a11y_is_grammar_error: AttributeDescription

Source

pub const a11y_is_search_match: AttributeDescription

Source

pub const a11y_is_suggestion: AttributeDescription

Source

pub const a11y_role: AttributeDescription

Source

pub const a11y_invalid: AttributeDescription

Source

pub const a11y_toggled: AttributeDescription

Source

pub const a11y_live: AttributeDescription

Source

pub const a11y_default_action_verb: AttributeDescription

Source

pub const a11y_orientation: AttributeDescription

Source

pub const a11y_sort_direction: AttributeDescription

Source

pub const a11y_current: AttributeDescription

Source

pub const a11y_auto_complete: AttributeDescription

Source

pub const a11y_has_popup: AttributeDescription

Source

pub const a11y_list_style: AttributeDescription

Source

pub const a11y_vertical_offset: AttributeDescription

Auto Trait Implementations§

§

impl Freeze for svg

§

impl RefUnwindSafe for svg

§

impl Send for svg

§

impl Sync for svg

§

impl Unpin for svg

§

impl UnwindSafe for svg

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert 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.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, O> SuperFrom<T> for O
where O: From<T>,

Source§

fn super_from(input: T) -> O

Convert from a type to another type.
Source§

impl<T, O, M> SuperInto<O, M> for T
where O: SuperFrom<T, M>,

Source§

fn super_into(self) -> O

Convert from a type to another type.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more