X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=js%2Finserts.js;h=d0722250769dcb4d3cb25be45586979d34f77f23;hb=e685a94465fe8f26c8ff3789242b43c1c20054cf;hp=d8f033ea7821fe1cb455d14cd52f6b791b66b05a;hpb=05d1e1fc65fe68645b540e06884db0e9f24b1a21;p=fa-stable.git diff --git a/js/inserts.js b/js/inserts.js index d8f033ea..d0722250 100644 --- a/js/inserts.js +++ b/js/inserts.js @@ -1,11 +1,11 @@ /********************************************************************** Copyright (C) FrontAccounting, LLC. - Released under the terms of the GNU General Public License, GPL, - as published by the Free Software Foundation, either version 3 + Released under the terms of the GNU General Public License, GPL, + as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the License here . ***********************************************************************/ var _focus; @@ -18,6 +18,20 @@ var _hotkeys = { function validate(e) { if (e.name && (typeof _validate[e.name] == 'function')) return _validate[e.name](e); + else { + var n = e.name.indexOf('['); + if(n!=-1) { + var key = e.name.substring(n+1, e.name.length-1); + if (key.length>1 && _validate[e.name.substring(0,n)]) + return _validate[e.name.substring(0,n)][key](e); + } + } + return true; +} + +function set_fullmode() { + document.getElementById('ui_mode').value = 1; + document.loginform.submit(); return true; } @@ -38,7 +52,7 @@ function _expand(tabobj) { if (ul.getAttribute("rel")){ for (var i=0; i=0) { var len = select.length; - var byid = this.className=='combo' || this.className=='combo3'; + var byid = string_contains(this.className, 'combo') || string_contains(this.className, 'combo3'); var ac = this.value.toUpperCase(); select.options[select.selectedIndex].selected = false; for (i = 0; i < len; i++) { var txt = byid ? select.options[i].value : select.options[i].text; - if (this.className=='combo3') { + if (string_contains(this.className, 'combo3')) { if(txt.toUpperCase().indexOf(ac) == 0) { select.options[i].selected = true; break; @@ -93,7 +107,7 @@ function _set_combo_input(e) { } } }; - e.onkeydown = function(ev) { + e.onkeydown = function(ev) { ev = ev||window.event; key = ev.keyCode||ev.which; if(key == 13) { @@ -104,7 +118,7 @@ function _set_combo_input(e) { } function _update_box(s) { - var byid = s.className=='combo' || s.className=='combo3'; + var byid = string_contains(s.className, 'combo') || string_contains(s.className, 'combo3'); var rel = s.getAttribute('rel'); var box = document.getElementsByName(rel)[0]; if(box && s.selectedIndex>=0) { @@ -120,29 +134,27 @@ function _update_box(s) { function _set_combo_select(e) { // When combo position is changed via js (eg from searchbox) - // no onchange event is generated. To ensure proper change + // no onchange event is generated. To ensure proper change // signaling we must track selectedIndex in onblur handler. e.setAttribute('_last', e.selectedIndex); e.onblur = function() { var box = document.getElementsByName(this.getAttribute('rel'))[0]; -// if(this.className=='combo') -// _update_box(this); if ((this.selectedIndex != this.getAttribute('_last')) - ||((this.className=='combo' || this.className=='combo3') && _update_box(this)) + ||((string_contains(this.className, 'combo') || string_contains(this.className, 'combo3')) && _update_box(this)) ) this.onchange(); } e.onchange = function() { var s = this; this.setAttribute('_last', this.selectedIndex); - if(s.className=='combo' || this.className=='combo3') + if(string_contains(s.className, 'combo') || string_contains(this.className, 'combo3')) _update_box(s); if(s.selectedIndex>=0) { var sname = '_'+s.name+'_update'; var update = document.getElementsByName(sname)[0]; if(update) { JsHttpRequest.request(update); - } + } } return true; } @@ -150,7 +162,11 @@ function _set_combo_select(e) { event = event||window.event; key = event.keyCode||event.which; var box = document.getElementsByName(this.getAttribute('rel'))[0]; - if (box && key == 32 && this.className == 'combo2') { + if(key == 8 || (key==37 && event.altKey)) { + event.returnValue = false; + return false; + } + if (box && (key == 32) && (string_contains(this.className, 'combo2'))) { this.style.display = 'none'; box.style.display = 'inline'; box.value=''; @@ -166,7 +182,7 @@ function _set_combo_select(e) { var _w; function callEditor(key) { - var el = document.getElementsByName(editors[key][1])[0]; + var el = document.getElementsByName(editors[key][1])[0]; if(_w) _w.close(); // this is really necessary to have window on top in FF2 :/ var left = (screen.width - editors[key][2]) / 2; var top = (screen.height - editors[key][3]) / 2; @@ -174,7 +190,7 @@ function callEditor(key) { "edit","scrollbars=yes,resizable=0,width="+editors[key][2]+",height="+editors[key][3]+",left="+left+",top="+top+",screenX="+left+",screenY="+top); if (_w.opener == null) _w.opener = self; - editors._call = key; // store call point for passBack + editors._call = key; // store call point for passBack _w.focus(); } @@ -184,7 +200,7 @@ function passBack(value) { var back = o.editors[o.editors._call]; // form input bindings var to = o.document.getElementsByName(back[1])[0]; if (to) { - if (to[0] != undefined) + if (to[0] != undefined) to[0].value = value; // ugly hack to set selector to any value to.value = value; // update page after item selection @@ -195,6 +211,67 @@ function passBack(value) { close(); } +/* + Normalize date format using previous input value to guess missing date elements. + Helps fast date input field change with only single or double numbers (for day or day-and-month fragments) +*/ +function fix_date(date, last) +{ + var dat = last.split(user.datesep); + var cur = date.split(user.datesep); + var day, month, year; + +// TODO: user.date as default? +// TODO: user.datesys + if (date == "" || date == last) // should we return an empty date or should we return last? + return date; + if (user.datefmt == 0 || user.datefmt == 3) // set defaults + { + day = dat[1]; month = dat[0]; year = dat[2]; + } else if (user.datefmt == 1 || user.datefmt == 4){ + day = dat[0]; month = dat[1]; year = dat[2]; + } else { + day = dat[2]; month = dat[1]; year = dat[0]; + } + if (cur[1] != undefined && cur[1] != "") // day or month entered, could be string 3 + { + if (user.datefmt == 0 || user.datefmt == 3 || ((user.datefmt == 2 || user.datefmt == 5) && (cur[2] == undefined || cur[2] == ""))) + day = cur[1]; + else + month = cur[1]; + } + if (cur[0] != undefined && cur[0] != "") // day or month entered. could be string 3 + { + if (cur[1] == undefined || cur[1] == "") + day = cur[0]; + else if (user.datefmt == 0 || user.datefmt == 3 || ((user.datefmt == 2 || user.datefmt == 5) && (cur[2] == undefined || cur[2] == ""))) + month = cur[0]; + else if (user.datefmt == 2 || user.datefmt == 5) + year = cur[0]; + else + day = cur[0]; + } + if (cur[2] != undefined && cur[2] != "") // year, + { + if (user.datefmt == 2 || user.datefmt == 5) + day = cur[2]; + else + year = cur[2]; + } + if (user.datefmt<3) { + if (day<10) day = '0'+parseInt(day, 10); + if (month<10) month = '0'+parseInt(month, 10); + } + if (year<100) year = year<60 ? (2000+parseInt(year,10)) : (1900+parseInt(year,10)); + +// console.info(day,month,year) + if (user.datefmt == 0 || user.datefmt==3) + return month+user.datesep+day+user.datesep+year; + if (user.datefmt == 1 || user.datefmt==4) + return day+user.datesep+month+user.datesep+year; + return year+user.datesep+month+user.datesep+day; +} + /* Behaviour definitions */ @@ -202,49 +279,66 @@ var inserts = { 'input': function(e) { if(e.onfocus==undefined) { e.onfocus = function() { - save_focus(this); - if (this.className == 'combo' || this.className == 'combo3') + save_focus(this); + if (string_contains(this.className, 'combo') || string_contains(this.className, 'combo3')) this.select(); }; } - if (e.className == 'combo' || e.className == 'combo2' || e.className == 'combo3') { + if (string_contains(e.className, 'combo') || string_contains(e.className, 'combo2') || string_contains(e.className, 'combo3')) { _set_combo_input(e); - } + } else if(e.type == 'text' ) { - e.onkeydown = function(ev) { + e.onkeydown = function(ev) { ev = ev||window.event; key = ev.keyCode||ev.which; if(key == 13) { if(e.className == 'searchbox') e.onblur(); return false; - } + } return true; } } }, - 'input.combo2,input[aspect="fallback"]': + 'input.combo2,input[aspect="fallback"]': function(e) { // this hides search button for js enabled browsers e.style.display = 'none'; }, - 'div.js_only': + 'div.js_only': function(e) { // this shows divs for js enabled browsers only e.style.display = 'block'; }, - 'button': function(e) { - e.onclick = function(){ return validate(e); } + e.onclick = function(){ + if (validate(e)) { + setTimeout(function() { var asp = e.getAttribute('aspect'); + if (asp && asp.indexOf('download') === -1 && asp.indexOf('popup') === -1) + set_mark((asp && ((asp.indexOf('process') !== -1) || (asp.indexOf('nonajax') !== -1))) ? 'progressbar.gif' : 'ajax-loader.gif'); + }, 100); + return true; + } + return false; + }, + e.onkeydown = function(ev) { // block unintentional page escape with 'history back' key pressed on buttons + ev = ev||window.event; + key = ev.keyCode||ev.which; + if(key == 8 || (key==37 && ev.altKey)) { + ev.returnValue = false; + return false; + } + } + }, // '.ajaxsubmit,.editbutton,.navibutton': // much slower on IE7 - 'button.ajaxsubmit,input.ajaxsubmit,input.editbutton,button.editbutton,button.navibutton': + 'button.ajaxsubmit,input.ajaxsubmit,input.editbutton,button.editbutton,button.navibutton': function(e) { e.onclick = function() { if (validate(e)) { save_focus(e); var asp = e.getAttribute('aspect') - if (asp && asp.indexOf('process') !== -1) + if (asp && (asp.indexOf('process') !== -1)) JsHttpRequest.request(this, null, 600000); // ten minutes for backup else JsHttpRequest.request(this); @@ -252,11 +346,18 @@ var inserts = { return false; } }, - '.amount': function(e) { - if(e.onblur==undefined) { + '.amount': function(e) { + if (e.onblur == undefined) { + e.setAttribute('_last_val', e.value); e.onblur = function() { var dec = this.getAttribute("dec"); - price_format(this.name, get_amount(this.name), dec); + var val = this.getAttribute('_last_val'); + if (val != get_amount(this.name)) { + this.setAttribute('_last_val', get_amount(this.name)); + price_format(this.name, get_amount(this.name), dec); + if (e.className.match(/\bactive\b/)) + JsHttpRequest.request('_'+this.name+'_changed', this.form); + } }; } }, @@ -272,6 +373,20 @@ var inserts = { } } }, + '.date': + function(e) { + e.setAttribute('_last_val', e.value); + e.setAttribute('autocomplete', 'off'); + e.onblur = function() { + var val = this.getAttribute('_last_val'); + if (val != this.value) { + this.value = fix_date(this.value, val); + this.setAttribute('_last_val', this.value); + if (e.className.match(/\bactive\b/)) + JsHttpRequest.request('_'+this.name+'_changed', this.form); + } + } + }, 'button[aspect*selector], button[aspect*abort], input[aspect*selector]': function(e) { e.onclick = function() { passBack(this.getAttribute('rel')); @@ -287,7 +402,7 @@ var inserts = { "edit","Scrollbars=0,resizable=0,width=800,height=600, top="+top+",left="+left+",screenX="+left+",screenY="+top); if (_w.opener == null) _w.opener = self; - // editors._call = key; // store call point for passBack + // editors._call = key; // store call point for passBack // _w.moveTo(50, 50); _w.focus(); return false; @@ -298,9 +413,19 @@ var inserts = { e.onfocus = function() { save_focus(this); }; - var c = e.className; - if (c == 'combo' || c == 'combo2' || c == 'combo3') + } + var c = e.className; + if (string_contains(c, 'combo') || string_contains(c, 'combo2') || string_contains(c, 'combo3')) _set_combo_select(e); + else { + e.onkeydown = function(ev) { // block unintentional page escape with 'history back' key pressed on buttons + ev = ev||window.event; + key = ev.keyCode||ev.which; + if(key == 8 || (key=37 && ev.altKey)) { + ev.returnValue = false; + return false; + } + } } }, 'a.printlink': function(l) { @@ -321,7 +446,7 @@ var inserts = { } }, 'a': function(e) { // traverse menu - e.onkeydown = function(ev) { + e.onkeydown = function(ev) { ev = ev||window.event; key = ev.keyCode||ev.which; if(key==37 || key==38 || key==39 || key==40) { @@ -331,53 +456,43 @@ var inserts = { } } // prevent unneeded transaction entry abortion - if (e.className == 'shortcut' - || e.className == 'menu_option' + if (e.className == 'shortcut' + || e.className == 'menu_option' || e.className == 'menu_tab' || e.className == 'selected') e.onclick = function(ev) { - if (_validate._processing + if (_validate._processing && _validate._modified && !confirm(_validate._processing)) { ev.returnValue = false; return false; } - window.location = e.href; + if (_hotkeys.alt) // ommit Chrome accesskeys + return false; + window.location = e.href; } }, 'ul.ajaxtabs': function(ul) { var ulist=ul.getElementsByTagName("li"); for (var x=0; x= 0) { var link = _hotkeys.list[_hotkeys.focus]; - if(link.onclick) + if(link.onclick) link.onclick(); else if (link.target=='_blank') { @@ -488,7 +605,7 @@ function setHotKeys() { window.location = link.href; } return stopEv(ev); - } + } } return true; }