mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-25 15:29:17 +01:00
163 lines
3.8 KiB
JavaScript
163 lines
3.8 KiB
JavaScript
/**
|
|
* eGroupWare eTemplate2 - JS Template base class
|
|
*
|
|
* @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
|
|
* @copyright Stylite 2011
|
|
* @version $Id$
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
/*egw:uses
|
|
et2_core_xml;
|
|
et2_core_DOMWidget;
|
|
*/
|
|
|
|
/**
|
|
* Class which implements the "template" XET-Tag. When the id parameter is set,
|
|
* the template class checks whether another template with this id already
|
|
* exists. If yes, this template is removed from the DOM tree, copied and
|
|
* inserted in place of this template.
|
|
*
|
|
* TODO: Check whether this widget behaves as it should.
|
|
*/
|
|
var et2_template = et2_DOMWidget.extend({
|
|
|
|
attributes: {
|
|
"template": {
|
|
"name": "Template",
|
|
"type": "string",
|
|
"description": "Name / ID of template"
|
|
},
|
|
"group": {
|
|
// TODO: Not implemented
|
|
"name": "Group",
|
|
"description":"Not implemented",
|
|
"default": 0
|
|
},
|
|
"version": {
|
|
"name": "Version",
|
|
"type": "string",
|
|
"description": "Version of the template"
|
|
},
|
|
"lang": {
|
|
"name": "Language",
|
|
"type": "string",
|
|
"description": "Language the template is written in"
|
|
}
|
|
},
|
|
|
|
createNamespace: true,
|
|
|
|
/**
|
|
* Initializes this template widget as a simple container.
|
|
*/
|
|
init: function() {
|
|
this._super.apply(this, arguments);
|
|
|
|
this.proxiedTemplate = null;
|
|
this.isProxied = false;
|
|
this.isProxy = false;
|
|
|
|
this.div = document.createElement("div");
|
|
|
|
if (this.id != "")
|
|
{
|
|
// Get the window this object belongs to
|
|
var node = this.getDOMNode();
|
|
var wnd = node.ownerDocument.parentNode || node.ownerDocument.defaultView;
|
|
|
|
// Set the api instance to the first part of the name of the
|
|
// template
|
|
var splitted = this.id.split('.');
|
|
this.setApiInstance(egw(splitted[0], wnd));
|
|
|
|
this.createProxy();
|
|
}
|
|
},
|
|
|
|
createProxy: function() {
|
|
// Check whether a template with the given name already exists and
|
|
// is not a proxy.
|
|
var tmpl = this.getRoot().getWidgetById(this.id);
|
|
if (tmpl instanceof et2_template && tmpl.proxiedTemplate == null &&
|
|
tmpl != this)
|
|
{
|
|
// Detatch the proxied template from the DOM to and set its
|
|
// isProxied property to true
|
|
tmpl.makeProxied();
|
|
|
|
// Do not copy the id when cloning as this leads to infinit
|
|
// recursion
|
|
tmpl.options.id = "";
|
|
|
|
// Create a clone of the template and add it as child of this
|
|
// template (done by passing "this" to the clone function)
|
|
this.proxiedTemplate = tmpl.clone(this);
|
|
|
|
// Reset the id and manually copy the id to the proxied template
|
|
tmpl.options.id = this.id;
|
|
this.proxiedTemplate.id = tmpl.id;
|
|
this.proxiedTemplate.isProxy = true;
|
|
|
|
// Disallow adding any new node to this template
|
|
this.supportedWidgetClasses = [];
|
|
}
|
|
},
|
|
|
|
/**
|
|
* If the parent node is changed, either the DOM-Node of the proxied template
|
|
* or the DOM-Node of this template is connected to the parent DOM-Node.
|
|
*/
|
|
doLoadingFinished: function() {
|
|
// Check whether the parent implements the et2_IDOMNode interface.
|
|
if (this._parent && this._parent.implements(et2_IDOMNode)) {
|
|
var parentNode = this._parent.getDOMNode(this);
|
|
|
|
if (parentNode)
|
|
{
|
|
if (this.proxiedTemplate)
|
|
{
|
|
this.proxiedTemplate.setParentDOMNode(parentNode);
|
|
this.proxiedTemplate.loadingFinished();
|
|
return false;
|
|
}
|
|
else if (!this.isProxied && !this.isProxy)
|
|
{
|
|
this.setParentDOMNode(parentNode);
|
|
}
|
|
}
|
|
}
|
|
|
|
return true;
|
|
},
|
|
|
|
makeProxied: function() {
|
|
if (!this.isProxied)
|
|
{
|
|
this.detatchFromDOM();
|
|
this.div = null;
|
|
this.parentNode = null;
|
|
}
|
|
|
|
this.isProxied = true;
|
|
},
|
|
|
|
getDOMNode: function() {
|
|
return this.div;
|
|
},
|
|
|
|
isInTree: function(_sender) {
|
|
return this._super(this, !this.isProxied);
|
|
}
|
|
|
|
});
|
|
|
|
et2_register_widget(et2_template, ["template"]);
|
|
|
|
|