- // ==UserScript==
- // @name iMDB Large Images
- // @version 1.0.14
- // @description Large iMDB images when you hover over them.
- // @namespace https://greasyfork.org/en/scripts/11249-imdb-large-images
- // @homepage https://greasyfork.org/en/scripts/11249-imdb-large-images
- // @match http://imdb.com/*
- // @match https://imdb.com/*
- // @match http://*.imdb.com/*
- // @match https://*.imdb.com/*
- // @icon 
- // @require http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js
- // @grant none
- // ==/UserScript==
-
- this.$ = this.jQuery = jQuery.noConflict(true);
-
- /*!
- * hoverIntent v1.8.0 // 2014.06.29 // jQuery v1.9.1+
- * http://cherne.net/brian/resources/jquery.hoverIntent.html
- *
- * You may use hoverIntent under the terms of the MIT license. Basically that
- * means you are free to use hoverIntent as long as this header is left intact.
- * Copyright 2007, 2014 Brian Cherne
- */
- (function($){$.fn.hoverIntent=function(handlerIn,handlerOut,selector){var cfg={interval:100,sensitivity:6,timeout:0};if(typeof handlerIn==="object"){cfg=$.extend(cfg,handlerIn)}else{if($.isFunction(handlerOut)){cfg=$.extend(cfg,{over:handlerIn,out:handlerOut,selector:selector})}else{cfg=$.extend(cfg,{over:handlerIn,out:handlerIn,selector:handlerOut})}}var cX,cY,pX,pY;var track=function(ev){cX=ev.pageX;cY=ev.pageY};var compare=function(ev,ob){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);if(Math.sqrt((pX-cX)*(pX-cX)+(pY-cY)*(pY-cY))<cfg.sensitivity){$(ob).off("mousemove.hoverIntent",track);ob.hoverIntent_s=true;return cfg.over.apply(ob,[ev])}else{pX=cX;pY=cY;ob.hoverIntent_t=setTimeout(function(){compare(ev,ob)},cfg.interval)}};var delay=function(ev,ob){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);ob.hoverIntent_s=false;return cfg.out.apply(ob,[ev])};var handleHover=function(e){var ev=$.extend({},e);var ob=this;if(ob.hoverIntent_t){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t)}if(e.type==="mouseenter"){pX=ev.pageX;pY=ev.pageY;$(ob).on("mousemove.hoverIntent",track);if(!ob.hoverIntent_s){ob.hoverIntent_t=setTimeout(function(){compare(ev,ob)},cfg.interval)}}else{$(ob).off("mousemove.hoverIntent",track);if(ob.hoverIntent_s){ob.hoverIntent_t=setTimeout(function(){delay(ev,ob)},cfg.timeout)}}};return this.on({"mouseenter.hoverIntent":handleHover,"mouseleave.hoverIntent":handleHover},cfg.selector)}})(jQuery);
-
- $(document).ready(function() {
-
- var cssCode = `
- #largeImagePopover {
- position: absolute;
- box-shadow: 0 0 15px #000;
- cursor: pointer;
- z-index: 1000;
- }
- #largeImagePopover a.largeImageOriginal {
- font-family: sans-serif;
- font-size: 10px;
- background: rgba(0, 0, 0, 0.5);
- color: white;
- position: absolute;
- bottom: 2px;
- right: 2px;
- padding: 2px;
- z-index: 1001;
- }
- `;
-
- var styleElement = document.createElement("style");
- styleElement.type = "text/css";
- if (styleElement.styleSheet) {
- styleElement.styleSheet.cssText = cssCode;
- } else {
- styleElement.appendChild(document.createTextNode(cssCode));
- }
- document.getElementsByTagName("head")[0].appendChild(styleElement);
-
- var hoverInFunction = function (e) {
-
- var hoveredImage = this.src ? this : $(this).parent().find('img').get(0) || $(this).parent().parent().find('img').get(0);
-
- if(!hoveredImage) {
- console.log("Image Not Found");
- return;
- }
-
- hoveredImage.style.cursor = 'progress';
-
- $('div#largeImagePopover, div.largeImagePopover').remove();
- $("body").css("overflow", "auto");
-
- // setup the large image
- var popImage = document.createElement("img");
- var src = hoveredImage.src;
-
- src = src.replace(/_V1\.?.*?_\./g,"_V1_.");
- var srcorig = src;
- src = src.replace(/_V1_?\.jpg/,"_V1_SY"+window.innerHeight+"_.jpg");
-
- popImage.src = src
- popImage.alt = hoveredImage.alt;
- popImage.border = 0;
-
- // setup the image link
- var popLink = document.createElement("a");
- popLink.href = this.href ? this.href
- : $(this).parent().attr('href')
- || $(this).parent().find("a").attr('href')
- || $(this).parent().parent().attr('href')
- || $(this).parent().parent().find("a").attr('href')
- || $(this).parent().parent().parent().attr('href')
- || $(this).parent().parent().parent().find("a").attr('href')
- || $(this).parent().parent().parent().parent().attr('href')
- || $(this).parent().parent().parent().parent().find("a").attr('href');
- popLink.appendChild(popImage);
-
- var popLinkOriginal = document.createElement("a");
- popLinkOriginal.className = 'largeImageOriginal';
- popLinkOriginal.href = srcorig;
- popLinkOriginal.target = "_blank";
- popLinkOriginal.innerHTML = "[ ORIGNAL ]";
-
- // setup the image div
- var popDiv = document.createElement("div");
- popDiv.id = 'largeImagePopover';
- popDiv.className = 'largeImagePopover';
- popDiv.appendChild(popLink);
- popDiv.appendChild(popLinkOriginal);
- $(popDiv).hide();
-
- // attach events to new image
- $(popDiv).mouseleave( function() {
- $(popDiv).remove();
- });
- $(popImage).css('cursor','crosshair');
-
- $(popImage).load( function() {
- // these assignments may differ per browser
- var pageXOffset = window.pageXOffset;
- var pageYOffset = window.pageYOffset;
- var innerWidth = window.innerWidth;
- var innerHeight = window.innerHeight;
- var mouseX = e.pageX;
- var mouseY = e.pageY;
-
- // shrink image if wider than screen
- if(popImage.width > innerWidth-17) {
- var tmpW = popImage.width;
- popImage.width = Math.min(popImage.width,innerWidth-17);
- popImage.height = (popImage.width/tmpW) * popImage.height;
- }
- if(popImage.height > innerHeight) {
- var tmpH = popImage.height;
- popImage.height = Math.min(popImage.height,innerHeight);
- popImage.width = (popImage.height/tmpH) * popImage.width;
- }
-
- // center image on mouse cursor
- var x = mouseX - parseInt(popImage.width/2);
- var y = mouseY - parseInt(popImage.height/2);
-
- // move image down and right if off screen to the left or top
- x = Math.max(x,pageXOffset);
- y = Math.max(y,pageYOffset);
-
- // move image up or left if off screen to the right or bottom
- x = Math.min(x, pageXOffset + innerWidth - 17 - popImage.width)
- y = Math.min(y, pageYOffset + innerHeight - popImage.height);
-
- // move image down and right if off screen to the left or top
- x = Math.max(x,pageXOffset);
- y = Math.max(y,pageYOffset);
-
- $(popImage.parentNode.parentNode).css('left',x);
- $(popImage.parentNode.parentNode).css('top',y);
- $(popImage.parentNode.parentNode).show();
-
- hoveredImage.style.cursor = 'crosshair'
- });
-
- $('body').append($(popDiv));
- };
-
- $(document).keyup(function(e) {
- if (e.keyCode == 27) {
- $('div#largeImagePopover, div.largeImagePopover').remove();
- }
- });
-
- function checkImages() {
- $("img[src*='_V1']").not("img[src*='_ZA']").not(".imageDone").each(function() {
- $(this).addClass('imageDone').css('cursor','crosshair').hoverIntent( hoverInFunction, function(){} );
- });
- $("a.ipc-lockup-overlay").not(".imageDone").each(function() {
- $(this).addClass('imageDone').css('cursor','crosshair').hoverIntent( hoverInFunction, function(){} );
- });
-
- window.setTimeout(checkImages, 1000);
- }
-
- checkImages();
-
- });