X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fcommon.js;h=916011503adb49b45b25f0bc7d783904dc3cb2f2;hb=a9325fe964a8b3c4c240409ddf5020756324b1e4;hp=e1037d70f0bc1b02c1fb8ef121999b1fd48ed3e0;hpb=26e884f38679c47356f79b724cc592b4503ac307;p=kivitendo-erp.git diff --git a/js/common.js b/js/common.js index e1037d70f..916011503 100644 --- a/js/common.js +++ b/js/common.js @@ -1,17 +1,12 @@ -if (!window.a_onload_functions) a_onload_functions = new Object(); -if (!window.a_onsubmit_functions) a_onsubmit_functions = new Object(); -if (!window.a_onfocus_functions) a_onfocus_functions = new Object(); -window.focused_element = null; - 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); + thpoint = numberformat.substring(1, 2); } else { thpoint = null; } - wrongNumberFormat = wrongFormat + " ( " + numberformat + " ) "; + wrongNumberFormat = wrongFormat + " ( " + numberformat + " ) "; } function setupDateFormat(setDateFormat, setWrongDateFormat) { @@ -38,46 +33,31 @@ 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; - url = "common.pl?" + - "action=set_longdescription&" + - "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) { - if(decpoint == thpoint) { + if(decpoint && thpoint && thpoint == decpoint) { return show_alert_and_focus(input_name, wrongNumberFormat); } - if(decpoint == ',') { - var decnumbers = input_name.value.split(','); + var test_val = input_name.value; + if(thpoint && thpoint == ','){ + test_val = test_val.replace(/,/g, ''); } - else { - var decnumbers = input_name.value.split('.'); + if(thpoint && thpoint == '.'){ + test_val = test_val.replace(/\./g, ''); } - if(decnumbers.length == 2) { - if(decnumbers[1].length > 2) { - return show_alert_and_focus(input_name, wrongNumberFormat); - } + if(decpoint && decpoint == ','){ + test_val = test_val.replace(/,/g, '.'); } - else { - 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); - } - } + 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) { @@ -92,7 +72,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); } } @@ -131,7 +111,7 @@ 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]) @@ -139,26 +119,10 @@ function get_input_value(input_name) { return ''; } -a_onfocus_functions["focus_listener"] = (function (event) { - if (focussable(event.target)) window.focused_element = event.target; -}); - -a_onsubmit_functions["get_cursor_position"] = (function () { - if (window.focused_element) - document.forms[0].cursor_fokus.value = window.focused_element.name; -}); - function set_cursor_position(n) { - document.getElementsByName(n)[0].focus(); + $('[name=' + n + ']').focus(); } -a_onload_functions["restore_cursor_position"] = (function () { - var e = document.getElementsByName('cursor_fokus')[0]; - if (e) var f = document.getElementsByName(e.value)[0]; - if (focussable(f)) set_cursor_position(f.name) - else set_cursor_to_first_element(); -}); - function focussable(e) { return e && e.name && e.type != 'hidden' && e.type != 'submit' && e.disabled != true; } @@ -171,16 +135,36 @@ function set_cursor_to_first_element(){ try { df[f][i].focus(); return } catch (er) { } } -function add_event(e, type, fn, c) { - var ret = 0; - if (e.addEventListener) e.addEventListener(type, fn, c) - else if (e.attachEvent) e.attachEvent('on' + type, fn) - else e['on' + type] = fn; -} - -function do_load_events() { - for (var name in window.a_onload_functions) add_event(window, "load", window.a_onload_functions[name], false); - for (var name in window.a_onsubmit_functions) add_event(window, "submit", window.a_onsubmit_functions[name], false); - for (var name in window.a_onfocus_functions) add_event(window, "focus", window.a_onfocus_functions[name], false); +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; } -do_load_events(); + +$(document).ready(function () { + $('input').focus(function(){ + if (focussable(this)) window.focused_element = this; + }); + + var initial_focus = $(".initial_focus").filter(':visible')[0]; + if (initial_focus) + $(initial_focus).focus(); + + // 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(){ + if (window.focused_element) + document.forms[0].cursor_fokus.value = window.focused_element.name; +});