1
0
mirror of https://github.com/SuperBFG7/ympd synced 2025-01-14 19:25:49 +00:00

Advanced actions for queue tab

This commit is contained in:
jcorporation 2018-06-26 23:46:29 +01:00
parent 68476a7f04
commit 0555f26abf
3 changed files with 104 additions and 157 deletions

View File

@ -11,7 +11,6 @@
<link href="css/bootstrap-slider.min.css" rel="stylesheet"> <link href="css/bootstrap-slider.min.css" rel="stylesheet">
<link href="css/mpd.css" rel="stylesheet"> <link href="css/mpd.css" rel="stylesheet">
<link href="assets/favicon.ico" rel="shortcut icon" type="image/vnd.microsoft.icon"> <link href="assets/favicon.ico" rel="shortcut icon" type="image/vnd.microsoft.icon">
<script src="js/modernizr-custom.min.js"></script>
<meta name="apple-mobile-web-app-capable" content="yes" /> <meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="apple-mobile-web-app-status-bar-style" content="black"/> <meta name="apple-mobile-web-app-status-bar-style" content="black"/>
@ -103,24 +102,6 @@
</div> </div>
<div class="card-body"> <div class="card-body">
<div class="btn-toolbar collapse show card-toolbar" id="queue-buttons" role="toolbar"> <div class="btn-toolbar collapse show card-toolbar" id="queue-buttons" role="toolbar">
<div id="trashmode" class="btn-group mr-2">
<button class="btn btn-secondary dropdown-toggle" type="button" data-toggle="dropdown"><span class="material-icons">delete</span></button>
<div class="dropdown-menu bg-dark px-2" id="trashmodebtns">
<h6 class="dropdown-header text-light">Trashmode</h6>
<button id="btntrashmodeup" type="button" class="btn btn-secondary btn-block">
<span class="material-icons float-left">vertical_align_top</span>
<span class="ml-3">Delete upward</span>
</button>
<button id="btntrashmodesingle" type="button" class="btn btn-secondary active btn-block">
<span class="material-icons float-left">delete</span>
<span class="ml-3">Delete single</span>
</button>
<button id="btntrashmodedown" type="button" class="btn btn-secondary btn-block">
<span class="material-icons float-left">vertical_align_bottom</span>
<span class="ml-3">Delete downward</span>
</button>
</div>
</div>
<div id="queue-actions" class="btn-group mr-2"> <div id="queue-actions" class="btn-group mr-2">
<button type="button" class="btn btn-secondary" onclick="socket.send('MPD_API_SEND_SHUFFLE');" title="Shuffle queue"> <button type="button" class="btn btn-secondary" onclick="socket.send('MPD_API_SEND_SHUFFLE');" title="Shuffle queue">
<span class="material-icons">shuffle</span> <span class="material-icons">shuffle</span>

File diff suppressed because one or more lines are too long

View File

@ -27,7 +27,6 @@ var last_song = '';
var last_state; var last_state;
var last_outputs; var last_outputs;
var current_song = new Object(); var current_song = new Object();
var isTouch = Modernizr.touch ? 1 : 0;
var playstate = ''; var playstate = '';
var progressBar; var progressBar;
var volumeBar; var volumeBar;
@ -129,7 +128,7 @@ app.route=function() {
if (app.current.search.length < 2) { if (app.current.search.length < 2) {
setPagination(app.current.page); setPagination(app.current.page);
} }
}
var btns = document.getElementById('searchqueuetag').getElementsByTagName('button'); var btns = document.getElementById('searchqueuetag').getElementsByTagName('button');
for (var i = 0; i < btns.length; i ++) { for (var i = 0; i < btns.length; i ++) {
btns[i].classList.remove('active'); btns[i].classList.remove('active');
@ -138,7 +137,6 @@ app.route=function() {
document.getElementById('searchqueuetagdesc').innerText = btns[i].innerText; document.getElementById('searchqueuetagdesc').innerText = btns[i].innerText;
} }
} }
}
getQueue(); getQueue();
} }
else if (app.current.app == 'Browse' && app.current.tab == 'Playlists') { else if (app.current.app == 'Browse' && app.current.tab == 'Playlists') {
@ -532,13 +530,13 @@ function parseState(obj) {
document.getElementById('counter').innerText = counterText; document.getElementById('counter').innerText = counterText;
if (last_state) { if (last_state) {
$('#QueueList > tbody > tr[trackid=' + last_state.data.currentsongid + '] > td').eq(4).text(last_state.data.totalTime); $('#QueueList > tbody > tr[data-trackid=' + last_state.data.currentsongid + '] > td').eq(4).text(last_state.data.totalTime);
$('#QueueList > tbody > tr[trackid=' + last_state.data.currentsongid + '] > td').eq(0).removeClass('material-icons').text(last_state.data.songpos); $('#QueueList > tbody > tr[data-trackid=' + last_state.data.currentsongid + '] > td').eq(0).removeClass('material-icons').text(last_state.data.songpos);
} }
$('#QueueList > tbody > tr').removeClass('active').removeClass("font-weight-bold"); $('#QueueList > tbody > tr').removeClass('active').removeClass("font-weight-bold");
$('#QueueList > tbody > tr[trackid='+obj.data.currentsongid+'] > td').eq(4).text(counterText); $('#QueueList > tbody > tr[data-trackid='+obj.data.currentsongid+'] > td').eq(4).text(counterText);
$('#QueueList > tbody > tr[trackid='+obj.data.currentsongid+'] > td').eq(0).addClass('material-icons').text('play_arrow'); $('#QueueList > tbody > tr[data-trackid='+obj.data.currentsongid+'] > td').eq(0).addClass('material-icons').text('play_arrow');
$('#QueueList > tbody > tr[trackid='+obj.data.currentsongid+']').addClass('active').addClass("font-weight-bold"); $('#QueueList > tbody > tr[data-trackid='+obj.data.currentsongid+']').addClass('active').addClass("font-weight-bold");
//Get current song on queue change for http streams //Get current song on queue change for http streams
if (last_state == undefined || obj.data.queue_version != last_state.data.queue_version) if (last_state == undefined || obj.data.queue_version != last_state.data.queue_version)
@ -566,83 +564,64 @@ function getQueue() {
function parseQueue(obj) { function parseQueue(obj) {
if (app.current.app !== 'Queue') if (app.current.app !== 'Queue')
return; return;
$('#panel-heading-queue').empty();
if (obj.totalEntities > 0) { if (typeof(obj.totalTime) != undefined && obj.totalTime > 0 )
$('#panel-heading-queue').text(obj.totalEntities+' Songs'); document.getElementById('panel-heading-queue').innerText = obj.totalEntities + ' Songs ' + beautifyDuration(obj.totalTime);
} else if (obj.totalEntities > 0)
if (typeof(obj.totalTime) != undefined && obj.totalTime > 0 ) { document.getElementById('panel-heading-queue').innerText = obj.totalEntities + ' Songs';
$('#panel-heading-queue').append(' ' + beautifyDuration(obj.totalTime)); else
} document.getElementById('panel-heading-queue').innerText = '';
var nrItems=0; var nrItems=0;
var tr=document.getElementById(app.current.app+'List').getElementsByTagName('tbody')[0].getElementsByTagName('tr'); var tbody = document.getElementById(app.current.app + 'List').getElementsByTagName('tbody')[0];
for (var song in obj.data) { var tr = tbody.getElementsByTagName('tr');
for (var item in obj.data) {
nrItems++; nrItems++;
var minutes = Math.floor(obj.data[song].duration / 60); if (tr[nrItems-1])
var seconds = obj.data[song].duration - minutes * 60; if (tr[nrItems-1].getAttribute('data-trackid') == obj.data[item].id)
continue;
var row = document.createElement('tr');
row.setAttribute('data-trackid', obj.data[item].id);
var row="<tr trackid=\"" + obj.data[song].id + "\"><td>" + (obj.data[song].pos + 1) + "</td>" + var minutes = Math.floor(obj.data[item].duration / 60);
"<td>"+ obj.data[song].title +"</td>" + var seconds = obj.data[item].duration - minutes * 60;
"<td>"+ obj.data[song].artist +"</td>" +
"<td>"+ obj.data[song].album +"</td>" + row.innerHTML = '<td>' + (obj.data[item].pos + 1) + '</td>' +
"<td>"+ minutes + ":" + (seconds < 10 ? '0' : '') + seconds + '<td>' + obj.data[item].title + '</td>' +
"</td><td></td></tr>"; '<td>' + obj.data[item].artist + '</td>' +
if (nrItems <= tr.length) { if ($(tr[nrItems-1]).attr('trackid')!=obj.data[song].id) $(tr[nrItems-1]).replaceWith(row); } '<td>' + obj.data[item].album + '</td>' +
else { $('#'+app.current.app+'List > tbody').append(row); } '<td>' + minutes + ':' + (seconds < 10 ? '0' : '') + seconds +
'</td><td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td></tr>';
if (nrItems <= tr.length)
tr[nrItems-1].replaceWith(row);
else
tbody.append(row);
tr[nrItems-1].getElementsByTagName('a')[0].addEventListener('click', function(event) {
event.stopPropagation();
event.preventDefault();
showMenu(this);
},false);
tr[nrItems-1].addEventListener('click', function() {
sendAPI({"cmd":"MPD_API_PLAY_TRACK","data": {"track":this.getAttribute('data-trackid')}});
},false);
} }
for (var i=tr.length;i>nrItems;i--) { var tr_length=tr.length - 1;
$(tr[tr.length-1]).remove(); for (var i = tr_length; i >= nrItems; i --) {
tr[i].remove();
} }
if (obj.type == 'queuesearch' && nrItems == 0) { if (obj.type == 'queuesearch' && nrItems == 0) {
$('#QueueList > tbody').append( tbody.innerHTML = '<tr><td><span class="material-icons">error_outline</span></td>' +
"<tr><td><span class=\"material-icons\">error_outline</span></td>" + '<td colspan="5">No results, please refine your search!</td></tr>';
"<td colspan=\"3\">No results, please refine your search!</td>" +
"<td></td><td></td></tr>"
);
} }
else if (obj.type == 'queue' && nrItems == 0) {
tbody.innerHTML = '<tr><td><span class="material-icons">error_outline</span></td>' +
'<td colspan="5">Empty queue</td></tr>';
}
setPagination(obj.totalEntities); setPagination(obj.totalEntities);
if ( isTouch ) {
$('#QueueList > tbody > tr > td:last-child').append(
'<a class="pull-right btn-group-hover color-darkgrey" href="#/Queue!' + app.current.page + '/'+app.current.filter+'/'+app.current.search + '" '+
'onclick="delQueueSong($(this).parents(\'tr\'),event);">' +
'<span class="material-icons">delete</span></a>');
} else {
$('#QueueList > tbody > tr').on({
mouseover: function(){
var doomed = $(this);
if ( $('#btntrashmodeup').hasClass('active') )
doomed = $('#QueueList > tbody > tr:lt(' + ($(this).index() + 1) + ')');
if ( $('#btntrashmodedown').hasClass('active') )
doomed = $('#QueueList > tbody > tr:gt(' + ($(this).index() - 1) + ')');
$.each(doomed, function(){
if($(this).children().last().has('a').length == 0)
$(this).children().last().append(
'<a class="pull-right btn-group-hover color-darkgrey" href="#/Queue!'+ app.current.page + '/' +app.current.filter+'/'+app.current.search + '" ' +
'onclick="delQueueSong($(this).parents(\'tr\'),event);">' +
'<span class="material-icons">delete</span></a>')
.find('a').fadeTo('fast',1);
});
},
mouseleave: function(){
var doomed = $(this);
if ( $('#btntrashmodeup').hasClass('active') )
doomed = $("#QueueList > tbody > tr:lt(" + ($(this).index() + 1) + ")");
if ( $('#btntrashmodedown').hasClass('active') )
doomed = $("#QueueList > tbody > tr:gt(" + ($(this).index() - 1) + ")");
$.each(doomed, function(){$(this).children().last().find("a").stop().remove();});
}
});
};
$('#QueueList > tbody > tr').on({
click: function() {
$('#queueList > tbody > tr').removeClass('active');
sendAPI({"cmd":"MPD_API_PLAY_TRACK","data": {"track":$(this).attr('trackid')}});
$(this).addClass('active');
},
});
} }
function parseSearch(obj) { function parseSearch(obj) {
@ -917,8 +896,8 @@ function setPagination(number) {
var totalPages=Math.ceil(number / settings.max_elements_per_page); var totalPages=Math.ceil(number / settings.max_elements_per_page);
var cat=app.current.app+(app.current.tab==undefined ? '': app.current.tab); var cat=app.current.app+(app.current.tab==undefined ? '': app.current.tab);
if (totalPages ==0 ) { totalPages = 1; } if (totalPages ==0 ) { totalPages = 1; }
$('#'+cat+'PaginationTopPage').text('Page '+(app.current.page / settings.max_elements_per_page + 1)+' / '+totalPages); $('#'+cat+'PaginationTopPage').text((app.current.page / settings.max_elements_per_page + 1) + ' / ' + totalPages);
$('#'+cat+'PaginationBottomPage').text('Page '+(app.current.page / settings.max_elements_per_page + 1)+' / '+totalPages); $('#'+cat+'PaginationBottomPage').text((app.current.page / settings.max_elements_per_page + 1) + ' / ' + totalPages);
if (totalPages > 1) { if (totalPages > 1) {
$('#'+cat+'PaginationTopPage').removeClass('disabled').removeAttr('disabled'); $('#'+cat+'PaginationTopPage').removeClass('disabled').removeAttr('disabled');
$('#'+cat+'PaginationBottomPage').removeClass('disabled').removeAttr('disabled'); $('#'+cat+'PaginationBottomPage').removeClass('disabled').removeAttr('disabled');
@ -985,9 +964,18 @@ function showMenu(el) {
'<a class="dropdown-item" href="#">Replace queue</a>' + '<a class="dropdown-item" href="#">Replace queue</a>' +
'<div class="dropdown-divider"></div>' + '<div class="dropdown-divider"></div>' +
'<a class="dropdown-item" href="#">Show playlist</a>' + '<a class="dropdown-item" href="#">Show playlist</a>' +
'<a class="dropdown-item" href="#">Rename playlist</a>' +
'<a class="dropdown-item" href="#">Delete playlist</a>' '<a class="dropdown-item" href="#">Delete playlist</a>'
}); });
} }
else if (app.current.app == 'Queue') {
$(el).popover({html:true, content:'<a class="dropdown-item" href="#" onclick="">Remove</a>' +
'<a class="dropdown-item" href="#">Remove all upwards</a>' +
'<a class="dropdown-item" href="#">Remove all downwards</a>' +
'<div class="dropdown-divider"></div>' +
'<a class="dropdown-item" href="#">Songdetails</a>'
});
}
$(el).popover('show'); $(el).popover('show');
} }
@ -1144,13 +1132,9 @@ function confirmSettings() {
} }
function toggleoutput(button, id) { function toggleoutput(button, id) {
sendAPI({"cmd":"MPD_API_TOGGLE_OUTPUT", "data": {"output": id, "state": ($(button).hasClass('active') ? 0 : 1)}}); sendAPI({"cmd":"MPD_API_TOGGLE_OUTPUT", "data": {"output": id, "state": (button.classList.contains('active') ? 0 : 1)}});
} }
$('#trashmodebtns > button').on('click', function(e) {
$('#trashmodebtns').children('button').removeClass('active');
$(this).addClass('active');
});
$('#search > input').keypress(function (event) { $('#search > input').keypress(function (event) {
if ( event.which == 13 ) { if ( event.which == 13 ) {
@ -1170,40 +1154,25 @@ $('#search2').submit(function () {
function addAllFromSearch() { function addAllFromSearch() {
if (app.current.search.length >= 2) { if (app.current.search.length >= 2) {
sendAPI({"cmd":"MPD_API_SEARCH_ADD","data":{"filter": app.current.filter,"searchstr": + app.current.search}}); sendAPI({"cmd":"MPD_API_SEARCH_ADD","data":{"filter": app.current.filter,"searchstr": + app.current.search}});
var rowCount = $('#SearchList >tbody >tr').length; var rowCount = parseInt(document.getElementById('panel-heading-search').innerText);
showNotification('Added '+rowCount+' songs from search','','','success'); showNotification('Added '+rowCount+' songs from search','','','success');
} }
} }
$('#searchstr2').keyup(function (event) { $('#searchstr2').keyup(function (event) {
app.current.page=0; app.goto('Search', undefined, undefined, app.current.page + '0/' + app.current.filter + '/' + this.value);
app.current.search=$(this).val();
app.goto('Search',undefined,undefined,app.current.page + '/' + app.current.filter + '/' + app.current.search);
}); });
$('#searchtags2 > button').on('click',function (e) { $('#searchtags2 > button').on('click',function (e) {
$('#searchtags2 > button').removeClass('active'); app.goto(app.current.app, app.current.tab, app.current.view, '0/' + this.innerText + '/' + app.current.search);
$(this).removeClass('btn-secondary').addClass('active');
app.current.filter=$(this).text();
app.goto(app.current.app,app.current.tab,app.current.view,app.current.page + '/' + app.current.filter + '/' + app.current.search);
}); });
$('#searchqueuestr').keyup(function (event) { $('#searchqueuestr').keyup(function (event) {
app.current.page=0; app.goto(app.current.app, app.current.tab, app.current.view, '0/' + app.current.filter + '/' + this.value);
app.current.search=$(this).val();
app.goto(app.current.app,app.current.tab,app.current.view,app.current.page + '/' + app.current.filter + '/' + app.current.search);
}); });
$('#searchqueuetag > button').on('click',function (e) { $('#searchqueuetag > button').on('click',function (e) {
$('#searchqueuetag > button').removeClass('active'); app.goto(app.current.app, app.current.tab, app.current.view, app.current.page + '/' + this.innerText + '/' + app.current.search);
$(this).removeClass('btn-secondary').addClass('active');
app.current.filter=$(this).text();
$('#searchqueuetagdesc').text(app.current.filter);
app.goto(app.current.app,app.current.tab,app.current.view,app.current.page + '/' + app.current.filter + '/' + app.current.search);
});
$('#searchqueue').submit(function () {
return false;
}); });
$('#searchqueue').submit(function () { $('#searchqueue').submit(function () {
@ -1217,10 +1186,10 @@ function scrollToTop() {
function gotoPage(x, element, event) { function gotoPage(x, element, event) {
switch (x) { switch (x) {
case "next": case 'next':
app.current.page += settings.max_elements_per_page; app.current.page += settings.max_elements_per_page;
break; break;
case "prev": case 'prev':
app.current.page -= settings.max_elements_per_page; app.current.page -= settings.max_elements_per_page;
if (app.current.page <= 0) if (app.current.page <= 0)
app.current.page = 0; app.current.page = 0;
@ -1269,39 +1238,40 @@ function notificationsSupported() {
} }
function songChange(obj) { function songChange(obj) {
if (last_song == obj.data.title+obj.data.artist+obj.data.album+obj.data.uri+obj.data.currentsongid) var cur_song = obj.data.title + obj.data.artist + obj.data.album + obj.data.uri + obj.data.currentsongid;
if (last_song == cur_song)
return; return;
var textNotification = ''; var textNotification = '';
var htmlNotification = ''; var htmlNotification = '';
var pageTitle = 'myMPD: '; var pageTitle = 'myMPD: ';
$('#album-cover').css('backgroundImage','url("'+obj.data.cover+'")'); document.getElementById('album-cover').style.backgroundImage = 'url("'+obj.data.cover+'")';
if(typeof obj.data.artist != 'undefined' && obj.data.artist.length > 0 && obj.data.artist != '-') { if(typeof obj.data.artist != 'undefined' && obj.data.artist.length > 0 && obj.data.artist != '-') {
textNotification += obj.data.artist; textNotification += obj.data.artist;
htmlNotification += '<br/>' + obj.data.artist; htmlNotification += '<br/>' + obj.data.artist;
pageTitle += obj.data.artist + ' - '; pageTitle += obj.data.artist + ' - ';
$('#artist').text(obj.data.artist); document.getElementById('artist').innerText = obj.data.artist;
} else { } else {
$('#artist').text(''); document.getElementById('artist').innerText = '';
} }
if(typeof obj.data.album != 'undefined' && obj.data.album.length > 0 && obj.data.album != '-') { if(typeof obj.data.album != 'undefined' && obj.data.album.length > 0 && obj.data.album != '-') {
textNotification += ' - ' + obj.data.album; textNotification += ' - ' + obj.data.album;
htmlNotification += '<br/>' + obj.data.album; htmlNotification += '<br/>' + obj.data.album;
$('#album').text(obj.data.album); document.getElementById('album').innerText = obj.data.album;
} }
else { else {
$('#album').text(''); document.getElementById('album').innerText = '';
} }
if(typeof obj.data.title != 'undefined' && obj.data.title.length > 0) { if(typeof obj.data.title != 'undefined' && obj.data.title.length > 0) {
pageTitle += obj.data.title; pageTitle += obj.data.title;
$('#currenttrack').text(obj.data.title); document.getElementById('currenttrack').innerText = obj.data.title;
} else { } else {
$('#currenttrack').text(''); document.getElementById('currenttrack').innerText = '';
} }
document.title = pageTitle; document.title = pageTitle;
showNotification(obj.data.title,textNotification,htmlNotification,'success'); showNotification(obj.data.title,textNotification,htmlNotification,'success');
last_song = obj.data.title+obj.data.artist+obj.data.album+obj.data.uri+obj.data.currentsongid; last_song = cur_song;
} }