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 30 31 32 33 34 35 36 37 38 39 40 41 42 43
use yew::prelude::*;
use super::{use_effect_once, use_mut_latest};
/// A lifecycle hook that calls a function when the component will unmount.
///
/// # Example
///
/// ```rust
/// # use yew::prelude::*;
/// # use log::debug;
/// #
/// use yew_hooks::prelude::*;
///
/// #[function_component(Unmount)]
/// fn unmount() -> Html {
/// use_unmount(|| {
/// debug!("Running clean-up of effect on unmount");
/// });
///
/// html! {
/// <>
/// </>
/// }
/// }
/// ```
#[hook]
pub fn use_unmount<Callback>(callback: Callback)
where
Callback: FnOnce() + 'static,
{
let callback_ref = use_mut_latest(Some(callback));
use_effect_once(move || {
move || {
let callback_ref = callback_ref.current();
let callback = (*callback_ref.borrow_mut()).take();
if let Some(callback) = callback {
callback();
}
}
});
}