X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/410bfa05ee36ed1d99356c443a5f3f6aa3ee9578..6d48df570d9b759d0fd18001fbcacc5c5a36a7e0:/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 06b2cc9..8326eb0 100644
--- a/forum/skins/default/media/js/osqa.main.js
+++ b/forum/skins/default/media/js/osqa.main.js
@@ -124,78 +124,133 @@ var response_commands = {
}
}
-function show_message(object, msg, callback) {
- var div = $('
' + msg + '
(' +
- 'click to close' + ')');
-
- div.click(function(event) {
- $(".vote-notification").fadeOut("fast", function() {
- $(this).remove();
- if (callback) {
- callback();
- }
+function show_dialog (extern) {
+ var default_close_function = function($diag) {
+ $diag.fadeOut('fast', function() {
+ $diag.remove();
});
- });
+ }
- object.parent().append(div);
- div.fadeIn("fast");
-}
+ var options = {
+ extra_class: '',
+ pos: {
+ x: ($(window).width() / 2) + $(window).scrollLeft(),
+ y: ($(window).height() / 2) + $(window).scrollTop()
+ },
+ dim: false,
+ yes_text: messages.ok,
+ yes_callback: default_close_function,
+ no_text: messages.cancel,
+ show_no: false,
+ close_on_clickoutside: false
+ }
-function load_prompt(object, url) {
- var $box = $('' +
- '
' +
- '
');
+ $.extend(options, extern);
+ if (options.event != undefined) {
+ options.pos = {x: options.event.pageX, y: options.event.pageY};
+ }
- object.parent().append($box);
- $box.fadeIn("fast");
+ var html = '';
+
+ $dialog = $(html);
+ $('body').append($dialog);
+
+ if (options.dim === false) {
+ $dialog.css({
+ visibility: 'hidden',
+ display: 'block'
});
- $box.find('.prompt-submit').click(function() {
- start_command();
- $.post(url, {prompt: $box.find('textarea').val()}, function(data) {
- $box.fadeOut('fast', function() {
- $box.remove();
- });
- process_ajax_response(data, object);
- }, 'json');
- return false;
+ options.dim = {w: $dialog.width(), h: $dialog.height()};
+
+ $dialog.css({
+ width: 1,
+ height: 1,
+ visibility: 'visible'
});
+ }
+
+ $dialog.css({
+ top: options.pos.y,
+ left: options.pos.x
+ });
+
+ $dialog.animate({
+ top: "-=" + (options.dim.h / 2),
+ left: "-=" + (options.dim.w / 2),
+ width: options.dim.w,
+ height: options.dim.h
+ }, 200);
+
+ $dialog.find('.dialog-no').click(function() {
+ default_close_function($dialog);
});
-}
-function show_prompt(object, msg, callback) {
- var div = $('' + msg + '
' +
- '
' +
- '' +
- '' +
- '
');
+ $dialog.find('.dialog-yes').click(function() {
+ options.yes_callback($dialog);
+ });
- function fade_out() {
- div.fadeOut("fast", function() { div.remove(); });
+ if (options.close_on_clickoutside) {
+ $dialog.one('clickoutside', function() {
+ default_close_function($dialog);
+ });
}
- div.find('.prompt-cancel').click(fade_out);
+ return $dialog;
+}
- div.find('.prompt-ok').click(function(event) {
- callback(div.find('.command-prompt').val());
- fade_out();
+function show_message(evt, msg, callback) {
+ var $dialog = show_dialog({
+ html: msg,
+ extra_class: 'warning',
+ event: evt,
+ yes_callback: function() {
+ $dialog.fadeOut('fast', function() {
+ $dialog.remove();
+ });
+ if (callback) {
+ callback();
+ }
+ },
+ close_on_clickoutside: true
});
+}
- object.parent().append(div);
- div.fadeIn("fast");
+function load_prompt(evt, url) {
+ $.get(url, function(data) {
+ var $dialog = show_dialog({
+ html: data,
+ extra_class: 'prompt',
+ event: evt,
+ yes_callback: function() {
+ var postvars = {};
+ $dialog.find('input, textarea, select').each(function() {
+ postvars[$(this).attr('name')] = $(this).val();
+ });
+ $.post(url, postvars, function(data) {
+ $dialog.fadeOut('fast', function() {
+ $dialog.remove();
+ });
+ process_ajax_response(data, evt);
+ }, 'json');
+ },
+ show_no: true
+ });
+ });
}
-function process_ajax_response(data, el, callback) {
+function process_ajax_response(data, evt, callback) {
if (!data.success && data['error_message'] != undefined) {
- show_message(el, data.error_message, function() {if (callback) callback(true);});
+ show_message(evt, data.error_message, function() {if (callback) callback(true);});
end_command(false);
} else if (typeof data['commands'] != undefined){
for (var command in data.commands) {
@@ -203,7 +258,7 @@ function process_ajax_response(data, el, callback) {
}
if (data['message'] != undefined) {
- show_message(el, data.message, function() {if (callback) callback(false);})
+ show_message(evt, data.message, function() {if (callback) callback(false);})
} else {
if (callback) callback(false);
}
@@ -232,23 +287,57 @@ function end_command(success) {
}
$(function() {
- $('a.ajax-command').live('click', function() {
+ $('a.ajax-command').live('click', function(evt) {
if (running) return false;
var el = $(this);
if (el.is('.withprompt')) {
- load_prompt(el, el.attr('href'));
+ load_prompt(evt, el.attr('href'));
+ } else if(el.is('.confirm')) {
+ $dialog = show_dialog({
+ html: messages.confirm,
+ extra_class: 'confirm',
+ event: evt,
+ yes_callback: function() {
+ start_command();
+ $.getJSON(el.attr('href'), function(data) {
+ process_ajax_response(data, evt);
+ $dialog.fadeOut('fast', function() {
+ $dialog.remove();
+ });
+ });
+ },
+ yes_text: messages.yes,
+ show_no: true,
+ no_text: messages.no
+ });
} else {
start_command();
$.getJSON(el.attr('href'), function(data) {
- process_ajax_response(data, el);
+ process_ajax_response(data, evt);
});
}
return false
});
+ $('.context-menu').each(function() {
+ var $menu = $(this);
+ var $trigger = $menu.find('.context-menu-trigger');
+ var $dropdown = $menu.find('.context-menu-dropdown');
+
+ $trigger.click(function() {
+ $dropdown.slideToggle('fast', function() {
+ if ($dropdown.is(':visible')) {
+ $dropdown.one('clickoutside', function() {
+ $dropdown.slideUp('fast')
+ });
+ }
+ });
+ });
+ });
+
$('div.comment-form-container').each(function() {
var $container = $(this);
var $form = $container.find('form');
@@ -301,7 +390,7 @@ $(function() {
cleanup_form();
function process_form_changes() {
- var length = $textarea.val().length;
+ var length = $textarea.val().replace(/[ ]{2,}/g," ").length;
if (current_length == length)
return;
@@ -317,6 +406,7 @@ $(function() {
$chars_togo_message.show();
$chars_counter.html(min_length - length);
} else {
+ length = $textarea.val().length;
$chars_togo_message.hide();
$chars_left_message.show();
$chars_counter.html(max_length - length);
@@ -385,7 +475,7 @@ $(function() {
return false;
});
- $button.click(function() {
+ $button.click(function(evt) {
if (running) return false;
var post_data = {
@@ -398,7 +488,7 @@ $(function() {
start_command();
$.post($form.attr('action'), post_data, function(data) {
- process_ajax_response(data, $button, function(error) {
+ process_ajax_response(data, evt, function(error) {
if (!error) {
cleanup_form();
hide_comment_form();
@@ -925,14 +1015,20 @@ var notify = function() {
visible = true;
},
close: function(doPostback) {
- if (doPostback) {
- $.post(scriptUrl + $.i18n._("messages/") +
- $.i18n._("markread/"), { formdata: "required" });
- }
$(".notify").fadeOut("fast");
$("body").css("margin-top", "0");
visible = false;
},
isVisible: function() { return visible; }
};
-} ();
\ No newline at end of file
+} ();
+
+/*
+ * jQuery outside events - v1.1 - 3/16/2010
+ * http://benalman.com/projects/jquery-outside-events-plugin/
+ *
+ * Copyright (c) 2010 "Cowboy" Ben Alman
+ * Dual licensed under the MIT and GPL licenses.
+ * http://benalman.com/about/license/
+ */
+(function($,c,b){$.map("click dblclick mousemove mousedown mouseup mouseover mouseout change select submit keydown keypress keyup".split(" "),function(d){a(d)});a("focusin","focus"+b);a("focusout","blur"+b);$.addOutsideEvent=a;function a(g,e){e=e||g+b;var d=$(),h=g+"."+e+"-special-event";$.event.special[e]={setup:function(){d=d.add(this);if(d.length===1){$(c).bind(h,f)}},teardown:function(){d=d.not(this);if(d.length===0){$(c).unbind(h)}},add:function(i){var j=i.handler;i.handler=function(l,k){l.target=k;j.apply(this,arguments)}}};function f(i){$(d).each(function(){var j=$(this);if(this!==i.target&&!j.has(i.target).length){j.triggerHandler(e,[i.target])}})}}})(jQuery,document,"outside");
\ No newline at end of file