Continue playing MISSAV

Prevents the video from stopping when clicking off-screen.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Continue playing MISSAV
// @name:ja      Continue playing MISSAV
// @namespace    http://tampermonkey.net/
// @version      2025-10-18-01
// @description  Prevents the video from stopping when clicking off-screen.
// @description:ja 画面外クリック時に動画が停止するのを防ぎます。
// @author       musuni
// @match        https://missav.live/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=hyperts.net
// @grant        none
// @license MIT
// ==/UserScript==

'use strict'

const getStackTrace = () => {
    const obj = {}
    Error.captureStackTrace(obj, getStackTrace)
    return obj.stack
}

const pausedByUser = (stackTrace) => {
    return stackTrace.includes('at wt.togglePlay')
}

const sleep = ms => {
    return new Promise(resolve => setTimeout(resolve, ms))
}

const waitUntilPlayerLoaded = async () => {
    while (!window.player || !window.player.pause) {
        console.log('[Continue playing MISSAV] Player is not loaded yet...')
        await sleep(1000)
    }
    console.log('[Continue playing MISSAV] Player is loaded!')
}

waitUntilPlayerLoaded().then(() => {
    window.player.pause = () => {
        if (pausedByUser(getStackTrace())) {
            window.player.media.pause()
        }
    }
})