diff options
| author | 2019-09-24 15:39:33 +0200 | |
|---|---|---|
| committer | 2019-09-24 15:39:33 +0200 | |
| commit | 68c4752e998dca1d618380ce4e7d8ac52b710056 (patch) | |
| tree | 35e386030b072c189509bb2ed3adeaec5b0fd4d1 /web/src/widget/button.rs | |
| parent | bb5cac49d028eb53c259ae58e3a007ebfb736fd4 (diff) | |
| parent | 05c7c39ecb8910c75b82dc4052a7720fb2d42b4a (diff) | |
| download | iced-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/widget/button.rs')
| -rw-r--r-- | web/src/widget/button.rs | 45 | 
1 files changed, 45 insertions, 0 deletions
| diff --git a/web/src/widget/button.rs b/web/src/widget/button.rs new file mode 100644 index 00000000..23a4165a --- /dev/null +++ b/web/src/widget/button.rs @@ -0,0 +1,45 @@ +use crate::{Bus, Element, Widget}; + +use dodrio::bumpalo; + +pub use iced_core::button::*; + +impl<'a, Message> Widget<Message> for Button<'a, Message> +where +    Message: 'static + Copy, +{ +    fn node<'b>( +        &self, +        bump: &'b bumpalo::Bump, +        bus: &Bus<Message>, +    ) -> dodrio::Node<'b> { +        use dodrio::builder::*; + +        let label = bumpalo::format!(in bump, "{}", self.label); + +        let mut node = button(bump).children(vec![text(label.into_bump_str())]); + +        if let Some(on_press) = self.on_press { +            let event_bus = bus.clone(); + +            node = node.on("click", move |root, vdom, _event| { +                event_bus.publish(on_press, root); + +                vdom.schedule_render(); +            }); +        } + +        // TODO: Complete styling + +        node.finish() +    } +} + +impl<'a, Message> From<Button<'a, Message>> for Element<'a, Message> +where +    Message: 'static + Copy, +{ +    fn from(button: Button<'a, Message>) -> Element<'a, Message> { +        Element::new(button) +    } +} | 
