123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- 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 => render! {
- nav_bar {}
- dash_board {}
- },
- 1 => render! {
- nav_bar {}
- dash_results {}
- },
- 2 => render! {
- nav_bar {}
- dash_board {}
- },
- 3 => render! {
- nav_bar {}
- dash_results {}
- },
- 4 => render! {
- nav_bar {}
- dash_board {}
- },
- _ => render!("blah"),
- }
- }
- fn nav_bar() -> Element {
- render! {
- h1 { "NavBar", {(0..3).map(|_| render!(nav_link {}))} }
- }
- }
- fn nav_link() -> Element {
- render!( h1 { "nav_link" } )
- }
- fn dash_board() -> Element {
- render!( div { "dashboard" } )
- }
- fn dash_results() -> Element {
- render!( 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 }
- ]
- );
- }
|