diff --git a/4chan_x.js b/4chan_x.js index 62138fa3a..761528791 100644 --- a/4chan_x.js +++ b/4chan_x.js @@ -1141,17 +1141,25 @@ } }, dialog: function(link) { - var clone, dialog, el, html, resto, script, xpath, _i, _len, _ref; - html = "
Quick Reply X
"; + var clone, dialog, el, html, resto, script, spoiler, xpath, _i, _len, _ref; + html = "
Quick Reply X
"; dialog = ui.dialog('qr', { top: '0px', left: '0px' }, html); - el = $('input[title=autohide]', dialog); + el = $('#autohide', dialog); $.bind(el, 'click', qr.cb.autohide); + $('input[name="MAX_FILE_SIZE"]', dialog).value = $('.postarea input[name="MAX_FILE_SIZE"]').value; + if ($('.postarea label')) { + spoiler = $.el('label', { + innerHTML: " [Spoiler Image?]" + }); + $.append($('div:nth-of-type(2)', dialog), spoiler); + } clone = $('#recaptcha_widget_div').cloneNode(true); $.append($('#qr_captcha', dialog), clone); - $('input[name=recaptcha_response_field]', clone).placeholder = 'verification'; + $('input[name=recaptcha_response_field]', clone).placeholder = 'Verification'; + $('input[name=recaptcha_response_field]', clone).className = 'inputtext'; $.append(d.body, dialog); return; clone = $('form[name=post]').cloneNode(true); @@ -1470,7 +1478,7 @@ }; watcher = { init: function() { - var board, dialog, favicon, html, id, input, inputs, props, src, watched, watchedBoard, _i, _len, _ref, _results; + var dialog, favicon, html, id, input, inputs, src, watched, watchedBoard, _i, _len, _results; html = '
Thread Watcher
'; dialog = ui.dialog('watcher', { top: '50px', @@ -1478,13 +1486,7 @@ }, html); $.append(d.body, dialog); watched = $.getValue('watched', {}); - for (board in watched) { - _ref = watched[board]; - for (id in _ref) { - props = _ref[id]; - watcher.addLink(props, dialog); - } - } + watcher.refresh(watched); watchedBoard = watched[g.BOARD] || {}; inputs = $$('form > input[value=delete], div.thread > input[value=delete]'); _results = []; @@ -1505,9 +1507,30 @@ } return _results; }, + refresh: function(watched) { + var board, div, id, props, _i, _len, _ref, _results; + _ref = $$('#watcher > div:not(.move)'); + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + div = _ref[_i]; + $.remove(div); + } + _results = []; + for (board in watched) { + _results.push((function() { + var _ref2, _results2; + _ref2 = watched[board]; + _results2 = []; + for (id in _ref2) { + props = _ref2[id]; + _results2.push(watcher.addLink(props, $('#watcher'))); + } + return _results2; + })()); + } + return _results; + }, addLink: function(props, dialog) { var div, link, x; - dialog || (dialog = $('#watcher')); div = $.el('div'); x = $.el('a', { textContent: 'X' @@ -1538,17 +1561,15 @@ } }, unwatch: function(board, id) { - var div, favicon, href, input, watched; - href = "/" + board + "/res/" + id; - div = $("#watcher a[href=\"" + href + "\"]").parentNode; - $.remove(div); + var favicon, input, watched; if (input = $("input[name=\"" + id + "\"]")) { favicon = input.previousSibling; favicon.src = Favicon.empty; } watched = $.getValue('watched', {}); delete watched[board][id]; - return $.setValue('watched', watched); + $.setValue('watched', watched); + return watcher.refresh(watched); }, watch: function(thread) { var favicon, id, props, tc, watched, _name; @@ -1567,7 +1588,7 @@ watched[_name = g.BOARD] || (watched[_name] = {}); watched[g.BOARD][id] = props; $.setValue('watched', watched); - return watcher.addLink(props); + return watcher.refresh(watched); } }; anonymize = { @@ -2286,24 +2307,55 @@ #qr #recaptcha_table td:nth-of-type(3) {/* captcha logos */\ display: none;\ }\ - #qr textarea {\ - width: 300px;\ - height: 100px;\ - }\ #qr form {\ - margin: 0px;\ + width: 302px;\ }\ - #qr * {\ - padding: 0px !important;\ + #qr form, #qr #com_submit, #qr input[type="file"] {\ + margin: 0;\ + }\ + #qr textarea {\ + width: 302px;\ + height: 80px;\ + }\ + #qr *:not(input):not(textarea) {\ + padding: 0 !important;\ }\ #qr.auto:not(:hover) form {\ display: none;\ }\ #qr span.error {\ position: absolute;\ - bottom: 0;\ + top: 0;\ left: 0;\ }\ + /* qr reCAPTCHA */\ + #qr_captcha input {\ + border: 1px solid #AAA !important;\ + margin-top: 2px;\ + padding: 2px 4px 3px;\ + }\ + #qr tr {\ + height: auto;\ + }\ + #qr .recaptchatable #recaptcha_image {\ + border: 1px solid #AAA !important;\ + }\ + #qr #recaptcha_reload, #qr #recaptcha_switch_audio, #qr #recaptcha_whatsthis {\ + height: 0;\ + width: 0;\ + padding: 10px 6px !important;\ + margin-left: -16px;\ + position: relative;\ + }\ + #recaptcha_reload {\ + background: url() no-repeat center;\ +}\ + #recaptcha_switch_audio {\ + background: url() no-repeat center;\ + }\ + #recaptcha_whatsthis {\ + background: url() no-repeat center;\ + }\ \ #updater {\ position: fixed;\ diff --git a/script.coffee b/script.coffee index a1dc8b46a..ead516f75 100644 --- a/script.coffee +++ b/script.coffee @@ -876,24 +876,33 @@ qr = dialog: (link) -> html = " -
Quick Reply X
-
-
-
-
-
-
-
-
+
Quick Reply X
+ + +
+
+
+
+
+
+
" dialog = ui.dialog 'qr', top: '0px', left: '0px', html - el = $ 'input[title=autohide]', dialog + el = $ '#autohide', dialog $.bind el, 'click', qr.cb.autohide + $('input[name="MAX_FILE_SIZE"]', dialog).value = $('.postarea input[name="MAX_FILE_SIZE"]').value + + if $ '.postarea label' + spoiler = $.el 'label', + innerHTML: " [Spoiler Image?]" + $.append $('div:nth-of-type(2)', dialog), spoiler + clone = $('#recaptcha_widget_div').cloneNode(true) $.append $('#qr_captcha', dialog), clone - $('input[name=recaptcha_response_field]', clone).placeholder = 'verification' + $('input[name=recaptcha_response_field]', clone).placeholder = 'Verification' + $('input[name=recaptcha_response_field]', clone).className = 'inputtext' $.append d.body, dialog return @@ -1187,9 +1196,7 @@ watcher = #populate watcher watched = $.getValue 'watched', {} - for board of watched - for id, props of watched[board] - watcher.addLink props, dialog + watcher.refresh watched #add watch buttons watchedBoard = watched[g.BOARD] or {} @@ -1206,8 +1213,14 @@ watcher = $.bind favicon, 'click', watcher.cb.toggle $.before input, favicon + refresh: (watched) -> + for div in $$ '#watcher > div:not(.move)' + $.remove div + for board of watched + for id, props of watched[board] + watcher.addLink props, $ '#watcher' + addLink: (props, dialog) -> - dialog or= $ '#watcher' div = $.el 'div' x = $.el 'a', textContent: 'X' @@ -1234,10 +1247,6 @@ watcher = watcher.unwatch g.BOARD, id unwatch: (board, id) -> - href = "/#{board}/res/#{id}" - div = $("#watcher a[href=\"#{href}\"]").parentNode - $.remove div - if input = $ "input[name=\"#{id}\"]" favicon = input.previousSibling favicon.src = Favicon.empty @@ -1246,6 +1255,8 @@ watcher = delete watched[board][id] $.setValue 'watched', watched + watcher.refresh watched + watch: (thread) -> favicon = $ 'img.favicon', thread @@ -1264,7 +1275,7 @@ watcher = watched[g.BOARD][id] = props $.setValue 'watched', watched - watcher.addLink props + watcher.refresh watched anonymize = init: -> @@ -1810,24 +1821,55 @@ main = #qr #recaptcha_table td:nth-of-type(3) {/* captcha logos */ display: none; } - #qr textarea { - width: 300px; - height: 100px; - } #qr form { - margin: 0px; + width: 302px; } - #qr * { - padding: 0px !important; + #qr form, #qr #com_submit, #qr input[type="file"] { + margin: 0; + } + #qr textarea { + width: 302px; + height: 80px; + } + #qr *:not(input):not(textarea) { + padding: 0 !important; } #qr.auto:not(:hover) form { display: none; } #qr span.error { position: absolute; - bottom: 0; + top: 0; left: 0; } + /* qr reCAPTCHA */ + #qr_captcha input { + border: 1px solid #AAA !important; + margin-top: 2px; + padding: 2px 4px 3px; + } + #qr tr { + height: auto; + } + #qr .recaptchatable #recaptcha_image { + border: 1px solid #AAA !important; + } + #qr #recaptcha_reload, #qr #recaptcha_switch_audio, #qr #recaptcha_whatsthis { + height: 0; + width: 0; + padding: 10px 6px !important; + margin-left: -16px; + position: relative; + } + #recaptcha_reload { + background: url() no-repeat center; +} + #recaptcha_switch_audio { + background: url() no-repeat center; + } + #recaptcha_whatsthis { + background: url() no-repeat center; + } #updater { position: fixed;