Readable Textarea Expander

Expands small textareas to improve readability and editing comfort on common websites.

이 스크립트는 직접 설치하는 용도가 아닙니다. 다른 스크립트에서 메타 지시문 // @require https://update.greasyfork.org/scripts/570704/1780717/Readable%20Textarea%20Expander.js을(를) 사용하여 포함하는 라이브러리입니다.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Readable Textarea Expander
// @namespace    https://example.com/userscripts
// @version      1.0.0
// @description  Expands small textareas to improve readability and editing comfort on common websites.
// @match        *://*/*
// @grant        none
// ==/UserScript==

(function () {
    'use strict';

    // Minimum height for textareas that are too small
    const MIN_HEIGHT = 220;

    // Apply better sizing to a textarea
    function improveTextarea(textarea) {
        if (!(textarea instanceof HTMLTextAreaElement)) {
            return;
        }

        // Avoid processing the same textarea multiple times
        if (textarea.dataset.expanderApplied === 'true') {
            return;
        }
        textarea.dataset.expanderApplied = 'true';

        const computedStyle = window.getComputedStyle(textarea);
        const currentHeight = parseFloat(computedStyle.height) || textarea.offsetHeight;

        if (currentHeight < MIN_HEIGHT) {
            textarea.style.minHeight = `${MIN_HEIGHT}px`;
        }

        textarea.style.resize = 'vertical';
        textarea.style.lineHeight = '1.5';
        textarea.style.padding = '10px';
        textarea.style.boxSizing = 'border-box';
    }

    // Process all existing textareas
    function processPage() {
        const textareas = document.querySelectorAll('textarea');
        textareas.forEach(improveTextarea);
    }

    // Watch for dynamically added textareas
    const observer = new MutationObserver(() => {
        processPage();
    });

    observer.observe(document.documentElement, {
        childList: true,
        subtree: true
    });

    // Run once on load
    processPage();
})();