X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=js%2Finserts.js;h=5e6774b26435577ad54fd3c3ed0390e64f5a210a;hb=c89567ef64ba87a8387fa09ae8d55a4667d74f00;hp=33bff885f6bd22d0f6ed166aa2e68ca4f166ecc3;hpb=fed6bc04a7b050a0b69136a332e92ee651812487;p=fa-stable.git diff --git a/js/inserts.js b/js/inserts.js index 33bff885..5e6774b2 100644 --- a/js/inserts.js +++ b/js/inserts.js @@ -1,14 +1,22 @@ var _focus; +var _hotkeys = { + 'alt': false, // whether is the Alt key pressed + 'focus': -1 // currently selected indeks of document.links +}; function debug(msg) { box = document.getElementById('msgbox') box.innerHTML= box.innerHTML+'
'+msg } -function progbar(container) { - container.innerHTML= "
"+ - user.loadtxt+"
"; +function progbar() { + box = document.getElementById('msgbox'); + box.innerHTML= "
" + +"
" + +""
+		+user.loadtxt+"

"; + box.style.display = 'block'; } function save_focus(e) { @@ -111,7 +119,7 @@ function _set_combo_select(e) { } e.onchange = function() { var s = this; - + this.setAttribute('_last', this.selectedIndex); if(s.className=='combo') _update_box(s); if(s.selectedIndex>=0) { @@ -134,6 +142,12 @@ function _set_combo_select(e) { setFocus(box.name); 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 + } } } @@ -141,6 +155,20 @@ function _set_combo_select(e) { Behaviour definitions */ var inserts = { + 'form': function(e) { + e.onkeydown = function(ev) { + ev = ev||window.event; + key = ev.keyCode||ev.which; + if((ev.ctrlKey && key == 13) || key == 27) { + ev.cancelBubble = true; + if(ev.stopPropagation) ev.stopPropagation(); +// here ctrl-enter/escape support + ev.returnValue = false; + return false; + } + return true; + } + }, 'input': function(e) { if(e.onfocus==undefined) { e.onfocus = function() { @@ -151,16 +179,37 @@ 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) { + // 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.navibutton': function(e) { e.onclick = function() { + if (this.getAttribute('aspect') == 'process') + progbar(); + save_focus(this); JsHttpRequest.request(this); return false; } @@ -184,7 +233,7 @@ var inserts = { JsHttpRequest.request('_'+this.name+'_changed', this.form); } } - e.onkeydown = function(ev) { +/* e.onkeydown = function(ev) { ev = ev||window.event; key = ev.keyCode||ev.which; if (key == 13 && (this.value != this.getAttribute('_last_val'))) { @@ -192,7 +241,7 @@ var inserts = { return false; } } - }, +*/ }, 'select': function(e) { if(e.onfocus==undefined) { e.onfocus = function() { @@ -210,6 +259,13 @@ var inserts = { }; } }, + 'a.printlink': function(l) { + l.onclick = function() { + save_focus(this); + JsHttpRequest.request(this); + return false; + } + }, 'ul.ajaxtabs': function(ul) { var ulist=ul.getElementsByTagName("li"); for (var x=0; x47 && 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.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);