/**
* @file big-play-button.js
*/
import Button from './button.js' ;
import Component from './component.js' ;
import {isPromise, silencePromise} de './utils/promesse' ;
import * as browser from './utils/browser.js' ;
/**
* Le bouton de lecture initiale qui s'affiche avant la lecture de la vidéo. La dissimulation de la
* `BigPlayButton` se fait via CSS et les états `Player`.
*
* bouton @extends
*/
class BigPlayButton extends Button {
constructor(player, options) {
super(player, options) ;
this.mouseused_ = false ;
this.on('mousedown', (e) => this.handleMouseDown(e)) ;
}
/**
* Construit le DOM par défaut `className`.
*
* @return {string}
* Le `nom de classe` du DOM pour cet objet. Retourne toujours « vjs-big-play-button ».
*/
buildCSSClass() {
return 'vjs-big-play-button' ;
}
/**
* Cette fonction est appelée lorsqu'un `BigPlayButton` est "cliqué". Voir {@link ClickableComponent}
* pour obtenir des informations plus détaillées sur ce que peut être un clic.
*
* @param {EventTarget~Event} event
* L'événement `keydown`, `tap` ou `click` qui a provoqué l'activation de cette fonction est le suivant
* appelé.
*
* @listens tap
* @listens click
*/
handleClick(event) {
const playPromise = this.player_.play() ;
// sortir prématurément si l'on clique avec la souris
if (this.mouseused_ && event.clientX && event.clientY) {
const sourceIsEncrypted = this.player_.usingPlugin('eme') &&
ce.joueur_.eme.sessions &&
ce.joueur_.eme.sessions.length > 0 ;
silencePromesse(playPromesse) ;
si (this.player_.tech(true) &&
// Nous avons observé un bug dans IE et Edge lors de la lecture de contenu DRM où
// l'appel de .focus() sur l'élément vidéo entraîne le noir de la vidéo,
// nous l'évitons donc dans ce cas précis
!((browser.IE_VERSION || browser.IS_EDGE) && sourceIsEncrypted)) {
this.player_.tech(true).focus() ;
}
retour ;
}
const cb = this.player_.getChild('controlBar') ;
const playToggle = cb && cb.getChild('playToggle') ;
if (!playToggle) {
this.player_.tech(true).focus() ;
retour ;
}
const playFocus = () => playToggle.focus() ;
if (isPromise(playPromise)) {
playPromise.then(playFocus, () => {}) ;
} else {
this.setTimeout(playFocus, 1) ;
}
}
handleKeyDown(event) {
this.mouseused_ = false ;
super.handleKeyDown(event) ;
}
handleMouseDown(event) {
this.mouseused_ = true ;
}
}
/**
* Le texte qui doit s'afficher au-dessus des contrôles `BigPlayButton`s. Ajouté pour la localisation.
*
* @type {string}
* @private
*/
BigPlayButton.prototype.controlText_ = 'Play Video' ;
Component.registerComponent('BigPlayButton', BigPlayButton) ;
export default BigPlayButton ;