From b5710d0694b19432921c735de13e88b38d514e7d Mon Sep 17 00:00:00 2001 From: Nikola Stamatovic Date: Wed, 7 Feb 2024 01:02:36 +0100 Subject: [PATCH] add group states --- src/lib/controls.js | 17 ++++++++++++++++- youtube-background-experimental.js | 21 +++++++++++++++++++-- youtube-background-experimental.js.map | 4 ++-- youtube-background-experimental.min.js | 2 +- 4 files changed, 38 insertions(+), 6 deletions(-) diff --git a/src/lib/controls.js b/src/lib/controls.js index 37e78a8..e8799b4 100644 --- a/src/lib/controls.js +++ b/src/lib/controls.js @@ -73,6 +73,12 @@ export class VideoBackgroundGroup { this.videoBackgroundFactoryInstance = videoBackgroundFactoryInstance; this.stack = []; this.map = new Map(); + this.current = 0; + this.currentElement = null; + this.currentInstance = null; + + this.playing = false; + this.muted = true; for (let i = 0; i < this.elements.length; i++) { const element = this.elements[i]; @@ -104,7 +110,12 @@ export class VideoBackgroundGroup { if (this.stack[this.current] !== event.detail.element) return; this.setVideoBackgroundFactoryInstance(event); const videoBackground = event.detail; - if (videoBackground.currentState !== 'playing' && videoBackground.isIntersecting) videoBackground.softPlay(); + if (videoBackground.params.muted) this.muted = true; + if (!videoBackground.isIntersecting) return; + if (!videoBackground.params.autoplay) return; + this.playing = true; + if (videoBackground.currentState === 'playing') return; + videoBackground.softPlay(); } onVideoPause(event) {; @@ -202,6 +213,7 @@ export class VideoBackgroundGroup { instance.unmute(); } + this.muted = false; this.dispatchEvent('video-background-group-umnute'); } @@ -212,16 +224,19 @@ export class VideoBackgroundGroup { instance.mute(); } + this.muted = true; this.dispatchEvent('video-background-group-mute'); } pause() { this.currentInstance.pause(); + this.playing = false; this.dispatchEvent('video-background-group-previous'); } play() { this.currentInstance.play(); + this.playing = true; this.dispatchEvent('video-background-group-previous'); } diff --git a/youtube-background-experimental.js b/youtube-background-experimental.js index 4feba0f..0469a73 100644 --- a/youtube-background-experimental.js +++ b/youtube-background-experimental.js @@ -78,6 +78,11 @@ this.videoBackgroundFactoryInstance = videoBackgroundFactoryInstance; this.stack = []; this.map = /* @__PURE__ */ new Map(); + this.current = 0; + this.currentElement = null; + this.currentInstance = null; + this.playing = false; + this.muted = true; for (let i = 0; i < this.elements.length; i++) { const element = this.elements[i]; if (!element.hasAttribute("data-vbg-uid") && this.videoBackgroundFactoryInstance) @@ -110,8 +115,16 @@ return; this.setVideoBackgroundFactoryInstance(event); const videoBackground = event.detail; - if (videoBackground.currentState !== "playing" && videoBackground.isIntersecting) - videoBackground.softPlay(); + if (videoBackground.params.muted) + this.muted = true; + if (!videoBackground.isIntersecting) + return; + if (!videoBackground.params.autoplay) + return; + this.playing = true; + if (videoBackground.currentState === "playing") + return; + videoBackground.softPlay(); } onVideoPause(event) { ; @@ -211,6 +224,7 @@ continue; instance.unmute(); } + this.muted = false; this.dispatchEvent("video-background-group-umnute"); } mute() { @@ -220,14 +234,17 @@ continue; instance.mute(); } + this.muted = true; this.dispatchEvent("video-background-group-mute"); } pause() { this.currentInstance.pause(); + this.playing = false; this.dispatchEvent("video-background-group-previous"); } play() { this.currentInstance.play(); + this.playing = true; this.dispatchEvent("video-background-group-previous"); } destroy() { diff --git a/youtube-background-experimental.js.map b/youtube-background-experimental.js.map index deca22d..0ca1dc3 100644 --- a/youtube-background-experimental.js.map +++ b/youtube-background-experimental.js.map @@ -1,7 +1,7 @@ { "version": 3, "sources": ["src/lib/controls.js", "src/experimental.js"], - "sourcesContent": ["export class SeekBar {\n constructor(element, vbgInstance) {\n this.lock = false;\n if (!element) return;\n this.element = element;\n if (this.element.hasAttribute('data-target-uid')) return;\n this.progressElem = this.element.querySelector('.js-seek-bar-progress');\n this.inputElem = this.element.querySelector('.js-seek-bar');\n this.targetSelector = this.element.getAttribute('data-target');\n if (this.targetSelector) this.targetElem = document.querySelector(this.targetSelector);\n if (!this.targetSelector && vbgInstance) this.targetElem = vbgInstance.element;\n if (!this.targetElem) return;\n\n if (vbgInstance) this.setVBGInstance(vbgInstance);\n \n this.targetElem.addEventListener('video-background-time-update', this.onTimeUpdate.bind(this));\n this.targetElem.addEventListener('video-background-play', this.onReady.bind(this));\n this.targetElem.addEventListener('video-background-ready', this.onReady.bind(this));\n this.targetElem.addEventListener('video-background-destroyed', this.onDestroyed.bind(this));\n\n this.inputElem.addEventListener('input', this.onInput.bind(this));\n this.inputElem.addEventListener('change', this.onChange.bind(this));\n }\n\n setVBGInstance(vbgInstance) {\n if (this.vbgInstance) return;\n this.vbgInstance = vbgInstance;\n this.element.setAttribute('data-target-uid', vbgInstance.uid);\n }\n\n onReady(event) {\n this.setVBGInstance(event.detail);\n }\n\n onTimeUpdate(event) {\n this.setVBGInstance(event.detail);\n if (!this.lock) requestAnimationFrame(() => this.setProgress(this.vbgInstance.percentComplete));\n }\n\n onDestroyed(event) {\n this.vbgInstance = null;\n requestAnimationFrame(() => this.setProgress(0));\n }\n\n onInput(event) {\n this.lock = true;\n requestAnimationFrame(() => this.setProgress(event.target.value));\n }\n\n onChange(event) {\n this.lock = false;\n requestAnimationFrame(() => this.setProgress(event.target.value));\n if (this.vbgInstance) {\n this.vbgInstance.seek(event.target.value);\n if (this.vbgInstance.playerElement && this.vbgInstance.playerElement.style.opacity === 0) this.vbgInstance.playerElement.style.opacity = 1;\n }\n}\n\n setProgress(value) {\n if (this.progressElem) this.progressElem.value = value;\n if (this.inputElem) this.inputElem.value = value;\n }\n}\n\nexport class VideoBackgroundGroup {\n constructor(selector, videoBackgroundSelector, videoBackgroundFactoryInstance) {\n this.element = selector;\n if (typeof this.element === 'string') this.element = document.querySelector(selector);\n if (!this.element) return;\n this.elements = this.element.querySelectorAll(videoBackgroundSelector || '[data-vbg]');\n if (!this.elements.length) return;\n\n this.videoBackgroundFactoryInstance = videoBackgroundFactoryInstance;\n this.stack = [];\n this.map = new Map();\n\n for (let i = 0; i < this.elements.length; i++) {\n const element = this.elements[i];\n if (!element.hasAttribute('data-vbg-uid') && this.videoBackgroundFactoryInstance) this.videoBackgroundFactoryInstance.add(element);\n this.stack.push(element);\n this.map.set(element, i);\n \n if (i === 0) {\n this.current = 0;\n this.currentElement = element;\n if (this.videoBackgroundFactoryInstance) this.currentInstance = this.videoBackgroundFactoryInstance.get(element);\n }\n element.addEventListener('video-background-ended', this.onVideoEnded.bind(this));\n element.addEventListener('video-background-seeked', this.onVideoSeeked.bind(this));\n element.addEventListener('video-background-pause', this.onVideoPause.bind(this));\n element.addEventListener('video-background-ready', this.onVideoReady.bind(this));\n element.addEventListener('video-background-state-change', this.setVideoBackgroundFactoryInstance.bind(this), { once: true });\n element.addEventListener('video-background-time-update', this.setVideoBackgroundFactoryInstance.bind(this), { once: true });\n }\n }\n\n setVideoBackgroundFactoryInstance(event) {\n if (this.videoBackgroundFactoryInstance) return;\n this.videoBackgroundFactoryInstance = event.detail.factoryInstance;\n if (!this.currentInstance) this.currentInstance = this.videoBackgroundFactoryInstance.get(this.currentElement);\n }\n\n onVideoReady(event) {\n if (this.stack[this.current] !== event.detail.element) return;\n this.setVideoBackgroundFactoryInstance(event);\n const videoBackground = event.detail;\n if (videoBackground.currentState !== 'playing' && videoBackground.isIntersecting) videoBackground.softPlay();\n }\n\n onVideoPause(event) {;\n this.setVideoBackgroundFactoryInstance(event);\n const stackIndex = this.map.get(event.detail.element);\n if (stackIndex === this.current) return;\n }\n\n levelSeekBars() {\n for (let i = 0; i < this.stack.length; i++) {\n if (i === this.current) continue;\n const seekBarElem = this.getSeekBar(this.videoBackgroundFactoryInstance.get(this.stack[i]));\n if (!seekBarElem) continue;\n if (i < this.current) {\n this.setProgress(seekBarElem, 100);\n } else {\n this.setProgress(seekBarElem, 0);\n }\n }\n }\n\n getSeekBar(currentInstance) {\n if (!currentInstance) return;\n const uid = currentInstance.uid;\n const element = document.querySelector(`.js-seek-bar-wrap[data-target-uid=\"${uid}\"]`);\n if (!element) return;\n return element;\n }\n\n setProgress(seekBarElem, value) {\n if (!seekBarElem) return;\n const progressElem = seekBarElem.querySelector('.js-seek-bar-progress');\n const inputElem = seekBarElem.querySelector('.js-seek-bar');\n if (progressElem) progressElem.value = value;\n if (inputElem) inputElem.value = value;\n }\n\n onVideoSeeked(event) {\n const current = this.map.get(event.detail.element);\n if (this.current !== current) this.setCurrent(current, true);\n }\n\n setCurrent(index, seek) {\n const previous = this.current;\n if (index >= this.stack.length) index = 0;\n if (index < 0) index = this.stack.length - 1;\n const previousInstance = this.videoBackgroundFactoryInstance.get(this.stack[previous]);\n this.current = index;\n this.currentInstance = this.videoBackgroundFactoryInstance.get(this.stack[this.current]);\n this.currentElement = this.stack[this.current];\n \n this.stack[previous].style.display = 'none';\n this.currentElement.style.display = 'block';\n\n if (!seek) {\n const seekBarElem = this.getSeekBar(this.currentInstance);\n if (seekBarElem) this.setProgress(seekBarElem, 0);\n this.currentInstance.seek(0);\n }\n\n setTimeout(() => {\n if (this.currentInstance.currentState !== 'playing') this.currentInstance.play();\n }, 100);\n if (previousInstance && previousInstance.currentState !== 'paused') previousInstance.pause();\n\n setTimeout(this.levelSeekBars.bind(this), 100);\n\n if (index >= this.stack.length) this.dispatchEvent('video-background-group-forward-rewind');\n if (index < 0) this.dispatchEvent('video-background-group-backward-rewind');\n }\n\n dispatchEvent(name) {\n this.element.dispatchEvent(new CustomEvent(name, { bubbles: true, detail: this }));\n }\n\n onVideoEnded(event) {\n if (event.detail.element !== this.currentElement) return;\n this.next();\n }\n\n next() {\n this.setCurrent(this.current + 1);\n this.dispatchEvent('video-background-group-next');\n }\n\n prev() {\n this.setCurrent(this.current - 1);\n this.dispatchEvent('video-background-group-previous');\n }\n\n unmute() {\n for (let i = 0; i < this.stack.length; i++) {\n const instance = this.videoBackgroundFactoryInstance.get(this.stack[i]);\n if (!instance) continue;\n instance.unmute();\n }\n\n this.dispatchEvent('video-background-group-umnute');\n }\n\n mute() {\n for (let i = 0; i < this.stack.length; i++) {\n const instance = this.videoBackgroundFactoryInstance.get(this.stack[i]);\n if (!instance) continue;\n instance.mute();\n }\n\n this.dispatchEvent('video-background-group-mute');\n }\n\n pause() {\n this.currentInstance.pause();\n this.dispatchEvent('video-background-group-previous');\n }\n\n play() {\n this.currentInstance.play();\n this.dispatchEvent('video-background-group-previous');\n }\n\n destroy() {\n for (let i = 0; i < this.elements.length; i++) {\n const element = this.elements[i];\n element.removeEventListener('video-background-ended', this.onVideoEnded.bind(this));\n element.removeEventListener('video-background-seeked', this.onVideoSeeked.bind(this));\n element.removeEventListener('video-background-pause', this.onVideoPause.bind(this));\n element.removeEventListener('video-background-ready', this.onVideoReady.bind(this));\n element.removeEventListener('video-background-state-change', this.setVideoBackgroundFactoryInstance.bind(this));\n element.removeEventListener('video-background-time-update', this.setVideoBackgroundFactoryInstance.bind(this));\n }\n }\n}\n\nexport class PlayToggle {\n constructor(playToggleElem, vbgInstance) {\n if (!playToggleElem) return;\n \n this.element = playToggleElem;\n this.targetSelector = this.element.getAttribute('data-target');\n\n if (!this.targetSelector) return;\n this.active = false;\n\n if (this.element.hasAttribute('aria-checked')) {\n this.active = this.element.getAttribute('aria-checked') === 'true';\n } else {\n this.element.setAttribute('aria-checked', this.active);\n }\n\n this.element.setAttribute('role', 'switch');\n\n this.targetElem = document.querySelector(this.targetSelector);\n if (!this.targetElem) return;\n\n if (vbgInstance) this.vbgInstance = vbgInstance;\n\n this.targetElem.addEventListener('video-background-ready', this.onReady.bind(this));\n this.targetElem.addEventListener('video-background-state-change', this.onStateChange.bind(this));\n this.targetElem.addEventListener('video-background-play', this.onPlay.bind(this));\n this.targetElem.addEventListener('video-background-pause', this.onPause.bind(this));\n this.targetElem.addEventListener('video-background-destroyed', this.onDestroyed.bind(this));\n\n this.element.addEventListener('click', this.onClick.bind(this));\n }\n\n onReady(event) {\n this.vbgInstance = event.detail;\n }\n\n onStateChange(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = this.vbgInstance.currentState === 'playing' || this.vbgInstance.currentState === 'buffering';\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onPlay(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = true;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onPause(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = false;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onDestroyed(event) {\n this.vbgInstance = null;\n this.active = false;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onClick(event) {\n if (!this.vbgInstance) return;\n if (this.active) {\n this.vbgInstance.pause();\n } else {\n this.vbgInstance.play();\n }\n }\n}\n\nexport class MuteToggle {\n constructor(muteToggleElem, vbgInstance) {\n if (!muteToggleElem) return;\n \n this.element = muteToggleElem;\n this.targetSelector = this.element.getAttribute('data-target');\n\n if (!this.targetSelector) return;\n this.active = false;\n\n if (this.element.hasAttribute('aria-checked')) {\n this.active = this.element.getAttribute('aria-checked') === 'true';\n } else {\n this.element.setAttribute('aria-checked', this.active);\n }\n\n this.element.setAttribute('role', 'switch');\n\n this.targetElem = document.querySelector(this.targetSelector);\n if (!this.targetElem) return;\n\n if (vbgInstance) this.vbgInstance = vbgInstance;\n\n this.targetElem.addEventListener('video-background-ready', this.onReady.bind(this));\n this.targetElem.addEventListener('video-background-mute', this.onMute.bind(this));\n this.targetElem.addEventListener('video-background-unmute', this.onUnmute.bind(this));\n this.targetElem.addEventListener('video-background-destroyed', this.onDestroyed.bind(this));\n\n this.element.addEventListener('click', this.onClick.bind(this));\n }\n\n onReady(event) {\n this.vbgInstance = event.detail;\n if (this.vbgInstance.params.muted) {\n this.active = true;\n this.element.setAttribute('aria-checked', this.active);\n }\n }\n\n onMute(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = true;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onUnmute(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = false;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onDestroyed(event) {\n this.vbgInstance = null;\n this.active = false;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onClick(event) {\n if (!this.vbgInstance) return;\n if (this.active) {\n this.vbgInstance.unmute();\n } else {\n this.vbgInstance.mute();\n }\n }\n}\n\n// TODO: this can be achieved with custom elements... Maybe it's finally time to use them?\nclass GeneralFactory {\n constructor(selector, callback, uidAttribute = 'data-uid') {\n this.instances = {};\n this.selector = selector;\n this.elements = [];\n this.callback = callback;\n this.uidAttribute = uidAttribute;\n\n if (!callback || typeof callback !== 'function') return;\n\n if (typeof this.selector === 'string') {\n this.elements = document.querySelectorAll(this.selector);\n }\n\n if (this.selector instanceof Element) {\n this.elements = [this.selector];\n }\n\n if (this.selector instanceof NodeList) {\n this.elements = this.selector;\n }\n\n for (let i = 0; i < this.elements.length; i++) {\n this.add(this.elements[i]);\n\n // TODO: maybe manage elements array?\n }\n }\n\n basicUID() {\n return Date.now().toString(36) + Math.random().toString(36).substring(2);\n }\n\n generateUID() {\n let tempuid = this.basicUID();\n if (!this.instances.hasOwnProperty(tempuid)) return tempuid;\n return this.generateUID();\n }\n\n add(element) {\n let id = element.getAttribute('id');\n if (!id || this.instances.hasOwnProperty(id)) {\n id = element.getAttribute(this.uidAttribute);\n\n if (!id || this.instances.hasOwnProperty(id)) {\n id = this.generateUID();\n element.setAttribute(this.uidAttribute, id);\n }\n }\n\n if (this.callback && typeof this.callback === 'function') \n this.instances[id] = this.callback(element, id, this);\n }\n\n getID(element) {\n if (!element) return;\n if (typeof element === 'string') return element;\n const id = element.getAttribute('id');\n if (id && this.instances.hasOwnProperty(id)) return id;\n const uid = element.getAttribute(this.uidAttribute);\n if (uid && this.instances.hasOwnProperty(uid)) return uid;\n }\n\n get(element) {\n if (!element) return;\n const id = this.getID(element);\n if (!id) return;\n return this.instances[id];\n }\n\n destroy(element) {\n if (!element) return;\n const id = this.getID(element);\n if (!id) return;\n const instance = this.instances[id];\n if (instance.hasOwnProperty('destroy') && typeof instance.destroy == 'function') this.instances[id].destroy();\n delete this.instances[id];\n }\n\n destroyAll() {\n for (const uid in this.instances) {\n const instance = this.instances[uid];\n if (instance.hasOwnProperty('destroy') && typeof instance.destroy == 'function') instance.destroy();\n delete this.instances[uid];\n }\n }\n}\n\nexport class VideoBackgroundGroups extends GeneralFactory {\n constructor(selector = '.js-vbg-group', videoBackgroundSelector, videoBackgroundFactoryInstance) {\n super(selector, (element, id, factoryInstance) => new VideoBackgroundGroup(element, videoBackgroundSelector, videoBackgroundFactoryInstance));\n }\n}\n", "import { SeekBar, PlayToggle, MuteToggle, VideoBackgroundGroup, VideoBackgroundGroups } from \"./lib/controls\";\n\nwindow.SeekBar = SeekBar;\nwindow.PlayToggle = PlayToggle;\nwindow.MuteToggle = MuteToggle;\nwindow.VideoBackgroundGroup = VideoBackgroundGroup;\nwindow.VideoBackgroundGroups = VideoBackgroundGroups;\n"], - "mappings": ";;;AAAO,MAAM,UAAN,MAAc;AAAA,IACnB,YAAY,SAAS,aAAa;AAChC,WAAK,OAAO;AACZ,UAAI,CAAC;AAAS;AACd,WAAK,UAAU;AACf,UAAI,KAAK,QAAQ,aAAa,iBAAiB;AAAG;AAClD,WAAK,eAAe,KAAK,QAAQ,cAAc,uBAAuB;AACtE,WAAK,YAAY,KAAK,QAAQ,cAAc,cAAc;AAC1D,WAAK,iBAAiB,KAAK,QAAQ,aAAa,aAAa;AAC7D,UAAI,KAAK;AAAgB,aAAK,aAAa,SAAS,cAAc,KAAK,cAAc;AACrF,UAAI,CAAC,KAAK,kBAAkB;AAAa,aAAK,aAAa,YAAY;AACvE,UAAI,CAAC,KAAK;AAAY;AAEtB,UAAI;AAAa,aAAK,eAAe,WAAW;AAEhD,WAAK,WAAW,iBAAiB,gCAAgC,KAAK,aAAa,KAAK,IAAI,CAAC;AAC7F,WAAK,WAAW,iBAAiB,yBAAyB,KAAK,QAAQ,KAAK,IAAI,CAAC;AACjF,WAAK,WAAW,iBAAiB,0BAA0B,KAAK,QAAQ,KAAK,IAAI,CAAC;AAClF,WAAK,WAAW,iBAAiB,8BAA8B,KAAK,YAAY,KAAK,IAAI,CAAC;AAE1F,WAAK,UAAU,iBAAiB,SAAS,KAAK,QAAQ,KAAK,IAAI,CAAC;AAChE,WAAK,UAAU,iBAAiB,UAAU,KAAK,SAAS,KAAK,IAAI,CAAC;AAAA,IACpE;AAAA,IAEA,eAAe,aAAa;AAC1B,UAAI,KAAK;AAAa;AACtB,WAAK,cAAc;AACnB,WAAK,QAAQ,aAAa,mBAAmB,YAAY,GAAG;AAAA,IAC9D;AAAA,IAEA,QAAQ,OAAO;AACb,WAAK,eAAe,MAAM,MAAM;AAAA,IAClC;AAAA,IAEA,aAAa,OAAO;AAClB,WAAK,eAAe,MAAM,MAAM;AAChC,UAAI,CAAC,KAAK;AAAM,8BAAsB,MAAM,KAAK,YAAY,KAAK,YAAY,eAAe,CAAC;AAAA,IAChG;AAAA,IAEA,YAAY,OAAO;AACjB,WAAK,cAAc;AACnB,4BAAsB,MAAM,KAAK,YAAY,CAAC,CAAC;AAAA,IACjD;AAAA,IAEA,QAAQ,OAAO;AACb,WAAK,OAAO;AACZ,4BAAsB,MAAM,KAAK,YAAY,MAAM,OAAO,KAAK,CAAC;AAAA,IAClE;AAAA,IAEA,SAAS,OAAO;AACd,WAAK,OAAO;AACZ,4BAAsB,MAAM,KAAK,YAAY,MAAM,OAAO,KAAK,CAAC;AAChE,UAAI,KAAK,aAAa;AACpB,aAAK,YAAY,KAAK,MAAM,OAAO,KAAK;AACxC,YAAI,KAAK,YAAY,iBAAiB,KAAK,YAAY,cAAc,MAAM,YAAY;AAAG,eAAK,YAAY,cAAc,MAAM,UAAU;AAAA,MAC3I;AAAA,IACJ;AAAA,IAEE,YAAY,OAAO;AACjB,UAAI,KAAK;AAAc,aAAK,aAAa,QAAQ;AACjD,UAAI,KAAK;AAAW,aAAK,UAAU,QAAQ;AAAA,IAC7C;AAAA,EACF;AAEO,MAAM,uBAAN,MAA2B;AAAA,IAChC,YAAY,UAAU,yBAAyB,gCAAgC;AAC7E,WAAK,UAAU;AACf,UAAI,OAAO,KAAK,YAAY;AAAU,aAAK,UAAU,SAAS,cAAc,QAAQ;AACpF,UAAI,CAAC,KAAK;AAAS;AACnB,WAAK,WAAW,KAAK,QAAQ,iBAAiB,2BAA2B,YAAY;AACrF,UAAI,CAAC,KAAK,SAAS;AAAQ;AAE3B,WAAK,iCAAiC;AACtC,WAAK,QAAQ,CAAC;AACd,WAAK,MAAM,oBAAI,IAAI;AAEnB,eAAS,IAAI,GAAG,IAAI,KAAK,SAAS,QAAQ,KAAK;AAC7C,cAAM,UAAU,KAAK,SAAS,CAAC;AAC/B,YAAI,CAAC,QAAQ,aAAa,cAAc,KAAK,KAAK;AAAgC,eAAK,+BAA+B,IAAI,OAAO;AACjI,aAAK,MAAM,KAAK,OAAO;AACvB,aAAK,IAAI,IAAI,SAAS,CAAC;AAEvB,YAAI,MAAM,GAAG;AACX,eAAK,UAAU;AACf,eAAK,iBAAiB;AACtB,cAAI,KAAK;AAAgC,iBAAK,kBAAkB,KAAK,+BAA+B,IAAI,OAAO;AAAA,QACjH;AACA,gBAAQ,iBAAiB,0BAA0B,KAAK,aAAa,KAAK,IAAI,CAAC;AAC/E,gBAAQ,iBAAiB,2BAA2B,KAAK,cAAc,KAAK,IAAI,CAAC;AACjF,gBAAQ,iBAAiB,0BAA0B,KAAK,aAAa,KAAK,IAAI,CAAC;AAC/E,gBAAQ,iBAAiB,0BAA0B,KAAK,aAAa,KAAK,IAAI,CAAC;AAC/E,gBAAQ,iBAAiB,iCAAiC,KAAK,kCAAkC,KAAK,IAAI,GAAG,EAAE,MAAM,KAAK,CAAC;AAC3H,gBAAQ,iBAAiB,gCAAgC,KAAK,kCAAkC,KAAK,IAAI,GAAG,EAAE,MAAM,KAAK,CAAC;AAAA,MAC5H;AAAA,IACF;AAAA,IAEA,kCAAkC,OAAO;AACvC,UAAI,KAAK;AAAgC;AACzC,WAAK,iCAAiC,MAAM,OAAO;AACnD,UAAI,CAAC,KAAK;AAAiB,aAAK,kBAAkB,KAAK,+BAA+B,IAAI,KAAK,cAAc;AAAA,IAC/G;AAAA,IAEA,aAAa,OAAO;AAClB,UAAI,KAAK,MAAM,KAAK,OAAO,MAAM,MAAM,OAAO;AAAS;AACvD,WAAK,kCAAkC,KAAK;AAC5C,YAAM,kBAAkB,MAAM;AAC9B,UAAI,gBAAgB,iBAAiB,aAAa,gBAAgB;AAAgB,wBAAgB,SAAS;AAAA,IAC7G;AAAA,IAEA,aAAa,OAAO;AAAC;AACnB,WAAK,kCAAkC,KAAK;AAC5C,YAAM,aAAa,KAAK,IAAI,IAAI,MAAM,OAAO,OAAO;AACpD,UAAI,eAAe,KAAK;AAAS;AAAA,IACnC;AAAA,IAEA,gBAAgB;AACd,eAAS,IAAI,GAAG,IAAI,KAAK,MAAM,QAAQ,KAAK;AAC1C,YAAI,MAAM,KAAK;AAAS;AACxB,cAAM,cAAc,KAAK,WAAW,KAAK,+BAA+B,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC;AAC1F,YAAI,CAAC;AAAa;AAClB,YAAI,IAAI,KAAK,SAAS;AACpB,eAAK,YAAY,aAAa,GAAG;AAAA,QACnC,OAAO;AACL,eAAK,YAAY,aAAa,CAAC;AAAA,QACjC;AAAA,MACF;AAAA,IACF;AAAA,IAEA,WAAW,iBAAiB;AAC1B,UAAI,CAAC;AAAiB;AACtB,YAAM,MAAM,gBAAgB;AAC5B,YAAM,UAAU,SAAS,cAAc,sCAAsC,GAAG,IAAI;AACpF,UAAI,CAAC;AAAS;AACd,aAAO;AAAA,IACT;AAAA,IAEA,YAAY,aAAa,OAAO;AAC9B,UAAI,CAAC;AAAa;AAClB,YAAM,eAAe,YAAY,cAAc,uBAAuB;AACtE,YAAM,YAAY,YAAY,cAAc,cAAc;AAC1D,UAAI;AAAc,qBAAa,QAAQ;AACvC,UAAI;AAAW,kBAAU,QAAQ;AAAA,IACnC;AAAA,IAEA,cAAc,OAAO;AACnB,YAAM,UAAU,KAAK,IAAI,IAAI,MAAM,OAAO,OAAO;AACjD,UAAI,KAAK,YAAY;AAAS,aAAK,WAAW,SAAS,IAAI;AAAA,IAC7D;AAAA,IAEA,WAAW,OAAO,MAAM;AACtB,YAAM,WAAW,KAAK;AACtB,UAAI,SAAS,KAAK,MAAM;AAAQ,gBAAQ;AACxC,UAAI,QAAQ;AAAG,gBAAQ,KAAK,MAAM,SAAS;AAC3C,YAAM,mBAAmB,KAAK,+BAA+B,IAAI,KAAK,MAAM,QAAQ,CAAC;AACrF,WAAK,UAAU;AACf,WAAK,kBAAkB,KAAK,+BAA+B,IAAI,KAAK,MAAM,KAAK,OAAO,CAAC;AACvF,WAAK,iBAAiB,KAAK,MAAM,KAAK,OAAO;AAE7C,WAAK,MAAM,QAAQ,EAAE,MAAM,UAAU;AACrC,WAAK,eAAe,MAAM,UAAU;AAEpC,UAAI,CAAC,MAAM;AACP,cAAM,cAAc,KAAK,WAAW,KAAK,eAAe;AACxD,YAAI;AAAa,eAAK,YAAY,aAAa,CAAC;AAChD,aAAK,gBAAgB,KAAK,CAAC;AAAA,MAC/B;AAEA,iBAAW,MAAM;AACb,YAAI,KAAK,gBAAgB,iBAAiB;AAAW,eAAK,gBAAgB,KAAK;AAAA,MACnF,GAAG,GAAG;AACN,UAAI,oBAAoB,iBAAiB,iBAAiB;AAAU,yBAAiB,MAAM;AAE3F,iBAAW,KAAK,cAAc,KAAK,IAAI,GAAG,GAAG;AAE7C,UAAI,SAAS,KAAK,MAAM;AAAQ,aAAK,cAAc,uCAAuC;AAC1F,UAAI,QAAQ;AAAG,aAAK,cAAc,wCAAwC;AAAA,IAC5E;AAAA,IAEA,cAAc,MAAM;AAClB,WAAK,QAAQ,cAAc,IAAI,YAAY,MAAM,EAAE,SAAS,MAAM,QAAQ,KAAK,CAAC,CAAC;AAAA,IACnF;AAAA,IAEA,aAAa,OAAO;AAClB,UAAI,MAAM,OAAO,YAAY,KAAK;AAAgB;AAClD,WAAK,KAAK;AAAA,IACZ;AAAA,IAEA,OAAO;AACL,WAAK,WAAW,KAAK,UAAU,CAAC;AAChC,WAAK,cAAc,6BAA6B;AAAA,IAClD;AAAA,IAEA,OAAO;AACL,WAAK,WAAW,KAAK,UAAU,CAAC;AAChC,WAAK,cAAc,iCAAiC;AAAA,IACtD;AAAA,IAEA,SAAS;AACP,eAAS,IAAI,GAAG,IAAI,KAAK,MAAM,QAAQ,KAAK;AAC1C,cAAM,WAAW,KAAK,+BAA+B,IAAI,KAAK,MAAM,CAAC,CAAC;AACtE,YAAI,CAAC;AAAU;AACf,iBAAS,OAAO;AAAA,MAClB;AAEA,WAAK,cAAc,+BAA+B;AAAA,IACpD;AAAA,IAEA,OAAO;AACL,eAAS,IAAI,GAAG,IAAI,KAAK,MAAM,QAAQ,KAAK;AAC1C,cAAM,WAAW,KAAK,+BAA+B,IAAI,KAAK,MAAM,CAAC,CAAC;AACtE,YAAI,CAAC;AAAU;AACf,iBAAS,KAAK;AAAA,MAChB;AAEA,WAAK,cAAc,6BAA6B;AAAA,IAClD;AAAA,IAEA,QAAQ;AACN,WAAK,gBAAgB,MAAM;AAC3B,WAAK,cAAc,iCAAiC;AAAA,IACtD;AAAA,IAEA,OAAO;AACL,WAAK,gBAAgB,KAAK;AAC1B,WAAK,cAAc,iCAAiC;AAAA,IACtD;AAAA,IAEA,UAAU;AACR,eAAS,IAAI,GAAG,IAAI,KAAK,SAAS,QAAQ,KAAK;AAC7C,cAAM,UAAU,KAAK,SAAS,CAAC;AAC/B,gBAAQ,oBAAoB,0BAA0B,KAAK,aAAa,KAAK,IAAI,CAAC;AAClF,gBAAQ,oBAAoB,2BAA2B,KAAK,cAAc,KAAK,IAAI,CAAC;AACpF,gBAAQ,oBAAoB,0BAA0B,KAAK,aAAa,KAAK,IAAI,CAAC;AAClF,gBAAQ,oBAAoB,0BAA0B,KAAK,aAAa,KAAK,IAAI,CAAC;AAClF,gBAAQ,oBAAoB,iCAAiC,KAAK,kCAAkC,KAAK,IAAI,CAAC;AAC9G,gBAAQ,oBAAoB,gCAAgC,KAAK,kCAAkC,KAAK,IAAI,CAAC;AAAA,MAC/G;AAAA,IACF;AAAA,EACF;AAEO,MAAM,aAAN,MAAiB;AAAA,IACtB,YAAY,gBAAgB,aAAa;AACvC,UAAI,CAAC;AAAgB;AAErB,WAAK,UAAU;AACf,WAAK,iBAAiB,KAAK,QAAQ,aAAa,aAAa;AAE7D,UAAI,CAAC,KAAK;AAAgB;AAC1B,WAAK,SAAS;AAEd,UAAI,KAAK,QAAQ,aAAa,cAAc,GAAG;AAC7C,aAAK,SAAS,KAAK,QAAQ,aAAa,cAAc,MAAM;AAAA,MAC9D,OAAO;AACL,aAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,MACvD;AAEA,WAAK,QAAQ,aAAa,QAAQ,QAAQ;AAE1C,WAAK,aAAa,SAAS,cAAc,KAAK,cAAc;AAC5D,UAAI,CAAC,KAAK;AAAY;AAEtB,UAAI;AAAa,aAAK,cAAc;AAEpC,WAAK,WAAW,iBAAiB,0BAA0B,KAAK,QAAQ,KAAK,IAAI,CAAC;AAClF,WAAK,WAAW,iBAAiB,iCAAiC,KAAK,cAAc,KAAK,IAAI,CAAC;AAC/F,WAAK,WAAW,iBAAiB,yBAAyB,KAAK,OAAO,KAAK,IAAI,CAAC;AAChF,WAAK,WAAW,iBAAiB,0BAA0B,KAAK,QAAQ,KAAK,IAAI,CAAC;AAClF,WAAK,WAAW,iBAAiB,8BAA8B,KAAK,YAAY,KAAK,IAAI,CAAC;AAE1F,WAAK,QAAQ,iBAAiB,SAAS,KAAK,QAAQ,KAAK,IAAI,CAAC;AAAA,IAChE;AAAA,IAEA,QAAQ,OAAO;AACb,WAAK,cAAc,MAAM;AAAA,IAC3B;AAAA,IAEA,cAAc,OAAO;AACnB,UAAI,CAAC,KAAK;AAAa,aAAK,cAAc,MAAM;AAChD,WAAK,SAAS,KAAK,YAAY,iBAAiB,aAAa,KAAK,YAAY,iBAAiB;AAC/F,WAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,IACvD;AAAA,IAEA,OAAO,OAAO;AACZ,UAAI,CAAC,KAAK;AAAa,aAAK,cAAc,MAAM;AAChD,WAAK,SAAS;AACd,WAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,IACvD;AAAA,IAEA,QAAQ,OAAO;AACb,UAAI,CAAC,KAAK;AAAa,aAAK,cAAc,MAAM;AAChD,WAAK,SAAS;AACd,WAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,IACvD;AAAA,IAEA,YAAY,OAAO;AACjB,WAAK,cAAc;AACnB,WAAK,SAAS;AACd,WAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,IACvD;AAAA,IAEA,QAAQ,OAAO;AACb,UAAI,CAAC,KAAK;AAAa;AACvB,UAAI,KAAK,QAAQ;AACf,aAAK,YAAY,MAAM;AAAA,MACzB,OAAO;AACL,aAAK,YAAY,KAAK;AAAA,MACxB;AAAA,IACF;AAAA,EACF;AAEO,MAAM,aAAN,MAAiB;AAAA,IACtB,YAAY,gBAAgB,aAAa;AACrC,UAAI,CAAC;AAAgB;AAErB,WAAK,UAAU;AACf,WAAK,iBAAiB,KAAK,QAAQ,aAAa,aAAa;AAE7D,UAAI,CAAC,KAAK;AAAgB;AAC1B,WAAK,SAAS;AAEd,UAAI,KAAK,QAAQ,aAAa,cAAc,GAAG;AAC3C,aAAK,SAAS,KAAK,QAAQ,aAAa,cAAc,MAAM;AAAA,MAChE,OAAO;AACH,aAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,MACzD;AAEA,WAAK,QAAQ,aAAa,QAAQ,QAAQ;AAE1C,WAAK,aAAa,SAAS,cAAc,KAAK,cAAc;AAC5D,UAAI,CAAC,KAAK;AAAY;AAEtB,UAAI;AAAa,aAAK,cAAc;AAEpC,WAAK,WAAW,iBAAiB,0BAA0B,KAAK,QAAQ,KAAK,IAAI,CAAC;AAClF,WAAK,WAAW,iBAAiB,yBAAyB,KAAK,OAAO,KAAK,IAAI,CAAC;AAChF,WAAK,WAAW,iBAAiB,2BAA2B,KAAK,SAAS,KAAK,IAAI,CAAC;AACpF,WAAK,WAAW,iBAAiB,8BAA8B,KAAK,YAAY,KAAK,IAAI,CAAC;AAE1F,WAAK,QAAQ,iBAAiB,SAAS,KAAK,QAAQ,KAAK,IAAI,CAAC;AAAA,IAClE;AAAA,IAEA,QAAQ,OAAO;AACb,WAAK,cAAc,MAAM;AACzB,UAAI,KAAK,YAAY,OAAO,OAAO;AACjC,aAAK,SAAS;AACd,aAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,MACvD;AAAA,IACF;AAAA,IAEA,OAAO,OAAO;AACZ,UAAI,CAAC,KAAK;AAAa,aAAK,cAAc,MAAM;AAChD,WAAK,SAAS;AACd,WAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,IACvD;AAAA,IAEA,SAAS,OAAO;AACd,UAAI,CAAC,KAAK;AAAa,aAAK,cAAc,MAAM;AAChD,WAAK,SAAS;AACd,WAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,IACvD;AAAA,IAEA,YAAY,OAAO;AACjB,WAAK,cAAc;AACnB,WAAK,SAAS;AACd,WAAK,QAAQ,aAAa,gBAAgB,KAAK,MAAM;AAAA,IACvD;AAAA,IAEA,QAAQ,OAAO;AACb,UAAI,CAAC,KAAK;AAAa;AACvB,UAAI,KAAK,QAAQ;AACf,aAAK,YAAY,OAAO;AAAA,MAC1B,OAAO;AACL,aAAK,YAAY,KAAK;AAAA,MACxB;AAAA,IACF;AAAA,EACF;AAGA,MAAM,iBAAN,MAAqB;AAAA,IACnB,YAAY,UAAU,UAAU,eAAe,YAAY;AACzD,WAAK,YAAY,CAAC;AAClB,WAAK,WAAW;AAChB,WAAK,WAAW,CAAC;AACjB,WAAK,WAAW;AAChB,WAAK,eAAe;AAEpB,UAAI,CAAC,YAAY,OAAO,aAAa;AAAY;AAEjD,UAAI,OAAO,KAAK,aAAa,UAAU;AACrC,aAAK,WAAW,SAAS,iBAAiB,KAAK,QAAQ;AAAA,MACzD;AAEA,UAAI,KAAK,oBAAoB,SAAS;AACpC,aAAK,WAAW,CAAC,KAAK,QAAQ;AAAA,MAChC;AAEA,UAAI,KAAK,oBAAoB,UAAU;AACrC,aAAK,WAAW,KAAK;AAAA,MACvB;AAEA,eAAS,IAAI,GAAG,IAAI,KAAK,SAAS,QAAQ,KAAK;AAC7C,aAAK,IAAI,KAAK,SAAS,CAAC,CAAC;AAAA,MAG3B;AAAA,IACF;AAAA,IAEA,WAAW;AACT,aAAO,KAAK,IAAI,EAAE,SAAS,EAAE,IAAI,KAAK,OAAO,EAAE,SAAS,EAAE,EAAE,UAAU,CAAC;AAAA,IACzE;AAAA,IAEA,cAAc;AACZ,UAAI,UAAU,KAAK,SAAS;AAC5B,UAAI,CAAC,KAAK,UAAU,eAAe,OAAO;AAAG,eAAO;AACpD,aAAO,KAAK,YAAY;AAAA,IAC1B;AAAA,IAEA,IAAI,SAAS;AACX,UAAI,KAAK,QAAQ,aAAa,IAAI;AAClC,UAAI,CAAC,MAAM,KAAK,UAAU,eAAe,EAAE,GAAG;AAC5C,aAAK,QAAQ,aAAa,KAAK,YAAY;AAE3C,YAAI,CAAC,MAAM,KAAK,UAAU,eAAe,EAAE,GAAG;AAC5C,eAAK,KAAK,YAAY;AACtB,kBAAQ,aAAa,KAAK,cAAc,EAAE;AAAA,QAC5C;AAAA,MACF;AAEA,UAAI,KAAK,YAAY,OAAO,KAAK,aAAa;AAC5C,aAAK,UAAU,EAAE,IAAI,KAAK,SAAS,SAAS,IAAI,IAAI;AAAA,IACxD;AAAA,IAEA,MAAM,SAAS;AACb,UAAI,CAAC;AAAS;AACd,UAAI,OAAO,YAAY;AAAU,eAAO;AACxC,YAAM,KAAK,QAAQ,aAAa,IAAI;AACpC,UAAI,MAAM,KAAK,UAAU,eAAe,EAAE;AAAG,eAAO;AACpD,YAAM,MAAM,QAAQ,aAAa,KAAK,YAAY;AAClD,UAAI,OAAO,KAAK,UAAU,eAAe,GAAG;AAAG,eAAO;AAAA,IACxD;AAAA,IAEA,IAAI,SAAS;AACX,UAAI,CAAC;AAAS;AACd,YAAM,KAAK,KAAK,MAAM,OAAO;AAC7B,UAAI,CAAC;AAAI;AACT,aAAO,KAAK,UAAU,EAAE;AAAA,IAC1B;AAAA,IAEA,QAAQ,SAAS;AACf,UAAI,CAAC;AAAS;AACd,YAAM,KAAK,KAAK,MAAM,OAAO;AAC7B,UAAI,CAAC;AAAI;AACT,YAAM,WAAW,KAAK,UAAU,EAAE;AAClC,UAAI,SAAS,eAAe,SAAS,KAAK,OAAO,SAAS,WAAW;AAAY,aAAK,UAAU,EAAE,EAAE,QAAQ;AAC5G,aAAO,KAAK,UAAU,EAAE;AAAA,IAC1B;AAAA,IAEA,aAAa;AACX,iBAAW,OAAO,KAAK,WAAW;AAChC,cAAM,WAAW,KAAK,UAAU,GAAG;AACnC,YAAI,SAAS,eAAe,SAAS,KAAK,OAAO,SAAS,WAAW;AAAY,mBAAS,QAAQ;AAClG,eAAO,KAAK,UAAU,GAAG;AAAA,MAC3B;AAAA,IACF;AAAA,EACF;AAEO,MAAM,wBAAN,cAAoC,eAAe;AAAA,IACxD,YAAY,WAAW,iBAAiB,yBAAyB,gCAAgC;AAC/F,YAAM,UAAU,CAAC,SAAS,IAAI,oBAAoB,IAAI,qBAAqB,SAAS,yBAAyB,8BAA8B,CAAC;AAAA,IAC9I;AAAA,EACF;;;ACpdA,SAAO,UAAU;AACjB,SAAO,aAAa;AACpB,SAAO,aAAa;AACpB,SAAO,uBAAuB;AAC9B,SAAO,wBAAwB;", + "sourcesContent": ["export class SeekBar {\n constructor(element, vbgInstance) {\n this.lock = false;\n if (!element) return;\n this.element = element;\n if (this.element.hasAttribute('data-target-uid')) return;\n this.progressElem = this.element.querySelector('.js-seek-bar-progress');\n this.inputElem = this.element.querySelector('.js-seek-bar');\n this.targetSelector = this.element.getAttribute('data-target');\n if (this.targetSelector) this.targetElem = document.querySelector(this.targetSelector);\n if (!this.targetSelector && vbgInstance) this.targetElem = vbgInstance.element;\n if (!this.targetElem) return;\n\n if (vbgInstance) this.setVBGInstance(vbgInstance);\n \n this.targetElem.addEventListener('video-background-time-update', this.onTimeUpdate.bind(this));\n this.targetElem.addEventListener('video-background-play', this.onReady.bind(this));\n this.targetElem.addEventListener('video-background-ready', this.onReady.bind(this));\n this.targetElem.addEventListener('video-background-destroyed', this.onDestroyed.bind(this));\n\n this.inputElem.addEventListener('input', this.onInput.bind(this));\n this.inputElem.addEventListener('change', this.onChange.bind(this));\n }\n\n setVBGInstance(vbgInstance) {\n if (this.vbgInstance) return;\n this.vbgInstance = vbgInstance;\n this.element.setAttribute('data-target-uid', vbgInstance.uid);\n }\n\n onReady(event) {\n this.setVBGInstance(event.detail);\n }\n\n onTimeUpdate(event) {\n this.setVBGInstance(event.detail);\n if (!this.lock) requestAnimationFrame(() => this.setProgress(this.vbgInstance.percentComplete));\n }\n\n onDestroyed(event) {\n this.vbgInstance = null;\n requestAnimationFrame(() => this.setProgress(0));\n }\n\n onInput(event) {\n this.lock = true;\n requestAnimationFrame(() => this.setProgress(event.target.value));\n }\n\n onChange(event) {\n this.lock = false;\n requestAnimationFrame(() => this.setProgress(event.target.value));\n if (this.vbgInstance) {\n this.vbgInstance.seek(event.target.value);\n if (this.vbgInstance.playerElement && this.vbgInstance.playerElement.style.opacity === 0) this.vbgInstance.playerElement.style.opacity = 1;\n }\n}\n\n setProgress(value) {\n if (this.progressElem) this.progressElem.value = value;\n if (this.inputElem) this.inputElem.value = value;\n }\n}\n\nexport class VideoBackgroundGroup {\n constructor(selector, videoBackgroundSelector, videoBackgroundFactoryInstance) {\n this.element = selector;\n if (typeof this.element === 'string') this.element = document.querySelector(selector);\n if (!this.element) return;\n this.elements = this.element.querySelectorAll(videoBackgroundSelector || '[data-vbg]');\n if (!this.elements.length) return;\n\n this.videoBackgroundFactoryInstance = videoBackgroundFactoryInstance;\n this.stack = [];\n this.map = new Map();\n this.current = 0;\n this.currentElement = null;\n this.currentInstance = null;\n\n this.playing = false;\n this.muted = true;\n\n for (let i = 0; i < this.elements.length; i++) {\n const element = this.elements[i];\n if (!element.hasAttribute('data-vbg-uid') && this.videoBackgroundFactoryInstance) this.videoBackgroundFactoryInstance.add(element);\n this.stack.push(element);\n this.map.set(element, i);\n \n if (i === 0) {\n this.current = 0;\n this.currentElement = element;\n if (this.videoBackgroundFactoryInstance) this.currentInstance = this.videoBackgroundFactoryInstance.get(element);\n }\n element.addEventListener('video-background-ended', this.onVideoEnded.bind(this));\n element.addEventListener('video-background-seeked', this.onVideoSeeked.bind(this));\n element.addEventListener('video-background-pause', this.onVideoPause.bind(this));\n element.addEventListener('video-background-ready', this.onVideoReady.bind(this));\n element.addEventListener('video-background-state-change', this.setVideoBackgroundFactoryInstance.bind(this), { once: true });\n element.addEventListener('video-background-time-update', this.setVideoBackgroundFactoryInstance.bind(this), { once: true });\n }\n }\n\n setVideoBackgroundFactoryInstance(event) {\n if (this.videoBackgroundFactoryInstance) return;\n this.videoBackgroundFactoryInstance = event.detail.factoryInstance;\n if (!this.currentInstance) this.currentInstance = this.videoBackgroundFactoryInstance.get(this.currentElement);\n }\n\n onVideoReady(event) {\n if (this.stack[this.current] !== event.detail.element) return;\n this.setVideoBackgroundFactoryInstance(event);\n const videoBackground = event.detail;\n if (videoBackground.params.muted) this.muted = true;\n if (!videoBackground.isIntersecting) return;\n if (!videoBackground.params.autoplay) return;\n this.playing = true;\n if (videoBackground.currentState === 'playing') return;\n videoBackground.softPlay();\n }\n\n onVideoPause(event) {;\n this.setVideoBackgroundFactoryInstance(event);\n const stackIndex = this.map.get(event.detail.element);\n if (stackIndex === this.current) return;\n }\n\n levelSeekBars() {\n for (let i = 0; i < this.stack.length; i++) {\n if (i === this.current) continue;\n const seekBarElem = this.getSeekBar(this.videoBackgroundFactoryInstance.get(this.stack[i]));\n if (!seekBarElem) continue;\n if (i < this.current) {\n this.setProgress(seekBarElem, 100);\n } else {\n this.setProgress(seekBarElem, 0);\n }\n }\n }\n\n getSeekBar(currentInstance) {\n if (!currentInstance) return;\n const uid = currentInstance.uid;\n const element = document.querySelector(`.js-seek-bar-wrap[data-target-uid=\"${uid}\"]`);\n if (!element) return;\n return element;\n }\n\n setProgress(seekBarElem, value) {\n if (!seekBarElem) return;\n const progressElem = seekBarElem.querySelector('.js-seek-bar-progress');\n const inputElem = seekBarElem.querySelector('.js-seek-bar');\n if (progressElem) progressElem.value = value;\n if (inputElem) inputElem.value = value;\n }\n\n onVideoSeeked(event) {\n const current = this.map.get(event.detail.element);\n if (this.current !== current) this.setCurrent(current, true);\n }\n\n setCurrent(index, seek) {\n const previous = this.current;\n if (index >= this.stack.length) index = 0;\n if (index < 0) index = this.stack.length - 1;\n const previousInstance = this.videoBackgroundFactoryInstance.get(this.stack[previous]);\n this.current = index;\n this.currentInstance = this.videoBackgroundFactoryInstance.get(this.stack[this.current]);\n this.currentElement = this.stack[this.current];\n \n this.stack[previous].style.display = 'none';\n this.currentElement.style.display = 'block';\n\n if (!seek) {\n const seekBarElem = this.getSeekBar(this.currentInstance);\n if (seekBarElem) this.setProgress(seekBarElem, 0);\n this.currentInstance.seek(0);\n }\n\n setTimeout(() => {\n if (this.currentInstance.currentState !== 'playing') this.currentInstance.play();\n }, 100);\n if (previousInstance && previousInstance.currentState !== 'paused') previousInstance.pause();\n\n setTimeout(this.levelSeekBars.bind(this), 100);\n\n if (index >= this.stack.length) this.dispatchEvent('video-background-group-forward-rewind');\n if (index < 0) this.dispatchEvent('video-background-group-backward-rewind');\n }\n\n dispatchEvent(name) {\n this.element.dispatchEvent(new CustomEvent(name, { bubbles: true, detail: this }));\n }\n\n onVideoEnded(event) {\n if (event.detail.element !== this.currentElement) return;\n this.next();\n }\n\n next() {\n this.setCurrent(this.current + 1);\n this.dispatchEvent('video-background-group-next');\n }\n\n prev() {\n this.setCurrent(this.current - 1);\n this.dispatchEvent('video-background-group-previous');\n }\n\n unmute() {\n for (let i = 0; i < this.stack.length; i++) {\n const instance = this.videoBackgroundFactoryInstance.get(this.stack[i]);\n if (!instance) continue;\n instance.unmute();\n }\n\n this.muted = false;\n this.dispatchEvent('video-background-group-umnute');\n }\n\n mute() {\n for (let i = 0; i < this.stack.length; i++) {\n const instance = this.videoBackgroundFactoryInstance.get(this.stack[i]);\n if (!instance) continue;\n instance.mute();\n }\n\n this.muted = true;\n this.dispatchEvent('video-background-group-mute');\n }\n\n pause() {\n this.currentInstance.pause();\n this.playing = false;\n this.dispatchEvent('video-background-group-previous');\n }\n\n play() {\n this.currentInstance.play();\n this.playing = true;\n this.dispatchEvent('video-background-group-previous');\n }\n\n destroy() {\n for (let i = 0; i < this.elements.length; i++) {\n const element = this.elements[i];\n element.removeEventListener('video-background-ended', this.onVideoEnded.bind(this));\n element.removeEventListener('video-background-seeked', this.onVideoSeeked.bind(this));\n element.removeEventListener('video-background-pause', this.onVideoPause.bind(this));\n element.removeEventListener('video-background-ready', this.onVideoReady.bind(this));\n element.removeEventListener('video-background-state-change', this.setVideoBackgroundFactoryInstance.bind(this));\n element.removeEventListener('video-background-time-update', this.setVideoBackgroundFactoryInstance.bind(this));\n }\n }\n}\n\nexport class PlayToggle {\n constructor(playToggleElem, vbgInstance) {\n if (!playToggleElem) return;\n \n this.element = playToggleElem;\n this.targetSelector = this.element.getAttribute('data-target');\n\n if (!this.targetSelector) return;\n this.active = false;\n\n if (this.element.hasAttribute('aria-checked')) {\n this.active = this.element.getAttribute('aria-checked') === 'true';\n } else {\n this.element.setAttribute('aria-checked', this.active);\n }\n\n this.element.setAttribute('role', 'switch');\n\n this.targetElem = document.querySelector(this.targetSelector);\n if (!this.targetElem) return;\n\n if (vbgInstance) this.vbgInstance = vbgInstance;\n\n this.targetElem.addEventListener('video-background-ready', this.onReady.bind(this));\n this.targetElem.addEventListener('video-background-state-change', this.onStateChange.bind(this));\n this.targetElem.addEventListener('video-background-play', this.onPlay.bind(this));\n this.targetElem.addEventListener('video-background-pause', this.onPause.bind(this));\n this.targetElem.addEventListener('video-background-destroyed', this.onDestroyed.bind(this));\n\n this.element.addEventListener('click', this.onClick.bind(this));\n }\n\n onReady(event) {\n this.vbgInstance = event.detail;\n }\n\n onStateChange(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = this.vbgInstance.currentState === 'playing' || this.vbgInstance.currentState === 'buffering';\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onPlay(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = true;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onPause(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = false;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onDestroyed(event) {\n this.vbgInstance = null;\n this.active = false;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onClick(event) {\n if (!this.vbgInstance) return;\n if (this.active) {\n this.vbgInstance.pause();\n } else {\n this.vbgInstance.play();\n }\n }\n}\n\nexport class MuteToggle {\n constructor(muteToggleElem, vbgInstance) {\n if (!muteToggleElem) return;\n \n this.element = muteToggleElem;\n this.targetSelector = this.element.getAttribute('data-target');\n\n if (!this.targetSelector) return;\n this.active = false;\n\n if (this.element.hasAttribute('aria-checked')) {\n this.active = this.element.getAttribute('aria-checked') === 'true';\n } else {\n this.element.setAttribute('aria-checked', this.active);\n }\n\n this.element.setAttribute('role', 'switch');\n\n this.targetElem = document.querySelector(this.targetSelector);\n if (!this.targetElem) return;\n\n if (vbgInstance) this.vbgInstance = vbgInstance;\n\n this.targetElem.addEventListener('video-background-ready', this.onReady.bind(this));\n this.targetElem.addEventListener('video-background-mute', this.onMute.bind(this));\n this.targetElem.addEventListener('video-background-unmute', this.onUnmute.bind(this));\n this.targetElem.addEventListener('video-background-destroyed', this.onDestroyed.bind(this));\n\n this.element.addEventListener('click', this.onClick.bind(this));\n }\n\n onReady(event) {\n this.vbgInstance = event.detail;\n if (this.vbgInstance.params.muted) {\n this.active = true;\n this.element.setAttribute('aria-checked', this.active);\n }\n }\n\n onMute(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = true;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onUnmute(event) {\n if (!this.vbgInstance) this.vbgInstance = event.detail;\n this.active = false;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onDestroyed(event) {\n this.vbgInstance = null;\n this.active = false;\n this.element.setAttribute('aria-checked', this.active);\n }\n\n onClick(event) {\n if (!this.vbgInstance) return;\n if (this.active) {\n this.vbgInstance.unmute();\n } else {\n this.vbgInstance.mute();\n }\n }\n}\n\n// TODO: this can be achieved with custom elements... Maybe it's finally time to use them?\nclass GeneralFactory {\n constructor(selector, callback, uidAttribute = 'data-uid') {\n this.instances = {};\n this.selector = selector;\n this.elements = [];\n this.callback = callback;\n this.uidAttribute = uidAttribute;\n\n if (!callback || typeof callback !== 'function') return;\n\n if (typeof this.selector === 'string') {\n this.elements = document.querySelectorAll(this.selector);\n }\n\n if (this.selector instanceof Element) {\n this.elements = [this.selector];\n }\n\n if (this.selector instanceof NodeList) {\n this.elements = this.selector;\n }\n\n for (let i = 0; i < this.elements.length; i++) {\n this.add(this.elements[i]);\n\n // TODO: maybe manage elements array?\n }\n }\n\n basicUID() {\n return Date.now().toString(36) + Math.random().toString(36).substring(2);\n }\n\n generateUID() {\n let tempuid = this.basicUID();\n if (!this.instances.hasOwnProperty(tempuid)) return tempuid;\n return this.generateUID();\n }\n\n add(element) {\n let id = element.getAttribute('id');\n if (!id || this.instances.hasOwnProperty(id)) {\n id = element.getAttribute(this.uidAttribute);\n\n if (!id || this.instances.hasOwnProperty(id)) {\n id = this.generateUID();\n element.setAttribute(this.uidAttribute, id);\n }\n }\n\n if (this.callback && typeof this.callback === 'function') \n this.instances[id] = this.callback(element, id, this);\n }\n\n getID(element) {\n if (!element) return;\n if (typeof element === 'string') return element;\n const id = element.getAttribute('id');\n if (id && this.instances.hasOwnProperty(id)) return id;\n const uid = element.getAttribute(this.uidAttribute);\n if (uid && this.instances.hasOwnProperty(uid)) return uid;\n }\n\n get(element) {\n if (!element) return;\n const id = this.getID(element);\n if (!id) return;\n return this.instances[id];\n }\n\n destroy(element) {\n if (!element) return;\n const id = this.getID(element);\n if (!id) return;\n const instance = this.instances[id];\n if (instance.hasOwnProperty('destroy') && typeof instance.destroy == 'function') this.instances[id].destroy();\n delete this.instances[id];\n }\n\n destroyAll() {\n for (const uid in this.instances) {\n const instance = this.instances[uid];\n if (instance.hasOwnProperty('destroy') && typeof instance.destroy == 'function') instance.destroy();\n delete this.instances[uid];\n }\n }\n}\n\nexport class VideoBackgroundGroups extends GeneralFactory {\n constructor(selector = '.js-vbg-group', videoBackgroundSelector, videoBackgroundFactoryInstance) {\n super(selector, (element, id, factoryInstance) => new VideoBackgroundGroup(element, videoBackgroundSelector, videoBackgroundFactoryInstance));\n }\n}\n", "import { SeekBar, PlayToggle, MuteToggle, VideoBackgroundGroup, VideoBackgroundGroups } from \"./lib/controls\";\n\nwindow.SeekBar = SeekBar;\nwindow.PlayToggle = PlayToggle;\nwindow.MuteToggle = MuteToggle;\nwindow.VideoBackgroundGroup = VideoBackgroundGroup;\nwindow.VideoBackgroundGroups = VideoBackgroundGroups;\n"], + "mappings": "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", "names": [] } diff --git a/youtube-background-experimental.min.js b/youtube-background-experimental.min.js index d4b123d..77d5a42 100644 --- a/youtube-background-experimental.min.js +++ b/youtube-background-experimental.min.js @@ -1,2 +1,2 @@ /* youtube-background v1.1.4 | https://github.com/stamat/youtube-background | MIT License */ -(()=>{var a=class{constructor(t,e){this.lock=!1,t&&(this.element=t,!this.element.hasAttribute("data-target-uid")&&(this.progressElem=this.element.querySelector(".js-seek-bar-progress"),this.inputElem=this.element.querySelector(".js-seek-bar"),this.targetSelector=this.element.getAttribute("data-target"),this.targetSelector&&(this.targetElem=document.querySelector(this.targetSelector)),!this.targetSelector&&e&&(this.targetElem=e.element),this.targetElem&&(e&&this.setVBGInstance(e),this.targetElem.addEventListener("video-background-time-update",this.onTimeUpdate.bind(this)),this.targetElem.addEventListener("video-background-play",this.onReady.bind(this)),this.targetElem.addEventListener("video-background-ready",this.onReady.bind(this)),this.targetElem.addEventListener("video-background-destroyed",this.onDestroyed.bind(this)),this.inputElem.addEventListener("input",this.onInput.bind(this)),this.inputElem.addEventListener("change",this.onChange.bind(this)))))}setVBGInstance(t){this.vbgInstance||(this.vbgInstance=t,this.element.setAttribute("data-target-uid",t.uid))}onReady(t){this.setVBGInstance(t.detail)}onTimeUpdate(t){this.setVBGInstance(t.detail),this.lock||requestAnimationFrame(()=>this.setProgress(this.vbgInstance.percentComplete))}onDestroyed(t){this.vbgInstance=null,requestAnimationFrame(()=>this.setProgress(0))}onInput(t){this.lock=!0,requestAnimationFrame(()=>this.setProgress(t.target.value))}onChange(t){this.lock=!1,requestAnimationFrame(()=>this.setProgress(t.target.value)),this.vbgInstance&&(this.vbgInstance.seek(t.target.value),this.vbgInstance.playerElement&&this.vbgInstance.playerElement.style.opacity===0&&(this.vbgInstance.playerElement.style.opacity=1))}setProgress(t){this.progressElem&&(this.progressElem.value=t),this.inputElem&&(this.inputElem.value=t)}},r=class{constructor(t,e,i){if(this.element=t,typeof this.element=="string"&&(this.element=document.querySelector(t)),!!this.element&&(this.elements=this.element.querySelectorAll(e||"[data-vbg]"),!!this.elements.length)){this.videoBackgroundFactoryInstance=i,this.stack=[],this.map=new Map;for(let s=0;s=this.stack.length&&(t=0),t<0&&(t=this.stack.length-1);const s=this.videoBackgroundFactoryInstance.get(this.stack[i]);if(this.current=t,this.currentInstance=this.videoBackgroundFactoryInstance.get(this.stack[this.current]),this.currentElement=this.stack[this.current],this.stack[i].style.display="none",this.currentElement.style.display="block",!e){const n=this.getSeekBar(this.currentInstance);n&&this.setProgress(n,0),this.currentInstance.seek(0)}setTimeout(()=>{this.currentInstance.currentState!=="playing"&&this.currentInstance.play()},100),s&&s.currentState!=="paused"&&s.pause(),setTimeout(this.levelSeekBars.bind(this),100),t>=this.stack.length&&this.dispatchEvent("video-background-group-forward-rewind"),t<0&&this.dispatchEvent("video-background-group-backward-rewind")}dispatchEvent(t){this.element.dispatchEvent(new CustomEvent(t,{bubbles:!0,detail:this}))}onVideoEnded(t){t.detail.element===this.currentElement&&this.next()}next(){this.setCurrent(this.current+1),this.dispatchEvent("video-background-group-next")}prev(){this.setCurrent(this.current-1),this.dispatchEvent("video-background-group-previous")}unmute(){for(let t=0;tnew r(s,e,i))}};window.SeekBar=a,window.PlayToggle=c,window.MuteToggle=h,window.VideoBackgroundGroup=r,window.VideoBackgroundGroups=d})(); +(()=>{var a=class{constructor(t,e){this.lock=!1,t&&(this.element=t,!this.element.hasAttribute("data-target-uid")&&(this.progressElem=this.element.querySelector(".js-seek-bar-progress"),this.inputElem=this.element.querySelector(".js-seek-bar"),this.targetSelector=this.element.getAttribute("data-target"),this.targetSelector&&(this.targetElem=document.querySelector(this.targetSelector)),!this.targetSelector&&e&&(this.targetElem=e.element),this.targetElem&&(e&&this.setVBGInstance(e),this.targetElem.addEventListener("video-background-time-update",this.onTimeUpdate.bind(this)),this.targetElem.addEventListener("video-background-play",this.onReady.bind(this)),this.targetElem.addEventListener("video-background-ready",this.onReady.bind(this)),this.targetElem.addEventListener("video-background-destroyed",this.onDestroyed.bind(this)),this.inputElem.addEventListener("input",this.onInput.bind(this)),this.inputElem.addEventListener("change",this.onChange.bind(this)))))}setVBGInstance(t){this.vbgInstance||(this.vbgInstance=t,this.element.setAttribute("data-target-uid",t.uid))}onReady(t){this.setVBGInstance(t.detail)}onTimeUpdate(t){this.setVBGInstance(t.detail),this.lock||requestAnimationFrame(()=>this.setProgress(this.vbgInstance.percentComplete))}onDestroyed(t){this.vbgInstance=null,requestAnimationFrame(()=>this.setProgress(0))}onInput(t){this.lock=!0,requestAnimationFrame(()=>this.setProgress(t.target.value))}onChange(t){this.lock=!1,requestAnimationFrame(()=>this.setProgress(t.target.value)),this.vbgInstance&&(this.vbgInstance.seek(t.target.value),this.vbgInstance.playerElement&&this.vbgInstance.playerElement.style.opacity===0&&(this.vbgInstance.playerElement.style.opacity=1))}setProgress(t){this.progressElem&&(this.progressElem.value=t),this.inputElem&&(this.inputElem.value=t)}},r=class{constructor(t,e,i){if(this.element=t,typeof this.element=="string"&&(this.element=document.querySelector(t)),!!this.element&&(this.elements=this.element.querySelectorAll(e||"[data-vbg]"),!!this.elements.length)){this.videoBackgroundFactoryInstance=i,this.stack=[],this.map=new Map,this.current=0,this.currentElement=null,this.currentInstance=null,this.playing=!1,this.muted=!0;for(let s=0;s=this.stack.length&&(t=0),t<0&&(t=this.stack.length-1);const s=this.videoBackgroundFactoryInstance.get(this.stack[i]);if(this.current=t,this.currentInstance=this.videoBackgroundFactoryInstance.get(this.stack[this.current]),this.currentElement=this.stack[this.current],this.stack[i].style.display="none",this.currentElement.style.display="block",!e){const n=this.getSeekBar(this.currentInstance);n&&this.setProgress(n,0),this.currentInstance.seek(0)}setTimeout(()=>{this.currentInstance.currentState!=="playing"&&this.currentInstance.play()},100),s&&s.currentState!=="paused"&&s.pause(),setTimeout(this.levelSeekBars.bind(this),100),t>=this.stack.length&&this.dispatchEvent("video-background-group-forward-rewind"),t<0&&this.dispatchEvent("video-background-group-backward-rewind")}dispatchEvent(t){this.element.dispatchEvent(new CustomEvent(t,{bubbles:!0,detail:this}))}onVideoEnded(t){t.detail.element===this.currentElement&&this.next()}next(){this.setCurrent(this.current+1),this.dispatchEvent("video-background-group-next")}prev(){this.setCurrent(this.current-1),this.dispatchEvent("video-background-group-previous")}unmute(){for(let t=0;tnew r(s,e,i))}};window.SeekBar=a,window.PlayToggle=h,window.MuteToggle=c,window.VideoBackgroundGroup=r,window.VideoBackgroundGroups=d})();