Highlight JS

Loads the ace code editor when going to a .js file

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

You will need to install an extension such as Tampermonkey to install this script.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         Highlight JS
// @namespace    http://tampermonkey.net/
// @version      1
// @description  Loads the ace code editor when going to a .js file
// @author       pooiod7
// @icon         https://www.google.com/s2/favicons?sz=64&domain=js.org
// @match        *://*/*.js
// @grant        none
// ==/UserScript==

(function() {
    if (!document.body) return;
    fetch(window.location.href).then(r => r.text()).then(t => {
        let trimmed = t.trim().toLowerCase();
        if (trimmed.startsWith('<!doctype html') || trimmed.startsWith('<html')) return;
        document.body.style.margin = '0';
        document.body.innerHTML = '<div id="editor" style="height:100vh;width:100vw;"></div>';
        let script = document.createElement('script');
        script.src = 'https://cdnjs.cloudflare.com/ajax/libs/ace/1.15.2/ace.js';
        script.onload = () => {
            let editor = ace.edit("editor");
            editor.session.setMode("ace/mode/javascript");
            editor.setShowPrintMargin(false);
            editor.setHighlightActiveLine(false);
            let darkMode = window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches;
            editor.setTheme(darkMode ? "ace/theme/monokai" : "ace/theme/tomorrow");
            editor.setValue(t, -1);
        };
        document.body.appendChild(script);
    });
})();