feat: now playing display
This commit is contained in:
parent
8e93412d7a
commit
f6b007356b
6 changed files with 105 additions and 0 deletions
src
|
@ -69,5 +69,11 @@
|
|||
</head>
|
||||
<body class="dark:text-white bg-white dark:bg-gray-900 font-sans text-gray-800 scrollbar-thin scrollbar-thumb-purple-500 scrollbar-track-purple-100">
|
||||
{{ content }}
|
||||
{% capture js %}
|
||||
{% render "../assets/scripts/script.js" %}
|
||||
{% endcapture %}
|
||||
<script>
|
||||
{{ js }}
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
|
@ -15,5 +15,12 @@
|
|||
<span class="pt-1 md:pt-0 mr-1">{{ status.emoji }}</span>
|
||||
<span>{{ status.content }}</span>
|
||||
</p>
|
||||
<p id="now-playing" class="mb-0 flex flex-row items-start md:items-center">
|
||||
<span id="now-playing-loading" class="text--blur">Loading...</span>
|
||||
<span id="now-playing-display">
|
||||
<span id="now-playing-emoji" class="pt-1 md:pt-0 mr-1"></span>
|
||||
<span id="now-playing-content"></span>
|
||||
</span>
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
40
src/assets/scripts/script.js
Normal file
40
src/assets/scripts/script.js
Normal file
|
@ -0,0 +1,40 @@
|
|||
;(async function () {
|
||||
const nowPlaying = document.getElementById('now-playing')
|
||||
if (nowPlaying) {
|
||||
const emoji = document.getElementById('now-playing-emoji')
|
||||
const content = document.getElementById('now-playing-content')
|
||||
const loading = document.getElementById('now-playing-loading')
|
||||
|
||||
try {
|
||||
const cache = JSON.parse(localStorage.getItem('now-playing'))
|
||||
if (cache) {
|
||||
loading.style.display = 'none'
|
||||
emoji.innerText = cache.emoji
|
||||
content.innerText = `${cache.title} by ${cache.artist}`
|
||||
emoji.classList.remove('hidden')
|
||||
content.classList.remove('hidden')
|
||||
}
|
||||
} catch (e) {
|
||||
/* quiet catch */
|
||||
}
|
||||
|
||||
const res = await fetch('/api/now-playing', {
|
||||
type: 'json',
|
||||
}).catch()
|
||||
const data = await res.json()
|
||||
|
||||
try {
|
||||
localStorage.setItem('now-playing', JSON.stringify(data))
|
||||
} catch (e) {
|
||||
/* quiet catch */
|
||||
}
|
||||
|
||||
if (!JSON.parse(localStorage.getItem('now-playing')) && !data) nowPlaying.remove()
|
||||
|
||||
loading.style.display = 'none'
|
||||
emoji.innerText = data.emoji
|
||||
content.innerText = `${data.title} by ${data.artist}`
|
||||
emoji.classList.remove('hidden')
|
||||
content.classList.remove('hidden')
|
||||
}
|
||||
})()
|
Reference in a new issue