raui_core/widget/component/containers/
flex_box.rs1use crate::{
2 PropsData, Scalar, make_widget, pre_hooks,
3 widget::{
4 component::interactive::navigation::{
5 NavContainerActive, NavItemActive, NavJumpActive, use_nav_container_active,
6 use_nav_item, use_nav_jump,
7 },
8 context::WidgetContext,
9 node::WidgetNode,
10 unit::flex::{FlexBoxDirection, FlexBoxItemLayout, FlexBoxItemNode, FlexBoxNode},
11 utils::Transform,
12 },
13};
14use serde::{Deserialize, Serialize};
15
16#[derive(PropsData, Debug, Default, Clone, Serialize, Deserialize)]
17#[props_data(crate::props::PropsData)]
18#[prefab(crate::Prefab)]
19pub struct FlexBoxProps {
20 #[serde(default)]
21 pub direction: FlexBoxDirection,
22 #[serde(default)]
23 pub separation: Scalar,
24 #[serde(default)]
25 pub wrap: bool,
26 #[serde(default)]
27 pub transform: Transform,
28}
29
30#[pre_hooks(use_nav_container_active, use_nav_jump, use_nav_item)]
31pub fn nav_flex_box(mut context: WidgetContext) -> WidgetNode {
32 let WidgetContext {
33 key,
34 props,
35 listed_slots,
36 ..
37 } = context;
38
39 let props = props
40 .clone()
41 .without::<NavContainerActive>()
42 .without::<NavJumpActive>()
43 .without::<NavItemActive>();
44
45 make_widget!(flex_box)
46 .key(key)
47 .merge_props(props)
48 .listed_slots(listed_slots)
49 .into()
50}
51
52pub fn flex_box(context: WidgetContext) -> WidgetNode {
53 let WidgetContext {
54 id,
55 props,
56 listed_slots,
57 ..
58 } = context;
59
60 let FlexBoxProps {
61 direction,
62 separation,
63 wrap,
64 transform,
65 } = props.read_cloned_or_default();
66
67 let items = listed_slots
68 .into_iter()
69 .filter_map(|slot| {
70 if let Some(props) = slot.props() {
71 let layout = props.read_cloned_or_default::<FlexBoxItemLayout>();
72 Some(FlexBoxItemNode { slot, layout })
73 } else {
74 None
75 }
76 })
77 .collect::<Vec<_>>();
78
79 FlexBoxNode {
80 id: id.to_owned(),
81 props: props.clone(),
82 items,
83 direction,
84 separation,
85 wrap,
86 transform,
87 }
88 .into()
89}