2019-04-08 20:31:18 +02:00
|
|
|
define(['playbackManager', 'text!./subtitlesync.template.html', 'css!./subtitlesync'], function (playbackManager, template, css) {
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var player;
|
|
|
|
var subtitleSyncSlider;
|
|
|
|
var subtitleSyncTextField;
|
|
|
|
var subtitleSyncCloseButton;
|
|
|
|
var subtitleSyncContainer;
|
|
|
|
|
|
|
|
function init(instance) {
|
|
|
|
|
|
|
|
var parent = document.createElement('div');
|
|
|
|
parent.innerHTML = template;
|
|
|
|
|
|
|
|
subtitleSyncSlider = parent.querySelector(".subtitleSyncSlider");
|
|
|
|
subtitleSyncTextField = parent.querySelector(".subtitleSyncTextField");
|
|
|
|
subtitleSyncCloseButton = parent.querySelector(".subtitleSync-closeButton");
|
|
|
|
subtitleSyncContainer = parent.querySelector(".subtitleSyncContainer");
|
|
|
|
|
|
|
|
subtitleSyncContainer.classList.add("hide");
|
|
|
|
|
|
|
|
subtitleSyncTextField.updateOffset = function(offset) {
|
|
|
|
this.textContent = offset + "s";
|
|
|
|
}
|
|
|
|
|
|
|
|
subtitleSyncTextField.addEventListener("keypress", function(event) {
|
|
|
|
|
2019-11-23 00:29:38 +09:00
|
|
|
if (event.key === "Enter") {
|
2019-04-08 20:31:18 +02:00
|
|
|
// if input key is enter search for float pattern
|
|
|
|
var inputOffset = /[-+]?\d+\.?\d*/g.exec(this.textContent);
|
2019-11-23 00:29:38 +09:00
|
|
|
if (inputOffset) {
|
2019-04-08 20:31:18 +02:00
|
|
|
inputOffset = inputOffset[0];
|
|
|
|
|
|
|
|
// replace current text by considered offset
|
|
|
|
this.textContent = inputOffset + "s";
|
|
|
|
|
|
|
|
inputOffset = parseFloat(inputOffset);
|
|
|
|
// set new offset
|
|
|
|
playbackManager.setSubtitleOffset(inputOffset, player);
|
|
|
|
// synchronize with slider value
|
|
|
|
subtitleSyncSlider.updateOffset(
|
|
|
|
getPercentageFromOffset(inputOffset));
|
|
|
|
} else {
|
|
|
|
this.textContent = (playbackManager.getPlayerSubtitleOffset(player) || 0) + "s";
|
|
|
|
}
|
|
|
|
this.hasFocus = false;
|
|
|
|
event.preventDefault();
|
|
|
|
} else {
|
|
|
|
// keep focus to prevent fade with bottom layout
|
|
|
|
this.hasFocus = true;
|
2019-11-23 00:29:38 +09:00
|
|
|
if (event.key.match(/[+-\d.s]/) === null) {
|
2019-04-08 20:31:18 +02:00
|
|
|
event.preventDefault();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
subtitleSyncSlider.updateOffset = function(percent) {
|
|
|
|
// default value is 0s = 50%
|
|
|
|
this.value = percent === undefined ? 50 : percent;
|
|
|
|
}
|
|
|
|
|
|
|
|
subtitleSyncSlider.addEventListener("change", function () {
|
|
|
|
// set new offset
|
|
|
|
playbackManager.setSubtitleOffset(getOffsetFromPercentage(this.value), player);
|
|
|
|
// synchronize with textField value
|
|
|
|
subtitleSyncTextField.updateOffset(
|
|
|
|
getOffsetFromPercentage(this.value));
|
|
|
|
});
|
|
|
|
|
|
|
|
subtitleSyncSlider.addEventListener("touchmove", function () {
|
|
|
|
// set new offset
|
|
|
|
playbackManager.setSubtitleOffset(getOffsetFromPercentage(this.value), player);
|
|
|
|
// synchronize with textField value
|
|
|
|
subtitleSyncTextField.updateOffset(
|
|
|
|
getOffsetFromPercentage(this.value));
|
|
|
|
});
|
|
|
|
|
|
|
|
subtitleSyncSlider.getBubbleHtml = function (value) {
|
|
|
|
var newOffset = getOffsetFromPercentage(value);
|
|
|
|
return '<h1 class="sliderBubbleText">' +
|
|
|
|
(newOffset > 0 ? "+" : "") + parseFloat(newOffset) + "s" +
|
|
|
|
"</h1>";
|
|
|
|
};
|
|
|
|
|
|
|
|
subtitleSyncCloseButton.addEventListener("click", function() {
|
|
|
|
playbackManager.disableShowingSubtitleOffset(player);
|
|
|
|
SubtitleSync.prototype.toggle("forceToHide");
|
|
|
|
});
|
|
|
|
|
|
|
|
document.body.appendChild(parent);
|
|
|
|
|
|
|
|
instance.element = parent;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getOffsetFromPercentage(value) {
|
|
|
|
// convert percent to fraction
|
|
|
|
var offset = (value - 50) / 50;
|
|
|
|
// multiply by offset min/max range value (-x to +x) :
|
|
|
|
offset *= 30;
|
|
|
|
return offset.toFixed(1);
|
2019-11-23 00:29:38 +09:00
|
|
|
}
|
2019-04-08 20:31:18 +02:00
|
|
|
|
|
|
|
function getPercentageFromOffset(value) {
|
|
|
|
// divide by offset min/max range value (-x to +x) :
|
|
|
|
var percentValue = value / 30;
|
|
|
|
// convert fraction to percent
|
|
|
|
percentValue *= 50;
|
|
|
|
percentValue += 50;
|
|
|
|
return Math.min(100, Math.max(0, percentValue.toFixed()));
|
2019-11-23 00:29:38 +09:00
|
|
|
}
|
2019-04-08 20:31:18 +02:00
|
|
|
|
|
|
|
function SubtitleSync(currentPlayer) {
|
|
|
|
player = currentPlayer;
|
|
|
|
init(this);
|
|
|
|
}
|
|
|
|
|
2019-11-23 00:29:38 +09:00
|
|
|
SubtitleSync.prototype.destroy = function() {
|
2019-04-08 20:31:18 +02:00
|
|
|
SubtitleSync.prototype.toggle("forceToHide");
|
2019-11-23 00:29:38 +09:00
|
|
|
if (player) {
|
2019-04-08 20:31:18 +02:00
|
|
|
playbackManager.disableShowingSubtitleOffset(player);
|
|
|
|
playbackManager.setSubtitleOffset(0, player);
|
|
|
|
}
|
|
|
|
var elem = this.element;
|
|
|
|
if (elem) {
|
|
|
|
elem.parentNode.removeChild(elem);
|
|
|
|
this.element = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SubtitleSync.prototype.toggle = function(action) {
|
|
|
|
|
2019-11-23 00:29:38 +09:00
|
|
|
if (player && playbackManager.supportSubtitleOffset(player)) {
|
2020-02-26 01:12:48 -05:00
|
|
|
/* eslint-disable no-fallthrough */
|
2019-11-23 00:29:38 +09:00
|
|
|
switch (action) {
|
2019-04-08 20:31:18 +02:00
|
|
|
case undefined:
|
|
|
|
// if showing subtitle sync is enabled
|
2019-11-23 00:29:38 +09:00
|
|
|
if (playbackManager.isShowingSubtitleOffsetEnabled(player) &&
|
2019-04-08 20:31:18 +02:00
|
|
|
// if there is an external subtitle stream enabled
|
2019-11-23 00:29:38 +09:00
|
|
|
playbackManager.canHandleOffsetOnCurrentSubtitle(player)) {
|
|
|
|
// if no subtitle offset is defined
|
|
|
|
if (!playbackManager.getPlayerSubtitleOffset(player)) {
|
|
|
|
// set default offset to '0' = 50%
|
|
|
|
subtitleSyncSlider.value = "50";
|
|
|
|
subtitleSyncTextField.textContent = "0s";
|
|
|
|
playbackManager.setSubtitleOffset(0, player);
|
|
|
|
}
|
|
|
|
// show subtitle sync
|
|
|
|
subtitleSyncContainer.classList.remove("hide");
|
|
|
|
break; // stop here
|
2019-04-08 20:31:18 +02:00
|
|
|
} // else continue and hide
|
|
|
|
case "hide":
|
2019-11-23 00:29:38 +09:00
|
|
|
// only break if element has focus
|
|
|
|
if (subtitleSyncTextField.hasFocus) {
|
|
|
|
break;
|
|
|
|
}
|
2019-04-08 20:31:18 +02:00
|
|
|
case "forceToHide":
|
|
|
|
subtitleSyncContainer.classList.add("hide");
|
|
|
|
break;
|
|
|
|
}
|
2020-02-26 01:12:48 -05:00
|
|
|
/* eslint-enable no-fallthrough */
|
2019-04-08 20:31:18 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return SubtitleSync;
|
|
|
|
});
|