/**
 * @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 ;