mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-27 16:29:22 +01:00
Revert "use egw.applyFunc instead of own/old code, to allow calling api methods eg. egw.start_timer too"
This reverts commit 03fdceb847
.
This commit is contained in:
parent
f130134dd1
commit
330461c28b
@ -367,17 +367,60 @@ egwFnct.prototype.setValue = function(_value)
|
||||
{
|
||||
this.fnct = _value;
|
||||
}
|
||||
else if (typeof _value == "string" && _value.substring(0, 11) === 'javaScript:')
|
||||
|
||||
// Global function (on window)
|
||||
else if (typeof _value == "string" &&
|
||||
_value.substr(0,11) == "javaScript:" &&
|
||||
typeof window[_value.substr(11)] == "function")
|
||||
{
|
||||
this.fnct = function()
|
||||
{
|
||||
return egw.applyFunc(_value.substring(11), arguments, this);
|
||||
}
|
||||
this.fnct = window[_value.substr(11)];
|
||||
console.log("Global function is bad!", _value);
|
||||
}
|
||||
else if (this.acceptedTypes.indexOf(typeof _value) >= 0)
|
||||
{
|
||||
this.value = _value;
|
||||
}
|
||||
|
||||
// egw application specific function
|
||||
else if (typeof _value === "string" &&
|
||||
_value.substr(0,15) === "javaScript:app." && app)
|
||||
{
|
||||
var parts = _value.split(".");
|
||||
var existing_func = parts.pop();
|
||||
var manager = this.context && this.context.getManager ? this.context.getManager() : null;
|
||||
var parent = (manager ? manager.data.context : null) || window.app;
|
||||
for (var i = 1; i < parts.length; ++i) {
|
||||
if (typeof parent[parts[i]] !== "undefined") {
|
||||
parent = parent[parts[i]];
|
||||
}
|
||||
// check if we need a not yet included app.js object --> include it now and re-set when it arrives
|
||||
else if (i === 1 && typeof app.classes[parts[1]] === "undefined")
|
||||
{
|
||||
return import(egw.webserverUrl+"/"+parts[1]+"/js/app.min.js?"+((new Date).valueOf()/86400|0).toString())
|
||||
.then(() => {
|
||||
if(typeof app.classes[parts[i]] === "undefined")
|
||||
{
|
||||
throw new Error("app.classes."+parts[i]+" not found!");
|
||||
}
|
||||
this.setValue(_value);
|
||||
});
|
||||
}
|
||||
// check if we need a not yet instantiated app.js object --> instantiate it now
|
||||
else if (i === 1 && typeof app.classes[parts[1]] === "function")
|
||||
{
|
||||
parent = parent[parts[1]] = new app.classes[parts[1]]();
|
||||
}
|
||||
// Nope
|
||||
else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (typeof parent[existing_func] === "function") {
|
||||
this.fnct = parent[existing_func];
|
||||
this.context = parent;
|
||||
}
|
||||
}
|
||||
|
||||
// Something, but could not figure it out
|
||||
else if (_value)
|
||||
{
|
||||
@ -516,4 +559,5 @@ export function sprintf() {
|
||||
f = f.substring(m[0].length);
|
||||
}
|
||||
return o.join('');
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user