2017-12-30 02:58:24 +01:00
|
|
|
if(Debug.debug)
|
|
|
|
console.log("Loading: PageInfo.js");
|
|
|
|
|
2018-05-13 13:49:25 +02:00
|
|
|
class PageInfo {
|
2018-11-02 02:52:01 +01:00
|
|
|
constructor(comms, settings, extensionMode){
|
2018-05-13 13:49:25 +02:00
|
|
|
this.hasVideos = false;
|
|
|
|
this.siteDisabled = false;
|
|
|
|
this.videos = [];
|
2018-08-05 23:48:56 +02:00
|
|
|
this.settings = settings;
|
2018-05-13 13:49:25 +02:00
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
this.lastUrl = window.location.href;
|
2018-11-02 02:52:01 +01:00
|
|
|
this.extensionMode = extensionMode;
|
2018-05-13 13:49:25 +02:00
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
this.rescan(RescanReason.PERIODIC);
|
|
|
|
this.scheduleUrlCheck();
|
2018-05-26 23:08:49 +02:00
|
|
|
|
|
|
|
if(comms){
|
|
|
|
this.comms = comms;
|
2018-08-30 00:56:15 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if(this.videos.length > 0){
|
2018-09-20 01:11:18 +02:00
|
|
|
console.log("registering video")
|
2018-08-30 00:56:15 +02:00
|
|
|
comms.registerVideo();
|
2018-05-26 23:08:49 +02:00
|
|
|
}
|
2018-09-21 00:26:08 +02:00
|
|
|
|
|
|
|
this.currentZoomScale = 1;
|
2018-05-13 21:05:11 +02:00
|
|
|
}
|
|
|
|
|
2018-08-30 00:56:15 +02:00
|
|
|
destroy() {
|
2018-09-23 19:46:40 +02:00
|
|
|
if(Debug.debug || Debug.init){
|
2018-08-30 00:56:15 +02:00
|
|
|
console.log("[PageInfo::destroy] destroying all videos!")
|
|
|
|
}
|
2018-08-30 23:03:47 +02:00
|
|
|
if(this.rescanTimer){
|
|
|
|
clearTimeout(this.rescanTimer);
|
|
|
|
}
|
2018-08-30 00:56:15 +02:00
|
|
|
for (var video of this.videos) {
|
|
|
|
video.destroy();
|
|
|
|
}
|
|
|
|
}
|
2018-06-15 00:33:10 +02:00
|
|
|
|
2018-08-22 23:46:59 +02:00
|
|
|
reset() {
|
2018-08-23 01:04:37 +02:00
|
|
|
for(var video of this.videos) {
|
2018-06-15 00:33:10 +02:00
|
|
|
video.destroy();
|
|
|
|
}
|
|
|
|
this.rescan(RescanReason.MANUAL);
|
|
|
|
}
|
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
rescan(rescanReason){
|
2018-05-16 23:26:47 +02:00
|
|
|
try{
|
2018-05-13 21:05:11 +02:00
|
|
|
var vids = document.getElementsByTagName('video');
|
2018-05-13 13:49:25 +02:00
|
|
|
|
2018-05-13 21:05:11 +02:00
|
|
|
if(!vids || vids.length == 0){
|
2018-05-13 13:49:25 +02:00
|
|
|
this.hasVideos = false;
|
2018-05-16 23:26:47 +02:00
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
if(rescanReason == RescanReason.PERIODIC){
|
|
|
|
this.scheduleRescan(RescanReason.PERIODIC);
|
|
|
|
}
|
2018-05-13 13:49:25 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// add new videos
|
2018-05-21 22:43:56 +02:00
|
|
|
this.hasVideos = false;
|
|
|
|
var videoExists = false;
|
|
|
|
var video, v;
|
|
|
|
|
|
|
|
for (video of vids) {
|
|
|
|
// če najdemo samo en video z višino in širino, to pomeni, da imamo na strani veljavne videe
|
|
|
|
// če trenutni video nima definiranih teh vrednostih, preskočimo vse nadaljnja preverjanja
|
|
|
|
// <===[:::::::]===>
|
|
|
|
// if we find even a single video with width and height, that means the page has valid videos
|
|
|
|
// if video lacks either of the two properties, we skip all further checks cos pointless
|
|
|
|
if(video.offsetWidth && video.offsetHeight){
|
|
|
|
this.hasVideos = true;
|
|
|
|
} else {
|
|
|
|
continue;
|
2018-05-20 23:17:09 +02:00
|
|
|
}
|
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
videoExists = false;
|
2018-05-19 22:20:35 +02:00
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
for (v of this.videos) {
|
|
|
|
if (v.destroyed) {
|
|
|
|
continue; //TODO: if destroyed video is same as current video, copy aspect ratio settings to current video
|
|
|
|
}
|
2018-05-20 23:17:09 +02:00
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
if (v.video == video) {
|
|
|
|
videoExists = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2018-05-20 23:17:09 +02:00
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
if (videoExists) {
|
|
|
|
continue;
|
|
|
|
} else {
|
2018-05-22 00:19:50 +02:00
|
|
|
if(Debug.debug && Debug.periodic && Debug.videoRescan){
|
|
|
|
console.log("[PageInfo::rescan] found new video candidate:", video)
|
|
|
|
}
|
2018-09-21 00:26:08 +02:00
|
|
|
v = new VideoData(video, this.settings, this);
|
2018-05-22 00:19:50 +02:00
|
|
|
// console.log("[PageInfo::rescan] v is:", v)
|
|
|
|
// debugger;
|
2018-05-21 22:43:56 +02:00
|
|
|
v.initArDetection();
|
|
|
|
this.videos.push(v);
|
2018-05-22 00:19:50 +02:00
|
|
|
|
|
|
|
if(Debug.debug && Debug.periodic && Debug.videoRescan){
|
|
|
|
console.log("[PageInfo::rescan] — videos[] is now this:", this.videos,"\n\n\n\n\n\n\n\n")
|
|
|
|
}
|
2018-05-21 22:43:56 +02:00
|
|
|
}
|
2018-05-16 23:26:47 +02:00
|
|
|
}
|
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
this.removeDestroyed();
|
2018-05-16 23:26:47 +02:00
|
|
|
}catch(e){
|
|
|
|
console.log("rescan error:",e)
|
2018-05-13 13:49:25 +02:00
|
|
|
}
|
2018-05-21 22:43:56 +02:00
|
|
|
|
|
|
|
if(rescanReason == RescanReason.PERIODIC){
|
|
|
|
this.scheduleRescan(RescanReason.PERIODIC);
|
|
|
|
}
|
2018-05-16 23:26:47 +02:00
|
|
|
}
|
|
|
|
|
2018-05-21 22:43:56 +02:00
|
|
|
removeDestroyed(){
|
|
|
|
this.videos = this.videos.filter( vid => vid.destroyed === false);
|
|
|
|
}
|
|
|
|
|
|
|
|
scheduleRescan(rescanReason){
|
|
|
|
if(rescanReason != RescanReason.PERIODIC){
|
|
|
|
this.rescan(rescanReason);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-05-16 23:26:47 +02:00
|
|
|
try{
|
2018-05-21 22:43:56 +02:00
|
|
|
if(this.rescanTimer){
|
|
|
|
clearTimeout(this.rescanTimer);
|
|
|
|
}
|
|
|
|
|
|
|
|
var ths = this;
|
|
|
|
|
|
|
|
|
|
|
|
this.rescanTimer = setTimeout(function(rr){
|
|
|
|
ths.rescanTimer = null;
|
|
|
|
ths.rescan(rr);
|
|
|
|
ths = null;
|
2018-08-30 00:56:15 +02:00
|
|
|
}, rescanReason === this.settings.active.pageInfo.timeouts.rescan, RescanReason.PERIODIC)
|
2018-05-21 22:43:56 +02:00
|
|
|
} catch(e) {
|
|
|
|
if(Debug.debug){
|
|
|
|
console.log("[PageInfo::scheduleRescan] scheduling rescan failed. Here's why:",e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
scheduleUrlCheck() {
|
|
|
|
try{
|
|
|
|
if(this.urlCheckTimer){
|
|
|
|
clearTimeout(this.urlCheckTimer);
|
2018-05-16 23:26:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
var ths = this;
|
2018-05-21 22:43:56 +02:00
|
|
|
|
2018-05-16 23:26:47 +02:00
|
|
|
this.rescanTimer = setTimeout(function(){
|
|
|
|
ths.rescanTimer = null;
|
2018-05-21 22:43:56 +02:00
|
|
|
ths.ghettoUrlCheck();
|
2018-05-16 23:26:47 +02:00
|
|
|
ths = null;
|
2018-08-30 00:56:15 +02:00
|
|
|
}, this.settings.active.pageInfo.timeouts.urlCheck)
|
2018-05-21 22:43:56 +02:00
|
|
|
}catch(e){
|
|
|
|
if(Debug.debug){
|
|
|
|
console.log("[PageInfo::scheduleUrlCheck] scheduling URL check failed. Here's why:",e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ghettoUrlCheck() {
|
|
|
|
if (this.lastUrl != window.location.href){
|
|
|
|
if(Debug.debug){
|
|
|
|
console.log("[PageInfo::ghettoUrlCheck] URL has changed. Triggering a rescan!");
|
|
|
|
}
|
|
|
|
|
|
|
|
this.rescan(RescanReason.URL_CHANGE);
|
|
|
|
this.lastUrl = window.location.href;
|
|
|
|
}
|
2018-07-12 23:27:10 +02:00
|
|
|
|
|
|
|
this.scheduleUrlCheck();
|
2018-05-13 13:49:25 +02:00
|
|
|
}
|
|
|
|
|
2018-05-14 20:39:15 +02:00
|
|
|
initArDetection(){
|
2018-05-24 20:50:37 +02:00
|
|
|
for(var vd of this.videos){
|
2018-05-14 20:39:15 +02:00
|
|
|
vd.initArDetection();
|
2018-05-13 21:05:11 +02:00
|
|
|
}
|
|
|
|
}
|
2018-05-13 13:49:25 +02:00
|
|
|
|
2018-05-23 23:57:51 +02:00
|
|
|
|
|
|
|
// to je treba klicat ob menjavi zavihkov
|
|
|
|
// these need to be called on tab switch
|
|
|
|
pauseProcessing(){
|
|
|
|
for(var vd of this.videos){
|
|
|
|
vd.pause();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
resumeProcessing(resumeAutoar = false){
|
|
|
|
for(var vd of this.videos){
|
|
|
|
vd.resume();
|
|
|
|
if(resumeAutoar){
|
|
|
|
vd.resumeAutoAr();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
|
|
|
|
|
|
|
|
startArDetection(){
|
|
|
|
for(var vd of this.videos){
|
|
|
|
vd.startArDetection();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
stopArDetection(){
|
|
|
|
for(var vd of this.videos){
|
|
|
|
vd.stopArDetection();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-13 21:05:11 +02:00
|
|
|
setAr(ar){
|
2018-05-27 01:29:02 +02:00
|
|
|
if(ar !== 'auto') {
|
|
|
|
this.stopArDetection();
|
|
|
|
}
|
2018-09-14 00:10:57 +02:00
|
|
|
|
2018-05-13 21:05:11 +02:00
|
|
|
// TODO: find a way to only change aspect ratio for one video
|
2018-09-14 00:10:57 +02:00
|
|
|
if (ar === 'reset') {
|
|
|
|
for (var vd of this.videos) {
|
|
|
|
vd.resetAr();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
for (var vd of this.videos) {
|
|
|
|
vd.setAr(ar)
|
|
|
|
}
|
2018-05-13 21:05:11 +02:00
|
|
|
}
|
|
|
|
}
|
2017-12-30 02:58:24 +01:00
|
|
|
|
2018-09-23 02:39:27 +02:00
|
|
|
setVideoFloat(videoFloat) {
|
|
|
|
for(var vd of this.videos) {
|
|
|
|
vd.setVideoFloat(videoFloat)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-13 23:47:20 +02:00
|
|
|
setPanMode(mode) {
|
|
|
|
for(var vd of this.videos) {
|
|
|
|
vd.setPanMode(mode);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-15 16:22:32 +02:00
|
|
|
restoreAr() {
|
|
|
|
for(var vd of this.videos){
|
|
|
|
vd.restoreAr()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-13 21:05:11 +02:00
|
|
|
setStretchMode(sm){
|
2018-05-27 21:41:08 +02:00
|
|
|
// TODO: find a way to only change aspect ratio for one video
|
|
|
|
|
2018-05-24 20:50:37 +02:00
|
|
|
for(var vd of this.videos){
|
2018-05-27 21:41:08 +02:00
|
|
|
vd.setStretchMode(sm)
|
2018-05-13 21:05:11 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-21 00:26:08 +02:00
|
|
|
setZoom(zoomLevel, no_announce) {
|
2018-09-18 23:37:33 +02:00
|
|
|
for(var vd of this.videos) {
|
2018-09-21 00:26:08 +02:00
|
|
|
vd.setZoom(zoomLevel, no_announce);
|
2018-09-18 23:37:33 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-24 22:49:32 +02:00
|
|
|
zoomStep(step){
|
2018-05-24 20:50:37 +02:00
|
|
|
for(var vd of this.videos){
|
|
|
|
vd.zoomStep(step);
|
|
|
|
}
|
|
|
|
}
|
2018-09-21 00:26:08 +02:00
|
|
|
|
|
|
|
announceZoom(scale) {
|
|
|
|
if (this.announceZoomTimeout) {
|
|
|
|
clearTimeout(this.announceZoom);
|
|
|
|
}
|
|
|
|
this.currentZoomScale = scale;
|
|
|
|
const ths = this;
|
|
|
|
this.announceZoomTimeout = setTimeout(() => ths.comms.announceZoom(scale), this.settings.active.zoom.announceDebounce);
|
|
|
|
}
|
|
|
|
|
|
|
|
requestCurrentZoom() {
|
|
|
|
this.comms.announceZoom(this.currentZoomScale);
|
|
|
|
}
|
2018-05-13 21:05:11 +02:00
|
|
|
}
|
2018-05-21 22:43:56 +02:00
|
|
|
|
|
|
|
var RescanReason = {
|
|
|
|
PERIODIC: 0,
|
|
|
|
URL_CHANGE: 1,
|
|
|
|
MANUAL: 2
|
|
|
|
}
|