Notion Navigation Fixer

Allow browser nav options like back forward pgup pgdown

当前为 2019-06-05 提交的版本,查看 最新版本

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         Notion Navigation Fixer
// @namespace    http://tampermonkey.net/
// @version      0.2
// @description  Allow browser nav options like back forward pgup pgdown
// @author       Andreas Huttenrauch
// @match        *://www.notion.so/*
// @run-at       document-end
// ==/UserScript==

console.log("fixing nav");

document.addEventListener('mousedown', function(e) {
    console.log(e);
    if ( (e.buttons & 8) == 8 ) {
        e.stopImmediatePropagation();
        e.preventDefault();
        window.history.back();
    }
    if ( (e.buttons & 16) == 16 ) {
        e.stopImmediatePropagation();
        e.preventDefault();
        window.history.forward();
    }
});

document.addEventListener('keydown', function(e) {
    console.log(e);
    /*
    if ( e.target.contentEditable ) {
        console.log("not moving because you are editing something important");
        return;
    }
    */
    var mainDiv = document.querySelector(".notion-frame .notion-scroller");
    if ( mainDiv == "undefined" ) return;
    var scrollAmt = parseInt(window.innerHeight*0.8);
    if ( e.keyCode == 34 && e.shiftKey == false && e.ctrlKey == false ) {
        e.stopImmediatePropagation();
        e.preventDefault();
        mainDiv.scrollBy(0, scrollAmt);
    }
    if ( e.keyCode == 33 && e.shiftKey == false && e.ctrlKey == false ) {
        e.stopImmediatePropagation();
        e.preventDefault();
        mainDiv.scrollBy(0, -scrollAmt);
    }
});