From 6ac730a5fcccfb0a175f21364c18bd439c7d1eb7 Mon Sep 17 00:00:00 2001 From: Chris Boustead Date: Wed, 15 Nov 2017 16:46:54 -0500 Subject: [PATCH] better handling of event listeners --- package.json | 2 +- src/plugin.js | 23 ++++++++++++++++------- 2 files changed, 17 insertions(+), 8 deletions(-) diff --git a/package.json b/package.json index 61e2e10..8cca71a 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "videojs-vtt-thumbnails", - "version": "0.0.3", + "version": "0.0.4", "description": "Display thumnails on progress bar hover, driven by external VTT files.", "main": "dist/videojs-vtt-thumbnails.cjs.js", "module": "dist/videojs-vtt-thumbnails.es.js", diff --git a/src/plugin.js b/src/plugin.js index c50a1b0..3ade963 100644 --- a/src/plugin.js +++ b/src/plugin.js @@ -69,6 +69,7 @@ class vttThumbnailsPlugin { this.player = player this.options = options this.initializeThumbnails(); + this.registeredEvents = {}; return this; } @@ -83,9 +84,12 @@ class vttThumbnailsPlugin { } resetPlugin() { - this.progressBar.removeEventListener('mouseenter',() => { return this.onBarMouseenter() }); - this.progressBar.removeEventListener('mouseleave',() => { return this.onBarMouseleave() }); - this.progressBar.removeEventListener('mousemove',this.onBarMousemove); + this.progressBar.removeEventListener('mouseenter', this.registeredEvents.progressBarMouseEnter); + this.progressBar.removeEventListener('mouseleave', this.registeredEvents.progressBarMouseLeave); + this.progressBar.removeEventListener('mousemove', this.registeredEvents.progressBarMouseMove); + delete this.registeredEvents.progressBarMouseEnter; + delete this.registeredEvents.progressBarMouseLeave; + delete this.registeredEvents.progressBarMouseMove; delete this.progressBar; delete this.vttData; delete this.thumbnailHolder; @@ -156,18 +160,23 @@ class vttThumbnailsPlugin { this.progressBar.appendChild(thumbHolder) this.thumbnailHolder = thumbHolder mouseDisplay.classList.add('vjs-hidden') - this.progressBar.addEventListener('mouseenter', () => { return this.onBarMouseenter() }) - this.progressBar.addEventListener('mouseleave', () => { return this.onBarMouseleave() }) + this.registeredEvents.progressBarMouseEnter = () => { return this.onBarMouseenter() }; + this.registeredEvents.progressBarMouseLeave = () => { return this.onBarMouseleave() }; + this.progressBar.addEventListener('mouseenter', this.registeredEvents.progressBarMouseEnter) + this.progressBar.addEventListener('mouseleave', this.registeredEvents.progressBarMouseLeave) } onBarMouseenter () { this.mouseMoveCallback = (e) => { this.onBarMousemove(e) } - this.progressBar.addEventListener('mousemove', this.mouseMoveCallback) + this.registeredEvents.progressBarMouseMove = this.mouseMoveCallback; + this.progressBar.addEventListener('mousemove', this.registeredEvents.progressBarMouseMove) this.showThumbnailHolder() } onBarMouseleave () { - this.progressBar.removeEventListener('mousemove', this.mouseMoveCallback) + if(this.registeredEvents.progressBarMouseMove) { + this.progressBar.removeEventListener('mousemove', this.registeredEvents.progressBarMouseMove) + } this.hideThumbnailHolder() }