X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fkivi.js;h=2c281102775eac43d29f8659ba9b92889e830204;hb=8317fdf49404110c9f15c93d469c83e5bb0235e7;hp=2be03018b007b90bb25e9e918cfcce8fa622fb31;hpb=a88e544966ffc9b0d5b2990709fdcb7c4713c1fd;p=kivitendo-erp.git diff --git a/js/kivi.js b/js/kivi.js index 2be03018b..2c2811027 100644 --- a/js/kivi.js +++ b/js/kivi.js @@ -28,16 +28,26 @@ namespace("kivi", function(ns) { }; ns.reinit_widgets = function() { - $('.datepicker').each(function() { - $(this).datepicker(); + ns.run_once_for('.datepicker', 'datepicker', function(elt) { + $(elt).datepicker(); }); if (ns.PartPicker) - $('input.part_autocomplete').each(function(idx, elt){ + ns.run_once_for('input.part_autocomplete', 'part_picker', function(elt) { kivi.PartPicker($(elt)); }); }; + ns.submit_ajax_form = function(url, form_selector, additional_data) { + $(form_selector).ajaxSubmit({ + url: url, + data: additional_data, + success: ns.eval_json_result + }); + + return true; + }; + // Return a function object by its name (a string). Works both with // global functions (e.g. "check_right_date_format") and those in // namespaces (e.g. "kivi.t8"). @@ -89,6 +99,52 @@ namespace("kivi", function(ns) { return true; }; + + // Run code only once for each matched element + // + // This allows running the function 'code' exactly once for each + // element that matches 'selector'. This is achieved by storing the + // state with jQuery's 'data' function. The 'identification' is + // required for differentiating unambiguously so that different code + // functions can still be run on the same elements. + // + // 'code' can be either a function or the name of one. It must + // resolve to a function that receives the jQueryfied element as its + // sole argument. + // + // Returns nothing. + ns.run_once_for = function(selector, identification, code) { + var attr_name = 'data-run-once-for-' + identification.toLowerCase().replace(/[^a-z]+/g, '-'); + var fn = typeof code === 'function' ? code : ns.get_function_by_name(code); + if (!fn) { + console.error('kivi.run_once_for(..., "' + code + '"): No function by that name found'); + return; + } + + $(selector).filter(function() { return $(this).data(attr_name) != true; }).each(function(idx, elt) { + var $elt = $(elt); + $elt.data(attr_name, true); + fn($elt); + }); + }; + + // Run a function by its name passing it some arguments + // + // This is a function useful mainly for the ClientJS functionality. + // It finds a function by its name and then executes it on an empty + // object passing the elements in 'args' (an array) as the function + // parameters retuning its result. + // + // Logs an error to the console and returns 'undefined' if the + // function cannot be found. + ns.run = function(function_name, args) { + var fn = ns.get_function_by_name(function_name); + if (fn) + return fn.apply({}, args); + + console.error('kivi.run("' + function_name + '"): No function by that name found'); + return undefined; + }; }); kivi = namespace('kivi');