Auto-Sort RuneLite.net Plugin Hub

Automatically selects "Sort by time added" on RuneLite plugin hub

이 스크립트를 설치하려면 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         Auto-Sort RuneLite.net Plugin Hub
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  Automatically selects "Sort by time added" on RuneLite plugin hub
// @author       Vexy
// @match        https://runelite.net/plugin-hub/*
// @grant        none
// @license      GNU GPLv3
// ==/UserScript==

(function () {
    'use strict';

    // Function to sort by "time added"
    function sortByTimeAdded() {
        // Make a list of dropdown options
        const buttons = document.querySelectorAll('.dropdown-menu .dropdown-item');
        for (const button of buttons) {
            // If button text is "Sort by time added", click it
            if (button.textContent.trim() === 'Sort by time added') {
                // Simulate a click on the button
                button.click();
                console.log('Sorted by time added');
                break;
            }
        }
    }

    // Wait for the dropdown menu to be present
    const observer = new MutationObserver(() => {
        if (document.querySelector('.dropdown-menu')) {
            observer.disconnect(); // Stop observing once found
            sortByTimeAdded(); // Trigger the sorting
        }
    });

    // Start observing the document for changes
    observer.observe(document.body, { childList: true, subtree: true });
})();