mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-14 18:08:21 +01:00
ecb972ca66
XML files are parsed into JSON objects on the server, then sent as JSON. Etemplate parses the JSON object on the client side instead of the XML file directly. This is supposed to be faster for IE.
142 lines
3.0 KiB
JavaScript
142 lines
3.0 KiB
JavaScript
/**
|
|
* EGroupware eTemplate2 - JS Box 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
|
|
* @copyright Stylite 2011
|
|
* @version $Id$
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
/*egw:uses
|
|
jquery.jquery;
|
|
et2_core_baseWidget;
|
|
*/
|
|
|
|
/**
|
|
* Class which implements box and vbox tag
|
|
*
|
|
* @augments et2_baseWidget
|
|
*/
|
|
var et2_box = et2_baseWidget.extend([et2_IDetachedDOM],
|
|
{
|
|
attributes: {
|
|
// Not needed
|
|
"rows": {"ignore": true},
|
|
"cols": {"ignore": true}
|
|
},
|
|
|
|
createNamespace: true,
|
|
|
|
/**
|
|
* Constructor
|
|
*
|
|
* @memberOf et2_box
|
|
*/
|
|
init: function() {
|
|
this._super.apply(this, arguments);
|
|
|
|
this.div = $j(document.createElement("div"))
|
|
.addClass("et2_" + this._type)
|
|
.addClass("et2_box_widget");
|
|
|
|
this.setDOMNode(this.div[0]);
|
|
},
|
|
|
|
/**
|
|
* Overriden so we can check for autorepeating children. We only check for
|
|
* $ in the immediate children & grandchildren of this node.
|
|
*
|
|
* @param {object} _node
|
|
*/
|
|
loadFromJSON: function(_node) {
|
|
if(this._type != "box")
|
|
{
|
|
return this._super.apply(this, arguments);
|
|
}
|
|
// Load the child nodes.
|
|
var childIndex = 0;
|
|
var repeatNode = null;
|
|
for (var i=0; i < _node.children.length; i++)
|
|
{
|
|
var node = _node.children[i];
|
|
var widgetType = node.tag;
|
|
|
|
// Create the new element, if no expansion needed
|
|
var id = et2_readAttrWithDefault(node, "id", "");
|
|
if(id.indexOf('$') < 0 || widgetType != 'box')
|
|
{
|
|
this.createElementFromObject(node);
|
|
childIndex++;
|
|
}
|
|
else
|
|
{
|
|
repeatNode = node;
|
|
}
|
|
}
|
|
|
|
// Only the last child repeats(?)
|
|
if(repeatNode != null)
|
|
{
|
|
var currentPerspective = this.getArrayMgr("content").perspectiveData;
|
|
// Extra content
|
|
for(childIndex; typeof this.getArrayMgr("content").data[childIndex] != "undefined" && this.getArrayMgr("content").data[childIndex]; childIndex++) {
|
|
// Adjust for the row
|
|
var mgrs = this.getArrayMgrs();
|
|
for(var name in mgrs)
|
|
{
|
|
if(this.getArrayMgr(name).getEntry(childIndex))
|
|
{
|
|
this.getArrayMgr(name).perspectiveData.row = childIndex;
|
|
}
|
|
}
|
|
|
|
this.createElementFromObject(repeatNode);
|
|
}
|
|
|
|
// Reset
|
|
for(var name in this.getArrayMgrs())
|
|
{
|
|
this.getArrayMgr(name).perspectiveData = currentPerspective;
|
|
}
|
|
}
|
|
},
|
|
|
|
/**
|
|
* Code for implementing et2_IDetachedDOM
|
|
* This doesn't need to be implemented.
|
|
* Individual widgets are detected and handled by the grid, but the interface is needed for this to happen
|
|
*
|
|
* @param {array} _attrs array to add further attributes to
|
|
*/
|
|
getDetachedAttributes: function(_attrs)
|
|
{
|
|
_attrs.push('data');
|
|
},
|
|
|
|
getDetachedNodes: function()
|
|
{
|
|
return [this.getDOMNode()];
|
|
},
|
|
|
|
setDetachedAttributes: function(_nodes, _values)
|
|
{
|
|
if (_values.data)
|
|
{
|
|
var pairs = _values.data.split(/,/g);
|
|
for(var i=0; i < pairs.length; ++i)
|
|
{
|
|
var name_value = pairs[i].split(':');
|
|
$j(_nodes[0]).attr('data-'+name_value[0], name_value[1]);
|
|
}
|
|
}
|
|
}
|
|
|
|
});
|
|
et2_register_widget(et2_box, ["vbox", "box"]);
|
|
|