1
0
mirror of https://github.com/vichan-devel/vichan.git synced 2025-01-18 17:14:04 +01:00

js/inline-expanding.js: Allow to work with auto-reload.js, etc. (jQuery is still optional)

Conflicts:
	js/inline-expanding.js
This commit is contained in:
czaks 2013-07-27 02:19:58 -04:00 committed by Michael Foster
parent 1759ac2ea3
commit 54714595f7

View File

@ -6,49 +6,62 @@
* Copyright (c) 2012-2013 Michael Save <savetheinternet@tinyboard.org> * Copyright (c) 2012-2013 Michael Save <savetheinternet@tinyboard.org>
* *
* Usage: * Usage:
* // $config['additional_javascript'][] = 'js/jquery.min.js';
* $config['additional_javascript'][] = 'js/inline-expanding.js'; * $config['additional_javascript'][] = 'js/inline-expanding.js';
* *
*/ */
onready(function(){ onready(function(){
var link = document.getElementsByTagName('a'); var inline_expand_post = function() {
var link = this.getElementsByTagName('a');
for (var i = 0; i < link.length; i++) { for (var i = 0; i < link.length; i++) {
if (typeof link[i] == "object" && link[i].childNodes && link[i].childNodes[0].src && link[i].className != 'file') { if (typeof link[i] == "object" && link[i].childNodes && typeof link[i].childNodes[0] !== 'undefined' && link[i].childNodes[0].src && link[i].className != 'file') {
link[i].childNodes[0].style.maxWidth = '95%'; link[i].childNodes[0].style.maxWidth = '95%';
link[i].childNodes[0].style.maxHeight = '95%'; link[i].onclick = function(e) {
link[i].onclick = function(e) { if (this.childNodes[0].className == 'hidden')
if (this.childNodes[0].className == 'hidden') return false;
return false; if (e.which == 2)
if (e.which == 2) return true;
return true; if (!this.dataset.src) {
if (!this.dataset.src) { this.dataset.expanded = 'true';
this.dataset.expanded = 'true'; this.dataset.src= this.childNodes[0].src;
this.dataset.src= this.childNodes[0].src; this.dataset.width = this.childNodes[0].style.width;
this.dataset.width = this.childNodes[0].style.width; this.dataset.height = this.childNodes[0].style.height;
this.dataset.height = this.childNodes[0].style.height; this.childNodes[0].src = this.href;
this.childNodes[0].src = this.href; this.childNodes[0].style.width = 'auto';
this.childNodes[0].style.width = 'auto'; this.childNodes[0].style.height = 'auto';
this.childNodes[0].style.height = 'auto'; this.childNodes[0].style.opacity = '0.4';
this.childNodes[0].style.opacity = '0.4'; this.childNodes[0].style.filter = 'alpha(opacity=40)';
this.childNodes[0].style.filter = 'alpha(opacity=40)'; this.childNodes[0].onload = function() {
this.childNodes[0].onload = function() { this.style.opacity = '';
this.style.opacity = ''; delete this.style.filter;
delete this.style.filter; }
} else {
this.childNodes[0].src = this.dataset.src;
this.childNodes[0].style.width = this.dataset.width;
this.childNodes[0].style.height = this.dataset.height;
delete this.dataset.expanded;
delete this.dataset.src;
delete this.childNodes[0].style.opacity;
delete this.childNodes[0].style.filter;
} }
} else { return false;
this.childNodes[0].src = this.dataset.src;
this.childNodes[0].style.width = this.dataset.width;
this.childNodes[0].style.height = this.dataset.height;
delete this.dataset.expanded;
delete this.dataset.src;
delete this.childNodes[0].style.opacity;
delete this.childNodes[0].style.filter;
} }
return false;
} }
} }
} }
if (window.jQuery) {
$('div[id^="thread_"]').each(inline_expand_post);
// allow to work with auto-reload.js, etc.
$(document).bind('new_post', function(e, post) {
inline_expand_post.call(post);
});
} else {
inline_expand_post.call(document);
}
}); });