dioxus_switch/
lib.rs

1use dioxus_core::{Element, IntoDynNode};
2use dioxus_core_macro::{Props, component, rsx};
3use dioxus_hooks::{use_context, use_context_provider};
4use dioxus_signals::{GlobalSignal, Readable, Signal, Writable};
5
6pub trait Switchable: Default + PartialEq + Clone + 'static {
7    fn component(self) -> Element;
8}
9
10#[component]
11pub fn Switch<T: Switchable + 'static>(#[props(optional)] current: Option<T>) -> Element {
12    let context =
13        use_context_provider(move || Signal::new(current.unwrap_or_else(|| T::default())));
14    rsx! {
15        {context.read().clone().component()}
16    }
17}
18
19pub fn switch<T: Switchable>(to: T) {
20    *use_context::<Signal<T>>().write() = to;
21}