mirror of
https://github.com/videojs/video.js.git
synced 2025-01-23 11:04:59 +02:00
fix(progress control): Fix the video continuing to play when the user scrubs outside of seekbar (#4918)
Scrubbing inside the seekbar paused the player properly but scrubbing inside the progress control outside the seekbar, the player never paused. This meant that when you scrubbed, if you kept the mouse down but lingered for a moment, the player would continue playing until the mouse moved again. This fixes it so that the seekbar mousedown and mouseup handlers are called when the progress control mousedown and mouseup handlers are triggered.
This commit is contained in:
parent
29a8ee1d60
commit
a1cef809b3
@ -55,6 +55,8 @@ class ProgressControl extends Component {
|
|||||||
*/
|
*/
|
||||||
handleMouseMove(event) {
|
handleMouseMove(event) {
|
||||||
const seekBar = this.getChild('seekBar');
|
const seekBar = this.getChild('seekBar');
|
||||||
|
|
||||||
|
if (seekBar) {
|
||||||
const mouseTimeDisplay = seekBar.getChild('mouseTimeDisplay');
|
const mouseTimeDisplay = seekBar.getChild('mouseTimeDisplay');
|
||||||
const seekBarEl = seekBar.el();
|
const seekBarEl = seekBar.el();
|
||||||
const seekBarRect = Dom.getBoundingClientRect(seekBarEl);
|
const seekBarRect = Dom.getBoundingClientRect(seekBarEl);
|
||||||
@ -73,6 +75,7 @@ class ProgressControl extends Component {
|
|||||||
mouseTimeDisplay.update(seekBarRect, seekBarPoint);
|
mouseTimeDisplay.update(seekBarRect, seekBarPoint);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A throttled version of the {@link ProgressControl#handleMouseSeek} listener.
|
* A throttled version of the {@link ProgressControl#handleMouseSeek} listener.
|
||||||
@ -97,8 +100,10 @@ class ProgressControl extends Component {
|
|||||||
handleMouseSeek(event) {
|
handleMouseSeek(event) {
|
||||||
const seekBar = this.getChild('seekBar');
|
const seekBar = this.getChild('seekBar');
|
||||||
|
|
||||||
|
if (seekBar) {
|
||||||
seekBar.handleMouseMove(event);
|
seekBar.handleMouseMove(event);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Are controls are currently enabled for this progress control.
|
* Are controls are currently enabled for this progress control.
|
||||||
@ -157,6 +162,11 @@ class ProgressControl extends Component {
|
|||||||
*/
|
*/
|
||||||
handleMouseDown(event) {
|
handleMouseDown(event) {
|
||||||
const doc = this.el_.ownerDocument;
|
const doc = this.el_.ownerDocument;
|
||||||
|
const seekBar = this.getChild('seekBar');
|
||||||
|
|
||||||
|
if (seekBar) {
|
||||||
|
seekBar.handleMouseDown(event);
|
||||||
|
}
|
||||||
|
|
||||||
this.on(doc, 'mousemove', this.throttledHandleMouseSeek);
|
this.on(doc, 'mousemove', this.throttledHandleMouseSeek);
|
||||||
this.on(doc, 'touchmove', this.throttledHandleMouseSeek);
|
this.on(doc, 'touchmove', this.throttledHandleMouseSeek);
|
||||||
@ -175,6 +185,11 @@ class ProgressControl extends Component {
|
|||||||
*/
|
*/
|
||||||
handleMouseUp(event) {
|
handleMouseUp(event) {
|
||||||
const doc = this.el_.ownerDocument;
|
const doc = this.el_.ownerDocument;
|
||||||
|
const seekBar = this.getChild('seekBar');
|
||||||
|
|
||||||
|
if (seekBar) {
|
||||||
|
seekBar.handleMouseUp(event);
|
||||||
|
}
|
||||||
|
|
||||||
this.off(doc, 'mousemove', this.throttledHandleMouseSeek);
|
this.off(doc, 'mousemove', this.throttledHandleMouseSeek);
|
||||||
this.off(doc, 'touchmove', this.throttledHandleMouseSeek);
|
this.off(doc, 'touchmove', this.throttledHandleMouseSeek);
|
||||||
|
@ -179,6 +179,8 @@ class SeekBar extends Slider {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Stop event propagation to prevent double fire in progress-control.js
|
||||||
|
event.stopPropagation();
|
||||||
this.player_.scrubbing(true);
|
this.player_.scrubbing(true);
|
||||||
|
|
||||||
this.videoWasPlaying = !this.player_.paused();
|
this.videoWasPlaying = !this.player_.paused();
|
||||||
@ -244,6 +246,8 @@ class SeekBar extends Slider {
|
|||||||
handleMouseUp(event) {
|
handleMouseUp(event) {
|
||||||
super.handleMouseUp(event);
|
super.handleMouseUp(event);
|
||||||
|
|
||||||
|
// Stop event propagation to prevent double fire in progress-control.js
|
||||||
|
event.stopPropagation();
|
||||||
this.player_.scrubbing(false);
|
this.player_.scrubbing(false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user