From d4bb8a00a914e8306999d9b6d7b6c0a0bf8180ec Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Mon, 23 Jun 2014 08:10:40 +0000 Subject: [PATCH] move et2_call method to egw.js to have it always available at window scope (it is NOT et2 specific), maybe we find a better/nicer place for it --- etemplate/js/et2_core_common.js | 41 --------------------------------- phpgwapi/js/jsapi/egw.js | 41 +++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 41 deletions(-) diff --git a/etemplate/js/et2_core_common.js b/etemplate/js/et2_core_common.js index 72ad9390c0..c088f928b3 100644 --- a/etemplate/js/et2_core_common.js +++ b/etemplate/js/et2_core_common.js @@ -768,47 +768,6 @@ function et2_rangeSubstract(_ar1, _ar2) return res; } -/** - * Call a function specified by it's name (possibly dot separated, eg. "app.myapp.myfunc") - * - * @param {string} _func dot-separated function name - * variable number of arguments - * @returns {Boolean} - */ -function et2_call(_func) -{ - var args = [].slice.call(arguments); // convert arguments to array - var func = args.shift(); - var parent = window; - - if (typeof _func == 'string') - { - var parts = _func.split('.'); - func = parts.pop(); - for(var i=0; i < parts.length; ++i) - { - if (typeof parent[parts[i]] != 'undefined') - { - parent = parent[parts[i]]; - } - // check if we need a not yet instanciated app.js object --> instanciate it now - else if (i == 1 && parts[0] == 'app' && typeof window.app.classes[parts[1]] == 'function') - { - parent = parent[parts[1]] = new window.app.classes[parts[1]](); - } - } - if (typeof parent[func] == 'function') - { - func = parent[func]; - } - } - if (typeof func != 'function') - { - throw _func+" is not a function!"; - } - return func.apply(parent, args); -} - /** * Decode html entities so they can be added via .text(_str), eg. html_entity_decode('&') === '&' * diff --git a/phpgwapi/js/jsapi/egw.js b/phpgwapi/js/jsapi/egw.js index 4deb33e61e..16868063f3 100644 --- a/phpgwapi/js/jsapi/egw.js +++ b/phpgwapi/js/jsapi/egw.js @@ -260,3 +260,44 @@ } }; })(); + +/** + * Call a function specified by it's name (possibly dot separated, eg. "app.myapp.myfunc") + * + * @param {string} _func dot-separated function name + * variable number of arguments + * @returns {Boolean} + */ +function et2_call(_func) +{ + var args = [].slice.call(arguments); // convert arguments to array + var func = args.shift(); + var parent = window; + + if (typeof _func == 'string') + { + var parts = _func.split('.'); + func = parts.pop(); + for(var i=0; i < parts.length; ++i) + { + if (typeof parent[parts[i]] != 'undefined') + { + parent = parent[parts[i]]; + } + // check if we need a not yet instanciated app.js object --> instanciate it now + else if (i == 1 && parts[0] == 'app' && typeof window.app.classes[parts[1]] == 'function') + { + parent = parent[parts[1]] = new window.app.classes[parts[1]](); + } + } + if (typeof parent[func] == 'function') + { + func = parent[func]; + } + } + if (typeof func != 'function') + { + throw _func+" is not a function!"; + } + return func.apply(parent, args); +}