Compare commits

...

2 Commits

Author SHA1 Message Date
cffb4ec9e2 Merge remote-tracking branch 'origin/development' 2025-04-19 06:33:19 +00:00
787f799ab1 robust downloads 2025-04-19 08:32:43 +02:00
3 changed files with 30 additions and 17 deletions

View File

@ -292,7 +292,7 @@ document.querySelectorAll('.play-file').forEach(link => {
title: currentMusicFiles[currentMusicIndex].title,
artist: folderName,
artwork: [
{ src: '/static/icons/logo-192x192.png', sizes: '192x192', type: 'image/png' }
{ src: '/icons/logo-192x192.png', sizes: '192x192', type: 'image/png' }
]
});
}

View File

@ -98,20 +98,33 @@ audio.onended = function() {
playerButton.innerHTML = playIcon;
};
function downloadAudio() {
// Get the current audio source URL
const audioSrc = audio.currentSrc || audio.src;
if (audioSrc) {
// Create a temporary link element
const a = document.createElement('a');
a.href = audioSrc;
// Extract the file name from the URL, decode it, and set as download attribute
let fileName = audioSrc.split('/').pop() || 'audio';
fileName = decodeURIComponent(fileName);
a.download = fileName;
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
}
async function downloadAudio() {
const src = audio.currentSrc;
if (!src) return;
// Fetch with credentials / correct mode
const response = await fetch(src, { credentials: 'same-origin' });
if (!response.ok) throw new Error(`Download failed: ${response.status}`);
// Grab the data as a Blob
const blob = await response.blob();
// Create your own blob: URL and anchor
const url = URL.createObjectURL(blob);
const a = document.createElement('a');
a.href = url;
// Retain original filename if possible
let filename = decodeURIComponent(src.split('/').pop() || 'audio');
a.download = filename;
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
// Cleanup
URL.revokeObjectURL(url);
}

View File

@ -1,4 +1,4 @@
const cacheName = 'gottesdienste-v1.2';
const cacheName = 'gottesdienste-v1.3';
const assets = [
'/',
'/static/app.css',