X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=js%2Finserts.js;h=e15da1efe2ee42485a6dab5d67ce153f9501c6cd;hb=758eda4e8cef6af76516199636f64415150b6da3;hp=a4207dec48bfbd47ad662b154c08cd6d32974f44;hpb=847876006a1caee9d6b6e3107d4ad5d075d0c62e;p=fa-stable.git diff --git a/js/inserts.js b/js/inserts.js index a4207dec..e15da1ef 100644 --- a/js/inserts.js +++ b/js/inserts.js @@ -18,6 +18,14 @@ 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; } @@ -150,7 +158,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) && (this.className == 'combo2')) { this.style.display = 'none'; box.style.display = 'inline'; box.value=''; @@ -168,8 +180,10 @@ var _w; function callEditor(key) { 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; _w = open(editors[key][0]+el.value+'&popup=1', - "edit","scrollbars=yes,resizable=0,width="+editors[key][2]+",height="+editors[key][3]); + "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 @@ -231,9 +245,24 @@ var inserts = { // 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'); + set_mark((asp && (asp.indexOf('process') !== -1)) ? 'progressbar.gif' : 'ajax-loader.gif'); + }, 100); + return true; + } + }, + 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': @@ -242,7 +271,7 @@ var inserts = { 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); @@ -279,8 +308,10 @@ var inserts = { 'button[aspect=popup]': function(e) { e.onclick = function() { if(_w) _w.close(); // this is really necessary to have window on top in FF2 :/ + var left = (screen.width - 800)/2; + var top = (screen.height - 600)/2; _w = open(document.location+'popup=1', - "edit","Scrollbars=0,resizable=0,width=800,height=600, top=50,left=50"); + "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 @@ -294,9 +325,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 (c == 'combo' || c == 'combo2' || 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) { @@ -354,8 +395,14 @@ var inserts = { } } // } + }, + 'textarea': function(e) { + if(e.onfocus==undefined) { + e.onfocus = function() { + save_focus(this); + }; + } } - /* 'tr.editrow': function(e) { e.onkeydown = function(ev) { ev = ev||window.event; @@ -437,7 +484,6 @@ function setHotKeys() { for (var i=0; i