Merge pull request #155 from hcandelaria/use_web_notification

Feat: Enhance UseWebNotificationOptions and ShowOptions with additional field
This commit is contained in:
Marc-Stefan Cassola 2024-08-24 12:10:22 +01:00 committed by GitHub
commit ff5f6a62a0
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 32 additions and 6 deletions

View file

@ -3,6 +3,7 @@ use cfg_if::cfg_if;
use default_struct_builder::DefaultBuilder; use default_struct_builder::DefaultBuilder;
use leptos::*; use leptos::*;
use std::rc::Rc; use std::rc::Rc;
use wasm_bindgen::JsValue;
/// Reactive [Notification API](https://developer.mozilla.org/en-US/docs/Web/API/Notification). /// Reactive [Notification API](https://developer.mozilla.org/en-US/docs/Web/API/Notification).
/// ///
@ -228,7 +229,6 @@ impl From<NotificationDirection> for web_sys::NotificationDirection {
/// See [MDN Docs](https://developer.mozilla.org/en-US/docs/Web/API/notification) for more info. /// See [MDN Docs](https://developer.mozilla.org/en-US/docs/Web/API/notification) for more info.
/// ///
/// The following implementations are missing: /// The following implementations are missing:
/// - `vibrate`
#[derive(DefaultBuilder, Clone)] #[derive(DefaultBuilder, Clone)]
#[cfg_attr(feature = "ssr", allow(dead_code))] #[cfg_attr(feature = "ssr", allow(dead_code))]
pub struct UseWebNotificationOptions { pub struct UseWebNotificationOptions {
@ -277,10 +277,15 @@ pub struct UseWebNotificationOptions {
renotify: bool, renotify: bool,
/// A boolean value specifying whether the notification should be silent, regardless of the device settings. /// A boolean value specifying whether the notification should be silent, regardless of the device settings.
/// The default is `false`, which means the notification is not silent. If `true`, then the notification will be silent. /// The default is `null`, which means the notification is not silent. If `true`, then the notification will be silent.
#[builder(into)] #[builder(into)]
silent: Option<bool>, silent: Option<bool>,
/// A `Vec<u16>` specifying the vibration pattern in milliseconds for vibrating and not vibrating.
/// The last entry can be a vibration since it stops automatically after each period.
#[builder(into)]
vibrate: Option<Vec<u16>>,
/// Called when the user clicks on displayed `Notification`. /// Called when the user clicks on displayed `Notification`.
on_click: Rc<dyn Fn(web_sys::Event)>, on_click: Rc<dyn Fn(web_sys::Event)>,
@ -308,6 +313,7 @@ impl Default for UseWebNotificationOptions {
require_interaction: false, require_interaction: false,
renotify: false, renotify: false,
silent: None, silent: None,
vibrate: None,
on_click: Rc::new(|_| {}), on_click: Rc::new(|_| {}),
on_close: Rc::new(|_| {}), on_close: Rc::new(|_| {}),
on_error: Rc::new(|_| {}), on_error: Rc::new(|_| {}),
@ -345,6 +351,9 @@ impl From<&UseWebNotificationOptions> for web_sys::NotificationOptions {
web_sys_options.set_tag(tag); web_sys_options.set_tag(tag);
} }
if let Some(vibrate) = &options.vibrate {
web_sys_options.set_vibrate(&vibration_pattern_to_jsvalue(vibrate));
}
web_sys_options web_sys_options
} }
} }
@ -354,7 +363,6 @@ impl From<&UseWebNotificationOptions> for web_sys::NotificationOptions {
/// See [MDN Docs](https://developer.mozilla.org/en-US/docs/Web/API/notification) for more info. /// See [MDN Docs](https://developer.mozilla.org/en-US/docs/Web/API/notification) for more info.
/// ///
/// The following implementations are missing: /// The following implementations are missing:
/// - `vibrate`
#[derive(DefaultBuilder, Default)] #[derive(DefaultBuilder, Default)]
#[cfg_attr(feature = "ssr", allow(dead_code))] #[cfg_attr(feature = "ssr", allow(dead_code))]
pub struct ShowOptions { pub struct ShowOptions {
@ -405,9 +413,14 @@ pub struct ShowOptions {
renotify: Option<bool>, renotify: Option<bool>,
/// A boolean value specifying whether the notification should be silent, regardless of the device settings. /// A boolean value specifying whether the notification should be silent, regardless of the device settings.
/// The default is `false`, which means the notification is not silent. If `true`, then the notification will be silent. /// The default is `null`, which means the notification is not silent. If `true`, then the notification will be silent.
#[builder(into)] #[builder(into)]
silent: Option<bool>, silent: Option<bool>,
/// A `Vec<u16>` specifying the vibration pattern in milliseconds for vibrating and not vibrating.
/// The last entry can be a vibration since it stops automatically after each period.
#[builder(into)]
vibrate: Option<Vec<u16>>,
} }
#[cfg(not(feature = "ssr"))] #[cfg(not(feature = "ssr"))]
@ -448,6 +461,10 @@ impl ShowOptions {
if let Some(silent) = self.silent { if let Some(silent) = self.silent {
options.set_silent(Some(silent)); options.set_silent(Some(silent));
} }
if let Some(vibrate) = &self.vibrate {
options.set_vibrate(&vibration_pattern_to_jsvalue(vibrate));
}
} }
} }
@ -462,6 +479,15 @@ fn browser_supports_notifications() -> bool {
false false
} }
/// Helper function to convert a slice of `u16` into a `JsValue` array that represents a vibration pattern
fn vibration_pattern_to_jsvalue(pattern: &[u16]) -> 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)] #[derive(Copy, Clone, PartialEq, Eq, Debug, Default)]
/// The permission to send notifications /// The permission to send notifications
pub enum NotificationPermission { pub enum NotificationPermission {

View file

@ -1,4 +1,4 @@
use crate::{watch_with_options, utils::DebounceOptions, WatchOptions}; use crate::{utils::DebounceOptions, watch_with_options, WatchOptions};
use default_struct_builder::DefaultBuilder; use default_struct_builder::DefaultBuilder;
use leptos::*; use leptos::*;

View file

@ -1,4 +1,4 @@
use crate::{watch_with_options, utils::ThrottleOptions, WatchOptions}; use crate::{utils::ThrottleOptions, watch_with_options, WatchOptions};
use default_struct_builder::DefaultBuilder; use default_struct_builder::DefaultBuilder;
/// A throttled version of `leptos::watch`. /// A throttled version of `leptos::watch`.