2023-01-29 21:57:40 +00:00
|
|
|
use dioxus_core::ScopeState;
|
|
|
|
|
|
|
|
use crate::UseFutureDep;
|
|
|
|
|
2023-06-27 22:15:00 +00:00
|
|
|
/// A hook that provides a callback that executes if the dependencies change.
|
|
|
|
/// This is useful to avoid running computation-expensive calculations even when the data doesn't change.
|
2023-01-29 21:57:40 +00:00
|
|
|
///
|
2023-06-27 22:15:00 +00:00
|
|
|
/// - dependencies: a tuple of references to values that are `PartialEq` + `Clone`
|
2023-01-29 21:57:40 +00:00
|
|
|
///
|
|
|
|
/// ## Examples
|
|
|
|
///
|
2023-06-27 22:15:00 +00:00
|
|
|
/// ```rust, no_run
|
2023-01-29 21:57:40 +00:00
|
|
|
///
|
|
|
|
/// #[inline_props]
|
2023-06-27 22:15:00 +00:00
|
|
|
/// fn Calculator(cx: Scope, number: usize) -> Element {
|
|
|
|
/// let bigger_number = use_memo(cx, (number,), |(number,)| {
|
|
|
|
/// // This will only be calculated when `number` has changed.
|
|
|
|
/// number * 100
|
2023-07-02 21:00:26 +00:00
|
|
|
/// });
|
2023-06-27 22:15:00 +00:00
|
|
|
/// render!(
|
|
|
|
/// p { "{bigger_number}" }
|
|
|
|
/// )
|
|
|
|
/// }
|
|
|
|
/// fn app(cx: Scope) -> Element {
|
2023-07-02 21:00:26 +00:00
|
|
|
/// render!(Calculator { number: 0 })
|
2023-01-29 21:57:40 +00:00
|
|
|
/// }
|
|
|
|
/// ```
|
|
|
|
pub fn use_memo<T, D>(cx: &ScopeState, dependencies: D, callback: impl FnOnce(D::Out) -> T) -> &T
|
|
|
|
where
|
|
|
|
T: 'static,
|
|
|
|
D: UseFutureDep,
|
|
|
|
{
|
|
|
|
let value = cx.use_hook(|| None);
|
|
|
|
|
|
|
|
let dependancies_vec = cx.use_hook(Vec::new);
|
|
|
|
|
|
|
|
if dependencies.clone().apply(dependancies_vec) || value.is_none() {
|
|
|
|
// Create the new value
|
|
|
|
*value = Some(callback(dependencies.out()));
|
|
|
|
}
|
|
|
|
|
|
|
|
value.as_ref().unwrap()
|
|
|
|
}
|