mirror of
https://github.com/adoyle0/leptos-use.git
synced 2025-01-23 09:09:21 -05:00
make UseMouseEventExtractor
not return an option
This makes it so that `Movement` always returns (0., 0.)
This commit is contained in:
parent
cef0e68121
commit
e795c1f8f3
1 changed files with 27 additions and 26 deletions
|
@ -6,6 +6,7 @@ use cfg_if::cfg_if;
|
||||||
use default_struct_builder::DefaultBuilder;
|
use default_struct_builder::DefaultBuilder;
|
||||||
use leptos::ev::{dragover, mousemove, touchend, touchmove, touchstart};
|
use leptos::ev::{dragover, mousemove, touchend, touchmove, touchstart};
|
||||||
use leptos::*;
|
use leptos::*;
|
||||||
|
use std::convert::Infallible;
|
||||||
use std::marker::PhantomData;
|
use std::marker::PhantomData;
|
||||||
use wasm_bindgen::{JsCast, JsValue};
|
use wasm_bindgen::{JsCast, JsValue};
|
||||||
|
|
||||||
|
@ -108,7 +109,7 @@ where
|
||||||
move |event: web_sys::MouseEvent| {
|
move |event: web_sys::MouseEvent| {
|
||||||
let result = coord_type.extract_mouse_coords(&event);
|
let result = coord_type.extract_mouse_coords(&event);
|
||||||
|
|
||||||
if let Some((x, y)) = result {
|
if let (x, y) = result {
|
||||||
set_x.set(x);
|
set_x.set(x);
|
||||||
set_y.set(y);
|
set_y.set(y);
|
||||||
set_source_type.set(UseMouseSourceType::Mouse);
|
set_source_type.set(UseMouseSourceType::Mouse);
|
||||||
|
@ -137,7 +138,7 @@ where
|
||||||
.expect("Just checked that there's at least on touch"),
|
.expect("Just checked that there's at least on touch"),
|
||||||
);
|
);
|
||||||
|
|
||||||
if let Some((x, y)) = result {
|
if let (x, y) = result {
|
||||||
set_x.set(x);
|
set_x.set(x);
|
||||||
set_y.set(y);
|
set_y.set(y);
|
||||||
set_source_type.set(UseMouseSourceType::Touch);
|
set_source_type.set(UseMouseSourceType::Touch);
|
||||||
|
@ -230,10 +231,10 @@ where
|
||||||
_marker: PhantomData<T>,
|
_marker: PhantomData<T>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for UseMouseOptions<UseWindow, web_sys::Window, UseMouseEventExtractorDefault> {
|
impl Default for UseMouseOptions<UseWindow, web_sys::Window, Infallible> {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self {
|
Self {
|
||||||
coord_type: UseMouseCoordType::<UseMouseEventExtractorDefault>::default(),
|
coord_type: UseMouseCoordType::<Infallible>::default(),
|
||||||
target: use_window(),
|
target: use_window(),
|
||||||
touch: true,
|
touch: true,
|
||||||
reset_on_touch_ends: false,
|
reset_on_touch_ends: false,
|
||||||
|
@ -245,7 +246,7 @@ impl Default for UseMouseOptions<UseWindow, web_sys::Window, UseMouseEventExtrac
|
||||||
|
|
||||||
/// Defines how to get the coordinates from the event.
|
/// Defines how to get the coordinates from the event.
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub enum UseMouseCoordType<E: UseMouseEventExtractor + Clone> {
|
pub enum UseMouseCoordType<E> {
|
||||||
Page,
|
Page,
|
||||||
Client,
|
Client,
|
||||||
Screen,
|
Screen,
|
||||||
|
@ -253,54 +254,54 @@ pub enum UseMouseCoordType<E: UseMouseEventExtractor + Clone> {
|
||||||
Custom(E),
|
Custom(E),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for UseMouseCoordType<UseMouseEventExtractorDefault> {
|
impl<E> Default for UseMouseCoordType<E> {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self::Page
|
Self::Page
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Trait to implement if you want to specify a custom extractor
|
/// Trait to implement if you want to specify a custom extractor
|
||||||
#[allow(unused_variables)]
|
|
||||||
pub trait UseMouseEventExtractor {
|
pub trait UseMouseEventExtractor {
|
||||||
/// Return the coordinates from mouse events (`Some(x, y)`) or `None`
|
/// Return the coordinates from mouse events (`Some(x, y)`) or `None`
|
||||||
fn extract_mouse_coords(&self, event: &web_sys::MouseEvent) -> Option<(f64, f64)> {
|
fn extract_mouse_coords(&self, event: &web_sys::MouseEvent) -> (f64, f64);
|
||||||
None
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Return the coordinates from touches (`Some(x, y)`) or `None`
|
/// Return the coordinates from touches (`Some(x, y)`) or `None`
|
||||||
fn extract_touch_coords(&self, touch: &web_sys::Touch) -> Option<(f64, f64)> {
|
fn extract_touch_coords(&self, touch: &web_sys::Touch) -> (f64, f64);
|
||||||
None
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<E: UseMouseEventExtractor + Clone> UseMouseEventExtractor for UseMouseCoordType<E> {
|
impl<E: UseMouseEventExtractor + Clone> UseMouseEventExtractor for UseMouseCoordType<E> {
|
||||||
fn extract_mouse_coords(&self, event: &web_sys::MouseEvent) -> Option<(f64, f64)> {
|
fn extract_mouse_coords(&self, event: &web_sys::MouseEvent) -> (f64, f64) {
|
||||||
match self {
|
match self {
|
||||||
UseMouseCoordType::Page => Some((event.page_x() as f64, event.page_y() as f64)),
|
UseMouseCoordType::Page => (event.page_x() as f64, event.page_y() as f64),
|
||||||
UseMouseCoordType::Client => Some((event.client_x() as f64, event.client_y() as f64)),
|
UseMouseCoordType::Client => (event.client_x() as f64, event.client_y() as f64),
|
||||||
UseMouseCoordType::Screen => Some((event.screen_x() as f64, event.client_y() as f64)),
|
UseMouseCoordType::Screen => (event.screen_x() as f64, event.client_y() as f64),
|
||||||
UseMouseCoordType::Movement => {
|
UseMouseCoordType::Movement => {
|
||||||
Some((event.movement_x() as f64, event.movement_y() as f64))
|
(event.movement_x() as f64, event.movement_y() as f64)
|
||||||
}
|
}
|
||||||
UseMouseCoordType::Custom(ref extractor) => extractor.extract_mouse_coords(event),
|
UseMouseCoordType::Custom(ref extractor) => extractor.extract_mouse_coords(event),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn extract_touch_coords(&self, touch: &web_sys::Touch) -> Option<(f64, f64)> {
|
fn extract_touch_coords(&self, touch: &web_sys::Touch) -> (f64, f64) {
|
||||||
match self {
|
match self {
|
||||||
UseMouseCoordType::Page => Some((touch.page_x() as f64, touch.page_y() as f64)),
|
UseMouseCoordType::Page => (touch.page_x() as f64, touch.page_y() as f64),
|
||||||
UseMouseCoordType::Client => Some((touch.client_x() as f64, touch.client_y() as f64)),
|
UseMouseCoordType::Client => (touch.client_x() as f64, touch.client_y() as f64),
|
||||||
UseMouseCoordType::Screen => Some((touch.screen_x() as f64, touch.client_y() as f64)),
|
UseMouseCoordType::Screen => (touch.screen_x() as f64, touch.client_y() as f64),
|
||||||
UseMouseCoordType::Movement => None,
|
UseMouseCoordType::Movement => (0., 0.),
|
||||||
UseMouseCoordType::Custom(ref extractor) => extractor.extract_touch_coords(touch),
|
UseMouseCoordType::Custom(ref extractor) => extractor.extract_touch_coords(touch),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone)]
|
impl UseMouseEventExtractor for Infallible {
|
||||||
pub struct UseMouseEventExtractorDefault;
|
fn extract_mouse_coords(&self, _: &web_sys::MouseEvent) -> (f64, f64) {
|
||||||
|
unreachable!()
|
||||||
|
}
|
||||||
|
|
||||||
impl UseMouseEventExtractor for UseMouseEventExtractorDefault {}
|
fn extract_touch_coords(&self, _: &web_sys::Touch) -> (f64, f64) {
|
||||||
|
unreachable!()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Return type of [`use_mouse`].
|
/// Return type of [`use_mouse`].
|
||||||
pub struct UseMouseReturn {
|
pub struct UseMouseReturn {
|
||||||
|
|
Loading…
Add table
Reference in a new issue