mirror of
https://github.com/DioxusLabs/dioxus
synced 2025-01-20 00:33:58 +00:00
49 lines
1.7 KiB
Rust
49 lines
1.7 KiB
Rust
use dioxus::prelude::*;
|
|
use std::time::Duration;
|
|
|
|
fn main() {
|
|
dioxus_desktop::launch(app);
|
|
}
|
|
|
|
fn app(cx: Scope) -> Element {
|
|
let running = dioxus_signals::use_signal(cx, || true);
|
|
let mut count = dioxus_signals::use_signal(cx, || 0);
|
|
let saved_values = dioxus_signals::use_signal(cx, || vec![0.to_string()]);
|
|
|
|
// Signals can be used in async functions without an explicit clone since they're 'static and Copy
|
|
// Signals are backed by a runtime that is designed to deeply integrate with Dioxus apps
|
|
use_future!(cx, || async move {
|
|
loop {
|
|
if running.value() {
|
|
count += 1;
|
|
}
|
|
tokio::time::sleep(Duration::from_millis(400)).await;
|
|
}
|
|
});
|
|
|
|
cx.render(rsx! {
|
|
h1 { "High-Five counter: {count}" }
|
|
button { onclick: move |_| count += 1, "Up high!" }
|
|
button { onclick: move |_| count -= 1, "Down low!" }
|
|
button { onclick: move |_| running.toggle(), "Toggle counter" }
|
|
button { onclick: move |_| saved_values.push(count.value().to_string()), "Save this value" }
|
|
button { onclick: move |_| saved_values.write().clear(), "Clear saved values" }
|
|
|
|
// We can do boolean operations on the current signal value
|
|
if count.value() > 5 {
|
|
rsx!{ h2 { "High five!" } }
|
|
}
|
|
|
|
// We can cleanly map signals with iterators
|
|
for value in saved_values.read().iter() {
|
|
h3 { "Saved value: {value}" }
|
|
}
|
|
|
|
// We can also use the signal value as a slice
|
|
if let [ref first, .., ref last] = saved_values.read().as_slice() {
|
|
rsx! { li { "First and last: {first}, {last}" } }
|
|
} else {
|
|
rsx! { "No saved values" }
|
|
}
|
|
})
|
|
}
|