mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-03 04:29:28 +01:00
Hopefully fix context for action system applyFunc call
This commit is contained in:
parent
55f1c2a53b
commit
006199a199
@ -367,60 +367,18 @@ egwFnct.prototype.setValue = function(_value)
|
|||||||
{
|
{
|
||||||
this.fnct = _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 = window[_value.substr(11)];
|
this.fnct = function()
|
||||||
console.log("Global function is bad!", _value);
|
{
|
||||||
|
const manager = this.context && this.context.getManager ? this.context.getManager() : null;
|
||||||
|
return egw.applyFunc(_value.substring(11), arguments, (manager ? manager.data.context : null) || window);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (this.acceptedTypes.indexOf(typeof _value) >= 0)
|
else if (this.acceptedTypes.indexOf(typeof _value) >= 0)
|
||||||
{
|
{
|
||||||
this.value = _value;
|
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
|
// Something, but could not figure it out
|
||||||
else if (_value)
|
else if (_value)
|
||||||
{
|
{
|
||||||
@ -560,4 +518,3 @@ export function sprintf() {
|
|||||||
}
|
}
|
||||||
return o.join('');
|
return o.join('');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user