FIX: Embed loading and pinning

This commit is contained in:
Tony Air 2024-07-03 18:17:17 +02:00
parent c0eb3936a1
commit eb3b153a54
3 changed files with 17 additions and 15 deletions

2
dist/report.html vendored
View File

@ -3,7 +3,7 @@
<head> <head>
<meta charset="UTF-8"/> <meta charset="UTF-8"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/> <meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>@a2nt/meta-lightbox-js [10 Aug 2023 at 19:02]</title> <title>@a2nt/meta-lightbox-js [18 Jun 2024 at 16:41]</title>
<link rel="shortcut icon" href="" type="image/x-icon" /> <link rel="shortcut icon" href="" type="image/x-icon" />
<script> <script>

View File

@ -41,9 +41,7 @@ rules:
indentation: indentation:
- 2 - 2
- size: 4 - size: 4
final-newline: final-newline: false
- 2
- include: true
no-trailing-whitespace: 2 no-trailing-whitespace: 2
border-zero: border-zero:
- 2 - 2

View File

@ -3,6 +3,7 @@
*/ */
// import Events from './_events' // import Events from './_events'
const W = window const W = window
const NAME = 'MetaWindow'
class MetaWindow { class MetaWindow {
state = { state = {
@ -18,14 +19,14 @@ class MetaWindow {
extraClass: null, extraClass: null,
} }
cleanLinks () { cleanLinks() {
document.querySelectorAll('[data-toggle="lightbox"]') document.querySelectorAll('[data-toggle="lightbox"]')
.forEach((el) => { .forEach((el) => {
el.classList.remove('loading') el.classList.remove('loading')
}) })
} }
collectGaleries (gallery) { collectGaleries(gallery) {
const ui = this const ui = this
if (!gallery) { if (!gallery) {
@ -42,25 +43,26 @@ class MetaWindow {
}) })
} }
toggle (el) { toggle(el) {
const ui = this const ui = this
ui.cleanLinks() ui.cleanLinks()
const link = el.getAttribute('href') || el.getAttribute('data-href') const link = el.getAttribute('href') || el.getAttribute('data-href')
const embed = el.getAttribute('data-embed') const embed = el.getAttribute('data-embed') || el.getAttribute('data-video-preview')
el.classList.add('loading') el.classList.add('loading')
ui.state.current = el ui.state.current = el
const title = el.getAttribute('data-title') const title = el.getAttribute('data-title')
if (title) { if (title) {
ui.setCaption(title) ui.setCaption(title)
}else{ } else {
ui.setCaption('') ui.setCaption('')
} }
if (embed) { if (embed) {
ui.embed(link) ui.embed(link)
el.classList.remove('loading')
} else { } else {
ui.load(link) ui.load(link)
} }
@ -68,9 +70,9 @@ class MetaWindow {
ui.addExtraClass(el.getAttribute('data-lightbox-class')) ui.addExtraClass(el.getAttribute('data-lightbox-class'))
} }
init () { init() {
const ui = this const ui = this
console.log('MetaWindow: [links] init') console.log(`${NAME}: [links] init`)
document document
.querySelectorAll('[data-toggle="lightbox"],[data-gallery]') .querySelectorAll('[data-toggle="lightbox"],[data-gallery]')
@ -81,7 +83,9 @@ class MetaWindow {
// click handler // click handler
el.addEventListener('click', (e) => { el.addEventListener('click', (e) => {
e.preventDefault() e.preventDefault()
console.log('MetaWindow: [link] click') e.stopPropagation()
console.log(`${NAME}: [link] click`)
const el = e.currentTarget const el = e.currentTarget
ui.toggle(el) ui.toggle(el)
@ -89,7 +93,7 @@ class MetaWindow {
}) })
} }
constructor ( constructor(
state = { state = {
shown: false, shown: false,
}, },
@ -385,13 +389,13 @@ class MetaWindow {
return ui.state.content return ui.state.content
} }
setState (state) { setState(state) {
const ui = this const ui = this
ui.state = Object.assign({}, ui.state, state) ui.state = Object.assign({}, ui.state, state)
ui.render() ui.render()
} }
render () { render() {
const ui = this const ui = this
const name = ui.name const name = ui.name
const el = ui.state.current const el = ui.state.current