Greasy Fork is available in English.

Show Saved Video's Position | Invidious

show position where you stopped watching video at thumbnails. (Don't forget to turn on that function!)

// ==UserScript==
// @name Show Saved Video's Position | Invidious
// @description show position where you stopped watching video at thumbnails. (Don't forget to turn on that function!)
// @namespace -
// @version 1.0.2
// @author NotYou
// @include *://invidious.snopyta.org/*
// @include *://yewtu.be/*
// @include *://invidious.kavin.rocks/*
// @include *://vid.puffyan.us/*
// @include *://invidious.namazso.eu/*
// @include *://inv.riverside.rocks/*
// @include *://youtube.076.ne.jp/*
// @include *://yt.artemislena.eu/*
// @include *://invidious.flokinet.to/*
// @include *://invidious.esmailelbob.xyz/*
// @include *://invidious.projectsegfau.lt/*
// @include *://inv.bp.projectsegfau.lt/*
// @include *://y.com.sb/*
// @include *://invidious.sethforprivacy.com/*
// @include *://invidious.tiekoetter.com/*
// @include *://invidious.nerdvpn.de/*
// @include *://inv.vern.cc/*
// @include *://invidious.slipfox.xyz/*
// @include *://inv.privacy.com.de/*
// @include *://invidious.rhyshl.live/*
// @include *://invidio.xamh.de/*
// @include *://invidious.dhusch.de/*
// @include *://inv.odyssey346.dev/*
// @include *://c7hqkpkpemu6e7emz5b4vyz7idjgdvgaaa3dyimmeojqbgpea3xqjoid.onion/*
// @include *://w6ijuptxiku4xpnnaetxvnkc5vqcdu7mgns2u77qefoixi63vbvnpnqd.onion/*
// @include *://kbjggqkzv65ivcqj6bumvp337z6264huv5kpkwuv6gu5yjiskvan7fad.onion/*
// @include *://grwp24hodrefzvjjuccrkw3mjq4tzhaaq32amf33dzpmuxe7ilepcmad.onion/*
// @include *://osbivz6guyeahrwp2lnwyjk2xos342h4ocsxyqrlaopqjuhwn2djiiyd.onion/*
// @include *://u2cvlit75owumwpy4dj2hsmvkq7nvrclkpht7xgyye2pyoxhpmclkrad.onion/*
// @include *://euxxcnhsynwmfidvhjf6uzptsmh4dipkmgdmcmxxuo7tunp3ad2jrwyd.onion/*
// @include *://invidious.esmail5pdn24shtvieloeedh7ehz3nrwcdivnfhfcedl7gf4kwddhkqd.onion/*
// @include *://inv.vernccvbvyi5qhfzyqengccj7lkove6bjot2xhh5kajhwvidqafczrad.onion/*
// @include *://am74vkcrjp2d5v36lcdqgsj2m6x36tbrkhsruoegwfcizzabnfgf5zyd.onion/*
// @include *://ng27owmagn5amdm7l5s3rsqxwscl5ynppnis5dqcasogkyxcfqn7psid.onion/*
// @include *://verni6dr4qxjgjumnvesxerh5rvhv6oy5ddeibaqy5d7tgbiiyfa.b32.i2p/*
// @license GPL-3.0-or-later
// @grant none
// @icon 
// ==/UserScript==

let thumbs = document.querySelectorAll('div.thumbnail')
let style = `.progress-bar {
  width: var(--percentage);
  display: block;
  height: 4.5px;
  pointer-events: none;
  position: absolute;
  left: 0;
  bottom: 0;
  background: rgb(0, 182, 240);
}`
let styleNode = document.createElement('style')
styleNode.textContent = style
document.querySelector('head').appendChild(styleNode)

for (let i = 0; i < thumbs.length; i++) {
    let thumb = thumbs[i]
    let id = thumb.children[0].src.match(/\/vi\/(.*?)\//)[1]
    let total = thumb.children[1]?.textContent.split(':').map((e, i, a) => multiply(e, a.length - (i + 1))).reduce((a, e) => a + +e, 0)
    let percentage = getPositions()[id] / total * 100
    let progress = document.createElement('div')

    if(percentage) {
        thumb.setAttribute('style', '--percentage:' + percentage + '%')
        progress.className = 'progress-bar'
        thumb.appendChild(progress)
    }
}

function getPositions() {
    return JSON.parse(decodeURIComponent(localStorage.getItem('save_player_pos')))
}

function multiply(x, y) {
	for (let i = 0; i < y; i++) {
        x *= 60
    }

    return x
}