Files
shaka-player/ui/fullscreen_button.js
T
Joey Parrish 00442a9a7c Split up localization data for lazy loading
This changes the format of the localization data to enable apps to
trivially lazy-load translations.  It also adds --locales to the build
scripts to allow app developers to choose the compiled-in locales.
The generated output now goes into dist/ and is not checked into
revision control.  Finally, it adds "description" and "meaning" fields
to the source messages to allow us to more easily integrate with a
context-aware human translation service.  The "description" field
provides application context for the translator, while the "meaning"
field provides linguistic disambiguation for words with multiple
meanings or parts of speech in the original English.

Because the translation service wants to collapse messages with
identical text, we had to merge several messages together.  To this
end, we have removed the prefixes "ARIA_LABEL_" and "LABEL_" from the
messages themselves and collapsed what remained.

Issue #1688

Change-Id: I24c17e71c73f6663cf123cfdba118c486fa80ecc
2019-04-09 16:06:14 -07:00

146 lines
3.8 KiB
JavaScript

/**
* @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.FullscreenButton');
goog.require('shaka.ui.Element');
goog.require('shaka.ui.Enums');
goog.require('shaka.ui.Locales');
goog.require('shaka.ui.Localization');
goog.require('shaka.util.Dom');
/**
* @extends {shaka.ui.Element}
* @final
* @export
*/
shaka.ui.FullscreenButton = class extends shaka.ui.Element {
/**
* @param {!HTMLElement} parent
* @param {!shaka.ui.Controls} controls
*/
constructor(parent, controls) {
super(parent, controls);
this.button_ = shaka.util.Dom.createHTMLElement('button');
this.button_.classList.add('shaka-fullscreen-button');
this.button_.classList.add('material-icons');
this.button_.textContent = shaka.ui.Enums.MaterialDesignIcons.FULLSCREEN;
this.parent.appendChild(this.button_);
this.updateAriaLabel_();
/** @private {!HTMLElement} */
this.videoContainer_ = this.controls.getVideoContainer();
this.eventManager.listen(
this.localization, shaka.ui.Localization.LOCALE_UPDATED, () => {
this.updateAriaLabel_();
});
this.eventManager.listen(
this.localization, shaka.ui.Localization.LOCALE_CHANGED, () => {
this.updateAriaLabel_();
});
this.eventManager.listen(this.button_, 'click', () => {
this.toggleFullScreen_();
});
if (screen.orientation) {
this.eventManager.listen(screen.orientation, 'change', () => {
this.onScreenRotation_();
});
}
this.eventManager.listen(document, 'fullscreenchange', () => {
this.updateIcon_();
this.updateAriaLabel_();
});
}
/**
* @private
*/
updateAriaLabel_() {
const LocIds = shaka.ui.Locales.Ids;
const label = document.fullscreenElement ?
LocIds.EXIT_FULL_SCREEN : LocIds.FULL_SCREEN;
this.button_.setAttribute(shaka.ui.Constants.ARIA_LABEL,
this.localization.resolve(label));
}
/**
* @private
*/
updateIcon_() {
this.button_.textContent =
document.fullscreenElement ?
shaka.ui.Enums.MaterialDesignIcons.EXIT_FULLSCREEN :
shaka.ui.Enums.MaterialDesignIcons.FULLSCREEN;
}
/**
* @private
*/
async toggleFullScreen_() {
if (document.fullscreenElement) {
document.exitFullscreen();
} else {
await this.videoContainer_.requestFullscreen();
}
}
/**
* When a mobile device is rotated to landscape layout, and the video is
* loaded, make the demo app go into fullscreen.
* Similarly, exit fullscreen when the device is rotated to portrait layout.
* @private
*/
onScreenRotation_() {
if (!this.video ||
this.video.readyState == 0 ||
this.controls.getCastProxy().isCasting()) return;
if (screen.orientation.type.includes('landscape') &&
!document.fullscreenElement) {
this.videoContainer_.requestFullscreen();
} else if (screen.orientation.type.includes('portrait') &&
document.fullscreenElement) {
document.exitFullscreen();
}
}
};
/**
* @implements {shaka.extern.IUIElement.Factory}
* @final
*/
shaka.ui.FullscreenButton.Factory = class {
/** @override */
create(rootElement, controls) {
return new shaka.ui.FullscreenButton(rootElement, controls);
}
};
shaka.ui.Controls.registerElement(
'fullscreen', new shaka.ui.FullscreenButton.Factory());