1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
use dioxus::prelude::Scope;
use dioxus_signals::Signal;
use dioxus_use_mounted::UseMounted;

pub fn use_animated<T, V>(
    cx: Scope<T>,
    mounted: UseMounted,
    value_ref: Signal<V>,
    mut make_style: impl FnMut(V) -> String + 'static,
) where
    V: Clone,
{
    dioxus_signals::use_effect(cx, move || {
        let value = value_ref.read();
        set_style(mounted, &make_style(value.clone()));
    })
}

fn set_style(mounted: UseMounted, style: &str) {
    if let Some(element) = &*mounted.signal.read() {
        let raw_elem = element
            .get_raw_element()
            .unwrap()
            .downcast_ref::<web_sys::Element>()
            .unwrap();

        raw_elem.set_attribute("style", style).unwrap();
    }
}