mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-16 10:58:47 +01:00
d486e50a57
* Changed way of how "webserverUrl" gets set - any type of data can now be injected into the egw object by creating an object with the data and an entry "prefsOnly" set to true. This allows to ensure, that "webserverUrl" is the first thing that is being set in the egw object (as needed when including new JS/CSS files at runtime) jsapi: * Fixed including JS/CSS files at runtime in other windows than the root window * Added "ready" function/module, which provides an alternative to the $j("ready") function. The ready module provides the functionality to postpone calling the "ready" until certain events happened. * using jQuery calendar object instead of jscalendar in the calendar function. * added "jquery" module which takes care of including all jQuery modules in all windows * added possibility for modules to update constants using the "constant" function. * added possibility for modules to access certain other modules using the "module" function etemplate: * Using new egw(window).ready function to build the template first if loading has finished.
165 lines
3.8 KiB
JavaScript
165 lines
3.8 KiB
JavaScript
/**
|
|
* EGroupware clientside API object
|
|
*
|
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
|
* @package etemplate
|
|
* @subpackage api
|
|
* @link http://www.egroupware.org
|
|
* @author Andreas Stöckel (as AT stylite.de)
|
|
* @author Ralf Becker <RalfBecker@outdoor-training.de>
|
|
* @version $Id$
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
/*egw:uses
|
|
egw_core;
|
|
egw_ready;
|
|
egw_debug;
|
|
*/
|
|
|
|
egw.extend('files', egw.MODULE_WND_LOCAL, function(_app, _wnd) {
|
|
|
|
var egw = this;
|
|
|
|
/**
|
|
* Array which contains all currently bound in javascript and css files.
|
|
*/
|
|
var files = {};
|
|
|
|
/**
|
|
* Gather all already loaded JavaScript and CSS files on document load.
|
|
*
|
|
* TODO: Currently this can only contain the JS files present in the main
|
|
* window.
|
|
*/
|
|
this.module('ready', _wnd).ready(function() {
|
|
// Iterate over the script tags
|
|
var scripts = _wnd.document.getElementsByTagName('script');
|
|
for (var i = 0; i < scripts.length; i++)
|
|
{
|
|
var src = scripts[i].getAttribute('src');
|
|
|
|
if (src)
|
|
{
|
|
files[src] = true;
|
|
}
|
|
}
|
|
|
|
// Iterate over the link tags
|
|
var links = _wnd.document.getElementsByTagName('link');
|
|
for (var i = 0; i < links.length; i++)
|
|
{
|
|
var src = links[i].getAttribute('href');
|
|
|
|
if (src)
|
|
{
|
|
files[src] = true;
|
|
}
|
|
}
|
|
});
|
|
|
|
function includeJSFile(_jsFile, _callback, _context)
|
|
{
|
|
var alreadyLoaded = false;
|
|
|
|
if (typeof files[_jsFile] === 'undefined')
|
|
{
|
|
// Create the script node which contains the new file
|
|
var scriptnode = _wnd.document.createElement('script');
|
|
scriptnode.type = "text/javascript";
|
|
scriptnode.src = _jsFile;
|
|
scriptnode._originalSrc = _jsFile;
|
|
|
|
// Setup the 'onload' handler for FF, Opera, Chrome
|
|
scriptnode.onload = function(e) {
|
|
egw.debug('info', 'Retrieved JS file "%s" from server', _jsFile);
|
|
_callback.call(_context, _jsFile);
|
|
};
|
|
|
|
// IE
|
|
if (typeof scriptnode.readyState != 'undefined')
|
|
{
|
|
if (scriptnode.readyState != 'complete' &&
|
|
scriptnode.readyState != 'loaded')
|
|
{
|
|
scriptnode.onreadystatechange = function() {
|
|
var node = _wnd.event.srcElement;
|
|
if (node.readyState == 'complete' || node.readyState == 'loaded')
|
|
{
|
|
egw.debug('info', 'Retrieved JS file "%s" from server', _jsFile);
|
|
_callback.call(_context, _jsFile);
|
|
}
|
|
};
|
|
}
|
|
else
|
|
{
|
|
alreadyLoaded = true;
|
|
}
|
|
}
|
|
|
|
// Append the newly create script node to the head
|
|
var head = _wnd.document.getElementsByTagName('head')[0];
|
|
head.appendChild(scriptnode);
|
|
|
|
// Request the given javascript file
|
|
egw.debug('info', 'Requested JS file "%s" from server', _jsFile);
|
|
}
|
|
|
|
// If the file is already loaded, call the callback
|
|
if (alreadyLoaded)
|
|
{
|
|
_wnd.setTimeout(
|
|
function() {
|
|
_callback.call(_context, _jsFile);
|
|
}, 0);
|
|
}
|
|
}
|
|
|
|
return {
|
|
includeJS: function(_jsFiles, _callback, _context) {
|
|
// Also allow including a single javascript file
|
|
if (typeof _jsFiles === 'string')
|
|
{
|
|
_jsFiles = [_jsFiles];
|
|
}
|
|
|
|
var loaded = 0;
|
|
|
|
// Include all given JS files, if all are successfully loaded, call
|
|
// the context function
|
|
for (var i = 0; i < _jsFiles.length; i++)
|
|
{
|
|
includeJSFile.call(this, _jsFiles[i], function(_file) {
|
|
loaded++;
|
|
if (loaded == _jsFiles.length && _callback) {
|
|
_callback.call(_context);
|
|
}
|
|
});
|
|
}
|
|
},
|
|
|
|
includeCSS: function(_cssFile) {
|
|
//Check whether the requested file has already been included
|
|
if (typeof files[_cssFile] === 'undefined')
|
|
{
|
|
files[_cssFile] = true;
|
|
|
|
// Create the node which is used to include the css fiel
|
|
var cssnode = _wnd.document.createElement('link');
|
|
cssnode.type = "text/css";
|
|
cssnode.rel = "stylesheet";
|
|
cssnode.href = _cssFile;
|
|
|
|
// Get the head node and append the newly created "link" node
|
|
// to it.
|
|
var head = _wnd.document.getElementsByTagName('head')[0];
|
|
head.appendChild(cssnode);
|
|
}
|
|
}
|
|
}
|
|
|
|
});
|
|
|
|
|