Fullscreen Map

Fullscreen Map with 'M'

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         Fullscreen Map
// @namespace    bennoghg
// @match        https://map-making.app/*
// @grant        none
// @version      1.2.1
// @author       BennoGHG
// @license MIT
// @description  Fullscreen Map with 'M'
// ==/UserScript==

(function() {
    'use strict';

    function isTyping() {
        const el = document.activeElement;
        return el && (
            el.tagName === 'INPUT' ||
            el.isContentEditable
        );
    }

    document.addEventListener('keydown', e => {
        if (e.repeat || e.key.toLowerCase() !== 'm' || isTyping()) return;

        const fsElem = document.fullscreenElement;
        if (fsElem) {
            document.exitFullscreen();
        } else {
            const mapContainer = document.querySelector('.gm-style')?.parentElement;
            if (mapContainer?.requestFullscreen) {
                mapContainer.requestFullscreen();
            }
        }
    });
})();