Mirror of BetterYTM's source code https://github.com/Sv443/BetterYTM

Sven 52e8f88d6e fix: restore video time edge cases 10 maanden geleden
.github e33368547b ci: upgrade to node v22 6 maanden geleden
.storybook fe424b4191 fix: invis characters 6 maanden geleden
.vscode df21050045 fix: queue btns overhaul 11 maanden geleden
assets 71a9a1b0f8 fix: update translations and remove outdated ones 6 maanden geleden
dist f2a7217e13 chore: build 6 maanden geleden
src 52e8f88d6e fix: restore video time edge cases 6 maanden geleden
.env.template 520689c104 Release 1.1.0 (#35) 1 jaar geleden
.gitignore 479acf2407 feat: install storybook 6 maanden geleden
LICENSE.txt 520689c104 Release 1.1.0 (#35) 1 jaar geleden
README-summary.md 52e8f88d6e fix: restore video time edge cases 6 maanden geleden
README.md 52e8f88d6e fix: restore video time edge cases 6 maanden geleden
changelog.md 6b830a34e7 feat: expose `fetchVideoVotes` function on interface 6 maanden geleden
contributing.md 6b830a34e7 feat: expose `fetchVideoVotes` function on interface 6 maanden geleden
eslint.config.mjs 2dd0a8d754 ref!: remove "remove upgrade tab" feature 6 maanden geleden
license-for-plugins.txt eccf0d259b docs: changelog & plugin loicense 6 maanden geleden
package-lock.json 1a6ad1b7a6 ref: use pnpm for scripts 6 maanden geleden
package.json 7907ceee51 fix: pnpm syntax error 6 maanden geleden
rollup.config.mjs 7907ceee51 fix: pnpm syntax error 6 maanden geleden
tsconfig.json 83b9bc99f5 ref: switch to NodeNext module resolution thanks to a cool eslint plugin 6 maanden geleden

README-summary.md


BetterYTM

Lots of configurable layout and user experience improvements for YouTube Music™ and YouTube™

Supported Languages: 🇩🇪 German, 🇺🇸 English (US), 🇬🇧 English (UK), 🇪🇸 Spanish, 🇫🇷 French, 🇮🇳 Hindi, 🇯🇵 Japanese, 🇵🇹 Portuguese, 🇨🇳 Chinese (simpl.) FeaturesInstallationPluginsSupportDevelopmentAttributionsDisclaimers



Features:

All of these can be toggled and configured in the configuration menu.

  • Layout & User Experience:
    • Auto-like your favorite channels' songs and videos
    • Show the amount of likes and dislikes on songs (powered by returnyoutubedislike.com)
    • Open any song's lyrics on genius.com which generally has higher quality than YouTube's providers
    • Quick actions on songs in a queue, to quickly open their lyrics or remove them from the queue
    • Set a custom size and step resolution for the volume slider and show a percentage label next to it
    • Improvements to clickability of song titles and thumbnails when wanting to open them in a new tab
    • Remember the time of the last played song to resume playback after reloading or reopening the tab
    • Quickly scroll to the currently active song in the queue by clicking a button
    • Remove the tracking parameter from URLs in the share menu
    • Automatically close permanent notifications
  • Input / Interaction:
    • Use arrow keys to skip forward or backward by a configurable amount of time
    • Press number keys to skip to a percentage of the currently playing song
    • Press a hotkey on a video/song to switch between YouTube and YouTube Music, while keeping the video time
    • Prevent the "unsaved data" popup that sometimes appears before leaving the site

... and these are just the notable features, there are many more smaller improvements and bugfixes!


To toggle and configure features, after installing the userscript, click the "BetterYTM" text under the logo to open the configuration menu.
If you disabled the watermark, you can still click your avatar in the top right corner on YTM or open the left sidebar on YT to open it.

My work relies on donations, so if you like this userscript please consider supporting development ❤️



Installation:

Requires a userscript manager browser extension.
I really recommend ViolentMonkey: FirefoxChromeEdge

Once you have the extension, click the install button at the top of this page!


Note: the unsafeWindow grant is required due to limitations in some browsers, see this issue for more info.


To install the latest development build click here (note: the script will not auto-update to the next release version)




Plugins:

BetterYTM supports plugin userscripts that can be installed in parallel and can make use of BetterYTM's pre-existing API.

Currently there are no available plugins, but you can submit an issue using the plugin submission template so it will be listed here.
Also refer to the plugin creation guide for more information on how to use the API to create a plugin.



Support:

If you have any questions, issues, or feature requests, please open an issue here.
You can also join my Discord server and ask your questions there or just hang out with other community members and me:

Discord



Development:

This project is based on my extensive template for making a userscript with TypeScript and many modern language and convenience features.
Check it out here if you want to make your own userscripts!

For information on how to contribute to this project or how to develop a plugin for BetterYTM, see the contributing guide



Attributions:

This userscript depends on these runtime libraries:

For development dependencies, please refer to devDependencies in package.json

Icons:



Disclaimers:

  • I am not affiliated with or endorsed by YouTube, Google, Alphabet, Genius, or anyone else.
  • I do not own any third party icons, I just re-host them here for better stability and availability.
  • I do not intend to ever collect any data about you, everything in this script is done and stored locally on your device or on the site the script runs on.
  • I can't guarantee this software is without flaws. If something bad happens, I don't accept blame. I do however accept bug reports and feature requests.





Made with ❤️ by Sv443
If you like this userscript, please consider supporting me

© 2022 Sv443 - AGPL-3.0