DetectTextStateChange

Отслеживание элементов ввода текста на форуме и защита от случайного перехода

이 스크립트를 설치하려면 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         DetectTextStateChange
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  Отслеживание элементов ввода текста на форуме и защита от случайного перехода
// @author       vuchaev2015
// @match        https://zelenka.guru/*
// @icon         data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==
// @grant        none
// ==/UserScript==

let element = document.querySelector('.fr-wrapper');

let lastState = null;

let observer = new MutationObserver(function(mutations) {
    mutations.forEach(function(mutation) {
        if (mutation.attributeName === "class") {
            let classList = mutation.target.classList;
            if (classList.contains('show-placeholder')) {
                if (lastState !== 'empty') {
                    lastState = 'empty';
                }
            } else {
                if (lastState !== 'filled') {
                    lastState = 'filled';
                }
            }
        }
    });
});

observer.observe(element, { attributes: true });

window.addEventListener('beforeunload', function (e) {
    if (lastState === 'filled') {
        e.preventDefault();
        e.returnValue = '';
    }
});