X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/52f39e99d1e133c07ee2f2b549a7720028bd2909..d3b0d0f597e0f84246dd755c6de3f29770134b44:/forum/skins/default/media/js/osqa.main.js
diff --git a/forum/skins/default/media/js/osqa.main.js b/forum/skins/default/media/js/osqa.main.js
index 0cf354f..89a59ef 100644
--- a/forum/skins/default/media/js/osqa.main.js
+++ b/forum/skins/default/media/js/osqa.main.js
@@ -1,3 +1,32 @@
+/**
+ * We do not want the CSRF protection enabled for the AJAX post requests, it causes only trouble.
+ * Get the csrftoken cookie and pass it to the X-CSRFToken HTTP request property.
+ */
+
+$('html').ajaxSend(function(event, xhr, settings) {
+ function getCookie(name) {
+ var cookieValue = null;
+ if (document.cookie && document.cookie != '') {
+ var cookies = document.cookie.split(';');
+ for (var i = 0; i < cookies.length; i++) {
+ var cookie = jQuery.trim(cookies[i]);
+ // Does this cookie string begin with the name we want?
+ if (cookie.substring(0, name.length + 1) == (name + '=')) {
+ cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
+ break;
+ }
+ }
+ }
+ return cookieValue;
+ }
+ try {
+ if (!(/^http:.*/.test(settings.url) || /^https:.*/.test(settings.url))) {
+ // Only send the token to relative URLs i.e. locally.
+ xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken'));
+ }
+ } catch (e) {}
+});
+
var response_commands = {
refresh_page: function() {
window.location.reload(true)
@@ -75,7 +104,7 @@ var response_commands = {
alert('ok');
},
- insert_comment: function(post_id, comment_id, comment, username, profile_url, delete_url, edit_url, convert_url) {
+ insert_comment: function(post_id, comment_id, comment, username, profile_url, delete_url, edit_url, convert_url, can_convert, show_latest_comments_first) {
var $container = $('#comments-container-' + post_id);
var skeleton = $('#new-comment-skeleton-' + post_id).html().toString();
@@ -86,8 +115,16 @@ var response_commands = {
.replace(new RegExp('%DELETE_URL%', 'g'), delete_url)
.replace(new RegExp('%EDIT_URL%', 'g'), edit_url)
.replace(new RegExp('%CONVERT_URL%', 'g'), convert_url);
+ if (show_latest_comments_first) {
+ $container.prepend(skeleton);
+ } else {
+ $container.append(skeleton);
+ }
- $container.append(skeleton);
+ // Show the convert comment to answer tool only if the current comment can be converted
+ if (can_convert == true) {
+ $('#comment-' + comment_id + '-convert').show();
+ }
$('#comment-' + comment_id).slideDown('slow');
},
@@ -100,12 +137,12 @@ var response_commands = {
},
mark_deleted: function(post_type, post_id) {
- if (post_type == 'answer') {
- var $answer = $('#answer-container-' + post_id);
- $answer.addClass('deleted');
- } else {
+ if (post_type == 'question') {
var $container = $('#question-table');
$container.addClass('deleted');
+ } else {
+ var $el = $('#' + post_type + '-container-' + post_id);
+ $el.addClass('deleted');
}
},
@@ -128,7 +165,6 @@ var response_commands = {
},
copy_url: function(url) {
- $.copy(url);
}
}
@@ -150,11 +186,17 @@ function show_dialog (extern) {
yes_callback: default_close_function,
no_text: messages.cancel,
show_no: false,
- close_on_clickoutside: false
+ close_on_clickoutside: false,
+ copy: false
}
$.extend(options, extern);
+ var copy_id = '';
+ if (options.copy) {
+ copy_id = ' id="copy_clip_button"'
+ }
+
if (options.event != undefined) {
options.pos = {x: options.event.pageX, y: options.event.pageY};
}
@@ -166,8 +208,7 @@ function show_dialog (extern) {
html += '';
}
- html += ''
- + '';
+ html += '' + '';
$dialog = $(html);
$('body').append($dialog);
@@ -273,7 +314,12 @@ function load_prompt(evt, el, url) {
process_ajax_response(data, evt);
}, 'json');
},
- show_no: true
+ show_no: true,
+ copy: false
+ }
+
+ if (el.hasClass('copy')) {
+ $.extend(doptions, { yes_text : 'Copy', copy: true});
}
if (!el.is('.centered')) {
@@ -288,7 +334,8 @@ function process_ajax_response(data, evt, callback) {
if (!data.success && data['error_message'] != undefined) {
show_message(evt, data.error_message, function() {if (callback) callback(true);});
end_command(false);
- } else if (typeof data['commands'] != undefined){
+ }
+ if (typeof data['commands'] != undefined){
for (var command in data.commands) {
response_commands[command].apply(null, data.commands[command])
@@ -324,23 +371,47 @@ function end_command(success) {
}
}
+var comment_box_cursor_position = 0;
+function canned_comment(post_id, comment) {
+ textarea = $('#comment-' + post_id + '-form textarea')
+
+ // Get the text from the beginning to the caret
+ textarea_start = textarea.val().substr(0, comment_box_cursor_position)
+
+ // Get the text from the caret to the end
+ textarea_end = textarea.val().substr(comment_box_cursor_position, textarea.val().length)
+
+ textarea.val(textarea_start + comment + textarea_end);
+}
+
$(function() {
+ $('textarea.commentBox').bind('keydown keyup mousedown mouseup mousemove', function(evt) {
+ comment_box_cursor_position = $(this).caret().start;
+ });
+
+ $('textarea.commentBox').blur(function() {
+ //alert(comment_box_cursor_position);
+ });
+
$('a.ajax-command').live('click', function(evt) {
if (running) return false;
- $('.context-menu-dropdown').slideUp('fast');
-
var el = $(this);
+ var ajax_url = el.attr('href')
+ ajax_url = ajax_url + "?nocache=" + new Date().getTime()
+
+ $('.context-menu-dropdown').slideUp('fast');
+
if (el.is('.withprompt')) {
- load_prompt(evt, el, el.attr('href'));
+ load_prompt(evt, el, ajax_url);
} else if(el.is('.confirm')) {
var doptions = {
html: messages.confirm,
extra_class: 'confirm',
yes_callback: function() {
start_command();
- $.getJSON(el.attr('href'), function(data) {
+ $.getJSON(ajax_url, function(data) {
process_ajax_response(data, evt);
$dialog.fadeOut('fast', function() {
$dialog.remove();
@@ -358,7 +429,7 @@ $(function() {
var $dialog = show_dialog(doptions);
} else {
start_command();
- $.getJSON(el.attr('href'), function(data) {
+ $.getJSON(ajax_url, function(data) {
process_ajax_response(data, evt);
});
}
@@ -542,6 +613,14 @@ $(function() {
return false;
});
+ // Submit comment with CTRL + Enter
+ $textarea.keydown(function(e) {
+ if (e.ctrlKey && e.keyCode == 13 && !$button.attr('disabled')) {
+ // console.log('submit');
+ $(this).parent().find('input.comment-submit').click();
+ }
+ });
+
$cancel.click(function(event) {
if (confirm("You will lose all of your changes in this comment. Do you still wish to proceed?")){
if (comment_in_form) {
@@ -685,7 +764,7 @@ function pickedTags(){
tag_link.attr('rel','tag');
tag_link.attr('href', scriptUrl + $.i18n._('tags/') + tagname + '/');
tag_link.html(tagname);
- var del_link = $('
');
+ var del_link = $('
');
del_link.addClass('delete-icon');
del_link.attr('src', mediaUrl('media/images/close-small-dark.png'));