summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorUlrich-Matthias Schäfer <ulima.ums@googlemail.com>2015-11-04 02:43:53 +0100
committerUlrich-Matthias Schäfer <ulima.ums@googlemail.com>2015-11-04 02:43:53 +0100
commitc271f48c64e859367bdd22321dbfc2e96eefc0af (patch)
tree7bc5223f6e4f649c7487530c21d9cd209dc97a7e /src
parent2bcd57ca3776a026786c0812206a17d4f1aeae19 (diff)
downloadsvg.js-c271f48c64e859367bdd22321dbfc2e96eefc0af.tar.gz
svg.js-c271f48c64e859367bdd22321dbfc2e96eefc0af.zip
fixed return value of `text()` after import/clone (#393)
Diffstat (limited to 'src')
-rw-r--r--src/svg.js12
-rw-r--r--src/text.js63
2 files changed, 44 insertions, 31 deletions
diff --git a/src/svg.js b/src/svg.js
index 42d486e..c8454f0 100644
--- a/src/svg.js
+++ b/src/svg.js
@@ -21,7 +21,7 @@ SVG.supported = (function() {
!! document.createElementNS(SVG.ns,'svg').createSVGRect
})()
-// Don't bother to continue if SVG is not supported
+// Don't bother to continue if SVG is not supported
if (!SVG.supported) return false
// Element id sequence
@@ -36,23 +36,23 @@ SVG.eid = function(name) {
SVG.create = function(name) {
// create element
var element = document.createElementNS(this.ns, name)
-
+
// apply unique id
element.setAttribute('id', this.eid(name))
-
+
return element
}
// Method for extending objects
SVG.extend = function() {
var modules, methods, key, i
-
+
// Get list of modules
modules = [].slice.call(arguments)
-
+
// Get object with extensions
methods = modules.pop()
-
+
for (i = modules.length - 1; i >= 0; i--)
if (modules[i])
for (key in methods)
diff --git a/src/text.js b/src/text.js
index cfe797f..e207d9f 100644
--- a/src/text.js
+++ b/src/text.js
@@ -2,7 +2,7 @@ SVG.Text = SVG.invent({
// Initialize node
create: function() {
this.constructor.call(this, SVG.create('text'))
-
+
this._leading = new SVG.Number(1.3) // store leading value for rebuilding
this._rebuild = true // enable automatic updating of dy values
this._build = false // disable build mode for adding multiple lines
@@ -21,10 +21,12 @@ SVG.Text = SVG.invent({
var clone = assignNewId(this.node.cloneNode(true))
// mark first level tspans as newlines
- clone.lines().each(function(){
- this.newLined = true
+ this.lines().each(function(i){
+ clone.lines().get(i).newLined = this.newLined;
})
+ clone._leading = new SVG.Number(this._leading.valueOf())
+
// insert the clone after myself
this.after(clone)
@@ -35,7 +37,7 @@ SVG.Text = SVG.invent({
// act as getter
if (x == null)
return this.attr('x')
-
+
// move lines as well if no textPath is present
if (!this.textPath)
this.lines().each(function() { if (this.newLined) this.x(x) })
@@ -64,24 +66,39 @@ SVG.Text = SVG.invent({
// Set the text content
, text: function(text) {
// act as getter
- if (typeof text === 'undefined') return this.content
-
+ if (typeof text === 'undefined'){
+ var text = ''
+ var children = this.node.childNodes
+ for(var i = 0, len = children.length; i < len; ++i){
+
+ // add newline if its not the first child and newLined is set to true
+ if(i != 0 && children[i].nodeType != 3 && SVG.adopt(children[i]).newLined == true){
+ text += '\n'
+ }
+
+ // add content of this node
+ text += children[i].textContent
+ }
+
+ return text
+ }
+
// remove existing content
this.clear().build(true)
-
+
if (typeof text === 'function') {
// call block
text.call(this, this)
} else {
// store text and make sure text is not blank
- text = (this.content = text).split('\n')
-
+ text = text.split('\n')
+
// build new lines
for (var i = 0, il = text.length; i < il; i++)
this.tspan(text[i]).newLine()
}
-
+
// disable build mode and rebuild lines
return this.build(false).rebuild()
}
@@ -94,10 +111,10 @@ SVG.Text = SVG.invent({
// act as getter
if (value == null)
return this._leading
-
+
// act as setter
this._leading = new SVG.Number(value)
-
+
return this.rebuild()
}
// Get all the first level lines
@@ -119,13 +136,13 @@ SVG.Text = SVG.invent({
// define position of all lines
if (this._rebuild) {
var self = this
-
+
this.lines().each(function() {
if (this.newLined) {
if (!this.textPath)
this.attr('x', self.attr('x'))
-
- this.attr('dy', self._leading * new SVG.Number(self.attr('font-size')))
+
+ this.attr('dy', self._leading * new SVG.Number(self.attr('font-size')))
}
})
@@ -140,7 +157,7 @@ SVG.Text = SVG.invent({
return this
}
}
-
+
// Add parent method
, construct: {
// Create text element
@@ -190,7 +207,7 @@ SVG.Tspan = SVG.invent({
return this.dy(t._leading * t.attr('font-size')).attr('x', t.x())
}
}
-
+
})
SVG.extend(SVG.Text, SVG.Tspan, {
@@ -201,8 +218,8 @@ SVG.extend(SVG.Text, SVG.Tspan, {
this.clear()
// create text node
- this.node.appendChild(document.createTextNode((this.content = text)))
-
+ this.node.appendChild(document.createTextNode(text))
+
return this
}
// Create a tspan
@@ -213,7 +230,7 @@ SVG.extend(SVG.Text, SVG.Tspan, {
// clear if build mode is disabled
if (this._build === false)
this.clear()
-
+
// add new tspan
node.appendChild(tspan.node)
@@ -226,11 +243,7 @@ SVG.extend(SVG.Text, SVG.Tspan, {
// remove existing child nodes
while (node.hasChildNodes())
node.removeChild(node.lastChild)
-
- // reset content references
- if (this instanceof SVG.Text)
- this.content = ''
-
+
return this
}
// Get length of text element