Greasy Fork is available in English.

Enhanced Invidious Player

Adds hotkeys and more to invidious player.

// ==UserScript==
// @name Enhanced Invidious Player
// @version 1.3.0
// @author NotYou
// @description Adds hotkeys and more to invidious player.
// @icon 
// @namespace -
// @include *invidious.snopyta.org/watch?v=*
// @include *yewtu.be/watch?v=*
// @include *uptime.invidious.io/784257752watch?v=*
// @include *invidious.kavin.rocks/watch?v=*
// @include *vid.puffyan.us/watch?v=*
// @include *invidious.namazso.eu/watch?v=*
// @include *inv.riverside.rocks/watch?v=*
// @include *invidious.osi.kr/watch?v=*
// @include *youtube.076.ne.jp/watch?v=*
// @include *yt.artemislena.eu/watch?v=*
// @include *tube.cthd.icu/watch?v=*
// @include *invidious.flokinet.to/watch?v=*
// @include *invidious.weblibre.org/watch?v=*
// @include *invidious.esmailelbob.xyz/watch?v=*
// @include *invidious.lunar.icu/watch?v=*
// @include *invidious.mutahar.rocks/watch?v=*
// @include *inv.bp.projectsegfau.lt/watch?v=*
// @include *y.com.sb/watch?v=*
// @include *invidious.sethforprivacy.com/watch?v=*
// @include *invidious.tiekoetter.com/watch?v=*
// @license GPL-3.0-or-later
// @run-at document-end
// @grant none
// ==/UserScript==

let vid = document.querySelector('video'),
    par = document.querySelector('#contents'),
    diff = 0.021,
    skip = 60

vid.focus()

// SCROLL //

vid.addEventListener('mouseenter', () => {
	vid.focus()
  document.documentElement.style.overflow = 'hidden'
})

vid.addEventListener('mouseleave', () => {
  document.documentElement.style.overflow = 'unset'
})

vid.addEventListener('wheel', e => {
	if (e.deltaY >= 0) {
  	vid.volume >= 0
    	? vid.volume -= diff
    	: vid.volume = 0
  } else if (e.deltaY < 0) {
    if (vid.muted === true) vid.muted = false
    vid.volume < 1
    	? vid.volume += diff
    	: vid.volume = 1
  }
})

// HOTKEYS //

vid.addEventListener('keydown', e => {
  if (e.key === 'm') vid.muted = vid.muted === false ? true : false
  if (e.key === 'r') vid.loop = vid.loop === false ? true : false
  if (e.key === 't') par.style.width = par.style.width === '' ? '100%' : ''
  if (e.key === 'c') {
    if (e.ctrlKey === true) navigator.clipboard.writeText(vid.currentSrc)
    else navigator.clipboard.writeText(JSON.parse(document.querySelector('#player_data').textContent.replaceAll('\n', '')).title)
  }
  if (e.key === 'ArrowRight') if (e.ctrlkey === true) if (vid.currentTime+skip < vid.duration) vid.currentTime += skip
  if (e.key === 'ArrowLeft') if (e.ctrlkey === true) if (vid.currentTime-skip > 0) vid.currentTime -= skip
  if (e.key === 'f') {
    let el = document.querySelector('div#player') || vid
  	if (el.requestFullscreen) el.requestFullscreen()
  	else if (el.webkitRequestFullscreen) el.webkitRequestFullscreen()
  	else if (el.msRequestFullscreen) el.msRequestFullscreen()
  }
  if (e.code === 'Numpad0' || e.code === 'Numpad1') rateTo(1)
  if (e.code === 'Numpad2') rateTo(2)
  if (e.code === 'Numpad3') rateTo(2.5)
  if (e.code === 'Numpad4') rateTo(3)
})

// FUNCS

function rateTo(n) {
  vid.playbackRate = n
}