tcpclient.addResponseListener(tramp_mpc_recv);
mpc = new Mpc(mpc_sender, update_ui);
console.log('connected to ' + host + ':' + port);
+ console.log('protip: use the "mpc" object to poke mpd directly.\n' +
+ 'you can also do mpc.set_debug(3) to see traffic');
mpc_refresh();
update_refresh_timer();
});
}
function update_refresh_timer() {
- if (refresh_id != NaN)
+ if (!isNaN(refresh_id))
window.clearTimeout(refresh_id);
var rate = window['opts_refresh'].value * 1000;
if (rate > 0)
'seekcur', 'setvol', 'single', 'stop',
].forEach(function(id) {
var ele = window['ui_mpc_' + id] = document.getElementById(id);
- ele.onclick = window['tramp_mpc_' + id];
+ ele.onchange = ele.onclick = window['tramp_mpc_' + id];
ele.title = id;
});
if ('file' in state) {
// Hack: should be a real object.
- ui_mpc_metadata.innerText = state['file'];
- return;
+ ui_mpc_metadata.innerText = state.file;
}
- var time = state.time.split(':');
- window['ui_mpc_seekcur'].max = time[1];
- window['ui_mpc_seekcur'].value = time[0];
+ var time;
+ if ('time' in state)
+ // When stopped, there is no time field at all.
+ time = state.time.split(':');
+ else
+ time = [0, 0];
+ window.ui_mpc_seekcur.max = time[1];
+ window.ui_mpc_seekcur.value = time[0];
+ percent = Math.floor((0.0 + time[0]) * 100 / (0.0 + time[1]));
+ window.ui_mpc_seekcur.title = 'seekcur (' + percent + '%)';
+
+ window.ui_mpc_setvol.value = state.volume;
+ window.ui_mpc_setvol.title = 'setvol (' + state.volume + '%)';
- window['ui_mpc_setvol'].value = state.volume;
[
'consume', 'random', 'repeat', 'single',
].forEach(function(id) {