X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=js%2Finserts.js;h=b9564ed98491906f9914c57de504048357590bc5;hb=70c2dbcf463a5d500d15b8510c7f45e527a7fa53;hp=a51cb88bdefa1ec477d234fbfdb66f685c1d5d21;hpb=7b10804aae7a48abbe9f43eea1c85fe9ca41171a;p=fa-stable.git
diff --git a/js/inserts.js b/js/inserts.js
index a51cb88b..b9564ed9 100644
--- a/js/inserts.js
+++ b/js/inserts.js
@@ -11,24 +11,10 @@
var _focus;
var _hotkeys = {
'alt': false, // whether is the Alt key pressed
- 'focus': -1 // currently selected indeks of document.links
+ 'list': false, // list of all elements with hotkey used recently
+ 'focus': -1 // currently selected list element
};
-function debug(msg) {
- box = document.getElementById('msgbox')
- box.innerHTML= box.innerHTML+'
'+msg
-}
-
-function progbar() {
- box = document.getElementById('msgbox');
- box.innerHTML= "
"
- +""
- +"!["
- +user.loadtxt+"]("+user.theme+"images/progressbar.gif) |
";
- box.style.display = 'block';
-}
-
function save_focus(e) {
_focus = e.name||e.id;
var h = document.getElementById('hints');
@@ -41,7 +27,7 @@ function save_focus(e) {
function _expand(tabobj) {
var ul = tabobj.parentNode.parentNode;
- var alltabs=ul.getElementsByTagName("input");
+ var alltabs=ul.getElementsByTagName("button");
var frm = tabobj.form;
if (ul.getAttribute("rel")){
@@ -68,8 +54,9 @@ function _set_combo_input(e) {
save_focus(select);
// 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);
+ JsHttpRequest.request(button);
} else if(this.className=='combo2') {
this.style.display = 'none';
select.style.display = 'inline';
@@ -81,14 +68,21 @@ function _set_combo_input(e) {
var select = document.getElementsByName(this.getAttribute('rel'))[0];
if(select && select.selectedIndex>=0) {
var len = select.length;
- var byid = this.className=='combo';
+ var byid = this.className=='combo' || 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 (txt.toUpperCase().indexOf(ac) >= 0) {
- select.options[i].selected = true;
- break;
+ if (this.className=='combo3') {
+ if(txt.toUpperCase().indexOf(ac) == 0) {
+ select.options[i].selected = true;
+ break;
+ }
+ } else {
+ if(txt.toUpperCase().indexOf(ac) >= 0) {
+ select.options[i].selected = true;
+ break;
+ }
}
}
}
@@ -104,14 +98,16 @@ function _set_combo_input(e) {
}
function _update_box(s) {
- var byid = s.className=='combo';
+ var byid = s.className=='combo' || s.className=='combo3';
var rel = s.getAttribute('rel');
var box = document.getElementsByName(rel)[0];
if(box && s.selectedIndex>=0) {
var opt = s.options[s.selectedIndex];
if(box) {
+ var old = box.value;
box.value = byid ? opt.value : opt.text;
box.setAttribute('_last', box.value);
+ return old != box.value
}
}
}
@@ -122,15 +118,18 @@ function _set_combo_select(e) {
// 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();
+ 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))
+ )
+ this.onchange();
}
e.onchange = function() {
var s = this;
- this.setAttribute('_last', this.selectedIndex);
- if(s.className=='combo')
+ this.setAttribute('_last', this.selectedIndex);
+ if(s.className=='combo' || this.className=='combo3')
_update_box(s);
if(s.selectedIndex>=0) {
var sname = '_'+s.name+'_update';
@@ -152,15 +151,39 @@ function _set_combo_select(e) {
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
- }
}
}
+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 :/
+ _w = open(editors[key][0]+el.value+'&popup=1',
+ "edit","Scrollbars=0,resizable=0,width=800,height=600");
+ if (_w.opener == null)
+ _w.opener = self;
+ editors._call = key; // store call point for passBack
+ _w.focus();
+}
+
+function passBack(value) {
+ var o = opener;
+ if(value != false) {
+ var back = o.editors[o.editors._call]; // form input bindings
+ var to = o.document.getElementsByName(back[1])[0];
+ if (to) {
+ if (to[0] != undefined)
+ to[0].value = value; // ugly hack to set selector to any value
+ to.value = value;
+ // update page after item selection
+ o.JsHttpRequest.request('_'+to.name+'_update', to.form);
+ o.setFocus(to.name);
+ }
+ }
+ close();
+}
+
/*
Behaviour definitions
*/
@@ -169,11 +192,11 @@ var inserts = {
if(e.onfocus==undefined) {
e.onfocus = function() {
save_focus(this);
- if (this.className == 'combo')
+ if (this.className == 'combo' || this.className == 'combo3')
this.select();
};
}
- if (e.className == 'combo' || e.className == 'combo2') {
+ if (e.className == 'combo' || e.className == 'combo2' || e.className == 'combo3') {
_set_combo_input(e);
}
else
@@ -200,15 +223,35 @@ var inserts = {
e.style.display = 'block';
},
// '.ajaxsubmit,.editbutton,.navibutton': // much slower on IE7
- 'button.ajaxsubmit,input.ajaxsubmit,input.editbutton,button.navibutton':
+ 'button.ajaxsubmit,input.ajaxsubmit,input.editbutton,button.editbutton,button.navibutton':
function(e) {
- e.onclick = function() {
- if (this.getAttribute('aspect') == 'process')
- progbar();
- save_focus(this);
- JsHttpRequest.request(this);
- return false;
- }
+ e.onclick = function() {
+ save_focus(e);
+ var asp = e.getAttribute('aspect')
+ if (asp && asp.indexOf('process') !== -1)
+ JsHttpRequest.request(this, null, 60000);
+ 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' || old == func) { // prevent multiply binding on ajax update
+ e.onclick = func;
+ } else {
+ e.onclick = function() {
+ if(func())
+ { old(); return true;}
+ else
+ return false;
+ }
+ }
+ }
+ }
},
'.amount': function(e) {
if(e.onblur==undefined) {
@@ -229,32 +272,44 @@ var inserts = {
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'));
+ return false;
+ }
+ },
+ 'button[aspect=popup]': function(e) {
+ var old = e.onclick
+ e.onclick = function() {
+// this.form.target = '_blank';
+// old();
+// return true;
+ if(_w) _w.close(); // this is really necessary to have window on top in FF2 :/
+ _w = open(document.location+'popup=1',
+ "edit","Scrollbars=0,resizable=0,width=800,height=600, top=50,left=50");
+ if (_w.opener == null)
+ _w.opener = self;
+ // editors._call = key; // store call point for passBack
+// _w.moveTo(50, 50);
+ _w.focus();
+ return false;
+ }
+ },
'select': function(e) {
if(e.onfocus==undefined) {
e.onfocus = function() {
save_focus(this);
};
var c = e.className;
- if (c == 'combo' || c == 'combo2')
+ if (c == 'combo' || c == 'combo2' || c == 'combo3')
_set_combo_select(e);
}
},
- 'textarea,a': function(e) {
- if(e.onfocus==undefined) {
- 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);
+ JsHttpRequest.request(this, null, 60000);
return false;
}
},
@@ -272,17 +327,17 @@ var inserts = {
'ul.ajaxtabs': function(ul) {
var ulist=ul.getElementsByTagName("li");
for (var x=0; x47 && key<58) || (key>64 && key<91))) {
+ else if (ev.altKey && !ev.ctrlKey && ((key>47 && key<58) || (key>64 && key<91))) {
+ key = String.fromCharCode(key);
var n = _hotkeys.focus;
- var l = document.links;
+ var l = document.getElementsBySelector('[accesskey='+key+']');
var cnt = l.length;
- key = String.fromCharCode(key);
+ _hotkeys.list = l;
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;
+ var link = _hotkeys.list[_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;
}