summaryrefslogtreecommitdiffstats
path: root/web/src/bus.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2019-09-24 15:39:33 +0200
committerLibravatar GitHub <noreply@github.com>2019-09-24 15:39:33 +0200
commit68c4752e998dca1d618380ce4e7d8ac52b710056 (patch)
tree35e386030b072c189509bb2ed3adeaec5b0fd4d1 /web/src/bus.rs
parentbb5cac49d028eb53c259ae58e3a007ebfb736fd4 (diff)
parent05c7c39ecb8910c75b82dc4052a7720fb2d42b4a (diff)
downloadiced-68c4752e998dca1d618380ce4e7d8ac52b710056.tar.gz
iced-68c4752e998dca1d618380ce4e7d8ac52b710056.tar.bz2
iced-68c4752e998dca1d618380ce4e7d8ac52b710056.zip
Merge pull request #17 from hecrj/web
Basic web support (core, native, and web crates)
Diffstat (limited to 'web/src/bus.rs')
-rw-r--r--web/src/bus.rs40
1 files changed, 40 insertions, 0 deletions
diff --git a/web/src/bus.rs b/web/src/bus.rs
new file mode 100644
index 00000000..d76466f5
--- /dev/null
+++ b/web/src/bus.rs
@@ -0,0 +1,40 @@
+use crate::Application;
+
+use std::rc::Rc;
+
+#[derive(Clone)]
+pub struct Bus<Message> {
+ publish: Rc<Box<dyn Fn(Message, &mut dyn dodrio::RootRender)>>,
+}
+
+impl<Message> Bus<Message>
+where
+ Message: 'static,
+{
+ pub fn new() -> Self {
+ Self {
+ publish: Rc::new(Box::new(|message, root| {
+ let app = root.unwrap_mut::<Application<Message>>();
+
+ app.update(message)
+ })),
+ }
+ }
+
+ pub fn publish(&self, message: Message, root: &mut dyn dodrio::RootRender) {
+ (self.publish)(message, root);
+ }
+
+ pub fn map<B>(&self, mapper: Rc<Box<dyn Fn(B) -> Message>>) -> Bus<B>
+ where
+ B: 'static,
+ {
+ let publish = self.publish.clone();
+
+ Bus {
+ publish: Rc::new(Box::new(move |message, root| {
+ publish(mapper(message), root)
+ })),
+ }
+ }
+}