|
|
(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){
|
|
|
var CRender = require('../lib/index')
|
|
|
|
|
|
window.CRender = CRender
|
|
|
},{"../lib/index":6}],2:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
|
|
|
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
|
|
|
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
|
|
|
|
var _color = _interopRequireDefault(require("@jiaminghi/color"));
|
|
|
|
|
|
var _bezierCurve = _interopRequireDefault(require("@jiaminghi/bezier-curve"));
|
|
|
|
|
|
var _util = require("../plugin/util");
|
|
|
|
|
|
var _graphs = _interopRequireDefault(require("../config/graphs"));
|
|
|
|
|
|
var _graph = _interopRequireDefault(require("./graph.class"));
|
|
|
|
|
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
|
|
|
|
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
|
|
|
|
/**
|
|
|
* @description Class of CRender
|
|
|
* @param {Object} canvas Canvas DOM
|
|
|
* @return {CRender} Instance of CRender
|
|
|
*/
|
|
|
var CRender = function CRender(canvas) {
|
|
|
(0, _classCallCheck2["default"])(this, CRender);
|
|
|
|
|
|
if (!canvas) {
|
|
|
console.error('CRender Missing parameters!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
var ctx = canvas.getContext('2d');
|
|
|
var clientWidth = canvas.clientWidth,
|
|
|
clientHeight = canvas.clientHeight;
|
|
|
var area = [clientWidth, clientHeight];
|
|
|
canvas.setAttribute('width', clientWidth);
|
|
|
canvas.setAttribute('height', clientHeight);
|
|
|
/**
|
|
|
* @description Context of the canvas
|
|
|
* @type {Object}
|
|
|
* @example ctx = canvas.getContext('2d')
|
|
|
*/
|
|
|
|
|
|
this.ctx = ctx;
|
|
|
/**
|
|
|
* @description Width and height of the canvas
|
|
|
* @type {Array}
|
|
|
* @example area = [300,100]
|
|
|
*/
|
|
|
|
|
|
this.area = area;
|
|
|
/**
|
|
|
* @description Whether render is in animation rendering
|
|
|
* @type {Boolean}
|
|
|
* @example animationStatus = true|false
|
|
|
*/
|
|
|
|
|
|
this.animationStatus = false;
|
|
|
/**
|
|
|
* @description Added graph
|
|
|
* @type {[Graph]}
|
|
|
* @example graphs = [Graph, Graph, ...]
|
|
|
*/
|
|
|
|
|
|
this.graphs = [];
|
|
|
/**
|
|
|
* @description Color plugin
|
|
|
* @type {Object}
|
|
|
* @link https://github.com/jiaming743/color
|
|
|
*/
|
|
|
|
|
|
this.color = _color["default"];
|
|
|
/**
|
|
|
* @description Bezier Curve plugin
|
|
|
* @type {Object}
|
|
|
* @link https://github.com/jiaming743/BezierCurve
|
|
|
*/
|
|
|
|
|
|
this.bezierCurve = _bezierCurve["default"]; // bind event handler
|
|
|
|
|
|
canvas.addEventListener('mousedown', mouseDown.bind(this));
|
|
|
canvas.addEventListener('mousemove', mouseMove.bind(this));
|
|
|
canvas.addEventListener('mouseup', mouseUp.bind(this));
|
|
|
};
|
|
|
/**
|
|
|
* @description Clear canvas drawing area
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
exports["default"] = CRender;
|
|
|
|
|
|
CRender.prototype.clearArea = function () {
|
|
|
var _this$ctx;
|
|
|
|
|
|
var area = this.area;
|
|
|
|
|
|
(_this$ctx = this.ctx).clearRect.apply(_this$ctx, [0, 0].concat((0, _toConsumableArray2["default"])(area)));
|
|
|
};
|
|
|
/**
|
|
|
* @description Add graph to render
|
|
|
* @param {Object} config Graph configuration
|
|
|
* @return {Graph} Graph instance
|
|
|
*/
|
|
|
|
|
|
|
|
|
CRender.prototype.add = function () {
|
|
|
var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
|
var name = config.name;
|
|
|
|
|
|
if (!name) {
|
|
|
console.error('add Missing parameters!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
var graphConfig = _graphs["default"].get(name);
|
|
|
|
|
|
if (!graphConfig) {
|
|
|
console.warn('No corresponding graph configuration found!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
var graph = new _graph["default"](graphConfig, config);
|
|
|
if (!graph.validator(graph)) return;
|
|
|
graph.render = this;
|
|
|
this.graphs.push(graph);
|
|
|
this.sortGraphsByIndex();
|
|
|
this.drawAllGraph();
|
|
|
return graph;
|
|
|
};
|
|
|
/**
|
|
|
* @description Sort the graph by index
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
CRender.prototype.sortGraphsByIndex = function () {
|
|
|
var graphs = this.graphs;
|
|
|
graphs.sort(function (a, b) {
|
|
|
if (a.index > b.index) return 1;
|
|
|
if (a.index === b.index) return 0;
|
|
|
if (a.index < b.index) return -1;
|
|
|
});
|
|
|
};
|
|
|
/**
|
|
|
* @description Delete graph in render
|
|
|
* @param {Graph} graph The graph to be deleted
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
CRender.prototype.delGraph = function (graph) {
|
|
|
if (typeof graph.delProcessor !== 'function') return;
|
|
|
graph.delProcessor(this);
|
|
|
this.graphs = this.graphs.filter(function (graph) {
|
|
|
return graph;
|
|
|
});
|
|
|
this.drawAllGraph();
|
|
|
};
|
|
|
/**
|
|
|
* @description Delete all graph in render
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
CRender.prototype.delAllGraph = function () {
|
|
|
var _this = this;
|
|
|
|
|
|
this.graphs.forEach(function (graph) {
|
|
|
return graph.delProcessor(_this);
|
|
|
});
|
|
|
this.graphs = this.graphs.filter(function (graph) {
|
|
|
return graph;
|
|
|
});
|
|
|
this.drawAllGraph();
|
|
|
};
|
|
|
/**
|
|
|
* @description Draw all the graphs in the render
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
CRender.prototype.drawAllGraph = function () {
|
|
|
var _this2 = this;
|
|
|
|
|
|
this.clearArea();
|
|
|
this.graphs.filter(function (graph) {
|
|
|
return graph && graph.visible;
|
|
|
}).forEach(function (graph) {
|
|
|
return graph.drawProcessor(_this2, graph);
|
|
|
});
|
|
|
};
|
|
|
/**
|
|
|
* @description Animate the graph whose animation queue is not empty
|
|
|
* and the animationPause is equal to false
|
|
|
* @return {Promise} Animation Promise
|
|
|
*/
|
|
|
|
|
|
|
|
|
CRender.prototype.launchAnimation = function () {
|
|
|
var _this3 = this;
|
|
|
|
|
|
var animationStatus = this.animationStatus;
|
|
|
if (animationStatus) return;
|
|
|
this.animationStatus = true;
|
|
|
return new Promise(function (resolve) {
|
|
|
animation.call(_this3, function () {
|
|
|
_this3.animationStatus = false;
|
|
|
resolve();
|
|
|
}, Date.now());
|
|
|
});
|
|
|
};
|
|
|
/**
|
|
|
* @description Try to animate every graph
|
|
|
* @param {Function} callback Callback in animation end
|
|
|
* @param {Number} timeStamp Time stamp of animation start
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
function animation(callback, timeStamp) {
|
|
|
var graphs = this.graphs;
|
|
|
|
|
|
if (!animationAble(graphs)) {
|
|
|
callback();
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
graphs.forEach(function (graph) {
|
|
|
return graph.turnNextAnimationFrame(timeStamp);
|
|
|
});
|
|
|
this.drawAllGraph();
|
|
|
requestAnimationFrame(animation.bind(this, callback, timeStamp));
|
|
|
}
|
|
|
/**
|
|
|
* @description Find if there are graph that can be animated
|
|
|
* @param {[Graph]} graphs
|
|
|
* @return {Boolean}
|
|
|
*/
|
|
|
|
|
|
|
|
|
function animationAble(graphs) {
|
|
|
return graphs.find(function (graph) {
|
|
|
return !graph.animationPause && graph.animationFrameState.length;
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Handler of CRender mousedown event
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
function mouseDown(e) {
|
|
|
var graphs = this.graphs;
|
|
|
var hoverGraph = graphs.find(function (graph) {
|
|
|
return graph.status === 'hover';
|
|
|
});
|
|
|
if (!hoverGraph) return;
|
|
|
hoverGraph.status = 'active';
|
|
|
}
|
|
|
/**
|
|
|
* @description Handler of CRender mousemove event
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
function mouseMove(e) {
|
|
|
var offsetX = e.offsetX,
|
|
|
offsetY = e.offsetY;
|
|
|
var position = [offsetX, offsetY];
|
|
|
var graphs = this.graphs;
|
|
|
var activeGraph = graphs.find(function (graph) {
|
|
|
return graph.status === 'active' || graph.status === 'drag';
|
|
|
});
|
|
|
|
|
|
if (activeGraph) {
|
|
|
if (!activeGraph.drag) return;
|
|
|
|
|
|
if (typeof activeGraph.move !== 'function') {
|
|
|
console.error('No move method is provided, cannot be dragged!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
activeGraph.moveProcessor(e);
|
|
|
activeGraph.status = 'drag';
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
var hoverGraph = graphs.find(function (graph) {
|
|
|
return graph.status === 'hover';
|
|
|
});
|
|
|
var hoverAbleGraphs = graphs.filter(function (graph) {
|
|
|
return graph.hover && (typeof graph.hoverCheck === 'function' || graph.hoverRect);
|
|
|
});
|
|
|
var hoveredGraph = hoverAbleGraphs.find(function (graph) {
|
|
|
return graph.hoverCheckProcessor(position, graph);
|
|
|
});
|
|
|
|
|
|
if (hoveredGraph) {
|
|
|
document.body.style.cursor = hoveredGraph.style.hoverCursor;
|
|
|
} else {
|
|
|
document.body.style.cursor = 'default';
|
|
|
}
|
|
|
|
|
|
var hoverGraphMouseOuterIsFun = false,
|
|
|
hoveredGraphMouseEnterIsFun = false;
|
|
|
if (hoverGraph) hoverGraphMouseOuterIsFun = typeof hoverGraph.mouseOuter === 'function';
|
|
|
if (hoveredGraph) hoveredGraphMouseEnterIsFun = typeof hoveredGraph.mouseEnter === 'function';
|
|
|
if (!hoveredGraph && !hoverGraph) return;
|
|
|
|
|
|
if (!hoveredGraph && hoverGraph) {
|
|
|
if (hoverGraphMouseOuterIsFun) hoverGraph.mouseOuter(e, hoverGraph);
|
|
|
hoverGraph.status = 'static';
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (hoveredGraph && hoveredGraph === hoverGraph) return;
|
|
|
|
|
|
if (hoveredGraph && !hoverGraph) {
|
|
|
if (hoveredGraphMouseEnterIsFun) hoveredGraph.mouseEnter(e, hoveredGraph);
|
|
|
hoveredGraph.status = 'hover';
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (hoveredGraph && hoverGraph && hoveredGraph !== hoverGraph) {
|
|
|
if (hoverGraphMouseOuterIsFun) hoverGraph.mouseOuter(e, hoverGraph);
|
|
|
hoverGraph.status = 'static';
|
|
|
if (hoveredGraphMouseEnterIsFun) hoveredGraph.mouseEnter(e, hoveredGraph);
|
|
|
hoveredGraph.status = 'hover';
|
|
|
}
|
|
|
}
|
|
|
/**
|
|
|
* @description Handler of CRender mouseup event
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
function mouseUp(e) {
|
|
|
var graphs = this.graphs;
|
|
|
var activeGraph = graphs.find(function (graph) {
|
|
|
return graph.status === 'active';
|
|
|
});
|
|
|
var dragGraph = graphs.find(function (graph) {
|
|
|
return graph.status === 'drag';
|
|
|
});
|
|
|
if (activeGraph && typeof activeGraph.click === 'function') activeGraph.click(e, activeGraph);
|
|
|
graphs.forEach(function (graph) {
|
|
|
return graph && (graph.status = 'static');
|
|
|
});
|
|
|
if (activeGraph) activeGraph.status = 'hover';
|
|
|
if (dragGraph) dragGraph.status = 'hover';
|
|
|
}
|
|
|
/**
|
|
|
* @description Clone Graph
|
|
|
* @param {Graph} graph The target to be cloned
|
|
|
* @return {Graph} Cloned graph
|
|
|
*/
|
|
|
|
|
|
|
|
|
CRender.prototype.clone = function (graph) {
|
|
|
var style = graph.style.getStyle();
|
|
|
|
|
|
var clonedGraph = _objectSpread({}, graph, {
|
|
|
style: style
|
|
|
});
|
|
|
|
|
|
delete clonedGraph.render;
|
|
|
clonedGraph = (0, _util.deepClone)(clonedGraph, true);
|
|
|
return this.add(clonedGraph);
|
|
|
};
|
|
|
},{"../config/graphs":5,"../plugin/util":8,"./graph.class":3,"@babel/runtime/helpers/classCallCheck":12,"@babel/runtime/helpers/defineProperty":13,"@babel/runtime/helpers/interopRequireDefault":14,"@babel/runtime/helpers/toConsumableArray":20,"@jiaminghi/bezier-curve":25,"@jiaminghi/color":27}],3:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
|
|
|
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
|
|
|
|
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
|
|
|
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
|
|
|
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
|
|
|
|
var _style = _interopRequireDefault(require("./style.class"));
|
|
|
|
|
|
var _transition = _interopRequireDefault(require("@jiaminghi/transition"));
|
|
|
|
|
|
var _util = require("../plugin/util");
|
|
|
|
|
|
/**
|
|
|
* @description Class Graph
|
|
|
* @param {Object} graph Graph default configuration
|
|
|
* @param {Object} config Graph config
|
|
|
* @return {Graph} Instance of Graph
|
|
|
*/
|
|
|
var Graph = function Graph(graph, config) {
|
|
|
(0, _classCallCheck2["default"])(this, Graph);
|
|
|
config = (0, _util.deepClone)(config, true);
|
|
|
var defaultConfig = {
|
|
|
/**
|
|
|
* @description Weather to render graph
|
|
|
* @type {Boolean}
|
|
|
* @default visible = true
|
|
|
*/
|
|
|
visible: true,
|
|
|
|
|
|
/**
|
|
|
* @description Whether to enable drag
|
|
|
* @type {Boolean}
|
|
|
* @default drag = false
|
|
|
*/
|
|
|
drag: false,
|
|
|
|
|
|
/**
|
|
|
* @description Whether to enable hover
|
|
|
* @type {Boolean}
|
|
|
* @default hover = false
|
|
|
*/
|
|
|
hover: false,
|
|
|
|
|
|
/**
|
|
|
* @description Graph rendering index
|
|
|
* Give priority to index high graph in rendering
|
|
|
* @type {Number}
|
|
|
* @example index = 1
|
|
|
*/
|
|
|
index: 1,
|
|
|
|
|
|
/**
|
|
|
* @description Animation delay time(ms)
|
|
|
* @type {Number}
|
|
|
* @default animationDelay = 0
|
|
|
*/
|
|
|
animationDelay: 0,
|
|
|
|
|
|
/**
|
|
|
* @description Number of animation frames
|
|
|
* @type {Number}
|
|
|
* @default animationFrame = 30
|
|
|
*/
|
|
|
animationFrame: 30,
|
|
|
|
|
|
/**
|
|
|
* @description Animation dynamic curve (Supported by transition)
|
|
|
* @type {String}
|
|
|
* @default animationCurve = 'linear'
|
|
|
* @link https://github.com/jiaming743/Transition
|
|
|
*/
|
|
|
animationCurve: 'linear',
|
|
|
|
|
|
/**
|
|
|
* @description Weather to pause graph animation
|
|
|
* @type {Boolean}
|
|
|
* @default animationPause = false
|
|
|
*/
|
|
|
animationPause: false,
|
|
|
|
|
|
/**
|
|
|
* @description Rectangular hover detection zone
|
|
|
* Use this method for hover detection first
|
|
|
* @type {Null|Array}
|
|
|
* @default hoverRect = null
|
|
|
* @example hoverRect = [0, 0, 100, 100] // [Rect start x, y, Rect width, height]
|
|
|
*/
|
|
|
hoverRect: null,
|
|
|
|
|
|
/**
|
|
|
* @description Mouse enter event handler
|
|
|
* @type {Function|Null}
|
|
|
* @default mouseEnter = null
|
|
|
*/
|
|
|
mouseEnter: null,
|
|
|
|
|
|
/**
|
|
|
* @description Mouse outer event handler
|
|
|
* @type {Function|Null}
|
|
|
* @default mouseOuter = null
|
|
|
*/
|
|
|
mouseOuter: null,
|
|
|
|
|
|
/**
|
|
|
* @description Mouse click event handler
|
|
|
* @type {Function|Null}
|
|
|
* @default click = null
|
|
|
*/
|
|
|
click: null
|
|
|
};
|
|
|
var configAbleNot = {
|
|
|
status: 'static',
|
|
|
animationRoot: [],
|
|
|
animationKeys: [],
|
|
|
animationFrameState: [],
|
|
|
cache: {}
|
|
|
};
|
|
|
if (!config.shape) config.shape = {};
|
|
|
if (!config.style) config.style = {};
|
|
|
var shape = Object.assign({}, graph.shape, config.shape);
|
|
|
Object.assign(defaultConfig, config, configAbleNot);
|
|
|
Object.assign(this, graph, defaultConfig);
|
|
|
this.shape = shape;
|
|
|
this.style = new _style["default"](config.style);
|
|
|
this.addedProcessor();
|
|
|
};
|
|
|
/**
|
|
|
* @description Processor of added
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
exports["default"] = Graph;
|
|
|
|
|
|
Graph.prototype.addedProcessor = function () {
|
|
|
if (typeof this.setGraphCenter === 'function') this.setGraphCenter(null, this); // The life cycle 'added"
|
|
|
|
|
|
if (typeof this.added === 'function') this.added(this);
|
|
|
};
|
|
|
/**
|
|
|
* @description Processor of draw
|
|
|
* @param {CRender} render Instance of CRender
|
|
|
* @param {Graph} graph Instance of Graph
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.drawProcessor = function (render, graph) {
|
|
|
var ctx = render.ctx;
|
|
|
graph.style.initStyle(ctx);
|
|
|
if (typeof this.beforeDraw === 'function') this.beforeDraw(this, render);
|
|
|
graph.draw(render, graph);
|
|
|
if (typeof this.drawed === 'function') this.drawed(this, render);
|
|
|
graph.style.restoreTransform(ctx);
|
|
|
};
|
|
|
/**
|
|
|
* @description Processor of hover check
|
|
|
* @param {Array} position Mouse Position
|
|
|
* @param {Graph} graph Instance of Graph
|
|
|
* @return {Boolean} Result of hover check
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.hoverCheckProcessor = function (position, _ref) {
|
|
|
var hoverRect = _ref.hoverRect,
|
|
|
style = _ref.style,
|
|
|
hoverCheck = _ref.hoverCheck;
|
|
|
var graphCenter = style.graphCenter,
|
|
|
rotate = style.rotate,
|
|
|
scale = style.scale,
|
|
|
translate = style.translate;
|
|
|
|
|
|
if (graphCenter) {
|
|
|
if (rotate) position = (0, _util.getRotatePointPos)(-rotate, position, graphCenter);
|
|
|
if (scale) position = (0, _util.getScalePointPos)(scale.map(function (s) {
|
|
|
return 1 / s;
|
|
|
}), position, graphCenter);
|
|
|
if (translate) position = (0, _util.getTranslatePointPos)(translate.map(function (v) {
|
|
|
return v * -1;
|
|
|
}), position);
|
|
|
}
|
|
|
|
|
|
if (hoverRect) return _util.checkPointIsInRect.apply(void 0, [position].concat((0, _toConsumableArray2["default"])(hoverRect)));
|
|
|
return hoverCheck(position, this);
|
|
|
};
|
|
|
/**
|
|
|
* @description Processor of move
|
|
|
* @param {Event} e Mouse movement event
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.moveProcessor = function (e) {
|
|
|
this.move(e, this);
|
|
|
if (typeof this.beforeMove === 'function') this.beforeMove(e, this);
|
|
|
if (typeof this.setGraphCenter === 'function') this.setGraphCenter(e, this);
|
|
|
if (typeof this.moved === 'function') this.moved(e, this);
|
|
|
};
|
|
|
/**
|
|
|
* @description Update graph state
|
|
|
* @param {String} attrName Updated attribute name
|
|
|
* @param {Any} change Updated value
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.attr = function (attrName) {
|
|
|
var change = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
|
|
|
if (!attrName || change === undefined) return false;
|
|
|
var isObject = (0, _typeof2["default"])(this[attrName]) === 'object';
|
|
|
if (isObject) change = (0, _util.deepClone)(change, true);
|
|
|
var render = this.render;
|
|
|
|
|
|
if (attrName === 'style') {
|
|
|
this.style.update(change);
|
|
|
} else if (isObject) {
|
|
|
Object.assign(this[attrName], change);
|
|
|
} else {
|
|
|
this[attrName] = change;
|
|
|
}
|
|
|
|
|
|
if (attrName === 'index') render.sortGraphsByIndex();
|
|
|
render.drawAllGraph();
|
|
|
};
|
|
|
/**
|
|
|
* @description Update graphics state (with animation)
|
|
|
* Only shape and style attributes are supported
|
|
|
* @param {String} attrName Updated attribute name
|
|
|
* @param {Any} change Updated value
|
|
|
* @param {Boolean} wait Whether to store the animation waiting
|
|
|
* for the next animation request
|
|
|
* @return {Promise} Animation Promise
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.animation =
|
|
|
/*#__PURE__*/
|
|
|
function () {
|
|
|
var _ref2 = (0, _asyncToGenerator2["default"])(
|
|
|
/*#__PURE__*/
|
|
|
_regenerator["default"].mark(function _callee2(attrName, change) {
|
|
|
var wait,
|
|
|
changeRoot,
|
|
|
changeKeys,
|
|
|
beforeState,
|
|
|
animationFrame,
|
|
|
animationCurve,
|
|
|
animationDelay,
|
|
|
animationFrameState,
|
|
|
render,
|
|
|
_args2 = arguments;
|
|
|
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
|
while (1) {
|
|
|
switch (_context2.prev = _context2.next) {
|
|
|
case 0:
|
|
|
wait = _args2.length > 2 && _args2[2] !== undefined ? _args2[2] : false;
|
|
|
|
|
|
if (!(attrName !== 'shape' && attrName !== 'style')) {
|
|
|
_context2.next = 4;
|
|
|
break;
|
|
|
}
|
|
|
|
|
|
console.error('Only supported shape and style animation!');
|
|
|
return _context2.abrupt("return");
|
|
|
|
|
|
case 4:
|
|
|
change = (0, _util.deepClone)(change, true);
|
|
|
if (attrName === 'style') this.style.colorProcessor(change);
|
|
|
changeRoot = this[attrName];
|
|
|
changeKeys = Object.keys(change);
|
|
|
beforeState = {};
|
|
|
changeKeys.forEach(function (key) {
|
|
|
return beforeState[key] = changeRoot[key];
|
|
|
});
|
|
|
animationFrame = this.animationFrame, animationCurve = this.animationCurve, animationDelay = this.animationDelay;
|
|
|
animationFrameState = (0, _transition["default"])(animationCurve, beforeState, change, animationFrame, true);
|
|
|
this.animationRoot.push(changeRoot);
|
|
|
this.animationKeys.push(changeKeys);
|
|
|
this.animationFrameState.push(animationFrameState);
|
|
|
|
|
|
if (!wait) {
|
|
|
_context2.next = 17;
|
|
|
break;
|
|
|
}
|
|
|
|
|
|
return _context2.abrupt("return");
|
|
|
|
|
|
case 17:
|
|
|
if (!(animationDelay > 0)) {
|
|
|
_context2.next = 20;
|
|
|
break;
|
|
|
}
|
|
|
|
|
|
_context2.next = 20;
|
|
|
return delay(animationDelay);
|
|
|
|
|
|
case 20:
|
|
|
render = this.render;
|
|
|
return _context2.abrupt("return", new Promise(
|
|
|
/*#__PURE__*/
|
|
|
function () {
|
|
|
var _ref3 = (0, _asyncToGenerator2["default"])(
|
|
|
/*#__PURE__*/
|
|
|
_regenerator["default"].mark(function _callee(resolve) {
|
|
|
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
|
while (1) {
|
|
|
switch (_context.prev = _context.next) {
|
|
|
case 0:
|
|
|
_context.next = 2;
|
|
|
return render.launchAnimation();
|
|
|
|
|
|
case 2:
|
|
|
resolve();
|
|
|
|
|
|
case 3:
|
|
|
case "end":
|
|
|
return _context.stop();
|
|
|
}
|
|
|
}
|
|
|
}, _callee);
|
|
|
}));
|
|
|
|
|
|
return function (_x3) {
|
|
|
return _ref3.apply(this, arguments);
|
|
|
};
|
|
|
}()));
|
|
|
|
|
|
case 22:
|
|
|
case "end":
|
|
|
return _context2.stop();
|
|
|
}
|
|
|
}
|
|
|
}, _callee2, this);
|
|
|
}));
|
|
|
|
|
|
return function (_x, _x2) {
|
|
|
return _ref2.apply(this, arguments);
|
|
|
};
|
|
|
}();
|
|
|
/**
|
|
|
* @description Extract the next frame of data from the animation queue
|
|
|
* and update the graph state
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.turnNextAnimationFrame = function (timeStamp) {
|
|
|
var animationDelay = this.animationDelay,
|
|
|
animationRoot = this.animationRoot,
|
|
|
animationKeys = this.animationKeys,
|
|
|
animationFrameState = this.animationFrameState,
|
|
|
animationPause = this.animationPause;
|
|
|
if (animationPause) return;
|
|
|
if (Date.now() - timeStamp < animationDelay) return;
|
|
|
animationRoot.forEach(function (root, i) {
|
|
|
animationKeys[i].forEach(function (key) {
|
|
|
root[key] = animationFrameState[i][0][key];
|
|
|
});
|
|
|
});
|
|
|
animationFrameState.forEach(function (stateItem, i) {
|
|
|
stateItem.shift();
|
|
|
var noFrame = stateItem.length === 0;
|
|
|
if (noFrame) animationRoot[i] = null;
|
|
|
if (noFrame) animationKeys[i] = null;
|
|
|
});
|
|
|
this.animationFrameState = animationFrameState.filter(function (state) {
|
|
|
return state.length;
|
|
|
});
|
|
|
this.animationRoot = animationRoot.filter(function (root) {
|
|
|
return root;
|
|
|
});
|
|
|
this.animationKeys = animationKeys.filter(function (keys) {
|
|
|
return keys;
|
|
|
});
|
|
|
};
|
|
|
/**
|
|
|
* @description Skip to the last frame of animation
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.animationEnd = function () {
|
|
|
var animationFrameState = this.animationFrameState,
|
|
|
animationKeys = this.animationKeys,
|
|
|
animationRoot = this.animationRoot,
|
|
|
render = this.render;
|
|
|
animationRoot.forEach(function (root, i) {
|
|
|
var currentKeys = animationKeys[i];
|
|
|
var lastState = animationFrameState[i].pop();
|
|
|
currentKeys.forEach(function (key) {
|
|
|
return root[key] = lastState[key];
|
|
|
});
|
|
|
});
|
|
|
this.animationFrameState = [];
|
|
|
this.animationKeys = [];
|
|
|
this.animationRoot = [];
|
|
|
return render.drawAllGraph();
|
|
|
};
|
|
|
/**
|
|
|
* @description Pause animation behavior
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.pauseAnimation = function () {
|
|
|
this.attr('animationPause', true);
|
|
|
};
|
|
|
/**
|
|
|
* @description Try animation behavior
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.playAnimation = function () {
|
|
|
var render = this.render;
|
|
|
this.attr('animationPause', false);
|
|
|
return new Promise(
|
|
|
/*#__PURE__*/
|
|
|
function () {
|
|
|
var _ref4 = (0, _asyncToGenerator2["default"])(
|
|
|
/*#__PURE__*/
|
|
|
_regenerator["default"].mark(function _callee3(resolve) {
|
|
|
return _regenerator["default"].wrap(function _callee3$(_context3) {
|
|
|
while (1) {
|
|
|
switch (_context3.prev = _context3.next) {
|
|
|
case 0:
|
|
|
_context3.next = 2;
|
|
|
return render.launchAnimation();
|
|
|
|
|
|
case 2:
|
|
|
resolve();
|
|
|
|
|
|
case 3:
|
|
|
case "end":
|
|
|
return _context3.stop();
|
|
|
}
|
|
|
}
|
|
|
}, _callee3);
|
|
|
}));
|
|
|
|
|
|
return function (_x4) {
|
|
|
return _ref4.apply(this, arguments);
|
|
|
};
|
|
|
}());
|
|
|
};
|
|
|
/**
|
|
|
* @description Processor of delete
|
|
|
* @param {CRender} render Instance of CRender
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Graph.prototype.delProcessor = function (render) {
|
|
|
var _this = this;
|
|
|
|
|
|
var graphs = render.graphs;
|
|
|
var index = graphs.findIndex(function (graph) {
|
|
|
return graph === _this;
|
|
|
});
|
|
|
if (index === -1) return;
|
|
|
if (typeof this.beforeDelete === 'function') this.beforeDelete(this);
|
|
|
graphs.splice(index, 1, null);
|
|
|
if (typeof this.deleted === 'function') this.deleted(this);
|
|
|
};
|
|
|
/**
|
|
|
* @description Return a timed release Promise
|
|
|
* @param {Number} time Release time
|
|
|
* @return {Promise} A timed release Promise
|
|
|
*/
|
|
|
|
|
|
|
|
|
function delay(time) {
|
|
|
return new Promise(function (resolve) {
|
|
|
setTimeout(resolve, time);
|
|
|
});
|
|
|
}
|
|
|
},{"../plugin/util":8,"./style.class":4,"@babel/runtime/helpers/asyncToGenerator":11,"@babel/runtime/helpers/classCallCheck":12,"@babel/runtime/helpers/interopRequireDefault":14,"@babel/runtime/helpers/toConsumableArray":20,"@babel/runtime/helpers/typeof":21,"@babel/runtime/regenerator":22,"@jiaminghi/transition":29}],4:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
|
|
|
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
|
|
|
|
var _color = require("@jiaminghi/color");
|
|
|
|
|
|
var _util = require("../plugin/util");
|
|
|
|
|
|
/**
|
|
|
* @description Class Style
|
|
|
* @param {Object} style Style configuration
|
|
|
* @return {Style} Instance of Style
|
|
|
*/
|
|
|
var Style = function Style(style) {
|
|
|
(0, _classCallCheck2["default"])(this, Style);
|
|
|
this.colorProcessor(style);
|
|
|
var defaultStyle = {
|
|
|
/**
|
|
|
* @description Rgba value of graph fill color
|
|
|
* @type {Array}
|
|
|
* @default fill = [0, 0, 0, 1]
|
|
|
*/
|
|
|
fill: [0, 0, 0, 1],
|
|
|
|
|
|
/**
|
|
|
* @description Rgba value of graph stroke color
|
|
|
* @type {Array}
|
|
|
* @default stroke = [0, 0, 0, 1]
|
|
|
*/
|
|
|
stroke: [0, 0, 0, 0],
|
|
|
|
|
|
/**
|
|
|
* @description Opacity of graph
|
|
|
* @type {Number}
|
|
|
* @default opacity = 1
|
|
|
*/
|
|
|
opacity: 1,
|
|
|
|
|
|
/**
|
|
|
* @description LineCap of Ctx
|
|
|
* @type {String}
|
|
|
* @default lineCap = null
|
|
|
* @example lineCap = 'butt'|'round'|'square'
|
|
|
*/
|
|
|
lineCap: null,
|
|
|
|
|
|
/**
|
|
|
* @description Linejoin of Ctx
|
|
|
* @type {String}
|
|
|
* @default lineJoin = null
|
|
|
* @example lineJoin = 'round'|'bevel'|'miter'
|
|
|
*/
|
|
|
lineJoin: null,
|
|
|
|
|
|
/**
|
|
|
* @description LineDash of Ctx
|
|
|
* @type {Array}
|
|
|
* @default lineDash = null
|
|
|
* @example lineDash = [10, 10]
|
|
|
*/
|
|
|
lineDash: null,
|
|
|
|
|
|
/**
|
|
|
* @description LineDashOffset of Ctx
|
|
|
* @type {Number}
|
|
|
* @default lineDashOffset = null
|
|
|
* @example lineDashOffset = 10
|
|
|
*/
|
|
|
lineDashOffset: null,
|
|
|
|
|
|
/**
|
|
|
* @description ShadowBlur of Ctx
|
|
|
* @type {Number}
|
|
|
* @default shadowBlur = 0
|
|
|
*/
|
|
|
shadowBlur: 0,
|
|
|
|
|
|
/**
|
|
|
* @description Rgba value of graph shadow color
|
|
|
* @type {Array}
|
|
|
* @default shadowColor = [0, 0, 0, 0]
|
|
|
*/
|
|
|
shadowColor: [0, 0, 0, 0],
|
|
|
|
|
|
/**
|
|
|
* @description ShadowOffsetX of Ctx
|
|
|
* @type {Number}
|
|
|
* @default shadowOffsetX = 0
|
|
|
*/
|
|
|
shadowOffsetX: 0,
|
|
|
|
|
|
/**
|
|
|
* @description ShadowOffsetY of Ctx
|
|
|
* @type {Number}
|
|
|
* @default shadowOffsetY = 0
|
|
|
*/
|
|
|
shadowOffsetY: 0,
|
|
|
|
|
|
/**
|
|
|
* @description LineWidth of Ctx
|
|
|
* @type {Number}
|
|
|
* @default lineWidth = 0
|
|
|
*/
|
|
|
lineWidth: 0,
|
|
|
|
|
|
/**
|
|
|
* @description Center point of the graph
|
|
|
* @type {Array}
|
|
|
* @default graphCenter = null
|
|
|
* @example graphCenter = [10, 10]
|
|
|
*/
|
|
|
graphCenter: null,
|
|
|
|
|
|
/**
|
|
|
* @description Graph scale
|
|
|
* @type {Array}
|
|
|
* @default scale = null
|
|
|
* @example scale = [1.5, 1.5]
|
|
|
*/
|
|
|
scale: null,
|
|
|
|
|
|
/**
|
|
|
* @description Graph rotation degree
|
|
|
* @type {Number}
|
|
|
* @default rotate = null
|
|
|
* @example rotate = 10
|
|
|
*/
|
|
|
rotate: null,
|
|
|
|
|
|
/**
|
|
|
* @description Graph translate distance
|
|
|
* @type {Array}
|
|
|
* @default translate = null
|
|
|
* @example translate = [10, 10]
|
|
|
*/
|
|
|
translate: null,
|
|
|
|
|
|
/**
|
|
|
* @description Cursor status when hover
|
|
|
* @type {String}
|
|
|
* @default hoverCursor = 'pointer'
|
|
|
* @example hoverCursor = 'default'|'pointer'|'auto'|'crosshair'|'move'|'wait'|...
|
|
|
*/
|
|
|
hoverCursor: 'pointer',
|
|
|
|
|
|
/**
|
|
|
* @description Font style of Ctx
|
|
|
* @type {String}
|
|
|
* @default fontStyle = 'normal'
|
|
|
* @example fontStyle = 'normal'|'italic'|'oblique'
|
|
|
*/
|
|
|
fontStyle: 'normal',
|
|
|
|
|
|
/**
|
|
|
* @description Font varient of Ctx
|
|
|
* @type {String}
|
|
|
* @default fontVarient = 'normal'
|
|
|
* @example fontVarient = 'normal'|'small-caps'
|
|
|
*/
|
|
|
fontVarient: 'normal',
|
|
|
|
|
|
/**
|
|
|
* @description Font weight of Ctx
|
|
|
* @type {String|Number}
|
|
|
* @default fontWeight = 'normal'
|
|
|
* @example fontWeight = 'normal'|'bold'|'bolder'|'lighter'|Number
|
|
|
*/
|
|
|
fontWeight: 'normal',
|
|
|
|
|
|
/**
|
|
|
* @description Font size of Ctx
|
|
|
* @type {Number}
|
|
|
* @default fontSize = 10
|
|
|
*/
|
|
|
fontSize: 10,
|
|
|
|
|
|
/**
|
|
|
* @description Font family of Ctx
|
|
|
* @type {String}
|
|
|
* @default fontFamily = 'Arial'
|
|
|
*/
|
|
|
fontFamily: 'Arial',
|
|
|
|
|
|
/**
|
|
|
* @description TextAlign of Ctx
|
|
|
* @type {String}
|
|
|
* @default textAlign = 'center'
|
|
|
* @example textAlign = 'start'|'end'|'left'|'right'|'center'
|
|
|
*/
|
|
|
textAlign: 'center',
|
|
|
|
|
|
/**
|
|
|
* @description TextBaseline of Ctx
|
|
|
* @type {String}
|
|
|
* @default textBaseline = 'middle'
|
|
|
* @example textBaseline = 'top'|'bottom'|'middle'|'alphabetic'|'hanging'
|
|
|
*/
|
|
|
textBaseline: 'middle',
|
|
|
|
|
|
/**
|
|
|
* @description The color used to create the gradient
|
|
|
* @type {Array}
|
|
|
* @default gradientColor = null
|
|
|
* @example gradientColor = ['#000', '#111', '#222']
|
|
|
*/
|
|
|
gradientColor: null,
|
|
|
|
|
|
/**
|
|
|
* @description Gradient type
|
|
|
* @type {String}
|
|
|
* @default gradientType = 'linear'
|
|
|
* @example gradientType = 'linear' | 'radial'
|
|
|
*/
|
|
|
gradientType: 'linear',
|
|
|
|
|
|
/**
|
|
|
* @description Gradient params
|
|
|
* @type {Array}
|
|
|
* @default gradientParams = null
|
|
|
* @example gradientParams = [x0, y0, x1, y1] (Linear Gradient)
|
|
|
* @example gradientParams = [x0, y0, r0, x1, y1, r1] (Radial Gradient)
|
|
|
*/
|
|
|
gradientParams: null,
|
|
|
|
|
|
/**
|
|
|
* @description When to use gradients
|
|
|
* @type {String}
|
|
|
* @default gradientWith = 'stroke'
|
|
|
* @example gradientWith = 'stroke' | 'fill'
|
|
|
*/
|
|
|
gradientWith: 'stroke',
|
|
|
|
|
|
/**
|
|
|
* @description Gradient color stops
|
|
|
* @type {String}
|
|
|
* @default gradientStops = 'auto'
|
|
|
* @example gradientStops = 'auto' | [0, .2, .3, 1]
|
|
|
*/
|
|
|
gradientStops: 'auto',
|
|
|
|
|
|
/**
|
|
|
* @description Extended color that supports animation transition
|
|
|
* @type {Array|Object}
|
|
|
* @default colors = null
|
|
|
* @example colors = ['#000', '#111', '#222', 'red' ]
|
|
|
* @example colors = { a: '#000', b: '#111' }
|
|
|
*/
|
|
|
colors: null
|
|
|
};
|
|
|
Object.assign(this, defaultStyle, style);
|
|
|
};
|
|
|
/**
|
|
|
* @description Set colors to rgba value
|
|
|
* @param {Object} style style config
|
|
|
* @param {Boolean} reverse Whether to perform reverse operation
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
exports["default"] = Style;
|
|
|
|
|
|
Style.prototype.colorProcessor = function (style) {
|
|
|
var reverse = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
|
var processor = reverse ? _color.getColorFromRgbValue : _color.getRgbaValue;
|
|
|
var colorProcessorKeys = ['fill', 'stroke', 'shadowColor'];
|
|
|
var allKeys = Object.keys(style);
|
|
|
var colorKeys = allKeys.filter(function (key) {
|
|
|
return colorProcessorKeys.find(function (k) {
|
|
|
return k === key;
|
|
|
});
|
|
|
});
|
|
|
colorKeys.forEach(function (key) {
|
|
|
return style[key] = processor(style[key]);
|
|
|
});
|
|
|
var gradientColor = style.gradientColor,
|
|
|
colors = style.colors;
|
|
|
if (gradientColor) style.gradientColor = gradientColor.map(function (c) {
|
|
|
return processor(c);
|
|
|
});
|
|
|
|
|
|
if (colors) {
|
|
|
var colorsKeys = Object.keys(colors);
|
|
|
colorsKeys.forEach(function (key) {
|
|
|
return colors[key] = processor(colors[key]);
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
/**
|
|
|
* @description Init graph style
|
|
|
* @param {Object} ctx Context of canvas
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Style.prototype.initStyle = function (ctx) {
|
|
|
initTransform(ctx, this);
|
|
|
initGraphStyle(ctx, this);
|
|
|
initGradient(ctx, this);
|
|
|
};
|
|
|
/**
|
|
|
* @description Init canvas transform
|
|
|
* @param {Object} ctx Context of canvas
|
|
|
* @param {Style} style Instance of Style
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
function initTransform(ctx, style) {
|
|
|
ctx.save();
|
|
|
var graphCenter = style.graphCenter,
|
|
|
rotate = style.rotate,
|
|
|
scale = style.scale,
|
|
|
translate = style.translate;
|
|
|
if (!(graphCenter instanceof Array)) return;
|
|
|
ctx.translate.apply(ctx, (0, _toConsumableArray2["default"])(graphCenter));
|
|
|
if (rotate) ctx.rotate(rotate * Math.PI / 180);
|
|
|
if (scale instanceof Array) ctx.scale.apply(ctx, (0, _toConsumableArray2["default"])(scale));
|
|
|
if (translate) ctx.translate.apply(ctx, (0, _toConsumableArray2["default"])(translate));
|
|
|
ctx.translate(-graphCenter[0], -graphCenter[1]);
|
|
|
}
|
|
|
|
|
|
var autoSetStyleKeys = ['lineCap', 'lineJoin', 'lineDashOffset', 'shadowOffsetX', 'shadowOffsetY', 'lineWidth', 'textAlign', 'textBaseline'];
|
|
|
/**
|
|
|
* @description Set the style of canvas ctx
|
|
|
* @param {Object} ctx Context of canvas
|
|
|
* @param {Style} style Instance of Style
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
function initGraphStyle(ctx, style) {
|
|
|
var fill = style.fill,
|
|
|
stroke = style.stroke,
|
|
|
shadowColor = style.shadowColor,
|
|
|
opacity = style.opacity;
|
|
|
autoSetStyleKeys.forEach(function (key) {
|
|
|
if (key || typeof key === 'number') ctx[key] = style[key];
|
|
|
});
|
|
|
fill = (0, _toConsumableArray2["default"])(fill);
|
|
|
stroke = (0, _toConsumableArray2["default"])(stroke);
|
|
|
shadowColor = (0, _toConsumableArray2["default"])(shadowColor);
|
|
|
fill[3] *= opacity;
|
|
|
stroke[3] *= opacity;
|
|
|
shadowColor[3] *= opacity;
|
|
|
ctx.fillStyle = (0, _color.getColorFromRgbValue)(fill);
|
|
|
ctx.strokeStyle = (0, _color.getColorFromRgbValue)(stroke);
|
|
|
ctx.shadowColor = (0, _color.getColorFromRgbValue)(shadowColor);
|
|
|
var lineDash = style.lineDash,
|
|
|
shadowBlur = style.shadowBlur;
|
|
|
|
|
|
if (lineDash) {
|
|
|
lineDash = lineDash.map(function (v) {
|
|
|
return v >= 0 ? v : 0;
|
|
|
});
|
|
|
ctx.setLineDash(lineDash);
|
|
|
}
|
|
|
|
|
|
if (typeof shadowBlur === 'number') ctx.shadowBlur = shadowBlur > 0 ? shadowBlur : 0.001;
|
|
|
var fontStyle = style.fontStyle,
|
|
|
fontVarient = style.fontVarient,
|
|
|
fontWeight = style.fontWeight,
|
|
|
fontSize = style.fontSize,
|
|
|
fontFamily = style.fontFamily;
|
|
|
ctx.font = fontStyle + ' ' + fontVarient + ' ' + fontWeight + ' ' + fontSize + 'px' + ' ' + fontFamily;
|
|
|
}
|
|
|
/**
|
|
|
* @description Set the gradient color of canvas ctx
|
|
|
* @param {Object} ctx Context of canvas
|
|
|
* @param {Style} style Instance of Style
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
function initGradient(ctx, style) {
|
|
|
if (!gradientValidator(style)) return;
|
|
|
var gradientColor = style.gradientColor,
|
|
|
gradientParams = style.gradientParams,
|
|
|
gradientType = style.gradientType,
|
|
|
gradientWith = style.gradientWith,
|
|
|
gradientStops = style.gradientStops,
|
|
|
opacity = style.opacity;
|
|
|
gradientColor = gradientColor.map(function (color) {
|
|
|
var colorOpacity = color[3] * opacity;
|
|
|
var clonedColor = (0, _toConsumableArray2["default"])(color);
|
|
|
clonedColor[3] = colorOpacity;
|
|
|
return clonedColor;
|
|
|
});
|
|
|
gradientColor = gradientColor.map(function (c) {
|
|
|
return (0, _color.getColorFromRgbValue)(c);
|
|
|
});
|
|
|
if (gradientStops === 'auto') gradientStops = getAutoColorStops(gradientColor);
|
|
|
var gradient = ctx["create".concat(gradientType.slice(0, 1).toUpperCase() + gradientType.slice(1), "Gradient")].apply(ctx, (0, _toConsumableArray2["default"])(gradientParams));
|
|
|
gradientStops.forEach(function (stop, i) {
|
|
|
return gradient.addColorStop(stop, gradientColor[i]);
|
|
|
});
|
|
|
ctx["".concat(gradientWith, "Style")] = gradient;
|
|
|
}
|
|
|
/**
|
|
|
* @description Check if the gradient configuration is legal
|
|
|
* @param {Style} style Instance of Style
|
|
|
* @return {Boolean} Check Result
|
|
|
*/
|
|
|
|
|
|
|
|
|
function gradientValidator(style) {
|
|
|
var gradientColor = style.gradientColor,
|
|
|
gradientParams = style.gradientParams,
|
|
|
gradientType = style.gradientType,
|
|
|
gradientWith = style.gradientWith,
|
|
|
gradientStops = style.gradientStops;
|
|
|
if (!gradientColor || !gradientParams) return false;
|
|
|
|
|
|
if (gradientColor.length === 1) {
|
|
|
console.warn('The gradient needs to provide at least two colors');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (gradientType !== 'linear' && gradientType !== 'radial') {
|
|
|
console.warn('GradientType only supports linear or radial, current value is ' + gradientType);
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var gradientParamsLength = gradientParams.length;
|
|
|
|
|
|
if (gradientType === 'linear' && gradientParamsLength !== 4 || gradientType === 'radial' && gradientParamsLength !== 6) {
|
|
|
console.warn('The expected length of gradientParams is ' + (gradientType === 'linear' ? '4' : '6'));
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (gradientWith !== 'fill' && gradientWith !== 'stroke') {
|
|
|
console.warn('GradientWith only supports fill or stroke, current value is ' + gradientWith);
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (gradientStops !== 'auto' && !(gradientStops instanceof Array)) {
|
|
|
console.warn("gradientStops only supports 'auto' or Number Array ([0, .5, 1]), current value is " + gradientStops);
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get a uniform gradient color stop
|
|
|
* @param {Array} color Gradient color
|
|
|
* @return {Array} Gradient color stop
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getAutoColorStops(color) {
|
|
|
var stopGap = 1 / (color.length - 1);
|
|
|
return color.map(function (foo, i) {
|
|
|
return stopGap * i;
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Restore canvas ctx transform
|
|
|
* @param {Object} ctx Context of canvas
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Style.prototype.restoreTransform = function (ctx) {
|
|
|
ctx.restore();
|
|
|
};
|
|
|
/**
|
|
|
* @description Update style data
|
|
|
* @param {Object} change Changed data
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
Style.prototype.update = function (change) {
|
|
|
this.colorProcessor(change);
|
|
|
Object.assign(this, change);
|
|
|
};
|
|
|
/**
|
|
|
* @description Get the current style configuration
|
|
|
* @return {Object} Style configuration
|
|
|
*/
|
|
|
|
|
|
|
|
|
Style.prototype.getStyle = function () {
|
|
|
var clonedStyle = (0, _util.deepClone)(this, true);
|
|
|
this.colorProcessor(clonedStyle, true);
|
|
|
return clonedStyle;
|
|
|
};
|
|
|
},{"../plugin/util":8,"@babel/runtime/helpers/classCallCheck":12,"@babel/runtime/helpers/interopRequireDefault":14,"@babel/runtime/helpers/toConsumableArray":20,"@jiaminghi/color":27}],5:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports.extendNewGraph = extendNewGraph;
|
|
|
exports["default"] = exports.text = exports.bezierCurve = exports.smoothline = exports.polyline = exports.regPolygon = exports.sector = exports.arc = exports.ring = exports.rect = exports.ellipse = exports.circle = void 0;
|
|
|
|
|
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
|
|
|
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
|
|
|
|
var _bezierCurve2 = _interopRequireDefault(require("@jiaminghi/bezier-curve"));
|
|
|
|
|
|
var _util = require("../plugin/util");
|
|
|
|
|
|
var _canvas = require("../plugin/canvas");
|
|
|
|
|
|
var polylineToBezierCurve = _bezierCurve2["default"].polylineToBezierCurve,
|
|
|
bezierCurveToPolyline = _bezierCurve2["default"].bezierCurveToPolyline;
|
|
|
var circle = {
|
|
|
shape: {
|
|
|
rx: 0,
|
|
|
ry: 0,
|
|
|
r: 0
|
|
|
},
|
|
|
validator: function validator(_ref) {
|
|
|
var shape = _ref.shape;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r;
|
|
|
|
|
|
if (typeof rx !== 'number' || typeof ry !== 'number' || typeof r !== 'number') {
|
|
|
console.error('Circle shape configuration is abnormal!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref2, _ref3) {
|
|
|
var ctx = _ref2.ctx;
|
|
|
var shape = _ref3.shape;
|
|
|
ctx.beginPath();
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r;
|
|
|
ctx.arc(rx, ry, r > 0 ? r : 0.01, 0, Math.PI * 2);
|
|
|
ctx.fill();
|
|
|
ctx.stroke();
|
|
|
ctx.closePath();
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref4) {
|
|
|
var shape = _ref4.shape;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r;
|
|
|
return (0, _util.checkPointIsInCircle)(position, rx, ry, r);
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref5) {
|
|
|
var shape = _ref5.shape,
|
|
|
style = _ref5.style;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry;
|
|
|
style.graphCenter = [rx, ry];
|
|
|
},
|
|
|
move: function move(_ref6, _ref7) {
|
|
|
var movementX = _ref6.movementX,
|
|
|
movementY = _ref6.movementY;
|
|
|
var shape = _ref7.shape;
|
|
|
this.attr('shape', {
|
|
|
rx: shape.rx + movementX,
|
|
|
ry: shape.ry + movementY
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.circle = circle;
|
|
|
var ellipse = {
|
|
|
shape: {
|
|
|
rx: 0,
|
|
|
ry: 0,
|
|
|
hr: 0,
|
|
|
vr: 0
|
|
|
},
|
|
|
validator: function validator(_ref8) {
|
|
|
var shape = _ref8.shape;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
hr = shape.hr,
|
|
|
vr = shape.vr;
|
|
|
|
|
|
if (typeof rx !== 'number' || typeof ry !== 'number' || typeof hr !== 'number' || typeof vr !== 'number') {
|
|
|
console.error('Ellipse shape configuration is abnormal!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref9, _ref10) {
|
|
|
var ctx = _ref9.ctx;
|
|
|
var shape = _ref10.shape;
|
|
|
ctx.beginPath();
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
hr = shape.hr,
|
|
|
vr = shape.vr;
|
|
|
ctx.ellipse(rx, ry, hr > 0 ? hr : 0.01, vr > 0 ? vr : 0.01, 0, 0, Math.PI * 2);
|
|
|
ctx.fill();
|
|
|
ctx.stroke();
|
|
|
ctx.closePath();
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref11) {
|
|
|
var shape = _ref11.shape;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
hr = shape.hr,
|
|
|
vr = shape.vr;
|
|
|
var a = Math.max(hr, vr);
|
|
|
var b = Math.min(hr, vr);
|
|
|
var c = Math.sqrt(a * a - b * b);
|
|
|
var leftFocusPoint = [rx - c, ry];
|
|
|
var rightFocusPoint = [rx + c, ry];
|
|
|
var distance = (0, _util.getTwoPointDistance)(position, leftFocusPoint) + (0, _util.getTwoPointDistance)(position, rightFocusPoint);
|
|
|
return distance <= 2 * a;
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref12) {
|
|
|
var shape = _ref12.shape,
|
|
|
style = _ref12.style;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry;
|
|
|
style.graphCenter = [rx, ry];
|
|
|
},
|
|
|
move: function move(_ref13, _ref14) {
|
|
|
var movementX = _ref13.movementX,
|
|
|
movementY = _ref13.movementY;
|
|
|
var shape = _ref14.shape;
|
|
|
this.attr('shape', {
|
|
|
rx: shape.rx + movementX,
|
|
|
ry: shape.ry + movementY
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.ellipse = ellipse;
|
|
|
var rect = {
|
|
|
shape: {
|
|
|
x: 0,
|
|
|
y: 0,
|
|
|
w: 0,
|
|
|
h: 0
|
|
|
},
|
|
|
validator: function validator(_ref15) {
|
|
|
var shape = _ref15.shape;
|
|
|
var x = shape.x,
|
|
|
y = shape.y,
|
|
|
w = shape.w,
|
|
|
h = shape.h;
|
|
|
|
|
|
if (typeof x !== 'number' || typeof y !== 'number' || typeof w !== 'number' || typeof h !== 'number') {
|
|
|
console.error('Rect shape configuration is abnormal!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref16, _ref17) {
|
|
|
var ctx = _ref16.ctx;
|
|
|
var shape = _ref17.shape;
|
|
|
ctx.beginPath();
|
|
|
var x = shape.x,
|
|
|
y = shape.y,
|
|
|
w = shape.w,
|
|
|
h = shape.h;
|
|
|
ctx.rect(x, y, w, h);
|
|
|
ctx.fill();
|
|
|
ctx.stroke();
|
|
|
ctx.closePath();
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref18) {
|
|
|
var shape = _ref18.shape;
|
|
|
var x = shape.x,
|
|
|
y = shape.y,
|
|
|
w = shape.w,
|
|
|
h = shape.h;
|
|
|
return (0, _util.checkPointIsInRect)(position, x, y, w, h);
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref19) {
|
|
|
var shape = _ref19.shape,
|
|
|
style = _ref19.style;
|
|
|
var x = shape.x,
|
|
|
y = shape.y,
|
|
|
w = shape.w,
|
|
|
h = shape.h;
|
|
|
style.graphCenter = [x + w / 2, y + h / 2];
|
|
|
},
|
|
|
move: function move(_ref20, _ref21) {
|
|
|
var movementX = _ref20.movementX,
|
|
|
movementY = _ref20.movementY;
|
|
|
var shape = _ref21.shape;
|
|
|
this.attr('shape', {
|
|
|
x: shape.x + movementX,
|
|
|
y: shape.y + movementY
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.rect = rect;
|
|
|
var ring = {
|
|
|
shape: {
|
|
|
rx: 0,
|
|
|
ry: 0,
|
|
|
r: 0
|
|
|
},
|
|
|
validator: function validator(_ref22) {
|
|
|
var shape = _ref22.shape;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r;
|
|
|
|
|
|
if (typeof rx !== 'number' || typeof ry !== 'number' || typeof r !== 'number') {
|
|
|
console.error('Ring shape configuration is abnormal!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref23, _ref24) {
|
|
|
var ctx = _ref23.ctx;
|
|
|
var shape = _ref24.shape;
|
|
|
ctx.beginPath();
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r;
|
|
|
ctx.arc(rx, ry, r > 0 ? r : 0.01, 0, Math.PI * 2);
|
|
|
ctx.stroke();
|
|
|
ctx.closePath();
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref25) {
|
|
|
var shape = _ref25.shape,
|
|
|
style = _ref25.style;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r;
|
|
|
var lineWidth = style.lineWidth;
|
|
|
var halfLineWidth = lineWidth / 2;
|
|
|
var minDistance = r - halfLineWidth;
|
|
|
var maxDistance = r + halfLineWidth;
|
|
|
var distance = (0, _util.getTwoPointDistance)(position, [rx, ry]);
|
|
|
return distance >= minDistance && distance <= maxDistance;
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref26) {
|
|
|
var shape = _ref26.shape,
|
|
|
style = _ref26.style;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry;
|
|
|
style.graphCenter = [rx, ry];
|
|
|
},
|
|
|
move: function move(_ref27, _ref28) {
|
|
|
var movementX = _ref27.movementX,
|
|
|
movementY = _ref27.movementY;
|
|
|
var shape = _ref28.shape;
|
|
|
this.attr('shape', {
|
|
|
rx: shape.rx + movementX,
|
|
|
ry: shape.ry + movementY
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.ring = ring;
|
|
|
var arc = {
|
|
|
shape: {
|
|
|
rx: 0,
|
|
|
ry: 0,
|
|
|
r: 0,
|
|
|
startAngle: 0,
|
|
|
endAngle: 0,
|
|
|
clockWise: true
|
|
|
},
|
|
|
validator: function validator(_ref29) {
|
|
|
var shape = _ref29.shape;
|
|
|
var keys = ['rx', 'ry', 'r', 'startAngle', 'endAngle'];
|
|
|
|
|
|
if (keys.find(function (key) {
|
|
|
return typeof shape[key] !== 'number';
|
|
|
})) {
|
|
|
console.error('Arc shape configuration is abnormal!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref30, _ref31) {
|
|
|
var ctx = _ref30.ctx;
|
|
|
var shape = _ref31.shape;
|
|
|
ctx.beginPath();
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r,
|
|
|
startAngle = shape.startAngle,
|
|
|
endAngle = shape.endAngle,
|
|
|
clockWise = shape.clockWise;
|
|
|
ctx.arc(rx, ry, r > 0 ? r : 0.001, startAngle, endAngle, !clockWise);
|
|
|
ctx.stroke();
|
|
|
ctx.closePath();
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref32) {
|
|
|
var shape = _ref32.shape,
|
|
|
style = _ref32.style;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r,
|
|
|
startAngle = shape.startAngle,
|
|
|
endAngle = shape.endAngle,
|
|
|
clockWise = shape.clockWise;
|
|
|
var lineWidth = style.lineWidth;
|
|
|
var halfLineWidth = lineWidth / 2;
|
|
|
var insideRadius = r - halfLineWidth;
|
|
|
var outsideRadius = r + halfLineWidth;
|
|
|
return !(0, _util.checkPointIsInSector)(position, rx, ry, insideRadius, startAngle, endAngle, clockWise) && (0, _util.checkPointIsInSector)(position, rx, ry, outsideRadius, startAngle, endAngle, clockWise);
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref33) {
|
|
|
var shape = _ref33.shape,
|
|
|
style = _ref33.style;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry;
|
|
|
style.graphCenter = [rx, ry];
|
|
|
},
|
|
|
move: function move(_ref34, _ref35) {
|
|
|
var movementX = _ref34.movementX,
|
|
|
movementY = _ref34.movementY;
|
|
|
var shape = _ref35.shape;
|
|
|
this.attr('shape', {
|
|
|
rx: shape.rx + movementX,
|
|
|
ry: shape.ry + movementY
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.arc = arc;
|
|
|
var sector = {
|
|
|
shape: {
|
|
|
rx: 0,
|
|
|
ry: 0,
|
|
|
r: 0,
|
|
|
startAngle: 0,
|
|
|
endAngle: 0,
|
|
|
clockWise: true
|
|
|
},
|
|
|
validator: function validator(_ref36) {
|
|
|
var shape = _ref36.shape;
|
|
|
var keys = ['rx', 'ry', 'r', 'startAngle', 'endAngle'];
|
|
|
|
|
|
if (keys.find(function (key) {
|
|
|
return typeof shape[key] !== 'number';
|
|
|
})) {
|
|
|
console.error('Sector shape configuration is abnormal!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref37, _ref38) {
|
|
|
var ctx = _ref37.ctx;
|
|
|
var shape = _ref38.shape;
|
|
|
ctx.beginPath();
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r,
|
|
|
startAngle = shape.startAngle,
|
|
|
endAngle = shape.endAngle,
|
|
|
clockWise = shape.clockWise;
|
|
|
ctx.arc(rx, ry, r > 0 ? r : 0.01, startAngle, endAngle, !clockWise);
|
|
|
ctx.lineTo(rx, ry);
|
|
|
ctx.closePath();
|
|
|
ctx.stroke();
|
|
|
ctx.fill();
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref39) {
|
|
|
var shape = _ref39.shape;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r,
|
|
|
startAngle = shape.startAngle,
|
|
|
endAngle = shape.endAngle,
|
|
|
clockWise = shape.clockWise;
|
|
|
return (0, _util.checkPointIsInSector)(position, rx, ry, r, startAngle, endAngle, clockWise);
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref40) {
|
|
|
var shape = _ref40.shape,
|
|
|
style = _ref40.style;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry;
|
|
|
style.graphCenter = [rx, ry];
|
|
|
},
|
|
|
move: function move(_ref41, _ref42) {
|
|
|
var movementX = _ref41.movementX,
|
|
|
movementY = _ref41.movementY;
|
|
|
var shape = _ref42.shape;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry;
|
|
|
this.attr('shape', {
|
|
|
rx: rx + movementX,
|
|
|
ry: ry + movementY
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.sector = sector;
|
|
|
var regPolygon = {
|
|
|
shape: {
|
|
|
rx: 0,
|
|
|
ry: 0,
|
|
|
r: 0,
|
|
|
side: 0
|
|
|
},
|
|
|
validator: function validator(_ref43) {
|
|
|
var shape = _ref43.shape;
|
|
|
var side = shape.side;
|
|
|
var keys = ['rx', 'ry', 'r', 'side'];
|
|
|
|
|
|
if (keys.find(function (key) {
|
|
|
return typeof shape[key] !== 'number';
|
|
|
})) {
|
|
|
console.error('RegPolygon shape configuration is abnormal!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (side < 3) {
|
|
|
console.error('RegPolygon at least trigon!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref44, _ref45) {
|
|
|
var ctx = _ref44.ctx;
|
|
|
var shape = _ref45.shape,
|
|
|
cache = _ref45.cache;
|
|
|
ctx.beginPath();
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry,
|
|
|
r = shape.r,
|
|
|
side = shape.side;
|
|
|
|
|
|
if (!cache.points || cache.rx !== rx || cache.ry !== ry || cache.r !== r || cache.side !== side) {
|
|
|
var _points = (0, _util.getRegularPolygonPoints)(rx, ry, r, side);
|
|
|
|
|
|
Object.assign(cache, {
|
|
|
points: _points,
|
|
|
rx: rx,
|
|
|
ry: ry,
|
|
|
r: r,
|
|
|
side: side
|
|
|
});
|
|
|
}
|
|
|
|
|
|
var points = cache.points;
|
|
|
(0, _canvas.drawPolylinePath)(ctx, points);
|
|
|
ctx.closePath();
|
|
|
ctx.stroke();
|
|
|
ctx.fill();
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref46) {
|
|
|
var cache = _ref46.cache;
|
|
|
var points = cache.points;
|
|
|
return (0, _util.checkPointIsInPolygon)(position, points);
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref47) {
|
|
|
var shape = _ref47.shape,
|
|
|
style = _ref47.style;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry;
|
|
|
style.graphCenter = [rx, ry];
|
|
|
},
|
|
|
move: function move(_ref48, _ref49) {
|
|
|
var movementX = _ref48.movementX,
|
|
|
movementY = _ref48.movementY;
|
|
|
var shape = _ref49.shape,
|
|
|
cache = _ref49.cache;
|
|
|
var rx = shape.rx,
|
|
|
ry = shape.ry;
|
|
|
cache.rx += movementX;
|
|
|
cache.ry += movementY;
|
|
|
this.attr('shape', {
|
|
|
rx: rx + movementX,
|
|
|
ry: ry + movementY
|
|
|
});
|
|
|
cache.points = cache.points.map(function (_ref50) {
|
|
|
var _ref51 = (0, _slicedToArray2["default"])(_ref50, 2),
|
|
|
x = _ref51[0],
|
|
|
y = _ref51[1];
|
|
|
|
|
|
return [x + movementX, y + movementY];
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.regPolygon = regPolygon;
|
|
|
var polyline = {
|
|
|
shape: {
|
|
|
points: [],
|
|
|
close: false
|
|
|
},
|
|
|
validator: function validator(_ref52) {
|
|
|
var shape = _ref52.shape;
|
|
|
var points = shape.points;
|
|
|
|
|
|
if (!(points instanceof Array)) {
|
|
|
console.error('Polyline points should be an array!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref53, _ref54) {
|
|
|
var ctx = _ref53.ctx;
|
|
|
var shape = _ref54.shape,
|
|
|
lineWidth = _ref54.style.lineWidth;
|
|
|
ctx.beginPath();
|
|
|
var points = shape.points,
|
|
|
close = shape.close;
|
|
|
if (lineWidth === 1) points = (0, _util.eliminateBlur)(points);
|
|
|
(0, _canvas.drawPolylinePath)(ctx, points);
|
|
|
|
|
|
if (close) {
|
|
|
ctx.closePath();
|
|
|
ctx.fill();
|
|
|
ctx.stroke();
|
|
|
} else {
|
|
|
ctx.stroke();
|
|
|
}
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref55) {
|
|
|
var shape = _ref55.shape,
|
|
|
style = _ref55.style;
|
|
|
var points = shape.points,
|
|
|
close = shape.close;
|
|
|
var lineWidth = style.lineWidth;
|
|
|
|
|
|
if (close) {
|
|
|
return (0, _util.checkPointIsInPolygon)(position, points);
|
|
|
} else {
|
|
|
return (0, _util.checkPointIsNearPolyline)(position, points, lineWidth);
|
|
|
}
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref56) {
|
|
|
var shape = _ref56.shape,
|
|
|
style = _ref56.style;
|
|
|
var points = shape.points;
|
|
|
style.graphCenter = points[0];
|
|
|
},
|
|
|
move: function move(_ref57, _ref58) {
|
|
|
var movementX = _ref57.movementX,
|
|
|
movementY = _ref57.movementY;
|
|
|
var shape = _ref58.shape;
|
|
|
var points = shape.points;
|
|
|
var moveAfterPoints = points.map(function (_ref59) {
|
|
|
var _ref60 = (0, _slicedToArray2["default"])(_ref59, 2),
|
|
|
x = _ref60[0],
|
|
|
y = _ref60[1];
|
|
|
|
|
|
return [x + movementX, y + movementY];
|
|
|
});
|
|
|
this.attr('shape', {
|
|
|
points: moveAfterPoints
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.polyline = polyline;
|
|
|
var smoothline = {
|
|
|
shape: {
|
|
|
points: [],
|
|
|
close: false
|
|
|
},
|
|
|
validator: function validator(_ref61) {
|
|
|
var shape = _ref61.shape;
|
|
|
var points = shape.points;
|
|
|
|
|
|
if (!(points instanceof Array)) {
|
|
|
console.error('Smoothline points should be an array!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref62, _ref63) {
|
|
|
var ctx = _ref62.ctx;
|
|
|
var shape = _ref63.shape,
|
|
|
cache = _ref63.cache;
|
|
|
var points = shape.points,
|
|
|
close = shape.close;
|
|
|
|
|
|
if (!cache.points || cache.points.toString() !== points.toString()) {
|
|
|
var _bezierCurve = polylineToBezierCurve(points, close);
|
|
|
|
|
|
var hoverPoints = bezierCurveToPolyline(_bezierCurve);
|
|
|
Object.assign(cache, {
|
|
|
points: (0, _util.deepClone)(points, true),
|
|
|
bezierCurve: _bezierCurve,
|
|
|
hoverPoints: hoverPoints
|
|
|
});
|
|
|
}
|
|
|
|
|
|
var bezierCurve = cache.bezierCurve;
|
|
|
ctx.beginPath();
|
|
|
(0, _canvas.drawBezierCurvePath)(ctx, bezierCurve.slice(1), bezierCurve[0]);
|
|
|
|
|
|
if (close) {
|
|
|
ctx.closePath();
|
|
|
ctx.fill();
|
|
|
ctx.stroke();
|
|
|
} else {
|
|
|
ctx.stroke();
|
|
|
}
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref64) {
|
|
|
var cache = _ref64.cache,
|
|
|
shape = _ref64.shape,
|
|
|
style = _ref64.style;
|
|
|
var hoverPoints = cache.hoverPoints;
|
|
|
var close = shape.close;
|
|
|
var lineWidth = style.lineWidth;
|
|
|
|
|
|
if (close) {
|
|
|
return (0, _util.checkPointIsInPolygon)(position, hoverPoints);
|
|
|
} else {
|
|
|
return (0, _util.checkPointIsNearPolyline)(position, hoverPoints, lineWidth);
|
|
|
}
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref65) {
|
|
|
var shape = _ref65.shape,
|
|
|
style = _ref65.style;
|
|
|
var points = shape.points;
|
|
|
style.graphCenter = points[0];
|
|
|
},
|
|
|
move: function move(_ref66, _ref67) {
|
|
|
var movementX = _ref66.movementX,
|
|
|
movementY = _ref66.movementY;
|
|
|
var shape = _ref67.shape,
|
|
|
cache = _ref67.cache;
|
|
|
var points = shape.points;
|
|
|
var moveAfterPoints = points.map(function (_ref68) {
|
|
|
var _ref69 = (0, _slicedToArray2["default"])(_ref68, 2),
|
|
|
x = _ref69[0],
|
|
|
y = _ref69[1];
|
|
|
|
|
|
return [x + movementX, y + movementY];
|
|
|
});
|
|
|
cache.points = moveAfterPoints;
|
|
|
|
|
|
var _cache$bezierCurve$ = (0, _slicedToArray2["default"])(cache.bezierCurve[0], 2),
|
|
|
fx = _cache$bezierCurve$[0],
|
|
|
fy = _cache$bezierCurve$[1];
|
|
|
|
|
|
var curves = cache.bezierCurve.slice(1);
|
|
|
cache.bezierCurve = [[fx + movementX, fy + movementY]].concat((0, _toConsumableArray2["default"])(curves.map(function (curve) {
|
|
|
return curve.map(function (_ref70) {
|
|
|
var _ref71 = (0, _slicedToArray2["default"])(_ref70, 2),
|
|
|
x = _ref71[0],
|
|
|
y = _ref71[1];
|
|
|
|
|
|
return [x + movementX, y + movementY];
|
|
|
});
|
|
|
})));
|
|
|
cache.hoverPoints = cache.hoverPoints.map(function (_ref72) {
|
|
|
var _ref73 = (0, _slicedToArray2["default"])(_ref72, 2),
|
|
|
x = _ref73[0],
|
|
|
y = _ref73[1];
|
|
|
|
|
|
return [x + movementX, y + movementY];
|
|
|
});
|
|
|
this.attr('shape', {
|
|
|
points: moveAfterPoints
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.smoothline = smoothline;
|
|
|
var bezierCurve = {
|
|
|
shape: {
|
|
|
points: [],
|
|
|
close: false
|
|
|
},
|
|
|
validator: function validator(_ref74) {
|
|
|
var shape = _ref74.shape;
|
|
|
var points = shape.points;
|
|
|
|
|
|
if (!(points instanceof Array)) {
|
|
|
console.error('BezierCurve points should be an array!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref75, _ref76) {
|
|
|
var ctx = _ref75.ctx;
|
|
|
var shape = _ref76.shape,
|
|
|
cache = _ref76.cache;
|
|
|
var points = shape.points,
|
|
|
close = shape.close;
|
|
|
|
|
|
if (!cache.points || cache.points.toString() !== points.toString()) {
|
|
|
var hoverPoints = bezierCurveToPolyline(points, 20);
|
|
|
Object.assign(cache, {
|
|
|
points: (0, _util.deepClone)(points, true),
|
|
|
hoverPoints: hoverPoints
|
|
|
});
|
|
|
}
|
|
|
|
|
|
ctx.beginPath();
|
|
|
(0, _canvas.drawBezierCurvePath)(ctx, points.slice(1), points[0]);
|
|
|
|
|
|
if (close) {
|
|
|
ctx.closePath();
|
|
|
ctx.fill();
|
|
|
ctx.stroke();
|
|
|
} else {
|
|
|
ctx.stroke();
|
|
|
}
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref77) {
|
|
|
var cache = _ref77.cache,
|
|
|
shape = _ref77.shape,
|
|
|
style = _ref77.style;
|
|
|
var hoverPoints = cache.hoverPoints;
|
|
|
var close = shape.close;
|
|
|
var lineWidth = style.lineWidth;
|
|
|
|
|
|
if (close) {
|
|
|
return (0, _util.checkPointIsInPolygon)(position, hoverPoints);
|
|
|
} else {
|
|
|
return (0, _util.checkPointIsNearPolyline)(position, hoverPoints, lineWidth);
|
|
|
}
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref78) {
|
|
|
var shape = _ref78.shape,
|
|
|
style = _ref78.style;
|
|
|
var points = shape.points;
|
|
|
style.graphCenter = points[0];
|
|
|
},
|
|
|
move: function move(_ref79, _ref80) {
|
|
|
var movementX = _ref79.movementX,
|
|
|
movementY = _ref79.movementY;
|
|
|
var shape = _ref80.shape,
|
|
|
cache = _ref80.cache;
|
|
|
var points = shape.points;
|
|
|
|
|
|
var _points$ = (0, _slicedToArray2["default"])(points[0], 2),
|
|
|
fx = _points$[0],
|
|
|
fy = _points$[1];
|
|
|
|
|
|
var curves = points.slice(1);
|
|
|
var bezierCurve = [[fx + movementX, fy + movementY]].concat((0, _toConsumableArray2["default"])(curves.map(function (curve) {
|
|
|
return curve.map(function (_ref81) {
|
|
|
var _ref82 = (0, _slicedToArray2["default"])(_ref81, 2),
|
|
|
x = _ref82[0],
|
|
|
y = _ref82[1];
|
|
|
|
|
|
return [x + movementX, y + movementY];
|
|
|
});
|
|
|
})));
|
|
|
cache.points = bezierCurve;
|
|
|
cache.hoverPoints = cache.hoverPoints.map(function (_ref83) {
|
|
|
var _ref84 = (0, _slicedToArray2["default"])(_ref83, 2),
|
|
|
x = _ref84[0],
|
|
|
y = _ref84[1];
|
|
|
|
|
|
return [x + movementX, y + movementY];
|
|
|
});
|
|
|
this.attr('shape', {
|
|
|
points: bezierCurve
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.bezierCurve = bezierCurve;
|
|
|
var text = {
|
|
|
shape: {
|
|
|
content: '',
|
|
|
position: [],
|
|
|
maxWidth: undefined,
|
|
|
rowGap: 0
|
|
|
},
|
|
|
validator: function validator(_ref85) {
|
|
|
var shape = _ref85.shape;
|
|
|
var content = shape.content,
|
|
|
position = shape.position,
|
|
|
rowGap = shape.rowGap;
|
|
|
|
|
|
if (typeof content !== 'string') {
|
|
|
console.error('Text content should be a string!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (!(position instanceof Array)) {
|
|
|
console.error('Text position should be an array!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (typeof rowGap !== 'number') {
|
|
|
console.error('Text rowGap should be a number!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
},
|
|
|
draw: function draw(_ref86, _ref87) {
|
|
|
var ctx = _ref86.ctx;
|
|
|
var shape = _ref87.shape;
|
|
|
var content = shape.content,
|
|
|
position = shape.position,
|
|
|
maxWidth = shape.maxWidth,
|
|
|
rowGap = shape.rowGap;
|
|
|
var textBaseline = ctx.textBaseline,
|
|
|
font = ctx.font;
|
|
|
var fontSize = parseInt(font.replace(/\D/g, ''));
|
|
|
|
|
|
var _position = position,
|
|
|
_position2 = (0, _slicedToArray2["default"])(_position, 2),
|
|
|
x = _position2[0],
|
|
|
y = _position2[1];
|
|
|
|
|
|
content = content.split('\n');
|
|
|
var rowNum = content.length;
|
|
|
var lineHeight = fontSize + rowGap;
|
|
|
var allHeight = rowNum * lineHeight - rowGap;
|
|
|
var offset = 0;
|
|
|
|
|
|
if (textBaseline === 'middle') {
|
|
|
offset = allHeight / 2;
|
|
|
y += fontSize / 2;
|
|
|
}
|
|
|
|
|
|
if (textBaseline === 'bottom') {
|
|
|
offset = allHeight;
|
|
|
y += fontSize;
|
|
|
}
|
|
|
|
|
|
position = new Array(rowNum).fill(0).map(function (foo, i) {
|
|
|
return [x, y + i * lineHeight - offset];
|
|
|
});
|
|
|
ctx.beginPath();
|
|
|
content.forEach(function (text, i) {
|
|
|
ctx.fillText.apply(ctx, [text].concat((0, _toConsumableArray2["default"])(position[i]), [maxWidth]));
|
|
|
ctx.strokeText.apply(ctx, [text].concat((0, _toConsumableArray2["default"])(position[i]), [maxWidth]));
|
|
|
});
|
|
|
ctx.closePath();
|
|
|
},
|
|
|
hoverCheck: function hoverCheck(position, _ref88) {
|
|
|
var shape = _ref88.shape,
|
|
|
style = _ref88.style;
|
|
|
return false;
|
|
|
},
|
|
|
setGraphCenter: function setGraphCenter(e, _ref89) {
|
|
|
var shape = _ref89.shape,
|
|
|
style = _ref89.style;
|
|
|
var position = shape.position;
|
|
|
style.graphCenter = (0, _toConsumableArray2["default"])(position);
|
|
|
},
|
|
|
move: function move(_ref90, _ref91) {
|
|
|
var movementX = _ref90.movementX,
|
|
|
movementY = _ref90.movementY;
|
|
|
var shape = _ref91.shape;
|
|
|
|
|
|
var _shape$position = (0, _slicedToArray2["default"])(shape.position, 2),
|
|
|
x = _shape$position[0],
|
|
|
y = _shape$position[1];
|
|
|
|
|
|
this.attr('shape', {
|
|
|
position: [x + movementX, y + movementY]
|
|
|
});
|
|
|
}
|
|
|
};
|
|
|
exports.text = text;
|
|
|
var graphs = new Map([['circle', circle], ['ellipse', ellipse], ['rect', rect], ['ring', ring], ['arc', arc], ['sector', sector], ['regPolygon', regPolygon], ['polyline', polyline], ['smoothline', smoothline], ['bezierCurve', bezierCurve], ['text', text]]);
|
|
|
var _default = graphs;
|
|
|
/**
|
|
|
* @description Extend new graph
|
|
|
* @param {String} name Name of Graph
|
|
|
* @param {Object} config Configuration of Graph
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
exports["default"] = _default;
|
|
|
|
|
|
function extendNewGraph(name, config) {
|
|
|
if (!name || !config) {
|
|
|
console.error('ExtendNewGraph Missing Parameters!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (!config.shape) {
|
|
|
console.error('Required attribute of shape to extendNewGraph!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (!config.validator) {
|
|
|
console.error('Required function of validator to extendNewGraph!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (!config.draw) {
|
|
|
console.error('Required function of draw to extendNewGraph!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
graphs.set(name, config);
|
|
|
}
|
|
|
},{"../plugin/canvas":7,"../plugin/util":8,"@babel/runtime/helpers/interopRequireDefault":14,"@babel/runtime/helpers/slicedToArray":19,"@babel/runtime/helpers/toConsumableArray":20,"@jiaminghi/bezier-curve":25}],6:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
Object.defineProperty(exports, "CRender", {
|
|
|
enumerable: true,
|
|
|
get: function get() {
|
|
|
return _crender["default"];
|
|
|
}
|
|
|
});
|
|
|
Object.defineProperty(exports, "extendNewGraph", {
|
|
|
enumerable: true,
|
|
|
get: function get() {
|
|
|
return _graphs.extendNewGraph;
|
|
|
}
|
|
|
});
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _crender = _interopRequireDefault(require("./class/crender.class"));
|
|
|
|
|
|
var _graphs = require("./config/graphs");
|
|
|
|
|
|
var _default = _crender["default"];
|
|
|
exports["default"] = _default;
|
|
|
},{"./class/crender.class":2,"./config/graphs":5,"@babel/runtime/helpers/interopRequireDefault":14}],7:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports.drawPolylinePath = drawPolylinePath;
|
|
|
exports.drawBezierCurvePath = drawBezierCurvePath;
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
|
|
|
|
/**
|
|
|
* @description Draw a polyline path
|
|
|
* @param {Object} ctx Canvas 2d context
|
|
|
* @param {Array} points The points that makes up a polyline
|
|
|
* @param {Boolean} beginPath Whether to execute beginPath
|
|
|
* @param {Boolean} closePath Whether to execute closePath
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
function drawPolylinePath(ctx, points) {
|
|
|
var beginPath = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
|
var closePath = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
|
|
if (!ctx || points.length < 2) return false;
|
|
|
if (beginPath) ctx.beginPath();
|
|
|
points.forEach(function (point, i) {
|
|
|
return point && (i === 0 ? ctx.moveTo.apply(ctx, (0, _toConsumableArray2["default"])(point)) : ctx.lineTo.apply(ctx, (0, _toConsumableArray2["default"])(point)));
|
|
|
});
|
|
|
if (closePath) ctx.closePath();
|
|
|
}
|
|
|
/**
|
|
|
* @description Draw a bezier curve path
|
|
|
* @param {Object} ctx Canvas 2d context
|
|
|
* @param {Array} points The points that makes up a bezier curve
|
|
|
* @param {Array} moveTo The point need to excute moveTo
|
|
|
* @param {Boolean} beginPath Whether to execute beginPath
|
|
|
* @param {Boolean} closePath Whether to execute closePath
|
|
|
* @return {Undefined} Void
|
|
|
*/
|
|
|
|
|
|
|
|
|
function drawBezierCurvePath(ctx, points) {
|
|
|
var moveTo = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
|
var beginPath = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
|
|
var closePath = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
|
|
|
if (!ctx || !points) return false;
|
|
|
if (beginPath) ctx.beginPath();
|
|
|
if (moveTo) ctx.moveTo.apply(ctx, (0, _toConsumableArray2["default"])(moveTo));
|
|
|
points.forEach(function (item) {
|
|
|
return item && ctx.bezierCurveTo.apply(ctx, (0, _toConsumableArray2["default"])(item[0]).concat((0, _toConsumableArray2["default"])(item[1]), (0, _toConsumableArray2["default"])(item[2])));
|
|
|
});
|
|
|
if (closePath) ctx.closePath();
|
|
|
}
|
|
|
|
|
|
var _default = {
|
|
|
drawPolylinePath: drawPolylinePath,
|
|
|
drawBezierCurvePath: drawBezierCurvePath
|
|
|
};
|
|
|
exports["default"] = _default;
|
|
|
},{"@babel/runtime/helpers/interopRequireDefault":14,"@babel/runtime/helpers/toConsumableArray":20}],8:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports.deepClone = deepClone;
|
|
|
exports.eliminateBlur = eliminateBlur;
|
|
|
exports.checkPointIsInCircle = checkPointIsInCircle;
|
|
|
exports.getTwoPointDistance = getTwoPointDistance;
|
|
|
exports.checkPointIsInPolygon = checkPointIsInPolygon;
|
|
|
exports.checkPointIsInSector = checkPointIsInSector;
|
|
|
exports.checkPointIsNearPolyline = checkPointIsNearPolyline;
|
|
|
exports.checkPointIsInRect = checkPointIsInRect;
|
|
|
exports.getRotatePointPos = getRotatePointPos;
|
|
|
exports.getScalePointPos = getScalePointPos;
|
|
|
exports.getTranslatePointPos = getTranslatePointPos;
|
|
|
exports.getDistanceBetweenPointAndLine = getDistanceBetweenPointAndLine;
|
|
|
exports.getCircleRadianPoint = getCircleRadianPoint;
|
|
|
exports.getRegularPolygonPoints = getRegularPolygonPoints;
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
|
|
|
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
|
|
|
|
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
|
|
|
|
var abs = Math.abs,
|
|
|
sqrt = Math.sqrt,
|
|
|
sin = Math.sin,
|
|
|
cos = Math.cos,
|
|
|
max = Math.max,
|
|
|
min = Math.min,
|
|
|
PI = Math.PI;
|
|
|
/**
|
|
|
* @description Clone an object or array
|
|
|
* @param {Object|Array} object Cloned object
|
|
|
* @param {Boolean} recursion Whether to use recursive cloning
|
|
|
* @return {Object|Array} Clone object
|
|
|
*/
|
|
|
|
|
|
function deepClone(object) {
|
|
|
var recursion = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
|
if (!object) return object;
|
|
|
var parse = JSON.parse,
|
|
|
stringify = JSON.stringify;
|
|
|
if (!recursion) return parse(stringify(object));
|
|
|
var clonedObj = object instanceof Array ? [] : {};
|
|
|
|
|
|
if (object && (0, _typeof2["default"])(object) === 'object') {
|
|
|
for (var key in object) {
|
|
|
if (object.hasOwnProperty(key)) {
|
|
|
if (object[key] && (0, _typeof2["default"])(object[key]) === 'object') {
|
|
|
clonedObj[key] = deepClone(object[key], true);
|
|
|
} else {
|
|
|
clonedObj[key] = object[key];
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
return clonedObj;
|
|
|
}
|
|
|
/**
|
|
|
* @description Eliminate line blur due to 1px line width
|
|
|
* @param {Array} points Line points
|
|
|
* @return {Array} Line points after processed
|
|
|
*/
|
|
|
|
|
|
|
|
|
function eliminateBlur(points) {
|
|
|
return points.map(function (_ref) {
|
|
|
var _ref2 = (0, _slicedToArray2["default"])(_ref, 2),
|
|
|
x = _ref2[0],
|
|
|
y = _ref2[1];
|
|
|
|
|
|
return [parseInt(x) + 0.5, parseInt(y) + 0.5];
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Check if the point is inside the circle
|
|
|
* @param {Array} point Postion of point
|
|
|
* @param {Number} rx Circle x coordinate
|
|
|
* @param {Number} ry Circle y coordinate
|
|
|
* @param {Number} r Circle radius
|
|
|
* @return {Boolean} Result of check
|
|
|
*/
|
|
|
|
|
|
|
|
|
function checkPointIsInCircle(point, rx, ry, r) {
|
|
|
return getTwoPointDistance(point, [rx, ry]) <= r;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the distance between two points
|
|
|
* @param {Array} point1 point1
|
|
|
* @param {Array} point2 point2
|
|
|
* @return {Number} Distance between two points
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getTwoPointDistance(_ref3, _ref4) {
|
|
|
var _ref5 = (0, _slicedToArray2["default"])(_ref3, 2),
|
|
|
xa = _ref5[0],
|
|
|
ya = _ref5[1];
|
|
|
|
|
|
var _ref6 = (0, _slicedToArray2["default"])(_ref4, 2),
|
|
|
xb = _ref6[0],
|
|
|
yb = _ref6[1];
|
|
|
|
|
|
var minusX = abs(xa - xb);
|
|
|
var minusY = abs(ya - yb);
|
|
|
return sqrt(minusX * minusX + minusY * minusY);
|
|
|
}
|
|
|
/**
|
|
|
* @description Check if the point is inside the polygon
|
|
|
* @param {Array} point Postion of point
|
|
|
* @param {Array} points The points that makes up a polyline
|
|
|
* @return {Boolean} Result of check
|
|
|
*/
|
|
|
|
|
|
|
|
|
function checkPointIsInPolygon(point, polygon) {
|
|
|
var counter = 0;
|
|
|
|
|
|
var _point = (0, _slicedToArray2["default"])(point, 2),
|
|
|
x = _point[0],
|
|
|
y = _point[1];
|
|
|
|
|
|
var pointNum = polygon.length;
|
|
|
|
|
|
for (var i = 1, p1 = polygon[0]; i <= pointNum; i++) {
|
|
|
var p2 = polygon[i % pointNum];
|
|
|
|
|
|
if (x > min(p1[0], p2[0]) && x <= max(p1[0], p2[0])) {
|
|
|
if (y <= max(p1[1], p2[1])) {
|
|
|
if (p1[0] !== p2[0]) {
|
|
|
var xinters = (x - p1[0]) * (p2[1] - p1[1]) / (p2[0] - p1[0]) + p1[1];
|
|
|
|
|
|
if (p1[1] === p2[1] || y <= xinters) {
|
|
|
counter++;
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
p1 = p2;
|
|
|
}
|
|
|
|
|
|
return counter % 2 === 1;
|
|
|
}
|
|
|
/**
|
|
|
* @description Check if the point is inside the sector
|
|
|
* @param {Array} point Postion of point
|
|
|
* @param {Number} rx Sector x coordinate
|
|
|
* @param {Number} ry Sector y coordinate
|
|
|
* @param {Number} r Sector radius
|
|
|
* @param {Number} startAngle Sector start angle
|
|
|
* @param {Number} endAngle Sector end angle
|
|
|
* @param {Boolean} clockWise Whether the sector angle is clockwise
|
|
|
* @return {Boolean} Result of check
|
|
|
*/
|
|
|
|
|
|
|
|
|
function checkPointIsInSector(point, rx, ry, r, startAngle, endAngle, clockWise) {
|
|
|
if (!point) return false;
|
|
|
if (getTwoPointDistance(point, [rx, ry]) > r) return false;
|
|
|
|
|
|
if (!clockWise) {
|
|
|
var _deepClone = deepClone([endAngle, startAngle]);
|
|
|
|
|
|
var _deepClone2 = (0, _slicedToArray2["default"])(_deepClone, 2);
|
|
|
|
|
|
startAngle = _deepClone2[0];
|
|
|
endAngle = _deepClone2[1];
|
|
|
}
|
|
|
|
|
|
var reverseBE = startAngle > endAngle;
|
|
|
|
|
|
if (reverseBE) {
|
|
|
var _ref7 = [endAngle, startAngle];
|
|
|
startAngle = _ref7[0];
|
|
|
endAngle = _ref7[1];
|
|
|
}
|
|
|
|
|
|
var minus = endAngle - startAngle;
|
|
|
if (minus >= PI * 2) return true;
|
|
|
|
|
|
var _point2 = (0, _slicedToArray2["default"])(point, 2),
|
|
|
x = _point2[0],
|
|
|
y = _point2[1];
|
|
|
|
|
|
var _getCircleRadianPoint = getCircleRadianPoint(rx, ry, r, startAngle),
|
|
|
_getCircleRadianPoint2 = (0, _slicedToArray2["default"])(_getCircleRadianPoint, 2),
|
|
|
bx = _getCircleRadianPoint2[0],
|
|
|
by = _getCircleRadianPoint2[1];
|
|
|
|
|
|
var _getCircleRadianPoint3 = getCircleRadianPoint(rx, ry, r, endAngle),
|
|
|
_getCircleRadianPoint4 = (0, _slicedToArray2["default"])(_getCircleRadianPoint3, 2),
|
|
|
ex = _getCircleRadianPoint4[0],
|
|
|
ey = _getCircleRadianPoint4[1];
|
|
|
|
|
|
var vPoint = [x - rx, y - ry];
|
|
|
var vBArm = [bx - rx, by - ry];
|
|
|
var vEArm = [ex - rx, ey - ry];
|
|
|
var reverse = minus > PI;
|
|
|
|
|
|
if (reverse) {
|
|
|
var _deepClone3 = deepClone([vEArm, vBArm]);
|
|
|
|
|
|
var _deepClone4 = (0, _slicedToArray2["default"])(_deepClone3, 2);
|
|
|
|
|
|
vBArm = _deepClone4[0];
|
|
|
vEArm = _deepClone4[1];
|
|
|
}
|
|
|
|
|
|
var inSector = isClockWise(vBArm, vPoint) && !isClockWise(vEArm, vPoint);
|
|
|
if (reverse) inSector = !inSector;
|
|
|
if (reverseBE) inSector = !inSector;
|
|
|
return inSector;
|
|
|
}
|
|
|
/**
|
|
|
* @description Determine if the point is in the clockwise direction of the vector
|
|
|
* @param {Array} vArm Vector
|
|
|
* @param {Array} vPoint Point
|
|
|
* @return {Boolean} Result of check
|
|
|
*/
|
|
|
|
|
|
|
|
|
function isClockWise(vArm, vPoint) {
|
|
|
var _vArm = (0, _slicedToArray2["default"])(vArm, 2),
|
|
|
ax = _vArm[0],
|
|
|
ay = _vArm[1];
|
|
|
|
|
|
var _vPoint = (0, _slicedToArray2["default"])(vPoint, 2),
|
|
|
px = _vPoint[0],
|
|
|
py = _vPoint[1];
|
|
|
|
|
|
return -ay * px + ax * py > 0;
|
|
|
}
|
|
|
/**
|
|
|
* @description Check if the point is inside the polyline
|
|
|
* @param {Array} point Postion of point
|
|
|
* @param {Array} polyline The points that makes up a polyline
|
|
|
* @param {Number} lineWidth Polyline linewidth
|
|
|
* @return {Boolean} Result of check
|
|
|
*/
|
|
|
|
|
|
|
|
|
function checkPointIsNearPolyline(point, polyline, lineWidth) {
|
|
|
var halfLineWidth = lineWidth / 2;
|
|
|
var moveUpPolyline = polyline.map(function (_ref8) {
|
|
|
var _ref9 = (0, _slicedToArray2["default"])(_ref8, 2),
|
|
|
x = _ref9[0],
|
|
|
y = _ref9[1];
|
|
|
|
|
|
return [x, y - halfLineWidth];
|
|
|
});
|
|
|
var moveDownPolyline = polyline.map(function (_ref10) {
|
|
|
var _ref11 = (0, _slicedToArray2["default"])(_ref10, 2),
|
|
|
x = _ref11[0],
|
|
|
y = _ref11[1];
|
|
|
|
|
|
return [x, y + halfLineWidth];
|
|
|
});
|
|
|
var polygon = [].concat((0, _toConsumableArray2["default"])(moveUpPolyline), (0, _toConsumableArray2["default"])(moveDownPolyline.reverse()));
|
|
|
return checkPointIsInPolygon(point, polygon);
|
|
|
}
|
|
|
/**
|
|
|
* @description Check if the point is inside the rect
|
|
|
* @param {Array} point Postion of point
|
|
|
* @param {Number} x Rect start x coordinate
|
|
|
* @param {Number} y Rect start y coordinate
|
|
|
* @param {Number} width Rect width
|
|
|
* @param {Number} height Rect height
|
|
|
* @return {Boolean} Result of check
|
|
|
*/
|
|
|
|
|
|
|
|
|
function checkPointIsInRect(_ref12, x, y, width, height) {
|
|
|
var _ref13 = (0, _slicedToArray2["default"])(_ref12, 2),
|
|
|
px = _ref13[0],
|
|
|
py = _ref13[1];
|
|
|
|
|
|
if (px < x) return false;
|
|
|
if (py < y) return false;
|
|
|
if (px > x + width) return false;
|
|
|
if (py > y + height) return false;
|
|
|
return true;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the coordinates of the rotated point
|
|
|
* @param {Number} rotate Degree of rotation
|
|
|
* @param {Array} point Postion of point
|
|
|
* @param {Array} origin Rotation center
|
|
|
* @param {Array} origin Rotation center
|
|
|
* @return {Number} Coordinates after rotation
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getRotatePointPos() {
|
|
|
var rotate = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
|
|
|
var point = arguments.length > 1 ? arguments[1] : undefined;
|
|
|
var origin = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [0, 0];
|
|
|
if (!point) return false;
|
|
|
if (rotate % 360 === 0) return point;
|
|
|
|
|
|
var _point3 = (0, _slicedToArray2["default"])(point, 2),
|
|
|
x = _point3[0],
|
|
|
y = _point3[1];
|
|
|
|
|
|
var _origin = (0, _slicedToArray2["default"])(origin, 2),
|
|
|
ox = _origin[0],
|
|
|
oy = _origin[1];
|
|
|
|
|
|
rotate *= PI / 180;
|
|
|
return [(x - ox) * cos(rotate) - (y - oy) * sin(rotate) + ox, (x - ox) * sin(rotate) + (y - oy) * cos(rotate) + oy];
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the coordinates of the scaled point
|
|
|
* @param {Array} scale Scale factor
|
|
|
* @param {Array} point Postion of point
|
|
|
* @param {Array} origin Scale center
|
|
|
* @return {Number} Coordinates after scale
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getScalePointPos() {
|
|
|
var scale = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [1, 1];
|
|
|
var point = arguments.length > 1 ? arguments[1] : undefined;
|
|
|
var origin = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [0, 0];
|
|
|
if (!point) return false;
|
|
|
if (scale === 1) return point;
|
|
|
|
|
|
var _point4 = (0, _slicedToArray2["default"])(point, 2),
|
|
|
x = _point4[0],
|
|
|
y = _point4[1];
|
|
|
|
|
|
var _origin2 = (0, _slicedToArray2["default"])(origin, 2),
|
|
|
ox = _origin2[0],
|
|
|
oy = _origin2[1];
|
|
|
|
|
|
var _scale = (0, _slicedToArray2["default"])(scale, 2),
|
|
|
xs = _scale[0],
|
|
|
ys = _scale[1];
|
|
|
|
|
|
var relativePosX = x - ox;
|
|
|
var relativePosY = y - oy;
|
|
|
return [relativePosX * xs + ox, relativePosY * ys + oy];
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the coordinates of the scaled point
|
|
|
* @param {Array} translate Translation distance
|
|
|
* @param {Array} point Postion of point
|
|
|
* @return {Number} Coordinates after translation
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getTranslatePointPos(translate, point) {
|
|
|
if (!translate || !point) return false;
|
|
|
|
|
|
var _point5 = (0, _slicedToArray2["default"])(point, 2),
|
|
|
x = _point5[0],
|
|
|
y = _point5[1];
|
|
|
|
|
|
var _translate = (0, _slicedToArray2["default"])(translate, 2),
|
|
|
tx = _translate[0],
|
|
|
ty = _translate[1];
|
|
|
|
|
|
return [x + tx, y + ty];
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the distance from the point to the line
|
|
|
* @param {Array} point Postion of point
|
|
|
* @param {Array} lineBegin Line start position
|
|
|
* @param {Array} lineEnd Line end position
|
|
|
* @return {Number} Distance between point and line
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getDistanceBetweenPointAndLine(point, lineBegin, lineEnd) {
|
|
|
if (!point || !lineBegin || !lineEnd) return false;
|
|
|
|
|
|
var _point6 = (0, _slicedToArray2["default"])(point, 2),
|
|
|
x = _point6[0],
|
|
|
y = _point6[1];
|
|
|
|
|
|
var _lineBegin = (0, _slicedToArray2["default"])(lineBegin, 2),
|
|
|
x1 = _lineBegin[0],
|
|
|
y1 = _lineBegin[1];
|
|
|
|
|
|
var _lineEnd = (0, _slicedToArray2["default"])(lineEnd, 2),
|
|
|
x2 = _lineEnd[0],
|
|
|
y2 = _lineEnd[1];
|
|
|
|
|
|
var a = y2 - y1;
|
|
|
var b = x1 - x2;
|
|
|
var c = y1 * (x2 - x1) - x1 * (y2 - y1);
|
|
|
var molecule = abs(a * x + b * y + c);
|
|
|
var denominator = sqrt(a * a + b * b);
|
|
|
return molecule / denominator;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the coordinates of the specified radian on the circle
|
|
|
* @param {Number} x Circle x coordinate
|
|
|
* @param {Number} y Circle y coordinate
|
|
|
* @param {Number} radius Circle radius
|
|
|
* @param {Number} radian Specfied radian
|
|
|
* @return {Array} Postion of point
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getCircleRadianPoint(x, y, radius, radian) {
|
|
|
return [x + cos(radian) * radius, y + sin(radian) * radius];
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the points that make up a regular polygon
|
|
|
* @param {Number} x X coordinate of the polygon inscribed circle
|
|
|
* @param {Number} y Y coordinate of the polygon inscribed circle
|
|
|
* @param {Number} r Radius of the polygon inscribed circle
|
|
|
* @param {Number} side Side number
|
|
|
* @param {Number} minus Radian offset
|
|
|
* @return {Array} Points that make up a regular polygon
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getRegularPolygonPoints(rx, ry, r, side) {
|
|
|
var minus = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : PI * -0.5;
|
|
|
var radianGap = PI * 2 / side;
|
|
|
var radians = new Array(side).fill('').map(function (t, i) {
|
|
|
return i * radianGap + minus;
|
|
|
});
|
|
|
return radians.map(function (radian) {
|
|
|
return getCircleRadianPoint(rx, ry, r, radian);
|
|
|
});
|
|
|
}
|
|
|
|
|
|
var _default = {
|
|
|
deepClone: deepClone,
|
|
|
eliminateBlur: eliminateBlur,
|
|
|
checkPointIsInCircle: checkPointIsInCircle,
|
|
|
checkPointIsInPolygon: checkPointIsInPolygon,
|
|
|
checkPointIsInSector: checkPointIsInSector,
|
|
|
checkPointIsNearPolyline: checkPointIsNearPolyline,
|
|
|
getTwoPointDistance: getTwoPointDistance,
|
|
|
getRotatePointPos: getRotatePointPos,
|
|
|
getScalePointPos: getScalePointPos,
|
|
|
getTranslatePointPos: getTranslatePointPos,
|
|
|
getCircleRadianPoint: getCircleRadianPoint,
|
|
|
getRegularPolygonPoints: getRegularPolygonPoints,
|
|
|
getDistanceBetweenPointAndLine: getDistanceBetweenPointAndLine
|
|
|
};
|
|
|
exports["default"] = _default;
|
|
|
},{"@babel/runtime/helpers/interopRequireDefault":14,"@babel/runtime/helpers/slicedToArray":19,"@babel/runtime/helpers/toConsumableArray":20,"@babel/runtime/helpers/typeof":21}],9:[function(require,module,exports){
|
|
|
function _arrayWithHoles(arr) {
|
|
|
if (Array.isArray(arr)) return arr;
|
|
|
}
|
|
|
|
|
|
module.exports = _arrayWithHoles;
|
|
|
},{}],10:[function(require,module,exports){
|
|
|
function _arrayWithoutHoles(arr) {
|
|
|
if (Array.isArray(arr)) {
|
|
|
for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) {
|
|
|
arr2[i] = arr[i];
|
|
|
}
|
|
|
|
|
|
return arr2;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
module.exports = _arrayWithoutHoles;
|
|
|
},{}],11:[function(require,module,exports){
|
|
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
|
try {
|
|
|
var info = gen[key](arg);
|
|
|
var value = info.value;
|
|
|
} catch (error) {
|
|
|
reject(error);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (info.done) {
|
|
|
resolve(value);
|
|
|
} else {
|
|
|
Promise.resolve(value).then(_next, _throw);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
function _asyncToGenerator(fn) {
|
|
|
return function () {
|
|
|
var self = this,
|
|
|
args = arguments;
|
|
|
return new Promise(function (resolve, reject) {
|
|
|
var gen = fn.apply(self, args);
|
|
|
|
|
|
function _next(value) {
|
|
|
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
|
}
|
|
|
|
|
|
function _throw(err) {
|
|
|
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
|
}
|
|
|
|
|
|
_next(undefined);
|
|
|
});
|
|
|
};
|
|
|
}
|
|
|
|
|
|
module.exports = _asyncToGenerator;
|
|
|
},{}],12:[function(require,module,exports){
|
|
|
function _classCallCheck(instance, Constructor) {
|
|
|
if (!(instance instanceof Constructor)) {
|
|
|
throw new TypeError("Cannot call a class as a function");
|
|
|
}
|
|
|
}
|
|
|
|
|
|
module.exports = _classCallCheck;
|
|
|
},{}],13:[function(require,module,exports){
|
|
|
function _defineProperty(obj, key, value) {
|
|
|
if (key in obj) {
|
|
|
Object.defineProperty(obj, key, {
|
|
|
value: value,
|
|
|
enumerable: true,
|
|
|
configurable: true,
|
|
|
writable: true
|
|
|
});
|
|
|
} else {
|
|
|
obj[key] = value;
|
|
|
}
|
|
|
|
|
|
return obj;
|
|
|
}
|
|
|
|
|
|
module.exports = _defineProperty;
|
|
|
},{}],14:[function(require,module,exports){
|
|
|
function _interopRequireDefault(obj) {
|
|
|
return obj && obj.__esModule ? obj : {
|
|
|
"default": obj
|
|
|
};
|
|
|
}
|
|
|
|
|
|
module.exports = _interopRequireDefault;
|
|
|
},{}],15:[function(require,module,exports){
|
|
|
function _iterableToArray(iter) {
|
|
|
if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter);
|
|
|
}
|
|
|
|
|
|
module.exports = _iterableToArray;
|
|
|
},{}],16:[function(require,module,exports){
|
|
|
function _iterableToArrayLimit(arr, i) {
|
|
|
var _arr = [];
|
|
|
var _n = true;
|
|
|
var _d = false;
|
|
|
var _e = undefined;
|
|
|
|
|
|
try {
|
|
|
for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {
|
|
|
_arr.push(_s.value);
|
|
|
|
|
|
if (i && _arr.length === i) break;
|
|
|
}
|
|
|
} catch (err) {
|
|
|
_d = true;
|
|
|
_e = err;
|
|
|
} finally {
|
|
|
try {
|
|
|
if (!_n && _i["return"] != null) _i["return"]();
|
|
|
} finally {
|
|
|
if (_d) throw _e;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
return _arr;
|
|
|
}
|
|
|
|
|
|
module.exports = _iterableToArrayLimit;
|
|
|
},{}],17:[function(require,module,exports){
|
|
|
function _nonIterableRest() {
|
|
|
throw new TypeError("Invalid attempt to destructure non-iterable instance");
|
|
|
}
|
|
|
|
|
|
module.exports = _nonIterableRest;
|
|
|
},{}],18:[function(require,module,exports){
|
|
|
function _nonIterableSpread() {
|
|
|
throw new TypeError("Invalid attempt to spread non-iterable instance");
|
|
|
}
|
|
|
|
|
|
module.exports = _nonIterableSpread;
|
|
|
},{}],19:[function(require,module,exports){
|
|
|
var arrayWithHoles = require("./arrayWithHoles");
|
|
|
|
|
|
var iterableToArrayLimit = require("./iterableToArrayLimit");
|
|
|
|
|
|
var nonIterableRest = require("./nonIterableRest");
|
|
|
|
|
|
function _slicedToArray(arr, i) {
|
|
|
return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();
|
|
|
}
|
|
|
|
|
|
module.exports = _slicedToArray;
|
|
|
},{"./arrayWithHoles":9,"./iterableToArrayLimit":16,"./nonIterableRest":17}],20:[function(require,module,exports){
|
|
|
var arrayWithoutHoles = require("./arrayWithoutHoles");
|
|
|
|
|
|
var iterableToArray = require("./iterableToArray");
|
|
|
|
|
|
var nonIterableSpread = require("./nonIterableSpread");
|
|
|
|
|
|
function _toConsumableArray(arr) {
|
|
|
return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();
|
|
|
}
|
|
|
|
|
|
module.exports = _toConsumableArray;
|
|
|
},{"./arrayWithoutHoles":10,"./iterableToArray":15,"./nonIterableSpread":18}],21:[function(require,module,exports){
|
|
|
function _typeof2(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof2(obj); }
|
|
|
|
|
|
function _typeof(obj) {
|
|
|
if (typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol") {
|
|
|
module.exports = _typeof = function _typeof(obj) {
|
|
|
return _typeof2(obj);
|
|
|
};
|
|
|
} else {
|
|
|
module.exports = _typeof = function _typeof(obj) {
|
|
|
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : _typeof2(obj);
|
|
|
};
|
|
|
}
|
|
|
|
|
|
return _typeof(obj);
|
|
|
}
|
|
|
|
|
|
module.exports = _typeof;
|
|
|
},{}],22:[function(require,module,exports){
|
|
|
module.exports = require("regenerator-runtime");
|
|
|
|
|
|
},{"regenerator-runtime":30}],23:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports.bezierCurveToPolyline = bezierCurveToPolyline;
|
|
|
exports.getBezierCurveLength = getBezierCurveLength;
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
|
|
|
|
|
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
|
|
|
|
|
|
function _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
|
|
|
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
|
|
|
|
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }
|
|
|
|
|
|
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); }
|
|
|
|
|
|
function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); }
|
|
|
|
|
|
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }
|
|
|
|
|
|
var sqrt = Math.sqrt,
|
|
|
pow = Math.pow,
|
|
|
ceil = Math.ceil,
|
|
|
abs = Math.abs; // Initialize the number of points per curve
|
|
|
|
|
|
var defaultSegmentPointsNum = 50;
|
|
|
/**
|
|
|
* @example data structure of bezierCurve
|
|
|
* bezierCurve = [
|
|
|
* // Starting point of the curve
|
|
|
* [10, 10],
|
|
|
* // BezierCurve segment data (controlPoint1, controlPoint2, endPoint)
|
|
|
* [
|
|
|
* [20, 20], [40, 20], [50, 10]
|
|
|
* ],
|
|
|
* ...
|
|
|
* ]
|
|
|
*/
|
|
|
|
|
|
/**
|
|
|
* @description Abstract the curve as a polyline consisting of N points
|
|
|
* @param {Array} bezierCurve bezierCurve data
|
|
|
* @param {Number} precision calculation accuracy. Recommended for 1-20. Default = 5
|
|
|
* @return {Object} Calculation results and related data
|
|
|
* @return {Array} Option.segmentPoints Point data that constitutes a polyline after calculation
|
|
|
* @return {Number} Option.cycles Number of iterations
|
|
|
* @return {Number} Option.rounds The number of recursions for the last iteration
|
|
|
*/
|
|
|
|
|
|
function abstractBezierCurveToPolyline(bezierCurve) {
|
|
|
var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5;
|
|
|
var segmentsNum = bezierCurve.length - 1;
|
|
|
var startPoint = bezierCurve[0];
|
|
|
var endPoint = bezierCurve[segmentsNum][2];
|
|
|
var segments = bezierCurve.slice(1);
|
|
|
var getSegmentTPointFuns = segments.map(function (seg, i) {
|
|
|
var beginPoint = i === 0 ? startPoint : segments[i - 1][2];
|
|
|
return createGetBezierCurveTPointFun.apply(void 0, [beginPoint].concat(_toConsumableArray(seg)));
|
|
|
}); // Initialize the curve to a polyline
|
|
|
|
|
|
var segmentPointsNum = new Array(segmentsNum).fill(defaultSegmentPointsNum);
|
|
|
var segmentPoints = getSegmentPointsByNum(getSegmentTPointFuns, segmentPointsNum); // Calculate uniformly distributed points by iteratively
|
|
|
|
|
|
var result = calcUniformPointsByIteration(segmentPoints, getSegmentTPointFuns, segments, precision);
|
|
|
result.segmentPoints.push(endPoint);
|
|
|
return result;
|
|
|
}
|
|
|
/**
|
|
|
* @description Generate a method for obtaining corresponding point by t according to curve data
|
|
|
* @param {Array} beginPoint BezierCurve begin point. [x, y]
|
|
|
* @param {Array} controlPoint1 BezierCurve controlPoint1. [x, y]
|
|
|
* @param {Array} controlPoint2 BezierCurve controlPoint2. [x, y]
|
|
|
* @param {Array} endPoint BezierCurve end point. [x, y]
|
|
|
* @return {Function} Expected function
|
|
|
*/
|
|
|
|
|
|
|
|
|
function createGetBezierCurveTPointFun(beginPoint, controlPoint1, controlPoint2, endPoint) {
|
|
|
return function (t) {
|
|
|
var tSubed1 = 1 - t;
|
|
|
var tSubed1Pow3 = pow(tSubed1, 3);
|
|
|
var tSubed1Pow2 = pow(tSubed1, 2);
|
|
|
var tPow3 = pow(t, 3);
|
|
|
var tPow2 = pow(t, 2);
|
|
|
return [beginPoint[0] * tSubed1Pow3 + 3 * controlPoint1[0] * t * tSubed1Pow2 + 3 * controlPoint2[0] * tPow2 * tSubed1 + endPoint[0] * tPow3, beginPoint[1] * tSubed1Pow3 + 3 * controlPoint1[1] * t * tSubed1Pow2 + 3 * controlPoint2[1] * tPow2 * tSubed1 + endPoint[1] * tPow3];
|
|
|
};
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the distance between two points
|
|
|
* @param {Array} point1 BezierCurve begin point. [x, y]
|
|
|
* @param {Array} point2 BezierCurve controlPoint1. [x, y]
|
|
|
* @return {Number} Expected distance
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getTwoPointDistance(_ref, _ref2) {
|
|
|
var _ref3 = _slicedToArray(_ref, 2),
|
|
|
ax = _ref3[0],
|
|
|
ay = _ref3[1];
|
|
|
|
|
|
var _ref4 = _slicedToArray(_ref2, 2),
|
|
|
bx = _ref4[0],
|
|
|
by = _ref4[1];
|
|
|
|
|
|
return sqrt(pow(ax - bx, 2) + pow(ay - by, 2));
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the sum of the array of numbers
|
|
|
* @param {Array} nums An array of numbers
|
|
|
* @return {Number} Expected sum
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getNumsSum(nums) {
|
|
|
return nums.reduce(function (sum, num) {
|
|
|
return sum + num;
|
|
|
}, 0);
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the distance of multiple sets of points
|
|
|
* @param {Array} segmentPoints Multiple sets of point data
|
|
|
* @return {Array} Distance of multiple sets of point data
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getSegmentPointsDistance(segmentPoints) {
|
|
|
return segmentPoints.map(function (points, i) {
|
|
|
return new Array(points.length - 1).fill(0).map(function (temp, j) {
|
|
|
return getTwoPointDistance(points[j], points[j + 1]);
|
|
|
});
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the distance of multiple sets of points
|
|
|
* @param {Array} segmentPoints Multiple sets of point data
|
|
|
* @return {Array} Distance of multiple sets of point data
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getSegmentPointsByNum(getSegmentTPointFuns, segmentPointsNum) {
|
|
|
return getSegmentTPointFuns.map(function (getSegmentTPointFun, i) {
|
|
|
var tGap = 1 / segmentPointsNum[i];
|
|
|
return new Array(segmentPointsNum[i]).fill('').map(function (foo, j) {
|
|
|
return getSegmentTPointFun(j * tGap);
|
|
|
});
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the sum of deviations between line segment and the average length
|
|
|
* @param {Array} segmentPointsDistance Segment length of polyline
|
|
|
* @param {Number} avgLength Average length of the line segment
|
|
|
* @return {Number} Deviations
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getAllDeviations(segmentPointsDistance, avgLength) {
|
|
|
return segmentPointsDistance.map(function (seg) {
|
|
|
return seg.map(function (s) {
|
|
|
return abs(s - avgLength);
|
|
|
});
|
|
|
}).map(function (seg) {
|
|
|
return getNumsSum(seg);
|
|
|
}).reduce(function (total, v) {
|
|
|
return total + v;
|
|
|
}, 0);
|
|
|
}
|
|
|
/**
|
|
|
* @description Calculate uniformly distributed points by iteratively
|
|
|
* @param {Array} segmentPoints Multiple setd of points that make up a polyline
|
|
|
* @param {Array} getSegmentTPointFuns Functions of get a point on the curve with t
|
|
|
* @param {Array} segments BezierCurve data
|
|
|
* @param {Number} precision Calculation accuracy
|
|
|
* @return {Object} Calculation results and related data
|
|
|
* @return {Array} Option.segmentPoints Point data that constitutes a polyline after calculation
|
|
|
* @return {Number} Option.cycles Number of iterations
|
|
|
* @return {Number} Option.rounds The number of recursions for the last iteration
|
|
|
*/
|
|
|
|
|
|
|
|
|
function calcUniformPointsByIteration(segmentPoints, getSegmentTPointFuns, segments, precision) {
|
|
|
// The number of loops for the current iteration
|
|
|
var rounds = 4; // Number of iterations
|
|
|
|
|
|
var cycles = 1;
|
|
|
|
|
|
var _loop = function _loop() {
|
|
|
// Recalculate the number of points per curve based on the last iteration data
|
|
|
var totalPointsNum = segmentPoints.reduce(function (total, seg) {
|
|
|
return total + seg.length;
|
|
|
}, 0); // Add last points of segment to calc exact segment length
|
|
|
|
|
|
segmentPoints.forEach(function (seg, i) {
|
|
|
return seg.push(segments[i][2]);
|
|
|
});
|
|
|
var segmentPointsDistance = getSegmentPointsDistance(segmentPoints);
|
|
|
var lineSegmentNum = segmentPointsDistance.reduce(function (total, seg) {
|
|
|
return total + seg.length;
|
|
|
}, 0);
|
|
|
var segmentlength = segmentPointsDistance.map(function (seg) {
|
|
|
return getNumsSum(seg);
|
|
|
});
|
|
|
var totalLength = getNumsSum(segmentlength);
|
|
|
var avgLength = totalLength / lineSegmentNum; // Check if precision is reached
|
|
|
|
|
|
var allDeviations = getAllDeviations(segmentPointsDistance, avgLength);
|
|
|
if (allDeviations <= precision) return "break";
|
|
|
totalPointsNum = ceil(avgLength / precision * totalPointsNum * 1.1);
|
|
|
var segmentPointsNum = segmentlength.map(function (length) {
|
|
|
return ceil(length / totalLength * totalPointsNum);
|
|
|
}); // Calculate the points after redistribution
|
|
|
|
|
|
segmentPoints = getSegmentPointsByNum(getSegmentTPointFuns, segmentPointsNum);
|
|
|
totalPointsNum = segmentPoints.reduce(function (total, seg) {
|
|
|
return total + seg.length;
|
|
|
}, 0);
|
|
|
var segmentPointsForLength = JSON.parse(JSON.stringify(segmentPoints));
|
|
|
segmentPointsForLength.forEach(function (seg, i) {
|
|
|
return seg.push(segments[i][2]);
|
|
|
});
|
|
|
segmentPointsDistance = getSegmentPointsDistance(segmentPointsForLength);
|
|
|
lineSegmentNum = segmentPointsDistance.reduce(function (total, seg) {
|
|
|
return total + seg.length;
|
|
|
}, 0);
|
|
|
segmentlength = segmentPointsDistance.map(function (seg) {
|
|
|
return getNumsSum(seg);
|
|
|
});
|
|
|
totalLength = getNumsSum(segmentlength);
|
|
|
avgLength = totalLength / lineSegmentNum;
|
|
|
var stepSize = 1 / totalPointsNum / 10; // Recursively for each segment of the polyline
|
|
|
|
|
|
getSegmentTPointFuns.forEach(function (getSegmentTPointFun, i) {
|
|
|
var currentSegmentPointsNum = segmentPointsNum[i];
|
|
|
var t = new Array(currentSegmentPointsNum).fill('').map(function (foo, j) {
|
|
|
return j / segmentPointsNum[i];
|
|
|
}); // Repeated recursive offset
|
|
|
|
|
|
for (var r = 0; r < rounds; r++) {
|
|
|
var distance = getSegmentPointsDistance([segmentPoints[i]])[0];
|
|
|
var deviations = distance.map(function (d) {
|
|
|
return d - avgLength;
|
|
|
});
|
|
|
var offset = 0;
|
|
|
|
|
|
for (var j = 0; j < currentSegmentPointsNum; j++) {
|
|
|
if (j === 0) return;
|
|
|
offset += deviations[j - 1];
|
|
|
t[j] -= stepSize * offset;
|
|
|
if (t[j] > 1) t[j] = 1;
|
|
|
if (t[j] < 0) t[j] = 0;
|
|
|
segmentPoints[i][j] = getSegmentTPointFun(t[j]);
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
rounds *= 4;
|
|
|
cycles++;
|
|
|
};
|
|
|
|
|
|
do {
|
|
|
var _ret = _loop();
|
|
|
|
|
|
if (_ret === "break") break;
|
|
|
} while (rounds <= 1025);
|
|
|
|
|
|
segmentPoints = segmentPoints.reduce(function (all, seg) {
|
|
|
return all.concat(seg);
|
|
|
}, []);
|
|
|
return {
|
|
|
segmentPoints: segmentPoints,
|
|
|
cycles: cycles,
|
|
|
rounds: rounds
|
|
|
};
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the polyline corresponding to the Bezier curve
|
|
|
* @param {Array} bezierCurve BezierCurve data
|
|
|
* @param {Number} precision Calculation accuracy. Recommended for 1-20. Default = 5
|
|
|
* @return {Array|Boolean} Point data that constitutes a polyline after calculation (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function bezierCurveToPolyline(bezierCurve) {
|
|
|
var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5;
|
|
|
|
|
|
if (!bezierCurve) {
|
|
|
console.error('bezierCurveToPolyline: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (!(bezierCurve instanceof Array)) {
|
|
|
console.error('bezierCurveToPolyline: Parameter bezierCurve must be an array!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (typeof precision !== 'number') {
|
|
|
console.error('bezierCurveToPolyline: Parameter precision must be a number!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var _abstractBezierCurveT = abstractBezierCurveToPolyline(bezierCurve, precision),
|
|
|
segmentPoints = _abstractBezierCurveT.segmentPoints;
|
|
|
|
|
|
return segmentPoints;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the bezier curve length
|
|
|
* @param {Array} bezierCurve bezierCurve data
|
|
|
* @param {Number} precision calculation accuracy. Recommended for 5-10. Default = 5
|
|
|
* @return {Number|Boolean} BezierCurve length (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getBezierCurveLength(bezierCurve) {
|
|
|
var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5;
|
|
|
|
|
|
if (!bezierCurve) {
|
|
|
console.error('getBezierCurveLength: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (!(bezierCurve instanceof Array)) {
|
|
|
console.error('getBezierCurveLength: Parameter bezierCurve must be an array!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (typeof precision !== 'number') {
|
|
|
console.error('getBezierCurveLength: Parameter precision must be a number!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var _abstractBezierCurveT2 = abstractBezierCurveToPolyline(bezierCurve, precision),
|
|
|
segmentPoints = _abstractBezierCurveT2.segmentPoints; // Calculate the total length of the points that make up the polyline
|
|
|
|
|
|
|
|
|
var pointsDistance = getSegmentPointsDistance([segmentPoints])[0];
|
|
|
var length = getNumsSum(pointsDistance);
|
|
|
return length;
|
|
|
}
|
|
|
|
|
|
var _default = bezierCurveToPolyline;
|
|
|
exports["default"] = _default;
|
|
|
},{}],24:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
|
|
|
|
|
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
|
|
|
|
|
|
function _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
|
|
|
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
|
|
|
|
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }
|
|
|
|
|
|
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); }
|
|
|
|
|
|
function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); }
|
|
|
|
|
|
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }
|
|
|
|
|
|
/**
|
|
|
* @description Abstract the polyline formed by N points into a set of bezier curve
|
|
|
* @param {Array} polyline A set of points that make up a polyline
|
|
|
* @param {Boolean} close Closed curve
|
|
|
* @param {Number} offsetA Smoothness
|
|
|
* @param {Number} offsetB Smoothness
|
|
|
* @return {Array|Boolean} A set of bezier curve (Invalid input will return false)
|
|
|
*/
|
|
|
function polylineToBezierCurve(polyline) {
|
|
|
var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
|
var offsetA = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0.25;
|
|
|
var offsetB = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0.25;
|
|
|
|
|
|
if (!(polyline instanceof Array)) {
|
|
|
console.error('polylineToBezierCurve: Parameter polyline must be an array!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (polyline.length <= 2) {
|
|
|
console.error('polylineToBezierCurve: Converting to a curve requires at least 3 points!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var startPoint = polyline[0];
|
|
|
var bezierCurveLineNum = polyline.length - 1;
|
|
|
var bezierCurvePoints = new Array(bezierCurveLineNum).fill(0).map(function (foo, i) {
|
|
|
return [].concat(_toConsumableArray(getBezierCurveLineControlPoints(polyline, i, close, offsetA, offsetB)), [polyline[i + 1]]);
|
|
|
});
|
|
|
if (close) closeBezierCurve(bezierCurvePoints, startPoint);
|
|
|
bezierCurvePoints.unshift(polyline[0]);
|
|
|
return bezierCurvePoints;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the control points of the Bezier curve
|
|
|
* @param {Array} polyline A set of points that make up a polyline
|
|
|
* @param {Number} index The index of which get controls points's point in polyline
|
|
|
* @param {Boolean} close Closed curve
|
|
|
* @param {Number} offsetA Smoothness
|
|
|
* @param {Number} offsetB Smoothness
|
|
|
* @return {Array} Control points
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getBezierCurveLineControlPoints(polyline, index) {
|
|
|
var close = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
|
var offsetA = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0.25;
|
|
|
var offsetB = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 0.25;
|
|
|
var pointNum = polyline.length;
|
|
|
if (pointNum < 3 || index >= pointNum) return;
|
|
|
var beforePointIndex = index - 1;
|
|
|
if (beforePointIndex < 0) beforePointIndex = close ? pointNum + beforePointIndex : 0;
|
|
|
var afterPointIndex = index + 1;
|
|
|
if (afterPointIndex >= pointNum) afterPointIndex = close ? afterPointIndex - pointNum : pointNum - 1;
|
|
|
var afterNextPointIndex = index + 2;
|
|
|
if (afterNextPointIndex >= pointNum) afterNextPointIndex = close ? afterNextPointIndex - pointNum : pointNum - 1;
|
|
|
var pointBefore = polyline[beforePointIndex];
|
|
|
var pointMiddle = polyline[index];
|
|
|
var pointAfter = polyline[afterPointIndex];
|
|
|
var pointAfterNext = polyline[afterNextPointIndex];
|
|
|
return [[pointMiddle[0] + offsetA * (pointAfter[0] - pointBefore[0]), pointMiddle[1] + offsetA * (pointAfter[1] - pointBefore[1])], [pointAfter[0] - offsetB * (pointAfterNext[0] - pointMiddle[0]), pointAfter[1] - offsetB * (pointAfterNext[1] - pointMiddle[1])]];
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the last curve of the closure
|
|
|
* @param {Array} bezierCurve A set of sub-curve
|
|
|
* @param {Array} startPoint Start point
|
|
|
* @return {Array} The last curve for closure
|
|
|
*/
|
|
|
|
|
|
|
|
|
function closeBezierCurve(bezierCurve, startPoint) {
|
|
|
var firstSubCurve = bezierCurve[0];
|
|
|
var lastSubCurve = bezierCurve.slice(-1)[0];
|
|
|
bezierCurve.push([getSymmetryPoint(lastSubCurve[1], lastSubCurve[2]), getSymmetryPoint(firstSubCurve[0], startPoint), startPoint]);
|
|
|
return bezierCurve;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the symmetry point
|
|
|
* @param {Array} point Symmetric point
|
|
|
* @param {Array} centerPoint Symmetric center
|
|
|
* @return {Array} Symmetric point
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getSymmetryPoint(point, centerPoint) {
|
|
|
var _point = _slicedToArray(point, 2),
|
|
|
px = _point[0],
|
|
|
py = _point[1];
|
|
|
|
|
|
var _centerPoint = _slicedToArray(centerPoint, 2),
|
|
|
cx = _centerPoint[0],
|
|
|
cy = _centerPoint[1];
|
|
|
|
|
|
var minusX = cx - px;
|
|
|
var minusY = cy - py;
|
|
|
return [cx + minusX, cy + minusY];
|
|
|
}
|
|
|
|
|
|
var _default = polylineToBezierCurve;
|
|
|
exports["default"] = _default;
|
|
|
},{}],25:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
Object.defineProperty(exports, "bezierCurveToPolyline", {
|
|
|
enumerable: true,
|
|
|
get: function get() {
|
|
|
return _bezierCurveToPolyline.bezierCurveToPolyline;
|
|
|
}
|
|
|
});
|
|
|
Object.defineProperty(exports, "getBezierCurveLength", {
|
|
|
enumerable: true,
|
|
|
get: function get() {
|
|
|
return _bezierCurveToPolyline.getBezierCurveLength;
|
|
|
}
|
|
|
});
|
|
|
Object.defineProperty(exports, "polylineToBezierCurve", {
|
|
|
enumerable: true,
|
|
|
get: function get() {
|
|
|
return _polylineToBezierCurve["default"];
|
|
|
}
|
|
|
});
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _bezierCurveToPolyline = require("./core/bezierCurveToPolyline");
|
|
|
|
|
|
var _polylineToBezierCurve = _interopRequireDefault(require("./core/polylineToBezierCurve"));
|
|
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
|
|
|
|
var _default = {
|
|
|
bezierCurveToPolyline: _bezierCurveToPolyline.bezierCurveToPolyline,
|
|
|
getBezierCurveLength: _bezierCurveToPolyline.getBezierCurveLength,
|
|
|
polylineToBezierCurve: _polylineToBezierCurve["default"]
|
|
|
};
|
|
|
exports["default"] = _default;
|
|
|
},{"./core/bezierCurveToPolyline":23,"./core/polylineToBezierCurve":24}],26:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _default = new Map([['transparent', 'rgba(0,0,0,0)'], ['black', '#000000'], ['silver', '#C0C0C0'], ['gray', '#808080'], ['white', '#FFFFFF'], ['maroon', '#800000'], ['red', '#FF0000'], ['purple', '#800080'], ['fuchsia', '#FF00FF'], ['green', '#008000'], ['lime', '#00FF00'], ['olive', '#808000'], ['yellow', '#FFFF00'], ['navy', '#000080'], ['blue', '#0000FF'], ['teal', '#008080'], ['aqua', '#00FFFF'], ['aliceblue', '#f0f8ff'], ['antiquewhite', '#faebd7'], ['aquamarine', '#7fffd4'], ['azure', '#f0ffff'], ['beige', '#f5f5dc'], ['bisque', '#ffe4c4'], ['blanchedalmond', '#ffebcd'], ['blueviolet', '#8a2be2'], ['brown', '#a52a2a'], ['burlywood', '#deb887'], ['cadetblue', '#5f9ea0'], ['chartreuse', '#7fff00'], ['chocolate', '#d2691e'], ['coral', '#ff7f50'], ['cornflowerblue', '#6495ed'], ['cornsilk', '#fff8dc'], ['crimson', '#dc143c'], ['cyan', '#00ffff'], ['darkblue', '#00008b'], ['darkcyan', '#008b8b'], ['darkgoldenrod', '#b8860b'], ['darkgray', '#a9a9a9'], ['darkgreen', '#006400'], ['darkgrey', '#a9a9a9'], ['darkkhaki', '#bdb76b'], ['darkmagenta', '#8b008b'], ['darkolivegreen', '#556b2f'], ['darkorange', '#ff8c00'], ['darkorchid', '#9932cc'], ['darkred', '#8b0000'], ['darksalmon', '#e9967a'], ['darkseagreen', '#8fbc8f'], ['darkslateblue', '#483d8b'], ['darkslategray', '#2f4f4f'], ['darkslategrey', '#2f4f4f'], ['darkturquoise', '#00ced1'], ['darkviolet', '#9400d3'], ['deeppink', '#ff1493'], ['deepskyblue', '#00bfff'], ['dimgray', '#696969'], ['dimgrey', '#696969'], ['dodgerblue', '#1e90ff'], ['firebrick', '#b22222'], ['floralwhite', '#fffaf0'], ['forestgreen', '#228b22'], ['gainsboro', '#dcdcdc'], ['ghostwhite', '#f8f8ff'], ['gold', '#ffd700'], ['goldenrod', '#daa520'], ['greenyellow', '#adff2f'], ['grey', '#808080'], ['honeydew', '#f0fff0'], ['hotpink', '#ff69b4'], ['indianred', '#cd5c5c'], ['indigo', '#4b0082'], ['ivory', '#fffff0'], ['khaki', '#f0e68c'], ['lavender', '#e6e6fa'], ['lavenderblush', '#fff0f5'], ['lawngreen', '#7cfc00'], ['lemonchiffon', '#fffacd'], ['lightblue', '#add8e6'], ['lightcoral', '#f08080'], ['lightcyan', '#e0ffff'], ['lightgoldenrodyellow', '#fafad2'], ['lightgray', '#d3d3d3'], ['lightgreen', '#90ee90'], ['lightgrey', '#d3d3d3'], ['lightpink', '#ffb6c1'], ['lightsalmon', '#ffa07a'], ['lightseagreen', '#20b2aa'], ['lightskyblue', '#87cefa'], ['lightslategray', '#778899'], ['lightslategrey', '#778899'], ['lightsteelblue', '#b0c4de'], ['lightyellow', '#ffffe0'], ['limegreen', '#32cd32'], ['linen', '#faf0e6'], ['magenta', '#ff00ff'], ['mediumaquamarine', '#66cdaa'], ['mediumblue', '#0000cd'], ['mediumorchid', '#ba55d3'], ['mediumpurple', '#9370db'], ['mediumseagreen', '#3cb371'], ['mediumslateblue', '#7b68ee'], ['mediumspringgreen', '#00fa9a'], ['mediumturquoise', '#48d1cc'], ['mediumvioletred', '#c71585'], ['midnightblue', '#191970'], ['mintcream', '#f5fffa'], ['mistyrose', '#ffe4e1'], ['moccasin', '#ffe4b5'], ['navajowhite', '#ffdead'], ['oldlace', '#fdf5e6'], ['olivedrab', '#6b8e23'], ['orange', '#ffa500'], ['orangered', '#ff4500'], ['orchid', '#da70d6'], ['palegoldenrod', '#eee8aa'], ['palegreen', '#98fb98'], ['paleturquoise', '#afeeee'], ['palevioletred', '#db7093'], ['papayawhip', '#ffefd5'], ['peachpuff', '#ffdab9'], ['peru', '#cd853f'], ['pink', '#ffc0cb'], ['plum', '#dda0dd'], ['powderblue', '#b0e0e6'], ['rosybrown', '#bc8f8f'], ['royalblue', '#4169e1'], ['saddlebrown', '#8b4513'], ['salmon', '#fa8072'], ['sandybrown', '#f4a460'], ['seagreen', '#2e8b57'], ['seashell', '#fff5ee'], ['sienna', '#a0522d'], ['skyblue', '#87ceeb'], ['slateblue', '#6a5acd'], ['slategray', '#708090'], ['slategrey', '#708090'], ['snow', '#fffafa'], ['springgreen', '#00ff7f'], ['steelblue', '#4682b4'], ['tan', '#d2b48c'], ['thistle', '#d8bfd8'], ['tomato', '#ff6347'], ['turquoise', '#40e0d0'], ['violet', '#ee82ee'], ['wheat', '#f5deb3'], ['whitesmoke', '#f5f5f5'], ['yellowgreen', '#9acd32']]);
|
|
|
|
|
|
exports["default"] = _default;
|
|
|
},{}],27:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports.getRgbValue = getRgbValue;
|
|
|
exports.getRgbaValue = getRgbaValue;
|
|
|
exports.getOpacity = getOpacity;
|
|
|
exports.toRgb = toRgb;
|
|
|
exports.toHex = toHex;
|
|
|
exports.getColorFromRgbValue = getColorFromRgbValue;
|
|
|
exports.darken = darken;
|
|
|
exports.lighten = lighten;
|
|
|
exports.fade = fade;
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _keywords = _interopRequireDefault(require("./config/keywords"));
|
|
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
|
|
|
|
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }
|
|
|
|
|
|
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); }
|
|
|
|
|
|
function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); }
|
|
|
|
|
|
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }
|
|
|
|
|
|
var hexReg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
|
|
|
var rgbReg = /^(rgb|rgba|RGB|RGBA)/;
|
|
|
var rgbaReg = /^(rgba|RGBA)/;
|
|
|
/**
|
|
|
* @description Color validator
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @return {String|Boolean} Valid color Or false
|
|
|
*/
|
|
|
|
|
|
function validator(color) {
|
|
|
var isHex = hexReg.test(color);
|
|
|
var isRgb = rgbReg.test(color);
|
|
|
if (isHex || isRgb) return color;
|
|
|
color = getColorByKeyword(color);
|
|
|
|
|
|
if (!color) {
|
|
|
console.error('Color: Invalid color!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
return color;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get color by keyword
|
|
|
* @param {String} keyword Color keyword like red, green and etc.
|
|
|
* @return {String|Boolean} Hex or rgba color (Invalid keyword will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getColorByKeyword(keyword) {
|
|
|
if (!keyword) {
|
|
|
console.error('getColorByKeywords: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (!_keywords["default"].has(keyword)) return false;
|
|
|
return _keywords["default"].get(keyword);
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the Rgb value of the color
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @return {Array<Number>|Boolean} Rgb value of the color (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getRgbValue(color) {
|
|
|
if (!color) {
|
|
|
console.error('getRgbValue: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
color = validator(color);
|
|
|
if (!color) return false;
|
|
|
var isHex = hexReg.test(color);
|
|
|
var isRgb = rgbReg.test(color);
|
|
|
var lowerColor = color.toLowerCase();
|
|
|
if (isHex) return getRgbValueFromHex(lowerColor);
|
|
|
if (isRgb) return getRgbValueFromRgb(lowerColor);
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the rgb value of the hex color
|
|
|
* @param {String} color Hex color
|
|
|
* @return {Array<Number>} Rgb value of the color
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getRgbValueFromHex(color) {
|
|
|
color = color.replace('#', '');
|
|
|
if (color.length === 3) color = Array.from(color).map(function (hexNum) {
|
|
|
return hexNum + hexNum;
|
|
|
}).join('');
|
|
|
color = color.split('');
|
|
|
return new Array(3).fill(0).map(function (t, i) {
|
|
|
return parseInt("0x".concat(color[i * 2]).concat(color[i * 2 + 1]));
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the rgb value of the rgb/rgba color
|
|
|
* @param {String} color Hex color
|
|
|
* @return {Array} Rgb value of the color
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getRgbValueFromRgb(color) {
|
|
|
return color.replace(/rgb\(|rgba\(|\)/g, '').split(',').slice(0, 3).map(function (n) {
|
|
|
return parseInt(n);
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the Rgba value of the color
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @return {Array<Number>|Boolean} Rgba value of the color (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getRgbaValue(color) {
|
|
|
if (!color) {
|
|
|
console.error('getRgbaValue: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var colorValue = getRgbValue(color);
|
|
|
if (!colorValue) return false;
|
|
|
colorValue.push(getOpacity(color));
|
|
|
return colorValue;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the opacity of color
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @return {Number|Boolean} Color opacity (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getOpacity(color) {
|
|
|
if (!color) {
|
|
|
console.error('getOpacity: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
color = validator(color);
|
|
|
if (!color) return false;
|
|
|
var isRgba = rgbaReg.test(color);
|
|
|
if (!isRgba) return 1;
|
|
|
color = color.toLowerCase();
|
|
|
return Number(color.split(',').slice(-1)[0].replace(/[)|\s]/g, ''));
|
|
|
}
|
|
|
/**
|
|
|
* @description Convert color to Rgb|Rgba color
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @param {Number} opacity The opacity of color
|
|
|
* @return {String|Boolean} Rgb|Rgba color (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function toRgb(color, opacity) {
|
|
|
if (!color) {
|
|
|
console.error('toRgb: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var rgbValue = getRgbValue(color);
|
|
|
if (!rgbValue) return false;
|
|
|
var addOpacity = typeof opacity === 'number';
|
|
|
if (addOpacity) return 'rgba(' + rgbValue.join(',') + ",".concat(opacity, ")");
|
|
|
return 'rgb(' + rgbValue.join(',') + ')';
|
|
|
}
|
|
|
/**
|
|
|
* @description Convert color to Hex color
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @return {String|Boolean} Hex color (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function toHex(color) {
|
|
|
if (!color) {
|
|
|
console.error('toHex: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (hexReg.test(color)) return color;
|
|
|
color = getRgbValue(color);
|
|
|
if (!color) return false;
|
|
|
return '#' + color.map(function (n) {
|
|
|
return Number(n).toString(16);
|
|
|
}).map(function (n) {
|
|
|
return n === '0' ? '00' : n;
|
|
|
}).join('');
|
|
|
}
|
|
|
/**
|
|
|
* @description Get Color from Rgb|Rgba value
|
|
|
* @param {Array<Number>} value Rgb|Rgba color value
|
|
|
* @return {String|Boolean} Rgb|Rgba color (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getColorFromRgbValue(value) {
|
|
|
if (!value) {
|
|
|
console.error('getColorFromRgbValue: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var valueLength = value.length;
|
|
|
|
|
|
if (valueLength !== 3 && valueLength !== 4) {
|
|
|
console.error('getColorFromRgbValue: Value is illegal!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var color = valueLength === 3 ? 'rgb(' : 'rgba(';
|
|
|
color += value.join(',') + ')';
|
|
|
return color;
|
|
|
}
|
|
|
/**
|
|
|
* @description Deepen color
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @return {Number} Percent of Deepen (1-100)
|
|
|
* @return {String|Boolean} Rgba color (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function darken(color) {
|
|
|
var percent = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
|
|
|
|
if (!color) {
|
|
|
console.error('darken: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var rgbaValue = getRgbaValue(color);
|
|
|
if (!rgbaValue) return false;
|
|
|
rgbaValue = rgbaValue.map(function (v, i) {
|
|
|
return i === 3 ? v : v - Math.ceil(2.55 * percent);
|
|
|
}).map(function (v) {
|
|
|
return v < 0 ? 0 : v;
|
|
|
});
|
|
|
return getColorFromRgbValue(rgbaValue);
|
|
|
}
|
|
|
/**
|
|
|
* @description Brighten color
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @return {Number} Percent of brighten (1-100)
|
|
|
* @return {String|Boolean} Rgba color (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function lighten(color) {
|
|
|
var percent = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
|
|
|
|
if (!color) {
|
|
|
console.error('lighten: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var rgbaValue = getRgbaValue(color);
|
|
|
if (!rgbaValue) return false;
|
|
|
rgbaValue = rgbaValue.map(function (v, i) {
|
|
|
return i === 3 ? v : v + Math.ceil(2.55 * percent);
|
|
|
}).map(function (v) {
|
|
|
return v > 255 ? 255 : v;
|
|
|
});
|
|
|
return getColorFromRgbValue(rgbaValue);
|
|
|
}
|
|
|
/**
|
|
|
* @description Adjust color opacity
|
|
|
* @param {String} color Hex|Rgb|Rgba color or color keyword
|
|
|
* @param {Number} Percent of opacity
|
|
|
* @return {String|Boolean} Rgba color (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
|
|
|
function fade(color) {
|
|
|
var percent = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100;
|
|
|
|
|
|
if (!color) {
|
|
|
console.error('fade: Missing parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var rgbValue = getRgbValue(color);
|
|
|
if (!rgbValue) return false;
|
|
|
var rgbaValue = [].concat(_toConsumableArray(rgbValue), [percent / 100]);
|
|
|
return getColorFromRgbValue(rgbaValue);
|
|
|
}
|
|
|
|
|
|
var _default = {
|
|
|
fade: fade,
|
|
|
toHex: toHex,
|
|
|
toRgb: toRgb,
|
|
|
darken: darken,
|
|
|
lighten: lighten,
|
|
|
getOpacity: getOpacity,
|
|
|
getRgbValue: getRgbValue,
|
|
|
getRgbaValue: getRgbaValue,
|
|
|
getColorFromRgbValue: getColorFromRgbValue
|
|
|
};
|
|
|
exports["default"] = _default;
|
|
|
},{"./config/keywords":26}],28:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports["default"] = exports.easeInOutBounce = exports.easeOutBounce = exports.easeInBounce = exports.easeInOutElastic = exports.easeOutElastic = exports.easeInElastic = exports.easeInOutBack = exports.easeOutBack = exports.easeInBack = exports.easeInOutQuint = exports.easeOutQuint = exports.easeInQuint = exports.easeInOutQuart = exports.easeOutQuart = exports.easeInQuart = exports.easeInOutCubic = exports.easeOutCubic = exports.easeInCubic = exports.easeInOutQuad = exports.easeOutQuad = exports.easeInQuad = exports.easeInOutSine = exports.easeOutSine = exports.easeInSine = exports.linear = void 0;
|
|
|
var linear = [[[0, 1], '', [0.33, 0.67]], [[1, 0], [0.67, 0.33]]];
|
|
|
/**
|
|
|
* @description Sine
|
|
|
*/
|
|
|
|
|
|
exports.linear = linear;
|
|
|
var easeInSine = [[[0, 1]], [[0.538, 0.564], [0.169, 0.912], [0.880, 0.196]], [[1, 0]]];
|
|
|
exports.easeInSine = easeInSine;
|
|
|
var easeOutSine = [[[0, 1]], [[0.444, 0.448], [0.169, 0.736], [0.718, 0.16]], [[1, 0]]];
|
|
|
exports.easeOutSine = easeOutSine;
|
|
|
var easeInOutSine = [[[0, 1]], [[0.5, 0.5], [0.2, 1], [0.8, 0]], [[1, 0]]];
|
|
|
/**
|
|
|
* @description Quad
|
|
|
*/
|
|
|
|
|
|
exports.easeInOutSine = easeInOutSine;
|
|
|
var easeInQuad = [[[0, 1]], [[0.550, 0.584], [0.231, 0.904], [0.868, 0.264]], [[1, 0]]];
|
|
|
exports.easeInQuad = easeInQuad;
|
|
|
var easeOutQuad = [[[0, 1]], [[0.413, 0.428], [0.065, 0.816], [0.760, 0.04]], [[1, 0]]];
|
|
|
exports.easeOutQuad = easeOutQuad;
|
|
|
var easeInOutQuad = [[[0, 1]], [[0.5, 0.5], [0.3, 0.9], [0.7, 0.1]], [[1, 0]]];
|
|
|
/**
|
|
|
* @description Cubic
|
|
|
*/
|
|
|
|
|
|
exports.easeInOutQuad = easeInOutQuad;
|
|
|
var easeInCubic = [[[0, 1]], [[0.679, 0.688], [0.366, 0.992], [0.992, 0.384]], [[1, 0]]];
|
|
|
exports.easeInCubic = easeInCubic;
|
|
|
var easeOutCubic = [[[0, 1]], [[0.321, 0.312], [0.008, 0.616], [0.634, 0.008]], [[1, 0]]];
|
|
|
exports.easeOutCubic = easeOutCubic;
|
|
|
var easeInOutCubic = [[[0, 1]], [[0.5, 0.5], [0.3, 1], [0.7, 0]], [[1, 0]]];
|
|
|
/**
|
|
|
* @description Quart
|
|
|
*/
|
|
|
|
|
|
exports.easeInOutCubic = easeInOutCubic;
|
|
|
var easeInQuart = [[[0, 1]], [[0.812, 0.74], [0.611, 0.988], [1.013, 0.492]], [[1, 0]]];
|
|
|
exports.easeInQuart = easeInQuart;
|
|
|
var easeOutQuart = [[[0, 1]], [[0.152, 0.244], [0.001, 0.448], [0.285, -0.02]], [[1, 0]]];
|
|
|
exports.easeOutQuart = easeOutQuart;
|
|
|
var easeInOutQuart = [[[0, 1]], [[0.5, 0.5], [0.4, 1], [0.6, 0]], [[1, 0]]];
|
|
|
/**
|
|
|
* @description Quint
|
|
|
*/
|
|
|
|
|
|
exports.easeInOutQuart = easeInOutQuart;
|
|
|
var easeInQuint = [[[0, 1]], [[0.857, 0.856], [0.714, 1], [1, 0.712]], [[1, 0]]];
|
|
|
exports.easeInQuint = easeInQuint;
|
|
|
var easeOutQuint = [[[0, 1]], [[0.108, 0.2], [0.001, 0.4], [0.214, -0.012]], [[1, 0]]];
|
|
|
exports.easeOutQuint = easeOutQuint;
|
|
|
var easeInOutQuint = [[[0, 1]], [[0.5, 0.5], [0.5, 1], [0.5, 0]], [[1, 0]]];
|
|
|
/**
|
|
|
* @description Back
|
|
|
*/
|
|
|
|
|
|
exports.easeInOutQuint = easeInOutQuint;
|
|
|
var easeInBack = [[[0, 1]], [[0.667, 0.896], [0.380, 1.184], [0.955, 0.616]], [[1, 0]]];
|
|
|
exports.easeInBack = easeInBack;
|
|
|
var easeOutBack = [[[0, 1]], [[0.335, 0.028], [0.061, 0.22], [0.631, -0.18]], [[1, 0]]];
|
|
|
exports.easeOutBack = easeOutBack;
|
|
|
var easeInOutBack = [[[0, 1]], [[0.5, 0.5], [0.4, 1.4], [0.6, -0.4]], [[1, 0]]];
|
|
|
/**
|
|
|
* @description Elastic
|
|
|
*/
|
|
|
|
|
|
exports.easeInOutBack = easeInOutBack;
|
|
|
var easeInElastic = [[[0, 1]], [[0.474, 0.964], [0.382, 0.988], [0.557, 0.952]], [[0.619, 1.076], [0.565, 1.088], [0.669, 1.08]], [[0.770, 0.916], [0.712, 0.924], [0.847, 0.904]], [[0.911, 1.304], [0.872, 1.316], [0.961, 1.34]], [[1, 0]]];
|
|
|
exports.easeInElastic = easeInElastic;
|
|
|
var easeOutElastic = [[[0, 1]], [[0.073, -0.32], [0.034, -0.328], [0.104, -0.344]], [[0.191, 0.092], [0.110, 0.06], [0.256, 0.08]], [[0.310, -0.076], [0.260, -0.068], [0.357, -0.076]], [[0.432, 0.032], [0.362, 0.028], [0.683, -0.004]], [[1, 0]]];
|
|
|
exports.easeOutElastic = easeOutElastic;
|
|
|
var easeInOutElastic = [[[0, 1]], [[0.210, 0.94], [0.167, 0.884], [0.252, 0.98]], [[0.299, 1.104], [0.256, 1.092], [0.347, 1.108]], [[0.5, 0.496], [0.451, 0.672], [0.548, 0.324]], [[0.696, -0.108], [0.652, -0.112], [0.741, -0.124]], [[0.805, 0.064], [0.756, 0.012], [0.866, 0.096]], [[1, 0]]];
|
|
|
/**
|
|
|
* @description Bounce
|
|
|
*/
|
|
|
|
|
|
exports.easeInOutElastic = easeInOutElastic;
|
|
|
var easeInBounce = [[[0, 1]], [[0.148, 1], [0.075, 0.868], [0.193, 0.848]], [[0.326, 1], [0.276, 0.836], [0.405, 0.712]], [[0.600, 1], [0.511, 0.708], [0.671, 0.348]], [[1, 0]]];
|
|
|
exports.easeInBounce = easeInBounce;
|
|
|
var easeOutBounce = [[[0, 1]], [[0.357, 0.004], [0.270, 0.592], [0.376, 0.252]], [[0.604, -0.004], [0.548, 0.312], [0.669, 0.184]], [[0.820, 0], [0.749, 0.184], [0.905, 0.132]], [[1, 0]]];
|
|
|
exports.easeOutBounce = easeOutBounce;
|
|
|
var easeInOutBounce = [[[0, 1]], [[0.102, 1], [0.050, 0.864], [0.117, 0.86]], [[0.216, 0.996], [0.208, 0.844], [0.227, 0.808]], [[0.347, 0.996], [0.343, 0.8], [0.480, 0.292]], [[0.635, 0.004], [0.511, 0.676], [0.656, 0.208]], [[0.787, 0], [0.760, 0.2], [0.795, 0.144]], [[0.905, -0.004], [0.899, 0.164], [0.944, 0.144]], [[1, 0]]];
|
|
|
exports.easeInOutBounce = easeInOutBounce;
|
|
|
|
|
|
var _default = new Map([['linear', linear], ['easeInSine', easeInSine], ['easeOutSine', easeOutSine], ['easeInOutSine', easeInOutSine], ['easeInQuad', easeInQuad], ['easeOutQuad', easeOutQuad], ['easeInOutQuad', easeInOutQuad], ['easeInCubic', easeInCubic], ['easeOutCubic', easeOutCubic], ['easeInOutCubic', easeInOutCubic], ['easeInQuart', easeInQuart], ['easeOutQuart', easeOutQuart], ['easeInOutQuart', easeInOutQuart], ['easeInQuint', easeInQuint], ['easeOutQuint', easeOutQuint], ['easeInOutQuint', easeInOutQuint], ['easeInBack', easeInBack], ['easeOutBack', easeOutBack], ['easeInOutBack', easeInOutBack], ['easeInElastic', easeInElastic], ['easeOutElastic', easeOutElastic], ['easeInOutElastic', easeInOutElastic], ['easeInBounce', easeInBounce], ['easeOutBounce', easeOutBounce], ['easeInOutBounce', easeInOutBounce]]);
|
|
|
|
|
|
exports["default"] = _default;
|
|
|
},{}],29:[function(require,module,exports){
|
|
|
"use strict";
|
|
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
|
value: true
|
|
|
});
|
|
|
exports.transition = transition;
|
|
|
exports.injectNewCurve = injectNewCurve;
|
|
|
exports["default"] = void 0;
|
|
|
|
|
|
var _curves = _interopRequireDefault(require("./config/curves"));
|
|
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
|
|
|
|
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
|
|
|
|
|
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
|
|
|
|
|
|
function _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
|
|
|
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
|
|
|
|
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
|
|
|
|
|
|
var defaultTransitionBC = 'linear';
|
|
|
/**
|
|
|
* @description Get the N-frame animation state by the start and end state
|
|
|
* of the animation and the easing curve
|
|
|
* @param {String|Array} tBC Easing curve name or data
|
|
|
* @param {Number|Array|Object} startState Animation start state
|
|
|
* @param {Number|Array|Object} endState Animation end state
|
|
|
* @param {Number} frameNum Number of Animation frames
|
|
|
* @param {Boolean} deep Whether to use recursive mode
|
|
|
* @return {Array|Boolean} State of each frame of the animation (Invalid input will return false)
|
|
|
*/
|
|
|
|
|
|
function transition(tBC) {
|
|
|
var startState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
|
|
|
var endState = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
|
|
|
var frameNum = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 30;
|
|
|
var deep = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
|
|
|
if (!checkParams.apply(void 0, arguments)) return false;
|
|
|
|
|
|
try {
|
|
|
// Get the transition bezier curve
|
|
|
var bezierCurve = getBezierCurve(tBC); // Get the progress of each frame state
|
|
|
|
|
|
var frameStateProgress = getFrameStateProgress(bezierCurve, frameNum); // If the recursion mode is not enabled or the state type is Number, the shallow state calculation is performed directly.
|
|
|
|
|
|
if (!deep || typeof endState === 'number') return getTransitionState(startState, endState, frameStateProgress);
|
|
|
return recursionTransitionState(startState, endState, frameStateProgress);
|
|
|
} catch (_unused) {
|
|
|
console.warn('Transition parameter may be abnormal!');
|
|
|
return [endState];
|
|
|
}
|
|
|
}
|
|
|
/**
|
|
|
* @description Check if the parameters are legal
|
|
|
* @param {String} tBC Name of transition bezier curve
|
|
|
* @param {Any} startState Transition start state
|
|
|
* @param {Any} endState Transition end state
|
|
|
* @param {Number} frameNum Number of transition frames
|
|
|
* @return {Boolean} Is the parameter legal
|
|
|
*/
|
|
|
|
|
|
|
|
|
function checkParams(tBC) {
|
|
|
var startState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
|
var endState = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
|
var frameNum = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 30;
|
|
|
|
|
|
if (!tBC || startState === false || endState === false || !frameNum) {
|
|
|
console.error('transition: Missing Parameters!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (_typeof(startState) !== _typeof(endState)) {
|
|
|
console.error('transition: Inconsistent Status Types!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
var stateType = _typeof(endState);
|
|
|
|
|
|
if (stateType === 'string' || stateType === 'boolean' || !tBC.length) {
|
|
|
console.error('transition: Unsupported Data Type of State!');
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
if (!_curves["default"].has(tBC) && !(tBC instanceof Array)) {
|
|
|
console.warn('transition: Transition curve not found, default curve will be used!');
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the transition bezier curve
|
|
|
* @param {String} tBC Name of transition bezier curve
|
|
|
* @return {Array} Bezier curve data
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getBezierCurve(tBC) {
|
|
|
var bezierCurve = '';
|
|
|
|
|
|
if (_curves["default"].has(tBC)) {
|
|
|
bezierCurve = _curves["default"].get(tBC);
|
|
|
} else if (tBC instanceof Array) {
|
|
|
bezierCurve = tBC;
|
|
|
} else {
|
|
|
bezierCurve = _curves["default"].get(defaultTransitionBC);
|
|
|
}
|
|
|
|
|
|
return bezierCurve;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the progress of each frame state
|
|
|
* @param {Array} bezierCurve Transition bezier curve
|
|
|
* @param {Number} frameNum Number of transition frames
|
|
|
* @return {Array} Progress of each frame state
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getFrameStateProgress(bezierCurve, frameNum) {
|
|
|
var tMinus = 1 / (frameNum - 1);
|
|
|
var tState = new Array(frameNum).fill(0).map(function (t, i) {
|
|
|
return i * tMinus;
|
|
|
});
|
|
|
var frameState = tState.map(function (t) {
|
|
|
return getFrameStateFromT(bezierCurve, t);
|
|
|
});
|
|
|
return frameState;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the progress of the corresponding frame according to t
|
|
|
* @param {Array} bezierCurve Transition bezier curve
|
|
|
* @param {Number} t Current frame t
|
|
|
* @return {Number} Progress of current frame
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getFrameStateFromT(bezierCurve, t) {
|
|
|
var tBezierCurvePoint = getBezierCurvePointFromT(bezierCurve, t);
|
|
|
var bezierCurvePointT = getBezierCurvePointTFromReT(tBezierCurvePoint, t);
|
|
|
return getBezierCurveTState(tBezierCurvePoint, bezierCurvePointT);
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the corresponding sub-curve according to t
|
|
|
* @param {Array} bezierCurve Transition bezier curve
|
|
|
* @param {Number} t Current frame t
|
|
|
* @return {Array} Sub-curve of t
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getBezierCurvePointFromT(bezierCurve, t) {
|
|
|
var lastIndex = bezierCurve.length - 1;
|
|
|
var begin = '',
|
|
|
end = '';
|
|
|
bezierCurve.findIndex(function (item, i) {
|
|
|
if (i === lastIndex) return;
|
|
|
begin = item;
|
|
|
end = bezierCurve[i + 1];
|
|
|
var currentMainPointX = begin[0][0];
|
|
|
var nextMainPointX = end[0][0];
|
|
|
return t >= currentMainPointX && t < nextMainPointX;
|
|
|
});
|
|
|
var p0 = begin[0];
|
|
|
var p1 = begin[2] || begin[0];
|
|
|
var p2 = end[1] || end[0];
|
|
|
var p3 = end[0];
|
|
|
return [p0, p1, p2, p3];
|
|
|
}
|
|
|
/**
|
|
|
* @description Get local t based on t and sub-curve
|
|
|
* @param {Array} bezierCurve Sub-curve
|
|
|
* @param {Number} t Current frame t
|
|
|
* @return {Number} local t of sub-curve
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getBezierCurvePointTFromReT(bezierCurve, t) {
|
|
|
var reBeginX = bezierCurve[0][0];
|
|
|
var reEndX = bezierCurve[3][0];
|
|
|
var xMinus = reEndX - reBeginX;
|
|
|
var tMinus = t - reBeginX;
|
|
|
return tMinus / xMinus;
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the curve progress of t
|
|
|
* @param {Array} bezierCurve Sub-curve
|
|
|
* @param {Number} t Current frame t
|
|
|
* @return {Number} Progress of current frame
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getBezierCurveTState(_ref, t) {
|
|
|
var _ref2 = _slicedToArray(_ref, 4),
|
|
|
_ref2$ = _slicedToArray(_ref2[0], 2),
|
|
|
p0 = _ref2$[1],
|
|
|
_ref2$2 = _slicedToArray(_ref2[1], 2),
|
|
|
p1 = _ref2$2[1],
|
|
|
_ref2$3 = _slicedToArray(_ref2[2], 2),
|
|
|
p2 = _ref2$3[1],
|
|
|
_ref2$4 = _slicedToArray(_ref2[3], 2),
|
|
|
p3 = _ref2$4[1];
|
|
|
|
|
|
var pow = Math.pow;
|
|
|
var tMinus = 1 - t;
|
|
|
var result1 = p0 * pow(tMinus, 3);
|
|
|
var result2 = 3 * p1 * t * pow(tMinus, 2);
|
|
|
var result3 = 3 * p2 * pow(t, 2) * tMinus;
|
|
|
var result4 = p3 * pow(t, 3);
|
|
|
return 1 - (result1 + result2 + result3 + result4);
|
|
|
}
|
|
|
/**
|
|
|
* @description Get transition state according to frame progress
|
|
|
* @param {Any} startState Transition start state
|
|
|
* @param {Any} endState Transition end state
|
|
|
* @param {Array} frameState Frame state progress
|
|
|
* @return {Array} Transition frame state
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getTransitionState(begin, end, frameState) {
|
|
|
var stateType = 'object';
|
|
|
if (typeof begin === 'number') stateType = 'number';
|
|
|
if (begin instanceof Array) stateType = 'array';
|
|
|
if (stateType === 'number') return getNumberTransitionState(begin, end, frameState);
|
|
|
if (stateType === 'array') return getArrayTransitionState(begin, end, frameState);
|
|
|
if (stateType === 'object') return getObjectTransitionState(begin, end, frameState);
|
|
|
return frameState.map(function (t) {
|
|
|
return end;
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the transition data of the number type
|
|
|
* @param {Number} startState Transition start state
|
|
|
* @param {Number} endState Transition end state
|
|
|
* @param {Array} frameState Frame state progress
|
|
|
* @return {Array} Transition frame state
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getNumberTransitionState(begin, end, frameState) {
|
|
|
var minus = end - begin;
|
|
|
return frameState.map(function (s) {
|
|
|
return begin + minus * s;
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the transition data of the array type
|
|
|
* @param {Array} startState Transition start state
|
|
|
* @param {Array} endState Transition end state
|
|
|
* @param {Array} frameState Frame state progress
|
|
|
* @return {Array} Transition frame state
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getArrayTransitionState(begin, end, frameState) {
|
|
|
var minus = end.map(function (v, i) {
|
|
|
if (typeof v !== 'number') return false;
|
|
|
return v - begin[i];
|
|
|
});
|
|
|
return frameState.map(function (s) {
|
|
|
return minus.map(function (v, i) {
|
|
|
if (v === false) return end[i];
|
|
|
return begin[i] + v * s;
|
|
|
});
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the transition data of the object type
|
|
|
* @param {Object} startState Transition start state
|
|
|
* @param {Object} endState Transition end state
|
|
|
* @param {Array} frameState Frame state progress
|
|
|
* @return {Array} Transition frame state
|
|
|
*/
|
|
|
|
|
|
|
|
|
function getObjectTransitionState(begin, end, frameState) {
|
|
|
var keys = Object.keys(end);
|
|
|
var beginValue = keys.map(function (k) {
|
|
|
return begin[k];
|
|
|
});
|
|
|
var endValue = keys.map(function (k) {
|
|
|
return end[k];
|
|
|
});
|
|
|
var arrayState = getArrayTransitionState(beginValue, endValue, frameState);
|
|
|
return arrayState.map(function (item) {
|
|
|
var frameData = {};
|
|
|
item.forEach(function (v, i) {
|
|
|
return frameData[keys[i]] = v;
|
|
|
});
|
|
|
return frameData;
|
|
|
});
|
|
|
}
|
|
|
/**
|
|
|
* @description Get the transition state data by recursion
|
|
|
* @param {Array|Object} startState Transition start state
|
|
|
* @param {Array|Object} endState Transition end state
|
|
|
* @param {Array} frameState Frame state progress
|
|
|
* @return {Array} Transition frame state
|
|
|
*/
|
|
|
|
|
|
|
|
|
function recursionTransitionState(begin, end, frameState) {
|
|
|
var state = getTransitionState(begin, end, frameState);
|
|
|
|
|
|
var _loop = function _loop(key) {
|
|
|
var bTemp = begin[key];
|
|
|
var eTemp = end[key];
|
|
|
if (_typeof(eTemp) !== 'object') return "continue";
|
|
|
var data = recursionTransitionState(bTemp, eTemp, frameState);
|
|
|
state.forEach(function (fs, i) {
|
|
|
return fs[key] = data[i];
|
|
|
});
|
|
|
};
|
|
|
|
|
|
for (var key in end) {
|
|
|
var _ret = _loop(key);
|
|
|
|
|
|
if (_ret === "continue") continue;
|
|
|
}
|
|
|
|
|
|
return state;
|
|
|
}
|
|
|
/**
|
|
|
* @description Inject new curve into curves as config
|
|
|
* @param {Any} key The key of curve
|
|
|
* @param {Array} curve Bezier curve data
|
|
|
* @return {Undefined} No return
|
|
|
*/
|
|
|
|
|
|
|
|
|
function injectNewCurve(key, curve) {
|
|
|
if (!key || !curve) {
|
|
|
console.error('InjectNewCurve Missing Parameters!');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
_curves["default"].set(key, curve);
|
|
|
}
|
|
|
|
|
|
var _default = transition;
|
|
|
exports["default"] = _default;
|
|
|
},{"./config/curves":28}],30:[function(require,module,exports){
|
|
|
/**
|
|
|
* Copyright (c) 2014-present, Facebook, Inc.
|
|
|
*
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
* LICENSE file in the root directory of this source tree.
|
|
|
*/
|
|
|
|
|
|
var runtime = (function (exports) {
|
|
|
"use strict";
|
|
|
|
|
|
var Op = Object.prototype;
|
|
|
var hasOwn = Op.hasOwnProperty;
|
|
|
var undefined; // More compressible than void 0.
|
|
|
var $Symbol = typeof Symbol === "function" ? Symbol : {};
|
|
|
var iteratorSymbol = $Symbol.iterator || "@@iterator";
|
|
|
var asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator";
|
|
|
var toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag";
|
|
|
|
|
|
function wrap(innerFn, outerFn, self, tryLocsList) {
|
|
|
// If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.
|
|
|
var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;
|
|
|
var generator = Object.create(protoGenerator.prototype);
|
|
|
var context = new Context(tryLocsList || []);
|
|
|
|
|
|
// The ._invoke method unifies the implementations of the .next,
|
|
|
// .throw, and .return methods.
|
|
|
generator._invoke = makeInvokeMethod(innerFn, self, context);
|
|
|
|
|
|
return generator;
|
|
|
}
|
|
|
exports.wrap = wrap;
|
|
|
|
|
|
// Try/catch helper to minimize deoptimizations. Returns a completion
|
|
|
// record like context.tryEntries[i].completion. This interface could
|
|
|
// have been (and was previously) designed to take a closure to be
|
|
|
// invoked without arguments, but in all the cases we care about we
|
|
|
// already have an existing method we want to call, so there's no need
|
|
|
// to create a new function object. We can even get away with assuming
|
|
|
// the method takes exactly one argument, since that happens to be true
|
|
|
// in every case, so we don't have to touch the arguments object. The
|
|
|
// only additional allocation required is the completion record, which
|
|
|
// has a stable shape and so hopefully should be cheap to allocate.
|
|
|
function tryCatch(fn, obj, arg) {
|
|
|
try {
|
|
|
return { type: "normal", arg: fn.call(obj, arg) };
|
|
|
} catch (err) {
|
|
|
return { type: "throw", arg: err };
|
|
|
}
|
|
|
}
|
|
|
|
|
|
var GenStateSuspendedStart = "suspendedStart";
|
|
|
var GenStateSuspendedYield = "suspendedYield";
|
|
|
var GenStateExecuting = "executing";
|
|
|
var GenStateCompleted = "completed";
|
|
|
|
|
|
// Returning this object from the innerFn has the same effect as
|
|
|
// breaking out of the dispatch switch statement.
|
|
|
var ContinueSentinel = {};
|
|
|
|
|
|
// Dummy constructor functions that we use as the .constructor and
|
|
|
// .constructor.prototype properties for functions that return Generator
|
|
|
// objects. For full spec compliance, you may wish to configure your
|
|
|
// minifier not to mangle the names of these two functions.
|
|
|
function Generator() {}
|
|
|
function GeneratorFunction() {}
|
|
|
function GeneratorFunctionPrototype() {}
|
|
|
|
|
|
// This is a polyfill for %IteratorPrototype% for environments that
|
|
|
// don't natively support it.
|
|
|
var IteratorPrototype = {};
|
|
|
IteratorPrototype[iteratorSymbol] = function () {
|
|
|
return this;
|
|
|
};
|
|
|
|
|
|
var getProto = Object.getPrototypeOf;
|
|
|
var NativeIteratorPrototype = getProto && getProto(getProto(values([])));
|
|
|
if (NativeIteratorPrototype &&
|
|
|
NativeIteratorPrototype !== Op &&
|
|
|
hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {
|
|
|
// This environment has a native %IteratorPrototype%; use it instead
|
|
|
// of the polyfill.
|
|
|
IteratorPrototype = NativeIteratorPrototype;
|
|
|
}
|
|
|
|
|
|
var Gp = GeneratorFunctionPrototype.prototype =
|
|
|
Generator.prototype = Object.create(IteratorPrototype);
|
|
|
GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;
|
|
|
GeneratorFunctionPrototype.constructor = GeneratorFunction;
|
|
|
GeneratorFunctionPrototype[toStringTagSymbol] =
|
|
|
GeneratorFunction.displayName = "GeneratorFunction";
|
|
|
|
|
|
// Helper for defining the .next, .throw, and .return methods of the
|
|
|
// Iterator interface in terms of a single ._invoke method.
|
|
|
function defineIteratorMethods(prototype) {
|
|
|
["next", "throw", "return"].forEach(function(method) {
|
|
|
prototype[method] = function(arg) {
|
|
|
return this._invoke(method, arg);
|
|
|
};
|
|
|
});
|
|
|
}
|
|
|
|
|
|
exports.isGeneratorFunction = function(genFun) {
|
|
|
var ctor = typeof genFun === "function" && genFun.constructor;
|
|
|
return ctor
|
|
|
? ctor === GeneratorFunction ||
|
|
|
// For the native GeneratorFunction constructor, the best we can
|
|
|
// do is to check its .name property.
|
|
|
(ctor.displayName || ctor.name) === "GeneratorFunction"
|
|
|
: false;
|
|
|
};
|
|
|
|
|
|
exports.mark = function(genFun) {
|
|
|
if (Object.setPrototypeOf) {
|
|
|
Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);
|
|
|
} else {
|
|
|
genFun.__proto__ = GeneratorFunctionPrototype;
|
|
|
if (!(toStringTagSymbol in genFun)) {
|
|
|
genFun[toStringTagSymbol] = "GeneratorFunction";
|
|
|
}
|
|
|
}
|
|
|
genFun.prototype = Object.create(Gp);
|
|
|
return genFun;
|
|
|
};
|
|
|
|
|
|
// Within the body of any async function, `await x` is transformed to
|
|
|
// `yield regeneratorRuntime.awrap(x)`, so that the runtime can test
|
|
|
// `hasOwn.call(value, "__await")` to determine if the yielded value is
|
|
|
// meant to be awaited.
|
|
|
exports.awrap = function(arg) {
|
|
|
return { __await: arg };
|
|
|
};
|
|
|
|
|
|
function AsyncIterator(generator) {
|
|
|
function invoke(method, arg, resolve, reject) {
|
|
|
var record = tryCatch(generator[method], generator, arg);
|
|
|
if (record.type === "throw") {
|
|
|
reject(record.arg);
|
|
|
} else {
|
|
|
var result = record.arg;
|
|
|
var value = result.value;
|
|
|
if (value &&
|
|
|
typeof value === "object" &&
|
|
|
hasOwn.call(value, "__await")) {
|
|
|
return Promise.resolve(value.__await).then(function(value) {
|
|
|
invoke("next", value, resolve, reject);
|
|
|
}, function(err) {
|
|
|
invoke("throw", err, resolve, reject);
|
|
|
});
|
|
|
}
|
|
|
|
|
|
return Promise.resolve(value).then(function(unwrapped) {
|
|
|
// When a yielded Promise is resolved, its final value becomes
|
|
|
// the .value of the Promise<{value,done}> result for the
|
|
|
// current iteration.
|
|
|
result.value = unwrapped;
|
|
|
resolve(result);
|
|
|
}, function(error) {
|
|
|
// If a rejected Promise was yielded, throw the rejection back
|
|
|
// into the async generator function so it can be handled there.
|
|
|
return invoke("throw", error, resolve, reject);
|
|
|
});
|
|
|
}
|
|
|
}
|
|
|
|
|
|
var previousPromise;
|
|
|
|
|
|
function enqueue(method, arg) {
|
|
|
function callInvokeWithMethodAndArg() {
|
|
|
return new Promise(function(resolve, reject) {
|
|
|
invoke(method, arg, resolve, reject);
|
|
|
});
|
|
|
}
|
|
|
|
|
|
return previousPromise =
|
|
|
// If enqueue has been called before, then we want to wait until
|
|
|
// all previous Promises have been resolved before calling invoke,
|
|
|
// so that results are always delivered in the correct order. If
|
|
|
// enqueue has not been called before, then it is important to
|
|
|
// call invoke immediately, without waiting on a callback to fire,
|
|
|
// so that the async generator function has the opportunity to do
|
|
|
// any necessary setup in a predictable way. This predictability
|
|
|
// is why the Promise constructor synchronously invokes its
|
|
|
// executor callback, and why async functions synchronously
|
|
|
// execute code before the first await. Since we implement simple
|
|
|
// async functions in terms of async generators, it is especially
|
|
|
// important to get this right, even though it requires care.
|
|
|
previousPromise ? previousPromise.then(
|
|
|
callInvokeWithMethodAndArg,
|
|
|
// Avoid propagating failures to Promises returned by later
|
|
|
// invocations of the iterator.
|
|
|
callInvokeWithMethodAndArg
|
|
|
) : callInvokeWithMethodAndArg();
|
|
|
}
|
|
|
|
|
|
// Define the unified helper method that is used to implement .next,
|
|
|
// .throw, and .return (see defineIteratorMethods).
|
|
|
this._invoke = enqueue;
|
|
|
}
|
|
|
|
|
|
defineIteratorMethods(AsyncIterator.prototype);
|
|
|
AsyncIterator.prototype[asyncIteratorSymbol] = function () {
|
|
|
return this;
|
|
|
};
|
|
|
exports.AsyncIterator = AsyncIterator;
|
|
|
|
|
|
// Note that simple async functions are implemented on top of
|
|
|
// AsyncIterator objects; they just return a Promise for the value of
|
|
|
// the final result produced by the iterator.
|
|
|
exports.async = function(innerFn, outerFn, self, tryLocsList) {
|
|
|
var iter = new AsyncIterator(
|
|
|
wrap(innerFn, outerFn, self, tryLocsList)
|
|
|
);
|
|
|
|
|
|
return exports.isGeneratorFunction(outerFn)
|
|
|
? iter // If outerFn is a generator, return the full iterator.
|
|
|
: iter.next().then(function(result) {
|
|
|
return result.done ? result.value : iter.next();
|
|
|
});
|
|
|
};
|
|
|
|
|
|
function makeInvokeMethod(innerFn, self, context) {
|
|
|
var state = GenStateSuspendedStart;
|
|
|
|
|
|
return function invoke(method, arg) {
|
|
|
if (state === GenStateExecuting) {
|
|
|
throw new Error("Generator is already running");
|
|
|
}
|
|
|
|
|
|
if (state === GenStateCompleted) {
|
|
|
if (method === "throw") {
|
|
|
throw arg;
|
|
|
}
|
|
|
|
|
|
// Be forgiving, per 25.3.3.3.3 of the spec:
|
|
|
// https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume
|
|
|
return doneResult();
|
|
|
}
|
|
|
|
|
|
context.method = method;
|
|
|
context.arg = arg;
|
|
|
|
|
|
while (true) {
|
|
|
var delegate = context.delegate;
|
|
|
if (delegate) {
|
|
|
var delegateResult = maybeInvokeDelegate(delegate, context);
|
|
|
if (delegateResult) {
|
|
|
if (delegateResult === ContinueSentinel) continue;
|
|
|
return delegateResult;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
if (context.method === "next") {
|
|
|
// Setting context._sent for legacy support of Babel's
|
|
|
// function.sent implementation.
|
|
|
context.sent = context._sent = context.arg;
|
|
|
|
|
|
} else if (context.method === "throw") {
|
|
|
if (state === GenStateSuspendedStart) {
|
|
|
state = GenStateCompleted;
|
|
|
throw context.arg;
|
|
|
}
|
|
|
|
|
|
context.dispatchException(context.arg);
|
|
|
|
|
|
} else if (context.method === "return") {
|
|
|
context.abrupt("return", context.arg);
|
|
|
}
|
|
|
|
|
|
state = GenStateExecuting;
|
|
|
|
|
|
var record = tryCatch(innerFn, self, context);
|
|
|
if (record.type === "normal") {
|
|
|
// If an exception is thrown from innerFn, we leave state ===
|
|
|
// GenStateExecuting and loop back for another invocation.
|
|
|
state = context.done
|
|
|
? GenStateCompleted
|
|
|
: GenStateSuspendedYield;
|
|
|
|
|
|
if (record.arg === ContinueSentinel) {
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
return {
|
|
|
value: record.arg,
|
|
|
done: context.done
|
|
|
};
|
|
|
|
|
|
} else if (record.type === "throw") {
|
|
|
state = GenStateCompleted;
|
|
|
// Dispatch the exception by looping back around to the
|
|
|
// context.dispatchException(context.arg) call above.
|
|
|
context.method = "throw";
|
|
|
context.arg = record.arg;
|
|
|
}
|
|
|
}
|
|
|
};
|
|
|
}
|
|
|
|
|
|
// Call delegate.iterator[context.method](context.arg) and handle the
|
|
|
// result, either by returning a { value, done } result from the
|
|
|
// delegate iterator, or by modifying context.method and context.arg,
|
|
|
// setting context.delegate to null, and returning the ContinueSentinel.
|
|
|
function maybeInvokeDelegate(delegate, context) {
|
|
|
var method = delegate.iterator[context.method];
|
|
|
if (method === undefined) {
|
|
|
// A .throw or .return when the delegate iterator has no .throw
|
|
|
// method always terminates the yield* loop.
|
|
|
context.delegate = null;
|
|
|
|
|
|
if (context.method === "throw") {
|
|
|
// Note: ["return"] must be used for ES3 parsing compatibility.
|
|
|
if (delegate.iterator["return"]) {
|
|
|
// If the delegate iterator has a return method, give it a
|
|
|
// chance to clean up.
|
|
|
context.method = "return";
|
|
|
context.arg = undefined;
|
|
|
maybeInvokeDelegate(delegate, context);
|
|
|
|
|
|
if (context.method === "throw") {
|
|
|
// If maybeInvokeDelegate(context) changed context.method from
|
|
|
// "return" to "throw", let that override the TypeError below.
|
|
|
return ContinueSentinel;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
context.method = "throw";
|
|
|
context.arg = new TypeError(
|
|
|
"The iterator does not provide a 'throw' method");
|
|
|
}
|
|
|
|
|
|
return ContinueSentinel;
|
|
|
}
|
|
|
|
|
|
var record = tryCatch(method, delegate.iterator, context.arg);
|
|
|
|
|
|
if (record.type === "throw") {
|
|
|
context.method = "throw";
|
|
|
context.arg = record.arg;
|
|
|
context.delegate = null;
|
|
|
return ContinueSentinel;
|
|
|
}
|
|
|
|
|
|
var info = record.arg;
|
|
|
|
|
|
if (! info) {
|
|
|
context.method = "throw";
|
|
|
context.arg = new TypeError("iterator result is not an object");
|
|
|
context.delegate = null;
|
|
|
return ContinueSentinel;
|
|
|
}
|
|
|
|
|
|
if (info.done) {
|
|
|
// Assign the result of the finished delegate to the temporary
|
|
|
// variable specified by delegate.resultName (see delegateYield).
|
|
|
context[delegate.resultName] = info.value;
|
|
|
|
|
|
// Resume execution at the desired location (see delegateYield).
|
|
|
context.next = delegate.nextLoc;
|
|
|
|
|
|
// If context.method was "throw" but the delegate handled the
|
|
|
// exception, let the outer generator proceed normally. If
|
|
|
// context.method was "next", forget context.arg since it has been
|
|
|
// "consumed" by the delegate iterator. If context.method was
|
|
|
// "return", allow the original .return call to continue in the
|
|
|
// outer generator.
|
|
|
if (context.method !== "return") {
|
|
|
context.method = "next";
|
|
|
context.arg = undefined;
|
|
|
}
|
|
|
|
|
|
} else {
|
|
|
// Re-yield the result returned by the delegate method.
|
|
|
return info;
|
|
|
}
|
|
|
|
|
|
// The delegate iterator is finished, so forget it and continue with
|
|
|
// the outer generator.
|
|
|
context.delegate = null;
|
|
|
return ContinueSentinel;
|
|
|
}
|
|
|
|
|
|
// Define Generator.prototype.{next,throw,return} in terms of the
|
|
|
// unified ._invoke helper method.
|
|
|
defineIteratorMethods(Gp);
|
|
|
|
|
|
Gp[toStringTagSymbol] = "Generator";
|
|
|
|
|
|
// A Generator should always return itself as the iterator object when the
|
|
|
// @@iterator function is called on it. Some browsers' implementations of the
|
|
|
// iterator prototype chain incorrectly implement this, causing the Generator
|
|
|
// object to not be returned from this call. This ensures that doesn't happen.
|
|
|
// See https://github.com/facebook/regenerator/issues/274 for more details.
|
|
|
Gp[iteratorSymbol] = function() {
|
|
|
return this;
|
|
|
};
|
|
|
|
|
|
Gp.toString = function() {
|
|
|
return "[object Generator]";
|
|
|
};
|
|
|
|
|
|
function pushTryEntry(locs) {
|
|
|
var entry = { tryLoc: locs[0] };
|
|
|
|
|
|
if (1 in locs) {
|
|
|
entry.catchLoc = locs[1];
|
|
|
}
|
|
|
|
|
|
if (2 in locs) {
|
|
|
entry.finallyLoc = locs[2];
|
|
|
entry.afterLoc = locs[3];
|
|
|
}
|
|
|
|
|
|
this.tryEntries.push(entry);
|
|
|
}
|
|
|
|
|
|
function resetTryEntry(entry) {
|
|
|
var record = entry.completion || {};
|
|
|
record.type = "normal";
|
|
|
delete record.arg;
|
|
|
entry.completion = record;
|
|
|
}
|
|
|
|
|
|
function Context(tryLocsList) {
|
|
|
// The root entry object (effectively a try statement without a catch
|
|
|
// or a finally block) gives us a place to store values thrown from
|
|
|
// locations where there is no enclosing try statement.
|
|
|
this.tryEntries = [{ tryLoc: "root" }];
|
|
|
tryLocsList.forEach(pushTryEntry, this);
|
|
|
this.reset(true);
|
|
|
}
|
|
|
|
|
|
exports.keys = function(object) {
|
|
|
var keys = [];
|
|
|
for (var key in object) {
|
|
|
keys.push(key);
|
|
|
}
|
|
|
keys.reverse();
|
|
|
|
|
|
// Rather than returning an object with a next method, we keep
|
|
|
// things simple and return the next function itself.
|
|
|
return function next() {
|
|
|
while (keys.length) {
|
|
|
var key = keys.pop();
|
|
|
if (key in object) {
|
|
|
next.value = key;
|
|
|
next.done = false;
|
|
|
return next;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// To avoid creating an additional object, we just hang the .value
|
|
|
// and .done properties off the next function object itself. This
|
|
|
// also ensures that the minifier will not anonymize the function.
|
|
|
next.done = true;
|
|
|
return next;
|
|
|
};
|
|
|
};
|
|
|
|
|
|
function values(iterable) {
|
|
|
if (iterable) {
|
|
|
var iteratorMethod = iterable[iteratorSymbol];
|
|
|
if (iteratorMethod) {
|
|
|
return iteratorMethod.call(iterable);
|
|
|
}
|
|
|
|
|
|
if (typeof iterable.next === "function") {
|
|
|
return iterable;
|
|
|
}
|
|
|
|
|
|
if (!isNaN(iterable.length)) {
|
|
|
var i = -1, next = function next() {
|
|
|
while (++i < iterable.length) {
|
|
|
if (hasOwn.call(iterable, i)) {
|
|
|
next.value = iterable[i];
|
|
|
next.done = false;
|
|
|
return next;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
next.value = undefined;
|
|
|
next.done = true;
|
|
|
|
|
|
return next;
|
|
|
};
|
|
|
|
|
|
return next.next = next;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// Return an iterator with no values.
|
|
|
return { next: doneResult };
|
|
|
}
|
|
|
exports.values = values;
|
|
|
|
|
|
function doneResult() {
|
|
|
return { value: undefined, done: true };
|
|
|
}
|
|
|
|
|
|
Context.prototype = {
|
|
|
constructor: Context,
|
|
|
|
|
|
reset: function(skipTempReset) {
|
|
|
this.prev = 0;
|
|
|
this.next = 0;
|
|
|
// Resetting context._sent for legacy support of Babel's
|
|
|
// function.sent implementation.
|
|
|
this.sent = this._sent = undefined;
|
|
|
this.done = false;
|
|
|
this.delegate = null;
|
|
|
|
|
|
this.method = "next";
|
|
|
this.arg = undefined;
|
|
|
|
|
|
this.tryEntries.forEach(resetTryEntry);
|
|
|
|
|
|
if (!skipTempReset) {
|
|
|
for (var name in this) {
|
|
|
// Not sure about the optimal order of these conditions:
|
|
|
if (name.charAt(0) === "t" &&
|
|
|
hasOwn.call(this, name) &&
|
|
|
!isNaN(+name.slice(1))) {
|
|
|
this[name] = undefined;
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
|
|
|
stop: function() {
|
|
|
this.done = true;
|
|
|
|
|
|
var rootEntry = this.tryEntries[0];
|
|
|
var rootRecord = rootEntry.completion;
|
|
|
if (rootRecord.type === "throw") {
|
|
|
throw rootRecord.arg;
|
|
|
}
|
|
|
|
|
|
return this.rval;
|
|
|
},
|
|
|
|
|
|
dispatchException: function(exception) {
|
|
|
if (this.done) {
|
|
|
throw exception;
|
|
|
}
|
|
|
|
|
|
var context = this;
|
|
|
function handle(loc, caught) {
|
|
|
record.type = "throw";
|
|
|
record.arg = exception;
|
|
|
context.next = loc;
|
|
|
|
|
|
if (caught) {
|
|
|
// If the dispatched exception was caught by a catch block,
|
|
|
// then let that catch block handle the exception normally.
|
|
|
context.method = "next";
|
|
|
context.arg = undefined;
|
|
|
}
|
|
|
|
|
|
return !! caught;
|
|
|
}
|
|
|
|
|
|
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
|
|
|
var entry = this.tryEntries[i];
|
|
|
var record = entry.completion;
|
|
|
|
|
|
if (entry.tryLoc === "root") {
|
|
|
// Exception thrown outside of any try block that could handle
|
|
|
// it, so set the completion value of the entire function to
|
|
|
// throw the exception.
|
|
|
return handle("end");
|
|
|
}
|
|
|
|
|
|
if (entry.tryLoc <= this.prev) {
|
|
|
var hasCatch = hasOwn.call(entry, "catchLoc");
|
|
|
var hasFinally = hasOwn.call(entry, "finallyLoc");
|
|
|
|
|
|
if (hasCatch && hasFinally) {
|
|
|
if (this.prev < entry.catchLoc) {
|
|
|
return handle(entry.catchLoc, true);
|
|
|
} else if (this.prev < entry.finallyLoc) {
|
|
|
return handle(entry.finallyLoc);
|
|
|
}
|
|
|
|
|
|
} else if (hasCatch) {
|
|
|
if (this.prev < entry.catchLoc) {
|
|
|
return handle(entry.catchLoc, true);
|
|
|
}
|
|
|
|
|
|
} else if (hasFinally) {
|
|
|
if (this.prev < entry.finallyLoc) {
|
|
|
return handle(entry.finallyLoc);
|
|
|
}
|
|
|
|
|
|
} else {
|
|
|
throw new Error("try statement without catch or finally");
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
|
|
|
abrupt: function(type, arg) {
|
|
|
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
|
|
|
var entry = this.tryEntries[i];
|
|
|
if (entry.tryLoc <= this.prev &&
|
|
|
hasOwn.call(entry, "finallyLoc") &&
|
|
|
this.prev < entry.finallyLoc) {
|
|
|
var finallyEntry = entry;
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
if (finallyEntry &&
|
|
|
(type === "break" ||
|
|
|
type === "continue") &&
|
|
|
finallyEntry.tryLoc <= arg &&
|
|
|
arg <= finallyEntry.finallyLoc) {
|
|
|
// Ignore the finally entry if control is not jumping to a
|
|
|
// location outside the try/catch block.
|
|
|
finallyEntry = null;
|
|
|
}
|
|
|
|
|
|
var record = finallyEntry ? finallyEntry.completion : {};
|
|
|
record.type = type;
|
|
|
record.arg = arg;
|
|
|
|
|
|
if (finallyEntry) {
|
|
|
this.method = "next";
|
|
|
this.next = finallyEntry.finallyLoc;
|
|
|
return ContinueSentinel;
|
|
|
}
|
|
|
|
|
|
return this.complete(record);
|
|
|
},
|
|
|
|
|
|
complete: function(record, afterLoc) {
|
|
|
if (record.type === "throw") {
|
|
|
throw record.arg;
|
|
|
}
|
|
|
|
|
|
if (record.type === "break" ||
|
|
|
record.type === "continue") {
|
|
|
this.next = record.arg;
|
|
|
} else if (record.type === "return") {
|
|
|
this.rval = this.arg = record.arg;
|
|
|
this.method = "return";
|
|
|
this.next = "end";
|
|
|
} else if (record.type === "normal" && afterLoc) {
|
|
|
this.next = afterLoc;
|
|
|
}
|
|
|
|
|
|
return ContinueSentinel;
|
|
|
},
|
|
|
|
|
|
finish: function(finallyLoc) {
|
|
|
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
|
|
|
var entry = this.tryEntries[i];
|
|
|
if (entry.finallyLoc === finallyLoc) {
|
|
|
this.complete(entry.completion, entry.afterLoc);
|
|
|
resetTryEntry(entry);
|
|
|
return ContinueSentinel;
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
|
|
|
"catch": function(tryLoc) {
|
|
|
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
|
|
|
var entry = this.tryEntries[i];
|
|
|
if (entry.tryLoc === tryLoc) {
|
|
|
var record = entry.completion;
|
|
|
if (record.type === "throw") {
|
|
|
var thrown = record.arg;
|
|
|
resetTryEntry(entry);
|
|
|
}
|
|
|
return thrown;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// The context.catch method must only be called with a location
|
|
|
// argument that corresponds to a known catch block.
|
|
|
throw new Error("illegal catch attempt");
|
|
|
},
|
|
|
|
|
|
delegateYield: function(iterable, resultName, nextLoc) {
|
|
|
this.delegate = {
|
|
|
iterator: values(iterable),
|
|
|
resultName: resultName,
|
|
|
nextLoc: nextLoc
|
|
|
};
|
|
|
|
|
|
if (this.method === "next") {
|
|
|
// Deliberately forget the last sent value so that we don't
|
|
|
// accidentally pass it on to the delegate.
|
|
|
this.arg = undefined;
|
|
|
}
|
|
|
|
|
|
return ContinueSentinel;
|
|
|
}
|
|
|
};
|
|
|
|
|
|
// Regardless of whether this script is executing as a CommonJS module
|
|
|
// or not, return the runtime object so that we can declare the variable
|
|
|
// regeneratorRuntime in the outer scope, which allows this module to be
|
|
|
// injected easily by `bin/regenerator --include-runtime script.js`.
|
|
|
return exports;
|
|
|
|
|
|
}(
|
|
|
// If this script is executing as a CommonJS module, use module.exports
|
|
|
// as the regeneratorRuntime namespace. Otherwise create a new empty
|
|
|
// object. Either way, the resulting object will be used to initialize
|
|
|
// the regeneratorRuntime variable at the top of this file.
|
|
|
typeof module === "object" ? module.exports : {}
|
|
|
));
|
|
|
|
|
|
try {
|
|
|
regeneratorRuntime = runtime;
|
|
|
} catch (accidentalStrictMode) {
|
|
|
// This module should not be running in strict mode, so the above
|
|
|
// assignment should always work unless something is misconfigured. Just
|
|
|
// in case runtime.js accidentally runs in strict mode, we can escape
|
|
|
// strict mode using a global Function call. This could conceivably fail
|
|
|
// if a Content Security Policy forbids using Function, but in that case
|
|
|
// the proper solution is to fix the accidental strict mode problem. If
|
|
|
// you've misconfigured your bundler to force strict mode and applied a
|
|
|
// CSP to forbid Function, and you're not willing to fix either of those
|
|
|
// problems, please detail your unique predicament in a GitHub issue.
|
|
|
Function("r", "regeneratorRuntime = r")(runtime);
|
|
|
}
|
|
|
|
|
|
},{}]},{},[1])
|
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","build/entry.js","lib/class/crender.class.js","lib/class/graph.class.js","lib/class/style.class.js","lib/config/graphs.js","lib/index.js","lib/plugin/canvas.js","lib/plugin/util.js","node_modules/@babel/runtime/helpers/arrayWithHoles.js","node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","node_modules/@babel/runtime/helpers/asyncToGenerator.js","node_modules/@babel/runtime/helpers/classCallCheck.js","node_modules/@babel/runtime/helpers/defineProperty.js","node_modules/@babel/runtime/helpers/interopRequireDefault.js","node_modules/@babel/runtime/helpers/iterableToArray.js","node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","node_modules/@babel/runtime/helpers/nonIterableRest.js","node_modules/@babel/runtime/helpers/nonIterableSpread.js","node_modules/@babel/runtime/helpers/slicedToArray.js","node_modules/@babel/runtime/helpers/toConsumableArray.js","node_modules/@babel/runtime/helpers/typeof.js","node_modules/@babel/runtime/regenerator/index.js","node_modules/@jiaminghi/bezier-curve/lib/core/bezierCurveToPolyline.js","node_modules/@jiaminghi/bezier-curve/lib/core/polylineToBezierCurve.js","node_modules/@jiaminghi/bezier-curve/lib/index.js","node_modules/@jiaminghi/color/lib/config/keywords.js","node_modules/@jiaminghi/color/lib/index.js","node_modules/@jiaminghi/transition/lib/config/curves.js","node_modules/@jiaminghi/transition/lib/index.js","node_modules/regenerator-runtime/runtime.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5XA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxeA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7eA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACp4BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrcA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/SA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","var CRender = require('../lib/index')\r\n\r\nwindow.CRender = CRender","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports[\"default\"] = void 0;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _color = _interopRequireDefault(require(\"@jiaminghi/color\"));\n\nvar _bezierCurve = _interopRequireDefault(require(\"@jiaminghi/bezier-curve\"));\n\nvar _util = require(\"../plugin/util\");\n\nvar _graphs = _interopRequireDefault(require(\"../config/graphs\"));\n\nvar _graph = _interopRequireDefault(require(\"./graph.class\"));\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\n/**\r\n * @description           Class of CRender\r\n * @param {Object} canvas Canvas DOM\r\n * @return {CRender}      Instance of CRender\r\n */\nvar CRender = function CRender(canvas) {\n  (0, _classCallCheck2[\"default\"])(this, CRender);\n\n  if (!canvas) {\n    console.error('CRender Missing parameters!');\n    return;\n  }\n\n  var ctx = canvas.getContext('2d');\n  var clientWidth = canvas.clientWidth,\n      clientHeight = canvas.clientHeight;\n  var area = [clientWidth, clientHeight];\n  canvas.setAttribute('width', clientWidth);\n  canvas.setAttribute('height', clientHeight);\n  /**\r\n   * @description Context of the canvas\r\n   * @type {Object}\r\n   * @example ctx = canvas.getContext('2d')\r\n   */\n\n  this.ctx = ctx;\n  /**\r\n   * @description Width and height of the canvas\r\n   * @type {Array}\r\n   * @example area = [300，100]\r\n   */\n\n  this.area = area;\n  /**\r\n   * @description Whether render is in animation rendering\r\n   * @type {Boolean}\r\n   * @example animationStatus = true|false\r\n   */\n\n  this.animationStatus = false;\n  /**\r\n   * @description Added graph\r\n   * @type {[Graph]}\r\n   * @example graphs = [Graph, Graph, ...]\r\n   */\n\n  this.graphs = [];\n  /**\r\n   * @description Color plugin\r\n   * @type {Object}\r\n   * @link https://github.com/jiaming743/color\r\n   */\n\n  this.color = _color[\"default\"];\n  /**\r\n   * @description Bezier Curve plugin\r\n   * @type {Object}\r\n   * @link https://github.com/jiaming743/BezierCurve\r\n   */\n\n  this.bezierCurve = _bezierCurve[\"default\"]; // bind event handler\n\n  canvas.addEventListener('mousedown', mouseDown.bind(this));\n  canvas.addEventListener('mousemove', mouseMove.bind(this));\n  canvas.addEventListener('mouseup', mouseUp.bind(this));\n};\n/**\r\n * @description        Clear canvas drawing area\r\n * @return {Undefined} Void\r\n */\n\n\nexports[\"default\"] = CRender;\n\nCRender.prototype.clearArea = function () {\n  var _this$ctx;\n\n  var area = this.area;\n\n  (_this$ctx = this.ctx).clearRect.apply(_this$ctx, [0, 0].concat((0, _toConsumableArray2[\"default\"])(area)));\n};\n/**\r\n * @description           Add graph to render\r\n * @param {Object} config Graph configuration\r\n * @return {Graph}        Graph instance\r\n */\n\n\nCRender.prototype.add = function () {\n  var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n  var name = config.name;\n\n  if (!name) {\n    console.error('add Missing parameters!');\n    return;\n  }\n\n  var graphConfig = _graphs[\"default\"].get(name);\n\n  if (!graphConfig) {\n    console.warn('No corresponding graph configuration found!');\n    return;\n  }\n\n  var graph = new _graph[\"default\"](graphConfig, config);\n  if (!graph.validator(graph)) return;\n  graph.render = this;\n  this.graphs.push(graph);\n  this.sortGraphsByIndex();\n  this.drawAllGraph();\n  return graph;\n};\n/**\r\n * @description Sort the graph by index\r\n * @return {Undefined} Void\r\n */\n\n\nCRender.prototype.sortGraphsByIndex = function () {\n  var graphs = this.graphs;\n  graphs.sort(function (a, b) {\n    if (a.index > b.index) return 1;\n    if (a.index === b.index) return 0;\n    if (a.index < b.index) return -1;\n  });\n};\n/**\r\n * @description         Delete graph in render\r\n * @param {Graph} graph The graph to be deleted\r\n * @return {Undefined}  Void\r\n */\n\n\nCRender.prototype.delGraph = function (graph) {\n  if (typeof graph.delProcessor !== 'function') return;\n  graph.delProcessor(this);\n  this.graphs = this.graphs.filter(function (graph) {\n    return graph;\n  });\n  this.drawAllGraph();\n};\n/**\r\n * @description        Delete all graph in render\r\n * @return {Undefined} Void\r\n */\n\n\nCRender.prototype.delAllGraph = function () {\n  var _this = this;\n\n  this.graphs.forEach(function (graph) {\n    return graph.delProcessor(_this);\n  });\n  this.graphs = this.graphs.filter(function (graph) {\n    return graph;\n  });\n  this.drawAllGraph();\n};\n/**\r\n * @description        Draw all the graphs in the render\r\n * @return {Undefined} Void\r\n */\n\n\nCRender.prototype.drawAllGraph = function () {\n  var _this2 = this;\n\n  this.clearArea();\n  this.graphs.filter(function (graph) {\n    return graph && graph.visible;\n  }).forEach(function (graph) {\n    return graph.drawProcessor(_this2, graph);\n  });\n};\n/**\r\n * @description      Animate the graph whose animation queue is not empty\r\n *                   and the animationPause is equal to false\r\n * @return {Promise} Animation Promise\r\n */\n\n\nCRender.prototype.launchAnimation = function () {\n  var _this3 = this;\n\n  var animationStatus = this.animationStatus;\n  if (animationStatus) return;\n  this.animationStatus = true;\n  return new Promise(function (resolve) {\n    animation.call(_this3, function () {\n      _this3.animationStatus = false;\n      resolve();\n    }, Date.now());\n  });\n};\n/**\r\n * @description Try to animate every graph\r\n * @param {Function} callback Callback in animation end\r\n * @param {Number} timeStamp  Time stamp of animation start\r\n * @return {Undefined} Void\r\n */\n\n\nfunction animation(callback, timeStamp) {\n  var graphs = this.graphs;\n\n  if (!animationAble(graphs)) {\n    callback();\n    return;\n  }\n\n  graphs.forEach(function (graph) {\n    return graph.turnNextAnimationFrame(timeStamp);\n  });\n  this.drawAllGraph();\n  requestAnimationFrame(animation.bind(this, callback, timeStamp));\n}\n/**\r\n * @description Find if there are graph that can be animated\r\n * @param {[Graph]} graphs\r\n * @return {Boolean}\r\n */\n\n\nfunction animationAble(graphs) {\n  return graphs.find(function (graph) {\n    return !graph.animationPause && graph.animationFrameState.length;\n  });\n}\n/**\r\n * @description Handler of CRender mousedown event\r\n * @return {Undefined} Void\r\n */\n\n\nfunction mouseDown(e) {\n  var graphs = this.graphs;\n  var hoverGraph = graphs.find(function (graph) {\n    return graph.status === 'hover';\n  });\n  if (!hoverGraph) return;\n  hoverGraph.status = 'active';\n}\n/**\r\n * @description Handler of CRender mousemove event\r\n * @return {Undefined} Void\r\n */\n\n\nfunction mouseMove(e) {\n  var offsetX = e.offsetX,\n      offsetY = e.offsetY;\n  var position = [offsetX, offsetY];\n  var graphs = this.graphs;\n  var activeGraph = graphs.find(function (graph) {\n    return graph.status === 'active' || graph.status === 'drag';\n  });\n\n  if (activeGraph) {\n    if (!activeGraph.drag) return;\n\n    if (typeof activeGraph.move !== 'function') {\n      console.error('No move method is provided, cannot be dragged!');\n      return;\n    }\n\n    activeGraph.moveProcessor(e);\n    activeGraph.status = 'drag';\n    return;\n  }\n\n  var hoverGraph = graphs.find(function (graph) {\n    return graph.status === 'hover';\n  });\n  var hoverAbleGraphs = graphs.filter(function (graph) {\n    return graph.hover && (typeof graph.hoverCheck === 'function' || graph.hoverRect);\n  });\n  var hoveredGraph = hoverAbleGraphs.find(function (graph) {\n    return graph.hoverCheckProcessor(position, graph);\n  });\n\n  if (hoveredGraph) {\n    document.body.style.cursor = hoveredGraph.style.hoverCursor;\n  } else {\n    document.body.style.cursor = 'default';\n  }\n\n  var hoverGraphMouseOuterIsFun = false,\n      hoveredGraphMouseEnterIsFun = false;\n  if (hoverGraph) hoverGraphMouseOuterIsFun = typeof hoverGraph.mouseOuter === 'function';\n  if (hoveredGraph) hoveredGraphMouseEnterIsFun = typeof hoveredGraph.mouseEnter === 'function';\n  if (!hoveredGraph && !hoverGraph) return;\n\n  if (!hoveredGraph && hoverGraph) {\n    if (hoverGraphMouseOuterIsFun) hoverGraph.mouseOuter(e, hoverGraph);\n    hoverGraph.status = 'static';\n    return;\n  }\n\n  if (hoveredGraph && hoveredGraph === hoverGraph) return;\n\n  if (hoveredGraph && !hoverGraph) {\n    if (hoveredGraphMouseEnterIsFun) hoveredGraph.mouseEnter(e, hoveredGraph);\n    hoveredGraph.status = 'hover';\n    return;\n  }\n\n  if (hoveredGraph && hoverGraph && hoveredGraph !== hoverGraph) {\n    if (hoverGraphMouseOuterIsFun) hoverGraph.mouseOuter(e, hoverGraph);\n    hoverGraph.status = 'static';\n    if (hoveredGraphMouseEnterIsFun) hoveredGraph.mouseEnter(e, hoveredGraph);\n    hoveredGraph.status = 'hover';\n  }\n}\n/**\r\n * @description Handler of CRender mouseup event\r\n * @return {Undefined} Void\r\n */\n\n\nfunction mouseUp(e) {\n  var graphs = this.graphs;\n  var activeGraph = graphs.find(function (graph) {\n    return graph.status === 'active';\n  });\n  var dragGraph = graphs.find(function (graph) {\n    return graph.status === 'drag';\n  });\n  if (activeGraph && typeof activeGraph.click === 'function') activeGraph.click(e, activeGraph);\n  graphs.forEach(function (graph) {\n    return graph && (graph.status = 'static');\n  });\n  if (activeGraph) activeGraph.status = 'hover';\n  if (dragGraph) dragGraph.status = 'hover';\n}\n/**\r\n * @description         Clone Graph\r\n * @param {Graph} graph The target to be cloned\r\n * @return {Graph}      Cloned graph\r\n */\n\n\nCRender.prototype.clone = function (graph) {\n  var style = graph.style.getStyle();\n\n  var clonedGraph = _objectSpread({}, graph, {\n    style: style\n  });\n\n  delete clonedGraph.render;\n  clonedGraph = (0, _util.deepClone)(clonedGraph, true);\n  return this.add(clonedGraph);\n};","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports[\"default\"] = void 0;\n\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\n\nvar _asyncToGenerator2 = _interopRequireDefault(require(\"@babel/runtime/helpers/asyncToGenerator\"));\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _style = _interopRequireDefault(require(\"./style.class\"));\n\nvar _transition = _interopRequireDefault(require(\"@jiaminghi/transition\"));\n\nvar _util = require(\"../plugin/util\");\n\n/**\r\n * @description Class Graph\r\n * @param {Object} graph  Graph default configuration\r\n * @param {Object} config Graph config\r\n * @return {Graph} Instance of Graph\r\n */\nvar Graph = function Graph(graph, config) {\n  (0, _classCallCheck2[\"default\"])(this, Graph);\n  config = (0, _util.deepClone)(config, true);\n  var defaultConfig = {\n    /**\r\n     * @description Weather to render graph\r\n     * @type {Boolean}\r\n     * @default visible = true\r\n     */\n    visible: true,\n\n    /**\r\n     * @description Whether to enable drag\r\n     * @type {Boolean}\r\n     * @default drag = false\r\n     */\n    drag: false,\n\n    /**\r\n     * @description Whether to enable hover\r\n     * @type {Boolean}\r\n     * @default hover = false\r\n     */\n    hover: false,\n\n    /**\r\n     * @description Graph rendering index\r\n     *  Give priority to index high graph in rendering\r\n     * @type {Number}\r\n     * @example index = 1\r\n     */\n    index: 1,\n\n    /**\r\n     * @description Animation delay time(ms)\r\n     * @type {Number}\r\n     * @default animationDelay = 0\r\n     */\n    animationDelay: 0,\n\n    /**\r\n     * @description Number of animation frames\r\n     * @type {Number}\r\n     * @default animationFrame = 30\r\n     */\n    animationFrame: 30,\n\n    /**\r\n     * @description Animation dynamic curve (Supported by transition)\r\n     * @type {String}\r\n     * @default animationCurve = 'linear'\r\n     * @link https://github.com/jiaming743/Transition\r\n     */\n    animationCurve: 'linear',\n\n    /**\r\n     * @description Weather to pause graph animation\r\n     * @type {Boolean}\r\n     * @default animationPause = false\r\n     */\n    animationPause: false,\n\n    /**\r\n     * @description Rectangular hover detection zone\r\n     *  Use this method for hover detection first\r\n     * @type {Null|Array}\r\n     * @default hoverRect = null\r\n     * @example hoverRect = [0, 0, 100, 100] // [Rect start x, y, Rect width, height]\r\n     */\n    hoverRect: null,\n\n    /**\r\n     * @description Mouse enter event handler\r\n     * @type {Function|Null}\r\n     * @default mouseEnter = null\r\n     */\n    mouseEnter: null,\n\n    /**\r\n     * @description Mouse outer event handler\r\n     * @type {Function|Null}\r\n     * @default mouseOuter = null\r\n     */\n    mouseOuter: null,\n\n    /**\r\n     * @description Mouse click event handler\r\n     * @type {Function|Null}\r\n     * @default click = null\r\n     */\n    click: null\n  };\n  var configAbleNot = {\n    status: 'static',\n    animationRoot: [],\n    animationKeys: [],\n    animationFrameState: [],\n    cache: {}\n  };\n  if (!config.shape) config.shape = {};\n  if (!config.style) config.style = {};\n  var shape = Object.assign({}, graph.shape, config.shape);\n  Object.assign(defaultConfig, config, configAbleNot);\n  Object.assign(this, graph, defaultConfig);\n  this.shape = shape;\n  this.style = new _style[\"default\"](config.style);\n  this.addedProcessor();\n};\n/**\r\n * @description Processor of added\r\n * @return {Undefined} Void\r\n */\n\n\nexports[\"default\"] = Graph;\n\nGraph.prototype.addedProcessor = function () {\n  if (typeof this.setGraphCenter === 'function') this.setGraphCenter(null, this); // The life cycle 'added\"\n\n  if (typeof this.added === 'function') this.added(this);\n};\n/**\r\n * @description Processor of draw\r\n * @param {CRender} render Instance of CRender\r\n * @param {Graph} graph    Instance of Graph\r\n * @return {Undefined} Void\r\n */\n\n\nGraph.prototype.drawProcessor = function (render, graph) {\n  var ctx = render.ctx;\n  graph.style.initStyle(ctx);\n  if (typeof this.beforeDraw === 'function') this.beforeDraw(this, render);\n  graph.draw(render, graph);\n  if (typeof this.drawed === 'function') this.drawed(this, render);\n  graph.style.restoreTransform(ctx);\n};\n/**\r\n * @description Processor of hover check\r\n * @param {Array} position Mouse Position\r\n * @param {Graph} graph    Instance of Graph\r\n * @return {Boolean} Result of hover check\r\n */\n\n\nGraph.prototype.hoverCheckProcessor = function (position, _ref) {\n  var hoverRect = _ref.hoverRect,\n      style = _ref.style,\n      hoverCheck = _ref.hoverCheck;\n  var graphCenter = style.graphCenter,\n      rotate = style.rotate,\n      scale = style.scale,\n      translate = style.translate;\n\n  if (graphCenter) {\n    if (rotate) position = (0, _util.getRotatePointPos)(-rotate, position, graphCenter);\n    if (scale) position = (0, _util.getScalePointPos)(scale.map(function (s) {\n      return 1 / s;\n    }), position, graphCenter);\n    if (translate) position = (0, _util.getTranslatePointPos)(translate.map(function (v) {\n      return v * -1;\n    }), position);\n  }\n\n  if (hoverRect) return _util.checkPointIsInRect.apply(void 0, [position].concat((0, _toConsumableArray2[\"default\"])(hoverRect)));\n  return hoverCheck(position, this);\n};\n/**\r\n * @description Processor of move\r\n * @param {Event} e Mouse movement event\r\n * @return {Undefined} Void\r\n */\n\n\nGraph.prototype.moveProcessor = function (e) {\n  this.move(e, this);\n  if (typeof this.beforeMove === 'function') this.beforeMove(e, this);\n  if (typeof this.setGraphCenter === 'function') this.setGraphCenter(e, this);\n  if (typeof this.moved === 'function') this.moved(e, this);\n};\n/**\r\n * @description Update graph state\r\n * @param {String} attrName Updated attribute name\r\n * @param {Any} change      Updated value\r\n * @return {Undefined} Void\r\n */\n\n\nGraph.prototype.attr = function (attrName) {\n  var change = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;\n  if (!attrName || change === undefined) return false;\n  var isObject = (0, _typeof2[\"default\"])(this[attrName]) === 'object';\n  if (isObject) change = (0, _util.deepClone)(change, true);\n  var render = this.render;\n\n  if (attrName === 'style') {\n    this.style.update(change);\n  } else if (isObject) {\n    Object.assign(this[attrName], change);\n  } else {\n    this[attrName] = change;\n  }\n\n  if (attrName === 'index') render.sortGraphsByIndex();\n  render.drawAllGraph();\n};\n/**\r\n * @description Update graphics state (with animation)\r\n *  Only shape and style attributes are supported\r\n * @param {String} attrName Updated attribute name\r\n * @param {Any} change      Updated value\r\n * @param {Boolean} wait    Whether to store the animation waiting\r\n *                          for the next animation request\r\n * @return {Promise} Animation Promise\r\n */\n\n\nGraph.prototype.animation =\n/*#__PURE__*/\nfunction () {\n  var _ref2 = (0, _asyncToGenerator2[\"default\"])(\n  /*#__PURE__*/\n  _regenerator[\"default\"].mark(function _callee2(attrName, change) {\n    var wait,\n        changeRoot,\n        changeKeys,\n        beforeState,\n        animationFrame,\n        animationCurve,\n        animationDelay,\n        animationFrameState,\n        render,\n        _args2 = arguments;\n    return _regenerator[\"default\"].wrap(function _callee2$(_context2) {\n      while (1) {\n        switch (_context2.prev = _context2.next) {\n          case 0:\n            wait = _args2.length > 2 && _args2[2] !== undefined ? _args2[2] : false;\n\n            if (!(attrName !== 'shape' && attrName !== 'style')) {\n              _context2.next = 4;\n              break;\n            }\n\n            console.error('Only supported shape and style animation!');\n            return _context2.abrupt(\"return\");\n\n          case 4:\n            change = (0, _util.deepClone)(change, true);\n            if (attrName === 'style') this.style.colorProcessor(change);\n            changeRoot = this[attrName];\n            changeKeys = Object.keys(change);\n            beforeState = {};\n            changeKeys.forEach(function (key) {\n              return beforeState[key] = changeRoot[key];\n            });\n            animationFrame = this.animationFrame, animationCurve = this.animationCurve, animationDelay = this.animationDelay;\n            animationFrameState = (0, _transition[\"default\"])(animationCurve, beforeState, change, animationFrame, true);\n            this.animationRoot.push(changeRoot);\n            this.animationKeys.push(changeKeys);\n            this.animationFrameState.push(animationFrameState);\n\n            if (!wait) {\n              _context2.next = 17;\n              break;\n            }\n\n            return _context2.abrupt(\"return\");\n\n          case 17:\n            if (!(animationDelay > 0)) {\n              _context2.next = 20;\n              break;\n            }\n\n            _context2.next = 20;\n            return delay(animationDelay);\n\n          case 20:\n            render = this.render;\n            return _context2.abrupt(\"return\", new Promise(\n            /*#__PURE__*/\n            function () {\n              var _ref3 = (0, _asyncToGenerator2[\"default\"])(\n              /*#__PURE__*/\n              _regenerator[\"default\"].mark(function _callee(resolve) {\n                return _regenerator[\"default\"].wrap(function _callee$(_context) {\n                  while (1) {\n                    switch (_context.prev = _context.next) {\n                      case 0:\n                        _context.next = 2;\n                        return render.launchAnimation();\n\n                      case 2:\n                        resolve();\n\n                      case 3:\n                      case \"end\":\n                        return _context.stop();\n                    }\n                  }\n                }, _callee);\n              }));\n\n              return function (_x3) {\n                return _ref3.apply(this, arguments);\n              };\n            }()));\n\n          case 22:\n          case \"end\":\n            return _context2.stop();\n        }\n      }\n    }, _callee2, this);\n  }));\n\n  return function (_x, _x2) {\n    return _ref2.apply(this, arguments);\n  };\n}();\n/**\r\n * @description Extract the next frame of data from the animation queue\r\n *              and update the graph state\r\n * @return {Undefined} Void\r\n */\n\n\nGraph.prototype.turnNextAnimationFrame = function (timeStamp) {\n  var animationDelay = this.animationDelay,\n      animationRoot = this.animationRoot,\n      animationKeys = this.animationKeys,\n      animationFrameState = this.animationFrameState,\n      animationPause = this.animationPause;\n  if (animationPause) return;\n  if (Date.now() - timeStamp < animationDelay) return;\n  animationRoot.forEach(function (root, i) {\n    animationKeys[i].forEach(function (key) {\n      root[key] = animationFrameState[i][0][key];\n    });\n  });\n  animationFrameState.forEach(function (stateItem, i) {\n    stateItem.shift();\n    var noFrame = stateItem.length === 0;\n    if (noFrame) animationRoot[i] = null;\n    if (noFrame) animationKeys[i] = null;\n  });\n  this.animationFrameState = animationFrameState.filter(function (state) {\n    return state.length;\n  });\n  this.animationRoot = animationRoot.filter(function (root) {\n    return root;\n  });\n  this.animationKeys = animationKeys.filter(function (keys) {\n    return keys;\n  });\n};\n/**\r\n * @description Skip to the last frame of animation\r\n * @return {Undefined} Void\r\n */\n\n\nGraph.prototype.animationEnd = function () {\n  var animationFrameState = this.animationFrameState,\n      animationKeys = this.animationKeys,\n      animationRoot = this.animationRoot,\n      render = this.render;\n  animationRoot.forEach(function (root, i) {\n    var currentKeys = animationKeys[i];\n    var lastState = animationFrameState[i].pop();\n    currentKeys.forEach(function (key) {\n      return root[key] = lastState[key];\n    });\n  });\n  this.animationFrameState = [];\n  this.animationKeys = [];\n  this.animationRoot = [];\n  return render.drawAllGraph();\n};\n/**\r\n * @description Pause animation behavior\r\n * @return {Undefined} Void\r\n */\n\n\nGraph.prototype.pauseAnimation = function () {\n  this.attr('animationPause', true);\n};\n/**\r\n * @description Try animation behavior\r\n * @return {Undefined} Void\r\n */\n\n\nGraph.prototype.playAnimation = function () {\n  var render = this.render;\n  this.attr('animationPause', false);\n  return new Promise(\n  /*#__PURE__*/\n  function () {\n    var _ref4 = (0, _asyncToGenerator2[\"default\"])(\n    /*#__PURE__*/\n    _regenerator[\"default\"].mark(function _callee3(resolve) {\n      return _regenerator[\"default\"].wrap(function _callee3$(_context3) {\n        while (1) {\n          switch (_context3.prev = _context3.next) {\n            case 0:\n              _context3.next = 2;\n              return render.launchAnimation();\n\n            case 2:\n              resolve();\n\n            case 3:\n            case \"end\":\n              return _context3.stop();\n          }\n        }\n      }, _callee3);\n    }));\n\n    return function (_x4) {\n      return _ref4.apply(this, arguments);\n    };\n  }());\n};\n/**\r\n * @description Processor of delete\r\n * @param {CRender} render Instance of CRender\r\n * @return {Undefined} Void\r\n */\n\n\nGraph.prototype.delProcessor = function (render) {\n  var _this = this;\n\n  var graphs = render.graphs;\n  var index = graphs.findIndex(function (graph) {\n    return graph === _this;\n  });\n  if (index === -1) return;\n  if (typeof this.beforeDelete === 'function') this.beforeDelete(this);\n  graphs.splice(index, 1, null);\n  if (typeof this.deleted === 'function') this.deleted(this);\n};\n/**\r\n * @description Return a timed release Promise\r\n * @param {Number} time Release time\r\n * @return {Promise} A timed release Promise\r\n */\n\n\nfunction delay(time) {\n  return new Promise(function (resolve) {\n    setTimeout(resolve, time);\n  });\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports[\"default\"] = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _color = require(\"@jiaminghi/color\");\n\nvar _util = require(\"../plugin/util\");\n\n/**\r\n * @description Class Style\r\n * @param {Object} style  Style configuration\r\n * @return {Style} Instance of Style\r\n */\nvar Style = function Style(style) {\n  (0, _classCallCheck2[\"default\"])(this, Style);\n  this.colorProcessor(style);\n  var defaultStyle = {\n    /**\r\n     * @description Rgba value of graph fill color\r\n     * @type {Array}\r\n     * @default fill = [0, 0, 0, 1]\r\n     */\n    fill: [0, 0, 0, 1],\n\n    /**\r\n     * @description Rgba value of graph stroke color\r\n     * @type {Array}\r\n     * @default stroke = [0, 0, 0, 1]\r\n     */\n    stroke: [0, 0, 0, 0],\n\n    /**\r\n     * @description Opacity of graph\r\n     * @type {Number}\r\n     * @default opacity = 1\r\n     */\n    opacity: 1,\n\n    /**\r\n     * @description LineCap of Ctx\r\n     * @type {String}\r\n     * @default lineCap = null\r\n     * @example lineCap = 'butt'|'round'|'square'\r\n     */\n    lineCap: null,\n\n    /**\r\n     * @description Linejoin of Ctx\r\n     * @type {String}\r\n     * @default lineJoin = null\r\n     * @example lineJoin = 'round'|'bevel'|'miter'\r\n     */\n    lineJoin: null,\n\n    /**\r\n     * @description LineDash of Ctx\r\n     * @type {Array}\r\n     * @default lineDash = null\r\n     * @example lineDash = [10, 10]\r\n     */\n    lineDash: null,\n\n    /**\r\n     * @description LineDashOffset of Ctx\r\n     * @type {Number}\r\n     * @default lineDashOffset = null\r\n     * @example lineDashOffset = 10\r\n     */\n    lineDashOffset: null,\n\n    /**\r\n     * @description ShadowBlur of Ctx\r\n     * @type {Number}\r\n     * @default shadowBlur = 0\r\n     */\n    shadowBlur: 0,\n\n    /**\r\n     * @description Rgba value of graph shadow color\r\n     * @type {Array}\r\n     * @default shadowColor = [0, 0, 0, 0]\r\n     */\n    shadowColor: [0, 0, 0, 0],\n\n    /**\r\n     * @description ShadowOffsetX of Ctx\r\n     * @type {Number}\r\n     * @default shadowOffsetX = 0\r\n     */\n    shadowOffsetX: 0,\n\n    /**\r\n     * @description ShadowOffsetY of Ctx\r\n     * @type {Number}\r\n     * @default shadowOffsetY = 0\r\n     */\n    shadowOffsetY: 0,\n\n    /**\r\n     * @description LineWidth of Ctx\r\n     * @type {Number}\r\n     * @default lineWidth = 0\r\n     */\n    lineWidth: 0,\n\n    /**\r\n     * @description Center point of the graph\r\n     * @type {Array}\r\n     * @default graphCenter = null\r\n     * @example graphCenter = [10, 10]\r\n     */\n    graphCenter: null,\n\n    /**\r\n     * @description Graph scale\r\n     * @type {Array}\r\n     * @default scale = null\r\n     * @example scale = [1.5, 1.5]\r\n     */\n    scale: null,\n\n    /**\r\n     * @description Graph rotation degree\r\n     * @type {Number}\r\n     * @default rotate = null\r\n     * @example rotate = 10\r\n     */\n    rotate: null,\n\n    /**\r\n     * @description Graph translate distance\r\n     * @type {Array}\r\n     * @default translate = null\r\n     * @example translate = [10, 10]\r\n     */\n    translate: null,\n\n    /**\r\n     * @description Cursor status when hover\r\n     * @type {String}\r\n     * @default hoverCursor = 'pointer'\r\n     * @example hoverCursor = 'default'|'pointer'|'auto'|'crosshair'|'move'|'wait'|...\r\n     */\n    hoverCursor: 'pointer',\n\n    /**\r\n     * @description Font style of Ctx\r\n     * @type {String}\r\n     * @default fontStyle = 'normal'\r\n     * @example fontStyle = 'normal'|'italic'|'oblique'\r\n     */\n    fontStyle: 'normal',\n\n    /**\r\n     * @description Font varient of Ctx\r\n     * @type {String}\r\n     * @default fontVarient = 'normal'\r\n     * @example fontVarient = 'normal'|'small-caps'\r\n     */\n    fontVarient: 'normal',\n\n    /**\r\n     * @description Font weight of Ctx\r\n     * @type {String|Number}\r\n     * @default fontWeight = 'normal'\r\n     * @example fontWeight = 'normal'|'bold'|'bolder'|'lighter'|Number\r\n     */\n    fontWeight: 'normal',\n\n    /**\r\n     * @description Font size of Ctx\r\n     * @type {Number}\r\n     * @default fontSize = 10\r\n     */\n    fontSize: 10,\n\n    /**\r\n     * @description Font family of Ctx\r\n     * @type {String}\r\n     * @default fontFamily = 'Arial'\r\n     */\n    fontFamily: 'Arial',\n\n    /**\r\n     * @description TextAlign of Ctx\r\n     * @type {String}\r\n     * @default textAlign = 'center'\r\n     * @example textAlign = 'start'|'end'|'left'|'right'|'center'\r\n     */\n    textAlign: 'center',\n\n    /**\r\n     * @description TextBaseline of Ctx\r\n     * @type {String}\r\n     * @default textBaseline = 'middle'\r\n     * @example textBaseline = 'top'|'bottom'|'middle'|'alphabetic'|'hanging'\r\n     */\n    textBaseline: 'middle',\n\n    /**\r\n     * @description The color used to create the gradient\r\n     * @type {Array}\r\n     * @default gradientColor = null\r\n     * @example gradientColor = ['#000', '#111', '#222']\r\n     */\n    gradientColor: null,\n\n    /**\r\n     * @description Gradient type\r\n     * @type {String}\r\n     * @default gradientType = 'linear'\r\n     * @example gradientType = 'linear' | 'radial'\r\n     */\n    gradientType: 'linear',\n\n    /**\r\n     * @description Gradient params\r\n     * @type {Array}\r\n     * @default gradientParams = null\r\n     * @example gradientParams = [x0, y0, x1, y1] (Linear Gradient)\r\n     * @example gradientParams = [x0, y0, r0, x1, y1, r1] (Radial Gradient)\r\n     */\n    gradientParams: null,\n\n    /**\r\n     * @description When to use gradients\r\n     * @type {String}\r\n     * @default gradientWith = 'stroke'\r\n     * @example gradientWith = 'stroke' | 'fill'\r\n     */\n    gradientWith: 'stroke',\n\n    /**\r\n     * @description Gradient color stops\r\n     * @type {String}\r\n     * @default gradientStops = 'auto'\r\n     * @example gradientStops = 'auto' | [0, .2, .3, 1]\r\n     */\n    gradientStops: 'auto',\n\n    /**\r\n     * @description Extended color that supports animation transition\r\n     * @type {Array|Object}\r\n     * @default colors = null\r\n     * @example colors = ['#000', '#111', '#222', 'red' ]\r\n     * @example colors = { a: '#000', b: '#111' }\r\n     */\n    colors: null\n  };\n  Object.assign(this, defaultStyle, style);\n};\n/**\r\n * @description Set colors to rgba value\r\n * @param {Object} style style config\r\n * @param {Boolean} reverse Whether to perform reverse operation\r\n * @return {Undefined} Void\r\n */\n\n\nexports[\"default\"] = Style;\n\nStyle.prototype.colorProcessor = function (style) {\n  var reverse = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n  var processor = reverse ? _color.getColorFromRgbValue : _color.getRgbaValue;\n  var colorProcessorKeys = ['fill', 'stroke', 'shadowColor'];\n  var allKeys = Object.keys(style);\n  var colorKeys = allKeys.filter(function (key) {\n    return colorProcessorKeys.find(function (k) {\n      return k === key;\n    });\n  });\n  colorKeys.forEach(function (key) {\n    return style[key] = processor(style[key]);\n  });\n  var gradientColor = style.gradientColor,\n      colors = style.colors;\n  if (gradientColor) style.gradientColor = gradientColor.map(function (c) {\n    return processor(c);\n  });\n\n  if (colors) {\n    var colorsKeys = Object.keys(colors);\n    colorsKeys.forEach(function (key) {\n      return colors[key] = processor(colors[key]);\n    });\n  }\n};\n/**\r\n * @description Init graph style\r\n * @param {Object} ctx Context of canvas\r\n * @return {Undefined} Void\r\n */\n\n\nStyle.prototype.initStyle = function (ctx) {\n  initTransform(ctx, this);\n  initGraphStyle(ctx, this);\n  initGradient(ctx, this);\n};\n/**\r\n * @description Init canvas transform\r\n * @param {Object} ctx  Context of canvas\r\n * @param {Style} style Instance of Style\r\n * @return {Undefined} Void\r\n */\n\n\nfunction initTransform(ctx, style) {\n  ctx.save();\n  var graphCenter = style.graphCenter,\n      rotate = style.rotate,\n      scale = style.scale,\n      translate = style.translate;\n  if (!(graphCenter instanceof Array)) return;\n  ctx.translate.apply(ctx, (0, _toConsumableArray2[\"default\"])(graphCenter));\n  if (rotate) ctx.rotate(rotate * Math.PI / 180);\n  if (scale instanceof Array) ctx.scale.apply(ctx, (0, _toConsumableArray2[\"default\"])(scale));\n  if (translate) ctx.translate.apply(ctx, (0, _toConsumableArray2[\"default\"])(translate));\n  ctx.translate(-graphCenter[0], -graphCenter[1]);\n}\n\nvar autoSetStyleKeys = ['lineCap', 'lineJoin', 'lineDashOffset', 'shadowOffsetX', 'shadowOffsetY', 'lineWidth', 'textAlign', 'textBaseline'];\n/**\r\n * @description Set the style of canvas ctx\r\n * @param {Object} ctx  Context of canvas\r\n * @param {Style} style Instance of Style\r\n * @return {Undefined} Void\r\n */\n\nfunction initGraphStyle(ctx, style) {\n  var fill = style.fill,\n      stroke = style.stroke,\n      shadowColor = style.shadowColor,\n      opacity = style.opacity;\n  autoSetStyleKeys.forEach(function (key) {\n    if (key || typeof key === 'number') ctx[key] = style[key];\n  });\n  fill = (0, _toConsumableArray2[\"default\"])(fill);\n  stroke = (0, _toConsumableArray2[\"default\"])(stroke);\n  shadowColor = (0, _toConsumableArray2[\"default\"])(shadowColor);\n  fill[3] *= opacity;\n  stroke[3] *= opacity;\n  shadowColor[3] *= opacity;\n  ctx.fillStyle = (0, _color.getColorFromRgbValue)(fill);\n  ctx.strokeStyle = (0, _color.getColorFromRgbValue)(stroke);\n  ctx.shadowColor = (0, _color.getColorFromRgbValue)(shadowColor);\n  var lineDash = style.lineDash,\n      shadowBlur = style.shadowBlur;\n\n  if (lineDash) {\n    lineDash = lineDash.map(function (v) {\n      return v >= 0 ? v : 0;\n    });\n    ctx.setLineDash(lineDash);\n  }\n\n  if (typeof shadowBlur === 'number') ctx.shadowBlur = shadowBlur > 0 ? shadowBlur : 0.001;\n  var fontStyle = style.fontStyle,\n      fontVarient = style.fontVarient,\n      fontWeight = style.fontWeight,\n      fontSize = style.fontSize,\n      fontFamily = style.fontFamily;\n  ctx.font = fontStyle + ' ' + fontVarient + ' ' + fontWeight + ' ' + fontSize + 'px' + ' ' + fontFamily;\n}\n/**\r\n * @description Set the gradient color of canvas ctx\r\n * @param {Object} ctx  Context of canvas\r\n * @param {Style} style Instance of Style\r\n * @return {Undefined} Void\r\n */\n\n\nfunction initGradient(ctx, style) {\n  if (!gradientValidator(style)) return;\n  var gradientColor = style.gradientColor,\n      gradientParams = style.gradientParams,\n      gradientType = style.gradientType,\n      gradientWith = style.gradientWith,\n      gradientStops = style.gradientStops,\n      opacity = style.opacity;\n  gradientColor = gradientColor.map(function (color) {\n    var colorOpacity = color[3] * opacity;\n    var clonedColor = (0, _toConsumableArray2[\"default\"])(color);\n    clonedColor[3] = colorOpacity;\n    return clonedColor;\n  });\n  gradientColor = gradientColor.map(function (c) {\n    return (0, _color.getColorFromRgbValue)(c);\n  });\n  if (gradientStops === 'auto') gradientStops = getAutoColorStops(gradientColor);\n  var gradient = ctx[\"create\".concat(gradientType.slice(0, 1).toUpperCase() + gradientType.slice(1), \"Gradient\")].apply(ctx, (0, _toConsumableArray2[\"default\"])(gradientParams));\n  gradientStops.forEach(function (stop, i) {\n    return gradient.addColorStop(stop, gradientColor[i]);\n  });\n  ctx[\"\".concat(gradientWith, \"Style\")] = gradient;\n}\n/**\r\n * @description Check if the gradient configuration is legal\r\n * @param {Style} style Instance of Style\r\n * @return {Boolean} Check Result\r\n */\n\n\nfunction gradientValidator(style) {\n  var gradientColor = style.gradientColor,\n      gradientParams = style.gradientParams,\n      gradientType = style.gradientType,\n      gradientWith = style.gradientWith,\n      gradientStops = style.gradientStops;\n  if (!gradientColor || !gradientParams) return false;\n\n  if (gradientColor.length === 1) {\n    console.warn('The gradient needs to provide at least two colors');\n    return false;\n  }\n\n  if (gradientType !== 'linear' && gradientType !== 'radial') {\n    console.warn('GradientType only supports linear or radial, current value is ' + gradientType);\n    return false;\n  }\n\n  var gradientParamsLength = gradientParams.length;\n\n  if (gradientType === 'linear' && gradientParamsLength !== 4 || gradientType === 'radial' && gradientParamsLength !== 6) {\n    console.warn('The expected length of gradientParams is ' + (gradientType === 'linear' ? '4' : '6'));\n    return false;\n  }\n\n  if (gradientWith !== 'fill' && gradientWith !== 'stroke') {\n    console.warn('GradientWith only supports fill or stroke, current value is ' + gradientWith);\n    return false;\n  }\n\n  if (gradientStops !== 'auto' && !(gradientStops instanceof Array)) {\n    console.warn(\"gradientStops only supports 'auto' or Number Array ([0, .5, 1]), current value is \" + gradientStops);\n    return false;\n  }\n\n  return true;\n}\n/**\r\n * @description Get a uniform gradient color stop\r\n * @param {Array} color Gradient color\r\n * @return {Array} Gradient color stop\r\n */\n\n\nfunction getAutoColorStops(color) {\n  var stopGap = 1 / (color.length - 1);\n  return color.map(function (foo, i) {\n    return stopGap * i;\n  });\n}\n/**\r\n * @description Restore canvas ctx transform\r\n * @param {Object} ctx  Context of canvas\r\n * @return {Undefined} Void\r\n */\n\n\nStyle.prototype.restoreTransform = function (ctx) {\n  ctx.restore();\n};\n/**\r\n * @description Update style data\r\n * @param {Object} change Changed data\r\n * @return {Undefined} Void\r\n */\n\n\nStyle.prototype.update = function (change) {\n  this.colorProcessor(change);\n  Object.assign(this, change);\n};\n/**\r\n * @description Get the current style configuration\r\n * @return {Object} Style configuration\r\n */\n\n\nStyle.prototype.getStyle = function () {\n  var clonedStyle = (0, _util.deepClone)(this, true);\n  this.colorProcessor(clonedStyle, true);\n  return clonedStyle;\n};","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.extendNewGraph = extendNewGraph;\nexports[\"default\"] = exports.text = exports.bezierCurve = exports.smoothline = exports.polyline = exports.regPolygon = exports.sector = exports.arc = exports.ring = exports.rect = exports.ellipse = exports.circle = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _bezierCurve2 = _interopRequireDefault(require(\"@jiaminghi/bezier-curve\"));\n\nvar _util = require(\"../plugin/util\");\n\nvar _canvas = require(\"../plugin/canvas\");\n\nvar polylineToBezierCurve = _bezierCurve2[\"default\"].polylineToBezierCurve,\n    bezierCurveToPolyline = _bezierCurve2[\"default\"].bezierCurveToPolyline;\nvar circle = {\n  shape: {\n    rx: 0,\n    ry: 0,\n    r: 0\n  },\n  validator: function validator(_ref) {\n    var shape = _ref.shape;\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r;\n\n    if (typeof rx !== 'number' || typeof ry !== 'number' || typeof r !== 'number') {\n      console.error('Circle shape configuration is abnormal!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref2, _ref3) {\n    var ctx = _ref2.ctx;\n    var shape = _ref3.shape;\n    ctx.beginPath();\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r;\n    ctx.arc(rx, ry, r > 0 ? r : 0.01, 0, Math.PI * 2);\n    ctx.fill();\n    ctx.stroke();\n    ctx.closePath();\n  },\n  hoverCheck: function hoverCheck(position, _ref4) {\n    var shape = _ref4.shape;\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r;\n    return (0, _util.checkPointIsInCircle)(position, rx, ry, r);\n  },\n  setGraphCenter: function setGraphCenter(e, _ref5) {\n    var shape = _ref5.shape,\n        style = _ref5.style;\n    var rx = shape.rx,\n        ry = shape.ry;\n    style.graphCenter = [rx, ry];\n  },\n  move: function move(_ref6, _ref7) {\n    var movementX = _ref6.movementX,\n        movementY = _ref6.movementY;\n    var shape = _ref7.shape;\n    this.attr('shape', {\n      rx: shape.rx + movementX,\n      ry: shape.ry + movementY\n    });\n  }\n};\nexports.circle = circle;\nvar ellipse = {\n  shape: {\n    rx: 0,\n    ry: 0,\n    hr: 0,\n    vr: 0\n  },\n  validator: function validator(_ref8) {\n    var shape = _ref8.shape;\n    var rx = shape.rx,\n        ry = shape.ry,\n        hr = shape.hr,\n        vr = shape.vr;\n\n    if (typeof rx !== 'number' || typeof ry !== 'number' || typeof hr !== 'number' || typeof vr !== 'number') {\n      console.error('Ellipse shape configuration is abnormal!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref9, _ref10) {\n    var ctx = _ref9.ctx;\n    var shape = _ref10.shape;\n    ctx.beginPath();\n    var rx = shape.rx,\n        ry = shape.ry,\n        hr = shape.hr,\n        vr = shape.vr;\n    ctx.ellipse(rx, ry, hr > 0 ? hr : 0.01, vr > 0 ? vr : 0.01, 0, 0, Math.PI * 2);\n    ctx.fill();\n    ctx.stroke();\n    ctx.closePath();\n  },\n  hoverCheck: function hoverCheck(position, _ref11) {\n    var shape = _ref11.shape;\n    var rx = shape.rx,\n        ry = shape.ry,\n        hr = shape.hr,\n        vr = shape.vr;\n    var a = Math.max(hr, vr);\n    var b = Math.min(hr, vr);\n    var c = Math.sqrt(a * a - b * b);\n    var leftFocusPoint = [rx - c, ry];\n    var rightFocusPoint = [rx + c, ry];\n    var distance = (0, _util.getTwoPointDistance)(position, leftFocusPoint) + (0, _util.getTwoPointDistance)(position, rightFocusPoint);\n    return distance <= 2 * a;\n  },\n  setGraphCenter: function setGraphCenter(e, _ref12) {\n    var shape = _ref12.shape,\n        style = _ref12.style;\n    var rx = shape.rx,\n        ry = shape.ry;\n    style.graphCenter = [rx, ry];\n  },\n  move: function move(_ref13, _ref14) {\n    var movementX = _ref13.movementX,\n        movementY = _ref13.movementY;\n    var shape = _ref14.shape;\n    this.attr('shape', {\n      rx: shape.rx + movementX,\n      ry: shape.ry + movementY\n    });\n  }\n};\nexports.ellipse = ellipse;\nvar rect = {\n  shape: {\n    x: 0,\n    y: 0,\n    w: 0,\n    h: 0\n  },\n  validator: function validator(_ref15) {\n    var shape = _ref15.shape;\n    var x = shape.x,\n        y = shape.y,\n        w = shape.w,\n        h = shape.h;\n\n    if (typeof x !== 'number' || typeof y !== 'number' || typeof w !== 'number' || typeof h !== 'number') {\n      console.error('Rect shape configuration is abnormal!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref16, _ref17) {\n    var ctx = _ref16.ctx;\n    var shape = _ref17.shape;\n    ctx.beginPath();\n    var x = shape.x,\n        y = shape.y,\n        w = shape.w,\n        h = shape.h;\n    ctx.rect(x, y, w, h);\n    ctx.fill();\n    ctx.stroke();\n    ctx.closePath();\n  },\n  hoverCheck: function hoverCheck(position, _ref18) {\n    var shape = _ref18.shape;\n    var x = shape.x,\n        y = shape.y,\n        w = shape.w,\n        h = shape.h;\n    return (0, _util.checkPointIsInRect)(position, x, y, w, h);\n  },\n  setGraphCenter: function setGraphCenter(e, _ref19) {\n    var shape = _ref19.shape,\n        style = _ref19.style;\n    var x = shape.x,\n        y = shape.y,\n        w = shape.w,\n        h = shape.h;\n    style.graphCenter = [x + w / 2, y + h / 2];\n  },\n  move: function move(_ref20, _ref21) {\n    var movementX = _ref20.movementX,\n        movementY = _ref20.movementY;\n    var shape = _ref21.shape;\n    this.attr('shape', {\n      x: shape.x + movementX,\n      y: shape.y + movementY\n    });\n  }\n};\nexports.rect = rect;\nvar ring = {\n  shape: {\n    rx: 0,\n    ry: 0,\n    r: 0\n  },\n  validator: function validator(_ref22) {\n    var shape = _ref22.shape;\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r;\n\n    if (typeof rx !== 'number' || typeof ry !== 'number' || typeof r !== 'number') {\n      console.error('Ring shape configuration is abnormal!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref23, _ref24) {\n    var ctx = _ref23.ctx;\n    var shape = _ref24.shape;\n    ctx.beginPath();\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r;\n    ctx.arc(rx, ry, r > 0 ? r : 0.01, 0, Math.PI * 2);\n    ctx.stroke();\n    ctx.closePath();\n  },\n  hoverCheck: function hoverCheck(position, _ref25) {\n    var shape = _ref25.shape,\n        style = _ref25.style;\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r;\n    var lineWidth = style.lineWidth;\n    var halfLineWidth = lineWidth / 2;\n    var minDistance = r - halfLineWidth;\n    var maxDistance = r + halfLineWidth;\n    var distance = (0, _util.getTwoPointDistance)(position, [rx, ry]);\n    return distance >= minDistance && distance <= maxDistance;\n  },\n  setGraphCenter: function setGraphCenter(e, _ref26) {\n    var shape = _ref26.shape,\n        style = _ref26.style;\n    var rx = shape.rx,\n        ry = shape.ry;\n    style.graphCenter = [rx, ry];\n  },\n  move: function move(_ref27, _ref28) {\n    var movementX = _ref27.movementX,\n        movementY = _ref27.movementY;\n    var shape = _ref28.shape;\n    this.attr('shape', {\n      rx: shape.rx + movementX,\n      ry: shape.ry + movementY\n    });\n  }\n};\nexports.ring = ring;\nvar arc = {\n  shape: {\n    rx: 0,\n    ry: 0,\n    r: 0,\n    startAngle: 0,\n    endAngle: 0,\n    clockWise: true\n  },\n  validator: function validator(_ref29) {\n    var shape = _ref29.shape;\n    var keys = ['rx', 'ry', 'r', 'startAngle', 'endAngle'];\n\n    if (keys.find(function (key) {\n      return typeof shape[key] !== 'number';\n    })) {\n      console.error('Arc shape configuration is abnormal!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref30, _ref31) {\n    var ctx = _ref30.ctx;\n    var shape = _ref31.shape;\n    ctx.beginPath();\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r,\n        startAngle = shape.startAngle,\n        endAngle = shape.endAngle,\n        clockWise = shape.clockWise;\n    ctx.arc(rx, ry, r > 0 ? r : 0.001, startAngle, endAngle, !clockWise);\n    ctx.stroke();\n    ctx.closePath();\n  },\n  hoverCheck: function hoverCheck(position, _ref32) {\n    var shape = _ref32.shape,\n        style = _ref32.style;\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r,\n        startAngle = shape.startAngle,\n        endAngle = shape.endAngle,\n        clockWise = shape.clockWise;\n    var lineWidth = style.lineWidth;\n    var halfLineWidth = lineWidth / 2;\n    var insideRadius = r - halfLineWidth;\n    var outsideRadius = r + halfLineWidth;\n    return !(0, _util.checkPointIsInSector)(position, rx, ry, insideRadius, startAngle, endAngle, clockWise) && (0, _util.checkPointIsInSector)(position, rx, ry, outsideRadius, startAngle, endAngle, clockWise);\n  },\n  setGraphCenter: function setGraphCenter(e, _ref33) {\n    var shape = _ref33.shape,\n        style = _ref33.style;\n    var rx = shape.rx,\n        ry = shape.ry;\n    style.graphCenter = [rx, ry];\n  },\n  move: function move(_ref34, _ref35) {\n    var movementX = _ref34.movementX,\n        movementY = _ref34.movementY;\n    var shape = _ref35.shape;\n    this.attr('shape', {\n      rx: shape.rx + movementX,\n      ry: shape.ry + movementY\n    });\n  }\n};\nexports.arc = arc;\nvar sector = {\n  shape: {\n    rx: 0,\n    ry: 0,\n    r: 0,\n    startAngle: 0,\n    endAngle: 0,\n    clockWise: true\n  },\n  validator: function validator(_ref36) {\n    var shape = _ref36.shape;\n    var keys = ['rx', 'ry', 'r', 'startAngle', 'endAngle'];\n\n    if (keys.find(function (key) {\n      return typeof shape[key] !== 'number';\n    })) {\n      console.error('Sector shape configuration is abnormal!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref37, _ref38) {\n    var ctx = _ref37.ctx;\n    var shape = _ref38.shape;\n    ctx.beginPath();\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r,\n        startAngle = shape.startAngle,\n        endAngle = shape.endAngle,\n        clockWise = shape.clockWise;\n    ctx.arc(rx, ry, r > 0 ? r : 0.01, startAngle, endAngle, !clockWise);\n    ctx.lineTo(rx, ry);\n    ctx.closePath();\n    ctx.stroke();\n    ctx.fill();\n  },\n  hoverCheck: function hoverCheck(position, _ref39) {\n    var shape = _ref39.shape;\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r,\n        startAngle = shape.startAngle,\n        endAngle = shape.endAngle,\n        clockWise = shape.clockWise;\n    return (0, _util.checkPointIsInSector)(position, rx, ry, r, startAngle, endAngle, clockWise);\n  },\n  setGraphCenter: function setGraphCenter(e, _ref40) {\n    var shape = _ref40.shape,\n        style = _ref40.style;\n    var rx = shape.rx,\n        ry = shape.ry;\n    style.graphCenter = [rx, ry];\n  },\n  move: function move(_ref41, _ref42) {\n    var movementX = _ref41.movementX,\n        movementY = _ref41.movementY;\n    var shape = _ref42.shape;\n    var rx = shape.rx,\n        ry = shape.ry;\n    this.attr('shape', {\n      rx: rx + movementX,\n      ry: ry + movementY\n    });\n  }\n};\nexports.sector = sector;\nvar regPolygon = {\n  shape: {\n    rx: 0,\n    ry: 0,\n    r: 0,\n    side: 0\n  },\n  validator: function validator(_ref43) {\n    var shape = _ref43.shape;\n    var side = shape.side;\n    var keys = ['rx', 'ry', 'r', 'side'];\n\n    if (keys.find(function (key) {\n      return typeof shape[key] !== 'number';\n    })) {\n      console.error('RegPolygon shape configuration is abnormal!');\n      return false;\n    }\n\n    if (side < 3) {\n      console.error('RegPolygon at least trigon!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref44, _ref45) {\n    var ctx = _ref44.ctx;\n    var shape = _ref45.shape,\n        cache = _ref45.cache;\n    ctx.beginPath();\n    var rx = shape.rx,\n        ry = shape.ry,\n        r = shape.r,\n        side = shape.side;\n\n    if (!cache.points || cache.rx !== rx || cache.ry !== ry || cache.r !== r || cache.side !== side) {\n      var _points = (0, _util.getRegularPolygonPoints)(rx, ry, r, side);\n\n      Object.assign(cache, {\n        points: _points,\n        rx: rx,\n        ry: ry,\n        r: r,\n        side: side\n      });\n    }\n\n    var points = cache.points;\n    (0, _canvas.drawPolylinePath)(ctx, points);\n    ctx.closePath();\n    ctx.stroke();\n    ctx.fill();\n  },\n  hoverCheck: function hoverCheck(position, _ref46) {\n    var cache = _ref46.cache;\n    var points = cache.points;\n    return (0, _util.checkPointIsInPolygon)(position, points);\n  },\n  setGraphCenter: function setGraphCenter(e, _ref47) {\n    var shape = _ref47.shape,\n        style = _ref47.style;\n    var rx = shape.rx,\n        ry = shape.ry;\n    style.graphCenter = [rx, ry];\n  },\n  move: function move(_ref48, _ref49) {\n    var movementX = _ref48.movementX,\n        movementY = _ref48.movementY;\n    var shape = _ref49.shape,\n        cache = _ref49.cache;\n    var rx = shape.rx,\n        ry = shape.ry;\n    cache.rx += movementX;\n    cache.ry += movementY;\n    this.attr('shape', {\n      rx: rx + movementX,\n      ry: ry + movementY\n    });\n    cache.points = cache.points.map(function (_ref50) {\n      var _ref51 = (0, _slicedToArray2[\"default\"])(_ref50, 2),\n          x = _ref51[0],\n          y = _ref51[1];\n\n      return [x + movementX, y + movementY];\n    });\n  }\n};\nexports.regPolygon = regPolygon;\nvar polyline = {\n  shape: {\n    points: [],\n    close: false\n  },\n  validator: function validator(_ref52) {\n    var shape = _ref52.shape;\n    var points = shape.points;\n\n    if (!(points instanceof Array)) {\n      console.error('Polyline points should be an array!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref53, _ref54) {\n    var ctx = _ref53.ctx;\n    var shape = _ref54.shape,\n        lineWidth = _ref54.style.lineWidth;\n    ctx.beginPath();\n    var points = shape.points,\n        close = shape.close;\n    if (lineWidth === 1) points = (0, _util.eliminateBlur)(points);\n    (0, _canvas.drawPolylinePath)(ctx, points);\n\n    if (close) {\n      ctx.closePath();\n      ctx.fill();\n      ctx.stroke();\n    } else {\n      ctx.stroke();\n    }\n  },\n  hoverCheck: function hoverCheck(position, _ref55) {\n    var shape = _ref55.shape,\n        style = _ref55.style;\n    var points = shape.points,\n        close = shape.close;\n    var lineWidth = style.lineWidth;\n\n    if (close) {\n      return (0, _util.checkPointIsInPolygon)(position, points);\n    } else {\n      return (0, _util.checkPointIsNearPolyline)(position, points, lineWidth);\n    }\n  },\n  setGraphCenter: function setGraphCenter(e, _ref56) {\n    var shape = _ref56.shape,\n        style = _ref56.style;\n    var points = shape.points;\n    style.graphCenter = points[0];\n  },\n  move: function move(_ref57, _ref58) {\n    var movementX = _ref57.movementX,\n        movementY = _ref57.movementY;\n    var shape = _ref58.shape;\n    var points = shape.points;\n    var moveAfterPoints = points.map(function (_ref59) {\n      var _ref60 = (0, _slicedToArray2[\"default\"])(_ref59, 2),\n          x = _ref60[0],\n          y = _ref60[1];\n\n      return [x + movementX, y + movementY];\n    });\n    this.attr('shape', {\n      points: moveAfterPoints\n    });\n  }\n};\nexports.polyline = polyline;\nvar smoothline = {\n  shape: {\n    points: [],\n    close: false\n  },\n  validator: function validator(_ref61) {\n    var shape = _ref61.shape;\n    var points = shape.points;\n\n    if (!(points instanceof Array)) {\n      console.error('Smoothline points should be an array!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref62, _ref63) {\n    var ctx = _ref62.ctx;\n    var shape = _ref63.shape,\n        cache = _ref63.cache;\n    var points = shape.points,\n        close = shape.close;\n\n    if (!cache.points || cache.points.toString() !== points.toString()) {\n      var _bezierCurve = polylineToBezierCurve(points, close);\n\n      var hoverPoints = bezierCurveToPolyline(_bezierCurve);\n      Object.assign(cache, {\n        points: (0, _util.deepClone)(points, true),\n        bezierCurve: _bezierCurve,\n        hoverPoints: hoverPoints\n      });\n    }\n\n    var bezierCurve = cache.bezierCurve;\n    ctx.beginPath();\n    (0, _canvas.drawBezierCurvePath)(ctx, bezierCurve.slice(1), bezierCurve[0]);\n\n    if (close) {\n      ctx.closePath();\n      ctx.fill();\n      ctx.stroke();\n    } else {\n      ctx.stroke();\n    }\n  },\n  hoverCheck: function hoverCheck(position, _ref64) {\n    var cache = _ref64.cache,\n        shape = _ref64.shape,\n        style = _ref64.style;\n    var hoverPoints = cache.hoverPoints;\n    var close = shape.close;\n    var lineWidth = style.lineWidth;\n\n    if (close) {\n      return (0, _util.checkPointIsInPolygon)(position, hoverPoints);\n    } else {\n      return (0, _util.checkPointIsNearPolyline)(position, hoverPoints, lineWidth);\n    }\n  },\n  setGraphCenter: function setGraphCenter(e, _ref65) {\n    var shape = _ref65.shape,\n        style = _ref65.style;\n    var points = shape.points;\n    style.graphCenter = points[0];\n  },\n  move: function move(_ref66, _ref67) {\n    var movementX = _ref66.movementX,\n        movementY = _ref66.movementY;\n    var shape = _ref67.shape,\n        cache = _ref67.cache;\n    var points = shape.points;\n    var moveAfterPoints = points.map(function (_ref68) {\n      var _ref69 = (0, _slicedToArray2[\"default\"])(_ref68, 2),\n          x = _ref69[0],\n          y = _ref69[1];\n\n      return [x + movementX, y + movementY];\n    });\n    cache.points = moveAfterPoints;\n\n    var _cache$bezierCurve$ = (0, _slicedToArray2[\"default\"])(cache.bezierCurve[0], 2),\n        fx = _cache$bezierCurve$[0],\n        fy = _cache$bezierCurve$[1];\n\n    var curves = cache.bezierCurve.slice(1);\n    cache.bezierCurve = [[fx + movementX, fy + movementY]].concat((0, _toConsumableArray2[\"default\"])(curves.map(function (curve) {\n      return curve.map(function (_ref70) {\n        var _ref71 = (0, _slicedToArray2[\"default\"])(_ref70, 2),\n            x = _ref71[0],\n            y = _ref71[1];\n\n        return [x + movementX, y + movementY];\n      });\n    })));\n    cache.hoverPoints = cache.hoverPoints.map(function (_ref72) {\n      var _ref73 = (0, _slicedToArray2[\"default\"])(_ref72, 2),\n          x = _ref73[0],\n          y = _ref73[1];\n\n      return [x + movementX, y + movementY];\n    });\n    this.attr('shape', {\n      points: moveAfterPoints\n    });\n  }\n};\nexports.smoothline = smoothline;\nvar bezierCurve = {\n  shape: {\n    points: [],\n    close: false\n  },\n  validator: function validator(_ref74) {\n    var shape = _ref74.shape;\n    var points = shape.points;\n\n    if (!(points instanceof Array)) {\n      console.error('BezierCurve points should be an array!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref75, _ref76) {\n    var ctx = _ref75.ctx;\n    var shape = _ref76.shape,\n        cache = _ref76.cache;\n    var points = shape.points,\n        close = shape.close;\n\n    if (!cache.points || cache.points.toString() !== points.toString()) {\n      var hoverPoints = bezierCurveToPolyline(points, 20);\n      Object.assign(cache, {\n        points: (0, _util.deepClone)(points, true),\n        hoverPoints: hoverPoints\n      });\n    }\n\n    ctx.beginPath();\n    (0, _canvas.drawBezierCurvePath)(ctx, points.slice(1), points[0]);\n\n    if (close) {\n      ctx.closePath();\n      ctx.fill();\n      ctx.stroke();\n    } else {\n      ctx.stroke();\n    }\n  },\n  hoverCheck: function hoverCheck(position, _ref77) {\n    var cache = _ref77.cache,\n        shape = _ref77.shape,\n        style = _ref77.style;\n    var hoverPoints = cache.hoverPoints;\n    var close = shape.close;\n    var lineWidth = style.lineWidth;\n\n    if (close) {\n      return (0, _util.checkPointIsInPolygon)(position, hoverPoints);\n    } else {\n      return (0, _util.checkPointIsNearPolyline)(position, hoverPoints, lineWidth);\n    }\n  },\n  setGraphCenter: function setGraphCenter(e, _ref78) {\n    var shape = _ref78.shape,\n        style = _ref78.style;\n    var points = shape.points;\n    style.graphCenter = points[0];\n  },\n  move: function move(_ref79, _ref80) {\n    var movementX = _ref79.movementX,\n        movementY = _ref79.movementY;\n    var shape = _ref80.shape,\n        cache = _ref80.cache;\n    var points = shape.points;\n\n    var _points$ = (0, _slicedToArray2[\"default\"])(points[0], 2),\n        fx = _points$[0],\n        fy = _points$[1];\n\n    var curves = points.slice(1);\n    var bezierCurve = [[fx + movementX, fy + movementY]].concat((0, _toConsumableArray2[\"default\"])(curves.map(function (curve) {\n      return curve.map(function (_ref81) {\n        var _ref82 = (0, _slicedToArray2[\"default\"])(_ref81, 2),\n            x = _ref82[0],\n            y = _ref82[1];\n\n        return [x + movementX, y + movementY];\n      });\n    })));\n    cache.points = bezierCurve;\n    cache.hoverPoints = cache.hoverPoints.map(function (_ref83) {\n      var _ref84 = (0, _slicedToArray2[\"default\"])(_ref83, 2),\n          x = _ref84[0],\n          y = _ref84[1];\n\n      return [x + movementX, y + movementY];\n    });\n    this.attr('shape', {\n      points: bezierCurve\n    });\n  }\n};\nexports.bezierCurve = bezierCurve;\nvar text = {\n  shape: {\n    content: '',\n    position: [],\n    maxWidth: undefined,\n    rowGap: 0\n  },\n  validator: function validator(_ref85) {\n    var shape = _ref85.shape;\n    var content = shape.content,\n        position = shape.position,\n        rowGap = shape.rowGap;\n\n    if (typeof content !== 'string') {\n      console.error('Text content should be a string!');\n      return false;\n    }\n\n    if (!(position instanceof Array)) {\n      console.error('Text position should be an array!');\n      return false;\n    }\n\n    if (typeof rowGap !== 'number') {\n      console.error('Text rowGap should be a number!');\n      return false;\n    }\n\n    return true;\n  },\n  draw: function draw(_ref86, _ref87) {\n    var ctx = _ref86.ctx;\n    var shape = _ref87.shape;\n    var content = shape.content,\n        position = shape.position,\n        maxWidth = shape.maxWidth,\n        rowGap = shape.rowGap;\n    var textBaseline = ctx.textBaseline,\n        font = ctx.font;\n    var fontSize = parseInt(font.replace(/\\D/g, ''));\n\n    var _position = position,\n        _position2 = (0, _slicedToArray2[\"default\"])(_position, 2),\n        x = _position2[0],\n        y = _position2[1];\n\n    content = content.split('\\n');\n    var rowNum = content.length;\n    var lineHeight = fontSize + rowGap;\n    var allHeight = rowNum * lineHeight - rowGap;\n    var offset = 0;\n\n    if (textBaseline === 'middle') {\n      offset = allHeight / 2;\n      y += fontSize / 2;\n    }\n\n    if (textBaseline === 'bottom') {\n      offset = allHeight;\n      y += fontSize;\n    }\n\n    position = new Array(rowNum).fill(0).map(function (foo, i) {\n      return [x, y + i * lineHeight - offset];\n    });\n    ctx.beginPath();\n    content.forEach(function (text, i) {\n      ctx.fillText.apply(ctx, [text].concat((0, _toConsumableArray2[\"default\"])(position[i]), [maxWidth]));\n      ctx.strokeText.apply(ctx, [text].concat((0, _toConsumableArray2[\"default\"])(position[i]), [maxWidth]));\n    });\n    ctx.closePath();\n  },\n  hoverCheck: function hoverCheck(position, _ref88) {\n    var shape = _ref88.shape,\n        style = _ref88.style;\n    return false;\n  },\n  setGraphCenter: function setGraphCenter(e, _ref89) {\n    var shape = _ref89.shape,\n        style = _ref89.style;\n    var position = shape.position;\n    style.graphCenter = (0, _toConsumableArray2[\"default\"])(position);\n  },\n  move: function move(_ref90, _ref91) {\n    var movementX = _ref90.movementX,\n        movementY = _ref90.movementY;\n    var shape = _ref91.shape;\n\n    var _shape$position = (0, _slicedToArray2[\"default\"])(shape.position, 2),\n        x = _shape$position[0],\n        y = _shape$position[1];\n\n    this.attr('shape', {\n      position: [x + movementX, y + movementY]\n    });\n  }\n};\nexports.text = text;\nvar graphs = new Map([['circle', circle], ['ellipse', ellipse], ['rect', rect], ['ring', ring], ['arc', arc], ['sector', sector], ['regPolygon', regPolygon], ['polyline', polyline], ['smoothline', smoothline], ['bezierCurve', bezierCurve], ['text', text]]);\nvar _default = graphs;\n/**\r\n * @description Extend new graph\r\n * @param {String} name   Name of Graph\r\n * @param {Object} config Configuration of Graph\r\n * @return {Undefined} Void\r\n */\n\nexports[\"default\"] = _default;\n\nfunction extendNewGraph(name, config) {\n  if (!name || !config) {\n    console.error('ExtendNewGraph Missing Parameters!');\n    return;\n  }\n\n  if (!config.shape) {\n    console.error('Required attribute of shape to extendNewGraph!');\n    return;\n  }\n\n  if (!config.validator) {\n    console.error('Required function of validator to extendNewGraph!');\n    return;\n  }\n\n  if (!config.draw) {\n    console.error('Required function of draw to extendNewGraph!');\n    return;\n  }\n\n  graphs.set(name, config);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nObject.defineProperty(exports, \"CRender\", {\n  enumerable: true,\n  get: function get() {\n    return _crender[\"default\"];\n  }\n});\nObject.defineProperty(exports, \"extendNewGraph\", {\n  enumerable: true,\n  get: function get() {\n    return _graphs.extendNewGraph;\n  }\n});\nexports[\"default\"] = void 0;\n\nvar _crender = _interopRequireDefault(require(\"./class/crender.class\"));\n\nvar _graphs = require(\"./config/graphs\");\n\nvar _default = _crender[\"default\"];\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.drawPolylinePath = drawPolylinePath;\nexports.drawBezierCurvePath = drawBezierCurvePath;\nexports[\"default\"] = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\n/**\r\n * @description Draw a polyline path\r\n * @param {Object} ctx        Canvas 2d context\r\n * @param {Array} points      The points that makes up a polyline\r\n * @param {Boolean} beginPath Whether to execute beginPath\r\n * @param {Boolean} closePath Whether to execute closePath\r\n * @return {Undefined} Void\r\n */\nfunction drawPolylinePath(ctx, points) {\n  var beginPath = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n  var closePath = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n  if (!ctx || points.length < 2) return false;\n  if (beginPath) ctx.beginPath();\n  points.forEach(function (point, i) {\n    return point && (i === 0 ? ctx.moveTo.apply(ctx, (0, _toConsumableArray2[\"default\"])(point)) : ctx.lineTo.apply(ctx, (0, _toConsumableArray2[\"default\"])(point)));\n  });\n  if (closePath) ctx.closePath();\n}\n/**\r\n * @description Draw a bezier curve path\r\n * @param {Object} ctx        Canvas 2d context\r\n * @param {Array} points      The points that makes up a bezier curve\r\n * @param {Array} moveTo      The point need to excute moveTo\r\n * @param {Boolean} beginPath Whether to execute beginPath\r\n * @param {Boolean} closePath Whether to execute closePath\r\n * @return {Undefined} Void\r\n */\n\n\nfunction drawBezierCurvePath(ctx, points) {\n  var moveTo = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n  var beginPath = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n  var closePath = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;\n  if (!ctx || !points) return false;\n  if (beginPath) ctx.beginPath();\n  if (moveTo) ctx.moveTo.apply(ctx, (0, _toConsumableArray2[\"default\"])(moveTo));\n  points.forEach(function (item) {\n    return item && ctx.bezierCurveTo.apply(ctx, (0, _toConsumableArray2[\"default\"])(item[0]).concat((0, _toConsumableArray2[\"default\"])(item[1]), (0, _toConsumableArray2[\"default\"])(item[2])));\n  });\n  if (closePath) ctx.closePath();\n}\n\nvar _default = {\n  drawPolylinePath: drawPolylinePath,\n  drawBezierCurvePath: drawBezierCurvePath\n};\nexports[\"default\"] = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.deepClone = deepClone;\nexports.eliminateBlur = eliminateBlur;\nexports.checkPointIsInCircle = checkPointIsInCircle;\nexports.getTwoPointDistance = getTwoPointDistance;\nexports.checkPointIsInPolygon = checkPointIsInPolygon;\nexports.checkPointIsInSector = checkPointIsInSector;\nexports.checkPointIsNearPolyline = checkPointIsNearPolyline;\nexports.checkPointIsInRect = checkPointIsInRect;\nexports.getRotatePointPos = getRotatePointPos;\nexports.getScalePointPos = getScalePointPos;\nexports.getTranslatePointPos = getTranslatePointPos;\nexports.getDistanceBetweenPointAndLine = getDistanceBetweenPointAndLine;\nexports.getCircleRadianPoint = getCircleRadianPoint;\nexports.getRegularPolygonPoints = getRegularPolygonPoints;\nexports[\"default\"] = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar abs = Math.abs,\n    sqrt = Math.sqrt,\n    sin = Math.sin,\n    cos = Math.cos,\n    max = Math.max,\n    min = Math.min,\n    PI = Math.PI;\n/**\r\n * @description Clone an object or array\r\n * @param {Object|Array} object Cloned object\r\n * @param {Boolean} recursion   Whether to use recursive cloning\r\n * @return {Object|Array} Clone object\r\n */\n\nfunction deepClone(object) {\n  var recursion = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n  if (!object) return object;\n  var parse = JSON.parse,\n      stringify = JSON.stringify;\n  if (!recursion) return parse(stringify(object));\n  var clonedObj = object instanceof Array ? [] : {};\n\n  if (object && (0, _typeof2[\"default\"])(object) === 'object') {\n    for (var key in object) {\n      if (object.hasOwnProperty(key)) {\n        if (object[key] && (0, _typeof2[\"default\"])(object[key]) === 'object') {\n          clonedObj[key] = deepClone(object[key], true);\n        } else {\n          clonedObj[key] = object[key];\n        }\n      }\n    }\n  }\n\n  return clonedObj;\n}\n/**\r\n * @description Eliminate line blur due to 1px line width\r\n * @param {Array} points Line points\r\n * @return {Array} Line points after processed\r\n */\n\n\nfunction eliminateBlur(points) {\n  return points.map(function (_ref) {\n    var _ref2 = (0, _slicedToArray2[\"default\"])(_ref, 2),\n        x = _ref2[0],\n        y = _ref2[1];\n\n    return [parseInt(x) + 0.5, parseInt(y) + 0.5];\n  });\n}\n/**\r\n * @description Check if the point is inside the circle\r\n * @param {Array} point Postion of point\r\n * @param {Number} rx   Circle x coordinate\r\n * @param {Number} ry   Circle y coordinate\r\n * @param {Number} r    Circle radius\r\n * @return {Boolean} Result of check\r\n */\n\n\nfunction checkPointIsInCircle(point, rx, ry, r) {\n  return getTwoPointDistance(point, [rx, ry]) <= r;\n}\n/**\r\n * @description Get the distance between two points\r\n * @param {Array} point1 point1\r\n * @param {Array} point2 point2\r\n * @return {Number} Distance between two points\r\n */\n\n\nfunction getTwoPointDistance(_ref3, _ref4) {\n  var _ref5 = (0, _slicedToArray2[\"default\"])(_ref3, 2),\n      xa = _ref5[0],\n      ya = _ref5[1];\n\n  var _ref6 = (0, _slicedToArray2[\"default\"])(_ref4, 2),\n      xb = _ref6[0],\n      yb = _ref6[1];\n\n  var minusX = abs(xa - xb);\n  var minusY = abs(ya - yb);\n  return sqrt(minusX * minusX + minusY * minusY);\n}\n/**\r\n * @description Check if the point is inside the polygon\r\n * @param {Array} point  Postion of point\r\n * @param {Array} points The points that makes up a polyline\r\n * @return {Boolean} Result of check\r\n */\n\n\nfunction checkPointIsInPolygon(point, polygon) {\n  var counter = 0;\n\n  var _point = (0, _slicedToArray2[\"default\"])(point, 2),\n      x = _point[0],\n      y = _point[1];\n\n  var pointNum = polygon.length;\n\n  for (var i = 1, p1 = polygon[0]; i <= pointNum; i++) {\n    var p2 = polygon[i % pointNum];\n\n    if (x > min(p1[0], p2[0]) && x <= max(p1[0], p2[0])) {\n      if (y <= max(p1[1], p2[1])) {\n        if (p1[0] !== p2[0]) {\n          var xinters = (x - p1[0]) * (p2[1] - p1[1]) / (p2[0] - p1[0]) + p1[1];\n\n          if (p1[1] === p2[1] || y <= xinters) {\n            counter++;\n          }\n        }\n      }\n    }\n\n    p1 = p2;\n  }\n\n  return counter % 2 === 1;\n}\n/**\r\n * @description Check if the point is inside the sector\r\n * @param {Array} point       Postion of point\r\n * @param {Number} rx         Sector x coordinate\r\n * @param {Number} ry         Sector y coordinate\r\n * @param {Number} r          Sector radius\r\n * @param {Number} startAngle Sector start angle\r\n * @param {Number} endAngle   Sector end angle\r\n * @param {Boolean} clockWise Whether the sector angle is clockwise\r\n * @return {Boolean} Result of check\r\n */\n\n\nfunction checkPointIsInSector(point, rx, ry, r, startAngle, endAngle, clockWise) {\n  if (!point) return false;\n  if (getTwoPointDistance(point, [rx, ry]) > r) return false;\n\n  if (!clockWise) {\n    var _deepClone = deepClone([endAngle, startAngle]);\n\n    var _deepClone2 = (0, _slicedToArray2[\"default\"])(_deepClone, 2);\n\n    startAngle = _deepClone2[0];\n    endAngle = _deepClone2[1];\n  }\n\n  var reverseBE = startAngle > endAngle;\n\n  if (reverseBE) {\n    var _ref7 = [endAngle, startAngle];\n    startAngle = _ref7[0];\n    endAngle = _ref7[1];\n  }\n\n  var minus = endAngle - startAngle;\n  if (minus >= PI * 2) return true;\n\n  var _point2 = (0, _slicedToArray2[\"default\"])(point, 2),\n      x = _point2[0],\n      y = _point2[1];\n\n  var _getCircleRadianPoint = getCircleRadianPoint(rx, ry, r, startAngle),\n      _getCircleRadianPoint2 = (0, _slicedToArray2[\"default\"])(_getCircleRadianPoint, 2),\n      bx = _getCircleRadianPoint2[0],\n      by = _getCircleRadianPoint2[1];\n\n  var _getCircleRadianPoint3 = getCircleRadianPoint(rx, ry, r, endAngle),\n      _getCircleRadianPoint4 = (0, _slicedToArray2[\"default\"])(_getCircleRadianPoint3, 2),\n      ex = _getCircleRadianPoint4[0],\n      ey = _getCircleRadianPoint4[1];\n\n  var vPoint = [x - rx, y - ry];\n  var vBArm = [bx - rx, by - ry];\n  var vEArm = [ex - rx, ey - ry];\n  var reverse = minus > PI;\n\n  if (reverse) {\n    var _deepClone3 = deepClone([vEArm, vBArm]);\n\n    var _deepClone4 = (0, _slicedToArray2[\"default\"])(_deepClone3, 2);\n\n    vBArm = _deepClone4[0];\n    vEArm = _deepClone4[1];\n  }\n\n  var inSector = isClockWise(vBArm, vPoint) && !isClockWise(vEArm, vPoint);\n  if (reverse) inSector = !inSector;\n  if (reverseBE) inSector = !inSector;\n  return inSector;\n}\n/**\r\n * @description Determine if the point is in the clockwise direction of the vector\r\n * @param {Array} vArm   Vector\r\n * @param {Array} vPoint Point\r\n * @return {Boolean} Result of check\r\n */\n\n\nfunction isClockWise(vArm, vPoint) {\n  var _vArm = (0, _slicedToArray2[\"default\"])(vArm, 2),\n      ax = _vArm[0],\n      ay = _vArm[1];\n\n  var _vPoint = (0, _slicedToArray2[\"default\"])(vPoint, 2),\n      px = _vPoint[0],\n      py = _vPoint[1];\n\n  return -ay * px + ax * py > 0;\n}\n/**\r\n * @description Check if the point is inside the polyline\r\n * @param {Array} point      Postion of point\r\n * @param {Array} polyline   The points that makes up a polyline\r\n * @param {Number} lineWidth Polyline linewidth\r\n * @return {Boolean} Result of check\r\n */\n\n\nfunction checkPointIsNearPolyline(point, polyline, lineWidth) {\n  var halfLineWidth = lineWidth / 2;\n  var moveUpPolyline = polyline.map(function (_ref8) {\n    var _ref9 = (0, _slicedToArray2[\"default\"])(_ref8, 2),\n        x = _ref9[0],\n        y = _ref9[1];\n\n    return [x, y - halfLineWidth];\n  });\n  var moveDownPolyline = polyline.map(function (_ref10) {\n    var _ref11 = (0, _slicedToArray2[\"default\"])(_ref10, 2),\n        x = _ref11[0],\n        y = _ref11[1];\n\n    return [x, y + halfLineWidth];\n  });\n  var polygon = [].concat((0, _toConsumableArray2[\"default\"])(moveUpPolyline), (0, _toConsumableArray2[\"default\"])(moveDownPolyline.reverse()));\n  return checkPointIsInPolygon(point, polygon);\n}\n/**\r\n * @description Check if the point is inside the rect\r\n * @param {Array} point   Postion of point\r\n * @param {Number} x      Rect start x coordinate\r\n * @param {Number} y      Rect start y coordinate\r\n * @param {Number} width  Rect width\r\n * @param {Number} height Rect height\r\n * @return {Boolean} Result of check\r\n */\n\n\nfunction checkPointIsInRect(_ref12, x, y, width, height) {\n  var _ref13 = (0, _slicedToArray2[\"default\"])(_ref12, 2),\n      px = _ref13[0],\n      py = _ref13[1];\n\n  if (px < x) return false;\n  if (py < y) return false;\n  if (px > x + width) return false;\n  if (py > y + height) return false;\n  return true;\n}\n/**\r\n * @description Get the coordinates of the rotated point\r\n * @param {Number} rotate Degree of rotation\r\n * @param {Array} point   Postion of point\r\n * @param {Array} origin  Rotation center\r\n * @param {Array} origin  Rotation center\r\n * @return {Number} Coordinates after rotation\r\n */\n\n\nfunction getRotatePointPos() {\n  var rotate = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n  var point = arguments.length > 1 ? arguments[1] : undefined;\n  var origin = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [0, 0];\n  if (!point) return false;\n  if (rotate % 360 === 0) return point;\n\n  var _point3 = (0, _slicedToArray2[\"default\"])(point, 2),\n      x = _point3[0],\n      y = _point3[1];\n\n  var _origin = (0, _slicedToArray2[\"default\"])(origin, 2),\n      ox = _origin[0],\n      oy = _origin[1];\n\n  rotate *= PI / 180;\n  return [(x - ox) * cos(rotate) - (y - oy) * sin(rotate) + ox, (x - ox) * sin(rotate) + (y - oy) * cos(rotate) + oy];\n}\n/**\r\n * @description Get the coordinates of the scaled point\r\n * @param {Array} scale  Scale factor\r\n * @param {Array} point  Postion of point\r\n * @param {Array} origin Scale center\r\n * @return {Number} Coordinates after scale\r\n */\n\n\nfunction getScalePointPos() {\n  var scale = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [1, 1];\n  var point = arguments.length > 1 ? arguments[1] : undefined;\n  var origin = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [0, 0];\n  if (!point) return false;\n  if (scale === 1) return point;\n\n  var _point4 = (0, _slicedToArray2[\"default\"])(point, 2),\n      x = _point4[0],\n      y = _point4[1];\n\n  var _origin2 = (0, _slicedToArray2[\"default\"])(origin, 2),\n      ox = _origin2[0],\n      oy = _origin2[1];\n\n  var _scale = (0, _slicedToArray2[\"default\"])(scale, 2),\n      xs = _scale[0],\n      ys = _scale[1];\n\n  var relativePosX = x - ox;\n  var relativePosY = y - oy;\n  return [relativePosX * xs + ox, relativePosY * ys + oy];\n}\n/**\r\n * @description Get the coordinates of the scaled point\r\n * @param {Array} translate Translation distance\r\n * @param {Array} point     Postion of point\r\n * @return {Number} Coordinates after translation\r\n */\n\n\nfunction getTranslatePointPos(translate, point) {\n  if (!translate || !point) return false;\n\n  var _point5 = (0, _slicedToArray2[\"default\"])(point, 2),\n      x = _point5[0],\n      y = _point5[1];\n\n  var _translate = (0, _slicedToArray2[\"default\"])(translate, 2),\n      tx = _translate[0],\n      ty = _translate[1];\n\n  return [x + tx, y + ty];\n}\n/**\r\n * @description Get the distance from the point to the line\r\n * @param {Array} point     Postion of point\r\n * @param {Array} lineBegin Line start position\r\n * @param {Array} lineEnd   Line end position\r\n * @return {Number} Distance between point and line\r\n */\n\n\nfunction getDistanceBetweenPointAndLine(point, lineBegin, lineEnd) {\n  if (!point || !lineBegin || !lineEnd) return false;\n\n  var _point6 = (0, _slicedToArray2[\"default\"])(point, 2),\n      x = _point6[0],\n      y = _point6[1];\n\n  var _lineBegin = (0, _slicedToArray2[\"default\"])(lineBegin, 2),\n      x1 = _lineBegin[0],\n      y1 = _lineBegin[1];\n\n  var _lineEnd = (0, _slicedToArray2[\"default\"])(lineEnd, 2),\n      x2 = _lineEnd[0],\n      y2 = _lineEnd[1];\n\n  var a = y2 - y1;\n  var b = x1 - x2;\n  var c = y1 * (x2 - x1) - x1 * (y2 - y1);\n  var molecule = abs(a * x + b * y + c);\n  var denominator = sqrt(a * a + b * b);\n  return molecule / denominator;\n}\n/**\r\n * @description Get the coordinates of the specified radian on the circle\r\n * @param {Number} x      Circle x coordinate\r\n * @param {Number} y      Circle y coordinate\r\n * @param {Number} radius Circle radius\r\n * @param {Number} radian Specfied radian\r\n * @return {Array} Postion of point\r\n */\n\n\nfunction getCircleRadianPoint(x, y, radius, radian) {\n  return [x + cos(radian) * radius, y + sin(radian) * radius];\n}\n/**\r\n * @description Get the points that make up a regular polygon\r\n * @param {Number} x     X coordinate of the polygon inscribed circle\r\n * @param {Number} y     Y coordinate of the polygon inscribed circle\r\n * @param {Number} r     Radius of the polygon inscribed circle\r\n * @param {Number} side  Side number\r\n * @param {Number} minus Radian offset\r\n * @return {Array} Points that make up a regular polygon\r\n */\n\n\nfunction getRegularPolygonPoints(rx, ry, r, side) {\n  var minus = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : PI * -0.5;\n  var radianGap = PI * 2 / side;\n  var radians = new Array(side).fill('').map(function (t, i) {\n    return i * radianGap + minus;\n  });\n  return radians.map(function (radian) {\n    return getCircleRadianPoint(rx, ry, r, radian);\n  });\n}\n\nvar _default = {\n  deepClone: deepClone,\n  eliminateBlur: eliminateBlur,\n  checkPointIsInCircle: checkPointIsInCircle,\n  checkPointIsInPolygon: checkPointIsInPolygon,\n  checkPointIsInSector: checkPointIsInSector,\n  checkPointIsNearPolyline: checkPointIsNearPolyline,\n  getTwoPointDistance: getTwoPointDistance,\n  getRotatePointPos: getRotatePointPos,\n  getScalePointPos: getScalePointPos,\n  getTranslatePointPos: getTranslatePointPos,\n  getCircleRadianPoint: getCircleRadianPoint,\n  getRegularPolygonPoints: getRegularPolygonPoints,\n  getDistanceBetweenPointAndLine: getDistanceBetweenPointAndLine\n};\nexports[\"default\"] = _default;","function _arrayWithHoles(arr) {\n  if (Array.isArray(arr)) return arr;\n}\n\nmodule.exports = _arrayWithHoles;","function _arrayWithoutHoles(arr) {\n  if (Array.isArray(arr)) {\n    for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) {\n      arr2[i] = arr[i];\n    }\n\n    return arr2;\n  }\n}\n\nmodule.exports = _arrayWithoutHoles;","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n  try {\n    var info = gen[key](arg);\n    var value = info.value;\n  } catch (error) {\n    reject(error);\n    return;\n  }\n\n  if (info.done) {\n    resolve(value);\n  } else {\n    Promise.resolve(value).then(_next, _throw);\n  }\n}\n\nfunction _asyncToGenerator(fn) {\n  return function () {\n    var self = this,\n        args = arguments;\n    return new Promise(function (resolve, reject) {\n      var gen = fn.apply(self, args);\n\n      function _next(value) {\n        asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n      }\n\n      function _throw(err) {\n        asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n      }\n\n      _next(undefined);\n    });\n  };\n}\n\nmodule.exports = _asyncToGenerator;","function _classCallCheck(instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n}\n\nmodule.exports = _classCallCheck;","function _defineProperty(obj, key, value) {\n  if (key in obj) {\n    Object.defineProperty(obj, key, {\n      value: value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n}\n\nmodule.exports = _defineProperty;","function _interopRequireDefault(obj) {\n  return obj && obj.__esModule ? obj : {\n    \"default\": obj\n  };\n}\n\nmodule.exports = _interopRequireDefault;","function _iterableToArray(iter) {\n  if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}\n\nmodule.exports = _iterableToArray;","function _iterableToArrayLimit(arr, i) {\n  var _arr = [];\n  var _n = true;\n  var _d = false;\n  var _e = undefined;\n\n  try {\n    for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n      _arr.push(_s.value);\n\n      if (i && _arr.length === i) break;\n    }\n  } catch (err) {\n    _d = true;\n    _e = err;\n  } finally {\n    try {\n      if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n    } finally {\n      if (_d) throw _e;\n    }\n  }\n\n  return _arr;\n}\n\nmodule.exports = _iterableToArrayLimit;","function _nonIterableRest() {\n  throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n}\n\nmodule.exports = _nonIterableRest;","function _nonIterableSpread() {\n  throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}\n\nmodule.exports = _nonIterableSpread;","var arrayWithHoles = require(\"./arrayWithHoles\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit\");\n\nvar nonIterableRest = require(\"./nonIterableRest\");\n\nfunction _slicedToArray(arr, i) {\n  return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray;","var arrayWithoutHoles = require(\"./arrayWithoutHoles\");\n\nvar iterableToArray = require(\"./iterableToArray\");\n\nvar nonIterableSpread = require(\"./nonIterableSpread\");\n\nfunction _toConsumableArray(arr) {\n  return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();\n}\n\nmodule.exports = _toConsumableArray;","function _typeof2(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof2(obj); }\n\nfunction _typeof(obj) {\n  if (typeof Symbol === \"function\" && _typeof2(Symbol.iterator) === \"symbol\") {\n    module.exports = _typeof = function _typeof(obj) {\n      return _typeof2(obj);\n    };\n  } else {\n    module.exports = _typeof = function _typeof(obj) {\n      return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : _typeof2(obj);\n    };\n  }\n\n  return _typeof(obj);\n}\n\nmodule.exports = _typeof;","module.exports = require(\"regenerator-runtime\");\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.bezierCurveToPolyline = bezierCurveToPolyline;\nexports.getBezierCurveLength = getBezierCurveLength;\nexports[\"default\"] = void 0;\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); }\n\nfunction _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance\"); }\n\nfunction _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }\n\nvar sqrt = Math.sqrt,\n    pow = Math.pow,\n    ceil = Math.ceil,\n    abs = Math.abs; // Initialize the number of points per curve\n\nvar defaultSegmentPointsNum = 50;\n/**\r\n * @example data structure of bezierCurve\r\n * bezierCurve = [\r\n *  // Starting point of the curve\r\n *  [10, 10],\r\n *  // BezierCurve segment data (controlPoint1, controlPoint2, endPoint)\r\n *  [\r\n *    [20, 20], [40, 20], [50, 10]\r\n *  ],\r\n *  ...\r\n * ]\r\n */\n\n/**\r\n * @description               Abstract the curve as a polyline consisting of N points\r\n * @param {Array} bezierCurve bezierCurve data\r\n * @param {Number} precision  calculation accuracy. Recommended for 1-20. Default = 5\r\n * @return {Object}           Calculation results and related data\r\n * @return {Array}            Option.segmentPoints Point data that constitutes a polyline after calculation\r\n * @return {Number}           Option.cycles Number of iterations\r\n * @return {Number}           Option.rounds The number of recursions for the last iteration\r\n */\n\nfunction abstractBezierCurveToPolyline(bezierCurve) {\n  var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5;\n  var segmentsNum = bezierCurve.length - 1;\n  var startPoint = bezierCurve[0];\n  var endPoint = bezierCurve[segmentsNum][2];\n  var segments = bezierCurve.slice(1);\n  var getSegmentTPointFuns = segments.map(function (seg, i) {\n    var beginPoint = i === 0 ? startPoint : segments[i - 1][2];\n    return createGetBezierCurveTPointFun.apply(void 0, [beginPoint].concat(_toConsumableArray(seg)));\n  }); // Initialize the curve to a polyline\n\n  var segmentPointsNum = new Array(segmentsNum).fill(defaultSegmentPointsNum);\n  var segmentPoints = getSegmentPointsByNum(getSegmentTPointFuns, segmentPointsNum); // Calculate uniformly distributed points by iteratively\n\n  var result = calcUniformPointsByIteration(segmentPoints, getSegmentTPointFuns, segments, precision);\n  result.segmentPoints.push(endPoint);\n  return result;\n}\n/**\r\n * @description  Generate a method for obtaining corresponding point by t according to curve data\r\n * @param {Array} beginPoint    BezierCurve begin point. [x, y]\r\n * @param {Array} controlPoint1 BezierCurve controlPoint1. [x, y]\r\n * @param {Array} controlPoint2 BezierCurve controlPoint2. [x, y]\r\n * @param {Array} endPoint      BezierCurve end point. [x, y]\r\n * @return {Function} Expected function\r\n */\n\n\nfunction createGetBezierCurveTPointFun(beginPoint, controlPoint1, controlPoint2, endPoint) {\n  return function (t) {\n    var tSubed1 = 1 - t;\n    var tSubed1Pow3 = pow(tSubed1, 3);\n    var tSubed1Pow2 = pow(tSubed1, 2);\n    var tPow3 = pow(t, 3);\n    var tPow2 = pow(t, 2);\n    return [beginPoint[0] * tSubed1Pow3 + 3 * controlPoint1[0] * t * tSubed1Pow2 + 3 * controlPoint2[0] * tPow2 * tSubed1 + endPoint[0] * tPow3, beginPoint[1] * tSubed1Pow3 + 3 * controlPoint1[1] * t * tSubed1Pow2 + 3 * controlPoint2[1] * tPow2 * tSubed1 + endPoint[1] * tPow3];\n  };\n}\n/**\r\n * @description Get the distance between two points\r\n * @param {Array} point1 BezierCurve begin point. [x, y]\r\n * @param {Array} point2 BezierCurve controlPoint1. [x, y]\r\n * @return {Number} Expected distance\r\n */\n\n\nfunction getTwoPointDistance(_ref, _ref2) {\n  var _ref3 = _slicedToArray(_ref, 2),\n      ax = _ref3[0],\n      ay = _ref3[1];\n\n  var _ref4 = _slicedToArray(_ref2, 2),\n      bx = _ref4[0],\n      by = _ref4[1];\n\n  return sqrt(pow(ax - bx, 2) + pow(ay - by, 2));\n}\n/**\r\n * @description Get the sum of the array of numbers\r\n * @param {Array} nums An array of numbers\r\n * @return {Number} Expected sum\r\n */\n\n\nfunction getNumsSum(nums) {\n  return nums.reduce(function (sum, num) {\n    return sum + num;\n  }, 0);\n}\n/**\r\n * @description Get the distance of multiple sets of points\r\n * @param {Array} segmentPoints Multiple sets of point data\r\n * @return {Array} Distance of multiple sets of point data\r\n */\n\n\nfunction getSegmentPointsDistance(segmentPoints) {\n  return segmentPoints.map(function (points, i) {\n    return new Array(points.length - 1).fill(0).map(function (temp, j) {\n      return getTwoPointDistance(points[j], points[j + 1]);\n    });\n  });\n}\n/**\r\n * @description Get the distance of multiple sets of points\r\n * @param {Array} segmentPoints Multiple sets of point data\r\n * @return {Array} Distance of multiple sets of point data\r\n */\n\n\nfunction getSegmentPointsByNum(getSegmentTPointFuns, segmentPointsNum) {\n  return getSegmentTPointFuns.map(function (getSegmentTPointFun, i) {\n    var tGap = 1 / segmentPointsNum[i];\n    return new Array(segmentPointsNum[i]).fill('').map(function (foo, j) {\n      return getSegmentTPointFun(j * tGap);\n    });\n  });\n}\n/**\r\n * @description Get the sum of deviations between line segment and the average length\r\n * @param {Array} segmentPointsDistance Segment length of polyline\r\n * @param {Number} avgLength            Average length of the line segment\r\n * @return {Number} Deviations\r\n */\n\n\nfunction getAllDeviations(segmentPointsDistance, avgLength) {\n  return segmentPointsDistance.map(function (seg) {\n    return seg.map(function (s) {\n      return abs(s - avgLength);\n    });\n  }).map(function (seg) {\n    return getNumsSum(seg);\n  }).reduce(function (total, v) {\n    return total + v;\n  }, 0);\n}\n/**\r\n * @description Calculate uniformly distributed points by iteratively\r\n * @param {Array} segmentPoints        Multiple setd of points that make up a polyline\r\n * @param {Array} getSegmentTPointFuns Functions of get a point on the curve with t\r\n * @param {Array} segments             BezierCurve data\r\n * @param {Number} precision           Calculation accuracy\r\n * @return {Object} Calculation results and related data\r\n * @return {Array}  Option.segmentPoints Point data that constitutes a polyline after calculation\r\n * @return {Number} Option.cycles Number of iterations\r\n * @return {Number} Option.rounds The number of recursions for the last iteration\r\n */\n\n\nfunction calcUniformPointsByIteration(segmentPoints, getSegmentTPointFuns, segments, precision) {\n  // The number of loops for the current iteration\n  var rounds = 4; // Number of iterations\n\n  var cycles = 1;\n\n  var _loop = function _loop() {\n    // Recalculate the number of points per curve based on the last iteration data\n    var totalPointsNum = segmentPoints.reduce(function (total, seg) {\n      return total + seg.length;\n    }, 0); // Add last points of segment to calc exact segment length\n\n    segmentPoints.forEach(function (seg, i) {\n      return seg.push(segments[i][2]);\n    });\n    var segmentPointsDistance = getSegmentPointsDistance(segmentPoints);\n    var lineSegmentNum = segmentPointsDistance.reduce(function (total, seg) {\n      return total + seg.length;\n    }, 0);\n    var segmentlength = segmentPointsDistance.map(function (seg) {\n      return getNumsSum(seg);\n    });\n    var totalLength = getNumsSum(segmentlength);\n    var avgLength = totalLength / lineSegmentNum; // Check if precision is reached\n\n    var allDeviations = getAllDeviations(segmentPointsDistance, avgLength);\n    if (allDeviations <= precision) return \"break\";\n    totalPointsNum = ceil(avgLength / precision * totalPointsNum * 1.1);\n    var segmentPointsNum = segmentlength.map(function (length) {\n      return ceil(length / totalLength * totalPointsNum);\n    }); // Calculate the points after redistribution\n\n    segmentPoints = getSegmentPointsByNum(getSegmentTPointFuns, segmentPointsNum);\n    totalPointsNum = segmentPoints.reduce(function (total, seg) {\n      return total + seg.length;\n    }, 0);\n    var segmentPointsForLength = JSON.parse(JSON.stringify(segmentPoints));\n    segmentPointsForLength.forEach(function (seg, i) {\n      return seg.push(segments[i][2]);\n    });\n    segmentPointsDistance = getSegmentPointsDistance(segmentPointsForLength);\n    lineSegmentNum = segmentPointsDistance.reduce(function (total, seg) {\n      return total + seg.length;\n    }, 0);\n    segmentlength = segmentPointsDistance.map(function (seg) {\n      return getNumsSum(seg);\n    });\n    totalLength = getNumsSum(segmentlength);\n    avgLength = totalLength / lineSegmentNum;\n    var stepSize = 1 / totalPointsNum / 10; // Recursively for each segment of the polyline\n\n    getSegmentTPointFuns.forEach(function (getSegmentTPointFun, i) {\n      var currentSegmentPointsNum = segmentPointsNum[i];\n      var t = new Array(currentSegmentPointsNum).fill('').map(function (foo, j) {\n        return j / segmentPointsNum[i];\n      }); // Repeated recursive offset\n\n      for (var r = 0; r < rounds; r++) {\n        var distance = getSegmentPointsDistance([segmentPoints[i]])[0];\n        var deviations = distance.map(function (d) {\n          return d - avgLength;\n        });\n        var offset = 0;\n\n        for (var j = 0; j < currentSegmentPointsNum; j++) {\n          if (j === 0) return;\n          offset += deviations[j - 1];\n          t[j] -= stepSize * offset;\n          if (t[j] > 1) t[j] = 1;\n          if (t[j] < 0) t[j] = 0;\n          segmentPoints[i][j] = getSegmentTPointFun(t[j]);\n        }\n      }\n    });\n    rounds *= 4;\n    cycles++;\n  };\n\n  do {\n    var _ret = _loop();\n\n    if (_ret === \"break\") break;\n  } while (rounds <= 1025);\n\n  segmentPoints = segmentPoints.reduce(function (all, seg) {\n    return all.concat(seg);\n  }, []);\n  return {\n    segmentPoints: segmentPoints,\n    cycles: cycles,\n    rounds: rounds\n  };\n}\n/**\r\n * @description Get the polyline corresponding to the Bezier curve\r\n * @param {Array} bezierCurve BezierCurve data\r\n * @param {Number} precision  Calculation accuracy. Recommended for 1-20. Default = 5\r\n * @return {Array|Boolean} Point data that constitutes a polyline after calculation (Invalid input will return false)\r\n */\n\n\nfunction bezierCurveToPolyline(bezierCurve) {\n  var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5;\n\n  if (!bezierCurve) {\n    console.error('bezierCurveToPolyline: Missing parameters!');\n    return false;\n  }\n\n  if (!(bezierCurve instanceof Array)) {\n    console.error('bezierCurveToPolyline: Parameter bezierCurve must be an array!');\n    return false;\n  }\n\n  if (typeof precision !== 'number') {\n    console.error('bezierCurveToPolyline: Parameter precision must be a number!');\n    return false;\n  }\n\n  var _abstractBezierCurveT = abstractBezierCurveToPolyline(bezierCurve, precision),\n      segmentPoints = _abstractBezierCurveT.segmentPoints;\n\n  return segmentPoints;\n}\n/**\r\n * @description Get the bezier curve length\r\n * @param {Array} bezierCurve bezierCurve data\r\n * @param {Number} precision  calculation accuracy. Recommended for 5-10. Default = 5\r\n * @return {Number|Boolean} BezierCurve length (Invalid input will return false)\r\n */\n\n\nfunction getBezierCurveLength(bezierCurve) {\n  var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5;\n\n  if (!bezierCurve) {\n    console.error('getBezierCurveLength: Missing parameters!');\n    return false;\n  }\n\n  if (!(bezierCurve instanceof Array)) {\n    console.error('getBezierCurveLength: Parameter bezierCurve must be an array!');\n    return false;\n  }\n\n  if (typeof precision !== 'number') {\n    console.error('getBezierCurveLength: Parameter precision must be a number!');\n    return false;\n  }\n\n  var _abstractBezierCurveT2 = abstractBezierCurveToPolyline(bezierCurve, precision),\n      segmentPoints = _abstractBezierCurveT2.segmentPoints; // Calculate the total length of the points that make up the polyline\n\n\n  var pointsDistance = getSegmentPointsDistance([segmentPoints])[0];\n  var length = getNumsSum(pointsDistance);\n  return length;\n}\n\nvar _default = bezierCurveToPolyline;\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports[\"default\"] = void 0;\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); }\n\nfunction _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance\"); }\n\nfunction _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }\n\n/**\r\n * @description Abstract the polyline formed by N points into a set of bezier curve\r\n * @param {Array} polyline A set of points that make up a polyline\r\n * @param {Boolean} close  Closed curve\r\n * @param {Number} offsetA Smoothness\r\n * @param {Number} offsetB Smoothness\r\n * @return {Array|Boolean} A set of bezier curve (Invalid input will return false)\r\n */\nfunction polylineToBezierCurve(polyline) {\n  var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n  var offsetA = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0.25;\n  var offsetB = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0.25;\n\n  if (!(polyline instanceof Array)) {\n    console.error('polylineToBezierCurve: Parameter polyline must be an array!');\n    return false;\n  }\n\n  if (polyline.length <= 2) {\n    console.error('polylineToBezierCurve: Converting to a curve requires at least 3 points!');\n    return false;\n  }\n\n  var startPoint = polyline[0];\n  var bezierCurveLineNum = polyline.length - 1;\n  var bezierCurvePoints = new Array(bezierCurveLineNum).fill(0).map(function (foo, i) {\n    return [].concat(_toConsumableArray(getBezierCurveLineControlPoints(polyline, i, close, offsetA, offsetB)), [polyline[i + 1]]);\n  });\n  if (close) closeBezierCurve(bezierCurvePoints, startPoint);\n  bezierCurvePoints.unshift(polyline[0]);\n  return bezierCurvePoints;\n}\n/**\r\n * @description Get the control points of the Bezier curve\r\n * @param {Array} polyline A set of points that make up a polyline\r\n * @param {Number} index   The index of which get controls points's point in polyline\r\n * @param {Boolean} close  Closed curve\r\n * @param {Number} offsetA Smoothness\r\n * @param {Number} offsetB Smoothness\r\n * @return {Array} Control points\r\n */\n\n\nfunction getBezierCurveLineControlPoints(polyline, index) {\n  var close = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n  var offsetA = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0.25;\n  var offsetB = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 0.25;\n  var pointNum = polyline.length;\n  if (pointNum < 3 || index >= pointNum) return;\n  var beforePointIndex = index - 1;\n  if (beforePointIndex < 0) beforePointIndex = close ? pointNum + beforePointIndex : 0;\n  var afterPointIndex = index + 1;\n  if (afterPointIndex >= pointNum) afterPointIndex = close ? afterPointIndex - pointNum : pointNum - 1;\n  var afterNextPointIndex = index + 2;\n  if (afterNextPointIndex >= pointNum) afterNextPointIndex = close ? afterNextPointIndex - pointNum : pointNum - 1;\n  var pointBefore = polyline[beforePointIndex];\n  var pointMiddle = polyline[index];\n  var pointAfter = polyline[afterPointIndex];\n  var pointAfterNext = polyline[afterNextPointIndex];\n  return [[pointMiddle[0] + offsetA * (pointAfter[0] - pointBefore[0]), pointMiddle[1] + offsetA * (pointAfter[1] - pointBefore[1])], [pointAfter[0] - offsetB * (pointAfterNext[0] - pointMiddle[0]), pointAfter[1] - offsetB * (pointAfterNext[1] - pointMiddle[1])]];\n}\n/**\r\n * @description Get the last curve of the closure\r\n * @param {Array} bezierCurve A set of sub-curve\r\n * @param {Array} startPoint  Start point\r\n * @return {Array} The last curve for closure\r\n */\n\n\nfunction closeBezierCurve(bezierCurve, startPoint) {\n  var firstSubCurve = bezierCurve[0];\n  var lastSubCurve = bezierCurve.slice(-1)[0];\n  bezierCurve.push([getSymmetryPoint(lastSubCurve[1], lastSubCurve[2]), getSymmetryPoint(firstSubCurve[0], startPoint), startPoint]);\n  return bezierCurve;\n}\n/**\r\n * @description Get the symmetry point\r\n * @param {Array} point       Symmetric point\r\n * @param {Array} centerPoint Symmetric center\r\n * @return {Array} Symmetric point\r\n */\n\n\nfunction getSymmetryPoint(point, centerPoint) {\n  var _point = _slicedToArray(point, 2),\n      px = _point[0],\n      py = _point[1];\n\n  var _centerPoint = _slicedToArray(centerPoint, 2),\n      cx = _centerPoint[0],\n      cy = _centerPoint[1];\n\n  var minusX = cx - px;\n  var minusY = cy - py;\n  return [cx + minusX, cy + minusY];\n}\n\nvar _default = polylineToBezierCurve;\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nObject.defineProperty(exports, \"bezierCurveToPolyline\", {\n  enumerable: true,\n  get: function get() {\n    return _bezierCurveToPolyline.bezierCurveToPolyline;\n  }\n});\nObject.defineProperty(exports, \"getBezierCurveLength\", {\n  enumerable: true,\n  get: function get() {\n    return _bezierCurveToPolyline.getBezierCurveLength;\n  }\n});\nObject.defineProperty(exports, \"polylineToBezierCurve\", {\n  enumerable: true,\n  get: function get() {\n    return _polylineToBezierCurve[\"default\"];\n  }\n});\nexports[\"default\"] = void 0;\n\nvar _bezierCurveToPolyline = require(\"./core/bezierCurveToPolyline\");\n\nvar _polylineToBezierCurve = _interopRequireDefault(require(\"./core/polylineToBezierCurve\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nvar _default = {\n  bezierCurveToPolyline: _bezierCurveToPolyline.bezierCurveToPolyline,\n  getBezierCurveLength: _bezierCurveToPolyline.getBezierCurveLength,\n  polylineToBezierCurve: _polylineToBezierCurve[\"default\"]\n};\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports[\"default\"] = void 0;\n\nvar _default = new Map([['transparent', 'rgba(0,0,0,0)'], ['black', '#000000'], ['silver', '#C0C0C0'], ['gray', '#808080'], ['white', '#FFFFFF'], ['maroon', '#800000'], ['red', '#FF0000'], ['purple', '#800080'], ['fuchsia', '#FF00FF'], ['green', '#008000'], ['lime', '#00FF00'], ['olive', '#808000'], ['yellow', '#FFFF00'], ['navy', '#000080'], ['blue', '#0000FF'], ['teal', '#008080'], ['aqua', '#00FFFF'], ['aliceblue', '#f0f8ff'], ['antiquewhite', '#faebd7'], ['aquamarine', '#7fffd4'], ['azure', '#f0ffff'], ['beige', '#f5f5dc'], ['bisque', '#ffe4c4'], ['blanchedalmond', '#ffebcd'], ['blueviolet', '#8a2be2'], ['brown', '#a52a2a'], ['burlywood', '#deb887'], ['cadetblue', '#5f9ea0'], ['chartreuse', '#7fff00'], ['chocolate', '#d2691e'], ['coral', '#ff7f50'], ['cornflowerblue', '#6495ed'], ['cornsilk', '#fff8dc'], ['crimson', '#dc143c'], ['cyan', '#00ffff'], ['darkblue', '#00008b'], ['darkcyan', '#008b8b'], ['darkgoldenrod', '#b8860b'], ['darkgray', '#a9a9a9'], ['darkgreen', '#006400'], ['darkgrey', '#a9a9a9'], ['darkkhaki', '#bdb76b'], ['darkmagenta', '#8b008b'], ['darkolivegreen', '#556b2f'], ['darkorange', '#ff8c00'], ['darkorchid', '#9932cc'], ['darkred', '#8b0000'], ['darksalmon', '#e9967a'], ['darkseagreen', '#8fbc8f'], ['darkslateblue', '#483d8b'], ['darkslategray', '#2f4f4f'], ['darkslategrey', '#2f4f4f'], ['darkturquoise', '#00ced1'], ['darkviolet', '#9400d3'], ['deeppink', '#ff1493'], ['deepskyblue', '#00bfff'], ['dimgray', '#696969'], ['dimgrey', '#696969'], ['dodgerblue', '#1e90ff'], ['firebrick', '#b22222'], ['floralwhite', '#fffaf0'], ['forestgreen', '#228b22'], ['gainsboro', '#dcdcdc'], ['ghostwhite', '#f8f8ff'], ['gold', '#ffd700'], ['goldenrod', '#daa520'], ['greenyellow', '#adff2f'], ['grey', '#808080'], ['honeydew', '#f0fff0'], ['hotpink', '#ff69b4'], ['indianred', '#cd5c5c'], ['indigo', '#4b0082'], ['ivory', '#fffff0'], ['khaki', '#f0e68c'], ['lavender', '#e6e6fa'], ['lavenderblush', '#fff0f5'], ['lawngreen', '#7cfc00'], ['lemonchiffon', '#fffacd'], ['lightblue', '#add8e6'], ['lightcoral', '#f08080'], ['lightcyan', '#e0ffff'], ['lightgoldenrodyellow', '#fafad2'], ['lightgray', '#d3d3d3'], ['lightgreen', '#90ee90'], ['lightgrey', '#d3d3d3'], ['lightpink', '#ffb6c1'], ['lightsalmon', '#ffa07a'], ['lightseagreen', '#20b2aa'], ['lightskyblue', '#87cefa'], ['lightslategray', '#778899'], ['lightslategrey', '#778899'], ['lightsteelblue', '#b0c4de'], ['lightyellow', '#ffffe0'], ['limegreen', '#32cd32'], ['linen', '#faf0e6'], ['magenta', '#ff00ff'], ['mediumaquamarine', '#66cdaa'], ['mediumblue', '#0000cd'], ['mediumorchid', '#ba55d3'], ['mediumpurple', '#9370db'], ['mediumseagreen', '#3cb371'], ['mediumslateblue', '#7b68ee'], ['mediumspringgreen', '#00fa9a'], ['mediumturquoise', '#48d1cc'], ['mediumvioletred', '#c71585'], ['midnightblue', '#191970'], ['mintcream', '#f5fffa'], ['mistyrose', '#ffe4e1'], ['moccasin', '#ffe4b5'], ['navajowhite', '#ffdead'], ['oldlace', '#fdf5e6'], ['olivedrab', '#6b8e23'], ['orange', '#ffa500'], ['orangered', '#ff4500'], ['orchid', '#da70d6'], ['palegoldenrod', '#eee8aa'], ['palegreen', '#98fb98'], ['paleturquoise', '#afeeee'], ['palevioletred', '#db7093'], ['papayawhip', '#ffefd5'], ['peachpuff', '#ffdab9'], ['peru', '#cd853f'], ['pink', '#ffc0cb'], ['plum', '#dda0dd'], ['powderblue', '#b0e0e6'], ['rosybrown', '#bc8f8f'], ['royalblue', '#4169e1'], ['saddlebrown', '#8b4513'], ['salmon', '#fa8072'], ['sandybrown', '#f4a460'], ['seagreen', '#2e8b57'], ['seashell', '#fff5ee'], ['sienna', '#a0522d'], ['skyblue', '#87ceeb'], ['slateblue', '#6a5acd'], ['slategray', '#708090'], ['slategrey', '#708090'], ['snow', '#fffafa'], ['springgreen', '#00ff7f'], ['steelblue', '#4682b4'], ['tan', '#d2b48c'], ['thistle', '#d8bfd8'], ['tomato', '#ff6347'], ['turquoise', '#40e0d0'], ['violet', '#ee82ee'], ['wheat', '#f5deb3'], ['whitesmoke', '#f5f5f5'], ['yellowgreen', '#9acd32']]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.getRgbValue = getRgbValue;\nexports.getRgbaValue = getRgbaValue;\nexports.getOpacity = getOpacity;\nexports.toRgb = toRgb;\nexports.toHex = toHex;\nexports.getColorFromRgbValue = getColorFromRgbValue;\nexports.darken = darken;\nexports.lighten = lighten;\nexports.fade = fade;\nexports[\"default\"] = void 0;\n\nvar _keywords = _interopRequireDefault(require(\"./config/keywords\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance\"); }\n\nfunction _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }\n\nvar hexReg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;\nvar rgbReg = /^(rgb|rgba|RGB|RGBA)/;\nvar rgbaReg = /^(rgba|RGBA)/;\n/**\r\n * @description Color validator\r\n * @param {String} color Hex|Rgb|Rgba color or color keyword\r\n * @return {String|Boolean} Valid color Or false\r\n */\n\nfunction validator(color) {\n  var isHex = hexReg.test(color);\n  var isRgb = rgbReg.test(color);\n  if (isHex || isRgb) return color;\n  color = getColorByKeyword(color);\n\n  if (!color) {\n    console.error('Color: Invalid color!');\n    return false;\n  }\n\n  return color;\n}\n/**\r\n * @description Get color by keyword\r\n * @param {String} keyword Color keyword like red, green and etc.\r\n * @return {String|Boolean} Hex or rgba color (Invalid keyword will return false)\r\n */\n\n\nfunction getColorByKeyword(keyword) {\n  if (!keyword) {\n    console.error('getColorByKeywords: Missing parameters!');\n    return false;\n  }\n\n  if (!_keywords[\"default\"].has(keyword)) return false;\n  return _keywords[\"default\"].get(keyword);\n}\n/**\r\n * @description Get the Rgb value of the color\r\n * @param {String} color Hex|Rgb|Rgba color or color keyword\r\n * @return {Array<Number>|Boolean} Rgb value of the color (Invalid input will return false)\r\n */\n\n\nfunction getRgbValue(color) {\n  if (!color) {\n    console.error('getRgbValue: Missing parameters!');\n    return false;\n  }\n\n  color = validator(color);\n  if (!color) return false;\n  var isHex = hexReg.test(color);\n  var isRgb = rgbReg.test(color);\n  var lowerColor = color.toLowerCase();\n  if (isHex) return getRgbValueFromHex(lowerColor);\n  if (isRgb) return getRgbValueFromRgb(lowerColor);\n}\n/**\r\n * @description Get the rgb value of the hex color\r\n * @param {String} color Hex color\r\n * @return {Array<Number>} Rgb value of the color\r\n */\n\n\nfunction getRgbValueFromHex(color) {\n  color = color.replace('#', '');\n  if (color.length === 3) color = Array.from(color).map(function (hexNum) {\n    return hexNum + hexNum;\n  }).join('');\n  color = color.split('');\n  return new Array(3).fill(0).map(function (t, i) {\n    return parseInt(\"0x\".concat(color[i * 2]).concat(color[i * 2 + 1]));\n  });\n}\n/**\r\n * @description Get the rgb value of the rgb/rgba color\r\n * @param {String} color Hex color\r\n * @return {Array} Rgb value of the color\r\n */\n\n\nfunction getRgbValueFromRgb(color) {\n  return color.replace(/rgb\\(|rgba\\(|\\)/g, '').split(',').slice(0, 3).map(function (n) {\n    return parseInt(n);\n  });\n}\n/**\r\n * @description Get the Rgba value of the color\r\n * @param {String} color Hex|Rgb|Rgba color or color keyword\r\n * @return {Array<Number>|Boolean} Rgba value of the color (Invalid input will return false)\r\n */\n\n\nfunction getRgbaValue(color) {\n  if (!color) {\n    console.error('getRgbaValue: Missing parameters!');\n    return false;\n  }\n\n  var colorValue = getRgbValue(color);\n  if (!colorValue) return false;\n  colorValue.push(getOpacity(color));\n  return colorValue;\n}\n/**\r\n * @description Get the opacity of color\r\n * @param {String} color Hex|Rgb|Rgba color or color keyword\r\n * @return {Number|Boolean} Color opacity (Invalid input will return false)\r\n */\n\n\nfunction getOpacity(color) {\n  if (!color) {\n    console.error('getOpacity: Missing parameters!');\n    return false;\n  }\n\n  color = validator(color);\n  if (!color) return false;\n  var isRgba = rgbaReg.test(color);\n  if (!isRgba) return 1;\n  color = color.toLowerCase();\n  return Number(color.split(',').slice(-1)[0].replace(/[)|\\s]/g, ''));\n}\n/**\r\n * @description Convert color to Rgb|Rgba color\r\n * @param {String} color   Hex|Rgb|Rgba color or color keyword\r\n * @param {Number} opacity The opacity of color\r\n * @return {String|Boolean} Rgb|Rgba color (Invalid input will return false)\r\n */\n\n\nfunction toRgb(color, opacity) {\n  if (!color) {\n    console.error('toRgb: Missing parameters!');\n    return false;\n  }\n\n  var rgbValue = getRgbValue(color);\n  if (!rgbValue) return false;\n  var addOpacity = typeof opacity === 'number';\n  if (addOpacity) return 'rgba(' + rgbValue.join(',') + \",\".concat(opacity, \")\");\n  return 'rgb(' + rgbValue.join(',') + ')';\n}\n/**\r\n * @description Convert color to Hex color\r\n * @param {String} color Hex|Rgb|Rgba color or color keyword\r\n * @return {String|Boolean} Hex color (Invalid input will return false)\r\n */\n\n\nfunction toHex(color) {\n  if (!color) {\n    console.error('toHex: Missing parameters!');\n    return false;\n  }\n\n  if (hexReg.test(color)) return color;\n  color = getRgbValue(color);\n  if (!color) return false;\n  return '#' + color.map(function (n) {\n    return Number(n).toString(16);\n  }).map(function (n) {\n    return n === '0' ? '00' : n;\n  }).join('');\n}\n/**\r\n * @description Get Color from Rgb|Rgba value\r\n * @param {Array<Number>} value Rgb|Rgba color value\r\n * @return {String|Boolean} Rgb|Rgba color (Invalid input will return false)\r\n */\n\n\nfunction getColorFromRgbValue(value) {\n  if (!value) {\n    console.error('getColorFromRgbValue: Missing parameters!');\n    return false;\n  }\n\n  var valueLength = value.length;\n\n  if (valueLength !== 3 && valueLength !== 4) {\n    console.error('getColorFromRgbValue: Value is illegal!');\n    return false;\n  }\n\n  var color = valueLength === 3 ? 'rgb(' : 'rgba(';\n  color += value.join(',') + ')';\n  return color;\n}\n/**\r\n * @description Deepen color\r\n * @param {String} color Hex|Rgb|Rgba color or color keyword\r\n * @return {Number} Percent of Deepen (1-100)\r\n * @return {String|Boolean} Rgba color (Invalid input will return false)\r\n */\n\n\nfunction darken(color) {\n  var percent = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n\n  if (!color) {\n    console.error('darken: Missing parameters!');\n    return false;\n  }\n\n  var rgbaValue = getRgbaValue(color);\n  if (!rgbaValue) return false;\n  rgbaValue = rgbaValue.map(function (v, i) {\n    return i === 3 ? v : v - Math.ceil(2.55 * percent);\n  }).map(function (v) {\n    return v < 0 ? 0 : v;\n  });\n  return getColorFromRgbValue(rgbaValue);\n}\n/**\r\n * @description Brighten color\r\n * @param {String} color Hex|Rgb|Rgba color or color keyword\r\n * @return {Number} Percent of brighten (1-100)\r\n * @return {String|Boolean} Rgba color (Invalid input will return false)\r\n */\n\n\nfunction lighten(color) {\n  var percent = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n\n  if (!color) {\n    console.error('lighten: Missing parameters!');\n    return false;\n  }\n\n  var rgbaValue = getRgbaValue(color);\n  if (!rgbaValue) return false;\n  rgbaValue = rgbaValue.map(function (v, i) {\n    return i === 3 ? v : v + Math.ceil(2.55 * percent);\n  }).map(function (v) {\n    return v > 255 ? 255 : v;\n  });\n  return getColorFromRgbValue(rgbaValue);\n}\n/**\r\n * @description Adjust color opacity\r\n * @param {String} color   Hex|Rgb|Rgba color or color keyword\r\n * @param {Number} Percent of opacity\r\n * @return {String|Boolean} Rgba color (Invalid input will return false)\r\n */\n\n\nfunction fade(color) {\n  var percent = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100;\n\n  if (!color) {\n    console.error('fade: Missing parameters!');\n    return false;\n  }\n\n  var rgbValue = getRgbValue(color);\n  if (!rgbValue) return false;\n  var rgbaValue = [].concat(_toConsumableArray(rgbValue), [percent / 100]);\n  return getColorFromRgbValue(rgbaValue);\n}\n\nvar _default = {\n  fade: fade,\n  toHex: toHex,\n  toRgb: toRgb,\n  darken: darken,\n  lighten: lighten,\n  getOpacity: getOpacity,\n  getRgbValue: getRgbValue,\n  getRgbaValue: getRgbaValue,\n  getColorFromRgbValue: getColorFromRgbValue\n};\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports[\"default\"] = exports.easeInOutBounce = exports.easeOutBounce = exports.easeInBounce = exports.easeInOutElastic = exports.easeOutElastic = exports.easeInElastic = exports.easeInOutBack = exports.easeOutBack = exports.easeInBack = exports.easeInOutQuint = exports.easeOutQuint = exports.easeInQuint = exports.easeInOutQuart = exports.easeOutQuart = exports.easeInQuart = exports.easeInOutCubic = exports.easeOutCubic = exports.easeInCubic = exports.easeInOutQuad = exports.easeOutQuad = exports.easeInQuad = exports.easeInOutSine = exports.easeOutSine = exports.easeInSine = exports.linear = void 0;\nvar linear = [[[0, 1], '', [0.33, 0.67]], [[1, 0], [0.67, 0.33]]];\n/**\r\n * @description Sine\r\n */\n\nexports.linear = linear;\nvar easeInSine = [[[0, 1]], [[0.538, 0.564], [0.169, 0.912], [0.880, 0.196]], [[1, 0]]];\nexports.easeInSine = easeInSine;\nvar easeOutSine = [[[0, 1]], [[0.444, 0.448], [0.169, 0.736], [0.718, 0.16]], [[1, 0]]];\nexports.easeOutSine = easeOutSine;\nvar easeInOutSine = [[[0, 1]], [[0.5, 0.5], [0.2, 1], [0.8, 0]], [[1, 0]]];\n/**\r\n * @description Quad\r\n */\n\nexports.easeInOutSine = easeInOutSine;\nvar easeInQuad = [[[0, 1]], [[0.550, 0.584], [0.231, 0.904], [0.868, 0.264]], [[1, 0]]];\nexports.easeInQuad = easeInQuad;\nvar easeOutQuad = [[[0, 1]], [[0.413, 0.428], [0.065, 0.816], [0.760, 0.04]], [[1, 0]]];\nexports.easeOutQuad = easeOutQuad;\nvar easeInOutQuad = [[[0, 1]], [[0.5, 0.5], [0.3, 0.9], [0.7, 0.1]], [[1, 0]]];\n/**\r\n * @description Cubic\r\n */\n\nexports.easeInOutQuad = easeInOutQuad;\nvar easeInCubic = [[[0, 1]], [[0.679, 0.688], [0.366, 0.992], [0.992, 0.384]], [[1, 0]]];\nexports.easeInCubic = easeInCubic;\nvar easeOutCubic = [[[0, 1]], [[0.321, 0.312], [0.008, 0.616], [0.634, 0.008]], [[1, 0]]];\nexports.easeOutCubic = easeOutCubic;\nvar easeInOutCubic = [[[0, 1]], [[0.5, 0.5], [0.3, 1], [0.7, 0]], [[1, 0]]];\n/**\r\n * @description Quart\r\n */\n\nexports.easeInOutCubic = easeInOutCubic;\nvar easeInQuart = [[[0, 1]], [[0.812, 0.74], [0.611, 0.988], [1.013, 0.492]], [[1, 0]]];\nexports.easeInQuart = easeInQuart;\nvar easeOutQuart = [[[0, 1]], [[0.152, 0.244], [0.001, 0.448], [0.285, -0.02]], [[1, 0]]];\nexports.easeOutQuart = easeOutQuart;\nvar easeInOutQuart = [[[0, 1]], [[0.5, 0.5], [0.4, 1], [0.6, 0]], [[1, 0]]];\n/**\r\n * @description Quint\r\n */\n\nexports.easeInOutQuart = easeInOutQuart;\nvar easeInQuint = [[[0, 1]], [[0.857, 0.856], [0.714, 1], [1, 0.712]], [[1, 0]]];\nexports.easeInQuint = easeInQuint;\nvar easeOutQuint = [[[0, 1]], [[0.108, 0.2], [0.001, 0.4], [0.214, -0.012]], [[1, 0]]];\nexports.easeOutQuint = easeOutQuint;\nvar easeInOutQuint = [[[0, 1]], [[0.5, 0.5], [0.5, 1], [0.5, 0]], [[1, 0]]];\n/**\r\n * @description Back\r\n */\n\nexports.easeInOutQuint = easeInOutQuint;\nvar easeInBack = [[[0, 1]], [[0.667, 0.896], [0.380, 1.184], [0.955, 0.616]], [[1, 0]]];\nexports.easeInBack = easeInBack;\nvar easeOutBack = [[[0, 1]], [[0.335, 0.028], [0.061, 0.22], [0.631, -0.18]], [[1, 0]]];\nexports.easeOutBack = easeOutBack;\nvar easeInOutBack = [[[0, 1]], [[0.5, 0.5], [0.4, 1.4], [0.6, -0.4]], [[1, 0]]];\n/**\r\n * @description Elastic\r\n */\n\nexports.easeInOutBack = easeInOutBack;\nvar easeInElastic = [[[0, 1]], [[0.474, 0.964], [0.382, 0.988], [0.557, 0.952]], [[0.619, 1.076], [0.565, 1.088], [0.669, 1.08]], [[0.770, 0.916], [0.712, 0.924], [0.847, 0.904]], [[0.911, 1.304], [0.872, 1.316], [0.961, 1.34]], [[1, 0]]];\nexports.easeInElastic = easeInElastic;\nvar easeOutElastic = [[[0, 1]], [[0.073, -0.32], [0.034, -0.328], [0.104, -0.344]], [[0.191, 0.092], [0.110, 0.06], [0.256, 0.08]], [[0.310, -0.076], [0.260, -0.068], [0.357, -0.076]], [[0.432, 0.032], [0.362, 0.028], [0.683, -0.004]], [[1, 0]]];\nexports.easeOutElastic = easeOutElastic;\nvar easeInOutElastic = [[[0, 1]], [[0.210, 0.94], [0.167, 0.884], [0.252, 0.98]], [[0.299, 1.104], [0.256, 1.092], [0.347, 1.108]], [[0.5, 0.496], [0.451, 0.672], [0.548, 0.324]], [[0.696, -0.108], [0.652, -0.112], [0.741, -0.124]], [[0.805, 0.064], [0.756, 0.012], [0.866, 0.096]], [[1, 0]]];\n/**\r\n * @description Bounce\r\n */\n\nexports.easeInOutElastic = easeInOutElastic;\nvar easeInBounce = [[[0, 1]], [[0.148, 1], [0.075, 0.868], [0.193, 0.848]], [[0.326, 1], [0.276, 0.836], [0.405, 0.712]], [[0.600, 1], [0.511, 0.708], [0.671, 0.348]], [[1, 0]]];\nexports.easeInBounce = easeInBounce;\nvar easeOutBounce = [[[0, 1]], [[0.357, 0.004], [0.270, 0.592], [0.376, 0.252]], [[0.604, -0.004], [0.548, 0.312], [0.669, 0.184]], [[0.820, 0], [0.749, 0.184], [0.905, 0.132]], [[1, 0]]];\nexports.easeOutBounce = easeOutBounce;\nvar easeInOutBounce = [[[0, 1]], [[0.102, 1], [0.050, 0.864], [0.117, 0.86]], [[0.216, 0.996], [0.208, 0.844], [0.227, 0.808]], [[0.347, 0.996], [0.343, 0.8], [0.480, 0.292]], [[0.635, 0.004], [0.511, 0.676], [0.656, 0.208]], [[0.787, 0], [0.760, 0.2], [0.795, 0.144]], [[0.905, -0.004], [0.899, 0.164], [0.944, 0.144]], [[1, 0]]];\nexports.easeInOutBounce = easeInOutBounce;\n\nvar _default = new Map([['linear', linear], ['easeInSine', easeInSine], ['easeOutSine', easeOutSine], ['easeInOutSine', easeInOutSine], ['easeInQuad', easeInQuad], ['easeOutQuad', easeOutQuad], ['easeInOutQuad', easeInOutQuad], ['easeInCubic', easeInCubic], ['easeOutCubic', easeOutCubic], ['easeInOutCubic', easeInOutCubic], ['easeInQuart', easeInQuart], ['easeOutQuart', easeOutQuart], ['easeInOutQuart', easeInOutQuart], ['easeInQuint', easeInQuint], ['easeOutQuint', easeOutQuint], ['easeInOutQuint', easeInOutQuint], ['easeInBack', easeInBack], ['easeOutBack', easeOutBack], ['easeInOutBack', easeInOutBack], ['easeInElastic', easeInElastic], ['easeOutElastic', easeOutElastic], ['easeInOutElastic', easeInOutElastic], ['easeInBounce', easeInBounce], ['easeOutBounce', easeOutBounce], ['easeInOutBounce', easeInOutBounce]]);\n\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.transition = transition;\nexports.injectNewCurve = injectNewCurve;\nexports[\"default\"] = void 0;\n\nvar _curves = _interopRequireDefault(require(\"./config/curves\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); }\n\nfunction _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nvar defaultTransitionBC = 'linear';\n/**\r\n * @description Get the N-frame animation state by the start and end state\r\n *              of the animation and the easing curve\r\n * @param {String|Array} tBC               Easing curve name or data\r\n * @param {Number|Array|Object} startState Animation start state\r\n * @param {Number|Array|Object} endState   Animation end state\r\n * @param {Number} frameNum                Number of Animation frames\r\n * @param {Boolean} deep                   Whether to use recursive mode\r\n * @return {Array|Boolean} State of each frame of the animation (Invalid input will return false)\r\n */\n\nfunction transition(tBC) {\n  var startState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n  var endState = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;\n  var frameNum = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 30;\n  var deep = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;\n  if (!checkParams.apply(void 0, arguments)) return false;\n\n  try {\n    // Get the transition bezier curve\n    var bezierCurve = getBezierCurve(tBC); // Get the progress of each frame state\n\n    var frameStateProgress = getFrameStateProgress(bezierCurve, frameNum); // If the recursion mode is not enabled or the state type is Number, the shallow state calculation is performed directly.\n\n    if (!deep || typeof endState === 'number') return getTransitionState(startState, endState, frameStateProgress);\n    return recursionTransitionState(startState, endState, frameStateProgress);\n  } catch (_unused) {\n    console.warn('Transition parameter may be abnormal!');\n    return [endState];\n  }\n}\n/**\r\n * @description Check if the parameters are legal\r\n * @param {String} tBC      Name of transition bezier curve\r\n * @param {Any} startState  Transition start state\r\n * @param {Any} endState    Transition end state\r\n * @param {Number} frameNum Number of transition frames\r\n * @return {Boolean} Is the parameter legal\r\n */\n\n\nfunction checkParams(tBC) {\n  var startState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n  var endState = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n  var frameNum = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 30;\n\n  if (!tBC || startState === false || endState === false || !frameNum) {\n    console.error('transition: Missing Parameters!');\n    return false;\n  }\n\n  if (_typeof(startState) !== _typeof(endState)) {\n    console.error('transition: Inconsistent Status Types!');\n    return false;\n  }\n\n  var stateType = _typeof(endState);\n\n  if (stateType === 'string' || stateType === 'boolean' || !tBC.length) {\n    console.error('transition: Unsupported Data Type of State!');\n    return false;\n  }\n\n  if (!_curves[\"default\"].has(tBC) && !(tBC instanceof Array)) {\n    console.warn('transition: Transition curve not found, default curve will be used!');\n  }\n\n  return true;\n}\n/**\r\n * @description Get the transition bezier curve\r\n * @param {String} tBC Name of transition bezier curve\r\n * @return {Array} Bezier curve data\r\n */\n\n\nfunction getBezierCurve(tBC) {\n  var bezierCurve = '';\n\n  if (_curves[\"default\"].has(tBC)) {\n    bezierCurve = _curves[\"default\"].get(tBC);\n  } else if (tBC instanceof Array) {\n    bezierCurve = tBC;\n  } else {\n    bezierCurve = _curves[\"default\"].get(defaultTransitionBC);\n  }\n\n  return bezierCurve;\n}\n/**\r\n * @description Get the progress of each frame state\r\n * @param {Array} bezierCurve Transition bezier curve\r\n * @param {Number} frameNum   Number of transition frames\r\n * @return {Array} Progress of each frame state\r\n */\n\n\nfunction getFrameStateProgress(bezierCurve, frameNum) {\n  var tMinus = 1 / (frameNum - 1);\n  var tState = new Array(frameNum).fill(0).map(function (t, i) {\n    return i * tMinus;\n  });\n  var frameState = tState.map(function (t) {\n    return getFrameStateFromT(bezierCurve, t);\n  });\n  return frameState;\n}\n/**\r\n * @description Get the progress of the corresponding frame according to t\r\n * @param {Array} bezierCurve Transition bezier curve\r\n * @param {Number} t          Current frame t\r\n * @return {Number} Progress of current frame\r\n */\n\n\nfunction getFrameStateFromT(bezierCurve, t) {\n  var tBezierCurvePoint = getBezierCurvePointFromT(bezierCurve, t);\n  var bezierCurvePointT = getBezierCurvePointTFromReT(tBezierCurvePoint, t);\n  return getBezierCurveTState(tBezierCurvePoint, bezierCurvePointT);\n}\n/**\r\n * @description Get the corresponding sub-curve according to t\r\n * @param {Array} bezierCurve Transition bezier curve\r\n * @param {Number} t          Current frame t\r\n * @return {Array} Sub-curve of t\r\n */\n\n\nfunction getBezierCurvePointFromT(bezierCurve, t) {\n  var lastIndex = bezierCurve.length - 1;\n  var begin = '',\n      end = '';\n  bezierCurve.findIndex(function (item, i) {\n    if (i === lastIndex) return;\n    begin = item;\n    end = bezierCurve[i + 1];\n    var currentMainPointX = begin[0][0];\n    var nextMainPointX = end[0][0];\n    return t >= currentMainPointX && t < nextMainPointX;\n  });\n  var p0 = begin[0];\n  var p1 = begin[2] || begin[0];\n  var p2 = end[1] || end[0];\n  var p3 = end[0];\n  return [p0, p1, p2, p3];\n}\n/**\r\n * @description Get local t based on t and sub-curve\r\n * @param {Array} bezierCurve Sub-curve\r\n * @param {Number} t          Current frame t\r\n * @return {Number} local t of sub-curve\r\n */\n\n\nfunction getBezierCurvePointTFromReT(bezierCurve, t) {\n  var reBeginX = bezierCurve[0][0];\n  var reEndX = bezierCurve[3][0];\n  var xMinus = reEndX - reBeginX;\n  var tMinus = t - reBeginX;\n  return tMinus / xMinus;\n}\n/**\r\n * @description Get the curve progress of t\r\n * @param {Array} bezierCurve Sub-curve\r\n * @param {Number} t          Current frame t\r\n * @return {Number} Progress of current frame\r\n */\n\n\nfunction getBezierCurveTState(_ref, t) {\n  var _ref2 = _slicedToArray(_ref, 4),\n      _ref2$ = _slicedToArray(_ref2[0], 2),\n      p0 = _ref2$[1],\n      _ref2$2 = _slicedToArray(_ref2[1], 2),\n      p1 = _ref2$2[1],\n      _ref2$3 = _slicedToArray(_ref2[2], 2),\n      p2 = _ref2$3[1],\n      _ref2$4 = _slicedToArray(_ref2[3], 2),\n      p3 = _ref2$4[1];\n\n  var pow = Math.pow;\n  var tMinus = 1 - t;\n  var result1 = p0 * pow(tMinus, 3);\n  var result2 = 3 * p1 * t * pow(tMinus, 2);\n  var result3 = 3 * p2 * pow(t, 2) * tMinus;\n  var result4 = p3 * pow(t, 3);\n  return 1 - (result1 + result2 + result3 + result4);\n}\n/**\r\n * @description Get transition state according to frame progress\r\n * @param {Any} startState   Transition start state\r\n * @param {Any} endState     Transition end state\r\n * @param {Array} frameState Frame state progress\r\n * @return {Array} Transition frame state\r\n */\n\n\nfunction getTransitionState(begin, end, frameState) {\n  var stateType = 'object';\n  if (typeof begin === 'number') stateType = 'number';\n  if (begin instanceof Array) stateType = 'array';\n  if (stateType === 'number') return getNumberTransitionState(begin, end, frameState);\n  if (stateType === 'array') return getArrayTransitionState(begin, end, frameState);\n  if (stateType === 'object') return getObjectTransitionState(begin, end, frameState);\n  return frameState.map(function (t) {\n    return end;\n  });\n}\n/**\r\n * @description Get the transition data of the number type\r\n * @param {Number} startState Transition start state\r\n * @param {Number} endState   Transition end state\r\n * @param {Array} frameState  Frame state progress\r\n * @return {Array} Transition frame state\r\n */\n\n\nfunction getNumberTransitionState(begin, end, frameState) {\n  var minus = end - begin;\n  return frameState.map(function (s) {\n    return begin + minus * s;\n  });\n}\n/**\r\n * @description Get the transition data of the array type\r\n * @param {Array} startState Transition start state\r\n * @param {Array} endState   Transition end state\r\n * @param {Array} frameState Frame state progress\r\n * @return {Array} Transition frame state\r\n */\n\n\nfunction getArrayTransitionState(begin, end, frameState) {\n  var minus = end.map(function (v, i) {\n    if (typeof v !== 'number') return false;\n    return v - begin[i];\n  });\n  return frameState.map(function (s) {\n    return minus.map(function (v, i) {\n      if (v === false) return end[i];\n      return begin[i] + v * s;\n    });\n  });\n}\n/**\r\n * @description Get the transition data of the object type\r\n * @param {Object} startState Transition start state\r\n * @param {Object} endState   Transition end state\r\n * @param {Array} frameState  Frame state progress\r\n * @return {Array} Transition frame state\r\n */\n\n\nfunction getObjectTransitionState(begin, end, frameState) {\n  var keys = Object.keys(end);\n  var beginValue = keys.map(function (k) {\n    return begin[k];\n  });\n  var endValue = keys.map(function (k) {\n    return end[k];\n  });\n  var arrayState = getArrayTransitionState(beginValue, endValue, frameState);\n  return arrayState.map(function (item) {\n    var frameData = {};\n    item.forEach(function (v, i) {\n      return frameData[keys[i]] = v;\n    });\n    return frameData;\n  });\n}\n/**\r\n * @description Get the transition state data by recursion\r\n * @param {Array|Object} startState Transition start state\r\n * @param {Array|Object} endState   Transition end state\r\n * @param {Array} frameState        Frame state progress\r\n * @return {Array} Transition frame state\r\n */\n\n\nfunction recursionTransitionState(begin, end, frameState) {\n  var state = getTransitionState(begin, end, frameState);\n\n  var _loop = function _loop(key) {\n    var bTemp = begin[key];\n    var eTemp = end[key];\n    if (_typeof(eTemp) !== 'object') return \"continue\";\n    var data = recursionTransitionState(bTemp, eTemp, frameState);\n    state.forEach(function (fs, i) {\n      return fs[key] = data[i];\n    });\n  };\n\n  for (var key in end) {\n    var _ret = _loop(key);\n\n    if (_ret === \"continue\") continue;\n  }\n\n  return state;\n}\n/**\r\n * @description Inject new curve into curves as config\r\n * @param {Any} key     The key of curve\r\n * @param {Array} curve Bezier curve data\r\n * @return {Undefined} No return\r\n */\n\n\nfunction injectNewCurve(key, curve) {\n  if (!key || !curve) {\n    console.error('InjectNewCurve Missing Parameters!');\n    return;\n  }\n\n  _curves[\"default\"].set(key, curve);\n}\n\nvar _default = transition;\nexports[\"default\"] = _default;","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n  \"use strict\";\n\n  var Op = Object.prototype;\n  var hasOwn = Op.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n  var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n  var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n  var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n    var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n    var generator = Object.create(protoGenerator.prototype);\n    var context = new Context(tryLocsList || []);\n\n    // The ._invoke method unifies the implementations of the .next,\n    // .throw, and .return methods.\n    generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n    return generator;\n  }\n  exports.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function Generator() {}\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  // This is a polyfill for %IteratorPrototype% for environments that\n  // don't natively support it.\n  var IteratorPrototype = {};\n  IteratorPrototype[iteratorSymbol] = function () {\n    return this;\n  };\n\n  var getProto = Object.getPrototypeOf;\n  var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n  if (NativeIteratorPrototype &&\n      NativeIteratorPrototype !== Op &&\n      hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n    // This environment has a native %IteratorPrototype%; use it instead\n    // of the polyfill.\n    IteratorPrototype = NativeIteratorPrototype;\n  }\n\n  var Gp = GeneratorFunctionPrototype.prototype =\n    Generator.prototype = Object.create(IteratorPrototype);\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunctionPrototype[toStringTagSymbol] =\n    GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function(method) {\n      prototype[method] = function(arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  exports.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  exports.mark = function(genFun) {\n    if (Object.setPrototypeOf) {\n      Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n    } else {\n      genFun.__proto__ = GeneratorFunctionPrototype;\n      if (!(toStringTagSymbol in genFun)) {\n        genFun[toStringTagSymbol] = \"GeneratorFunction\";\n      }\n    }\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n  // meant to be awaited.\n  exports.awrap = function(arg) {\n    return { __await: arg };\n  };\n\n  function AsyncIterator(generator) {\n    function invoke(method, arg, resolve, reject) {\n      var record = tryCatch(generator[method], generator, arg);\n      if (record.type === \"throw\") {\n        reject(record.arg);\n      } else {\n        var result = record.arg;\n        var value = result.value;\n        if (value &&\n            typeof value === \"object\" &&\n            hasOwn.call(value, \"__await\")) {\n          return Promise.resolve(value.__await).then(function(value) {\n            invoke(\"next\", value, resolve, reject);\n          }, function(err) {\n            invoke(\"throw\", err, resolve, reject);\n          });\n        }\n\n        return Promise.resolve(value).then(function(unwrapped) {\n          // When a yielded Promise is resolved, its final value becomes\n          // the .value of the Promise<{value,done}> result for the\n          // current iteration.\n          result.value = unwrapped;\n          resolve(result);\n        }, function(error) {\n          // If a rejected Promise was yielded, throw the rejection back\n          // into the async generator function so it can be handled there.\n          return invoke(\"throw\", error, resolve, reject);\n        });\n      }\n    }\n\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      function callInvokeWithMethodAndArg() {\n        return new Promise(function(resolve, reject) {\n          invoke(method, arg, resolve, reject);\n        });\n      }\n\n      return previousPromise =\n        // If enqueue has been called before, then we want to wait until\n        // all previous Promises have been resolved before calling invoke,\n        // so that results are always delivered in the correct order. If\n        // enqueue has not been called before, then it is important to\n        // call invoke immediately, without waiting on a callback to fire,\n        // so that the async generator function has the opportunity to do\n        // any necessary setup in a predictable way. This predictability\n        // is why the Promise constructor synchronously invokes its\n        // executor callback, and why async functions synchronously\n        // execute code before the first await. Since we implement simple\n        // async functions in terms of async generators, it is especially\n        // important to get this right, even though it requires care.\n        previousPromise ? previousPromise.then(\n          callInvokeWithMethodAndArg,\n          // Avoid propagating failures to Promises returned by later\n          // invocations of the iterator.\n          callInvokeWithMethodAndArg\n        ) : callInvokeWithMethodAndArg();\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n  AsyncIterator.prototype[asyncIteratorSymbol] = function () {\n    return this;\n  };\n  exports.AsyncIterator = AsyncIterator;\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  exports.async = function(innerFn, outerFn, self, tryLocsList) {\n    var iter = new AsyncIterator(\n      wrap(innerFn, outerFn, self, tryLocsList)\n    );\n\n    return exports.isGeneratorFunction(outerFn)\n      ? iter // If outerFn is a generator, return the full iterator.\n      : iter.next().then(function(result) {\n          return result.done ? result.value : iter.next();\n        });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      context.method = method;\n      context.arg = arg;\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var delegateResult = maybeInvokeDelegate(delegate, context);\n          if (delegateResult) {\n            if (delegateResult === ContinueSentinel) continue;\n            return delegateResult;\n          }\n        }\n\n        if (context.method === \"next\") {\n          // Setting context._sent for legacy support of Babel's\n          // function.sent implementation.\n          context.sent = context._sent = context.arg;\n\n        } else if (context.method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw context.arg;\n          }\n\n          context.dispatchException(context.arg);\n\n        } else if (context.method === \"return\") {\n          context.abrupt(\"return\", context.arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          if (record.arg === ContinueSentinel) {\n            continue;\n          }\n\n          return {\n            value: record.arg,\n            done: context.done\n          };\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(context.arg) call above.\n          context.method = \"throw\";\n          context.arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Call delegate.iterator[context.method](context.arg) and handle the\n  // result, either by returning a { value, done } result from the\n  // delegate iterator, or by modifying context.method and context.arg,\n  // setting context.delegate to null, and returning the ContinueSentinel.\n  function maybeInvokeDelegate(delegate, context) {\n    var method = delegate.iterator[context.method];\n    if (method === undefined) {\n      // A .throw or .return when the delegate iterator has no .throw\n      // method always terminates the yield* loop.\n      context.delegate = null;\n\n      if (context.method === \"throw\") {\n        // Note: [\"return\"] must be used for ES3 parsing compatibility.\n        if (delegate.iterator[\"return\"]) {\n          // If the delegate iterator has a return method, give it a\n          // chance to clean up.\n          context.method = \"return\";\n          context.arg = undefined;\n          maybeInvokeDelegate(delegate, context);\n\n          if (context.method === \"throw\") {\n            // If maybeInvokeDelegate(context) changed context.method from\n            // \"return\" to \"throw\", let that override the TypeError below.\n            return ContinueSentinel;\n          }\n        }\n\n        context.method = \"throw\";\n        context.arg = new TypeError(\n          \"The iterator does not provide a 'throw' method\");\n      }\n\n      return ContinueSentinel;\n    }\n\n    var record = tryCatch(method, delegate.iterator, context.arg);\n\n    if (record.type === \"throw\") {\n      context.method = \"throw\";\n      context.arg = record.arg;\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    var info = record.arg;\n\n    if (! info) {\n      context.method = \"throw\";\n      context.arg = new TypeError(\"iterator result is not an object\");\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    if (info.done) {\n      // Assign the result of the finished delegate to the temporary\n      // variable specified by delegate.resultName (see delegateYield).\n      context[delegate.resultName] = info.value;\n\n      // Resume execution at the desired location (see delegateYield).\n      context.next = delegate.nextLoc;\n\n      // If context.method was \"throw\" but the delegate handled the\n      // exception, let the outer generator proceed normally. If\n      // context.method was \"next\", forget context.arg since it has been\n      // \"consumed\" by the delegate iterator. If context.method was\n      // \"return\", allow the original .return call to continue in the\n      // outer generator.\n      if (context.method !== \"return\") {\n        context.method = \"next\";\n        context.arg = undefined;\n      }\n\n    } else {\n      // Re-yield the result returned by the delegate method.\n      return info;\n    }\n\n    // The delegate iterator is finished, so forget it and continue with\n    // the outer generator.\n    context.delegate = null;\n    return ContinueSentinel;\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\n\n  Gp[toStringTagSymbol] = \"Generator\";\n\n  // A Generator should always return itself as the iterator object when the\n  // @@iterator function is called on it. Some browsers' implementations of the\n  // iterator prototype chain incorrectly implement this, causing the Generator\n  // object to not be returned from this call. This ensures that doesn't happen.\n  // See https://github.com/facebook/regenerator/issues/274 for more details.\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset(true);\n  }\n\n  exports.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  exports.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function(skipTempReset) {\n      this.prev = 0;\n      this.next = 0;\n      // Resetting context._sent for legacy support of Babel's\n      // function.sent implementation.\n      this.sent = this._sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.method = \"next\";\n      this.arg = undefined;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" &&\n              hasOwn.call(this, name) &&\n              !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n\n        if (caught) {\n          // If the dispatched exception was caught by a catch block,\n          // then let that catch block handle the exception normally.\n          context.method = \"next\";\n          context.arg = undefined;\n        }\n\n        return !! caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg <= finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.method = \"next\";\n        this.next = finallyEntry.finallyLoc;\n        return ContinueSentinel;\n      }\n\n      return this.complete(record);\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = this.arg = record.arg;\n        this.method = \"return\";\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      if (this.method === \"next\") {\n        // Deliberately forget the last sent value so that we don't\n        // accidentally pass it on to the delegate.\n        this.arg = undefined;\n      }\n\n      return ContinueSentinel;\n    }\n  };\n\n  // Regardless of whether this script is executing as a CommonJS module\n  // or not, return the runtime object so that we can declare the variable\n  // regeneratorRuntime in the outer scope, which allows this module to be\n  // injected easily by `bin/regenerator --include-runtime script.js`.\n  return exports;\n\n}(\n  // If this script is executing as a CommonJS module, use module.exports\n  // as the regeneratorRuntime namespace. Otherwise create a new empty\n  // object. Either way, the resulting object will be used to initialize\n  // the regeneratorRuntime variable at the top of this file.\n  typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n  regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n  // This module should not be running in strict mode, so the above\n  // assignment should always work unless something is misconfigured. Just\n  // in case runtime.js accidentally runs in strict mode, we can escape\n  // strict mode using a global Function call. This could conceivably fail\n  // if a Content Security Policy forbids using Function, but in that case\n  // the proper solution is to fix the accidental strict mode problem. If\n  // you've misconfigured your bundler to force strict mode and applied a\n  // CSP to forbid Function, and you're not willing to fix either of those\n  // problems, please detail your unique predicament in a GitHub issue.\n  Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n}\n"]}
|