The Problem
If you're a EDM fan like me you probably know the super traditional website Digitally Imported.
I'm a long time supporter (and I recommend you consider supporting it - streaming bills ain't cheap ya know). But one thing bugged me for a long time: it has no native player like Spotify and Apple Music. And I like changing stations all day long. And I don't like keeping a browser tab exclusively for this.
Since I'm a heavy Alfred user I looked for a workflow but had no luck. So I made one.
The Solution
The workflow editor is pretty neat. You drop boxes and link them in order to make one box's output become the other's input:
And that's it. Just two boxes linked in order to play some electronic music β€οΈ
But wait, there's more!
It would be a very boring article if it ended here, right? π
First of all, the list of radio stations is huge! (99):
double clicking on List Filter
I would never type 99 times each station information... No... I asked our friendly overlord GPT-4 for some help.
Chat GPT to the rescue
All I had was the 99 url slugs for each radio station. When you open a playlist (.pls file) you'll get all the streaming url's in the form:
http://prem1.di.fm/${query}?XXXXXX
Where ${query}
is the station name and XXXX
is your 'Listen key' that can be grabbed on the Settings page.
But in order to fill the workflow's List Filter I needed a .csv file with 3 columns:
- First some words, separated by space, which are searched after you type your workflow's keyword
- A plain text english description that will be shown as a subtitle
- The value that will be passed as the input for the next node on the graph
So the prompt I wrote was basically:
Given the following slugs:
- 00sclubhits
- ambient
- atmosphericbreaks
... (until 99)
Create a three column CSV formatted list of:
- the slug broken in words
- a plain english description of the slug
- the slug unchanged
For example:
- 00sclubhits
in CSV:
00s club hits, 2000's Club Hits, 00sclubhits
And it very kindly generated this csv file. β€οΈ (full disclosure: I removed the header line and removed extra spaces between columns that confused Alfred)
Then I dragged the generated .csv file into the left column of the List Filter and that was it for this node.
The second node is super simple. It's a Run Script node with the following:
Open Apple Music with the following url
You can use your preferred player here. I tested with VLC and Apple Music.
And that's it!
Now you have a personalized station picker:
I hope you enjoyed reading this as much as I enjoyed putting this together.
Have a good one!
Top comments (0)