1
0
Fork 0
mirror of https://github.com/alangrainger/immich-public-proxy.git synced 2025-01-23 16:02:43 +01:00
immich-public-proxy/app/public/web.js

83 lines
2.6 KiB
JavaScript
Raw Permalink Normal View History

// How many thumbnails to load per "page" fetched from Immich
const PER_PAGE = 50
2025-01-09 14:16:16 +01:00
class LGallery {
items
lightGallery
element
index = PER_PAGE
2025-01-09 14:16:16 +01:00
2025-01-10 07:17:54 +01:00
/**
* Create a lightGallery instance and populate it with the first page of gallery items
*/
2025-01-09 14:16:16 +01:00
init (params = {}) {
// Create the lightGallery instance
this.element = document.getElementById('lightgallery')
this.lightGallery = lightGallery(this.element, Object.assign({
plugins: [lgZoom, lgThumbnail, lgVideo, lgFullscreen],
speed: 500,
/*
This license key was graciously provided by LightGallery under their
GPLv3 open-source project license:
*/
licenseKey: '8FFA6495-676C4D30-8BFC54B6-4D0A6CEC'
/*
Please do not take it and use it for other projects, as it was provided
specifically for Immich Public Proxy.
For your own projects you can use the default license key of
0000-0000-000-0000 as per their docs:
https://www.lightgalleryjs.com/docs/settings/#licenseKey
*/
}, params.lgConfig))
2025-01-10 07:00:40 +01:00
this.items = params.items
2025-01-09 14:16:16 +01:00
let timeout
window.addEventListener('scroll', () => {
if (timeout) clearTimeout(timeout)
timeout = setTimeout(lgallery.handleScroll, 100)
})
lgallery.handleScroll()
2024-12-27 02:04:10 +01:00
}
2025-01-10 07:17:54 +01:00
/**
* Listen for scroll events and load more gallery items
*/
2025-01-09 14:16:16 +01:00
handleScroll () {
const rect = lgallery.element.getBoundingClientRect()
const scrollPosition = Math.max(0, rect.bottom - window.innerHeight)
const buffer = 200 // pixels before bottom to trigger load
if (scrollPosition <= buffer) {
lgallery.loadMoreItems()
}
}
2025-01-10 07:17:54 +01:00
/**
* Load more gallery items as per lightGallery docs
* https://www.lightgalleryjs.com/demos/infinite-scrolling/
*/
2025-01-09 14:16:16 +01:00
loadMoreItems () {
if (this.index < this.items.length) {
2025-01-10 07:17:54 +01:00
// Append new thumbnails
2025-01-09 14:16:16 +01:00
this.items
.slice(this.index, this.index + PER_PAGE)
2025-01-09 14:16:16 +01:00
.forEach(item => {
if (item.video) {
this.element.insertAdjacentHTML('beforeend', `<a data-video='${item.video}'
2024-12-27 02:04:10 +01:00
${item.downloadUrl ? 'data-download-url="' + item.downloadUrl + '"' : ''}>
<img alt="" src="${item.thumbnailUrl}"/><div class="play-icon"></div></a>`)
2025-01-09 14:16:16 +01:00
} else {
this.element.insertAdjacentHTML('beforeend', `<a href="${item.previewUrl}"
2024-12-27 02:04:10 +01:00
${item.downloadUrl ? 'data-download-url="' + item.downloadUrl + '"' : ''}>
<img alt="" src="${item.thumbnailUrl}"/></a>`)
2025-01-09 14:16:16 +01:00
}
})
this.index += PER_PAGE
2025-01-09 14:16:16 +01:00
this.lightGallery.refresh()
2024-12-27 02:04:10 +01:00
}
}
2024-11-01 11:58:27 +01:00
}
2025-01-09 14:16:16 +01:00
const lgallery = new LGallery()