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 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
use super::*;
use std::{
cell::RefCell,
mem,
mem::{zeroed, MaybeUninit},
ops::Deref,
};
use web_sys::Event;
impl UseCursor {
/// builder of `UseCursor`
pub(crate) fn new(cx: &ScopeState) -> Option<Self> {
let window = window()?;
let data = Rc::new(RefCell::new(UseCursorData { mouse: None }));
let setter = data.clone();
let regenerate = cx.schedule_update();
let mouse_move = EventListener::new(&window, "mousemove", move |e| {
let mut setter = setter.borrow_mut();
let e: MouseEvent = e.clone().unchecked_into();
setter.mouse = Some(e);
regenerate();
});
Some(Self { data, listen_mouse_move: mouse_move })
}
}
impl UseCursor {
/// Getter for the screenX field of this object.
// pub fn screen_x(&self) -> usize {
// self.view_mouse().map(|e| e.screen_x()).unwrap_or_default() as _
// }
// ///
// pub fn screen_y(&self) -> usize {
// self.view_mouse().map(|e| e.screen_y()).unwrap_or_default() as _
// }
///
// pub fn element_width(&self) -> usize {
// self.view_mouse().map(|e| e.page_x()).unwrap_or_default() as _
// }
// ///
// pub fn element_height(&self) -> usize {
// self.view_mouse().map(|e| e.element_height()).unwrap_or_default() as _
// }
///
pub fn is_over(&self) {}
///
pub fn is_down(&self) {}
// #[inline]
// fn view_mouse(&self) -> Option<&MouseEvent> {
// self.data.borrow().mouse.as_ref()
// }
}
/// https://www.npmjs.com/package/@react-hook/mouse-position
impl UseHover {
// pub fn new() {
// let mut hook = UseCursor {
// last_event: UseCursor {}
// };
//
// let mouseover = EventListener::new(&window, "mouseover", move |_| {
// hook.over = true;
// });
// let mouseout = EventListener::new(&window, "mouseout", move |_| {
// hook.over = false;
// });
// }
}
impl UseHover {
///
#[inline]
pub fn get(&self) {
// self.over.is_over()
}
}