expand comment rewrite

This commit is contained in:
James Campos 2011-04-16 18:04:05 -07:00
parent 510f83954c
commit ba4fcf2828
2 changed files with 88 additions and 83 deletions

View File

@ -59,7 +59,7 @@
*/
(function() {
var $, $$, NAMESPACE, a, as, autoWatch, callback, changeCheckbox, changeValue, config, d, delform, el, expand, expandComment, expandThread, g, imageClick, imageExpand, imageExpandClick, imageHover, imageResize, imageThumb, imageToggle, imageType, imageTypeChange, keyModeNormal, keybinds, log, nav, navtopr, nodeInserted, onloadComment, option, options, parseResponse, pathname, qr, recaptcha, recaptchaListener, recaptchaReload, redirect, replyHiding, replyNav, report, scroll, scrollThread, temp, text, threadHiding, tzOffset, ui, updateFavicon, updateTitle, updater, watcher, _config, _i, _j, _k, _l, _len, _len2, _len3, _len4, _ref, _ref2, _ref3, _ref4;
var $, $$, NAMESPACE, autoWatch, callback, changeCheckbox, changeValue, config, d, delform, el, expand, expandComment, expandThread, g, imageClick, imageExpand, imageExpandClick, imageHover, imageResize, imageThumb, imageToggle, imageType, imageTypeChange, keyModeNormal, keybinds, log, nav, navtopr, nodeInserted, option, options, parseResponse, pathname, qr, recaptcha, recaptchaListener, recaptchaReload, redirect, replyHiding, replyNav, report, scroll, scrollThread, temp, text, threadHiding, tzOffset, ui, updateFavicon, updateTitle, updater, watcher, _config, _i, _j, _k, _len, _len2, _len3, _ref, _ref2, _ref3, _ref4;
var __slice = Array.prototype.slice;
if (typeof console != "undefined" && console !== null) {
log = console.log;
@ -423,21 +423,49 @@
autoText = $('textarea', this).value.slice(0, 25);
return GM_setValue('autoText', "/" + g.BOARD + "/ - " + autoText);
};
expandComment = function(e) {
var a, href, r;
e.preventDefault();
a = this;
href = a.getAttribute('href');
r = new XMLHttpRequest();
r.onload = function() {
return onloadComment(this.responseText, a, href);
};
r.open('GET', href, true);
r.send();
return g.xhrs.push({
r: r,
id: href.match(/\d+/)[0]
});
expandComment = {
init: function() {
var a, _i, _len, _ref, _results;
_ref = $$('span.abbr a');
_results = [];
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
a = _ref[_i];
_results.push($.bind(a, 'click', expandComment.cb.expand));
}
return _results;
},
cb: {
expand: function(e) {
var a, href, replyID, threadID, _, _ref;
e.preventDefault();
a = e.target;
a.textContent = 'Loading...';
href = a.getAttribute('href');
_ref = href.match(/(\d+)#(\d+)/), _ = _ref[0], threadID = _ref[1], replyID = _ref[2];
return g.cache[threadID] = $.get(href, (function() {
return expandComment.load(this, a, threadID, replyID);
}));
}
},
load: function(xhr, a, threadID, replyID) {
var body, bq, reply, _i, _len, _ref;
body = $.el('body', {
innerHTML: xhr.responseText
});
if (threadID === replyID) {
bq = $('blockqoute', body);
} else {
_ref = $$('td[id]', body);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
reply = _ref[_i];
if (reply.id === replyID) {
bq = $('blockquote', reply);
break;
}
}
}
return $.replace(a.parentNode.parentNode, bq);
}
};
expandThread = {
init: function() {
@ -455,8 +483,6 @@
}
return _results;
},
cache: {},
requests: {},
cb: {
toggle: function(e) {
var thread;
@ -471,7 +497,7 @@
} else {
html = xhr.responseText;
id = thread.firstChild.id;
expandThread.cache[id] = html;
g.cache[id] = html;
return expandThread.expand(html, thread, a);
}
}
@ -483,17 +509,17 @@
switch (a.textContent[0]) {
case '+':
a.textContent = a.textContent.replace('+', 'X Loading...');
if (html = expandThread.cache[id]) {
if (html = g.cache[id]) {
return expandThread.expand(html, thread, a);
} else {
return expandThread.requests[id] = $.get("res/" + id, (function() {
return g.requests[id] = $.get("res/" + id, (function() {
return expandThread.cb.load(this, thread, a);
}));
}
break;
case 'X':
a.textContent = a.textContent.replace('X Loading...', '+');
return expandThread.requests[id].abort();
return g.requests[id].abort();
case '-':
a.textContent = a.textContent.replace('-', '+');
num = g.BOARD === 'b' ? 3 : 5;
@ -1040,23 +1066,6 @@
return $('#recaptcha_challenge_field', dialog).value = target.value;
}
};
onloadComment = function(responseText, a, href) {
var bq, html, id, op, opbq, replies, reply, _, _i, _len, _ref, _ref2;
_ref = href.match(/(\d+)#(\d+)/), _ = _ref[0], op = _ref[1], id = _ref[2];
_ref2 = parseResponse(responseText), replies = _ref2[0], opbq = _ref2[1];
if (id === op) {
html = opbq.innerHTML;
} else {
for (_i = 0, _len = replies.length; _i < _len; _i++) {
reply = replies[_i];
if (reply.id === id) {
html = $('blockquote', reply).innerHTML;
}
}
}
bq = $.x('ancestor::blockquote', a);
return bq.innerHTML = html;
};
changeCheckbox = function() {
return GM_setValue(this.name, this.checked);
};
@ -1826,6 +1835,8 @@
};
NAMESPACE = 'AEOS.4chan_x.';
g = {
cache: {},
requests: {},
callbacks: [],
expand: false,
favDead: '',
@ -2209,16 +2220,12 @@
expandThread.init();
}
if ($.config('Comment Expansion')) {
as = $$('span.abbr a');
for (_k = 0, _len3 = as.length; _k < _len3; _k++) {
a = as[_k];
$.bind(a, 'click', expandComment);
}
expandComment.init();
}
}
_ref4 = g.callbacks;
for (_l = 0, _len4 = _ref4.length; _l < _len4; _l++) {
callback = _ref4[_l];
for (_k = 0, _len3 = _ref4.length; _k < _len3; _k++) {
callback = _ref4[_k];
callback();
}
$.bind(d.body, 'DOMNodeInserted', nodeInserted);

View File

@ -279,19 +279,34 @@ autoWatch = ->
autoText = $('textarea', this).value.slice(0, 25)
GM_setValue('autoText', "/#{g.BOARD}/ - #{autoText}")
expandComment = (e) ->
e.preventDefault()
a = this
href = a.getAttribute('href')
r = new XMLHttpRequest()
r.onload = ->
onloadComment(@responseText, a, href)
r.open('GET', href, true)
r.send()
g.xhrs.push {
r: r,
id: href.match(/\d+/)[0]
}
expandComment =
init: ->
for a in $$ 'span.abbr a'
$.bind a, 'click', expandComment.cb.expand
cb:
expand: (e) ->
e.preventDefault()
a = e.target
a.textContent = 'Loading...'
href = a.getAttribute 'href'
[_, threadID, replyID] = href.match /(\d+)#(\d+)/
g.cache[threadID] = $.get href, (->
expandComment.load this, a, threadID, replyID)
load: (xhr, a, threadID, replyID) ->
body = $.el 'body',
innerHTML: xhr.responseText
if threadID is replyID
bq = $ 'blockqoute', body
else
#css selectors don't like ids starting with numbers,
# getElementById only works for root document.
for reply in $$ 'td[id]', body
if reply.id == replyID
bq = $ 'blockquote', reply
break
$.replace a.parentNode.parentNode, bq
expandThread =
init: ->
@ -302,9 +317,6 @@ expandThread =
$.bind a, 'click', expandThread.cb.toggle
$.replace span, a
cache: {}
requests: {}
cb:
toggle: (e) ->
thread = e.target.parentNode
@ -317,7 +329,7 @@ expandThread =
else
html = xhr.responseText
id = thread.firstChild.id
expandThread.cache[id] = html
g.cache[id] = html
expandThread.expand html, thread, a
toggle: (thread) ->
@ -327,15 +339,15 @@ expandThread =
switch a.textContent[0]
when '+'
a.textContent = a.textContent.replace '+', 'X Loading...'
if html = expandThread.cache[id]
if html = g.cache[id]
expandThread.expand html, thread, a
else
expandThread.requests[id] =
g.requests[id] =
$.get "res/#{id}", (-> expandThread.cb.load this, thread, a)
when 'X'
a.textContent = a.textContent.replace 'X Loading...', '+'
expandThread.requests[id].abort()
g.requests[id].abort()
when '-'
a.textContent = a.textContent.replace '-', '+'
@ -794,20 +806,6 @@ nodeInserted = (e) ->
$('#recaptcha_image img', dialog).src = "http://www.google.com/recaptcha/api/image?c=" + target.value
$('#recaptcha_challenge_field', dialog).value = target.value
onloadComment = (responseText, a, href) ->
[_, op, id] = href.match /(\d+)#(\d+)/
[replies, opbq] = parseResponse responseText
if id is op
html = opbq.innerHTML
else
#css selectors don't like ids starting with numbers,
# getElementById only works for root document.
for reply in replies
if reply.id == id
html = $('blockquote', reply).innerHTML
bq = $.x 'ancestor::blockquote', a
bq.innerHTML = html
changeCheckbox = ->
GM_setValue @name, @checked
@ -1439,6 +1437,8 @@ watcher =
#main
NAMESPACE = 'AEOS.4chan_x.'
g =
cache: {}
requests: {}
callbacks: []
expand: false
favDead: ''
@ -1761,9 +1761,7 @@ else #not reply
expandThread.init()
if $.config 'Comment Expansion'
as = $$('span.abbr a')
for a in as
$.bind a, 'click', expandComment
expandComment.init()
callback() for callback in g.callbacks
$.bind d.body, 'DOMNodeInserted', nodeInserted