From a23d7ea47c7ec8cfee9f5c60932ce64a830dbb50 Mon Sep 17 00:00:00 2001 From: veggiecan0419 <137440114+veggiecan0419@users.noreply.github.com> Date: Sat, 26 Aug 2023 23:33:15 +0300 Subject: [PATCH] Add veggiecan/browserfullscreen extension (#778) --- extensions/extensions.json | 1 + extensions/veggiecan/browserfullscreen.js | 103 ++++++++++++++++++++++ 2 files changed, 104 insertions(+) create mode 100644 extensions/veggiecan/browserfullscreen.js diff --git a/extensions/extensions.json b/extensions/extensions.json index 659449ef4f..2cf066f897 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);