1
0

compose.rs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. //! This example shows how to create a popup window and send data back to the parent window.
  2. use dioxus::prelude::*;
  3. use futures_util::StreamExt;
  4. use tokio::sync::mpsc::UnboundedSender;
  5. fn main() {
  6. dioxus_desktop::launch(app);
  7. }
  8. fn app() -> Element {
  9. let 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 tx = use_coroutine(|mut rx: UnboundedReceiver<String>| async move {
  12. while let Some(message) = rx.next().await {
  13. emails_sent.write().push(message);
  14. }
  15. });
  16. let open_compose_window = move |evt: MouseEvent| {
  17. dioxus_desktop::window().new_window(
  18. VirtualDom::new_with_props(compose, tx.clone()),
  19. Default::default(),
  20. )
  21. };
  22. rsx! {
  23. h1 { "This is your email" }
  24. button { onclick: open_compose_window, "Click to compose a new email" }
  25. ul {
  26. for message in emails_sent.read().iter() {
  27. li {
  28. h3 { "email" }
  29. span { "{message}" }
  30. }
  31. }
  32. }
  33. }
  34. }
  35. fn compose(receiver: UnboundedSender<String>) -> Element {
  36. let user_input = use_signal(String::new);
  37. rsx! {
  38. div {
  39. h1 { "Compose a new email" }
  40. button {
  41. onclick: move |_| {
  42. cx.props.app_tx.send(user_input.get().clone());
  43. dioxus_desktop::window().close();
  44. },
  45. "Click to send"
  46. }
  47. input { oninput: move |e| user_input.set(e.value()), value: "{user_input}" }
  48. }
  49. }
  50. }