FreshRSS Double-Tap and Auto-Scroll

Double-tap to close active articles and auto-scroll to the active article in FreshRSS.

当前为 2025-02-04 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         FreshRSS Double-Tap and Auto-Scroll
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  Double-tap to close active articles and auto-scroll to the active article in FreshRSS.
// @author       Your Name
// @homepage     https://greasyfork.org/en/scripts/525912
// @match        http://192.168.1.2:1030/*
// @grant        none
// ==/UserScript==

(function () {
    'use strict';

    // Double-tap event to close active articles
    document.addEventListener('dblclick', function (event) {
        // Check if the double-tap is on an interactive element
        const interactiveElements = ['A', 'BUTTON', 'INPUT', 'TEXTAREA', 'SELECT', 'LABEL'];
        if (interactiveElements.includes(event.target.tagName)) {
            return; // Ignore double-taps on interactive elements
        }

        // Find the closest element with 'active' classes
        const activeElement = event.target.closest('.active');
        if (activeElement) {
            // Remove the 'active' class
            activeElement.classList.remove('active');
            // console.log('Removed "active" class from:', activeElement);

            // Scroll the page to the closed article (activeElement)
            activeElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
        }
    });

    // Automatically scroll to the active article when it gains the 'active' class
    const observeActiveElements = () => {
        // Set up a MutationObserver to watch for changes to the 'active' class
        const observer = new MutationObserver((mutations) => {
            mutations.forEach((mutation) => {
                if (mutation.type === 'attributes' && mutation.attributeName === 'class') {
                    const targetElement = mutation.target;
                    if (targetElement.classList.contains('active')) {
                        // Scroll the active element into view
                        targetElement.scrollIntoView({ behavior: 'smooth', block: 'top' });
                    }
                }
            });
        });

        // Observe all elements with the 'flux' class (potential candidates for 'active')
        const currentElements = document.querySelectorAll('.flux');
        currentElements.forEach((element) => {
            observer.observe(element, { attributes: true });
        });
    };

    // Start observing for changes
    observeActiveElements();
})();