Skip to content

Instantly share code, notes, and snippets.

@PseudoImplementation
Created January 26, 2015 15:02
Show Gist options
  • Save PseudoImplementation/55683929b5f81b3f5162 to your computer and use it in GitHub Desktop.
Save PseudoImplementation/55683929b5f81b3f5162 to your computer and use it in GitHub Desktop.
// ==UserScript==
// @name Sankaku Fast Image Viewer
// @namespace faleij
// @description View full image without being redirected
// @include http://*.sankakucomplex.com*
// @include https://*.sankakucomplex.com*
// @grant GM_getResourceText
// @grant GM_getValue
// @grant GM_setValue
// @version 3.21
// @updateURL http://userscripts.org/scripts/source/168579.meta.js
// @resource css http://pastebin.com/raw.php?i=RctNLpPK&v=3.21
// ==/UserScript==
var $ = unsafeWindow.jQuery;
var $unsafeWindow = $(unsafeWindow);
$("<style type='text/css'/>").text(GM_getResourceText("css")).appendTo("head");
var loadingImage = "";
var ErrorImage = "";
var $settings = $("" +
"<div style='margin-bottom: 1em;'>" +
" <h5>Image Display Mode</h5>" +
" <form action='' onsubmit='return false;'>" +
" <div>" +
" <select style='width: 13em;' id='displayMode' name='displayMode'>" +
" <option value='full'>Full</option>" +
" <option value='adaptive'>Adaptive</option>" +
" <option value='redirect'>Redirect (Off)</option>" +
" </select>" +
" </div>" +
" </form>" +
"</div>"+
"<div style='margin-bottom: 1em;'>" +
" <h5>Scroll Mode</h5>" +
" <form action='' onsubmit='return false;'>" +
" <div>" +
" <select style='width: 13em;' id='scrollMode' name='scrollMode'>" +
" <option value='image'>Image</option>" +
" <option value='window'>Window</option>" +
" <option value='none'>None</option>" +
" </select>" +
" </div>" +
" </form>" +
"</div>" +
"<div style='margin-bottom: 1em;'>" +
" <h5>Middle Mouse Button Action</h5>" +
" <form action='' onsubmit='return false;'>" +
" <div>" +
" <select style='width: 13em;' id='MMBAction' name='MMBAction'>" +
" <option value='newTab'>Open in New Tab</option>" +
" <option value='sameTab'>Open in Same Tab</option>" +
" </select>" +
" </div>" +
" </form>" +
"</div>" +
"<div style='margin-bottom: 1em;'>" +
" <h5>Show Image By</h5>" +
" <form action='' onsubmit='return false;'>" +
" <div>" +
" <select style='width: 13em;' id='showBy' name='showBy'>" +
" <option value='clicking'>Clicking</option>" +
" <option value='hovering'>Hovering</option>" +
" </select>" +
" </div>" +
" </form>" +
"</div>");
var standardDisplayMode = "adaptive";
var standardScrollMode = "window";
var standardShowBy = "clicking";
var standardMMBAction = "newTab";
showBy = GM_getValue("showBy", standardShowBy);
displayMode = GM_getValue("displayMode", standardDisplayMode);
MMBAction = GM_getValue("MMBAction", standardMMBAction);
$("#displayMode option[value='" + GM_getValue("displayMode", standardDisplayMode) + "']", $settings).attr("selected", "true");
$("#scrollMode option[value='" + GM_getValue("scrollMode", standardScrollMode) + "']", $settings).attr("selected", "true");
$("#MMBAction option[value='" + GM_getValue("MMBAction", standardMMBAction) + "']", $settings).attr("selected", "true");
$("#showBy option[value='" + GM_getValue("showBy", standardShowBy) + "']", $settings).attr("selected", "true");
$sidebar = $(".sidebar");
$sidebar.append($settings);
$("#displayMode", $settings).change(function () {
setTimeout(function () {
GM_setValue("displayMode", $("#displayMode :selected", $settings).val());
displayMode = GM_getValue("displayMode", standardDisplayMode);
}, 0);
});
$("#MMBAction", $settings).change(function () {
setTimeout(function () {
GM_setValue("MMBAction", $("#MMBAction :selected", $settings).val());
MMBAction = GM_getValue("MMBAction", standardMMBAction);
}, 0);
});
$("#showBy", $settings).change(function () {
setTimeout(function () {
GM_setValue("showBy", $("#showBy :selected", $settings).val());
showBy = GM_getValue("showBy", standardShowBy);
}, 0);
});
$("#scrollMode", $settings).change(function () {
setTimeout(function () {
GM_setValue("scrollMode", $("#scrollMode :selected", $settings).val());
}, 0);
});
var imgCache = {};
function preloadImage(src,cb){
if(imgCache.hasOwnProperty(src)){
cb.call(imgCache[src]);
}else{
$("<img/>").attr("src", src).one('load',function(){
imgCache[src] = this;
cb.call(this);
});
}
}
function loadPage(src,cb){
var $iframe = $("<iframe style='visibility:hidden;'/>");
$iframe.one('load', function(){cb.call(this,$iframe)});
$iframe.attr("src",src);
$("body").append($iframe);
return $iframe;
}
function openImage(img, src) {
var that = this;
img.one('load', function(){
img.css({"opacity":"1.0"});
img.parent().parent().css("background-image", "");
setTimeout(function () {
closeOpenImages();
var fullWidth = that.width;
var fullHeight = that.height;
var vpHeight = $unsafeWindow.height();
var vpWidth = $unsafeWindow.width();
var thumbWidth = img.width();
var thumbHeight = img.height();
var offset = img.offset();
var scale;
switch (GM_getValue("displayMode", standardDisplayMode)) {
case "full":
scale = fullHeight / thumbHeight;
break;
case "adaptive":
{
var h = Math.min(fullHeight, vpHeight);
var hscale = h / thumbHeight;
var w = Math.min(fullWidth, vpWidth);
var wscale = w / thumbWidth;
scale = Math.min(hscale, wscale);
}
break;
}
var xtanslation = ($(document).scrollLeft()) -offset.left - (thumbWidth * 0.5) + ((vpWidth * 0.5));
var ytranslation = 0;
switch(GM_getValue("scrollMode", standardScrollMode)){
case "image":
ytranslation = -(offset.top+thumbHeight*0.5 - ($unsafeWindow.scrollTop() + vpHeight*0.5));
break;
case "window":
$('html, body').animate({
scrollTop: offset.top + thumbHeight * 0.5 - vpHeight * 0.5
}, 2000);
break;
case "none":
break;
}
img.css({
"-webkit-transform" :"translate(" + xtanslation + "px, " + ytranslation + "px) scale(" + scale + ")",
"-moz-transform" :"translate(" + xtanslation + "px, " + ytranslation + "px) scale(" + scale + ")",
"box-shadow" :"0px 0px "+ (35/scale) +"px #888888",
"padding" :"0px"
});
img.parent().parent().css("z-index", "5");
img.attr("isLarge", "true");
}, 1);
});
img.attr("src",src);
}
$unsafeWindow.bind("keydown",function(e){
var openImage = $(".thumb a img[isLarge='true']");
if(openImage.length === 1){
var src = openImage.attr("src");
var imgs = document.querySelectorAll(".thumb a img");
var openIdx = -1;
for(var idx in imgs){
if(imgs[idx].src === src){
openIdx = parseInt(idx);
break;
}
}
switch(e.keyCode) {
case 39:
closeOpenImages();
imgs[++openIdx].click();
break;
case 37:
closeOpenImages();
imgs[--openIdx].click();
break;
}
}
});
function closeOpenImages() {
$(".thumb a img[isLarge='true']").each(function () {
var img = $(this);
img.attr("isLarge", "false");
img.css({"-webkit-transform":"", "-moz-transform":"", "box-shadow":"none"});
img.attr("src",img.attr("thumbSrc"));
setTimeout(function () {
if (img.attr("isLarge") !== "true") {
img.css({"padding":""});
img.parent().parent().css("z-index", "1");
}
}, 1000);
});
}
var tags = {};
var $tag = null;
function addTags($iframe,key){
var tag = tags[key] = $iframe.contents().find("#tag-sidebar").parent().clone().hide();
$("h5",tag).text("Image Tags")
}
function showTag(key){
if($tag !== null) $tag.fadeOut().remove();
$tag = tags[key];
$tag.appendTo($sidebar).fadeIn();
}
function imageInteract(){
var href = this.href;
var img = $("img", $(this));
img.addClass("thumbTransition");
if (img.attr("isLarge") !== "true") {
if (img.attr("isLoaded") === "true") {
img.css({"opacity":"0.3"});
img.parent().parent().css("background-image", "url(" + loadingImage + ")");
preloadImage(img.attr("fullSrc"), function () {
var that = this;
openImage.call(that, img, img.attr("fullSrc"));
showTag(href);
});
} else if(img.attr("isLoading") !== "true") {
img.attr("isLoading", "true");
img.css({"opacity":"0.3"});
img.parent().parent().css("background-image", "url(" + loadingImage + ")");
img.attr("thumbSrc",img.attr("src"));
loadPage(href,function($iframe){
console.log("iframe loaded");
var src = $iframe.contents().find("#highres").attr("href");
var fimg = $iframe.contents().find("#image");
if(src!==undefined){
addTags($iframe,href);
fimg.load(function(){
$iframe.remove();
preloadImage(src, function () {
var that = this;
img.attr("isLoading", "false");
img.attr("isLoaded", "true");
img.attr("fullSrc",src);
openImage.call(that, img, src);
showTag(href);
});
});
fimg.attr("src",""); //force unload image
fimg.attr("src",src); //force reload
}else{
$iframe.remove();
img.parent().parent().css("background-image", "url(" + ErrorImage + ")");
setTimeout(function(){
img.attr("isLoading", "false");
img.css({"opacity":"1.0"});
},3000);
}
});
}
}else{
closeOpenImages();
}
}
var mousex,mousey;
function stopWatch(){
var $timer = $('<div class="timer"></div>');
$timer.hide().appendTo("body").fadeIn(100);
$timer.css({
left: mousex-20,
top: mousey-15
});
var timer;
var timerCurrent = 0;
var timerSeconds = 1;
var timerFinish = new Date().getTime() + (timerSeconds * 1000);
function drawTimer(percent) {
$timer.html('<div class="percent"></div><div id="slice"' + (percent > 50 ? ' class="gt50"' : '') +
'><div class="pie"></div>' + (percent > 50 ? '<div class="pie fill"></div>' : '') + '</div>');
var deg = 360 / 100 * percent;
$('#slice .pie',$timer).css({
'-moz-transform': 'rotate(' + deg + 'deg)',
'-webkit-transform': 'rotate(' + deg + 'deg)',
'-o-transform': 'rotate(' + deg + 'deg)',
'transform': 'rotate(' + deg + 'deg)'
});
}
function intervalFn() {
var seconds = (timerFinish - (new Date().getTime())) / 1000;
if (seconds <= 0) {
drawTimer(100);
clearInterval(timer);
$timer.fadeOut(100).remove();
} else {
var percent = 100 - ((seconds / timerSeconds) * 100);
drawTimer(percent);
}
}
var timer = setInterval(intervalFn,50);
return function(){
clearInterval(timer);
$timer.fadeOut(100).remove();
}
}
function decideAction(button){
if(showBy==="clicking"){
if (button === 0 && (displayMode !== "redirect")) {
imageInteract.call(this);
return true;
}
}else if("hovering"){
if(this.timeout) clearTimeout(this.timeout);
this.timeout = setTimeout(imageInteract.bind(this), 1000);
this.stopWatch = stopWatch();
}
if(button === 1){
if(MMBAction === "sameTab"){
document.location = this.href;
return true;
}
}
return false;
}
$(".thumb a").live("click", function (e) {
if(decideAction.call(this,e.button)){
e.preventDefault();
return false;
}
});
$(".thumb a").live("mouseover", function (e) {
decideAction.call(this)
});
$(".thumb a").live("mouseout", function (e) {
if(this.timeout){
clearTimeout(this.timeout);
this.timeout = null;
this.stopWatch();
this.stopWatch = null;
}
});
$(document).mousemove(function(e){
mousex = e.pageX;
mousey = e.pageY;
$(".timer").css({
left: mousex-20,
top: mousey-15
});
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment