diff options
author | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2018-11-07 17:09:52 +0100 |
---|---|---|
committer | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2018-11-07 17:09:52 +0100 |
commit | 38ce7a752078588aca394ef91f8c80502e68731a (patch) | |
tree | 5a504333966f755f04d1b9cf8322637fc505c9c2 /src/elements | |
parent | 47fda3cf67cdc8ab20d3b1ba9d65a810adddf5ee (diff) | |
download | svg.js-38ce7a752078588aca394ef91f8c80502e68731a.tar.gz svg.js-38ce7a752078588aca394ef91f8c80502e68731a.zip |
fix the export/import function and enhance it
Diffstat (limited to 'src/elements')
-rw-r--r-- | src/elements/Dom.js | 92 |
1 files changed, 70 insertions, 22 deletions
diff --git a/src/elements/Dom.js b/src/elements/Dom.js index eab3f0d..16aefd8 100644 --- a/src/elements/Dom.js +++ b/src/elements/Dom.js @@ -188,11 +188,10 @@ export default class Dom extends EventTarget { return this } - // Replace element + // Replace this with element replace (element) { - // FIXME: after() might not be available here - this.after(element).remove() - + element = makeInstance(element) + this.node.parentNode.replaceChild(element.node, this.node) return element } @@ -202,30 +201,79 @@ export default class Dom extends EventTarget { } // Import raw svg - svg (svg) { - var well, len - - // act as a setter if svg is given - if (svg) { - // create temporary holder - well = document.createElementNS(ns, 'svg') - // dump raw svg - well.innerHTML = svg - - // transplant nodes - for (len = well.children.length; len--;) { - this.node.appendChild(well.firstElementChild) - } + svg (svgOrFn, outerHTML) { + var well, len, fragment + + if (svgOrFn === false) { + outerHTML = false + svgOrFn = null + } + + // act as getter if no svg string is given + if (svgOrFn == null || typeof svgOrFn === 'function') { + // The default for exports is, that the outerNode is included + outerHTML = outerHTML == null ? true : outerHTML - // otherwise act as a getter - } else { // write svgjs data to the dom this.writeDataToDom() + let current = this + + // An export modifier was passed + if (svgOrFn != null) { + current = adopt(current.node.cloneNode(true)) + + // If the user wants outerHTML we need to process this node, too + if (outerHTML) { + let result = svgOrFn(current) + current = result || current + + // The user does not want this node? Well, then he gets nothing + if (result === false) return '' + } + + // Deep loop through all children and apply modifier + current.each(function () { + let result = svgOrFn(this) + let _this = result || this + + // If modifier returns false, discard node + if (result === false) { + this.remove() + + // If modifier returns new node, use it + } else if (result && this !== _this) { + this.replace(_this) + } + }, true) + } - return this.node.outerHTML + // Return outer or inner content + return outerHTML + ? current.node.outerHTML + : current.node.innerHTML } - return this + // Act as setter if we got a string + + // The default for import is, that the current node is not replaced + outerHTML = outerHTML == null ? false : outerHTML + + // Create temporary holder + well = document.createElementNS(ns, 'svg') + fragment = document.createDocumentFragment() + + // Dump raw svg + well.innerHTML = svgOrFn + + // Transplant nodes into the fragment + for (len = well.children.length; len--;) { + fragment.appendChild(well.firstElementChild) + } + + // Add the whole fragment at once + return outerHTML + ? this.replace(fragment) + : this.add(fragment) } // write svgjs data to the dom |