video auto size (kissanime)

resize the video to pixel format size

// ==UserScript==
// @name video auto size (kissanime)
// @description resize the video to pixel format size
// @namespace gnblizz
// @homepageURL https://greasyfork.org/en/scripts/25492-video-auto-size-kissanime
// @include https://kissanime.ac/*
// @include https://kissanime.ru/*
// @exclude https://kissanime.ru/xyz/check.aspx
// @include https://openload.co/embed/*
// @include https://www.rapidvideo.com/*
// @include https://streamango.com/embed/*
// @version 1.07
// @grant none
// @compatible firefox
// @compatible chrome
// @run-at document-start
// @icon 
// ==/UserScript==
"use strict";

var autodimmer = true;

var video, container, isTop = window.self==window.top, once;

function RunWhenVideoReady(cb) {
  if(!video) video = fn('VIDEO');
  if(video.readyState) cb(); else video.addEventListener('loadedmetadata', cb);
  video.addEventListener('ended', EndFullScreenMode, false);
}

function SetResolution(event) { window.self.postMessage('videoformat' + this.textContent, 'http://kissanime.ru'); }

function showVideoSizeInfo() {
  rn(nn('DIV', { TEXT: video.videoWidth + 'x' + video.videoHeight, style:{ position: 'absolute', top: 1, left: 2, color: 'white', textShadow: '1px 1px black', fontSize: 'large', fontWeight: 'bold'}}, video.parentNode), 7);
  if(!isTop)
    window.top.postMessage('videoformat'.concat(video.videoWidth, 'x', video.videoHeight), 'https://kissanime.ru');
  if(autodimmer) {
    if(isTop) {
      var dim = fn('#allofthelights_bg1');
      if(!dim || dim.style.display != 'block')
        setTimeout(function() { fn('#switch').click() }, 100);
    } else video.addEventListener('ended', function(event) { window.top.postMessage('videoended', 'https://kissanime.ru'); }, false);
  }
}

window.addEventListener('DOMContentLoaded', function(e) {
video = fn('VIDEO');
//console.info('Started VideoAutoSize at:', location.hostname);
if(isTop) switch(location.hostname) {
case 'kissanime.ru':
  if(location.pathname == '/Special/AreYouHuman2') {
    document.title = unescape(location.search).match(/\/[^?]+/)[0].replace(/\/Anime\//, '').replace(/\/|-/g, ' ');
    break;
  }
  if(video) {
    RunWhenVideoReady(setSizeNow);
    SetStyle('.vjs-playing.vjs-user-inactive{cursor:none}');
  } else {
    container = fn('?#divMyVideo>iframe');
    if(container) {
      window.addEventListener('message', receiveMessage, false);
      var div = nn('DIV#defaultvideosizes', 0, container.parentNode.parentNode.parentNode), resolutions = '1200x800/800x600/640x480'.split('/');
      while(resolutions.length) {
        nn('BUTTON', { type: 'button', TEXT: resolutions.shift() }, div).onclick = SetResolution;
      }
      SetStyle('iframe[id^=ads],#divFloatRight',{visibility:'hidden'}, '#adsIfrme button', {margin: '2px 10px', backgroundColor: '#393939', color: '#ccc', border: '1px solid #666666;'});
    } else {
      var h = setInterval(function() { //TODO: use observers
        video = fn('VIDEO');
        if(video) {
          clearInterval(h);
          RunWhenVideoReady(setSizeNow);
        }
      }, 500);
    }
  }
  break;
case 'kissanime.ac': // .io
  setTimeout(function() {
    var myPlayer = videojs('player_html5' + (player_reload || ''));
    myPlayer.ready(function () {
      video = fn('VIDEO');
      RunWhenVideoReady(function(){
        var w = video.videoWidth, h = video.videoHeight, i = 'px!important';
        showVideoSizeInfo();
        SetStyle(
          'video',{objectPosition:'center top'},
          'div#container',{width:(w+40)+i},
          'div#player_html5,div#player_container',{width:(w)+i,height:(h+30)+i},
          'div#centerDivVideo',{maxWidth:'unset'},
          '.vjs-user-inactive',{cursor:'none'},
          '[style*="float"]{display:none!important;}').id = 'autosizestyle';
        video.scrollIntoView();
        i = fn('#AdtruePopupVideoClose');
        if(i) i.click();
      });
    });
  }, 3000);
  break;
} else {
  switch(location.hostname) {
  case 'openload.co':
    RunWhenVideoReady(showVideoSizeInfo);
    setTimeout(function() { window.popAdsLoaded = 1; fn('#videooverlay').click(); }, 1000);
    setTimeout(function() { fn('.vjs-poster').click(); window.BetterJsPop.destroy(); }, 2000);
    break;
  case 'www.rapidvideo.com':
    setTimeout(function() {
      RunWhenVideoReady(showVideoSizeInfo);
    }, 3000);
    SetStyle('video', {objectFit: 'contain !important', backgroundColor: '#111111'}, '#spinner~*:not(style)', {display: 'none'});
    break;
  case 'streamango.com':
    RunWhenVideoReady(showVideoSizeInfo);
    SetStyle('.vjs-user-inactive.vjs-playing', {cursor: 'none'});
    break;
}}
});

function receiveMessage(event) {
  // console.log('VideoAutoSize received:', event.data);
  if(typeof event.data == 'string') switch(event.data.slice(0,11)) {
  case 'videoformat':
    var m = event.data.match(/(\d+)x(\d+)$/);
    video = { videoWidth: parseInt(m[1]), videoHeight: parseInt(m[2])};
    setSizeNow(event);
    if(event.source != window.self) rn('#defaultvideosizes');
    if(autodimmer) {
      var dim = fn('#allofthelights_bg1');
      if(!dim || dim.style.display != 'block') fn('#switch').click();
    }
    break;
  case 'videoended':
    if(autodimmer) {
      var dim = fn('#allofthelights_bg1');
      if(dim && dim.style.display == 'block') dim.click();
    }
    break;
  }
}

function setSizeNow(event) {
  function parsePx(px){ if(/^\d+px$/.test(px)) return parseInt(px); }
  var obj, videoWidth = video.videoWidth, videoHeight = video.videoHeight;
  //
  console.log('VideoAutoSize video format:', [videoWidth,videoHeight].join('x'));
  if(container) video = container;
  else {
    showVideoSizeInfo(video);
    video.style.objectPosition = 'center top';
  }
  obj = video;
  var n, origWidth = parsePx(obj.style.width) || parsePx(obj.parentNode.style.width) || obj.clientWidth,
    origHeight = parsePx(obj.style.height) || parsePx(obj.parentNode.style.height) || obj.clientHeight;
  if(!origWidth) throw 'no width found!'; if(!origHeight) throw 'no height found!';
  var deltaWidth = videoWidth - origWidth, deltaHeight = videoHeight+30 - origHeight;
  do {
    n = parsePx(obj.style.width); if(n) obj.style.width = (n + deltaWidth)+ 'px';
    n = parsePx(obj.style.height); if(n) obj.style.height = (n + deltaHeight)+ 'px';
    obj = obj.parentNode;
  } while(obj.id != 'containerRoot' && obj.tagName != 'BODY');
  if(!once) {
    once = 1;
    obj = document.querySelectorAll('.divCloseBut>a');
    for(var i of obj) { i.click(); }
    if(!window.scrollY) video.scrollIntoView();
  }
}

function FullScreenElement() {
  if(document.exitFullscreen) return document.fullscreenElement;
  if(document.mozCancelFullScreen) return document.mozFullScreenElement;
  if(document.webkitExitFullscreen) return document.webkitFullscreenElement;
}

function EndFullScreenMode() {
  if(!FullScreenElement()) return false;
  (document.exitFullscreen||document.mozCancelFullScreen||document.webkitExitFullscreen).call(document);
  return true;
}

// new node
function nn(name, attributes, insertion) {
  var a = name.split('.'), i = a.shift().split('#'), node = document.createElement(i.shift());
  if(i[0]) node.id = i[0];
  if(a[0]) node.className = a.join(' ');
  if(attributes) {
    var names = Object.keys(attributes);
    for(name of names) {
      var value = attributes[name];
      switch(name) {
      case 'TEXT':
        node.textContent = value;
        break;
      case 'HTML':
        node.innerHTML = value;
        break;
      case 'style':
        if(typeof value == 'object')
          value = ConvertCSS(value);
      default:
        node.setAttribute(name, value);
      }
    }
  }
  if(insertion) {
  if(insertion.appendChild) insertion.appendChild(node);
  else {
  i = Object.keys(insertion)[0];
  if(i) {
    a = insertion[i];
    switch(i) {
    case 'append': a.appendChild(node); break;
    case 'insert': a.insertBefore(node, a.firstChild); break;
    case 'before': a.parentNode.insertBefore(node, a); break;
    case 'after': a.parentNode.insertBefore(node, a.nextSibling); break;
    }
  }}}
  return node;
}

// find node
function fn(name, parent) {
  if(!parent) parent = document;
  switch(name.charAt(0)) {
  case '#': return parent.getElementById(name.slice(1));
  case '.': return parent.getElementsByClassName(name.slice(1))[0];
  case '?': return parent.querySelector(name.slice(1));
  }
  return parent.getElementsByTagName(name)[0];
}

// remove node
function rn(node, delay, cb) {
  if(delay) {
    window.setTimeout(function() {
      if(!cb || !cb(node)) rn(node);
    }, 1000 * parseFloat(delay));
    return;
  }
  if(typeof(node)=='string') node = fn(node);
  if(node && node.parentNode) return node.parentNode.removeChild(node);
}

// CSS
function SetStyle() {
  var i = 0, style = '', t;
  do {
    style += arguments[i++];
    t = arguments[i++];
    switch(typeof t) {
    case 'object':
      t = ConvertCSS(t);
    case 'string':
      style += '{' + t + '}\n';
    }
  } while(i < arguments.length);
  return nn('STYLE', { TEXT: style }, document.head);
}

function ConvertCSS(def) {
  var names = Object.keys(def), style = '', name, value;
  for(name of names) {
    value = def[name];
    if(typeof value == 'number' && name != 'zIndex') value += 'px';
    style += name.replace(/([A-Z])/g, '-$1').toLowerCase().concat(': ', value, '; ');
  }
  return style.trimRight();
}

// public domain by gnblizz
// contact me with my username + '@web.de'