North-Plus MarkRead

Mark read thread.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey, Greasemonkey или Violentmonkey.

Для установки этого скрипта вам необходимо установить расширение, такое как Tampermonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Userscripts.

Чтобы установить этот скрипт, сначала вы должны установить расширение браузера, например Tampermonkey.

Чтобы установить этот скрипт, вы должны установить расширение — менеджер скриптов.

(у меня уже есть менеджер скриптов, дайте мне установить скрипт!)

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

(у меня уже есть менеджер стилей, дайте мне установить скрипт!)

// ==UserScript==
// @name         North-Plus MarkRead
// @namespace    https://github.com/sssssssl
// @version      0.1
// @description  Mark read thread.
// @author       sl
// @match        https://*.white-plus.net/thread.php?fid-*
// @match        https://*.south-plus.net/thread.php?fid-*
// @match        https://*.imoutolove.me/thread.php?fid-*
// @grant GM_setValue
// @grant GM_getValue
// ==/UserScript==

(function() {
    'use strict';

    const CLS_THREAD = '.tr3.t_one';
    const TD_ID_PAT = /td_(\d+)/;
    const KEY_VISITED_TD = 'visited_id';
    const CLS_UNREAD = 'np-unread';

    const NP_UNREAD_STYLE = `
    <style>
    .np-unread {
        font-weight : bold;
    }
    </style>`;

    let threads = document.querySelectorAll(CLS_THREAD);

    let visitedThreads = GM_getValue(KEY_VISITED_TD);
    if(!visitedThreads) {
        visitedThreads = [];
    }

    document.head.insertAdjacentHTML('beforeend', NP_UNREAD_STYLE);

    threads.forEach((elem) => {
        let _td = elem.querySelector('td[id]');
        if(_td) {
            let m = TD_ID_PAT.exec(_td.id);
            if(m) {
                let id = parseInt(m[1]);
                if(visitedThreads.indexOf(id) == -1) {
                    let title = _td.querySelector('h3 a');
                    title.classList.add(CLS_UNREAD);

                    _td.onclick = () => {
                        let idx = visitedThreads.indexOf(id);
                        if(idx == -1) {
                            visitedThreads.push(id);
                            GM_setValue(KEY_VISITED_TD, visitedThreads);
                            console.log(`${id} clicked.`);
                        }
                    };
                }
            }
        }
    });

    // Your code here...
})();