Hide web push toggles if disabled on server

This commit is contained in:
nimbleghost 2023-05-31 18:43:06 +02:00
parent 0c25425346
commit 7aa3d8f59b
2 changed files with 6 additions and 3 deletions

View File

@ -115,7 +115,7 @@ class Notifier {
}
pushSupported() {
return "serviceWorker" in navigator && "PushManager" in window;
return config.enable_web_push && "serviceWorker" in navigator && "PushManager" in window;
}
/**

View File

@ -103,6 +103,7 @@ const SubscribeDialog = (props) => {
const browserNotificationsSupported = notifier.supported();
const pushNotificationsSupported = notifier.pushSupported();
const iosInstallRequired = notifier.iosSupportedButInstallRequired();
const pushPossible = pushNotificationsSupported && iosInstallRequired;
const getNotificationTypeFromToggles = (browserNotificationsEnabled, backgroundNotificationsEnabled) => {
if (backgroundNotificationsEnabled) {
@ -138,12 +139,14 @@ const SubscribePage = (props) => {
const [notificationsExplicitlyDenied, setNotificationsExplicitlyDenied] = useState(notifier.denied());
// default to on if notifications are already granted
const [browserNotificationsEnabled, setBrowserNotificationsEnabled] = useState(notifier.granted());
const [backgroundNotificationsEnabled, setBackgroundNotificationsEnabled] = useState(props.webPushDefaultEnabled === "enabled");
const [backgroundNotificationsEnabled, setBackgroundNotificationsEnabled] = useState(
pushPossible && props.webPushDefaultEnabled === "enabled"
);
const handleBrowserNotificationsChanged = async (e) => {
if (e.target.checked && (await notifier.maybeRequestPermission())) {
setBrowserNotificationsEnabled(true);
if (props.webPushDefaultEnabled === "enabled") {
if (pushPossible && props.webPushDefaultEnabled === "enabled") {
setBackgroundNotificationsEnabled(true);
}
} else {