Disable WakeLock for Twitter

Prevent Twitter from blocking system hibernation by preventing videos from looping. (Translated by DeepL)

이 스크립트를 설치하려면 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         Disable WakeLock for Twitter
// @namespace    https://github.com/ipcjs
// @version      0.1
// @description  Prevent Twitter from blocking system hibernation by preventing videos from looping. (Translated by DeepL)
// @author       ipcjs
// @match        https://twitter.com/*
// @grant        none
// @run-at       document-start
// ==/UserScript==

new MutationObserver((mutations, observer) => {
    for (const m of mutations) {
        for (const node of m.addedNodes) {
            if (node.nodeType === Node.ELEMENT_NODE) {
                /** @type {HTMLVideoElement[]} */
                const videos = Array.from((node).querySelectorAll('video'))
                for (const video of videos) {
                    // console.log('video', m.type, video)
                    video.addEventListener('seeked', function (ev) {
                        // console.log('seeked', ev, this.currentTime)
                        // Twitter的自动循环播放功能, seek的位置一般在0.02以下
                        if (this.currentTime < 0.02) {
                            console.debug('prevent looping', this)
                            this.pause()
                        }
                    })
                }
            }
        }
    }
}).observe(document.documentElement, {
    childList: true,
    subtree: true,
})