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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
use std::{cell::RefCell, collections::BTreeMap, rc::Rc};
use dces::prelude::{Component, ComponentBox, Entity, EntityComponentManager, SharedComponentBox};
use crate::{prelude::*, tree::Tree};
use super::State;
pub type WidgetBuildContext = Option<Box<dyn Fn(&mut BuildContext, usize) -> Entity + 'static>>;
#[derive(Constructor)]
pub struct BuildContext<'a> {
ecm: &'a mut EntityComponentManager<Tree, StringComponentStore>,
render_objects: &'a RefCell<BTreeMap<Entity, Box<dyn RenderObject>>>,
layouts: &'a mut BTreeMap<Entity, Box<dyn Layout>>,
handlers: &'a mut EventHandlerMap,
states: &'a mut BTreeMap<Entity, Box<dyn State>>,
theme: &'a ThemeValue,
}
impl<'a> BuildContext<'a> {
pub fn get_widget(&mut self, entity: Entity) -> WidgetContainer<'_> {
WidgetContainer::new(entity, self.ecm, self.theme)
}
pub fn create_entity(&mut self) -> Entity {
self.ecm.create_entity().build()
}
pub fn update_theme_by_state(&mut self, entity: Entity) {
self.get_widget(entity).update_theme_by_state(true);
}
pub fn append_child(&mut self, parent: Entity, child: Entity) {
self.ecm
.entity_store_mut()
.append_child(parent, child)
.unwrap();
}
pub fn append_child_to_overlay(&mut self, child: Entity) -> Result<(), String> {
if let Some(overlay) = self.ecm.entity_store().overlay {
self.append_child(overlay.into(), child);
return Ok(());
}
Err("BuildContext.append_child_to_overlay: Could not find overlay.".to_string())
}
pub fn register_property<P: Component>(&mut self, key: &str, widget: Entity, property: P) {
self.ecm
.component_store_mut()
.register(key, widget, property);
}
pub fn register_property_box(&mut self, key: &str, widget: Entity, property: ComponentBox) {
self.ecm
.component_store_mut()
.register_box(key, widget, property);
}
pub fn register_shared_property<P: Component>(
&mut self,
key: &str,
target: Entity,
source: Entity,
) {
self.register_shared_property_by_source_key::<P>(key, key, target, source);
}
pub fn register_shared_property_by_source_key<P: Component>(
&mut self,
key: &str,
source_key: &str,
target: Entity,
source: Entity,
) {
self.ecm
.component_store_mut()
.register_shared_by_source_key::<P>(key, source_key, target, source);
}
pub fn register_property_shared_box(
&mut self,
key: &str,
widget: Entity,
property: SharedComponentBox,
) {
self.register_property_shared_box_by_source_key(key, key, widget, property);
}
pub fn register_property_shared_box_by_source_key(
&mut self,
key: &str,
source_key: &str,
widget: Entity,
property: SharedComponentBox,
) {
self.ecm
.component_store_mut()
.register_shared_box_by_source_key(key, source_key, widget, property);
}
pub fn register_state(&mut self, widget: Entity, state: Box<dyn State>) {
self.states.insert(widget, state);
}
pub fn register_render_object(&mut self, widget: Entity, render_object: Box<dyn RenderObject>) {
self.render_objects
.borrow_mut()
.insert(widget, render_object);
}
pub fn register_handler(&mut self, widget: Entity, handler: Rc<dyn EventHandler>) {
if !self.handlers.contains_key(&widget) {
self.handlers.insert(widget, vec![]);
}
self.handlers.get_mut(&widget).unwrap().push(handler);
}
pub fn register_layout(&mut self, widget: Entity, layout: Box<dyn Layout>) {
self.layouts.insert(widget, layout);
}
}