From 2f64332f1c68004d79e1b51f3f015f8263b29858 Mon Sep 17 00:00:00 2001 From: Henri Bergius Date: Mon, 4 Dec 2017 16:14:46 +0100 Subject: [PATCH] Custom element for visualizing MPD status --- elements/mpd.js | 89 +++++++++++++++++++++++++++++++++++++++++++++++++ index.js | 2 ++ 2 files changed, 91 insertions(+) create mode 100644 elements/mpd.js diff --git a/elements/mpd.js b/elements/mpd.js new file mode 100644 index 0000000..db98373 --- /dev/null +++ b/elements/mpd.js @@ -0,0 +1,89 @@ +import { withComponent, props } from 'skatejs'; + +function renderTime(duration) { + let seconds = parseInt((duration)%60) + let minutes = parseInt((duration/(60))%60) + let hours = parseInt(duration/(60*60)); + + hours = (hours < 10) ? "0" + hours : hours; + minutes = (minutes < 10) ? "0" + minutes : minutes; + seconds = (seconds < 10) ? "0" + seconds : seconds; + + return hours + ":" + minutes + ":" + seconds; +} + +const Component = withComponent(); +class MPD extends Component { + static props = { + mpd: props.string, + data: props.object, + interval: props.number, + }; + + connected() { + if (!this.mpd) { + return; + } + this.fetchData(); + if (!this.interval) { + return; + } + this.runInterval = window.setInterval(() => { + this.fetchData(); + }, this.interval * 1000); + } + + disconnecting() { + if (this.runInterval) { + window.clearInterval(this.runInterval); + delete this.runInterval; + } + } + + fetchData() { + const url = `https://c-beam.cbrp3.c-base.org/mpd/${this.mpd}/status/?_${Date.now()}`; + fetch(url, { + headers: { + 'X-Requested-With': 'XMLHttpRequest', + } + }) + .then(data => data.json()) + .then((data) => { + this.data = data.content; + }); + } + + renderer(renderRoot, render) { + const root = renderRoot; + while (root.firstChild) { + root.removeChild(root.firstChild); + } + root.appendChild(render()); + } + + render({ data }) { + const el = document.createElement('div'); + if (!data.state) { + return el; + } + let status = 'Stopped'; + if (data.state === 'play') { + status = 'Now playing'; + } + let artist = data.current_song.artist ? `${data.current_song.artist} - ${data.current_song.album}` : data.current_song.name + if (!artist) { + artist = 'Unknown'; + } + const elapsed = + el.innerHTML = ` +
${status}
+
${artist}
+
${data.current_song.title}
+
${renderTime(data.elapsed)}/${renderTime(data.total)}
+
🔈
+ `; + return el; + } +} + +customElements.define('cbase-mpd', MPD); diff --git a/index.js b/index.js index f1624c0..2343812 100644 --- a/index.js +++ b/index.js @@ -1,6 +1,7 @@ import currentstate from './elements/currentstate'; import heatmap from './elements/heatmap'; import linechart from './elements/linechart'; +import mpd from './elements/mpd'; import polar from './elements/polar'; import time from './elements/time'; import userlist from './elements/userlist'; @@ -9,6 +10,7 @@ export default { currentstate, heatmap, linechart, + mpd, polar, time, userlist,