X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fclient_js.js;h=c9a152459c33041a36b3356fb162c95159baa9d7;hb=73f7989fcf23410ebd879d5150f6a13913ca2b90;hp=e5fdcb5788686fd31b0ca18f0f8023201c1e667e;hpb=824f9ddf5ac3c5d8f46fa8a3bcd49456aa9f0e22;p=kivitendo-erp.git diff --git a/js/client_js.js b/js/client_js.js index e5fdcb578..c9a152459 100644 --- a/js/client_js.js +++ b/js/client_js.js @@ -5,9 +5,27 @@ // SL/ClientJS.pm for instructions. namespace("kivi", function(ns) { -ns.display_flash = function(type, message) { +ns.display_flash = function(type, message, noscroll) { $('#flash_' + type + '_content').text(message); $('#flash_' + type).show(); + if (!noscroll && $('#frame-header')[0]) { + $('#frame-header')[0].scrollIntoView(); + } +}; + +ns.display_flash_detail = function(type, message) { + $('#flash_' + type + '_detail').html(message); + $('#flash_' + type + '_disp').show(); +}; + +ns.clear_flash = function(category , timeout) { + window.setTimeout(function(){ + $('#flash_' + category).hide(); + $('#flash_detail_' + category).hide(); + $('#flash_' + category + '_disp').hide(); + $('#flash_' + category + '_content').empty(); + $('#flash_' + category + '_detail').empty(); + }, timeout); }; ns.eval_json_result = function(data) { @@ -17,25 +35,27 @@ ns.eval_json_result = function(data) { if (data.error) return ns.display_flash('error', data.error); - $(['info', 'warning', 'error']).each(function(idx, category) { - $('#flash_' + category).hide(); - $('#flash_' + category + '_content').empty(); - }); - - if ((data.js || '') != '') + if (!data.no_flash_clear) { + $(['info', 'warning', 'error']).each(function(idx, category) { + $('#flash_' + category).hide(); + $('#flash_detail_' + category).hide(); + $('#flash_' + category + '_disp').hide(); + $('#flash_' + category + '_content').empty(); + $('#flash_' + category + '_detail').empty(); + }); + } + if ((data.js || '') !== '') + // jshint -W061 eval(data.js); + // jshint +W061 if (data.eval_actions) $(data.eval_actions).each(function(idx, action) { // console.log("ACTION " + action[0] + " ON " + action[1]); - // ## Non-jQuery methods ## - if (action[0] == 'flash') kivi.display_flash(action[1], action[2]); - // ## jQuery basics ## - // Basic effects - else if (action[0] == 'hide') $(action[1]).hide(); + if (action[0] == 'hide') $(action[1]).hide(); else if (action[0] == 'show') $(action[1]).show(); else if (action[0] == 'toggle') $(action[1]).toggle(); @@ -84,17 +104,21 @@ ns.eval_json_result = function(data) { else if (action[0] == 'removeData') $(action[1]).removeData(action[2]); // Form Events - else if (action[0] == 'focus') $(action[1]).focus(); + else if (action[0] == 'focus') kivi.set_focus(action[1]); // Generic Event Handling ## else if (action[0] == 'on') $(action[1]).on(action[2], kivi.get_function_by_name(action[3])); else if (action[0] == 'off') $(action[1]).off(action[2], kivi.get_function_by_name(action[3])); else if (action[0] == 'one') $(action[1]).one(action[2], kivi.get_function_by_name(action[3])); - // ## jqModal plugin ## + // ## jQuery UI dialog plugin ## - // Closing and removing the popup - else if (action[0] == 'jqmClose') $(action[1]).jqmClose(); + // Opening and closing a popup + else if (action[0] == 'dialog:open') kivi.popup_dialog(action[1]); + else if (action[0] == 'dialog:close') $(action[1]).dialog('close'); + + // ## jQuery Form plugin ## + else if (action[0] == 'ajaxForm') $(action[1]).ajaxForm({ success: eval_json_result }); // ## jstree plugin ## @@ -122,9 +146,20 @@ ns.eval_json_result = function(data) { else if (action[0] == 'jstree:deselect_node') $.jstree._reference($(action[1])).deselect_node(action[2]); else if (action[0] == 'jstree:deselect_all') $.jstree._reference($(action[1])).deselect_all(); + // ## ckeditor stuff ## + else if (action[0] == 'focus_ckeditor') kivi.focus_ckeditor_when_ready(action[1]); + // ## other stuff ## else if (action[0] == 'redirect_to') window.location.href = action[1]; + else if (action[0] == 'save_file') kivi.save_file(action[1], action[2], action[3], action[4]); + else if (action[0] == 'flash') kivi.display_flash(action[1], action[2]); + else if (action[0] == 'flash_detail') kivi.display_flash_detail(action[1], action[2]); + else if (action[0] == 'clear_flash') kivi.clear_flash(action[1], action[2]); else if (action[0] == 'reinit_widgets') kivi.reinit_widgets(); + else if (action[0] == 'run') kivi.run(action[1], action.slice(2, action.length)); + else if (action[0] == 'run_once_for') kivi.run_once_for(action[1], action[2], action[3]); + else if (action[0] == 'scroll_into_view') $(action[1])[0].scrollIntoView(); + else if (action[0] == 'set_cursor_position') kivi.set_cursor_position(action[1], action[2]); else console.log('Unknown action: ' + action[0]); @@ -133,19 +168,6 @@ ns.eval_json_result = function(data) { // console.log("current_content_type " + $('#current_content_type').val() + ' ID ' + $('#current_content_id').val()); }; -ns.submit_ajax_form = function(url, form_selector, additional_data) { - var data = $(form_selector).serialize(); - if (additional_data) { - if (data) - data += '&'; - data += typeof additional_data == "string" ? additional_data : $(additional_data).serialize(); - } - - $.post(url, data, ns.eval_json_result); - - return true; -}; - }); // Local Variables: