diff options
author | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2018-11-12 13:59:07 +0100 |
---|---|---|
committer | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2018-11-12 13:59:07 +0100 |
commit | 334d9c73c2f74679a93b1d7b3e39b614f6444faa (patch) | |
tree | 75e7da40f8a1af67854816f1aa65b199b0733387 | |
parent | b9f5c216c6eb75f3a00c6b121da5a72885286fa0 (diff) | |
download | svg.js-334d9c73c2f74679a93b1d7b3e39b614f6444faa.tar.gz svg.js-334d9c73c2f74679a93b1d7b3e39b614f6444faa.zip |
reworked parents so that it is useful now, changelog
-rw-r--r-- | CHANGELOG.md | 4 | ||||
-rw-r--r-- | dist/svg.js | 14 | ||||
-rw-r--r-- | spec/spec/element.js | 13 | ||||
-rw-r--r-- | src/elements/Element.js | 18 |
4 files changed, 28 insertions, 21 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md index b8c78c7..94fff52 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -29,12 +29,13 @@ The document follows the conventions described in [“Keep a CHANGELOG”](http: - added `ax(), ay(), amove()` to change texts x and y values directly (#787) - added possibility to pass attributes into a constructor like: `new SVG.Rect({width:100})` - added possibility to pass in additional attribues to element creators e.g. `canvas.rect({x:100})` or `canvas.rect(100, 100, {x:100})` (#796) +- added `SVG.List` (#645) ### Removed - removed `SVG.Array.split()` function - removed workaround for browser bug with stroke-width - removed polyfills -- removed `SVG.Set` +- removed `SVG.Set` in favour of `SVG.List` - removed feature to set style with css string (e.g. "fill:none;display:block;") - removed `loaded()` and `error()` method on `SVG.Image` (#706) - removed sub-pixel offset fix @@ -84,6 +85,7 @@ The document follows the conventions described in [“Keep a CHANGELOG”](http: - `attr()` excepts array now to get multiple values at once - `SVG.Text.rebuild()` now takes every font-size into account (#512) - `fill()` and `stroke()` return the fill and stroke attribute when called as getter (#789) +- `parents()` now gives back all parents until the passed one or document ### Fixed - fixed a bug in clipping and masking where empty nodes persists after removal -> __TODO!__ diff --git a/dist/svg.js b/dist/svg.js index 8670803..3a2d11a 100644 --- a/dist/svg.js +++ b/dist/svg.js @@ -6,7 +6,7 @@ * @copyright Wout Fierens <wout@mick-wout.com> * @license MIT * -* BUILT: Mon Nov 12 2018 13:26:51 GMT+0100 (GMT+01:00) +* BUILT: Mon Nov 12 2018 13:58:37 GMT+0100 (GMT+01:00) */; var SVG = (function () { 'use strict'; @@ -1925,15 +1925,15 @@ var SVG = (function () { }, { key: "parents", - value: function parents(type) { - var parents = []; + value: function parents() { + var until = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : globals.document; + until = makeInstance(until); + var parents = new List(); var parent = this; - do { - parent = parent.parent(type); - if (!parent || parent instanceof getClass('HtmlNode')) break; + while ((parent = parent.parent()) && parent.node !== until.node && parent.node !== globals.document) { parents.push(parent); - } while (parent.parent); + } return parents; } // Get referenced element form attribute value diff --git a/spec/spec/element.js b/spec/spec/element.js index 1cb754e..b36ea82 100644 --- a/spec/spec/element.js +++ b/spec/spec/element.js @@ -651,15 +651,16 @@ describe('Element', function() { }) describe('parents()', function() { - it('returns array of parent up to but not including the dom element filtered by type', function() { + it('returns array of parents until the passed element or document', function() { var group1 = draw.group().addClass('test') , group2 = group1.group() - , rect = group2.rect(100,100) + , group3 = group2.group() + , rect = group3.rect(100,100) - expect(rect.parents('.test')[0]).toBe(group1) - expect(rect.parents(SVG.G)[0]).toBe(group2) - expect(rect.parents(SVG.G)[1]).toBe(group1) - expect(rect.parents().length).toBe(3) + expect(rect.parents('.test')[0]).toBe(group3) + expect(rect.parents('.test')[1]).toBe(group2) + expect(rect.parents(group2)[0]).toBe(group3) + expect(rect.parents(group1).length).toBe(2) }) }) diff --git a/src/elements/Element.js b/src/elements/Element.js index 03b5f07..3b96bf4 100644 --- a/src/elements/Element.js +++ b/src/elements/Element.js @@ -1,7 +1,9 @@ import { getClass, makeInstance, register, root } from '../utils/adopter.js' +import { globals } from '../utils/window.js' import { proportionalSize } from '../utils/utils.js' import { reference } from '../modules/core/regex.js' import Dom from './Dom.js' +import List from '../types/List.js' import SVGNumber from '../types/SVGNumber.js' const Doc = getClass(root) @@ -75,16 +77,18 @@ export default class Element extends Dom { } // return array of all ancestors of given type up to the root svg - parents (type) { - let parents = [] + parents (until = globals.document) { + until = makeInstance(until) + let parents = new List() let parent = this - do { - parent = parent.parent(type) - if (!parent || parent instanceof getClass('HtmlNode')) break - + while ( + (parent = parent.parent()) && + parent.node !== until.node && + parent.node !== globals.document + ) { parents.push(parent) - } while (parent.parent) + } return parents } |