123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 |
- /**
- * @license Highcharts JS v2.1.4 (2011-03-30)
- * MooTools adapter
- *
- * (c) 2010 Torstein Hønsi
- *
- * License: www.highcharts.com/license
- */
- // JSLint options:
- /*global Highcharts, Fx, $, $extend, $each, $merge, Events, Event */
- (function() {
-
- var win = window,
- legacy = !!win.$merge
- $extend = win.$extend || function() {
- return Object.append.apply(Object, arguments)
- };
- win.HighchartsAdapter = {
- /**
- * Initialize the adapter. This is run once as Highcharts is first run.
- */
- init: function() {
- var fxProto = Fx.prototype,
- fxStart = fxProto.start,
- morphProto = Fx.Morph.prototype,
- morphCompute = morphProto.compute;
-
- // override Fx.start to allow animation of SVG element wrappers
- fxProto.start = function(from, to) {
- var fx = this,
- elem = fx.element;
-
- // special for animating paths
- if (from.d) {
- //this.fromD = this.element.d.split(' ');
- fx.paths = Highcharts.pathAnim.init(
- elem,
- elem.d,
- fx.toD
- );
- }
- fxStart.apply(fx, arguments);
- };
-
- // override Fx.step to allow animation of SVG element wrappers
- morphProto.compute = function(from, to, delta) {
- var fx = this,
- paths = fx.paths;
-
- if (paths) {
- fx.element.attr(
- 'd',
- Highcharts.pathAnim.step(paths[0], paths[1], delta, fx.toD)
- );
- } else {
- return morphCompute.apply(fx, arguments);
- }
- };
-
- },
-
- /**
- * Animate a HTML element or SVG element wrapper
- * @param {Object} el
- * @param {Object} params
- * @param {Object} options jQuery-like animation options: duration, easing, callback
- */
- animate: function (el, params, options) {
- var isSVGElement = el.attr,
- effect,
- complete = options && options.complete;
-
- if (isSVGElement && !el.setStyle) {
- // add setStyle and getStyle methods for internal use in Moo
- el.getStyle = el.attr;
- el.setStyle = function() { // property value is given as array in Moo - break it down
- var args = arguments;
- el.attr.call(el, args[0], args[1][0]);
- }
- // dirty hack to trick Moo into handling el as an element wrapper
- el.$family = el.uid = true;
- }
-
- // stop running animations
- HighchartsAdapter.stop(el);
-
- // define and run the effect
- effect = new Fx.Morph(
- isSVGElement ? el : $(el),
- $extend({
- transition: Fx.Transitions.Quad.easeInOut
- }, options)
- );
-
- // special treatment for paths
- if (params.d) {
- effect.toD = params.d;
- }
-
- // jQuery-like events
- if (complete) {
- effect.addEvent('complete', complete);
- }
-
- // run
- effect.start(params);
-
- // record for use in stop method
- el.fx = effect;
- },
-
- /**
- * MooTool's each function
- *
- */
- each: function(arr, fn) {
- return legacy ?
- $each(arr, fn) :
- arr.each(fn);
- },
-
- /**
- * Map an array
- * @param {Array} arr
- * @param {Function} fn
- */
- map: function (arr, fn){
- return arr.map(fn);
- },
-
- /**
- * Grep or filter an array
- * @param {Array} arr
- * @param {Function} fn
- */
- grep: function(arr, fn) {
- return arr.filter(fn);
- },
-
- /**
- * Deep merge two objects and return a third
- */
- merge: function() {
- var args = arguments,
- args13 = [{}], // MooTools 1.3+
- i = args.length,
- ret;
-
- if (legacy) {
- ret = $merge.apply(null, args);
- } else {
- while (i--) {
- args13[i + 1] = args[i];
- }
- ret = Object.merge.apply(Object, args13);
- }
-
- return ret;
- },
-
- /**
- * Hyphenate a string, like minWidth becomes min-width
- * @param {Object} str
- */
- hyphenate: function (str){
- return str.hyphenate();
- },
-
- /**
- * Add an event listener
- * @param {Object} el HTML element or custom object
- * @param {String} type Event type
- * @param {Function} fn Event handler
- */
- addEvent: function (el, type, fn) {
- if (typeof type == 'string') { // chart broke due to el being string, type function
-
- if (type == 'unload') { // Moo self destructs before custom unload events
- type = 'beforeunload';
- }
- // if the addEvent method is not defined, el is a custom Highcharts object
- // like series or point
- if (!el.addEvent) {
- if (el.nodeName) {
- el = $(el); // a dynamically generated node
- } else {
- $extend(el, new Events()); // a custom object
- }
- }
-
- el.addEvent(type, fn);
- }
- },
-
- removeEvent: function(el, type, fn) {
- if (type) {
- if (type == 'unload') { // Moo self destructs before custom unload events
- type = 'beforeunload';
- }
- el.removeEvent(type, fn);
- }
- },
-
- fireEvent: function(el, event, eventArguments, defaultFunction) {
- // create an event object that keeps all functions
- event = new Event({
- type: event,
- target: el
- });
- event = $extend(event, eventArguments);
- // override the preventDefault function to be able to use
- // this for custom events
- event.preventDefault = function() {
- defaultFunction = null;
- };
- // if fireEvent is not available on the object, there hasn't been added
- // any events to it above
- if (el.fireEvent) {
- el.fireEvent(event.type, event);
- }
-
- // fire the default if it is passed and it is not prevented above
- if (defaultFunction) {
- defaultFunction(event);
- }
- },
-
- /**
- * Stop running animations on the object
- */
- stop: function (el) {
- if (el.fx) {
- el.fx.cancel();
- }
- }
- }
- })();
|