mirror of
https://github.com/a2nt/meta-lightbox.git
synced 2024-10-22 17:05:53 +02:00
FIX: Embed loading and pinning
This commit is contained in:
parent
c0eb3936a1
commit
eb3b153a54
2
dist/report.html
vendored
2
dist/report.html
vendored
@ -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>
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user