1
0
mirror of https://github.com/SuperBFG7/ympd synced 2025-10-25 02:47:41 +00:00

Added Replaygain to settings

Improved coverimage display
This commit is contained in:
jcorporation
2018-05-31 21:23:57 +01:00
parent 060aeff3ff
commit 7d5accdb92
6 changed files with 92 additions and 41 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.9 KiB

View File

Before

Width:  |  Height:  |  Size: 10 KiB

After

Width:  |  Height:  |  Size: 10 KiB

View File

@@ -464,6 +464,16 @@
</div> </div>
<input id="inputCrossfade" type="text" class="form-control border-secondary" value=""> <input id="inputCrossfade" type="text" class="form-control border-secondary" value="">
</div> </div>
<div class="form-group input-group col-md-6 border-secondary">
<div class="input-group-prepend">
<div class="input-group-text bg-secondary text-light border-secondary">Replaygain</div>
</div>
<select id="selectReplaygain" class="form-control border-secondary">
<option value="off">Off</option>
<option value="track">Track</option>
<option value="album">Album</option>
</select>
</div>
</div> </div>
<div class="row"> <div class="row">
<div class="form-group input-group col-md-6 border-secondary"> <div class="form-group input-group col-md-6 border-secondary">

View File

@@ -45,7 +45,6 @@ var app = $.sammy(function() {
$('#cardQueue').addClass('hide'); $('#cardQueue').addClass('hide');
$('#cardBrowse').addClass('hide'); $('#cardBrowse').addClass('hide');
$('#cardSearch').addClass('hide'); $('#cardSearch').addClass('hide');
$('.pagination').addClass('hide');
$('#searchqueue > input').val(''); $('#searchqueue > input').val('');
$('#cardBrowsePlaylists').addClass('hide'); $('#cardBrowsePlaylists').addClass('hide');
$('#cardBrowseDatabase').addClass('hide'); $('#cardBrowseDatabase').addClass('hide');
@@ -81,7 +80,6 @@ var app = $.sammy(function() {
$('#cardQueue').removeClass('hide'); $('#cardQueue').removeClass('hide');
$('#navQueue').addClass('active'); $('#navQueue').addClass('active');
} }
//$('#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 +121,6 @@ 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();
$('#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
@@ -252,14 +249,13 @@ function webSocketConnect() {
try { try {
socket.onopen = function() { socket.onopen = function() {
console.log("connected"); console.log("connected");
showNotification('Connected to myMPD','','','success');
$('#modalConnectionError').modal('hide');
app.run();
/* emit request for mympd settings */ /* emit request for mympd settings */
socket.send('MPD_API_GET_SETTINGS'); socket.send('MPD_API_GET_SETTINGS');
/* emit initial request for output names */ /* emit initial request for output names */
socket.send('MPD_API_GET_OUTPUTS'); socket.send('MPD_API_GET_OUTPUTS');
showNotification('Connected to myMPD','','','success');
$('#modalConnectionError').modal('hide');
app.run();
} }
socket.onmessage = function got_packet(msg) { socket.onmessage = function got_packet(msg) {
@@ -278,7 +274,6 @@ function webSocketConnect() {
if(current_app !== 'queue') if(current_app !== 'queue')
break; break;
$('#panel-heading-queue').empty(); $('#panel-heading-queue').empty();
if (obj.totalEntities > 0) { if (obj.totalEntities > 0) {
$('#panel-heading-queue').text(obj.totalEntities+' Songs'); $('#panel-heading-queue').text(obj.totalEntities+' Songs');
} }
@@ -286,7 +281,6 @@ function webSocketConnect() {
$('#panel-heading-queue').append(' ' + beautifyDuration(obj.totalTime)); $('#panel-heading-queue').append(' ' + beautifyDuration(obj.totalTime));
} }
//$('#queueList > tbody').empty();
var nrItems=0; var nrItems=0;
var tr=document.getElementById(current_app+'List').getElementsByTagName('tbody')[0].getElementsByTagName('tr'); var tr=document.getElementById(current_app+'List').getElementsByTagName('tbody')[0].getElementsByTagName('tr');
for (var song in obj.data) { for (var song in obj.data) {
@@ -407,7 +401,6 @@ function webSocketConnect() {
} }
break; break;
case 'search': case 'search':
//$('#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')
@@ -577,7 +570,6 @@ function webSocketConnect() {
break; break;
case 'disconnected': case 'disconnected':
showNotification('myMPD lost connection to MPD','','','danger'); showNotification('myMPD lost connection to MPD','','','danger');
break; break;
case 'update_queue': case 'update_queue':
if(current_app === 'queue') { if(current_app === 'queue') {
@@ -632,6 +624,8 @@ function webSocketConnect() {
else else
$('#btnrepeat').removeClass("btn-success").addClass("btn-secondary"); $('#btnrepeat').removeClass("btn-success").addClass("btn-secondary");
$("#selectReplaygain").val(obj.data.replaygain);
setLocalStream(obj.data.mpdhost,obj.data.streamport); setLocalStream(obj.data.mpdhost,obj.data.streamport);
coverImageFile=obj.data.coverimage; coverImageFile=obj.data.coverimage;
break; break;
@@ -823,56 +817,69 @@ function toggleBtn(btn) {
} }
$('#btnrandom').on('click', function (e) { $('#btnrandom').on('click', function (e) {
socket.send("MPD_API_TOGGLE_RANDOM," + ($(this).hasClass('btn-success') ? 0 : 1));
toggleBtn(this); toggleBtn(this);
}); });
$('#btnconsume').on('click', function (e) { $('#btnconsume').on('click', function (e) {
socket.send("MPD_API_TOGGLE_CONSUME," + ($(this).hasClass('btn-success') ? 0 : 1));
toggleBtn(this); toggleBtn(this);
}); });
$('#btnsingle').on('click', function (e) { $('#btnsingle').on('click', function (e) {
socket.send("MPD_API_TOGGLE_SINGLE," + ($(this).hasClass('btn-success') ? 0 : 1));
toggleBtn(this); toggleBtn(this);
}); });
$('#btnrepeat').on('click', function (e) { $('#btnrepeat').on('click', function (e) {
socket.send("MPD_API_TOGGLE_REPEAT," + ($(this).hasClass('btn-success') ? 0 : 1));
toggleBtn(this); toggleBtn(this);
}); });
function confirmSettings() { function confirmSettings() {
var formOK=true;
if (!$('#inputCrossfade').is(':disabled')) {
var value=parseInt($('#inputCrossfade').val()); var value=parseInt($('#inputCrossfade').val());
if (!isNaN(value)) { if (!isNaN(value)) {
$('#inputCrossfade').val(value); $('#inputCrossfade').val(value);
socket.send("MPD_API_SET_CROSSFADE," + value);
} else { } else {
$('#inputCrossfade').popover({"content":"Must be a number","trigger":"manual"}); $('#inputCrossfade').popover({"content":"Must be a number","trigger":"manual"});
$('#inputCrossfade').popover('show'); $('#inputCrossfade').popover('show');
$('#inputCrossfade').focus(); $('#inputCrossfade').focus();
return; formOK=false;
} }
}
if (!$('#inputMixrampdb').is(':disabled')) {
value=parseFloat($('#inputMixrampdb').val()); value=parseFloat($('#inputMixrampdb').val());
if (!isNaN(value)) { if (!isNaN(value)) {
$('#inputMixrampdb').val(value); $('#inputMixrampdb').val(value);
socket.send("MPD_API_SET_MIXRAMPDB," + value);
} else { } else {
$('#inputMixrampdb').popover({"content":"Must be a number","trigger":"manual"}); $('#inputMixrampdb').popover({"content":"Must be a number","trigger":"manual"});
$('#inputMixrampdb').popover('show'); $('#inputMixrampdb').popover('show');
$('#inputMixrampdb').focus(); $('#inputMixrampdb').focus();
return; formOK=false;
} }
}
if (!$('#inputMixrampdelay').is(':disabled')) {
value=parseFloat($('#inputMixrampdelay').val()); value=parseFloat($('#inputMixrampdelay').val());
if (!isNaN(value)) { if (!isNaN(value)) {
$('#inputMixrampdelay').val(value); $('#inputMixrampdelay').val(value);
socket.send("MPD_API_SET_MIXRAMPDELAY," + value);
} else { } else {
$('#inputMixrampdelay').popover({"content":"Must be a number","trigger":"manual"}); $('#inputMixrampdelay').popover({"content":"Must be a number","trigger":"manual"});
$('#inputMixrampdelay').popover('show'); $('#inputMixrampdelay').popover('show');
$('#inputMixrampdelay').focus(); $('#inputMixrampdelay').focus();
return; formOK=false;
} }
}
if (formOK == true) {
socket.send("MPD_API_TOGGLE_CONSUME," + ($('#btnconsume').hasClass('btn-success') ? 1 : 0));
socket.send("MPD_API_TOGGLE_RANDOM," + ($('#btnrandom').hasClass('btn-success') ? 1 : 0));
socket.send("MPD_API_TOGGLE_SINGLE," + ($('#btnsingle').hasClass('btn-success') ? 1 : 0));
socket.send("MPD_API_TOGGLE_REPEAT," + ($('#btnrepeat').hasClass('btn-success') ? 1 : 0));
socket.send("MPD_API_SET_REPLAYGAIN," + $('#selectReplaygain').val());
if (!$('#inputCrossfade').is(':disabled'))
socket.send("MPD_API_SET_CROSSFADE," + $('#inputCrossfade').val());
if (!$('#inputMixrampdb').is(':disabled'))
socket.send("MPD_API_SET_MIXRAMPDB," + $('#inputMixrampdb').val());
if (!$('#inputMixrampdelay').is(':disabled'))
socket.send("MPD_API_SET_MIXRAMPDELAY," + $('#inputMixrampdelay').val());
$('#settings').modal('hide'); $('#settings').modal('hide');
} }
}
function toggleoutput(button, id) { function toggleoutput(button, id) {
socket.send("MPD_API_TOGGLE_OUTPUT,"+id+"," + ($(button).hasClass('btn-success') ? 0 : 1)); socket.send("MPD_API_TOGGLE_OUTPUT,"+id+"," + ($(button).hasClass('btn-success') ? 0 : 1));
@@ -1061,12 +1068,14 @@ function songChange(title, artist, album, uri) {
if (typeof uri != 'undefined' && uri.length > 0) { if (typeof uri != 'undefined' && uri.length > 0) {
var coverImg=''; var coverImg='';
if (uri.indexOf('http://') == 0) { if (uri.indexOf('http://') == 0 || uri.indexOf('https://') == 0 ) {
coverImg='/assets/httpstream.png'; coverImg='/assets/coverimage-httpstream.png';
} else { } else if (coverImageFile != '') {
coverImg='/library/'+uri.replace(/\/[^\/]+$/,'\/'+coverImageFile); coverImg='/library/'+uri.replace(/\/[^\/]+$/,'\/'+coverImageFile);
} else {
coverImg='/assets/coverimage-notavailable.png';
} }
$('#album-cover').css('backgroundImage','url("'+coverImg+'")'); $('#album-cover').css('backgroundImage','url("'+coverImg+'"),url("/assets/coverimage-notavailable.png")');
} }
if(typeof artist != 'undefined' && artist.length > 0 && artist != '-') { if(typeof artist != 'undefined' && artist.length > 0 && artist != '-') {
textNotification += artist; textNotification += artist;

View File

@@ -337,6 +337,24 @@ out_rm_playlist:
case MPD_API_GET_STATS: case MPD_API_GET_STATS:
n = mympd_get_stats(mpd.buf); n = mympd_get_stats(mpd.buf);
break; break;
case MPD_API_SET_REPLAYGAIN:
p_charbuf = strdup(c->content);
if(strcmp(strtok(p_charbuf, ","), "MPD_API_SET_REPLAYGAIN"))
goto out_set_replaygain;
if((token = strtok(NULL, ",")) == NULL)
goto out_set_replaygain;
free(p_charbuf);
p_charbuf = strdup(c->content);
mpd_send_command(mpd.conn, "replay_gain_mode", get_arg1(p_charbuf), NULL);
struct mpd_pair *pair;
while ((pair = mpd_recv_pair(mpd.conn)) != NULL) {
mpd_return_pair(mpd.conn, pair);
}
out_set_replaygain:
free(p_charbuf);
break;
} }
if(mpd.conn_state == MPD_CONNECTED && mpd_connection_get_error(mpd.conn) != MPD_ERROR_SUCCESS) if(mpd.conn_state == MPD_CONNECTED && mpd_connection_get_error(mpd.conn) != MPD_ERROR_SUCCESS)
@@ -549,6 +567,7 @@ char* mpd_get_year(struct mpd_song const *song)
int mpd_put_state(char *buffer, int *current_song_id, int *next_song_id, unsigned *queue_version) int mpd_put_state(char *buffer, int *current_song_id, int *next_song_id, unsigned *queue_version)
{ {
struct mpd_status *status; struct mpd_status *status;
const struct mpd_audio_format *audioformat;
int len; int len;
status = mpd_run_status(mpd.conn); status = mpd_run_status(mpd.conn);
@@ -557,11 +576,13 @@ int mpd_put_state(char *buffer, int *current_song_id, int *next_song_id, unsign
mpd.conn_state = MPD_FAILURE; mpd.conn_state = MPD_FAILURE;
return 0; return 0;
} }
audioformat = mpd_status_get_audio_format(status);
len = snprintf(buffer, MAX_SIZE, len = snprintf(buffer, MAX_SIZE,
"{\"type\":\"state\", \"data\":{" "{\"type\":\"state\", \"data\":{"
"\"state\":%d, \"volume\":%d, \"songpos\": %d, \"elapsedTime\": %d, " "\"state\":%d, \"volume\":%d, \"songpos\": %d, \"elapsedTime\": %d, "
"\"totalTime\":%d, \"currentsongid\": %d, \"kbitrate\": %d, " "\"totalTime\":%d, \"currentsongid\": %d, \"kbitrate\": %d, "
"\"audioformat\": { \"sample_rate\": %d, \"bits\": %d, \"channels\": %d}, "
"\"queue_length\": %d, \"nextsongpos\": %d" "\"queue_length\": %d, \"nextsongpos\": %d"
"}}", "}}",
mpd_status_get_state(status), mpd_status_get_state(status),
@@ -571,6 +592,7 @@ int mpd_put_state(char *buffer, int *current_song_id, int *next_song_id, unsign
mpd_status_get_total_time(status), mpd_status_get_total_time(status),
mpd_status_get_song_id(status), mpd_status_get_song_id(status),
mpd_status_get_kbit_rate(status), mpd_status_get_kbit_rate(status),
audioformat->sample_rate, audioformat->bits, audioformat->channels,
mpd_status_get_queue_length(status), mpd_status_get_queue_length(status),
mpd_status_get_next_song_pos(status) mpd_status_get_next_song_pos(status)
); );
@@ -586,6 +608,7 @@ int mympd_put_settings(char *buffer)
{ {
struct mpd_status *status; struct mpd_status *status;
int len; int len;
char *replaygain;
status = mpd_run_status(mpd.conn); status = mpd_run_status(mpd.conn);
if (!status) { if (!status) {
@@ -594,11 +617,18 @@ int mympd_put_settings(char *buffer)
return 0; return 0;
} }
mpd_send_command(mpd.conn, "replay_gain_status", NULL);
struct mpd_pair *pair;
while ((pair = mpd_recv_pair(mpd.conn)) != NULL) {
replaygain=strdup(pair->value);
mpd_return_pair(mpd.conn, pair);
}
len = snprintf(buffer, MAX_SIZE, len = snprintf(buffer, MAX_SIZE,
"{\"type\":\"settings\", \"data\":{" "{\"type\":\"settings\", \"data\":{"
"\"repeat\":%d, \"single\":%d, \"crossfade\":%d, \"consume\":%d, \"random\":%d, " "\"repeat\":%d, \"single\":%d, \"crossfade\":%d, \"consume\":%d, \"random\":%d, "
"\"mixrampdb\": %lf, \"mixrampdelay\": %lf, \"mpdhost\" : \"%s\", \"mpdport\": \"%d\", \"passwort_set\": %s, " "\"mixrampdb\": %lf, \"mixrampdelay\": %lf, \"mpdhost\" : \"%s\", \"mpdport\": \"%d\", \"passwort_set\": %s, "
"\"streamport\": \"%d\",\"coverimage\": \"%s\", \"max_elements_per_page\": %d" "\"streamport\": \"%d\",\"coverimage\": \"%s\", \"max_elements_per_page\": %d, \"replaygain\": \"%s\""
"}}", "}}",
mpd_status_get_repeat(status), mpd_status_get_repeat(status),
mpd_status_get_single(status), mpd_status_get_single(status),
@@ -610,7 +640,8 @@ int mympd_put_settings(char *buffer)
mpd.host, mpd.port, mpd.host, mpd.port,
mpd.password ? "true" : "false", mpd.password ? "true" : "false",
streamport, coverimage, streamport, coverimage,
MAX_ELEMENTS_PER_PAGE MAX_ELEMENTS_PER_PAGE,
replaygain
); );
mpd_status_free(status); mpd_status_free(status);
return len; return len;

View File

@@ -78,7 +78,8 @@
X(MPD_API_SET_MIXRAMPDB) \ X(MPD_API_SET_MIXRAMPDB) \
X(MPD_API_SET_MIXRAMPDELAY) \ X(MPD_API_SET_MIXRAMPDELAY) \
X(MPD_API_GET_PLAYLISTS) \ X(MPD_API_GET_PLAYLISTS) \
X(MPD_API_RM_PLAYLIST) X(MPD_API_RM_PLAYLIST) \
X(MPD_API_SET_REPLAYGAIN)
enum mpd_cmd_ids { enum mpd_cmd_ids {
MPD_CMDS(GEN_ENUM) MPD_CMDS(GEN_ENUM)