Refactor the Recursive stuff, recursively un-hide resplies.

This commit is contained in:
Nicolas Stepien 2013-03-05 21:08:05 +01:00
parent 873d3540a9
commit cc842807c8
3 changed files with 140 additions and 53 deletions

View File

@ -20,7 +20,7 @@
// @icon  // @icon 
// ==/UserScript== // ==/UserScript==
/* 4chan X Beta - Version 3.0.0 - 2013-03-03 /* 4chan X Beta - Version 3.0.0 - 2013-03-05
* http://mayhemydg.github.com/4chan-x/ * http://mayhemydg.github.com/4chan-x/
* *
* Copyright (c) 2009-2011 James Campos <james.r.campos@gmail.com> * Copyright (c) 2009-2011 James Campos <james.r.campos@gmail.com>
@ -43,7 +43,7 @@
*/ */
(function() { (function() {
var $, $$, Anonymize, ArchiveLink, AutoGIF, Board, Build, Clone, Conf, Config, CustomCSS, DeleteLink, DownloadLink, ExpandComment, ExpandThread, Favicon, FileInfo, Filter, Fourchan, Get, Header, ImageExpand, ImageHover, Keybinds, Main, Menu, Misc, Nav, Notification, Polyfill, Post, QR, QuoteBacklink, QuoteCT, QuoteInline, QuoteOP, QuotePreview, QuoteYou, Quotify, Recursive, Redirect, RelativeDates, ReplyHiding, Report, ReportLink, RevealSpoilers, Sauce, Settings, Thread, ThreadExcerpt, ThreadHiding, ThreadStats, ThreadUpdater, ThreadWatcher, Time, UI, Unread, d, doc, g, var $, $$, Anonymize, ArchiveLink, AutoGIF, Board, Build, Clone, Conf, Config, CustomCSS, DeleteLink, DownloadLink, ExpandComment, ExpandThread, Favicon, FileInfo, Filter, Fourchan, Get, Header, ImageExpand, ImageHover, Keybinds, Main, Menu, Misc, Nav, Notification, Polyfill, Post, QR, QuoteBacklink, QuoteCT, QuoteInline, QuoteOP, QuotePreview, QuoteStrikeThrough, QuoteYou, Quotify, Recursive, Redirect, RelativeDates, ReplyHiding, Report, ReportLink, RevealSpoilers, Sauce, Settings, Thread, ThreadExcerpt, ThreadHiding, ThreadStats, ThreadUpdater, ThreadWatcher, Time, UI, Unread, d, doc, g,
__slice = [].slice, __slice = [].slice,
__indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }, __indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; },
__hasProp = {}.hasOwnProperty, __hasProp = {}.hasOwnProperty,
@ -2149,7 +2149,8 @@
if (data.thisPost) { if (data.thisPost) {
ReplyHiding.hide(this, data.makeStub, data.hideRecursively); ReplyHiding.hide(this, data.makeStub, data.hideRecursively);
} else { } else {
Recursive.hide(this, data.makeStub); Recursive.apply(ReplyHiding.hide, this, data.makeStub, true);
Recursive.add(ReplyHiding.hide, this, data.makeStub, true);
} }
} }
} }
@ -2185,7 +2186,7 @@
}); });
$.on(apply, 'click', ReplyHiding.menu.hide); $.on(apply, 'click', ReplyHiding.menu.hide);
thisPost = $.el('label', { thisPost = $.el('label', {
innerHTML: '<input type=checkbox name=thisPost checked=true> This post' innerHTML: '<input type=checkbox name=thisPost checked> This post'
}); });
replies = $.el('label', { replies = $.el('label', {
innerHTML: "<input type=checkbox name=replies checked=" + Conf['Recursive Hiding'] + "> Hide replies" innerHTML: "<input type=checkbox name=replies checked=" + Conf['Recursive Hiding'] + "> Hide replies"
@ -2227,7 +2228,8 @@
if (thisPost) { if (thisPost) {
ReplyHiding.hide(post, makeStub, replies); ReplyHiding.hide(post, makeStub, replies);
} else if (replies) { } else if (replies) {
Recursive.hide(post, makeStub); Recursive.apply(ReplyHiding.hide, post, makeStub, true);
Recursive.add(ReplyHiding.hide, post, makeStub, true);
} else { } else {
return; return;
} }
@ -2289,7 +2291,8 @@
} }
post.isHidden = true; post.isHidden = true;
if (hideRecursively) { if (hideRecursively) {
Recursive.hide(post, makeStub, true); Recursive.apply(ReplyHiding.hide, post, makeStub, true);
Recursive.add(ReplyHiding.hide, post, makeStub, true);
} }
_ref = Get.allQuotelinksLinkingTo(post); _ref = Get.allQuotelinksLinkingTo(post);
for (_i = 0, _len = _ref.length; _i < _len; _i++) { for (_i = 0, _len = _ref.length; _i < _len; _i++) {
@ -2312,8 +2315,11 @@
} }
return $.prepend(post.nodes.root, post.nodes.stub); return $.prepend(post.nodes.root, post.nodes.stub);
}, },
show: function(post) { show: function(post, showRecursively) {
var quotelink, _i, _len, _ref; var quotelink, _i, _len, _ref;
if (showRecursively == null) {
showRecursively = Conf['Recursive Hiding'];
}
if (post.nodes.stub) { if (post.nodes.stub) {
$.rm(post.nodes.stub); $.rm(post.nodes.stub);
delete post.nodes.stub; delete post.nodes.stub;
@ -2321,6 +2327,10 @@
post.nodes.root.hidden = false; post.nodes.root.hidden = false;
} }
post.isHidden = false; post.isHidden = false;
if (showRecursively) {
Recursive.apply(ReplyHiding.show, post, true);
Recursive.rm(ReplyHiding.hide, post);
}
_ref = Get.allQuotelinksLinkingTo(post); _ref = Get.allQuotelinksLinkingTo(post);
for (_i = 0, _len = _ref.length; _i < _len; _i++) { for (_i = 0, _len = _ref.length; _i < _len; _i++) {
quotelink = _ref[_i]; quotelink = _ref[_i];
@ -2330,51 +2340,94 @@
}; };
Recursive = { Recursive = {
toHide: [], recursives: {},
init: function() { init: function() {
if (g.VIEW === 'catalog') {
return;
}
$.unsafeWindow.Recursive = this;
$.unsafeWindow.ReplyHiding = ReplyHiding;
return Post.prototype.callbacks.push({ return Post.prototype.callbacks.push({
name: 'Recursive', name: 'Recursive',
cb: this.node cb: this.node
}); });
}, },
node: function() { node: function() {
var board, postID, quote, quotelink, _i, _j, _len, _len1, _ref, _ref1, _ref2, _ref3; var i, obj, quote, recursive, _i, _j, _len, _len1, _ref, _ref1;
if (this.isClone) { if (this.isClone) {
return; return;
} }
_ref = this.quotes; _ref = this.quotes;
for (_i = 0, _len = _ref.length; _i < _len; _i++) { for (_i = 0, _len = _ref.length; _i < _len; _i++) {
quote = _ref[_i]; quote = _ref[_i];
if (__indexOf.call(Recursive.toHide, quote) >= 0) { if (obj = Recursive.recursives[quote]) {
ReplyHiding.hide(this, !!g.posts[quote].nodes.stub, true); _ref1 = obj.recursives;
} for (i = _j = 0, _len1 = _ref1.length; _j < _len1; i = ++_j) {
} recursive = _ref1[i];
_ref1 = this.nodes.quotelinks; recursive.apply(null, [this].concat(__slice.call(obj.args[i])));
for (_j = 0, _len1 = _ref1.length; _j < _len1; _j++) { }
quotelink = _ref1[_j];
_ref2 = Get.postDataFromLink(quotelink), board = _ref2.board, postID = _ref2.postID;
if ((_ref3 = g.posts["" + board + "." + postID]) != null ? _ref3.isHidden : void 0) {
$.addClass(quotelink, 'filtered');
} }
} }
}, },
hide: function(post, makeStub) { add: function() {
var ID, fullID, quote, _i, _len, _ref, _ref1; var args, obj, post, recursive, _base, _name;
recursive = arguments[0], post = arguments[1], args = 3 <= arguments.length ? __slice.call(arguments, 2) : [];
obj = (_base = Recursive.recursives)[_name = post.fullID] || (_base[_name] = {
recursives: [],
args: []
});
obj.recursives.push(recursive);
return obj.args.push(args);
},
rm: function(recursive, post) {
var i, obj, rec, _i, _len, _ref;
if (!(obj = Recursive.recursives[post.fullID])) {
return;
}
_ref = obj.recursives;
for (i = _i = 0, _len = _ref.length; _i < _len; i = ++_i) {
rec = _ref[i];
if (rec === recursive) {
obj.recursives.splice(i, 1);
obj.args.splice(i, 1);
}
}
},
apply: function() {
var ID, args, fullID, post, recursive, _ref;
recursive = arguments[0], post = arguments[1], args = 3 <= arguments.length ? __slice.call(arguments, 2) : [];
fullID = post.fullID; fullID = post.fullID;
Recursive.toHide.push(fullID);
_ref = g.posts; _ref = g.posts;
for (ID in _ref) { for (ID in _ref) {
post = _ref[ID]; post = _ref[ID];
if (!post.isReply) { if (__indexOf.call(post.quotes, fullID) >= 0) {
continue; recursive.apply(null, [post].concat(__slice.call(args)));
} }
_ref1 = post.quotes; }
for (_i = 0, _len = _ref1.length; _i < _len; _i++) { }
quote = _ref1[_i]; };
if (quote === fullID) {
ReplyHiding.hide(post, makeStub, true); QuoteStrikeThrough = {
break; init: function() {
} if (g.VIEW === 'catalog' || !Conf['Reply Hiding'] && !Conf['Filter']) {
return;
}
return Post.prototype.callbacks.push({
name: 'Strike-through Quotes',
cb: this.node
});
},
node: function() {
var board, postID, quotelink, _i, _len, _ref, _ref1, _ref2;
if (this.isClone) {
return;
}
_ref = this.nodes.quotelinks;
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
quotelink = _ref[_i];
_ref1 = Get.postDataFromLink(quotelink), board = _ref1.board, postID = _ref1.postID;
if ((_ref2 = g.posts["" + board + "." + postID]) != null ? _ref2.isHidden : void 0) {
$.addClass(quotelink, 'filtered');
} }
} }
} }
@ -7279,6 +7332,7 @@
initFeature('Thread Hiding', ThreadHiding); initFeature('Thread Hiding', ThreadHiding);
initFeature('Reply Hiding', ReplyHiding); initFeature('Reply Hiding', ReplyHiding);
initFeature('Recursive', Recursive); initFeature('Recursive', Recursive);
initFeature('Strike-through Quotes', QuoteStrikeThrough);
initFeature('Quick Reply', QR); initFeature('Quick Reply', QR);
initFeature('Menu', Menu); initFeature('Menu', Menu);
initFeature('Report Link', ReportLink); initFeature('Report Link', ReportLink);

View File

@ -1060,7 +1060,8 @@ ReplyHiding =
if data.thisPost if data.thisPost
ReplyHiding.hide @, data.makeStub, data.hideRecursively ReplyHiding.hide @, data.makeStub, data.hideRecursively
else else
Recursive.hide @, data.makeStub Recursive.apply ReplyHiding.hide, @, data.makeStub, true
Recursive.add ReplyHiding.hide, @, data.makeStub, true
return unless Conf['Hiding Buttons'] return unless Conf['Hiding Buttons']
$.replace $('.sideArrows', @nodes.root), ReplyHiding.makeButton @, 'hide' $.replace $('.sideArrows', @nodes.root), ReplyHiding.makeButton @, 'hide'
@ -1085,7 +1086,7 @@ ReplyHiding =
$.on apply, 'click', ReplyHiding.menu.hide $.on apply, 'click', ReplyHiding.menu.hide
thisPost = $.el 'label', thisPost = $.el 'label',
innerHTML: '<input type=checkbox name=thisPost checked=true> This post' innerHTML: '<input type=checkbox name=thisPost checked> This post'
replies = $.el 'label', replies = $.el 'label',
innerHTML: "<input type=checkbox name=replies checked=#{Conf['Recursive Hiding']}> Hide replies" innerHTML: "<input type=checkbox name=replies checked=#{Conf['Recursive Hiding']}> Hide replies"
makeStub = $.el 'label', makeStub = $.el 'label',
@ -1110,7 +1111,8 @@ ReplyHiding =
if thisPost if thisPost
ReplyHiding.hide post, makeStub, replies ReplyHiding.hide post, makeStub, replies
else if replies else if replies
Recursive.hide post, makeStub Recursive.apply ReplyHiding.hide, post, makeStub, true
Recursive.add ReplyHiding.hide, post, makeStub, true
else else
return return
ReplyHiding.saveHiddenState post, true, thisPost, makeStub, replies ReplyHiding.saveHiddenState post, true, thisPost, makeStub, replies
@ -1153,7 +1155,9 @@ ReplyHiding =
return if post.isHidden return if post.isHidden
post.isHidden = true post.isHidden = true
Recursive.hide post, makeStub, true if hideRecursively if hideRecursively
Recursive.apply ReplyHiding.hide, post, makeStub, true
Recursive.add ReplyHiding.hide, post, makeStub, true
for quotelink in Get.allQuotelinksLinkingTo post for quotelink in Get.allQuotelinksLinkingTo post
$.addClass quotelink, 'filtered' $.addClass quotelink, 'filtered'
@ -1176,49 +1180,77 @@ ReplyHiding =
$.add post.nodes.stub, [$.tn(' '), Menu.makeButton post] $.add post.nodes.stub, [$.tn(' '), Menu.makeButton post]
$.prepend post.nodes.root, post.nodes.stub $.prepend post.nodes.root, post.nodes.stub
show: (post) -> show: (post, showRecursively=Conf['Recursive Hiding']) ->
if post.nodes.stub if post.nodes.stub
$.rm post.nodes.stub $.rm post.nodes.stub
delete post.nodes.stub delete post.nodes.stub
else else
post.nodes.root.hidden = false post.nodes.root.hidden = false
post.isHidden = false post.isHidden = false
if showRecursively
Recursive.apply ReplyHiding.show, post, true
Recursive.rm ReplyHiding.hide, post
for quotelink in Get.allQuotelinksLinkingTo post for quotelink in Get.allQuotelinksLinkingTo post
$.rmClass quotelink, 'filtered' $.rmClass quotelink, 'filtered'
return return
Recursive = Recursive =
toHide: [] recursives: {}
init: -> init: ->
return if g.VIEW is 'catalog'
$.unsafeWindow.Recursive = @
$.unsafeWindow.ReplyHiding = ReplyHiding
Post::callbacks.push Post::callbacks.push
name: 'Recursive' name: 'Recursive'
cb: @node cb: @node
node: -> node: ->
return if @isClone return if @isClone
# In fetched posts:
# - Strike-through quotelinks
# - Hide recursively
for quote in @quotes for quote in @quotes
if quote in Recursive.toHide if obj = Recursive.recursives[quote]
ReplyHiding.hide @, !!g.posts[quote].nodes.stub, true for recursive, i in obj.recursives
recursive @, obj.args[i]...
return
add: (recursive, post, args...) ->
obj = Recursive.recursives[post.fullID] or=
recursives: []
args: []
obj.recursives.push recursive
obj.args.push args
rm: (recursive, post) ->
return unless obj = Recursive.recursives[post.fullID]
for rec, i in obj.recursives
if rec is recursive
obj.recursives.splice i, 1
obj.args.splice i, 1
return
apply: (recursive, post, args...) ->
{fullID} = post
for ID, post of g.posts
if fullID in post.quotes
recursive post, args...
return
QuoteStrikeThrough =
init: ->
return if g.VIEW is 'catalog' or !Conf['Reply Hiding'] and !Conf['Filter']
Post::callbacks.push
name: 'Strike-through Quotes'
cb: @node
node: ->
return if @isClone
for quotelink in @nodes.quotelinks for quotelink in @nodes.quotelinks
{board, postID} = Get.postDataFromLink quotelink {board, postID} = Get.postDataFromLink quotelink
if g.posts["#{board}.#{postID}"]?.isHidden if g.posts["#{board}.#{postID}"]?.isHidden
$.addClass quotelink, 'filtered' $.addClass quotelink, 'filtered'
return return
hide: (post, makeStub) ->
{fullID} = post
Recursive.toHide.push fullID
for ID, post of g.posts
continue if !post.isReply
for quote in post.quotes
if quote is fullID
ReplyHiding.hide post, makeStub, true
break
return
Menu = Menu =
init: -> init: ->
return if g.VIEW is 'catalog' or !Conf['Menu'] return if g.VIEW is 'catalog' or !Conf['Menu']

View File

@ -321,6 +321,7 @@ Main =
initFeature 'Thread Hiding', ThreadHiding initFeature 'Thread Hiding', ThreadHiding
initFeature 'Reply Hiding', ReplyHiding initFeature 'Reply Hiding', ReplyHiding
initFeature 'Recursive', Recursive initFeature 'Recursive', Recursive
initFeature 'Strike-through Quotes', QuoteStrikeThrough
initFeature 'Quick Reply', QR initFeature 'Quick Reply', QR
initFeature 'Menu', Menu initFeature 'Menu', Menu
initFeature 'Report Link', ReportLink initFeature 'Report Link', ReportLink