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}