ukko: implement ukko hide
This commit is contained in:
parent
6f6a20af8e
commit
73b5cf5a08
@ -3,7 +3,54 @@
|
|||||||
var cache = new Array(),
|
var cache = new Array(),
|
||||||
thread = false,
|
thread = false,
|
||||||
loading = false;
|
loading = false;
|
||||||
|
|
||||||
|
if (localStorage.hiddenboards !== null) {
|
||||||
|
localStorage.hiddenboards = "{}";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Load data from HTML5 localStorage
|
||||||
|
var hiddenboards = JSON.parse(localStorage.hiddenboards);
|
||||||
|
|
||||||
|
var storeboards = function() {
|
||||||
|
localStorage.hiddenboards = JSON.stringify(hiddenboards);
|
||||||
|
};
|
||||||
|
|
||||||
$(document).ready(function() {
|
$(document).ready(function() {
|
||||||
|
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) {
|
||||||
|
$('[data-board="'+board+'"][data-cached!="yes"]').show().prev().
|
||||||
|
find('.ukkohide').html(_("(hide threads from this board)")).
|
||||||
|
parent().find('hr').hide();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$('[data-board="'+board+'"][data-cached!="yes"]').hide().prev().
|
||||||
|
find('.ukkohide').html(_("(show threads from this board)"))
|
||||||
|
.parent().find('hr').show();
|
||||||
|
}
|
||||||
|
storeboards();
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
};
|
||||||
|
$("h2").each(addukkohide);
|
||||||
|
|
||||||
$('.pages').hide();
|
$('.pages').hide();
|
||||||
$(window).on('scroll', function() {
|
$(window).on('scroll', function() {
|
||||||
if (overflow.length == 0) {
|
if (overflow.length == 0) {
|
||||||
@ -12,14 +59,17 @@ $(document).ready(function() {
|
|||||||
while($(window).scrollTop() + $(window).height() + 500 > $(document).height() && !loading && overflow.length > 0) {
|
while($(window).scrollTop() + $(window).height() + 500 > $(document).height() && !loading && overflow.length > 0) {
|
||||||
var page = '../' + overflow[0].board + '/' + overflow[0].page;
|
var page = '../' + overflow[0].board + '/' + overflow[0].page;
|
||||||
thread = $('div#thread_' + overflow[0].id + '[data-board="' + overflow[0].board + '"]');
|
thread = $('div#thread_' + overflow[0].id + '[data-board="' + overflow[0].board + '"]');
|
||||||
if (thread.length > 0 && thread.css('display') != 'none') { // already present
|
if (thread.length > 0 && thread.data("cached") !== 'yes') { // already present
|
||||||
overflow.shift();
|
overflow.shift();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var boardheader = $('<h2><a href="/' + overflow[0].board + '/">/' + overflow[0].board + '/</a> </h2>');
|
||||||
|
|
||||||
if($.inArray(page, cache) != -1 && thread.length > 0) {
|
if($.inArray(page, cache) != -1 && thread.length > 0) {
|
||||||
thread.prepend('<h2><a href="/' + overflow[0].board + '/">/' + overflow[0].board + '/</a></h2>');
|
$('div[id*="thread_"]').last().after(thread.attr('data-board', overflow[0].board).data("cached", "no").css('display', 'block'));
|
||||||
$('div[id*="thread_"]').last().after(thread.attr('data-board', overflow[0].board).css('display', 'block'));
|
boardheader.insertBefore(thread);
|
||||||
|
addukkohide.call(boardheader);
|
||||||
$(document).trigger('new_post', thread);
|
$(document).trigger('new_post', thread);
|
||||||
overflow.shift();
|
overflow.shift();
|
||||||
} else {
|
} else {
|
||||||
@ -29,13 +79,14 @@ $(document).ready(function() {
|
|||||||
cache.push(page);
|
cache.push(page);
|
||||||
|
|
||||||
$(data).find('div[id*="thread_"]').each(function() {
|
$(data).find('div[id*="thread_"]').each(function() {
|
||||||
$('form[name="postcontrols"]').prepend($(this).css('display', 'none').attr('data-board', overflow[0].board));
|
$('form[name="postcontrols"]').prepend($(this).css('display', 'none').data("cached", "yes").attr('data-board', overflow[0].board));
|
||||||
});
|
});
|
||||||
|
|
||||||
thread = $('div#thread_' + overflow[0].id + '[data-board="' + overflow[0].board + '"]');
|
thread = $('div#thread_' + overflow[0].id + '[data-board="' + overflow[0].board + '"]');
|
||||||
if(thread.length > 0 && thread.css('display') != 'none') {
|
if(thread.length > 0 && thread.data('cached') !== 'no') {
|
||||||
thread.prepend('<h2><a href="/' + overflow[0].board + '/">/' + overflow[0].board + '/</a></h2>');
|
$('div[id*="thread_"]').last().after(thread.attr('data-board', overflow[0].board).data("cached", "no").css('display', 'block'));
|
||||||
$('div[id*="thread_"]').last().after(thread.attr('data-board', overflow[0].board).css('display', 'block'));
|
boardheader.insertBefore(thread);
|
||||||
|
addukkohide.call(boardheader);
|
||||||
$(document).trigger('new_post', thread);
|
$(document).trigger('new_post', thread);
|
||||||
overflow.shift();
|
overflow.shift();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user