/**
* @class Ext.fx.target.CompositeElement
*
* This class represents a animation target for a {@link Ext.CompositeElement}. It allows
* each {@link Ext.dom.Element} in the group to be animated as a whole. In general this class
* will not be created directly, the {@link Ext.CompositeElement} will be passed to the animation
* and and the appropriate target will be created.
*/
Ext.define('Ext.fx.target.CompositeElement', {
extend: 'Ext.fx.target.Element',
/**
* @property {Boolean} isComposite
* `true` in this class to identify an object as an instantiated CompositeElement,
* or subclass thereof.
*/
isComposite: true,
constructor: function(target) {
target.id = target.id || Ext.id(null, 'ext-composite-');
this.callParent([target]);
},
getAttr: function(attr, val) {
var out = [],
target = this.target,
elements = target.elements,
length = elements.length,
i,
el;
for (i = 0; i < length; i++) {
el = elements[i];
if (el) {
el = target.getElement(el);
out.push([el, this.getElVal(el, attr, val)]);
}
}
return out;
},
setAttr: function(targetData) {
var target = this.target,
ln = targetData.length,
elements = target.elements,
ln3 = elements.length,
value, k,
attrs, attr, el, i, j, ln2;
for (i = 0; i < ln; i++) {
attrs = targetData[i].attrs;
for (attr in attrs) {
if (attrs.hasOwnProperty(attr)) {
ln2 = attrs[attr].length;
for (j = 0; j < ln2; j++) {
value = attrs[attr][j][1];
for (k = 0; k < ln3; ++k) {
el = elements[k];
if (el) {
el = target.getElement(el);
this.setElVal(el, attr, value);
}
}
}
}
}
}
},
remove: function() {
this.target.destroy();
}
});