scroll-navigate-ogs

enable scrolling to navigate game on OGS

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

You will need to install an extension such as Tampermonkey to install this script.

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

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

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

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

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

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

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

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

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

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

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

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

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==UserScript==
// @name        scroll-navigate-ogs
// @namespace   kvwu.io
// @match       https://online-go.com/demo/*
// @match       https://online-go.com/game/*
// @license     MIT
// @version     1.0
// @author      kvwu
// @description enable scrolling to navigate game on OGS
// ==/UserScript==
window.addEventListener('load', (event) => {
  function scrollNavigate(e) {
    e.preventDefault();
    const actionBar = document.getElementsByClassName('action-bar')[0];
    const controls = actionBar.getElementsByClassName('controls')[0].children;
    if (e.deltaY > 0) {
      const next = controls[4];
      next.click();
    } else if (e.deltaY < 0) {
      const prev = controls[2];
      prev.click();
    }
  }

  function setGobanContainerEvent() {
    const gobanContainers = document.getElementsByClassName('goban-container');
    if (gobanContainers.length > 0) {
      const gobanContainer = gobanContainers[0];
      gobanContainer.onwheel = scrollNavigate;
      return;
    }
    setTimeout(setGobanContainerEvent, 300);
  }

  setGobanContainerEvent();
});