1 var response_commands = {
\r
2 refresh_page: function() {
\r
3 window.location.reload(true)
\r
6 update_post_score: function(id, inc) {
\r
7 var $score_board = $('#post-' + id + '-score');
\r
8 var current = parseInt($score_board.html())
\r
12 $score_board.html(current + inc)
\r
15 update_user_post_vote: function(id, vote_type) {
\r
16 var $upvote_button = $('#post-' + id + '-upvote');
\r
17 var $downvote_button = $('#post-' + id + '-downvote');
\r
19 $upvote_button.removeClass('on');
\r
20 $downvote_button.removeClass('on');
\r
22 if (vote_type == 'up') {
\r
23 $upvote_button.addClass('on');
\r
24 } else if (vote_type == 'down') {
\r
25 $downvote_button.addClass('on');
\r
29 update_favorite_count: function(inc) {
\r
30 var $favorite_count = $('#favorite-count');
\r
31 var count = parseInt($favorite_count.html());
\r
41 $favorite_count.html(count);
\r
44 update_favorite_mark: function(type) {
\r
46 $('#favorite-mark').addClass('on');
\r
48 $('#favorite-mark').removeClass('on');
\r
52 mark_accepted: function(id) {
\r
53 var $answer = $('#answer-container-' + id);
\r
54 $answer.addClass('accepted-answer');
\r
55 $answer.find('.accept-answer').addClass('on');
\r
56 $answer.find('.accept-answer').attr('title', $answer.find('.accept-answer').attr('bn:on'));
\r
59 unmark_accepted: function(id) {
\r
60 var $answer = $('#answer-container-' + id);
\r
61 $answer.removeClass('accepted-answer');
\r
62 $answer.find('.accept-answer').removeClass('on');
\r
63 $answer.find('.accept-answer').attr('title', $answer.find('.accept-answer').attr('bn:off'));
\r
66 remove_comment: function(id) {
\r
67 var $comment = $('#comment-' + id);
\r
68 $comment.css('background', 'red')
\r
69 $comment.fadeOut('slow', function() {
\r
74 award_points: function(id) {
\r
78 insert_comment: function(post_id, comment_id, comment, username, profile_url, delete_url, edit_url, convert_url, can_convert) {
\r
79 var $container = $('#comments-container-' + post_id);
\r
80 var skeleton = $('#new-comment-skeleton-' + post_id).html().toString();
\r
82 skeleton = skeleton.replace(new RegExp('%ID%', 'g'), comment_id)
\r
83 .replace(new RegExp('%COMMENT%', 'g'), comment)
\r
84 .replace(new RegExp('%USERNAME%', 'g'), username)
\r
85 .replace(new RegExp('%PROFILE_URL%', 'g'), profile_url)
\r
86 .replace(new RegExp('%DELETE_URL%', 'g'), delete_url)
\r
87 .replace(new RegExp('%EDIT_URL%', 'g'), edit_url)
\r
88 .replace(new RegExp('%CONVERT_URL%', 'g'), convert_url);
\r
90 $container.append(skeleton);
\r
92 // Show the convert comment to answer tool only if the current comment can be converted
\r
93 if (can_convert == true) {
\r
94 $('#comment-' + comment_id + '-convert').show();
\r
97 $('#comment-' + comment_id).slideDown('slow');
\r
100 update_comment: function(comment_id, comment_text) {
\r
101 var $comment = $('#comment-' + comment_id);
\r
102 $comment.find('.comment-text').html(comment_text);
\r
104 $comment.slideDown('slow');
\r
107 mark_deleted: function(post_type, post_id) {
\r
108 if (post_type == 'question') {
\r
109 var $container = $('#question-table');
\r
110 $container.addClass('deleted');
\r
112 var $el = $('#' + post_type + '-container-' + post_id);
\r
113 $el.addClass('deleted');
\r
117 unmark_deleted: function(post_type, post_id) {
\r
118 if (post_type == 'answer') {
\r
119 var $answer = $('#answer-container-' + post_id);
\r
120 $answer.removeClass('deleted');
\r
122 var $container = $('#question-table');
\r
123 $container.removeClass('deleted');
\r
127 set_subscription_button: function(text) {
\r
128 $('.subscription_switch').html(text);
\r
131 set_subscription_status: function(text) {
\r
132 $('.subscription-status').html(text);
\r
135 copy_url: function(url) {
\r
140 function show_dialog (extern) {
\r
141 var default_close_function = function($diag) {
\r
142 $diag.fadeOut('fast', function() {
\r
150 x: ($(window).width() / 2) + $(window).scrollLeft(),
\r
151 y: ($(window).height() / 2) + $(window).scrollTop()
\r
154 yes_text: messages.ok,
\r
155 yes_callback: default_close_function,
\r
156 no_text: messages.cancel,
\r
158 close_on_clickoutside: false
\r
161 $.extend(options, extern);
\r
163 if (options.event != undefined) {
\r
164 options.pos = {x: options.event.pageX, y: options.event.pageY};
\r
167 var html = '<div class="dialog ' + options.extra_class + '" style="display: none;">'
\r
168 + '<div class="dialog-content">' + options.html + '</div><div class="dialog-buttons">';
\r
170 if (options.show_no) {
\r
171 html += '<button class="dialog-no">' + options.no_text + '</button>';
\r
174 html += '<button class="dialog-yes">' + options.yes_text + '</button>'
\r
178 $('body').append($dialog);
\r
179 var message = $('.dialog-content')[0];
\r
180 message.style.visibility = "hidden";
\r
182 if (options.dim === false) {
\r
184 visibility: 'hidden',
\r
188 options.dim = {w: $dialog.width(), h: $dialog.height()};
\r
193 visibility: 'visible'
\r
198 top: options.pos.y,
\r
199 left: options.pos.x
\r
202 top_position_change = (options.dim.h / 2)
\r
203 left_position_change = (options.dim.w / 2)
\r
205 new_top_position = options.pos.y - top_position_change
\r
206 new_left_position = options.pos.x - left_position_change
\r
208 if (new_left_position < 0) {
\r
209 left_position_change = 0
\r
211 if (($(window).scrollTop() - new_top_position) > 0) {
\r
212 top_position_change = 0
\r
214 if ((options.event.pageY + options.dim.h) > ($(window).height() + $(window).scrollTop())) {
\r
215 top_position_change = options.dim.h
\r
217 if ((options.event.pageX + options.dim.w) > ($(window).width() + $(window).scrollLeft())) {
\r
218 left_position_change = options.dim.w
\r
222 top: "-=" + top_position_change,
\r
223 left: "-=" + left_position_change,
\r
224 width: options.dim.w,
\r
225 height: options.dim.h
\r
226 }, 200, function() {
\r
227 message.style.visibility = "visible";
\r
230 $dialog.find('.dialog-no').click(function() {
\r
231 default_close_function($dialog);
\r
234 $dialog.find('.dialog-yes').click(function() {
\r
235 options.yes_callback($dialog);
\r
238 if (options.close_on_clickoutside) {
\r
239 $dialog.one('clickoutside', function() {
\r
240 default_close_function($dialog);
\r
247 function show_message(evt, msg, callback) {
\r
248 var $dialog = show_dialog({
\r
250 extra_class: 'warning',
\r
252 yes_callback: function() {
\r
253 $dialog.fadeOut('fast', function() {
\r
260 close_on_clickoutside: true
\r
264 function load_prompt(evt, el, url) {
\r
265 $.get(url, function(data) {
\r
268 extra_class: 'prompt',
\r
269 yes_callback: function() {
\r
271 $dialog.find('input, textarea, select').each(function() {
\r
272 postvars[$(this).attr('name')] = $(this).val();
\r
274 $.post(url, postvars, function(data) {
\r
275 $dialog.fadeOut('fast', function() {
\r
278 process_ajax_response(data, evt);
\r
284 if (!el.is('.centered')) {
\r
285 doptions.event = evt;
\r
288 var $dialog = show_dialog(doptions);
\r
292 function process_ajax_response(data, evt, callback) {
\r
293 if (!data.success && data['error_message'] != undefined) {
\r
294 show_message(evt, data.error_message, function() {if (callback) callback(true);});
\r
295 end_command(false);
\r
296 } else if (typeof data['commands'] != undefined){
\r
297 for (var command in data.commands) {
\r
298 response_commands[command].apply(null, data.commands[command])
\r
303 if (data['message'] != undefined) {
\r
304 show_message(evt, data.message, function() {if (callback) callback(false);})
\r
306 if (callback) callback(false);
\r
312 var running = false;
\r
314 function start_command() {
\r
315 $('body').append($('<div id="command-loader"></div>'));
\r
319 function end_command(success) {
\r
321 $('#command-loader').addClass('success');
\r
322 $('#command-loader').fadeOut("slow", function() {
\r
323 $('#command-loader').remove();
\r
327 $('#command-loader').remove();
\r
333 $('a.ajax-command').live('click', function(evt) {
\r
334 if (running) return false;
\r
338 var ajax_url = el.attr('href')
\r
339 ajax_url = ajax_url + "?nocache=" + new Date().getTime()
\r
341 $('.context-menu-dropdown').slideUp('fast');
\r
343 if (el.is('.withprompt')) {
\r
344 load_prompt(evt, el, ajax_url);
\r
345 } else if(el.is('.confirm')) {
\r
347 html: messages.confirm,
\r
348 extra_class: 'confirm',
\r
349 yes_callback: function() {
\r
351 $.getJSON(ajax_url, function(data) {
\r
352 process_ajax_response(data, evt);
\r
353 $dialog.fadeOut('fast', function() {
\r
358 yes_text: messages.yes,
\r
360 no_text: messages.no
\r
363 if (!el.is('.centered')) {
\r
364 doptions.event = evt;
\r
366 var $dialog = show_dialog(doptions);
\r
369 $.getJSON(ajax_url, function(data) {
\r
370 process_ajax_response(data, evt);
\r
377 $('.context-menu').each(function() {
\r
378 var $menu = $(this);
\r
379 var $trigger = $menu.find('.context-menu-trigger');
\r
380 var $dropdown = $menu.find('.context-menu-dropdown');
\r
382 $trigger.click(function() {
\r
383 $dropdown.slideToggle('fast', function() {
\r
384 if ($dropdown.is(':visible')) {
\r
385 $dropdown.one('clickoutside', function() {
\r
386 if ($dropdown.is(':visible'))
\r
387 $dropdown.slideUp('fast');
\r
394 $('div.comment-form-container').each(function() {
\r
395 var $container = $(this);
\r
396 var $comment_tools = $container.parent().find('.comment-tools');
\r
397 var $comments_container = $container.parent().find('.comments-container');
\r
399 var $form = $container.find('form');
\r
401 if ($form.length) {
\r
402 var $textarea = $container.find('textarea');
\r
403 var textarea = $textarea.get(0);
\r
404 var $button = $container.find('.comment-submit');
\r
405 var $cancel = $container.find('.comment-cancel');
\r
406 var $chars_left_message = $container.find('.comments-chars-left-msg');
\r
407 var $chars_togo_message = $container.find('.comments-chars-togo-msg');
\r
408 var $chars_counter = $container.find('.comments-char-left-count');
\r
410 var $add_comment_link = $comment_tools.find('.add-comment-link');
\r
412 var chars_limits = $chars_counter.html().split('|');
\r
414 var min_length = parseInt(chars_limits[0]);
\r
415 var max_length = parseInt(chars_limits[1]);
\r
417 var warn_length = max_length - 30;
\r
418 var current_length = 0;
\r
419 var comment_in_form = false;
\r
420 var interval = null;
\r
422 var hcheck = !($.browser.msie || $.browser.opera);
\r
424 $textarea.css("padding-top", 0).css("padding-bottom", 0).css("resize", "none");
\r
425 textarea.style.overflow = 'hidden';
\r
428 function cleanup_form() {
\r
430 $textarea.css('height', 80);
\r
431 $chars_counter.html(max_length);
\r
432 $chars_left_message.removeClass('warn');
\r
433 comment_in_form = false;
\r
434 current_length = 0;
\r
436 $chars_left_message.hide();
\r
437 $chars_togo_message.show();
\r
439 $chars_counter.removeClass('warn');
\r
440 $chars_counter.html(min_length);
\r
441 $button.attr("disabled","disabled");
\r
448 function process_form_changes() {
\r
449 var length = $textarea.val().replace(/[ ]{2,}/g," ").length;
\r
451 if (current_length == length)
\r
454 if (length < warn_length && current_length >= warn_length) {
\r
455 $chars_counter.removeClass('warn');
\r
456 } else if (current_length < warn_length && length >= warn_length){
\r
457 $chars_counter.addClass('warn');
\r
460 if (length < min_length) {
\r
461 $chars_left_message.hide();
\r
462 $chars_togo_message.show();
\r
463 $chars_counter.html(min_length - length);
\r
465 length = $textarea.val().length;
\r
466 $chars_togo_message.hide();
\r
467 $chars_left_message.show();
\r
468 $chars_counter.html(max_length - length);
\r
471 if (length > max_length || length < min_length) {
\r
472 $button.attr("disabled","disabled");
\r
474 $button.removeAttr("disabled");
\r
477 var current_height = textarea.style.height;
\r
479 textarea.style.height = "0px";
\r
481 var h = Math.max(80, textarea.scrollHeight);
\r
482 textarea.style.height = current_height;
\r
483 $textarea.animate({height: h + 'px'}, 50);
\r
485 current_length = length;
\r
488 function show_comment_form() {
\r
489 $container.slideDown('slow');
\r
490 $add_comment_link.fadeOut('slow');
\r
492 interval = window.setInterval(function() {
\r
493 process_form_changes();
\r
497 function hide_comment_form() {
\r
498 if (interval != null) {
\r
499 window.clearInterval(interval);
\r
502 $container.slideUp('slow');
\r
503 $add_comment_link.fadeIn('slow');
\r
506 $add_comment_link.click(function(){
\r
508 show_comment_form();
\r
512 $('#' + $comments_container.attr('id') + ' .comment-edit').live('click', function() {
\r
513 var $link = $(this);
\r
514 var comment_id = /comment-(\d+)-edit/.exec($link.attr('id'))[1];
\r
515 var $comment = $('#comment-' + comment_id);
\r
517 comment_in_form = comment_id;
\r
519 $.get($link.attr('href'), function(data) {
\r
520 $textarea.val(data);
\r
523 $comment.slideUp('slow');
\r
524 show_comment_form();
\r
528 $button.click(function(evt) {
\r
529 if (running) return false;
\r
532 comment: $textarea.val()
\r
535 if (comment_in_form) {
\r
536 post_data['id'] = comment_in_form;
\r
540 $.post($form.attr('action'), post_data, function(data) {
\r
541 process_ajax_response(data, evt, function(error) {
\r
544 hide_comment_form();
\r
553 $cancel.click(function(event) {
\r
554 if (confirm("You will lose all of your changes in this comment. Do you still wish to proceed?")){
\r
555 if (comment_in_form) {
\r
556 $comment = $('#comment-' + comment_in_form).slideDown('slow');
\r
558 hide_comment_form();
\r
565 $comment_tools.find('.show-all-comments-link').click(function() {
\r
566 $comments_container.find('.not_top_scorer').slideDown('slow');
\r
567 $(this).fadeOut('slow');
\r
568 $comment_tools.find('.comments-showing').fadeOut('slow');
\r
573 if ($('#editor').length) {
\r
574 var $editor = $('#editor');
\r
575 var $previewer = $('#previewer');
\r
576 var $container = $('#editor-metrics');
\r
578 var initial_whitespace_rExp = /^[^A-Za-zА-Яа-я0-9]+/gi;
\r
579 var non_alphanumerics_rExp = rExp = /[^A-Za-zА-Яа-я0-9]+/gi;
\r
580 var editor_interval = null;
\r
582 $editor.focus(function() {
\r
583 if (editor_interval == null) {
\r
584 editor_interval = window.setInterval(function() {
\r
590 function recalc_metrics() {
\r
591 var text = $previewer.text();
\r
593 var char_count = text.length;
\r
594 var fullStr = text + " ";
\r
595 var left_trimmedStr = fullStr.replace(initial_whitespace_rExp, "");
\r
596 var cleanedStr = left_trimmedStr.replace(non_alphanumerics_rExp, " ");
\r
597 var splitString = cleanedStr.split(" ");
\r
598 var word_count = splitString.length - 1;
\r
600 var metrics = char_count + " " + (char_count == 1 ? messages.character : messages.characters);
\r
601 metrics += " / " + word_count + " " + (word_count == 1 ? messages.word : messages.words);
\r
602 $container.html(metrics);
\r
607 //var scriptUrl, interestingTags, ignoredTags, tags, $;
\r
608 function pickedTags(){
\r
610 var sendAjax = function(tagname, reason, action, callback){
\r
611 var url = scriptUrl;
\r
612 if (action == 'add'){
\r
613 url += $.i18n._('mark-tag/');
\r
614 if (reason == 'good'){
\r
615 url += $.i18n._('interesting/');
\r
618 url += $.i18n._('ignored/');
\r
622 url += $.i18n._('unmark-tag/');
\r
624 url = url + tagname + '/';
\r
626 var call_settings = {
\r
631 if (callback !== false){
\r
632 call_settings.success = callback;
\r
634 $.ajax(call_settings);
\r
638 var unpickTag = function(from_target ,tagname, reason, send_ajax){
\r
639 //send ajax request to delete tag
\r
640 var deleteTagLocally = function(){
\r
641 from_target[tagname].remove();
\r
642 delete from_target[tagname];
\r
645 sendAjax(tagname,reason,'remove',deleteTagLocally);
\r
648 deleteTagLocally();
\r
653 var setupTagDeleteEvents = function(obj,tag_store,tagname,reason,send_ajax){
\r
654 obj.unbind('mouseover').bind('mouseover', function(){
\r
655 $(this).attr('src', mediaUrl('media/images/close-small-hover.png'));
\r
657 obj.unbind('mouseout').bind('mouseout', function(){
\r
658 $(this).attr('src', mediaUrl('media/images/close-small-dark.png'));
\r
660 obj.click( function(){
\r
661 unpickTag(tag_store,tagname,reason,send_ajax);
\r
665 var handlePickedTag = function(obj,reason){
\r
666 var tagname = $.trim($(obj).prev().attr('value'));
\r
667 var to_target = interestingTags;
\r
668 var from_target = ignoredTags;
\r
669 var to_tag_container;
\r
670 if (reason == 'bad'){
\r
671 to_target = ignoredTags;
\r
672 from_target = interestingTags;
\r
673 to_tag_container = $('div .tags.ignored');
\r
675 else if (reason != 'good'){
\r
679 to_tag_container = $('div .tags.interesting');
\r
682 if (tagname in from_target){
\r
683 unpickTag(from_target,tagname,reason,false);
\r
686 if (!(tagname in to_target)){
\r
687 //send ajax request to pick this tag
\r
689 sendAjax(tagname,reason,'add',function(){
\r
690 var new_tag = $('<span></span>');
\r
691 new_tag.addClass('deletable-tag');
\r
692 var tag_link = $('<a></a>');
\r
693 tag_link.attr('rel','tag');
\r
694 tag_link.attr('href', scriptUrl + $.i18n._('tags/') + tagname + '/');
\r
695 tag_link.html(tagname);
\r
696 var del_link = $('<img></img>');
\r
697 del_link.addClass('delete-icon');
\r
698 del_link.attr('src', mediaUrl('media/images/close-small-dark.png'));
\r
700 setupTagDeleteEvents(del_link, to_target, tagname, reason, true);
\r
702 new_tag.append(tag_link);
\r
703 new_tag.append(del_link);
\r
704 to_tag_container.append(new_tag);
\r
706 to_target[tagname] = new_tag;
\r
711 var collectPickedTags = function(){
\r
712 var good_prefix = 'interesting-tag-';
\r
713 var bad_prefix = 'ignored-tag-';
\r
714 var good_re = RegExp('^' + good_prefix);
\r
715 var bad_re = RegExp('^' + bad_prefix);
\r
716 interestingTags = {};
\r
718 $('.deletable-tag').each(
\r
720 var item_id = $(item).attr('id');
\r
721 var tag_name, tag_store;
\r
722 if (good_re.test(item_id)){
\r
723 tag_name = item_id.replace(good_prefix,'');
\r
724 tag_store = interestingTags;
\r
727 else if (bad_re.test(item_id)){
\r
728 tag_name = item_id.replace(bad_prefix,'');
\r
729 tag_store = ignoredTags;
\r
735 tag_store[tag_name] = $(item);
\r
736 setupTagDeleteEvents($(item).find('img'),tag_store,tag_name,reason,true);
\r
741 var setupHideIgnoredQuestionsControl = function(){
\r
742 $('#hideIgnoredTagsCb').unbind('click').click(function(){
\r
747 url: scriptUrl + $.i18n._('command/'),
\r
748 data: {command:'toggle-ignored-questions'}
\r
754 collectPickedTags();
\r
755 setupHideIgnoredQuestionsControl();
\r
756 $("#interestingTagInput, #ignoredTagInput").autocomplete(messages.matching_tags_url, {
\r
758 matchContains: true,
\r
760 /*multiple: false, - the favorite tags and ignore tags don't let you do multiple tags
\r
761 multipleSeparator: " "*/
\r
763 formatItem: function(row, i, max, value) {
\r
764 return row[1] + " (" + row[2] + ")";
\r
767 formatResult: function(row, i, max, value){
\r
772 $("#interestingTagAdd").click(function(){handlePickedTag(this,'good');});
\r
773 $("#ignoredTagAdd").click(function(){handlePickedTag(this,'bad');});
\r
778 Hilite={elementid:"content",exact:true,max_nodes:1000,onload:true,style_name:"hilite",style_name_suffix:true,debug_referrer:""};Hilite.search_engines=[["local","q"],["cnprog\\.","q"],["google\\.","q"],["search\\.yahoo\\.","p"],["search\\.msn\\.","q"],["search\\.live\\.","query"],["search\\.aol\\.","userQuery"],["ask\\.com","q"],["altavista\\.","q"],["feedster\\.","q"],["search\\.lycos\\.","q"],["alltheweb\\.","q"],["technorati\\.com/search/([^\\?/]+)",1],["dogpile\\.com/info\\.dogpl/search/web/([^\\?/]+)",1,true]];Hilite.decodeReferrer=function(d){var g=null;var e=new RegExp("");for(var c=0;c<Hilite.search_engines.length;c++){var f=Hilite.search_engines[c];e.compile("^http://(www\\.)?"+f[0],"i");var b=d.match(e);if(b){var a;if(isNaN(f[1])){a=Hilite.decodeReferrerQS(d,f[1])}else{a=b[f[1]+1]}if(a){a=decodeURIComponent(a);if(f.length>2&&f[2]){a=decodeURIComponent(a)}a=a.replace(/\'|"/g,"");a=a.split(/[\s,\+\.]+/);return a}break}}return null};Hilite.decodeReferrerQS=function(f,d){var b=f.indexOf("?");var c;if(b>=0){var a=new String(f.substring(b+1));b=0;c=0;while((b>=0)&&((c=a.indexOf("=",b))>=0)){var e,g;e=a.substring(b,c);b=a.indexOf("&",c)+1;if(e==d){if(b<=0){return a.substring(c+1)}else{return a.substring(c+1,b-1)}}else{if(b<=0){return null}}}}return null};Hilite.hiliteElement=function(f,e){if(!e||f.childNodes.length==0){return}var c=new Array();for(var b=0;b<e.length;b++){e[b]=e[b].toLowerCase();if(Hilite.exact){c.push("\\b"+e[b]+"\\b")}else{c.push(e[b])}}c=new RegExp(c.join("|"),"i");var a={};for(var b=0;b<e.length;b++){if(Hilite.style_name_suffix){a[e[b]]=Hilite.style_name+(b+1)}else{a[e[b]]=Hilite.style_name}}var d=function(m){var j=c.exec(m.data);if(j){var n=j[0];var i="";var h=m.splitText(j.index);var g=h.splitText(n.length);var l=m.ownerDocument.createElement("SPAN");m.parentNode.replaceChild(l,h);l.className=a[n.toLowerCase()];l.appendChild(h);return l}else{return m}};Hilite.walkElements(f.childNodes[0],1,d)};Hilite.hilite=function(){var a=Hilite.debug_referrer?Hilite.debug_referrer:document.referrer;var b=null;a=Hilite.decodeReferrer(a);if(a&&((Hilite.elementid&&(b=document.getElementById(Hilite.elementid)))||(b=document.body))){Hilite.hiliteElement(b,a)}};Hilite.walkElements=function(d,f,e){var a=/^(script|style|textarea)/i;var c=0;while(d&&f>0){c++;if(c>=Hilite.max_nodes){var b=function(){Hilite.walkElements(d,f,e)};setTimeout(b,50);return}if(d.nodeType==1){if(!a.test(d.tagName)&&d.childNodes.length>0){d=d.childNodes[0];f++;continue}}else{if(d.nodeType==3){d=e(d)}}if(d.nextSibling){d=d.nextSibling}else{while(f>0){d=d.parentNode;f--;if(d.nextSibling){d=d.nextSibling;break}}}}};if(Hilite.onload){if(window.attachEvent){window.attachEvent("onload",Hilite.hilite)}else{if(window.addEventListener){window.addEventListener("load",Hilite.hilite,false)}else{var __onload=window.onload;window.onload=function(){Hilite.hilite();__onload()}}}};
\r
780 var mediaUrl = function(resource){
\r
781 return scriptUrl + 'm/' + osqaSkin + '/' + resource;
\r
785 * jQuery i18n plugin
\r
786 * @requires jQuery v1.1 or later
\r
788 * Examples at: http://recurser.com/articles/2008/02/21/jquery-i18n-translation-plugin/
\r
789 * Dual licensed under the MIT and GPL licenses:
\r
790 * http://www.opensource.org/licenses/mit-license.php
\r
791 * http://www.gnu.org/licenses/gpl.html
\r
793 * Based on 'javascript i18n that almost doesn't suck' by markos
\r
794 * http://markos.gaivo.net/blog/?p=100
\r
797 * Version: 1.0.0 Feb-10-2008
\r
801 * i18n provides a mechanism for translating strings using a jscript dictionary.
\r
807 * i18n property list
\r
813 * Initialise the dictionary and translate nodes
\r
815 * @param property_list i18n_dict : The dictionary to use for translation
\r
817 setDictionary: function(i18n_dict) {
\r
818 i18n_dict = i18n_dict;
\r
823 * The actual translation function. Looks the given string up in the
\r
824 * dictionary and returns the translation if one exists. If a translation
\r
825 * is not found, returns the original word
\r
827 * @param string str : The string to translate
\r
828 * @param property_list params : params for using printf() on the string
\r
829 * @return string : Translated word
\r
832 _: function (str, params) {
\r
834 if (i18n_dict&& i18n_dict[str]) {
\r
835 transl = i18n_dict[str];
\r
837 return this.printf(transl, params);
\r
842 * Change non-ASCII characters to entity representation
\r
844 * @param string str : The string to transform
\r
845 * @return string result : Original string with non-ASCII content converted to entities
\r
848 toEntity: function (str) {
\r
850 for (var i=0;i<str.length; i++) {
\r
851 if (str.charCodeAt(i) > 128)
\r
852 result += "&#"+str.charCodeAt(i)+";";
\r
854 result += str.charAt(i);
\r
862 * @param string str : The string to strip
\r
863 * @return string result : Stripped string
\r
866 stripStr: function(str) {
\r
867 return str.replace(/^\s*/, "").replace(/\s*$/, "");
\r
873 * @param string str : The multi-line string to strip
\r
874 * @return string result : Stripped string
\r
877 stripStrML: function(str) {
\r
878 // Split because m flag doesn't exist before JS1.5 and we need to
\r
879 // strip newlines anyway
\r
880 var parts = str.split('\n');
\r
881 for (var i=0; i<parts.length; i++)
\r
882 parts[i] = stripStr(parts[i]);
\r
884 // Don't join with empty strings, because it "concats" words
\r
886 return stripStr(parts.join(" "));
\r
891 * C-printf like function, which substitutes %s with parameters
\r
892 * given in list. %%s is used to escape %s.
\r
894 * Doesn't work in IE5.0 (splice)
\r
896 * @param string S : string to perform printf on.
\r
897 * @param string L : Array of arguments for printf()
\r
899 printf: function(S, L) {
\r
903 var tS = S.split("%s");
\r
905 for(var i=0; i<L.length; i++) {
\r
906 if (tS[i].lastIndexOf('%') == tS[i].length-1 && i != L.length-1)
\r
907 tS[i] += "s"+tS.splice(i+1,1)[0];
\r
908 nS += tS[i] + L[i];
\r
910 return nS + tS[tS.length-1];
\r
921 'insufficient privilege':'??????????',
\r
922 'cannot pick own answer as best':'??????????????',
\r
923 'anonymous users cannot select favorite questions':'?????????????',
\r
924 'please login':'??????',
\r
925 'anonymous users cannot vote':'????????',
\r
926 '>15 points requried to upvote':'??+15?????????',
\r
927 '>100 points required to downvote':'??+100?????????',
\r
928 'please see': '??',
\r
929 'cannot vote for own posts':'??????????',
\r
930 'daily vote cap exhausted':'????????????????',
\r
931 'cannot revoke old vote':'??????????????',
\r
932 'please confirm offensive':"??????????????????????",
\r
933 'anonymous users cannot flag offensive posts':'???????????',
\r
934 'cannot flag message as offensive twice':'???????',
\r
935 'flag offensive cap exhausted':'?????????????5?
\91??
\92???',
\r
936 'need >15 points to report spam':"??+15??????
\91???
\92?",
\r
937 'confirm delete':"?????/????????",
\r
938 'anonymous users cannot delete/undelete':"???????????????",
\r
939 'post recovered':"?????????????",
\r
940 'post deleted':"????????????",
\r
941 'add comment':'????',
\r
942 'community karma points':'????',
\r
943 'to comment, need':'????',
\r
944 'delete this comment':'?????',
\r
945 'hide comments':"????",
\r
946 'add a comment':"????",
\r
948 'confirm delete comment':"?????????",
\r
951 'click to close':'???????',
\r
952 'loading...':'???...',
\r
953 'tags cannot be empty':'???????',
\r
954 'tablimits info':"??5????????????20????",
\r
955 'content cannot be empty':'???????',
\r
956 'content minchars': '????? {0} ???',
\r
957 'please enter title':'??????',
\r
958 'title minchars':"????? {0} ???",
\r
965 'preformatted text':'??',
\r
967 'numbered list':'??????',
\r
968 'bulleted list':'??????',
\r
970 'horizontal bar':'???',
\r
973 'enter image url':'<b>??????</b></p><p>???<br />http://www.example.com/image.jpg \"????\"',
\r
974 'enter url':'<b>??Web??</b></p><p>???<br />http://www.cnprog.com/ \"????\"</p>"',
\r
975 'upload image':'?????????'
\r
979 'need >15 points to report spam':'need >15 points to report spam ',
\r
980 '>15 points requried to upvote':'>15 points required to upvote ',
\r
981 'tags cannot be empty':'please enter at least one tag',
\r
982 'anonymous users cannot vote':'sorry, anonymous users cannot vote ',
\r
983 'anonymous users cannot select favorite questions':'sorry, anonymous users cannot select favorite questions ',
\r
984 'to comment, need': '(to comment other people\'s posts, karma ',
\r
985 'please see':'please see ',
\r
986 'community karma points':' or more is necessary) - ',
\r
987 'upload image':'Upload image:',
\r
988 'enter image url':'enter URL of the image, e.g. http://www.example.com/image.jpg \"image title\"',
\r
989 'enter url':'enter Web address, e.g. http://www.example.com \"page title\"',
\r
990 'daily vote cap exhausted':'sorry, you\'ve used up todays vote cap',
\r
991 'cannot pick own answer as best':'sorry, you cannot accept your own answer',
\r
992 'cannot revoke old vote':'sorry, older votes cannot be revoked',
\r
993 'please confirm offensive':'are you sure this post is offensive, contains spam, advertising, malicious remarks, etc.?',
\r
994 'flag offensive cap exhausted':'sorry, you\'ve used up todays cap of flagging offensive messages ',
\r
995 'confirm delete':'are you sure you want to delete this?',
\r
996 'anonymous users cannot delete/undelete':'sorry, anonymous users cannot delete or undelete posts',
\r
997 'post recovered':'your post is now restored!',
\r
998 'post deleted':'your post has been deleted',
\r
999 'confirm delete comment':'do you really want to delete this comment?',
\r
1000 'can write':'have ',
\r
1001 'tablimits info':'up to 5 tags, no more than 20 characters each',
\r
1002 'content minchars': 'please enter more than {0} characters',
\r
1003 'title minchars':"please enter at least {0} characters",
\r
1004 'characters':'characters left',
\r
1005 'cannot vote for own posts':'sorry, you cannot vote for your own posts',
\r
1006 'cannot flag message as offensive twice':'cannot flag message as offensive twice ',
\r
1007 '>100 points required to downvote':'>100 points required to downvote '
\r
1011 'insufficient privilege':'privilegio insuficiente',
\r
1012 'cannot pick own answer as best':'no puede escoger su propia respuesta como la mejor',
\r
1013 'anonymous users cannot select favorite questions':'usuarios anonimos no pueden seleccionar',
\r
1014 'please login':'por favor inicie sesión',
\r
1015 'anonymous users cannot vote':'usuarios anónimos no pueden votar',
\r
1016 '>15 points requried to upvote': '>15 puntos requeridos para votar positivamente',
\r
1017 '>100 points required to downvote':'>100 puntos requeridos para votar negativamente',
\r
1018 'please see': 'por favor vea',
\r
1019 'cannot vote for own posts':'no se puede votar por sus propias publicaciones',
\r
1020 'daily vote cap exhausted':'cuota de votos diarios excedida',
\r
1021 'cannot revoke old vote':'no puede revocar un voto viejo',
\r
1022 'please confirm offensive':"por favor confirme ofensiva",
\r
1023 'anonymous users cannot flag offensive posts':'usuarios anónimos no pueden marcar publicaciones como ofensivas',
\r
1024 'cannot flag message as offensive twice':'no puede marcar mensaje como ofensivo dos veces',
\r
1025 'flag offensive cap exhausted':'cuota para marcar ofensivas ha sido excedida',
\r
1026 'need >15 points to report spam':"necesita >15 puntos para reportar spam",
\r
1027 'confirm delete':"¿Está seguro que desea borrar esto?",
\r
1028 'anonymous users cannot delete/undelete':"usuarios anónimos no pueden borrar o recuperar publicaciones",
\r
1029 'post recovered':"publicación recuperada",
\r
1030 'post deleted':"publicación borrada?",
\r
1031 'add comment':'agregar comentario',
\r
1032 'community karma points':'reputación comunitaria',
\r
1033 'to comment, need':'para comentar, necesita reputación',
\r
1034 'delete this comment':'borrar este comentario',
\r
1035 'hide comments':"ocultar comentarios",
\r
1036 'add a comment':"agregar comentarios",
\r
1037 'comments':"comentarios",
\r
1038 'confirm delete comment':"¿Realmente desea borrar este comentario?",
\r
1039 'characters':'caracteres faltantes',
\r
1040 'can write':'tiene ',
\r
1041 'click to close':'haga click para cerrar',
\r
1042 'loading...':'cargando...',
\r
1043 'tags cannot be empty':'las etiquetas no pueden estar vacías',
\r
1044 'tablimits info':"hasta 5 etiquetas de no mas de 20 caracteres cada una",
\r
1045 'content cannot be empty':'el contenido no puede estar vacío',
\r
1046 'content minchars': 'por favor introduzca mas de {0} caracteres',
\r
1047 'please enter title':'por favor ingrese un título',
\r
1048 'title minchars':"por favor introduzca al menos {0} caracteres",
\r
1049 'delete':'borrar',
\r
1050 'undelete': 'recuperar',
\r
1051 'bold': 'negrita',
\r
1052 'italic':'cursiva',
\r
1055 'preformatted text':'texto preformateado',
\r
1057 'numbered list':'lista numerada',
\r
1058 'bulleted list':'lista no numerada',
\r
1060 'horizontal bar':'barra horizontal',
\r
1061 'undo':'deshacer',
\r
1063 'enter image url':'introduzca la URL de la imagen, por ejemplo?<br />http://www.example.com/image.jpg \"titulo de imagen\"',
\r
1064 'enter url':'introduzca direcciones web, ejemplo?<br />http://www.cnprog.com/ \"titulo del enlace\"</p>"',
\r
1065 'upload image':'cargar imagen?',
\r
1066 'questions/' : 'preguntas/',
\r
1067 'vote/' : 'votar/'
\r
1076 var i18n_dict = i18n[i18nLang];
\r
1079 jQuery TextAreaResizer plugin
\r
1080 Created on 17th January 2008 by Ryan O'Dell
\r
1082 */(function($){var textarea,staticOffset;var iLastMousePos=0;var iMin=32;var grip;$.fn.TextAreaResizer=function(){return this.each(function(){textarea=$(this).addClass('processed'),staticOffset=null;$(this).wrap('<div class="resizable-textarea"><span></span></div>').parent().append($('<div class="grippie"></div>').bind("mousedown",{el:this},startDrag));var grippie=$('div.grippie',$(this).parent())[0];grippie.style.marginRight=(grippie.offsetWidth-$(this)[0].offsetWidth)+'px'})};function startDrag(e){textarea=$(e.data.el);textarea.blur();iLastMousePos=mousePosition(e).y;staticOffset=textarea.height()-iLastMousePos;textarea.css('opacity',0.25);$(document).mousemove(performDrag).mouseup(endDrag);return false}function performDrag(e){var iThisMousePos=mousePosition(e).y;var iMousePos=staticOffset+iThisMousePos;if(iLastMousePos>=(iThisMousePos)){iMousePos-=5}iLastMousePos=iThisMousePos;iMousePos=Math.max(iMin,iMousePos);textarea.height(iMousePos+'px');if(iMousePos<iMin){endDrag(e)}return false}function endDrag(e){$(document).unbind('mousemove',performDrag).unbind('mouseup',endDrag);textarea.css('opacity',1);textarea.focus();textarea=null;staticOffset=null;iLastMousePos=0}function mousePosition(e){return{x:e.clientX+document.documentElement.scrollLeft,y:e.clientY+document.documentElement.scrollTop}}})(jQuery);
\r
1084 * Autocomplete - jQuery plugin 1.0.3
\r
1086 * Copyright (c) 2007 Dylan Verheul, Dan G. Switzer, Anjesh Tuladhar, Jörn Zaefferer
\r
1088 * Dual licensed under the MIT and GPL licenses:
\r
1089 * http://www.opensource.org/licenses/mit-license.php
\r
1090 * http://www.gnu.org/licenses/gpl.html
\r
1093 (function(a){a.fn.extend({autocomplete:function(b,c){var d=typeof b=="string";c=a.extend({},a.Autocompleter.defaults,{url:d?b:null,data:d?null:b,delay:d?a.Autocompleter.defaults.delay:10,max:c&&!c.scroll?10:150},c);c.highlight=c.highlight||function(e){return e};c.formatMatch=c.formatMatch||c.formatItem;return this.each(function(){new a.Autocompleter(this,c)})},result:function(b){return this.bind("result",b)},search:function(b){return this.trigger("search",[b])},flushCache:function(){return this.trigger("flushCache")},setOptions:function(b){return this.trigger("setOptions",[b])},unautocomplete:function(){return this.trigger("unautocomplete")}});a.Autocompleter=function(l,g){var c={UP:38,DOWN:40,DEL:46,TAB:9,RETURN:13,ESC:27,COMMA:188,PAGEUP:33,PAGEDOWN:34,BACKSPACE:8};var b=a(l).attr("autocomplete","off").addClass(g.inputClass);var j;var p="";var m=a.Autocompleter.Cache(g);var e=0;var u;var x={mouseDownOnSelect:false};var r=a.Autocompleter.Select(g,l,d,x);var w;a.browser.opera&&a(l.form).bind("submit.autocomplete",function(){if(w){w=false;return false}});b.bind((a.browser.opera?"keypress":"keydown")+".autocomplete",function(y){u=y.keyCode;switch(y.keyCode){case c.UP:y.preventDefault();if(r.visible()){r.prev()}else{t(0,true)}break;case c.DOWN:y.preventDefault();if(r.visible()){r.next()}else{t(0,true)}break;case c.PAGEUP:y.preventDefault();if(r.visible()){r.pageUp()}else{t(0,true)}break;case c.PAGEDOWN:y.preventDefault();if(r.visible()){r.pageDown()}else{t(0,true)}break;case g.multiple&&a.trim(g.multipleSeparator)==","&&c.COMMA:case c.TAB:case c.RETURN:if(d()){y.preventDefault();w=true;return false}break;case c.ESC:r.hide();break;default:clearTimeout(j);j=setTimeout(t,g.delay);break}}).focus(function(){e++}).blur(function(){e=0;if(!x.mouseDownOnSelect){s()}}).click(function(){if(e++>1&&!r.visible()){t(0,true)}}).bind("search",function(){var y=(arguments.length>1)?arguments[1]:null;function z(D,C){var A;if(C&&C.length){for(var B=0;B<C.length;B++){if(C[B].result.toLowerCase()==D.toLowerCase()){A=C[B];break}}}if(typeof y=="function"){y(A)}else{b.trigger("result",A&&[A.data,A.value])}}a.each(h(b.val()),function(A,B){f(B,z,z)})}).bind("flushCache",function(){m.flush()}).bind("setOptions",function(){a.extend(g,arguments[1]);if("data" in arguments[1]){m.populate()}}).bind("unautocomplete",function(){r.unbind();b.unbind();a(l.form).unbind(".autocomplete")});function d(){var z=r.selected();if(!z){return false}var y=z.result;p=y;if(g.multiple){var A=h(b.val());if(A.length>1){y=A.slice(0,A.length-1).join(g.multipleSeparator)+g.multipleSeparator+y}y+=g.multipleSeparator}b.val(y);v();b.trigger("result",[z.data,z.value]);return true}function t(A,z){if(u==c.DEL){r.hide();return}var y=b.val();if(!z&&y==p){return}p=y;y=i(y);if(y.length>=g.minChars){b.addClass(g.loadingClass);if(!g.matchCase){y=y.toLowerCase()}f(y,k,v)}else{n();r.hide()}}function h(z){if(!z){return[""]}var A=z.split(g.multipleSeparator);var y=[];a.each(A,function(B,C){if(a.trim(C)){y[B]=a.trim(C)}});return y}function i(y){if(!g.multiple){return y}var z=h(y);return z[z.length-1]}function q(y,z){if(g.autoFill&&(i(b.val()).toLowerCase()==y.toLowerCase())&&u!=c.BACKSPACE){b.val(b.val()+z.substring(i(p).length));a.Autocompleter.Selection(l,p.length,p.length+z.length)}}function s(){clearTimeout(j);j=setTimeout(v,200)}function v(){var y=r.visible();r.hide();clearTimeout(j);n();if(g.mustMatch){b.search(function(z){if(!z){if(g.multiple){var A=h(b.val()).slice(0,-1);b.val(A.join(g.multipleSeparator)+(A.length?g.multipleSeparator:""))}else{b.val("")}}})}if(y){a.Autocompleter.Selection(l,l.value.length,l.value.length)}}function k(z,y){if(y&&y.length&&e){n();r.display(y,z);q(z,y[0].value);r.show()}else{v()}}function f(z,B,y){if(!g.matchCase){z=z.toLowerCase()}var A=m.load(z);if(A&&A.length){B(z,A)}else{if((typeof g.url=="string")&&(g.url.length>0)){var C={timestamp:+new Date()};a.each(g.extraParams,function(D,E){C[D]=typeof E=="function"?E():E});a.ajax({mode:"abort",port:"autocomplete"+l.name,dataType:g.dataType,url:g.url,data:a.extend({q:i(z),limit:g.max},C),success:function(E){var D=g.parse&&g.parse(E)||o(E);m.add(z,D);B(z,D)}})}else{r.emptyList();y(z)}}}function o(B){var y=[];var A=B.split("\n");for(var z=0;z<A.length;z++){var C=a.trim(A[z]);if(C){C=C.split("|");y[y.length]={data:C,value:C[0],result:g.formatResult&&g.formatResult(C,C[0])||C[0]}}}return y}function n(){b.removeClass(g.loadingClass)}};a.Autocompleter.defaults={inputClass:"ac_input",resultsClass:"ac_results",loadingClass:"ac_loading",minChars:1,delay:400,matchCase:false,matchSubset:true,matchContains:false,cacheLength:10,max:100,mustMatch:false,extraParams:{},selectFirst:true,formatItem:function(b){return b[0]},formatMatch:null,autoFill:false,width:0,multiple:false,multipleSeparator:", ",highlight:function(c,b){return c.replace(new RegExp("(?![^&;]+;)(?!<[^<>]*)("+b.replace(/([\^\$\(\)\[\]\{\}\*\.\+\?\|\\])/gi,"\\$1")+")(?![^<>]*>)(?![^&;]+;)","gi"),"<strong>$1</strong>")},scroll:true,scrollHeight:180};a.Autocompleter.Cache=function(c){var f={};var d=0;function h(l,k){if(!c.matchCase){l=l.toLowerCase()}var j=l.indexOf(k);if(j==-1){return false}return j==0||c.matchContains}function g(j,i){if(d>c.cacheLength){b()}if(!f[j]){d++}f[j]=i}function e(){if(!c.data){return false}var k={},j=0;if(!c.url){c.cacheLength=1}k[""]=[];for(var m=0,l=c.data.length;m<l;m++){var p=c.data[m];p=(typeof p=="string")?[p]:p;var o=c.formatMatch(p,m+1,c.data.length);if(o===false){continue}var n=o.charAt(0).toLowerCase();if(!k[n]){k[n]=[]}var q={value:o,data:p,result:c.formatResult&&c.formatResult(p)||o};k[n].push(q);if(j++<c.max){k[""].push(q)}}a.each(k,function(r,s){c.cacheLength++;g(r,s)})}setTimeout(e,25);function b(){f={};d=0}return{flush:b,add:g,populate:e,load:function(n){if(!c.cacheLength||!d){return null}if(!c.url&&c.matchContains){var m=[];for(var j in f){if(j.length>0){var o=f[j];a.each(o,function(p,k){if(h(k.value,n)){m.push(k)}})}}return m}else{if(f[n]){return f[n]}else{if(c.matchSubset){for(var l=n.length-1;l>=c.minChars;l--){var o=f[n.substr(0,l)];if(o){var m=[];a.each(o,function(p,k){if(h(k.value,n)){m[m.length]=k}});return m}}}}}return null}}};a.Autocompleter.Select=function(e,j,l,p){var i={ACTIVE:"ac_over"};var k,f=-1,r,m="",s=true,c,o;function n(){if(!s){return}c=a("<div/>").hide().addClass(e.resultsClass).css("position","absolute").appendTo(document.body);o=a("<ul/>").appendTo(c).mouseover(function(t){if(q(t).nodeName&&q(t).nodeName.toUpperCase()=="LI"){f=a("li",o).removeClass(i.ACTIVE).index(q(t));a(q(t)).addClass(i.ACTIVE)}}).click(function(t){a(q(t)).addClass(i.ACTIVE);l();j.focus();return false}).mousedown(function(){p.mouseDownOnSelect=true}).mouseup(function(){p.mouseDownOnSelect=false});if(e.width>0){c.css("width",e.width)}s=false}function q(u){var t=u.target;while(t&&t.tagName!="LI"){t=t.parentNode}if(!t){return[]}return t}function h(t){k.slice(f,f+1).removeClass(i.ACTIVE);g(t);var v=k.slice(f,f+1).addClass(i.ACTIVE);if(e.scroll){var u=0;k.slice(0,f).each(function(){u+=this.offsetHeight});if((u+v[0].offsetHeight-o.scrollTop())>o[0].clientHeight){o.scrollTop(u+v[0].offsetHeight-o.innerHeight())}else{if(u<o.scrollTop()){o.scrollTop(u)}}}}function g(t){f+=t;if(f<0){f=k.size()-1}else{if(f>=k.size()){f=0}}}function b(t){return e.max&&e.max<t?e.max:t}function d(){o.empty();var u=b(r.length);for(var v=0;v<u;v++){if(!r[v]){continue}var w=e.formatItem(r[v].data,v+1,u,r[v].value,m);if(w===false){continue}var t=a("<li/>").html(e.highlight(w,m)).addClass(v%2==0?"ac_even":"ac_odd").appendTo(o)[0];a.data(t,"ac_data",r[v])}k=o.find("li");if(e.selectFirst){k.slice(0,1).addClass(i.ACTIVE);f=0}if(a.fn.bgiframe){o.bgiframe()}}return{display:function(u,t){n();r=u;m=t;d()},next:function(){h(1)},prev:function(){h(-1)},pageUp:function(){if(f!=0&&f-8<0){h(-f)}else{h(-8)}},pageDown:function(){if(f!=k.size()-1&&f+8>k.size()){h(k.size()-1-f)}else{h(8)}},hide:function(){c&&c.hide();k&&k.removeClass(i.ACTIVE);f=-1},visible:function(){return c&&c.is(":visible")},current:function(){return this.visible()&&(k.filter("."+i.ACTIVE)[0]||e.selectFirst&&k[0])},show:function(){var v=a(j).offset();c.css({width:typeof e.width=="string"||e.width>0?e.width:a(j).width(),top:v.top+j.offsetHeight,left:v.left}).show();if(e.scroll){o.scrollTop(0);o.css({maxHeight:e.scrollHeight,overflow:"auto"});if(a.browser.msie&&typeof document.body.style.maxHeight==="undefined"){var t=0;k.each(function(){t+=this.offsetHeight});var u=t>e.scrollHeight;o.css("height",u?e.scrollHeight:t);if(!u){k.width(o.width()-parseInt(k.css("padding-left"))-parseInt(k.css("padding-right")))}}}},selected:function(){var t=k&&k.filter("."+i.ACTIVE).removeClass(i.ACTIVE);return t&&t.length&&a.data(t[0],"ac_data")},emptyList:function(){o&&o.empty()},unbind:function(){c&&c.remove()}}};a.Autocompleter.Selection=function(d,e,c){if(d.setSelectionRange){d.setSelectionRange(e,c)}else{if(d.createTextRange){var b=d.createTextRange();b.collapse(true);b.moveStart("character",e);b.moveEnd("character",c);b.select()}else{if(d.selectionStart){d.selectionStart=e;d.selectionEnd=c}}}d.focus()}})(jQuery);
\r
1095 var notify = function() {
\r
1096 var visible = false;
\r
1098 show: function(html) {
\r
1100 $("body").css("margin-top", "2.2em");
\r
1101 $(".notify span").html(html);
\r
1103 $(".notify").fadeIn("slow");
\r
1106 close: function(doPostback) {
\r
1107 $(".notify").fadeOut("fast");
\r
1108 $("body").css("margin-top", "0");
\r
1111 isVisible: function() { return visible; }
\r
1116 * jQuery outside events - v1.1 - 3/16/2010
\r
1117 * http://benalman.com/projects/jquery-outside-events-plugin/
\r
1119 * Copyright (c) 2010 "Cowboy" Ben Alman
\r
1120 * Dual licensed under the MIT and GPL licenses.
\r
1121 * http://benalman.com/about/license/
\r
1123 (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");
\r
1125 $(document).ready( function(){
\r
1126 pickedTags().init();
\r
1128 $('input#bnewaccount').click(function() {
\r
1129 $('#bnewaccount').disabled=true;
\r
1133 function yourWorkWillBeLost(e) {
\r
1134 if(browserTester('chrome')) {
\r
1135 return "Are you sure you want to leave? Your work will be lost.";
\r
1136 } else if(browserTester('safari')) {
\r
1137 return "Are you sure you want to leave? Your work will be lost.";
\r
1139 if(!e) e = window.event;
\r
1140 e.cancelBubble = true;
\r
1141 e.returnValue = 'If you leave, your work will be lost.';
\r
1143 if (e.stopPropagation) {
\r
1144 e.stopPropagation();
\r
1145 e.preventDefault();
\r
1151 function browserTester(browserString) {
\r
1152 return navigator.userAgent.toLowerCase().indexOf(browserString) > -1;
\r
1155 // Add missing IE functionality
\r
1156 if (!window.addEventListener) {
\r
1157 if (window.attachEvent) {
\r
1158 window.addEventListener = function (type, listener, useCapture) {
\r
1159 window.attachEvent('on' + type, listener);
\r
1161 window.removeEventListener = function (type, listener, useCapture) {
\r
1162 window.detachEvent('on' + type, listener);
\r
1165 window.addEventListener = function (type, listener, useCapture) {
\r
1166 window['on' + type] = listener;
\r
1168 window.removeEventListener = function (type, listener, useCapture) {
\r
1169 window['on' + type] = null;
\r