/**
* @file captions-button.js
*/
import TextTrackButton de './text-track-button.js' ;
import Component from '../../component.js' ;
import CaptionSettingsMenuItem de './caption-settings-menu-item.js' ;
/**
* Le composant bouton pour basculer et sélectionner les sous-titres
*
* @extends TextTrackButton
*/
class CaptionsButton extends TextTrackButton {
/**
* 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.
*
* @param {Component~ReadyCallback} [ready]
* La fonction à appeler lorsque ce composant est prêt.
*/
constructor(player, options, ready) {
super(player, options, ready) ;
}
/**
* Construit le DOM par défaut `className`.
*
* @return {string}
* Le `nom de classe` du DOM pour cet objet.
*/
buildCSSClass() {
return `vjs-captions-button ${super.buildCSSClass()}` ;
}
buildWrapperCSSClass() {
return `vjs-captions-button ${super.buildWrapperCSSClass()}` ;
}
/**
* Créer des éléments de menu pour les légendes
*
* @return {CaptionSettingsMenuItem[]}
* Le tableau des éléments du menu actuel.
*/
createItems() {
const items = [] ;
if ( !(this.player().tech_ && this.player().tech_.featuresNativeTextTracks) &&
this.player().getChild('textTrackSettings')) {
items.push(new CaptionSettingsMenuItem(this.player_, {kind : this.kind_})) ;
this.hideThreshold_ += 1 ;
}
return super.createItems(items) ;
}
}
/**
* le type de TextTrack à rechercher pour l'associer à ce menu.
*
* @type {string}
* @private
*/
CaptionsButton.prototype.kind_ = 'captions' ;
/**
* Le texte qui doit s'afficher au-dessus des contrôles `CaptionsButton`. Ajouté pour la localisation.
*
* @type {string}
* @private
*/
CaptionsButton.prototype.controlText_ = 'Captions' ;
Component.registerComponent('CaptionsButton', CaptionsButton) ;
export default CaptionsButton ;