2012-03-31 19:18:53 +11:00
|
|
|
/*
|
|
|
|
* inline-expanding.js
|
|
|
|
* https://github.com/savetheinternet/Tinyboard/blob/master/js/inline-expanding.js
|
|
|
|
*
|
|
|
|
* Released under the MIT license
|
2013-07-27 00:14:43 -04:00
|
|
|
* Copyright (c) 2012-2013 Michael Save <savetheinternet@tinyboard.org>
|
2014-01-19 14:27:24 +01:00
|
|
|
* Copyright (c) 2013-2014 Marcin Łabanowski <marcin@6irc.net>
|
2012-03-31 19:18:53 +11:00
|
|
|
*
|
|
|
|
* Usage:
|
2014-10-28 23:35:58 +08:00
|
|
|
* $config['additional_javascript'][] = 'js/jquery.min.js';
|
2012-03-31 19:18:53 +11:00
|
|
|
* $config['additional_javascript'][] = 'js/inline-expanding.js';
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2012-03-31 19:37:31 +11:00
|
|
|
onready(function(){
|
2013-06-15 01:39:39 -04:00
|
|
|
var inline_expand_post = function() {
|
|
|
|
var link = this.getElementsByTagName('a');
|
2013-06-15 01:39:39 -04:00
|
|
|
|
2013-07-27 01:04:36 -04:00
|
|
|
for (var i = 0; i < link.length; i++) {
|
2013-08-18 16:40:07 +10:00
|
|
|
if (typeof link[i] == "object" && link[i].childNodes && typeof link[i].childNodes[0] !== 'undefined' && link[i].childNodes[0].src && link[i].childNodes[0].className.match(/post-image/) && !link[i].className.match(/file/)) {
|
2013-06-15 01:39:39 -04:00
|
|
|
link[i].onclick = function(e) {
|
2014-11-29 11:01:30 +08:00
|
|
|
var img, post_body, still_open, canvas;
|
2014-10-27 16:57:03 +08:00
|
|
|
var thumb = this.childNodes[0];
|
2014-10-28 23:35:58 +08:00
|
|
|
var padding = 5;
|
|
|
|
var boardlist = $('.boardlist')[0];
|
|
|
|
|
2014-10-27 16:49:17 +08:00
|
|
|
var loadImage = function(img, thumb) {
|
|
|
|
if (img.naturalWidth) {
|
|
|
|
thumb.style.display = 'none';
|
|
|
|
img.style.display = '';
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return thumb.parentNode.timeout = setTimeout(loadImage, 30, img, thumb);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2014-10-27 16:57:03 +08:00
|
|
|
if (thumb.className == 'hidden')
|
2013-07-27 01:04:36 -04:00
|
|
|
return false;
|
2014-10-27 16:49:17 +08:00
|
|
|
if (e.which == 2 || e.ctrlKey) //open in new tab
|
2013-06-15 01:39:39 -04:00
|
|
|
return true;
|
2014-10-27 16:49:17 +08:00
|
|
|
if (!this.dataset.expanded) {
|
2014-04-30 10:21:02 -04:00
|
|
|
this.parentNode.removeAttribute('style');
|
2013-07-27 01:04:36 -04:00
|
|
|
this.dataset.expanded = 'true';
|
2014-06-10 18:00:49 +00:00
|
|
|
|
2014-10-27 16:57:03 +08:00
|
|
|
if (thumb.tagName === 'CANVAS') {
|
2014-11-29 11:01:30 +08:00
|
|
|
canvas = thumb;
|
|
|
|
thumb = thumb.nextSibling;
|
|
|
|
this.removeChild(canvas);
|
|
|
|
canvas.style.display = 'block';
|
2014-06-10 18:00:49 +00:00
|
|
|
}
|
|
|
|
|
2014-10-27 16:57:03 +08:00
|
|
|
thumb.style.opacity = '0.4';
|
|
|
|
thumb.style.filter = 'alpha(opacity=40)';
|
2014-10-27 16:49:17 +08:00
|
|
|
|
|
|
|
img = document.createElement('img');
|
|
|
|
img.className = 'full-image';
|
|
|
|
img.setAttribute('src', this.href);
|
|
|
|
img.setAttribute('alt', 'Fullsized image');
|
|
|
|
img.style.display = 'none';
|
|
|
|
this.appendChild(img);
|
|
|
|
|
2014-10-27 16:57:03 +08:00
|
|
|
this.timeout = loadImage(img, thumb);
|
2013-06-15 01:39:39 -04:00
|
|
|
} else {
|
2014-10-27 16:49:17 +08:00
|
|
|
clearTimeout(this.timeout);
|
2014-10-28 23:35:58 +08:00
|
|
|
|
|
|
|
//scroll to thumb if not triggered by 'shrink all image'
|
|
|
|
if (e.target.className == 'full-image') {
|
|
|
|
post_body = $(e.target).parentsUntil('form > div').last();
|
|
|
|
still_open = post_body.find('.post-image').filter(function(){return $(this).parent().attr('data-expanded') == 'true'}).length;
|
|
|
|
|
|
|
|
//deal with differnt boards' menu styles
|
|
|
|
if ($(boardlist).css('position') == 'fixed')
|
|
|
|
padding += boardlist.getBoundingClientRect().height;
|
|
|
|
|
|
|
|
if (still_open > 1) {
|
|
|
|
if (e.target.getBoundingClientRect().top - padding < 0)
|
2014-12-09 02:04:53 +00:00
|
|
|
$(document).scrollTop($(e.target).parent().parent().offset().top - padding);
|
2014-10-28 23:35:58 +08:00
|
|
|
} else {
|
|
|
|
if (post_body[0].getBoundingClientRect().top - padding < 0)
|
2014-12-09 02:04:53 +00:00
|
|
|
$(document).scrollTop(post_body.offset().top - padding);
|
2014-10-28 23:35:58 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-06-12 17:48:31 +00:00
|
|
|
if (~this.parentNode.className.indexOf('multifile'))
|
|
|
|
this.parentNode.style.width = (parseInt(this.dataset.width)+40)+'px';
|
2014-10-27 16:49:17 +08:00
|
|
|
|
2014-10-27 16:57:03 +08:00
|
|
|
thumb.style.opacity = '';
|
|
|
|
thumb.style.display = '';
|
|
|
|
this.removeChild(thumb.nextSibling);
|
2013-07-27 01:04:36 -04:00
|
|
|
delete this.dataset.expanded;
|
2014-10-27 16:57:03 +08:00
|
|
|
delete thumb.style.filter;
|
2014-06-10 18:00:49 +00:00
|
|
|
|
|
|
|
if (localStorage.no_animated_gif === 'true' && typeof unanimate_gif === 'function') {
|
2014-10-27 16:57:03 +08:00
|
|
|
unanimate_gif(thumb);
|
2014-06-10 18:00:49 +00:00
|
|
|
}
|
2012-03-31 19:18:53 +11:00
|
|
|
}
|
2013-07-27 02:19:58 -04:00
|
|
|
return false;
|
2014-10-27 16:49:17 +08:00
|
|
|
};
|
2012-03-31 19:18:53 +11:00
|
|
|
}
|
|
|
|
}
|
2014-10-27 16:49:17 +08:00
|
|
|
};
|
2013-06-15 01:39:39 -04:00
|
|
|
|
2013-07-27 02:19:58 -04:00
|
|
|
if (window.jQuery) {
|
|
|
|
$('div[id^="thread_"]').each(inline_expand_post);
|
2013-06-15 01:39:39 -04:00
|
|
|
|
2013-07-27 02:19:58 -04:00
|
|
|
// allow to work with auto-reload.js, etc.
|
2014-01-21 19:25:11 +01:00
|
|
|
$(document).on('new_post', function(e, post) {
|
2013-07-27 02:19:58 -04:00
|
|
|
inline_expand_post.call(post);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
inline_expand_post.call(document);
|
|
|
|
}
|
2012-03-31 19:18:53 +11:00
|
|
|
});
|