// ==UserScript== // @name IPE禅模式 // @namespace https://thdog.moe/ // @version 0.3 // @description 为IPE添加F11全屏功能 // @author shirokurakana // @match *://thwiki.cc/* // @icon https://static.thbwiki.cc/favicon.ico // @license MIT // @grant none // @downloadURL none // ==/UserScript== (function() { 'use strict'; let isIPEFullScreen = false; // 配置参数 const config = { childList: true, subtree: true }; // 创建观察者 const observer = new MutationObserver((mutations, obs) => { if (document.querySelector('.monaco-container')) { let wraps = document.getElementsByClassName('ssi-modalWrapper'); if (wraps.length > 1) { for (let i = 0; i < wraps.length; i++) { let wrap = wraps[i]; let delWrap = false; if (wrap.firstChild === null) { delWrap=true; } else if (wrap.firstChild.id.search('ssi-notify') != -1) { delWrap=true; } if (delWrap) { let parent = wrap.parentElement; parent.removeChild(wrap); i--; } } } if (isIPEFullScreen) { isIPEFullScreen = true; setTimeout(() => { setFullScreen(); }, 200); } } }); // 开始观察 observer.observe(document.documentElement, config); // 监听键盘事件 document.addEventListener('keydown', function(event) { // 检测按下的键是否是F11 if (event.key === 'F11' || event.keyCode === 122) { // 双重兼容判断 // 阻止浏览器默认全屏行为(可选) event.preventDefault(); if (document.querySelector('.monaco-container') === null) { document.querySelector('#edit-btn').click(); isIPEFullScreen = true; setTimeout(() => { setFullScreen(); }, 500); } else { if (isIPEFullScreen) { unsetFullScreen(); isIPEFullScreen = false; } else { setFullScreen(); isIPEFullScreen = true; } } } }); function setFullScreen() { document.querySelector('.monaco-container').style.height = '640px'; document.querySelector('#ssi-modalWrapper').style.width = '100%'; document.querySelector('#ssi-modalWrapper').style.maxWidth = 'unset'; document.querySelector('#ssi-modalWrapper').style.margin = '0 auto'; } function unsetFullScreen() { document.querySelector('.monaco-container').style.height = '386px'; document.querySelector('#ssi-modalWrapper').style.width = '85%'; document.querySelector('#ssi-modalWrapper').style.maxWidth = '900px'; document.querySelector('#ssi-modalWrapper').style.margin = '30px auto 20px'; } })();