#![cfg_attr(feature = "ssr", allow(unused_variables, unused_imports))] use crate::core::ElementMaybeSignal; use crate::{use_mutation_observer_with_options, watch_with_options, WatchOptions}; use cfg_if::cfg_if; use default_struct_builder::DefaultBuilder; use leptos::*; use std::marker::PhantomData; use std::time::Duration; use wasm_bindgen::{JsCast, JsValue}; /// Manipulate CSS variables. /// /// ## Demo /// /// [Link to Demo](https://github.com/Synphonyte/leptos-use/tree/main/examples/use_css_var) /// /// ## Usage /// /// ``` /// # use leptos::*; /// # use leptos_use::use_css_var; /// # /// # #[component] /// # fn Demo() -> impl IntoView { /// let (color, set_color) = use_css_var("--color"); /// /// set_color.set("red".to_string()); /// # /// # view! { } /// # } /// ``` /// /// The variable name itself can be a `Signal`. /// /// ``` /// # use leptos::*; /// # use leptos_use::use_css_var; /// # /// # #[component] /// # fn Demo() -> impl IntoView { /// let (key, set_key) = create_signal("--color".to_string()); /// let (color, set_color) = use_css_var(key); /// # /// # view! { } /// # } /// ``` /// /// You can specify the element that the variable is applied to as well as an initial value in case /// the variable is not set yet. The option to listen for changes to the variable is also available. /// /// ``` /// # use leptos::*; /// # use leptos::html::Div; /// # use leptos_use::{use_css_var_with_options, UseCssVarOptions}; /// # /// # #[component] /// # fn Demo() -> impl IntoView { /// let el = create_node_ref::
(
prop: P,
options: UseCssVarOptions