summaryrefslogtreecommitdiffstats
path: root/dist/svg.js
diff options
context:
space:
mode:
Diffstat (limited to 'dist/svg.js')
-rw-r--r--dist/svg.js102
1 files changed, 49 insertions, 53 deletions
diff --git a/dist/svg.js b/dist/svg.js
index fb9e21b..b57af02 100644
--- a/dist/svg.js
+++ b/dist/svg.js
@@ -1,4 +1,4 @@
-/* svg.js v0.1-86-g8b253f8 - svg container element fx event group arrange defs mask pattern gradient doc shape wrap rect ellipse poly path image text nested sugar - svgjs.com/license */
+/* svg.js v0.1-87-g6ae4977 - svg container element fx event group arrange defs mask pattern gradient doc shape wrap rect ellipse poly path image text nested sugar - svgjs.com/license */
(function() {
this.svg = function(element) {
@@ -187,6 +187,7 @@
skewX: 0,
skewY: 0
};
+
};
//
@@ -225,6 +226,10 @@
clone.child.trans = this.child.trans;
clone.child.attr(this.child.attrs).transform({});
+ /* re-plot shape */
+ if (clone.plot)
+ clone.plot(this.child.attrs[this.child instanceof SVG.Path ? 'd' : 'points']);
+
} else {
var name = this.node.nodeName;
@@ -258,6 +263,10 @@
doc: function() {
return this._parent(SVG.Doc);
},
+ // Get parent nested document
+ nested: function() {
+ return this._parent(SVG.Nested);
+ },
// Set svg element attribute
attr: function(a, v, n) {
if (arguments.length < 2) {
@@ -727,7 +736,7 @@
SVG.extend(SVG.Element, {
// Get all siblings, including myself
siblings: function() {
- return this.parent.children();
+ return (this.nested() || this.doc()).children();
},
// Get the curent position siblings
position: function() {
@@ -786,8 +795,7 @@
this.constructor.call(this, SVG.create('mask'));
/* set unique id */
- this.id = 'svgjs_' + (SVG.did++);
- this.attr('id', this.id);
+ this.attr('id', (this.id = 'svgjs_element_' + (SVG.did++)));
};
// Inherit from SVG.Element
@@ -809,8 +817,7 @@
this.constructor.call(this, SVG.create('pattern'));
/* set unique id */
- this.id = 'svgjs_' + (SVG.did++);
- this.attr('id', this.id);
+ this.attr('id', (this.id = 'svgjs_element_' + (SVG.did++)));
};
// Inherit from SVG.Element
@@ -853,8 +860,7 @@
this.constructor.call(this, SVG.create(type + 'Gradient'));
/* set unique id */
- this.id = 'svgjs_' + (SVG.did++);
- this.attr('id', this.id);
+ this.attr('id', (this.id = 'svgjs_element_' + (SVG.did++)));
/* store type */
this.type = type;
@@ -1044,10 +1050,10 @@
SVG.extend(SVG.Wrap, {
// Move wrapper around
move: function(x, y) {
- return this.center(
- x + (this._b.width * this.child.trans.scaleX) / 2,
- y + (this._b.height * this.child.trans.scaleY) / 2
- );
+ return this.transform({
+ x: x,
+ y: y
+ });
},
// Set the actual size in pixels
size: function(width, height) {
@@ -1062,10 +1068,10 @@
},
// Move by center
center: function(x, y) {
- return this.transform({
- x: x,
- y: y
- });
+ return this.move(
+ x + (this._b.width * this.child.trans.scaleX) / -2,
+ y + (this._b.height * this.child.trans.scaleY) / -2
+ );
},
// Create distributed attr
attr: function(a, v, n) {
@@ -1102,8 +1108,8 @@
/* reposition element withing wrapper */
this.child.transform({
- x: -this._b.cx,
- y: -this._b.cy
+ x: -this._b.x,
+ y: -this._b.y
});
return this;
@@ -1349,23 +1355,35 @@
});
- SVG.extend(SVG.Element, {
- // Rotation
- rotate: function(angle) {
- return this.transform({
- rotation: angle || 0
- });
- },
- // Skew
- skew: function(x, y) {
- return this.transform({
- skewX: x || 0,
- skewY: y || 0
+ [SVG.Element, SVG.FX].forEach(function(module) {
+ if (module) {
+ SVG.extend(module, {
+ // Rotation
+ rotate: function(angle) {
+ return this.transform({
+ rotation: angle || 0
+ });
+ },
+ // Skew
+ skew: function(x, y) {
+ return this.transform({
+ skewX: x || 0,
+ skewY: y || 0
+ });
+ },
+ // Scale
+ scale: function(x, y) {
+ return this.transform({
+ scaleX: x || 0,
+ scaleY: y || 0
+ });
+ }
+
});
}
-
});
+
if (SVG.G) {
SVG.extend(SVG.G, {
// Move using translate
@@ -1400,28 +1418,6 @@
});
}
-
- if (SVG.FX) {
- SVG.extend(SVG.FX, {
- // Rotation
- rotate: function(angle) {
- return this.transform({
- rotation: angle || 0
- });
- },
-
- // Skew
- skew: function(x, y) {
- return this.transform({
- skewX: x || 0,
- skewY: y || 0
- });
- }
-
- });
- }
-
-
}).call(this);