X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fkivi.js;h=3ee73a7085d648b3540e27d7bfc21159b7dbd51f;hb=f5658124ac3d002c7843dc820249521bcad618ae;hp=ca9c1cb320d6ff742041aaee4c73820fc7f733e2;hpb=3791f8959dc73c3b991bf736fb0017640deeb742;p=kivitendo-erp.git diff --git a/js/kivi.js b/js/kivi.js index ca9c1cb32..3ee73a708 100644 --- a/js/kivi.js +++ b/js/kivi.js @@ -31,6 +31,15 @@ namespace("kivi", function(ns) { }; ns.parse_date = function(date) { + if (date === undefined) + return undefined; + + if (date === '') + return null; + + if (date === '0' || date === '00') + return new Date(); + var parts = date.replace(/\s+/g, "").split(ns._date_format.sep); var today = new Date(); @@ -59,19 +68,21 @@ namespace("kivi", function(ns) { if (parts.length == 3) { var year = +parts[ ns._date_format.y ] || 0 * 1 || (new Date()).getFullYear(); + if (year > 9999) + return undefined; if (year < 100) { year += year > 70 ? 1900 : 2000; } date = new Date( year, - (parts[ ns._date_format.m ] || 0) * 1 - 1, // Months are 0-based. - (parts[ ns._date_format.d ] || 0) * 1 + (parts[ ns._date_format.m ] || (today.getMonth() + 1)) * 1 - 1, // Months are 0-based. + (parts[ ns._date_format.d ] || today.getDate()) * 1 ); } else if (parts.length == 2) { date = new Date( (new Date()).getFullYear(), - (parts[ (ns._date_format.m > ns._date_format.d) * 1 ] || 0) * 1 - 1, // Months are 0-based. - (parts[ (ns._date_format.d > ns._date_format.m) * 1 ] || 0) * 1 + (parts[ (ns._date_format.m > ns._date_format.d) * 1 ] || (today.getMonth() + 1)) * 1 - 1, // Months are 0-based. + (parts[ (ns._date_format.d > ns._date_format.m) * 1 ] || today.getDate()) * 1 ); } else return undefined; @@ -91,8 +102,11 @@ namespace("kivi", function(ns) { }; ns.parse_amount = function(amount) { - if ((amount === undefined) || (amount === '')) - return 0; + if (amount === undefined) + return undefined; + + if (amount === '') + return null; if (ns._number_format.decimalSep == ',') amount = amount.replace(/\./g, "").replace(/,/g, "."); @@ -101,7 +115,7 @@ namespace("kivi", function(ns) { // Make sure no code wich is not a math expression ends up in eval(). if (!amount.match(/^[0-9 ()\-+*/.]*$/)) - return 0; + return undefined; amount = amount.replace(/^0+(\d+)/, '$1'); @@ -109,7 +123,7 @@ namespace("kivi", function(ns) { try { return eval(amount); } catch (err) { - return 0; + return undefined; } }; @@ -283,6 +297,7 @@ namespace("kivi", function(ns) { if (ns.Part) ns.Part.reinit_widgets(); if (ns.CustomerVendor) ns.CustomerVendor.reinit_widgets(); + if (ns.Validator) ns.Validator.reinit_widgets(); if (ns.ProjectPicker) ns.run_once_for('input.project_autocomplete', 'project_picker', function(elt) { @@ -353,8 +368,8 @@ namespace("kivi", function(ns) { }; // 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"). + // global functions (e.g. "focus_by_name") and those in namespaces (e.g. + // "kivi.t8"). // Returns null if the object is not found. ns.get_function_by_name = function(name) { var parts = name.match("(.+)\\.([^\\.]+)$"); @@ -499,6 +514,14 @@ namespace("kivi", function(ns) { console.log('No duplicate IDs found :)'); }; + ns.validate_form = function(selector) { + if (!kivi.Validator) { + console.log('kivi.Validator is not loaded'); + } else { + return kivi.Validator.validate_all(selector); + } + }; + // Verifies that at least one checkbox matching the // "checkbox_selector" is actually checked. If not, an error message // is shown, and false is returned. Otherwise (at least one of them @@ -514,62 +537,6 @@ namespace("kivi", function(ns) { return false; }; - // Performs various validation steps on the descendants of - // 'selector'. Elements that should be validated must have an - // attribute named "data-validate" which is set to a space-separated - // list of tests to perform. Additionally, the attribute - // "data-title" must be set to a human-readable name of the field - // that can be shown as part of an error message. - // - // Supported validation tests are: - // - "required": the field must be set (its .val() must not be empty) - // - // The validation will abort and return "false" as soon as - // validation routine fails. - // - // The function returns "true" if all validations succeed for all - // elements. - ns.validate_form = function(selector) { - var validate_field = function(elt) { - var $elt = $(elt); - var tests = $elt.data('validate').split(/ +/); - var info = { - title: $elt.data('title'), - value: $elt.val(), - }; - - for (var test_idx in tests) { - var test = tests[test_idx]; - - if (test === "required") { - if ($elt.val() === '') { - alert(kivi.t8("The field '#{title}' must be set.", info)); - return false; - } - - } else { - var error = "kivi.validate_form: unknown test '" + test + "' for element ID '" + $elt.prop('id') + "'"; - console.error(error); - alert(error); - - return false; - } - } - - return true; - }; - - selector = selector || '#form'; - var ok = true; - var to_check = $(selector + ' [data-validate]').toArray(); - - for (var to_check_idx in to_check) - if (!validate_field(to_check[to_check_idx])) - return false; - - return true; - }; - ns.switch_areainput_to_textarea = function(id) { var $input = $('#' + id); if (!$input.length)