1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
use yew::prelude::*; #[derive(Clone, PartialEq, Properties)] pub struct Props { pub children: ChildrenWithProps<SplitItem>, #[prop_or_default] pub gutter: bool, #[prop_or_default] pub wrap: bool, } #[derive(Clone, PartialEq)] pub struct Split { props: Props, } impl Component for Split { type Message = (); type Properties = Props; fn create(props: Self::Properties, _link: ComponentLink<Self>) -> Self { Self { props } } fn update(&mut self, _msg: Self::Message) -> ShouldRender { true } fn change(&mut self, props: Self::Properties) -> ShouldRender { if self.props != props { self.props = props; true } else { false } } fn view(&self) -> Html { let mut classes = Classes::from("pf-l-split"); if self.props.gutter { classes.push("pf-m-gutter"); } if self.props.wrap { classes.push("pf-m-wrap"); } return html! { <div class=classes> { for self.props.children.iter().map(|child|{ html_nested!{ { child } } }) } </div> }; } } #[derive(Clone, PartialEq, Properties)] pub struct SplitItemProps { #[prop_or_default] pub children: Children, #[prop_or_default] pub fill: bool, } pub struct SplitItem { props: SplitItemProps, } impl Component for SplitItem { type Message = (); type Properties = SplitItemProps; fn create(props: Self::Properties, _link: ComponentLink<Self>) -> Self { Self { props } } fn update(&mut self, _msg: Self::Message) -> ShouldRender { true } fn change(&mut self, props: Self::Properties) -> ShouldRender { if self.props != props { self.props = props; true } else { false } } fn view(&self) -> Html { let mut classes = Classes::from("pf-l-split__item"); if self.props.fill { classes.push("pf-m-fill"); } return html! { <div class=classes> { self.props.children.clone() } </div> }; } }