1
0
mirror of https://github.com/vichan-devel/vichan.git synced 2024-11-30 18:24:29 +01:00
vichan/templates/themes/ukko/ukko.js

117 lines
3.6 KiB
JavaScript
Raw Normal View History

2013-08-02 09:16:34 +02:00
(function(){
2013-01-02 18:40:30 +01:00
var cache = new Array(),
thread = false,
loading = false,
ukkotimer = false;
2013-12-24 16:29:14 +01:00
if (localStorage.hiddenboards === undefined) {
2013-08-02 10:20:57 +02:00
localStorage.hiddenboards = "{}";
}
// Load data from HTML5 localStorage
var hiddenboards = JSON.parse(localStorage.hiddenboards);
var storeboards = function() {
localStorage.hiddenboards = JSON.stringify(hiddenboards);
};
2013-01-02 18:40:30 +01:00
$(document).ready(function() {
2013-08-02 10:20:57 +02:00
var addukkohide = function() {
var ukkohide = $('<a href="javascript:void(0);" class="unimportant ukkohide"></a>');
var board = $(this).next().data("board");
var hr = $("<hr />");
$(this).append(ukkohide);
$(this).append(hr);
if (hiddenboards[board] !== true) {
ukkohide.html(_("(hide threads from this board)"));
hr.hide();
}
else {
ukkohide.html(_("(show threads from this board)"));
$(this).next().hide();
}
ukkohide.click(function() {
hiddenboards[board] = (hiddenboards[board] !== true);
if (hiddenboards[board] !== true) {
2013-08-02 10:36:08 +02:00
$('[data-board="'+board+'"]:not([data-cached="yes"])').show().prev().
2013-08-02 10:20:57 +02:00
find('.ukkohide').html(_("(hide threads from this board)")).
parent().find('hr').hide();
}
else {
2013-08-02 10:36:08 +02:00
$('[data-board="'+board+'"]:not([data-cached="yes"])').hide().prev().
2013-08-02 10:20:57 +02:00
find('.ukkohide').html(_("(show threads from this board)"))
.parent().find('hr').show();
}
storeboards();
return false;
});
};
$("h2").each(addukkohide);
2013-08-02 09:16:34 +02:00
$('.pages').hide();
var loadnext = function() {
2013-08-02 09:16:34 +02:00
if (overflow.length == 0) {
$('.pages').show().html(_("No more threads to display"));
}
while($(window).scrollTop() + $(window).height() + 1000 > $(document).height() && !loading && overflow.length > 0) {
2014-04-30 17:24:11 +02:00
var page = modRoot + overflow[0].board + '/' + overflow[0].page;
2013-08-02 09:16:34 +02:00
thread = $('div#thread_' + overflow[0].id + '[data-board="' + overflow[0].board + '"]');
2013-08-02 10:36:08 +02:00
if (thread.length > 0 && thread.attr("data-cached") !== 'yes') { // already present
2013-08-02 09:16:34 +02:00
overflow.shift();
continue;
}
2013-08-02 10:20:57 +02:00
var boardheader = $('<h2><a href="/' + overflow[0].board + '/">/' + overflow[0].board + '/</a> </h2>');
if($.inArray(page, cache) != -1) {
if (thread.length > 0) {
$('div[id*="thread_"]').last().after(thread.attr('data-board', overflow[0].board).attr("data-cached", "no").css('display', 'block'));
boardheader.insertBefore(thread);
addukkohide.call(boardheader);
$(document).trigger('new_post', thread);
}
2013-08-02 09:16:34 +02:00
overflow.shift();
2013-01-02 18:40:30 +01:00
} else {
loading = true;
2013-08-02 09:16:34 +02:00
$('.pages').show().html(_("Loading..."));
2013-01-02 18:40:30 +01:00
$.get(page, function(data) {
cache.push(page);
$(data).find('div[id*="thread_"]').each(function() {
var checkout = $(this).attr('id').replace('thread_', '');
if ($('div#thread_' + checkout + '[data-board="' + overflow[0].board + '"]').length == 0) {
$('form[name="postcontrols"]').prepend($(this).css('display', 'none').attr("data-cached", "yes").attr('data-board', overflow[0].board));
}
2013-01-02 18:40:30 +01:00
});
2013-08-04 04:17:25 +02:00
thread = $('div#thread_' + overflow[0].id + '[data-board="' + overflow[0].board + '"][data-cached="yes"]');
2013-08-04 03:59:05 +02:00
2013-08-04 04:17:25 +02:00
if(thread.length > 0) {
2013-08-02 10:36:08 +02:00
$('div[id*="thread_"]').last().after(thread.attr('data-board', overflow[0].board).attr("data-cached", "no").css('display', 'block'));
2013-08-02 10:20:57 +02:00
boardheader.insertBefore(thread);
addukkohide.call(boardheader);
2013-07-27 06:57:12 +02:00
$(document).trigger('new_post', thread);
2013-08-02 09:16:34 +02:00
}
overflow.shift();
2013-01-02 18:40:30 +01:00
loading = false;
2013-08-02 09:16:34 +02:00
$('.pages').hide().html("");
2013-01-02 18:40:30 +01:00
});
2013-08-02 09:16:34 +02:00
break;
2013-01-02 18:40:30 +01:00
}
}
clearTimeout(ukkotimer);
ukkotimer = setTimeout(loadnext, 1000);
};
$(window).on('scroll', loadnext);
ukkotimer = setTimeout(loadnext, 1000);
});
2013-08-02 09:16:34 +02:00
})();