|
@@ -0,0 +1,37 @@
|
|
|
+#![allow(non_snake_case)]
|
|
|
+use dioxus::prelude::*;
|
|
|
+
|
|
|
+fn main() {
|
|
|
+ dioxus_desktop::launch(App);
|
|
|
+}
|
|
|
+
|
|
|
+fn App(cx: Scope) -> Element {
|
|
|
+ let files_uploaded: &UseRef<Vec<String>> = use_ref(cx, Vec::new);
|
|
|
+
|
|
|
+ cx.render(rsx! {
|
|
|
+ input {
|
|
|
+ r#type: "file",
|
|
|
+ accept: "text/*",
|
|
|
+ onchange: |evt| {
|
|
|
+ to_owned![files_uploaded];
|
|
|
+ async move {
|
|
|
+ println!("files uploaded: {:?}", evt);
|
|
|
+ if let Some(file_engine) = &evt.files {
|
|
|
+ let files = file_engine.files();
|
|
|
+ for file_name in &files {
|
|
|
+ if let Some(file) = file_engine.read_file_to_string(&file_name).await{
|
|
|
+ files_uploaded.write().push(file);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ ul {
|
|
|
+ for file in files_uploaded.read().iter() {
|
|
|
+ li { "{file}" }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ })
|
|
|
+}
|