All Projects → khanhas → Spicetify

khanhas / Spicetify

Licence: gpl-3.0
Spice up your Spotify client

Programming Languages

javascript
184084 projects - #8 most used programming language

Projects that are alternatives of or similar to Spicetify

Spicetify Themes
A community-driven collection of themes for customizing Spotify through Spicetify (https://github.com/khanhas/spicetify-cli)
Stars: ✭ 3,034 (+337.81%)
Mutual labels:  customization, spotify
Spicetify Cli
Commandline tool to customize Spotify client. Supports Windows, MacOS and Linux.
Stars: ✭ 9,316 (+1244.3%)
Mutual labels:  customization, spotify
Homehost
self-hosted, Netflix-like app made for streaming
Stars: ✭ 564 (-18.61%)
Mutual labels:  spotify
Rpi Audio Receiver
Raspberry Pi Audio Receiver with Bluetooth A2DP, AirPlay, UPnP and Spotify Connect
Stars: ✭ 650 (-6.2%)
Mutual labels:  spotify
Lyricfier
a Spotify Lyrics alternative app | New updates at https://github.com/emilioastarita/lyricfier2 (a faster version in golang)
Stars: ✭ 598 (-13.71%)
Mutual labels:  spotify
Sconsify
A spotify console application
Stars: ✭ 572 (-17.46%)
Mutual labels:  spotify
Clone Wars
100+ open-source clones of popular sites like Airbnb, Amazon, Instagram, Netflix, Tiktok, Spotify, Whatsapp, Youtube etc. See source code, demo links, tech stack, github stars.
Stars: ✭ 12,604 (+1718.76%)
Mutual labels:  spotify
Spotifyadblock
Protect your privacy by blocking all annoying Spotify ads & analytics in Linux, OSX and Windows with hosts file.
Stars: ✭ 540 (-22.08%)
Mutual labels:  spotify
I3 Gnome
Use i3wm/i3-gaps with GNOME Session infrastructure.
Stars: ✭ 677 (-2.31%)
Mutual labels:  customization
Muse
An open-source Spotify controller with TouchBar support
Stars: ✭ 594 (-14.29%)
Mutual labels:  spotify
Spotify Adblock Linux
Spotify adblocker for Linux
Stars: ✭ 641 (-7.5%)
Mutual labels:  spotify
Secureuxtheme
🎨 A secure boot compatible in-memory UxTheme patcher
Stars: ✭ 586 (-15.44%)
Mutual labels:  customization
Lofi
🎵🔉 A mini Spotify player with WebGL visualizations.
Stars: ✭ 583 (-15.87%)
Mutual labels:  spotify
Monstercat Visualizer
A real time audio visualizer for Rainmeter similar to the ones used in the Monstercat videos.
Stars: ✭ 571 (-17.6%)
Mutual labels:  spotify
Spotify Web Api Php
A PHP wrapper for Spotify's Web API.
Stars: ✭ 652 (-5.92%)
Mutual labels:  spotify
Emacs Elisp Programming
Tutorial about programming Elisp and Emacs text editor customization.
Stars: ✭ 548 (-20.92%)
Mutual labels:  customization
Spotify Dl
Downloads songs from your Spotify Playlist
Stars: ✭ 578 (-16.59%)
Mutual labels:  spotify
Spotify Downloader
Download your Spotify playlists and songs along with album art and metadata (from YouTube if a match is found).
Stars: ✭ 6,957 (+903.9%)
Mutual labels:  spotify
Emagnet
Automated hacking tool that will find leaked databases with 97.1% accurate to grab mail + password together from recent uploads from https://pastebin.com. Bruteforce support for spotify accounts, instagram accounts, ssh servers, microsoft rdp clients and gmail accounts
Stars: ✭ 688 (-0.72%)
Mutual labels:  spotify
Spark
🎨 An Android library to create gradient animation like Instagram&Spotify
Stars: ✭ 669 (-3.46%)
Mutual labels:  spotify

Logo

Tool to customize Spotify client UI and expand functionalities. Supports only Windows.

This repo is no longer maintained.

Windows, Linux and MacOS users, please check out https://github.com/khanhas/spicetify-cli

GitHub release Github All Releases Join the community on Spectrum

How to use

1. Download and install Rainmeter (require version >= 4.1)
2. Download and install rmskin package in release page
3. Load Spicetify skin in Rainmeter Manage
4. Choose Backup in skin UI to start backing up original Spotify files
5. Pick color scheme, edit CSS then Apply

Note: Only Spotify normal version is supported. Windows Store version is under a write permission required folder so I can't make it work. Normal Spotify installer can be downloaded here.

Demo1

Outline

Custom CSS

To sastify any web developer that has experience with CSS, Inject CSS option will allow you to customize your Spotify client even more.

I included in install package my own CSS theme:

Demo2

Note: If you prefer original Spotify UI, please clear user.css file or uncheck Inject CSS.

To use color variables, check out Custom CSS wiki page.

Themes

If you have multiple themes in Themes folder, click at back and next buttons to rotate through all of them. You also can create new theme and duplicate current theme instantly by using right mouse context menu.

Demo3

Extensions

Spicetify also allows you inject custom Javascript to support your theme or enhance your Spotify client functionalities.

I included some extensions in install package you might find useful, activate them in Spicetify then Apply/Re-apply:

Auto Skip Videos

Videos are unable to play in some regions because of Spotify's policy. Instead of jumping to next song in playlist, it just stops playing. And it's kinda annoying to open up the client to manually click next every times it happens. Use this extension to skip them automatically.

Christian Spotify

Auto skip explicit tracks

Ext_ChristianDemo

DJ Mode

Easily setting up the client for your friends or audiences to choose, add song to queue but prevent them to control player. Plays button in album track list/playlist are re-purposed to add track to queue, instead of play track directly. Hide Controls option also allow you to hide all control button in player bar, Play/More/Follow buttons in cards.

Ext_DJDemo

Queue All

You like using Discover, New Releases page to find new music but adding each one of them to queue takes a lot of effort? If so, activate this extensions and apply. At top of every carousel now has a "Queue All" button to help you add all of them to queue. Note: Not available for playlist carousels. Just songs, albums ones.

QueueAllDemo

Shuffle+

Detect current context (playlist, album, user collection or show), gather all its items and shuffle them with Fisher–Yates algorithm. After injecting this extension, go to Queue and you can find 2 new buttons at page header: - Shuffle Context: detect current context and shuffle all its item. - Shuffle Queue: shuffle only 80 items or less that are visible in Queue page. It's only useful for mixed context queue. For most of the time, just use Shuffle Context.

Shuffle_1 Shuffle_2

Trash Bin

Throw songs/artists to trash bin and never hear them again (automatically skip). This extension will append a trash bin button in player bar and one in every artist page header. Button in player bar will immediately skip and add that song to trash list. Button in artist page will add that artist in trash list and skip whenever his/her songs play.

Ext_Trash1 Ext_Trash2

WebNowPlaying Companion

For Rainmeter user only. Works exactly like WebNowPlaying Companion for browser, get song information and control player directly with WebNowplaying plugin.

Check out Extension wiki page for list of useful functions, object.

Apps

Inject custom apps to Spotify and access them in left sidebar.

I included my own app to demonstrate how to make and inject an app:

Reddit

Fetching top 100 Spotify posts in any subreddit. This app has native feels and behavior just like other Spotify apps: you can follow, save, play, open playlist/track/album directly. Moreover, it also can fetch Youtube posts and play them inside Spotify.

RedditDemo

Check out App wiki page for some app making tips.

Community themes

Thicktify by 8roly

thicktify

How it works

Spotify UI is HTML/CSS and runs inside Chromium Embedded Framework[1]. All CSS files controlling element attributes and interaction are packed in SPA files (they basically are ZIP).

These CSS files are extracted first then go through a preparation process that finds and replaces almost all colors with specific keywords.

When user applies his/her own colors scheme, all keywords are replaced with actual colors value, both in hex and RRR,GGG,BBB format.

After that, modded CSS and remaining files are transferred back to Spotify directory.

How to contribute

  1. Install Rainmeter if you have not.

  2. Download this repo and unzip to Documents\Rainmeter\Skins.
    or use git:

cd %userprofile%\Documents\Rainmeter\Skins
git clone https://github.com/khanhas/Spicetify.git

Everything you need to run is already in repo.
3. (Optional) Install Nodejs and yarn to run/install some tools and scripts that make development process easier.

Credits

Thanks actionless for his oomoxify script that this skin is based on.
Thanks tjhrulz for his WebNowPlaying Browser Extension and MessagePassing plugin.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].