2016-06-02 17:53:26 +00:00
|
|
|
import $ from 'jquery';
|
|
|
|
import { map } from 'lodash';
|
|
|
|
|
|
|
|
import playlistStore from '../stores/playlist';
|
2016-06-04 11:20:11 +00:00
|
|
|
import favoriteStore from '../stores/favorite';
|
2016-06-02 17:53:26 +00:00
|
|
|
import ls from './ls';
|
|
|
|
|
|
|
|
export default {
|
2016-06-04 11:20:11 +00:00
|
|
|
/**
|
|
|
|
* Download individual song(s).
|
|
|
|
*
|
|
|
|
* @param {Array.<Object>|Object} songs
|
|
|
|
*/
|
2016-06-02 17:53:26 +00:00
|
|
|
fromSongs(songs) {
|
2016-06-04 11:20:11 +00:00
|
|
|
songs = [].concat(songs);
|
2016-06-02 17:53:26 +00:00
|
|
|
const ids = map(songs, 'id');
|
|
|
|
const params = $.param({ songs: ids });
|
|
|
|
|
|
|
|
return this.trigger(`songs?${params}`);
|
|
|
|
},
|
|
|
|
|
2016-06-04 11:20:11 +00:00
|
|
|
/**
|
|
|
|
* Download all songs in an album.
|
|
|
|
*
|
|
|
|
* @param {Object} album
|
|
|
|
*/
|
2016-06-02 17:53:26 +00:00
|
|
|
fromAlbum(album) {
|
2016-06-04 11:20:11 +00:00
|
|
|
return this.trigger(`album/${album.id}`);
|
2016-06-02 17:53:26 +00:00
|
|
|
},
|
|
|
|
|
2016-06-04 11:20:11 +00:00
|
|
|
/**
|
|
|
|
* Download all songs performed by an artist.
|
|
|
|
*
|
|
|
|
* @param {Object} artist
|
|
|
|
*/
|
2016-06-02 17:53:26 +00:00
|
|
|
fromArtist(artist) {
|
2016-06-04 11:20:11 +00:00
|
|
|
// It's safe to assume an artist always has songs.
|
|
|
|
// After all, what's an artist without her songs?
|
|
|
|
// (See what I did there? Yes, I'm advocating for women's rights).
|
|
|
|
return this.trigger(`artist/${artist.id}`);
|
2016-06-02 17:53:26 +00:00
|
|
|
},
|
|
|
|
|
2016-06-04 11:20:11 +00:00
|
|
|
/**
|
|
|
|
* Download all songs in a playlist.
|
|
|
|
*
|
|
|
|
* @param {Object} playlist
|
|
|
|
*/
|
2016-06-02 17:53:26 +00:00
|
|
|
fromPlaylist(playlist) {
|
|
|
|
if (!playlistStore.getSongs(playlist).length) {
|
|
|
|
console.warn('Empty playlist.');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.trigger(`playlist/${playlist.id}`);
|
|
|
|
},
|
|
|
|
|
2016-06-04 11:20:11 +00:00
|
|
|
/**
|
|
|
|
* Download all favorite songs.
|
|
|
|
*/
|
|
|
|
fromFavorites() {
|
|
|
|
if (!favoriteStore.all.length) {
|
|
|
|
console.warn("You don't like any song? Come on, don't be that grumpy.");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.trigger('favorites');
|
|
|
|
},
|
|
|
|
|
2016-06-02 17:53:26 +00:00
|
|
|
/**
|
|
|
|
* Build a download link using a segment and trigger it.
|
|
|
|
*
|
|
|
|
* @param {string} uri The uri segment, corresponding to the song(s),
|
|
|
|
* artist, playlist, or album.
|
|
|
|
*/
|
|
|
|
trigger(uri) {
|
|
|
|
const sep = uri.indexOf('?') === -1 ? '?' : '&';
|
|
|
|
const frameId = `downloader${Date.now()}`;
|
|
|
|
$(`<iframe id="${frameId}" style="display:none"></iframe`).appendTo('body');
|
|
|
|
document.getElementById(frameId).src = `/api/download/${uri}${sep}jwt-token=${ls.get('jwt-token')}`;
|
|
|
|
},
|
|
|
|
}
|