diff --git a/extensions/extensions.json b/extensions/extensions.json index e38c08ca2e..0c7f5d79c3 100644 --- a/extensions/extensions.json +++ b/extensions/extensions.json @@ -26,6 +26,7 @@ "Lily/MoreEvents", "NexusKitten/moremotion", "CubesterYT/WindowControls", + "veggiecan/browserfullscreen", "navigator", "battery", "TheShovel/CustomStyles", diff --git a/extensions/veggiecan/browserfullscreen.js b/extensions/veggiecan/browserfullscreen.js new file mode 100644 index 0000000000..7aa3f93b3d --- /dev/null +++ b/extensions/veggiecan/browserfullscreen.js @@ -0,0 +1,103 @@ +// Name: Browser Fullscreen +// ID: fullscreen0419 +// Description: Enter and exit fullscreen mode. +// By: Veggiecan0419 + +(function (Scratch) { + "use strict"; + const icon = + ""; + + window.addEventListener("fullscreenchange", () => { + Scratch.vm.runtime.startHats("fullscreen0419_whenfullscreen", { + ENABLED: document.fullscreenElement === null ? "exited" : "entered", + }); + }); + + class FullscreenExtension { + getInfo() { + return { + id: "fullscreen0419", + color1: "#F39016", + color2: "#C77612", + color3: "#9D5D0E", + blockIconURI: icon, + name: "Browser Fullscreen", + blocks: [ + { + opcode: "fullscreen", + blockType: Scratch.BlockType.COMMAND, + text: "[ACTION] fullscreen", + arguments: { + ACTION: { + type: Scratch.ArgumentType.STRING, + menu: "fullscreenMenu", + defaultValue: "enter", + }, + }, + }, + { + opcode: "isInFullscreen", + blockType: Scratch.BlockType.BOOLEAN, + text: "in browser fullscreen?", + arguments: {}, + }, + { + opcode: "whenfullscreen", + blockType: Scratch.BlockType.EVENT, + text: "when browser fullscreen [ENABLED]", + isEdgeActivated: false, + arguments: { + ENABLED: { + type: Scratch.ArgumentType.STRING, + menu: "whenfullscreenMenu", + }, + }, + }, + ], + menus: { + fullscreenMenu: { + acceptReporters: true, + items: [ + { + text: "enter", + value: "enter", + }, + { + text: "exit", + value: "exit", + }, + ], + }, + whenfullscreenMenu: { + // Used for startHats filtering. + acceptReporters: false, + items: [ + { + text: "entered", + value: "entered", + }, + { + text: "exited", + value: "exited", + }, + ], + }, + }, + }; + } + fullscreen(args) { + const action = args.ACTION; + if (action === "enter") { + document.documentElement.requestFullscreen(); + } else if (action === "exit") { + document.exitFullscreen(); + } + } + isInFullscreen() { + return document.fullscreenElement !== null; + } + } + + Scratch.extensions.register(new FullscreenExtension()); +})(Scratch);