UNPKG

shaka-player

Version:
89 lines (74 loc) 2.39 kB
/** * @license * Copyright 2016 Google Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ goog.provide('shaka.ui.PlayButton'); goog.require('shaka.ui.Element'); goog.require('shaka.ui.Locales'); goog.require('shaka.ui.Localization'); goog.require('shaka.util.Dom'); /** * @extends {shaka.ui.Element} * @export */ shaka.ui.PlayButton = class extends shaka.ui.Element { /** * @param {!HTMLElement} parent * @param {!shaka.ui.Controls} controls */ constructor(parent, controls) { super(parent, controls); /** @protected {!HTMLElement} */ this.button = shaka.util.Dom.createHTMLElement('button'); this.parent.appendChild(this.button); const LOCALE_UPDATED = shaka.ui.Localization.LOCALE_UPDATED; this.eventManager.listen(this.localization, LOCALE_UPDATED, () => { this.updateAriaLabel(); }); const LOCALE_CHANGED = shaka.ui.Localization.LOCALE_CHANGED; this.eventManager.listen(this.localization, LOCALE_CHANGED, () => { this.updateAriaLabel(); }); this.eventManager.listen(this.video, 'play', () => { this.updateAriaLabel(); }); this.eventManager.listen(this.video, 'pause', () => { this.updateAriaLabel(); }); this.eventManager.listen(this.button, 'click', () => { if (this.isPaused()) { this.video.play(); } else { this.video.pause(); } }); } /** * @return {boolean} * @protected */ isPaused() { // The video element is in a paused state while seeking, but we don't count // that. return this.video.paused && !this.controls.isSeeking(); } /** @protected */ updateAriaLabel() { const LocIds = shaka.ui.Locales.Ids; const label = this.isPaused() ? LocIds.PLAY : LocIds.PAUSE; this.button.setAttribute(shaka.ui.Constants.ARIA_LABEL, this.localization.resolve(label)); } };