From 3eadd9cf1a5765853c9ff99572983cc68a15dacc Mon Sep 17 00:00:00 2001 From: Hector Candelaria Date: Thu, 22 Aug 2024 23:22:02 -0400 Subject: [PATCH] Feat: Update `vibrate` type to Rust type - Updated `vibrate` type to `Vec` to improve SSR and type safety. - Added new helper function `vibration_patter_to_jsvalue` to convert `Vec` to `JsValue`. --- src/use_web_notification.rs | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/src/use_web_notification.rs b/src/use_web_notification.rs index f34c9cd..0a3cefb 100644 --- a/src/use_web_notification.rs +++ b/src/use_web_notification.rs @@ -3,6 +3,7 @@ use cfg_if::cfg_if; use default_struct_builder::DefaultBuilder; use leptos::*; use std::rc::Rc; +use wasm_bindgen::JsValue; /// Reactive [Notification API](https://developer.mozilla.org/en-US/docs/Web/API/Notification). /// @@ -282,7 +283,7 @@ pub struct UseWebNotificationOptions { /// A JsValue array specifying the vibration pattern in which the device is vibrating and not vibrating. #[builder(into)] - vibrate: Option, + vibrate: Option>, /// Called when the user clicks on displayed `Notification`. on_click: Rc, @@ -350,7 +351,7 @@ impl From<&UseWebNotificationOptions> for web_sys::NotificationOptions { } if let Some(vibrate) = &options.vibrate { - web_sys_options.set_vibrate(vibrate); + web_sys_options.set_vibrate(&vibration_pattern_to_jsvalue(vibrate)); } web_sys_options } @@ -417,7 +418,7 @@ pub struct ShowOptions { /// A JsValue array specifying the vibration pattern in which the device is vibrating and not vibrating. #[builder(into)] - vibrate: Option, + vibrate: Option>, } #[cfg(not(feature = "ssr"))] @@ -460,7 +461,7 @@ impl ShowOptions { } if let Some(vibrate) = &self.vibrate { - options.set_vibrate(vibrate); + options.set_vibrate(&vibration_pattern_to_jsvalue(vibrate)); } } } @@ -476,6 +477,15 @@ fn browser_supports_notifications() -> bool { false } +/// Helper function to convert `Vec` into a `JsValue` array that represents a vibration pattern +fn vibration_pattern_to_jsvalue(pattern: &Vec) -> JsValue { + let array = js_sys::Array::new(); + for &value in pattern.iter() { + array.push(&JsValue::from(value)); + } + array.into() +} + #[derive(Copy, Clone, PartialEq, Eq, Debug, Default)] /// The permission to send notifications pub enum NotificationPermission {