2016-07-10 18:05:18 +00:00
|
|
|
import isMobile from 'ismobilejs';
|
|
|
|
|
2016-07-10 17:55:20 +00:00
|
|
|
import { loadMainView } from './utils';
|
2016-07-10 18:05:18 +00:00
|
|
|
import { artistStore, albumStore, songStore, queueStore, playlistStore } from './stores';
|
|
|
|
import { playback } from './services';
|
2016-07-10 17:55:20 +00:00
|
|
|
|
|
|
|
export default {
|
|
|
|
routes: {
|
|
|
|
'/home'() {
|
|
|
|
loadMainView('home');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/queue'() {
|
|
|
|
loadMainView('queue');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/songs'() {
|
|
|
|
loadMainView('songs');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/albums'() {
|
|
|
|
loadMainView('albums');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/album/(\\d+)'(id) {
|
|
|
|
const album = albumStore.byId(Number.parseInt(id, 10));
|
|
|
|
if (album) {
|
|
|
|
loadMainView('album', album);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
'/artists'() {
|
|
|
|
loadMainView('artists');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/artist/(\\d+)'(id) {
|
|
|
|
const artist = artistStore.byId(Number.parseInt(id, 10));
|
|
|
|
if (artist) {
|
|
|
|
loadMainView('artist', artist);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
'/favorites'() {
|
|
|
|
loadMainView('favorites');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/playlist/(\\d+)'(id) {
|
|
|
|
const playlist = playlistStore.byId(Number.parseInt(id, 10));
|
|
|
|
if (playlist) {
|
|
|
|
loadMainView('playlist', playlist);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
'/settings'() {
|
|
|
|
loadMainView('settings');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/users'() {
|
|
|
|
loadMainView('users');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/profile'() {
|
|
|
|
loadMainView('profile');
|
|
|
|
},
|
|
|
|
|
|
|
|
'/login'() {
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
'/song/([a-z0-9]{32})'(id) {
|
2016-07-10 18:05:18 +00:00
|
|
|
const song = songStore.byId(id);
|
|
|
|
if (!song) return;
|
|
|
|
|
|
|
|
if (isMobile.apple.device) {
|
|
|
|
// Mobile Safari doesn't allow autoplay, so we just queue.
|
|
|
|
queueStore.queue(song);
|
2016-07-11 14:28:24 +00:00
|
|
|
this.go('queue');
|
2016-07-10 18:05:18 +00:00
|
|
|
} else {
|
|
|
|
playback.queueAndPlay(song);
|
|
|
|
}
|
2016-07-10 17:55:20 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
init() {
|
|
|
|
this.loadState();
|
|
|
|
window.addEventListener('popstate', () => this.loadState(), true);
|
|
|
|
},
|
|
|
|
|
|
|
|
loadState() {
|
|
|
|
if (!window.location.hash) {
|
2016-07-11 14:28:24 +00:00
|
|
|
return this.go('home');
|
2016-07-10 17:55:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Object.keys(this.routes).forEach(route => {
|
|
|
|
const matches = window.location.hash.match(new RegExp(`^#!${route}$`));
|
|
|
|
if (matches) {
|
|
|
|
const [, ...params] = matches;
|
|
|
|
this.routes[route](...params);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2016-07-11 01:41:35 +00:00
|
|
|
* Navigate to a (relative, hashed) path.
|
2016-07-10 17:55:20 +00:00
|
|
|
*
|
|
|
|
* @param {String} path
|
|
|
|
*/
|
|
|
|
go(path) {
|
|
|
|
if (path[0] !== '/') {
|
|
|
|
path = `/${path}`;
|
|
|
|
}
|
2016-07-11 01:41:35 +00:00
|
|
|
|
|
|
|
if (path.indexOf('/#!') !== 0) {
|
|
|
|
path = `/#!${path}`;
|
|
|
|
}
|
|
|
|
|
2016-07-10 17:55:20 +00:00
|
|
|
document.location.href = `${document.location.origin}${path}`;
|
|
|
|
},
|
|
|
|
};
|