X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fcommon.js;h=b354d3cccb80ec5d7f0fe4529370cde6943961f8;hb=784cf1e9c41eb8df2e9cb042734acc9d6f25cdda;hp=f25a1595ffbb52786f4e11eb0be02a7291ddea50;hpb=5def52b0f6322414eb2a8f554b85e1320d230b2c;p=kivitendo-erp.git diff --git a/js/common.js b/js/common.js index f25a1595f..b354d3ccc 100644 --- a/js/common.js +++ b/js/common.js @@ -1,13 +1,13 @@ 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 { thpoint = null; } - wrongNumberformat = wrongFormat + " ( " + numberformat + " ) "; + wrongNumberFormat = wrongFormat + " ( " + numberformat + " ) "; } function setupDateFormat(setDateFormat, setWrongDateFormat) { @@ -34,6 +34,11 @@ function centerParms(width,height,extra) { return string; } +function escape_more(s) { + s = escape(s); + return s.replace(/\+/g, '%2b'); +} + 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; @@ -41,45 +46,61 @@ function set_longdescription_window(input_name) { "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=" + escape_more(document.getElementsByName(input_name)[0].value) + "&" + + "input_name=" + escape_more(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)) { +// if(thpoint) { +// if(thpoint == ','){ +// var thnumbers = input_name.value.split(','); +// thnumbers[thnumbers.length-1] = thnumbers[thnumbers.length-1].substring((thnumbers[thnumbers.length-1].lastIndexOf(".") !== -1 ? thnumbers[thnumbers.length-1].lastIndexOf(".") : thnumbers[thnumbers.length-1].length), 0); +// } +// else{ +// var thnumbers = input_name.value.split('.'); +// thnumbers[thnumbers.length-1] = thnumbers[thnumbers.length-1].substring((thnumbers[thnumbers.length-1].lastIndexOf(",") !== -1 ? thnumbers[thnumbers.length-1].lastIndexOf(",") : thnumbers[thnumbers.length-1].length), 0); +// } +// +// for(var i = 0; i < thnumbers.length; i++) { +// if(i == 0 && thnumbers[i].length > 3) { +// return show_alert_and_focus(input_name, wrongNumberFormat); +// } +// if(i > 0 && thnumbers[i].length != 3) { +// return show_alert_and_focus(input_name, wrongNumberFormat); +// } +// } +// } + if(decpoint == thpoint) { + return show_alert_and_focus(input_name, wrongNumberFormat); + } + if(decpoint == ',') { + var decnumbers = input_name.value.split(','); + } + else { + var decnumbers = input_name.value.split('.'); + } + if(decnumbers.length == 2) { + if(decnumbers[1].length > 2) { return show_alert_and_focus(input_name, wrongNumberFormat); } } else { - if(decnumbers.length > 1 || decnumbers[0].length > 2) { + if(decnumbers.length > 2) { return show_alert_and_focus(input_name, wrongNumberFormat); } + if(!thpoint) { + if(decnumbers[0].match(/\D/)) { + 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");