thread.js
80 lines
| 2.7 KiB
| application/javascript
|
JavascriptLexer
neko259
|
r332 | /* | ||
@licstart The following is the entire license notice for the | ||||
JavaScript code in this page. | ||||
Copyright (C) 2013 neko259 | ||||
The JavaScript code in this page is free software: you can | ||||
redistribute it and/or modify it under the terms of the GNU | ||||
General Public License (GNU GPL) as published by the Free Software | ||||
Foundation, either version 3 of the License, or (at your option) | ||||
any later version. The code is distributed WITHOUT ANY WARRANTY; | ||||
without even the implied warranty of MERCHANTABILITY or FITNESS | ||||
FOR A PARTICULAR PURPOSE. See the GNU GPL for more details. | ||||
As additional permission under GNU GPL version 3 section 7, you | ||||
may distribute non-source (e.g., minimized or compacted) forms of | ||||
that code without the copy of the GNU GPL normally required by | ||||
section 4, provided you include this license notice and a URL | ||||
through which recipients can access the Corresponding Source. | ||||
@licend The above is the entire license notice | ||||
for the JavaScript code in this page. | ||||
*/ | ||||
rt@lightning
|
r253 | function addGalleryPanel() { | ||
var gallery = $('a[class="thumb"]').clone(true), | ||||
normal = $('.post').clone(true); | ||||
neko259
|
r66 | |||
rt@lightning
|
r253 | $('.navigation_panel').filter(':first').after( | ||
'<div class="image-mode-tab" role="radiogroup" aria-label="Image mode2">' + | ||||
'<label><input type="radio" class="image-mode-normal" name="image-mode" value="0" checked="checked"/>'+ gettext('Normal') +'</label>' + | ||||
'<label><input type="radio" class="image-mode-table" name="image-mode" value="1"/>'+ gettext('Gallery') +'</label>' + | ||||
'</div>' | ||||
); | ||||
rt@lightning
|
r252 | |||
rt@lightning
|
r253 | $('input[name="image-mode"]').change(function() { | ||
//gallery mode | ||||
if($(this).val() === '1') { | ||||
rt@lightning
|
r256 | $('.thread').replaceWith( | ||
rt@lightning
|
r253 | $('<div id="posts-table"></div>').append(gallery) | ||
neko259
|
r66 | ); | ||
} | ||||
rt@lightning
|
r253 | //normal mode | ||
else { | ||||
$('#posts-table').replaceWith( | ||||
rt@lightning
|
r256 | $('<div class="thread"></div>').append(normal) | ||
rt@lightning
|
r253 | ); | ||
} | ||||
}); | ||||
neko259
|
r66 | } | ||
Pavel Ryapolov
|
r106 | function moveCaretToEnd(el) { | ||
if (typeof el.selectionStart == "number") { | ||||
el.selectionStart = el.selectionEnd = el.value.length; | ||||
} else if (typeof el.createTextRange != "undefined") { | ||||
el.focus(); | ||||
var range = el.createTextRange(); | ||||
range.collapse(false); | ||||
range.select(); | ||||
} | ||||
} | ||||
neko259
|
r97 | function addQuickReply(postId) { | ||
var textToAdd = '>>' + postId + '\n\n'; | ||||
Pavel Ryapolov
|
r107 | var textAreaId = '#id_text'; | ||
$(textAreaId).val($(textAreaId).val()+ textToAdd); | ||||
neko259
|
r97 | |||
Pavel Ryapolov
|
r106 | var textarea = document.getElementById('id_text'); | ||
Pavel Ryapolov
|
r107 | $(textAreaId).focus(); | ||
Pavel Ryapolov
|
r106 | moveCaretToEnd(textarea); | ||
Pavel Ryapolov
|
r107 | $("html, body").animate({ scrollTop: $(textAreaId).offset().top }, "slow"); | ||
neko259
|
r97 | } | ||
ritsufag
|
r118 | |||
neko259
|
r66 | $(document).ready(function(){ | ||
rt@lightning
|
r253 | addGalleryPanel(); | ||
Pavel Ryapolov
|
r106 | }); | ||