AtCoder Customize Panel Fix

keep customize panel open when reloading standings page

2024/10/03のページです。最新版はこちら

スクリプトをインストールするには、Tampermonkey, GreasemonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyUserscripts のような拡張機能のインストールが必要です。

このスクリプトをインストールするには、Tampermonkeyなどの拡張機能をインストールする必要があります。

このスクリプトをインストールするには、ユーザースクリプト管理ツールの拡張機能をインストールする必要があります。

(ユーザースクリプト管理ツールは設定済みなのでインストール!)

このスタイルをインストールするには、Stylusなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus などの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus tなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

(ユーザースタイル管理ツールは設定済みなのでインストール!)

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==UserScript==
// @name         AtCoder Customize Panel Fix
// @namespace    https://fuwa.dev/
// @version      0.1
// @description  keep customize panel open when reloading standings page
// @author       ibuki2003
// @match        https://atcoder.jp/contests/*/standings
// @grant        none
// ==/UserScript==

(function() {
    'use strict';
    const observer = new MutationObserver(function (mutations) {
        if (document.querySelector('#standings-panel-heading form') !== null) { // search for panel element
            observer.disconnect(); // only once
            console.table(mutations);
            // const v = vueStandings.filterPanelActive; // last state
            const v = true; // always open

            vueStandings.filterPanelActive = !v;
            vueStandings.$nextTick(() => { // update later
                vueStandings.filterPanelActive = v;
            });
            console.log(v);
        }
    });

    observer.observe(vueStandings.$el, {
        childList: true,
        subtree: true
    });
})();