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.nerd###.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 ###CZmMpqJC7u7uJpmmlnHMPIeQZo9HYJoriTkmSykVRND/0Zw9NVdWFXC6XzOVyI6qqfsM5HySEKIIgJPx+/5anN117HJ2dnRSAmXO+jXNuBrC8r9AIIYuEkDQhJNPT06Pbne1/Acmz+r5w/zPmAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE5LTA0LTE0VDEzOjEwOjM5LTA0OjAwzYrzKwAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxOS0wNC0xNFQxMzoxMDozOS0wNDowMLzXS5cAAAAASUVORK5CYII= // ==/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 }