X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=js%2Finserts.js;h=5e6774b26435577ad54fd3c3ed0390e64f5a210a;hb=c89567ef64ba87a8387fa09ae8d55a4667d74f00;hp=43b5f43ba2ed1511723b12d48936863d456b0bca;hpb=c935a4090e3f152dd5549217d69b5b5036197024;p=fa-stable.git diff --git a/js/inserts.js b/js/inserts.js index 43b5f43b..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) { @@ -31,7 +39,7 @@ function _expand(tabobj) { alltabs[i].className = "ajaxbutton" //deselect all tabs } tabobj.className = "current"; - JsHttpRequest.request(tabobj.name) + JsHttpRequest.request(tabobj) } } @@ -42,14 +50,20 @@ function expandtab(tabcontentid, tabnumber) { } function _set_combo_input(e) { + e.setAttribute('_last', e.value); e.onblur=function() { var but_name = this.name.substring(0, this.name.length-4)+'button'; var button = document.getElementsByName(but_name)[0]; var select = document.getElementsByName(this.getAttribute('rel'))[0]; save_focus(select); -// this.style.display='none'; - if(button) { // if *_button set submit search request - JsHttpRequest.request(but_name); +// submit request if there is submit_on_change option set and +// search field has changed. + if (button && (this.value != this.getAttribute('_last'))) { + JsHttpRequest.request(button); + } else if(this.className=='combo2') { + this.style.display = 'none'; + select.style.display = 'inline'; + setFocus(select.name); } return false; }; @@ -68,15 +82,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) { @@ -85,27 +99,34 @@ function _update_box(s) { var box = document.getElementsByName(rel)[0]; if(box && s.selectedIndex>=0) { var opt = s.options[s.selectedIndex]; - if (opt.value != 0) { - if(box) box.value = byid ? opt.value : opt.text; - } + if(box) { + box.value = byid ? opt.value : opt.text; + box.setAttribute('_last', box.value); + } } } 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) { var sname = '_'+s.name+'_update'; var update = document.getElementsByName(sname)[0]; if(update) { - JsHttpRequest.request(sname); + JsHttpRequest.request(update); } } return true; @@ -121,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 + } } } @@ -128,45 +155,93 @@ 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() { save_focus(this); + if (this.className == 'combo') + this.select(); }; } 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'; }, -/* 'select.combo,select.combo2': + 'div.js_only': function(e) { - var box = document.getElementsByName(e.getAttribute('rel'))[0]; - if(box) { - box.style.width = 200+'px'; - e.style.width = 200+'px'; - debug(e.name+':'+e.style.width) - } + // this shows divs for js enabled browsers only + e.style.display = 'block'; }, -*/ 'input.ajaxsubmit,input.editbutton,input.navibutton': +// '.ajaxsubmit,.editbutton,.navibutton': // much slower on IE7 + 'button.ajaxsubmit,input.ajaxsubmit,input.editbutton,button.navibutton': function(e) { e.onclick = function() { - JsHttpRequest.request(this.name); - return false; + if (this.getAttribute('aspect') == 'process') + progbar(); + save_focus(this); + JsHttpRequest.request(this); + 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); }; } }, + '.searchbox': // emulated onchange event handling for text inputs + function(e) { + e.setAttribute('_last_val', e.value); + e.setAttribute('autocomplete', 'off'); //must be off when calling onblur + e.onblur = function() { + var val = this.getAttribute('_last_val'); + if (val != this.value) { + this.setAttribute('_last_val', this.value); + 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) { e.onfocus = function() { @@ -184,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);