diff options
author | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2018-10-25 23:28:12 +0200 |
---|---|---|
committer | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2018-10-25 23:28:12 +0200 |
commit | cfdfcc529dedff770dc54e78d2900d9a790f5766 (patch) | |
tree | 7b59c282a7823ded1d182aca95da5d55815456b2 /src/A.js | |
parent | 464af8b747389b7fdb569a933591c863b9be0f6b (diff) | |
download | svg.js-cfdfcc529dedff770dc54e78d2900d9a790f5766.tar.gz svg.js-cfdfcc529dedff770dc54e78d2900d9a790f5766.zip |
convert everything to es6 classes and imports
Diffstat (limited to 'src/A.js')
-rw-r--r-- | src/A.js | 48 |
1 files changed, 23 insertions, 25 deletions
@@ -1,35 +1,34 @@ -SVG.A = SVG.invent({ - // Initialize node - create: 'a', +import {Container, Element} from './classes.js' +import {nodeOrNew, addFactory} from './tools.js' +import {xlink} from './namespaces.js' - // Inherit from - inherit: SVG.Container, +export default class A extends Container { + constructor (node) { + super(nodeOrNew('a', node)) + } - // Add class methods - extend: { - // Link url - to: function (url) { - return this.attr('href', url, SVG.xlink) - }, - // Link target attribute - target: function (target) { - return this.attr('target', target) - } - }, + // Link url + to (url) { + return this.attr('href', url, xlink) + } - // Add parent method - construct: { - // Create a hyperlink element - link: function (url) { - return this.put(new SVG.A()).to(url) - } + // Link target attribute + target (target) { + return this.attr('target', target) + } +} + +addFactory(Container, { + // Create a hyperlink element + link: function (url) { + return this.put(new A()).to(url) } }) -SVG.extend(SVG.Element, { +addFactory(Element, { // Create a hyperlink element linkTo: function (url) { - var link = new SVG.A() + var link = new A() if (typeof url === 'function') { url.call(link, link) } else { link.to(url) @@ -37,5 +36,4 @@ SVG.extend(SVG.Element, { return this.parent().put(link).put(this) } - }) |