X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fcommon.js;h=b4784f4b11b870a6cc3dd424f5e54040aae6b6cd;hb=6b92d724ba32af43410d9563e77de6bb1013a5f1;hp=916011503adb49b45b25f0bc7d783904dc3cb2f2;hpb=766f5705ecb9cd56adfbffd94c871959bb64c6fd;p=kivitendo-erp.git diff --git a/js/common.js b/js/common.js index 916011503..b4784f4b1 100644 --- a/js/common.js +++ b/js/common.js @@ -1,6 +1,6 @@ function setupPoints(numberformat, wrongFormat) { - decpoint = numberformat.substring((numberformat.substring(1, 2).match(/\.|\,/) ? 5 : 4), (numberformat.substring(1, 2).match(/\.|\,/) ? 6 : 5)); - if (numberformat.substring(1, 2).match(/\.|\,/)) { + decpoint = numberformat.substring((numberformat.substring(1, 2).match(/\.|\,|\'/) ? 5 : 4), (numberformat.substring(1, 2).match(/\.|\,|\'/) ? 6 : 5)); + if (numberformat.substring(1, 2).match(/\.|\,|\'/)) { thpoint = numberformat.substring(1, 2); } else { @@ -44,6 +44,9 @@ function check_right_number_format(input_name) { if(thpoint && thpoint == '.'){ test_val = test_val.replace(/\./g, ''); } + if(thpoint && thpoint == "'"){ + test_val = test_val.replace(/\'/g, ''); + } if(decpoint && decpoint == ','){ test_val = test_val.replace(/,/g, '.'); } @@ -64,6 +67,46 @@ function check_right_date_format(input_name) { if(input_name.value == "") { return true; } + + if ( ( input_name.value.match(/^\d+$/ ) ) && !(dateFormat.lastIndexOf("y") == 3) ) { + // date shortcuts for entering date without separator for three date styles, e.g. + // 31122014 -> 12.04.2014 + // 12312014 -> 12/31/2014 + // 31122014 -> 31/12/2014 + + if (input_name.value.match(/^\d{8}$/)) { + input_name.value = input_name.value.replace(/^(\d\d)(\d\d)(\d\d\d\d)$/, "$1" + seperator + "$2" + seperator + "$3") + } else if (input_name.value.match(/^\d{6}$/)) { + // 120414 -> 12.04.2014 + input_name.value = input_name.value.replace(/^(\d\d)(\d\d)(\d\d)$/, "$1" + seperator + "$2" + seperator + "$3") + } else if (input_name.value.match(/^\d{4}$/)) { + // 1204 -> 12.04.2014 + var today = new Date(); + var year = today.getYear(); + if (year < 999) year += 1900; + input_name.value = input_name.value.replace(/^(\d\d)(\d\d)$/, "$1" + seperator + "$2"); + input_name.value = input_name.value + seperator + year; + } else if ( input_name.value.match(/^\d{1,2}$/ ) ) { + // assume the entry is the day of the current month and current year + var today = new Date(); + var day = input_name.value; + var month = today.getMonth() + 1; + var year = today.getYear(); + if( day.length == 1 && day < 10) { + day='0'+day; + }; + if(month<10) { + month='0'+month; + }; + if (year < 999) year += 1900; + if ( dateFormat.lastIndexOf("d") == 1) { + input_name.value = day + seperator + month + seperator + year; + } else { + input_name.value = month + seperator + day + seperator + year; + } + }; + } + var matching = new RegExp(dateFormat.replace(/\w/g, '\\d') + "\$","ig"); if(!(dateFormat.lastIndexOf("y") == 3) && !matching.test(input_name.value)) { matching = new RegExp(dateFormat.replace(/\w/g, '\\d') + '\\d\\d\$', "ig"); @@ -154,6 +197,10 @@ $(document).ready(function () { if (focussable(this)) window.focused_element = this; }); + // Lowest priority: first focussable element in form. + set_cursor_to_first_element(); + + // Medium priority: class set in template var initial_focus = $(".initial_focus").filter(':visible')[0]; if (initial_focus) $(initial_focus).focus(); @@ -161,7 +208,6 @@ $(document).ready(function () { // legacy. sone forms install these if (typeof fokus == 'function') { fokus(); return; } if (focus_by_name('cursor_fokus')) return; - set_cursor_to_first_element(); }); $('form').submit(function(){