mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-11-23 20:53:06 +00:00
37 lines
962 B
Rust
37 lines
962 B
Rust
//! Handle async streams using use_future and awaiting the next value.
|
|
|
|
use dioxus::prelude::*;
|
|
use futures_util::{future, stream, Stream, StreamExt};
|
|
use std::time::Duration;
|
|
|
|
fn main() {
|
|
launch_desktop(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 {
|
|
tokio::time::sleep(Duration::from_secs(1)).await;
|
|
second
|
|
})),
|
|
)
|
|
}
|