121 lines
3.1 KiB
JavaScript
121 lines
3.1 KiB
JavaScript
var PlayList={
|
|
urlBase:OC.linkTo('media','ajax/api.php')+'?action=play&path=',
|
|
current:-1,
|
|
items:[],
|
|
player:null,
|
|
next:function(){
|
|
var next=PlayList.current+1;
|
|
if(next>=PlayList.items.length){
|
|
next=0;
|
|
}
|
|
PlayList.play(next);
|
|
PlayList.render();
|
|
},
|
|
previous:function(){
|
|
var next=PlayList.current-1;
|
|
if(next<0){
|
|
next=PlayList.items.length-1;
|
|
}
|
|
PlayList.play(next);
|
|
PlayList.render();
|
|
},
|
|
play:function(index){
|
|
if(index==null){
|
|
index=PlayList.current;
|
|
}
|
|
if(index>-1 && index<PlayList.items.length){
|
|
PlayList.current=index;
|
|
if(PlayList.player){
|
|
if(PlayList.player.data('jPlayer').options.supplied!=PlayList.items[index].type){//the the audio type changes we need to reinitialize jplayer
|
|
PlayList.player.jPlayer("destroy");
|
|
PlayList.init(PlayList.items[index].type,PlayList.play);
|
|
}else{
|
|
PlayList.player.jPlayer("setMedia", PlayList.items[PlayList.current]);
|
|
PlayList.items[index].playcount++;
|
|
PlayList.player.jPlayer("play");
|
|
if(Collection){
|
|
Collection.registerPlay();
|
|
}
|
|
}
|
|
}else{
|
|
PlayList.init(PlayList.items[index].type,PlayList.play);
|
|
}
|
|
}
|
|
},
|
|
init:function(type,ready){
|
|
if(!PlayList.player){
|
|
$(".jp-previous").click(function() {
|
|
PlayList.previous();
|
|
$(this).blur();
|
|
PlayList.render();
|
|
return false;
|
|
});
|
|
$(".jp-next").click(function() {
|
|
PlayList.next();
|
|
$(this).blur();
|
|
PlayList.render();
|
|
return false;
|
|
});
|
|
PlayList.player=$('#jp-interface div.player');
|
|
}
|
|
$(PlayList.player).jPlayer({
|
|
ended:PlayList.next,
|
|
supplied:type,
|
|
ready:function(){
|
|
if(ready){
|
|
ready();
|
|
}
|
|
},
|
|
cssSelectorAncestor:'#jp-interface',
|
|
swfPath:OC.linkTo('media','js'),
|
|
});
|
|
},
|
|
add:function(song){
|
|
if(!song){
|
|
return;
|
|
}
|
|
if(song.substr){//we are passed a string, asume it's a url to a song
|
|
PlayList.addFile(song);
|
|
}
|
|
if(song.albums){//a artist object was passed, add all albums inside it
|
|
$.each(song.albums,function(index,album){
|
|
PlayList.add(album);
|
|
});
|
|
}
|
|
if(song.songs){//a album object was passed, add all songs inside it
|
|
$.each(song.songs,function(index,song){
|
|
PlayList.add(song);
|
|
});
|
|
}
|
|
if(song.song_name){
|
|
var type=musicTypeFromFile(song.song_path);
|
|
var item={name:song.song_name,type:type,artist:song.artist_name,album:song.album_name,length:song.song_length,playcount:song.song_playcount};
|
|
item[type]=PlayList.urlBase+encodeURIComponent(song.song_path);
|
|
PlayList.items.push(item);
|
|
}
|
|
},
|
|
addFile:function(path){
|
|
var type=musicTypeFromFile(path);
|
|
var item={name:'unknown',artist:'unknown',album:'unknwon',type:type};
|
|
$.getJSON(OC.filePath('media','ajax','api.php')+'?action=get_path_info&path='+encodeURIComponent(path),function(song){
|
|
item.name=song.song_name;
|
|
item.artist=song.artist;
|
|
item.album=song.album;
|
|
});
|
|
item[type]=PlayList.urlBase+encodeURIComponent(path);
|
|
PlayList.items.push(item);
|
|
},
|
|
remove:function(index){
|
|
PlayList.items.splice(index,1);
|
|
PlayList.render();
|
|
},
|
|
render:function(){},
|
|
playing:function(){
|
|
if(!PlayList.player){
|
|
return false;
|
|
}else{
|
|
return !PlayList.player.data("jPlayer").status.paused;
|
|
}
|
|
}
|
|
}
|