Created
August 8, 2024 16:51
-
-
Save ScarVite/0e8a9e25847405ba87a2f8319671a816 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(() => { | |
var Pe = Object.defineProperty; | |
var en = (o, t, e) => t in o ? Pe(o, t, { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: e | |
}) : o[t] = e; | |
var _e = (o, t) => { | |
for (var e in t) | |
Pe(o, e, { | |
get: t[e], | |
enumerable: true | |
}); | |
}; | |
var Ft = (o, t, e) => (en(o, typeof t != 'symbol' ? t + '' : t, e), e); | |
var qt = class { | |
constructor(t, e, i) { | |
this.eventTarget = t; | |
this.eventName = e; | |
this.eventOptions = i; | |
this.unorderedBindings = new Set(); | |
} | |
connect() { | |
this.eventTarget.addEventListener(this.eventName, this, this.eventOptions); | |
} | |
disconnect() { | |
this.eventTarget.removeEventListener(this.eventName, this, this.eventOptions); | |
} | |
bindingConnected(t) { | |
this.unorderedBindings.add(t); | |
} | |
bindingDisconnected(t) { | |
this.unorderedBindings.delete(t); | |
} | |
handleEvent(t) { | |
let e = nn(t); | |
for (let i of this.bindings) { | |
if (e.immediatePropagationStopped) { | |
break; | |
} | |
i.handleEvent(e); | |
} | |
} | |
hasBindings() { | |
return this.unorderedBindings.size > 0; | |
} | |
get bindings() { | |
return Array.from(this.unorderedBindings).sort((t, e) => { | |
let i = t.index, n = e.index; | |
return i < n ? -1 : i > n ? 1 : 0; | |
}); | |
} | |
}; | |
function nn(o) { | |
if ('immediatePropagationStopped' in o) { | |
return o; | |
} | |
{ | |
let {stopImmediatePropagation: t} = o; | |
return Object.assign(o, { | |
immediatePropagationStopped: false, | |
stopImmediatePropagation() { | |
this.immediatePropagationStopped = true; | |
t.call(this); | |
} | |
}); | |
} | |
} | |
var $t = class { | |
constructor(t) { | |
this.application = t; | |
this.eventListenerMaps = new Map(); | |
this.started = false; | |
} | |
start() { | |
this.started || (this.started = true, this.eventListeners.forEach(t => t.connect())); | |
} | |
stop() { | |
this.started && (this.started = false, this.eventListeners.forEach(t => t.disconnect())); | |
} | |
get eventListeners() { | |
return Array.from(this.eventListenerMaps.values()).reduce((t, e) => t.concat(Array.from(e.values())), []); | |
} | |
bindingConnected(t) { | |
this.fetchEventListenerForBinding(t).bindingConnected(t); | |
} | |
bindingDisconnected(t, e = false) { | |
this.fetchEventListenerForBinding(t).bindingDisconnected(t); | |
e && this.clearEventListenersForBinding(t); | |
} | |
handleError(t, e, i = {}) { | |
this.application.handleError(t, `Error ${ e }`, i); | |
} | |
clearEventListenersForBinding(t) { | |
let e = this.fetchEventListenerForBinding(t); | |
e.hasBindings() || (e.disconnect(), this.removeMappedEventListenerFor(t)); | |
} | |
removeMappedEventListenerFor(t) { | |
let { | |
eventTarget: e, | |
eventName: i, | |
eventOptions: n | |
} = t, s = this.fetchEventListenerMapForEventTarget(e), a = this.cacheKey(i, n); | |
s.delete(a); | |
s.size == 0 && this.eventListenerMaps.delete(e); | |
} | |
fetchEventListenerForBinding(t) { | |
let { | |
eventTarget: e, | |
eventName: i, | |
eventOptions: n | |
} = t; | |
return this.fetchEventListener(e, i, n); | |
} | |
fetchEventListener(t, e, i) { | |
let n = this.fetchEventListenerMapForEventTarget(t), s = this.cacheKey(e, i), a = n.get(s); | |
return a || (a = this.createEventListener(t, e, i), n.set(s, a)), a; | |
} | |
createEventListener(t, e, i) { | |
let n = new qt(t, e, i); | |
return this.started && n.connect(), n; | |
} | |
fetchEventListenerMapForEventTarget(t) { | |
let e = this.eventListenerMaps.get(t); | |
return e || (e = new Map(), this.eventListenerMaps.set(t, e)), e; | |
} | |
cacheKey(t, e) { | |
let i = [t]; | |
return Object.keys(e).sort().forEach(n => { | |
i.push(`${ e[n] ? '' : '!' }${ n }`); | |
}), i.join(':'); | |
} | |
}, sn = { | |
stop({ | |
event: o, | |
value: t | |
}) { | |
return t && o.stopPropagation(), true; | |
}, | |
prevent({ | |
event: o, | |
value: t | |
}) { | |
return t && o.preventDefault(), true; | |
}, | |
self({ | |
event: o, | |
value: t, | |
element: e | |
}) { | |
return t ? e === o.target : true; | |
} | |
}; | |
function an(o) { | |
let e = o.trim().match(/^(?:(?:([^.]+?)\+)?(.+?)(?:\.(.+?))?(?:@(window|document))?->)?(.+?)(?:#([^:]+?))(?::(.+))?$/) || [], i = e[2], n = e[3]; | |
return n && ![ | |
'keydown', | |
'keyup', | |
'keypress' | |
].includes(i) && (i += `.${ n }`, n = ''), { | |
eventTarget: rn(e[4]), | |
eventName: i, | |
eventOptions: e[7] ? ln(e[7]) : {}, | |
identifier: e[5], | |
methodName: e[6], | |
keyFilter: e[1] || n | |
}; | |
} | |
function rn(o) { | |
if (o == 'window') { | |
return window; | |
} | |
if (o == 'document') { | |
return document; | |
} | |
} | |
function ln(o) { | |
return o.split(':').reduce((t, e) => Object.assign(t, { [e.replace(/^!/, '')]: !/^!/.test(e) }), {}); | |
} | |
function cn(o) { | |
if (o == window) { | |
return 'window'; | |
} | |
if (o == document) { | |
return 'document'; | |
} | |
} | |
function ve(o) { | |
return o.replace(/(?:[_-])([a-z0-9])/g, (t, e) => e.toUpperCase()); | |
} | |
function te(o) { | |
return ve(o.replace(/--/g, '-').replace(/__/g, '_')); | |
} | |
function ut(o) { | |
return o.charAt(0).toUpperCase() + o.slice(1); | |
} | |
function ai(o) { | |
return o.replace(/([A-Z])/g, (t, e) => `-${ e.toLowerCase() }`); | |
} | |
function dn(o) { | |
return o.match(/[^\s]+/g) || []; | |
} | |
function Ke(o) { | |
return o != null; | |
} | |
function ee(o, t) { | |
return Object.prototype.hasOwnProperty.call(o, t); | |
} | |
var qe = [ | |
'meta', | |
'ctrl', | |
'alt', | |
'shift' | |
], ie = class { | |
constructor(t, e, i, n) { | |
this.element = t; | |
this.index = e; | |
this.eventTarget = i.eventTarget || t; | |
this.eventName = i.eventName || hn(t) || yt('missing event name'); | |
this.eventOptions = i.eventOptions || {}; | |
this.identifier = i.identifier || yt('missing identifier'); | |
this.methodName = i.methodName || yt('missing method name'); | |
this.keyFilter = i.keyFilter || ''; | |
this.schema = n; | |
} | |
static forToken(t, e) { | |
return new this(t.element, t.index, an(t.content), e); | |
} | |
toString() { | |
let t = this.keyFilter ? `.${ this.keyFilter }` : '', e = this.eventTargetName ? `@${ this.eventTargetName }` : ''; | |
return `${ this.eventName }${ t }${ e }->${ this.identifier }#${ this.methodName }`; | |
} | |
shouldIgnoreKeyboardEvent(t) { | |
if (!this.keyFilter) { | |
return false; | |
} | |
let e = this.keyFilter.split('+'); | |
if (this.keyFilterDissatisfied(t, e)) { | |
return true; | |
} | |
let i = e.filter(n => !qe.includes(n))[0]; | |
return i ? (ee(this.keyMappings, i) || yt(`contains unknown key filter: ${ this.keyFilter }`), this.keyMappings[i].toLowerCase() !== t.key.toLowerCase()) : false; | |
} | |
shouldIgnoreMouseEvent(t) { | |
if (!this.keyFilter) { | |
return false; | |
} | |
let e = [this.keyFilter]; | |
return !!this.keyFilterDissatisfied(t, e); | |
} | |
get params() { | |
let t = { | |
nav: null, | |
target: null, | |
el: n, | |
src: e, | |
state: Z.Opening, | |
imageEl: l, | |
panzoom: new nt(r, E({ transformParent: true }, this.option('Panzoom') || {}, { | |
content: l, | |
width: (c, d) => a.optionFor(t, 'width', 'auto', d) || 'auto', | |
height: (c, d) => a.optionFor(t, 'height', 'auto', d) || 'auto', | |
wheel: () => { | |
let c = a.option('wheel'); | |
return (c === 'zoom' || c == 'pan') && c; | |
}, | |
click: (c, d) => { | |
var u, m; | |
if (a.isCompact || a.isClosing() || t.index !== ((u = a.getSlide()) === null || u === void 0 ? void 0 : u.index)) { | |
return false; | |
} | |
if (d) { | |
let b = d.composedPath()[0]; | |
if ([ | |
'A', | |
'BUTTON', | |
'TEXTAREA', | |
'OPTION', | |
'INPUT', | |
'SELECT', | |
'VIDEO' | |
].includes(b.nodeName)) { | |
return false; | |
} | |
} | |
let h = !d || d.target && ((m = t.contentEl) === null || m === void 0 ? void 0 : m.contains(d.target)); | |
return a.option(h ? 'contentClick' : 'backdropClick') || false; | |
}, | |
dblClick: () => a.isCompact ? 'toggleZoom' : a.option('contentDblClick') || false, | |
spinner: false, | |
panOnlyZoomed: true, | |
wheelLimit: 1e+400, | |
on: { | |
ready: c => { | |
i(c); | |
}, | |
error: () => { | |
n(); | |
}, | |
destroy: () => { | |
n(); | |
} | |
} | |
})), | |
xhr: n, | |
placeholderEl: i, | |
iframeEl: s, | |
poller: setTimeout(i, 250), | |
videoId: d, | |
src: `https://${ l }/embed/${ d }?${ c }`, | |
thumbSrc: t.thumbSrc || `https://i.ytimg.com/vi/${ d }/mqdefault.jpg`, | |
videoId: a, | |
src: `https://player.vimeo.com/video/${ a }?${ r ? `h=${ r }${ s ? '&' : '' }` : '' }${ s }`, | |
type: i, | |
preload: false, | |
state: 'play', | |
timer: null, | |
timer: setTimeout(() => { | |
; | |
t.inHover || t.onTimerEnd(); | |
}, i), | |
state: 'ready', | |
closeBtnEl: t.contentEl.appendChild(n), | |
captionEl: l.appendChild(d), | |
state: Z.Loading, | |
spinnerEl: i, | |
error: e, | |
closeBtnEl: void 0, | |
captionEl: void 0, | |
spinnerEl: void 0 | |
}, e = new RegExp(`^data-${ this.identifier }-(.+)-param$`, 'i'); | |
for (let { | |
name: i, | |
value: n | |
} of Array.from(this.element.attributes)) { | |
let s = i.match(e), a = s && s[1]; | |
a && (t[ve(a)] = un(n)); | |
} | |
return t; | |
} | |
get eventTargetName() { | |
return cn(this.eventTarget); | |
} | |
get keyMappings() { | |
return this.schema.keyMappings; | |
} | |
keyFilterDissatisfied(t, e) { | |
let [i, n, s, a] = qe.map(r => e.includes(r)); | |
return t.metaKey !== i || t.ctrlKey !== n || t.altKey !== s || t.shiftKey !== a; | |
} | |
}, $e = { | |
a: () => 'click', | |
button: () => 'click', | |
form: () => 'submit', | |
details: () => 'toggle', | |
input: o => o.getAttribute('type') == 'submit' ? 'click' : 'input', | |
select: () => 'change', | |
textarea: () => 'input' | |
}; | |
function hn(o) { | |
let t = o.tagName.toLowerCase(); | |
if (t in $e) { | |
return $e[t](o); | |
} | |
} | |
function yt(o) { | |
throw new Error(o); | |
} | |
function un(o) { | |
try { | |
return JSON.parse(o); | |
} catch { | |
return o; | |
} | |
} | |
var ne = class { | |
constructor(t, e) { | |
this.context = t; | |
this.action = e; | |
} | |
get index() { | |
return this.action.index; | |
} | |
get eventTarget() { | |
return this.action.eventTarget; | |
} | |
get eventOptions() { | |
return this.action.eventOptions; | |
} | |
get identifier() { | |
return this.context.identifier; | |
} | |
handleEvent(t) { | |
let e = this.prepareActionEvent(t); | |
this.willBeInvokedByEvent(t) && this.applyEventModifiers(e) && this.invokeWithEvent(e); | |
} | |
get eventName() { | |
return this.action.eventName; | |
} | |
get method() { | |
let t = this.controller[this.methodName]; | |
if (typeof t == 'function') { | |
return t; | |
} | |
throw new Error(`Action "${ this.action }" references undefined method "${ this.methodName }"`); | |
} | |
applyEventModifiers(t) { | |
let {element: e} = this.action, {actionDescriptorFilters: i} = this.context.application, {controller: n} = this.context, s = true; | |
for (let [a, r] of Object.entries(this.eventOptions)) | |
if (a in i) { | |
let l = i[a]; | |
s = s && l({ | |
name: a, | |
value: r, | |
event: t, | |
element: e, | |
controller: n | |
}); | |
} else { | |
continue; | |
} | |
return s; | |
} | |
prepareActionEvent(t) { | |
return Object.assign(t, { params: this.action.params }); | |
} | |
invokeWithEvent(t) { | |
let { | |
target: e, | |
currentTarget: i | |
} = t; | |
try { | |
this.method.call(this.controller, t); | |
this.context.logDebugActivity(this.methodName, { | |
event: t, | |
target: e, | |
currentTarget: i, | |
action: this.methodName | |
}); | |
} catch (n) { | |
let { | |
identifier: s, | |
controller: a, | |
element: r, | |
index: l | |
} = this, c = { | |
identifier: s, | |
controller: a, | |
element: r, | |
index: l, | |
event: t | |
}; | |
this.context.handleError(n, `invoking action "${ this.action }"`, c); | |
} | |
} | |
willBeInvokedByEvent(t) { | |
let e = t.target; | |
return t instanceof KeyboardEvent && this.action.shouldIgnoreKeyboardEvent(t) || t instanceof MouseEvent && this.action.shouldIgnoreMouseEvent(t) ? false : this.element === e ? true : e instanceof Element && this.element.contains(e) ? this.scope.containsElement(e) : this.scope.containsElement(this.action.element); | |
} | |
get controller() { | |
return this.context.controller; | |
} | |
get methodName() { | |
return this.action.methodName; | |
} | |
get element() { | |
return this.scope.element; | |
} | |
get scope() { | |
return this.context.scope; | |
} | |
}, vt = class { | |
constructor(t, e) { | |
this.mutationObserverInit = { | |
attributes: true, | |
childList: true, | |
subtree: true | |
}; | |
this.element = t; | |
this.started = false; | |
this.delegate = e; | |
this.elements = new Set(); | |
this.mutationObserver = new MutationObserver(i => this.processMutations(i)); | |
} | |
start() { | |
this.started || (this.started = true, this.mutationObserver.observe(this.element, this.mutationObserverInit), this.refresh()); | |
} | |
pause(t) { | |
this.started && (this.mutationObserver.disconnect(), this.started = false); | |
t(); | |
this.started || (this.mutationObserver.observe(this.element, this.mutationObserverInit), this.started = true); | |
} | |
stop() { | |
this.started && (this.mutationObserver.takeRecords(), this.mutationObserver.disconnect(), this.started = false); | |
} | |
refresh() { | |
if (this.started) { | |
let t = new Set(this.matchElementsInTree()); | |
for (let e of Array.from(this.elements)) | |
t.has(e) || this.removeElement(e); | |
for (let e of Array.from(t)) | |
this.addElement(e); | |
} | |
} | |
processMutations(t) { | |
if (this.started) { | |
for (let e of t) | |
this.processMutation(e); | |
} | |
} | |
processMutation(t) { | |
t.type == 'attributes' ? this.processAttributeChange(t.target, t.attributeName) : t.type == 'childList' && (this.processRemovedNodes(t.removedNodes), this.processAddedNodes(t.addedNodes)); | |
} | |
processAttributeChange(t, e) { | |
this.elements.has(t) ? this.delegate.elementAttributeChanged && this.matchElement(t) ? this.delegate.elementAttributeChanged(t, e) : this.removeElement(t) : this.matchElement(t) && this.addElement(t); | |
} | |
processRemovedNodes(t) { | |
for (let e of Array.from(t)) { | |
let i = this.elementFromNode(e); | |
i && this.processTree(i, this.removeElement); | |
} | |
} | |
processAddedNodes(t) { | |
for (let e of Array.from(t)) { | |
let i = this.elementFromNode(e); | |
i && this.elementIsActive(i) && this.processTree(i, this.addElement); | |
} | |
} | |
matchElement(t) { | |
return this.delegate.matchElement(t); | |
} | |
matchElementsInTree(t = this.element) { | |
return this.delegate.matchElementsInTree(t); | |
} | |
processTree(t, e) { | |
for (let i of this.matchElementsInTree(t)) | |
e.call(this, i); | |
} | |
elementFromNode(t) { | |
if (t.nodeType == Node.ELEMENT_NODE) { | |
return t; | |
} | |
} | |
elementIsActive(t) { | |
return t.isConnected != this.element.isConnected ? false : this.element.contains(t); | |
} | |
addElement(t) { | |
this.elements.has(t) || this.elementIsActive(t) && (this.elements.add(t), this.delegate.elementMatched && this.delegate.elementMatched(t)); | |
} | |
removeElement(t) { | |
this.elements.has(t) && (this.elements.delete(t), this.delegate.elementUnmatched && this.delegate.elementUnmatched(t)); | |
} | |
}, Bt = class { | |
constructor(t, e, i) { | |
this.attributeName = e; | |
this.delegate = i; | |
this.elementObserver = new vt(t, this); | |
} | |
get element() { | |
return this.elementObserver.element; | |
} | |
get selector() { | |
return `[${ this.attributeName }]`; | |
} | |
start() { | |
this.elementObserver.start(); | |
} | |
pause(t) { | |
this.elementObserver.pause(t); | |
} | |
stop() { | |
this.elementObserver.stop(); | |
} | |
refresh() { | |
this.elementObserver.refresh(); | |
} | |
get started() { | |
return this.elementObserver.started; | |
} | |
matchElement(t) { | |
return t.hasAttribute(this.attributeName); | |
} | |
matchElementsInTree(t) { | |
let e = this.matchElement(t) ? [t] : [], i = Array.from(t.querySelectorAll(this.selector)); | |
return e.concat(i); | |
} | |
elementMatched(t) { | |
this.delegate.elementMatchedAttribute && this.delegate.elementMatchedAttribute(t, this.attributeName); | |
} | |
elementUnmatched(t) { | |
this.delegate.elementUnmatchedAttribute && this.delegate.elementUnmatchedAttribute(t, this.attributeName); | |
} | |
elementAttributeChanged(t, e) { | |
this.delegate.elementAttributeValueChanged && this.attributeName == e && this.delegate.elementAttributeValueChanged(t, e); | |
} | |
}; | |
function mn(o, t, e) { | |
ri(o, t).add(e); | |
} | |
function bn(o, t, e) { | |
ri(o, t).delete(e); | |
pn(o, t); | |
} | |
function ri(o, t) { | |
let e = o.get(t); | |
return e || (e = new Set(), o.set(t, e)), e; | |
} | |
function pn(o, t) { | |
let e = o.get(t); | |
e != null && e.size == 0 && o.delete(t); | |
} | |
var T = class { | |
constructor() { | |
this.valuesByKey = new Map(); | |
} | |
get keys() { | |
return Array.from(this.valuesByKey.keys()); | |
} | |
get values() { | |
return Array.from(this.valuesByKey.values()).reduce((e, i) => e.concat(Array.from(i)), []); | |
} | |
get size() { | |
return Array.from(this.valuesByKey.values()).reduce((e, i) => e + i.size, 0); | |
} | |
add(t, e) { | |
mn(this.valuesByKey, t, e); | |
} | |
delete(t, e) { | |
bn(this.valuesByKey, t, e); | |
} | |
has(t, e) { | |
let i = this.valuesByKey.get(t); | |
return i != null && i.has(e); | |
} | |
hasKey(t) { | |
return this.valuesByKey.has(t); | |
} | |
hasValue(t) { | |
return Array.from(this.valuesByKey.values()).some(i => i.has(t)); | |
} | |
getValuesForKey(t) { | |
let e = this.valuesByKey.get(t); | |
return e ? Array.from(e) : []; | |
} | |
getKeysForValue(t) { | |
return Array.from(this.valuesByKey).filter(([e, i]) => i.has(t)).map(([e, i]) => e); | |
} | |
}; | |
var se = class { | |
constructor(t, e, i, n) { | |
this._selector = e; | |
this.details = n; | |
this.elementObserver = new vt(t, this); | |
this.delegate = i; | |
this.matchesByElement = new T(); | |
} | |
get started() { | |
return this.elementObserver.started; | |
} | |
get selector() { | |
return this._selector; | |
} | |
set selector(t) { | |
this._selector = t; | |
this.refresh(); | |
} | |
start() { | |
this.elementObserver.start(); | |
} | |
pause(t) { | |
this.elementObserver.pause(t); | |
} | |
stop() { | |
this.elementObserver.stop(); | |
} | |
refresh() { | |
this.elementObserver.refresh(); | |
} | |
get element() { | |
return this.elementObserver.element; | |
} | |
matchElement(t) { | |
let {selector: e} = this; | |
if (e) { | |
let i = t.matches(e); | |
return this.delegate.selectorMatchElement ? i && this.delegate.selectorMatchElement(t, this.details) : i; | |
} else { | |
return false; | |
} | |
} | |
matchElementsInTree(t) { | |
let {selector: e} = this; | |
if (e) { | |
let i = this.matchElement(t) ? [t] : [], n = Array.from(t.querySelectorAll(e)).filter(s => this.matchElement(s)); | |
return i.concat(n); | |
} else { | |
return []; | |
} | |
} | |
elementMatched(t) { | |
let {selector: e} = this; | |
e && this.selectorMatched(t, e); | |
} | |
elementUnmatched(t) { | |
let e = this.matchesByElement.getKeysForValue(t); | |
for (let i of e) | |
this.selectorUnmatched(t, i); | |
} | |
elementAttributeChanged(t, e) { | |
let {selector: i} = this; | |
if (i) { | |
let n = this.matchElement(t), s = this.matchesByElement.has(i, t); | |
n && !s ? this.selectorMatched(t, i) : !n && s && this.selectorUnmatched(t, i); | |
} | |
} | |
selectorMatched(t, e) { | |
this.delegate.selectorMatched(t, e, this.details); | |
this.matchesByElement.add(e, t); | |
} | |
selectorUnmatched(t, e) { | |
this.delegate.selectorUnmatched(t, e, this.details); | |
this.matchesByElement.delete(e, t); | |
} | |
}, oe = class { | |
constructor(t, e) { | |
this.element = t; | |
this.delegate = e; | |
this.started = false; | |
this.stringMap = new Map(); | |
this.mutationObserver = new MutationObserver(i => this.processMutations(i)); | |
} | |
start() { | |
this.started || (this.started = true, this.mutationObserver.observe(this.element, { | |
attributes: true, | |
attributeOldValue: true | |
}), this.refresh()); | |
} | |
stop() { | |
this.started && (this.mutationObserver.takeRecords(), this.mutationObserver.disconnect(), this.started = false); | |
} | |
refresh() { | |
if (this.started) { | |
for (let t of this.knownAttributeNames) | |
this.refreshAttribute(t, null); | |
} | |
} | |
processMutations(t) { | |
if (this.started) { | |
for (let e of t) | |
this.processMutation(e); | |
} | |
} | |
processMutation(t) { | |
let e = t.attributeName; | |
e && this.refreshAttribute(e, t.oldValue); | |
} | |
refreshAttribute(t, e) { | |
let i = this.delegate.getStringMapKeyForAttribute(t); | |
if (i != null) { | |
this.stringMap.has(t) || this.stringMapKeyAdded(i, t); | |
let n = this.element.getAttribute(t); | |
if (this.stringMap.get(t) != n && this.stringMapValueChanged(n, i, e), n == null) { | |
let s = this.stringMap.get(t); | |
this.stringMap.delete(t); | |
s && this.stringMapKeyRemoved(i, t, s); | |
} else { | |
this.stringMap.set(t, n); | |
} | |
} | |
} | |
stringMapKeyAdded(t, e) { | |
this.delegate.stringMapKeyAdded && this.delegate.stringMapKeyAdded(t, e); | |
} | |
stringMapValueChanged(t, e, i) { | |
this.delegate.stringMapValueChanged && this.delegate.stringMapValueChanged(t, e, i); | |
} | |
stringMapKeyRemoved(t, e, i) { | |
this.delegate.stringMapKeyRemoved && this.delegate.stringMapKeyRemoved(t, e, i); | |
} | |
get knownAttributeNames() { | |
return Array.from(new Set(this.currentAttributeNames.concat(this.recordedAttributeNames))); | |
} | |
get currentAttributeNames() { | |
return Array.from(this.element.attributes).map(t => t.name); | |
} | |
get recordedAttributeNames() { | |
return Array.from(this.stringMap.keys()); | |
} | |
}, xt = class { | |
constructor(t, e, i) { | |
this.attributeObserver = new Bt(t, e, this); | |
this.delegate = i; | |
this.tokensByElement = new T(); | |
} | |
get started() { | |
return this.attributeObserver.started; | |
} | |
start() { | |
this.attributeObserver.start(); | |
} | |
pause(t) { | |
this.attributeObserver.pause(t); | |
} | |
stop() { | |
this.attributeObserver.stop(); | |
} | |
refresh() { | |
this.attributeObserver.refresh(); | |
} | |
get element() { | |
return this.attributeObserver.element; | |
} | |
get attributeName() { | |
return this.attributeObserver.attributeName; | |
} | |
elementMatchedAttribute(t) { | |
this.tokensMatched(this.readTokensForElement(t)); | |
} | |
elementAttributeValueChanged(t) { | |
let [e, i] = this.refreshTokensForElement(t); | |
this.tokensUnmatched(e); | |
this.tokensMatched(i); | |
} | |
elementUnmatchedAttribute(t) { | |
this.tokensUnmatched(this.tokensByElement.getValuesForKey(t)); | |
} | |
tokensMatched(t) { | |
t.forEach(e => this.tokenMatched(e)); | |
} | |
tokensUnmatched(t) { | |
t.forEach(e => this.tokenUnmatched(e)); | |
} | |
tokenMatched(t) { | |
this.delegate.tokenMatched(t); | |
this.tokensByElement.add(t.element, t); | |
} | |
tokenUnmatched(t) { | |
this.delegate.tokenUnmatched(t); | |
this.tokensByElement.delete(t.element, t); | |
} | |
refreshTokensForElement(t) { | |
let e = this.tokensByElement.getValuesForKey(t), i = this.readTokensForElement(t), n = gn(e, i).findIndex(([s, a]) => !Qn(s, a)); | |
return n == -1 ? [ | |
[], | |
[] | |
] : [ | |
e.slice(n), | |
i.slice(n) | |
]; | |
} | |
readTokensForElement(t) { | |
let e = this.attributeName, i = t.getAttribute(e) || ''; | |
return fn(i, t, e); | |
} | |
}; | |
function fn(o, t, e) { | |
return o.trim().split(/\s+/).filter(i => i.length).map((i, n) => ({ | |
element: t, | |
attributeName: e, | |
content: i, | |
index: n | |
})); | |
} | |
function gn(o, t) { | |
let e = Math.max(o.length, t.length); | |
return Array.from({ length: e }, (i, n) => [ | |
o[n], | |
t[n] | |
]); | |
} | |
function Qn(o, t) { | |
return o && t && o.index == t.index && o.content == t.content; | |
} | |
var Ut = class { | |
constructor(t, e, i) { | |
this.tokenListObserver = new xt(t, e, this); | |
this.delegate = i; | |
this.parseResultsByToken = new WeakMap(); | |
this.valuesByTokenByElement = new WeakMap(); | |
} | |
get started() { | |
return this.tokenListObserver.started; | |
} | |
start() { | |
this.tokenListObserver.start(); | |
} | |
stop() { | |
this.tokenListObserver.stop(); | |
} | |
refresh() { | |
this.tokenListObserver.refresh(); | |
} | |
get element() { | |
return this.tokenListObserver.element; | |
} | |
get attributeName() { | |
return this.tokenListObserver.attributeName; | |
} | |
tokenMatched(t) { | |
let {element: e} = t, {value: i} = this.fetchParseResultForToken(t); | |
i && (this.fetchValuesByTokenForElement(e).set(t, i), this.delegate.elementMatchedValue(e, i)); | |
} | |
tokenUnmatched(t) { | |
let {element: e} = t, {value: i} = this.fetchParseResultForToken(t); | |
i && (this.fetchValuesByTokenForElement(e).delete(t), this.delegate.elementUnmatchedValue(e, i)); | |
} | |
fetchParseResultForToken(t) { | |
let e = this.parseResultsByToken.get(t); | |
return e || (e = this.parseToken(t), this.parseResultsByToken.set(t, e)), e; | |
} | |
fetchValuesByTokenForElement(t) { | |
let e = this.valuesByTokenByElement.get(t); | |
return e || (e = new Map(), this.valuesByTokenByElement.set(t, e)), e; | |
} | |
parseToken(t) { | |
try { | |
return { value: this.delegate.parseValueForToken(t) }; | |
} catch (e) { | |
return { error: e }; | |
} | |
} | |
}, ae = class { | |
constructor(t, e) { | |
this.context = t; | |
this.delegate = e; | |
this.bindingsByAction = new Map(); | |
} | |
start() { | |
this.valueListObserver || (this.valueListObserver = new Ut(this.element, this.actionAttribute, this), this.valueListObserver.start()); | |
} | |
stop() { | |
this.valueListObserver && (this.valueListObserver.stop(), delete this.valueListObserver, this.disconnectAllActions()); | |
} | |
get element() { | |
return this.context.element; | |
} | |
get identifier() { | |
return this.context.identifier; | |
} | |
get actionAttribute() { | |
return this.schema.actionAttribute; | |
} | |
get schema() { | |
return this.context.schema; | |
} | |
get bindings() { | |
return Array.from(this.bindingsByAction.values()); | |
} | |
connectAction(t) { | |
let e = new ne(this.context, t); | |
this.bindingsByAction.set(t, e); | |
this.delegate.bindingConnected(e); | |
} | |
disconnectAction(t) { | |
let e = this.bindingsByAction.get(t); | |
e && (this.bindingsByAction.delete(t), this.delegate.bindingDisconnected(e)); | |
} | |
disconnectAllActions() { | |
this.bindings.forEach(t => this.delegate.bindingDisconnected(t, true)); | |
this.bindingsByAction.clear(); | |
} | |
parseValueForToken(t) { | |
let e = ie.forToken(t, this.schema); | |
if (e.identifier == this.identifier) { | |
return e; | |
} | |
} | |
elementMatchedValue(t, e) { | |
this.connectAction(e); | |
} | |
elementUnmatchedValue(t, e) { | |
this.disconnectAction(e); | |
} | |
}, re = class { | |
constructor(t, e) { | |
this.context = t; | |
this.receiver = e; | |
this.stringMapObserver = new oe(this.element, this); | |
this.valueDescriptorMap = this.controller.valueDescriptorMap; | |
} | |
start() { | |
this.stringMapObserver.start(); | |
this.invokeChangedCallbacksForDefaultValues(); | |
} | |
stop() { | |
this.stringMapObserver.stop(); | |
} | |
get element() { | |
return this.context.element; | |
} | |
get controller() { | |
return this.context.controller; | |
} | |
getStringMapKeyForAttribute(t) { | |
if (t in this.valueDescriptorMap) { | |
return this.valueDescriptorMap[t].name; | |
} | |
} | |
stringMapKeyAdded(t, e) { | |
let i = this.valueDescriptorMap[e]; | |
this.hasValue(t) || this.invokeChangedCallback(t, i.writer(this.receiver[t]), i.writer(i.defaultValue)); | |
} | |
stringMapValueChanged(t, e, i) { | |
let n = this.valueDescriptorNameMap[e]; | |
t !== null && (i === null && (i = n.writer(n.defaultValue)), this.invokeChangedCallback(e, t, i)); | |
} | |
stringMapKeyRemoved(t, e, i) { | |
let n = this.valueDescriptorNameMap[t]; | |
this.hasValue(t) ? this.invokeChangedCallback(t, n.writer(this.receiver[t]), i) : this.invokeChangedCallback(t, n.writer(n.defaultValue), i); | |
} | |
invokeChangedCallbacksForDefaultValues() { | |
for (let { | |
key: t, | |
name: e, | |
defaultValue: i, | |
writer: n | |
} of this.valueDescriptors) | |
i != null && !this.controller.data.has(t) && this.invokeChangedCallback(e, n(i), void 0); | |
} | |
invokeChangedCallback(t, e, i) { | |
let n = `${ t }Changed`, s = this.receiver[n]; | |
if (typeof s == 'function') { | |
let a = this.valueDescriptorNameMap[t]; | |
try { | |
let r = a.reader(e), l = i; | |
i && (l = a.reader(i)); | |
s.call(this.receiver, r, l); | |
} catch (r) { | |
throw r instanceof TypeError && (r.message = `Stimulus Value "${ this.context.identifier }.${ a.name }" - ${ r.message }`), r; | |
} | |
} | |
} | |
get valueDescriptors() { | |
let {valueDescriptorMap: t} = this; | |
return Object.keys(t).map(e => t[e]); | |
} | |
get valueDescriptorNameMap() { | |
let t = {}; | |
return Object.keys(this.valueDescriptorMap).forEach(e => { | |
let i = this.valueDescriptorMap[e]; | |
t[i.name] = i; | |
}), t; | |
} | |
hasValue(t) { | |
let e = this.valueDescriptorNameMap[t], i = `has${ ut(e.name) }`; | |
return this.receiver[i]; | |
} | |
}, le = class { | |
constructor(t, e) { | |
this.context = t; | |
this.delegate = e; | |
this.targetsByName = new T(); | |
} | |
start() { | |
this.tokenListObserver || (this.tokenListObserver = new xt(this.element, this.attributeName, this), this.tokenListObserver.start()); | |
} | |
stop() { | |
this.tokenListObserver && (this.disconnectAllTargets(), this.tokenListObserver.stop(), delete this.tokenListObserver); | |
} | |
tokenMatched({ | |
element: t, | |
content: e | |
}) { | |
this.scope.containsElement(t) && this.connectTarget(t, e); | |
} | |
tokenUnmatched({ | |
element: t, | |
content: e | |
}) { | |
this.disconnectTarget(t, e); | |
} | |
connectTarget(t, e) { | |
var i; | |
this.targetsByName.has(e, t) || (this.targetsByName.add(e, t), (i = this.tokenListObserver) === null || i === void 0 || i.pause(() => this.delegate.targetConnected(t, e))); | |
} | |
disconnectTarget(t, e) { | |
var i; | |
this.targetsByName.has(e, t) && (this.targetsByName.delete(e, t), (i = this.tokenListObserver) === null || i === void 0 || i.pause(() => this.delegate.targetDisconnected(t, e))); | |
} | |
disconnectAllTargets() { | |
for (let t of this.targetsByName.keys) | |
for (let e of this.targetsByName.getValuesForKey(t)) | |
this.disconnectTarget(e, t); | |
} | |
get attributeName() { | |
return `data-${ this.context.identifier }-target`; | |
} | |
get element() { | |
return this.context.element; | |
} | |
get scope() { | |
return this.context.scope; | |
} | |
}; | |
function mt(o, t) { | |
let e = li(o); | |
return Array.from(e.reduce((i, n) => (yn(n, t).forEach(s => i.add(s)), i), new Set())); | |
} | |
function Fn(o, t) { | |
return li(o).reduce((i, n) => (i.push(...vn(n, t)), i), []); | |
} | |
function li(o) { | |
let t = []; | |
for (; o;) { | |
t.push(o); | |
o = Object.getPrototypeOf(o); | |
} | |
return t.reverse(); | |
} | |
function yn(o, t) { | |
let e = o[t]; | |
return Array.isArray(e) ? e : []; | |
} | |
function vn(o, t) { | |
let e = o[t]; | |
return e ? Object.keys(e).map(i => [ | |
i, | |
e[i] | |
]) : []; | |
} | |
var ce = class { | |
constructor(t, e) { | |
this.started = false; | |
this.context = t; | |
this.delegate = e; | |
this.outletsByName = new T(); | |
this.outletElementsByName = new T(); | |
this.selectorObserverMap = new Map(); | |
this.attributeObserverMap = new Map(); | |
} | |
start() { | |
this.started || (this.outletDefinitions.forEach(t => { | |
this.setupSelectorObserverForOutlet(t); | |
this.setupAttributeObserverForOutlet(t); | |
}), this.started = true, this.dependentContexts.forEach(t => t.refresh())); | |
} | |
refresh() { | |
this.selectorObserverMap.forEach(t => t.refresh()); | |
this.attributeObserverMap.forEach(t => t.refresh()); | |
} | |
stop() { | |
this.started && (this.started = false, this.disconnectAllOutlets(), this.stopSelectorObservers(), this.stopAttributeObservers()); | |
} | |
stopSelectorObservers() { | |
this.selectorObserverMap.size > 0 && (this.selectorObserverMap.forEach(t => t.stop()), this.selectorObserverMap.clear()); | |
} | |
stopAttributeObservers() { | |
this.attributeObserverMap.size > 0 && (this.attributeObserverMap.forEach(t => t.stop()), this.attributeObserverMap.clear()); | |
} | |
selectorMatched(t, e, {outletName: i}) { | |
let n = this.getOutlet(t, i); | |
n && this.connectOutlet(n, t, i); | |
} | |
selectorUnmatched(t, e, {outletName: i}) { | |
let n = this.getOutletFromMap(t, i); | |
n && this.disconnectOutlet(n, t, i); | |
} | |
selectorMatchElement(t, {outletName: e}) { | |
let i = this.selector(e), n = this.hasOutlet(t, e), s = t.matches(`[${ this.schema.controllerAttribute }~=${ e }]`); | |
return i ? n && s && t.matches(i) : false; | |
} | |
elementMatchedAttribute(t, e) { | |
let i = this.getOutletNameFromOutletAttributeName(e); | |
i && this.updateSelectorObserverForOutlet(i); | |
} | |
elementAttributeValueChanged(t, e) { | |
let i = this.getOutletNameFromOutletAttributeName(e); | |
i && this.updateSelectorObserverForOutlet(i); | |
} | |
elementUnmatchedAttribute(t, e) { | |
let i = this.getOutletNameFromOutletAttributeName(e); | |
i && this.updateSelectorObserverForOutlet(i); | |
} | |
connectOutlet(t, e, i) { | |
var n; | |
this.outletElementsByName.has(i, e) || (this.outletsByName.add(i, t), this.outletElementsByName.add(i, e), (n = this.selectorObserverMap.get(i)) === null || n === void 0 || n.pause(() => this.delegate.outletConnected(t, e, i))); | |
} | |
disconnectOutlet(t, e, i) { | |
var n; | |
this.outletElementsByName.has(i, e) && (this.outletsByName.delete(i, t), this.outletElementsByName.delete(i, e), (n = this.selectorObserverMap.get(i)) === null || n === void 0 || n.pause(() => this.delegate.outletDisconnected(t, e, i))); | |
} | |
disconnectAllOutlets() { | |
for (let t of this.outletElementsByName.keys) | |
for (let e of this.outletElementsByName.getValuesForKey(t)) | |
for (let i of this.outletsByName.getValuesForKey(t)) | |
this.disconnectOutlet(i, e, t); | |
} | |
updateSelectorObserverForOutlet(t) { | |
let e = this.selectorObserverMap.get(t); | |
e && (e.selector = this.selector(t)); | |
} | |
setupSelectorObserverForOutlet(t) { | |
let e = this.selector(t), i = new se(document.body, e, this, { outletName: t }); | |
this.selectorObserverMap.set(t, i); | |
i.start(); | |
} | |
setupAttributeObserverForOutlet(t) { | |
let e = this.attributeNameForOutletName(t), i = new Bt(this.scope.element, e, this); | |
this.attributeObserverMap.set(t, i); | |
i.start(); | |
} | |
selector(t) { | |
return this.scope.outlets.getSelectorForOutletName(t); | |
} | |
attributeNameForOutletName(t) { | |
return this.scope.schema.outletAttributeForScope(this.identifier, t); | |
} | |
getOutletNameFromOutletAttributeName(t) { | |
return this.outletDefinitions.find(e => this.attributeNameForOutletName(e) === t); | |
} | |
get outletDependencies() { | |
let t = new T(); | |
return this.router.modules.forEach(e => { | |
let i = e.definition.controllerConstructor; | |
mt(i, 'outlets').forEach(s => t.add(s, e.identifier)); | |
}), t; | |
} | |
get outletDefinitions() { | |
return this.outletDependencies.getKeysForValue(this.identifier); | |
} | |
get dependentControllerIdentifiers() { | |
return this.outletDependencies.getValuesForKey(this.identifier); | |
} | |
get dependentContexts() { | |
let t = this.dependentControllerIdentifiers; | |
return this.router.contexts.filter(e => t.includes(e.identifier)); | |
} | |
hasOutlet(t, e) { | |
return !!this.getOutlet(t, e) || !!this.getOutletFromMap(t, e); | |
} | |
getOutlet(t, e) { | |
return this.application.getControllerForElementAndIdentifier(t, e); | |
} | |
getOutletFromMap(t, e) { | |
return this.outletsByName.getValuesForKey(e).find(i => i.element === t); | |
} | |
get scope() { | |
return this.context.scope; | |
} | |
get schema() { | |
return this.context.schema; | |
} | |
get identifier() { | |
return this.context.identifier; | |
} | |
get application() { | |
return this.context.application; | |
} | |
get router() { | |
return this.application.router; | |
} | |
}, de = class { | |
constructor(t, e) { | |
this.logDebugActivity = (i, n = {}) => { | |
let { | |
identifier: s, | |
controller: a, | |
element: r | |
} = this; | |
n = Object.assign({ | |
identifier: s, | |
controller: a, | |
element: r | |
}, n); | |
this.application.logDebugActivity(this.identifier, i, n); | |
}; | |
this.module = t; | |
this.scope = e; | |
this.controller = new t.controllerConstructor(this); | |
this.bindingObserver = new ae(this, this.dispatcher); | |
this.valueObserver = new re(this, this.controller); | |
this.targetObserver = new le(this, this); | |
this.outletObserver = new ce(this, this); | |
try { | |
this.controller.initialize(); | |
this.logDebugActivity('initialize'); | |
} catch (i) { | |
this.handleError(i, 'initializing controller'); | |
} | |
} | |
connect() { | |
this.bindingObserver.start(); | |
this.valueObserver.start(); | |
this.targetObserver.start(); | |
this.outletObserver.start(); | |
try { | |
this.controller.connect(); | |
this.logDebugActivity('connect'); | |
} catch (t) { | |
this.handleError(t, 'connecting controller'); | |
} | |
} | |
refresh() { | |
this.outletObserver.refresh(); | |
} | |
disconnect() { | |
try { | |
this.controller.disconnect(); | |
this.logDebugActivity('disconnect'); | |
} catch (t) { | |
this.handleError(t, 'disconnecting controller'); | |
} | |
this.outletObserver.stop(); | |
this.targetObserver.stop(); | |
this.valueObserver.stop(); | |
this.bindingObserver.stop(); | |
} | |
get application() { | |
return this.module.application; | |
} | |
get identifier() { | |
return this.module.identifier; | |
} | |
get schema() { | |
return this.application.schema; | |
} | |
get dispatcher() { | |
return this.application.dispatcher; | |
} | |
get element() { | |
return this.scope.element; | |
} | |
get parentElement() { | |
return this.element.parentElement; | |
} | |
handleError(t, e, i = {}) { | |
let { | |
identifier: n, | |
controller: s, | |
element: a | |
} = this; | |
i = Object.assign({ | |
identifier: n, | |
controller: s, | |
element: a | |
}, i); | |
this.application.handleError(t, `Error ${ e }`, i); | |
} | |
targetConnected(t, e) { | |
this.invokeControllerMethod(`${ e }TargetConnected`, t); | |
} | |
targetDisconnected(t, e) { | |
this.invokeControllerMethod(`${ e }TargetDisconnected`, t); | |
} | |
outletConnected(t, e, i) { | |
this.invokeControllerMethod(`${ te(i) }OutletConnected`, t, e); | |
} | |
outletDisconnected(t, e, i) { | |
this.invokeControllerMethod(`${ te(i) }OutletDisconnected`, t, e); | |
} | |
invokeControllerMethod(t, ...e) { | |
let i = this.controller; | |
typeof i[t] == 'function' && i[t](...e); | |
} | |
}; | |
function Bn(o) { | |
return xn(o, Un(o)); | |
} | |
function xn(o, t) { | |
let e = Wn(o), i = Ln(o.prototype, t); | |
return Object.defineProperties(e.prototype, i), e; | |
} | |
function Un(o) { | |
return mt(o, 'blessings').reduce((e, i) => { | |
let n = i(o); | |
for (let s in n) { | |
let a = e[s] || {}; | |
e[s] = Object.assign(a, n[s]); | |
} | |
return e; | |
}, {}); | |
} | |
function Ln(o, t) { | |
return An(t).reduce((e, i) => { | |
let n = wn(o, t, i); | |
return n && Object.assign(e, { [i]: n }), e; | |
}, {}); | |
} | |
function wn(o, t, e) { | |
let i = Object.getOwnPropertyDescriptor(o, e); | |
if (!(i && 'value' in i)) { | |
let s = Object.getOwnPropertyDescriptor(t, e).value; | |
return i && (s.get = i.get || s.get, s.set = i.set || s.set), s; | |
} | |
} | |
var An = typeof Object.getOwnPropertySymbols == 'function' ? o => [ | |
...Object.getOwnPropertyNames(o), | |
...Object.getOwnPropertySymbols(o) | |
] : Object.getOwnPropertyNames, Wn = (() => { | |
function o(e) { | |
function i() { | |
return Reflect.construct(e, arguments, new.target); | |
} | |
return i.prototype = Object.create(e.prototype, { constructor: { value: i } }), Reflect.setPrototypeOf(i, e), i; | |
} | |
function t() { | |
let i = o(function () { | |
this.a.call(this); | |
}); | |
return i.prototype.a = function () { | |
}, new i(); | |
} | |
try { | |
return t(), o; | |
} catch { | |
return i => class extends i { | |
}; | |
} | |
})(); | |
function Zn(o) { | |
return { | |
identifier: o.identifier, | |
controllerConstructor: Bn(o.controllerConstructor) | |
}; | |
} | |
var he = class { | |
constructor(t, e) { | |
this.application = t; | |
this.definition = Zn(e); | |
this.contextsByScope = new WeakMap(); | |
this.connectedContexts = new Set(); | |
} | |
get identifier() { | |
return this.definition.identifier; | |
} | |
get controllerConstructor() { | |
return this.definition.controllerConstructor; | |
} | |
get contexts() { | |
return Array.from(this.connectedContexts); | |
} | |
connectContextForScope(t) { | |
let e = this.fetchContextForScope(t); | |
this.connectedContexts.add(e); | |
e.connect(); | |
} | |
disconnectContextForScope(t) { | |
let e = this.contextsByScope.get(t); | |
e && (this.connectedContexts.delete(e), e.disconnect()); | |
} | |
fetchContextForScope(t) { | |
let e = this.contextsByScope.get(t); | |
return e || (e = new de(this, t), this.contextsByScope.set(t, e)), e; | |
} | |
}, ue = class { | |
constructor(t) { | |
this.scope = t; | |
} | |
has(t) { | |
return this.data.has(this.getDataKey(t)); | |
} | |
get(t) { | |
return this.getAll(t)[0]; | |
} | |
getAll(t) { | |
let e = this.data.get(this.getDataKey(t)) || ''; | |
return dn(e); | |
} | |
getAttributeName(t) { | |
return this.data.getAttributeNameForKey(this.getDataKey(t)); | |
} | |
getDataKey(t) { | |
return `${ t }-class`; | |
} | |
get data() { | |
return this.scope.data; | |
} | |
}, me = class { | |
constructor(t) { | |
this.scope = t; | |
} | |
get element() { | |
return this.scope.element; | |
} | |
get identifier() { | |
return this.scope.identifier; | |
} | |
get(t) { | |
let e = this.getAttributeNameForKey(t); | |
return this.element.getAttribute(e); | |
} | |
set(t, e) { | |
let i = this.getAttributeNameForKey(t); | |
return this.element.setAttribute(i, e), this.get(t); | |
} | |
has(t) { | |
let e = this.getAttributeNameForKey(t); | |
return this.element.hasAttribute(e); | |
} | |
delete(t) { | |
if (this.has(t)) { | |
let e = this.getAttributeNameForKey(t); | |
return this.element.removeAttribute(e), true; | |
} else { | |
return false; | |
} | |
} | |
getAttributeNameForKey(t) { | |
return `data-${ this.identifier }-${ ai(t) }`; | |
} | |
}, be = class { | |
constructor(t) { | |
this.warnedKeysByObject = new WeakMap(); | |
this.logger = t; | |
} | |
warn(t, e, i) { | |
let n = this.warnedKeysByObject.get(t); | |
n || (n = new Set(), this.warnedKeysByObject.set(t, n)); | |
n.has(e) || (n.add(e), this.logger.warn(i, t)); | |
} | |
}; | |
function pe(o, t) { | |
return `[${ o }~="${ t }"]`; | |
} | |
var fe = class { | |
constructor(t) { | |
this.scope = t; | |
} | |
get element() { | |
return this.scope.element; | |
} | |
get identifier() { | |
return this.scope.identifier; | |
} | |
get schema() { | |
return this.scope.schema; | |
} | |
has(t) { | |
return this.find(t) != null; | |
} | |
find(...t) { | |
return t.reduce((e, i) => e || this.findTarget(i) || this.findLegacyTarget(i), void 0); | |
} | |
findAll(...t) { | |
return t.reduce((e, i) => [ | |
...e, | |
...this.findAllTargets(i), | |
...this.findAllLegacyTargets(i) | |
], []); | |
} | |
findTarget(t) { | |
let e = this.getSelectorForTargetName(t); | |
return this.scope.findElement(e); | |
} | |
findAllTargets(t) { | |
let e = this.getSelectorForTargetName(t); | |
return this.scope.findAllElements(e); | |
} | |
getSelectorForTargetName(t) { | |
let e = this.schema.targetAttributeForScope(this.identifier); | |
return pe(e, t); | |
} | |
findLegacyTarget(t) { | |
let e = this.getLegacySelectorForTargetName(t); | |
return this.deprecate(this.scope.findElement(e), t); | |
} | |
findAllLegacyTargets(t) { | |
let e = this.getLegacySelectorForTargetName(t); | |
return this.scope.findAllElements(e).map(i => this.deprecate(i, t)); | |
} | |
getLegacySelectorForTargetName(t) { | |
let e = `${ this.identifier }.${ t }`; | |
return pe(this.schema.targetAttribute, e); | |
} | |
deprecate(t, e) { | |
if (t) { | |
let {identifier: i} = this, n = this.schema.targetAttribute, s = this.schema.targetAttributeForScope(i); | |
this.guide.warn(t, `target:${ e }`, `Please replace ${ n }="${ i }.${ e }" with ${ s }="${ e }". The ${ n } attribute is deprecated and will be removed in a future version of Stimulus.`); | |
} | |
return t; | |
} | |
get guide() { | |
return this.scope.guide; | |
} | |
}, ge = class { | |
constructor(t, e) { | |
this.scope = t; | |
this.controllerElement = e; | |
} | |
get element() { | |
return this.scope.element; | |
} | |
get identifier() { | |
return this.scope.identifier; | |
} | |
get schema() { | |
return this.scope.schema; | |
} | |
has(t) { | |
return this.find(t) != null; | |
} | |
find(...t) { | |
return t.reduce((e, i) => e || this.findOutlet(i), void 0); | |
} | |
findAll(...t) { | |
return t.reduce((e, i) => [ | |
...e, | |
...this.findAllOutlets(i) | |
], []); | |
} | |
getSelectorForOutletName(t) { | |
let e = this.schema.outletAttributeForScope(this.identifier, t); | |
return this.controllerElement.getAttribute(e); | |
} | |
findOutlet(t) { | |
let e = this.getSelectorForOutletName(t); | |
if (e) { | |
return this.findElement(e, t); | |
} | |
} | |
findAllOutlets(t) { | |
let e = this.getSelectorForOutletName(t); | |
return e ? this.findAllElements(e, t) : []; | |
} | |
findElement(t, e) { | |
return this.scope.queryElements(t).filter(n => this.matchesElement(n, t, e))[0]; | |
} | |
findAllElements(t, e) { | |
return this.scope.queryElements(t).filter(n => this.matchesElement(n, t, e)); | |
} | |
matchesElement(t, e, i) { | |
let n = t.getAttribute(this.scope.schema.controllerAttribute) || ''; | |
return t.matches(e) && n.split(' ').includes(i); | |
} | |
}, Qe = class o { | |
constructor(t, e, i, n) { | |
this.targets = new fe(this); | |
this.classes = new ue(this); | |
this.data = new me(this); | |
this.containsElement = s => s.closest(this.controllerSelector) === this.element; | |
this.schema = t; | |
this.element = e; | |
this.identifier = i; | |
this.guide = new be(n); | |
this.outlets = new ge(this.documentScope, e); | |
} | |
findElement(t) { | |
return this.element.matches(t) ? this.element : this.queryElements(t).find(this.containsElement); | |
} | |
findAllElements(t) { | |
return [ | |
...this.element.matches(t) ? [this.element] : [], | |
...this.queryElements(t).filter(this.containsElement) | |
]; | |
} | |
queryElements(t) { | |
return Array.from(this.element.querySelectorAll(t)); | |
} | |
get controllerSelector() { | |
return pe(this.schema.controllerAttribute, this.identifier); | |
} | |
get isDocumentScope() { | |
return this.element === document.documentElement; | |
} | |
get documentScope() { | |
return this.isDocumentScope ? this : new o(this.schema, document.documentElement, this.identifier, this.guide.logger); | |
} | |
}, Fe = class { | |
constructor(t, e, i) { | |
this.element = t; | |
this.schema = e; | |
this.delegate = i; | |
this.valueListObserver = new Ut(this.element, this.controllerAttribute, this); | |
this.scopesByIdentifierByElement = new WeakMap(); | |
this.scopeReferenceCounts = new WeakMap(); | |
} | |
start() { | |
this.valueListObserver.start(); | |
} | |
stop() { | |
this.valueListObserver.stop(); | |
} | |
get controllerAttribute() { | |
return this.schema.controllerAttribute; | |
} | |
parseValueForToken(t) { | |
let { | |
element: e, | |
content: i | |
} = t; | |
return this.parseValueForElementAndIdentifier(e, i); | |
} | |
parseValueForElementAndIdentifier(t, e) { | |
let i = this.fetchScopesByIdentifierForElement(t), n = i.get(e); | |
return n || (n = this.delegate.createScopeForElementAndIdentifier(t, e), i.set(e, n)), n; | |
} | |
elementMatchedValue(t, e) { | |
let i = (this.scopeReferenceCounts.get(e) || 0) + 1; | |
this.scopeReferenceCounts.set(e, i); | |
i == 1 && this.delegate.scopeConnected(e); | |
} | |
elementUnmatchedValue(t, e) { | |
let i = this.scopeReferenceCounts.get(e); | |
i && (this.scopeReferenceCounts.set(e, i - 1), i == 1 && this.delegate.scopeDisconnected(e)); | |
} | |
fetchScopesByIdentifierForElement(t) { | |
let e = this.scopesByIdentifierByElement.get(t); | |
return e || (e = new Map(), this.scopesByIdentifierByElement.set(t, e)), e; | |
} | |
}, ye = class { | |
constructor(t) { | |
this.application = t; | |
this.scopeObserver = new Fe(this.element, this.schema, this); | |
this.scopesByIdentifier = new T(); | |
this.modulesByIdentifier = new Map(); | |
} | |
get element() { | |
return this.application.element; | |
} | |
get schema() { | |
return this.application.schema; | |
} | |
get logger() { | |
return this.application.logger; | |
} | |
get controllerAttribute() { | |
return this.schema.controllerAttribute; | |
} | |
get modules() { | |
return Array.from(this.modulesByIdentifier.values()); | |
} | |
get contexts() { | |
return this.modules.reduce((t, e) => t.concat(e.contexts), []); | |
} | |
start() { | |
this.scopeObserver.start(); | |
} | |
stop() { | |
this.scopeObserver.stop(); | |
} | |
loadDefinition(t) { | |
this.unloadIdentifier(t.identifier); | |
let e = new he(this.application, t); | |
this.connectModule(e); | |
let i = t.controllerConstructor.afterLoad; | |
i && i.call(t.controllerConstructor, t.identifier, this.application); | |
} | |
unloadIdentifier(t) { | |
let e = this.modulesByIdentifier.get(t); | |
e && this.disconnectModule(e); | |
} | |
getContextForElementAndIdentifier(t, e) { | |
let i = this.modulesByIdentifier.get(e); | |
if (i) { | |
return i.contexts.find(n => n.element == t); | |
} | |
} | |
proposeToConnectScopeForElementAndIdentifier(t, e) { | |
let i = this.scopeObserver.parseValueForElementAndIdentifier(t, e); | |
i ? this.scopeObserver.elementMatchedValue(i.element, i) : console.error(`Couldn't find or create scope for identifier: "${ e }" and element:`, t); | |
} | |
handleError(t, e, i) { | |
this.application.handleError(t, e, i); | |
} | |
createScopeForElementAndIdentifier(t, e) { | |
return new Qe(this.schema, t, e, this.logger); | |
} | |
scopeConnected(t) { | |
this.scopesByIdentifier.add(t.identifier, t); | |
let e = this.modulesByIdentifier.get(t.identifier); | |
e && e.connectContextForScope(t); | |
} | |
scopeDisconnected(t) { | |
this.scopesByIdentifier.delete(t.identifier, t); | |
let e = this.modulesByIdentifier.get(t.identifier); | |
e && e.disconnectContextForScope(t); | |
} | |
connectModule(t) { | |
this.modulesByIdentifier.set(t.identifier, t); | |
this.scopesByIdentifier.getValuesForKey(t.identifier).forEach(i => t.connectContextForScope(i)); | |
} | |
disconnectModule(t) { | |
this.modulesByIdentifier.delete(t.identifier); | |
this.scopesByIdentifier.getValuesForKey(t.identifier).forEach(i => t.disconnectContextForScope(i)); | |
} | |
}, Cn = { | |
controllerAttribute: 'data-controller', | |
actionAttribute: 'data-action', | |
targetAttribute: 'data-target', | |
targetAttributeForScope: o => `data-${ o }-target`, | |
outletAttributeForScope: (o, t) => `data-${ o }-${ t }-outlet`, | |
keyMappings: Object.assign(Object.assign({ | |
enter: 'Enter', | |
tab: 'Tab', | |
esc: 'Escape', | |
space: ' ', | |
up: 'ArrowUp', | |
down: 'ArrowDown', | |
left: 'ArrowLeft', | |
right: 'ArrowRight', | |
home: 'Home', | |
end: 'End', | |
page_up: 'PageUp', | |
page_down: 'PageDown' | |
}, ti('abcdefghijklmnopqrstuvwxyz'.split('').map(o => [ | |
o, | |
o | |
]))), ti('0123456789'.split('').map(o => [ | |
o, | |
o | |
]))) | |
}; | |
function ti(o) { | |
return o.reduce((t, [e, i]) => Object.assign(Object.assign({}, t), { [e]: i }), {}); | |
} | |
var Lt = class { | |
constructor(t = document.documentElement, e = Cn) { | |
this.logger = console; | |
this.debug = false; | |
this.logDebugActivity = (i, n, s = {}) => { | |
this.debug && this.logFormattedMessage(i, n, s); | |
}; | |
this.element = t; | |
this.schema = e; | |
this.dispatcher = new $t(this); | |
this.router = new ye(this); | |
this.actionDescriptorFilters = Object.assign({}, sn); | |
} | |
static start(t, e) { | |
let i = new this(t, e); | |
return i.start(), i; | |
} | |
async start() { | |
await En(); | |
this.logDebugActivity('application', 'starting'); | |
this.dispatcher.start(); | |
this.router.start(); | |
this.logDebugActivity('application', 'start'); | |
} | |
stop() { | |
this.logDebugActivity('application', 'stopping'); | |
this.dispatcher.stop(); | |
this.router.stop(); | |
this.logDebugActivity('application', 'stop'); | |
} | |
register(t, e) { | |
this.load({ | |
identifier: t, | |
controllerConstructor: e | |
}); | |
} | |
registerActionOption(t, e) { | |
this.actionDescriptorFilters[t] = e; | |
} | |
load(t, ...e) { | |
(Array.isArray(t) ? t : [ | |
t, | |
...e | |
]).forEach(n => { | |
n.controllerConstructor.shouldLoad && this.router.loadDefinition(n); | |
}); | |
} | |
unload(t, ...e) { | |
(Array.isArray(t) ? t : [ | |
t, | |
...e | |
]).forEach(n => this.router.unloadIdentifier(n)); | |
} | |
get controllers() { | |
return this.router.contexts.map(t => t.controller); | |
} | |
getControllerForElementAndIdentifier(t, e) { | |
let i = this.router.getContextForElementAndIdentifier(t, e); | |
return i ? i.controller : null; | |
} | |
handleError(t, e, i) { | |
var n; | |
this.logger.error(`%s | |
%o | |
%o`, e, t, i); | |
(n = window.onerror) === null || n === void 0 || n.call(window, e, '', 0, 0, t); | |
} | |
logFormattedMessage(t, e, i = {}) { | |
i = Object.assign({ application: this }, i); | |
this.logger.groupCollapsed(`${ t } #${ e }`); | |
this.logger.log('details:', Object.assign({}, i)); | |
this.logger.groupEnd(); | |
} | |
}; | |
function En() { | |
return new Promise(o => { | |
document.readyState == 'loading' ? document.addEventListener('DOMContentLoaded', () => o()) : o(); | |
}); | |
} | |
function Mn(o) { | |
return mt(o, 'classes').reduce((e, i) => Object.assign(e, Dn(i)), {}); | |
} | |
function Dn(o) { | |
return { | |
[`${ o }Class`]: { | |
get() { | |
let {classes: t} = this; | |
if (t.has(o)) { | |
return t.get(o); | |
} | |
{ | |
let e = t.getAttributeName(o); | |
throw new Error(`Missing attribute "${ e }"`); | |
} | |
} | |
}, | |
[`${ o }Classes`]: { | |
get() { | |
return this.classes.getAll(o); | |
} | |
}, | |
[`has${ ut(o) }Class`]: { | |
get() { | |
return this.classes.has(o); | |
} | |
} | |
}; | |
} | |
function Yn(o) { | |
return mt(o, 'outlets').reduce((e, i) => Object.assign(e, On(i)), {}); | |
} | |
function ei(o, t, e) { | |
return o.application.getControllerForElementAndIdentifier(t, e); | |
} | |
function ii(o, t, e) { | |
let i = ei(o, t, e); | |
if (i || (o.application.router.proposeToConnectScopeForElementAndIdentifier(t, e), i = ei(o, t, e), i)) { | |
return i; | |
} | |
} | |
function On(o) { | |
let t = te(o); | |
return { | |
[`${ t }Outlet`]: { | |
get() { | |
let e = this.outlets.find(o), i = this.outlets.getSelectorForOutletName(o); | |
if (e) { | |
let n = ii(this, e, o); | |
if (n) { | |
return n; | |
} | |
throw new Error(`The provided outlet element is missing an outlet controller "${ o }" instance for host controller "${ this.identifier }"`); | |
} | |
throw new Error(`Missing outlet element "${ o }" for host controller "${ this.identifier }". Stimulus couldn't find a matching outlet element using selector "${ i }".`); | |
} | |
}, | |
[`${ t }Outlets`]: { | |
get() { | |
let e = this.outlets.findAll(o); | |
return e.length > 0 ? e.map(i => { | |
let n = ii(this, i, o); | |
if (n) { | |
return n; | |
} | |
console.warn(`The provided outlet element is missing an outlet controller "${ o }" instance for host controller "${ this.identifier }"`, i); | |
}).filter(i => i) : []; | |
} | |
}, | |
[`${ t }OutletElement`]: { | |
get() { | |
let e = this.outlets.find(o), i = this.outlets.getSelectorForOutletName(o); | |
if (e) { | |
return e; | |
} | |
throw new Error(`Missing outlet element "${ o }" for host controller "${ this.identifier }". Stimulus couldn't find a matching outlet element using selector "${ i }".`); | |
} | |
}, | |
[`${ t }OutletElements`]: { | |
get() { | |
return this.outlets.findAll(o); | |
} | |
}, | |
[`has${ ut(t) }Outlet`]: { | |
get() { | |
return this.outlets.has(o); | |
} | |
} | |
}; | |
} | |
function Nn(o) { | |
return mt(o, 'targets').reduce((e, i) => Object.assign(e, Rn(i)), {}); | |
} | |
function Rn(o) { | |
return { | |
[`${ o }Target`]: { | |
get() { | |
let t = this.targets.find(o); | |
if (t) { | |
return t; | |
} | |
throw new Error(`Missing target element "${ o }" for "${ this.identifier }" controller`); | |
} | |
}, | |
[`${ o }Targets`]: { | |
get() { | |
return this.targets.findAll(o); | |
} | |
}, | |
[`has${ ut(o) }Target`]: { | |
get() { | |
return this.targets.has(o); | |
} | |
} | |
}; | |
} | |
function kn(o) { | |
let t = Fn(o, 'values'), e = { | |
valueDescriptorMap: { | |
get() { | |
return t.reduce((i, n) => { | |
let s = ci(n, this.identifier), a = this.data.getAttributeNameForKey(s.key); | |
return Object.assign(i, { [a]: s }); | |
}, {}); | |
} | |
} | |
}; | |
return t.reduce((i, n) => Object.assign(i, Xn(n)), e); | |
} | |
function Xn(o, t) { | |
let e = ci(o, t), { | |
key: i, | |
name: n, | |
reader: s, | |
writer: a | |
} = e; | |
return { | |
[n]: { | |
get() { | |
let r = this.data.get(i); | |
return r !== null ? s(r) : e.defaultValue; | |
}, | |
set(r) { | |
r === void 0 ? this.data.delete(i) : this.data.set(i, a(r)); | |
} | |
}, | |
[`has${ ut(n) }`]: { | |
get() { | |
return this.data.has(i) || e.hasCustomDefaultValue; | |
} | |
} | |
}; | |
} | |
function ci([o, t], e) { | |
return Sn({ | |
controller: e, | |
token: o, | |
typeDefinition: t | |
}); | |
} | |
function wt(o) { | |
switch (o) { | |
case Array: | |
return 'array'; | |
case Boolean: | |
return 'boolean'; | |
case Number: | |
return 'number'; | |
case Object: | |
return 'object'; | |
case String: | |
return 'string'; | |
} | |
} | |
function ht(o) { | |
switch (typeof o) { | |
case 'boolean': | |
return 'boolean'; | |
case 'number': | |
return 'number'; | |
case 'string': | |
return 'string'; | |
} | |
if (Array.isArray(o)) { | |
return 'array'; | |
} | |
if (Object.prototype.toString.call(o) === '[object Object]') { | |
return 'object'; | |
} | |
} | |
function Gn(o) { | |
let { | |
controller: t, | |
token: e, | |
typeObject: i | |
} = o, n = Ke(i.type), s = Ke(i.default), a = n && s, r = n && !s, l = !n && s, c = wt(i.type), d = ht(o.typeObject.default); | |
if (r) { | |
return c; | |
} | |
if (l) { | |
return d; | |
} | |
if (c !== d) { | |
let u = t ? `${ t }.${ e }` : e; | |
throw new Error(`The specified default value for the Stimulus Value "${ u }" must match the defined type "${ c }". The provided default value of "${ i.default }" is of type "${ d }".`); | |
} | |
if (a) { | |
return c; | |
} | |
} | |
function Vn(o) { | |
let { | |
controller: t, | |
token: e, | |
typeDefinition: i | |
} = o, s = Gn({ | |
controller: t, | |
token: e, | |
typeObject: i | |
}), a = ht(i), r = wt(i), l = s || a || r; | |
if (l) { | |
return l; | |
} | |
let c = t ? `${ t }.${ i }` : e; | |
throw new Error(`Unknown value type "${ c }" for "${ e }" value`); | |
} | |
function In(o) { | |
let t = wt(o); | |
if (t) { | |
return ni[t]; | |
} | |
let e = ee(o, 'default'), i = ee(o, 'type'), n = o; | |
if (e) { | |
return n.default; | |
} | |
if (i) { | |
let {type: s} = n, a = wt(s); | |
if (a) { | |
return ni[a]; | |
} | |
} | |
return o; | |
} | |
function Sn(o) { | |
let { | |
token: t, | |
typeDefinition: e | |
} = o, i = `${ ai(t) }-value`, n = Vn(o); | |
return { | |
type: n, | |
key: i, | |
name: ve(i), | |
get defaultValue() { | |
return In(e); | |
}, | |
get hasCustomDefaultValue() { | |
return ht(e) !== void 0; | |
}, | |
reader: zn[n], | |
writer: si[n] || si.default | |
}; | |
} | |
var ni = { | |
get array() { | |
return []; | |
}, | |
boolean: false, | |
number: 0, | |
get object() { | |
return {}; | |
}, | |
string: '' | |
}, zn = { | |
array(o) { | |
let t = JSON.parse(o); | |
if (!Array.isArray(t)) { | |
throw new TypeError(`expected value of type "array" but instead got value "${ o }" of type "${ ht(t) }"`); | |
} | |
return t; | |
}, | |
boolean(o) { | |
return !(o == '0' || String(o).toLowerCase() == 'false'); | |
}, | |
number(o) { | |
return Number(o.replace(/_/g, '')); | |
}, | |
object(o) { | |
let t = JSON.parse(o); | |
if (t === null || typeof t != 'object' || Array.isArray(t)) { | |
throw new TypeError(`expected value of type "object" but instead got value "${ o }" of type "${ ht(t) }"`); | |
} | |
return t; | |
}, | |
string(o) { | |
return o; | |
} | |
}, si = { | |
default: Tn, | |
array: oi, | |
object: oi | |
}; | |
function oi(o) { | |
return JSON.stringify(o); | |
} | |
function Tn(o) { | |
return `${ o }`; | |
} | |
var V = class { | |
constructor(t) { | |
this.context = t; | |
} | |
static get shouldLoad() { | |
return true; | |
} | |
static afterLoad(t, e) { | |
} | |
get application() { | |
return this.context.application; | |
} | |
get scope() { | |
return this.context.scope; | |
} | |
get element() { | |
return this.scope.element; | |
} | |
get identifier() { | |
return this.scope.identifier; | |
} | |
get targets() { | |
return this.scope.targets; | |
} | |
get outlets() { | |
return this.scope.outlets; | |
} | |
get classes() { | |
return this.scope.classes; | |
} | |
get data() { | |
return this.scope.data; | |
} | |
initialize() { | |
} | |
connect() { | |
} | |
disconnect() { | |
} | |
dispatch(t, { | |
target: e = this.element, | |
detail: i = {}, | |
prefix: n = this.identifier, | |
bubbles: s = true, | |
cancelable: a = true | |
} = {}) { | |
let r = n ? `${ n }:${ t }` : t, l = new CustomEvent(r, { | |
detail: i, | |
bubbles: s, | |
cancelable: a | |
}); | |
return e.dispatchEvent(l), l; | |
} | |
}; | |
V.blessings = [ | |
Mn, | |
Nn, | |
kn, | |
Yn | |
]; | |
V.targets = []; | |
V.outlets = []; | |
V.values = {}; | |
var Be = {}; | |
_e(Be, { default: () => At }); | |
var At = class extends V { | |
connect() { | |
fetch('https://files.thisisnotawebsitedotcom.com/is-it-time-yet/well-is-it.txt', { cache: 'no-store' }).then(o => o.text()).then(o => { | |
o == 'NO' ? (this.updateCountdown(), setInterval(this.updateCountdown.bind(this), 1000)) : o.includes('https') ? window.location.replace(o) : (this.timeValue = o, this.updateCountdown(), setInterval(this.updateCountdown.bind(this), 1000)); | |
}); | |
} | |
updateCountdown() { | |
let o = new Date().getTime(), t = new Date(this.timeValue).getTime(), i = t - o, n = Math.floor(i / 86400000); | |
n < 10 && n > 0 && (n = `0${ n }`); | |
let s = Math.floor(i % 86400000 / 3600000); | |
s < 10 && s > 0 && (s = `0${ s }`); | |
let a = Math.floor(i % 3600000 / 60000); | |
a < 10 && a > 0 && (a = `0${ a }`); | |
a == 0 && (a = '00'); | |
let r = Math.floor(i % 60000 / 1000); | |
if (r < 10 && r > 0 && (r = `0${ r }`), true && i < 0) { | |
for (let l of document.querySelectorAll('.error')) | |
l.classList.remove('hidden'); | |
this.element.innerHTML = `<div class='flex gap-x-2 items-center justify-center'>${ n + 1 <= -1 ? '<span class=\'text-3xl whitespace-nowrap md:text-6xl w-8 md:w-16\'>' + (n + 1) + '</span><span class=\'text-2xl md:text-5xl w-4 md:w-8\'>:</span>' : '' }${ n + 1 <= -1 || s + 1 <= -1 ? '<span class=\'text-3xl whitespace-nowrap md:text-6xl w-8 md:w-16\'>' + (s + 1) + '</span><span class=\'text-2xl md:text-5xl w-4 md:w-8\'>:</span>' : '' }<span class='text-3xl whitespace-nowrap md:text-6xl w-8 md:w-16'>${ a }</span><span class='text-2xl md:text-5xl w-4 md:w-8'>:</span><span class='text-3xl whitespace-nowrap md:text-6xl w-8 md:w-16'>${ r }</span></div>`; | |
} else { | |
i < 0 ? this.element.innerHTML = 'NOW<br/><small>(REFRESH)</small>' : this.element.innerHTML = `<div class='flex gap-x-2 items-center justify-center'>${ n > 0 ? '<span class=\'text-3xl whitespace-nowrap md:text-6xl w-8 md:w-16\'>' + n + '</span><span class=\'text-2xl md:text-5xl w-4 md:w-8\'>:</span>' : '' }${ n > 0 || s > 0 ? '<span class=\'text-3xl whitespace-nowrap md:text-6xl w-8 md:w-16\'>' + s + '</span><span class=\'text-2xl md:text-5xl w-4 md:w-8\'>:</span>' : '' }<span class='text-3xl whitespace-nowrap md:text-6xl w-8 md:w-16'>${ a }</span><span class='text-2xl md:text-5xl w-4 md:w-8'>:</span><span class='text-3xl whitespace-nowrap md:text-6xl w-8 md:w-16'>${ r }</span></div>`; | |
} | |
} | |
}; | |
Ft(At, 'values', { | |
time: { | |
type: String, | |
default: '' | |
} | |
}); | |
var Te = {}; | |
_e(Te, { default: () => Kt }); | |
var Q = (o, t = 10000) => (o = parseFloat(o + '') || 0, Math.round((o + Number.EPSILON) * t) / t), Xe = function (o) { | |
if (!(o && o instanceof Element && o.offsetParent)) { | |
return false; | |
} | |
let t = o.scrollHeight > o.clientHeight, e = window.getComputedStyle(o).overflowY, i = e.indexOf('hidden') !== -1, n = e.indexOf('visible') !== -1; | |
return t && !i && !n; | |
}, Gt = function (o, t = void 0) { | |
return !(!o || o === document.body || t && o === t) && (Xe(o) ? o : Gt(o.parentElement, t)); | |
}, S = function (o) { | |
var t = new DOMParser().parseFromString(o, 'text/html').body; | |
if (t.childElementCount > 1) { | |
for (var e = document.createElement('div'); t.firstChild;) { | |
e.appendChild(t.firstChild); | |
} | |
return e; | |
} | |
return t.firstChild; | |
}, Se = o => `${ o || '' }`.split(' ').filter(t => !!t), z = (o, t, e) => { | |
o && Se(t).forEach(i => { | |
o.classList.toggle(i, e || false); | |
}); | |
}, K = class { | |
constructor(t) { | |
Object.defineProperty(this, 'pageX', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'pageY', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'clientX', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'clientY', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'id', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'time', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'nativePointer', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
this.nativePointer = t; | |
this.pageX = t.pageX; | |
this.pageY = t.pageY; | |
this.clientX = t.clientX; | |
this.clientY = t.clientY; | |
this.id = self.Touch && t instanceof Touch ? t.identifier : -1; | |
this.time = Date.now(); | |
} | |
}, Ge = class { | |
constructor(t, { | |
start: e = () => true, | |
move: i = () => { | |
}, | |
end: n = () => { | |
} | |
}) { | |
Object.defineProperty(this, 'element', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'startCallback', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'moveCallback', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'endCallback', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
Object.defineProperty(this, 'currentPointers', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: [] | |
}); | |
Object.defineProperty(this, 'startPointers', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: [] | |
}); | |
this.element = t; | |
this.startCallback = e; | |
this.moveCallback = i; | |
this.endCallback = n; | |
for (let s of [ | |
'onPointerStart', | |
'onTouchStart', | |
'onMove', | |
'onTouchEnd', | |
'onPointerEnd', | |
'onWindowBlur' | |
]) | |
this[s] = this[s].bind(this); | |
this.element.addEventListener('mousedown', this.onPointerStart, st); | |
this.element.addEventListener('touchstart', this.onTouchStart, st); | |
this.element.addEventListener('touchmove', this.onMove, st); | |
this.element.addEventListener('touchend', this.onTouchEnd); | |
this.element.addEventListener('touchcancel', this.onTouchEnd); | |
} | |
onPointerStart(t) { | |
if (!t.buttons || t.button !== 0) { | |
return; | |
} | |
let e = new K(t); | |
this.currentPointers.some(i => i.id === e.id) || this.triggerPointerStart(e, t) && (window.addEventListener('mousemove', this.onMove), window.addEventListener('mouseup', this.onPointerEnd), window.addEventListener('blur', this.onWindowBlur)); | |
} | |
onTouchStart(t) { | |
for (let e of Array.from(t.changedTouches || [])) | |
this.triggerPointerStart(new K(e), t); | |
window.addEventListener('blur', this.onWindowBlur); | |
} | |
onMove(t) { | |
let e = this.currentPointers.slice(), i = 'changedTouches' in t ? Array.from(t.changedTouches || []).map(s => new K(s)) : [new K(t)], n = []; | |
for (let s of i) { | |
let a = this.currentPointers.findIndex(r => r.id === s.id); | |
a < 0 || (n.push(s), this.currentPointers[a] = s); | |
} | |
n.length && this.moveCallback(t, this.currentPointers.slice(), e); | |
} | |
onPointerEnd(t) { | |
t.buttons > 0 && t.button !== 0 || (this.triggerPointerEnd(t, new K(t)), window.removeEventListener('mousemove', this.onMove), window.removeEventListener('mouseup', this.onPointerEnd), window.removeEventListener('blur', this.onWindowBlur)); | |
} | |
onTouchEnd(t) { | |
for (let e of Array.from(t.changedTouches || [])) | |
this.triggerPointerEnd(t, new K(e)); | |
} | |
triggerPointerStart(t, e) { | |
return !!this.startCallback(e, t, this.currentPointers.slice()) && (this.currentPointers.push(t), this.startPointers.push(t), true); | |
} | |
triggerPointerEnd(t, e) { | |
let i = this.currentPointers.findIndex(n => n.id === e.id); | |
i < 0 || (this.currentPointers.splice(i, 1), this.startPointers.splice(i, 1), this.endCallback(t, e, this.currentPointers.slice())); | |
} | |
onWindowBlur() { | |
this.clear(); | |
} | |
clear() { | |
for (; this.currentPointers.length;) { | |
let t = this.currentPointers[this.currentPointers.length - 1]; | |
this.currentPointers.splice(this.currentPointers.length - 1, 1); | |
this.startPointers.splice(this.currentPointers.length - 1, 1); | |
this.endCallback(new Event('touchend', { | |
bubbles: true, | |
cancelable: true, | |
clientX: t.clientX, | |
clientY: t.clientY | |
}), t, this.currentPointers.slice()); | |
} | |
} | |
stop() { | |
this.element.removeEventListener('mousedown', this.onPointerStart, st); | |
this.element.removeEventListener('touchstart', this.onTouchStart, st); | |
this.element.removeEventListener('touchmove', this.onMove, st); | |
this.element.removeEventListener('touchend', this.onTouchEnd); | |
this.element.removeEventListener('touchcancel', this.onTouchEnd); | |
window.removeEventListener('mousemove', this.onMove); | |
window.removeEventListener('mouseup', this.onPointerEnd); | |
window.removeEventListener('blur', this.onWindowBlur); | |
} | |
}; | |
function di(o, t) { | |
return t ? Math.sqrt(Math.pow(t.clientX - o.clientX, 2) + Math.pow(t.clientY - o.clientY, 2)) : 0; | |
} | |
function hi(o, t) { | |
return t ? { | |
clientX: (o.clientX + t.clientX) / 2, | |
clientY: (o.clientY + t.clientY) / 2 | |
} : o; | |
} | |
var Ve = o => typeof o == 'object' && o !== null && o.constructor === Object && Object.prototype.toString.call(o) === '[object Object]', E = (o, ...t) => { | |
let e = t.length; | |
for (let i = 0; i < e; i++) { | |
let n = t[i] || {}; | |
Object.entries(n).forEach(([s, a]) => { | |
let r = Array.isArray(a) ? [] : {}; | |
o[s] || Object.assign(o, { [s]: r }); | |
Ve(a) ? Object.assign(o[s], E(r, a)) : Array.isArray(a) ? Object.assign(o, { [s]: [...a] }) : Object.assign(o, { [s]: a }); | |
}); | |
} | |
return o; | |
}, xe = function (o, t) { | |
return o.split('.').reduce((e, i) => typeof e == 'object' ? e[i] : void 0, t); | |
}, dt = class { | |
constructor(t = {}) { | |
Object.defineProperty(this, 'options', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: t | |
}); | |
Object.defineProperty(this, 'events', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: new Map() | |
}); | |
this.setOptions(t); | |
for (let e of Object.getOwnPropertyNames(Object.getPrototypeOf(this))) | |
e.startsWith('on') && typeof this[e] == 'function' && (this[e] = this[e].bind(this)); | |
} | |
setOptions(t) { | |
this.options = t ? E({}, this.constructor.defaults, t) : {}; | |
for (let [e, i] of Object.entries(this.option('on') || {})) | |
this.on(e, i); | |
} | |
option(t, ...e) { | |
let i = xe(t, this.options); | |
return i && typeof i == 'function' && (i = i.call(this, this, ...e)), i; | |
} | |
optionFor(t, e, i, ...n) { | |
let s = xe(e, t); | |
var a; | |
typeof (a = s) != 'string' || isNaN(a) || isNaN(parseFloat(a)) || (s = parseFloat(s)); | |
s === 'true' && (s = true); | |
s === 'false' && (s = false); | |
s && typeof s == 'function' && (s = s.call(this, this, t, ...n)); | |
let r = xe(e, this.options); | |
return r && typeof r == 'function' ? s = r.call(this, this, t, ...n, s) : s === void 0 && (s = r), s === void 0 ? i : s; | |
} | |
cn(t) { | |
let e = this.options.classes; | |
return e && e[t] || ''; | |
} | |
localize(t, e = []) { | |
t = String(t).replace(/\{\{(\w+).?(\w+)?\}\}/g, (i, n, s) => { | |
let a = ''; | |
return s ? a = this.option(`${ n[0] + n.toLowerCase().substring(1) }.l10n.${ s }`) : n && (a = this.option(`l10n.${ n }`)), a || (a = i), a; | |
}); | |
for (let i = 0; i < e.length; i++) { | |
t = t.split(e[i][0]).join(e[i][1]); | |
} | |
return t = t.replace(/\{\{(.*?)\}\}/g, (i, n) => n); | |
} | |
on(t, e) { | |
let i = []; | |
typeof t == 'string' ? i = t.split(' ') : Array.isArray(t) && (i = t); | |
this.events || (this.events = new Map()); | |
i.forEach(n => { | |
let s = this.events.get(n); | |
s || (this.events.set(n, []), s = []); | |
s.includes(e) || s.push(e); | |
this.events.set(n, s); | |
}); | |
} | |
off(t, e) { | |
let i = []; | |
typeof t == 'string' ? i = t.split(' ') : Array.isArray(t) && (i = t); | |
i.forEach(n => { | |
let s = this.events.get(n); | |
if (Array.isArray(s)) { | |
let a = s.indexOf(e); | |
a > -1 && s.splice(a, 1); | |
} | |
}); | |
} | |
emit(t, ...e) { | |
[...this.events.get(t) || []].forEach(i => i(this, ...e)); | |
t !== '*' && this.emit('*', t, ...e); | |
} | |
}; | |
Object.defineProperty(dt, 'version', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: '5.0.36' | |
}); | |
Object.defineProperty(dt, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: {} | |
}); | |
var Qt = class extends dt { | |
constructor(t = {}) { | |
super(t); | |
Object.defineProperty(this, 'plugins', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: {} | |
}); | |
} | |
attachPlugins(t = {}) { | |
let e = new Map(); | |
for (let [i, n] of Object.entries(t)) { | |
let s = this.option(i), a = this.plugins[i]; | |
a || s === false ? a && s === false && (a.detach(), delete this.plugins[i]) : e.set(i, new n(this, s || {})); | |
} | |
for (let [i, n] of e) | |
this.plugins[i] = n, n.attach(); | |
} | |
detachPlugins(t) { | |
t = t || Object.keys(this.plugins); | |
for (let e of t) { | |
let i = this.plugins[e]; | |
i && i.detach(); | |
delete this.plugins[e]; | |
} | |
return this.emit('detachPlugins'), this; | |
} | |
}, U; | |
(function (o) { | |
o[o.Init = 0] = 'Init'; | |
o[o.Error = 1] = 'Error'; | |
o[o.Ready = 2] = 'Ready'; | |
o[o.Panning = 3] = 'Panning'; | |
o[o.Mousemove = 4] = 'Mousemove'; | |
o[o.Destroy = 5] = 'Destroy'; | |
}(U || (U = {}))); | |
var j = [ | |
'a', | |
'b', | |
'c', | |
'd', | |
'e', | |
'f' | |
], jn = { | |
content: null, | |
width: 'auto', | |
height: 'auto', | |
panMode: 'drag', | |
touch: true, | |
dragMinThreshold: 3, | |
lockAxis: false, | |
mouseMoveFactor: 1, | |
mouseMoveFriction: 0.12, | |
zoom: true, | |
pinchToZoom: true, | |
panOnlyZoomed: 'auto', | |
minScale: 1, | |
maxScale: 2, | |
friction: 0.25, | |
dragFriction: 0.35, | |
decelFriction: 0.05, | |
click: 'toggleZoom', | |
dblClick: false, | |
wheel: 'zoom', | |
wheelLimit: 7, | |
spinner: true, | |
bounds: 'auto', | |
infinite: false, | |
rubberband: true, | |
bounce: true, | |
maxVelocity: 75, | |
transformParent: false, | |
classes: { | |
content: 'f-panzoom__content', | |
isLoading: 'is-loading', | |
canZoomIn: 'can-zoom_in', | |
canZoomOut: 'can-zoom_out', | |
isDraggable: 'is-draggable', | |
isDragging: 'is-dragging', | |
inFullscreen: 'in-fullscreen', | |
htmlHasFullscreen: 'with-panzoom-in-fullscreen' | |
}, | |
l10n: Xi | |
}, ze = '<div class="f-spinner"><svg viewBox="0 0 50 50"><circle cx="25" cy="25" r="20"></circle><circle cx="25" cy="25" r="20"></circle></svg></div>', C = o => o && o !== null && o instanceof Element && 'nodeType' in o, x = (o, t) => { | |
o && Se(t).forEach(e => { | |
o.classList.remove(e); | |
}); | |
}, y = (o, t) => { | |
o && Se(t).forEach(e => { | |
o.classList.add(e); | |
}); | |
}, Ue = null, Le = null, nt = class o extends Qt { | |
get fits() { | |
return this.contentRect.width - this.contentRect.fitWidth < 1 && this.contentRect.height - this.contentRect.fitHeight < 1; | |
} | |
get isTouchDevice() { | |
return Le === null && (Le = window.matchMedia('(hover: none)').matches), Le; | |
} | |
get isMobile() { | |
return Ue === null && (Ue = /iPhone|iPad|iPod|Android/i.test(navigator.userAgent)), Ue; | |
} | |
get panMode() { | |
return this.options.panMode !== 'mousemove' || this.isTouchDevice ? 'drag' : 'mousemove'; | |
} | |
get panOnlyZoomed() { | |
let t = this.options.panOnlyZoomed; | |
return t === 'auto' ? this.isTouchDevice : t; | |
} | |
get isInfinite() { | |
return this.option('infinite'); | |
} | |
get angle() { | |
return 180 * Math.atan2(this.current.b, this.current.a) / Math.PI || 0; | |
} | |
get targetAngle() { | |
return 180 * Math.atan2(this.target.b, this.target.a) / Math.PI || 0; | |
} | |
get scale() { | |
let { | |
a: t, | |
b: e | |
} = this.current; | |
return Math.sqrt(t * t + e * e) || 1; | |
} | |
get targetScale() { | |
let { | |
a: t, | |
b: e | |
} = this.target; | |
return Math.sqrt(t * t + e * e) || 1; | |
} | |
get minScale() { | |
return this.option('minScale') || 1; | |
} | |
get fullScale() { | |
let {contentRect: t} = this; | |
return t.fullWidth / t.fitWidth || 1; | |
} | |
get maxScale() { | |
return this.fullScale * (this.option('maxScale') || 1) || 1; | |
} | |
get coverScale() { | |
let { | |
containerRect: t, | |
contentRect: e | |
} = this, i = Math.max(t.height / e.fitHeight, t.width / e.fitWidth) || 1; | |
return Math.min(this.fullScale, i); | |
} | |
get isScaling() { | |
return Math.abs(this.targetScale - this.scale) > 0.00001 && !this.isResting; | |
} | |
get isContentLoading() { | |
let t = this.content; | |
return !!(t && t instanceof HTMLImageElement) && !t.complete; | |
} | |
get isResting() { | |
if (this.isBouncingX || this.isBouncingY) { | |
return false; | |
} | |
for (let t of j) { | |
let e = t == 'e' || t === 'f' ? 0.0001 : 0.00001; | |
if (Math.abs(this.target[t] - this.current[t]) > e) { | |
return false; | |
} | |
} | |
return !(!this.ignoreBounds && !this.checkBounds().inBounds); | |
} | |
constructor(t, e = {}, i = {}) { | |
var n; | |
if (super(e), Object.defineProperty(this, 'pointerTracker', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'resizeObserver', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'updateTimer', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'clickTimer', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'rAF', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'isTicking', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}), Object.defineProperty(this, 'ignoreBounds', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}), Object.defineProperty(this, 'isBouncingX', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}), Object.defineProperty(this, 'isBouncingY', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}), Object.defineProperty(this, 'clicks', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}), Object.defineProperty(this, 'trackingPoints', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: [] | |
}), Object.defineProperty(this, 'pwt', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}), Object.defineProperty(this, 'cwd', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}), Object.defineProperty(this, 'pmme', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}), Object.defineProperty(this, 'friction', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}), Object.defineProperty(this, 'state', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: U.Init | |
}), Object.defineProperty(this, 'isDragging', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}), Object.defineProperty(this, 'container', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}), Object.defineProperty(this, 'content', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}), Object.defineProperty(this, 'spinner', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'containerRect', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
width: 0, | |
height: 0, | |
innerWidth: 0, | |
innerHeight: 0 | |
} | |
}), Object.defineProperty(this, 'contentRect', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
top: 0, | |
right: 0, | |
bottom: 0, | |
left: 0, | |
fullWidth: 0, | |
fullHeight: 0, | |
fitWidth: 0, | |
fitHeight: 0, | |
width: 0, | |
height: 0 | |
} | |
}), Object.defineProperty(this, 'dragStart', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
x: 0, | |
y: 0, | |
top: 0, | |
left: 0, | |
time: 0 | |
} | |
}), Object.defineProperty(this, 'dragOffset', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
x: 0, | |
y: 0, | |
time: 0 | |
} | |
}), Object.defineProperty(this, 'current', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: Object.assign({}, Wt) | |
}), Object.defineProperty(this, 'target', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: Object.assign({}, Wt) | |
}), Object.defineProperty(this, 'velocity', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
a: 0, | |
b: 0, | |
c: 0, | |
d: 0, | |
e: 0, | |
f: 0 | |
} | |
}), Object.defineProperty(this, 'lockedAxis', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}), !t) { | |
throw new Error('Container Element Not Found'); | |
} | |
this.container = t; | |
this.initContent(); | |
this.attachPlugins(Object.assign(Object.assign({}, o.Plugins), i)); | |
this.emit('attachPlugins'); | |
this.emit('init'); | |
let s = this.content; | |
if (s.addEventListener('load', this.onLoad), s.addEventListener('error', this.onError), this.isContentLoading) { | |
if (this.option('spinner')) { | |
t.classList.add(this.cn('isLoading')); | |
let a = S(ze); | |
!t.contains(s) || s.parentElement instanceof HTMLPictureElement ? this.spinner = t.appendChild(a) : this.spinner = ((n = s.parentElement) === null || n === void 0 ? void 0 : n.insertBefore(a, s)) || null; | |
} | |
this.emit('beforeLoad'); | |
} else { | |
queueMicrotask(() => { | |
this.enable(); | |
}); | |
} | |
} | |
initContent() { | |
let {container: t} = this, e = this.cn('content'), i = this.option('content') || t.querySelector(`.${ e }`); | |
if (i || (i = t.querySelector('img,picture') || t.firstElementChild, i && y(i, e)), i instanceof HTMLPictureElement && (i = i.querySelector('img')), !i) { | |
throw new Error('No content found'); | |
} | |
this.content = i; | |
} | |
onLoad() { | |
let { | |
spinner: t, | |
container: e, | |
state: i | |
} = this; | |
t && (t.remove(), this.spinner = null); | |
this.option('spinner') && e.classList.remove(this.cn('isLoading')); | |
this.emit('afterLoad'); | |
i === U.Init ? this.enable() : this.updateMetrics(); | |
} | |
onError() { | |
this.state !== U.Destroy && (this.spinner && (this.spinner.remove(), this.spinner = null), this.stop(), this.detachEvents(), this.state = U.Error, this.emit('error')); | |
} | |
getNextScale(t) { | |
let { | |
fullScale: e, | |
targetScale: i, | |
coverScale: n, | |
maxScale: s, | |
minScale: a | |
} = this, r = a; | |
switch (t) { | |
case 'toggleMax': | |
r = i - a < 0.5 * (s - a) ? s : a; | |
break; | |
case 'toggleCover': | |
r = i - a < 0.5 * (n - a) ? n : a; | |
break; | |
case 'toggleZoom': | |
r = i - a < 0.5 * (e - a) ? e : a; | |
break; | |
case 'iterateZoom': | |
let l = [ | |
1, | |
e, | |
s | |
].sort((d, u) => d - u), c = l.findIndex(d => d > i + 0.00001); | |
r = l[c] || 1; | |
} | |
return r; | |
} | |
attachObserver() { | |
var t; | |
let e = () => { | |
let { | |
container: i, | |
containerRect: n | |
} = this; | |
return Math.abs(n.width - i.getBoundingClientRect().width) > 0.1 || Math.abs(n.height - i.getBoundingClientRect().height) > 0.1; | |
}; | |
this.resizeObserver || window.ResizeObserver === void 0 || (this.resizeObserver = new ResizeObserver(() => { | |
this.updateTimer || (e() ? (this.onResize(), this.isMobile && (this.updateTimer = setTimeout(() => { | |
e() && this.onResize(); | |
this.updateTimer = null; | |
}, 500))) : this.updateTimer && (clearTimeout(this.updateTimer), this.updateTimer = null)); | |
})); | |
(t = this.resizeObserver) === null || t === void 0 || t.observe(this.container); | |
} | |
detachObserver() { | |
var t; | |
(t = this.resizeObserver) === null || t === void 0 || t.disconnect(); | |
} | |
attachEvents() { | |
let {container: t} = this; | |
t.addEventListener('click', this.onClick, { | |
passive: false, | |
capture: false | |
}); | |
t.addEventListener('wheel', this.onWheel, { passive: false }); | |
this.pointerTracker = new Ge(t, { | |
start: this.onPointerDown, | |
move: this.onPointerMove, | |
end: this.onPointerUp | |
}); | |
document.addEventListener('mousemove', this.onMouseMove); | |
} | |
detachEvents() { | |
var t; | |
let {container: e} = this; | |
e.removeEventListener('click', this.onClick, { | |
passive: false, | |
capture: false | |
}); | |
e.removeEventListener('wheel', this.onWheel, { passive: false }); | |
(t = this.pointerTracker) === null || t === void 0 || t.stop(); | |
this.pointerTracker = null; | |
document.removeEventListener('mousemove', this.onMouseMove); | |
document.removeEventListener('keydown', this.onKeydown, true); | |
this.clickTimer && (clearTimeout(this.clickTimer), this.clickTimer = null); | |
this.updateTimer && (clearTimeout(this.updateTimer), this.updateTimer = null); | |
} | |
animate() { | |
this.setTargetForce(); | |
let t = this.friction, e = this.option('maxVelocity'); | |
for (let i of j) | |
t ? (this.velocity[i] *= 1 - t, e && !this.isScaling && (this.velocity[i] = Math.max(Math.min(this.velocity[i], e), -1 * e)), this.current[i] += this.velocity[i]) : this.current[i] = this.target[i]; | |
this.setTransform(); | |
this.setEdgeForce(); | |
!this.isResting || this.isDragging ? this.rAF = requestAnimationFrame(() => this.animate()) : this.stop('current'); | |
} | |
setTargetForce() { | |
for (let t of j) | |
t === 'e' && this.isBouncingX || t === 'f' && this.isBouncingY || (this.velocity[t] = (1 / (1 - this.friction) - 1) * (this.target[t] - this.current[t])); | |
} | |
checkBounds(t = 0, e = 0) { | |
let {current: i} = this, n = i.e + t, s = i.f + e, a = this.getBounds(), { | |
x: r, | |
y: l | |
} = a, c = r.min, d = r.max, u = l.min, m = l.max, h = 0, b = 0; | |
return c !== 1e+400 && n < c ? h = c - n : d !== 1e+400 && n > d && (h = d - n), u !== 1e+400 && s < u ? b = u - s : m !== 1e+400 && s > m && (b = m - s), Math.abs(h) < 0.0001 && (h = 0), Math.abs(b) < 0.0001 && (b = 0), Object.assign(Object.assign({}, a), { | |
xDiff: h, | |
yDiff: b, | |
inBounds: !h && !b | |
}); | |
} | |
clampTargetBounds() { | |
let {target: t} = this, { | |
x: e, | |
y: i | |
} = this.getBounds(); | |
e.min !== 1e+400 && (t.e = Math.max(t.e, e.min)); | |
e.max !== 1e+400 && (t.e = Math.min(t.e, e.max)); | |
i.min !== 1e+400 && (t.f = Math.max(t.f, i.min)); | |
i.max !== 1e+400 && (t.f = Math.min(t.f, i.max)); | |
} | |
calculateContentDim(t = this.current) { | |
let { | |
content: e, | |
contentRect: i | |
} = this, { | |
fitWidth: n, | |
fitHeight: s, | |
fullWidth: a, | |
fullHeight: r | |
} = i, l = a, c = r; | |
if (this.option('zoom') || this.angle !== 0) { | |
let d = !(e instanceof HTMLImageElement) && (window.getComputedStyle(e).maxWidth === 'none' || window.getComputedStyle(e).maxHeight === 'none'), u = d ? a : n, m = d ? r : s, h = this.getMatrix(t), b = new DOMPoint(0, 0).matrixTransform(h), p = new DOMPoint(0 + u, 0).matrixTransform(h), f = new DOMPoint(0 + u, 0 + m).matrixTransform(h), g = new DOMPoint(0, 0 + m).matrixTransform(h), F = Math.abs(f.x - b.x), v = Math.abs(f.y - b.y), B = Math.abs(g.x - p.x), k = Math.abs(g.y - p.y); | |
l = Math.max(F, B); | |
c = Math.max(v, k); | |
} | |
return { | |
contentWidth: l, | |
contentHeight: c | |
}; | |
} | |
setEdgeForce() { | |
if (this.ignoreBounds || this.isDragging || this.panMode === 'mousemove' || this.targetScale < this.scale) { | |
return this.isBouncingX = false, void (this.isBouncingY = false); | |
} | |
let {target: t} = this, { | |
x: e, | |
y: i, | |
xDiff: n, | |
yDiff: s | |
} = this.checkBounds(), a = this.option('maxVelocity'), r = this.velocity.e, l = this.velocity.f; | |
n !== 0 ? (this.isBouncingX = true, n * r <= 0 ? r += 0.14 * n : (r = 0.14 * n, e.min !== 1e+400 && (this.target.e = Math.max(t.e, e.min)), e.max !== 1e+400 && (this.target.e = Math.min(t.e, e.max))), a && (r = Math.max(Math.min(r, a), -1 * a))) : this.isBouncingX = false; | |
s !== 0 ? (this.isBouncingY = true, s * l <= 0 ? l += 0.14 * s : (l = 0.14 * s, i.min !== 1e+400 && (this.target.f = Math.max(t.f, i.min)), i.max !== 1e+400 && (this.target.f = Math.min(t.f, i.max))), a && (l = Math.max(Math.min(l, a), -1 * a))) : this.isBouncingY = false; | |
this.isBouncingX && (this.velocity.e = r); | |
this.isBouncingY && (this.velocity.f = l); | |
} | |
enable() { | |
let {content: t} = this, e = new DOMMatrixReadOnly(window.getComputedStyle(t).transform); | |
for (let i of j) | |
this.current[i] = this.target[i] = e[i]; | |
this.updateMetrics(); | |
this.attachObserver(); | |
this.attachEvents(); | |
this.state = U.Ready; | |
this.emit('ready'); | |
} | |
onClick(t) { | |
var e; | |
t.type === 'click' && t.detail === 0 && (this.dragOffset.x = 0, this.dragOffset.y = 0); | |
this.isDragging && ((e = this.pointerTracker) === null || e === void 0 || e.clear(), this.trackingPoints = [], this.startDecelAnim()); | |
let i = t.target; | |
if (!i || t.defaultPrevented) { | |
return; | |
} | |
if (i.hasAttribute('disabled')) { | |
return t.preventDefault(), void t.stopPropagation(); | |
} | |
if ((() => { | |
let h = window.getSelection(); | |
return h && h.type === 'Range'; | |
})() && !i.closest('button')) { | |
return; | |
} | |
let n = i.closest('[data-panzoom-action]'), s = i.closest('[data-panzoom-change]'), a = n || s, r = a && C(a) ? a.dataset : null; | |
if (r) { | |
let h = r.panzoomChange, b = r.panzoomAction; | |
if ((h || b) && t.preventDefault(), h) { | |
let p = {}; | |
try { | |
p = JSON.parse(h); | |
} catch { | |
console && console.warn('The given data was not valid JSON'); | |
} | |
return void this.applyChange(p); | |
} | |
if (b) { | |
return void (this[b] && this[b]()); | |
} | |
} | |
if (Math.abs(this.dragOffset.x) > 3 || Math.abs(this.dragOffset.y) > 3) { | |
return t.preventDefault(), void t.stopPropagation(); | |
} | |
if (i.closest('[data-fancybox]')) { | |
return; | |
} | |
let l = this.content.getBoundingClientRect(), c = this.dragStart; | |
if (c.time && !this.canZoomOut() && (Math.abs(l.x - c.x) > 2 || Math.abs(l.y - c.y) > 2)) { | |
return; | |
} | |
this.dragStart.time = 0; | |
let d = h => { | |
this.option('zoom', t) && h && typeof h == 'string' && /(iterateZoom)|(toggle(Zoom|Full|Cover|Max)|(zoomTo(Fit|Cover|Max)))/.test(h) && typeof this[h] == 'function' && (t.preventDefault(), this[h]({ event: t })); | |
}, u = this.option('click', t), m = this.option('dblClick', t); | |
m ? (this.clicks++, this.clicks == 1 && (this.clickTimer = setTimeout(() => { | |
this.clicks === 1 ? (this.emit('click', t), !t.defaultPrevented && u && d(u)) : (this.emit('dblClick', t), t.defaultPrevented || d(m)); | |
this.clicks = 0; | |
this.clickTimer = null; | |
}, 350))) : (this.emit('click', t), !t.defaultPrevented && u && d(u)); | |
} | |
addTrackingPoint(t) { | |
let e = this.trackingPoints.filter(i => i.time > Date.now() - 100); | |
e.push(t); | |
this.trackingPoints = e; | |
} | |
onPointerDown(t, e, i) { | |
var n; | |
if (this.option('touch', t) === false) { | |
return false; | |
} | |
this.pwt = 0; | |
this.dragOffset = { | |
x: 0, | |
y: 0, | |
time: 0 | |
}; | |
this.trackingPoints = []; | |
let s = this.content.getBoundingClientRect(); | |
if (this.dragStart = { | |
x: s.x, | |
y: s.y, | |
top: s.top, | |
left: s.left, | |
time: Date.now() | |
}, this.clickTimer) { | |
return false; | |
} | |
if (this.panMode === 'mousemove' && this.targetScale > 1) { | |
return t.preventDefault(), t.stopPropagation(), false; | |
} | |
let a = t.composedPath()[0]; | |
if (!i.length) { | |
if ([ | |
'TEXTAREA', | |
'OPTION', | |
'INPUT', | |
'SELECT', | |
'VIDEO', | |
'IFRAME' | |
].includes(a.nodeName) || a.closest('[contenteditable],[data-selectable],[data-draggable],[data-clickable],[data-panzoom-change],[data-panzoom-action]')) { | |
return false; | |
} | |
(n = window.getSelection()) === null || n === void 0 || n.removeAllRanges(); | |
} | |
if (t.type === 'mousedown') { | |
[ | |
'A', | |
'BUTTON' | |
].includes(a.nodeName) || t.preventDefault(); | |
} else { | |
if (Math.abs(this.velocity.a) > 0.3) { | |
return false; | |
} | |
} | |
return this.target.e = this.current.e, this.target.f = this.current.f, this.stop(), this.isDragging || (this.isDragging = true, this.addTrackingPoint(e), this.emit('touchStart', t)), true; | |
} | |
onPointerMove(t, e, i) { | |
if (this.option('touch', t) === false || !this.isDragging || e.length < 2 && this.panOnlyZoomed && Q(this.targetScale) <= Q(this.minScale) || (this.emit('touchMove', t), t.defaultPrevented)) { | |
return; | |
} | |
this.addTrackingPoint(e[0]); | |
let {content: n} = this, s = hi(i[0], i[1]), a = hi(e[0], e[1]), r = 0, l = 0; | |
if (e.length > 1) { | |
let v = n.getBoundingClientRect(); | |
r = s.clientX - v.left - 0.5 * v.width; | |
l = s.clientY - v.top - 0.5 * v.height; | |
} | |
let c = di(i[0], i[1]), d = di(e[0], e[1]), u = c ? d / c : 1, m = a.clientX - s.clientX, h = a.clientY - s.clientY; | |
this.dragOffset.x += m; | |
this.dragOffset.y += h; | |
this.dragOffset.time = Date.now() - this.dragStart.time; | |
let b = Q(this.targetScale) === Q(this.minScale) && this.option('lockAxis'); | |
if (b && !this.lockedAxis) { | |
if (b === 'xy' || b === 'y' || t.type === 'touchmove') { | |
if (Math.abs(this.dragOffset.x) < 6 && Math.abs(this.dragOffset.y) < 6) { | |
return void t.preventDefault(); | |
} | |
let v = Math.abs(180 * Math.atan2(this.dragOffset.y, this.dragOffset.x) / Math.PI); | |
this.lockedAxis = v > 45 && v < 135 ? 'y' : 'x'; | |
this.dragOffset.x = 0; | |
this.dragOffset.y = 0; | |
m = 0; | |
h = 0; | |
} else { | |
this.lockedAxis = b; | |
} | |
} | |
if (Gt(t.target, this.content) && (b = 'x', this.dragOffset.y = 0), b && b !== 'xy' && this.lockedAxis !== b && Q(this.targetScale) === Q(this.minScale)) { | |
return; | |
} | |
t.cancelable && t.preventDefault(); | |
this.container.classList.add(this.cn('isDragging')); | |
let p = this.checkBounds(m, h); | |
this.option('rubberband') ? (this.isInfinite !== 'x' && (p.xDiff > 0 && m < 0 || p.xDiff < 0 && m > 0) && (m *= Math.max(0, 0.5 - Math.abs(0.75 / this.contentRect.fitWidth * p.xDiff))), this.isInfinite !== 'y' && (p.yDiff > 0 && h < 0 || p.yDiff < 0 && h > 0) && (h *= Math.max(0, 0.5 - Math.abs(0.75 / this.contentRect.fitHeight * p.yDiff)))) : (p.xDiff && (m = 0), p.yDiff && (h = 0)); | |
let f = this.targetScale, g = this.minScale, F = this.maxScale; | |
f < 0.5 * g && (u = Math.max(u, g)); | |
f > 1.5 * F && (u = Math.min(u, F)); | |
this.lockedAxis === 'y' && Q(f) === Q(g) && (m = 0); | |
this.lockedAxis === 'x' && Q(f) === Q(g) && (h = 0); | |
this.applyChange({ | |
originX: r, | |
originY: l, | |
panX: m, | |
panY: h, | |
scale: u, | |
friction: this.option('dragFriction'), | |
ignoreBounds: true | |
}); | |
} | |
onPointerUp(t, e, i) { | |
if (i.length) { | |
return this.dragOffset.x = 0, this.dragOffset.y = 0, void (this.trackingPoints = []); | |
} | |
this.container.classList.remove(this.cn('isDragging')); | |
this.isDragging && (this.addTrackingPoint(e), this.panOnlyZoomed && this.contentRect.width - this.contentRect.fitWidth < 1 && this.contentRect.height - this.contentRect.fitHeight < 1 && (this.trackingPoints = []), Gt(t.target, this.content) && this.lockedAxis === 'y' && (this.trackingPoints = []), this.emit('touchEnd', t), this.isDragging = false, this.lockedAxis = false, this.state !== U.Destroy && (t.defaultPrevented || this.startDecelAnim())); | |
} | |
startDecelAnim() { | |
var t; | |
let e = this.isScaling; | |
this.rAF && (cancelAnimationFrame(this.rAF), this.rAF = null); | |
this.isBouncingX = false; | |
this.isBouncingY = false; | |
for (let v of j) | |
this.velocity[v] = 0; | |
this.target.e = this.current.e; | |
this.target.f = this.current.f; | |
x(this.container, 'is-scaling'); | |
x(this.container, 'is-animating'); | |
this.isTicking = false; | |
let {trackingPoints: i} = this, n = i[0], s = i[i.length - 1], a = 0, r = 0, l = 0; | |
s && n && (a = s.clientX - n.clientX, r = s.clientY - n.clientY, l = s.time - n.time); | |
let c = ((t = window.visualViewport) === null || t === void 0 ? void 0 : t.scale) || 1; | |
c !== 1 && (a *= c, r *= c); | |
let d = 0, u = 0, m = 0, h = 0, b = this.option('decelFriction'), p = this.targetScale; | |
if (l > 0) { | |
m = Math.abs(a) > 3 ? a / (l / 30) : 0; | |
h = Math.abs(r) > 3 ? r / (l / 30) : 0; | |
let v = this.option('maxVelocity'); | |
v && (m = Math.max(Math.min(m, v), -1 * v), h = Math.max(Math.min(h, v), -1 * v)); | |
} | |
m && (d = m / (1 / (1 - b) - 1)); | |
h && (u = h / (1 / (1 - b) - 1)); | |
(this.option('lockAxis') === 'y' || this.option('lockAxis') === 'xy' && this.lockedAxis === 'y' && Q(p) === this.minScale) && (d = m = 0); | |
(this.option('lockAxis') === 'x' || this.option('lockAxis') === 'xy' && this.lockedAxis === 'x' && Q(p) === this.minScale) && (u = h = 0); | |
let f = this.dragOffset.x, g = this.dragOffset.y, F = this.option('dragMinThreshold') || 0; | |
Math.abs(f) < F && Math.abs(g) < F && (d = u = 0, m = h = 0); | |
(this.option('zoom') && (p < this.minScale - 0.00001 || p > this.maxScale + 0.00001) || e && !d && !u) && (b = 0.35); | |
this.applyChange({ | |
panX: d, | |
panY: u, | |
friction: b | |
}); | |
this.emit('decel', m, h, f, g); | |
} | |
onWheel(t) { | |
var e = [ | |
-t.deltaX || 0, | |
-t.deltaY || 0, | |
-t.detail || 0 | |
].reduce(function (s, a) { | |
return Math.abs(a) > Math.abs(s) ? a : s; | |
}); | |
let i = Math.max(-1, Math.min(1, e)); | |
if (this.emit('wheel', t, i), this.panMode === 'mousemove' || t.defaultPrevented) { | |
return; | |
} | |
let n = this.option('wheel'); | |
n === 'pan' ? (t.preventDefault(), this.panOnlyZoomed && !this.canZoomOut() || this.applyChange({ | |
panX: 2 * -t.deltaX, | |
panY: 2 * -t.deltaY, | |
bounce: false | |
})) : n === 'zoom' && this.option('zoom') !== false && this.zoomWithWheel(t); | |
} | |
onMouseMove(t) { | |
this.panWithMouse(t); | |
} | |
onKeydown(t) { | |
t.key === 'Escape' && this.toggleFS(); | |
} | |
onResize() { | |
this.updateMetrics(); | |
this.checkBounds().inBounds || this.requestTick(); | |
} | |
setTransform() { | |
this.emit('beforeTransform'); | |
let { | |
current: t, | |
target: e, | |
content: i, | |
contentRect: n | |
} = this, s = Object.assign({}, Wt); | |
for (let f of j) { | |
let g = f == 'e' || f === 'f' ? 10000 : 100000; | |
s[f] = Q(t[f], g); | |
Math.abs(e[f] - t[f]) < (f == 'e' || f === 'f' ? 0.51 : 0.001) && (t[f] = e[f]); | |
} | |
let { | |
a, | |
b: r, | |
c: l, | |
d: c, | |
e: d, | |
f: u | |
} = s, m = `matrix(${ a }, ${ r }, ${ l }, ${ c }, ${ d }, ${ u })`, h = i.parentElement instanceof HTMLPictureElement ? i.parentElement : i; | |
if (this.option('transformParent') && (h = h.parentElement || h), h.style.transform === m) { | |
return; | |
} | |
h.style.transform = m; | |
let { | |
contentWidth: b, | |
contentHeight: p | |
} = this.calculateContentDim(); | |
n.width = b; | |
n.height = p; | |
this.emit('afterTransform'); | |
} | |
updateMetrics(t = false) { | |
var e; | |
if (!this || this.state === U.Destroy || this.isContentLoading) { | |
return; | |
} | |
let i = Math.max(1, ((e = window.visualViewport) === null || e === void 0 ? void 0 : e.scale) || 1), { | |
container: n, | |
content: s | |
} = this, a = s instanceof HTMLImageElement, r = n.getBoundingClientRect(), l = getComputedStyle(this.container), c = r.width * i, d = r.height * i, u = parseFloat(l.paddingTop) + parseFloat(l.paddingBottom), m = c - (parseFloat(l.paddingLeft) + parseFloat(l.paddingRight)), h = d - u; | |
this.containerRect = { | |
width: c, | |
height: d, | |
innerWidth: m, | |
innerHeight: h | |
}; | |
let b = parseFloat(s.dataset.width || '') || (W => { | |
let P = 0; | |
return P = W instanceof HTMLImageElement ? W.naturalWidth : W instanceof SVGElement ? W.width.baseVal.value : Math.max(W.offsetWidth, W.scrollWidth), P || 0; | |
})(s), p = parseFloat(s.dataset.height || '') || (W => { | |
let P = 0; | |
return P = W instanceof HTMLImageElement ? W.naturalHeight : W instanceof SVGElement ? W.height.baseVal.value : Math.max(W.offsetHeight, W.scrollHeight), P || 0; | |
})(s), f = this.option('width', b) || 'auto', g = this.option('height', p) || 'auto', F = f === 'auto', v = g === 'auto'; | |
typeof f != 'number' && (f = b); | |
typeof g != 'number' && (g = p); | |
F && (f = b * (g / p)); | |
v && (g = p / (b / f)); | |
let B = s.parentElement instanceof HTMLPictureElement ? s.parentElement : s; | |
this.option('transformParent') && (B = B.parentElement || B); | |
let k = B.getAttribute('style') || ''; | |
B.style.setProperty('transform', 'none', 'important'); | |
a && (B.style.width = '', B.style.height = ''); | |
B.offsetHeight; | |
let X = s.getBoundingClientRect(), L = X.width * i, G = X.height * i, Pi = L, _i = G; | |
L = Math.min(L, f); | |
G = Math.min(G, g); | |
a ? { | |
width: L, | |
height: G | |
} = ((W, P, Ki, qi) => { | |
let $i = Ki / W, tn = qi / P, He = Math.min($i, tn); | |
return { | |
width: W *= He, | |
height: P *= He | |
}; | |
})(f, g, L, G) : (L = Math.min(L, f), G = Math.min(G, g)); | |
let je = 0.5 * (_i - G), Je = 0.5 * (Pi - L); | |
this.contentRect = Object.assign(Object.assign({}, this.contentRect), { | |
top: X.top - r.top + je, | |
bottom: r.bottom - X.bottom + je, | |
left: X.left - r.left + Je, | |
right: r.right - X.right + Je, | |
fitWidth: L, | |
fitHeight: G, | |
width: L, | |
height: G, | |
fullWidth: f, | |
fullHeight: g | |
}); | |
B.style.cssText = k; | |
a && (B.style.width = `${ L }px`, B.style.height = `${ G }px`); | |
this.setTransform(); | |
t !== true && this.emit('refresh'); | |
this.ignoreBounds || (Q(this.targetScale) < Q(this.minScale) ? this.zoomTo(this.minScale, { friction: 0 }) : this.targetScale > this.maxScale ? this.zoomTo(this.maxScale, { friction: 0 }) : this.state === U.Init || this.checkBounds().inBounds || this.requestTick()); | |
this.updateControls(); | |
} | |
calculateBounds() { | |
let { | |
contentWidth: t, | |
contentHeight: e | |
} = this.calculateContentDim(this.target), { | |
targetScale: i, | |
lockedAxis: n | |
} = this, { | |
fitWidth: s, | |
fitHeight: a | |
} = this.contentRect, r = 0, l = 0, c = 0, d = 0, u = this.option('infinite'); | |
if (u === true || n && u === n) { | |
r = null; | |
c = null; | |
l = null; | |
d = null; | |
} else { | |
let { | |
containerRect: m, | |
contentRect: h | |
} = this, b = Q(s * i, 10000), p = Q(a * i, 10000), { | |
innerWidth: f, | |
innerHeight: g | |
} = m; | |
if (m.width === b && (f = m.width), m.width === p && (g = m.height), t > f) { | |
c = 0.5 * (t - f); | |
r = -1 * c; | |
let F = 0.5 * (h.right - h.left); | |
r += F; | |
c += F; | |
} | |
if (s > f && t < f && (r -= 0.5 * (s - f), c -= 0.5 * (s - f)), e > g) { | |
d = 0.5 * (e - g); | |
l = -1 * d; | |
let F = 0.5 * (h.bottom - h.top); | |
l += F; | |
d += F; | |
} | |
a > g && e < g && (r -= 0.5 * (a - g), c -= 0.5 * (a - g)); | |
} | |
return { | |
x: { | |
min: r, | |
max: c | |
}, | |
y: { | |
min: l, | |
max: d | |
} | |
}; | |
} | |
getBounds() { | |
let t = this.option('bounds'); | |
return t !== 'auto' ? t : this.calculateBounds(); | |
} | |
updateControls() { | |
let t = this, e = t.container, { | |
panMode: i, | |
contentRect: n, | |
targetScale: s, | |
minScale: a | |
} = t, r = a, l = t.option('click') || false; | |
l && (r = t.getNextScale(l)); | |
let c = t.canZoomIn(), d = t.canZoomOut(), u = i === 'drag' && !!this.option('touch'), m = d && u; | |
if (u && (Q(s) < Q(a) && !this.panOnlyZoomed && (m = true), (Q(n.width, 1) > Q(n.fitWidth, 1) || Q(n.height, 1) > Q(n.fitHeight, 1)) && (m = true)), Q(n.width * s, 1) < Q(n.fitWidth, 1) && (m = false), i === 'mousemove' && (m = false), z(e, this.cn('isDraggable'), m), !this.option('zoom')) { | |
return; | |
} | |
let h = c && Q(r) > Q(s), b = !h && !m && d && Q(r) < Q(s); | |
z(e, this.cn('canZoomIn'), h); | |
z(e, this.cn('canZoomOut'), b); | |
for (let p of e.querySelectorAll('[data-panzoom-action]')) { | |
let f = false, g = false; | |
switch (p.dataset.panzoomAction) { | |
case 'zoomIn': | |
c ? f = true : g = true; | |
break; | |
case 'zoomOut': | |
d ? f = true : g = true; | |
break; | |
case 'toggleZoom': | |
case 'iterateZoom': | |
c || d ? f = true : g = true; | |
let F = p.querySelector('g'); | |
F && (F.style.display = c ? '' : 'none'); | |
} | |
f ? (p.removeAttribute('disabled'), p.removeAttribute('tabindex')) : g && (p.setAttribute('disabled', ''), p.setAttribute('tabindex', '-1')); | |
} | |
} | |
panTo({ | |
x: t = this.target.e, | |
y: e = this.target.f, | |
scale: i = this.targetScale, | |
friction: n = this.option('friction'), | |
angle: s = 0, | |
originX: a = 0, | |
originY: r = 0, | |
flipX: l = false, | |
flipY: c = false, | |
ignoreBounds: d = false | |
}) { | |
this.state !== U.Destroy && this.applyChange({ | |
panX: t - this.target.e, | |
panY: e - this.target.f, | |
scale: i / this.targetScale, | |
angle: s, | |
originX: a, | |
originY: r, | |
friction: n, | |
flipX: l, | |
flipY: c, | |
ignoreBounds: d | |
}); | |
} | |
applyChange({ | |
panX: t = 0, | |
panY: e = 0, | |
scale: i = 1, | |
angle: n = 0, | |
originX: s = -this.current.e, | |
originY: a = -this.current.f, | |
friction: r = this.option('friction'), | |
flipX: l = false, | |
flipY: c = false, | |
ignoreBounds: d = false, | |
bounce: u = this.option('bounce') | |
}) { | |
let m = this.state; | |
if (m === U.Destroy) { | |
return; | |
} | |
this.rAF && (cancelAnimationFrame(this.rAF), this.rAF = null); | |
this.friction = r || 0; | |
this.ignoreBounds = d; | |
let {current: h} = this, b = h.e, p = h.f, f = this.getMatrix(this.target), g = new DOMMatrix().translate(b, p).translate(s, a).translate(t, e); | |
if (this.option('zoom')) { | |
if (!d) { | |
let F = this.targetScale, v = this.minScale, B = this.maxScale; | |
F * i < v && (i = v / F); | |
F * i > B && (i = B / F); | |
} | |
g = g.scale(i); | |
} | |
g = g.translate(-s, -a).translate(-b, -p).multiply(f); | |
n && (g = g.rotate(n)); | |
l && (g = g.scale(-1, 1)); | |
c && (g = g.scale(1, -1)); | |
for (let F of j) | |
F !== 'e' && F !== 'f' && (g[F] > this.minScale + 0.00001 || g[F] < this.minScale - 0.00001) ? this.target[F] = g[F] : this.target[F] = Q(g[F], 10000); | |
(this.targetScale < this.scale || Math.abs(i - 1) > 0.1 || this.panMode === 'mousemove' || u === false) && !d && this.clampTargetBounds(); | |
m === U.Init ? this.animate() : this.isResting || (this.state = U.Panning, this.requestTick()); | |
} | |
stop(t = false) { | |
if (this.state === U.Init || this.state === U.Destroy) { | |
return; | |
} | |
let e = this.isTicking; | |
this.rAF && (cancelAnimationFrame(this.rAF), this.rAF = null); | |
this.isBouncingX = false; | |
this.isBouncingY = false; | |
for (let i of j) | |
this.velocity[i] = 0, t === 'current' ? this.current[i] = this.target[i] : t === 'target' && (this.target[i] = this.current[i]); | |
this.setTransform(); | |
x(this.container, 'is-scaling'); | |
x(this.container, 'is-animating'); | |
this.isTicking = false; | |
this.state = U.Ready; | |
e && (this.emit('endAnimation'), this.updateControls()); | |
} | |
requestTick() { | |
this.isTicking || (this.emit('startAnimation'), this.updateControls(), y(this.container, 'is-animating'), this.isScaling && y(this.container, 'is-scaling')); | |
this.isTicking = true; | |
this.rAF || (this.rAF = requestAnimationFrame(() => this.animate())); | |
} | |
panWithMouse(t, e = this.option('mouseMoveFriction')) { | |
if (this.pmme = t, this.panMode !== 'mousemove' || !t || Q(this.targetScale) <= Q(this.minScale)) { | |
return; | |
} | |
this.emit('mouseMove', t); | |
let { | |
container: i, | |
containerRect: n, | |
contentRect: s | |
} = this, a = n.width, r = n.height, l = i.getBoundingClientRect(), c = (t.clientX || 0) - l.left, d = (t.clientY || 0) - l.top, { | |
contentWidth: u, | |
contentHeight: m | |
} = this.calculateContentDim(this.target), h = this.option('mouseMoveFactor'); | |
h > 1 && (u !== a && (u *= h), m !== r && (m *= h)); | |
let b = 0.5 * (u - a) - c / a * 100 / 100 * (u - a); | |
b += 0.5 * (s.right - s.left); | |
let p = 0.5 * (m - r) - d / r * 100 / 100 * (m - r); | |
p += 0.5 * (s.bottom - s.top); | |
this.applyChange({ | |
panX: b - this.target.e, | |
panY: p - this.target.f, | |
friction: e | |
}); | |
} | |
zoomWithWheel(t) { | |
if (this.state === U.Destroy || this.state === U.Init) { | |
return; | |
} | |
let e = Date.now(); | |
if (e - this.pwt < 45) { | |
return void t.preventDefault(); | |
} | |
this.pwt = e; | |
var i = [ | |
-t.deltaX || 0, | |
-t.deltaY || 0, | |
-t.detail || 0 | |
].reduce(function (c, d) { | |
return Math.abs(d) > Math.abs(c) ? d : c; | |
}); | |
let n = Math.max(-1, Math.min(1, i)), { | |
targetScale: s, | |
maxScale: a, | |
minScale: r | |
} = this, l = s * (100 + 45 * n) / 100; | |
Q(l) < Q(r) && Q(s) <= Q(r) ? (this.cwd += Math.abs(n), l = r) : Q(l) > Q(a) && Q(s) >= Q(a) ? (this.cwd += Math.abs(n), l = a) : (this.cwd = 0, l = Math.max(Math.min(l, a), r)); | |
this.cwd > this.option('wheelLimit') || (t.preventDefault(), Q(l) !== Q(s) && this.zoomTo(l, { event: t })); | |
} | |
canZoomIn() { | |
return this.option('zoom') && (Q(this.contentRect.width, 1) < Q(this.contentRect.fitWidth, 1) || Q(this.targetScale) < Q(this.maxScale)); | |
} | |
canZoomOut() { | |
return this.option('zoom') && Q(this.targetScale) > Q(this.minScale); | |
} | |
zoomIn(t = 1.25, e) { | |
this.zoomTo(this.targetScale * t, e); | |
} | |
zoomOut(t = 0.8, e) { | |
this.zoomTo(this.targetScale * t, e); | |
} | |
zoomToFit(t) { | |
this.zoomTo('fit', t); | |
} | |
zoomToCover(t) { | |
this.zoomTo('cover', t); | |
} | |
zoomToFull(t) { | |
this.zoomTo('full', t); | |
} | |
zoomToMax(t) { | |
this.zoomTo('max', t); | |
} | |
toggleZoom(t) { | |
this.zoomTo(this.getNextScale('toggleZoom'), t); | |
} | |
toggleMax(t) { | |
this.zoomTo(this.getNextScale('toggleMax'), t); | |
} | |
toggleCover(t) { | |
this.zoomTo(this.getNextScale('toggleCover'), t); | |
} | |
iterateZoom(t) { | |
this.zoomTo('next', t); | |
} | |
zoomTo(t = 1, { | |
friction: e = 'auto', | |
originX: i = 'auto', | |
originY: n = 'auto', | |
event: s | |
} = {}) { | |
if (this.isContentLoading || this.state === U.Destroy) { | |
return; | |
} | |
let { | |
targetScale: a, | |
fullScale: r, | |
maxScale: l, | |
coverScale: c | |
} = this; | |
if (this.stop(), this.panMode === 'mousemove' && (s = this.pmme || s), s || i === 'auto' || n === 'auto') { | |
let u = this.content.getBoundingClientRect(), m = this.container.getBoundingClientRect(), h = s ? s.clientX : m.left + 0.5 * m.width, b = s ? s.clientY : m.top + 0.5 * m.height; | |
i = h - u.left - 0.5 * u.width; | |
n = b - u.top - 0.5 * u.height; | |
} | |
let d = 1; | |
typeof t == 'number' ? d = t : t === 'full' ? d = r : t === 'cover' ? d = c : t === 'max' ? d = l : t === 'fit' ? d = 1 : t === 'next' && (d = this.getNextScale('iterateZoom')); | |
d = d / a || 1; | |
e = e === 'auto' ? d > 1 ? 0.15 : 0.25 : e; | |
this.applyChange({ | |
scale: d, | |
originX: i, | |
originY: n, | |
friction: e | |
}); | |
s && this.panMode === 'mousemove' && this.panWithMouse(s, e); | |
} | |
rotateCCW() { | |
this.applyChange({ angle: -90 }); | |
} | |
rotateCW() { | |
this.applyChange({ angle: 90 }); | |
} | |
flipX() { | |
this.applyChange({ flipX: true }); | |
} | |
flipY() { | |
this.applyChange({ flipY: true }); | |
} | |
fitX() { | |
this.stop('target'); | |
let { | |
containerRect: t, | |
contentRect: e, | |
target: i | |
} = this; | |
this.applyChange({ | |
panX: 0.5 * t.width - (e.left + 0.5 * e.fitWidth) - i.e, | |
panY: 0.5 * t.height - (e.top + 0.5 * e.fitHeight) - i.f, | |
scale: t.width / e.fitWidth / this.targetScale, | |
originX: 0, | |
originY: 0, | |
ignoreBounds: true | |
}); | |
} | |
fitY() { | |
this.stop('target'); | |
let { | |
containerRect: t, | |
contentRect: e, | |
target: i | |
} = this; | |
this.applyChange({ | |
panX: 0.5 * t.width - (e.left + 0.5 * e.fitWidth) - i.e, | |
panY: 0.5 * t.innerHeight - (e.top + 0.5 * e.fitHeight) - i.f, | |
scale: t.height / e.fitHeight / this.targetScale, | |
originX: 0, | |
originY: 0, | |
ignoreBounds: true | |
}); | |
} | |
toggleFS() { | |
let {container: t} = this, e = this.cn('inFullscreen'), i = this.cn('htmlHasFullscreen'); | |
t.classList.toggle(e); | |
let n = t.classList.contains(e); | |
n ? (document.documentElement.classList.add(i), document.addEventListener('keydown', this.onKeydown, true)) : (document.documentElement.classList.remove(i), document.removeEventListener('keydown', this.onKeydown, true)); | |
this.updateMetrics(); | |
this.emit(n ? 'enterFS' : 'exitFS'); | |
} | |
getMatrix(t = this.current) { | |
let { | |
a: e, | |
b: i, | |
c: n, | |
d: s, | |
e: a, | |
f: r | |
} = t; | |
return new DOMMatrix([ | |
e, | |
i, | |
n, | |
s, | |
a, | |
r | |
]); | |
} | |
reset(t) { | |
if (this.state !== U.Init && this.state !== U.Destroy) { | |
this.stop('current'); | |
for (let e of j) | |
this.target[e] = 0; | |
this.target.a = this.minScale; | |
this.target.d = this.minScale; | |
this.clampTargetBounds(); | |
this.isResting || (this.friction = t === void 0 ? this.option('friction') : t, this.state = U.Panning, this.requestTick()); | |
} | |
} | |
destroy() { | |
this.stop(); | |
this.state = U.Destroy; | |
this.detachEvents(); | |
this.detachObserver(); | |
let { | |
container: t, | |
content: e | |
} = this, i = this.option('classes') || {}; | |
for (let n of Object.values(i)) | |
t.classList.remove(n + ''); | |
e && (e.removeEventListener('load', this.onLoad), e.removeEventListener('error', this.onError)); | |
this.detachPlugins(); | |
} | |
}; | |
Object.defineProperty(nt, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: jn | |
}); | |
Object.defineProperty(nt, 'Plugins', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: {} | |
}); | |
var pi = function (o, t) { | |
let e = true; | |
return (...i) => { | |
e && (e = false, o(...i), setTimeout(() => { | |
e = true; | |
}, t)); | |
}; | |
}, fi = (o, t) => { | |
let e = []; | |
return o.childNodes.forEach(i => { | |
i.nodeType !== Node.ELEMENT_NODE || t && !i.matches(t) || e.push(i); | |
}), e; | |
}, Hn = { | |
viewport: null, | |
track: null, | |
enabled: true, | |
slides: [], | |
axis: 'x', | |
transition: 'fade', | |
preload: 1, | |
slidesPerPage: 'auto', | |
initialPage: 0, | |
friction: 0.12, | |
Panzoom: { decelFriction: 0.12 }, | |
center: true, | |
infinite: true, | |
fill: true, | |
dragFree: false, | |
adaptiveHeight: false, | |
direction: 'ltr', | |
classes: { | |
container: 'f-carousel', | |
viewport: 'f-carousel__viewport', | |
track: 'f-carousel__track', | |
slide: 'f-carousel__slide', | |
isLTR: 'is-ltr', | |
isRTL: 'is-rtl', | |
isHorizontal: 'is-horizontal', | |
isVertical: 'is-vertical', | |
inTransition: 'in-transition', | |
isSelected: 'is-selected' | |
}, | |
l10n: { | |
NEXT: 'Next slide', | |
PREV: 'Previous slide', | |
GOTO: 'Go to slide #%d' | |
} | |
}, w; | |
(function (o) { | |
o[o.Init = 0] = 'Init'; | |
o[o.Ready = 1] = 'Ready'; | |
o[o.Destroy = 2] = 'Destroy'; | |
}(w || (w = {}))); | |
var we = o => { | |
if (typeof o == 'string' || o instanceof HTMLElement) { | |
o = { html: o }; | |
} else { | |
let t = o.thumb; | |
t !== void 0 && (typeof t == 'string' && (o.thumbSrc = t), t instanceof HTMLImageElement && (o.thumbEl = t, o.thumbElSrc = t.src, o.thumbSrc = t.src), delete o.thumb); | |
} | |
return Object.assign({ | |
html: '', | |
el: null, | |
isDom: false, | |
class: '', | |
customClass: '', | |
index: -1, | |
dim: 0, | |
gap: 0, | |
pos: 0, | |
transition: false | |
}, o); | |
}, Pn = (o = {}) => Object.assign({ | |
index: -1, | |
slides: [], | |
dim: 0, | |
pos: -1 | |
}, o), D = class extends dt { | |
constructor(t, e) { | |
super(e); | |
Object.defineProperty(this, 'instance', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: t | |
}); | |
} | |
attach() { | |
} | |
detach() { | |
} | |
}, _n = { | |
classes: { | |
list: 'f-carousel__dots', | |
isDynamic: 'is-dynamic', | |
hasDots: 'has-dots', | |
dot: 'f-carousel__dot', | |
isBeforePrev: 'is-before-prev', | |
isPrev: 'is-prev', | |
isCurrent: 'is-current', | |
isNext: 'is-next', | |
isAfterNext: 'is-after-next' | |
}, | |
dotTpl: '<button type="button" data-carousel-page="%i" aria-label="{{GOTO}}"><span class="f-carousel__dot" aria-hidden="true"></span></button>', | |
dynamicFrom: 11, | |
maxCount: 1e+400, | |
minCount: 2 | |
}, Vt = class extends D { | |
constructor() { | |
super(...arguments); | |
Object.defineProperty(this, 'isDynamic', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}); | |
Object.defineProperty(this, 'list', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
} | |
onRefresh() { | |
this.refresh(); | |
} | |
build() { | |
let t = this.list; | |
if (!t) { | |
t = document.createElement('ul'); | |
y(t, this.cn('list')); | |
t.setAttribute('role', 'tablist'); | |
let e = this.instance.container; | |
e.appendChild(t); | |
y(e, this.cn('hasDots')); | |
this.list = t; | |
} | |
return t; | |
} | |
refresh() { | |
var t; | |
let e = this.instance.pages.length, i = Math.min(2, this.option('minCount')), n = Math.max(2000, this.option('maxCount')), s = this.option('dynamicFrom'); | |
if (e < i || e > n) { | |
return void this.cleanup(); | |
} | |
let a = typeof s == 'number' && e > 5 && e >= s, r = !this.list || this.isDynamic !== a || this.list.children.length !== e; | |
r && this.cleanup(); | |
let l = this.build(); | |
if (z(l, this.cn('isDynamic'), !!a), r) { | |
for (let u = 0; u < e; u++) { | |
l.append(this.createItem(u)); | |
} | |
} | |
let c, d = 0; | |
for (let u of [...l.children]) { | |
let m = d === this.instance.page; | |
m && (c = u); | |
z(u, this.cn('isCurrent'), m); | |
(t = u.children[0]) === null || t === void 0 || t.setAttribute('aria-selected', m ? 'true' : 'false'); | |
for (let h of [ | |
'isBeforePrev', | |
'isPrev', | |
'isNext', | |
'isAfterNext' | |
]) | |
x(u, this.cn(h)); | |
d++; | |
} | |
if (c = c || l.firstChild, a && c) { | |
let u = c.previousElementSibling, m = u && u.previousElementSibling; | |
y(u, this.cn('isPrev')); | |
y(m, this.cn('isBeforePrev')); | |
let h = c.nextElementSibling, b = h && h.nextElementSibling; | |
y(h, this.cn('isNext')); | |
y(b, this.cn('isAfterNext')); | |
} | |
this.isDynamic = a; | |
} | |
createItem(t = 0) { | |
var e; | |
let i = document.createElement('li'); | |
i.setAttribute('role', 'presentation'); | |
let n = S(this.instance.localize(this.option('dotTpl'), [[ | |
'%d', | |
t + 1 | |
]]).replace(/\%i/g, t + '')); | |
return i.appendChild(n), (e = i.children[0]) === null || e === void 0 || e.setAttribute('role', 'tab'), i; | |
} | |
cleanup() { | |
this.list && (this.list.remove(), this.list = null); | |
this.isDynamic = false; | |
x(this.instance.container, this.cn('hasDots')); | |
} | |
attach() { | |
this.instance.on([ | |
'refresh', | |
'change' | |
], this.onRefresh); | |
} | |
detach() { | |
this.instance.off([ | |
'refresh', | |
'change' | |
], this.onRefresh); | |
this.cleanup(); | |
} | |
}; | |
Object.defineProperty(Vt, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: _n | |
}); | |
var It = class extends D { | |
constructor() { | |
super(...arguments); | |
Object.defineProperty(this, 'container', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'prev', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'next', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'isDom', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}); | |
} | |
onRefresh() { | |
let t = this.instance, e = t.pages.length, i = t.page; | |
if (e < 2) { | |
return void this.cleanup(); | |
} | |
this.build(); | |
let n = this.prev, s = this.next; | |
n && s && (n.removeAttribute('disabled'), s.removeAttribute('disabled'), t.isInfinite || (i <= 0 && n.setAttribute('disabled', ''), i >= e - 1 && s.setAttribute('disabled', ''))); | |
} | |
addBtn(t) { | |
var e; | |
let i = this.instance, n = document.createElement('button'); | |
n.setAttribute('tabindex', '0'); | |
n.setAttribute('title', i.localize(`{{${ t.toUpperCase() }}}`)); | |
y(n, this.cn('button') + ' ' + this.cn(t === 'next' ? 'isNext' : 'isPrev')); | |
let s = i.isRTL ? t === 'next' ? 'prev' : 'next' : t; | |
var a; | |
return n.innerHTML = i.localize(this.option(`${ s }Tpl`)), n.dataset[`carousel${ a = t, a ? a.match('^[a-z]') ? a.charAt(0).toUpperCase() + a.substring(1) : a : '' }`] = 'true', (e = this.container) === null || e === void 0 || e.appendChild(n), n; | |
} | |
build() { | |
let t = this.instance.container, e = this.cn('container'), { | |
container: i, | |
prev: n, | |
next: s | |
} = this; | |
i || (i = t.querySelector('.' + e), this.isDom = !!i); | |
i || (i = document.createElement('div'), y(i, e), t.appendChild(i)); | |
this.container = i; | |
s || (s = i.querySelector('[data-carousel-next]')); | |
s || (s = this.addBtn('next')); | |
this.next = s; | |
n || (n = i.querySelector('[data-carousel-prev]')); | |
n || (n = this.addBtn('prev')); | |
this.prev = n; | |
} | |
cleanup() { | |
this.isDom || (this.prev && this.prev.remove(), this.next && this.next.remove(), this.container && this.container.remove()); | |
this.prev = null; | |
this.next = null; | |
this.container = null; | |
this.isDom = false; | |
} | |
attach() { | |
this.instance.on([ | |
'refresh', | |
'change' | |
], this.onRefresh); | |
} | |
detach() { | |
this.instance.off([ | |
'refresh', | |
'change' | |
], this.onRefresh); | |
this.cleanup(); | |
} | |
}; | |
Object.defineProperty(It, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
classes: { | |
container: 'f-carousel__nav', | |
button: 'f-button', | |
isNext: 'is-next', | |
isPrev: 'is-prev' | |
}, | |
nextTpl: '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" tabindex="-1"><path d="M9 3l9 9-9 9"/></svg>', | |
prevTpl: '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" tabindex="-1"><path d="M15 3l-9 9 9 9"/></svg>' | |
} | |
}); | |
var St = class extends D { | |
constructor() { | |
super(...arguments); | |
Object.defineProperty(this, 'selectedIndex', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'target', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'nav', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
} | |
addAsTargetFor(t) { | |
this.target = this.instance; | |
this.nav = t; | |
this.attachEvents(); | |
} | |
addAsNavFor(t) { | |
this.nav = this.instance; | |
this.target = t; | |
this.attachEvents(); | |
} | |
attachEvents() { | |
let { | |
nav: t, | |
target: e | |
} = this; | |
t && e && (t.options.initialSlide = e.options.initialPage, t.state === w.Ready ? this.onNavReady(t) : t.on('ready', this.onNavReady), e.state === w.Ready ? this.onTargetReady(e) : e.on('ready', this.onTargetReady)); | |
} | |
onNavReady(t) { | |
t.on('createSlide', this.onNavCreateSlide); | |
t.on('Panzoom.click', this.onNavClick); | |
t.on('Panzoom.touchEnd', this.onNavTouch); | |
this.onTargetChange(); | |
} | |
onTargetReady(t) { | |
t.on('change', this.onTargetChange); | |
t.on('Panzoom.refresh', this.onTargetChange); | |
this.onTargetChange(); | |
} | |
onNavClick(t, e, i) { | |
this.onNavTouch(t, t.panzoom, i); | |
} | |
onNavTouch(t, e, i) { | |
var n, s; | |
if (Math.abs(e.dragOffset.x) > 3 || Math.abs(e.dragOffset.y) > 3) { | |
return; | |
} | |
let a = i.target, { | |
nav: r, | |
target: l | |
} = this; | |
if (!r || !l || !a) { | |
return; | |
} | |
let c = a.closest('[data-index]'); | |
if (i.stopPropagation(), i.preventDefault(), !c) { | |
return; | |
} | |
let d = parseInt(c.dataset.index || '', 10) || 0, u = l.getPageForSlide(d), m = r.getPageForSlide(d); | |
r.slideTo(m); | |
l.slideTo(u, { friction: ((s = (n = this.nav) === null || n === void 0 ? void 0 : n.plugins) === null || s === void 0 ? void 0 : s.Sync.option('friction')) || 0 }); | |
this.markSelectedSlide(d); | |
} | |
onNavCreateSlide(t, e) { | |
e.index === this.selectedIndex && this.markSelectedSlide(e.index); | |
} | |
onTargetChange() { | |
var t, e; | |
let { | |
target: i, | |
nav: n | |
} = this; | |
if (!i || !n || n.state !== w.Ready || i.state !== w.Ready) { | |
return; | |
} | |
let s = (e = (t = i.pages[i.page]) === null || t === void 0 ? void 0 : t.slides[0]) === null || e === void 0 ? void 0 : e.index, a = n.getPageForSlide(s); | |
this.markSelectedSlide(s); | |
n.slideTo(a, n.prevPage === null && i.prevPage === null ? { friction: 0 } : void 0); | |
} | |
markSelectedSlide(t) { | |
let e = this.nav; | |
e && e.state === w.Ready && (this.selectedIndex = t, [...e.slides].map(i => { | |
i.el && i.el.classList[i.index === t ? 'add' : 'remove']('is-nav-selected'); | |
})); | |
} | |
attach() { | |
let t = this, e = t.options.target, i = t.options.nav; | |
e ? t.addAsNavFor(e) : i && t.addAsTargetFor(i); | |
} | |
detach() { | |
let t = this, e = t.nav, i = t.target; | |
e && (e.off('ready', t.onNavReady), e.off('createSlide', t.onNavCreateSlide), e.off('Panzoom.click', t.onNavClick), e.off('Panzoom.touchEnd', t.onNavTouch)); | |
; | |
i && (i.off('ready', t.onTargetReady), i.off('refresh', t.onTargetChange), i.off('change', t.onTargetChange)); | |
; | |
} | |
}; | |
Object.defineProperty(St, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { friction: 0.35 } | |
}); | |
var Kn = { | |
Navigation: It, | |
Dots: Vt, | |
Sync: St | |
}, ct = class o extends Qt { | |
get axis() { | |
return this.isHorizontal ? 'e' : 'f'; | |
} | |
get isEnabled() { | |
return this.state === w.Ready; | |
} | |
get isInfinite() { | |
let t = false, { | |
contentDim: e, | |
viewportDim: i, | |
pages: n, | |
slides: s | |
} = this, a = s[0]; | |
return n.length >= 2 && a && e + a.dim >= i && (t = this.option('infinite')), t; | |
} | |
get isRTL() { | |
return this.option('direction') === 'rtl'; | |
} | |
get isHorizontal() { | |
return this.option('axis') === 'x'; | |
} | |
constructor(t, e = {}, i = {}) { | |
if (super(), Object.defineProperty(this, 'bp', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: '' | |
}), Object.defineProperty(this, 'lp', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}), Object.defineProperty(this, 'userOptions', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: {} | |
}), Object.defineProperty(this, 'userPlugins', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: {} | |
}), Object.defineProperty(this, 'state', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: w.Init | |
}), Object.defineProperty(this, 'page', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}), Object.defineProperty(this, 'prevPage', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'container', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}), Object.defineProperty(this, 'viewport', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'track', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'slides', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: [] | |
}), Object.defineProperty(this, 'pages', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: [] | |
}), Object.defineProperty(this, 'panzoom', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}), Object.defineProperty(this, 'inTransition', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: new Set() | |
}), Object.defineProperty(this, 'contentDim', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}), Object.defineProperty(this, 'viewportDim', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}), typeof t == 'string' && (t = document.querySelector(t)), !t || !C(t)) { | |
throw new Error('No Element found'); | |
} | |
this.container = t; | |
this.slideNext = pi(this.slideNext.bind(this), 150); | |
this.slidePrev = pi(this.slidePrev.bind(this), 150); | |
this.userOptions = e; | |
this.userPlugins = i; | |
queueMicrotask(() => { | |
this.processOptions(); | |
}); | |
} | |
processOptions() { | |
var t, e; | |
let i = E({}, o.defaults, this.userOptions), n = '', s = i.breakpoints; | |
if (s && Ve(s)) { | |
for (let [a, r] of Object.entries(s)) | |
window.matchMedia(a).matches && Ve(r) && (n += a, E(i, r)); | |
} | |
n === this.bp && this.state !== w.Init || (this.bp = n, this.state === w.Ready && (i.initialSlide = ((e = (t = this.pages[this.page]) === null || t === void 0 ? void 0 : t.slides[0]) === null || e === void 0 ? void 0 : e.index) || 0), this.state !== w.Init && this.destroy(), super.setOptions(i), this.option('enabled') === false ? this.attachEvents() : setTimeout(() => { | |
this.init(); | |
}, 0)); | |
} | |
init() { | |
this.state = w.Init; | |
this.emit('init'); | |
this.attachPlugins(Object.assign(Object.assign({}, o.Plugins), this.userPlugins)); | |
this.emit('attachPlugins'); | |
this.initLayout(); | |
this.initSlides(); | |
this.updateMetrics(); | |
this.setInitialPosition(); | |
this.initPanzoom(); | |
this.attachEvents(); | |
this.state = w.Ready; | |
this.emit('ready'); | |
} | |
initLayout() { | |
let {container: t} = this, e = this.option('classes'); | |
y(t, this.cn('container')); | |
z(t, e.isLTR, !this.isRTL); | |
z(t, e.isRTL, this.isRTL); | |
z(t, e.isVertical, !this.isHorizontal); | |
z(t, e.isHorizontal, this.isHorizontal); | |
let i = this.option('viewport') || t.querySelector(`.${ e.viewport }`); | |
i || (i = document.createElement('div'), y(i, e.viewport), i.append(...fi(t, `.${ e.slide }`)), t.prepend(i)); | |
i.addEventListener('scroll', this.onScroll); | |
let n = this.option('track') || t.querySelector(`.${ e.track }`); | |
n || (n = document.createElement('div'), y(n, e.track), n.append(...Array.from(i.childNodes))); | |
n.setAttribute('aria-live', 'polite'); | |
i.contains(n) || i.prepend(n); | |
this.viewport = i; | |
this.track = n; | |
this.emit('initLayout'); | |
} | |
initSlides() { | |
let {track: t} = this; | |
if (!t) { | |
return; | |
} | |
let e = [...this.slides], i = []; | |
[...fi(t, `.${ this.cn('slide') }`)].forEach(n => { | |
if (C(n)) { | |
let s = we({ | |
el: n, | |
isDom: true, | |
index: this.slides.length | |
}); | |
i.push(s); | |
} | |
}); | |
for (let n of [ | |
...this.option('slides', []) || [], | |
...e | |
]) | |
i.push(we(n)); | |
this.slides = i; | |
for (let n = 0; n < this.slides.length; n++) { | |
this.slides[n].index = n; | |
} | |
for (let n of i) | |
this.emit('beforeInitSlide', n, n.index), this.emit('initSlide', n, n.index); | |
this.emit('initSlides'); | |
} | |
setInitialPage() { | |
let t = this.option('initialSlide'); | |
this.page = typeof t == 'number' ? this.getPageForSlide(t) : parseInt(this.option('initialPage', 0) + '', 10) || 0; | |
} | |
setInitialPosition() { | |
let { | |
track: t, | |
pages: e, | |
isHorizontal: i | |
} = this; | |
if (!t || !e.length) { | |
return; | |
} | |
let n = this.page; | |
e[n] || (this.page = n = 0); | |
let s = (e[n].pos || 0) * (this.isRTL && i ? 1 : -1), a = i ? `${ s }px` : '0', r = i ? '0' : `${ s }px`; | |
t.style.transform = `translate3d(${ a }, ${ r }, 0) scale(1)`; | |
this.option('adaptiveHeight') && this.setViewportHeight(); | |
} | |
initPanzoom() { | |
this.panzoom && (this.panzoom.destroy(), this.panzoom = null); | |
let t = this.option('Panzoom') || {}; | |
this.panzoom = new nt(this.viewport, E({}, { | |
content: this.track, | |
zoom: false, | |
panOnlyZoomed: false, | |
lockAxis: this.isHorizontal ? 'x' : 'y', | |
infinite: this.isInfinite, | |
click: false, | |
dblClick: false, | |
touch: e => !(this.pages.length < 2 && !e.options.infinite), | |
bounds: () => this.getBounds(), | |
maxVelocity: e => Math.abs(e.target[this.axis] - e.current[this.axis]) < 2 * this.viewportDim ? 100 : 0 | |
}, t)); | |
this.panzoom.on('*', (e, i, ...n) => { | |
this.emit(`Panzoom.${ i }`, e, ...n); | |
}); | |
this.panzoom.on('decel', this.onDecel); | |
this.panzoom.on('refresh', this.onRefresh); | |
this.panzoom.on('beforeTransform', this.onBeforeTransform); | |
this.panzoom.on('endAnimation', this.onEndAnimation); | |
} | |
attachEvents() { | |
let t = this.container; | |
t && (t.addEventListener('click', this.onClick, { | |
passive: false, | |
capture: false | |
}), t.addEventListener('slideTo', this.onSlideTo)); | |
window.addEventListener('resize', this.onResize); | |
} | |
createPages() { | |
let t = [], { | |
contentDim: e, | |
viewportDim: i | |
} = this, n = this.option('slidesPerPage'); | |
n = (n === 'auto' || e <= i) && this.option('fill') !== false ? 1e+400 : parseFloat(n + ''); | |
let s = 0, a = 0, r = 0; | |
for (let l of this.slides) | |
(!t.length || a + l.dim - i > 0.05 || r >= n) && (t.push(Pn()), s = t.length - 1, a = 0, r = 0), t[s].slides.push(l), a += l.dim + l.gap, r++; | |
return t; | |
} | |
processPages() { | |
let t = this.pages, { | |
contentDim: e, | |
viewportDim: i, | |
isInfinite: n | |
} = this, s = this.option('center'), a = this.option('fill'), r = a && s && e > i && !n; | |
if (t.forEach((d, u) => { | |
var m; | |
d.index = u; | |
d.pos = ((m = d.slides[0]) === null || m === void 0 ? void 0 : m.pos) || 0; | |
d.dim = 0; | |
for (let [h, b] of d.slides.entries()) | |
d.dim += b.dim, h < d.slides.length - 1 && (d.dim += b.gap); | |
r && d.pos + 0.5 * d.dim < 0.5 * i ? d.pos = 0 : r && d.pos + 0.5 * d.dim >= e - 0.5 * i ? d.pos = e - i : s && (d.pos += -0.5 * (i - d.dim)); | |
}), t.forEach(d => { | |
a && !n && e > i && (d.pos = Math.max(d.pos, 0), d.pos = Math.min(d.pos, e - i)); | |
d.pos = Q(d.pos, 1000); | |
d.dim = Q(d.dim, 1000); | |
Math.abs(d.pos) <= 0.1 && (d.pos = 0); | |
}), n) { | |
return t; | |
} | |
let l = [], c; | |
return t.forEach(d => { | |
let u = Object.assign({}, d); | |
c && u.pos === c.pos ? (c.dim += u.dim, c.slides = [ | |
...c.slides, | |
...u.slides | |
]) : (u.index = l.length, c = u, l.push(u)); | |
}), l; | |
} | |
getPageFromIndex(t = 0) { | |
let e = this.pages.length, i; | |
return t = parseInt((t || 0).toString()) || 0, i = this.isInfinite ? (t % e + e) % e : Math.max(Math.min(t, e - 1), 0), i; | |
} | |
getSlideMetrics(t) { | |
var e, i; | |
let n = this.isHorizontal ? 'width' : 'height', s = 0, a = 0, r = t.el, l = !(!r || r.parentNode); | |
if (r ? s = parseFloat(r.dataset[n] || '') || 0 : (r = document.createElement('div'), r.style.visibility = 'hidden', (this.track || document.body).prepend(r)), y(r, this.cn('slide') + ' ' + t.class + ' ' + t.customClass), s) { | |
r.style[n] = `${ s }px`; | |
r.style[n === 'width' ? 'height' : 'width'] = ''; | |
} else { | |
l && (this.track || document.body).prepend(r); | |
s = r.getBoundingClientRect()[n] * Math.max(1, ((e = window.visualViewport) === null || e === void 0 ? void 0 : e.scale) || 1); | |
let d = r[this.isHorizontal ? 'offsetWidth' : 'offsetHeight']; | |
d - 1 > s && (s = d); | |
} | |
let c = getComputedStyle(r); | |
return c.boxSizing === 'content-box' && (this.isHorizontal ? (s += parseFloat(c.paddingLeft) || 0, s += parseFloat(c.paddingRight) || 0) : (s += parseFloat(c.paddingTop) || 0, s += parseFloat(c.paddingBottom) || 0)), a = parseFloat(c[this.isHorizontal ? 'marginRight' : 'marginBottom']) || 0, l ? (i = r.parentElement) === null || i === void 0 || i.removeChild(r) : t.el || r.remove(), { | |
dim: Q(s, 1000), | |
gap: Q(a, 1000) | |
}; | |
} | |
getBounds() { | |
let { | |
isInfinite: t, | |
isRTL: e, | |
isHorizontal: i, | |
pages: n | |
} = this; | |
if (t) { | |
s = { | |
min: null, | |
max: null | |
}; | |
} else { | |
if (n.length) { | |
let a = n[0].pos, r = n[n.length - 1].pos; | |
s = e && i ? { | |
min: a, | |
max: r | |
} : { | |
min: -1 * r, | |
max: -1 * a | |
}; | |
} | |
} | |
return { | |
x: i ? s : { | |
min: 0, | |
max: 0 | |
}, | |
y: i ? { | |
min: 0, | |
max: 0 | |
} : s | |
}; | |
} | |
repositionSlides() { | |
let t, { | |
isHorizontal: e, | |
isRTL: i, | |
isInfinite: n, | |
viewport: s, | |
viewportDim: a, | |
contentDim: r, | |
page: l, | |
pages: c, | |
slides: d, | |
panzoom: u | |
} = this, m = 0, h = 0, b = 0, p = 0; | |
u ? p = -1 * u.current[this.axis] : c[l] && (p = c[l].pos || 0); | |
t = e ? i ? 'right' : 'left' : 'top'; | |
i && e && (p *= -1); | |
for (let v of d) { | |
let B = v.el; | |
B ? (t === 'top' ? (B.style.right = '', B.style.left = '') : B.style.top = '', v.index !== m ? B.style[t] = h === 0 ? '' : `${ Q(h, 1000) }px` : B.style[t] = '', b += v.dim + v.gap, m++) : h += v.dim + v.gap; | |
} | |
if (n && b && s) { | |
let v = getComputedStyle(s), k = e ? 'Right' : 'Bottom', X = parseFloat(v['padding' + (e ? 'Left' : 'Top')]); | |
p -= X; | |
a += X; | |
a += parseFloat(v['padding' + k]); | |
for (let L of d) | |
L.el && (Q(L.pos) < Q(a) && Q(L.pos + L.dim + L.gap) < Q(p) && Q(p) > Q(r - a) && (L.el.style[t] = `${ Q(h + b, 1000) }px`), Q(L.pos + L.gap) >= Q(r - a) && Q(L.pos) > Q(p + a) && Q(p) < Q(a) && (L.el.style[t] = `-${ Q(b, 1000) }px`)); | |
} | |
let f, g, F = [...this.inTransition]; | |
if (F.length > 1 && (f = c[F[0]], g = c[F[1]]), f && g) { | |
let v = 0; | |
for (let B of d) | |
B.el ? this.inTransition.has(B.index) && f.slides.indexOf(B) < 0 && (B.el.style[t] = `${ Q(v + (f.pos - g.pos), 1000) }px`) : v += B.dim + B.gap; | |
} | |
} | |
createSlideEl(t) { | |
let { | |
track: e, | |
slides: i | |
} = this; | |
if (!e || !t || t.el && t.el.parentNode) { | |
return; | |
} | |
let n = t.el || document.createElement('div'); | |
y(n, this.cn('slide')); | |
y(n, t.class); | |
y(n, t.customClass); | |
let s = t.html; | |
s && (s instanceof HTMLElement ? n.appendChild(s) : n.innerHTML = t.html + ''); | |
let a = []; | |
i.forEach((d, u) => { | |
d.el && a.push(u); | |
}); | |
let r = t.index, l = null; | |
a.length && (l = i[a.reduce((d, u) => Math.abs(u - r) < Math.abs(d - r) ? u : d)]); | |
let c = l && l.el && l.el.parentNode ? l.index < t.index ? l.el.nextSibling : l.el : null; | |
e.insertBefore(n, e.contains(c) ? c : null); | |
; | |
this.emit('createSlide', t); | |
} | |
removeSlideEl(t, e = false) { | |
let i = t?.el; | |
if (!i || !i.parentNode) { | |
return; | |
} | |
let n = this.cn('isSelected'); | |
if (i.classList.contains(n) && (x(i, n), this.emit('unselectSlide', t)), t.isDom && !e) { | |
return i.removeAttribute('aria-hidden'), i.removeAttribute('data-index'), void (i.style.left = ''); | |
} | |
this.emit('removeSlide', t); | |
let s = new CustomEvent('animationend'); | |
i.dispatchEvent(s); | |
t.el && (t.el.remove(), t.el = null); | |
} | |
transitionTo(t = 0, e = this.option('transition')) { | |
var i, n, s, a; | |
if (!e) { | |
return false; | |
} | |
let r = this.page, { | |
pages: l, | |
panzoom: c | |
} = this; | |
t = parseInt((t || 0).toString()) || 0; | |
let d = this.getPageFromIndex(t); | |
if (!c || !l[d] || l.length < 2 || Math.abs((((n = (i = l[r]) === null || i === void 0 ? void 0 : i.slides[0]) === null || n === void 0 ? void 0 : n.dim) || 0) - this.viewportDim) > 1) { | |
return false; | |
} | |
let u = t > r ? 1 : -1; | |
this.isInfinite && (r === 0 && t === l.length - 1 && (u = -1), r === l.length - 1 && t === 0 && (u = 1)); | |
let m = l[d].pos * (this.isRTL ? 1 : -1); | |
if (r === d && Math.abs(m - c.target[this.axis]) < 1) { | |
return false; | |
} | |
this.clearTransitions(); | |
let h = c.isResting; | |
y(this.container, this.cn('inTransition')); | |
let b = ((s = l[r]) === null || s === void 0 ? void 0 : s.slides[0]) || null, p = ((a = l[d]) === null || a === void 0 ? void 0 : a.slides[0]) || null; | |
this.inTransition.add(p.index); | |
this.createSlideEl(p); | |
let f = b.el, g = p.el; | |
h || e === 'slide' || (e = 'fadeFast', f = null); | |
let F = this.isRTL ? 'next' : 'prev', v = this.isRTL ? 'prev' : 'next'; | |
return f && (this.inTransition.add(b.index), b.transition = e, f.addEventListener('animationend', this.onAnimationEnd), f.classList.add(`f-${ e }Out`, `to-${ u > 0 ? v : F }`)), g && (p.transition = e, g.addEventListener('animationend', this.onAnimationEnd), g.classList.add(`f-${ e }In`, `from-${ u > 0 ? F : v }`)), c.current[this.axis] = m, c.target[this.axis] = m, c.requestTick(), this.onChange(d), true; | |
} | |
manageSlideVisiblity() { | |
let t = new Set(), e = new Set(), i = this.getVisibleSlides(parseFloat(this.option('preload', 0) + '') || 0); | |
for (let n of this.slides) | |
i.has(n) ? t.add(n) : e.add(n); | |
for (let n of this.inTransition) | |
t.add(this.slides[n]); | |
for (let n of t) | |
this.createSlideEl(n), this.lazyLoadSlide(n); | |
for (let n of e) | |
t.has(n) || this.removeSlideEl(n); | |
this.markSelectedSlides(); | |
this.repositionSlides(); | |
} | |
markSelectedSlides() { | |
if (!this.pages[this.page] || !this.pages[this.page].slides) { | |
return; | |
} | |
let e = this.cn('isSelected'); | |
if (e) { | |
for (let i of this.slides) { | |
let n = i.el; | |
n && (n.dataset.index = `${ i.index }`, n.classList.contains('f-thumbs__slide') ? this.getVisibleSlides(0).has(i) ? n.removeAttribute('aria-hidden') : n.setAttribute('aria-hidden', 'true') : this.pages[this.page].slides.includes(i) ? (n.classList.contains(e) || (y(n, e), this.emit('selectSlide', i)), n.removeAttribute('aria-hidden')) : (n.classList.contains(e) && (x(n, e), this.emit('unselectSlide', i)), n.setAttribute('aria-hidden', 'true'))); | |
} | |
} | |
} | |
flipInfiniteTrack() { | |
let { | |
axis: t, | |
isHorizontal: e, | |
isInfinite: i, | |
isRTL: n, | |
viewportDim: s, | |
contentDim: a | |
} = this, r = this.panzoom; | |
if (!r || !i) { | |
return; | |
} | |
let l = r.current[t], c = r.target[t] - l, d = 0, u = 0.5 * s; | |
n && e ? (l < -u && (d = -1, l += a), l > a - u && (d = 1, l -= a)) : (l > u && (d = 1, l -= a), l < -a + u && (d = -1, l += a)); | |
d && (r.current[t] = l, r.target[t] = l + c); | |
} | |
lazyLoadImg(t, e) { | |
let i = this, a = false, r = null, l = () => { | |
a || (a = true, r && (r.remove(), r = null), x(e, 'is-preloading'), e.complete && (y(e, 'f-fadeIn'), setTimeout(() => { | |
x(e, 'f-fadeIn'); | |
}, 350)), this.option('adaptiveHeight') && t.el && this.pages[this.page].slides.indexOf(t) > -1 && (i.updateMetrics(), i.setViewportHeight()), this.emit('load', t)); | |
}; | |
y(e, 'is-preloading'); | |
e.src = e.dataset.lazySrcset || e.dataset.lazySrc || ''; | |
delete e.dataset.lazySrc; | |
delete e.dataset.lazySrcset; | |
e.addEventListener('error', () => { | |
l(); | |
}); | |
e.addEventListener('load', () => { | |
l(); | |
}); | |
setTimeout(() => { | |
let c = e.parentNode; | |
c && t.el && (e.complete ? l() : a || (r = S(ze), c.insertBefore(r, e))); | |
}, 300); | |
} | |
lazyLoadSlide(t) { | |
let e = t && t.el; | |
if (!e) { | |
return; | |
} | |
let i = new Set(), n = Array.from(e.querySelectorAll('[data-lazy-src],[data-lazy-srcset]')); | |
e.dataset.lazySrc && n.push(e); | |
n.map(s => { | |
s instanceof HTMLImageElement ? i.add(s) : s instanceof HTMLElement && s.dataset.lazySrc && (s.style.backgroundImage = `url('${ s.dataset.lazySrc }')`, delete s.dataset.lazySrc); | |
}); | |
for (let s of i) | |
this.lazyLoadImg(t, s); | |
} | |
onAnimationEnd(t) { | |
var e; | |
let i = t.target, n = i ? parseInt(i.dataset.index || '', 10) || 0 : -1, s = this.slides[n], a = t.animationName; | |
if (!i || !s || !a) { | |
return; | |
} | |
let r = !!this.inTransition.has(n) && s.transition; | |
r && a.substring(0, r.length + 2) === `f-${ r }` && this.inTransition.delete(n); | |
this.inTransition.size || this.clearTransitions(); | |
n === this.page && (!((e = this.panzoom) === null || e === void 0) && e.isResting) && this.emit('settle'); | |
} | |
onDecel(t, e = 0, i = 0, n = 0, s = 0) { | |
if (this.option('dragFree')) { | |
return void this.setPageFromPosition(); | |
} | |
let { | |
isRTL: a, | |
isHorizontal: r, | |
axis: l, | |
pages: c | |
} = this, d = c.length, u = Math.abs(Math.atan2(i, e) / (Math.PI / 180)), m = 0; | |
if (m = u > 45 && u < 135 ? r ? 0 : i : r ? e : 0, !d) { | |
return; | |
} | |
let h = this.page, b = a && r ? 1 : -1, p = t.current[l] * b, {pageIndex: f} = this.getPageFromPosition(p); | |
Math.abs(m) > 5 ? (c[h].dim < document.documentElement['client' + (this.isHorizontal ? 'Width' : 'Height')] - 1 && (h = f), h = a && r ? m < 0 ? h - 1 : h + 1 : m < 0 ? h + 1 : h - 1) : h = n === 0 && s === 0 ? h : f; | |
this.slideTo(h, { | |
transition: false, | |
friction: t.option('decelFriction') | |
}); | |
} | |
onClick(t) { | |
let e = t.target, i = e && C(e) ? e.dataset : null, n, s; | |
i && (i.carouselPage !== void 0 ? (s = 'slideTo', n = i.carouselPage) : i.carouselNext !== void 0 ? s = 'slideNext' : i.carouselPrev !== void 0 && (s = 'slidePrev')); | |
s ? (t.preventDefault(), t.stopPropagation(), e && !e.hasAttribute('disabled') && this[s](n)) : this.emit('click', t); | |
} | |
onSlideTo(t) { | |
let e = t.detail || 0; | |
this.slideTo(this.getPageForSlide(e), { friction: 0 }); | |
} | |
onChange(t, e = 0) { | |
let i = this.page; | |
this.prevPage = i; | |
this.page = t; | |
this.option('adaptiveHeight') && this.setViewportHeight(); | |
t !== i && (this.markSelectedSlides(), this.emit('change', t, i, e)); | |
} | |
onRefresh() { | |
let t = this.contentDim, e = this.viewportDim; | |
this.updateMetrics(); | |
this.contentDim === t && this.viewportDim === e || this.slideTo(this.page, { | |
friction: 0, | |
transition: false | |
}); | |
} | |
onScroll() { | |
var t; | |
(t = this.viewport) === null || t === void 0 || t.scroll(0, 0); | |
} | |
onResize() { | |
this.option('breakpoints') && this.processOptions(); | |
} | |
onBeforeTransform(t) { | |
this.lp !== t.current[this.axis] && (this.flipInfiniteTrack(), this.manageSlideVisiblity()); | |
this.lp = t.current.e; | |
} | |
onEndAnimation() { | |
this.inTransition.size || this.emit('settle'); | |
} | |
reInit(t = null, e = null) { | |
this.destroy(); | |
this.state = w.Init; | |
this.prevPage = null; | |
this.userOptions = t || this.userOptions; | |
this.userPlugins = e || this.userPlugins; | |
this.processOptions(); | |
} | |
slideTo(t = 0, { | |
friction: e = this.option('friction'), | |
transition: i = this.option('transition') | |
} = {}) { | |
if (this.state === w.Destroy) { | |
return; | |
} | |
t = parseInt((t || 0).toString()) || 0; | |
let n = this.getPageFromIndex(t), { | |
axis: s, | |
isHorizontal: a, | |
isRTL: r, | |
pages: l, | |
panzoom: c | |
} = this, d = l.length, u = r && a ? 1 : -1; | |
if (!c || !d) { | |
return; | |
} | |
if (this.page !== n) { | |
let h = new Event('beforeChange', { | |
bubbles: true, | |
cancelable: true | |
}); | |
if (this.emit('beforeChange', h, t), h.defaultPrevented) { | |
return; | |
} | |
} | |
if (this.transitionTo(t, i)) { | |
return; | |
} | |
let m = l[n].pos; | |
if (this.isInfinite) { | |
let h = this.contentDim, b = c.target[s] * u; | |
d === 2 ? m += h * Math.floor(parseFloat(t + '') / 2) : m = [ | |
m, | |
m - h, | |
m + h | |
].reduce(function (p, f) { | |
return Math.abs(f - b) < Math.abs(p - b) ? f : p; | |
}); | |
} | |
m *= u; | |
Math.abs(c.target[s] - m) < 1 || (c.panTo({ | |
x: a ? m : 0, | |
y: a ? 0 : m, | |
friction: e | |
}), this.onChange(n)); | |
} | |
slideToClosest(t) { | |
if (this.panzoom) { | |
let {pageIndex: e} = this.getPageFromPosition(); | |
this.slideTo(e, t); | |
} | |
} | |
slideNext() { | |
this.slideTo(this.page + 1); | |
} | |
slidePrev() { | |
this.slideTo(this.page - 1); | |
} | |
clearTransitions() { | |
this.inTransition.clear(); | |
x(this.container, this.cn('inTransition')); | |
let t = [ | |
'to-prev', | |
'to-next', | |
'from-prev', | |
'from-next' | |
]; | |
for (let e of this.slides) { | |
let i = e.el; | |
if (i) { | |
i.removeEventListener('animationend', this.onAnimationEnd); | |
i.classList.remove(...t); | |
let n = e.transition; | |
n && i.classList.remove(`f-${ n }Out`, `f-${ n }In`); | |
} | |
} | |
this.manageSlideVisiblity(); | |
} | |
addSlide(t, e) { | |
var i, n, s, a; | |
let r = this.panzoom, l = ((i = this.pages[this.page]) === null || i === void 0 ? void 0 : i.pos) || 0, c = ((n = this.pages[this.page]) === null || n === void 0 ? void 0 : n.dim) || 0, d = this.contentDim < this.viewportDim, u = Array.isArray(e) ? e : [e], m = []; | |
for (let h of u) | |
m.push(we(h)); | |
this.slides.splice(t, 0, ...m); | |
for (let h = 0; h < this.slides.length; h++) { | |
this.slides[h].index = h; | |
} | |
for (let h of m) | |
this.emit('beforeInitSlide', h, h.index); | |
if (this.page >= t && (this.page += m.length), this.updateMetrics(), r) { | |
let h = ((s = this.pages[this.page]) === null || s === void 0 ? void 0 : s.pos) || 0, b = ((a = this.pages[this.page]) === null || a === void 0 ? void 0 : a.dim) || 0, p = this.pages.length || 1, f = this.isRTL ? c - b : b - c, g = this.isRTL ? l - h : h - l; | |
d && p === 1 ? (t <= this.page && (r.current[this.axis] -= f, r.target[this.axis] -= f), r.panTo({ [this.isHorizontal ? 'x' : 'y']: -1 * h })) : g && t <= this.page && (r.target[this.axis] -= g, r.current[this.axis] -= g, r.requestTick()); | |
} | |
for (let h of m) | |
this.emit('initSlide', h, h.index); | |
} | |
prependSlide(t) { | |
this.addSlide(0, t); | |
} | |
appendSlide(t) { | |
this.addSlide(this.slides.length, t); | |
} | |
removeSlide(t) { | |
let e = this.slides.length; | |
t = (t % e + e) % e; | |
let i = this.slides[t]; | |
if (i) { | |
this.removeSlideEl(i, true); | |
this.slides.splice(t, 1); | |
for (let n = 0; n < this.slides.length; n++) { | |
this.slides[n].index = n; | |
} | |
this.updateMetrics(); | |
this.slideTo(this.page, { | |
friction: 0, | |
transition: false | |
}); | |
this.emit('destroySlide', i); | |
} | |
} | |
updateMetrics() { | |
let { | |
panzoom: t, | |
viewport: e, | |
track: i, | |
slides: n, | |
isHorizontal: s, | |
isInfinite: a | |
} = this; | |
if (!i) { | |
return; | |
} | |
let r = s ? 'width' : 'height', l = s ? 'offsetWidth' : 'offsetHeight'; | |
if (e) { | |
let u = Math.max(e[l], Q(e.getBoundingClientRect()[r], 1000)), m = getComputedStyle(e), b = s ? 'Right' : 'Bottom'; | |
u -= parseFloat(m['padding' + (s ? 'Left' : 'Top')]) + parseFloat(m['padding' + b]); | |
this.viewportDim = u; | |
} | |
let c, d = 0; | |
for (let [u, m] of n.entries()) { | |
let h = 0, b = 0; | |
!m.el && c ? (h = c.dim, b = c.gap) : ({ | |
dim: h, | |
gap: b | |
} = this.getSlideMetrics(m), c = m); | |
h = Q(h, 1000); | |
b = Q(b, 1000); | |
m.dim = h; | |
m.gap = b; | |
m.pos = d; | |
d += h; | |
(a || u < n.length - 1) && (d += b); | |
} | |
d = Q(d, 1000); | |
this.contentDim = d; | |
t && (t.contentRect[r] = d, t.contentRect[s ? 'fullWidth' : 'fullHeight'] = d); | |
this.pages = this.createPages(); | |
this.pages = this.processPages(); | |
this.state === w.Init && this.setInitialPage(); | |
this.page = Math.max(0, Math.min(this.page, this.pages.length - 1)); | |
this.manageSlideVisiblity(); | |
this.emit('refresh'); | |
} | |
getProgress(t, e = false, i = false) { | |
t === void 0 && (t = this.page); | |
let n = this, s = n.panzoom, a = n.contentDim, r = n.pages[t] || 0; | |
if (!r || !s) { | |
return t > this.page ? -1 : 1; | |
} | |
let l = -1 * s.current.e, c = Q((l - r.pos) / (1 * r.dim), 1000), d = c, u = c; | |
this.isInfinite && i !== true && (d = Q((l - r.pos + a) / (1 * r.dim), 1000), u = Q((l - r.pos - a) / (1 * r.dim), 1000)); | |
let m = [ | |
c, | |
d, | |
u | |
].reduce(function (h, b) { | |
return Math.abs(b) < Math.abs(h) ? b : h; | |
}); | |
return e ? m : m > 1 ? 1 : m < -1 ? -1 : m; | |
} | |
setViewportHeight() { | |
let { | |
page: t, | |
pages: e, | |
viewport: i, | |
isHorizontal: n | |
} = this; | |
if (!i || !e[t]) { | |
return; | |
} | |
let s = 0; | |
n && this.track && (this.track.style.height = 'auto', e[t].slides.forEach(a => { | |
a.el && (s = Math.max(s, a.el.offsetHeight)); | |
})); | |
i.style.height = s ? `${ s }px` : ''; | |
} | |
getPageForSlide(t) { | |
for (let e of this.pages) | |
for (let i of e.slides) | |
if (i.index === t) { | |
return e.index; | |
} | |
return -1; | |
} | |
getVisibleSlides(t = 0) { | |
var e; | |
let i = new Set(), { | |
panzoom: n, | |
contentDim: s, | |
viewportDim: a, | |
pages: r, | |
page: l | |
} = this; | |
if (a) { | |
s = s + ((e = this.slides[this.slides.length - 1]) === null || e === void 0 ? void 0 : e.gap) || 0; | |
let c = 0; | |
c = n && n.state !== U.Init && n.state !== U.Destroy ? -1 * n.current[this.axis] : r[l] && r[l].pos || 0; | |
this.isInfinite && (c -= Math.floor(c / s) * s); | |
this.isRTL && this.isHorizontal && (c *= -1); | |
let d = c - a * t, u = c + a * (t + 1), m = this.isInfinite ? [ | |
-1, | |
0, | |
1 | |
] : [0]; | |
for (let h of this.slides) | |
for (let b of m) { | |
let p = h.pos + b * s, f = p + h.dim + h.gap; | |
p < u && f > d && i.add(h); | |
} | |
} | |
return i; | |
} | |
getPageFromPosition(t) { | |
let { | |
viewportDim: e, | |
contentDim: i, | |
slides: n, | |
pages: s, | |
panzoom: a | |
} = this, r = s.length, l = n.length, c = n[0], d = n[l - 1], u = this.option('center'), m = 0, h = 0, b = 0, p = t === void 0 ? -1 * (a?.target[this.axis] || 0) : t; | |
u && (p += 0.5 * e); | |
this.isInfinite ? (p < c.pos - 0.5 * d.gap && (p -= i, b = -1), p > d.pos + d.dim + 0.5 * d.gap && (p -= i, b = 1)) : p = Math.max(c.pos || 0, Math.min(p, d.pos)); | |
let f = d, g = n.find(F => { | |
let v = F.pos - 0.5 * f.gap, B = F.pos + F.dim + 0.5 * F.gap; | |
return f = F, p >= v && p < B; | |
}); | |
return g || (g = d), h = this.getPageForSlide(g.index), m = h + b * r, { | |
page: m, | |
pageIndex: h | |
}; | |
} | |
setPageFromPosition() { | |
let {pageIndex: t} = this.getPageFromPosition(); | |
this.onChange(t); | |
} | |
destroy() { | |
if ([w.Destroy].includes(this.state)) { | |
return; | |
} | |
this.state = w.Destroy; | |
let { | |
container: t, | |
viewport: e, | |
track: i, | |
slides: n, | |
panzoom: s | |
} = this, a = this.option('classes'); | |
t.removeEventListener('click', this.onClick, { | |
passive: false, | |
capture: false | |
}); | |
t.removeEventListener('slideTo', this.onSlideTo); | |
window.removeEventListener('resize', this.onResize); | |
s && (s.destroy(), this.panzoom = null); | |
n && n.forEach(l => { | |
this.removeSlideEl(l); | |
}); | |
this.detachPlugins(); | |
e && (e.removeEventListener('scroll', this.onScroll), e.offsetParent && i && i.offsetParent && e.replaceWith(...i.childNodes)); | |
for (let [l, c] of Object.entries(a)) | |
l !== 'container' && c && t.classList.remove(c); | |
this.track = null; | |
this.viewport = null; | |
this.page = 0; | |
this.slides = []; | |
let r = this.events.get('ready'); | |
this.events = new Map(); | |
r && this.events.set('ready', r); | |
} | |
}; | |
Object.defineProperty(ct, 'Panzoom', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: nt | |
}); | |
Object.defineProperty(ct, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: Hn | |
}); | |
Object.defineProperty(ct, 'Plugins', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: Kn | |
}); | |
var Gi = function (o) { | |
if (!C(o)) { | |
return 0; | |
} | |
let t = window.scrollY, e = window.innerHeight, i = t + e, n = o.getBoundingClientRect(), s = n.y + t, a = n.height, r = s + a; | |
if (t > r || i < s) { | |
return 0; | |
} | |
if (t < s && i > r || s < t && r > i) { | |
return 100; | |
} | |
let l = a; | |
s < t && (l -= t - s); | |
r > i && (l -= r - i); | |
let c = l / e * 100; | |
return Math.round(c); | |
}, gt = !(typeof window > 'u' || !window.document || !window.document.createElement), Ae, We = [ | |
'a[href]', | |
'area[href]', | |
'input:not([disabled]):not([type="hidden"]):not([aria-hidden])', | |
'select:not([disabled]):not([aria-hidden])', | |
'textarea:not([disabled]):not([aria-hidden])', | |
'button:not([disabled]):not([aria-hidden]):not(.fancybox-focus-guard)', | |
'iframe', | |
'object', | |
'embed', | |
'video', | |
'audio', | |
'[contenteditable]', | |
'[tabindex]:not([tabindex^="-"]):not([disabled]):not([aria-hidden])' | |
].join(','), Fi = o => { | |
if (o && gt) { | |
Ae === void 0 && document.createElement('div').focus({ | |
get preventScroll() { | |
return Ae = true, false; | |
} | |
}); | |
try { | |
if (Ae) { | |
o.focus({ preventScroll: true }); | |
} else { | |
let t = window.scrollY || document.body.scrollTop, e = window.scrollX || document.body.scrollLeft; | |
o.focus(); | |
document.body.scrollTo({ | |
top: t, | |
left: e, | |
behavior: 'auto' | |
}); | |
} | |
} catch { | |
} | |
} | |
}, Vi = () => { | |
let o = document, t, e = '', i = '', n = ''; | |
return o.fullscreenEnabled ? (e = 'requestFullscreen', i = 'exitFullscreen', n = 'fullscreenElement') : o.webkitFullscreenEnabled && (e = 'webkitRequestFullscreen', i = 'webkitExitFullscreen', n = 'webkitFullscreenElement'), e && (t = { | |
request: function (s = o.documentElement) { | |
return e === 'webkitRequestFullscreen' ? s[e](Element.ALLOW_KEYBOARD_INPUT) : s[e](); | |
}, | |
exit: function () { | |
return o[n] && o[i](); | |
}, | |
isFullscreen: function () { | |
return o[n]; | |
} | |
}), t; | |
}, Ie = { | |
animated: true, | |
autoFocus: true, | |
backdropClick: 'close', | |
Carousel: { | |
classes: { | |
container: 'fancybox__carousel', | |
viewport: 'fancybox__viewport', | |
track: 'fancybox__track', | |
slide: 'fancybox__slide' | |
} | |
}, | |
closeButton: 'auto', | |
closeExisting: false, | |
commonCaption: false, | |
compact: () => window.matchMedia('(max-width: 578px), (max-height: 578px)').matches, | |
contentClick: 'toggleZoom', | |
contentDblClick: false, | |
defaultType: 'image', | |
defaultDisplay: 'flex', | |
dragToClose: true, | |
Fullscreen: { autoStart: false }, | |
groupAll: false, | |
groupAttr: 'data-fancybox', | |
hideClass: 'f-fadeOut', | |
hideScrollbar: true, | |
idle: 3500, | |
keyboard: { | |
Escape: 'close', | |
Delete: 'close', | |
Backspace: 'close', | |
PageUp: 'next', | |
PageDown: 'prev', | |
ArrowUp: 'prev', | |
ArrowDown: 'next', | |
ArrowRight: 'next', | |
ArrowLeft: 'prev' | |
}, | |
l10n: Object.assign(Object.assign({}, Xi), { | |
CLOSE: 'Close', | |
NEXT: 'Next', | |
PREV: 'Previous', | |
MODAL: 'You can close this modal content with the ESC key', | |
ERROR: 'Something Went Wrong, Please Try Again Later', | |
IMAGE_ERROR: 'Image Not Found', | |
ELEMENT_NOT_FOUND: 'HTML Element Not Found', | |
AJAX_NOT_FOUND: 'Error Loading AJAX : Not Found', | |
AJAX_FORBIDDEN: 'Error Loading AJAX : Forbidden', | |
IFRAME_ERROR: 'Error Loading Page', | |
TOGGLE_ZOOM: 'Toggle zoom level', | |
TOGGLE_THUMBS: 'Toggle thumbnails', | |
TOGGLE_SLIDESHOW: 'Toggle slideshow', | |
TOGGLE_FULLSCREEN: 'Toggle full-screen mode', | |
DOWNLOAD: 'Download' | |
}), | |
parentEl: null, | |
placeFocusBack: true, | |
showClass: 'f-zoomInUp', | |
startIndex: 0, | |
tpl: { | |
closeButton: '<button data-fancybox-close class="f-button is-close-btn" title="{{CLOSE}}"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" tabindex="-1"><path d="M20 20L4 4m16 0L4 20"/></svg></button>', | |
main: `<div class="fancybox__container" role="dialog" aria-modal="true" aria-label="{{MODAL}}" tabindex="-1"> | |
<div class="fancybox__backdrop"></div> | |
<div class="fancybox__carousel"></div> | |
<div class="fancybox__footer"></div> | |
</div>` | |
}, | |
trapFocus: true, | |
wheel: 'zoom' | |
}, A, Z; | |
(function (o) { | |
o[o.Init = 0] = 'Init'; | |
o[o.Ready = 1] = 'Ready'; | |
o[o.Closing = 2] = 'Closing'; | |
o[o.CustomClosing = 3] = 'CustomClosing'; | |
o[o.Destroy = 4] = 'Destroy'; | |
}(A || (A = {}))); | |
(function (o) { | |
o[o.Loading = 0] = 'Loading'; | |
o[o.Opening = 1] = 'Opening'; | |
o[o.Ready = 2] = 'Ready'; | |
o[o.Closing = 3] = 'Closing'; | |
}(Z || (Z = {}))); | |
var yi = '', ft = false, Yt = false, et = null, Ii = () => { | |
let o = '', t = '', e = M.getInstance(); | |
if (e) { | |
let i = e.carousel, n = e.getSlide(); | |
if (i && n) { | |
let s = n.slug || void 0, a = n.triggerEl || void 0; | |
t = s || e.option('slug') || ''; | |
!t && a && a.dataset && (t = a.dataset.fancybox || ''); | |
t && t !== 'true' && (o = '#' + t + (!s && i.slides.length > 1 ? '-' + (n.index + 1) : '')); | |
} | |
} | |
return { | |
hash: o, | |
slug: t, | |
index: 1 | |
}; | |
}, zt = () => { | |
let o = new URL(document.URL).hash, t = o.slice(1).split('-'), e = t[t.length - 1], i = e && /^\+?\d+$/.test(e) && parseInt(t.pop() || '1', 10) || 1; | |
return { | |
hash: o, | |
slug: t.join('-'), | |
index: i | |
}; | |
}, Si = () => { | |
let { | |
slug: o, | |
index: t | |
} = zt(); | |
if (!o) { | |
return; | |
} | |
let e = document.querySelector(`[data-slug="${ o }"]`); | |
if (e && e.dispatchEvent(new CustomEvent('click', { | |
bubbles: true, | |
cancelable: true | |
})), M.getInstance()) { | |
return; | |
} | |
let i = document.querySelectorAll(`[data-fancybox="${ o }"]`); | |
i.length && (e = i[t - 1], e && e.dispatchEvent(new CustomEvent('click', { | |
bubbles: true, | |
cancelable: true | |
}))); | |
}, zi = () => { | |
if (M.defaults.Hash === false) { | |
return; | |
} | |
let o = M.getInstance(); | |
if (o?.options.Hash === false) { | |
return; | |
} | |
let { | |
slug: t, | |
index: e | |
} = zt(), {slug: i} = Ii(); | |
o && (t === i ? o.jumpTo(e - 1) : (ft = true, o.close())); | |
Si(); | |
}, Ti = () => { | |
et && clearTimeout(et); | |
queueMicrotask(() => { | |
zi(); | |
}); | |
}, vi = () => { | |
window.addEventListener('hashchange', Ti, false); | |
setTimeout(() => { | |
zi(); | |
}, 500); | |
}; | |
gt && (/complete|interactive|loaded/.test(document.readyState) ? vi() : document.addEventListener('DOMContentLoaded', vi)); | |
var Tt = class extends D { | |
onCreateSlide(t, e, i) { | |
let n = this.instance.optionFor(i, 'src') || ''; | |
i.el && i.type === 'image' && typeof n == 'string' && this.setImage(i, n); | |
} | |
onRemoveSlide(t, e, i) { | |
i.panzoom && i.panzoom.destroy(); | |
i.panzoom = void 0; | |
i.imageEl = void 0; | |
} | |
onChange(t, e, i, n) { | |
x(this.instance.container, 'is-zooming-in'); | |
for (let s of e.slides) { | |
let a = s.panzoom; | |
a && s.index !== i && a.reset(0.35); | |
} | |
} | |
onClose() { | |
var t; | |
let e = this.instance, i = e.container, n = e.getSlide(); | |
if (!i || !i.parentElement || !n) { | |
return; | |
} | |
let { | |
el: s, | |
contentEl: a, | |
panzoom: r, | |
thumbElSrc: l | |
} = n; | |
if (!s || !l || !a || !r || r.isContentLoading || r.state === U.Init || r.state === U.Destroy) { | |
return; | |
} | |
r.updateMetrics(); | |
let c = this.getZoomInfo(n); | |
if (!c) { | |
return; | |
} | |
this.instance.state = A.CustomClosing; | |
i.classList.remove('is-zooming-in'); | |
i.classList.add('is-zooming-out'); | |
a.style.backgroundImage = `url('${ l }')`; | |
let d = i.getBoundingClientRect(); | |
(((t = window.visualViewport) === null || t === void 0 ? void 0 : t.scale) || 1) === 1 && Object.assign(i.style, { | |
position: 'absolute', | |
top: `${ i.offsetTop + window.scrollY }px`, | |
left: `${ i.offsetLeft + window.scrollX }px`, | |
bottom: 'auto', | |
right: 'auto', | |
width: `${ d.width }px`, | |
height: `${ d.height }px`, | |
overflow: 'hidden' | |
}); | |
let { | |
x: u, | |
y: m, | |
scale: h, | |
opacity: b | |
} = c; | |
if (b) { | |
let p = ((f, g, F, v) => { | |
let B = g - f, k = v - F; | |
return X => F + ((X - f) / B * k || 0); | |
})(r.scale, h, 1, 0); | |
r.on('afterTransform', () => { | |
a.style.opacity = p(r.scale) + ''; | |
}); | |
} | |
r.on('endAnimation', () => { | |
e.destroy(); | |
}); | |
r.target.a = h; | |
r.target.b = 0; | |
r.target.c = 0; | |
r.target.d = h; | |
r.panTo({ | |
x: u, | |
y: m, | |
scale: h, | |
friction: b ? 0.2 : 0.33, | |
ignoreBounds: true | |
}); | |
r.isResting && e.destroy(); | |
} | |
setImage(t, e) { | |
let i = this.instance; | |
; | |
this.process(t, e).then(n => { | |
let { | |
contentEl: s, | |
imageEl: a, | |
thumbElSrc: r, | |
el: l | |
} = t; | |
if (i.isClosing() || !s || !a) { | |
return; | |
} | |
s.offsetHeight; | |
let c = !!i.isOpeningSlide(t) && this.getZoomInfo(t); | |
if (this.option('protected') && l) { | |
l.addEventListener('contextmenu', m => { | |
m.preventDefault(); | |
}); | |
let u = document.createElement('div'); | |
y(u, 'fancybox-protected'); | |
s.appendChild(u); | |
} | |
if (r && c) { | |
let u = n.contentRect, m = Math.max(u.fullWidth, u.fullHeight), h = null; | |
!c.opacity && m > 1200 && (h = document.createElement('img'), y(h, 'fancybox-ghost'), h.src = r, s.appendChild(h)); | |
let b = () => { | |
h && (y(h, 'f-fadeFastOut'), setTimeout(() => { | |
h && (h.remove(), h = null); | |
}, 200)); | |
}; | |
(d = r, new Promise((p, f) => { | |
let g = new Image(); | |
g.onload = p; | |
g.onerror = f; | |
g.src = d; | |
})).then(() => { | |
i.hideLoading(t); | |
; | |
this.instance.emit('reveal', t); | |
this.zoomIn(t).then(() => { | |
b(); | |
this.instance.done(t); | |
}, () => { | |
}); | |
h && setTimeout(() => { | |
b(); | |
}, m > 2500 ? 800 : 200); | |
}, () => { | |
i.hideLoading(t); | |
i.revealContent(t); | |
}); | |
} else { | |
let u = this.optionFor(t, 'initialSize'), m = this.optionFor(t, 'zoom'), h = { | |
event: i.prevMouseMoveEvent || i.options.event, | |
friction: m ? 0.12 : 0 | |
}, b = i.optionFor(t, 'showClass') || void 0, p = true; | |
i.isOpeningSlide(t) && (u === 'full' ? n.zoomToFull(h) : u === 'cover' ? n.zoomToCover(h) : u === 'max' ? n.zoomToMax(h) : p = false, n.stop('current')); | |
p && b && (b = n.isDragging ? 'f-fadeIn' : ''); | |
i.hideLoading(t); | |
i.revealContent(t, b); | |
} | |
var d; | |
}, () => { | |
i.setError(t, '{{IMAGE_ERROR}}'); | |
}); | |
} | |
process(t, e) { | |
return new Promise((i, n) => { | |
var s; | |
let a = this.instance, r = t.el; | |
a.clearContent(t); | |
a.showLoading(t); | |
let l = this.optionFor(t, 'content'); | |
if (typeof l == 'string' && (l = S(l)), !l || !C(l)) { | |
if (l = document.createElement('img'), l instanceof HTMLImageElement) { | |
let c = '', d = t.caption; | |
c = typeof d == 'string' && d ? d.replace(/<[^>]+>/gi, '').substring(0, 1000) : `Image ${ t.index + 1 } of ${ ((s = a.carousel) === null || s === void 0 ? void 0 : s.pages.length) || 1 }`; | |
l.src = e || ''; | |
l.alt = c; | |
l.draggable = false; | |
t.srcset && l.setAttribute('srcset', t.srcset); | |
this.instance.isOpeningSlide(t) && (l.fetchPriority = 'high'); | |
} | |
t.sizes && l.setAttribute('sizes', t.sizes); | |
} | |
y(l, 'fancybox-image'); | |
; | |
a.setContent(t, l, false); | |
; | |
}); | |
} | |
zoomIn(t) { | |
return new Promise((e, i) => { | |
let n = this.instance, s = n.container, { | |
panzoom: a, | |
contentEl: r, | |
el: l | |
} = t; | |
a && a.updateMetrics(); | |
let c = this.getZoomInfo(t); | |
if (!(c && l && r && a && s)) { | |
return void i(); | |
} | |
let { | |
x: d, | |
y: u, | |
scale: m, | |
opacity: h | |
} = c, b = () => { | |
t.state !== Z.Closing && (h && (r.style.opacity = Math.max(Math.min(1, 1 - (1 - a.scale) / (1 - m)), 0) + ''), a.scale >= 1 && a.scale > a.targetScale - 0.1 && e(a)); | |
}, p = F => { | |
(F.scale < 0.99 || F.scale > 1.01) && !F.isDragging || (x(s, 'is-zooming-in'), r.style.opacity = '', F.off('endAnimation', p), F.off('touchStart', p), F.off('afterTransform', b), e(F)); | |
}; | |
a.on('endAnimation', p); | |
a.on('touchStart', p); | |
a.on('afterTransform', b); | |
a.on([ | |
'error', | |
'destroy' | |
], () => { | |
i(); | |
}); | |
a.panTo({ | |
x: d, | |
y: u, | |
scale: m, | |
friction: 0, | |
ignoreBounds: true | |
}); | |
a.stop('current'); | |
let f = { event: a.panMode === 'mousemove' ? n.prevMouseMoveEvent || n.options.event : void 0 }, g = this.optionFor(t, 'initialSize'); | |
y(s, 'is-zooming-in'); | |
n.hideLoading(t); | |
g === 'full' ? a.zoomToFull(f) : g === 'cover' ? a.zoomToCover(f) : g === 'max' ? a.zoomToMax(f) : a.reset(0.172); | |
}); | |
} | |
getZoomInfo(t) { | |
let { | |
el: e, | |
imageEl: i, | |
thumbEl: n, | |
panzoom: s | |
} = t, a = this.instance, r = a.container; | |
if (!e || !i || !n || !s || Gi(n) < 3 || !this.optionFor(t, 'zoom') || !r || a.state === A.Destroy || getComputedStyle(r).getPropertyValue('--f-images-zoom') === '0') { | |
return false; | |
} | |
let l = window.visualViewport || null; | |
if ((l ? l.scale : 1) !== 1) { | |
return false; | |
} | |
let { | |
top: c, | |
left: d, | |
width: u, | |
height: m | |
} = n.getBoundingClientRect(), { | |
top: h, | |
left: b, | |
fitWidth: p, | |
fitHeight: f | |
} = s.contentRect; | |
if (!(u && m && p && f)) { | |
return false; | |
} | |
let g = s.container.getBoundingClientRect(); | |
b += g.left; | |
h += g.top; | |
let F = -1 * (b + 0.5 * p - (d + 0.5 * u)), v = -1 * (h + 0.5 * f - (c + 0.5 * m)), B = u / p, k = this.option('zoomOpacity') || false; | |
return k === 'auto' && (k = Math.abs(u / m - p / f) > 0.1), { | |
x: F, | |
y: v, | |
scale: B, | |
opacity: k | |
}; | |
} | |
attach() { | |
let t = this, e = t.instance; | |
e.on('Carousel.change', t.onChange); | |
e.on('Carousel.createSlide', t.onCreateSlide); | |
e.on('Carousel.removeSlide', t.onRemoveSlide); | |
e.on('close', t.onClose); | |
} | |
detach() { | |
let t = this, e = t.instance; | |
e.off('Carousel.change', t.onChange); | |
e.off('Carousel.createSlide', t.onCreateSlide); | |
e.off('Carousel.removeSlide', t.onRemoveSlide); | |
e.off('close', t.onClose); | |
} | |
}; | |
Object.defineProperty(Tt, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
initialSize: 'fit', | |
Panzoom: { maxScale: 1 }, | |
protected: false, | |
zoom: true, | |
zoomOpacity: 'auto' | |
} | |
}); | |
typeof SuppressedError == 'function' && SuppressedError; | |
var xi = (o, t = {}) => { | |
let e = new URL(o), i = new URLSearchParams(e.search), n = new URLSearchParams(); | |
for (let [r, l] of [ | |
...i, | |
...Object.entries(t) | |
]) { | |
let c = l + ''; | |
if (r === 't') { | |
let d = c.match(/((\d*)m)?(\d*)s?/); | |
d && n.set('start', 60 * parseInt(d[2] || '0') + parseInt(d[3] || '0') + ''); | |
} else { | |
n.set(r, c); | |
} | |
} | |
let s = n + '', a = o.match(/#t=((.*)?\d+s)/); | |
return a && (s += `#t=${ a[1] }`), s; | |
}, qn = { | |
ajax: null, | |
autoSize: true, | |
iframeAttr: { | |
allow: 'autoplay; fullscreen', | |
scrolling: 'auto' | |
}, | |
preload: true, | |
videoAutoplay: true, | |
videoRatio: 1.7777777777777777, | |
videoTpl: `<video class="fancybox__html5video" playsinline controls controlsList="nodownload" poster="{{poster}}"> | |
<source src="{{src}}" type="{{format}}" />Sorry, your browser doesn't support embedded videos.</video>`, | |
videoFormat: '', | |
vimeo: { | |
byline: 1, | |
color: '00adef', | |
controls: 1, | |
dnt: 1, | |
muted: 0 | |
}, | |
youtube: { | |
controls: 1, | |
enablejsapi: 1, | |
nocookie: 1, | |
rel: 0, | |
fs: 1 | |
} | |
}, $n = [ | |
'image', | |
'html', | |
'ajax', | |
'inline', | |
'clone', | |
'iframe', | |
'map', | |
'pdf', | |
'html5video', | |
'youtube', | |
'vimeo' | |
], jt = class extends D { | |
onBeforeInitSlide(t, e, i) { | |
this.processType(i); | |
} | |
onCreateSlide(t, e, i) { | |
this.setContent(i); | |
} | |
onClearContent(t, e) { | |
e.xhr && (e.xhr.abort(), e.xhr = null); | |
let i = e.iframeEl; | |
i && (i.onload = i.onerror = null, i.src = '//about:blank', e.iframeEl = null); | |
let n = e.contentEl, s = e.placeholderEl; | |
if (e.type === 'inline' && n && s) { | |
n.classList.remove('fancybox__content'); | |
getComputedStyle(n).getPropertyValue('display') !== 'none' && (n.style.display = 'none'); | |
setTimeout(() => { | |
s && (n && s.parentNode && s.parentNode.insertBefore(n, s), s.remove()); | |
}, 0); | |
e.contentEl = void 0; | |
e.placeholderEl = void 0; | |
} else { | |
for (; e.el && e.el.firstChild;) { | |
e.el.removeChild(e.el.firstChild); | |
} | |
} | |
} | |
onSelectSlide(t, e, i) { | |
i.state === Z.Ready && this.playVideo(); | |
} | |
onUnselectSlide(t, e, i) { | |
var n, s; | |
if (i.type === 'html5video') { | |
try { | |
(s = (n = i.el) === null || n === void 0 ? void 0 : n.querySelector('video')) === null || s === void 0 || s.pause(); | |
} catch { | |
} | |
return; | |
} | |
let a; | |
i.type === 'vimeo' ? a = { | |
method: 'pause', | |
value: 'true' | |
} : i.type === 'youtube' && (a = { | |
event: 'command', | |
func: 'pauseVideo' | |
}); | |
a && i.iframeEl && i.iframeEl.contentWindow && i.iframeEl.contentWindow.postMessage(JSON.stringify(a), '*'); | |
i.poller && clearTimeout(i.poller); | |
} | |
onDone(t, e) { | |
t.isCurrentSlide(e) && !t.isClosing() && this.playVideo(); | |
} | |
onRefresh(t, e) { | |
e.slides.forEach(i => { | |
i.el && (this.resizeIframe(i), this.setAspectRatio(i)); | |
}); | |
} | |
onMessage(t) { | |
try { | |
let e = JSON.parse(t.data); | |
if (t.origin === 'https://player.vimeo.com') { | |
if (e.event === 'ready') { | |
for (let i of Array.from(document.getElementsByClassName('fancybox__iframe'))) | |
i instanceof HTMLIFrameElement && i.contentWindow === t.source && (i.dataset.ready = 'true'); | |
} | |
} else { | |
if (t.origin.match(/^https:\/\/(www.)?youtube(-nocookie)?.com$/) && e.event === 'onReady') { | |
let i = document.getElementById(e.id); | |
i && (i.dataset.ready = 'true'); | |
} | |
} | |
} catch { | |
} | |
} | |
loadAjaxContent(t) { | |
let e = this.instance.optionFor(t, 'src') || ''; | |
this.instance.showLoading(t); | |
let i = this.instance, n = new XMLHttpRequest(); | |
i.showLoading(t); | |
n.onreadystatechange = function () { | |
n.readyState === XMLHttpRequest.DONE && i.state === A.Ready && (i.hideLoading(t), n.status === 200 ? i.setContent(t, n.responseText) : i.setError(t, n.status === 404 ? '{{AJAX_NOT_FOUND}}' : '{{AJAX_FORBIDDEN}}')); | |
}; | |
let s = t.ajax || null; | |
n.open(s ? 'POST' : 'GET', e + ''); | |
n.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); | |
n.setRequestHeader('X-Requested-With', 'XMLHttpRequest'); | |
n.send(s); | |
; | |
} | |
setInlineContent(t) { | |
let e = null; | |
if (C(t.src)) { | |
e = t.src; | |
} else { | |
if (typeof t.src == 'string') { | |
let i = t.src.split('#', 2).pop(); | |
e = i ? document.getElementById(i) : null; | |
} | |
} | |
if (e) { | |
if (t.type === 'clone' || e.closest('.fancybox__slide')) { | |
e = e.cloneNode(true); | |
let i = e.dataset.animationName; | |
i && (e.classList.remove(i), delete e.dataset.animationName); | |
let n = e.getAttribute('id'); | |
n = n ? `${ n }--clone` : `clone-${ this.instance.id }-${ t.index }`; | |
e.setAttribute('id', n); | |
} else { | |
if (e.parentNode) { | |
let i = document.createElement('div'); | |
i.classList.add('fancybox-placeholder'); | |
e.parentNode.insertBefore(i, e); | |
; | |
} | |
} | |
this.instance.setContent(t, e); | |
} else { | |
this.instance.setError(t, '{{ELEMENT_NOT_FOUND}}'); | |
} | |
} | |
setIframeContent(t) { | |
let { | |
src: e, | |
el: i | |
} = t; | |
if (!e || typeof e != 'string' || !i) { | |
return; | |
} | |
i.classList.add('is-loading'); | |
let n = this.instance, s = document.createElement('iframe'); | |
s.className = 'fancybox__iframe'; | |
s.setAttribute('id', `fancybox__iframe_${ n.id }_${ t.index }`); | |
for (let [r, l] of Object.entries(this.optionFor(t, 'iframeAttr') || {})) | |
s.setAttribute(r, l); | |
s.onerror = () => { | |
n.setError(t, '{{IFRAME_ERROR}}'); | |
}; | |
; | |
let a = this.optionFor(t, 'preload'); | |
if (t.type !== 'iframe' || a === false) { | |
return s.setAttribute('src', t.src + ''), n.setContent(t, s, false), this.resizeIframe(t), void n.revealContent(t); | |
} | |
n.showLoading(t); | |
s.onload = () => { | |
if (!s.src.length) { | |
return; | |
} | |
let r = s.dataset.ready !== 'true'; | |
s.dataset.ready = 'true'; | |
this.resizeIframe(t); | |
r ? n.revealContent(t) : n.hideLoading(t); | |
}; | |
s.setAttribute('src', e); | |
n.setContent(t, s, false); | |
} | |
resizeIframe(t) { | |
let { | |
type: e, | |
iframeEl: i | |
} = t; | |
if (e === 'youtube' || e === 'vimeo') { | |
return; | |
} | |
let n = i?.parentElement; | |
if (!i || !n) { | |
return; | |
} | |
let s = t.autoSize; | |
s === void 0 && (s = this.optionFor(t, 'autoSize')); | |
let a = t.width || 0, r = t.height || 0; | |
a && r && (s = false); | |
let l = n && n.style; | |
if (t.preload !== false && s !== false && l) { | |
try { | |
let c = window.getComputedStyle(n), d = parseFloat(c.paddingLeft) + parseFloat(c.paddingRight), u = parseFloat(c.paddingTop) + parseFloat(c.paddingBottom), m = i.contentWindow; | |
if (m) { | |
let h = m.document, b = h.getElementsByTagName('html')[0], p = h.body; | |
l.width = ''; | |
p.style.overflow = 'hidden'; | |
a = a || b.scrollWidth + d; | |
l.width = `${ a }px`; | |
p.style.overflow = ''; | |
l.flex = '0 0 auto'; | |
l.height = `${ p.scrollHeight }px`; | |
r = b.scrollHeight + u; | |
} | |
} catch { | |
} | |
} | |
if (a || r) { | |
; | |
a && a !== 'auto' && ('' = `${ a }px`); | |
r && r !== 'auto' && ('' = `${ r }px`); | |
Object.assign(l, c); | |
} | |
} | |
playVideo() { | |
let t = this.instance.getSlide(); | |
if (!t) { | |
return; | |
} | |
let {el: e} = t; | |
if (!e || !e.offsetParent || !this.optionFor(t, 'videoAutoplay')) { | |
return; | |
} | |
if (t.type === 'html5video') { | |
try { | |
let n = e.querySelector('video'); | |
if (n) { | |
let s = n.play(); | |
s !== void 0 && s.then(() => { | |
}).catch(a => { | |
n.muted = true; | |
n.play(); | |
}); | |
} | |
} catch { | |
} | |
} | |
if (t.type !== 'youtube' && t.type !== 'vimeo') { | |
return; | |
} | |
let i = () => { | |
if (t.iframeEl && t.iframeEl.contentWindow) { | |
let n; | |
if (t.iframeEl.dataset.ready === 'true') { | |
return n = t.type === 'youtube' ? { | |
event: 'command', | |
func: 'playVideo' | |
} : { | |
method: 'play', | |
value: 'true' | |
}, n && t.iframeEl.contentWindow.postMessage(JSON.stringify(n), '*'), void (t.poller = void 0); | |
} | |
t.type === 'youtube' && (n = { | |
event: 'listening', | |
id: t.iframeEl.getAttribute('id') | |
}, t.iframeEl.contentWindow.postMessage(JSON.stringify(n), '*')); | |
} | |
; | |
}; | |
i(); | |
} | |
processType(t) { | |
if (t.html) { | |
return t.type = 'html', t.src = t.html, void (t.html = ''); | |
} | |
let e = this.instance.optionFor(t, 'src', ''); | |
if (!e || typeof e != 'string') { | |
return; | |
} | |
let i = t.type, n = null; | |
if (n = e.match(/(youtube\.com|youtu\.be|youtube\-nocookie\.com)\/(?:watch\?(?:.*&)?v=|v\/|u\/|shorts\/|embed\/?)?(videoseries\?list=(?:.*)|[\w-]{11}|\?listType=(?:.*)&list=(?:.*))(?:.*)/i)) { | |
let s = this.optionFor(t, 'youtube'), {nocookie: a} = s, r = function (u, m) { | |
var h = { tabIndex: -1 }; | |
for (var b in u) | |
Object.prototype.hasOwnProperty.call(u, b) && m.indexOf(b) < 0 && (h[b] = u[b]); | |
if (u != null && typeof Object.getOwnPropertySymbols == 'function') { | |
var p = 0; | |
for (b = Object.getOwnPropertySymbols(u); p < b.length; p++) { | |
m.indexOf(b[p]) < 0 && Object.prototype.propertyIsEnumerable.call(u, b[p]) && (h[b[p]] = u[b[p]]); | |
} | |
} | |
return h; | |
}(s, ['nocookie']), l = `www.youtube${ a ? '-nocookie' : '' }.com`, c = xi(e, r), d = encodeURIComponent(n[2]); | |
; | |
; | |
; | |
i = 'youtube'; | |
} else { | |
if (n = e.match(/^.+vimeo.com\/(?:\/)?([\d]+)((\/|\?h=)([a-z0-9]+))?(.*)?/)) { | |
let s = xi(e, this.optionFor(t, 'vimeo')), a = encodeURIComponent(n[1]), r = n[4] || ''; | |
; | |
; | |
i = 'vimeo'; | |
} | |
} | |
if (!i && t.triggerEl) { | |
let s = t.triggerEl.dataset.type; | |
$n.includes(s) && (i = s); | |
} | |
i || typeof e == 'string' && (e.charAt(0) === '#' ? i = 'inline' : (n = e.match(/\.(mp4|mov|ogv|webm)((\?|#).*)?$/i)) ? (i = 'html5video', t.videoFormat = t.videoFormat || 'video/' + (n[1] === 'ogv' ? 'ogg' : n[1])) : e.match(/(^data:image\/[a-z0-9+\/=]*,)|(\.(jp(e|g|eg)|gif|png|bmp|webp|svg|ico)((\?|#).*)?$)/i) ? i = 'image' : e.match(/\.(pdf)((\?|#).*)?$/i) && (i = 'pdf')); | |
(n = e.match(/(?:maps\.)?google\.([a-z]{2,3}(?:\.[a-z]{2})?)\/(?:(?:(?:maps\/(?:place\/(?:.*)\/)?\@(.*),(\d+.?\d+?)z))|(?:\?ll=))(.*)?/i)) ? (t.src = `https://maps.google.${ n[1] }/?ll=${ (n[2] ? n[2] + '&z=' + Math.floor(parseFloat(n[3])) + (n[4] ? n[4].replace(/^\//, '&') : '') : n[4] + '').replace(/\?/, '&') }&output=${ n[4] && n[4].indexOf('layer=c') > 0 ? 'svembed' : 'embed' }`, i = 'map') : (n = e.match(/(?:maps\.)?google\.([a-z]{2,3}(?:\.[a-z]{2})?)\/(?:maps\/search\/)(.*)/i)) && (t.src = `https://maps.google.${ n[1] }/maps?q=${ n[2].replace('query=', 'q=').replace('api=1', '') }&output=embed`, i = 'map'); | |
i = i || this.instance.option('defaultType'); | |
; | |
i === 'image' && (t.thumbSrc = t.thumbSrc || t.src); | |
} | |
setContent(t) { | |
let e = this.instance.optionFor(t, 'src') || ''; | |
if (t && t.type && e) { | |
switch (t.type) { | |
case 'html': | |
this.instance.setContent(t, e); | |
break; | |
case 'html5video': | |
let i = this.option('videoTpl'); | |
i && this.instance.setContent(t, i.replace(/\{\{src\}\}/gi, e + '').replace(/\{\{format\}\}/gi, this.optionFor(t, 'videoFormat') || '').replace(/\{\{poster\}\}/gi, t.poster || t.thumbSrc || '')); | |
break; | |
case 'inline': | |
case 'clone': | |
this.setInlineContent(t); | |
break; | |
case 'ajax': | |
this.loadAjaxContent(t); | |
break; | |
case 'pdf': | |
case 'map': | |
case 'youtube': | |
case 'vimeo': | |
; | |
case 'iframe': | |
this.setIframeContent(t); | |
} | |
this.setAspectRatio(t); | |
} | |
} | |
setAspectRatio(t) { | |
let e = t.contentEl; | |
if (!(t.el && e && t.type && [ | |
'youtube', | |
'vimeo', | |
'html5video' | |
].includes(t.type))) { | |
return; | |
} | |
let i, n = t.width || 'auto', s = t.height || 'auto'; | |
if (n === 'auto' || s === 'auto') { | |
i = this.optionFor(t, 'videoRatio'); | |
let c = (i + '').match(/(\d+)\s*\/\s?(\d+)/); | |
i = c && c.length > 2 ? parseFloat(c[1]) / parseFloat(c[2]) : parseFloat(i + ''); | |
} else { | |
n && s && (i = n / s); | |
} | |
if (!i) { | |
return; | |
} | |
e.style.aspectRatio = ''; | |
e.style.width = ''; | |
e.style.height = ''; | |
e.offsetHeight; | |
let a = e.getBoundingClientRect(), r = a.width || 1, l = a.height || 1; | |
e.style.aspectRatio = i + ''; | |
i < r / l ? (s = s === 'auto' ? l : Math.min(l, s), e.style.width = 'auto', e.style.height = `${ s }px`) : (n = n === 'auto' ? r : Math.min(r, n), e.style.width = `${ n }px`, e.style.height = 'auto'); | |
} | |
attach() { | |
let t = this, e = t.instance; | |
e.on('Carousel.beforeInitSlide', t.onBeforeInitSlide); | |
e.on('Carousel.createSlide', t.onCreateSlide); | |
e.on('Carousel.selectSlide', t.onSelectSlide); | |
e.on('Carousel.unselectSlide', t.onUnselectSlide); | |
e.on('Carousel.Panzoom.refresh', t.onRefresh); | |
e.on('done', t.onDone); | |
e.on('clearContent', t.onClearContent); | |
window.addEventListener('message', t.onMessage); | |
} | |
detach() { | |
let t = this, e = t.instance; | |
e.off('Carousel.beforeInitSlide', t.onBeforeInitSlide); | |
e.off('Carousel.createSlide', t.onCreateSlide); | |
e.off('Carousel.selectSlide', t.onSelectSlide); | |
e.off('Carousel.unselectSlide', t.onUnselectSlide); | |
e.off('Carousel.Panzoom.refresh', t.onRefresh); | |
e.off('done', t.onDone); | |
e.off('clearContent', t.onClearContent); | |
window.removeEventListener('message', t.onMessage); | |
} | |
}; | |
Object.defineProperty(jt, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: qn | |
}); | |
var Jt = class extends D { | |
constructor() { | |
super(...arguments); | |
Object.defineProperty(this, 'state', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 'ready' | |
}); | |
Object.defineProperty(this, 'inHover', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}); | |
Object.defineProperty(this, 'timer', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'progressBar', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
} | |
get isActive() { | |
return this.state !== 'ready'; | |
} | |
onReady(t) { | |
this.option('autoStart') && (t.isInfinite || t.page < t.pages.length - 1) && this.start(); | |
} | |
onChange() { | |
this.removeProgressBar(); | |
this.pause(); | |
} | |
onSettle() { | |
this.resume(); | |
} | |
onVisibilityChange() { | |
document.visibilityState === 'visible' ? this.resume() : this.pause(); | |
} | |
onMouseEnter() { | |
this.inHover = true; | |
this.pause(); | |
} | |
onMouseLeave() { | |
var t; | |
this.inHover = false; | |
!((t = this.instance.panzoom) === null || t === void 0) && t.isResting && this.resume(); | |
} | |
onTimerEnd() { | |
let t = this.instance; | |
this.state === 'play' && (t.isInfinite || t.page !== t.pages.length - 1 ? t.slideNext() : t.slideTo(0)); | |
} | |
removeProgressBar() { | |
this.progressBar && (this.progressBar.remove(), this.progressBar = null); | |
} | |
createProgressBar() { | |
var t; | |
if (!this.option('showProgress')) { | |
return null; | |
} | |
this.removeProgressBar(); | |
let e = this.instance, i = ((t = e.pages[e.page]) === null || t === void 0 ? void 0 : t.slides) || [], n = this.option('progressParentEl'); | |
if (n || (n = (i.length === 1 ? i[0].el : null) || e.viewport), !n) { | |
return null; | |
} | |
let s = document.createElement('div'); | |
return y(s, 'f-progress'), n.prepend(s), this.progressBar = s, s.offsetHeight, s; | |
} | |
set() { | |
let t = this, e = t.instance; | |
if (e.pages.length < 2 || t.timer) { | |
return; | |
} | |
let i = t.option('timeout'); | |
; | |
y(e.container, 'has-autoplay'); | |
let n = t.createProgressBar(); | |
n && (n.style.transitionDuration = `${ i }ms`, n.style.transform = 'scaleX(1)'); | |
; | |
t.emit('set'); | |
} | |
clear() { | |
let t = this; | |
t.timer && (clearTimeout(t.timer), t.timer = null); | |
t.removeProgressBar(); | |
} | |
start() { | |
let t = this; | |
if (t.set(), t.state !== 'ready') { | |
if (t.option('pauseOnHover')) { | |
let e = t.instance.container; | |
e.addEventListener('mouseenter', t.onMouseEnter, false); | |
e.addEventListener('mouseleave', t.onMouseLeave, false); | |
} | |
document.addEventListener('visibilitychange', t.onVisibilityChange, false); | |
t.emit('start'); | |
} | |
} | |
stop() { | |
let t = this, e = t.state, i = t.instance.container; | |
t.clear(); | |
; | |
i.removeEventListener('mouseenter', t.onMouseEnter, false); | |
i.removeEventListener('mouseleave', t.onMouseLeave, false); | |
document.removeEventListener('visibilitychange', t.onVisibilityChange, false); | |
x(i, 'has-autoplay'); | |
e !== 'ready' && t.emit('stop'); | |
} | |
pause() { | |
let t = this; | |
t.state === 'play' && (t.state = 'pause', t.clear(), t.emit('pause')); | |
} | |
resume() { | |
let t = this, e = t.instance; | |
if (e.isInfinite || e.page !== e.pages.length - 1) { | |
if (t.state !== 'play') { | |
if (t.state === 'pause' && !t.inHover) { | |
let i = new Event('resume', { | |
bubbles: true, | |
cancelable: true | |
}); | |
t.emit('resume', i); | |
i.defaultPrevented || t.set(); | |
} | |
} else { | |
t.set(); | |
} | |
} else { | |
t.stop(); | |
} | |
} | |
toggle() { | |
this.state === 'play' || this.state === 'pause' ? this.stop() : this.start(); | |
} | |
attach() { | |
let t = this, e = t.instance; | |
e.on('ready', t.onReady); | |
e.on('Panzoom.startAnimation', t.onChange); | |
e.on('Panzoom.endAnimation', t.onSettle); | |
e.on('Panzoom.touchMove', t.onChange); | |
} | |
detach() { | |
let t = this, e = t.instance; | |
e.off('ready', t.onReady); | |
e.off('Panzoom.startAnimation', t.onChange); | |
e.off('Panzoom.endAnimation', t.onSettle); | |
e.off('Panzoom.touchMove', t.onChange); | |
t.stop(); | |
} | |
}; | |
Object.defineProperty(Jt, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
autoStart: true, | |
pauseOnHover: true, | |
progressParentEl: null, | |
showProgress: true, | |
timeout: 3000 | |
} | |
}); | |
var Ht = class extends D { | |
constructor() { | |
super(...arguments); | |
Object.defineProperty(this, 'ref', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
} | |
onPrepare(t) { | |
let e = t.carousel; | |
if (!e) { | |
return; | |
} | |
let i = t.container; | |
i && (e.options.Autoplay = E({ autoStart: false }, this.option('Autoplay') || {}, { | |
pauseOnHover: false, | |
timeout: this.option('timeout'), | |
progressParentEl: () => this.option('progressParentEl') || null, | |
on: { | |
start: () => { | |
t.emit('startSlideshow'); | |
}, | |
set: n => { | |
var s; | |
i.classList.add('has-slideshow'); | |
((s = t.getSlide()) === null || s === void 0 ? void 0 : s.state) !== Z.Ready && n.pause(); | |
}, | |
stop: () => { | |
i.classList.remove('has-slideshow'); | |
t.isCompact || t.endIdle(); | |
t.emit('endSlideshow'); | |
}, | |
resume: (n, s) => { | |
var a, r, l; | |
!s || !s.cancelable || ((a = t.getSlide()) === null || a === void 0 ? void 0 : a.state) === Z.Ready && (!((l = (r = t.carousel) === null || r === void 0 ? void 0 : r.panzoom) === null || l === void 0) && l.isResting) || s.preventDefault(); | |
} | |
} | |
}), e.attachPlugins({ Autoplay: Jt }), this.ref = e.plugins.Autoplay); | |
} | |
onReady(t) { | |
let e = t.carousel, i = this.ref; | |
i && e && this.option('playOnStart') && (e.isInfinite || e.page < e.pages.length - 1) && i.start(); | |
} | |
onDone(t, e) { | |
let i = this.ref, n = t.carousel; | |
if (!i || !n) { | |
return; | |
} | |
let s = e.panzoom; | |
s && s.on('startAnimation', () => { | |
t.isCurrentSlide(e) && i.stop(); | |
}); | |
t.isCurrentSlide(e) && i.resume(); | |
} | |
onKeydown(t, e) { | |
var i; | |
let n = this.ref; | |
n && e === this.option('key') && ((i = document.activeElement) === null || i === void 0 ? void 0 : i.nodeName) !== 'BUTTON' && n.toggle(); | |
} | |
attach() { | |
let t = this, e = t.instance; | |
e.on('Carousel.init', t.onPrepare); | |
e.on('Carousel.ready', t.onReady); | |
e.on('done', t.onDone); | |
e.on('keydown', t.onKeydown); | |
} | |
detach() { | |
let t = this, e = t.instance; | |
e.off('Carousel.init', t.onPrepare); | |
e.off('Carousel.ready', t.onReady); | |
e.off('done', t.onDone); | |
e.off('keydown', t.onKeydown); | |
} | |
}; | |
Object.defineProperty(Ht, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: { | |
key: ' ', | |
playOnStart: false, | |
progressParentEl: o => { | |
var t; | |
return ((t = o.instance.container) === null || t === void 0 ? void 0 : t.querySelector('.fancybox__toolbar [data-fancybox-toggle-slideshow]')) || o.instance.container; | |
}, | |
timeout: 3000 | |
} | |
}); | |
var ji = { | |
classes: { | |
container: 'f-thumbs f-carousel__thumbs', | |
viewport: 'f-thumbs__viewport', | |
track: 'f-thumbs__track', | |
slide: 'f-thumbs__slide', | |
isResting: 'is-resting', | |
isSelected: 'is-selected', | |
isLoading: 'is-loading', | |
hasThumbs: 'has-thumbs' | |
}, | |
minCount: 2, | |
parentEl: null, | |
thumbTpl: '<button class="f-thumbs__slide__button" tabindex="0" type="button" aria-label="{{GOTO}}" data-carousel-index="%i"><img class="f-thumbs__slide__img" data-lazy-src="{{%s}}" alt="" /></button>', | |
type: 'modern' | |
}, H; | |
(function (o) { | |
o[o.Init = 0] = 'Init'; | |
o[o.Ready = 1] = 'Ready'; | |
o[o.Hidden = 2] = 'Hidden'; | |
}(H || (H = {}))); | |
var Ji = class extends D { | |
constructor() { | |
super(...arguments); | |
Object.defineProperty(this, 'type', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 'modern' | |
}); | |
Object.defineProperty(this, 'container', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'track', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'carousel', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'thumbWidth', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}); | |
Object.defineProperty(this, 'thumbClipWidth', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}); | |
Object.defineProperty(this, 'thumbHeight', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}); | |
Object.defineProperty(this, 'thumbGap', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}); | |
Object.defineProperty(this, 'thumbExtraGap', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}); | |
Object.defineProperty(this, 'state', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: H.Init | |
}); | |
} | |
get isModern() { | |
return this.type === 'modern'; | |
} | |
onInitSlide(o, t) { | |
let e = t.el ? t.el.dataset : void 0; | |
e && (t.thumbSrc = e.thumbSrc || t.thumbSrc || '', t.thumbClipWidth = parseFloat(e.thumbClipWidth || '') || t.thumbClipWidth || 0, t.thumbHeight = parseFloat(e.thumbHeight || '') || t.thumbHeight || 0); | |
this.addSlide(t); | |
} | |
onInitSlides() { | |
this.build(); | |
} | |
onChange() { | |
var o; | |
if (!this.isModern) { | |
return; | |
} | |
let t = this.container, e = this.instance, i = e.panzoom, n = this.carousel, s = n ? n.panzoom : null, a = e.page; | |
if (i && n && s) { | |
if (i.isDragging) { | |
x(t, this.cn('isResting')); | |
let r = ((o = n.pages[a]) === null || o === void 0 ? void 0 : o.pos) || 0; | |
r += e.getProgress(a) * (this.thumbClipWidth + this.thumbGap); | |
let l = s.getBounds(); | |
-1 * r > l.x.min && -1 * r < l.x.max && s.panTo({ | |
x: -1 * r, | |
friction: 0.12 | |
}); | |
} else { | |
z(t, this.cn('isResting'), i.isResting); | |
} | |
this.shiftModern(); | |
} | |
} | |
onRefresh() { | |
this.updateProps(); | |
for (let o of this.instance.slides || []) | |
this.resizeModernSlide(o); | |
this.shiftModern(); | |
} | |
isDisabled() { | |
let o = this.option('minCount') || 0; | |
if (o) { | |
let e = this.instance, i = 0; | |
for (let n of e.slides || []) | |
n.thumbSrc && i++; | |
if (i < o) { | |
return true; | |
} | |
} | |
let t = this.option('type'); | |
return [ | |
'modern', | |
'classic' | |
].indexOf(t) < 0; | |
} | |
getThumb(o) { | |
let t = this.option('thumbTpl') || ''; | |
return { | |
html: this.instance.localize(t, [ | |
[ | |
'%i', | |
o.index | |
], | |
[ | |
'%d', | |
o.index + 1 | |
], | |
[ | |
'%s', | |
o.thumbSrc || '' | |
] | |
]) | |
}; | |
} | |
addSlide(o) { | |
let t = this.carousel; | |
t && t.addSlide(o.index, this.getThumb(o)); | |
} | |
getSlides() { | |
let o = []; | |
for (let t of this.instance.slides || []) | |
o.push(this.getThumb(t)); | |
return o; | |
} | |
resizeModernSlide(o) { | |
this.isModern && (o.thumbWidth = o.thumbClipWidth && o.thumbHeight ? Math.round(this.thumbHeight * (o.thumbClipWidth / o.thumbHeight)) : this.thumbWidth); | |
} | |
updateProps() { | |
let o = this.container; | |
if (!o) { | |
return; | |
} | |
let t = e => parseFloat(getComputedStyle(o).getPropertyValue('--f-thumb-' + e)) || 0; | |
this.thumbGap = t('gap'); | |
this.thumbExtraGap = t('extra-gap'); | |
this.thumbWidth = t('width') || 40; | |
this.thumbClipWidth = t('clip-width') || 40; | |
this.thumbHeight = t('height') || 40; | |
} | |
build() { | |
let o = this; | |
if (o.state !== H.Init) { | |
return; | |
} | |
if (o.isDisabled()) { | |
return void o.emit('disabled'); | |
} | |
let t = o.instance, e = t.container, i = o.getSlides(), n = o.option('type'); | |
o.type = n; | |
let s = o.option('parentEl'), a = o.cn('container'), r = o.cn('track'), l = s?.querySelector('.' + a); | |
l || (l = document.createElement('div'), y(l, a), s ? s.appendChild(l) : e.after(l)); | |
y(l, `is-${ n }`); | |
y(e, o.cn('hasThumbs')); | |
o.container = l; | |
o.updateProps(); | |
let c = l.querySelector('.' + r); | |
c || (c = document.createElement('div'), y(c, o.cn('track')), l.appendChild(c)); | |
o.track = c; | |
let d = E({}, { | |
track: c, | |
infinite: false, | |
center: true, | |
fill: n === 'classic', | |
dragFree: true, | |
slidesPerPage: 1, | |
transition: false, | |
preload: 0.25, | |
friction: 0.12, | |
Panzoom: { maxVelocity: 0 }, | |
Dots: false, | |
Navigation: false, | |
classes: { | |
container: 'f-thumbs', | |
viewport: 'f-thumbs__viewport', | |
track: 'f-thumbs__track', | |
slide: 'f-thumbs__slide' | |
} | |
}, o.option('Carousel') || {}, { | |
Sync: { target: t }, | |
slides: i | |
}), u = new t.constructor(l, d); | |
u.on('createSlide', (m, h) => { | |
o.setProps(h.index); | |
o.emit('createSlide', h, h.el); | |
}); | |
u.on('ready', () => { | |
o.shiftModern(); | |
o.emit('ready'); | |
}); | |
u.on('refresh', () => { | |
o.shiftModern(); | |
}); | |
u.on('Panzoom.click', (m, h, b) => { | |
o.onClick(b); | |
}); | |
o.carousel = u; | |
o.state = H.Ready; | |
} | |
onClick(o) { | |
o.preventDefault(); | |
o.stopPropagation(); | |
let t = this.instance, { | |
pages: e, | |
page: i | |
} = t, n = p => { | |
if (p) { | |
let f = p.closest('[data-carousel-index]'); | |
if (f) { | |
return [ | |
parseInt(f.dataset.carouselIndex || '', 10) || 0, | |
f | |
]; | |
} | |
} | |
return [ | |
-1, | |
void 0 | |
]; | |
}, s = (p, f) => { | |
let g = document.elementFromPoint(p, f); | |
return g ? n(g) : [ | |
-1, | |
void 0 | |
]; | |
}, [a, r] = n(o.target); | |
if (a > -1) { | |
return; | |
} | |
let l = this.thumbClipWidth, c = o.clientX, d = o.clientY, [u, m] = s(c - l, d), [h, b] = s(c + l, d); | |
m && b ? (a = Math.abs(c - m.getBoundingClientRect().right) < Math.abs(c - b.getBoundingClientRect().left) ? u : h, a === i && (a = a === u ? h : u)) : m ? a = u : b && (a = h); | |
a > -1 && e[a] && t.slideTo(a); | |
} | |
getShift(o) { | |
var t; | |
let e = this, {instance: i} = e, n = e.carousel; | |
if (!i || !n) { | |
return 0; | |
} | |
let s = e.thumbWidth, a = e.thumbClipWidth, r = e.thumbGap, l = e.thumbExtraGap; | |
if (!(!((t = n.slides[o]) === null || t === void 0) && t.el)) { | |
return 0; | |
} | |
let c = 0.5 * (s - a), d = i.pages.length - 1, u = i.getProgress(0), m = i.getProgress(d), h = i.getProgress(o, false, true), b = 0, p = c + l + r, f = u < 0 && u > -1, g = m > 0 && m < 1; | |
return o === 0 ? (b = p * Math.abs(u), g && u === 1 && (b -= p * Math.abs(m))) : o === d ? (b = p * Math.abs(m) * -1, f && m === -1 && (b += p * Math.abs(u))) : f || g ? (b = -1 * p, b += p * Math.abs(u), b += p * (1 - Math.abs(m))) : b = p * h, b; | |
} | |
setProps(o) { | |
var t; | |
let e = this; | |
if (!e.isModern) { | |
return; | |
} | |
let {instance: i} = e, n = e.carousel; | |
if (i && n) { | |
let s = (t = n.slides[o]) === null || t === void 0 ? void 0 : t.el; | |
if (s && s.childNodes.length) { | |
let a = Q(1 - Math.abs(i.getProgress(o))), r = Q(e.getShift(o)); | |
s.style.setProperty('--progress', a ? a + '' : ''); | |
s.style.setProperty('--shift', r + ''); | |
} | |
} | |
} | |
shiftModern() { | |
let o = this; | |
if (!o.isModern) { | |
return; | |
} | |
let { | |
instance: t, | |
track: e | |
} = o, i = t.panzoom, n = o.carousel; | |
if (!(t && e && i && n) || i.state === U.Init || i.state === U.Destroy) { | |
return; | |
} | |
for (let a of t.slides) | |
o.setProps(a.index); | |
let s = (o.thumbClipWidth + o.thumbGap) * (n.slides.length || 0); | |
e.style.setProperty('--width', s + ''); | |
} | |
cleanup() { | |
let o = this; | |
o.carousel && o.carousel.destroy(); | |
o.carousel = null; | |
o.container && o.container.remove(); | |
o.container = null; | |
o.track && o.track.remove(); | |
o.track = null; | |
o.state = H.Init; | |
x(o.instance.container, o.cn('hasThumbs')); | |
} | |
attach() { | |
let o = this, t = o.instance; | |
t.on('initSlide', o.onInitSlide); | |
t.state === w.Init ? t.on('initSlides', o.onInitSlides) : o.onInitSlides(); | |
t.on([ | |
'change', | |
'Panzoom.afterTransform' | |
], o.onChange); | |
t.on('Panzoom.refresh', o.onRefresh); | |
} | |
detach() { | |
let o = this, t = o.instance; | |
t.off('initSlide', o.onInitSlide); | |
t.off('initSlides', o.onInitSlides); | |
t.off([ | |
'change', | |
'Panzoom.afterTransform' | |
], o.onChange); | |
t.off('Panzoom.refresh', o.onRefresh); | |
o.cleanup(); | |
} | |
}; | |
Object.defineProperty(Ji, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: ji | |
}); | |
var ts = Object.assign(Object.assign({}, ji), { | |
key: 't', | |
showOnStart: true, | |
parentEl: null | |
}), Pt = class extends D { | |
constructor() { | |
super(...arguments); | |
Object.defineProperty(this, 'ref', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'hidden', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}); | |
} | |
get isEnabled() { | |
let t = this.ref; | |
return t && !t.isDisabled(); | |
} | |
get isHidden() { | |
return this.hidden; | |
} | |
onClick(t, e) { | |
e.stopPropagation(); | |
} | |
onCreateSlide(t, e) { | |
var i, n, s; | |
let a = ((s = (n = (i = this.instance) === null || i === void 0 ? void 0 : i.carousel) === null || n === void 0 ? void 0 : n.slides[e.index]) === null || s === void 0 ? void 0 : s.type) || '', r = e.el; | |
if (r && a) { | |
let l = `for-${ a }`; | |
[ | |
'video', | |
'youtube', | |
'vimeo', | |
'html5video' | |
].includes(a) && (l += ' for-video'); | |
y(r, l); | |
} | |
} | |
onInit() { | |
var t; | |
let e = this, i = e.instance, n = i.carousel; | |
if (e.ref || !n) { | |
return; | |
} | |
let s = e.option('parentEl') || i.footer || i.container; | |
if (!s) { | |
return; | |
} | |
let a = E({}, e.options, { | |
parentEl: s, | |
classes: { container: 'f-thumbs fancybox__thumbs' }, | |
Carousel: { Sync: { friction: i.option('Carousel.friction') || 0 } }, | |
on: { | |
ready: r => { | |
let l = r.container; | |
l && this.hidden && (e.refresh(), l.style.transition = 'none', e.hide(), l.offsetHeight, queueMicrotask(() => { | |
l.style.transition = ''; | |
e.show(); | |
})); | |
} | |
} | |
}); | |
; | |
a.Carousel.on = E(((t = e.options.Carousel) === null || t === void 0 ? void 0 : t.on) || {}, { | |
click: this.onClick, | |
createSlide: this.onCreateSlide | |
}); | |
n.options.Thumbs = a; | |
n.attachPlugins({ Thumbs: Ji }); | |
e.ref = n.plugins.Thumbs; | |
e.option('showOnStart') || (e.ref.state = H.Hidden, e.hidden = true); | |
} | |
onResize() { | |
var t; | |
let e = (t = this.ref) === null || t === void 0 ? void 0 : t.container; | |
e && (e.style.maxHeight = ''); | |
} | |
onKeydown(t, e) { | |
let i = this.option('key'); | |
i && i === e && this.toggle(); | |
} | |
toggle() { | |
let t = this.ref; | |
if (t && !t.isDisabled()) { | |
return t.state === H.Hidden ? (t.state = H.Init, void t.build()) : void (this.hidden ? this.show() : this.hide()); | |
} | |
} | |
show() { | |
let t = this.ref; | |
if (!t || t.isDisabled()) { | |
return; | |
} | |
let e = t.container; | |
e && (this.refresh(), e.offsetHeight, e.removeAttribute('aria-hidden'), e.classList.remove('is-masked'), this.hidden = false); | |
} | |
hide() { | |
let t = this.ref, e = t && t.container; | |
e && (this.refresh(), e.offsetHeight, e.classList.add('is-masked'), e.setAttribute('aria-hidden', 'true')); | |
this.hidden = true; | |
} | |
refresh() { | |
let t = this.ref; | |
if (!t || !t.state) { | |
return; | |
} | |
let e = t.container, i = e?.firstChild || null; | |
e && i && i.childNodes.length && (e.style.maxHeight = `${ i.getBoundingClientRect().height }px`); | |
} | |
attach() { | |
let t = this, e = t.instance; | |
e.state === A.Init ? e.on('Carousel.init', t.onInit) : t.onInit(); | |
e.on('resize', t.onResize); | |
e.on('keydown', t.onKeydown); | |
} | |
detach() { | |
var t; | |
let e = this, i = e.instance; | |
i.off('Carousel.init', e.onInit); | |
i.off('resize', e.onResize); | |
i.off('keydown', e.onKeydown); | |
(t = i.carousel) === null || t === void 0 || t.detachPlugins(['Thumbs']); | |
e.ref = null; | |
} | |
}; | |
Object.defineProperty(Pt, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: ts | |
}); | |
var Ee = { | |
panLeft: { | |
icon: '<svg><path d="M5 12h14M5 12l6 6M5 12l6-6"/></svg>', | |
change: { panX: -100 } | |
}, | |
panRight: { | |
icon: '<svg><path d="M5 12h14M13 18l6-6M13 6l6 6"/></svg>', | |
change: { panX: 100 } | |
}, | |
panUp: { | |
icon: '<svg><path d="M12 5v14M18 11l-6-6M6 11l6-6"/></svg>', | |
change: { panY: -100 } | |
}, | |
panDown: { | |
icon: '<svg><path d="M12 5v14M18 13l-6 6M6 13l6 6"/></svg>', | |
change: { panY: 100 } | |
}, | |
zoomIn: { | |
icon: '<svg><circle cx="11" cy="11" r="7.5"/><path d="m21 21-4.35-4.35M11 8v6M8 11h6"/></svg>', | |
action: 'zoomIn' | |
}, | |
zoomOut: { | |
icon: '<svg><circle cx="11" cy="11" r="7.5"/><path d="m21 21-4.35-4.35M8 11h6"/></svg>', | |
action: 'zoomOut' | |
}, | |
toggle1to1: { | |
icon: '<svg><path d="M3.51 3.07c5.74.02 11.48-.02 17.22.02 1.37.1 2.34 1.64 2.18 3.13 0 4.08.02 8.16 0 12.23-.1 1.54-1.47 2.64-2.79 2.46-5.61-.01-11.24.02-16.86-.01-1.36-.12-2.33-1.65-2.17-3.14 0-4.07-.02-8.16 0-12.23.1-1.36 1.22-2.48 2.42-2.46Z"/><path d="M5.65 8.54h1.49v6.92m8.94-6.92h1.49v6.92M11.5 9.4v.02m0 5.18v0"/></svg>', | |
action: 'toggleZoom' | |
}, | |
toggleZoom: { | |
icon: '<svg><g><line x1="11" y1="8" x2="11" y2="14"></line></g><circle cx="11" cy="11" r="7.5"/><path d="m21 21-4.35-4.35M8 11h6"/></svg>', | |
action: 'toggleZoom' | |
}, | |
iterateZoom: { | |
icon: '<svg><g><line x1="11" y1="8" x2="11" y2="14"></line></g><circle cx="11" cy="11" r="7.5"/><path d="m21 21-4.35-4.35M8 11h6"/></svg>', | |
action: 'iterateZoom' | |
}, | |
rotateCCW: { | |
icon: '<svg><path d="M15 4.55a8 8 0 0 0-6 14.9M9 15v5H4M18.37 7.16v.01M13 19.94v.01M16.84 18.37v.01M19.37 15.1v.01M19.94 11v.01"/></svg>', | |
action: 'rotateCCW' | |
}, | |
rotateCW: { | |
icon: '<svg><path d="M9 4.55a8 8 0 0 1 6 14.9M15 15v5h5M5.63 7.16v.01M4.06 11v.01M4.63 15.1v.01M7.16 18.37v.01M11 19.94v.01"/></svg>', | |
action: 'rotateCW' | |
}, | |
flipX: { | |
icon: '<svg style="stroke-width: 1.3"><path d="M12 3v18M16 7v10h5L16 7M8 7v10H3L8 7"/></svg>', | |
action: 'flipX' | |
}, | |
flipY: { | |
icon: '<svg style="stroke-width: 1.3"><path d="M3 12h18M7 16h10L7 21v-5M7 8h10L7 3v5"/></svg>', | |
action: 'flipY' | |
}, | |
fitX: { | |
icon: '<svg><path d="M4 12V6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v6M10 18H3M21 18h-7M6 15l-3 3 3 3M18 15l3 3-3 3"/></svg>', | |
action: 'fitX' | |
}, | |
fitY: { | |
icon: '<svg><path d="M12 20H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h6M18 14v7M18 3v7M15 18l3 3 3-3M15 6l3-3 3 3"/></svg>', | |
action: 'fitY' | |
}, | |
reset: { | |
icon: '<svg><path d="M20 11A8.1 8.1 0 0 0 4.5 9M4 5v4h4M4 13a8.1 8.1 0 0 0 15.5 2m.5 4v-4h-4"/></svg>', | |
action: 'reset' | |
}, | |
toggleFS: { | |
icon: '<svg><g><path d="M14.5 9.5 21 3m0 0h-6m6 0v6M3 21l6.5-6.5M3 21v-6m0 6h6"/></g><g><path d="m14 10 7-7m-7 7h6m-6 0V4M3 21l7-7m0 0v6m0-6H4"/></g></svg>', | |
action: 'toggleFS' | |
} | |
}, it; | |
(function (o) { | |
o[o.Init = 0] = 'Init'; | |
o[o.Ready = 1] = 'Ready'; | |
o[o.Disabled = 2] = 'Disabled'; | |
}(it || (it = {}))); | |
var es = { | |
absolute: 'auto', | |
display: { | |
left: ['infobar'], | |
middle: [], | |
right: [ | |
'iterateZoom', | |
'slideshow', | |
'fullscreen', | |
'thumbs', | |
'close' | |
] | |
}, | |
enabled: 'auto', | |
items: { | |
infobar: { tpl: '<div class="fancybox__infobar" tabindex="-1"><span data-fancybox-current-index></span>/<span data-fancybox-count></span></div>' }, | |
download: { tpl: '<a class="f-button" title="{{DOWNLOAD}}" data-fancybox-download href="javasript:;"><svg><path d="M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-2M7 11l5 5 5-5M12 4v12"/></svg></a>' }, | |
prev: { tpl: '<button class="f-button" title="{{PREV}}" data-fancybox-prev><svg><path d="m15 6-6 6 6 6"/></svg></button>' }, | |
next: { tpl: '<button class="f-button" title="{{NEXT}}" data-fancybox-next><svg><path d="m9 6 6 6-6 6"/></svg></button>' }, | |
slideshow: { tpl: '<button class="f-button" title="{{TOGGLE_SLIDESHOW}}" data-fancybox-toggle-slideshow><svg><g><path d="M8 4v16l13 -8z"></path></g><g><path d="M8 4v15M17 4v15"/></g></svg></button>' }, | |
fullscreen: { tpl: '<button class="f-button" title="{{TOGGLE_FULLSCREEN}}" data-fancybox-toggle-fullscreen><svg><g><path d="M4 8V6a2 2 0 0 1 2-2h2M4 16v2a2 2 0 0 0 2 2h2M16 4h2a2 2 0 0 1 2 2v2M16 20h2a2 2 0 0 0 2-2v-2"/></g><g><path d="M15 19v-2a2 2 0 0 1 2-2h2M15 5v2a2 2 0 0 0 2 2h2M5 15h2a2 2 0 0 1 2 2v2M5 9h2a2 2 0 0 0 2-2V5"/></g></svg></button>' }, | |
thumbs: { tpl: '<button class="f-button" title="{{TOGGLE_THUMBS}}" data-fancybox-toggle-thumbs><svg><circle cx="5.5" cy="5.5" r="1"/><circle cx="12" cy="5.5" r="1"/><circle cx="18.5" cy="5.5" r="1"/><circle cx="5.5" cy="12" r="1"/><circle cx="12" cy="12" r="1"/><circle cx="18.5" cy="12" r="1"/><circle cx="5.5" cy="18.5" r="1"/><circle cx="12" cy="18.5" r="1"/><circle cx="18.5" cy="18.5" r="1"/></svg></button>' }, | |
close: { tpl: '<button class="f-button" title="{{CLOSE}}" data-fancybox-close><svg><path d="m19.5 4.5-15 15M4.5 4.5l15 15"/></svg></button>' } | |
}, | |
parentEl: null | |
}, _t = class extends D { | |
constructor() { | |
super(...arguments); | |
Object.defineProperty(this, 'state', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: it.Init | |
}); | |
Object.defineProperty(this, 'container', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
} | |
onReady(t) { | |
var e; | |
if (!t.carousel) { | |
return; | |
} | |
let i = this.option('display'), n = this.option('absolute'), s = this.option('enabled'); | |
if (s === 'auto') { | |
let c = this.instance.carousel, d = 0; | |
if (c) { | |
for (let u of c.slides) | |
(u.panzoom || u.type === 'image') && d++; | |
} | |
d || (s = false); | |
} | |
s || (i = void 0); | |
let a = 0, r = { | |
left: [], | |
middle: [], | |
right: [] | |
}; | |
if (i) { | |
for (let c of [ | |
'left', | |
'middle', | |
'right' | |
]) | |
for (let d of i[c]) { | |
let u = this.createEl(d); | |
u && ((e = r[c]) === null || e === void 0 || e.push(u), a++); | |
} | |
} | |
let l = null; | |
if (a && (l = this.createContainer()), l) { | |
for (let [c, d] of Object.entries(r)) { | |
let u = document.createElement('div'); | |
y(u, 'fancybox__toolbar__column is-' + c); | |
for (let m of d) | |
u.appendChild(m); | |
n !== 'auto' || c !== 'middle' || d.length || (n = true); | |
l.appendChild(u); | |
} | |
n === true && y(l, 'is-absolute'); | |
this.state = it.Ready; | |
this.onRefresh(); | |
} else { | |
this.state = it.Disabled; | |
} | |
} | |
onClick(t) { | |
var e, i; | |
let n = this.instance, s = n.getSlide(), a = s?.panzoom, r = t.target, l = r && C(r) ? r.dataset : null; | |
if (!l) { | |
return; | |
} | |
if (l.fancyboxToggleThumbs !== void 0) { | |
return t.preventDefault(), t.stopPropagation(), void ((e = n.plugins.Thumbs) === null || e === void 0 || e.toggle()); | |
} | |
if (l.fancyboxToggleFullscreen !== void 0) { | |
return t.preventDefault(), t.stopPropagation(), void this.instance.toggleFullscreen(); | |
} | |
if (l.fancyboxToggleSlideshow !== void 0) { | |
t.preventDefault(); | |
t.stopPropagation(); | |
let u = (i = n.carousel) === null || i === void 0 ? void 0 : i.plugins.Autoplay, m = u.isActive; | |
return a && a.panMode === 'mousemove' && !m && a.reset(), void (m ? u.stop() : u.start()); | |
} | |
let c = l.panzoomAction, d = l.panzoomChange; | |
if ((d || c) && (t.preventDefault(), t.stopPropagation()), d) { | |
let u = {}; | |
try { | |
u = JSON.parse(d); | |
} catch { | |
} | |
a && a.applyChange(u); | |
} else { | |
c && a && a[c] && a[c](); | |
} | |
} | |
onChange() { | |
this.onRefresh(); | |
} | |
onRefresh() { | |
if (this.instance.isClosing()) { | |
return; | |
} | |
let t = this.container; | |
if (!t) { | |
return; | |
} | |
let e = this.instance.getSlide(); | |
if (!e || e.state !== Z.Ready) { | |
return; | |
} | |
let i = e && !e.error && e.panzoom; | |
for (let a of t.querySelectorAll('[data-panzoom-action]')) | |
i ? (a.removeAttribute('disabled'), a.removeAttribute('tabindex')) : (a.setAttribute('disabled', ''), a.setAttribute('tabindex', '-1')); | |
let n = i && i.canZoomIn(), s = i && i.canZoomOut(); | |
for (let a of t.querySelectorAll('[data-panzoom-action="zoomIn"]')) | |
n ? (a.removeAttribute('disabled'), a.removeAttribute('tabindex')) : (a.setAttribute('disabled', ''), a.setAttribute('tabindex', '-1')); | |
for (let a of t.querySelectorAll('[data-panzoom-action="zoomOut"]')) | |
s ? (a.removeAttribute('disabled'), a.removeAttribute('tabindex')) : (a.setAttribute('disabled', ''), a.setAttribute('tabindex', '-1')); | |
for (let a of t.querySelectorAll('[data-panzoom-action="toggleZoom"],[data-panzoom-action="iterateZoom"]')) { | |
s || n ? (a.removeAttribute('disabled'), a.removeAttribute('tabindex')) : (a.setAttribute('disabled', ''), a.setAttribute('tabindex', '-1')); | |
let r = a.querySelector('g'); | |
r && (r.style.display = n ? '' : 'none'); | |
} | |
} | |
onDone(t, e) { | |
var i; | |
(i = e.panzoom) === null || i === void 0 || i.on('afterTransform', () => { | |
this.instance.isCurrentSlide(e) && this.onRefresh(); | |
}); | |
this.instance.isCurrentSlide(e) && this.onRefresh(); | |
} | |
createContainer() { | |
let t = this.instance.container; | |
if (!t) { | |
return null; | |
} | |
let e = this.option('parentEl') || t, i = e.querySelector('.fancybox__toolbar'); | |
return i || (i = document.createElement('div'), y(i, 'fancybox__toolbar'), e.prepend(i)), i.addEventListener('click', this.onClick, { | |
passive: false, | |
capture: true | |
}), t && y(t, 'has-toolbar'), this.container = i, i; | |
} | |
createEl(t) { | |
let e = this.instance, i = e.carousel; | |
if (!i || t === 'toggleFS' || t === 'fullscreen' && !Vi()) { | |
return null; | |
} | |
let n = null, s = i.slides.length || 0, a = 0, r = 0; | |
for (let c of i.slides) | |
(c.panzoom || c.type === 'image') && a++, (c.type === 'image' || c.downloadSrc) && r++; | |
if (s < 2 && [ | |
'infobar', | |
'prev', | |
'next' | |
].includes(t)) { | |
return n; | |
} | |
if (Ee[t] !== void 0 && !a || t === 'download' && !r) { | |
return null; | |
} | |
if (t === 'thumbs') { | |
let c = e.plugins.Thumbs; | |
if (!c || !c.isEnabled) { | |
return null; | |
} | |
} | |
if (t === 'slideshow' && (!i.plugins.Autoplay || s < 2)) { | |
return null; | |
} | |
if (Ee[t] !== void 0) { | |
let c = Ee[t]; | |
n = document.createElement('button'); | |
n.setAttribute('title', this.instance.localize(`{{${ t.toUpperCase() }}}`)); | |
y(n, 'f-button'); | |
c.action && (n.dataset.panzoomAction = c.action); | |
c.change && (n.dataset.panzoomChange = JSON.stringify(c.change)); | |
n.appendChild(S(this.instance.localize(c.icon))); | |
} else { | |
let c = (this.option('items') || [])[t]; | |
c && (n = S(this.instance.localize(c.tpl)), typeof c.click == 'function' && n.addEventListener('click', d => { | |
d.preventDefault(); | |
d.stopPropagation(); | |
typeof c.click == 'function' && c.click.call(this, this, d); | |
})); | |
} | |
let l = n?.querySelector('svg'); | |
if (l) { | |
for (let [c, d] of Object.entries(is)) | |
l.getAttribute(c) || l.setAttribute(c, String(d)); | |
} | |
return n; | |
} | |
removeContainer() { | |
let t = this.container; | |
t && t.remove(); | |
this.container = null; | |
this.state = it.Disabled; | |
let e = this.instance.container; | |
e && x(e, 'has-toolbar'); | |
} | |
attach() { | |
let t = this, e = t.instance; | |
e.on('Carousel.initSlides', t.onReady); | |
e.on('done', t.onDone); | |
e.on([ | |
'reveal', | |
'Carousel.change' | |
], t.onChange); | |
t.onReady(t.instance); | |
} | |
detach() { | |
let t = this, e = t.instance; | |
e.off('Carousel.initSlides', t.onReady); | |
e.off('done', t.onDone); | |
e.off([ | |
'reveal', | |
'Carousel.change' | |
], t.onChange); | |
t.removeContainer(); | |
} | |
}; | |
Object.defineProperty(_t, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: es | |
}); | |
var ns = { | |
Hash: class extends D { | |
onReady() { | |
ft = false; | |
} | |
onChange(o) { | |
et && clearTimeout(et); | |
let {hash: t} = Ii(), {hash: e} = zt(), i = o.isOpeningSlide(o.getSlide()); | |
i && (yi = e === t ? '' : e); | |
t && t !== e && (et = setTimeout(() => { | |
try { | |
if (o.state === A.Ready) { | |
let n = 'replaceState'; | |
i && !Yt && (n = 'pushState', Yt = true); | |
window.history[n]({}, document.title, window.location.pathname + window.location.search + t); | |
} | |
} catch { | |
} | |
}, 300)); | |
} | |
onClose(o) { | |
if (et && clearTimeout(et), !ft && Yt) { | |
return Yt = false, ft = false, void window.history.back(); | |
} | |
if (!ft) { | |
try { | |
window.history.replaceState({}, document.title, window.location.pathname + window.location.search + (yi || '')); | |
} catch { | |
} | |
} | |
} | |
attach() { | |
let o = this.instance; | |
o.on('ready', this.onReady); | |
o.on([ | |
'Carousel.ready', | |
'Carousel.change' | |
], this.onChange); | |
o.on('close', this.onClose); | |
} | |
detach() { | |
let o = this.instance; | |
o.off('ready', this.onReady); | |
o.off([ | |
'Carousel.ready', | |
'Carousel.change' | |
], this.onChange); | |
o.off('close', this.onClose); | |
} | |
static parseURL() { | |
return zt(); | |
} | |
static startFromUrl() { | |
Si(); | |
} | |
static destroy() { | |
window.removeEventListener('hashchange', Ti, false); | |
} | |
}, | |
Html: jt, | |
Images: Tt, | |
Slideshow: Ht, | |
Thumbs: Pt, | |
Toolbar: _t | |
}, _ = o => typeof o == 'string', Yi = function () { | |
var o = window.getSelection(); | |
return !!o && o.type === 'Range'; | |
}, N, R = null, tt = null, Oi = 0, Ni = 0, Ri = 0, ki = 0, lt = new Map(), ss = 0, M = class o extends Qt { | |
get isIdle() { | |
return this.idle; | |
} | |
get isCompact() { | |
return this.option('compact'); | |
} | |
constructor(t = [], e = {}, i = {}) { | |
super(e); | |
Object.defineProperty(this, 'userSlides', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: [] | |
}); | |
Object.defineProperty(this, 'userPlugins', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: {} | |
}); | |
Object.defineProperty(this, 'idle', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}); | |
Object.defineProperty(this, 'idleTimer', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'clickTimer', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'pwt', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}); | |
Object.defineProperty(this, 'ignoreFocusChange', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}); | |
Object.defineProperty(this, 'startedFs', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: false | |
}); | |
Object.defineProperty(this, 'state', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: A.Init | |
}); | |
Object.defineProperty(this, 'id', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: 0 | |
}); | |
Object.defineProperty(this, 'container', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'caption', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'footer', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'carousel', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'lastFocus', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: null | |
}); | |
Object.defineProperty(this, 'prevMouseMoveEvent', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: void 0 | |
}); | |
N || (N = Vi()); | |
this.id = e.id || ++ss; | |
lt.set(this.id, this); | |
this.userSlides = t; | |
this.userPlugins = i; | |
queueMicrotask(() => { | |
this.init(); | |
}); | |
} | |
init() { | |
if (this.state === A.Destroy) { | |
return; | |
} | |
this.state = A.Init; | |
this.attachPlugins(Object.assign(Object.assign({}, o.Plugins), this.userPlugins)); | |
this.emit('init'); | |
this.emit('attachPlugins'); | |
this.option('hideScrollbar') === true && (() => { | |
if (!gt) { | |
return; | |
} | |
let e = document, i = e.body, n = e.documentElement; | |
if (i.classList.contains('hide-scrollbar')) { | |
return; | |
} | |
let s = window.innerWidth - n.getBoundingClientRect().width, a = parseFloat(window.getComputedStyle(i).marginRight); | |
s < 0 && (s = 0); | |
n.style.setProperty('--fancybox-scrollbar-compensate', `${ s }px`); | |
a && i.style.setProperty('--fancybox-body-margin', `${ a }px`); | |
i.classList.add('hide-scrollbar'); | |
})(); | |
this.initLayout(); | |
this.scale(); | |
let t = () => { | |
this.initCarousel(this.userSlides); | |
this.state = A.Ready; | |
this.attachEvents(); | |
this.emit('ready'); | |
setTimeout(() => { | |
this.container && this.container.setAttribute('aria-hidden', 'false'); | |
}, 16); | |
}; | |
this.option('Fullscreen.autoStart') && N && !N.isFullscreen() ? N.request().then(() => { | |
this.startedFs = true; | |
t(); | |
}).catch(() => t()) : t(); | |
} | |
initLayout() { | |
var t, e; | |
let i = this.option('parentEl') || document.body, n = S(this.localize(this.option('tpl.main') || '')); | |
if (n) { | |
if (n.setAttribute('id', `fancybox-${ this.id }`), n.setAttribute('aria-label', this.localize('{{MODAL}}')), n.classList.toggle('is-compact', this.isCompact), y(n, this.option('mainClass') || ''), y(n, 'is-opening'), this.container = n, this.footer = n.querySelector('.fancybox__footer'), i.appendChild(n), y(document.documentElement, 'with-fancybox'), R && tt || (R = document.createElement('span'), y(R, 'fancybox-focus-guard'), R.setAttribute('tabindex', '0'), R.setAttribute('aria-hidden', 'true'), R.setAttribute('aria-label', 'Focus guard'), tt = R.cloneNode(), (t = n.parentElement) === null || t === void 0 || t.insertBefore(R, n), (e = n.parentElement) === null || e === void 0 || e.append(tt)), n.addEventListener('mousedown', s => { | |
Oi = s.pageX; | |
Ni = s.pageY; | |
x(n, 'is-using-tab'); | |
}), this.option('closeExisting')) { | |
for (let s of lt.values()) | |
s.id !== this.id && s.close(); | |
} else { | |
this.option('animated') && (y(n, 'is-animated'), setTimeout(() => { | |
this.isClosing() || x(n, 'is-animated'); | |
}, 350)); | |
} | |
this.emit('initLayout'); | |
} | |
} | |
initCarousel(t) { | |
let e = this.container; | |
if (!e) { | |
return; | |
} | |
let i = e.querySelector('.fancybox__carousel'); | |
if (!i) { | |
return; | |
} | |
let n = this.carousel = new ct(i, E({}, { | |
slides: t, | |
transition: 'fade', | |
Panzoom: { | |
lockAxis: this.option('dragToClose') ? 'xy' : 'x', | |
infinite: !!this.option('dragToClose') && 'y' | |
}, | |
Dots: false, | |
Navigation: { | |
classes: { | |
container: 'fancybox__nav', | |
button: 'f-button', | |
isNext: 'is-next', | |
isPrev: 'is-prev' | |
} | |
}, | |
initialPage: this.option('startIndex'), | |
l10n: this.option('l10n') | |
}, this.option('Carousel') || {})); | |
n.on('*', (s, a, ...r) => { | |
this.emit(`Carousel.${ a }`, s, ...r); | |
}); | |
n.on([ | |
'ready', | |
'change' | |
], () => { | |
this.manageCaption(); | |
}); | |
this.on('Carousel.removeSlide', (s, a, r) => { | |
this.clearContent(r); | |
r.state = void 0; | |
}); | |
n.on('Panzoom.touchStart', () => { | |
var s, a; | |
this.isCompact || this.endIdle(); | |
!((s = document.activeElement) === null || s === void 0) && s.closest('.f-thumbs') && ((a = this.container) === null || a === void 0 || a.focus()); | |
}); | |
n.on('settle', () => { | |
this.idleTimer || this.isCompact || !this.option('idle') || this.setIdle(); | |
this.option('autoFocus') && !this.isClosing && this.checkFocus(); | |
}); | |
this.option('dragToClose') && (n.on('Panzoom.afterTransform', (s, a) => { | |
let r = this.getSlide(); | |
if (r && Xe(r.el)) { | |
return; | |
} | |
let l = this.container; | |
if (l) { | |
let c = Math.abs(a.current.f), d = c < 1 ? '' : Math.max(0.5, Math.min(1, 1 - c / a.contentRect.fitHeight * 1.5)); | |
l.style.setProperty('--fancybox-ts', d ? '0s' : ''); | |
l.style.setProperty('--fancybox-opacity', d + ''); | |
} | |
}), n.on('Panzoom.touchEnd', (s, a, r) => { | |
var l; | |
let c = this.getSlide(); | |
if (c && Xe(c.el) || a.isMobile && document.activeElement && [ | |
'TEXTAREA', | |
'INPUT' | |
].indexOf((l = document.activeElement) === null || l === void 0 ? void 0 : l.nodeName) !== -1) { | |
return; | |
} | |
let d = Math.abs(a.dragOffset.y); | |
a.lockedAxis === 'y' && (d >= 200 || d >= 50 && a.dragOffset.time < 300) && (r && r.cancelable && r.preventDefault(), this.close(r, 'f-throwOut' + (a.current.f < 0 ? 'Up' : 'Down'))); | |
})); | |
n.on('change', s => { | |
var a; | |
let r = (a = this.getSlide()) === null || a === void 0 ? void 0 : a.triggerEl; | |
if (r) { | |
let l = new CustomEvent('slideTo', { | |
bubbles: true, | |
cancelable: true, | |
detail: s.page | |
}); | |
r.dispatchEvent(l); | |
} | |
}); | |
n.on([ | |
'refresh', | |
'change' | |
], s => { | |
let a = this.container; | |
if (!a) { | |
return; | |
} | |
for (let c of a.querySelectorAll('[data-fancybox-current-index]')) | |
c.innerHTML = s.page + 1; | |
for (let c of a.querySelectorAll('[data-fancybox-count]')) | |
c.innerHTML = s.pages.length; | |
if (!s.isInfinite) { | |
for (let c of a.querySelectorAll('[data-fancybox-next]')) | |
s.page < s.pages.length - 1 ? (c.removeAttribute('disabled'), c.removeAttribute('tabindex')) : (c.setAttribute('disabled', ''), c.setAttribute('tabindex', '-1')); | |
for (let c of a.querySelectorAll('[data-fancybox-prev]')) | |
s.page > 0 ? (c.removeAttribute('disabled'), c.removeAttribute('tabindex')) : (c.setAttribute('disabled', ''), c.setAttribute('tabindex', '-1')); | |
} | |
let r = this.getSlide(); | |
if (!r) { | |
return; | |
} | |
let l = r.downloadSrc || ''; | |
l || r.type !== 'image' || r.error || !_(r.src) || (l = r.src); | |
for (let c of a.querySelectorAll('[data-fancybox-download]')) { | |
let d = r.downloadFilename; | |
l ? (c.removeAttribute('disabled'), c.removeAttribute('tabindex'), c.setAttribute('href', l), c.setAttribute('download', d || l), c.setAttribute('target', '_blank')) : (c.setAttribute('disabled', ''), c.setAttribute('tabindex', '-1'), c.removeAttribute('href'), c.removeAttribute('download')); | |
} | |
}); | |
this.emit('initCarousel'); | |
} | |
attachEvents() { | |
let t = this, e = t.container; | |
if (!e) { | |
return; | |
} | |
e.addEventListener('click', t.onClick, { | |
passive: false, | |
capture: false | |
}); | |
e.addEventListener('wheel', t.onWheel, { | |
passive: false, | |
capture: false | |
}); | |
document.addEventListener('keydown', t.onKeydown, { | |
passive: false, | |
capture: true | |
}); | |
document.addEventListener('visibilitychange', t.onVisibilityChange, false); | |
document.addEventListener('mousemove', t.onMousemove); | |
t.option('trapFocus') && document.addEventListener('focus', t.onFocus, true); | |
window.addEventListener('resize', t.onResize); | |
let i = window.visualViewport; | |
i && (i.addEventListener('scroll', t.onResize), i.addEventListener('resize', t.onResize)); | |
} | |
detachEvents() { | |
let t = this, e = t.container; | |
if (!e) { | |
return; | |
} | |
document.removeEventListener('keydown', t.onKeydown, { | |
passive: false, | |
capture: true | |
}); | |
e.removeEventListener('wheel', t.onWheel, { | |
passive: false, | |
capture: false | |
}); | |
e.removeEventListener('click', t.onClick, { | |
passive: false, | |
capture: false | |
}); | |
document.removeEventListener('mousemove', t.onMousemove); | |
window.removeEventListener('resize', t.onResize); | |
let i = window.visualViewport; | |
i && (i.removeEventListener('resize', t.onResize), i.removeEventListener('scroll', t.onResize)); | |
document.removeEventListener('visibilitychange', t.onVisibilityChange, false); | |
document.removeEventListener('focus', t.onFocus, true); | |
} | |
scale() { | |
let t = this.container; | |
if (!t) { | |
return; | |
} | |
let e = window.visualViewport, i = Math.max(1, e?.scale || 1), n = '', s = '', a = ''; | |
if (e && i > 1) { | |
let r = `${ e.offsetLeft }px`, l = `${ e.offsetTop }px`; | |
n = e.width * i + 'px'; | |
s = e.height * i + 'px'; | |
a = `translate3d(${ r }, ${ l }, 0) scale(${ 1 / i })`; | |
} | |
t.style.transform = a; | |
t.style.width = n; | |
t.style.height = s; | |
} | |
onClick(t) { | |
var e; | |
let { | |
container: i, | |
isCompact: n | |
} = this; | |
if (!i || this.isClosing()) { | |
return; | |
} | |
!n && this.option('idle') && this.resetIdle(); | |
let s = t.composedPath()[0]; | |
if (s.closest('.fancybox-spinner') || s.closest('[data-fancybox-close]')) { | |
return t.preventDefault(), void this.close(t); | |
} | |
if (s.closest('[data-fancybox-prev]')) { | |
return t.preventDefault(), void this.prev(); | |
} | |
if (s.closest('[data-fancybox-next]')) { | |
return t.preventDefault(), void this.next(); | |
} | |
if (t.type === 'click' && t.detail === 0 || Math.abs(t.pageX - Oi) > 30 || Math.abs(t.pageY - Ni) > 30) { | |
return; | |
} | |
let a = document.activeElement; | |
if (Yi() && a && i.contains(a)) { | |
return; | |
} | |
if (n && ((e = this.getSlide()) === null || e === void 0 ? void 0 : e.type) === 'image') { | |
return void (this.clickTimer ? (clearTimeout(this.clickTimer), this.clickTimer = null) : this.clickTimer = setTimeout(() => { | |
this.toggleIdle(); | |
this.clickTimer = null; | |
}, 350)); | |
} | |
if (this.emit('click', t), t.defaultPrevented) { | |
return; | |
} | |
let r = false; | |
if (s.closest('.fancybox__content')) { | |
if (a) { | |
if (a.closest('[contenteditable]')) { | |
return; | |
} | |
s.matches(We) || a.blur(); | |
} | |
if (Yi()) { | |
return; | |
} | |
r = this.option('contentClick'); | |
} else { | |
s.closest('.fancybox__carousel') && !s.matches(We) && (r = this.option('backdropClick')); | |
} | |
r === 'close' ? (t.preventDefault(), this.close(t)) : r === 'next' ? (t.preventDefault(), this.next()) : r === 'prev' && (t.preventDefault(), this.prev()); | |
} | |
onWheel(t) { | |
let e = t.target, i = this.option('wheel', t); | |
e.closest('.fancybox__thumbs') && (i = 'slide'); | |
let n = i === 'slide', s = [ | |
-t.deltaX || 0, | |
-t.deltaY || 0, | |
-t.detail || 0 | |
].reduce(function (l, c) { | |
return Math.abs(c) > Math.abs(l) ? c : l; | |
}), a = Math.max(-1, Math.min(1, s)), r = Date.now(); | |
this.pwt && r - this.pwt < 300 ? n && t.preventDefault() : (this.pwt = r, this.emit('wheel', t, a), t.defaultPrevented || (i === 'close' ? (t.preventDefault(), this.close(t)) : i === 'slide' && (Gt(e) || (t.preventDefault(), this[a > 0 ? 'prev' : 'next']())))); | |
} | |
onScroll() { | |
window.scrollTo(Ri, ki); | |
} | |
onKeydown(t) { | |
if (!this.isTopmost()) { | |
return; | |
} | |
this.isCompact || !this.option('idle') || this.isClosing() || this.resetIdle(); | |
let e = t.key, i = this.option('keyboard'); | |
if (!i) { | |
return; | |
} | |
let n = t.composedPath()[0], s = document.activeElement && document.activeElement.classList, a = s && s.contains('f-button') || n.dataset.carouselPage || n.dataset.carouselIndex; | |
if (e !== 'Escape' && !a && C(n) && (n.isContentEditable || [ | |
'TEXTAREA', | |
'OPTION', | |
'INPUT', | |
'SELECT', | |
'VIDEO' | |
].indexOf(n.nodeName) !== -1) || (t.key === 'Tab' ? y(this.container, 'is-using-tab') : x(this.container, 'is-using-tab'), t.ctrlKey || t.altKey || t.shiftKey)) { | |
return; | |
} | |
this.emit('keydown', e, t); | |
let r = i[e]; | |
r && typeof this[r] == 'function' && (t.preventDefault(), this[r]()); | |
} | |
onResize() { | |
let t = this.container; | |
if (!t) { | |
return; | |
} | |
let e = this.isCompact; | |
t.classList.toggle('is-compact', e); | |
this.manageCaption(this.getSlide()); | |
this.isCompact ? this.clearIdle() : this.endIdle(); | |
this.scale(); | |
this.emit('resize'); | |
} | |
onFocus(t) { | |
this.isTopmost() && this.checkFocus(t); | |
} | |
onMousemove(t) { | |
this.prevMouseMoveEvent = t; | |
!this.isCompact && this.option('idle') && this.resetIdle(); | |
} | |
onVisibilityChange() { | |
document.visibilityState === 'visible' ? this.checkFocus() : this.endIdle(); | |
} | |
manageCloseBtn(t) { | |
let e = this.optionFor(t, 'closeButton') || false; | |
if (e === 'auto') { | |
let n = this.plugins.Toolbar; | |
if (n && n.state === it.Ready) { | |
return; | |
} | |
} | |
if (!e || !t.contentEl || t.closeBtnEl) { | |
return; | |
} | |
let i = this.option('tpl.closeButton'); | |
if (i) { | |
let n = S(this.localize(i)); | |
; | |
t.el && y(t.el, 'has-close-btn'); | |
} | |
} | |
manageCaption(t = void 0) { | |
var e, i; | |
let s = this.container; | |
if (!s) { | |
return; | |
} | |
x(s, 'has-caption'); | |
let a = this.isCompact || this.option('commonCaption'), r = !a; | |
if (this.caption && this.stop(this.caption), r && this.caption && (this.caption.remove(), this.caption = null), a && !this.caption) { | |
for (let u of ((e = this.carousel) === null || e === void 0 ? void 0 : e.slides) || []) | |
u.captionEl && (u.captionEl.remove(), u.captionEl = void 0, x(u.el, 'has-caption'), (i = u.el) === null || i === void 0 || i.removeAttribute('aria-labelledby')); | |
} | |
if (t || (t = this.getSlide()), !t || a && !this.isCurrentSlide(t)) { | |
return; | |
} | |
let l = t.el, c = this.optionFor(t, 'caption', ''); | |
if (!c) { | |
return void (a && this.caption && this.animate(this.caption, 'f-fadeOut', () => { | |
this.caption && (this.caption.innerHTML = ''); | |
})); | |
} | |
let d = null; | |
if (r) { | |
if (d = t.captionEl || null, l && !d) { | |
let u = 'fancybox__caption' + `_${ this.id }_${ t.index }`; | |
d = document.createElement('div'); | |
y(d, 'fancybox__caption'); | |
d.setAttribute('id', u); | |
; | |
y(l, 'has-caption'); | |
l.setAttribute('aria-labelledby', u); | |
} | |
} else { | |
d = this.caption; | |
d || (d = s.querySelector('.fancybox__caption')); | |
!d && (d = document.createElement('div'), d.dataset.fancyboxCaption = '', y(d, 'fancybox__caption'), (this.footer || s).prepend(d)); | |
y(s, 'has-caption'); | |
this.caption = d; | |
} | |
d && (d.innerHTML = '', _(c) || typeof c == 'number' ? d.innerHTML = c + '' : c instanceof HTMLElement && d.appendChild(c)); | |
} | |
checkFocus(t) { | |
this.focus(t); | |
} | |
focus(t) { | |
var e; | |
if (this.ignoreFocusChange) { | |
return; | |
} | |
let i = document.activeElement || null, n = t?.target || null, s = this.container, a = (e = this.carousel) === null || e === void 0 ? void 0 : e.viewport; | |
if (!s || !a || !t && i && s.contains(i)) { | |
return; | |
} | |
let r = this.getSlide(), l = r && r.state === Z.Ready ? r.el : null; | |
if (!l || l.contains(i) || s === i) { | |
return; | |
} | |
t && t.cancelable && t.preventDefault(); | |
this.ignoreFocusChange = true; | |
let c = Array.from(s.querySelectorAll(We)), d = [], u = null; | |
for (let h of c) { | |
let b = !h.offsetParent || !!h.closest('[aria-hidden="true"]'), p = l && l.contains(h), f = !a.contains(h); | |
if (h === s || (p || f) && !b) { | |
d.push(h); | |
let g = h.dataset.origTabindex; | |
g !== void 0 && g && (h.tabIndex = parseFloat(g)); | |
h.removeAttribute('data-orig-tabindex'); | |
!h.hasAttribute('autoFocus') && u || (u = h); | |
} else { | |
let g = h.dataset.origTabindex === void 0 ? h.getAttribute('tabindex') || '' : h.dataset.origTabindex; | |
g && (h.dataset.origTabindex = g); | |
; | |
} | |
} | |
let m = null; | |
t ? (!n || d.indexOf(n) < 0) && (m = u || s, d.length && (i === tt ? m = d[0] : this.lastFocus !== s && i !== R || (m = d[d.length - 1]))) : m = r && r.type === 'image' ? s : u || s; | |
m && Fi(m); | |
this.lastFocus = document.activeElement; | |
this.ignoreFocusChange = false; | |
} | |
next() { | |
let t = this.carousel; | |
t && t.pages.length > 1 && t.slideNext(); | |
} | |
prev() { | |
let t = this.carousel; | |
t && t.pages.length > 1 && t.slidePrev(); | |
} | |
jumpTo(...t) { | |
this.carousel && this.carousel.slideTo(...t); | |
} | |
isTopmost() { | |
var t; | |
return ((t = o.getInstance()) === null || t === void 0 ? void 0 : t.id) == this.id; | |
} | |
animate(t = null, e = '', i) { | |
if (!t || !e) { | |
return void (i && i()); | |
} | |
this.stop(t); | |
let n = s => { | |
s.target === t && t.dataset.animationName && (t.removeEventListener('animationend', n), delete t.dataset.animationName, i && i(), x(t, e)); | |
}; | |
t.dataset.animationName = e; | |
t.addEventListener('animationend', n); | |
y(t, e); | |
} | |
stop(t) { | |
t && t.dispatchEvent(new CustomEvent('animationend', { | |
bubbles: false, | |
cancelable: true, | |
currentTarget: t | |
})); | |
} | |
setContent(t, e = '', i = true) { | |
if (this.isClosing()) { | |
return; | |
} | |
let n = t.el; | |
if (!n) { | |
return; | |
} | |
let s = null; | |
if (C(e) ? s = e : (s = S(e + ''), C(s) || (s = document.createElement('div'), s.innerHTML = e + '')), [ | |
'img', | |
'picture', | |
'iframe', | |
'video', | |
'audio' | |
].includes(s.nodeName.toLowerCase())) { | |
let a = document.createElement('div'); | |
a.appendChild(s); | |
s = a; | |
} | |
C(s) && t.filter && !t.error && (s = s.querySelector(t.filter)); | |
s && C(s) ? (y(s, 'fancybox__content'), t.id && s.setAttribute('id', t.id), n.classList.add(`has-${ t.error ? 'error' : t.type || 'unknown' }`), n.prepend(s), s.style.display === 'none' && (s.style.display = ''), getComputedStyle(s).getPropertyValue('display') === 'none' && (s.style.display = t.display || this.option('defaultDisplay') || 'flex'), t.contentEl = s, i && this.revealContent(t), this.manageCloseBtn(t), this.manageCaption(t)) : this.setError(t, '{{ELEMENT_NOT_FOUND}}'); | |
} | |
revealContent(t, e) { | |
let i = t.el, n = t.contentEl; | |
i && n && (this.emit('reveal', t), this.hideLoading(t), t.state = Z.Opening, (e = this.isOpeningSlide(t) ? e === void 0 ? this.optionFor(t, 'showClass') : e : 'f-fadeIn') ? this.animate(n, e, () => { | |
this.done(t); | |
}) : this.done(t)); | |
} | |
done(t) { | |
this.isClosing() || (t.state = Z.Ready, this.emit('done', t), y(t.el, 'is-done'), this.isCurrentSlide(t) && this.option('autoFocus') && queueMicrotask(() => { | |
var e; | |
(e = t.panzoom) === null || e === void 0 || e.updateControls(); | |
this.option('autoFocus') && this.focus(); | |
}), this.isOpeningSlide(t) && (x(this.container, 'is-opening'), !this.isCompact && this.option('idle') && this.setIdle())); | |
} | |
isCurrentSlide(t) { | |
let e = this.getSlide(); | |
return !(!t || !e) && e.index === t.index; | |
} | |
isOpeningSlide(t) { | |
var e, i; | |
return ((e = this.carousel) === null || e === void 0 ? void 0 : e.prevPage) === null && t && t.index === ((i = this.getSlide()) === null || i === void 0 ? void 0 : i.index); | |
} | |
showLoading(t) { | |
; | |
let e = t.el; | |
e && (y(e, 'is-loading'), this.emit('loading', t), t.spinnerEl || setTimeout(() => { | |
if (!this.isClosing() && !t.spinnerEl && t.state === Z.Loading) { | |
let i = S(ze); | |
y(i, 'fancybox-spinner'); | |
; | |
e.prepend(i); | |
this.animate(i, 'f-fadeIn'); | |
} | |
}, 250)); | |
} | |
hideLoading(t) { | |
let e = t.el; | |
if (!e) { | |
return; | |
} | |
let i = t.spinnerEl; | |
this.isClosing() ? i?.remove() : (x(e, 'is-loading'), i && this.animate(i, 'f-fadeOut', () => { | |
i.remove(); | |
}), t.state === Z.Loading && (this.emit('loaded', t), t.state = Z.Ready)); | |
} | |
setError(t, e) { | |
if (this.isClosing()) { | |
return; | |
} | |
let i = new Event('error', { | |
bubbles: true, | |
cancelable: true | |
}); | |
if (this.emit('error', i, t), i.defaultPrevented) { | |
return; | |
} | |
; | |
this.hideLoading(t); | |
this.clearContent(t); | |
let n = document.createElement('div'); | |
n.classList.add('fancybox-error'); | |
n.innerHTML = this.localize(e || '<p>{{ERROR}}</p>'); | |
this.setContent(t, n); | |
} | |
clearContent(t) { | |
if (t.state === void 0) { | |
return; | |
} | |
this.emit('clearContent', t); | |
t.contentEl && (t.contentEl.remove(), t.contentEl = void 0); | |
let e = t.el; | |
e && (x(e, 'has-error'), x(e, 'has-unknown'), x(e, `has-${ t.type || 'unknown' }`)); | |
t.closeBtnEl && t.closeBtnEl.remove(); | |
; | |
t.captionEl && t.captionEl.remove(); | |
; | |
t.spinnerEl && t.spinnerEl.remove(); | |
; | |
} | |
getSlide() { | |
var t; | |
let e = this.carousel; | |
return ((t = e?.pages[e?.page]) === null || t === void 0 ? void 0 : t.slides[0]) || void 0; | |
} | |
close(t, e) { | |
if (this.isClosing()) { | |
return; | |
} | |
let i = new Event('shouldClose', { | |
bubbles: true, | |
cancelable: true | |
}); | |
if (this.emit('shouldClose', i, t), i.defaultPrevented) { | |
return; | |
} | |
t && t.cancelable && (t.preventDefault(), t.stopPropagation()); | |
let n = () => { | |
this.proceedClose(t, e); | |
}; | |
this.startedFs && N && N.isFullscreen() ? Promise.resolve(N.exit()).then(() => n()) : n(); | |
} | |
clearIdle() { | |
this.idleTimer && clearTimeout(this.idleTimer); | |
this.idleTimer = null; | |
} | |
setIdle(t = false) { | |
let e = () => { | |
this.clearIdle(); | |
this.idle = true; | |
y(this.container, 'is-idle'); | |
this.emit('setIdle'); | |
}; | |
if (this.clearIdle(), !this.isClosing()) { | |
if (t) { | |
e(); | |
} else { | |
let i = this.option('idle'); | |
i && (this.idleTimer = setTimeout(e, i)); | |
} | |
} | |
} | |
endIdle() { | |
this.clearIdle(); | |
this.idle && !this.isClosing() && (this.idle = false, x(this.container, 'is-idle'), this.emit('endIdle')); | |
} | |
resetIdle() { | |
this.endIdle(); | |
this.setIdle(); | |
} | |
toggleIdle() { | |
this.idle ? this.endIdle() : this.setIdle(true); | |
} | |
toggleFullscreen() { | |
N && (N.isFullscreen() ? N.exit() : N.request().then(() => { | |
this.startedFs = true; | |
})); | |
} | |
isClosing() { | |
return [ | |
A.Closing, | |
A.CustomClosing, | |
A.Destroy | |
].includes(this.state); | |
} | |
proceedClose(t, e) { | |
var i, n; | |
this.state = A.Closing; | |
this.clearIdle(); | |
this.detachEvents(); | |
let s = this.container, a = this.carousel, r = this.getSlide(), l = r && this.option('placeFocusBack') ? r.triggerEl || this.option('triggerEl') : null; | |
if (l && (Gi(l) ? Fi(l) : l.focus()), s && (x(s, 'is-opening'), y(s, 'is-closing'), s.setAttribute('aria-hidden', 'true'), this.option('animated') && y(s, 'is-animated'), s.style.pointerEvents = 'none'), a) { | |
a.clearTransitions(); | |
(i = a.panzoom) === null || i === void 0 || i.destroy(); | |
(n = a.plugins.Navigation) === null || n === void 0 || n.detach(); | |
for (let c of a.slides) { | |
c.state = Z.Closing; | |
this.hideLoading(c); | |
let d = c.contentEl; | |
d && this.stop(d); | |
let u = c?.panzoom; | |
u && (u.stop(), u.detachEvents(), u.detachObserver()); | |
this.isCurrentSlide(c) || a.emit('removeSlide', c); | |
} | |
} | |
Ri = window.scrollX; | |
ki = window.scrollY; | |
window.addEventListener('scroll', this.onScroll); | |
this.emit('close', t); | |
this.state !== A.CustomClosing ? (e === void 0 && r && (e = this.optionFor(r, 'hideClass')), e && r ? (this.animate(r.contentEl, e, () => { | |
a && a.emit('removeSlide', r); | |
}), setTimeout(() => { | |
this.destroy(); | |
}, 500)) : this.destroy()) : setTimeout(() => { | |
this.destroy(); | |
}, 500); | |
} | |
destroy() { | |
var t; | |
if (this.state === A.Destroy) { | |
return; | |
} | |
window.removeEventListener('scroll', this.onScroll); | |
this.state = A.Destroy; | |
(t = this.carousel) === null || t === void 0 || t.destroy(); | |
let e = this.container; | |
e && e.remove(); | |
lt.delete(this.id); | |
let i = o.getInstance(); | |
i ? i.focus() : (R && (R.remove(), R = null), tt && (tt.remove(), tt = null), x(document.documentElement, 'with-fancybox'), (() => { | |
if (!gt) { | |
return; | |
} | |
let n = document, s = n.body; | |
s.classList.remove('hide-scrollbar'); | |
s.style.setProperty('--fancybox-body-margin', ''); | |
n.documentElement.style.setProperty('--fancybox-scrollbar-compensate', ''); | |
})(), this.emit('destroy')); | |
} | |
static bind(t, e, i) { | |
if (!gt) { | |
return; | |
} | |
let n, s = '', a = { | |
Carousel: a.Carousel || {}, | |
innerHTML: await n.text() | |
}; | |
if (t === void 0 ? n = document.body : _(t) ? (n = document.body, s = t, typeof e == 'object' && (a = e || {})) : (n = t, _(e) && (s = e), typeof i == 'object' && (a = i || {})), !n || !C(n)) { | |
return; | |
} | |
s = s || '[data-fancybox]'; | |
let r = o.openers.get(n) || new Map(); | |
r.set(s, a); | |
o.openers.set(n, r); | |
r.size === 1 && n.addEventListener('click', o.fromEvent); | |
} | |
static unbind(t, e) { | |
let i, n = ''; | |
if (_(t) ? (i = document.body, n = t) : (i = t, _(e) && (n = e)), !i) { | |
return; | |
} | |
let s = o.openers.get(i); | |
s && n && s.delete(n); | |
n && s || (o.openers.delete(i), i.removeEventListener('click', o.fromEvent)); | |
} | |
static destroy() { | |
let t; | |
for (; t = o.getInstance();) { | |
t.destroy(); | |
} | |
for (let e of o.openers.keys()) | |
e.removeEventListener('click', o.fromEvent); | |
o.openers = new Map(); | |
} | |
static fromEvent(t) { | |
if (t.defaultPrevented || t.button && t.button !== 0 || t.ctrlKey || t.metaKey || t.shiftKey) { | |
return; | |
} | |
let e = t.composedPath()[0], i = e.closest('[data-fancybox-trigger]'); | |
if (i) { | |
let b = i.dataset.fancyboxTrigger || '', p = document.querySelectorAll(`[data-fancybox="${ b }"]`), f = parseInt(i.dataset.fancyboxIndex || '', 10) || 0; | |
e = p[f] || e; | |
} | |
if (!(e && e instanceof Element)) { | |
return; | |
} | |
let n, s, a, r; | |
if ([...o.openers].reverse().find(([b, p]) => !(!b.contains(e) || ![...p].reverse().find(([f, g]) => { | |
let F = e.closest(f); | |
return !!F && (n = b, s = f, a = F, r = g, true); | |
}))), !n || !s || !a) { | |
return; | |
} | |
r = r || {}; | |
t.preventDefault(); | |
e = a; | |
let l = [], c = E({}, Ie, r); | |
c.event = t; | |
c.triggerEl = e; | |
c.delegate = i; | |
let d = c.groupAll, u = c.groupAttr, m = u && e ? e.getAttribute(`${ u }`) : ''; | |
if ((!e || m || d) && (l = [].slice.call(n.querySelectorAll(s))), e && !d && (l = m ? l.filter(b => b.getAttribute(`${ u }`) === m) : [e]), !l.length) { | |
return; | |
} | |
let h = o.getInstance(); | |
return h && h.options.triggerEl && l.indexOf(h.options.triggerEl) > -1 ? void 0 : (e && (c.startIndex = l.indexOf(e)), o.fromNodes(l, c)); | |
} | |
static fromSelector(t, e, i) { | |
let n = null, s = '', a = {}; | |
if (_(t) ? (n = document.body, s = t, typeof e == 'object' && (a = e || {})) : t instanceof HTMLElement && _(e) && (n = t, s = e, typeof i == 'object' && (a = i || {})), !n || !s) { | |
return false; | |
} | |
let r = o.openers.get(n); | |
return !!r && (a = E({}, r.get(s) || {}, a), !!a && o.fromNodes(Array.from(n.querySelectorAll(s)), a)); | |
} | |
static fromNodes(t, e) { | |
e = E({}, Ie, e || {}); | |
let i = []; | |
for (let n of t) { | |
let s = n.dataset || {}, a = s.src || n.getAttribute('href') || n.getAttribute('currentSrc') || n.getAttribute('src') || void 0, r, l = e.delegate, c; | |
l && i.length === e.startIndex && (r = l instanceof HTMLImageElement ? l : l.querySelector('img:not([aria-hidden])')); | |
r || (r = n instanceof HTMLImageElement ? n : n.querySelector('img:not([aria-hidden])')); | |
r && (c = r.currentSrc || r.src || void 0, !c && r.dataset && (c = r.dataset.lazySrc || r.dataset.src || void 0)); | |
let d = { | |
src: a, | |
triggerEl: n, | |
thumbEl: r, | |
thumbElSrc: c, | |
thumbSrc: c | |
}; | |
for (let u in s) { | |
let m = s[u] + ''; | |
m = m !== 'false' && (m === 'true' || m); | |
d[u] = m; | |
} | |
i.push(d); | |
} | |
return new o(i, e); | |
} | |
static getInstance(t) { | |
return t ? lt.get(t) : Array.from(lt.values()).reverse().find(e => !e.isClosing() && e) || null; | |
} | |
static getSlide() { | |
var t; | |
return ((t = o.getInstance()) === null || t === void 0 ? void 0 : t.getSlide()) || null; | |
} | |
static show(t = [], e = {}) { | |
return new o(t, e); | |
} | |
static next() { | |
let t = o.getInstance(); | |
t && t.next(); | |
} | |
static prev() { | |
let t = o.getInstance(); | |
t && t.prev(); | |
} | |
static close(t = true, ...e) { | |
if (t) { | |
for (let i of lt.values()) | |
i.close(...e); | |
} else { | |
let i = o.getInstance(); | |
i && i.close(...e); | |
} | |
} | |
}; | |
Object.defineProperty(M, 'version', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: '5.0.36' | |
}); | |
Object.defineProperty(M, 'defaults', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: Ie | |
}); | |
Object.defineProperty(M, 'Plugins', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: ns | |
}); | |
Object.defineProperty(M, 'openers', { | |
enumerable: true, | |
configurable: true, | |
writable: true, | |
value: new Map() | |
}); | |
var Kt = class extends V { | |
submit(o) { | |
o.preventDefault(); | |
this.fieldTarget.classList.remove('animate-error'); | |
let t = o.target.code.value; | |
if (t = t.toLowerCase(), t = t.replace(/[^a-z0-9?]/gi, ''), document.getElementById(t)) { | |
this.fancyContent(t); | |
} else { | |
if (t.length < 2) { | |
this.flashError(); | |
} else { | |
this.fieldTarget.setAttribute('readonly', true); | |
this.buttonTarget.setAttribute('disabled', true); | |
window.hasOwnProperty('plausible') && window.plausible('Submit', { props: { code: t } }); | |
let i = new FormData(); | |
i.append('code', t); | |
fetch('https://mystery.thisisnotawebsitedotcom.com/', { | |
method: 'POST', | |
body: i | |
}).then(async n => { | |
if (!n.ok) { | |
this.flashError(); | |
} else { | |
let s = n.headers.get('content-type'), a = document.createElement('div'); | |
a.setAttribute('id', t); | |
a.classList.add('hidden', 'html'); | |
; | |
document.body.appendChild(a); | |
this.fancyContent(t); | |
} | |
this.fieldTarget.removeAttribute('readonly'); | |
this.buttonTarget.removeAttribute('disabled'); | |
}); | |
} | |
} | |
} | |
flashError() { | |
this.fieldTarget.offsetHeight; | |
this.fieldTarget.classList.add('animate-error'); | |
} | |
fancyContent(o) { | |
new M([{ | |
src: `#${ o }`, | |
type: 'inline' | |
}], { | |
backdropClick: false, | |
Toolbar: { | |
display: { | |
left: [], | |
middle: [], | |
right: ['close'] | |
} | |
} | |
}); | |
} | |
expandImage(o) { | |
new M([{ src: o.target.src }], { | |
backdropClick: 'toggleZoom', | |
Toolbar: { | |
display: { | |
left: [], | |
middle: [], | |
right: ['close'] | |
} | |
} | |
}); | |
} | |
randomizeError() { | |
if (this.hasBubbleTarget) { | |
let o = [ | |
'Oops, the Mystery Shack is currently experiencing some delays dude! Please bare with us as we figure out which wire goes where!', | |
'Lets see... the blue wire is connected to the....hip bone....', | |
'So what I wanna know is, why are cryptic riddles always written down on tattered yellowed parchment. Get some normal paper dude!', | |
'Still comin, dudes! In the meantime, please <a href=\'https://files.thisisnotawebsitedotcom.com/is-it-time-yet/the-great-gatsby.pdf\' target=\'_blank\'>enjoy this fine literature</a> while you wait. People are saying its the book of the summer!', | |
'In the meantime, experience some <a href=\'https://www.youtube.com/watch?v=qQJorCFgEHg\' target=\'_blank\'>soothing tunes</a> while you wait. They drown out the rage, dude!', | |
'I tried to explain to Mr Pines how to open a PDF one time. He got so angry and confused that he punched through my Funko shelf! Many brave Funkos were lost that day...', | |
'My favorite Otter Pop is Sir Isaac Lime. But Louie Bloo is pretty cool too. Which is your favorite Otter Pop? Sound off in chat!', | |
'If the ICEE bear was real, I wonder if he would be my friend...', | |
'Hopefully nobody was expecting anything too crazy , heh heh!', | |
'Hey dude, did you know that computers are filled with ghouls? That\u2019s a fact.', | |
'I\u2019M gonna watch YOU. You\u2019re the website now, dude!', | |
'To quote a great man, \u201Ceverythings gonna be alright...rockabye\u201D', | |
'I wonder if its possible to taste your own tongue. Im gonna get to the bottom of this,dude!', | |
'Boy that counter is MESSED UP. I guess we\u2019ll be ready when it finally reaches the bottom of....math?', | |
'Man, I tried to look at that Bill Book and it was just a bunch of static and the words \u201CHE\u2019S UNCORRUPTABLE.\u201D Whats that mean? Beats me, dawg!', | |
'Are you Blanchin? Girl we blanchin! I live up in a- dang, still in my head!', | |
'If I can\u2019t get this fixed, this WILL be the Final Countdown, dudes!', | |
'Ugh man did you see the new <u>Swordbirth: Rise of the Swordians: Age of Swords</u> DLC just got delayed AGAIN? Don\u2019t they understand, as a consumer, my time is valuable!?<br/>...<br/>I wonder if I could make a hat small enough to fit on a bird.', | |
'<img src=\'\' style=\'width: 100%\' />' | |
], t = Math.floor(Math.random() * o.length); | |
o[t].includes('data:image') && (t = Math.floor(Math.random() * o.length)); | |
this.bubbleTarget.innerHTML = o[t]; | |
o[t].includes('data:image') && this.hasLayerTarget ? this.layerTarget.classList.remove('hidden') : this.layerTarget.classList.add('hidden'); | |
} | |
} | |
}; | |
Ft(Kt, 'targets', [ | |
'button', | |
'field', | |
'bubble', | |
'layer' | |
]); | |
var os = { | |
'./controllers/countdown_controller.js': Be, | |
'./controllers/secrets_controller.js': Te | |
}, Hi = os; | |
window.Stimulus = Lt.start(); | |
Object.entries(Hi).forEach(([o, t]) => { | |
if (o.includes('_controller.') || o.includes('-controller.')) { | |
let e = o.replace('./controllers/', '').replace(/[_-]controller\..*$/, '').replace(/_/g, '-').replace(/\//g, '--'); | |
Stimulus.register(e, t.default); | |
} | |
}); | |
})(); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment