/**
 * @file big-play-button.js
 * /
importieren Sie Button aus './button.js';
importiere Komponente aus './component.js';
importiere {isPromise, silencePromise} aus './utils/promise';
importiere * as browser aus './utils/browser.js';

/**
 * Die anfängliche Wiedergabetaste, die angezeigt wird, bevor das Video abgespielt wurde. Das Verstecken der
 * bigPlayButton" wird über CSS und den "Player"-Status realisiert.
 *
 * @erweitert Button
 * /
class BigPlayButton extends Button {
  constructor(spieler, optionen) {
    super(Spieler, Optionen);

    this.mouseused_ = false;

    this.on('mousedown', (e) => this.handleMouseDown(e));
  }

  /**
   * Erzeugt den Standard-DOM "Klassenname".
   *
   * @return {string}
   *         Der DOM `className` für dieses Objekt. Gibt immer „vjs-big-play-button“ zurück.
   * /
  buildCSSClass() {
    return 'vjs-big-play-button';
  }

  /**
   * Diese Funktion wird aufgerufen, wenn ein `BigPlayButton` "angeklickt" wird. Siehe {@link ClickableComponent}
   * für genauere Informationen darüber, was ein Klick sein kann.
   *
   * @param {EventTarget~Event} event
   *        Das `Keydown`-, `Tap`- oder `Click`-Ereignis, das diese Funktion ausgelöst hat
   *        genannt.
   *
   * @listens tap
   * @listens klicken
   * /
  handleClick(event) {
    const playPromise = this.player_.play();

    // vorzeitiges Beenden, wenn mit der Maus geklickt wird
    if (this.mouseused_ && event.clientX && event.clientY) {
      const sourceIsEncrypted = this.player_.usingPlugin('eme') &&
                                this.player_.eme.sessions &&
                                this.player_.eme.sessions.length > 0;

      silencePromise(playPromise);
      wenn (this.player_.tech(true) &&
         // Wir haben einen Fehler in IE und Edge bei der Wiedergabe von DRM-Inhalten beobachtet, bei dem
         // Der Aufruf von .focus() für das Videoelement führt dazu, dass das Video schwarz wird,
         // also vermeiden wir es in diesem speziellen Fall
         !((browser.IE_VERSION || browser.IS_EDGE) && sourceIsEncrypted)) {
        this.player_.tech(true).focus();
      }
      rückkehr;
    }

    const cb = this.player_.getChild('controlBar');
    const playToggle = cb && cb.getChild('playToggle');

    if (!playToggle) {
      this.player_.tech(true).focus();
      rückkehr;
    }

    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;
  }
}

/**
 * Der Text, der über den Steuerelementen von "BigPlayButton" angezeigt werden soll. Zugefügt für die Lokalisierung.
 *
 * @Typ {String}
 * @privat
 * /
BigPlayButton.prototype.controlText_ = 'Video abspielen';

Component.registerComponent('BigPlayButton', BigPlayButton);
standard BigPlayButton exportieren;