Notion.so DOMLock bypass

Disable notion.so DOMLock, which prevents DOM modification from extensions.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Notion.so DOMLock bypass
// @description  Disable notion.so DOMLock, which prevents DOM modification from extensions.
// @namespace    http://tampermonkey.net/
// @version      0.1
// @author       Sophie Saiada (sophies.dev)
// @license MIT
// @include      https://www.notion.so/*
// @grant        none
// ==/UserScript==

(function () {
  const lockAfterRenderRegex =
    /\W+at [a-zA-Z]+\.lockAfterRender \(https:\/\/www.notion.so\/app/;
  // eslint-disable-next-line no-proto
  const mutationObserverPrototype = MutationObserver.prototype;
  const originalObserve = mutationObserverPrototype.observe;
  mutationObserverPrototype.observe = function () {
    const stackLines = new Error().stack.split("\n");
    if (
      stackLines.some(function (line) {
        return line.match(lockAfterRenderRegex) !== null;
      })
    ) {
      return;
    }
    originalObserve.call(this, ...arguments);
  };
})();