imageviewer.js will fallback to proxy image when full image fails to load

This commit is contained in:
partisan 2024-12-04 08:49:00 +01:00
parent 8f2c0d45f8
commit 72d76c85ed
2 changed files with 23 additions and 11 deletions

View file

@ -511,5 +511,6 @@ func serveMissingImage(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Cache-Control", "no-store, must-revalidate") w.Header().Set("Cache-Control", "no-store, must-revalidate")
w.Header().Set("Pragma", "no-cache") w.Header().Set("Pragma", "no-cache")
w.Header().Set("Expires", "0") w.Header().Set("Expires", "0")
w.WriteHeader(http.StatusNotFound)
http.ServeFile(w, r, missingImagePath) http.ServeFile(w, r, missingImagePath)
} }

View file

@ -96,24 +96,35 @@ document.addEventListener('DOMContentLoaded', function() {
// Fallback logic: if sourceUrl is null, use `data-proxy-full` or a meaningful default // Fallback logic: if sourceUrl is null, use `data-proxy-full` or a meaningful default
const proxyFullUrl = imgElement.getAttribute('data-proxy-full') || fullImageUrl; const proxyFullUrl = imgElement.getAttribute('data-proxy-full') || fullImageUrl;
// Check if full image is missing, fallback to proxy size
if (fullImageUrl === '/static/images/missing.svg') {
fullImageUrl = proxyFullUrl;
}
// Elements in the viewer // Elements in the viewer
const viewerImage = document.getElementById('viewer-image'); const viewerImage = document.getElementById('viewer-image');
const viewerTitle = document.getElementById('viewer-title'); const viewerTitle = document.getElementById('viewer-title');
const fullSizeLink = document.getElementById('viewer-full-size-link'); const fullSizeLink = document.getElementById('viewer-full-size-link');
const proxySizeLink = document.getElementById('viewer-proxy-size-link'); const proxySizeLink = document.getElementById('viewer-proxy-size-link');
viewerImage.src = fullImageUrl;
viewerTitle.textContent = title; viewerTitle.textContent = title;
fullSizeLink.href = sourceUrl || proxyFullUrl; fullSizeLink.href = sourceUrl || proxyFullUrl;
proxySizeLink.href = fullImageUrl;
} // Remove previous event listeners to avoid stacking
viewerImage.onload = null;
viewerImage.onerror = null;
// Set up the error handler to switch to the proxy image if the full image fails to load
viewerImage.onerror = function() {
// Use the proxy image as a fallback
viewerImage.src = proxyFullUrl;
proxySizeLink.href = proxyFullUrl;
};
// Set up the load handler to ensure the proxySizeLink is set correctly if the image loads
viewerImage.onload = function() {
proxySizeLink.href = fullImageUrl;
};
// Start loading the image
viewerImage.src = fullImageUrl;
}
document.body.addEventListener('click', function(e) { document.body.addEventListener('click', function(e) {
let target = e.target; let target = e.target;