Skip to content

Commit

Permalink
Use prefixed fullscreen methods (#1559)
Browse files Browse the repository at this point in the history
Some Safari versions that aren't even that old need webkit prefix
  • Loading branch information
GarboMuffin authored Jun 21, 2024
1 parent d7df8c3 commit 38be121
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 13 deletions.
36 changes: 31 additions & 5 deletions extensions/CubesterYT/WindowControls.js
Original file line number Diff line number Diff line change
Expand Up @@ -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 {
Expand Down Expand Up @@ -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({
Expand Down
44 changes: 36 additions & 8 deletions extensions/veggiecan/browserfullscreen.js
Original file line number Diff line number Diff line change
Expand Up @@ -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() {
Expand Down Expand Up @@ -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();
}
}

Expand Down

0 comments on commit 38be121

Please sign in to comment.