Show HN: A Chrome extension to give you back control over short-form videos
chromewebstore.google.com122 points by darajava 2 days ago
122 points by darajava 2 days ago
Hi HN! I built this little extension to prevent, in my opinion, the most offensive anti-pattern used by tech companies. That is removing the seek bar in short-form videos.
The "seek bar" is the bar at the bottom of a video that progresses as you play the video, and that you can click on or drag to skip around. Why companies ever thought it was a good idea to get rid of this I don't know, but I find it infuriating, so I decided to add it back for myself and thought others might like it too.
ReelControl adds a progress bar and seeking capabilities to videos on Instagram, YouTube Shorts, and Facebook Reels.
I do sometimes enjoy watching short-form content and I've found that with this extension enabled I can be more mindful about it and get sucked in way less. I'm also on my phone less because I tend to favor the web versions of these platforms now.
Open source--PRs and issues welcome! https://github.com/darajava/seek-anywhere/
I have a simple bookmarklet does does something similar: I turned this into a greasemonkey script: https://greasyfork.org/en/scripts/531780-universal-video-fix... That can be configured to run automatically on every site, and it uses the MutationObserver API to automatically fix any newly added/modified <video> elements on the page. Seems to work great on Snapchat and Instagram so far, but it does break some functionality. Op's chrome extension, with bespoke support for Instagram, likely offers a much better experience. This is just more universal. Ah that's a good idea! Similar effect to this but I guess packaging it in a chrome extension lends itself to "set it and forget it". I also have some customization options. It's also a security risk though, as in someone could take it over and push a bad update at any time... I have a few extensions installed but I'm terrified of adding more, even though there are parts of my browsing experience that could be significantly improved. I really wish there were a middle ground, like an external extension manager where you could opt into updates, with reproducible builds, changelogs, etc. You could add it from source which is pretty easy to do but you lose chrome’s syncing feature. Having said that I haven’t developed a chrome extension in years. They are so strict now. I know they can’t manually inspect each line but I do hope it helps solve the problem of extensions going rogue. This is great. I just asked ChatGPT to convert it into a script that I could use with Violentmonkey. Nice! I still use Greasemonkey and love it. Relatedly, I have a greasemonkey script[1] that makes Snapchat on web much more usable. I just updated it to include this video fixer logic so now it's easy to scrobble videos and download them. It uses the MutationObserver API to immediately 'fix' any <video> element added to the page. Really I should just copy you and make a version of it that just does the video fixing but runs on every site. It's crazy how browsers have a nice built in pro-user video element, but that every site intentionally overrides and degrades it... edit: I went ahead and turned this into a greasemonkey script as well: https://greasyfork.org/en/scripts/531780-universal-video-fix... [1] https://greasyfork.org/en/scripts/468156-unbreak-snapchat-we... For youtube shorts, replacing the "shorts" in URL with "watch" will give you the usual interface, for example: https://www.youtube.com/shorts/GqkmtcirwYA -> https://www.youtube.com/watch/GqkmtcirwYA But actually I see that seek bar is already available in youtube shorts. Maybe it's a recent change? I've noticed the seek bar is available in MOST but not ALL shorts. I always thought it might be an option by the video owner. It's horrible that the web has come to this, a need for a browser hack to restore the UI that some website hacked off. Product designers are going to experiment...Vote with your feet. Don't use horrible products. The only thing worse would be EU mandated progress bars I would love to vote with my feet. How do I watch YouTube or Instagram content with VLC, or some other user friendly video player? Look into LibRedirect and the projects it uses and also things like youtube-dl/yt-dlp. https://libredirect.github.io/ https://libredirect.codeberg.page/ > A web extension that redirects YouTube, Instagram, Reddit, TikTok and other websites to alternative privacy-friendly frontends. https://github.com/mendel5/alternative-front-ends https://github.com/digitalblossom/alternative-frontends mpv understands URLs to these websites and uses yt-dlp to download them. On KDE, I assigned an action to open some URLs with mpv, which means I can play then from the clipboard manager or the copy menu that is displayed when copying if it's enabled. An answer to my wishes ... https://news.ycombinator.com/item?id=43398696 thank you! I wrote a set of uBo rules to do the same on TikTok. Not sure if they still work, but might as well publish it: tiktok.com##sharing-main-video-el:watch-attr(controlslist):remove-attr(controlslist) It seems a bit flakey on mobile, but it was a nice addition to the other enhancements. I haven't been able to make the mobile web as useful as the desktop web version, but didn't want to spend too much time on it either. Thanks for releasing it! Whats the chance of this getting shipped to Firefox users? A future improvement might be to add the ability to change the playback speed :) I've made these for TikTok/Instagram: https://chromewebstore.google.com/detail/video-scrubber-for-... https://addons.mozilla.org/en-US/firefox/addon/video-scrubbe... https://chromewebstore.google.com/detail/video-controls-for-... https://microsoftedge.microsoft.com/addons/detail/video-cont... Thanks for this. I've thought about building this exact thing ever since this vicious trend began. is there a way to "save" a volume for instagram/youtube? i swear their volume is boosted to 200% volume I haven't tried this out but if it works it's one the biggest bang for the buck I've seen on HN. Thanks! Nice. Does this do more than the "Show Video Controls by Default" extension? https://chromewebstore.google.com/detail/show-video-controls... Adding a progress bar back might cause people to just skip to the part they want to see instead of watching the whole thing again though, and I'm worried that might not be in the best interests of the content creator or advertisers. Thanks for sharing! Also, would you mind adding a license to your gh repo? No problem. Yes, I never thought of that! What is the practical benefit of having a license here and which one should I choose? Without a license your repo is technically not open-source, only source-available. A license says what people are allowed to do with the code, so if you don't add a license, they're not allowed to do anything. That's great, I've added an MIT license. https://github.com/darajava/reel-control/commit/4d014f578b93... Having a license clarifies what permissions are you giving to someone who downloads your code. The practical benefit is that others can clearly contribute back or build on your work without any legal concerns. Something like MIT gives them permission to do anything as long as attribution is maintained, while avoiding liabilities. But there are others you can pick: https://choosealicense.com/ Thank you! MIT license added. https://github.com/darajava/reel-control/commit/4d014f578b93... Without a license, legaly nobody can do anything with the code. The license is essentially the way that you communicate what you will allow people to do with it. For a project like this, I would strongly recommend an MIT license. That will essentially allow people to use the code and modify it, contribute back to it, and otherwise distribute their changes. Instant download. Works great. Perhaps on Instagram you can make it save the audio level when the video is muted? If I mute a video then scroll to the next one, the audio still plays. Otherwise, thanks for making this, it's something I've wanted for a long time. For anyone looking: Safari has "Stop The Madness" which has something similar (and much more). Been using this extension to turn shorts back into regular videos for years: https://github.com/raven0230/Remove-Youtube-Shorts That way not only do you get the seek/pause controls back, but other stuff like volume, comments, keyboard shortcuts etc. now work as usual too.
varenc - a day ago
It just re-enables all controls on all <video> elements and uses z-indexing to push them to the top. Works on instagram but needs to be re-ran for new video elements. javascript:(function(){document.querySelectorAll("video").forEach(((e,o)=>{console.log(`VideoFixer: Processing <video> #${o+1}:`,e),e.style.position="relative",e.style.zIndex="999999",e.controls=!0,e.style.pointerEvents="auto";const t=[],i=[];["disablePictureInPicture","disableRemotePlayback"].forEach((o=>{e.hasAttribute(o)&&(t.push(o),e.removeAttribute(o))})),e.hasAttribute("controlsList")&&(i.push(...e.getAttribute("controlsList").split(/\\s+/)),e.removeAttribute("controlsList")),t.length&&console.log(`VideoFixer: Removed attributes: ${t.join(", ")}`),i.length&&console.log(`VideoFixer: Removed controlsList restrictions: ${i.join(", ")}`),t.length||i.length||console.log("VideoFixer: No restrictions found to remove.")})),console.log("VideoFixer: All videos processed.");}());
varenc - 14 minutes ago
darajava - a day ago
rendaw - 19 hours ago
darajava - 12 hours ago
coldtrait - 16 hours ago
varenc - an hour ago
omoikane - a day ago
Sohcahtoa82 - a day ago
NelsonMinar - a day ago
montag - a day ago
mrgoldenbrown - 19 hours ago
aspenmayer - 13 hours ago
jraph - 11 hours ago
uptown - a day ago
Aissen - a day ago
ensignavenger - a day ago
haberdasher - a day ago
robgibbons - a day ago
4jck - a day ago
megadata - a day ago
xnx - a day ago
umvi - a day ago
joshdavham - a day ago
darajava - a day ago
Jitnaught_ - a day ago
darajava - a day ago
captn3m0 - a day ago
darajava - a day ago
freedomben - a day ago
65 - a day ago
mthoms - a day ago
ranger_danger - a day ago