Greasy Fork is available in English.

Quicker-替换【我喜欢的】中子程序的打开的命令

【Quicker网站个人中心-我喜欢的】中的子程序打开命令不正确,点击后会报错,本脚本修复了此bug

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください。
// ==UserScript==
// @name         Quicker-替换【我喜欢的】中子程序的打开的命令
// @namespace    http://tampermonkey.net/
// @version      1.0
// @description  【Quicker网站个人中心-我喜欢的】中的子程序打开命令不正确,点击后会报错,本脚本修复了此bug
// @author       HDG
// @match        https://getquicker.net/Member/MyFavor
// @icon         
// @grant        none
// @run-at       document-end
// ==/UserScript==

(function() {
    'use strict';
    const table = document.querySelector('.table-hover');
    const existingIds = new Set(); // 用于存储已处理的ID
    const observer = new MutationObserver(() => {
        // 获取表格
        if (!table) return;

        // 获取第一列的单元格
        const rows = table.querySelectorAll('tr');

        rows.forEach(row => {
            const firstCell = row.cells[0]; // 获取第一列单元格
            if (firstCell) {
                const cellContent = firstCell.textContent.trim();
                const iconElement = firstCell.querySelector('i[data-copy]');
                if (iconElement) {
                    const dataCopy = iconElement.getAttribute('data-copy');
                    if (dataCopy) {
                        const id = new URL(dataCopy).searchParams.get("id");

                        // 只处理新增的部分
                        if (!existingIds.has(id)) {
                            existingIds.add(id); // 将ID添加到已处理集合中

                            // 获取同一行第五列的元素(命令)
                            const fifthCell = row.cells[4]; // 获取第五列单元格
                            if (fifthCell) {
                                const anchorElement = fifthCell.querySelector('a');
                                if (anchorElement) {
                                    anchorElement.href = `quicker:previewsp:${id}`;
                                }
                            }
                        }
                    }
                }
            }
        });
    });

    // 配置观察选项
    observer.observe(table, {
        childList: true,
        subtree: true
    });
})();