DeepSeek No Auto-Scroll

Block auto-scroll in DeepSeek while keeping manual scroll control

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         DeepSeek No Auto-Scroll
// @description  Block auto-scroll in DeepSeek while keeping manual scroll control
// @match        *://*.deepseek.com/*
// @version 0.0.1.20250514122428
// @namespace https://greasyfork.org/users/1435046
// ==/UserScript==

(function() {
    'use strict';

    function applyNoAutoScroll(scrollContainer) {
        Object.defineProperty(scrollContainer, 'scrollTop', {
            set: function() {}, 
            get: () => scrollContainer._realScrollTop || 0,
            configurable: true
        });
        scrollContainer.addEventListener('scroll', () => {
            scrollContainer._realScrollTop = scrollContainer.scrollTop;
        });
    }

    // Create and start one observer
    const observer = new MutationObserver(() => {
        const scrollContainers = document.querySelectorAll('div.scrollable');
        scrollContainers.forEach(container => {
            if (!container._noAutoScrollApplied) {
                container._noAutoScrollApplied = true;
                applyNoAutoScroll(container);
            }
        });
    });
    observer.observe(document.body, { childList: true, subtree: true });

    // Also run once immediately in case containers already exist
    document.querySelectorAll('div.scrollable').forEach(container => {
        if (!container._noAutoScrollApplied) {
            container._noAutoScrollApplied = true;
            applyNoAutoScroll(container);
        }
    });
})();