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