diff --git a/src/css/components/_progress.scss b/src/css/components/_progress.scss index 17001fd2ec..011eedf5af 100644 --- a/src/css/components/_progress.scss +++ b/src/css/components/_progress.scss @@ -2,6 +2,7 @@ // // This is the container for all progress bar-related components/elements. .video-js .vjs-progress-control { + cursor: pointer; @include flex(auto); @include display-flex(center); min-width: 4em; diff --git a/src/js/control-bar/progress-control/progress-control.js b/src/js/control-bar/progress-control/progress-control.js index d54fa578eb..c849f772d8 100644 --- a/src/js/control-bar/progress-control/progress-control.js +++ b/src/js/control-bar/progress-control/progress-control.js @@ -4,6 +4,7 @@ import Component from '../../component.js'; import * as Fn from '../../utils/fn.js'; import * as Dom from '../../utils/dom.js'; +import { throttle, bind } from '../../utils/fn.js'; import './seek-bar.js'; @@ -28,6 +29,9 @@ class ProgressControl extends Component { super(player, options); this.handleMouseMove = Fn.throttle(Fn.bind(this, this.handleMouseMove), 25); this.on(this.el_, 'mousemove', this.handleMouseMove); + + this.throttledHandleMouseSeek = throttle(bind(this, this.handleMouseSeek), 25); + this.on(['mousedown', 'touchstart'], this.handleMouseDown); } /** @@ -68,6 +72,68 @@ class ProgressControl extends Component { seekBar.getChild('mouseTimeDisplay').update(seekBarRect, seekBarPoint); } + + /** + * A throttled version of the {@link ProgressControl#handleMouseSeek} listener. + * + * @method ProgressControl#throttledHandleMouseSeek + * @param {EventTarget~Event} event + * The `mousemove` event that caused this function to run. + * + * @listen mousemove + * @listen touchmove + */ + + /** + * Handle `mousemove` or `touchmove` events on the `ProgressControl`. + * + * @param {EventTarget~Event} event + * `mousedown` or `touchstart` event that triggered this function + * + * @listens mousemove + * @listens touchmove + */ + handleMouseSeek(event) { + const seekBar = this.getChild('seekBar'); + + seekBar.handleMouseMove(event); + } + + /** + * Handle `mousedown` or `touchstart` events on the `ProgressControl`. + * + * @param {EventTarget~Event} event + * `mousedown` or `touchstart` event that triggered this function + * + * @listens mousedown + * @listens touchstart + */ + handleMouseDown(event) { + const doc = this.el_.ownerDocument; + + this.on(doc, 'mousemove', this.throttledHandleMouseSeek); + this.on(doc, 'touchmove', this.throttledHandleMouseSeek); + this.on(doc, 'mouseup', this.handleMouseUp); + this.on(doc, 'touchend', this.handleMouseUp); + } + + /** + * Handle `mouseup` or `touchend` events on the `ProgressControl`. + * + * @param {EventTarget~Event} event + * `mouseup` or `touchend` event that triggered this function. + * + * @listens touchend + * @listens mouseup + */ + handleMouseUp(event) { + const doc = this.el_.ownerDocument; + + this.off(doc, 'mousemove', this.throttledHandleMouseSeek); + this.off(doc, 'touchmove', this.throttledHandleMouseSeek); + this.off(doc, 'mouseup', this.handleMouseUp); + this.off(doc, 'touchend', this.handleMouseUp); + } } /**