.github/workflows | ||
.sass-cache/80ae838cce63531149daf490f23e4fe5c65c681b | ||
.vscode | ||
assets | ||
build | ||
docs | ||
src | ||
.editorconfig | ||
.gitignore | ||
CHANGELOG.md | ||
LICENSE | ||
package-lock.json | ||
package.json | ||
README.md | ||
sass-lint.yml | ||
stale.yml |
Tidal-hifi
The web version of listen.tidal.com running in electron with hifi support thanks to widevine.
Table of contents
- Installation
- Features
- Integrations
- Why
- Why not extend existing projects?
- Special thanks to...
- Buy me a coffee? Please don't
- Images
Installation
Using releases
Various packaged versions of the software are available on the releases tab.
Snap
To install with snap
you need to download the pre-packaged snap-package from this repository, found under releases:
- Download
wget <URI> #for instance: https://github.com/Mastermindzh/tidal-hifi/releases/download/1.0/tidal-hifi_1.0.0_amd64.snap
- Install
snap install --dangerous <path> #for instance: tidal-hifi_1.0.0_amd64.snap
Arch Linux
Arch Linux users can use the AUR to install tidal-hifi:
trizen tidal-hifi-bin
Flatpak
To install via Flatpak run the following command:
flatpak install flathub com.mastermindzh.tidal-hifi
Nix
To install with Nix run the following command:
nix-env -iA nixpkgs.tidal-hifi
Using source
To install and work with the code on this project follow these steps:
- git clone https://github.com/Mastermindzh/tidal-hifi.git
- cd tidal-hifi
- npm install
- npm start
Features
- HiFi playback
- Notifications
- Custom hotkeys (source)
- API for status and playback
- Mute artists automatically (defaults to "Tidal")
- Custom integrations
- Settings feature to disable certain functionality. (
ctrl+=
orctrl+0
) - AlbumArt in integrations (best-effort)
Integrations
Tidal-hifi comes with several integrations out of the box.
You can find these in the settings menu (ctrl + =
by default) under the "integrations" tab.
It currently includes:
- MPRIS - MPRIS media player controls/status
- Discord - Shows what you're listening to on Discord.
Not included:
- i3 blocks config - My dotfiles where I use this app to fetch currently playing music (direct commit)
Known bugs
last.fm doesn't work out of the box. Use rescrobbler as a workaround
The last.fm login doesn't work, as is evident from the following issue: Last.fm login doesn't work. However, in that same issue you can read about a workaround using rescrobbler. For now that will be the default workaround.
Why
I moved from Spotify over to Tidal and found Linux support to be lacking.
When I started this project there weren't any Linux apps that offered Tidal's "hifi" options nor any scripts to control it.
Why not extend existing projects?
Whilst there are a handful of projects attempting to run Tidal on Electron they are all unappealing to me because of various reasons:
- Lack of a maintainers/developers. (no hotfixes, no issues being handled etc)
- Most are simple web wrappers, not my cup of tea.
- Some are DE oriented. I want this to work on WM's too.
- None have widevine working at the moment
Sometimes it's just easier to start over, cover my own needs and then making it available to the public :)
Special thanks to...
- Castlabs For maintaining Electron with Widevine CDM installation, Verified Media Path (VMP), and persistent licenses (StorageID)
Buy me a coffee? Please don't
Instead spend some money on a charity I care for: kwf.nl. Inspired by haydenjames' issue
Images
Settings window
User setups
Some of our users are kind enough to share their usage pictures. If you want to see them or possibly even add one please do so in the following issue: #3 - image thread.