mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-20 22:39:50 -05:00
Make sure Item#children is always checked for != null and simplify many of the DOM methods.
This commit is contained in:
parent
e66dd46b9c
commit
be6d60102c
2 changed files with 56 additions and 60 deletions
|
@ -156,6 +156,7 @@ var Item = this.Item = Base.extend({
|
|||
* Reverses the order of this item's children
|
||||
*/
|
||||
reverseChildren: function() {
|
||||
if (this.children)
|
||||
this.children.reverse();
|
||||
},
|
||||
|
||||
|
@ -163,38 +164,28 @@ var Item = this.Item = Base.extend({
|
|||
* The first item contained within this item.
|
||||
*/
|
||||
getFirstChild: function() {
|
||||
if (this.children.length > 0)
|
||||
return this.children[0];
|
||||
return this.children && this.children[0] || null;
|
||||
},
|
||||
|
||||
/**
|
||||
* The last item contained within this item.
|
||||
*/
|
||||
getLastChild: function() {
|
||||
if (this.children.length > 0)
|
||||
return this.children[this.children.length - 1];
|
||||
return this.children && this.children[this.children.length - 1] || null;
|
||||
},
|
||||
|
||||
/**
|
||||
* The next item on the same level as this item.
|
||||
*/
|
||||
getNextSibling: function() {
|
||||
if (this.parent) {
|
||||
var index = this.index + 1;
|
||||
if (index < this.parent.children.length)
|
||||
return this.parent.children[index];
|
||||
}
|
||||
return this.parent && this.parent.children[this.getIndex() + 1] || null;
|
||||
},
|
||||
|
||||
/**
|
||||
* The previous item on the same level as this item.
|
||||
*/
|
||||
getPreviousSibling: function() {
|
||||
if (this.parent) {
|
||||
var index = this.index - 1;
|
||||
if (index <= 0)
|
||||
return this.parent.children[index];
|
||||
}
|
||||
return this.parent && this.parent.children[this.getIndex() - 1] || null;
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -204,23 +195,26 @@ var Item = this.Item = Base.extend({
|
|||
// TODO: Relying on indexOf() here is slow, especially since it is
|
||||
// used for getPrevious/NextSibling().
|
||||
// We need linked lists instead.
|
||||
return this.parent.children.indexOf(this);
|
||||
return this.parent ? this.parent.children.indexOf(this) : -1;
|
||||
},
|
||||
|
||||
/**
|
||||
* Removes the item from its parent's children list.
|
||||
*/
|
||||
removeFromParent: function() {
|
||||
if (this.parent)
|
||||
this.parent.children.splice(this.index, 1);
|
||||
if (this.parent) {
|
||||
var ok = !!this.parent.children.splice(this.getIndex(), 1).length;
|
||||
this.parent = null;
|
||||
return ok;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
|
||||
/**
|
||||
* Removes the item.
|
||||
*/
|
||||
remove: function() {
|
||||
this.removeFromParent();
|
||||
return this.removeFromParent();
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -231,7 +225,7 @@ var Item = this.Item = Base.extend({
|
|||
* @return {@true if it has one or more children}
|
||||
*/
|
||||
hasChildren: function() {
|
||||
return this.children && this.children.length;
|
||||
return this.children && this.children.length > 0;
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -283,10 +277,14 @@ var Item = this.Item = Base.extend({
|
|||
* @param item The item that will be appended as a child
|
||||
*/
|
||||
appendTop: function(item) {
|
||||
if (this.children) {
|
||||
item.removeFromParent();
|
||||
this.children.push(item);
|
||||
item.parent = this;
|
||||
item.document = this.document;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -305,10 +303,14 @@ var Item = this.Item = Base.extend({
|
|||
* @param item The item that will be appended as a child
|
||||
*/
|
||||
appendBottom: function(item) {
|
||||
if (this.children) {
|
||||
item.removeFromParent();
|
||||
this.children.splice(0, 0, item);
|
||||
item.parent = this;
|
||||
item.document = this.document;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -337,11 +339,13 @@ var Item = this.Item = Base.extend({
|
|||
*/
|
||||
moveAbove: function(item) {
|
||||
// first remove the item from its parent's children list
|
||||
this.removeFromParent();
|
||||
item.parent.children.splice(item.index + 1, 0, this);
|
||||
if (item.parent && this.removeFromParent()) {
|
||||
item.parent.children.splice(item.getIndex() + 1, 0, this);
|
||||
this.parent = item.parent;
|
||||
this.document = item.document;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -361,11 +365,13 @@ var Item = this.Item = Base.extend({
|
|||
*/
|
||||
moveBelow: function(item) {
|
||||
// first remove the item from its parent's children list
|
||||
this.removeFromParent();
|
||||
item.parent.children.splice(item.index - 1, 0, this);
|
||||
if (item.parent && this.removeFromParent()) {
|
||||
item.parent.children.splice(item.getIndex() - 1, 0, this);
|
||||
this.parent = item.parent;
|
||||
this.document = item.document;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
|
||||
/**
|
||||
|
|
|
@ -9,7 +9,7 @@ var Layer = this.Layer = Group.extend({
|
|||
},
|
||||
|
||||
getIndex: function() {
|
||||
return !this.parent ? this.document.layers.indexOf(this) : this.base();
|
||||
return this.parent ? this.base() : this.document.layers.indexOf(this);
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -18,9 +18,9 @@ var Layer = this.Layer = Group.extend({
|
|||
*/
|
||||
removeFromParent: function() {
|
||||
if (!this.parent) {
|
||||
this.document.layers.splice(this.index, 1);
|
||||
return !!this.document.layers.splice(this.getIndex(), 1).length;
|
||||
} else {
|
||||
this.base();
|
||||
return this.base();
|
||||
}
|
||||
},
|
||||
|
||||
|
@ -28,11 +28,11 @@ var Layer = this.Layer = Group.extend({
|
|||
// if the item is a layer and contained within Document#layers
|
||||
if (item instanceof Layer && !item.parent) {
|
||||
this.removeFromParent();
|
||||
item.document.layers.splice(item.index + 1, 0, this);
|
||||
item.document.layers.splice(item.getIndex() + 1, 0, this);
|
||||
this.document = item.document;
|
||||
return true;
|
||||
} else {
|
||||
this.base(item);
|
||||
return this.base(item);
|
||||
}
|
||||
},
|
||||
|
||||
|
@ -40,32 +40,22 @@ var Layer = this.Layer = Group.extend({
|
|||
// if the item is a layer and contained within Document#layers
|
||||
if (item instanceof Layer && !item.parent) {
|
||||
this.removeFromParent();
|
||||
item.document.layers.splice(item.index - 1, 0, this);
|
||||
item.document.layers.splice(item.getIndex() - 1, 0, this);
|
||||
this.document = item.document;
|
||||
return true;
|
||||
} else {
|
||||
this.base(item);
|
||||
return this.base(item);
|
||||
}
|
||||
},
|
||||
|
||||
getNextSibling: function() {
|
||||
if (!this.parent) {
|
||||
var index = this.index + 1;
|
||||
if (index < this.document.layers.length)
|
||||
return this.document.layers[index];
|
||||
} else {
|
||||
return this.base();
|
||||
}
|
||||
return this.parent ? this.base()
|
||||
: this.document.layers[this.getIndex() + 1] || null;
|
||||
},
|
||||
|
||||
getPreviousSibling: function() {
|
||||
if (!this.parent) {
|
||||
var index = this.index - 1;
|
||||
if (index <= 0)
|
||||
return this.document.layers[index];
|
||||
} else {
|
||||
return this.base();
|
||||
}
|
||||
return this.parent ? this.base()
|
||||
: this.document.layers[this.getIndex() - 1] || null;
|
||||
},
|
||||
|
||||
activate: function() {
|
||||
|
|
Loading…
Reference in a new issue