mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-11-10 06:34:20 +00:00
1dfa1b5e7f
* Use of async_std::task::sleep instead of tokio::time::sleep * Make the clock example run on wasm * Add control_focus and eval examples to Cargo.toml * Use web-time on desktop; It just falls back to std on non-wasm platforms --------- Co-authored-by: Evan Almloff <evanalmloff@gmail.com>
37 lines
955 B
Rust
37 lines
955 B
Rust
//! Handle async streams using use_future and awaiting the next value.
|
|
|
|
use async_std::task::sleep;
|
|
use dioxus::prelude::*;
|
|
use futures_util::{future, stream, Stream, StreamExt};
|
|
|
|
fn main() {
|
|
launch(app);
|
|
}
|
|
|
|
fn app() -> Element {
|
|
let mut count = use_signal(|| 10);
|
|
|
|
use_future(move || async move {
|
|
// Create the stream.
|
|
// This could be a network request, a file read, or any other async operation.
|
|
let mut stream = some_stream();
|
|
|
|
// Await the next value from the stream.
|
|
while let Some(second) = stream.next().await {
|
|
count.set(second);
|
|
}
|
|
});
|
|
|
|
rsx! {
|
|
h1 { "High-Five counter: {count}" }
|
|
}
|
|
}
|
|
|
|
fn some_stream() -> std::pin::Pin<Box<dyn Stream<Item = i32>>> {
|
|
Box::pin(
|
|
stream::once(future::ready(0)).chain(stream::iter(1..).then(|second| async move {
|
|
sleep(std::time::Duration::from_secs(1)).await;
|
|
second
|
|
})),
|
|
)
|
|
}
|