popup.rs 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. //! This example shows how to create a popup window and send data back to the parent window.
  2. //! Currently Dioxus doesn't support nested renderers, hence the need to create popups as separate windows.
  3. use dioxus::prelude::*;
  4. use std::rc::Rc;
  5. fn main() {
  6. dioxus::LaunchBuilder::desktop().launch(app);
  7. }
  8. fn app() -> Element {
  9. let mut emails_sent = use_signal(|| Vec::new() as Vec<String>);
  10. // Wait for responses to the compose channel, and then push them to the emails_sent signal.
  11. let handle = use_coroutine(move |mut rx: UnboundedReceiver<String>| async move {
  12. use futures_util::StreamExt;
  13. while let Some(message) = rx.next().await {
  14. emails_sent.write().push(message);
  15. }
  16. });
  17. let open_compose_window = move |_evt: MouseEvent| {
  18. let tx = handle.tx();
  19. dioxus::desktop::window().new_window(
  20. VirtualDom::new_with_props(popup, Rc::new(move |s| tx.unbounded_send(s).unwrap())),
  21. Default::default(),
  22. );
  23. };
  24. rsx! {
  25. h1 { "This is your email" }
  26. button { onclick: open_compose_window, "Click to compose a new email" }
  27. ul {
  28. for message in emails_sent.read().iter() {
  29. li {
  30. h3 { "email" }
  31. span { "{message}" }
  32. }
  33. }
  34. }
  35. }
  36. }
  37. fn popup(send: Rc<dyn Fn(String)>) -> Element {
  38. let mut user_input = use_signal(String::new);
  39. rsx! {
  40. div {
  41. h1 { "Compose a new email" }
  42. button {
  43. onclick: move |_| {
  44. send(user_input.cloned());
  45. dioxus::desktop::window().close();
  46. },
  47. "Send"
  48. }
  49. input { oninput: move |e| user_input.set(e.value()), value: "{user_input}" }
  50. }
  51. }
  52. }