X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=js%2Finserts.js;h=dd78a9f607be68de748e56c8bfde841f26093e8a;hb=89cb648e9d031fa624e7814f89e90ccba2042124;hp=b535cd03a361e5841450bf7147785c5213c3a975;hpb=35f960e8c8b1941c5d841ac916ed1468b376ff17;p=fa-stable.git diff --git a/js/inserts.js b/js/inserts.js index b535cd03..dd78a9f6 100644 --- a/js/inserts.js +++ b/js/inserts.js @@ -1,16 +1,25 @@ +/********************************************************************** + 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 + 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. + See the License here . +***********************************************************************/ var _focus; +var _hotkeys = { + 'alt': false, // whether is the Alt key pressed + 'focus': -1 // currently selected indeks of document.links +}; +var _validate = {}; // validation functions function debug(msg) { box = document.getElementById('msgbox') box.innerHTML= box.innerHTML+'
'+msg } -function progbar(container) { - container.innerHTML= "
"+ - user.loadtxt+"
"; -} - function save_focus(e) { _focus = e.name||e.id; var h = document.getElementById('hints'); @@ -55,7 +64,7 @@ function _set_combo_input(e) { } else if(this.className=='combo2') { this.style.display = 'none'; select.style.display = 'inline'; - setFocus(select.name); + setFocus(select); } return false; }; @@ -74,15 +83,15 @@ 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) { this.blur(); return false; } - } + } } function _update_box(s) { @@ -99,13 +108,19 @@ 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 + // signaling we must track selectedIndex in onblur handler. + e.setAttribute('_last', e.selectedIndex); e.onblur = function() { if(this.className=='combo') _update_box(this); + if (this.selectedIndex != this.getAttribute('_last')) + this.onchange(); } e.onchange = function() { var s = this; - + this.setAttribute('_last', this.selectedIndex); if(s.className=='combo') _update_box(s); if(s.selectedIndex>=0) { @@ -125,9 +140,15 @@ function _set_combo_select(e) { this.style.display = 'none'; box.style.display = 'inline'; box.value=''; - setFocus(box.name); + setFocus(box); return false; } + if (this.getAttribute('aspect') == 'editable' && key==115) { + // F4: call related database editor - not available in non-js fallback mode + JsHttpRequest.request('_'+this.name+'_editor', this.form); + return false; // prevent default binding + // TODO: stopPropagation when needed + } } } @@ -145,24 +166,64 @@ var inserts = { } if (e.className == 'combo' || e.className == 'combo2') { _set_combo_input(e); - } + } + else + if(e.type == 'text' ) { + 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.combo_submit,input.combo_select,input.combo2': + 'input.combo2,input[aspect="fallback"]': function(e) { // this hides search button for js enabled browsers e.style.display = 'none'; }, - 'input.ajaxsubmit,input.editbutton,input.navibutton': + 'div.js_only': function(e) { - e.onclick = function() { - JsHttpRequest.request(this); - return false; - } + // this shows divs for js enabled browsers only + e.style.display = 'block'; + }, +// '.ajaxsubmit,.editbutton,.navibutton': // much slower on IE7 + 'button.ajaxsubmit,input.ajaxsubmit,input.editbutton,button.editbutton,button.navibutton': + function(e) { + e.onclick = function() { + save_focus(e); + if (e.getAttribute('aspect') == 'process') + JsHttpRequest.request(this, null, 30000); + else + JsHttpRequest.request(this); + return false; + } + }, + 'button': function(e) { + if (e.name) { + var func = _validate[e.name]; + var old = e.onclick; + if(func) { + if (typeof old != 'function') { + e.onclick = func; + } else { + e.onclick = function() { + if(func()) + { old(); return true;} + else + return false; + } + } + } + } }, '.amount': function(e) { if(e.onblur==undefined) { - var dec = e.getAttribute("dec"); e.onblur = function() { + var dec = this.getAttribute("dec"); price_format(this.name, get_amount(this.name), dec); }; } @@ -178,14 +239,6 @@ var inserts = { JsHttpRequest.request('_'+this.name+'_changed', this.form); } } - e.onkeydown = function(ev) { - ev = ev||window.event; - key = ev.keyCode||ev.which; - if (key == 13 && (this.value != this.getAttribute('_last_val'))) { - this.blur(); - return false; - } - } }, 'select': function(e) { if(e.onfocus==undefined) { @@ -202,6 +255,28 @@ var inserts = { e.onfocus = function() { save_focus(this); }; + e.onmouseover = function(e) { + setFocus(this); + return false; + } + } + }, + 'a.printlink': function(l) { + l.onclick = function() { + save_focus(this); + JsHttpRequest.request(this); + return false; + } + }, + 'a': function(e) { // traverse menu + e.onkeydown = function(ev) { + ev = ev||window.event; + key = ev.keyCode||ev.which; + if(key==37 || key==38 || key==39 || key==40) { + move_focus(key, e, document.links); + ev.returnValue = false; + return false; + } } }, 'ul.ajaxtabs': function(ul) { @@ -218,7 +293,20 @@ var inserts = { } } }, - '#msgbox': function(e) { +/* 'tr.editrow': function(e) { + e.onkeydown = function(ev) { + ev = ev||window.event; + key = ev.keyCode||ev.which; + if(key == 13) { + // Find & click additem/update button + + } else if(key == 27) { + return false; + } + } + + }, +*/ '#msgbox': function(e) { // this is to avoid changing div height after ajax update in IE7 e.style.display = e.innerHTML.length ? 'block' : 'none'; } @@ -231,7 +319,92 @@ var inserts = { } */ }; +function stopEv(ev) { + ev.returnValue = false; + ev.cancelBubble = true; + if(ev.preventDefault) ev.preventDefault(); + return false; +} +/* + Modified accesskey system. While Alt key is pressed letter keys moves + focus to next marked link. Alt key release activates focused link. +*/ +function setHotKeys() { + document.onkeydown = function(ev) { + ev = ev||window.event; + key = ev.keyCode||ev.which; + if (key == 18 && !ev.ctrlKey) { // start selection, skip Win AltGr + _hotkeys.alt = true; + _hotkeys.focus = -1; + return stopEv(ev); + } + else if (_hotkeys.alt && ((key>47 && key<58) || (key>64 && key<91))) { + var n = _hotkeys.focus; + var l = document.links; + var cnt = l.length; + key = String.fromCharCode(key); + for (var i=0; i=0) { + var link = document.links[_hotkeys.focus]; + if(link.onclick) + link.onclick(); + else + if (link.target=='_blank') { + window.open(link.href,'','toolbar=no,scrollbar=no,resizable=yes,menubar=no,width=900,height=500'); + openWindow(link.href,'_blank'); + } else + window.location = link.href; + } + return stopEv(ev); + } + } + return true; + } +} Behaviour.register(inserts); Behaviour.addLoadEvent(setFocus); +Behaviour.addLoadEvent(setHotKeys);