NeoGAF : Image Scaling Lite

Fixes the issue with image links (prevents them from opening a new page when clicked) and makes quoted images a bit larger.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, Greasemonkey alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, % alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, % alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey alebo Userscripts.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie, ako napríklad Tampermonkey.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie správcu používateľských skriptov.

(Už mám správcu používateľských skriptov, nechajte ma ho nainštalovať!)

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

(Už mám správcu používateľských štýlov, nechajte ma ho nainštalovať!)

// ==UserScript==
// @id             neogaf-image-scaler-ad3894bc-e561-4ddb-9c7a-c32ddbf93215@hr
// @name           NeoGAF : Image Scaling Lite
// @version        6.0.1
// @namespace      hateradio)))
// @author         hateradio
// @description    Fixes the issue with image links (prevents them from opening a new page when clicked) and makes quoted images a bit larger.
// @icon           data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA2ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDpCQjgyQUQ5M0VFNENFMjExOUIzN0RGOTZFQzU2Qjc1MSIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDoyNkQ4NzkyMzRENUYxMUUyODJENzg2RDYzOEJCMDczOSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDoyNkQ4NzkyMjRENUYxMUUyODJENzg2RDYzOEJCMDczOSIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKSI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOkEyM0U0RTlGNTY0REUyMTE4NDg2RURCOTA3Q0QxMzZCIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkJCODJBRDkzRUU0Q0UyMTE5QjM3REY5NkVDNTZCNzUxIi8+IDwvcmRmOkRlc2NyaXB0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

// @include        http*://*neogaf.com/forum/showthread.php*
// @include        http*://*neogaf.com/forum/showpost.php*

// @match          *://*.neogaf.com/forum/showthread.php*
// @match          *://*.neogaf.com/forum/showpost.php*

// @homepage       https://greasyfork.org/scripts/1025-neogaf-image-scaling-lite

// @updated        16 Jul 2014
// @since          28 Feb 2010
// @grant          GM_Log

// @run-at document-end
// ==/UserScript==

(function () {
	'use strict';

	(function () {
		function windowRun(cb) {
			var script = document.createElement('script');
			script.type = 'application/javascript';
			script.textContent = '(' + cb + ')();';
			document.body.appendChild(script);
			document.body.removeChild(script);
		}

		windowRun(function () {
			var load = window.onload || function () {};
			window.onload = null;

			// console.log('loading old window.onload');
			load();
			// window.YAHOO.util.Event.onDOMReady(load);
		});
	}());

	var pix = {
		width: 720, // px
		height: 560,
		loop: null,
		init: function () {
			this.fn.screen();
			this.fn.css('img[data-gmscale] { cursor: pointer; box-shadow:0px 0px 3px rgba(0, 0, 0, 0.52) } img[data-gmscale].full-image { box-shadow: 0 0 2px rgba(0, 0, 0, 0.3); margin-right: 16px } img[data-gmscale]:hover { box-shadow:0px 0px 4px rgba(0, 0, 0, 0.3) } .post img:not([class*="full-image"]):not(.inlineimg) { max-width:' + this.width + 'px !important; max-height: ' + this.height + 'px !important } .gm_scale_link { position: relative; display:table; display:compact; padding-bottom: 3px; } .quote .gm_scale_link {display:inline-block} .gm_scale_link:after { content:"External Link"; border: 1px solid #EAEAEA; bottom: 13px; left: 10px; position: absolute; background:white; padding: 1px 5px; color: #333; z-index:2; opacity: .9 } a.gm_scale_link:hover:after {opacity:.6}');

			this.fn.shrink();
			this.loop = window.setInterval(this.fn.shrink, 1500);

			// window.addEventListener('load', function () {
				// // pix.fn.procA();
				// // console.log("Clearing", pix.loop);
				// window.clearInterval(pix.loop);
				// // console.log(pix.loop);
			// }, false);
		},
		evt: {
			capture: function (e) {
				console.log(e);
				if (e.target.tagName !== 'A') {
					e.preventDefault();
				}
			}
		},
		fn: {
			invalid: function (img) {
				return img && img.nodeType && !img.hasAttribute('data-gmscale')
					&& (img.naturalWidth > pix.width || img.naturalHeight > pix.height);
			},
			screen: function () {
				pix.width = Math.round(document.querySelector('.post').getBoundingClientRect().width * 0.9);
				pix.height = Math.round(window.innerHeight * 0.85);
			},
			select: function (selector, cb) {
				var s = document.querySelectorAll(selector), i = s.length;
				while (i--) {
					if (cb(s[i], i, s) === false) {
						break;
					}
				}
			},
			parent: function (el, search) {
				if (el.tagName.toLowerCase() === search.toLowerCase()) {
					return el;
				}
				if (el.parentElement) {
					return this.parent(el.parentElement, search);
				}
				return false;
			},
			shrink: function () {
				// console.log('shrink');
				// console.log(document.querySelectorAll('.post img[data-gms]').length, document.querySelectorAll('.post img').length);
				// if (document.querySelectorAll('.post img[data-gms]').length === document.querySelectorAll('.post img').length) {
					// // console.log('clear shrink');
					// window.clearInterval(pix.loop);
				// }
				pix.fn.select('.post a[href] img', pix.fn.procA);
				pix.fn.select('.post img', pix.fn.procImg);
			},
			procA: function (img) {
				if (pix.fn.invalid(img)) {
					var a = pix.fn.parent(img.parentElement, 'a'); // a = img.parentElement;
					if (a && !a.hasAttribute('data-gmscale')) { // a.tagName === 'A'
						a.setAttribute('data-gmscale', true);
						a.className += ' gm_scale_link';
						a.title = 'Click to open';
						a.addEventListener('click', pix.evt.capture, true);
						img.title = '[Middle click to open new page.] ';
					}
					pix.fn.procImg(img, true);
				}
			},
			procImg: function (img, force) {
				img.setAttribute('data-gms', 0);
				if (force === true || pix.fn.invalid(img)) {
					img.title = 'Image: ' + (img.naturalWidth) + 'x' + (img.naturalHeight) + ' ' + img.title;
					img.setAttribute('data-gmscale', true);
				}
			},
			css: function (css) {
				var e = document.createElement('style');
				e.textContent = css;
				document.body.appendChild(e);
			}
		}
	};

	pix.init();

}());