.gitea/workflows | ||
.github/workflows | ||
.jenkins | ||
.vscode | ||
docs | ||
music | ||
src | ||
tests | ||
.babelrc | ||
.dockerignore | ||
.gcloudignore | ||
.gitignore | ||
admin.py | ||
app.yaml | ||
dispatch.test.yaml | ||
dispatch.yaml | ||
Dockerfile | ||
gunicorn.conf.py | ||
main.api.py | ||
main.cron.py | ||
main.run_playlist.py | ||
main.update_tag.py | ||
package-lock.json | ||
package.json | ||
poetry.lock | ||
pyproject.toml | ||
README.md | ||
webpack.common.js | ||
webpack.dev.js | ||
webpack.prod.js |
Mixonomer
Smart playlists for Spotify with Last.fm insights. Mixonomer is a cloud native platform for combining Spotify playlists and enhancing them with recommendations and listening history data. I started the app in 2019, but Spotify have included similar features since then such as enhanced playlists and smart shuffle.
Built on my other libraries for Spotify (spotframework), Last.fm (fmframework) and interfacing utility tools for the two (spotfm). Currently running on a suite of Google Cloud Platform services. An iOS client is currently under development here.
Read the full documentation here. Read the blog post here.
Smart Playlists
Create smart playlists for Spotify including tracks from playlists, library and Spotify recommendations.
Playlists can pull tracks from multiple sources with some extra ones based on the playlist's type.
- Spotify playlists
- Currently referenced by case-sensitive names of those followed by the user
- Plan to include reference by Spotify URI
- Other Mixonomer playlists
- Dynamically include the Spotify playlists of other managed playlists
- Used to allow hierarchy playlists such as for genre (as seen above for multiple rap playlists)
- Spotify Library Tracks
- Monthly Playlists
- ONLY for "Recents" type playlists
- Find user playlists by name in the format "month year" e.g. february 20 (lowercase)
- Can dynamically include this month's and/or last month's playlist at runtime
- Last.fm track chart data
- ONLY for "Last.fm Chart" type playlists
- Include variable number of top tracks in the last date range
When not shuffled, playlists are date sorted with newest at the top for a rolling album artwork of newest releases.
Playlists are updated using the spotframework playlist engine three times a day.
Tags
Groups of Last.fm objects for summing of scrobble counts and listening statistics.
Structure
This repo consists of a front-end written in React.js and Material-UI being served by a back-end written in Flask.
The application is hosted on Google Cloud Infrastructure.
Acknowledgements
Took inspiration from Paul Lamere's smarter playlists.