AtCoder Search Query Holder

「すべての提出」「自分の提出」ページを遷移し合うときに検索条件を保持する

目前為 2023-02-25 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         AtCoder Search Query Holder
// @namespace    https://twitter.com/cpg_tea
// @version      1.0
// @description  「すべての提出」「自分の提出」ページを遷移し合うときに検索条件を保持する
// @author       gmm_tea
// @license      MIT
// @match        https://atcoder.jp/contests/*/submissions?*
// @match        https://atcoder.jp/contests/*/submissions/me?*
// @grant        none
// ==/UserScript==

(function() {
    "use strict";

    // 「すべての提出」「自分の提出」ボタンを取得
    const ul = document.querySelector("#main-container > div.row > div:nth-child(2) > ul");
    const buttons = Array.from(ul.querySelectorAll("li > a")).slice(0, 2);

    // リンク先に今の検索条件を書き加える
    buttons.forEach((button) => button.setAttribute("href", button.getAttribute("href") + location.search));
})();