Add support for accessing items by name through their parent's children list.

This commit is contained in:
Jonathan Puckey 2011-05-15 19:12:27 +02:00
parent 6fc418b581
commit d998cd30f3
3 changed files with 56 additions and 0 deletions

View file

@ -20,6 +20,7 @@ var Group = this.Group = Item.extend({
initialize: function(items) { initialize: function(items) {
this.base(); this.base();
this._children = []; this._children = [];
this._namedChildren = {};
if (items) { if (items) {
for (var i = 0, l = items.length; i < l; i++) { for (var i = 0, l = items.length; i < l; i++) {
this.appendTop(items[i]); this.appendTop(items[i]);

View file

@ -43,6 +43,54 @@ var Item = this.Item = Base.extend({
} }
return this._id; return this._id;
}, },
_removeFromNamed: function() {
var children = this._parent._children;
var namedChildren = this._parent._namedChildren;
var name = this._name;
if (children[name] = this)
delete children[name];
var namedArray = namedChildren[name];
namedArray.splice(namedArray.indexOf(this), 1);
// If there are any items left in the named array, set
// the last of them to be this.parent.children[this.name]
if (namedArray.length) {
children[name] = namedArray[namedArray.length - 1];
} else {
// Otherwise delete the empty array
delete namedChildren[name];
}
},
/**
* The name of the item.
*/
getName: function() {
if (this._name)
return this._name;
},
setName: function(name) {
var children = this._parent.children;
var namedChildren = this._parent._namedChildren;
if (name != this.name) {
// If the item already had a name,
// remove its property from the parent's children object:
if (this._name)
this._removeFromNamed();
this._name = name ? name : undefined;
}
if (name) {
if (!namedChildren[name]) {
namedChildren[name] = [this];
} else {
namedChildren[name].push(this);
}
children[name] = this;
} else {
children[name] = undefined;
}
},
/** /**
* When passed a document, copies the item to the document, * When passed a document, copies the item to the document,
@ -243,6 +291,8 @@ var Item = this.Item = Base.extend({
*/ */
_removeFromParent: function() { _removeFromParent: function() {
if (this._parent) { if (this._parent) {
if (this._name)
this._removeFromNamed();
var res = Base.splice(this._parent._children, null, this._index, 1); var res = Base.splice(this._parent._children, null, this._index, 1);
this._parent = this._index = null; this._parent = this._index = null;
return !!res.length; return !!res.length;
@ -699,6 +749,8 @@ var Item = this.Item = Base.extend({
Base.splice(this._children, [item], top ? undefined : 0, 0); Base.splice(this._children, [item], top ? undefined : 0, 0);
item._parent = this; item._parent = this;
item._setDocument(this._document); item._setDocument(this._document);
if (item._name)
item.setName(item._name);
return true; return true;
} }
return false; return false;
@ -713,6 +765,8 @@ var Item = this.Item = Base.extend({
item._index + (above ? 1 : -1), 0); item._index + (above ? 1 : -1), 0);
this._parent = item._parent; this._parent = item._parent;
this._setDocument(item._document); this._setDocument(item._document);
if (item._name)
item.setName(item._name);
return true; return true;
} }
return false; return false;

View file

@ -19,6 +19,7 @@ var Layer = this.Layer = Group.extend({
initialize: function() { initialize: function() {
this._children = []; this._children = [];
this._namedChildren = {};
this._document = paper.document; this._document = paper.document;
// Push it onto document.layers and set index: // Push it onto document.layers and set index:
this._index = this._document.layers.push(this) - 1; this._index = this._document.layers.push(this) - 1;