/**
 * @file fullscreen-toggle.js
 */
import Button from '../button.js' ;
import Component from '../component.js' ;
import document from 'global/document' ;

/**
 * Afficher la vidéo en plein écran
 *
 * bouton @extends
 */
class FullscreenToggle extends Button {

  /**
   * Crée une instance de cette classe.
   *
   * @param {Player} player
   *        Le `Player` auquel cette classe doit être attachée.
   *
   * @param {Objet} [options]
   *        La mémoire clé/valeur des options du lecteur.
   */
  constructor(player, options) {
    super(player, options) ;
    this.on(player, 'fullscreenchange', (e) => this.handleFullscreenChange(e)) ;

    if (document[player.fsApi_.fullscreenEnabled] === false) {
      this.disable() ;
    }
  }

  /**
   * Construit le DOM par défaut `className`.
   *
   * @return {string}
   *         Le `nom de classe` du DOM pour cet objet.
   */
  buildCSSClass() {
    return `vjs-fullscreen-control ${super.buildCSSClass()}` ;
  }

  /**
   * Gère le changement d'écran sur le lecteur et modifie le texte de contrôle en conséquence.
   *
   * @param {EventTarget~Event} [event]
   *        L'événement {@link Player#fullscreenchange} à l'origine de l'exécution de cette fonction est le suivant
   *        appelé.
   *
   * @listens Player#fullscreenchange
   */
  handleFullscreenChange(event) {
    if (this.player_.isFullscreen()) {
      this.controlText('Non-Fullscreen') ;
    } else {
      this.controlText('Fullscreen') ;
    }
  }

  /**
   * Cette fonction est appelée lorsqu'un `FullscreenToggle` est "cliqué". Voir
   * {@link ClickableComponent} pour 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) {
    if (!this.player_.isFullscreen())) {
      this.player_.requestFullscreen() ;
    } else {
      this.player_.exitFullscreen() ;
    }
  }

}

/**
 * Le texte qui doit s'afficher au-dessus des contrôles `FullscreenToggle`s. Ajouté pour la localisation.
 *
 * @type {string}
 * @private
 */
FullscreenToggle.prototype.controlText_ = 'Fullscreen' ;

Component.registerComponent('FullscreenToggle', FullscreenToggle) ;
exporter le FullscreenToggle par défaut ;