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

Incremental populate tables in queue, browse and search views

This commit is contained in:
jcorporation 2018-05-30 01:12:47 +02:00
parent 994f6d2daa
commit 0039fabc50
2 changed files with 30 additions and 18 deletions

View File

@ -47,6 +47,10 @@ button {
width: 200px; width: 200px;
} }
.card {
min-height:300px;
}
h1 { h1 {
display: block; display: block;
overflow: hidden; overflow: hidden;

View File

@ -81,7 +81,7 @@ var app = $.sammy(function() {
$('#cardQueue').removeClass('hide'); $('#cardQueue').removeClass('hide');
$('#navQueue').addClass('active'); $('#navQueue').addClass('active');
} }
$('#queueList > tbody').empty(); //$('#queueList > tbody').empty();
if (searchstr.length >= 3) { if (searchstr.length >= 3) {
socket.send('MPD_API_SEARCH_QUEUE,' + mpdtag + ','+pagination+',' + searchstr); socket.send('MPD_API_SEARCH_QUEUE,' + mpdtag + ','+pagination+',' + searchstr);
} }
@ -123,7 +123,7 @@ var app = $.sammy(function() {
$('#cardBrowse').removeClass('hide'); $('#cardBrowse').removeClass('hide');
$('#cardBrowseFilesystem').removeClass('hide'); $('#cardBrowseFilesystem').removeClass('hide');
$('#cardBrowseNavFilesystem').addClass('active'); $('#cardBrowseNavFilesystem').addClass('active');
$('#browseFilesystemList > tbody').empty(); //$('#browseFilesystemList > tbody').empty();
$('#browseBreadcrumb').empty().append("<li class=\"breadcrumb-item\"><a uri=\"\">root</a></li>"); $('#browseBreadcrumb').empty().append("<li class=\"breadcrumb-item\"><a uri=\"\">root</a></li>");
socket.send('MPD_API_GET_BROWSE,'+pagination+','+(browsepath ? browsepath : "/")); socket.send('MPD_API_GET_BROWSE,'+pagination+','+(browsepath ? browsepath : "/"));
// Don't add all songs from root // Don't add all songs from root
@ -177,9 +177,10 @@ var app = $.sammy(function() {
$('#cardSearch').removeClass('hide'); $('#cardSearch').removeClass('hide');
$('#navSearch').addClass('active'); $('#navSearch').addClass('active');
} }
$('#searchList > tbody').empty();
if (searchstr.length >= 3) { if (searchstr.length >= 3) {
socket.send('MPD_API_SEARCH,' + mpdtag + ','+pagination+',' + searchstr); socket.send('MPD_API_SEARCH,' + mpdtag + ','+pagination+',' + searchstr);
} else {
$('#searchList > tbody').empty();
} }
}); });
@ -285,21 +286,27 @@ function webSocketConnect() {
$('#panel-heading-queue').append(' ' + beautifyDuration(obj.totalTime)); $('#panel-heading-queue').append(' ' + beautifyDuration(obj.totalTime));
} }
$('#queueList > tbody').empty(); //$('#queueList > tbody').empty();
var nrItems=0; var nrItems=0;
var tr=document.getElementById(current_app+'List').getElementsByTagName('tbody')[0].getElementsByTagName('tr');
for (var song in obj.data) { for (var song in obj.data) {
nrItems++; nrItems++;
var minutes = Math.floor(obj.data[song].duration / 60); var minutes = Math.floor(obj.data[song].duration / 60);
var seconds = obj.data[song].duration - minutes * 60; var seconds = obj.data[song].duration - minutes * 60;
$('#queueList > tbody').append( var row="<tr trackid=\"" + obj.data[song].id + "\"><td>" + (obj.data[song].pos + 1) + "</td>" +
"<tr trackid=\"" + obj.data[song].id + "\"><td>" + (obj.data[song].pos + 1) + "</td>" +
"<td>"+ obj.data[song].title +"</td>" + "<td>"+ obj.data[song].title +"</td>" +
"<td>"+ obj.data[song].artist +"</td>" + "<td>"+ obj.data[song].artist +"</td>" +
"<td>"+ obj.data[song].album +"</td>" + "<td>"+ obj.data[song].album +"</td>" +
"<td>"+ minutes + ":" + (seconds < 10 ? '0' : '') + seconds + "<td>"+ minutes + ":" + (seconds < 10 ? '0' : '') + seconds +
"</td><td></td></tr>"); "</td><td></td></tr>";
if (nrItems < tr.length) { $(tr[nrItems-1]).replaceWith(row); }
else { $('#'+current_app+'List > tbody').append(row); }
} }
for (var i=tr.length;i>nrItems;i--) {
$(tr[tr.length-1]).remove();
}
if (obj.type == 'queuesearch' && nrItems == 0) { if (obj.type == 'queuesearch' && nrItems == 0) {
$('#queueList > tbody').append( $('#queueList > tbody').append(
"<tr><td><span class=\"material-icons\">error_outline</span></td>" + "<tr><td><span class=\"material-icons\">error_outline</span></td>" +
@ -400,7 +407,7 @@ function webSocketConnect() {
} }
break; break;
case 'search': case 'search':
$('#searchList > tbody').empty(); //$('#searchList > tbody').empty();
$('#panel-heading-search').text(obj.totalEntities + ' Songs found'); $('#panel-heading-search').text(obj.totalEntities + ' Songs found');
case 'browse': case 'browse':
if(current_app !== 'browseFilesystem' && current_app !== 'search') if(current_app !== 'browseFilesystem' && current_app !== 'search')
@ -411,34 +418,35 @@ function webSocketConnect() {
* URI from NFD to NFC, breaking our link with MPD. * URI from NFD to NFC, breaking our link with MPD.
*/ */
var nrItems=0; var nrItems=0;
var tr=document.getElementById(current_app+'List').getElementsByTagName('tbody')[0].getElementsByTagName('tr');
for (var item in obj.data) { for (var item in obj.data) {
nrItems++; nrItems++;
var row='';
switch(obj.data[item].type) { switch(obj.data[item].type) {
case 'directory': case 'directory':
$('#'+current_app+'List > tbody').append( row='<tr uri="' + encodeURI(obj.data[item].dir) + '" class="dir">' +
'<tr uri="' + encodeURI(obj.data[item].dir) + '" class="dir">' +
'<td><span class="material-icons">folder_open</span></td>' + '<td><span class="material-icons">folder_open</span></td>' +
'<td colspan="3"><a>' + basename(obj.data[item].dir) + '</a></td>' + '<td colspan="3"><a>' + basename(obj.data[item].dir) + '</a></td>' +
'<td></td><td></td></tr>' '<td></td><td></td></tr>';
);
break; break;
case 'song': case 'song':
var minutes = Math.floor(obj.data[item].duration / 60); var minutes = Math.floor(obj.data[item].duration / 60);
var seconds = obj.data[item].duration - minutes * 60; var seconds = obj.data[item].duration - minutes * 60;
row='<tr uri="' + encodeURI(obj.data[item].uri) + '" class="song">' +
$('#'+current_app+'List > tbody').append(
'<tr uri="' + encodeURI(obj.data[item].uri) + '" class="song">' +
'<td><span class="material-icons">music_note</span></td>' + '<td><span class="material-icons">music_note</span></td>' +
'<td>' + obj.data[item].title + '</td>' + '<td>' + obj.data[item].title + '</td>' +
'<td>' + obj.data[item].artist + '</td>' + '<td>' + obj.data[item].artist + '</td>' +
'<td>' + obj.data[item].album + '</td>' + '<td>' + obj.data[item].album + '</td>' +
'<td>' + minutes + ':' + (seconds < 10 ? '0' : '') + seconds + '<td>' + minutes + ':' + (seconds < 10 ? '0' : '') + seconds +
'</td><td></td></tr>' '</td><td></td></tr>';
);
break; break;
} }
if (nrItems < tr.length) { $(tr[nrItems-1]).replaceWith(row); }
else { $('#'+current_app+'List > tbody').append(row); }
}
for (var i=tr.length;i>nrItems;i--) {
$(tr[tr.length-1]).remove();
} }
setPagination(obj.totalEntities); setPagination(obj.totalEntities);
if (current_app == 'search') if (current_app == 'search')