mirror of
https://github.com/SuperBFG7/ympd
synced 2025-01-14 19:25:49 +00:00
Optimize javascript
This commit is contained in:
parent
0555f26abf
commit
fed98f8423
263
htdocs/js/mpd.js
263
htdocs/js/mpd.js
@ -53,24 +53,35 @@ app.apps = { "Playback": { "state": "0/-/" },
|
|||||||
app.current = { "app": "Playback", "tab": undefined, "view": undefined, "page": 0, "filter": "", "search": "" };
|
app.current = { "app": "Playback", "tab": undefined, "view": undefined, "page": 0, "filter": "", "search": "" };
|
||||||
app.last = { "app": undefined, "tab": undefined, "view": undefined };
|
app.last = { "app": undefined, "tab": undefined, "view": undefined };
|
||||||
|
|
||||||
|
var domCache = {};
|
||||||
|
domCache.navbarBottomBtns = document.getElementById('navbar-bottom').getElementsByTagName('div');
|
||||||
|
domCache.navbarBottomBtnsLen = domCache.navbarBottomBtns.length;
|
||||||
|
domCache.panelHeadingBrowse = document.getElementById('panel-heading-browse').getElementsByTagName('a');
|
||||||
|
domCache.panelHeadingBrowseLen = domCache.panelHeadingBrowse.length;
|
||||||
|
domCache.counter = document.getElementById('counter');
|
||||||
|
|
||||||
app.prepare=function() {
|
app.prepare=function() {
|
||||||
if (app.current.app != app.last.app || app.current.tab != app.last.tab || app.current.view != app.last.view) {
|
if (app.current.app != app.last.app || app.current.tab != app.last.tab || app.current.view != app.last.view) {
|
||||||
//Hide all cards + nav
|
//Hide all cards + nav
|
||||||
$('#navbar-bottom > div').removeClass('active');
|
for ( var i = 0; i < domCache.navbarBottomBtnsLen; i ++) {
|
||||||
$('#cardPlayback').addClass('hide');
|
domCache.navbarBottomBtns[i].classList.remove('active');
|
||||||
$('#cardQueue').addClass('hide');
|
}
|
||||||
$('#cardBrowse').addClass('hide');
|
document.getElementById('cardPlayback').classList.add('hide');
|
||||||
$('#cardSearch').addClass('hide');
|
document.getElementById('cardQueue').classList.add('hide');
|
||||||
$('#panel-heading-browse > ul > li > a').removeClass('active');
|
document.getElementById('cardBrowse').classList.add('hide');
|
||||||
$('#cardBrowsePlaylists').addClass('hide');
|
document.getElementById('cardSearch').classList.add('hide');
|
||||||
$('#cardBrowseDatabase').addClass('hide');
|
for ( var i = 0; i < domCache.panelHeadingBrowseLen; i ++) {
|
||||||
$('#cardBrowseFilesystem').addClass('hide');
|
domCache.panelHeadingBrowse[i].classList.remove('active');
|
||||||
|
}
|
||||||
|
document.getElementById('cardBrowsePlaylists').classList.add('hide');
|
||||||
|
document.getElementById('cardBrowseDatabase').classList.add('hide');
|
||||||
|
document.getElementById('cardBrowseFilesystem').classList.add('hide');
|
||||||
//show active card + nav
|
//show active card + nav
|
||||||
$('#card'+app.current.app).removeClass('hide');
|
document.getElementById('card' + app.current.app).classList.remove('hide');
|
||||||
$('#nav'+app.current.app).addClass('active');
|
document.getElementById('nav' + app.current.app).classList.add('active');
|
||||||
if (app.current.tab != undefined) {
|
if (app.current.tab != undefined) {
|
||||||
$('#card'+app.current.app+app.current.tab).removeClass('hide');
|
document.getElementById('card' + app.current.app + app.current.tab).classList.remove('hide');
|
||||||
$('#card'+app.current.app+'Nav'+app.current.tab).addClass('active');
|
document.getElementById('card' + app.current.app + 'Nav' + app.current.tab).classList.add('active');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -159,24 +170,26 @@ app.route=function() {
|
|||||||
else
|
else
|
||||||
document.getElementById('BrowseFilesystemAddAllSongs').setAttribute('disabled', 'disabled')
|
document.getElementById('BrowseFilesystemAddAllSongs').setAttribute('disabled', 'disabled')
|
||||||
// Create breadcrumb
|
// Create breadcrumb
|
||||||
var breadcrumbs=['<li class="breadcrumb-item"><a uri="">root</a></li>'];
|
var breadcrumbs=['<li class="breadcrumb-item"><a data-uri="">root</a></li>'];
|
||||||
var path_array = app.current.search.split('/');
|
var pathArray = app.current.search.split('/');
|
||||||
var full_path = '';
|
var pathArrayLen = pathArray.length;
|
||||||
for (var index in path_array) {
|
var fullPath = '';
|
||||||
if (path_array.length - 1 == index) {
|
for (var i = 0; i < pathArrayLen; i ++) {
|
||||||
breadcrumbs.push('<li class="breadcrumb-item active">' + path_array[index] + '</li>');
|
if (pathArrayLen -1 == i) {
|
||||||
|
breadcrumbs.push('<li class="breadcrumb-item active">' + pathArray[i] + '</li>');
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
full_path = full_path + path_array[index];
|
fullPath += pathArray[i];
|
||||||
breadcrumbs.push('<li class="breadcrumb-item"><a uri="' + full_path + '">' + path_array[index] + '</a></li>');
|
breadcrumbs.push('<li class="breadcrumb-item"><a data-uri="' + fullPath + '">' + pathArray[i] + '</a></li>');
|
||||||
full_path += '/';
|
fullPath += '/';
|
||||||
}
|
}
|
||||||
var elBrowseBreadcrumb=document.getElementById('BrowseBreadcrumb');
|
var elBrowseBreadcrumb=document.getElementById('BrowseBreadcrumb');
|
||||||
elBrowseBreadcrumb.innerHTML = breadcrumbs.join('');
|
elBrowseBreadcrumb.innerHTML = breadcrumbs.join('');
|
||||||
var breadcrumbItems = elBrowseBreadcrumb.getElementsByTagName('a');
|
var breadcrumbItems = elBrowseBreadcrumb.getElementsByTagName('a');
|
||||||
for (var i = 0; i < breadcrumbItems.length; i ++) {
|
var breadcrumbItemsLen = breadcrumbItems.length;
|
||||||
breadcrumbItems[index].addEventListener('click',function() {
|
for (var i = 0; i < breadcrumbItemsLen; i ++) {
|
||||||
app.goto('Browse', 'Filesystem', undefined, '0/'+app.current.filter+'/'+$(this).attr('uri'));
|
breadcrumbItems[i].addEventListener('click', function() {
|
||||||
|
app.goto('Browse', 'Filesystem', undefined, '0/' + app.current.filter + '/' + this.getAttribute('data-uri'));
|
||||||
}, false);
|
}, false);
|
||||||
}
|
}
|
||||||
doSetFilterLetter('#BrowseFilesystemFilter');
|
doSetFilterLetter('#BrowseFilesystemFilter');
|
||||||
@ -201,7 +214,8 @@ app.route=function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var btns = document.getElementById('searchtags2').getElementsByTagName('button');
|
var btns = document.getElementById('searchtags2').getElementsByTagName('button');
|
||||||
for (var i = 0; i < btns.length; i ++) {
|
var btnsLen = btns.length;
|
||||||
|
for (var i = 0; i < btnsLen; i ++) {
|
||||||
btns[i].classList.remove('active');
|
btns[i].classList.remove('active');
|
||||||
if (btns[i].innerText == app.current.filter) {
|
if (btns[i].innerText == app.current.filter) {
|
||||||
btns[i].classList.add('active');
|
btns[i].classList.add('active');
|
||||||
@ -213,9 +227,9 @@ app.route=function() {
|
|||||||
app.goto("Playback");
|
app.goto("Playback");
|
||||||
}
|
}
|
||||||
|
|
||||||
app.last.app=app.current.app;
|
app.last.app = app.current.app;
|
||||||
app.last.tab=app.current.tab;
|
app.last.tab = app.current.tab;
|
||||||
app.last.view=app.current.view;
|
app.last.view = app.current.view;
|
||||||
};
|
};
|
||||||
|
|
||||||
$(document).ready(function(){
|
$(document).ready(function(){
|
||||||
@ -488,7 +502,7 @@ function parseSettings(obj) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function getSettings() {
|
function getSettings() {
|
||||||
sendAPI({"cmd":"MPD_API_GET_SETTINGS"},parseSettings);
|
sendAPI({"cmd":"MPD_API_GET_SETTINGS"}, parseSettings);
|
||||||
}
|
}
|
||||||
|
|
||||||
function parseOutputnames(obj) {
|
function parseOutputnames(obj) {
|
||||||
@ -527,16 +541,28 @@ function parseState(obj) {
|
|||||||
var counterText = elapsed_minutes + ":" +
|
var counterText = elapsed_minutes + ":" +
|
||||||
(elapsed_seconds < 10 ? '0' : '') + elapsed_seconds + " / " +
|
(elapsed_seconds < 10 ? '0' : '') + elapsed_seconds + " / " +
|
||||||
total_minutes + ":" + (total_seconds < 10 ? '0' : '') + total_seconds;
|
total_minutes + ":" + (total_seconds < 10 ? '0' : '') + total_seconds;
|
||||||
document.getElementById('counter').innerText = counterText;
|
domCache.counter.innerText = counterText;
|
||||||
|
|
||||||
|
|
||||||
|
//Set playing track in queue view
|
||||||
if (last_state) {
|
if (last_state) {
|
||||||
$('#QueueList > tbody > tr[data-trackid=' + last_state.data.currentsongid + '] > td').eq(4).text(last_state.data.totalTime);
|
var tr = document.getElementById('queueTrackId' + last_state.data.currentsongid);
|
||||||
$('#QueueList > tbody > tr[data-trackid=' + last_state.data.currentsongid + '] > td').eq(0).removeClass('material-icons').text(last_state.data.songpos);
|
if (tr) {
|
||||||
|
var trtds = tr.getElementsByTagName('td');
|
||||||
|
trtds[4].innerText = tr.getAttribute('data-duration');
|
||||||
|
trtds[0].classList.remove('material-icons');
|
||||||
|
trtds[0].innerText = tr.getAttribute('data-songpos');
|
||||||
|
tr.classList.remove('font-weight-bold');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var tr = document.getElementById('queueTrackId' + obj.data.currentsongid);
|
||||||
|
if (tr) {
|
||||||
|
var trtds = tr.getElementsByTagName('td');
|
||||||
|
trtds[4].innerText = counterText;
|
||||||
|
trtds[0].classList.add('material-icons');
|
||||||
|
trtds[0].innerText = 'play_arrow';
|
||||||
|
tr.classList.add('font-weight-bold');
|
||||||
}
|
}
|
||||||
$('#QueueList > tbody > tr').removeClass('active').removeClass("font-weight-bold");
|
|
||||||
$('#QueueList > tbody > tr[data-trackid='+obj.data.currentsongid+'] > td').eq(4).text(counterText);
|
|
||||||
$('#QueueList > tbody > tr[data-trackid='+obj.data.currentsongid+'] > td').eq(0).addClass('material-icons').text('play_arrow');
|
|
||||||
$('#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)
|
||||||
@ -556,9 +582,9 @@ function parseState(obj) {
|
|||||||
|
|
||||||
function getQueue() {
|
function getQueue() {
|
||||||
if (app.current.search.length >= 2)
|
if (app.current.search.length >= 2)
|
||||||
sendAPI({"cmd":"MPD_API_SEARCH_QUEUE", "data": {"mpdtag":app.current.filter, "offset":app.current.page,"searchstr": app.current.search}},parseQueue);
|
sendAPI({"cmd":"MPD_API_SEARCH_QUEUE", "data": {"mpdtag":app.current.filter, "offset":app.current.page,"searchstr": app.current.search}}, parseQueue);
|
||||||
else
|
else
|
||||||
sendAPI({"cmd":"MPD_API_GET_QUEUE", "data": {"offset": app.current.page}},parseQueue);
|
sendAPI({"cmd":"MPD_API_GET_QUEUE", "data": {"offset": app.current.page}}, parseQueue);
|
||||||
}
|
}
|
||||||
|
|
||||||
function parseQueue(obj) {
|
function parseQueue(obj) {
|
||||||
@ -572,38 +598,41 @@ function parseQueue(obj) {
|
|||||||
else
|
else
|
||||||
document.getElementById('panel-heading-queue').innerText = '';
|
document.getElementById('panel-heading-queue').innerText = '';
|
||||||
|
|
||||||
var nrItems=0;
|
var nrItems = obj.data.length;
|
||||||
var tbody = document.getElementById(app.current.app + 'List').getElementsByTagName('tbody')[0];
|
var tbody = document.getElementById(app.current.app + 'List').getElementsByTagName('tbody')[0];
|
||||||
var tr = tbody.getElementsByTagName('tr');
|
var tr = tbody.getElementsByTagName('tr');
|
||||||
for (var item in obj.data) {
|
for (var i = 0; i < nrItems; i ++) {
|
||||||
nrItems++;
|
if (tr[i])
|
||||||
if (tr[nrItems-1])
|
if (tr[i].getAttribute('data-trackid') == obj.data[i].id)
|
||||||
if (tr[nrItems-1].getAttribute('data-trackid') == obj.data[item].id)
|
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
var minutes = Math.floor(obj.data[i].duration / 60);
|
||||||
|
var seconds = obj.data[i].duration - minutes * 60;
|
||||||
|
var duration = minutes + ':' + (seconds < 10 ? '0' : '') + seconds;
|
||||||
var row = document.createElement('tr');
|
var row = document.createElement('tr');
|
||||||
row.setAttribute('data-trackid', obj.data[item].id);
|
|
||||||
|
|
||||||
var minutes = Math.floor(obj.data[item].duration / 60);
|
row.setAttribute('data-trackid', obj.data[i].id);
|
||||||
var seconds = obj.data[item].duration - minutes * 60;
|
row.setAttribute('id','queueTrackId' + obj.data[i].id);
|
||||||
|
row.setAttribute('data-songpos', (obj.data[i].pos + 1));
|
||||||
row.innerHTML = '<td>' + (obj.data[item].pos + 1) + '</td>' +
|
row.setAttribute('data-duration', duration);
|
||||||
'<td>' + obj.data[item].title + '</td>' +
|
row.innerHTML = '<td>' + (obj.data[i].pos + 1) + '</td>' +
|
||||||
'<td>' + obj.data[item].artist + '</td>' +
|
'<td>' + obj.data[i].title + '</td>' +
|
||||||
'<td>' + obj.data[item].album + '</td>' +
|
'<td>' + obj.data[i].artist + '</td>' +
|
||||||
'<td>' + minutes + ':' + (seconds < 10 ? '0' : '') + seconds +
|
'<td>' + obj.data[i].album + '</td>' +
|
||||||
'</td><td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td></tr>';
|
'<td>' + duration + '</td>' +
|
||||||
if (nrItems <= tr.length)
|
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td></tr>';
|
||||||
tr[nrItems-1].replaceWith(row);
|
if (i < tr.length)
|
||||||
|
tr[i].replaceWith(row);
|
||||||
else
|
else
|
||||||
tbody.append(row);
|
tbody.append(row);
|
||||||
|
|
||||||
tr[nrItems-1].getElementsByTagName('a')[0].addEventListener('click', function(event) {
|
tr[i].getElementsByTagName('a')[0].addEventListener('click', function(event) {
|
||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
showMenu(this);
|
showMenu(this);
|
||||||
},false);
|
},false);
|
||||||
|
|
||||||
tr[nrItems-1].addEventListener('click', function() {
|
tr[i].addEventListener('click', function() {
|
||||||
sendAPI({"cmd":"MPD_API_PLAY_TRACK","data": {"track":this.getAttribute('data-trackid')}});
|
sendAPI({"cmd":"MPD_API_PLAY_TRACK","data": {"track":this.getAttribute('data-trackid')}});
|
||||||
},false);
|
},false);
|
||||||
}
|
}
|
||||||
@ -638,54 +667,53 @@ function parseSearch(obj) {
|
|||||||
function parseFilesystem(obj) {
|
function parseFilesystem(obj) {
|
||||||
if (app.current.app !== 'Browse' && app.current.tab !== 'Filesystem' && app.current.app !== 'Search')
|
if (app.current.app !== 'Browse' && app.current.tab !== 'Filesystem' && app.current.app !== 'Search')
|
||||||
return;
|
return;
|
||||||
var nrItems = 0;
|
var nrItems = obj.data.length;;
|
||||||
var tbody = document.getElementById(app.current.app + (app.current.tab==undefined ? '' : app.current.tab) + 'List').getElementsByTagName('tbody')[0];
|
var tbody = document.getElementById(app.current.app + (app.current.tab==undefined ? '' : app.current.tab) + 'List').getElementsByTagName('tbody')[0];
|
||||||
var tr = tbody.getElementsByTagName('tr');
|
var tr = tbody.getElementsByTagName('tr');
|
||||||
for (var item in obj.data) {
|
for (var i = 0; i < nrItems; i ++) {
|
||||||
nrItems ++;
|
var uri = encodeURI(obj.data[i].uri);
|
||||||
var uri = encodeURI(obj.data[item].uri);
|
if (tr[i])
|
||||||
if (tr[nrItems-1])
|
if (tr[i].getAttribute('data-uri') == uri)
|
||||||
if (tr[nrItems-1].getAttribute('data-uri') == uri)
|
|
||||||
continue;
|
continue;
|
||||||
var row = document.createElement('tr');
|
var row = document.createElement('tr');
|
||||||
row.setAttribute('data-type', obj.data[item].type);
|
row.setAttribute('data-type', obj.data[i].type);
|
||||||
row.setAttribute('data-uri', uri);
|
row.setAttribute('data-uri', uri);
|
||||||
row.setAttribute('data-name', obj.data[item].name);
|
row.setAttribute('data-name', obj.data[i].name);
|
||||||
|
|
||||||
switch(obj.data[item].type) {
|
switch(obj.data[i].type) {
|
||||||
case 'dir':
|
case 'dir':
|
||||||
row.innerHTML = '<td><span class="material-icons">folder_open</span></td>' +
|
row.innerHTML = '<td><span class="material-icons">folder_open</span></td>' +
|
||||||
'<td colspan="4">' + obj.data[item].name + '</td>' +
|
'<td colspan="4">' + obj.data[i].name + '</td>' +
|
||||||
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>';
|
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>';
|
||||||
break;
|
break;
|
||||||
case 'song':
|
case 'song':
|
||||||
var minutes = Math.floor(obj.data[item].duration / 60);
|
var minutes = Math.floor(obj.data[i].duration / 60);
|
||||||
var seconds = obj.data[item].duration - minutes * 60;
|
var seconds = obj.data[i].duration - minutes * 60;
|
||||||
row.innerHTML = '<td><span class="material-icons">music_note</span></td>' +
|
row.innerHTML = '<td><span class="material-icons">music_note</span></td>' +
|
||||||
'<td>' + obj.data[item].title + '</td>' +
|
'<td>' + obj.data[i].title + '</td>' +
|
||||||
'<td>' + obj.data[item].artist + '</td>' +
|
'<td>' + obj.data[i].artist + '</td>' +
|
||||||
'<td>' + obj.data[item].album + '</td>' +
|
'<td>' + obj.data[i].album + '</td>' +
|
||||||
'<td>' + minutes + ':' + (seconds < 10 ? '0' : '') + seconds +
|
'<td>' + minutes + ':' + (seconds < 10 ? '0' : '') + seconds +
|
||||||
'</td><td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>';
|
'</td><td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>';
|
||||||
break;
|
break;
|
||||||
case 'plist':
|
case 'plist':
|
||||||
row.innerHTML = '<td><span class="material-icons">list</span></td>' +
|
row.innerHTML = '<td><span class="material-icons">list</span></td>' +
|
||||||
'<td colspan="4">' + obj.data[item].name + '</td>' +
|
'<td colspan="4">' + obj.data[i].name + '</td>' +
|
||||||
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>';
|
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>';
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (nrItems <= tr.length)
|
if (i < tr.length)
|
||||||
tr[nrItems-1].replaceWith(row);
|
tr[i].replaceWith(row);
|
||||||
else
|
else
|
||||||
tbody.append(row);
|
tbody.append(row);
|
||||||
|
|
||||||
tr[nrItems-1].getElementsByTagName('a')[0].addEventListener('click', function(event) {
|
tr[i].getElementsByTagName('a')[0].addEventListener('click', function(event) {
|
||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
showMenu(this);
|
showMenu(this);
|
||||||
},false);
|
},false);
|
||||||
|
|
||||||
tr[nrItems-1].addEventListener('click', function() {
|
tr[i].addEventListener('click', function() {
|
||||||
switch(this.getAttribute('data-type')) {
|
switch(this.getAttribute('data-type')) {
|
||||||
case 'dir':
|
case 'dir':
|
||||||
app.goto('Browse', 'Filesystem', undefined, '0/' + app.current.filter +'/' + decodeURI(this.getAttribute("data-uri")));
|
app.goto('Browse', 'Filesystem', undefined, '0/' + app.current.filter +'/' + decodeURI(this.getAttribute("data-uri")));
|
||||||
@ -715,36 +743,36 @@ function parseFilesystem(obj) {
|
|||||||
function parsePlaylists(obj) {
|
function parsePlaylists(obj) {
|
||||||
if (app.current.app !== 'Browse' && app.current.tab !== 'Playlists')
|
if (app.current.app !== 'Browse' && app.current.tab !== 'Playlists')
|
||||||
return;
|
return;
|
||||||
var nrItems = 0;
|
|
||||||
|
var nrItems = obj.data.length;
|
||||||
var tbody = document.getElementById(app.current.app+app.current.tab+'List').getElementsByTagName('tbody')[0];
|
var tbody = document.getElementById(app.current.app+app.current.tab+'List').getElementsByTagName('tbody')[0];
|
||||||
var tr = tbody.getElementsByTagName('tr');
|
var tr = tbody.getElementsByTagName('tr');
|
||||||
for (var item in obj.data) {
|
for (var i = 0; i < nrItems; i ++) {
|
||||||
nrItems++;
|
var uri = encodeURI(obj.data[i].uri);
|
||||||
var uri = encodeURI(obj.data[item].uri);
|
if (tr[i])
|
||||||
if (tr[nrItems-1])
|
if (tr[i].getAttribute('data-uri') == uri)
|
||||||
if (tr[nrItems-1].getAttribute('data-uri') == uri)
|
|
||||||
continue;
|
continue;
|
||||||
var d = new Date(obj.data[item].last_modified * 1000);
|
var d = new Date(obj.data[i].last_modified * 1000);
|
||||||
var row = document.createElement('tr');
|
var row = document.createElement('tr');
|
||||||
row.setAttribute('data-uri', uri);
|
row.setAttribute('data-uri', uri);
|
||||||
row.setAttribute('data-type', 'plist');
|
row.setAttribute('data-type', 'plist');
|
||||||
row.setAttribute('data-name', obj.data[item].name);
|
row.setAttribute('data-name', obj.data[i].name);
|
||||||
row.innerHTML = '<td><span class="material-icons">list</span></td>' +
|
row.innerHTML = '<td><span class="material-icons">list</span></td>' +
|
||||||
'<td>' + obj.data[item].name + '</td>' +
|
'<td>' + obj.data[i].name + '</td>' +
|
||||||
'<td>'+ d.toUTCString() + '</td>' +
|
'<td>'+ d.toUTCString() + '</td>' +
|
||||||
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>';
|
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>';
|
||||||
if (nrItems <= tr.length)
|
if (i < tr.length)
|
||||||
tr[nrItems-1].replaceWith(row);
|
tr[i].replaceWith(row);
|
||||||
else
|
else
|
||||||
tbody.append(row);
|
tbody.append(row);
|
||||||
|
|
||||||
tr[nrItems-1].getElementsByTagName('a')[0].addEventListener('click', function(event) {
|
tr[i].getElementsByTagName('a')[0].addEventListener('click', function(event) {
|
||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
showMenu(this);
|
showMenu(this);
|
||||||
},false);
|
},false);
|
||||||
|
|
||||||
tr[nrItems-1].addEventListener('click', function() {
|
tr[i].addEventListener('click', function() {
|
||||||
appendQueue('plist', decodeURI(this.getAttribute("data-uri")), this.getAttribute("data-name"));
|
appendQueue('plist', decodeURI(this.getAttribute("data-uri")), this.getAttribute("data-name"));
|
||||||
},false);
|
},false);
|
||||||
}
|
}
|
||||||
@ -768,34 +796,33 @@ function parseListDBtags(obj) {
|
|||||||
$('#BrowseDatabaseAlbumCards').addClass('hide');
|
$('#BrowseDatabaseAlbumCards').addClass('hide');
|
||||||
$('#BrowseDatabaseArtistList').removeClass('hide');
|
$('#BrowseDatabaseArtistList').removeClass('hide');
|
||||||
$('#btnBrowseDatabaseArtist').addClass('hide');
|
$('#btnBrowseDatabaseArtist').addClass('hide');
|
||||||
var nrItems = 0;
|
var nrItems = obj.data.length;
|
||||||
var tbody = document.getElementById(app.current.app+app.current.tab+app.current.view+'List').getElementsByTagName('tbody')[0];
|
var tbody = document.getElementById(app.current.app+app.current.tab+app.current.view+'List').getElementsByTagName('tbody')[0];
|
||||||
var tr = tbody.getElementsByTagName('tr');
|
var tr = tbody.getElementsByTagName('tr');
|
||||||
for (var item in obj.data) {
|
for (var i = 0; i < nrItems; i ++) {
|
||||||
nrItems++;
|
var uri = encodeURI(obj.data[i].value);
|
||||||
var uri = encodeURI(obj.data[item].value);
|
if (tr[i])
|
||||||
if (tr[nrItems-1])
|
if (tr[i].getAttribute('data-uri') == uri)
|
||||||
if (tr[nrItems-1].getAttribute('data-uri') == uri)
|
|
||||||
continue;
|
continue;
|
||||||
var row = document.createElement('tr');
|
var row = document.createElement('tr');
|
||||||
row.setAttribute('data-uri', uri);
|
row.setAttribute('data-uri', uri);
|
||||||
row.innerHTML='<td><span class="material-icons">album</span></td>' +
|
row.innerHTML='<td><span class="material-icons">album</span></td>' +
|
||||||
'<td>' + obj.data[item].value + '</td>' +
|
'<td>' + obj.data[i].value + '</td>' +
|
||||||
'<!--<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>-->' +
|
// '<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>' +
|
||||||
'</tr>';
|
'</tr>';
|
||||||
|
|
||||||
if (nrItems <= tr.length)
|
if (i < tr.length)
|
||||||
tr[nrItems-1].replaceWith(row);
|
tr[i].replaceWith(row);
|
||||||
else
|
else
|
||||||
tbody.append(row);
|
tbody.append(row);
|
||||||
/*
|
/*
|
||||||
tr[nrItems-1].getElementsByTagName('a')[0].addEventListener('click', function(event) {
|
tr[i].getElementsByTagName('a')[0].addEventListener('click', function(event) {
|
||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
showMenu(this);
|
showMenu(this);
|
||||||
},false);
|
},false);
|
||||||
*/
|
*/
|
||||||
tr[nrItems-1].addEventListener('click', function() {
|
tr[i].addEventListener('click', function() {
|
||||||
app.goto('Browse','Database','Album','0/-/'+this.getAttribute('data-uri'));
|
app.goto('Browse','Database','Album','0/-/'+this.getAttribute('data-uri'));
|
||||||
},false);
|
},false);
|
||||||
}
|
}
|
||||||
@ -814,14 +841,13 @@ function parseListDBtags(obj) {
|
|||||||
$('#BrowseDatabaseArtistList').addClass('hide');
|
$('#BrowseDatabaseArtistList').addClass('hide');
|
||||||
$('#BrowseDatabaseAlbumCards').removeClass('hide');
|
$('#BrowseDatabaseAlbumCards').removeClass('hide');
|
||||||
$('#btnBrowseDatabaseArtist').removeClass('hide');
|
$('#btnBrowseDatabaseArtist').removeClass('hide');
|
||||||
var nrItems=0;
|
var nrItems = obj.data.length;
|
||||||
var cardContainer=document.getElementById('BrowseDatabaseAlbumCards')
|
var cardContainer = document.getElementById('BrowseDatabaseAlbumCards')
|
||||||
var cards=cardContainer.querySelectorAll('.col-md');
|
var cards = cardContainer.querySelectorAll('.col-md');
|
||||||
for (var item in obj.data) {
|
for (var i = 0; i < nrItems; i++) {
|
||||||
nrItems++;
|
var id=genId(obj.data[i].value);
|
||||||
var id=genId(obj.data[item].value);
|
if (cards[i])
|
||||||
if (cards[nrItems-1])
|
if (cards[i].getAttribute('id') == id)
|
||||||
if (cards[nrItems-1].getAttribute('id') == id)
|
|
||||||
continue;
|
continue;
|
||||||
var card=document.createElement('div');
|
var card=document.createElement('div');
|
||||||
card.classList.add('col-md');
|
card.classList.add('col-md');
|
||||||
@ -831,17 +857,17 @@ function parseListDBtags(obj) {
|
|||||||
' <img class="card-img-top" src="" tabindex="0" data-trigger="focus">' +
|
' <img class="card-img-top" src="" tabindex="0" data-trigger="focus">' +
|
||||||
' <div class="card-body">' +
|
' <div class="card-body">' +
|
||||||
' <h5 class="card-title">' + obj.searchstr + '</h5>' +
|
' <h5 class="card-title">' + obj.searchstr + '</h5>' +
|
||||||
' <h4 class="card-title">' + obj.data[item].value + '</h4>' +
|
' <h4 class="card-title">' + obj.data[i].value + '</h4>' +
|
||||||
' <table class="table table-sm table-hover" id="tbl' + id + '"><tbody></tbody></table'+
|
' <table class="table table-sm table-hover" id="tbl' + id + '"><tbody></tbody></table'+
|
||||||
' </div>'+
|
' </div>'+
|
||||||
'</div>';
|
'</div>';
|
||||||
|
|
||||||
if (nrItems <= cards.length)
|
if (i < cards.length)
|
||||||
cards[nrItems-1].replaceWith(card);
|
cards[i].replaceWith(card);
|
||||||
else
|
else
|
||||||
cardContainer.append(card);
|
cardContainer.append(card);
|
||||||
|
|
||||||
sendAPI({"cmd":"MPD_API_GET_ARTISTALBUMTITLES", "data": { "albumartist": obj.searchstr, "album": obj.data[item].value}}, parseListTitles);
|
sendAPI({"cmd":"MPD_API_GET_ARTISTALBUMTITLES", "data": { "albumartist": obj.searchstr, "album": obj.data[i].value}}, parseListTitles);
|
||||||
}
|
}
|
||||||
var cards_length=cards.length - 1;
|
var cards_length=cards.length - 1;
|
||||||
for (var i = cards_length; i >= nrItems; i --) {
|
for (var i = cards_length; i >= nrItems; i --) {
|
||||||
@ -865,9 +891,10 @@ function parseListTitles(obj) {
|
|||||||
img.setAttribute('data-type', 'album');
|
img.setAttribute('data-type', 'album');
|
||||||
|
|
||||||
var titleList=new Array();
|
var titleList=new Array();
|
||||||
for (var item in obj.data) {
|
var nrItems = obj.data.length;
|
||||||
titleList.push('<tr data-type="song" data-name="' + obj.data[item].title + '" data-uri="' + encodeURI(obj.data[item].uri) + '">' +
|
for (var i = 0; i < nrItems; i ++) {
|
||||||
'<td>' + obj.data[item].track + '</td><td>' + obj.data[item].title + '</td>' +
|
titleList.push('<tr data-type="song" data-name="' + obj.data[i].title + '" data-uri="' + encodeURI(obj.data[i].uri) + '">' +
|
||||||
|
'<td>' + obj.data[i].track + '</td><td>' + obj.data[i].title + '</td>' +
|
||||||
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>' +
|
'<td><a href="#" tabindex="0" data-trigger="focus" class="material-icons">playlist_add</a></td>' +
|
||||||
'</tr>');
|
'</tr>');
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user