From 38be121679d3261503cc12390db974549b35d1c9 Mon Sep 17 00:00:00 2001 From: GarboMuffin Date: Fri, 21 Jun 2024 16:31:57 -0500 Subject: [PATCH] Use prefixed fullscreen methods (#1559) Some Safari versions that aren't even that old need webkit prefix --- extensions/CubesterYT/WindowControls.js | 36 ++++++++++++++++--- extensions/veggiecan/browserfullscreen.js | 44 ++++++++++++++++++----- 2 files changed, 67 insertions(+), 13 deletions(-) diff --git a/extensions/CubesterYT/WindowControls.js b/extensions/CubesterYT/WindowControls.js index c77618d651..ff1ea7d3c9 100644 --- a/extensions/CubesterYT/WindowControls.js +++ b/extensions/CubesterYT/WindowControls.js @@ -19,6 +19,32 @@ return Math.floor(Math.random() * (max - min + 1)) + min; } + const isFullscreenEnabled = () => { + if (typeof document.fullscreenElement !== "undefined") { + return document.fullscreenElement !== null; + } + if (typeof document.webkitFullscreenElement !== "undefined") { + return document.webkitFullscreenElement !== null; + } + return false; + }; + + const enterFullscreen = () => { + if (document.documentElement.requestFullscreen) { + document.documentElement.requestFullscreen(); + } else if (document.documentElement.webkitRequestFullscreen) { + document.documentElement.webkitRequestFullscreen(); + } + }; + + const exitFullscreen = () => { + if (document.exitFullscreen) { + document.exitFullscreen(); + } else if (document.webkitExitFullscreen) { + document.webkitExitFullscreen(); + } + }; + class WindowControls { getInfo() { return { @@ -515,17 +541,17 @@ return document.title; } enterFullscreen() { - if (document.fullscreenElement == null) { - document.documentElement.requestFullscreen(); + if (!isFullscreenEnabled()) { + enterFullscreen(); } } exitFullscreen() { - if (document.fullscreenElement !== null) { - document.exitFullscreen(); + if (isFullscreenEnabled()) { + exitFullscreen(); } } isFullscreen() { - return document.fullscreenElement !== null; + return isFullscreenEnabled(); } closeWindow() { const editorConfirmation = Scratch.translate({ diff --git a/extensions/veggiecan/browserfullscreen.js b/extensions/veggiecan/browserfullscreen.js index 6d8944d0e6..e5a69214c5 100644 --- a/extensions/veggiecan/browserfullscreen.js +++ b/extensions/veggiecan/browserfullscreen.js @@ -9,11 +9,39 @@ const icon = ""; - window.addEventListener("fullscreenchange", () => { + const isFullscreenEnabled = () => { + if (typeof document.fullscreenElement !== "undefined") { + return document.fullscreenElement !== null; + } + if (typeof document.webkitFullscreenElement !== "undefined") { + return document.webkitFullscreenElement !== null; + } + return false; + }; + + const enterFullscreen = () => { + if (document.documentElement.requestFullscreen) { + document.documentElement.requestFullscreen(); + } else if (document.documentElement.webkitRequestFullscreen) { + document.documentElement.webkitRequestFullscreen(); + } + }; + + const exitFullscreen = () => { + if (document.exitFullscreen) { + document.exitFullscreen(); + } else if (document.webkitExitFullscreen) { + document.webkitExitFullscreen(); + } + }; + + const onFullScreenChange = () => { Scratch.vm.runtime.startHats("fullscreen0419_whenfullscreen", { - ENABLED: document.fullscreenElement === null ? "exited" : "entered", + ENABLED: isFullscreenEnabled() ? "entered" : "exited", }); - }); + }; + window.addEventListener("fullscreenchange", onFullScreenChange); + window.addEventListener("webkitfullscreenchange", onFullScreenChange); class FullscreenExtension { getInfo() { @@ -89,14 +117,14 @@ } fullscreen(args) { const action = Scratch.Cast.toString(args.ACTION).toLowerCase(); - if (action === "enter" && !document.fullscreenElement) { - document.documentElement.requestFullscreen(); - } else if (action === "exit" && document.fullscreenElement) { - document.exitFullscreen(); + if (action === "enter" && !isFullscreenEnabled()) { + enterFullscreen(); + } else if (action === "exit" && isFullscreenEnabled()) { + exitFullscreen(); } } isInFullscreen() { - return document.fullscreenElement !== null; + return isFullscreenEnabled(); } }