Notion TOC

try to take over the world!

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

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

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         Notion TOC
// @namespace    http://tampermonkey.net/
// @version      0.2.5
// @description  try to take over the world!
// @author       You
// @match        https://www.notion.so/*
// @grant        none
// ==/UserScript==

(function () {
    "use strict";
    const initToc = (el) => {
        el.style.boxSizing = "border-box";
        el.style.width = "auto";
        el.style.maxHeight = "calc(100% - 160px)";
        el.style.overflowY = "auto";
        el.style.position = "fixed";
        el.style.top = "50%";
        el.style.left = "50%";
        el.style.zIndex = 1;
        el.style.transform = "translate(500px, -50%)";
    };

    const observer = new MutationObserver((mutations, self) => {
        var el = document.querySelector(".notion-table_of_contents-block");
        if (el) {
            initToc(el);
            self.disconnect();
        }
    });

    observer.observe(document, {
        childList: true,
        subtree: true,
    });
})();