mirror of
https://github.com/shaka-project/shaka-player.git
synced 2026-06-24 17:35:10 +03:00
82f7eafdc5
Adds a replacement for removed JSDoc checks from ESLint v9. Additionally fixes lots of issues found in the JSDoc, such as: - missing `@param`/`@return` annotations - bad formatting - params order - param name in the same line as type definition (tried to disable it, but it was causing other issues and we didn't have lots of places with such formatting) Minor fixes in code found by Closure Compiler after fixing JSDoc are also included.
150 lines
4.6 KiB
JavaScript
150 lines
4.6 KiB
JavaScript
/*! @license
|
|
* Shaka Player
|
|
* Copyright 2016 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
|
|
goog.provide('shaka.ui.PresentationTimeTracker');
|
|
|
|
goog.require('shaka.ads.Utils');
|
|
goog.require('shaka.ui.Controls');
|
|
goog.require('shaka.ui.Element');
|
|
goog.require('shaka.ui.Locales');
|
|
goog.require('shaka.ui.Utils');
|
|
goog.require('shaka.util.Dom');
|
|
|
|
|
|
/**
|
|
* @extends {shaka.ui.Element}
|
|
* @final
|
|
* @export
|
|
*/
|
|
shaka.ui.PresentationTimeTracker = class extends shaka.ui.Element {
|
|
/**
|
|
* @param {!HTMLElement} parent
|
|
* @param {!shaka.ui.Controls} controls
|
|
*/
|
|
constructor(parent, controls) {
|
|
super(parent, controls);
|
|
|
|
/** @type {!HTMLButtonElement} */
|
|
this.currentTime_ = shaka.util.Dom.createButton();
|
|
this.currentTime_.classList.add('shaka-current-time');
|
|
this.setValue_('0:00');
|
|
this.parent.appendChild(this.currentTime_);
|
|
|
|
this.eventManager.listen(this.currentTime_, 'click', () => {
|
|
// Jump to LIVE if the user clicks on the current time.
|
|
if (this.player.isLive()) {
|
|
this.video.currentTime = this.player.seekRange().end;
|
|
}
|
|
});
|
|
|
|
this.eventManager.listen(this.player, 'loading', () => {
|
|
shaka.ui.Utils.setDisplay(this.currentTime_, true);
|
|
});
|
|
|
|
this.eventManager.listen(this.controls, 'timeandseekrangeupdated', () => {
|
|
this.updateTime_();
|
|
});
|
|
|
|
this.eventManager.listen(this.player, 'trackschanged', () => {
|
|
this.onTracksChanged_();
|
|
});
|
|
|
|
this.eventManager.listen(
|
|
this.adManager, shaka.ads.Utils.AD_STARTED, () => {
|
|
shaka.ui.Utils.setDisplay(this.currentTime_, !this.ad.isLinear());
|
|
});
|
|
|
|
this.eventManager.listen(
|
|
this.adManager, shaka.ads.Utils.AD_STOPPED, () => {
|
|
shaka.ui.Utils.setDisplay(this.currentTime_, true);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* @param {string} value
|
|
* @private
|
|
*/
|
|
setValue_(value) {
|
|
// To avoid constant updates to the DOM, which makes debugging more
|
|
// difficult, only set the value if it has changed. If we don't do this
|
|
// check, the DOM updates constantly, this element flashes in the debugger
|
|
// in Chrome, and you can't make changes in the CSS panel.
|
|
if (value != this.currentTime_.textContent) {
|
|
this.currentTime_.textContent = value;
|
|
}
|
|
}
|
|
|
|
/** @private */
|
|
updateTime_() {
|
|
const isSeeking = this.controls.isSeeking();
|
|
let displayTime = this.controls.getDisplayTime();
|
|
const seekRange = this.player.seekRange();
|
|
const seekRangeSize = seekRange.end - seekRange.start;
|
|
const Utils = shaka.ui.Utils;
|
|
|
|
if (!isFinite(seekRangeSize)) {
|
|
this.setValue_(this.localization.resolve(shaka.ui.Locales.Ids.LIVE));
|
|
this.currentTime_.disabled = true;
|
|
} else if (this.player.isLive()) {
|
|
// The amount of time we are behind the live edge.
|
|
const behindLive = Math.floor(seekRange.end - displayTime);
|
|
displayTime = Math.max(0, behindLive);
|
|
|
|
const showHour = seekRangeSize >= 3600;
|
|
|
|
// Consider "LIVE" when less than 1 second behind the live-edge. Always
|
|
// show the full time string when seeking, including the leading '-';
|
|
// otherwise, the time string "flickers" near the live-edge.
|
|
// The button should only be clickable when it's live stream content, and
|
|
// the current play time is behind live edge.
|
|
if ((displayTime >= 1) || isSeeking) {
|
|
this.setValue_('- ' + Utils.buildTimeString(displayTime, showHour));
|
|
this.currentTime_.disabled = false;
|
|
} else {
|
|
this.setValue_(this.localization.resolve(shaka.ui.Locales.Ids.LIVE));
|
|
this.currentTime_.disabled = true;
|
|
}
|
|
} else {
|
|
const showHour = seekRangeSize >= 3600;
|
|
|
|
const currentTime = Math.max(0, displayTime - seekRange.start);
|
|
let value = Utils.buildTimeString(currentTime, showHour);
|
|
if (seekRangeSize) {
|
|
value += ' / ' + Utils.buildTimeString(seekRangeSize, showHour);
|
|
}
|
|
this.setValue_(value);
|
|
this.currentTime_.disabled = true;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Set the aria label to be 'Live' when the content is live stream.
|
|
* @private
|
|
*/
|
|
onTracksChanged_() {
|
|
if (this.player.isLive()) {
|
|
const ariaLabel = shaka.ui.Locales.Ids.SKIP_TO_LIVE;
|
|
this.currentTime_.ariaLabel = this.localization.resolve(ariaLabel);
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
/**
|
|
* @implements {shaka.extern.IUIElement.Factory}
|
|
* @final
|
|
*/
|
|
shaka.ui.PresentationTimeTracker.Factory = class {
|
|
/** @override */
|
|
create(rootElement, controls) {
|
|
return new shaka.ui.PresentationTimeTracker(rootElement, controls);
|
|
}
|
|
};
|
|
|
|
shaka.ui.Controls.registerElement(
|
|
'time_and_duration', new shaka.ui.PresentationTimeTracker.Factory());
|