mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-11-14 16:37:14 +00:00
101 lines
2.8 KiB
Rust
101 lines
2.8 KiB
Rust
use dioxus::dioxus_core::{ElementId, Mutation::*};
|
|
use dioxus::prelude::*;
|
|
|
|
/// When returning sets of components, we do a light diff of the contents to preserve some react-like functionality
|
|
///
|
|
/// This means that nav_bar should never get re-created and that we should only be swapping out
|
|
/// different pointers
|
|
#[test]
|
|
fn component_swap() {
|
|
fn app() -> Element {
|
|
let mut render_phase = use_signal(|| 0);
|
|
|
|
render_phase += 1;
|
|
|
|
match render_phase() {
|
|
0 => rsx! {
|
|
nav_bar {}
|
|
dash_board {}
|
|
},
|
|
1 => rsx! {
|
|
nav_bar {}
|
|
dash_results {}
|
|
},
|
|
2 => rsx! {
|
|
nav_bar {}
|
|
dash_board {}
|
|
},
|
|
3 => rsx! {
|
|
nav_bar {}
|
|
dash_results {}
|
|
},
|
|
4 => rsx! {
|
|
nav_bar {}
|
|
dash_board {}
|
|
},
|
|
_ => rsx!("blah"),
|
|
}
|
|
}
|
|
|
|
fn nav_bar() -> Element {
|
|
rsx! {
|
|
h1 { "NavBar", {(0..3).map(|_| rsx!(nav_link {}))} }
|
|
}
|
|
}
|
|
|
|
fn nav_link() -> Element {
|
|
rsx!( h1 { "nav_link" } )
|
|
}
|
|
|
|
fn dash_board() -> Element {
|
|
rsx!( div { "dashboard" } )
|
|
}
|
|
|
|
fn dash_results() -> Element {
|
|
rsx!( div { "results" } )
|
|
}
|
|
|
|
let mut dom = VirtualDom::new(app);
|
|
{
|
|
let edits = dom.rebuild_to_vec().santize();
|
|
assert_eq!(
|
|
edits.edits,
|
|
[
|
|
LoadTemplate { name: "template", index: 0, id: ElementId(1) },
|
|
LoadTemplate { name: "template", index: 0, id: ElementId(2) },
|
|
LoadTemplate { name: "template", index: 0, id: ElementId(3) },
|
|
LoadTemplate { name: "template", index: 0, id: ElementId(4) },
|
|
ReplacePlaceholder { path: &[1], m: 3 },
|
|
LoadTemplate { name: "template", index: 0, id: ElementId(5) },
|
|
AppendChildren { m: 2, id: ElementId(0) }
|
|
]
|
|
);
|
|
}
|
|
|
|
dom.mark_dirty(ScopeId::ROOT);
|
|
assert_eq!(
|
|
dom.render_immediate_to_vec().santize().edits,
|
|
[
|
|
LoadTemplate { name: "template", index: 0, id: ElementId(6) },
|
|
ReplaceWith { id: ElementId(5), m: 1 }
|
|
]
|
|
);
|
|
|
|
dom.mark_dirty(ScopeId::ROOT);
|
|
assert_eq!(
|
|
dom.render_immediate_to_vec().santize().edits,
|
|
[
|
|
LoadTemplate { name: "template", index: 0, id: ElementId(5) },
|
|
ReplaceWith { id: ElementId(6), m: 1 }
|
|
]
|
|
);
|
|
|
|
dom.mark_dirty(ScopeId::ROOT);
|
|
assert_eq!(
|
|
dom.render_immediate_to_vec().santize().edits,
|
|
[
|
|
LoadTemplate { name: "template", index: 0, id: ElementId(6) },
|
|
ReplaceWith { id: ElementId(5), m: 1 }
|
|
]
|
|
);
|
|
}
|