yew_bs/components/
position.rs

1use yew::prelude::*;
2#[derive(Clone, Copy, PartialEq, Debug)]
3pub enum PositionVariant {
4    Static,
5    Relative,
6    Absolute,
7    Fixed,
8    Sticky,
9}
10impl PositionVariant {
11    pub fn as_str(&self) -> &'static str {
12        match self {
13            PositionVariant::Static => "position-static",
14            PositionVariant::Relative => "position-relative",
15            PositionVariant::Absolute => "position-absolute",
16            PositionVariant::Fixed => "position-fixed",
17            PositionVariant::Sticky => "position-sticky",
18        }
19    }
20}
21/// Props for the Position component
22#[derive(Properties, PartialEq)]
23pub struct PositionProps {
24    /// Position behavior
25    pub position: PositionVariant,
26    /// The child elements to be wrapped
27    #[prop_or_default]
28    pub children: Children,
29    /// Additional CSS classes to apply
30    #[prop_or_default]
31    pub class: Option<AttrValue>,
32}
33/// A utility component for applying Bootstrap position utilities
34///
35/// The Position component provides easy access to Bootstrap's position
36#[function_component(Position)]
37pub fn position(props: &PositionProps) -> Html {
38    let mut classes = Classes::new();
39    classes.push(props.position.as_str());
40    if let Some(custom_class) = &props.class {
41        classes.push(custom_class.to_string());
42    }
43    html! {
44        < div class = { classes } > { for props.children.iter() } </ div >
45    }
46}