X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fcommon.js;h=298d5a2cbee2fe4cdf2e36ef1c9d0618e0e2a48f;hb=919aac7928355937d6eedf8df4da56808ebd4eb9;hp=f25a1595ffbb52786f4e11eb0be02a7291ddea50;hpb=5def52b0f6322414eb2a8f554b85e1320d230b2c;p=kivitendo-erp.git diff --git a/js/common.js b/js/common.js index f25a1595f..298d5a2cb 100644 --- a/js/common.js +++ b/js/common.js @@ -1,13 +1,12 @@ - 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(/.|,/)) { - thpoint = numberformat.substring(1, 2); + 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 { thpoint = null; } - wrongNumberformat = wrongFormat + " ( " + numberformat + " ) "; + wrongNumberFormat = wrongFormat + " ( " + numberformat + " ) "; } function setupDateFormat(setDateFormat, setWrongDateFormat) { @@ -38,48 +37,44 @@ function set_longdescription_window(input_name) { var parm = centerParms(600,500) + ",width=600,height=500,status=yes,scrollbars=yes"; var name = document.getElementsByName(input_name)[0].value; url = "common.pl?" + + "INPUT_ENCODING=UTF-8&" + "action=set_longdescription&" + - "login=" + encodeURIComponent(document.getElementsByName("login")[0].value)+ "&"+ - "password=" + encodeURIComponent(document.getElementsByName("password")[0].value) + "&" + - "path=" + encodeURIComponent(document.getElementsByName("path")[0].value) + "&" + - "longdescription=" + escape(document.getElementsByName(input_name)[0].value) + "&" + - "input_name=" + escape(input_name) + "&" + "longdescription=" + encodeURIComponent(document.getElementsByName(input_name)[0].value) + "&" + + "input_name=" + encodeURIComponent(input_name) + "&" window.open(url, "_new_generic", parm); } function check_right_number_format(input_name) { - var decnumbers = input_name.value.split(decpoint); - if(thpoint) { - var thnumbers = input_name.value.split(thpoint); - if(thnumbers[thnumbers.length-1].match(/.+decpoint$/g)) { - thnumbers[thnumbers.length-1] = thnumbers[thnumbers.length-1].substring(thnumbers[thnumbers.length-1].length-1); - } - if(thnumbers[thnumbers.length-1].match(/.+decpoint\d$/g)) { - thnumbers[thnumbers.length-1] = thnumbers[thnumbers.length-1].substring(thnumbers[thnumbers.length-1].length-2); - } - if(thnumbers[thnumbers.length-1].match(/.+decpoint\d\d$/g)) { - thnumbers[thnumbers.length-1] = thnumbers[thnumbers.length-1].substring(thnumbers[thnumbers.length-1].length-3); - } - for(var i = 1; i < thnumbers.length; i++) { - if(!thnumbers[i].match(/\d\d\d/g)) { - return show_alert_and_focus(input_name, wrongNumberFormat); - } - if(thnumbers[i].match(/.*decpoint.*|.*thpoint.*/g)) { - return show_alert_and_focus(input_name, wrongNumberFormat); - } - } - if(decnumbers.length > 2 || (decnumbers.length > 1 ? (decnumbers[1].length > 2) : false)) { - return show_alert_and_focus(input_name, wrongNumberFormat); - } + if(decpoint && thpoint && thpoint == decpoint) { + return show_alert_and_focus(input_name, wrongNumberFormat); } - else { - if(decnumbers.length > 1 || decnumbers[0].length > 2) { - return show_alert_and_focus(input_name, wrongNumberFormat); - } + var test_val = input_name.value; + 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, '.'); + } + var forbidden = test_val.match(/[^\s\d\(\)\-\+\*\/\.]/g); + if (forbidden && forbidden.length > 0 ){ + return show_alert_and_focus(input_name, wrongNumberFormat); + } + + try{ + eval(test_val); + }catch(err){ + return show_alert_and_focus(input_name, wrongNumberFormat); + } + } function check_right_date_format(input_name) { + if(input_name.value == "") { + return true; + } 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"); @@ -88,7 +83,7 @@ function check_right_date_format(input_name) { } } else { - if (dateFormat.lastIndexOf("y") == 3 && !matching.test(input_name.value)) { + if (dateFormat.lastIndexOf("y") == 3 && !matching.test(input_name.value)) { return show_alert_and_focus(input_name, wrongDateFormat); } } @@ -127,4 +122,56 @@ function show_alert_and_focus(input_name, errorMessage) { input_name.focus(); return false; } - + +function get_input_value(input_name) { + var the_input = document.getElementsByName(input_name); + if (the_input && the_input[0]) + return the_input[0].value; + return ''; +} + +function set_cursor_position(n) { + $('[name=' + n + ']').focus(); +} + +function focussable(e) { + return e && e.name && e.type != 'hidden' && e.type != 'submit' && e.disabled != true; +} + +function set_cursor_to_first_element(){ + var df = document.forms; + for (var f = 0; f < df.length; f++) + for (var i = 0; i < df[f].length; i++) + if (focussable(df[f][i])) + try { df[f][i].focus(); return } catch (er) { } +} + +function getElementByIndirectName(name){ + var e = document.getElementsByName(name)[0]; + if (e) return document.getElementsByName(e.value)[0]; +} + +function focus_by_name(name){ + var f = getElementByIndirectName(name); + if (focussable(f)) { + set_cursor_position(f.name); + return true; + } + return false; +} + +$(document).ready(function () { + $('input').focus(function(){ + if (focussable(this)) window.focused_element = this; + }); + // legacy. sone forms install these + if (typeof fokus == 'function') { fokus(); return; } + if (focus_by_name('fokus')) return; + if (focus_by_name('cursor_fokus')) return; + set_cursor_to_first_element(); +}); + +$('form').submit(function(){ + if (window.focused_element) + document.forms[0].cursor_fokus.value = window.focused_element.name; +});