aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/animation/Morphable.js7
-rw-r--r--src/animation/Runner.js43
-rw-r--r--src/animation/Timeline.js5
-rw-r--r--src/modules/core/attr.js2
-rw-r--r--src/types/Box.js5
-rw-r--r--src/types/Color.js3
-rw-r--r--src/types/EventTarget.js3
-rw-r--r--src/types/List.js6
-rw-r--r--src/types/Matrix.js3
9 files changed, 60 insertions, 17 deletions
diff --git a/src/animation/Morphable.js b/src/animation/Morphable.js
index 56ffe95..0f191c9 100644
--- a/src/animation/Morphable.js
+++ b/src/animation/Morphable.js
@@ -90,7 +90,12 @@ export default class Morphable {
this._morphObj = this._morphObj || new this._type()
this._context = this._context
- || Array.apply(null, Array(result.length)).map(Object)
+ || Array.apply(null, Array(result.length))
+ .map(Object)
+ .map(function (o) {
+ o.done = true
+ return o
+ })
return result
}
diff --git a/src/animation/Runner.js b/src/animation/Runner.js
index 3af5823..d211876 100644
--- a/src/animation/Runner.js
+++ b/src/animation/Runner.js
@@ -1,5 +1,5 @@
import { Controller, Ease, Stepper } from './Controller.js'
-import { extend } from '../utils/adopter.js'
+import { extend, register } from '../utils/adopter.js'
import { from, to } from '../modules/core/gradiented.js'
import { getOrigin } from '../utils/utils.js'
import { noop, timeline } from '../modules/core/defaults.js'
@@ -64,6 +64,9 @@ export default class Runner extends EventTarget {
this._swing = false
this._wait = 0
this._times = 1
+
+ // Stores how long a runner is stored after beeing done
+ this._persist = this._isDeclarative ? true : null
}
/*
@@ -199,6 +202,12 @@ export default class Runner extends EventTarget {
return this.time(time)
}
+ persist (dtOrForever) {
+ if (dtOrForever == null) return this._persist
+ this._persist = dtOrForever
+ return this
+ }
+
position (p) {
// Get all of the variables we need
var x = this._time
@@ -338,11 +347,22 @@ export default class Runner extends EventTarget {
morpher: morpher,
caller: this._queue[this._queue.length - 1]
}
+
+ // We have to resume the timeline in case a controller
+ // is already done without beeing ever run
+ // This can happen when e.g. this is done:
+ // anim = el.animate(new SVG.Spring)
+ // and later
+ // anim.move(...)
+ if (this._isDeclarative) {
+ var timeline = this.timeline()
+ timeline && timeline.play()
+ }
}
// Try to set the target for a morpher if the morpher exists, otherwise
// do nothing and return false
- _tryRetarget (method, target) {
+ _tryRetarget (method, target, extra) {
if (this._history[method]) {
// if the last method wasnt even initialised, throw it away
if (!this._history[method].caller.initialised) {
@@ -354,7 +374,7 @@ export default class Runner extends EventTarget {
// for the case of transformations, we use the special retarget function
// which has access to the outer scope
if (this._history[method].caller.retarget) {
- this._history[method].caller.retarget(target)
+ this._history[method].caller.retarget(target, extra)
// for everything else a simple morpher change is sufficient
} else {
this._history[method].morpher.to(target)
@@ -362,7 +382,7 @@ export default class Runner extends EventTarget {
this._history[method].caller.finished = false
var timeline = this.timeline()
- timeline && timeline._continue()
+ timeline && timeline.play()
return true
}
return false
@@ -604,7 +624,7 @@ registerMethods({
.reduce(lmultiply, new Matrix())
},
- addRunner (runner) {
+ _addRunner (runner) {
this._transformationRunners.add(runner)
Animator.transform_frame(
@@ -636,9 +656,10 @@ extend(Runner, {
styleAttr (type, name, val) {
// apply attributes individually
if (typeof name === 'object') {
- for (var key in val) {
- this.styleAttr(type, key, val[key])
+ for (var key in name) {
+ this.styleAttr(type, key, name[key])
}
+ return this
}
var morpher = new Morphable(this._stepper).to(val)
@@ -654,6 +675,8 @@ extend(Runner, {
},
zoom (level, point) {
+ if (this._tryRetarget('zoom', to, point)) return this
+
var morpher = new Morphable(this._stepper).to(new SVGNumber(level))
this.queue(function () {
@@ -661,6 +684,9 @@ extend(Runner, {
}, function (pos) {
this.element().zoom(morpher.at(pos), point)
return morpher.done()
+ }, function (newLevel, newPoint) {
+ point = newPoint
+ morpher.to(newLevel)
})
return this
@@ -714,7 +740,7 @@ extend(Runner, {
startTransform = new Matrix(relative ? undefined : element)
// add the runner to the element so it can merge transformations
- element.addRunner(this)
+ element._addRunner(this)
// Deactivate all transforms that have run so far if we are absolute
if (!relative) {
@@ -953,3 +979,4 @@ extend(Runner, {
})
extend(Runner, { rx, ry, from, to })
+register(Runner)
diff --git a/src/animation/Timeline.js b/src/animation/Timeline.js
index c3ad07c..44b5261 100644
--- a/src/animation/Timeline.js
+++ b/src/animation/Timeline.js
@@ -80,11 +80,12 @@ export default class Timeline extends EventTarget {
// Manage runner
runner.unschedule()
runner.timeline(this)
- // runner.time(-delay)
+
+ const persist = runner.persist()
// Save runnerInfo
this._runners[runner.id] = {
- persist: this.persist(),
+ persist: persist === null ? this._persist : persist,
runner: runner,
start: absoluteStartTime + delay
}
diff --git a/src/modules/core/attr.js b/src/modules/core/attr.js
index 79dd0d7..548a6fb 100644
--- a/src/modules/core/attr.js
+++ b/src/modules/core/attr.js
@@ -30,7 +30,7 @@ export default function attr (attr, val, ns) {
last[curr] = this.attr(curr)
return last
}, {})
- } else if (typeof attr === 'object') {
+ } else if (typeof attr === 'object' && attr.constructor === Object) {
// apply every attribute individually if an object is passed
for (val in attr) this.attr(val, attr[val])
} else if (val === null) {
diff --git a/src/types/Box.js b/src/types/Box.js
index d2ddcdd..3df1367 100644
--- a/src/types/Box.js
+++ b/src/types/Box.js
@@ -1,6 +1,7 @@
import { delimiter } from '../modules/core/regex.js'
-import { registerMethods } from '../utils/methods.js'
import { globals } from '../utils/window.js'
+import { register } from '../utils/adopter.js'
+import { registerMethods } from '../utils/methods.js'
import Point from './Point.js'
import parser from '../modules/core/parser.js'
@@ -152,3 +153,5 @@ registerMethods({
}
}
})
+
+register(Box)
diff --git a/src/types/Color.js b/src/types/Color.js
index a1329aa..93ca570 100644
--- a/src/types/Color.js
+++ b/src/types/Color.js
@@ -63,6 +63,9 @@ export default class Color {
}
init (a = 0, b = 0, c = 0, d = 0, space = 'rgb') {
+ // This catches the case when a falsy value is passed like ''
+ a = !a ? 0 : a
+
// Reset all values in case the init function is rerun with new color space
if (this.space) {
for (let component in this.space) {
diff --git a/src/types/EventTarget.js b/src/types/EventTarget.js
index 5a005fd..d414dd8 100644
--- a/src/types/EventTarget.js
+++ b/src/types/EventTarget.js
@@ -1,4 +1,5 @@
import { dispatch, off, on } from '../modules/core/event.js'
+import { register } from '../utils/adopter.js'
import Base from './Base.js'
export default class EventTarget extends Base {
@@ -56,3 +57,5 @@ export default class EventTarget extends Base {
removeEventListener () {}
}
+
+register(EventTarget)
diff --git a/src/types/List.js b/src/types/List.js
index 44f0fed..f66e3cd 100644
--- a/src/types/List.js
+++ b/src/types/List.js
@@ -13,16 +13,14 @@ export default List
extend(List, {
each (fnOrMethodName, ...args) {
if (typeof fnOrMethodName === 'function') {
- this.forEach((el) => {
- fnOrMethodName.call(el, el)
+ return this.map((el) => {
+ return fnOrMethodName.call(el, el)
})
} else {
return this.map(el => {
return el[fnOrMethodName](...args)
})
}
-
- return this
},
toArray () {
diff --git a/src/types/Matrix.js b/src/types/Matrix.js
index 102192b..ef90ca3 100644
--- a/src/types/Matrix.js
+++ b/src/types/Matrix.js
@@ -1,5 +1,6 @@
import { delimiter } from '../modules/core/regex.js'
import { radians } from '../utils/utils.js'
+import { register } from '../utils/adopter.js'
import Element from '../elements/Element.js'
import Point from './Point.js'
@@ -498,3 +499,5 @@ export function screenCTM () {
}
return new Matrix(this.node.getScreenCTM())
}
+
+register(Matrix)