diff options
Diffstat (limited to 'dist/svg.js')
-rw-r--r-- | dist/svg.js | 266 |
1 files changed, 119 insertions, 147 deletions
diff --git a/dist/svg.js b/dist/svg.js index f78ec03..b854ee4 100644 --- a/dist/svg.js +++ b/dist/svg.js @@ -6,31 +6,31 @@ * @copyright Wout Fierens <wout@mick-wout.com> * @license MIT * -* BUILT: Thu Oct 18 2018 11:49:16 GMT+0200 (GMT+02:00) +* BUILT: Sat Oct 27 2018 12:02:54 GMT+0200 (CEST) */; -
-(function(root, factory) {
- /* istanbul ignore next */
- if (typeof define === 'function' && define.amd) {
- define(function(){
- return factory(root, root.document)
- })
- } else if (typeof exports === 'object') {
- module.exports = root.document ? factory(root, root.document) : function(w){ return factory(w, w.document) }
- } else {
- root.SVG = factory(root, root.document)
- }
-}(typeof window !== "undefined" ? window : this, function(window, document) {
-
-// Check that our browser supports svg
-var supported = !! document.createElementNS &&
- !! document.createElementNS('http://www.w3.org/2000/svg','svg').createSVGRect
-
-// If we don't support svg, just exit without doing anything
-if (!supported)
- return {supported: false}
-
-// Otherwise, the library will be here
+ +(function(root, factory) { + /* istanbul ignore next */ + if (typeof define === 'function' && define.amd) { + define(function(){ + return factory(root, root.document) + }) + } else if (typeof exports === 'object') { + module.exports = root.document ? factory(root, root.document) : function(w){ return factory(w, w.document) } + } else { + root.SVG = factory(root, root.document) + } +}(typeof window !== "undefined" ? window : this, function(window, document) { + +// Check that our browser supports svg +var supported = !! document.createElementNS && + !! document.createElementNS('http://www.w3.org/2000/svg','svg').createSVGRect + +// If we don't support svg, just exit without doing anything +if (!supported) + return {supported: false} + +// Otherwise, the library will be here "use strict"; function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); } @@ -336,33 +336,33 @@ SVG.Queue = SVG.invent({ }); /* globals fullHex, compToHex */ -/*
-
-Color {
- constructor (a, b, c, space) {
- space: 'hsl'
- a: 30
- b: 20
- c: 10
- },
-
- toRgb () { return new Color in rgb space }
- toHsl () { return new Color in hsl space }
- toLab () { return new Color in lab space }
-
- toArray () { [space, a, b, c] }
- fromArray () { convert it back }
-}
-
-// Conversions aren't always exact because of monitor profiles etc...
-new Color(h, s, l, 'hsl') !== new Color(r, g, b).hsl()
-new Color(100, 100, 100, [space])
-new Color('hsl(30, 20, 10)')
-
-// Sugar
-SVG.rgb(30, 20, 50).lab()
-SVG.hsl()
-SVG.lab('rgb(100, 100, 100)')
+/* + +Color { + constructor (a, b, c, space) { + space: 'hsl' + a: 30 + b: 20 + c: 10 + }, + + toRgb () { return new Color in rgb space } + toHsl () { return new Color in hsl space } + toLab () { return new Color in lab space } + + toArray () { [space, a, b, c] } + fromArray () { convert it back } +} + +// Conversions aren't always exact because of monitor profiles etc... +new Color(h, s, l, 'hsl') !== new Color(r, g, b).hsl() +new Color(100, 100, 100, [space]) +new Color('hsl(30, 20, 10)') + +// Sugar +SVG.rgb(30, 20, 50).lab() +SVG.hsl() +SVG.lab('rgb(100, 100, 100)') */ // Module for color convertions @@ -1021,16 +1021,6 @@ SVG.Number = SVG.invent({ number = new SVG.Number(number); return new SVG.Number(this / number, this.unit || number.unit); }, - // Convert to different unit - to: function to(unit) { - var number = new SVG.Number(this); - - if (typeof unit === 'string') { - number.unit = unit; - } - - return number; - }, // Make number morphable morph: function morph(number) { this.destination = new SVG.Number(number); @@ -1309,7 +1299,7 @@ SVG.Element = SVG.invent({ svg: function svg(_svg) { var well, len; // act as a setter if svg is given - if (_svg && this instanceof SVG.Parent) { + if (typeof _svg === 'string' && this instanceof SVG.Parent) { // create temporary holder well = document.createElementNS(SVG.ns, 'svg'); // dump raw svg @@ -1320,7 +1310,20 @@ SVG.Element = SVG.invent({ } // otherwise act as a getter } else { - // write svgjs data to the dom + // expose node modifiers + if (typeof _svg === 'function') { + this.each(function () { + well = _svg(this); // If modifier returns false, discard node + + if (well === false) { + this.remove(); // If modifier returns new node, use it + } else if (well && well !== this) { + this.replace(well); + } + }, true); + } // write svgjs data to the dom + + this.writeDataToDom(); return this.node.outerHTML; } @@ -1869,9 +1872,9 @@ SVG.Matrix = SVG.invent({ }, // Get current screen matrix screenCTM: function screenCTM() { - /* https://bugzilla.mozilla.org/show_bug.cgi?id=1344537
- This is needed because FF does not return the transformation matrix
- for the inner coordinate system when getScreenCTM() is called on nested svgs.
+ /* https://bugzilla.mozilla.org/show_bug.cgi?id=1344537 + This is needed because FF does not return the transformation matrix + for the inner coordinate system when getScreenCTM() is called on nested svgs. However all other Browsers do that */ if (this instanceof SVG.Doc && !this.isRoot()) { var rect = this.rect(1, 1); @@ -4442,8 +4445,7 @@ SVG.Runner = SVG.invent({ this.enabled = true; this._time = 0; - this._last = 0; - this.tags = {}; // Save transforms applied to this runner + this._last = 0; // Save transforms applied to this runner this.transforms = new SVG.Matrix(); this.transformId = 1; // Looping variables @@ -4466,11 +4468,11 @@ SVG.Runner = SVG.invent({ } }, extend: { - /*
- Runner Definitions
- ==================
- These methods help us define the runtime behaviour of the Runner or they
- help us make new runners from the current runner
+ /* + Runner Definitions + ================== + These methods help us define the runtime behaviour of the Runner or they + help us make new runners from the current runner */ element: function element(_element3) { if (_element3 == null) return this._element; @@ -4533,10 +4535,10 @@ SVG.Runner = SVG.invent({ return this.animate(0, _delay); }, - /*
- Basic Functionality
- ===================
- These methods allow us to attach basic functions to the runner directly
+ /* + Basic Functionality + =================== + These methods allow us to attach basic functions to the runner directly */ queue: function queue(initFn, runFn, isTransform) { this._queue.push({ @@ -4558,10 +4560,10 @@ SVG.Runner = SVG.invent({ return this.on('finish', fn); }, - /*
- Runner animation methods
- ========================
- Control how the animation plays
+ /* + Runner animation methods + ======================== + Control how the animation plays */ time: function time(_time) { if (_time == null) { @@ -4601,11 +4603,11 @@ SVG.Runner = SVG.invent({ var position; if (p == null) { - /*
- This function converts a time to a position in the range [0, 1]
- The full explanation can be found in this desmos demonstration
- https://www.desmos.com/calculator/u4fbavgche
- The logic is slightly simplified here because we can use booleans
+ /* + This function converts a time to a position in the range [0, 1] + The full explanation can be found in this desmos demonstration + https://www.desmos.com/calculator/u4fbavgche + The logic is slightly simplified here because we can use booleans */ // Figure out the value without thinking about the start or end time var f = function f(x) { @@ -4696,40 +4698,10 @@ SVG.Runner = SVG.invent({ return this; }, - /*
- Runner Management
- =================
- Functions that are used to help index the runner
- */ - tag: function tag(name) { - // Act as a getter to get all of the tags on this object - if (name == null) return Object.keys(this.tags); // Add all of the tags to the object directly - - name = Array.isArray(name) ? name : [name]; - - for (var i = name.length; i--;) { - this.tags[name[i]] = true; - } - - return this; - }, - untag: function untag(name) { - name = Array.isArray(name) ? name : [name]; - - for (var i = name.length; i--;) { - delete this.tags[name[i]]; - } - - return this; - }, - getEventTarget: function getEventTarget() { - return this._dispatcher; - }, - - /*
- Private Methods
- ===============
- Methods that shouldn't be used externally
+ /* + Private Methods + =============== + Methods that shouldn't be used externally */ // Save a morpher to the morpher list so that we can retarget it later _rememberMorpher: function _rememberMorpher(method, morpher) { @@ -5034,8 +5006,8 @@ SVG.extend(SVG.Runner, { return this; }, - /**
- ** absolute transformations
+ /** + ** absolute transformations **/ // // M v -----|-----(D M v = F v)------|-----> T v @@ -5253,14 +5225,14 @@ SVG.extend(SVG.Runner, { return this._queueObject('plot', new this._element.MorphArray(a)); - /*
- var morpher = this._element.morphArray().to(a)
- this.queue(function () {
- morpher.from(this._element.array())
- }, function (pos) {
- this._element.plot(morpher.at(pos))
- })
- return this
+ /* + var morpher = this._element.morphArray().to(a) + this.queue(function () { + morpher.from(this._element.array()) + }, function (pos) { + this._element.plot(morpher.at(pos)) + }) + return this */ }, // Add leading method @@ -5344,8 +5316,8 @@ SVG.Timeline = SVG.invent({ return this._dispatcher; }, - /**
- *
+ /** + * */ // schedules a runner on the timeline schedule: function schedule(runner, delay, when) { @@ -5560,10 +5532,10 @@ SVG.Timeline = SVG.invent({ // finished: Whether or not we are finished // } -/***
-Base Class
-==========
-The base stepper class that will be
+/*** +Base Class +========== +The base stepper class that will be ***/ function makeSetterGetter(k, f) { @@ -5578,9 +5550,9 @@ function makeSetterGetter(k, f) { SVG.Stepper = SVG.invent({ create: function create() {} }); -/***
-Easing Functions
-================
+/*** +Easing Functions +================ ***/ SVG.Ease = SVG.invent({ @@ -5619,9 +5591,9 @@ SVG.easing = { return function (t) {// TODO: FINISH }; } - /***
- Controller Types
- ================
+ /*** + Controller Types + ================ ***/ }; @@ -5719,9 +5691,9 @@ SVG.PID = SVG.invent({ i: makeSetterGetter('I'), d: makeSetterGetter('D') } -});
-
-return SVG
-
-}));
+}); + +return SVG + +})); //# sourceMappingURL=svg.js.map |