mirror of
https://github.com/DioxusLabs/dioxus
synced 2025-01-02 15:58:47 +00:00
6210c6fefe
* progress: reworked don't run this, it'll kill your web browser * feat: use_eval but with comms * revision: async recv & recv_sync * revision: use_eval * revision: standard eval interface * revision: use serde_json::Value instead of JsValue * revision: docs * revision: error message * create: desktop eval (wip) * fix: desktop eval * revision: wrap use_eval in Rc<RefCell<_>> * fix: fmt, clippy * fix: desktop tests * revision: change to channel system - fixes clippy errors - fixes playwright tests * fix: tests * fix: eval example * fix: fmt * fix: tests, desktop stuff * fix: tests * feat: drop handler * fix: tests * fix: rustfmt * revision: web promise/callback system * fix: recv error * revision: IntoFuture, functionation * fix: ci * revision: playwright web * remove: unescessary code * remove dioxus-html from public examples * prototype-patch * fix web eval * fix: rustfmt * fix: CI * make use_eval more efficient * implement eval for liveview as well * fix playwright tests * fix clippy * more clippy fixes * fix clippy * fix stack overflow * fix desktop mock * fix clippy --------- Co-authored-by: Evan Almloff <evanalmloff@gmail.com>
96 lines
3 KiB
Rust
96 lines
3 KiB
Rust
use dioxus::prelude::*;
|
|
use dioxus_desktop::DesktopContext;
|
|
|
|
pub(crate) fn check_app_exits(app: Component) {
|
|
use dioxus_desktop::tao::window::WindowBuilder;
|
|
use dioxus_desktop::Config;
|
|
// This is a deadman's switch to ensure that the app exits
|
|
let should_panic = std::sync::Arc::new(std::sync::atomic::AtomicBool::new(true));
|
|
let should_panic_clone = should_panic.clone();
|
|
std::thread::spawn(move || {
|
|
std::thread::sleep(std::time::Duration::from_secs(100));
|
|
if should_panic_clone.load(std::sync::atomic::Ordering::SeqCst) {
|
|
std::process::exit(exitcode::SOFTWARE);
|
|
}
|
|
});
|
|
|
|
dioxus_desktop::launch_cfg(
|
|
app,
|
|
Config::new().with_window(WindowBuilder::new().with_visible(false)),
|
|
);
|
|
|
|
should_panic.store(false, std::sync::atomic::Ordering::SeqCst);
|
|
}
|
|
|
|
fn main() {
|
|
check_app_exits(check_html_renders);
|
|
}
|
|
|
|
fn use_inner_html(cx: &ScopeState, id: &'static str) -> Option<String> {
|
|
let eval_provider = use_eval(cx);
|
|
|
|
let value: &UseRef<Option<String>> = use_ref(cx, || None);
|
|
use_effect(cx, (), |_| {
|
|
to_owned![value, eval_provider];
|
|
async move {
|
|
tokio::time::sleep(std::time::Duration::from_millis(100)).await;
|
|
let html = eval_provider(&format!(
|
|
r#"let element = document.getElementById('{}');
|
|
return element.innerHTML"#,
|
|
id
|
|
))
|
|
.unwrap();
|
|
if let Ok(serde_json::Value::String(html)) = html.await {
|
|
println!("html: {}", html);
|
|
value.set(Some(html));
|
|
}
|
|
}
|
|
});
|
|
value.read().clone()
|
|
}
|
|
|
|
const EXPECTED_HTML: &str = r#"<div id="5" style="width: 100px; height: 100px; color: rgb(0, 0, 0);"><input type="checkbox"><h1>text</h1><div><p>hello world</p></div></div>"#;
|
|
|
|
fn check_html_renders(cx: Scope) -> Element {
|
|
let inner_html = use_inner_html(cx, "main_div");
|
|
|
|
let desktop_context: DesktopContext = cx.consume_context().unwrap();
|
|
|
|
if let Some(raw_html) = inner_html {
|
|
println!("{}", raw_html);
|
|
let fragment = scraper::Html::parse_fragment(&raw_html);
|
|
println!("fragment: {}", fragment.html());
|
|
let expected = scraper::Html::parse_fragment(EXPECTED_HTML);
|
|
println!("expected: {}", expected.html());
|
|
if fragment == expected {
|
|
println!("html matches");
|
|
desktop_context.close();
|
|
}
|
|
}
|
|
|
|
let dyn_value = 0;
|
|
let dyn_element = rsx! {
|
|
div {
|
|
dangerous_inner_html: "<p>hello world</p>",
|
|
}
|
|
};
|
|
|
|
render! {
|
|
div {
|
|
id: "main_div",
|
|
div {
|
|
width: "100px",
|
|
height: "100px",
|
|
color: "rgb({dyn_value}, {dyn_value}, {dyn_value})",
|
|
id: 5,
|
|
input {
|
|
"type": "checkbox",
|
|
},
|
|
h1 {
|
|
"text"
|
|
}
|
|
dyn_element
|
|
}
|
|
}
|
|
}
|
|
}
|