chunk-03addcd9.64fd1552.js.map 2.1 MB

1
  1. {"version":3,"sources":["webpack:///./node_modules/lodash/_getRawTag.js","webpack:///./node_modules/echarts/lib/coord/cartesian/cartesianAxisHelper.js","webpack:///./node_modules/echarts/lib/component/gridSimple.js","webpack:///./node_modules/echarts/lib/component/dataset.js","webpack:///./node_modules/zrender/lib/core/timsort.js","webpack:///./node_modules/zrender/lib/contain/polygon.js","webpack:///./node_modules/zrender/lib/animation/Animator.js","webpack:///./node_modules/core-js/modules/_array-methods.js","webpack:///./node_modules/zrender/lib/core/GestureMgr.js","webpack:///./node_modules/zrender/lib/mixin/Transformable.js","webpack:///./node_modules/zrender/lib/graphic/Image.js","webpack:///./node_modules/echarts/lib/data/helper/sourceHelper.js","webpack:///./node_modules/core-js/modules/_is-array.js","webpack:///./src/views/orderAdmin/Statistics.vue?f30a","webpack:///./node_modules/vue-echarts/components/ECharts.vue?d867","webpack:///./node_modules/resize-detector/esm/index.js","webpack:///node_modules/vue-echarts/components/ECharts.vue","webpack:///./node_modules/vue-echarts/components/ECharts.vue?12fa","webpack:///./node_modules/vue-echarts/components/ECharts.vue","webpack:///./node_modules/mpvue-calendar/src/mpvue-calendar.vue?f26b","webpack:///./node_modules/@babel/runtime-corejs2/helpers/esm/arrayWithHoles.js","webpack:///./node_modules/@babel/runtime-corejs2/helpers/esm/iterableToArrayLimit.js","webpack:///./node_modules/@babel/runtime-corejs2/helpers/esm/nonIterableRest.js","webpack:///./node_modules/@babel/runtime-corejs2/helpers/esm/slicedToArray.js","webpack:///./node_modules/mpvue-calendar/src/calendarinit.js","webpack:///node_modules/mpvue-calendar/src/mpvue-calendar.vue","webpack:///./node_modules/mpvue-calendar/src/mpvue-calendar.vue?6394","webpack:///./node_modules/mpvue-calendar/src/mpvue-calendar.vue","webpack:///src/views/orderAdmin/Statistics.vue","webpack:///./src/views/orderAdmin/Statistics.vue?91ce","webpack:///./src/views/orderAdmin/Statistics.vue","webpack:///./node_modules/lodash/isObjectLike.js","webpack:///./node_modules/echarts/lib/component/axisPointer/findPointFromSeries.js","webpack:///./node_modules/echarts/lib/chart/helper/Symbol.js","webpack:///./node_modules/echarts/lib/component/axis/RadiusAxisView.js","webpack:///./node_modules/echarts/lib/helper.js","webpack:///./node_modules/zrender/lib/core/matrix.js","webpack:///./node_modules/echarts/lib/component/axisPointer/globalListener.js","webpack:///./node_modules/echarts/lib/scale/Ordinal.js","webpack:///./node_modules/zrender/lib/graphic/Displayable.js","webpack:///./node_modules/lodash/isObject.js","webpack:///./node_modules/echarts/lib/coord/polar/polarCreator.js","webpack:///./node_modules/echarts/lib/layout/barPolar.js","webpack:///./node_modules/vue-echarts/components/ECharts.vue?619e","webpack:///./node_modules/zrender/lib/mixin/Eventful.js","webpack:///./node_modules/echarts/lib/coord/axisModelCommonMixin.js","webpack:///./node_modules/echarts/lib/CoordinateSystem.js","webpack:///./node_modules/zrender/lib/core/PathProxy.js","webpack:///./node_modules/core-js/modules/es6.array.find-index.js","webpack:///./node_modules/echarts/lib/scale/Time.js","webpack:///./node_modules/echarts/lib/chart/line/LineSeries.js","webpack:///./node_modules/zrender/lib/core/env.js","webpack:///./node_modules/echarts/lib/util/graphic.js","webpack:///./node_modules/echarts/lib/preprocessor/helper/compatStyle.js","webpack:///./node_modules/echarts/lib/model/mixin/makeStyleMapper.js","webpack:///./node_modules/echarts/lib/lang.js","webpack:///./node_modules/lodash/_objectToString.js","webpack:///./node_modules/echarts/lib/data/helper/dataProvider.js","webpack:///./node_modules/lodash/_root.js","webpack:///./node_modules/zrender/lib/graphic/Style.js","webpack:///./node_modules/zrender/lib/config.js","webpack:///./node_modules/echarts/lib/data/helper/dimensionHelper.js","webpack:///./node_modules/echarts/lib/component/polar.js","webpack:///./node_modules/zrender/lib/tool/parseSVG.js","webpack:///./node_modules/zrender/lib/animation/Animation.js","webpack:///./node_modules/echarts/lib/chart/helper/createListFromArray.js","webpack:///./node_modules/zrender/lib/tool/path.js","webpack:///./node_modules/lodash/_baseGetTag.js","webpack:///./node_modules/echarts/lib/util/number.js","webpack:///./node_modules/echarts/lib/model/mixin/dataFormat.js","webpack:///./node_modules/echarts/lib/model/mixin/lineStyle.js","webpack:///./node_modules/zrender/lib/graphic/IncrementalDisplayable.js","webpack:///./node_modules/echarts/lib/echarts.js","webpack:///./node_modules/zrender/lib/core/vector.js","webpack:///./node_modules/lodash/now.js","webpack:///./node_modules/zrender/lib/tool/color.js","webpack:///./node_modules/zrender/lib/graphic/Gradient.js","webpack:///./node_modules/echarts/lib/model/Model.js","webpack:///./node_modules/zrender/lib/animation/Clip.js","webpack:///./node_modules/zrender/lib/graphic/shape/Ring.js","webpack:///./node_modules/core-js/library/fn/get-iterator.js","webpack:///./node_modules/zrender/lib/graphic/LinearGradient.js","webpack:///./node_modules/echarts/lib/component/axisPointer/AxisPointerModel.js","webpack:///./node_modules/echarts/lib/coord/cartesian/AxisModel.js","webpack:///./node_modules/zrender/lib/core/log.js","webpack:///./node_modules/zrender/lib/core/curve.js","webpack:///./node_modules/echarts/lib/component/axisPointer/CartesianAxisPointer.js","webpack:///./node_modules/zrender/lib/graphic/shape/Sector.js","webpack:///./node_modules/echarts/lib/config.js","webpack:///./node_modules/echarts/lib/model/Series.js","webpack:///./node_modules/zrender/lib/graphic/helper/poly.js","webpack:///./src/api/admin.js","webpack:///./node_modules/echarts/lib/model/mixin/itemStyle.js","webpack:///./node_modules/zrender/lib/graphic/helper/roundRect.js","webpack:///./node_modules/lodash/_freeGlobal.js","webpack:///./node_modules/echarts/lib/coord/cartesian/Grid.js","webpack:///./node_modules/@babel/runtime-corejs2/core-js/get-iterator.js","webpack:///./node_modules/zrender/lib/Layer.js","webpack:///./node_modules/zrender/lib/graphic/helper/image.js","webpack:///./node_modules/zrender/lib/core/event.js","webpack:///./node_modules/echarts/lib/data/List.js","webpack:///./node_modules/zrender/lib/graphic/helper/smoothSpline.js","webpack:///./node_modules/echarts/lib/util/clazz.js","webpack:///./node_modules/echarts/lib/component/axis/AxisView.js","webpack:///./node_modules/zrender/lib/contain/quadratic.js","webpack:///./node_modules/echarts/lib/coord/axisHelper.js","webpack:///./node_modules/zrender/lib/zrender.js","webpack:///./node_modules/echarts/lib/stream/Scheduler.js","webpack:///./node_modules/echarts/lib/component/axisPointer/PolarAxisPointer.js","webpack:///./node_modules/echarts/lib/model/Component.js","webpack:///./node_modules/zrender/lib/core/util.js","webpack:///./node_modules/echarts/lib/coord/axisDefault.js","webpack:///./node_modules/zrender/lib/animation/easing.js","webpack:///./node_modules/core-js/modules/es6.array.find.js","webpack:///./node_modules/zrender/lib/graphic/Text.js","webpack:///./node_modules/echarts/lib/coord/polar/PolarModel.js","webpack:///./node_modules/echarts/lib/component/radiusAxis.js","webpack:///./node_modules/zrender/lib/graphic/helper/fixShadow.js","webpack:///./node_modules/core-js/library/modules/core.get-iterator.js","webpack:///./node_modules/echarts/lib/model/Global.js","webpack:///./node_modules/echarts/lib/visual/symbol.js","webpack:///./node_modules/echarts/lib/data/DataDiffer.js","webpack:///./node_modules/zrender/lib/graphic/constant.js","webpack:///./node_modules/echarts/lib/ExtensionAPI.js","webpack:///./node_modules/echarts/lib/coord/Axis.js","webpack:///./node_modules/zrender/lib/contain/util.js","webpack:///./node_modules/echarts/lib/data/helper/completeDimensions.js","webpack:///./node_modules/zrender/lib/contain/windingLine.js","webpack:///./node_modules/zrender/lib/graphic/shape/Polygon.js","webpack:///./node_modules/echarts/lib/layout/points.js","webpack:///./node_modules/echarts/lib/util/throttle.js","webpack:///./node_modules/echarts/lib/util/component.js","webpack:///./node_modules/echarts/lib/model/globalDefault.js","webpack:///./node_modules/zrender/lib/graphic/helper/fixClipWithShadow.js","webpack:///./node_modules/echarts/lib/scale/Interval.js","webpack:///./node_modules/echarts/lib/model/referHelper.js","webpack:///./node_modules/echarts/lib/scale/Log.js","webpack:///./node_modules/zrender/lib/graphic/shape/Arc.js","webpack:///./node_modules/echarts/lib/data/OrdinalMeta.js","webpack:///./node_modules/echarts/lib/coord/cartesian/GridModel.js","webpack:///./node_modules/echarts/lib/coord/polar/RadiusAxis.js","webpack:///./node_modules/echarts/lib/data/helper/sourceType.js","webpack:///./node_modules/echarts/lib/scale/helper.js","webpack:///./node_modules/zrender/lib/contain/line.js","webpack:///./node_modules/zrender/lib/core/BoundingRect.js","webpack:///./node_modules/zrender/lib/animation/requestAnimationFrame.js","webpack:///./node_modules/echarts/lib/loading/default.js","webpack:///./node_modules/echarts/lib/model/mixin/areaStyle.js","webpack:///./node_modules/zrender/lib/graphic/helper/smoothBezier.js","webpack:///./node_modules/zrender/lib/graphic/helper/subPixelOptimize.js","webpack:///./node_modules/echarts/lib/layout/barGrid.js","webpack:///./node_modules/zrender/lib/graphic/mixin/RectText.js","webpack:///./node_modules/echarts/lib/coord/axisModelCreator.js","webpack:///./node_modules/lodash/_Symbol.js","webpack:///./node_modules/zrender/lib/contain/arc.js","webpack:///./node_modules/echarts/lib/chart/line/helper.js","webpack:///./node_modules/echarts/lib/util/symbol.js","webpack:///./node_modules/zrender/lib/graphic/helper/text.js","webpack:///./node_modules/echarts/lib/coord/polar/AngleAxis.js","webpack:///./node_modules/zrender/lib/graphic/shape/BezierCurve.js","webpack:///./node_modules/zrender/lib/graphic/shape/Ellipse.js","webpack:///./node_modules/echarts/lib/component/axis.js","webpack:///./node_modules/zrender/lib/Storage.js","webpack:///./node_modules/lodash/debounce.js","webpack:///./node_modules/echarts/lib/view/Component.js","webpack:///./src/views/orderAdmin/Statistics.vue?1665","webpack:///./node_modules/echarts/lib/data/helper/createDimensions.js","webpack:///./node_modules/echarts/lib/component/axis/AngleAxisView.js","webpack:///./node_modules/lodash/toNumber.js","webpack:///./node_modules/echarts/lib/export.js","webpack:///./node_modules/echarts/lib/visual/aria.js","webpack:///./node_modules/zrender/lib/mixin/Animatable.js","webpack:///./node_modules/echarts/lib/coord/geo/parseGeoJson.js","webpack:///./node_modules/echarts/lib/theme/light.js","webpack:///./node_modules/echarts/lib/chart/helper/labelHelper.js","webpack:///./node_modules/zrender/lib/graphic/shape/Rect.js","webpack:///./node_modules/echarts/lib/model/OptionManager.js","webpack:///./node_modules/zrender/lib/graphic/shape/Line.js","webpack:///./node_modules/zrender/lib/mixin/Draggable.js","webpack:///./node_modules/echarts/lib/component/axisPointer.js","webpack:///./node_modules/zrender/lib/graphic/Path.js","webpack:///./node_modules/echarts/lib/coord/cartesian/Cartesian2D.js","webpack:///./node_modules/echarts/lib/chart/helper/createRenderPlanner.js","webpack:///./node_modules/core-js/modules/_array-species-create.js","webpack:///./node_modules/echarts/lib/component/axisPointer/modelHelper.js","webpack:///./node_modules/zrender/lib/dom/HandlerProxy.js","webpack:///./node_modules/echarts/lib/coord/cartesian/Cartesian.js","webpack:///./node_modules/echarts/lib/processor/dataStack.js","webpack:///./node_modules/zrender/lib/Handler.js","webpack:///./node_modules/zrender/lib/graphic/shape/Polyline.js","webpack:///./node_modules/echarts/lib/component/axisPointer/AxisPointerView.js","webpack:///./node_modules/zrender/lib/graphic/CompoundPath.js","webpack:///./node_modules/echarts/lib/chart/line/poly.js","webpack:///./node_modules/zrender/lib/core/LRU.js","webpack:///./node_modules/zrender/lib/Element.js","webpack:///./node_modules/zrender/lib/contain/path.js","webpack:///./node_modules/echarts/lib/coord/polar/AxisModel.js","webpack:///./node_modules/zrender/lib/graphic/shape/Circle.js","webpack:///./node_modules/zrender/lib/graphic/Pattern.js","webpack:///./node_modules/echarts/lib/component/axisPointer/BaseAxisPointer.js","webpack:///./node_modules/zrender/lib/graphic/RadialGradient.js","webpack:///./node_modules/zrender/lib/core/guid.js","webpack:///./node_modules/echarts/lib/model/mixin/boxLayout.js","webpack:///./node_modules/echarts/lib/coord/axisTickLabelBuilder.js","webpack:///./node_modules/echarts/lib/util/model.js","webpack:///./node_modules/echarts/lib/scale/Scale.js","webpack:///./node_modules/zrender/lib/container/Group.js","webpack:///./node_modules/zrender/lib/core/bbox.js","webpack:///./node_modules/echarts/lib/model/mixin/colorPalette.js","webpack:///./node_modules/zrender/lib/contain/cubic.js","webpack:///./node_modules/core-js/modules/_array-species-constructor.js","webpack:///./node_modules/zrender/lib/contain/text.js","webpack:///./node_modules/echarts/lib/view/Chart.js","webpack:///./node_modules/echarts/lib/component/axisPointer/axisTrigger.js","webpack:///./node_modules/echarts/lib/coord/cartesian/Axis2D.js","webpack:///./node_modules/echarts/lib/coord/geo/mapDataStorage.js","webpack:///./node_modules/echarts/lib/data/Source.js","webpack:///./node_modules/zrender/lib/Painter.js","webpack:///./node_modules/echarts/lib/util/format.js","webpack:///./node_modules/echarts/lib/data/helper/dataStackHelper.js","webpack:///./node_modules/zrender/lib/tool/transformPath.js","webpack:///./node_modules/echarts/lib/chart/line.js","webpack:///./node_modules/echarts/lib/chart/line/lineAnimationDiff.js","webpack:///./node_modules/echarts/lib/chart/line/LineView.js","webpack:///./node_modules/echarts/lib/theme/dark.js","webpack:///./node_modules/echarts/lib/component/axis/CartesianAxisView.js","webpack:///./node_modules/echarts/lib/coord/geo/Region.js","webpack:///./node_modules/echarts/lib/stream/task.js","webpack:///./node_modules/echarts/lib/component/angleAxis.js","webpack:///./node_modules/echarts/lib/chart/helper/SymbolDraw.js","webpack:///./node_modules/echarts/lib/util/layout.js","webpack:///./node_modules/echarts/lib/component/axis/AxisBuilder.js","webpack:///./node_modules/echarts/lib/preprocessor/backwardCompat.js","webpack:///./node_modules/echarts/lib/coord/polar/Polar.js","webpack:///./node_modules/echarts/lib/visual/seriesColor.js","webpack:///./node_modules/echarts/lib/processor/dataSample.js","webpack:///./node_modules/echarts/lib/model/mixin/textStyle.js","webpack:///./node_modules/echarts/lib/component/axisPointer/viewHelper.js","webpack:///./node_modules/lodash/isSymbol.js"],"names":["Symbol","__webpack_require__","objectProto","Object","prototype","hasOwnProperty","nativeObjectToString","toString","symToStringTag","toStringTag","undefined","getRawTag","value","isOwn","call","tag","unmasked","e","result","module","exports","zrUtil","layout","gridModel","axisModel","opt","grid","coordinateSystem","axis","otherAxisOnZeroOf","getAxesOnZeroOf","rawAxisPosition","position","axisPosition","axisDim","dim","rect","getRect","rectBound","x","width","y","height","idx","left","right","top","bottom","onZero","axisOffset","get","posBound","onZeroCoord","toGlobalCoord","dataToCoord","Math","max","min","rotation","PI","dirMap","labelDirection","tickDirection","nameDirection","labelOffset","retrieve","labelInside","labelRotate","z2","echarts","graphic","extendComponentView","type","render","ecModel","this","group","removeAll","add","Rect","shape","style","defaults","fill","getItemStyle","silent","registerPreprocessor","option","xAxis","yAxis","ComponentModel","ComponentView","_sourceHelper","detectSourceFormat","_sourceType","SERIES_LAYOUT_BY_COLUMN","extend","defaultOption","seriesLayoutBy","sourceHeader","dimensions","source","optionUpdated","DEFAULT_MIN_MERGE","DEFAULT_MIN_GALLOPING","minRunLength","n","r","makeAscendingRun","array","lo","hi","compare","runHi","reverseRun","t","binaryInsertionSort","start","mid","pivot","gallopLeft","length","hint","lastOffset","maxOffset","offset","tmp","m","gallopRight","TimSort","runStart","runLength","minGallop","stackSize","pushRun","_runStart","_runLength","mergeRuns","mergeAt","forceMergeRuns","i","start1","length1","start2","length2","k","mergeLow","mergeHigh","cursor1","cursor2","dest","count1","count2","exit","_minGallop","Error","customCursor","customDest","sort","remaining","ts","minRun","force","windingLine","EPSILON","isAroundEqual","a","b","abs","contain","points","w","p","p2","p0","Clip","color","_util","isArrayLike","arraySlice","Array","slice","defaultGetter","target","key","defaultSetter","interpolateNumber","p1","percent","interpolateString","interpolateArray","out","arrDim","len","len2","j","fillArr","arr0","arr1","arr0Len","arr1Len","isPreviousLarger","push","isNaN","isArraySame","catmullRomInterpolateArray","p3","t2","t3","catmullRomInterpolate","v0","v1","cloneValue","ret","rgba2String","rgba","floor","join","getArrayDim","keyframes","lastValue","createTrackClip","animator","easing","oneTrackDone","propName","forceAnimate","getter","_getter","setter","_setter","useSpline","trackLen","trackMaxTime","firstVal","isValueArray","isValueColor","isValueString","time","kfPercents","kfValues","prevValue","isAllValueEqual","colorArray","parse","_target","lastFrame","lastFramePercent","onframe","frame","range","clip","life","loop","_loop","delay","_delay","ondestroy","Animator","_tracks","_clipCount","_doneList","_onframeList","_clipList","when","props","tracks","during","callback","pause","_paused","resume","isPaused","_doneCallback","doneList","lastClip","self","clipCount","animation","addClip","oldOnFrame","stop","forwardToLast","clipList","removeClip","done","cb","getClips","_default","ctx","IObject","toObject","toLength","asc","TYPE","$create","IS_MAP","IS_FILTER","IS_SOME","IS_EVERY","IS_FIND_INDEX","NO_HOLES","create","$this","callbackfn","that","val","res","O","f","index","eventUtil","GestureMgr","_track","dist","pointPair","dx","dy","sqrt","center","constructor","recognize","event","root","_doTrack","_recognize","clear","touches","trackItem","touch","pos","clientToLocal","zrX","zrY","eventName","recognizers","gestureInfo","pinch","track","pinchEnd","pinchPre","pinchScale","isFinite","pinchCenter","pinchX","pinchY","matrix","vector","mIdentity","identity","isNotAroundZero","Transformable","opts","scale","origin","transformableProto","transform","needLocalTransform","scaleTmp","updateTransform","parent","parentHasTransform","getLocalTransform","mul","copy","globalScaleRatio","getGlobalScale","relX","relY","sx","sy","invTransform","invert","setTransform","dpr","restoreTransform","tmpTransform","originTransform","setLocalTransform","atan2","decomposeTransform","transformCoordToLocal","v2","applyTransform","transformCoordToGlobal","rotate","Displayable","BoundingRect","imageHelper","ZImage","brush","prevEl","src","image","bind","_image","createOrUpdateImage","onload","isImageReady","aspect","sWidth","sHeight","drawImage","text","drawRectText","getBoundingRect","_rect","inherits","_config","_model","__DEV__","makeInner","getDataItemValue","_referHelper","getCoordSysDefineBySeries","createHashMap","each","map","isArray","isString","isObject","isTypedArray","Source","assert","SOURCE_FORMAT_ORIGINAL","SOURCE_FORMAT_ARRAY_ROWS","SOURCE_FORMAT_OBJECT_ROWS","SOURCE_FORMAT_KEYED_COLUMNS","SOURCE_FORMAT_UNKNOWN","SOURCE_FORMAT_TYPED_ARRAY","SERIES_LAYOUT_BY_ROW","inner","datasetModel","data","sourceFormat","item","getSource","seriesModel","resetSourceDefaulter","datasetMap","prepareSource","seriesOption","fromDataset","dimensionsDefine","getDatasetModel","datasetOption","completeResult","completeBySourceData","encodeDefine","encode","makeDefaultEncode","startIndex","dimensionsDetectCount","normalizeDimensionsDefine","findPotentialName","potentialNameDimIndex","arrayRowsTravelFirst","objectRowsCollectDimensions","colArr","value0","name","nameMap","displayName","exist","count","set","maxLoop","Infinity","obj","firstIndex","coordSysDefine","encodeItemName","encodeSeriesName","seriesType","subType","nSeriesMap","cSeriesMap","uid","datasetRecord","categoryWayDim","valueWayDim","coordSysDims","coordDim","firstCategoryDimIndex","dataDim","categoryAxisMap","firstNotOrdinal","doGuessOrdinal","nameDimIndex","itemName","seriesName","thisData","getComponent","datasetIndex","guessOrdinal","dimIndex","dimName","sample","detectValue","row","cof","arg","_vm","_h","$createElement","_c","_self","ref","staticClass","class","on","click","$event","setTime","_v","dateTitle","_s","title","where","time_price","increase_time_status","growth_rate","increase_time","attrs","options","polar","_m","_l","price","current","clean","lunar","isrange","multi","ismulti","weekSwitch","monthRange","rangeMonthFormat","monFirst","responsive","begin","end","select","next","prev","directives","rawName","expression","touchmove","preventDefault","close","loaded","loading","staticRenderFns","EChartsvue_type_template_id_65292532_render","EChartsvue_type_template_id_65292532_staticRenderFns","raf","requestAnimationFrame","window","webkitRequestAnimationFrame","mozRequestAnimationFrame","setTimeout","caf","cancelAnimationFrame","id","webkitCancelAnimationFrame","mozCancelAnimationFrame","clearTimeout","createStyles","styleText","document","createElement","styleSheet","cssText","appendChild","createTextNode","querySelector","body","tagName","elem","keys","forEach","getComputedStyle","prop","pseudo","computedStyle","display","getRenderInfo","documentElement","contains","detached","rendered","parentNode","css","total","addListener","__resize_mutation_handler__","handleMutation","listeners","__resize_listeners__","ResizeObserver","offsetWidth","offsetHeight","ro","__resize_observer_triggered__","runCallbacks","__resize_observer__","observe","attachEvent","addEventListener","__resize_legacy_resize_handler__","initTriggers","__resize_rendered__","MutationObserver","mo","attributes","childList","characterData","subtree","__resize_mutation_observer__","removeListener","detachEvent","removeEventListener","splice","indexOf","unobserve","disconnect","handleScroll","removeChild","__resize_triggers__","triggers","getUpdatedSize","__resize_last__","resetTriggers","__resize_raf__","updated","__resize_old_position__","className","expand","expandChild","contract","scrollWidth","csw","scrollHeight","csh","eow","eoh","esw","esh","scrollLeft","scrollTop","EVENTS","INIT_TRIGGERS","REWATCH_TRIGGERS","EChartsvue_type_script_lang_js_","theme","String","initOptions","autoresize","Boolean","watchShallow","manualUpdate","lastArea","watch","_group","chart","methods","mergeOptions","notMerge","lazyUpdate","manualOptions","delegateMethod","init","appendData","params","resize","dispatchAction","payload","convertToPixel","finder","convertFromPixel","containPixel","showLoading","hideLoading","getDataURL","getConnectedDataURL","dispose","_this$chart","_len","arguments","args","_key","apply","delegateGet","methodName","getArea","$el","_this","echarts_default","setOption","$emit","__resizeHandler","debounce_default","leading","defineProperties","configurable","isDisposed","computedOptions","initOptionsWatcher","_this2","__unwatchOptions","$watch","oldVal","deep","destroy","refresh","created","_this3","mounted","activated","beforeDestroy","connect","disConnect","registerMap","mapName","geoJSON","specialAreas","registerTheme","components_EChartsvue_type_script_lang_js_","component","componentNormalizer","ECharts","mpvue_calendarvue_type_template_id_2947f353_render","isMonthRange","_e","arrowLeft","arrowRight","stopPropagation","changeYear","oversliding","monthPosition","unit","monthText","year","cellpadding","mc-month-range-mode-head","week","days","mc-range-mode","week-switch","month-range-mode","rangeOfMonths","day","k1","gregorianStyle","child","k2","selected","mc-today-element","isToday","disabled","mc-range-select-one","rangeBgHide","lunarStyle","mc-range-row-first","month-last-date","lastDay","month-first-date","mc-range-row-last","mc-last-month","lastMonth","mc-next-month","nextMonth","rangeClassName","showToday","show","mc-date-red","content","isLunarFestival","isAlmanac","isGregorianFestival","isTerm","almanac","yearsShow","active","selectYear","calendar-week-switch-months","month","changeMonth","mpvue_calendarvue_type_template_id_2947f353_staticRenderFns","_arrayWithHoles","arr","is_array_default","_iterableToArrayLimit","_arr","_n","_d","_i","get_iterator_default","err","_nonIterableRest","TypeError","_slicedToArray","calendar","lunarInfo","solarMonth","Gan","Zhi","Animals","solarTerm","sTermInfo","nStr1","nStr2","nStr3","lYearDays","sum","leapDays","leapMonth","monthDays","solarDays","ms","toGanZhiYear","lYear","ganKey","zhiKey","toAstro","cMonth","cDay","s","substr","toGanZhi","getTerm","_table","_info","parseInt","_calday","toChinaMonth","toChinaDay","d","getAnimal","solar2lunar","objDate","Date","leap","temp","getFullYear","getMonth","getDate","UTC","isTodayObj","nWeek","getDay","cWeek","isLeap","sm","gzY","firstNode","secondNode","gzM","Term","dayCyclical","gzD","astro","lMonth","lDay","Animal","IMonthCn","IDayCn","cYear","gzYear","gzMonth","gzDay","ncWeek","lunar2solar","isLeapMonth","_day","isAdd","stmap","calObj","cY","getUTCFullYear","cM","getUTCMonth","cD","getUTCDate","calendarinit","isBrowser","now","todayString","mpvue_calendarvue_type_script_lang_js_","default","completion","zero","almanacs","tileContent","weeks","months","events","years","multiDays","today","handleMultiDay","firstRender","isIos","festival","1-1","1-15","2-2","5-5","7-7","7-15","8-15","9-9","10-1","10-15","12-8","12-23","gregorian","2-14","3-8","3-12","5-1","5-4","6-1","7-1","8-1","9-10","12-24","12-25","rangeBegin","rangeEnd","multiDaysData","monthsLoop","itemWidth","positionH","monthIndex","monthRangeDays","weekIndex","startWeekIndex","positionWeek","computed","itemStyle","fontSize","lineHeight","isRendeRangeMode","isUserSelect","addResponsiveListener","loopArray","concat","unshift","monthsLoopCopy","wx","getSystemInfo","success","system","split","initRender","Number","yearEnd","monthEnd","dayEnd","thatYear","thatMonth","updateHeadMonth","renderOption","playload","seletSplit","isMonthModeCurrentMonth","disabledFilter","find","v","dayArr","assign","getLunarInfo","getEvents","date","copyRangeBegin","copyRangeEnd","beginTime","endTime","stepTime","_beginTime","_endTime","monthFirstDay","monthLastDay","isCurrentMonthToday","_options","_beginTime2","_endTime2","_options2","monthHuman","_beginTime3","_endTime3","watchRender","daysDeepCopy","JSON","stringify","some","vv","renderer","isCustomRender","isWatchRenderValue","firstDayOfMonth","lastDateOfMonth","lastDayOfLastMonth","line","nextMonthPushDays","computedPrevYear","computedPrevMonth","_k","lastDateOfMonthLength","computedNextYear","computedNextMonth","lastMonthDay","LastMonthItems","lastIndex","secondToLastIndex","differentMonth","_i2","contents","_ref","tempLength","lastLineMonth","secondLastMonth","payloadDay","searchIndex","thisTimeSelect","setIndex","positionDay","isWeekNow","setMonthRangeofWeekSwitch","todayText","rendeRange","formatDateText","fYear","fMonth","reg","exec","substring","RegExp","$1","$2","$3","$4","_monthRange$0$split","_monthRange$0$split2","monthRangeOfStart","monthRangeOfEnd","startYear","startMonth","endYear","endtMonth","monthsRange","_item","yearParam","monthParam","renderY","renderM","yearEve","lunarValue","lunarInfoObj","changed","changeWeek","currentWeek","monthChenged","lastMonthLength","_this4","_this5","selectedDates","selectMonth","selectMonthHuman","selectDay","rangeEndTemp","rangeBeginTemp","rangeDate","zeroPad","filterDayIndex","findIndex","filter","currentSelected","selectDate","setToday","_this6","reduce","prveDate","prevMonth","currentMonth","prevMonthText","currentMonthText","dateInfo","$refs","clientWidth","toFixed","src_mpvue_calendarvue_type_script_lang_js_","mpvue_calendar_component","mpvue_calendar","Statisticsvue_type_script_lang_js_","components","Calendar","Loading","tooltip","trigger","legend","toolbox","feature","mark","dataView","readOnly","magicType","restore","saveAsImage","calculable","boundaryGap","splitLine","axisLine","lineStyle","series","stack","normal","x2","y2","animationDuration","renderValues","types","page","limit","list","$route.params","newVal","setType","getIndex","handelRenderValues","$route","getInfo","$scroll","container","monthRangeText","admin","then","num","error","$dialog","msg","getTime","clickSomeThing","console","log","setMonthRange","switchMode","values","multiMode","rangeMode","valueMode","info","val2","message","orderAdmin_Statisticsvue_type_script_lang_js_","Statistics_component","__webpack_exports__","isObjectLike","modelUtil","point","seriesIndex","getSeriesByIndex","getData","dataIndex","queryDataIndex","el","getItemGraphicEl","coordSys","getTooltipPosition","dataToPoint","getValues","mapDimension","clone","_symbol","createSymbol","_number","parsePercent","_labelHelper","getDefaultLabel","SymbolClz","seriesScope","Group","updateData","symbolProto","getSymbolSize","symbolSize","getItemVisual","getScale","driftSymbol","drift","_createSymbol","symbolType","keepAspect","symbolPath","attr","culling","_symbolType","stopSymbolAnimation","toLastFrame","childAt","stopAnimation","getSymbolPath","highlight","downplay","setZ","zlevel","z","setDraggable","draggable","cursor","hostModel","isInit","updateProps","_updateCommon","fadeIn","opacity","initProps","_seriesModel","normalStyleAccessPath","emphasisStyleAccessPath","normalLabelAccessPath","emphasisLabelAccessPath","onMouseOver","isInEmphasis","onEmphasis","onMouseOut","onNormal","incremental","useHoverLayer","__symbolOriginalScale","ratio","animateTo","useStyle","strokeNoScale","hoverItemStyle","symbolRotate","symbolOffset","labelModel","hoverLabelModel","hoverAnimation","cursorStyle","hasItemOption","itemModel","getItemModel","getModel","getShallow","elStyle","setColor","symbolInnerColor","setStyle","liftZ","z2Origin","__z2Origin","useNameLabel","getLabelDefaultText","getName","setLabelStyle","labelFetcher","labelDataIndex","defaultText","isRectText","autoColor","off","hoverStyle","setHoverStyle","isAnimationEnabled","fadeOut","keepLabel","AxisBuilder","AxisView","axisBuilderAttrs","selfBuilderAttrs","axisPointerClass","radiusAxisModel","radiusAxis","angleAxis","getAngleAxis","ticksCoords","getTicksCoords","axisAngle","getExtent","radiusExtent","layoutAxis","axisBuilder","getGroup","isBlank","_splitLine","splitLineModel","lineStyleModel","lineColors","lineCount","splitLines","colorIndex","Circle","cx","cy","coord","mergePath","stroke","getLineStyle","_splitArea","splitAreaModel","areaStyleModel","areaColors","splitAreas","prevRadius","Sector","r0","startAngle","endAngle","getAreaStyle","createListFromArray","axisHelper","axisModelCommonMixin","Model","_layout","getLayoutRect","_dataStackHelper","enableDataStack","isDimensionStacked","getStackedDimension","_completeDimensions","completeDimensions","_createDimensions","createDimensions","createList","dataStack","createScale","dataExtent","isInstance","mixin","createScaleByModel","setExtent","niceScaleExtent","mixinAxisModelCommonMethods","ArrayCtor","Float32Array","m1","m2","out0","out1","out2","out3","out4","out5","translate","rad","aa","ac","atx","ab","ad","aty","st","sin","ct","cos","vx","vy","det","env","register","api","handler","node","zr","getZr","records","initGlobalListeners","record","useHandler","eventType","dis","makeDispatchAction","dispatchTooltipFinally","pendings","initialized","curry","doEnter","onLeave","actuallyPayload","showLen","showTip","hideLen","hideTip","currTrigger","pendingList","unregister","Scale","OrdinalMeta","scaleProto","OrdinalScale","ordinalMeta","extent","categories","_ordinalMeta","_extent","getOrdinal","round","rank","normalize","getTicks","ticks","getLabel","unionExtentFromData","unionExtent","getApproximateExtent","getOrdinalMeta","niceTicks","noop","niceExtent","Style","Element","RectText","__clipPaths","__dirty","invisible","dragging","rectHover","progressive","beforeBrush","afterBrush","rectContain","traverse","context","dirty","__dirtyText","__zr","animateStyle","animate","attrKV","Polar","_axisHelper","CoordinateSystem","resizePolar","polarModel","getWidth","getHeight","getRadiusAxis","size","radius","inverse","updatePolarScale","eachSeries","model","onBand","diff","setAxis","mainType","polarCreator","polarList","eachComponent","update","findAxisModel","angleAxisModel","queryComponents","getSeriesStackId","getAxisKey","barLayoutPolar","lastStackCoords","barWidthAndOffset","calRadialBar","getSeriesByType","isSeriesFiltered","eachSeriesByType","baseAxis","getBaseAxis","stackId","columnLayoutInfo","columnOffset","columnWidth","valueAxis","getOtherAxis","barMinHeight","barMinAngle","valueDim","baseDim","stacked","valueAxisStart","baseValue","sign","baseCoord","radiusSpan","dataToRadius","angle","dataToAngle","angleSpan","setItemLayout","barSeries","columnsMap","axisExtent","bandWidth","getBandWidth","columnsOnAxis","remainedWidth","autoWidthCount","categoryGap","gap","stacks","maxWidth","barWidth","barMaxWidth","barGap","barCategoryGap","coordSysName","barGapPercent","autoWidth","column","lastColumn","widthSum","_mini_css_extract_plugin_dist_loader_js_ref_6_oneOf_1_0_css_loader_index_js_ref_6_oneOf_1_1_vue_loader_lib_loaders_stylePostLoader_js_postcss_loader_src_index_js_ref_6_oneOf_1_2_cache_loader_dist_cjs_js_ref_0_0_vue_loader_lib_index_js_vue_loader_options_ECharts_vue_vue_type_style_index_0_lang_css___WEBPACK_IMPORTED_MODULE_0__","_mini_css_extract_plugin_dist_loader_js_ref_6_oneOf_1_0_css_loader_index_js_ref_6_oneOf_1_1_vue_loader_lib_loaders_stylePostLoader_js_postcss_loader_src_index_js_ref_6_oneOf_1_2_cache_loader_dist_cjs_js_ref_0_0_vue_loader_lib_index_js_vue_loader_options_ECharts_vue_vue_type_style_index_0_lang_css___WEBPACK_IMPORTED_MODULE_0___default","arrySlice","Eventful","eventProcessor","_$handlers","_$eventProcessor","normalizeQuery","host","query","eventful","isOnce","h","wrap","one","callAtLast","zrEventfulCallAtLast","lastWrap","isSilent","newList","l","argLen","hItem","afterTrigger","triggerWithContext","getMin","rangeStart","eqNaN","getMax","getNeedCrossZero","getCoordSysModel","setRange","resetRange","coordinateSystemCreators","CoordinateSystemManager","_coordinateSystems","coordinateSystems","creater","getCoordinateSystems","coordinateSystemCreator","curve","vec2","bbox","devicePixelRatio","CMD","M","L","C","Q","A","Z","R","min2","max2","mathMin","mathMax","mathCos","mathSin","mathSqrt","mathAbs","hasTypedArray","PathProxy","notSaveData","_saveData","_ctx","_xi","_yi","_x0","_y0","_ux","_uy","_lineDash","_dashOffset","_dashIdx","_dashSum","setScale","getContext","beginPath","moveTo","addData","lineTo","exceedUnit","_needsDash","_dashedLineTo","bezierCurveTo","x1","y1","x3","y3","_dashedBezierTo","quadraticCurveTo","_dashedQuadraticTo","arc","anticlockwise","arcTo","closePath","x0","y0","toStatic","setLineDash","lineDash","lineDashSum","setLineDashOffset","setData","appendPath","path","appendSize","appendPathData","cmd","_expandData","_prevCmd","newData","dash","dashSum","nDash","cubicAt","bezierLen","tmpLen","MAX_VALUE","xi","yi","fromLine","fromCubic","fromQuadratic","rx","ry","fromArc","rebuildPath","ux","uy","theta","dTheta","psi","fs","scaleX","scaleY","isEllipse","$export","$find","KEY","forced","P","F","numberUtil","formatUtil","scaleHelper","IntervalScale","intervalScaleProto","mathCeil","ceil","mathFloor","ONE_SECOND","ONE_MINUTE","ONE_HOUR","ONE_DAY","bisect","TimeScale","stepLvl","_stepLvl","formatTime","getSetting","splitNumber","minInterval","maxInterval","interval","_interval","fixMin","fixMax","approxTickNum","span","approxInterval","scaleLevelsLen","scaleLevels","level","yearSpan","yearStep","nice","timezoneOffset","getTimezoneOffset","fixExtent","_niceExtent","parseDate","useUTC","SeriesModel","dependencies","getInitialData","legendHoverLink","clipOverflow","label","step","smooth","smoothMonotone","symbol","showSymbol","showAllSymbol","connectNulls","sampling","animationEasing","hoverLayerThreshold","getSystemInfoSync","browser","os","wxa","canvasSupported","svgSupported","touchEventsSupported","domSupported","worker","navigator","detect","userAgent","ua","firefox","match","ie","edge","weChat","test","version","SVGRect","pointerEventsSupported","pathTool","colorTool","Path","Image","Text","Ring","Polygon","Polyline","Line","BezierCurve","Arc","CompoundPath","LinearGradient","RadialGradient","IncrementalDisplayable","EMPTY_OBJ","Z2_EMPHASIS_LIFT","extendShape","extendPath","pathData","extendFromString","makePath","createFromString","centerGraphic","resizePath","makeImage","imageUrl","img","boundingRect","pathRect","calculateTransform","subPixelOptimizeLine","param","lineWidth","subPixelOptimize","subPixelOptimizeRect","originX","originY","originWidth","originHeight","positiveOrNegative","doubledPosition","hasFillOrStroke","fillOrStroke","liftedColorMap","liftedColorCount","liftColor","liftedColor","lift","cacheElementStl","__hoverStlDirty","__hoverStl","normalStyle","__cachedNormalStl","__cachedNormalZ2","doSingleEnterHover","hoverStl","__highlighted","elTarget","targetStyle","addHover","rollbackDefaultTextStyle","extendFrom","setDefaultHoverFillStroke","applyDefaultTextStyle","doSingleLeaveHover","highlighted","removeHover","normalStl","normalZ2","traverseCall","method","isGroup","setElementHoverStyle","__isEmphasisEntered","onElementMouseOver","__hoverSilentOnTouch","zrByTouch","onElementMouseOut","enterEmphasis","leaveEmphasis","setAsHoverStyleTrigger","disable","hoverSilentOnTouch","__hoverStyleTrigger","emphasisStyle","normalModel","emphasisModel","normalSpecified","emphasisSpecified","baseText","labelDimIndex","showNormal","showEmphasis","getFormattedLabel","isFunction","normalStyleText","emphasisStyleText","retrieve2","setTextStyle","textStyle","textStyleModel","specifiedTextStyle","isEmphasis","setTextStyleCommon","setText","defaultColor","textPosition","textOffset","textRotation","textDistance","richResult","globalTextStyle","richItemNames","getRichItemNames","richTextStyle","setTokenTextStyle","rich","forceRich","richItemNameMap","parentModel","isBlock","textFill","getAutoColor","textStroke","textBorderColor","textStrokeWidth","textBorderWidth","insideRawTextPosition","insideRollbackOpt","fontStyle","fontWeight","fontFamily","textAlign","textVerticalAlign","textLineHeight","textWidth","textHeight","textTag","disableBox","textBackgroundColor","textPadding","textBorderRadius","textBoxShadowColor","textBoxShadowBlur","textBoxShadowOffsetX","textBoxShadowOffsetY","textShadowColor","textShadowBlur","textShadowOffsetX","textShadowOffsetY","insideRollback","useInsideStyle","getFont","gTextStyleModel","trim","animateOrSetProps","isUpdate","animatableModel","animationEnabled","postfix","duration","animationDelay","getAnimationDelayParams","getTransform","ancestor","mat","transformDirection","direction","hBase","vBase","vertex","groupTransition","g1","g2","elMap1","getElMap","anid","oldEl","newProp","getAnimatableProps","g","elMap","clipPointsByRect","clipRectByRect","targetRect","createIcon","iconStr","replace","POSSIBLE_STYLES","compatEC2ItemStyle","itemStyleOpt","styleName","normalItemStyleOpt","emphasisItemStyleOpt","emphasis","merge","convertNormalEmphasis","optType","useExtend","normalOpt","emphasisOpt","removeEC3NormalStatus","compatTextStyle","labelOptSingle","TEXT_STYLE_OPTIONS","compatEC3CommonStyles","processSeries","seriesOpt","markPoint","markLine","markArea","nodes","edgeData","links","edges","mpData","mlData","breadcrumb","levels","leaves","toArr","o","toObj","isTheme","axes","axisName","axisOpt","axisPointer","parallel","parallelOpt","parallelAxisDefault","calendarOpt","radar","radarOpt","geo","geoOpt","regions","regionObj","timeline","timelineOpt","toolboxOpt","featureOpt","properties","excludes","includes","polygon","lineX","lineY","keep","lang","dataZoom","zoom","back","bar","tiled","typeNames","pie","scatter","effectScatter","tree","treemap","boxplot","candlestick","heatmap","lines","graph","sankey","funnel","gauge","pictorialBar","themeRiver","sunburst","aria","general","withTitle","withoutTitle","single","prefix","withName","withoutName","multiple","separator","middle","allData","partialData","objectToString","isDataItemOption","DefaultDataProvider","dimSize","seriesDataToSource","_source","_data","_offset","_dimSize","providerMethods","providerProto","pure","persistent","arrayRows_column","getItem","appendDataSimply","arrayRows_row","objectRows","countSimply","getItemSimply","keyedColumns","col","dims","newCol","oldCol","original","typedArray","rawValueGetters","arrayRows","getRawValueSimply","dataItem","defaultDimValueGetters","getDimValueSimply","converDataValue","_dimensionInfos","_rawData","dimInfo","dimType","parseAndCollect","NaN","retrieveRawValue","getRawDataItem","getProvider","getDimensionInfo","retrieveRawAttr","freeGlobal","freeSelf","Function","fixShadow","_constant","ContextCachedBy","STYLE_COMMON_PROPS","createLinearGradient","global","canvasGradient","createRadialGradient","fillOpacity","strokeOpacity","lineDashOffset","shadowBlur","shadowOffsetX","shadowOffsetY","font","textFont","textRect","transformText","textOrigin","truncate","blend","prevStyle","notCheckCache","__attrCachedBy","STYLE_BIND","fillStyle","strokeStyle","globalAlpha","globalCompositeOperation","hasStroke","getLineScale","hasFill","otherStyle","overwrite","newStyle","getGradient","colorStops","addColorStop","styleProto","debugMode","OTHER_DIMENSIONS","summarizeDimensions","summary","notExtraCoordDimMap","defaultedLabel","defaultedTooltip","dimItem","coordDimArr","coordDimIndex","isExtraCoord","mayLabelDimType","defaultTooltip","otherDim","otherDimArr","otherDims","dataDimsOnCoord","encodeFirstDimNotExtra","dimArr","encodeLabel","encodeTooltip","getDimensionTypeByAxis","axisType","barPolar","registerLayout","Ellipse","_path","DILIMITER_REG","parseXML","svg","parser","DOMParser","parseFromString","nodeType","firstChild","nodeName","toLowerCase","nextSibling","SVGParser","_defs","_root","_isDefine","_isText","xml","viewBox","getAttribute","parseFloat","parseAttributes","viewBoxRect","viewBoxTransform","_parseNode","viewBoxArr","makeViewBoxTransform","ignoreViewBox","elRoot","ignoreRootClip","setClipPath","xmlNode","parentGroup","defineParsers","def","nodeParsers","_parseText","_textX","_textY","textContent","inheritStyle","setShape","circle","ellipse","parsePoints","polyline","tspan","lineargradient","gradient","_parseGradientColorStops","radialgradient","stopColor","__inheritedStyle","pointsString","attributesMap","stroke-width","fill-opacity","stroke-opacity","stroke-dasharray","stroke-dashoffset","stroke-linecap","stroke-linejoin","stroke-miterlimit","font-family","font-size","font-style","font-weight","text-align","alignment-baseline","defs","onlyInlineStyle","zrStyle","isTextEl","parseTransformAttribute","parseStyleAttribute","svgAttrName","attrValue","elFillProp","elStrokeProp","getPaint","elPropName","textBaseline","urlRegex","str","urlMatch","url","transformRegex","transformOps","warn","styleRegex","styleRegResult","styleList","viewBoxScale","viewBoxPosition","parseSVG","util","_event","Dispatcher","Animation","stage","_clips","_running","_time","_pausedTime","_pauseStart","addAnimator","clips","removeAnimator","_update","delta","deferredEvents","deferredClips","_needsRemove","pop","fire","_startLoop","isFinished","List","_dimensionHelper","coordSysDimDefs","registeredCoordSys","axisMap","getDimensionsInfo","hasNameEncode","dimInfoList","coordDimensions","generateCoord","categoryAxisModel","stackCalculationInfo","setCalculationInfo","dimValueGetter","isNeedCompleteOrdinalData","itemOpt","defaultDimValueGetter","initData","sampleItem","firstDataNotNull","transformPath","vMag","vRatio","u","vAngle","acos","processArc","fa","psiDeg","xp","yp","lambda","cxp","cyp","commandReg","numberReg","createPathProxyFromString","prevCmd","cpx","cpy","subpathX","subpathY","cmdList","cmdText","cmdStr","charAt","pLen","ctlPtx","ctlPty","createPathOptions","pathProxy","buildPath","pathEls","pathList","pathEl","createPathProxy","__dirtyPath","pathBundle","nullTag","undefinedTag","baseGetTag","RADIAN_EPSILON","_trim","linearMap","domain","clamp","subDomain","subRange","all","precision","returnStr","getPrecision","getPrecisionSafe","eIndex","dotIndex","getPixelPrecision","pixelExtent","LN10","dataQuantity","sizeQuantity","getPercentWithPrecision","valueList","acc","digits","pow","votesPerQuota","targetSeats","seats","votes","currentSum","remainder","NEGATIVE_INFINITY","maxId","MAX_SAFE_INTEGER","remRadian","radian","pi2","isRadianAroundZero","TIME_REG","hour","toUpperCase","quantity","quantityExponent","nf","exponent","exp10","quantile","ascArr","H","reformIntervals","littleThan","curr","currClose","lg","isNumeric","_dataProvider","_format","getTooltipMarker","formatTpl","getTooltipRenderMode","DIMENSION_LABEL_REG","getDataParams","dataType","rawValue","getRawValue","rawDataIndex","getRawIndex","tooltipModel","renderModeOption","renderMode","isSeries","componentType","componentSubType","componentIndex","seriesId","marker","$vars","status","labelProp","formatter","formatTooltip","makeStyleMapper","getLineDash","lineType","dotSize","dashSize","Displayble","IncrementalDisplayble","_displayables","_temporaryDisplayables","_cursor","notClear","clearDisplaybles","addDisplayable","displayable","notPersistent","addDisplayables","displayables","eachPendingDisplayable","childRect","union","localPos","zrender","timsort","GlobalModel","ExtensionAPI","OptionManager","backwardCompat","ChartView","_throttle","throttle","seriesColor","loadingDefault","Scheduler","lightTheme","darkTheme","mapDataStorage","parseClassType","TEST_FRAME_REMAIN_TIME","PRIORITY_PROCESSOR_FILTER","PRIORITY_PROCESSOR_STATISTIC","PRIORITY_VISUAL_LAYOUT","PRIORITY_VISUAL_GLOBAL","PRIORITY_VISUAL_CHART","PRIORITY_VISUAL_COMPONENT","PRIORITY_VISUAL_BRUSH","PRIORITY","PROCESSOR","FILTER","STATISTIC","VISUAL","LAYOUT","GLOBAL","CHART","COMPONENT","BRUSH","IN_MAIN_PROCESS","OPTION_UPDATED","ACTION_REG","createRegisterEventWithLowercaseName","MessageCenter","dom","themeStorage","_dom","defaultRenderer","_zr","_throttledZrFlush","flush","_theme","_chartsViews","_chartsMap","_componentsViews","_componentsMap","_coordSysMgr","_api","createExtensionAPI","prioritySortFunc","__prio","visualFuncs","dataProcessorFuncs","_scheduler","_ecEventProcessor","EventProcessor","_messageCenter","_initEvents","_pendingActions","_onframe","bindRenderedEvent","setAsPrimitive","echartsProto","doConvertPixel","coordSysList","parseFinder","_disposed","scheduler","prepare","updateMethods","flushPendingActions","triggerUpdatedEvent","unfinished","remainTime","startTime","performSeriesTasks","performDataProcessorTasks","updateStreamModes","performVisualTasks","renderSeries","getDom","optionManager","optionPreprocessorFuncs","setTheme","getOption","getDevicePixelRatio","painter","getRenderedCanvas","pixelRatio","backgroundColor","getSvgDataUrl","storage","getDisplayList","pathToDataUrl","excludeComponents","excludesComponentViews","view","__viewId","ignore","getType","toDataURL","groupId","MAX_NUMBER","connectedGroups","canvasList","instances","canvas","getBoundingClientRect","targetCanvas","createCanvas","refreshImmediately","models","containPoint","getVisual","visualType","defaultMainType","dataIndexInside","indexOfRawIndex","getViewOfComponentModel","componentModel","getViewOfSeriesModel","prepareAndUpdate","coordSysMgr","restoreData","clearColorPalette","setBackgroundColor","colorArr","performPostUpdateFuncs","ecIns","componentDirtyList","componentView","__alive","seriesDirtyMap","chartView","setDirty","dirtyMap","updateView","markUpdateMethod","updateVisual","updateLayout","restorePipelines","prepareStageTasks","prepareView","plan","updateDirectly","condition","excludeSeriesId","normalizeToArray","callView","__model","chartsMap","doDispatchAction","payloadType","escapeConnect","actionWrap","actions","actionInfo","cptType","updateMethod","payloads","batched","batch","eventObj","eventObjBatch","isHighDown","batchItem","action","main","sub","pendingActions","shift","isComponent","viewList","viewMap","doPrepare","viewId","classType","Clazz","getClass","__id","__ecComponentInfo","renderTask","remove","renderComponents","dirtyList","updateZ","updatePayload","perform","getPerformArgs","updateBlend","updateHoverLayerStatus","postUpdateFuncs","func","_loadingFX","optionChanged","resetOption","cfg","loadingEffects","makeActionFromEvent","eventActionMap","MOUSE_EVENT_NAMES","elCount","blendMode","ecInstance","getComponentByElement","modelInfo","eventInfo","eveName","isGlobalOut","dataModel","eventData","targetEl","packedEvent","actionType","setAttribute","DOM_ATTRIBUTE_KEY","cptQuery","dataQuery","otherQuery","condCptType","suffixes","dataKeys","reserved","propSuffix","suffixPos","lastIndexOf","check","filterForExposedEvent","propOnHost","idBase","groupIdBase","enableConnect","STATUS_PENDING","STATUS_UPDATING","STATUS_UPDATED","STATUS_KEY","updateConnectedChartsStatus","charts","otherChart","otherCharts","existInstance","getInstanceByDom","getInstanceById","preprocessorFunc","registerProcessor","priority","processor","normalizeRegister","registerPostUpdate","postUpdateFunc","registerAction","registerCoordinateSystem","getCoordinateSystemDimensions","coordSysCreator","layoutTask","registerVisual","visualTask","targetList","fn","defaultPriority","stageHandler","wrapStageHandler","__raw","registerLoading","loadingFx","extendComponentModel","extendSeriesModel","extendChartView","setCanvasCreator","creator","$override","geoJson","getMap","retrieveMap","dataTool","___ec_export","scaleAndAdd","lenSquare","lengthSquare","div","dot","distance","distanceSquare","distSquare","negate","lerp","LRU","kCSSColorTable","transparent","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","clampCssByte","clampCssAngle","clampCssFloat","parseCssInt","parseCssFloat","cssHueToRgb","lerpNumber","setRgba","copyRgba","colorCache","lastRemovedArr","putToCache","colorStr","rgbaArr","put","cached","op","ep","fname","alpha","hsla2rgba","iv","hsla","rgba2hsla","S","G","B","vMin","vMax","deltaR","deltaG","deltaB","toHex","fastLerp","normalizedValue","colors","leftIndex","rightIndex","leftColor","rightColor","dv","fastMapToColor","fullOutput","mapToColor","modifyHSL","modifyAlpha","arrColor","Gradient","_clazz","enableClassExtend","enableClassCheck","lineStyleMixin","areaStyleMixin","textStyleMixin","itemStyleMixin","doGet","pathArr","getParent","getParentMethod","mergeOption","ignoreParent","parsePath","thisParentModel","isEmpty","Ctor","setReadOnly","customizeGetParent","easingFuncs","_life","_initialized","onrestart","globalTime","deltaTime","_startTime","easingFunc","schedule","restart","PI2","globalCoord","AxisPointerModel","coordSysAxesInfo","triggerOn","snap","triggerTooltip","link","animationDurationUpdate","shadowStyle","margin","padding","borderColor","borderWidth","shadowColor","handle","icon","axisModelCreator","AxisModel","superApply","gridIndex","gridId","getAxisType","extraOption","_vector","v2Create","v2DistSquare","mathPow","EPSILON_NUMERIC","THREE_SQRT","ONE_THIRD","_v0","_v1","_v2","isAroundZero","onet","cubicDerivativeAt","cubicRootAt","roots","c","t1","disc","K","discSqrt","Y1","Y2","T","ASqrt","cubicExtrema","extrema","cubicSubdivide","p01","p12","p23","p012","p123","p0123","cubicProjectPoint","d1","d2","_t","quadraticAt","quadraticDerivativeAt","quadraticRootAt","quadraticExtremum","divider","quadraticSubdivide","quadraticProjectPoint","BaseAxisPointer","viewHelper","cartesianAxisHelper","CartesianAxisPointer","makeElOption","elOption","axisPointerModel","axisPointerType","otherExtent","getCartesian","getGlobalExtent","pixelValue","buildElStyle","pointerOption","pointerShapeBuilder","graphicKey","pointer","layoutInfo","buildCartesianSingleLabelElOption","getHandleTransform","labelMargin","getTransformedPosition","updateHandleTransform","currPosition","cursorOtherValue","cursorPoint","tooltipOptions","verticalAlign","align","tooltipOption","targetShape","makeLineShape","getAxisDimIndex","shadow","makeRectShape","registerAxisPointerClass","fixClipWithShadow","clockwise","unitX","unitY","dev","encodeHTML","addCommas","colorPaletteMixin","dataFormatMixin","getLayoutParams","mergeLayoutParam","_task","createTask","legendDataProvider","visualColorAccessPath","layoutMode","extraOpt","dataTask","dataTaskCount","reset","dataTaskReset","mergeDefaultAndTheme","wrapData","dataBeforeProcessed","autoSeriesName","inputPositionParams","themeSubType","hasClass","getTheme","getDefaultOption","defaultEmphasis","fillDataTextStyle","newSeriesOption","getRawData","task","getCurrentTask","getLinkedData","modifyOutputEnd","setOutputEnd","outputData","multipleSeries","newLine","isRichText","markers","markerId","formatArrayValue","vertially","setEachItem","markName","dimHead","dimHeadStr","valStr","tooltipDims","formatSingleValue","tooltipDimLen","isValueArr","formattedValue","colorEl","isNameSpecified","html","getColorFromPalette","scope","requestColorNum","coordDimToDataDim","getProgressive","getProgressiveThreshold","getAxisTooltipData","pipeTask","preventIncremental","pipelineContext","getSeriesAutoName","dataDims","nameArr","cloneShallow","dataTaskProgress","CHANGABLE_METHODS","wrapMethod","onDataSelfChange","pipeline","getPipeline","currentTask","agentStubMap","smoothSpline","smoothBezier","controlPoints","smoothConstraint","cp1","cp2","getStatisticsInfo","getStatisticsMonth","getAdminOrderList","setAdminOrderPrice","setAdminOrderRemark","getAdminOrderDetail","getAdminOrderDelivery","setAdminOrderDelivery","getStatisticsTime","setOfflinePay","setOrderRefund","_utils_request__WEBPACK_IMPORTED_MODULE_0__","request","login","post","orderId","getBorderLineDash","r1","r2","r3","r4","ifAxisCrossZero","estimateLabelUnionRect","Cartesian2D","Axis2D","isAxisUsedInTheGrid","Grid","_coordsMap","_coordsList","_axesMap","_axesList","_initCartesian","gridProto","fixAxisOnZero","axesMap","otherAxisDim","onZeroRecords","otherAxes","onZeroAxisIndex","canOnZeroToAxis","getOnZeroRecordKey","updateAxisTransform","coordBase","axisExtentSum","toLocalCoord","axisPointerEnabled","_updateScale","ignoreContainLabel","gridRect","getBoxLayoutParams","axesList","adjustAxes","isHorizontal","labelUnionRect","getAxis","axisIndex","axesMapOnDim","getAxes","xAxisIndex","yAxisIndex","coordList","getCartesians","_findConvertTarget","cartesian","pointToData","coordToData","xAxisModel","getReferringComponents","yAxisModel","coordsList","axisPositionUsed","axesCount","createAxisCreator","isCategory","addAxis","isCartesian2D","axesModels","findAxesModels","getTooltipAxes","baseAxes","otherAxis","axesTypes","grids","Pattern","returnFalse","createDom","newDom","newDomStyle","Layer","domStyle","onselectstart","domBack","ctxBack","config","clearColor","motionBlur","lastFrameAlpha","__used","__drawIndex","__startIndex","__endIndex","getElementCount","initContext","createBackBuffer","clearAll","clearColorGradientOrPattern","haveMotionBLur","clearRect","__canvasGradient","getCanvasPattern","save","fillRect","globalImageCache","findExistImage","newImageOrSrc","cachedImgObj","hostEl","cbPayload","__zrImageSrc","pendingWrap","pending","onerror","imageOnLoad","__cachedImgObj","isDomLevel2","MOUSE_EVENT_REG","calculate","defaultGetZrXY","layerX","offsetX","layerY","offsetY","box","clientX","clientY","normalizeEvent","isTouch","targetTouches","changedTouches","zrDelta","wheelDelta","detail","button","which","cancelBubble","returnValue","isMiddleOrRightButtonOnMouseUpDown","notLeftMouse","DataDiffer","UNDEFINED","INDEX_NOT_FOUND","ID_PREFIX","dataCtors","float","Float64Array","int","Int32Array","ordinal","number","CtorUint32Array","Uint32Array","CtorInt32Array","CtorUint16Array","Uint16Array","getIndicesCtor","_rawCount","cloneChunk","originalChunk","TRANSFERABLE_PROPERTIES","CLONE_PROPERTIES","transferProperties","__wrappedMethods","_calculationInfo","dimensionInfos","dimensionNames","invertedIndicesMap","dimensionInfo","dimensionName","createInvertedIndices","_indices","_count","_storage","_nameList","_idList","_optionModels","_visual","_itemVisuals","hasItemVisual","_itemLayouts","_graphicEls","_chunkSize","_chunkCount","_rawExtent","_approximateExtent","_dimensionsSummary","_invertedIndicesMap","listProto","prepareChunks","chunkSize","chunkCount","DataCtor","lastChunkIndex","resizeChunkArray","newStore","prepareInvertedIndex","invertedIndices","getRawValueFromStore","rawIndex","chunkIndex","chunkOffset","chunk","getRawIndexWithoutIndices","getRawIndexWithIndices","getId","_idDimIdx","normalizeDimensions","cloneListForMapAndSample","excludeDimensions","allDimensions","originalStorage","cloneDimStore","getInitialExtent","originalDimStore","newDimStore","getDimension","getDimensionsOnCoord","dimensionsSummary","nameList","notProvider","_nameRepeatCount","_dimValueGetter","_dimValueGetterArrayRows","_initDataFromProvider","rawData","appendValues","names","dimLen","rawExtent","originalChunkCount","emptyDataItem","sourceIdx","dimRawExtent","nameDimIdx","dimensionInfoMap","idList","nameRepeatCount","_nameDimIdx","itemId","dimStorage","nameDim","nameDimChunk","getIndices","indices","thisCount","newIndices","buffer","chunkStore","getByRawIndex","rawIdx","dimStore","_getFast","hasValue","getDataExtent","dimData","initialExtent","dimExtent","currEnd","useRaw","setApproximateExtent","getCalculationInfo","getSum","getMedian","dimDataArray","sortedDimDataArray","rawIndexOf","indexOfName","indicesOfNearest","maxDistance","nearestIndices","minDist","minDiff","contextCompat","filterSelf","dim0","selectRange","originalCount","quickFinished","chunkStorage","dimStorage2","chunkStorage2","dimk","mapArray","tmpRetValue","dataCount","retValue","rawExtentOnDim","downSample","dimension","rate","sampleValue","sampleIndex","targetStorage","frameValues","frameSize","dataIdx","originalChunkIndex","originalChunkOffset","sampleFrameIdx","sampleChunkIndex","sampleChunkOffset","otherList","thisList","visual","setVisual","setLayout","getLayout","getItemLayout","clearItemLayouts","itemVisual","setItemVisual","clearAllVisual","setItemDataAndSeriesIndex","setItemGraphicEl","eachItemGraphicEl","dimensionInfoList","injectFunction","originalMethod","TRANSFERABLE_METHODS","v2Distance","interpolate","isLoop","segs","w2","w3","TYPE_DELIMITER","IS_CONTAINER","checkClassType","RootClass","mandatoryMethods","$constructor","proto","superClass","ExtendedClass","superCall","classBase","Clz","classAttr","random","enableClassManagement","entity","makeContainer","registerClass","componentMainType","throwWhenNotFound","getClassesByMainType","getAllClassMainTypes","hasSubTypes","registerWhenExtend","originalExtend","axisPointerModelHelper","_axisPointer","fixValue","updateAxisPointer","disposeAxisPointer","axisView","forceRender","getAxisPointerClass","getAxisPointerModel","axisPointerClazz","clazz","_curve","containStroke","_barGrid","prepareLayoutBarSeries","makeColumnLayout","retrieveColumnLayout","getScaleExtent","axisDataLen","scaleType","originalExtent","getCategories","setBlank","isBaseAxisAndHasBarSeries","barSeriesModels","adjustedScale","adjustScaleForOverflow","axisLength","barsOnCurrentAxis","minOverflow","maxOverflow","totalOverFlow","oldRange","oldRangePercentOfNew","overflowBuffer","base","setInterval","makeLabelFormatter","labelFormatter","getLabelModel","categoryTickStart","tpl","tickValue","getAxisRawValue","tick","realNumberScaleTicks","tickCount","categoryScaleExtent","axisLabelModel","unrotatedSingleRect","getTextRect","singleRect","rotateTextRect","rotateRadians","boundingBox","plain","beforeWidth","beforeHeight","afterWidth","afterHeight","rotatedRect","getOptionCategoryInterval","shouldShowAllLabels","guid","Handler","Storage","Painter","HandlerProxy","useVML","painterCtors","ZRender","getInstance","registerPainter","delInstance","rendererType","vml","handerProxy","getViewportRoot","_needsRefresh","oldDelFromStorage","delFromStorage","oldAddToStorage","addToStorage","removeSelfFromZr","addSelfToZr","addRoot","delRoot","configLayer","zLevel","triggerRendered","_needsRefreshHover","refreshHoverImmediately","elMirror","refreshHover","clearHover","clearAnimation","pathToImage","setCursorStyle","findHover","eventHandler","_component","getUID","dataProcessorHandlers","visualHandlers","_dataProcessorHandlers","_visualHandlers","_allHandlers","_stageTaskMap","performStageTasks","stageHandlers","needSetDirty","__pipeline","stageHandlerRecord","seriesTaskMap","overallTask","overallNeedDirty","stub","performArgs","block","pipelineId","skip","performRawSeries","taskRecord","_pipelineMap","pCtx","progressiveEnabled","progressiveRender","__idxInPipeline","blockIndex","modDataCount","modBy","dataLen","incrementalPrepareRender","threshold","large","pipelineMap","head","tail","pipe","stageTaskMap","createSeriesStageTask","overallReset","createOverallStageTask","__block","getUpstream","getTargetSeries","seriesTaskPlan","seriesTaskReset","seriesTaskCount","useClearVisual","isVisual","isLayout","createOnAllSeries","eachRawSeries","eachRawSeriesByType","removeKey","overallTaskReset","overallProgress","createStub","stubReset","onDirty","stubOnDirty","agent","getSeries","upstreamContext","stubProgress","getDownstream","resetDefines","makeSeriesTaskProgress","singleSeriesTaskProgress","resetDefineIdx","resetDefine","dataEach","progress","detectSeriseType","legacyFunc","ecModelMock","apiMock","mockMethods","cond","PolarAxisPointer","animationThreshold","coordValue","capitalFirst","labelPos","getLabelPosition","buildLabelElOption","labelRotation","labelLayout","innerTextLayout","coordToPoint","makeSectorShape","componentUtil","boxLayoutMixin","dependentModels","themeModel","newCptOption","fields","optList","Class","getDependencies","deps","enableSubTypeDefaulter","enableTopologicalTravel","BUILTIN_OBJECT","[object Function]","[object RegExp]","[object Date]","[object Error]","[object CanvasGradient]","[object CanvasPattern]","[object Image]","[object Canvas]","TYPED_ARRAY","[object Int8Array]","[object Uint8Array]","[object Uint8ClampedArray]","[object Int16Array]","[object Uint16Array]","[object Int32Array]","[object Uint32Array]","[object Float32Array]","[object Float64Array]","objToString","arrayProto","nativeForEach","nativeFilter","nativeSlice","nativeMap","nativeReduce","typeStr","isPrimitive","from","isDom","targetProp","sourceProp","isBuiltInObject","mergeAll","targetAndSources","overlay","baseClazz","clazzPrototype","memo","ownerDocument","value1","retrieve3","value2","normalizeCssArray","primitiveKey","HashMap","isArr","thisMap","visit","concatArray","newArray","nameLocation","nameRotate","nameTruncate","ellipsis","placeholder","nameTextStyle","nameGap","triggerEvent","axisTick","inside","axisLabel","showMinLabel","showMaxLabel","splitArea","areaStyle","axisDefault","categoryAxis","deduplication","alignWithLabel","timeAxis","logAxis","logBase","linear","quadraticIn","quadraticOut","quadraticInOut","cubicIn","cubicOut","cubicInOut","quarticIn","quarticOut","quarticInOut","quinticIn","quinticOut","quinticInOut","sinusoidalIn","sinusoidalOut","sinusoidalInOut","exponentialIn","exponentialOut","exponentialInOut","circularIn","circularOut","circularInOut","elasticIn","asin","elasticOut","elasticInOut","backIn","backOut","backInOut","bounceIn","bounceOut","bounceInOut","textContain","textHelper","normalizeTextStyle","needDrawText","renderText","NONE","getStroke","foundAxisModel","SHADOW_PROPS","anObject","getIterator","it","iterFn","globalDefault","OPTION_INNER_KEY","_optionManager","baseOption","mountOption","initBase","timelineOption","getTimelineOption","mediaOptions","getMediaOption","mediaOption","newOption","componentsMap","newCptTypes","visitComponent","newCptOptionList","mapResult","mappingToExists","makeIdAndName","keyInfo","determineSubType","getComponentsByTypes","resultItem","ComponentModelClass","createSeriesIndices","componentOption","topologicalTravel","_seriesIndicesMap","_seriesIndices","isIdInner","cpts","isIdArray","cpt","isNameArray","filterBySubType","findComponents","queryCond","getQueryCond","doFilter","q","indexAttr","idAttr","nameAttr","queryResult","getSeriesByName","oneSeries","getSeriesCount","assertSeriesInitialized","rawSeriesIndex","getCurrentSeriesIndices","filterSeries","filteredSeries","componentTypes","isNotTargetSeries","seiresIndex","mergeTheme","notMergeColorLayer","colorLayer","themeItem","existComponent","seriesModels","defaultSymbolType","legendSymbol","symbolKeepAspect","hasCallback","itemSymbolType","itemSymbolSize","itemSymbolKeepAspect","defaultKeyGetter","oldArr","newArr","oldKeyGetter","newKeyGetter","_old","_new","_oldKeyGetter","_newKeyGetter","initIndexMap","keyArr","keyGetterName","dataDiffer","existence","_add","_remove","execute","oldDataIndexMap","newDataIndexMap","oldDataKeyArr","newDataKeyArr","PLAIN_TEXT","WILL_BE_RESTORED","echartsAPIList","chartInstance","_axisTickLabelBuilder","createAxisTicks","createAxisLabels","calculateCategoryInterval","NORMALIZED_EXTENT","Axis","fixExtentWithBands","nTick","fixOnBandTicksCoords","tickCategoryInterval","ticksLen","last","ticksItem","containData","tickModel","getTickModel","getViewLabels","labels","getRotate","normalizeRadian","sysDims","dimsDef","encodeDef","dataDimNameMap","coordDimNameMap","dimCount","getDimCount","dimDefItem","userDimName","validDataDims","resultDimIdx","applyDim","availDimIdx","sysDimItem","sysDimIndex","sysDimItemDimsDef","sysDimItemOtherDims","sysDimItemDimsDefItem","generateCoordCount","fromZero","extra","genName","optDimCount","dir","x_","polyHelper","createRenderPlanner","isLargeRender","stackResultDim","segCount","tmpIn","tmpOut","ORIGIN_METHOD","RATE","THROTTLE_TYPE","debounce","currCall","debounceNextCall","lastCall","lastExec","timer","thisDelay","thisDebounce","debounceDelay","createOrUpdate","fnAttr","throttleType","originFn","lastThrottleType","lastRate","subTypeDefaulters","registerSubTypeDefaulter","defaulter","componentTypeMain","dependencyGetter","makeDepndencyGraph","fullNameList","noEntryList","thisItem","createDependencyGraphItem","originalDeps","availableDeps","getAvailableDependencies","entryCount","dependentName","predecessor","thatItem","successor","dep","targetNameList","targetNameSet","currComponentType","currVertex","isInTargetNameSet","removeEdgeAndAdd","removeEdge","succComponentType","platform","gradientColor","animationEasingUpdate","progressiveThreshold","shadowTemp","orignalBrush","modified","clipPaths","clipPath","helper","roundNumber","_intervalPrecision","thisExtent","other","getInterval","getIntervalPrecision","intervalScaleGetTicks","reverse","intervalScaleNiceTicks","intervalPrecision","niceTickExtent","expandSize","fetch","fetchers","cartesian2d","singleAxis","singleAxisModel","parallelModel","parallelAxisIndex","roundingErrorFix","mathLog","LogScale","_originalScale","originalScale","powVal","__fixMin","fixRoundingError","__fixMax","originalVal","_needCollect","needCollect","_deduplication","_map","createByAxisModel","dedplication","getOrCreateMap","category","containLabel","RadiusAxis","radiusToData","safeLimit","_a","_b","v2ApplyTransform","lt","rb","lb","rt","maxX","maxY","intersect","ax0","ax1","ay0","ay1","bx0","bx1","by0","by1","msRequestAnimationFrame","textColor","maskColor","mask","lineCap","labelRect","animateShape","v2Min","v2Max","v2Scale","v2Add","v2Clone","v2Sub","constraint","prevPoint","nextPoint","cps","d0","cp0","outputShape","inputShape","STACK_PREFIX","LARGE_BAR_MIN_WIDTH","LargeArr","getLayoutOnAxis","axisKey","widthAndOffsets","doCalBarWidthAndOffset","offsetCenter","isOnCartesian","isInLargeMode","seriesInfoList","seriesInfo","lastStackCoordsOrigin","isValueAxisH","getValueAxisStart","largeLayout","valueAxisHorizontal","valueDimIdx","largePoints","valuePair","valueStart","tmpRect","AXIS_TYPES","BaseAxisModelClass","axisTypeDefaulter","extraDefaultOption","thisOption","__ordinalMeta","prepareDataCoordInfo","valueOrigin","getValueStart","baseAxisDim","valueAxisDim","baseDataOffset","dataDimsForPoint","stackedOverDimension","getStackedOnPoint","dataCoordInfo","stackedData","Triangle","Diamond","Pin","tanX","tanY","cpLen","cpLen2","Arrow","symbolCtors","roundRect","square","diamond","pin","arrow","triangle","symbolShapeMakers","symbolBuildProxies","inBundle","proxySymbol","symbolPathSetColor","innerColor","symbolStyle","symbolShape","__isEmptyBrush","roundRectHelper","DEFAULT_FONT","VALID_TEXT_ALIGN","VALID_TEXT_VERTICAL_ALIGN","SHADOW_STYLE_COMMON_PROPS","normalizeStyle","makeFont","renderRichText","renderPlainText","needDrawBg","needDrawBackground","checkCache","cachedByMe","styleFont","computedFont","__computedFont","__styleFont","contentBlock","__textCotentBlock","parsePlainText","outerHeight","textLines","boxPos","getBoxPosition","baseX","baseY","applyTextRotation","boxY","adjustTextY","textX","textY","outerWidth","boxX","adjustTextX","drawBackground","getTextXForPadding","propItem","styleProp","ctxProp","textStrokeWidthPrev","strokeWidthChanged","strokeChanged","getFill","strokeText","fillText","parseRichText","drawRichText","contentWidth","xLeft","lineTop","xRight","token","tokens","tokenCount","usedWidth","lineXLeft","lineXRight","placeToken","tokenStyle","isLineHolder","setCtx","isPlainBg","originalGlobalAlpha","onBgImageLoaded","blockHeiht","adjustTextPositionOnRect","maxValue","AngleAxis","angleExtent","angleToData","ordinalScale","ordinalExtent","unitSpan","unitH","maxH","dh","cache","lastAutoInterval","lastTickCount","someVectorAt","isTangent","cpx2","cpy2","cpx1","cpy1","pointAt","tangentAt","ox","oy","shapeCompareFunc","_roots","_displayList","_displayListLen","includeIgnore","updateDisplayList","displayList","_updateAndAddDisplayable","beforeUpdate","afterUpdate","userSetClipPath","currentClipPath","parentClipPath","children","_children","__storage","addChildrenToStorage","delChildrenFromStorage","_renderList","displayableSortFunc","toNumber","FUNC_ERROR_TEXT","nativeMax","nativeMin","wait","lastArgs","lastThis","maxWait","timerId","lastCallTime","lastInvokeTime","maxing","trailing","invokeFunc","thisArg","leadingEdge","timerExpired","remainingWait","timeSinceLastCall","timeSinceLastInvoke","timeWaiting","shouldInvoke","trailingEdge","cancel","debounced","isInvoking","clazzUtil","Component","componentProto","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_6_oneOf_1_0_node_modules_css_loader_index_js_ref_6_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_6_oneOf_1_2_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_Statistics_vue_vue_type_style_index_0_id_0c8f63c6_scoped_true_lang_css___WEBPACK_IMPORTED_MODULE_0__","_node_modules_mini_css_extract_plugin_dist_loader_js_ref_6_oneOf_1_0_node_modules_css_loader_index_js_ref_6_oneOf_1_1_node_modules_vue_loader_lib_loaders_stylePostLoader_js_node_modules_postcss_loader_src_index_js_ref_6_oneOf_1_2_node_modules_cache_loader_dist_cjs_js_ref_0_0_node_modules_vue_loader_lib_index_js_vue_loader_options_Statistics_vue_vue_type_style_index_0_id_0c8f63c6_scoped_true_lang_css___WEBPACK_IMPORTED_MODULE_0___default","dimensionsCount","elementList","getAxisLineShape","rExtent","getRadiusIdx","fixAngleOverlap","firstItem","lastItem","ticksAngles","labelItem","_axisLine","_axisTick","tickLen","tickAngleItem","_axisLabel","rawCategoryData","commonLabelModel","labelTextAlign","labelTextVerticalAlign","textEl","getTextColor","formattedLabel","RADIAN","prevAngle","isSymbol","NAN","reTrim","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","valueOf","isBinary","graphicUtil","format","ecHelper","parseGeoJSON","_List","_Model","_Axis","_env","parseGeoJson","ecUtil","ariaModel","seriesCnt","ariaLabel","maxDataCnt","maxSeriesCnt","displaySeriesCnt","getTitle","getConfig","seriesLabels","seriesCount","seriesLabel","seriesTpl","getSeriesTypeName","displayCnt","dataLabels","keyValues","userConfig","Animatable","animators","animatable","animateToShallow","objShallow","propertyCount","setAttrByPath","animatingShape","pathSplitted","animateFrom","Region","decode","json","UTF8Encoding","encodeScale","UTF8Scale","features","geometry","coordinates","encodeOffsets","coordinate","decodePolygon","c2","prevX","prevY","charCodeAt","featureObj","geometries","exterior","interiors","region","cp","colorAll","labelDims","vals","_subPixelOptimize","subPixelOptimizeOutputShape","QUERY_REG","_timelineOptions","_mediaList","_mediaDefault","_currentMediaIndices","_optionBackup","_newBaseOption","parseRawOption","rawOption","isNew","mediaDefault","timelineOptions","mediaList","media","singleMedia","preProcess","applyMediaQuery","ecWidth","ecHeight","realMap","aspectratio","applicatable","matched","operator","realAttr","real","expect","indicesEquals","indices1","indices2","oldOption","newCptOpt","oldCptOpt","oldOptionBackup","newParsedOption","isRecreate","optionBackup","timelineModel","getCurrentIndex","Draggable","_dragStart","_drag","_dragEnd","topTarget","draggingTarget","_draggingTarget","_x","_y","dispatchToElement","dropTarget","lastDropTarget","_dropTarget","axisTrigger","collect","pathContain","pathProxyForDraw","strokeContainThreshold","hasFillGradient","hasStrokeGradient","hasFillPattern","hasStrokePattern","_fillGradient","_strokeGradient","ctxLineDash","shapeCfg","needsUpdateRect","rectWithStroke","_rectWithStroke","lineScale","dirtyPath","__clipTarget","Sub","defaultShape","thisShape","Cartesian","getAxesByScale","axisX","axisY","clampData","xScale","yScale","xAxisExtent","yAxisExtent","originalLarge","originalProgressive","speciesConstructor","axesInfo","seriesInvolved","coordSysMap","collectAxesInfo","collectSeriesInfo","globalTooltipModel","globalAxisPointerModel","linksOption","linkGroups","coordSysKey","makeKey","axesInfoInCoordSys","coordSysModel","baseTooltipModel","saveTooltipAxisInfo","triggerAxis","cross","tooltipAxes","fromTooltip","axisPointerShow","isHandleTrigger","makeAxisPointerModel","involveSeries","axisInfo","useHandle","groupIndex","getLinkGroupIndex","linkGroup","mapper","tooltipAxisPointerModel","volatileOption","field","labelOption","tooltipAxisPointerLabelShow","crossStyle","seriesTooltipTrigger","seriesTooltipShow","seriesDataCount","linkOption","checkPropInLink","linkPropValue","axisPropValue","getAxisInfo","TOUCH_CLICK_DELAY","mouseHandlerNames","touchHandlerNames","pointerEventNames","pointerdown","pointerup","pointermove","pointerout","pointerHandlerNames","nm","eventNameFix","setTouchTimer","instance","_touching","_touchTimer","domHandlers","mousemove","mouseout","element","toElement","relatedTarget","touchstart","_lastTouchMoment","processGesture","mousedown","touchend","mouseup","isPointerFromTouch","pointerType","initDomHandler","makeMouseHandler","_handlers","HandlerDomProxy","mountHandlers","handlerNames","handlerDomProxyProto","setCursor","dimAxisMapper","_axes","_dimList","_dataCoordConvert","input","dimList","output","stackInfoMap","stackInfoList","stackInfo","stackResultDimension","stackedDimension","stackedByDimension","isStackedByIndex","calculateStack","targetStackInfo","idxInStack","resultVal","resultNaN","targetData","byValue","stackedDataRawIndex","stackedOver","eventTool","SILENT","makeEventPacket","eveType","targetInfo","gestureEvent","stopEvent","EmptyProxy","proxy","painterRoot","_hovered","_lastX","_lastY","_gestureMgr","setHandlerProxy","isHover","lastHovered","lastHoveredTarget","hovered","hoveredTarget","innerDom","dispatch","eventArgs","eventPacket","eachOtherLayer","layer","exclude","hoverCheckResult","gestureMgr","_downEl","_downPoint","_upEl","globalListener","AxisPointerView","paths","_updatePathDirty","vec2Min","vec2Max","v2Copy","isPointNull","drawSegment","segLen","allLen","smoothMin","smoothMax","drawMono","drawNonMono","prevIdx","prevP","ctrlLen","nextIdx","nextP","ratioNextSeg","lenPrevSeg","lenNextSeg","getBoundingBox","ptMin","ptMax","pt","stackedOnPoints","stackedOnSmooth","stackedOnBBox","LinkedList","linkedListProto","insert","entry","Entry","insertEntry","maxSize","_list","_maxSize","_lastRemovedEntry","LRUProto","removed","leastUsedEntry","hide","removeClipPath","cubic","quadratic","swapExtrema","windingCubic","nRoots","y0_","y1_","nExtrema","windingQuadratic","y_","windingArc","containPath","isStroke","PolarAxisModel","polarIndex","polarId","polarAxisDefaultExtendedOption","repeat","createPattern","throttleUtil","animationModel","moveAnimation","propsEqual","lastProp","lastProps","newProps","equals","updateLabelShowHide","labelEl","getHandleTransProps","trans","updateMandatoryProps","_lastGraphicKey","_handle","_dragging","_lastValue","_lastStatus","_payloadInfo","_axisModel","_axisPointerModel","_moveAnimation","determineAnimation","doUpdateProps","updatePointerEl","updateLabelEl","createPointerEl","createLabelEl","_renderHandle","isCategoryAxis","useSnap","pointerEl","handleModel","onmousemove","onmousedown","_onHandleDragMove","ondragend","_onHandleDragEnd","includeStyles","handleSize","_moveHandleToValue","_doDispatchAxisPointer","payloadInfo","doClear","buildLabel","xy","wh","xDimIndex","idStart","makeCategoryLabels","makeRealNumberLabels","makeCategoryTicks","makeCategoryLabelsActually","labelCategoryInterval","numericLabelInterval","labelsCache","getListCache","optionLabelInterval","listCacheGet","makeLabelsByCustomizedCategoryInterval","makeAutoCategoryInterval","makeLabelsByNumericCategoryInterval","listCacheSet","ticksCache","optionTickInterval","labelsResult","rawLabel","autoInterval","fetchAutoCategoryIntervalCalculationParams","axisRotate","unitW","maxW","dw","categoryInterval","onlyTick","startTick","showAllLabel","includeMinLabel","includeMaxLabel","addItem","tVal","DUMMY_COMPONENT_NAME_PREFIX","subOpts","subOptName","exists","newCptOptions","cptOption","idMap","existCpt","idNum","compressBatches","batchA","batchB","mapA","mapB","makeMap","mapToArray","sourceBatch","otherMap","dataIndices","otherDataIndices","lenj","isData","innerUniqueIndex","hostObj","has","parsedKey","queryType","includeMainTypes","queryParam","groupData","getKey","buckets","setting","_setting","_isBlank","childOfName","childCount","_doAdd","addBefore","eachChild","includeChildren","tmpMat","extremity","fromPoints","xDim","yDim","tx","ty","getNearestColorPalette","paletteNum","colorIdx","colorNameMap","scopeFields","defaultColorPalette","layeredColorPalette","colorPalette","SPECIES","textWidthCache","textWidthCacheCounter","TEXT_CACHE_MAX","STYLE_REG","measureText","getRichTextRect","getPlainTextRect","halfHeight","truncateText","containerWidth","prepareTruncateOptions","truncateSingleLine","maxIterations","minChar","cnCharWidth","ascCharWidth","ellipsisWidth","textLine","subLength","estimateLength","charCode","getLineHeight","truncOuterHeight","truncOuterWidth","matchedIndex","pushTokens","contentHeight","stlPadding","truncateWidth","truncateHeight","tokenHeight","tokenWidth","tokenWidthNotSpecified","percentWidth","bgImg","paddingW","remianTruncWidth","isEmptyStr","strs","tokensLen","renderPlanner","Chart","renderTaskPlan","renderTaskReset","toggleHighlight","incrementalRender","chartProto","elSetState","state","progressMethodMap","forceFirstProgress","modelHelper","findPointFromSeries","illegalPoint","isIllegalPoint","inputAxesInfo","shouldHide","outputFinder","showValueMap","dataByCoordSys","updaters","showPointer","showTooltip","coordSysContainsPoint","inputAxisInfo","findInputAxisInfo","processOnAxis","linkTriggers","tarAxisInfo","tarKey","srcAxisInfo","srcKey","srcValItem","makeMapperParam","updateModelActually","dispatchTooltipActually","dispatchHighDownActually","newValue","dontSnap","buildPayloadsBySeries","payloadBatch","snapToValue","seriesNestestValue","nestestValue","coordSysItem","coordSysId","coordSysIndex","coordSysType","coordSysMainType","dataByAxis","axisId","valueLabelOpt","seriesDataIndices","outputAxesInfo","valItem","highDownKey","lastHighlights","newHighlights","toHighlight","toDownplay","coordExtent","_parseSVG","rawGeoJson","rawSpecialAreas","parsers","svgXML","HOVER_LAYER_ZLEVEL","CANVAS_ZLEVEL","EL_AFTER_INCREMENTAL_INC","INCREMENTAL_INC","parseInt10","isLayerValid","__builtin__","viewRect","isDisplayableCulled","isClipPathChanged","prevClipPaths","doClip","createRoot","domRoot","singleCanvas","_opts","_singleCanvas","rootStyle","innerHTML","zlevelList","_zlevelList","layers","_layers","_layerConfig","_needsManuallyCompositing","_width","_height","mainLayer","_domRoot","_getSize","_hoverlayer","_hoverElements","isSingleCanvas","getViewportRootOffset","viewportRoot","offsetLeft","offsetTop","paintAll","_redrawId","_paintList","_backgroundColor","__hoverMir","__from","hoverElements","hoverLayer","getLayer","originalEl","_doPaintEl","getHoverLayer","redrawId","_updateLayerStatus","finished","_doPaintList","_compositeManually","eachBuiltinLayer","virtual","layerList","zi","useTimer","firstEl","dTime","prevElClipPaths","draw","currentLayer","forcePaint","insertLayer","layersMap","prevLayer","prevDom","insertBefore","eachLayer","getLayers","updatePrevLayer","incrementalLayerCount","_clearLayer","layerConfig","_zlevel","delLayer","_progressiveLayers","clearLayer","imageLayer","renderToCanvas","whIdx","cwh","plt","prb","stl","defaultView","shadowBlurSize","leftMargin","rightMargin","topMargin","bottomMargin","pathTransform","ImageShape","imgShape","toCamelCase","upperCaseFirst","group1","replaceReg","replaceMap","&","<",">","\"","'","TPL_VAR_ALIAS","wrapVar","varName","seriesIdx","paramsList","seriesLen","alias","formatTplSimple","extraCssText","pad","isUTC","utc","getTextBoundingRect","stackedByDimInfo","stackedDimInfo","byIndex","stackedCoordDimension","mayStack","stackedDimCoordDim","stackedDimType","stackedDimCoordIndex","isCalculationCoord","stackedDim","targetDim","mathAtan2","nPoint","visualSymbol","layoutPoints","dataSample","_helper","diffData","oldData","diffResult","newIdx","oldIdx","idx1","oldStackedOnPoints","newStackedOnPoints","oldCoordSys","newCoordSys","oldValueOrigin","newValueOrigin","currPoints","nextPoints","currStackedPoints","nextStackedPoints","sortedIndices","rawIndices","newDataOldCoordInfo","oldDataNewCoordInfo","diffItem","pointAdded","currentPt","nextPt","sortedCurrPoints","sortedNextPoints","sortedCurrStackedPoints","sortedNextStackedPoints","sortedStatus","stackedOnCurrent","stackedOnNext","SymbolDraw","lineAnimationDiff","_poly","isPointsSame","points1","points2","getSmooth","getAxisExtentWithGap","halfBandWidth","getStackedOnPoints","createGridClipShape","hasAnimation","forSymbol","xExtent","yExtent","createPolarClipShape","createClipShape","turnPointsIntoStep","stepTurnAt","baseIndex","stepPoints","stepPt","stepPt2","getVisualGradient","visualMetaList","visualMeta","stops","stopLen","outerColors","tinyExtent","minCoord","maxCoord","coordSpan","getIsIgnoreFunc","isAuto","canShowAllSymbolForCategory","categoryDataDim","labelMap","availSize","lineGroup","symbolDraw","_symbolDraw","_lineGroup","isCoordSysPolar","prevCoordSys","_coordSys","_polyline","_polygon","isAreaChart","isIgnoreFunc","__temp","_step","_newPolygon","isIgnore","clipShape","_stackedOnPoints","_points","_updateAnimation","_newPolyline","visualColor","lineJoin","stackedOnSeries","_valueOrigin","__points","updatedDataInfo","diffStatus","ptIdx","contrastColor","axisCommon","iconStyle","visualMap","controlStyle","color0","borderColor0","CartesianAxisView","oldAxisGroup","_axisGroup","_splitAreaColors","tickCoord","areaColorsLen","lastSplitAreaColors","newSplitAreaColors","cIndex","polygonContain","loopGeo","transformTo","newRegion","define","Task","_reset","_plan","_onDirty","_dirty","taskProto","planResult","upTask","_upstream","lastModBy","normalizeModBy","_modBy","lastModDataCount","_modDataCount","_dueEnd","_outputDueEnd","_progress","_dueIndex","doProgress","outputDueEnd","_settedOutputEnd","iterator","winCount","sStep","sCount","modNext","sequentialNext","taskIns","_callingProgress","downstream","_downstream","downTask","symbolCtor","_symbolCtor","symbolDrawProto","symbolNeedsDraw","normalizeUpdateOpt","makeSeriesScope","SymbolCtor","symbolEl","isPersistent","incrementalPrepareUpdate","_seriesScope","incrementalUpdate","taskParams","updateIncrementalAndHover","enableAnimation","LOCATION_PARAMS","HV_NAMES","boxLayout","orient","maxHeight","currentLineMaxSize","nextX","nextY","nextChild","nextChildRect","moveX","newline","moveY","vbox","hbox","getAvailableSize","positionInfo","containerRect","containerHeight","verticalMargin","horizontalMargin","positionElement","hv","boundingMode","elPos","sizeCalculable","hvIdx","targetOption","ignoreSize","hResult","vResult","newParams","newValueCount","merged","mergedValueCount","enoughParamNumber","hasProp","copyLayoutParams","matrixUtil","makeAxisEventDataBase","dumbGroup","_transform","_dumbGroup","hasBuilder","builders","pt1","pt2","arrows","arrowSize","arrowOffset","symbolWidth","symbolHeight","axisTickLabel","tickEls","buildAxisTick","labelEls","buildAxisLabel","fixMinMaxLabelShow","axisNameAvailableWidth","gapSignal","isNameLocationCenter","nameRotation","endTextLayout","truncateOpt","nameTruncateMaxWidth","truncatedText","tooltipOpt","formatterParams","__fullText","__truncatedText","targetType","axisRotation","rotationDiff","textRotate","onLeft","firstLabel","nextLabel","lastLabel","prevLabel","firstTick","nextTick","lastTick","prevTick","ignoreEl","isTwoLabelOverlapped","firstRect","nextRect","mRotationBack","tickEl","axisLabelShow","itemLabelModel","compatStyle","compatLayoutProperties","LAYOUT_PROPERTIES","COMPATITABLE_COMPONENTS","clockWise","pointerColor","dataRange","componentName","_radiusAxis","_angleAxis","pointToCoord","minAngle","maxAngle","colorAccessPath","samplers","average","nearest","indexSampler","sampler","PATH_COLOR","styleModel","getValueLabel","paddings","confineInContainer","bgColor","viewWidth","viewHeight","seriesData","idxItem","dataParams","textLayout","symbolTag"],"mappings":"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","file":"h5/js/chunk-03addcd9.64fd1552.js","sourcesContent":["var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Can only be called after coordinate system creation stage.\n * (Can be called before coordinate system update stage).\n *\n * @param {Object} opt {labelInside}\n * @return {Object} {\n * position, rotation, labelDirection, labelOffset,\n * tickDirection, labelRotate, z2\n * }\n */\nfunction layout(gridModel, axisModel, opt) {\n opt = opt || {};\n var grid = gridModel.coordinateSystem;\n var axis = axisModel.axis;\n var layout = {};\n var otherAxisOnZeroOf = axis.getAxesOnZeroOf()[0];\n var rawAxisPosition = axis.position;\n var axisPosition = otherAxisOnZeroOf ? 'onZero' : rawAxisPosition;\n var axisDim = axis.dim;\n var rect = grid.getRect();\n var rectBound = [rect.x, rect.x + rect.width, rect.y, rect.y + rect.height];\n var idx = {\n left: 0,\n right: 1,\n top: 0,\n bottom: 1,\n onZero: 2\n };\n var axisOffset = axisModel.get('offset') || 0;\n var posBound = axisDim === 'x' ? [rectBound[2] - axisOffset, rectBound[3] + axisOffset] : [rectBound[0] - axisOffset, rectBound[1] + axisOffset];\n\n if (otherAxisOnZeroOf) {\n var onZeroCoord = otherAxisOnZeroOf.toGlobalCoord(otherAxisOnZeroOf.dataToCoord(0));\n posBound[idx.onZero] = Math.max(Math.min(onZeroCoord, posBound[1]), posBound[0]);\n } // Axis position\n\n\n layout.position = [axisDim === 'y' ? posBound[idx[axisPosition]] : rectBound[0], axisDim === 'x' ? posBound[idx[axisPosition]] : rectBound[3]]; // Axis rotation\n\n layout.rotation = Math.PI / 2 * (axisDim === 'x' ? 0 : 1); // Tick and label direction, x y is axisDim\n\n var dirMap = {\n top: -1,\n bottom: 1,\n left: -1,\n right: 1\n };\n layout.labelDirection = layout.tickDirection = layout.nameDirection = dirMap[rawAxisPosition];\n layout.labelOffset = otherAxisOnZeroOf ? posBound[idx[rawAxisPosition]] - posBound[idx.onZero] : 0;\n\n if (axisModel.get('axisTick.inside')) {\n layout.tickDirection = -layout.tickDirection;\n }\n\n if (zrUtil.retrieve(opt.labelInside, axisModel.get('axisLabel.inside'))) {\n layout.labelDirection = -layout.labelDirection;\n } // Special label rotation\n\n\n var labelRotate = axisModel.get('axisLabel.rotate');\n layout.labelRotate = axisPosition === 'top' ? -labelRotate : labelRotate; // Over splitLine and splitArea\n\n layout.z2 = 1;\n return layout;\n}\n\nexports.layout = layout;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar echarts = require(\"../echarts\");\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar graphic = require(\"../util/graphic\");\n\nrequire(\"../coord/cartesian/Grid\");\n\nrequire(\"./axis\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// Grid view\necharts.extendComponentView({\n type: 'grid',\n render: function (gridModel, ecModel) {\n this.group.removeAll();\n\n if (gridModel.get('show')) {\n this.group.add(new graphic.Rect({\n shape: gridModel.coordinateSystem.getRect(),\n style: zrUtil.defaults({\n fill: gridModel.get('backgroundColor')\n }, gridModel.getItemStyle()),\n silent: true,\n z2: -1\n }));\n }\n }\n});\necharts.registerPreprocessor(function (option) {\n // Only create grid when need\n if (option.xAxis && option.yAxis && !option.grid) {\n option.grid = {};\n }\n});","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar ComponentModel = require(\"../model/Component\");\n\nvar ComponentView = require(\"../view/Component\");\n\nvar _sourceHelper = require(\"../data/helper/sourceHelper\");\n\nvar detectSourceFormat = _sourceHelper.detectSourceFormat;\n\nvar _sourceType = require(\"../data/helper/sourceType\");\n\nvar SERIES_LAYOUT_BY_COLUMN = _sourceType.SERIES_LAYOUT_BY_COLUMN;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * This module is imported by echarts directly.\n *\n * Notice:\n * Always keep this file exists for backward compatibility.\n * Because before 4.1.0, dataset is an optional component,\n * some users may import this module manually.\n */\nComponentModel.extend({\n type: 'dataset',\n\n /**\n * @protected\n */\n defaultOption: {\n // 'row', 'column'\n seriesLayoutBy: SERIES_LAYOUT_BY_COLUMN,\n // null/'auto': auto detect header, see \"module:echarts/data/helper/sourceHelper\"\n sourceHeader: null,\n dimensions: null,\n source: null\n },\n optionUpdated: function () {\n detectSourceFormat(this);\n }\n});\nComponentView.extend({\n type: 'dataset'\n});","// https://github.com/mziccard/node-timsort\nvar DEFAULT_MIN_MERGE = 32;\nvar DEFAULT_MIN_GALLOPING = 7;\nvar DEFAULT_TMP_STORAGE_LENGTH = 256;\n\nfunction minRunLength(n) {\n var r = 0;\n\n while (n >= DEFAULT_MIN_MERGE) {\n r |= n & 1;\n n >>= 1;\n }\n\n return n + r;\n}\n\nfunction makeAscendingRun(array, lo, hi, compare) {\n var runHi = lo + 1;\n\n if (runHi === hi) {\n return 1;\n }\n\n if (compare(array[runHi++], array[lo]) < 0) {\n while (runHi < hi && compare(array[runHi], array[runHi - 1]) < 0) {\n runHi++;\n }\n\n reverseRun(array, lo, runHi);\n } else {\n while (runHi < hi && compare(array[runHi], array[runHi - 1]) >= 0) {\n runHi++;\n }\n }\n\n return runHi - lo;\n}\n\nfunction reverseRun(array, lo, hi) {\n hi--;\n\n while (lo < hi) {\n var t = array[lo];\n array[lo++] = array[hi];\n array[hi--] = t;\n }\n}\n\nfunction binaryInsertionSort(array, lo, hi, start, compare) {\n if (start === lo) {\n start++;\n }\n\n for (; start < hi; start++) {\n var pivot = array[start];\n var left = lo;\n var right = start;\n var mid;\n\n while (left < right) {\n mid = left + right >>> 1;\n\n if (compare(pivot, array[mid]) < 0) {\n right = mid;\n } else {\n left = mid + 1;\n }\n }\n\n var n = start - left;\n\n switch (n) {\n case 3:\n array[left + 3] = array[left + 2];\n\n case 2:\n array[left + 2] = array[left + 1];\n\n case 1:\n array[left + 1] = array[left];\n break;\n\n default:\n while (n > 0) {\n array[left + n] = array[left + n - 1];\n n--;\n }\n\n }\n\n array[left] = pivot;\n }\n}\n\nfunction gallopLeft(value, array, start, length, hint, compare) {\n var lastOffset = 0;\n var maxOffset = 0;\n var offset = 1;\n\n if (compare(value, array[start + hint]) > 0) {\n maxOffset = length - hint;\n\n while (offset < maxOffset && compare(value, array[start + hint + offset]) > 0) {\n lastOffset = offset;\n offset = (offset << 1) + 1;\n\n if (offset <= 0) {\n offset = maxOffset;\n }\n }\n\n if (offset > maxOffset) {\n offset = maxOffset;\n }\n\n lastOffset += hint;\n offset += hint;\n } else {\n maxOffset = hint + 1;\n\n while (offset < maxOffset && compare(value, array[start + hint - offset]) <= 0) {\n lastOffset = offset;\n offset = (offset << 1) + 1;\n\n if (offset <= 0) {\n offset = maxOffset;\n }\n }\n\n if (offset > maxOffset) {\n offset = maxOffset;\n }\n\n var tmp = lastOffset;\n lastOffset = hint - offset;\n offset = hint - tmp;\n }\n\n lastOffset++;\n\n while (lastOffset < offset) {\n var m = lastOffset + (offset - lastOffset >>> 1);\n\n if (compare(value, array[start + m]) > 0) {\n lastOffset = m + 1;\n } else {\n offset = m;\n }\n }\n\n return offset;\n}\n\nfunction gallopRight(value, array, start, length, hint, compare) {\n var lastOffset = 0;\n var maxOffset = 0;\n var offset = 1;\n\n if (compare(value, array[start + hint]) < 0) {\n maxOffset = hint + 1;\n\n while (offset < maxOffset && compare(value, array[start + hint - offset]) < 0) {\n lastOffset = offset;\n offset = (offset << 1) + 1;\n\n if (offset <= 0) {\n offset = maxOffset;\n }\n }\n\n if (offset > maxOffset) {\n offset = maxOffset;\n }\n\n var tmp = lastOffset;\n lastOffset = hint - offset;\n offset = hint - tmp;\n } else {\n maxOffset = length - hint;\n\n while (offset < maxOffset && compare(value, array[start + hint + offset]) >= 0) {\n lastOffset = offset;\n offset = (offset << 1) + 1;\n\n if (offset <= 0) {\n offset = maxOffset;\n }\n }\n\n if (offset > maxOffset) {\n offset = maxOffset;\n }\n\n lastOffset += hint;\n offset += hint;\n }\n\n lastOffset++;\n\n while (lastOffset < offset) {\n var m = lastOffset + (offset - lastOffset >>> 1);\n\n if (compare(value, array[start + m]) < 0) {\n offset = m;\n } else {\n lastOffset = m + 1;\n }\n }\n\n return offset;\n}\n\nfunction TimSort(array, compare) {\n var minGallop = DEFAULT_MIN_GALLOPING;\n var length = 0;\n var tmpStorageLength = DEFAULT_TMP_STORAGE_LENGTH;\n var stackLength = 0;\n var runStart;\n var runLength;\n var stackSize = 0;\n length = array.length;\n\n if (length < 2 * DEFAULT_TMP_STORAGE_LENGTH) {\n tmpStorageLength = length >>> 1;\n }\n\n var tmp = [];\n stackLength = length < 120 ? 5 : length < 1542 ? 10 : length < 119151 ? 19 : 40;\n runStart = [];\n runLength = [];\n\n function pushRun(_runStart, _runLength) {\n runStart[stackSize] = _runStart;\n runLength[stackSize] = _runLength;\n stackSize += 1;\n }\n\n function mergeRuns() {\n while (stackSize > 1) {\n var n = stackSize - 2;\n\n if (n >= 1 && runLength[n - 1] <= runLength[n] + runLength[n + 1] || n >= 2 && runLength[n - 2] <= runLength[n] + runLength[n - 1]) {\n if (runLength[n - 1] < runLength[n + 1]) {\n n--;\n }\n } else if (runLength[n] > runLength[n + 1]) {\n break;\n }\n\n mergeAt(n);\n }\n }\n\n function forceMergeRuns() {\n while (stackSize > 1) {\n var n = stackSize - 2;\n\n if (n > 0 && runLength[n - 1] < runLength[n + 1]) {\n n--;\n }\n\n mergeAt(n);\n }\n }\n\n function mergeAt(i) {\n var start1 = runStart[i];\n var length1 = runLength[i];\n var start2 = runStart[i + 1];\n var length2 = runLength[i + 1];\n runLength[i] = length1 + length2;\n\n if (i === stackSize - 3) {\n runStart[i + 1] = runStart[i + 2];\n runLength[i + 1] = runLength[i + 2];\n }\n\n stackSize--;\n var k = gallopRight(array[start2], array, start1, length1, 0, compare);\n start1 += k;\n length1 -= k;\n\n if (length1 === 0) {\n return;\n }\n\n length2 = gallopLeft(array[start1 + length1 - 1], array, start2, length2, length2 - 1, compare);\n\n if (length2 === 0) {\n return;\n }\n\n if (length1 <= length2) {\n mergeLow(start1, length1, start2, length2);\n } else {\n mergeHigh(start1, length1, start2, length2);\n }\n }\n\n function mergeLow(start1, length1, start2, length2) {\n var i = 0;\n\n for (i = 0; i < length1; i++) {\n tmp[i] = array[start1 + i];\n }\n\n var cursor1 = 0;\n var cursor2 = start2;\n var dest = start1;\n array[dest++] = array[cursor2++];\n\n if (--length2 === 0) {\n for (i = 0; i < length1; i++) {\n array[dest + i] = tmp[cursor1 + i];\n }\n\n return;\n }\n\n if (length1 === 1) {\n for (i = 0; i < length2; i++) {\n array[dest + i] = array[cursor2 + i];\n }\n\n array[dest + length2] = tmp[cursor1];\n return;\n }\n\n var _minGallop = minGallop;\n var count1, count2, exit;\n\n while (1) {\n count1 = 0;\n count2 = 0;\n exit = false;\n\n do {\n if (compare(array[cursor2], tmp[cursor1]) < 0) {\n array[dest++] = array[cursor2++];\n count2++;\n count1 = 0;\n\n if (--length2 === 0) {\n exit = true;\n break;\n }\n } else {\n array[dest++] = tmp[cursor1++];\n count1++;\n count2 = 0;\n\n if (--length1 === 1) {\n exit = true;\n break;\n }\n }\n } while ((count1 | count2) < _minGallop);\n\n if (exit) {\n break;\n }\n\n do {\n count1 = gallopRight(array[cursor2], tmp, cursor1, length1, 0, compare);\n\n if (count1 !== 0) {\n for (i = 0; i < count1; i++) {\n array[dest + i] = tmp[cursor1 + i];\n }\n\n dest += count1;\n cursor1 += count1;\n length1 -= count1;\n\n if (length1 <= 1) {\n exit = true;\n break;\n }\n }\n\n array[dest++] = array[cursor2++];\n\n if (--length2 === 0) {\n exit = true;\n break;\n }\n\n count2 = gallopLeft(tmp[cursor1], array, cursor2, length2, 0, compare);\n\n if (count2 !== 0) {\n for (i = 0; i < count2; i++) {\n array[dest + i] = array[cursor2 + i];\n }\n\n dest += count2;\n cursor2 += count2;\n length2 -= count2;\n\n if (length2 === 0) {\n exit = true;\n break;\n }\n }\n\n array[dest++] = tmp[cursor1++];\n\n if (--length1 === 1) {\n exit = true;\n break;\n }\n\n _minGallop--;\n } while (count1 >= DEFAULT_MIN_GALLOPING || count2 >= DEFAULT_MIN_GALLOPING);\n\n if (exit) {\n break;\n }\n\n if (_minGallop < 0) {\n _minGallop = 0;\n }\n\n _minGallop += 2;\n }\n\n minGallop = _minGallop;\n minGallop < 1 && (minGallop = 1);\n\n if (length1 === 1) {\n for (i = 0; i < length2; i++) {\n array[dest + i] = array[cursor2 + i];\n }\n\n array[dest + length2] = tmp[cursor1];\n } else if (length1 === 0) {\n throw new Error(); // throw new Error('mergeLow preconditions were not respected');\n } else {\n for (i = 0; i < length1; i++) {\n array[dest + i] = tmp[cursor1 + i];\n }\n }\n }\n\n function mergeHigh(start1, length1, start2, length2) {\n var i = 0;\n\n for (i = 0; i < length2; i++) {\n tmp[i] = array[start2 + i];\n }\n\n var cursor1 = start1 + length1 - 1;\n var cursor2 = length2 - 1;\n var dest = start2 + length2 - 1;\n var customCursor = 0;\n var customDest = 0;\n array[dest--] = array[cursor1--];\n\n if (--length1 === 0) {\n customCursor = dest - (length2 - 1);\n\n for (i = 0; i < length2; i++) {\n array[customCursor + i] = tmp[i];\n }\n\n return;\n }\n\n if (length2 === 1) {\n dest -= length1;\n cursor1 -= length1;\n customDest = dest + 1;\n customCursor = cursor1 + 1;\n\n for (i = length1 - 1; i >= 0; i--) {\n array[customDest + i] = array[customCursor + i];\n }\n\n array[dest] = tmp[cursor2];\n return;\n }\n\n var _minGallop = minGallop;\n\n while (true) {\n var count1 = 0;\n var count2 = 0;\n var exit = false;\n\n do {\n if (compare(tmp[cursor2], array[cursor1]) < 0) {\n array[dest--] = array[cursor1--];\n count1++;\n count2 = 0;\n\n if (--length1 === 0) {\n exit = true;\n break;\n }\n } else {\n array[dest--] = tmp[cursor2--];\n count2++;\n count1 = 0;\n\n if (--length2 === 1) {\n exit = true;\n break;\n }\n }\n } while ((count1 | count2) < _minGallop);\n\n if (exit) {\n break;\n }\n\n do {\n count1 = length1 - gallopRight(tmp[cursor2], array, start1, length1, length1 - 1, compare);\n\n if (count1 !== 0) {\n dest -= count1;\n cursor1 -= count1;\n length1 -= count1;\n customDest = dest + 1;\n customCursor = cursor1 + 1;\n\n for (i = count1 - 1; i >= 0; i--) {\n array[customDest + i] = array[customCursor + i];\n }\n\n if (length1 === 0) {\n exit = true;\n break;\n }\n }\n\n array[dest--] = tmp[cursor2--];\n\n if (--length2 === 1) {\n exit = true;\n break;\n }\n\n count2 = length2 - gallopLeft(array[cursor1], tmp, 0, length2, length2 - 1, compare);\n\n if (count2 !== 0) {\n dest -= count2;\n cursor2 -= count2;\n length2 -= count2;\n customDest = dest + 1;\n customCursor = cursor2 + 1;\n\n for (i = 0; i < count2; i++) {\n array[customDest + i] = tmp[customCursor + i];\n }\n\n if (length2 <= 1) {\n exit = true;\n break;\n }\n }\n\n array[dest--] = array[cursor1--];\n\n if (--length1 === 0) {\n exit = true;\n break;\n }\n\n _minGallop--;\n } while (count1 >= DEFAULT_MIN_GALLOPING || count2 >= DEFAULT_MIN_GALLOPING);\n\n if (exit) {\n break;\n }\n\n if (_minGallop < 0) {\n _minGallop = 0;\n }\n\n _minGallop += 2;\n }\n\n minGallop = _minGallop;\n\n if (minGallop < 1) {\n minGallop = 1;\n }\n\n if (length2 === 1) {\n dest -= length1;\n cursor1 -= length1;\n customDest = dest + 1;\n customCursor = cursor1 + 1;\n\n for (i = length1 - 1; i >= 0; i--) {\n array[customDest + i] = array[customCursor + i];\n }\n\n array[dest] = tmp[cursor2];\n } else if (length2 === 0) {\n throw new Error(); // throw new Error('mergeHigh preconditions were not respected');\n } else {\n customCursor = dest - (length2 - 1);\n\n for (i = 0; i < length2; i++) {\n array[customCursor + i] = tmp[i];\n }\n }\n }\n\n this.mergeRuns = mergeRuns;\n this.forceMergeRuns = forceMergeRuns;\n this.pushRun = pushRun;\n}\n\nfunction sort(array, compare, lo, hi) {\n if (!lo) {\n lo = 0;\n }\n\n if (!hi) {\n hi = array.length;\n }\n\n var remaining = hi - lo;\n\n if (remaining < 2) {\n return;\n }\n\n var runLength = 0;\n\n if (remaining < DEFAULT_MIN_MERGE) {\n runLength = makeAscendingRun(array, lo, hi, compare);\n binaryInsertionSort(array, lo, hi, lo + runLength, compare);\n return;\n }\n\n var ts = new TimSort(array, compare);\n var minRun = minRunLength(remaining);\n\n do {\n runLength = makeAscendingRun(array, lo, hi, compare);\n\n if (runLength < minRun) {\n var force = remaining;\n\n if (force > minRun) {\n force = minRun;\n }\n\n binaryInsertionSort(array, lo, lo + force, lo + runLength, compare);\n runLength = force;\n }\n\n ts.pushRun(lo, runLength);\n ts.mergeRuns();\n remaining -= runLength;\n lo += runLength;\n } while (remaining !== 0);\n\n ts.forceMergeRuns();\n}\n\nmodule.exports = sort;","var windingLine = require(\"./windingLine\");\n\nvar EPSILON = 1e-8;\n\nfunction isAroundEqual(a, b) {\n return Math.abs(a - b) < EPSILON;\n}\n\nfunction contain(points, x, y) {\n var w = 0;\n var p = points[0];\n\n if (!p) {\n return false;\n }\n\n for (var i = 1; i < points.length; i++) {\n var p2 = points[i];\n w += windingLine(p[0], p[1], p2[0], p2[1], x, y);\n p = p2;\n } // Close polygon\n\n\n var p0 = points[0];\n\n if (!isAroundEqual(p[0], p0[0]) || !isAroundEqual(p[1], p0[1])) {\n w += windingLine(p[0], p[1], p0[0], p0[1], x, y);\n }\n\n return w !== 0;\n}\n\nexports.contain = contain;","var Clip = require(\"./Clip\");\n\nvar color = require(\"../tool/color\");\n\nvar _util = require(\"../core/util\");\n\nvar isArrayLike = _util.isArrayLike;\n\n/**\n * @module echarts/animation/Animator\n */\nvar arraySlice = Array.prototype.slice;\n\nfunction defaultGetter(target, key) {\n return target[key];\n}\n\nfunction defaultSetter(target, key, value) {\n target[key] = value;\n}\n/**\n * @param {number} p0\n * @param {number} p1\n * @param {number} percent\n * @return {number}\n */\n\n\nfunction interpolateNumber(p0, p1, percent) {\n return (p1 - p0) * percent + p0;\n}\n/**\n * @param {string} p0\n * @param {string} p1\n * @param {number} percent\n * @return {string}\n */\n\n\nfunction interpolateString(p0, p1, percent) {\n return percent > 0.5 ? p1 : p0;\n}\n/**\n * @param {Array} p0\n * @param {Array} p1\n * @param {number} percent\n * @param {Array} out\n * @param {number} arrDim\n */\n\n\nfunction interpolateArray(p0, p1, percent, out, arrDim) {\n var len = p0.length;\n\n if (arrDim === 1) {\n for (var i = 0; i < len; i++) {\n out[i] = interpolateNumber(p0[i], p1[i], percent);\n }\n } else {\n var len2 = len && p0[0].length;\n\n for (var i = 0; i < len; i++) {\n for (var j = 0; j < len2; j++) {\n out[i][j] = interpolateNumber(p0[i][j], p1[i][j], percent);\n }\n }\n }\n} // arr0 is source array, arr1 is target array.\n// Do some preprocess to avoid error happened when interpolating from arr0 to arr1\n\n\nfunction fillArr(arr0, arr1, arrDim) {\n var arr0Len = arr0.length;\n var arr1Len = arr1.length;\n\n if (arr0Len !== arr1Len) {\n // FIXME Not work for TypedArray\n var isPreviousLarger = arr0Len > arr1Len;\n\n if (isPreviousLarger) {\n // Cut the previous\n arr0.length = arr1Len;\n } else {\n // Fill the previous\n for (var i = arr0Len; i < arr1Len; i++) {\n arr0.push(arrDim === 1 ? arr1[i] : arraySlice.call(arr1[i]));\n }\n }\n } // Handling NaN value\n\n\n var len2 = arr0[0] && arr0[0].length;\n\n for (var i = 0; i < arr0.length; i++) {\n if (arrDim === 1) {\n if (isNaN(arr0[i])) {\n arr0[i] = arr1[i];\n }\n } else {\n for (var j = 0; j < len2; j++) {\n if (isNaN(arr0[i][j])) {\n arr0[i][j] = arr1[i][j];\n }\n }\n }\n }\n}\n/**\n * @param {Array} arr0\n * @param {Array} arr1\n * @param {number} arrDim\n * @return {boolean}\n */\n\n\nfunction isArraySame(arr0, arr1, arrDim) {\n if (arr0 === arr1) {\n return true;\n }\n\n var len = arr0.length;\n\n if (len !== arr1.length) {\n return false;\n }\n\n if (arrDim === 1) {\n for (var i = 0; i < len; i++) {\n if (arr0[i] !== arr1[i]) {\n return false;\n }\n }\n } else {\n var len2 = arr0[0].length;\n\n for (var i = 0; i < len; i++) {\n for (var j = 0; j < len2; j++) {\n if (arr0[i][j] !== arr1[i][j]) {\n return false;\n }\n }\n }\n }\n\n return true;\n}\n/**\n * Catmull Rom interpolate array\n * @param {Array} p0\n * @param {Array} p1\n * @param {Array} p2\n * @param {Array} p3\n * @param {number} t\n * @param {number} t2\n * @param {number} t3\n * @param {Array} out\n * @param {number} arrDim\n */\n\n\nfunction catmullRomInterpolateArray(p0, p1, p2, p3, t, t2, t3, out, arrDim) {\n var len = p0.length;\n\n if (arrDim === 1) {\n for (var i = 0; i < len; i++) {\n out[i] = catmullRomInterpolate(p0[i], p1[i], p2[i], p3[i], t, t2, t3);\n }\n } else {\n var len2 = p0[0].length;\n\n for (var i = 0; i < len; i++) {\n for (var j = 0; j < len2; j++) {\n out[i][j] = catmullRomInterpolate(p0[i][j], p1[i][j], p2[i][j], p3[i][j], t, t2, t3);\n }\n }\n }\n}\n/**\n * Catmull Rom interpolate number\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} p3\n * @param {number} t\n * @param {number} t2\n * @param {number} t3\n * @return {number}\n */\n\n\nfunction catmullRomInterpolate(p0, p1, p2, p3, t, t2, t3) {\n var v0 = (p2 - p0) * 0.5;\n var v1 = (p3 - p1) * 0.5;\n return (2 * (p1 - p2) + v0 + v1) * t3 + (-3 * (p1 - p2) - 2 * v0 - v1) * t2 + v0 * t + p1;\n}\n\nfunction cloneValue(value) {\n if (isArrayLike(value)) {\n var len = value.length;\n\n if (isArrayLike(value[0])) {\n var ret = [];\n\n for (var i = 0; i < len; i++) {\n ret.push(arraySlice.call(value[i]));\n }\n\n return ret;\n }\n\n return arraySlice.call(value);\n }\n\n return value;\n}\n\nfunction rgba2String(rgba) {\n rgba[0] = Math.floor(rgba[0]);\n rgba[1] = Math.floor(rgba[1]);\n rgba[2] = Math.floor(rgba[2]);\n return 'rgba(' + rgba.join(',') + ')';\n}\n\nfunction getArrayDim(keyframes) {\n var lastValue = keyframes[keyframes.length - 1].value;\n return isArrayLike(lastValue && lastValue[0]) ? 2 : 1;\n}\n\nfunction createTrackClip(animator, easing, oneTrackDone, keyframes, propName, forceAnimate) {\n var getter = animator._getter;\n var setter = animator._setter;\n var useSpline = easing === 'spline';\n var trackLen = keyframes.length;\n\n if (!trackLen) {\n return;\n } // Guess data type\n\n\n var firstVal = keyframes[0].value;\n var isValueArray = isArrayLike(firstVal);\n var isValueColor = false;\n var isValueString = false; // For vertices morphing\n\n var arrDim = isValueArray ? getArrayDim(keyframes) : 0;\n var trackMaxTime; // Sort keyframe as ascending\n\n keyframes.sort(function (a, b) {\n return a.time - b.time;\n });\n trackMaxTime = keyframes[trackLen - 1].time; // Percents of each keyframe\n\n var kfPercents = []; // Value of each keyframe\n\n var kfValues = [];\n var prevValue = keyframes[0].value;\n var isAllValueEqual = true;\n\n for (var i = 0; i < trackLen; i++) {\n kfPercents.push(keyframes[i].time / trackMaxTime); // Assume value is a color when it is a string\n\n var value = keyframes[i].value; // Check if value is equal, deep check if value is array\n\n if (!(isValueArray && isArraySame(value, prevValue, arrDim) || !isValueArray && value === prevValue)) {\n isAllValueEqual = false;\n }\n\n prevValue = value; // Try converting a string to a color array\n\n if (typeof value === 'string') {\n var colorArray = color.parse(value);\n\n if (colorArray) {\n value = colorArray;\n isValueColor = true;\n } else {\n isValueString = true;\n }\n }\n\n kfValues.push(value);\n }\n\n if (!forceAnimate && isAllValueEqual) {\n return;\n }\n\n var lastValue = kfValues[trackLen - 1]; // Polyfill array and NaN value\n\n for (var i = 0; i < trackLen - 1; i++) {\n if (isValueArray) {\n fillArr(kfValues[i], lastValue, arrDim);\n } else {\n if (isNaN(kfValues[i]) && !isNaN(lastValue) && !isValueString && !isValueColor) {\n kfValues[i] = lastValue;\n }\n }\n }\n\n isValueArray && fillArr(getter(animator._target, propName), lastValue, arrDim); // Cache the key of last frame to speed up when\n // animation playback is sequency\n\n var lastFrame = 0;\n var lastFramePercent = 0;\n var start;\n var w;\n var p0;\n var p1;\n var p2;\n var p3;\n\n if (isValueColor) {\n var rgba = [0, 0, 0, 0];\n }\n\n var onframe = function (target, percent) {\n // Find the range keyframes\n // kf1-----kf2---------current--------kf3\n // find kf2 and kf3 and do interpolation\n var frame; // In the easing function like elasticOut, percent may less than 0\n\n if (percent < 0) {\n frame = 0;\n } else if (percent < lastFramePercent) {\n // Start from next key\n // PENDING start from lastFrame ?\n start = Math.min(lastFrame + 1, trackLen - 1);\n\n for (frame = start; frame >= 0; frame--) {\n if (kfPercents[frame] <= percent) {\n break;\n }\n } // PENDING really need to do this ?\n\n\n frame = Math.min(frame, trackLen - 2);\n } else {\n for (frame = lastFrame; frame < trackLen; frame++) {\n if (kfPercents[frame] > percent) {\n break;\n }\n }\n\n frame = Math.min(frame - 1, trackLen - 2);\n }\n\n lastFrame = frame;\n lastFramePercent = percent;\n var range = kfPercents[frame + 1] - kfPercents[frame];\n\n if (range === 0) {\n return;\n } else {\n w = (percent - kfPercents[frame]) / range;\n }\n\n if (useSpline) {\n p1 = kfValues[frame];\n p0 = kfValues[frame === 0 ? frame : frame - 1];\n p2 = kfValues[frame > trackLen - 2 ? trackLen - 1 : frame + 1];\n p3 = kfValues[frame > trackLen - 3 ? trackLen - 1 : frame + 2];\n\n if (isValueArray) {\n catmullRomInterpolateArray(p0, p1, p2, p3, w, w * w, w * w * w, getter(target, propName), arrDim);\n } else {\n var value;\n\n if (isValueColor) {\n value = catmullRomInterpolateArray(p0, p1, p2, p3, w, w * w, w * w * w, rgba, 1);\n value = rgba2String(rgba);\n } else if (isValueString) {\n // String is step(0.5)\n return interpolateString(p1, p2, w);\n } else {\n value = catmullRomInterpolate(p0, p1, p2, p3, w, w * w, w * w * w);\n }\n\n setter(target, propName, value);\n }\n } else {\n if (isValueArray) {\n interpolateArray(kfValues[frame], kfValues[frame + 1], w, getter(target, propName), arrDim);\n } else {\n var value;\n\n if (isValueColor) {\n interpolateArray(kfValues[frame], kfValues[frame + 1], w, rgba, 1);\n value = rgba2String(rgba);\n } else if (isValueString) {\n // String is step(0.5)\n return interpolateString(kfValues[frame], kfValues[frame + 1], w);\n } else {\n value = interpolateNumber(kfValues[frame], kfValues[frame + 1], w);\n }\n\n setter(target, propName, value);\n }\n }\n };\n\n var clip = new Clip({\n target: animator._target,\n life: trackMaxTime,\n loop: animator._loop,\n delay: animator._delay,\n onframe: onframe,\n ondestroy: oneTrackDone\n });\n\n if (easing && easing !== 'spline') {\n clip.easing = easing;\n }\n\n return clip;\n}\n/**\n * @alias module:zrender/animation/Animator\n * @constructor\n * @param {Object} target\n * @param {boolean} loop\n * @param {Function} getter\n * @param {Function} setter\n */\n\n\nvar Animator = function (target, loop, getter, setter) {\n this._tracks = {};\n this._target = target;\n this._loop = loop || false;\n this._getter = getter || defaultGetter;\n this._setter = setter || defaultSetter;\n this._clipCount = 0;\n this._delay = 0;\n this._doneList = [];\n this._onframeList = [];\n this._clipList = [];\n};\n\nAnimator.prototype = {\n /**\n * 设置动画关键帧\n * @param {number} time 关键帧时间,单位是ms\n * @param {Object} props 关键帧的属性值,key-value表示\n * @return {module:zrender/animation/Animator}\n */\n when: function (time\n /* ms */\n , props) {\n var tracks = this._tracks;\n\n for (var propName in props) {\n if (!props.hasOwnProperty(propName)) {\n continue;\n }\n\n if (!tracks[propName]) {\n tracks[propName] = []; // Invalid value\n\n var value = this._getter(this._target, propName);\n\n if (value == null) {\n // zrLog('Invalid property ' + propName);\n continue;\n } // If time is 0\n // Then props is given initialize value\n // Else\n // Initialize value from current prop value\n\n\n if (time !== 0) {\n tracks[propName].push({\n time: 0,\n value: cloneValue(value)\n });\n }\n }\n\n tracks[propName].push({\n time: time,\n value: props[propName]\n });\n }\n\n return this;\n },\n\n /**\n * 添加动画每一帧的回调函数\n * @param {Function} callback\n * @return {module:zrender/animation/Animator}\n */\n during: function (callback) {\n this._onframeList.push(callback);\n\n return this;\n },\n pause: function () {\n for (var i = 0; i < this._clipList.length; i++) {\n this._clipList[i].pause();\n }\n\n this._paused = true;\n },\n resume: function () {\n for (var i = 0; i < this._clipList.length; i++) {\n this._clipList[i].resume();\n }\n\n this._paused = false;\n },\n isPaused: function () {\n return !!this._paused;\n },\n _doneCallback: function () {\n // Clear all tracks\n this._tracks = {}; // Clear all clips\n\n this._clipList.length = 0;\n var doneList = this._doneList;\n var len = doneList.length;\n\n for (var i = 0; i < len; i++) {\n doneList[i].call(this);\n }\n },\n\n /**\n * 开始执行动画\n * @param {string|Function} [easing]\n * 动画缓动函数,详见{@link module:zrender/animation/easing}\n * @param {boolean} forceAnimate\n * @return {module:zrender/animation/Animator}\n */\n start: function (easing, forceAnimate) {\n var self = this;\n var clipCount = 0;\n\n var oneTrackDone = function () {\n clipCount--;\n\n if (!clipCount) {\n self._doneCallback();\n }\n };\n\n var lastClip;\n\n for (var propName in this._tracks) {\n if (!this._tracks.hasOwnProperty(propName)) {\n continue;\n }\n\n var clip = createTrackClip(this, easing, oneTrackDone, this._tracks[propName], propName, forceAnimate);\n\n if (clip) {\n this._clipList.push(clip);\n\n clipCount++; // If start after added to animation\n\n if (this.animation) {\n this.animation.addClip(clip);\n }\n\n lastClip = clip;\n }\n } // Add during callback on the last clip\n\n\n if (lastClip) {\n var oldOnFrame = lastClip.onframe;\n\n lastClip.onframe = function (target, percent) {\n oldOnFrame(target, percent);\n\n for (var i = 0; i < self._onframeList.length; i++) {\n self._onframeList[i](target, percent);\n }\n };\n } // This optimization will help the case that in the upper application\n // the view may be refreshed frequently, where animation will be\n // called repeatly but nothing changed.\n\n\n if (!clipCount) {\n this._doneCallback();\n }\n\n return this;\n },\n\n /**\n * 停止动画\n * @param {boolean} forwardToLast If move to last frame before stop\n */\n stop: function (forwardToLast) {\n var clipList = this._clipList;\n var animation = this.animation;\n\n for (var i = 0; i < clipList.length; i++) {\n var clip = clipList[i];\n\n if (forwardToLast) {\n // Move to last frame before stop\n clip.onframe(this._target, 1);\n }\n\n animation && animation.removeClip(clip);\n }\n\n clipList.length = 0;\n },\n\n /**\n * 设置动画延迟开始的时间\n * @param {number} time 单位ms\n * @return {module:zrender/animation/Animator}\n */\n delay: function (time) {\n this._delay = time;\n return this;\n },\n\n /**\n * 添加动画结束的回调\n * @param {Function} cb\n * @return {module:zrender/animation/Animator}\n */\n done: function (cb) {\n if (cb) {\n this._doneList.push(cb);\n }\n\n return this;\n },\n\n /**\n * @return {Array.<module:zrender/animation/Clip>}\n */\n getClips: function () {\n return this._clipList;\n }\n};\nvar _default = Animator;\nmodule.exports = _default;","// 0 -> Array#forEach\n// 1 -> Array#map\n// 2 -> Array#filter\n// 3 -> Array#some\n// 4 -> Array#every\n// 5 -> Array#find\n// 6 -> Array#findIndex\nvar ctx = require('./_ctx');\nvar IObject = require('./_iobject');\nvar toObject = require('./_to-object');\nvar toLength = require('./_to-length');\nvar asc = require('./_array-species-create');\nmodule.exports = function (TYPE, $create) {\n var IS_MAP = TYPE == 1;\n var IS_FILTER = TYPE == 2;\n var IS_SOME = TYPE == 3;\n var IS_EVERY = TYPE == 4;\n var IS_FIND_INDEX = TYPE == 6;\n var NO_HOLES = TYPE == 5 || IS_FIND_INDEX;\n var create = $create || asc;\n return function ($this, callbackfn, that) {\n var O = toObject($this);\n var self = IObject(O);\n var f = ctx(callbackfn, that, 3);\n var length = toLength(self.length);\n var index = 0;\n var result = IS_MAP ? create($this, length) : IS_FILTER ? create($this, 0) : undefined;\n var val, res;\n for (;length > index; index++) if (NO_HOLES || index in self) {\n val = self[index];\n res = f(val, index, O);\n if (TYPE) {\n if (IS_MAP) result[index] = res; // map\n else if (res) switch (TYPE) {\n case 3: return true; // some\n case 5: return val; // find\n case 6: return index; // findIndex\n case 2: result.push(val); // filter\n } else if (IS_EVERY) return false; // every\n }\n }\n return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : result;\n };\n};\n","var eventUtil = require(\"./event\");\n\n/**\n * Only implements needed gestures for mobile.\n */\nvar GestureMgr = function () {\n /**\n * @private\n * @type {Array.<Object>}\n */\n this._track = [];\n};\n\nGestureMgr.prototype = {\n constructor: GestureMgr,\n recognize: function (event, target, root) {\n this._doTrack(event, target, root);\n\n return this._recognize(event);\n },\n clear: function () {\n this._track.length = 0;\n return this;\n },\n _doTrack: function (event, target, root) {\n var touches = event.touches;\n\n if (!touches) {\n return;\n }\n\n var trackItem = {\n points: [],\n touches: [],\n target: target,\n event: event\n };\n\n for (var i = 0, len = touches.length; i < len; i++) {\n var touch = touches[i];\n var pos = eventUtil.clientToLocal(root, touch, {});\n trackItem.points.push([pos.zrX, pos.zrY]);\n trackItem.touches.push(touch);\n }\n\n this._track.push(trackItem);\n },\n _recognize: function (event) {\n for (var eventName in recognizers) {\n if (recognizers.hasOwnProperty(eventName)) {\n var gestureInfo = recognizers[eventName](this._track, event);\n\n if (gestureInfo) {\n return gestureInfo;\n }\n }\n }\n }\n};\n\nfunction dist(pointPair) {\n var dx = pointPair[1][0] - pointPair[0][0];\n var dy = pointPair[1][1] - pointPair[0][1];\n return Math.sqrt(dx * dx + dy * dy);\n}\n\nfunction center(pointPair) {\n return [(pointPair[0][0] + pointPair[1][0]) / 2, (pointPair[0][1] + pointPair[1][1]) / 2];\n}\n\nvar recognizers = {\n pinch: function (track, event) {\n var trackLen = track.length;\n\n if (!trackLen) {\n return;\n }\n\n var pinchEnd = (track[trackLen - 1] || {}).points;\n var pinchPre = (track[trackLen - 2] || {}).points || pinchEnd;\n\n if (pinchPre && pinchPre.length > 1 && pinchEnd && pinchEnd.length > 1) {\n var pinchScale = dist(pinchEnd) / dist(pinchPre);\n !isFinite(pinchScale) && (pinchScale = 1);\n event.pinchScale = pinchScale;\n var pinchCenter = center(pinchEnd);\n event.pinchX = pinchCenter[0];\n event.pinchY = pinchCenter[1];\n return {\n type: 'pinch',\n target: track[0].target,\n event: event\n };\n }\n } // Only pinch currently.\n\n};\nvar _default = GestureMgr;\nmodule.exports = _default;","var matrix = require(\"../core/matrix\");\n\nvar vector = require(\"../core/vector\");\n\n/**\n * 提供变换扩展\n * @module zrender/mixin/Transformable\n * @author pissang (https://www.github.com/pissang)\n */\nvar mIdentity = matrix.identity;\nvar EPSILON = 5e-5;\n\nfunction isNotAroundZero(val) {\n return val > EPSILON || val < -EPSILON;\n}\n/**\n * @alias module:zrender/mixin/Transformable\n * @constructor\n */\n\n\nvar Transformable = function (opts) {\n opts = opts || {}; // If there are no given position, rotation, scale\n\n if (!opts.position) {\n /**\n * 平移\n * @type {Array.<number>}\n * @default [0, 0]\n */\n this.position = [0, 0];\n }\n\n if (opts.rotation == null) {\n /**\n * 旋转\n * @type {Array.<number>}\n * @default 0\n */\n this.rotation = 0;\n }\n\n if (!opts.scale) {\n /**\n * 缩放\n * @type {Array.<number>}\n * @default [1, 1]\n */\n this.scale = [1, 1];\n }\n /**\n * 旋转和缩放的原点\n * @type {Array.<number>}\n * @default null\n */\n\n\n this.origin = this.origin || null;\n};\n\nvar transformableProto = Transformable.prototype;\ntransformableProto.transform = null;\n/**\n * 判断是否需要有坐标变换\n * 如果有坐标变换, 则从position, rotation, scale以及父节点的transform计算出自身的transform矩阵\n */\n\ntransformableProto.needLocalTransform = function () {\n return isNotAroundZero(this.rotation) || isNotAroundZero(this.position[0]) || isNotAroundZero(this.position[1]) || isNotAroundZero(this.scale[0] - 1) || isNotAroundZero(this.scale[1] - 1);\n};\n\nvar scaleTmp = [];\n\ntransformableProto.updateTransform = function () {\n var parent = this.parent;\n var parentHasTransform = parent && parent.transform;\n var needLocalTransform = this.needLocalTransform();\n var m = this.transform;\n\n if (!(needLocalTransform || parentHasTransform)) {\n m && mIdentity(m);\n return;\n }\n\n m = m || matrix.create();\n\n if (needLocalTransform) {\n this.getLocalTransform(m);\n } else {\n mIdentity(m);\n } // 应用父节点变换\n\n\n if (parentHasTransform) {\n if (needLocalTransform) {\n matrix.mul(m, parent.transform, m);\n } else {\n matrix.copy(m, parent.transform);\n }\n } // 保存这个变换矩阵\n\n\n this.transform = m;\n var globalScaleRatio = this.globalScaleRatio;\n\n if (globalScaleRatio != null && globalScaleRatio !== 1) {\n this.getGlobalScale(scaleTmp);\n var relX = scaleTmp[0] < 0 ? -1 : 1;\n var relY = scaleTmp[1] < 0 ? -1 : 1;\n var sx = ((scaleTmp[0] - relX) * globalScaleRatio + relX) / scaleTmp[0] || 0;\n var sy = ((scaleTmp[1] - relY) * globalScaleRatio + relY) / scaleTmp[1] || 0;\n m[0] *= sx;\n m[1] *= sx;\n m[2] *= sy;\n m[3] *= sy;\n }\n\n this.invTransform = this.invTransform || matrix.create();\n matrix.invert(this.invTransform, m);\n};\n\ntransformableProto.getLocalTransform = function (m) {\n return Transformable.getLocalTransform(this, m);\n};\n/**\n * 将自己的transform应用到context上\n * @param {CanvasRenderingContext2D} ctx\n */\n\n\ntransformableProto.setTransform = function (ctx) {\n var m = this.transform;\n var dpr = ctx.dpr || 1;\n\n if (m) {\n ctx.setTransform(dpr * m[0], dpr * m[1], dpr * m[2], dpr * m[3], dpr * m[4], dpr * m[5]);\n } else {\n ctx.setTransform(dpr, 0, 0, dpr, 0, 0);\n }\n};\n\ntransformableProto.restoreTransform = function (ctx) {\n var dpr = ctx.dpr || 1;\n ctx.setTransform(dpr, 0, 0, dpr, 0, 0);\n};\n\nvar tmpTransform = [];\nvar originTransform = matrix.create();\n\ntransformableProto.setLocalTransform = function (m) {\n if (!m) {\n // TODO return or set identity?\n return;\n }\n\n var sx = m[0] * m[0] + m[1] * m[1];\n var sy = m[2] * m[2] + m[3] * m[3];\n var position = this.position;\n var scale = this.scale;\n\n if (isNotAroundZero(sx - 1)) {\n sx = Math.sqrt(sx);\n }\n\n if (isNotAroundZero(sy - 1)) {\n sy = Math.sqrt(sy);\n }\n\n if (m[0] < 0) {\n sx = -sx;\n }\n\n if (m[3] < 0) {\n sy = -sy;\n }\n\n position[0] = m[4];\n position[1] = m[5];\n scale[0] = sx;\n scale[1] = sy;\n this.rotation = Math.atan2(-m[1] / sy, m[0] / sx);\n};\n/**\n * 分解`transform`矩阵到`position`, `rotation`, `scale`\n */\n\n\ntransformableProto.decomposeTransform = function () {\n if (!this.transform) {\n return;\n }\n\n var parent = this.parent;\n var m = this.transform;\n\n if (parent && parent.transform) {\n // Get local transform and decompose them to position, scale, rotation\n matrix.mul(tmpTransform, parent.invTransform, m);\n m = tmpTransform;\n }\n\n var origin = this.origin;\n\n if (origin && (origin[0] || origin[1])) {\n originTransform[4] = origin[0];\n originTransform[5] = origin[1];\n matrix.mul(tmpTransform, m, originTransform);\n tmpTransform[4] -= origin[0];\n tmpTransform[5] -= origin[1];\n m = tmpTransform;\n }\n\n this.setLocalTransform(m);\n};\n/**\n * Get global scale\n * @return {Array.<number>}\n */\n\n\ntransformableProto.getGlobalScale = function (out) {\n var m = this.transform;\n out = out || [];\n\n if (!m) {\n out[0] = 1;\n out[1] = 1;\n return out;\n }\n\n out[0] = Math.sqrt(m[0] * m[0] + m[1] * m[1]);\n out[1] = Math.sqrt(m[2] * m[2] + m[3] * m[3]);\n\n if (m[0] < 0) {\n out[0] = -out[0];\n }\n\n if (m[3] < 0) {\n out[1] = -out[1];\n }\n\n return out;\n};\n/**\n * 变换坐标位置到 shape 的局部坐标空间\n * @method\n * @param {number} x\n * @param {number} y\n * @return {Array.<number>}\n */\n\n\ntransformableProto.transformCoordToLocal = function (x, y) {\n var v2 = [x, y];\n var invTransform = this.invTransform;\n\n if (invTransform) {\n vector.applyTransform(v2, v2, invTransform);\n }\n\n return v2;\n};\n/**\n * 变换局部坐标位置到全局坐标空间\n * @method\n * @param {number} x\n * @param {number} y\n * @return {Array.<number>}\n */\n\n\ntransformableProto.transformCoordToGlobal = function (x, y) {\n var v2 = [x, y];\n var transform = this.transform;\n\n if (transform) {\n vector.applyTransform(v2, v2, transform);\n }\n\n return v2;\n};\n/**\n * @static\n * @param {Object} target\n * @param {Array.<number>} target.origin\n * @param {number} target.rotation\n * @param {Array.<number>} target.position\n * @param {Array.<number>} [m]\n */\n\n\nTransformable.getLocalTransform = function (target, m) {\n m = m || [];\n mIdentity(m);\n var origin = target.origin;\n var scale = target.scale || [1, 1];\n var rotation = target.rotation || 0;\n var position = target.position || [0, 0];\n\n if (origin) {\n // Translate to origin\n m[4] -= origin[0];\n m[5] -= origin[1];\n }\n\n matrix.scale(m, m, scale);\n\n if (rotation) {\n matrix.rotate(m, m, rotation);\n }\n\n if (origin) {\n // Translate back from origin\n m[4] += origin[0];\n m[5] += origin[1];\n }\n\n m[4] += position[0];\n m[5] += position[1];\n return m;\n};\n\nvar _default = Transformable;\nmodule.exports = _default;","var Displayable = require(\"./Displayable\");\n\nvar BoundingRect = require(\"../core/BoundingRect\");\n\nvar zrUtil = require(\"../core/util\");\n\nvar imageHelper = require(\"./helper/image\");\n\n/**\n * @alias zrender/graphic/Image\n * @extends module:zrender/graphic/Displayable\n * @constructor\n * @param {Object} opts\n */\nfunction ZImage(opts) {\n Displayable.call(this, opts);\n}\n\nZImage.prototype = {\n constructor: ZImage,\n type: 'image',\n brush: function (ctx, prevEl) {\n var style = this.style;\n var src = style.image; // Must bind each time\n\n style.bind(ctx, this, prevEl);\n var image = this._image = imageHelper.createOrUpdateImage(src, this._image, this, this.onload);\n\n if (!image || !imageHelper.isImageReady(image)) {\n return;\n } // 图片已经加载完成\n // if (image.nodeName.toUpperCase() == 'IMG') {\n // if (!image.complete) {\n // return;\n // }\n // }\n // Else is canvas\n\n\n var x = style.x || 0;\n var y = style.y || 0;\n var width = style.width;\n var height = style.height;\n var aspect = image.width / image.height;\n\n if (width == null && height != null) {\n // Keep image/height ratio\n width = height * aspect;\n } else if (height == null && width != null) {\n height = width / aspect;\n } else if (width == null && height == null) {\n width = image.width;\n height = image.height;\n } // 设置transform\n\n\n this.setTransform(ctx);\n\n if (style.sWidth && style.sHeight) {\n var sx = style.sx || 0;\n var sy = style.sy || 0;\n ctx.drawImage(image, sx, sy, style.sWidth, style.sHeight, x, y, width, height);\n } else if (style.sx && style.sy) {\n var sx = style.sx;\n var sy = style.sy;\n var sWidth = width - sx;\n var sHeight = height - sy;\n ctx.drawImage(image, sx, sy, sWidth, sHeight, x, y, width, height);\n } else {\n ctx.drawImage(image, x, y, width, height);\n } // Draw rect text\n\n\n if (style.text != null) {\n // Only restore transform when needs draw text.\n this.restoreTransform(ctx);\n this.drawRectText(ctx, this.getBoundingRect());\n }\n },\n getBoundingRect: function () {\n var style = this.style;\n\n if (!this._rect) {\n this._rect = new BoundingRect(style.x || 0, style.y || 0, style.width || 0, style.height || 0);\n }\n\n return this._rect;\n }\n};\nzrUtil.inherits(ZImage, Displayable);\nvar _default = ZImage;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar _model = require(\"../../util/model\");\n\nvar makeInner = _model.makeInner;\nvar getDataItemValue = _model.getDataItemValue;\n\nvar _referHelper = require(\"../../model/referHelper\");\n\nvar getCoordSysDefineBySeries = _referHelper.getCoordSysDefineBySeries;\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar createHashMap = _util.createHashMap;\nvar each = _util.each;\nvar map = _util.map;\nvar isArray = _util.isArray;\nvar isString = _util.isString;\nvar isObject = _util.isObject;\nvar isTypedArray = _util.isTypedArray;\nvar isArrayLike = _util.isArrayLike;\nvar extend = _util.extend;\nvar assert = _util.assert;\n\nvar Source = require(\"../Source\");\n\nvar _sourceType = require(\"./sourceType\");\n\nvar SOURCE_FORMAT_ORIGINAL = _sourceType.SOURCE_FORMAT_ORIGINAL;\nvar SOURCE_FORMAT_ARRAY_ROWS = _sourceType.SOURCE_FORMAT_ARRAY_ROWS;\nvar SOURCE_FORMAT_OBJECT_ROWS = _sourceType.SOURCE_FORMAT_OBJECT_ROWS;\nvar SOURCE_FORMAT_KEYED_COLUMNS = _sourceType.SOURCE_FORMAT_KEYED_COLUMNS;\nvar SOURCE_FORMAT_UNKNOWN = _sourceType.SOURCE_FORMAT_UNKNOWN;\nvar SOURCE_FORMAT_TYPED_ARRAY = _sourceType.SOURCE_FORMAT_TYPED_ARRAY;\nvar SERIES_LAYOUT_BY_ROW = _sourceType.SERIES_LAYOUT_BY_ROW;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar inner = makeInner();\n/**\n * @see {module:echarts/data/Source}\n * @param {module:echarts/component/dataset/DatasetModel} datasetModel\n * @return {string} sourceFormat\n */\n\nfunction detectSourceFormat(datasetModel) {\n var data = datasetModel.option.source;\n var sourceFormat = SOURCE_FORMAT_UNKNOWN;\n\n if (isTypedArray(data)) {\n sourceFormat = SOURCE_FORMAT_TYPED_ARRAY;\n } else if (isArray(data)) {\n // FIXME Whether tolerate null in top level array?\n if (data.length === 0) {\n sourceFormat = SOURCE_FORMAT_ARRAY_ROWS;\n }\n\n for (var i = 0, len = data.length; i < len; i++) {\n var item = data[i];\n\n if (item == null) {\n continue;\n } else if (isArray(item)) {\n sourceFormat = SOURCE_FORMAT_ARRAY_ROWS;\n break;\n } else if (isObject(item)) {\n sourceFormat = SOURCE_FORMAT_OBJECT_ROWS;\n break;\n }\n }\n } else if (isObject(data)) {\n for (var key in data) {\n if (data.hasOwnProperty(key) && isArrayLike(data[key])) {\n sourceFormat = SOURCE_FORMAT_KEYED_COLUMNS;\n break;\n }\n }\n } else if (data != null) {\n throw new Error('Invalid data');\n }\n\n inner(datasetModel).sourceFormat = sourceFormat;\n}\n/**\n * [Scenarios]:\n * (1) Provide source data directly:\n * series: {\n * encode: {...},\n * dimensions: [...]\n * seriesLayoutBy: 'row',\n * data: [[...]]\n * }\n * (2) Refer to datasetModel.\n * series: [{\n * encode: {...}\n * // Ignore datasetIndex means `datasetIndex: 0`\n * // and the dimensions defination in dataset is used\n * }, {\n * encode: {...},\n * seriesLayoutBy: 'column',\n * datasetIndex: 1\n * }]\n *\n * Get data from series itself or datset.\n * @return {module:echarts/data/Source} source\n */\n\n\nfunction getSource(seriesModel) {\n return inner(seriesModel).source;\n}\n/**\n * MUST be called before mergeOption of all series.\n * @param {module:echarts/model/Global} ecModel\n */\n\n\nfunction resetSourceDefaulter(ecModel) {\n // `datasetMap` is used to make default encode.\n inner(ecModel).datasetMap = createHashMap();\n}\n/**\n * [Caution]:\n * MUST be called after series option merged and\n * before \"series.getInitailData()\" called.\n *\n * [The rule of making default encode]:\n * Category axis (if exists) alway map to the first dimension.\n * Each other axis occupies a subsequent dimension.\n *\n * [Why make default encode]:\n * Simplify the typing of encode in option, avoiding the case like that:\n * series: [{encode: {x: 0, y: 1}}, {encode: {x: 0, y: 2}}, {encode: {x: 0, y: 3}}],\n * where the \"y\" have to be manually typed as \"1, 2, 3, ...\".\n *\n * @param {module:echarts/model/Series} seriesModel\n */\n\n\nfunction prepareSource(seriesModel) {\n var seriesOption = seriesModel.option;\n var data = seriesOption.data;\n var sourceFormat = isTypedArray(data) ? SOURCE_FORMAT_TYPED_ARRAY : SOURCE_FORMAT_ORIGINAL;\n var fromDataset = false;\n var seriesLayoutBy = seriesOption.seriesLayoutBy;\n var sourceHeader = seriesOption.sourceHeader;\n var dimensionsDefine = seriesOption.dimensions;\n var datasetModel = getDatasetModel(seriesModel);\n\n if (datasetModel) {\n var datasetOption = datasetModel.option;\n data = datasetOption.source;\n sourceFormat = inner(datasetModel).sourceFormat;\n fromDataset = true; // These settings from series has higher priority.\n\n seriesLayoutBy = seriesLayoutBy || datasetOption.seriesLayoutBy;\n sourceHeader == null && (sourceHeader = datasetOption.sourceHeader);\n dimensionsDefine = dimensionsDefine || datasetOption.dimensions;\n }\n\n var completeResult = completeBySourceData(data, sourceFormat, seriesLayoutBy, sourceHeader, dimensionsDefine); // Note: dataset option does not have `encode`.\n\n var encodeDefine = seriesOption.encode;\n\n if (!encodeDefine && datasetModel) {\n encodeDefine = makeDefaultEncode(seriesModel, datasetModel, data, sourceFormat, seriesLayoutBy, completeResult);\n }\n\n inner(seriesModel).source = new Source({\n data: data,\n fromDataset: fromDataset,\n seriesLayoutBy: seriesLayoutBy,\n sourceFormat: sourceFormat,\n dimensionsDefine: completeResult.dimensionsDefine,\n startIndex: completeResult.startIndex,\n dimensionsDetectCount: completeResult.dimensionsDetectCount,\n encodeDefine: encodeDefine\n });\n} // return {startIndex, dimensionsDefine, dimensionsCount}\n\n\nfunction completeBySourceData(data, sourceFormat, seriesLayoutBy, sourceHeader, dimensionsDefine) {\n if (!data) {\n return {\n dimensionsDefine: normalizeDimensionsDefine(dimensionsDefine)\n };\n }\n\n var dimensionsDetectCount;\n var startIndex;\n var findPotentialName;\n\n if (sourceFormat === SOURCE_FORMAT_ARRAY_ROWS) {\n // Rule: Most of the first line are string: it is header.\n // Caution: consider a line with 5 string and 1 number,\n // it still can not be sure it is a head, because the\n // 5 string may be 5 values of category columns.\n if (sourceHeader === 'auto' || sourceHeader == null) {\n arrayRowsTravelFirst(function (val) {\n // '-' is regarded as null/undefined.\n if (val != null && val !== '-') {\n if (isString(val)) {\n startIndex == null && (startIndex = 1);\n } else {\n startIndex = 0;\n }\n } // 10 is an experience number, avoid long loop.\n\n }, seriesLayoutBy, data, 10);\n } else {\n startIndex = sourceHeader ? 1 : 0;\n }\n\n if (!dimensionsDefine && startIndex === 1) {\n dimensionsDefine = [];\n arrayRowsTravelFirst(function (val, index) {\n dimensionsDefine[index] = val != null ? val : '';\n }, seriesLayoutBy, data);\n }\n\n dimensionsDetectCount = dimensionsDefine ? dimensionsDefine.length : seriesLayoutBy === SERIES_LAYOUT_BY_ROW ? data.length : data[0] ? data[0].length : null;\n } else if (sourceFormat === SOURCE_FORMAT_OBJECT_ROWS) {\n if (!dimensionsDefine) {\n dimensionsDefine = objectRowsCollectDimensions(data);\n findPotentialName = true;\n }\n } else if (sourceFormat === SOURCE_FORMAT_KEYED_COLUMNS) {\n if (!dimensionsDefine) {\n dimensionsDefine = [];\n findPotentialName = true;\n each(data, function (colArr, key) {\n dimensionsDefine.push(key);\n });\n }\n } else if (sourceFormat === SOURCE_FORMAT_ORIGINAL) {\n var value0 = getDataItemValue(data[0]);\n dimensionsDetectCount = isArray(value0) && value0.length || 1;\n } else if (sourceFormat === SOURCE_FORMAT_TYPED_ARRAY) {}\n\n var potentialNameDimIndex;\n\n if (findPotentialName) {\n each(dimensionsDefine, function (dim, idx) {\n if ((isObject(dim) ? dim.name : dim) === 'name') {\n potentialNameDimIndex = idx;\n }\n });\n }\n\n return {\n startIndex: startIndex,\n dimensionsDefine: normalizeDimensionsDefine(dimensionsDefine),\n dimensionsDetectCount: dimensionsDetectCount,\n potentialNameDimIndex: potentialNameDimIndex // TODO: potentialIdDimIdx\n\n };\n} // Consider dimensions defined like ['A', 'price', 'B', 'price', 'C', 'price'],\n// which is reasonable. But dimension name is duplicated.\n// Returns undefined or an array contains only object without null/undefiend or string.\n\n\nfunction normalizeDimensionsDefine(dimensionsDefine) {\n if (!dimensionsDefine) {\n // The meaning of null/undefined is different from empty array.\n return;\n }\n\n var nameMap = createHashMap();\n return map(dimensionsDefine, function (item, index) {\n item = extend({}, isObject(item) ? item : {\n name: item\n }); // User can set null in dimensions.\n // We dont auto specify name, othewise a given name may\n // cause it be refered unexpectedly.\n\n if (item.name == null) {\n return item;\n } // Also consider number form like 2012.\n\n\n item.name += ''; // User may also specify displayName.\n // displayName will always exists except user not\n // specified or dim name is not specified or detected.\n // (A auto generated dim name will not be used as\n // displayName).\n\n if (item.displayName == null) {\n item.displayName = item.name;\n }\n\n var exist = nameMap.get(item.name);\n\n if (!exist) {\n nameMap.set(item.name, {\n count: 1\n });\n } else {\n item.name += '-' + exist.count++;\n }\n\n return item;\n });\n}\n\nfunction arrayRowsTravelFirst(cb, seriesLayoutBy, data, maxLoop) {\n maxLoop == null && (maxLoop = Infinity);\n\n if (seriesLayoutBy === SERIES_LAYOUT_BY_ROW) {\n for (var i = 0; i < data.length && i < maxLoop; i++) {\n cb(data[i] ? data[i][0] : null, i);\n }\n } else {\n var value0 = data[0] || [];\n\n for (var i = 0; i < value0.length && i < maxLoop; i++) {\n cb(value0[i], i);\n }\n }\n}\n\nfunction objectRowsCollectDimensions(data) {\n var firstIndex = 0;\n var obj;\n\n while (firstIndex < data.length && !(obj = data[firstIndex++])) {} // jshint ignore: line\n\n\n if (obj) {\n var dimensions = [];\n each(obj, function (value, key) {\n dimensions.push(key);\n });\n return dimensions;\n }\n} // ??? TODO merge to completedimensions, where also has\n// default encode making logic. And the default rule\n// should depends on series? consider 'map'.\n\n\nfunction makeDefaultEncode(seriesModel, datasetModel, data, sourceFormat, seriesLayoutBy, completeResult) {\n var coordSysDefine = getCoordSysDefineBySeries(seriesModel);\n var encode = {}; // var encodeTooltip = [];\n // var encodeLabel = [];\n\n var encodeItemName = [];\n var encodeSeriesName = [];\n var seriesType = seriesModel.subType; // ??? TODO refactor: provide by series itself.\n // Consider the case: 'map' series is based on geo coordSys,\n // 'graph', 'heatmap' can be based on cartesian. But can not\n // give default rule simply here.\n\n var nSeriesMap = createHashMap(['pie', 'map', 'funnel']);\n var cSeriesMap = createHashMap(['line', 'bar', 'pictorialBar', 'scatter', 'effectScatter', 'candlestick', 'boxplot']); // Usually in this case series will use the first data\n // dimension as the \"value\" dimension, or other default\n // processes respectively.\n\n if (coordSysDefine && cSeriesMap.get(seriesType) != null) {\n var ecModel = seriesModel.ecModel;\n var datasetMap = inner(ecModel).datasetMap;\n var key = datasetModel.uid + '_' + seriesLayoutBy;\n var datasetRecord = datasetMap.get(key) || datasetMap.set(key, {\n categoryWayDim: 1,\n valueWayDim: 0\n }); // TODO\n // Auto detect first time axis and do arrangement.\n\n each(coordSysDefine.coordSysDims, function (coordDim) {\n // In value way.\n if (coordSysDefine.firstCategoryDimIndex == null) {\n var dataDim = datasetRecord.valueWayDim++;\n encode[coordDim] = dataDim; // ??? TODO give a better default series name rule?\n // especially when encode x y specified.\n // consider: when mutiple series share one dimension\n // category axis, series name should better use\n // the other dimsion name. On the other hand, use\n // both dimensions name.\n\n encodeSeriesName.push(dataDim); // encodeTooltip.push(dataDim);\n // encodeLabel.push(dataDim);\n } // In category way, category axis.\n else if (coordSysDefine.categoryAxisMap.get(coordDim)) {\n encode[coordDim] = 0;\n encodeItemName.push(0);\n } // In category way, non-category axis.\n else {\n var dataDim = datasetRecord.categoryWayDim++;\n encode[coordDim] = dataDim; // encodeTooltip.push(dataDim);\n // encodeLabel.push(dataDim);\n\n encodeSeriesName.push(dataDim);\n }\n });\n } // Do not make a complex rule! Hard to code maintain and not necessary.\n // ??? TODO refactor: provide by series itself.\n // [{name: ..., value: ...}, ...] like:\n else if (nSeriesMap.get(seriesType) != null) {\n // Find the first not ordinal. (5 is an experience value)\n var firstNotOrdinal;\n\n for (var i = 0; i < 5 && firstNotOrdinal == null; i++) {\n if (!doGuessOrdinal(data, sourceFormat, seriesLayoutBy, completeResult.dimensionsDefine, completeResult.startIndex, i)) {\n firstNotOrdinal = i;\n }\n }\n\n if (firstNotOrdinal != null) {\n encode.value = firstNotOrdinal;\n var nameDimIndex = completeResult.potentialNameDimIndex || Math.max(firstNotOrdinal - 1, 0); // By default, label use itemName in charts.\n // So we dont set encodeLabel here.\n\n encodeSeriesName.push(nameDimIndex);\n encodeItemName.push(nameDimIndex); // encodeTooltip.push(firstNotOrdinal);\n }\n } // encodeTooltip.length && (encode.tooltip = encodeTooltip);\n // encodeLabel.length && (encode.label = encodeLabel);\n\n\n encodeItemName.length && (encode.itemName = encodeItemName);\n encodeSeriesName.length && (encode.seriesName = encodeSeriesName);\n return encode;\n}\n/**\n * If return null/undefined, indicate that should not use datasetModel.\n */\n\n\nfunction getDatasetModel(seriesModel) {\n var option = seriesModel.option; // Caution: consider the scenario:\n // A dataset is declared and a series is not expected to use the dataset,\n // and at the beginning `setOption({series: { noData })` (just prepare other\n // option but no data), then `setOption({series: {data: [...]}); In this case,\n // the user should set an empty array to avoid that dataset is used by default.\n\n var thisData = option.data;\n\n if (!thisData) {\n return seriesModel.ecModel.getComponent('dataset', option.datasetIndex || 0);\n }\n}\n/**\n * The rule should not be complex, otherwise user might not\n * be able to known where the data is wrong.\n * The code is ugly, but how to make it neat?\n *\n * @param {module:echars/data/Source} source\n * @param {number} dimIndex\n * @return {boolean} Whether ordinal.\n */\n\n\nfunction guessOrdinal(source, dimIndex) {\n return doGuessOrdinal(source.data, source.sourceFormat, source.seriesLayoutBy, source.dimensionsDefine, source.startIndex, dimIndex);\n} // dimIndex may be overflow source data.\n\n\nfunction doGuessOrdinal(data, sourceFormat, seriesLayoutBy, dimensionsDefine, startIndex, dimIndex) {\n var result; // Experience value.\n\n var maxLoop = 5;\n\n if (isTypedArray(data)) {\n return false;\n } // When sourceType is 'objectRows' or 'keyedColumns', dimensionsDefine\n // always exists in source.\n\n\n var dimName;\n\n if (dimensionsDefine) {\n dimName = dimensionsDefine[dimIndex];\n dimName = isObject(dimName) ? dimName.name : dimName;\n }\n\n if (sourceFormat === SOURCE_FORMAT_ARRAY_ROWS) {\n if (seriesLayoutBy === SERIES_LAYOUT_BY_ROW) {\n var sample = data[dimIndex];\n\n for (var i = 0; i < (sample || []).length && i < maxLoop; i++) {\n if ((result = detectValue(sample[startIndex + i])) != null) {\n return result;\n }\n }\n } else {\n for (var i = 0; i < data.length && i < maxLoop; i++) {\n var row = data[startIndex + i];\n\n if (row && (result = detectValue(row[dimIndex])) != null) {\n return result;\n }\n }\n }\n } else if (sourceFormat === SOURCE_FORMAT_OBJECT_ROWS) {\n if (!dimName) {\n return;\n }\n\n for (var i = 0; i < data.length && i < maxLoop; i++) {\n var item = data[i];\n\n if (item && (result = detectValue(item[dimName])) != null) {\n return result;\n }\n }\n } else if (sourceFormat === SOURCE_FORMAT_KEYED_COLUMNS) {\n if (!dimName) {\n return;\n }\n\n var sample = data[dimName];\n\n if (!sample || isTypedArray(sample)) {\n return false;\n }\n\n for (var i = 0; i < sample.length && i < maxLoop; i++) {\n if ((result = detectValue(sample[i])) != null) {\n return result;\n }\n }\n } else if (sourceFormat === SOURCE_FORMAT_ORIGINAL) {\n for (var i = 0; i < data.length && i < maxLoop; i++) {\n var item = data[i];\n var val = getDataItemValue(item);\n\n if (!isArray(val)) {\n return false;\n }\n\n if ((result = detectValue(val[dimIndex])) != null) {\n return result;\n }\n }\n }\n\n function detectValue(val) {\n // Consider usage convenience, '1', '2' will be treated as \"number\".\n // `isFinit('')` get `true`.\n if (val != null && isFinite(val) && val !== '') {\n return false;\n } else if (isString(val) && val !== '-') {\n return true;\n }\n }\n\n return false;\n}\n\nexports.detectSourceFormat = detectSourceFormat;\nexports.getSource = getSource;\nexports.resetSourceDefaulter = resetSourceDefaulter;\nexports.prepareSource = prepareSource;\nexports.guessOrdinal = guessOrdinal;","// 7.2.2 IsArray(argument)\nvar cof = require('./_cof');\nmodule.exports = Array.isArray || function isArray(arg) {\n return cof(arg) == 'Array';\n};\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{ref:\"container\",staticClass:\"statistical-page\"},[_c('div',{staticClass:\"navs\"},[_c('div',{staticClass:\"list\"},[_c('div',{staticClass:\"item\",class:_vm.time == 'today' ? 'on' : '',on:{\"click\":function($event){return _vm.setTime('today')}}},[_vm._v(\"\\n 今天\\n \")]),_c('div',{staticClass:\"item\",class:_vm.time == 'yesterday' ? 'on' : '',on:{\"click\":function($event){return _vm.setTime('yesterday')}}},[_vm._v(\"\\n 昨天\\n \")]),_c('div',{staticClass:\"item\",class:_vm.time == 'seven' ? 'on' : '',on:{\"click\":function($event){return _vm.setTime('seven')}}},[_vm._v(\"\\n 最近7天\\n \")]),_c('div',{staticClass:\"item\",class:_vm.time == 'month' ? 'on' : '',on:{\"click\":function($event){return _vm.setTime('month')}}},[_vm._v(\"\\n 本月\\n \")]),_c('div',{staticClass:\"item\",class:_vm.time == 'date' ? 'on' : '',on:{\"click\":_vm.dateTitle}},[_vm._v(\"\\n 自定义\\n \")])])]),_c('div',{staticClass:\"wrapper\"},[_c('div',{staticClass:\"title\"},[_vm._v(\"\\n \"+_vm._s(_vm.title)+_vm._s(this.where.type == 1 ? \"营业额(元)\" : \"订单量(份)\")+\"\\n \")]),_c('div',{staticClass:\"money\"},[_vm._v(_vm._s(_vm.time_price))]),_c('div',{staticClass:\"increase acea-row row-between-wrapper\"},[_c('div',[_vm._v(\"\\n \"+_vm._s(_vm.title)+\"增长率:\"),_c('span',{class:_vm.increase_time_status === 1 ? 'red' : 'green'},[_vm._v(_vm._s(_vm.increase_time_status === 1 ? \"\" : \"-\")+_vm._s(_vm.growth_rate)+\"%\\n \"),_c('span',{staticClass:\"iconfont\",class:_vm.increase_time_status === 1\n ? 'icon-xiangshang1'\n : 'icon-xiangxia2'})])]),_c('div',[_vm._v(\"\\n \"+_vm._s(_vm.title)+\"增长:\"),_c('span',{class:_vm.increase_time_status === 1 ? 'red' : 'green'},[_vm._v(_vm._s(_vm.increase_time_status === 1 ? \"\" : \"-\")+_vm._s(_vm.increase_time)+\"\\n \"),_c('span',{staticClass:\"iconfont\",class:_vm.increase_time_status === 1\n ? 'icon-xiangshang1'\n : 'icon-xiangxia2'})])])])]),_c('div',{staticClass:\"chart\"},[_c('div',{staticClass:\"company\"},[_vm._v(\"\\n \"+_vm._s(_vm.where.type === 1 ? \"单位(元)\" : \"单位(份)\")+\"\\n \")]),_c('ECharts',{attrs:{\"options\":_vm.polar}})],1),_c('div',{staticClass:\"public-wrapper\"},[_vm._m(0),_vm._m(1),_c('div',{staticClass:\"conter\"},_vm._l((_vm.list),function(item,index){return _c('div',{key:index,staticClass:\"item acea-row row-between-wrapper\"},[_c('div',{staticClass:\"data\"},[_vm._v(_vm._s(item.time))]),_c('div',{staticClass:\"browse\"},[_vm._v(_vm._s(item.count))]),_c('div',{staticClass:\"turnover\"},[_vm._v(_vm._s(item.price))])])}),0)]),_c('div',{staticClass:\"calendar-wrapper\",class:_vm.current === true ? 'on' : ''},[_c('div',{staticClass:\"calendar\"},[_c('Calendar',{ref:\"calendar\",attrs:{\"clean\":_vm.clean,\"lunar\":_vm.lunar,\"range\":_vm.isrange,\"multi\":_vm.ismulti,\"value\":_vm.value,\"weekSwitch\":_vm.weekSwitch,\"monthRange\":_vm.monthRange,\"rangeMonthFormat\":\"yyyy年MM月\",\"monFirst\":\"\",\"responsive\":\"\",\"begin\":[1992, 5, 20],\"end\":[2049, 5, 20]},on:{\"select\":_vm.select,\"next\":_vm.next,\"prev\":_vm.prev}})],1)]),_c('div',{directives:[{name:\"show\",rawName:\"v-show\",value:(_vm.current === true),expression:\"current === true\"}],staticClass:\"mask\",on:{\"touchmove\":function($event){$event.preventDefault();},\"click\":_vm.close}}),_c('Loading',{attrs:{\"loaded\":_vm.loaded,\"loading\":_vm.loading}})],1)}\nvar staticRenderFns = [function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"title\"},[_c('span',{staticClass:\"iconfont icon-xiangxishuju\"}),_vm._v(\"详细数据\\n \")])},function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"nav acea-row row-between-wrapper\"},[_c('div',{staticClass:\"data\"},[_vm._v(\"日期\")]),_c('div',{staticClass:\"browse\"},[_vm._v(\"订单量\")]),_c('div',{staticClass:\"turnover\"},[_vm._v(\"成交额\")])])}]\n\nexport { render, staticRenderFns }","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"echarts\"})}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","let raf = null;\nfunction requestAnimationFrame (callback) {\n if (!raf) {\n raf = (\n window.requestAnimationFrame ||\n window.webkitRequestAnimationFrame ||\n window.mozRequestAnimationFrame ||\n function (callback) {\n return setTimeout(callback, 16)\n }\n ).bind(window);\n }\n return raf(callback)\n}\n\nlet caf = null;\nfunction cancelAnimationFrame (id) {\n if (!caf) {\n caf = (\n window.cancelAnimationFrame ||\n window.webkitCancelAnimationFrame ||\n window.mozCancelAnimationFrame ||\n function (id) {\n clearTimeout(id);\n }\n ).bind(window);\n }\n\n caf(id);\n}\n\nfunction createStyles (styleText) {\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (style.styleSheet) {\n style.styleSheet.cssText = styleText;\n } else {\n style.appendChild(document.createTextNode(styleText));\n }\n (document.querySelector('head') || document.body).appendChild(style);\n return style\n}\n\nfunction createElement (tagName, props = {}) {\n let elem = document.createElement(tagName);\n Object.keys(props).forEach(key => {\n elem[key] = props[key];\n });\n return elem\n}\n\nfunction getComputedStyle (elem, prop, pseudo) {\n // for older versions of Firefox, `getComputedStyle` required\n // the second argument and may return `null` for some elements\n // when `display: none`\n let computedStyle = window.getComputedStyle(elem, pseudo || null) || {\n display: 'none'\n };\n\n return computedStyle[prop]\n}\n\nfunction getRenderInfo (elem) {\n if (!document.documentElement.contains(elem)) {\n return {\n detached: true,\n rendered: false\n }\n }\n\n let current = elem;\n while (current !== document) {\n if (getComputedStyle(current, 'display') === 'none') {\n return {\n detached: false,\n rendered: false\n }\n }\n current = current.parentNode;\n }\n\n return {\n detached: false,\n rendered: true\n }\n}\n\nvar css = \".resize-triggers{visibility:hidden;opacity:0}.resize-contract-trigger,.resize-contract-trigger:before,.resize-expand-trigger,.resize-triggers{content:\\\"\\\";position:absolute;top:0;left:0;height:100%;width:100%;overflow:hidden}.resize-contract-trigger,.resize-expand-trigger{background:#eee;overflow:auto}.resize-contract-trigger:before{width:200%;height:200%}\";\n\nlet total = 0;\nlet style = null;\n\nfunction addListener (elem, callback) {\n if (!elem.__resize_mutation_handler__) {\n elem.__resize_mutation_handler__ = handleMutation.bind(elem);\n }\n\n let listeners = elem.__resize_listeners__;\n\n if (!listeners) {\n elem.__resize_listeners__ = [];\n if (window.ResizeObserver) {\n let { offsetWidth, offsetHeight } = elem;\n let ro = new ResizeObserver(() => {\n if (!elem.__resize_observer_triggered__) {\n elem.__resize_observer_triggered__ = true;\n if (elem.offsetWidth === offsetWidth && elem.offsetHeight === offsetHeight) {\n return\n }\n }\n runCallbacks(elem);\n });\n\n // initially display none won't trigger ResizeObserver callback\n let { detached, rendered } = getRenderInfo(elem);\n elem.__resize_observer_triggered__ = detached === false && rendered === false;\n elem.__resize_observer__ = ro;\n ro.observe(elem);\n } else if (elem.attachEvent && elem.addEventListener) {\n // targeting IE9/10\n elem.__resize_legacy_resize_handler__ = function handleLegacyResize () {\n runCallbacks(elem);\n };\n elem.attachEvent('onresize', elem.__resize_legacy_resize_handler__);\n document.addEventListener('DOMSubtreeModified', elem.__resize_mutation_handler__);\n } else {\n if (!total) {\n style = createStyles(css);\n }\n initTriggers(elem);\n\n elem.__resize_rendered__ = getRenderInfo(elem).rendered;\n if (window.MutationObserver) {\n let mo = new MutationObserver(elem.__resize_mutation_handler__);\n mo.observe(document, {\n attributes: true,\n childList: true,\n characterData: true,\n subtree: true\n });\n elem.__resize_mutation_observer__ = mo;\n }\n }\n }\n\n elem.__resize_listeners__.push(callback);\n total++;\n}\n\nfunction removeListener (elem, callback) {\n // targeting IE9/10\n if (elem.detachEvent && elem.removeEventListener) {\n elem.detachEvent('onresize', elem.__resize_legacy_resize_handler__);\n document.removeEventListener('DOMSubtreeModified', elem.__resize_mutation_handler__);\n return\n }\n\n let listeners = elem.__resize_listeners__;\n if (!listeners) {\n return\n }\n listeners.splice(listeners.indexOf(callback), 1);\n\n if (!listeners.length) {\n if (elem.__resize_observer__) {\n elem.__resize_observer__.unobserve(elem);\n elem.__resize_observer__.disconnect();\n elem.__resize_observer__ = null;\n } else {\n if (elem.__resize_mutation_observer__) {\n elem.__resize_mutation_observer__.disconnect();\n elem.__resize_mutation_observer__ = null;\n }\n elem.removeEventListener('scroll', handleScroll);\n elem.removeChild(elem.__resize_triggers__.triggers);\n elem.__resize_triggers__ = null;\n }\n elem.__resize_listeners__ = null;\n }\n\n if (!--total && style) {\n style.parentNode.removeChild(style);\n }\n}\n\nfunction getUpdatedSize (elem) {\n let { width, height } = elem.__resize_last__;\n let { offsetWidth, offsetHeight } = elem;\n if (offsetWidth !== width || offsetHeight !== height) {\n return {\n width: offsetWidth,\n height: offsetHeight\n }\n }\n return null\n}\n\nfunction handleMutation () {\n // `this` denotes the scrolling element\n let { rendered, detached } = getRenderInfo(this);\n if (rendered !== this.__resize_rendered__) {\n if (!detached && this.__resize_triggers__) {\n resetTriggers(this);\n this.addEventListener('scroll', handleScroll, true);\n }\n this.__resize_rendered__ = rendered;\n runCallbacks(this);\n }\n}\n\nfunction handleScroll () {\n // `this` denotes the scrolling element\n resetTriggers(this);\n if (this.__resize_raf__) {\n cancelAnimationFrame(this.__resize_raf__);\n }\n this.__resize_raf__ = requestAnimationFrame(() => {\n let updated = getUpdatedSize(this);\n if (updated) {\n this.__resize_last__ = updated;\n runCallbacks(this);\n }\n });\n}\n\nfunction runCallbacks (elem) {\n if (!elem || !elem.__resize_listeners__) {\n return\n }\n elem.__resize_listeners__.forEach(callback => {\n callback.call(elem);\n });\n}\n\nfunction initTriggers (elem) {\n let position = getComputedStyle(elem, 'position');\n if (!position || position === 'static') {\n elem.style.position = 'relative';\n }\n\n elem.__resize_old_position__ = position;\n elem.__resize_last__ = {};\n\n let triggers = createElement('div', {\n className: 'resize-triggers'\n });\n let expand = createElement('div', {\n className: 'resize-expand-trigger'\n });\n let expandChild = createElement('div');\n let contract = createElement('div', {\n className: 'resize-contract-trigger'\n });\n expand.appendChild(expandChild);\n triggers.appendChild(expand);\n triggers.appendChild(contract);\n elem.appendChild(triggers);\n\n elem.__resize_triggers__ = {\n triggers,\n expand,\n expandChild,\n contract\n };\n\n resetTriggers(elem);\n elem.addEventListener('scroll', handleScroll, true);\n\n elem.__resize_last__ = {\n width: elem.offsetWidth,\n height: elem.offsetHeight\n };\n}\n\nfunction resetTriggers (elem) {\n let { expand, expandChild, contract } = elem.__resize_triggers__;\n\n // batch read\n let { scrollWidth: csw, scrollHeight: csh } = contract;\n let { offsetWidth: eow, offsetHeight: eoh, scrollWidth: esw, scrollHeight: esh } = expand;\n\n // batch write\n contract.scrollLeft = csw;\n contract.scrollTop = csh;\n expandChild.style.width = eow + 1 + 'px';\n expandChild.style.height = eoh + 1 + 'px';\n expand.scrollLeft = esw;\n expand.scrollTop = esh;\n}\n\nexport { addListener, removeListener };\n","<template>\n<div class=\"echarts\"/>\n</template>\n\n<style>\n.echarts {\n width: 600px;\n height: 400px;\n}\n</style>\n\n<script>\nimport echarts from 'echarts/lib/echarts'\nimport debounce from 'lodash/debounce'\nimport { addListener, removeListener } from 'resize-detector'\n\n// enumerating ECharts events for now\nconst EVENTS = [\n 'legendselectchanged',\n 'legendselected',\n 'legendunselected',\n 'legendscroll',\n 'datazoom',\n 'datarangeselected',\n 'timelinechanged',\n 'timelineplaychanged',\n 'restore',\n 'dataviewchanged',\n 'magictypechanged',\n 'geoselectchanged',\n 'geoselected',\n 'geounselected',\n 'pieselectchanged',\n 'pieselected',\n 'pieunselected',\n 'mapselectchanged',\n 'mapselected',\n 'mapunselected',\n 'axisareaselected',\n 'focusnodeadjacency',\n 'unfocusnodeadjacency',\n 'brush',\n 'brushselected',\n 'rendered',\n 'finished',\n 'click',\n 'dblclick',\n 'mouseover',\n 'mouseout',\n 'mousemove',\n 'mousedown',\n 'mouseup',\n 'globalout',\n 'contextmenu'\n]\n\nconst INIT_TRIGGERS = ['theme', 'initOptions', 'autoresize']\nconst REWATCH_TRIGGERS = ['manualUpdate', 'watchShallow']\n\nexport default {\n props: {\n options: Object,\n theme: [String, Object],\n initOptions: Object,\n group: String,\n autoresize: Boolean,\n watchShallow: Boolean,\n manualUpdate: Boolean\n },\n data () {\n return {\n lastArea: 0\n }\n },\n watch: {\n group (group) {\n this.chart.group = group\n }\n },\n methods: {\n // provide a explicit merge option method\n mergeOptions (options, notMerge, lazyUpdate) {\n if (this.manualUpdate) {\n this.manualOptions = options\n }\n\n if (!this.chart) {\n this.init()\n } else {\n this.delegateMethod('setOption', options, notMerge, lazyUpdate)\n }\n },\n // just delegates ECharts methods to Vue component\n // use explicit params to reduce transpiled size for now\n appendData (params) {\n this.delegateMethod('appendData', params)\n },\n resize (options) {\n this.delegateMethod('resize', options)\n },\n dispatchAction (payload) {\n this.delegateMethod('dispatchAction', payload)\n },\n convertToPixel (finder, value) {\n return this.delegateMethod('convertToPixel', finder, value)\n },\n convertFromPixel (finder, value) {\n return this.delegateMethod('convertFromPixel', finder, value)\n },\n containPixel (finder, value) {\n return this.delegateMethod('containPixel', finder, value)\n },\n showLoading (type, options) {\n this.delegateMethod('showLoading', type, options)\n },\n hideLoading () {\n this.delegateMethod('hideLoading')\n },\n getDataURL (options) {\n return this.delegateMethod('getDataURL', options)\n },\n getConnectedDataURL (options) {\n return this.delegateMethod('getConnectedDataURL', options)\n },\n clear () {\n this.delegateMethod('clear')\n },\n dispose () {\n this.delegateMethod('dispose')\n },\n delegateMethod (name, ...args) {\n if (!this.chart) {\n this.init()\n }\n return this.chart[name](...args)\n },\n delegateGet (methodName) {\n if (!this.chart) {\n this.init()\n }\n return this.chart[methodName]()\n },\n getArea () {\n return this.$el.offsetWidth * this.$el.offsetHeight\n },\n init () {\n if (this.chart) {\n return\n }\n\n let chart = echarts.init(this.$el, this.theme, this.initOptions)\n\n if (this.group) {\n chart.group = this.group\n }\n\n chart.setOption(this.manualOptions || this.options || {}, true)\n\n // expose ECharts events as custom events\n EVENTS.forEach(event => {\n chart.on(event, params => {\n this.$emit(event, params)\n })\n })\n\n if (this.autoresize) {\n this.lastArea = this.getArea()\n this.__resizeHandler = debounce(() => {\n if (this.lastArea === 0) {\n // emulate initial render for initially hidden charts\n this.mergeOptions({}, true)\n this.resize()\n this.mergeOptions(this.options || this.manualOptions || {}, true)\n } else {\n this.resize()\n }\n this.lastArea = this.getArea()\n }, 100, { leading: true })\n addListener(this.$el, this.__resizeHandler)\n }\n\n Object.defineProperties(this, {\n // Only recalculated when accessed from JavaScript.\n // Won't update DOM on value change because getters\n // don't depend on reactive values\n width: {\n configurable: true,\n get: () => {\n return this.delegateGet('getWidth')\n }\n },\n height: {\n configurable: true,\n get: () => {\n return this.delegateGet('getHeight')\n }\n },\n isDisposed: {\n configurable: true,\n get: () => {\n return !!this.delegateGet('isDisposed')\n }\n },\n computedOptions: {\n configurable: true,\n get: () => {\n return this.delegateGet('getOption')\n }\n }\n })\n\n this.chart = chart\n },\n initOptionsWatcher () {\n if (this.__unwatchOptions) {\n this.__unwatchOptions()\n this.__unwatchOptions = null\n }\n\n if (!this.manualUpdate) {\n this.__unwatchOptions = this.$watch('options', (val, oldVal) => {\n if (!this.chart && val) {\n this.init()\n } else {\n // mutating `options` will lead to merging\n // replacing it with new reference will lead to not merging\n // eg.\n // `this.options = Object.assign({}, this.options, { ... })`\n // will trigger `this.chart.setOption(val, true)\n // `this.options.title.text = 'Trends'`\n // will trigger `this.chart.setOption(val, false)`\n this.chart.setOption(val, val !== oldVal)\n }\n }, { deep: !this.watchShallow })\n }\n },\n destroy () {\n if (this.autoresize) {\n removeListener(this.$el, this.__resizeHandler)\n }\n this.dispose()\n this.chart = null\n },\n refresh () {\n if (this.chart) {\n this.destroy()\n this.init()\n }\n }\n },\n created () {\n this.initOptionsWatcher()\n\n INIT_TRIGGERS.forEach(prop => {\n this.$watch(prop, () => {\n this.refresh()\n }, { deep: true })\n })\n\n REWATCH_TRIGGERS.forEach(prop => {\n this.$watch(prop, () => {\n this.initOptionsWatcher()\n this.refresh()\n })\n })\n },\n mounted () {\n // auto init if `options` is already provided\n if (this.options) {\n this.init()\n }\n },\n activated () {\n if (this.autoresize) {\n this.chart && this.chart.resize()\n }\n },\n beforeDestroy () {\n if (!this.chart) {\n return\n }\n this.destroy()\n },\n connect (group) {\n if (typeof group !== 'string') {\n group = group.map(chart => chart.chart)\n }\n echarts.connect(group)\n },\n disconnect (group) {\n echarts.disConnect(group)\n },\n registerMap (mapName, geoJSON, specialAreas) {\n echarts.registerMap(mapName, geoJSON, specialAreas)\n },\n registerTheme (name, theme) {\n echarts.registerTheme(name, theme)\n },\n graphic: echarts.graphic\n}\n</script>\n","import mod from \"-!../../cache-loader/dist/cjs.js??ref--12-0!../../thread-loader/dist/cjs.js!../../babel-loader/lib/index.js!../../cache-loader/dist/cjs.js??ref--0-0!../../vue-loader/lib/index.js??vue-loader-options!./ECharts.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../cache-loader/dist/cjs.js??ref--12-0!../../thread-loader/dist/cjs.js!../../babel-loader/lib/index.js!../../cache-loader/dist/cjs.js??ref--0-0!../../vue-loader/lib/index.js??vue-loader-options!./ECharts.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ECharts.vue?vue&type=template&id=65292532&\"\nimport script from \"./ECharts.vue?vue&type=script&lang=js&\"\nexport * from \"./ECharts.vue?vue&type=script&lang=js&\"\nimport style0 from \"./ECharts.vue?vue&type=style&index=0&lang=css&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{ref:\"calendar\",staticClass:\"mpvue-calendar\"},[(!_vm.isMonthRange)?_c('div',{staticClass:\"calendar-tools\"},[_c('div',{staticClass:\"calendar-prev\",on:{\"click\":_vm.prev}},[(!!_vm.arrowLeft)?_c('img',{attrs:{\"src\":_vm.arrowLeft}}):_c('i',{staticClass:\"iconfont icon-arrow-left\"})]),_c('div',{staticClass:\"calendar-next\",on:{\"click\":_vm.next}},[(!!_vm.arrowRight)?_c('img',{attrs:{\"src\":_vm.arrowRight}}):_c('i',{staticClass:\"iconfont icon-arrow-right\"})]),_c('div',{staticClass:\"calendar-info\",on:{\"click\":function($event){$event.stopPropagation();return _vm.changeYear($event)}}},[_c('div',{staticClass:\"mc-month\"},[(_vm.isIos)?_c('div',{class:['mc-month-inner', _vm.oversliding ? '' : 'month-transition'],style:({'top': _vm.monthPosition + _vm.unit})},_vm._l((_vm.monthsLoop),function(m,i){return _c('span',{key:i},[_vm._v(_vm._s(m))])}),0):_c('div',{staticClass:\"mc-month-text\"},[_vm._v(_vm._s(_vm.monthText))])]),_c('div',{staticClass:\"mc-year\"},[_vm._v(_vm._s(_vm.year))])])]):_vm._e(),_c('table',{attrs:{\"cellpadding\":\"5\"}},[_c('div',{staticClass:\"mc-head\",class:['mc-head', {'mc-month-range-mode-head': _vm.isMonthRange}]},[_c('div',{staticClass:\"mc-head-box\"},_vm._l((_vm.weeks),function(week,index){return _c('div',{key:index,staticClass:\"mc-week\"},[_vm._v(_vm._s(week))])}),0)]),_vm._l((_vm.monthRangeDays),function(days,index){return _c('div',{key:index,class:['mc-body', {'mc-range-mode': _vm.range, 'week-switch': _vm.weekSwitch && !_vm.isMonthRange, 'month-range-mode': _vm.isMonthRange}]},[(_vm.isMonthRange)?_c('div',{staticClass:\"month-rang-head\"},[_vm._v(_vm._s(_vm.rangeOfMonths[index][2]))]):_vm._e(),_vm._l((days),function(day,k1){return _c('tr',{key:k1,class:{'gregorianStyle': !_vm.lunar}},_vm._l((day),function(child,k2){return _c('td',{key:k2,staticClass:\"mc-day\",class:[{'selected': child.selected, 'mc-today-element': child.isToday, 'disabled': child.disabled, 'mc-range-select-one': _vm.rangeBgHide && child.selected, 'lunarStyle': _vm.lunar, 'mc-range-row-first': k2 === 0 && child.selected, 'month-last-date': child.lastDay, 'month-first-date': 1 === child.day, 'mc-range-row-last': k2 === 6 && child.selected, 'mc-last-month': child.lastMonth, 'mc-next-month': child.nextMonth}, child.className, child.rangeClassName],style:(_vm.itemStyle),on:{\"click\":function($event){return _vm.select(k1, k2, child, $event, index)}}},[(_vm.showToday.show && child.isToday)?_c('span',{staticClass:\"mc-today calendar-date\"},[_vm._v(_vm._s(_vm.showToday.text))]):_c('span',{class:[{'mc-date-red': k2 === (_vm.monFirst ? 5 : 0) || k2 === 6}, 'calendar-date']},[_vm._v(_vm._s(child.day))]),(!!child.content)?_c('div',{staticClass:\"slot-element\"},[_vm._v(_vm._s(child.content))]):_vm._e(),(child.eventName && !_vm.clean)?_c('div',{staticClass:\"mc-text remark-text\"},[_vm._v(_vm._s(child.eventName))]):_vm._e(),(child.eventName && _vm.clean)?_c('div',{staticClass:\"mc-dot\"}):_vm._e(),(_vm.lunar && (!child.eventName || _vm.clean))?_c('div',{staticClass:\"mc-text\",class:{'isLunarFestival': child.isAlmanac || child.isLunarFestival,'isGregorianFestival': child.isGregorianFestival,'isTerm': child.isTerm}},[_vm._v(_vm._s(child.almanac || child.lunar))]):_vm._e(),(_vm.range && child.selected)?_c('div',{staticClass:\"mc-range-bg\"}):_vm._e()])}),0)})],2)})],2),_c('div',{staticClass:\"mpvue-calendar-change\",class:{'show': _vm.yearsShow}},[(!_vm.weekSwitch)?_c('div',{staticClass:\"calendar-years\"},_vm._l((_vm.years),function(y){return _c('span',{key:y,class:{'active': y === _vm.year},on:{\"click\":function($event){$event.stopPropagation();return _vm.selectYear(y)}}},[_vm._v(_vm._s(y))])}),0):_vm._e(),_c('div',{class:['calendar-months', {'calendar-week-switch-months': _vm.weekSwitch}]},_vm._l((_vm.months),function(m,i){return _c('span',{key:m,class:{'active': i === _vm.month},on:{\"click\":function($event){$event.stopPropagation();return _vm.changeMonth(i)}}},[_vm._v(_vm._s(m))])}),0)])])}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import _Array$isArray from \"../../core-js/array/is-array\";\nexport default function _arrayWithHoles(arr) {\n if (_Array$isArray(arr)) return arr;\n}","import _getIterator from \"../../core-js/get-iterator\";\nexport default 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 = _getIterator(arr), _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}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n}","import arrayWithHoles from \"./arrayWithHoles\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit\";\nimport nonIterableRest from \"./nonIterableRest\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();\n}","/**\n * @1900-2100区间内的公历、农历互转\n * @charset UTF-8\n * @Author Jea杨(JJonline@JJonline.Cn)\n * @Time 2014-7-21\n * @Time 2016-8-13 Fixed 2033hex、Attribution Annals\n * @Time 2016-9-25 Fixed lunar LeapMonth Param Bug\n * @Version 1.0.2\n * @公历转农历:calendar.solar2lunar(1987,11,01); //[you can ignore params of prefix 0]\n * @农历转公历:calendar.lunar2solar(1987,09,10); //[you can ignore params of prefix 0]\n */\nvar calendar = {\n\n /**\n * 农历1900-2100的润大小信息表\n * @Array Of Property\n * @return Hex\n */\n lunarInfo:[0x04bd8,0x04ae0,0x0a570,0x054d5,0x0d260,0x0d950,0x16554,0x056a0,0x09ad0,0x055d2,//1900-1909\n 0x04ae0,0x0a5b6,0x0a4d0,0x0d250,0x1d255,0x0b540,0x0d6a0,0x0ada2,0x095b0,0x14977,//1910-1919\n 0x04970,0x0a4b0,0x0b4b5,0x06a50,0x06d40,0x1ab54,0x02b60,0x09570,0x052f2,0x04970,//1920-1929\n 0x06566,0x0d4a0,0x0ea50,0x06e95,0x05ad0,0x02b60,0x186e3,0x092e0,0x1c8d7,0x0c950,//1930-1939\n 0x0d4a0,0x1d8a6,0x0b550,0x056a0,0x1a5b4,0x025d0,0x092d0,0x0d2b2,0x0a950,0x0b557,//1940-1949\n 0x06ca0,0x0b550,0x15355,0x04da0,0x0a5b0,0x14573,0x052b0,0x0a9a8,0x0e950,0x06aa0,//1950-1959\n 0x0aea6,0x0ab50,0x04b60,0x0aae4,0x0a570,0x05260,0x0f263,0x0d950,0x05b57,0x056a0,//1960-1969\n 0x096d0,0x04dd5,0x04ad0,0x0a4d0,0x0d4d4,0x0d250,0x0d558,0x0b540,0x0b6a0,0x195a6,//1970-1979\n 0x095b0,0x049b0,0x0a974,0x0a4b0,0x0b27a,0x06a50,0x06d40,0x0af46,0x0ab60,0x09570,//1980-1989\n 0x04af5,0x04970,0x064b0,0x074a3,0x0ea50,0x06b58,0x055c0,0x0ab60,0x096d5,0x092e0,//1990-1999\n 0x0c960,0x0d954,0x0d4a0,0x0da50,0x07552,0x056a0,0x0abb7,0x025d0,0x092d0,0x0cab5,//2000-2009\n 0x0a950,0x0b4a0,0x0baa4,0x0ad50,0x055d9,0x04ba0,0x0a5b0,0x15176,0x052b0,0x0a930,//2010-2019\n 0x07954,0x06aa0,0x0ad50,0x05b52,0x04b60,0x0a6e6,0x0a4e0,0x0d260,0x0ea65,0x0d530,//2020-2029\n 0x05aa0,0x076a3,0x096d0,0x04afb,0x04ad0,0x0a4d0,0x1d0b6,0x0d250,0x0d520,0x0dd45,//2030-2039\n 0x0b5a0,0x056d0,0x055b2,0x049b0,0x0a577,0x0a4b0,0x0aa50,0x1b255,0x06d20,0x0ada0,//2040-2049\n /**Add By JJonline@JJonline.Cn**/\n 0x14b63,0x09370,0x049f8,0x04970,0x064b0,0x168a6,0x0ea50, 0x06b20,0x1a6c4,0x0aae0,//2050-2059\n 0x0a2e0,0x0d2e3,0x0c960,0x0d557,0x0d4a0,0x0da50,0x05d55,0x056a0,0x0a6d0,0x055d4,//2060-2069\n 0x052d0,0x0a9b8,0x0a950,0x0b4a0,0x0b6a6,0x0ad50,0x055a0,0x0aba4,0x0a5b0,0x052b0,//2070-2079\n 0x0b273,0x06930,0x07337,0x06aa0,0x0ad50,0x14b55,0x04b60,0x0a570,0x054e4,0x0d160,//2080-2089\n 0x0e968,0x0d520,0x0daa0,0x16aa6,0x056d0,0x04ae0,0x0a9d4,0x0a2d0,0x0d150,0x0f252,//2090-2099\n 0x0d520],//2100\n\n /**\n * 公历每个月份的天数普通表\n * @Array Of Property\n * @return Number\n */\n solarMonth:[31,28,31,30,31,30,31,31,30,31,30,31],\n\n /**\n * 天干地支之天干速查表\n * @Array Of Property trans[\"甲\",\"乙\",\"丙\",\"丁\",\"戊\",\"己\",\"庚\",\"辛\",\"壬\",\"癸\"]\n * @return Cn string\n */\n Gan:[\"\\u7532\",\"\\u4e59\",\"\\u4e19\",\"\\u4e01\",\"\\u620a\",\"\\u5df1\",\"\\u5e9a\",\"\\u8f9b\",\"\\u58ec\",\"\\u7678\"],\n\n /**\n * 天干地支之地支速查表\n * @Array Of Property\n * @trans[\"子\",\"丑\",\"寅\",\"卯\",\"辰\",\"巳\",\"午\",\"未\",\"申\",\"酉\",\"戌\",\"亥\"]\n * @return Cn string\n */\n Zhi:[\"\\u5b50\",\"\\u4e11\",\"\\u5bc5\",\"\\u536f\",\"\\u8fb0\",\"\\u5df3\",\"\\u5348\",\"\\u672a\",\"\\u7533\",\"\\u9149\",\"\\u620c\",\"\\u4ea5\"],\n\n /**\n * 天干地支之地支速查表<=>生肖\n * @Array Of Property\n * @trans[\"鼠\",\"牛\",\"虎\",\"兔\",\"龙\",\"蛇\",\"马\",\"羊\",\"猴\",\"鸡\",\"狗\",\"猪\"]\n * @return Cn string\n */\n Animals:[\"\\u9f20\",\"\\u725b\",\"\\u864e\",\"\\u5154\",\"\\u9f99\",\"\\u86c7\",\"\\u9a6c\",\"\\u7f8a\",\"\\u7334\",\"\\u9e21\",\"\\u72d7\",\"\\u732a\"],\n\n /**\n * 24节气速查表\n * @Array Of Property\n * @trans[\"小寒\",\"大寒\",\"立春\",\"雨水\",\"惊蛰\",\"春分\",\"清明\",\"谷雨\",\"立夏\",\"小满\",\"芒种\",\"夏至\",\"小暑\",\"大暑\",\"立秋\",\"处暑\",\"白露\",\"秋分\",\"寒露\",\"霜降\",\"立冬\",\"小雪\",\"大雪\",\"冬至\"]\n * @return Cn string\n */\n solarTerm:[\"\\u5c0f\\u5bd2\",\"\\u5927\\u5bd2\",\"\\u7acb\\u6625\",\"\\u96e8\\u6c34\",\"\\u60ca\\u86f0\",\"\\u6625\\u5206\",\"\\u6e05\\u660e\",\"\\u8c37\\u96e8\",\"\\u7acb\\u590f\",\"\\u5c0f\\u6ee1\",\"\\u8292\\u79cd\",\"\\u590f\\u81f3\",\"\\u5c0f\\u6691\",\"\\u5927\\u6691\",\"\\u7acb\\u79cb\",\"\\u5904\\u6691\",\"\\u767d\\u9732\",\"\\u79cb\\u5206\",\"\\u5bd2\\u9732\",\"\\u971c\\u964d\",\"\\u7acb\\u51ac\",\"\\u5c0f\\u96ea\",\"\\u5927\\u96ea\",\"\\u51ac\\u81f3\"],\n\n /**\n * 1900-2100各年的24节气日期速查表\n * @Array Of Property\n * @return 0x string For splice\n */\n sTermInfo:['9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e','97bcf97c3598082c95f8c965cc920f',\n '97bd0b06bdb0722c965ce1cfcc920f','b027097bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e',\n '97bcf97c359801ec95f8c965cc920f','97bd0b06bdb0722c965ce1cfcc920f','b027097bd097c36b0b6fc9274c91aa',\n '97b6b97bd19801ec9210c965cc920e','97bcf97c359801ec95f8c965cc920f','97bd0b06bdb0722c965ce1cfcc920f',\n 'b027097bd097c36b0b6fc9274c91aa','9778397bd19801ec9210c965cc920e','97b6b97bd19801ec95f8c965cc920f',\n '97bd09801d98082c95f8e1cfcc920f','97bd097bd097c36b0b6fc9210c8dc2','9778397bd197c36c9210c9274c91aa',\n '97b6b97bd19801ec95f8c965cc920e','97bd09801d98082c95f8e1cfcc920f','97bd097bd097c36b0b6fc9210c8dc2',\n '9778397bd097c36c9210c9274c91aa','97b6b97bd19801ec95f8c965cc920e','97bcf97c3598082c95f8e1cfcc920f',\n '97bd097bd097c36b0b6fc9210c8dc2','9778397bd097c36c9210c9274c91aa','97b6b97bd19801ec9210c965cc920e',\n '97bcf97c3598082c95f8c965cc920f','97bd097bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',\n '97b6b97bd19801ec9210c965cc920e','97bcf97c3598082c95f8c965cc920f','97bd097bd097c35b0b6fc920fb0722',\n '9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e','97bcf97c359801ec95f8c965cc920f',\n '97bd097bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e',\n '97bcf97c359801ec95f8c965cc920f','97bd097bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',\n '97b6b97bd19801ec9210c965cc920e','97bcf97c359801ec95f8c965cc920f','97bd097bd07f595b0b6fc920fb0722',\n '9778397bd097c36b0b6fc9210c8dc2','9778397bd19801ec9210c9274c920e','97b6b97bd19801ec95f8c965cc920f',\n '97bd07f5307f595b0b0bc920fb0722','7f0e397bd097c36b0b6fc9210c8dc2','9778397bd097c36c9210c9274c920e',\n '97b6b97bd19801ec95f8c965cc920f','97bd07f5307f595b0b0bc920fb0722','7f0e397bd097c36b0b6fc9210c8dc2',\n '9778397bd097c36c9210c9274c91aa','97b6b97bd19801ec9210c965cc920e','97bd07f1487f595b0b0bc920fb0722',\n '7f0e397bd097c36b0b6fc9210c8dc2','9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e',\n '97bcf7f1487f595b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',\n '97b6b97bd19801ec9210c965cc920e','97bcf7f1487f595b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722',\n '9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e','97bcf7f1487f531b0b0bb0b6fb0722',\n '7f0e397bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e',\n '97bcf7f1487f531b0b0bb0b6fb0722','7f0e397bd07f595b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',\n '97b6b97bd19801ec9210c9274c920e','97bcf7f0e47f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722',\n '9778397bd097c36b0b6fc9210c91aa','97b6b97bd197c36c9210c9274c920e','97bcf7f0e47f531b0b0bb0b6fb0722',\n '7f0e397bd07f595b0b0bc920fb0722','9778397bd097c36b0b6fc9210c8dc2','9778397bd097c36c9210c9274c920e',\n '97b6b7f0e47f531b0723b0b6fb0722','7f0e37f5307f595b0b0bc920fb0722','7f0e397bd097c36b0b6fc9210c8dc2',\n '9778397bd097c36b0b70c9274c91aa','97b6b7f0e47f531b0723b0b6fb0721','7f0e37f1487f595b0b0bb0b6fb0722',\n '7f0e397bd097c35b0b6fc9210c8dc2','9778397bd097c36b0b6fc9274c91aa','97b6b7f0e47f531b0723b0b6fb0721',\n '7f0e27f1487f595b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',\n '97b6b7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722',\n '9778397bd097c36b0b6fc9274c91aa','97b6b7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722',\n '7f0e397bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa','97b6b7f0e47f531b0723b0b6fb0721',\n '7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722','9778397bd097c36b0b6fc9274c91aa',\n '97b6b7f0e47f531b0723b0787b0721','7f0e27f0e47f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722',\n '9778397bd097c36b0b6fc9210c91aa','97b6b7f0e47f149b0723b0787b0721','7f0e27f0e47f531b0723b0b6fb0722',\n '7f0e397bd07f595b0b0bc920fb0722','9778397bd097c36b0b6fc9210c8dc2','977837f0e37f149b0723b0787b0721',\n '7f07e7f0e47f531b0723b0b6fb0722','7f0e37f5307f595b0b0bc920fb0722','7f0e397bd097c35b0b6fc9210c8dc2',\n '977837f0e37f14998082b0787b0721','7f07e7f0e47f531b0723b0b6fb0721','7f0e37f1487f595b0b0bb0b6fb0722',\n '7f0e397bd097c35b0b6fc9210c8dc2','977837f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721',\n '7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722','977837f0e37f14998082b0787b06bd',\n '7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722',\n '977837f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722',\n '7f0e397bd07f595b0b0bc920fb0722','977837f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721',\n '7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722','977837f0e37f14998082b0787b06bd',\n '7f07e7f0e47f149b0723b0787b0721','7f0e27f0e47f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722',\n '977837f0e37f14998082b0723b06bd','7f07e7f0e37f149b0723b0787b0721','7f0e27f0e47f531b0723b0b6fb0722',\n '7f0e397bd07f595b0b0bc920fb0722','977837f0e37f14898082b0723b02d5','7ec967f0e37f14998082b0787b0721',\n '7f07e7f0e47f531b0723b0b6fb0722','7f0e37f1487f595b0b0bb0b6fb0722','7f0e37f0e37f14898082b0723b02d5',\n '7ec967f0e37f14998082b0787b0721','7f07e7f0e47f531b0723b0b6fb0722','7f0e37f1487f531b0b0bb0b6fb0722',\n '7f0e37f0e37f14898082b0723b02d5','7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721',\n '7f0e37f1487f531b0b0bb0b6fb0722','7f0e37f0e37f14898082b072297c35','7ec967f0e37f14998082b0787b06bd',\n '7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722','7f0e37f0e37f14898082b072297c35',\n '7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722',\n '7f0e37f0e366aa89801eb072297c35','7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f149b0723b0787b0721',\n '7f0e27f1487f531b0b0bb0b6fb0722','7f0e37f0e366aa89801eb072297c35','7ec967f0e37f14998082b0723b06bd',\n '7f07e7f0e47f149b0723b0787b0721','7f0e27f0e47f531b0723b0b6fb0722','7f0e37f0e366aa89801eb072297c35',\n '7ec967f0e37f14998082b0723b06bd','7f07e7f0e37f14998083b0787b0721','7f0e27f0e47f531b0723b0b6fb0722',\n '7f0e37f0e366aa89801eb072297c35','7ec967f0e37f14898082b0723b02d5','7f07e7f0e37f14998082b0787b0721',\n '7f07e7f0e47f531b0723b0b6fb0722','7f0e36665b66aa89801e9808297c35','665f67f0e37f14898082b0723b02d5',\n '7ec967f0e37f14998082b0787b0721','7f07e7f0e47f531b0723b0b6fb0722','7f0e36665b66a449801e9808297c35',\n '665f67f0e37f14898082b0723b02d5','7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721',\n '7f0e36665b66a449801e9808297c35','665f67f0e37f14898082b072297c35','7ec967f0e37f14998082b0787b06bd',\n '7f07e7f0e47f531b0723b0b6fb0721','7f0e26665b66a449801e9808297c35','665f67f0e37f1489801eb072297c35',\n '7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722'],\n\n /**\n * 数字转中文速查表\n * @Array Of Property\n * @trans ['日','一','二','三','四','五','六','七','八','九','十']\n * @return Cn string\n */\n nStr1:[\"\\u65e5\",\"\\u4e00\",\"\\u4e8c\",\"\\u4e09\",\"\\u56db\",\"\\u4e94\",\"\\u516d\",\"\\u4e03\",\"\\u516b\",\"\\u4e5d\",\"\\u5341\"],\n\n /**\n * 日期转农历称呼速查表\n * @Array Of Property\n * @trans ['初','十','廿','卅']\n * @return Cn string\n */\n nStr2:[\"\\u521d\",\"\\u5341\",\"\\u5eff\",\"\\u5345\"],\n\n /**\n * 月份转农历称呼速查表\n * @Array Of Property\n * @trans ['正','一','二','三','四','五','六','七','八','九','十','冬','腊']\n * @return Cn string\n */\n nStr3:[\"\\u6b63\",\"\\u4e8c\",\"\\u4e09\",\"\\u56db\",\"\\u4e94\",\"\\u516d\",\"\\u4e03\",\"\\u516b\",\"\\u4e5d\",\"\\u5341\",\"\\u51ac\",\"\\u814a\"],\n\n /**\n * 返回农历y年一整年的总天数\n * @param lunar Year\n * @return Number\n * @eg:var count = calendar.lYearDays(1987) ;//count=387\n */\n lYearDays:function(y) {\n var i, sum = 348;\n for(i=0x8000; i>0x8; i>>=1) { sum += (calendar.lunarInfo[y-1900] & i)? 1: 0; }\n return(sum+calendar.leapDays(y));\n },\n\n /**\n * 返回农历y年闰月是哪个月;若y年没有闰月 则返回0\n * @param lunar Year\n * @return Number (0-12)\n * @eg:var leapMonth = calendar.leapMonth(1987) ;//leapMonth=6\n */\n leapMonth:function(y) { //闰字编码 \\u95f0\n return(calendar.lunarInfo[y-1900] & 0xf);\n },\n\n /**\n * 返回农历y年闰月的天数 若该年没有闰月则返回0\n * @param lunar Year\n * @return Number (0、29、30)\n * @eg:var leapMonthDay = calendar.leapDays(1987) ;//leapMonthDay=29\n */\n leapDays:function(y) {\n if(calendar.leapMonth(y)) {\n return((calendar.lunarInfo[y-1900] & 0x10000)? 30: 29);\n }\n return(0);\n },\n\n /**\n * 返回农历y年m月(非闰月)的总天数,计算m为闰月时的天数请使用leapDays方法\n * @param lunar Year\n * @return Number (-1、29、30)\n * @eg:var MonthDay = calendar.monthDays(1987,9) ;//MonthDay=29\n */\n monthDays:function(y,m) {\n if(m>12 || m<1) {return -1}//月份参数从1至12,参数错误返回-1\n return( (calendar.lunarInfo[y-1900] & (0x10000>>m))? 30: 29 );\n },\n\n /**\n * 返回公历(!)y年m月的天数\n * @param solar Year\n * @return Number (-1、28、29、30、31)\n * @eg:var solarMonthDay = calendar.leapDays(1987) ;//solarMonthDay=30\n */\n solarDays:function(y,m) {\n if(m>12 || m<1) {return -1} //若参数错误 返回-1\n var ms = m-1;\n if(ms==1) { //2月份的闰平规律测算后确认返回28或29\n return(((y%4 == 0) && (y%100 != 0) || (y%400 == 0))? 29: 28);\n }else {\n return(calendar.solarMonth[ms]);\n }\n },\n\n /**\n * 农历年份转换为干支纪年\n * @param lYear 农历年的年份数\n * @return Cn string\n */\n toGanZhiYear:function(lYear) {\n var ganKey = (lYear - 3) % 10;\n var zhiKey = (lYear - 3) % 12;\n if(ganKey == 0) ganKey = 10;//如果余数为0则为最后一个天干\n if(zhiKey == 0) zhiKey = 12;//如果余数为0则为最后一个地支\n return calendar.Gan[ganKey-1] + calendar.Zhi[zhiKey-1];\n\n },\n\n /**\n * 公历月、日判断所属星座\n * @param cMonth [description]\n * @param cDay [description]\n * @return Cn string\n */\n toAstro:function(cMonth,cDay) {\n var s = \"\\u9b54\\u7faf\\u6c34\\u74f6\\u53cc\\u9c7c\\u767d\\u7f8a\\u91d1\\u725b\\u53cc\\u5b50\\u5de8\\u87f9\\u72ee\\u5b50\\u5904\\u5973\\u5929\\u79e4\\u5929\\u874e\\u5c04\\u624b\\u9b54\\u7faf\";\n var arr = [20,19,21,21,21,22,23,23,23,23,22,22];\n return s.substr(cMonth*2 - (cDay < arr[cMonth-1] ? 2 : 0),2) + \"\\u5ea7\";//座\n },\n\n /**\n * 传入offset偏移量返回干支\n * @param offset 相对甲子的偏移量\n * @return Cn string\n */\n toGanZhi:function(offset) {\n return calendar.Gan[offset%10] + calendar.Zhi[offset%12];\n },\n\n /**\n * 传入公历(!)y年获得该年第n个节气的公历日期\n * @param y公历年(1900-2100);n二十四节气中的第几个节气(1~24);从n=1(小寒)算起\n * @return day Number\n * @eg:var _24 = calendar.getTerm(1987,3) ;//_24=4;意即1987年2月4日立春\n */\n getTerm:function(y,n) {\n if(y<1900 || y>2100) {return -1;}\n if(n<1 || n>24) {return -1;}\n var _table = calendar.sTermInfo[y-1900];\n var _info = [\n parseInt('0x'+_table.substr(0,5)).toString() ,\n parseInt('0x'+_table.substr(5,5)).toString(),\n parseInt('0x'+_table.substr(10,5)).toString(),\n parseInt('0x'+_table.substr(15,5)).toString(),\n parseInt('0x'+_table.substr(20,5)).toString(),\n parseInt('0x'+_table.substr(25,5)).toString()\n ];\n var _calday = [\n _info[0].substr(0,1),\n _info[0].substr(1,2),\n _info[0].substr(3,1),\n _info[0].substr(4,2),\n\n _info[1].substr(0,1),\n _info[1].substr(1,2),\n _info[1].substr(3,1),\n _info[1].substr(4,2),\n\n _info[2].substr(0,1),\n _info[2].substr(1,2),\n _info[2].substr(3,1),\n _info[2].substr(4,2),\n\n _info[3].substr(0,1),\n _info[3].substr(1,2),\n _info[3].substr(3,1),\n _info[3].substr(4,2),\n\n _info[4].substr(0,1),\n _info[4].substr(1,2),\n _info[4].substr(3,1),\n _info[4].substr(4,2),\n\n _info[5].substr(0,1),\n _info[5].substr(1,2),\n _info[5].substr(3,1),\n _info[5].substr(4,2),\n ];\n return parseInt(_calday[n-1]);\n },\n\n /**\n * 传入农历数字月份返回汉语通俗表示法\n * @param lunar month\n * @return Cn string\n * @eg:var cnMonth = calendar.toChinaMonth(12) ;//cnMonth='腊月'\n */\n toChinaMonth:function(m) { // 月 => \\u6708\n if(m>12 || m<1) {return -1} //若参数错误 返回-1\n var s = calendar.nStr3[m-1];\n s+= \"\\u6708\";//加上月字\n return s;\n },\n\n /**\n * 传入农历日期数字返回汉字表示法\n * @param lunar day\n * @return Cn string\n * @eg:var cnDay = calendar.toChinaDay(21) ;//cnMonth='廿一'\n */\n toChinaDay:function(d){ //日 => \\u65e5\n var s;\n switch (d) {\n case 10:\n s = '\\u521d\\u5341'; break;\n case 20:\n s = '\\u4e8c\\u5341'; break;\n break;\n case 30:\n s = '\\u4e09\\u5341'; break;\n break;\n default :\n s = calendar.nStr2[Math.floor(d/10)];\n s += calendar.nStr1[d%10];\n }\n return(s);\n },\n\n /**\n * 年份转生肖[!仅能大致转换] => 精确划分生肖分界线是“立春”\n * @param y year\n * @return Cn string\n * @eg:var animal = calendar.getAnimal(1987) ;//animal='兔'\n */\n getAnimal: function(y) {\n return calendar.Animals[(y - 4) % 12]\n },\n\n /**\n * 传入阳历年月日获得详细的公历、农历object信息 <=>JSON\n * @param y solar year\n * @param m solar month\n * @param d solar day\n * @return JSON object\n * @eg:console.log(calendar.solar2lunar(1987,11,01));\n */\n solar2lunar:function (y,m,d) { //参数区间1900.1.31~2100.12.31\n if(y<1900 || y>2100) {return -1;}//年份限定、上限\n if(y==1900&&m==1&&d<31) {return -1;}//下限\n if(!y) { //未传参 获得当天\n var objDate = new Date();\n }else {\n var objDate = new Date(y,parseInt(m)-1,d)\n }\n var i, leap=0, temp=0;\n //修正ymd参数\n var y = objDate.getFullYear(),m = objDate.getMonth()+1,d = objDate.getDate();\n var offset = (Date.UTC(objDate.getFullYear(),objDate.getMonth(),objDate.getDate()) - Date.UTC(1900,0,31))/86400000;\n for(i=1900; i<2101 && offset>0; i++) { temp=calendar.lYearDays(i); offset-=temp; }\n if(offset<0) { offset+=temp; i--; }\n\n //是否今天\n var isTodayObj = new Date(),isToday=false;\n if(isTodayObj.getFullYear()==y && isTodayObj.getMonth()+1==m && isTodayObj.getDate()==d) {\n isToday = true;\n }\n //星期几\n var nWeek = objDate.getDay(),cWeek = calendar.nStr1[nWeek];\n if(nWeek==0) {nWeek =7;}//数字表示周几顺应天朝周一开始的惯例\n //农历年\n var year = i;\n\n var leap = calendar.leapMonth(i); //闰哪个月\n var isLeap = false;\n\n //效验闰月\n for(i=1; i<13 && offset>0; i++) {\n //闰月\n if(leap>0 && i==(leap+1) && isLeap==false){\n --i;\n isLeap = true; temp = calendar.leapDays(year); //计算农历闰月天数\n }\n else{\n temp = calendar.monthDays(year, i);//计算农历普通月天数\n }\n //解除闰月\n if(isLeap==true && i==(leap+1)) { isLeap = false; }\n offset -= temp;\n }\n\n if(offset==0 && leap>0 && i==leap+1)\n if(isLeap){\n isLeap = false;\n }else{\n isLeap = true; --i;\n }\n if(offset<0){ offset += temp; --i; }\n //农历月\n var month = i;\n //农历日\n var day = offset + 1;\n\n //天干地支处理\n var sm = m-1;\n var gzY = calendar.toGanZhiYear(year);\n\n //月柱 1900年1月小寒以前为 丙子月(60进制12)\n var firstNode = calendar.getTerm(year,(m*2-1));//返回当月「节」为几日开始\n var secondNode = calendar.getTerm(year,(m*2));//返回当月「节」为几日开始\n\n //依据12节气修正干支月\n var gzM = calendar.toGanZhi((y-1900)*12+m+11);\n if(d>=firstNode) {\n gzM = calendar.toGanZhi((y-1900)*12+m+12);\n }\n\n //传入的日期的节气与否\n var isTerm = false;\n var Term = null;\n if(firstNode==d) {\n isTerm = true;\n Term = calendar.solarTerm[m*2-2];\n }\n if(secondNode==d) {\n isTerm = true;\n Term = calendar.solarTerm[m*2-1];\n }\n //日柱 当月一日与 1900/1/1 相差天数\n var dayCyclical = Date.UTC(y,sm,1,0,0,0,0)/86400000+25567+10;\n var gzD = calendar.toGanZhi(dayCyclical+d-1);\n //该日期所属的星座\n var astro = calendar.toAstro(m,d);\n\n return {'lYear':year,'lMonth':month,'lDay':day,'Animal':calendar.getAnimal(year),'IMonthCn':(isLeap?\"\\u95f0\":'')+calendar.toChinaMonth(month),'IDayCn':calendar.toChinaDay(day),'cYear':y,'cMonth':m,'cDay':d,'gzYear':gzY,'gzMonth':gzM,'gzDay':gzD,'isToday':isToday,'isLeap':isLeap,'nWeek':nWeek,'ncWeek':\"\\u661f\\u671f\"+cWeek,'isTerm':isTerm,'Term':Term,'astro':astro};\n },\n\n /**\n * 传入农历年月日以及传入的月份是否闰月获得详细的公历、农历object信息 <=>JSON\n * @param y lunar year\n * @param m lunar month\n * @param d lunar day\n * @param isLeapMonth lunar month is leap or not.[如果是农历闰月第四个参数赋值true即可]\n * @return JSON object\n * @eg:console.log(calendar.lunar2solar(1987,9,10));\n */\n lunar2solar:function(y,m,d,isLeapMonth) { //参数区间1900.1.31~2100.12.1\n var isLeapMonth = !!isLeapMonth;\n var leapOffset = 0;\n var leapMonth = calendar.leapMonth(y);\n var leapDay = calendar.leapDays(y);\n if(isLeapMonth&&(leapMonth!=m)) {return -1;}//传参要求计算该闰月公历 但该年得出的闰月与传参的月份并不同\n if(y==2100&&m==12&&d>1 || y==1900&&m==1&&d<31) {return -1;}//超出了最大极限值\n var day = calendar.monthDays(y,m);\n var _day = day;\n //bugFix 2016-9-25\n //if month is leap, _day use leapDays method\n if(isLeapMonth) {\n _day = calendar.leapDays(y,m);\n }\n if(y < 1900 || y > 2100 || d > _day) {return -1;}//参数合法性效验\n\n //计算农历的时间差\n var offset = 0;\n for(var i=1900;i<y;i++) {\n offset+=calendar.lYearDays(i);\n }\n var leap = 0,isAdd= false;\n for(var i=1;i<m;i++) {\n leap = calendar.leapMonth(y);\n if(!isAdd) {//处理闰月\n if(leap<=i && leap>0) {\n offset+=calendar.leapDays(y);isAdd = true;\n }\n }\n offset+=calendar.monthDays(y,i);\n }\n //转换闰月农历 需补充该年闰月的前一个月的时差\n if(isLeapMonth) {offset+=day;}\n //1900年农历正月一日的公历时间为1900年1月30日0时0分0秒(该时间也是本农历的最开始起始点)\n var stmap = Date.UTC(1900,1,30,0,0,0);\n var calObj = new Date((offset+d-31)*86400000+stmap);\n var cY = calObj.getUTCFullYear();\n var cM = calObj.getUTCMonth()+1;\n var cD = calObj.getUTCDate();\n\n return calendar.solar2lunar(cY,cM,cD);\n }\n};\n\nexport default calendar\n","<template>\n <div class=\"mpvue-calendar\" ref=\"calendar\">\n <div class=\"calendar-tools\" v-if=\"!isMonthRange\">\n <div class=\"calendar-prev\" @click=\"prev\">\n <img :src=\"arrowLeft\" v-if=\"!!arrowLeft\">\n <i class=\"iconfont icon-arrow-left\" v-else></i>\n </div>\n <div class=\"calendar-next\" @click=\"next\">\n <img :src=\"arrowRight\" v-if=\"!!arrowRight\">\n <i class=\"iconfont icon-arrow-right\" v-else></i>\n </div>\n <div class=\"calendar-info\" @click.stop=\"changeYear\">\n <div class=\"mc-month\">\n <div :class=\"['mc-month-inner', oversliding ? '' : 'month-transition']\" :style=\"{'top': monthPosition + unit}\" v-if=\"isIos\">\n <span v-for=\"(m, i) in monthsLoop\" :key=\"i\" >{{m}}</span>\n </div>\n <div class=\"mc-month-text\" v-else>{{monthText}}</div>\n </div>\n <div class=\"mc-year\">{{year}}</div>\n </div>\n </div>\n <table cellpadding=\"5\">\n <div class=\"mc-head\" :class=\"['mc-head', {'mc-month-range-mode-head': isMonthRange}]\">\n <div class=\"mc-head-box\">\n <div v-for=\"(week, index) in weeks\" :key=\"index\" class=\"mc-week\">{{week}}</div>\n </div>\n </div>\n <div :class=\"['mc-body', {'mc-range-mode': range, 'week-switch': weekSwitch && !isMonthRange, 'month-range-mode': isMonthRange}]\" v-for=\"(days, index) in monthRangeDays\" :key='index'>\n <div class=\"month-rang-head\" v-if=\"isMonthRange\">{{rangeOfMonths[index][2]}}</div>\n <tr v-for=\"(day,k1) in days\" :key=\"k1\" :class=\"{'gregorianStyle': !lunar}\">\n <td v-for=\"(child,k2) in day\" :key=\"k2\" :class=\"[{'selected': child.selected, 'mc-today-element': child.isToday, 'disabled': child.disabled, 'mc-range-select-one': rangeBgHide && child.selected, 'lunarStyle': lunar, 'mc-range-row-first': k2 === 0 && child.selected, 'month-last-date': child.lastDay, 'month-first-date': 1 === child.day, 'mc-range-row-last': k2 === 6 && child.selected, 'mc-last-month': child.lastMonth, 'mc-next-month': child.nextMonth}, child.className, child.rangeClassName]\" @click=\"select(k1, k2, child, $event, index)\" class=\"mc-day\" :style=\"itemStyle\">\n <span v-if=\"showToday.show && child.isToday\" class=\"mc-today calendar-date\">{{showToday.text}}</span>\n <span :class=\"[{'mc-date-red': k2 === (monFirst ? 5 : 0) || k2 === 6}, 'calendar-date']\" v-else>{{child.day}}</span>\n <div class=\"slot-element\" v-if=\"!!child.content\">{{child.content}}</div>\n <div class=\"mc-text remark-text\" v-if=\"child.eventName && !clean\">{{child.eventName}}</div>\n <div class=\"mc-dot\" v-if=\"child.eventName && clean\"></div>\n <div class=\"mc-text\" :class=\"{'isLunarFestival': child.isAlmanac || child.isLunarFestival,'isGregorianFestival': child.isGregorianFestival,'isTerm': child.isTerm}\" v-if=\"lunar && (!child.eventName || clean)\">{{child.almanac || child.lunar}}</div>\n <div class=\"mc-range-bg\" v-if=\"range && child.selected\"/>\n </td>\n </tr>\n </div>\n </table>\n <div class=\"mpvue-calendar-change\" :class=\"{'show': yearsShow}\">\n <div class=\"calendar-years\" v-if=\"!weekSwitch\">\n <span v-for=\"y in years\" :key=\"y\" @click.stop=\"selectYear(y)\" :class=\"{'active': y === year}\">{{y}}</span>\n </div>\n <div :class=\"['calendar-months', {'calendar-week-switch-months': weekSwitch}]\">\n <span v-for=\"(m, i) in months\" :key=\"m\" @click.stop=\"changeMonth(i)\" :class=\"{'active': i === month}\">{{m}}</span>\n </div>\n </div>\n </div>\n</template>\n\n<script>\n import calendar from './calendarinit.js';\n import './icon.css';\n const isBrowser = !!window;\n const now = new Date();\n const todayString = [now.getFullYear(), now.getMonth() + 1, now.getDate()].join('-');\n export default {\n props: {\n multi: {\n type: Boolean,\n default: false\n },\n arrowLeft: {\n type: String,\n default: ''\n },\n arrowRight: {\n type: String,\n default: ''\n },\n clean: {\n type: Boolean,\n default: false\n },\n now: {\n type: [String, Boolean],\n default: true\n },\n range:{\n type: Boolean,\n default: false\n },\n completion:{\n type: Boolean,\n default: false\n },\n value: {\n type: Array,\n default: function(){\n return []\n }\n },\n begin: {\n type: Array,\n default: function(){\n return []\n }\n },\n end: {\n type: Array,\n default: function(){\n return []\n }\n },\n zero:{\n type: Boolean,\n default: false\n },\n disabled:{\n type: Array,\n default: function(){\n return []\n }\n },\n almanacs:{\n type: Object,\n default: function(){\n return {}\n }\n },\n tileContent:{\n type: Array,\n default: function(){\n return []\n }\n },\n lunar: {\n type: Boolean,\n default: false\n },\n monFirst: {\n type: Boolean,\n default: false\n },\n weeks: {\n type: Array,\n default:function(){\n return this.monFirst ? ['一', '二', '三', '四', '五', '六', '日'] : ['日', '一', '二', '三', '四', '五', '六']\n }\n },\n months:{\n type: Array,\n default:function(){\n return ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月']\n }\n },\n events: {\n type: Object,\n default: function(){\n return {}\n }\n },\n weekSwitch: {\n type: Boolean,\n default: false\n },\n monthRange: {\n type: Array,\n default: function(){\n return []\n }\n },\n responsive: {\n type: Boolean,\n default: false\n },\n rangeMonthFormat: {\n type: String,\n default: ''\n }\n },\n data() {\n return {\n years:[],\n yearsShow:false,\n year: 0,\n month: 0,\n monthPosition: 0,\n day: 0,\n days: [],\n multiDays:[],\n today: [],\n handleMultiDay: [],\n firstRender: true,\n isIos: true,\n showToday: {},\n monthText: '',\n festival:{\n lunar:{\n \"1-1\":\"春节\",\n \"1-15\":\"元宵节\",\n \"2-2\":\"龙头节\",\n \"5-5\":\"端午节\",\n \"7-7\":\"七夕节\",\n \"7-15\":\"中元节\",\n \"8-15\":\"中秋节\",\n \"9-9\":\"重阳节\",\n \"10-1\":\"寒衣节\",\n \"10-15\":\"下元节\",\n \"12-8\":\"腊八节\",\n \"12-23\":\"小年\",\n },\n gregorian:{\n \"1-1\":\"元旦\",\n \"2-14\":\"情人节\",\n \"3-8\":\"妇女节\",\n \"3-12\":\"植树节\",\n \"5-1\":\"劳动节\",\n \"5-4\":\"青年节\",\n \"6-1\":\"儿童节\",\n \"7-1\":\"建党节\",\n \"8-1\":\"建军节\",\n \"9-10\":\"教师节\",\n \"10-1\":\"国庆节\",\n \"12-24\":\"平安夜\",\n \"12-25\":\"圣诞节\",\n },\n },\n rangeBegin: [],\n rangeEnd: [],\n multiDaysData: [],\n monthsLoop: [],\n itemWidth: 50,\n unit: isBrowser ? 'px' : 'rpx',\n positionH: isBrowser ? -24 : -40,\n monthIndex: 0,\n oversliding: false,\n rangeBgHide: false,\n monthRangeDays: [],\n rangeOfMonths: [],\n monthDays: [],\n weekIndex: 0,\n startWeekIndex: 0,\n positionWeek: true,\n isMonthRange: false,\n }\n },\n computed: {\n itemStyle() {\n return {width: this.itemWidth + 'px', height: this.itemWidth + 'px', fontSize: this.itemWidth / 4 + 'px', lineHeight: this.lunar ? (this.itemWidth / 1.5 + 'px') : (this.itemWidth + 'px')}\n }\n },\n watch:{\n events() {\n if (this.isRendeRangeMode()) return;\n this.render(this.year, this.month, '_WATCHRENDER_', 'events');\n },\n disabled() {\n if (this.isRendeRangeMode()) return;\n this.render(this.year, this.month, '_WATCHRENDER_', 'disabled');\n },\n value() {\n if (this.isRendeRangeMode('_WATCHRENDERVALUE_')) return;\n const value = this.value;\n let year = value[0], month = value[1] - 1;\n if (this.multi) {\n year = value[value.length - 1][0];\n month = value[value.length - 1][1] - 1;\n } else if (this.range) {\n if (this.isUserSelect) {\n year = this.year;\n month = this.month;\n this.isUserSelect = false;\n } else {\n year = value[0][0];\n month = value[0][1] - 1;\n const day = value[0][2];\n return this.render(year, month, '_WATCHRENDERVALUE_', [year, month, day]);\n }\n }\n this.render(year, month, '_WATCHRENDERVALUE_');\n },\n tileContent() {\n if (this.isRendeRangeMode()) return;\n this.render(this.year, this.month, '_WATCHRENDER_', 'tileContent');\n },\n almanacs() {\n if (this.isRendeRangeMode()) return;\n this.render(this.year, this.month, '_WATCHRENDER_', 'almanacs');\n },\n monthRange() {\n if (this.isRendeRangeMode()) return;\n this.render(this.year, this.month, '_WATCHRENDER_', 'almanacs');\n },\n responsive() {\n if (this.responsive) this.addResponsiveListener();\n }\n },\n created() {\n this.isMonthRange = !!this.monthRange.length;\n const loopArray = this.months.concat();\n loopArray.unshift(this.months[this.months.length - 1]);\n loopArray.push(this.months[0]);\n this.monthsLoop = loopArray;\n this.monthsLoopCopy = this.monthsLoop.concat();\n },\n mounted() {\n const self = this;\n this.resize();\n if (!isBrowser) {\n wx.getSystemInfo({\n success: function(res) {\n self.isIos = (res.system.split(' ') || [])[0] === 'iOS';\n }\n });\n } else if (this.responsive) {\n this.addResponsiveListener();\n }\n this.oversliding = true;\n this.initRender = true;\n this.init();\n },\n beforeDestroy() {\n if (isBrowser) {\n window.removeEventListener('resize', this.resize)\n }\n },\n methods: {\n init() {\n let now = new Date();\n this.year = now.getFullYear();\n this.month = now.getMonth();\n this.day = now.getDate();\n this.monthIndex = this.month + 1;\n if (this.value.length || this.multi) {\n if (this.range) {\n this.year = Number(this.value[0][0]);\n this.month = this.value[0][1] - 1;\n this.day = Number(this.value[0][2]);\n const yearEnd = Number(this.value[1][0]);\n const monthEnd = this.value[1][1] - 1;\n const dayEnd = this.value[1][2];\n this.rangeBegin = [this.year, this.month, this.day];\n this.rangeEnd = [yearEnd, monthEnd, dayEnd];\n } else if (this.multi) {\n this.multiDays = this.value;\n const handleMultiDay = this.handleMultiDay;\n if (this.firstRender) {\n this.firstRender = false;\n const thatYear = (this.value[0] || [])[0];\n const thatMonth = (this.value[0] || [])[1];\n if (isFinite(thatYear) && isFinite(thatMonth)) {\n this.month = parseInt(thatMonth) - 1;\n this.year = parseInt(thatYear);\n }\n } else if (this.handleMultiDay.length) {\n this.month = parseInt(handleMultiDay[handleMultiDay.length - 1][1]) - 1;\n this.year = parseInt(handleMultiDay[handleMultiDay.length - 1][0]);\n this.handleMultiDay = [];\n } else {\n this.month = parseInt(this.value[this.value.length - 1][1]) - 1;\n this.year = parseInt(this.value[this.value.length - 1][0]);\n }\n this.day = parseInt((this.value[0] || [])[2]);\n } else {\n this.year = parseInt(this.value[0]);\n this.month = parseInt(this.value[1]) - 1;\n this.day = parseInt(this.value[2]);\n }\n }\n this.updateHeadMonth();\n if (this.isRendeRangeMode()) return;\n this.render(this.year, this.month);\n },\n renderOption(year, month, i, playload) {\n const weekSwitch = this.monthRange.length ? false : this.weekSwitch;\n const seletSplit = this.value;\n const isMonthModeCurrentMonth = !weekSwitch && !playload;\n const disabledFilter = (disabled) => {\n return disabled.find(v => {\n const dayArr = v.split('-');\n return year === Number(dayArr[0]) && month === (dayArr[1] - 1) && i === Number(dayArr[2]);\n });\n };\n if (this.range) {\n const lastDay = new Date(year, month + 1, 0).getDate() === i ? {lastDay: true} : null;\n const options = Object.assign(\n {day: i},\n this.getLunarInfo(year, month + 1, i),\n this.getEvents(year, month + 1, i),\n lastDay\n );\n const {date, day} = options;\n const copyRangeBegin = this.rangeBegin.concat();\n const copyRangeEnd = this.rangeEnd.concat();\n copyRangeBegin[1] = copyRangeBegin[1] + 1;\n copyRangeEnd[1] = copyRangeEnd[1] + 1;\n if (weekSwitch || isMonthModeCurrentMonth) {\n (copyRangeEnd.join('-') === date) && (options.rangeClassName = 'mc-range-end');\n (copyRangeBegin.join('-') === date) && (options.rangeClassName = 'mc-range-begin');\n }\n if (year === copyRangeEnd[0] && (month + 1) === copyRangeEnd[1] && day === (copyRangeEnd[2] - 1)) {\n options.rangeClassName = options.rangeClassName ? ['mc-range-begin', 'mc-range-second-to-last'] : 'mc-range-second-to-last';\n }\n if (this.rangeBegin.length) {\n const beginTime = +new Date(this.rangeBegin[0], this.rangeBegin[1], this.rangeBegin[2]);\n const endTime = +new Date(this.rangeEnd[0], this.rangeEnd[1], this.rangeEnd[2]);\n const stepTime = +new Date(year, month, i);\n if (beginTime <= stepTime && endTime >= stepTime) {\n options.selected = true;\n }\n }\n if (this.begin.length) {\n const beginTime = +new Date(parseInt(this.begin[0]), parseInt(this.begin[1]) - 1, parseInt(this.begin[2]));\n if (beginTime > +new Date(year, month, i)) {\n options.disabled = true;\n }\n }\n if (this.end.length) {\n let endTime = Number(new Date(parseInt(this.end[0]), parseInt(this.end[1]) - 1, parseInt(this.end[2])));\n if (endTime < Number(new Date(year, month, i))) {\n options.disabled = true;\n }\n }\n if (playload && !weekSwitch) {\n options.disabled = true;\n } else if (this.disabled.length && disabledFilter(this.disabled)) {\n options.disabled = true;\n }\n const monthFirstDay = year + '-' + (month + 1) + '-' + 1;\n const monthLastDay = year + '-' + (month + 1) + '-' + new Date(year, month + 1, 0).getDate();\n (monthFirstDay === date && options.selected && !options.rangeClassName) && (options.rangeClassName = 'mc-range-month-first');\n (monthLastDay === date && options.selected && !options.rangeClassName) && (options.rangeClassName = 'mc-range-month-last');\n this.isCurrentMonthToday(options) && (options.isToday = true);\n (!weekSwitch && playload) && (options.selected = false);\n return options;\n } else if(this.multi) {\n let options;\n if (this.value.find(v => year === v[0] && month === v[1]-1 && i === v[2])){\n options = Object.assign(\n {day: i, selected: true},\n this.getLunarInfo(year, month + 1, i),\n this.getEvents(year, month + 1, i)\n );\n } else {\n options = Object.assign(\n {day: i, selected: false},\n this.getLunarInfo(year, month + 1, i),\n this.getEvents(year, month + 1, i)\n );\n if (this.begin.length) {\n const beginTime = +new Date(parseInt(this.begin[0]), parseInt(this.begin[1]) - 1, parseInt(this.begin[2]));\n if (beginTime > +(new Date(year, month, i))) {\n options.disabled = true;\n }\n }\n if (this.end.length){\n const endTime = +new Date(parseInt(this.end[0]), parseInt(this.end[1]) - 1, parseInt(this.end[2]));\n if (endTime < +(new Date(year, month, i))) {\n options.disabled = true;\n }\n }\n if (playload && !weekSwitch) {\n options.disabled = true;\n } else if (this.disabled.length && disabledFilter(this.disabled)) {\n options.disabled = true;\n }\n }\n if (options.selected && this.multiDaysData.length !== this.value.length) {\n this.multiDaysData.push(options);\n }\n this.isCurrentMonthToday(options) && (options.isToday = true);\n (!weekSwitch && playload) && (options.selected = false);\n return options;\n } else {\n const options = {};\n const monthHuman = month + 1;\n if (seletSplit[0] === year && seletSplit[1] === monthHuman && seletSplit[2] === i) {\n Object.assign(\n options,\n {day: i, selected: true},\n this.getLunarInfo(year, monthHuman, i),\n this.getEvents(year, monthHuman, i)\n );\n } else {\n Object.assign(\n options,\n {day: i, selected: false},\n this.getLunarInfo(year, monthHuman, i),\n this.getEvents(year, monthHuman, i)\n );\n if (this.begin.length) {\n const beginTime = +new Date(parseInt(this.begin[0]), parseInt(this.begin[1]) - 1, parseInt(this.begin[2]));\n if (beginTime > Number(new Date(year, month, i))) {\n options.disabled = true;\n }\n }\n if (this.end.length){\n const endTime = +new Date(parseInt(this.end[0]), parseInt(this.end[1]) - 1, parseInt(this.end[2]));\n if (endTime < +(new Date(year, month, i))) {\n options.disabled = true;\n }\n }\n if (playload && !weekSwitch) {\n options.disabled = true;\n } else if (this.disabled.length && disabledFilter(this.disabled)) {\n options.disabled = true;\n }\n }\n this.isCurrentMonthToday(options) && (options.isToday = true);\n (!weekSwitch && playload) && (options.selected = false);\n return options;\n }\n },\n isCurrentMonthToday(options) {\n const isToday = todayString === options.date;\n if (!isToday) return false;\n return this.weekSwitch ? isToday : (Number(todayString.split('-')[1]) === this.month + 1);\n },\n watchRender(type) {\n const weekSwitch = this.weekSwitch;\n const daysDeepCopy = JSON.parse(JSON.stringify(this.monthDays));\n if (type === 'events') {\n const events = this.events || {};\n Object.keys(events).forEach(value => {\n daysDeepCopy.some(v => v.some(vv => {\n if (vv.date === value) {\n vv.eventName = events[value];\n return true;\n }\n }))\n });\n this.monthDays = daysDeepCopy;\n } else if (type === 'disabled') {\n const disabled = this.disabled || [];\n disabled.forEach(value => {\n daysDeepCopy.some(v => v.some(vv => {\n if (vv.date === value) {\n vv.disabled = true;\n return true;\n }\n }))\n });\n } else if (type === 'almanacs') {\n const almanacs = this.almanacs || {};\n Object.keys(almanacs).forEach(value => {\n daysDeepCopy.some(v => v.some(vv => {\n if (vv.date.slice(5, 20) === value) {\n vv.lunar = almanacs[value];\n return true;\n }\n }))\n });\n } else if (type === 'tileContent') {\n const tileContent = this.tileContent || [];\n tileContent.forEach(value => {\n daysDeepCopy.some(v => v.some(vv => {\n if (vv.date === value.date) {\n vv.className = value.className;\n vv.content = value.content;\n return true;\n }\n }))\n });\n }\n if (weekSwitch) {\n this.monthDays = daysDeepCopy;\n this.days = [daysDeepCopy[this.weekIndex]];\n this.monthRangeDays = [this.days];\n } else {\n this.days = daysDeepCopy;\n this.monthRangeDays = [this.days];\n }\n },\n render(y, m, renderer, payload) {\n const weekSwitch = this.weekSwitch;\n const isCustomRender = renderer === 'CUSTOMRENDER';\n const isWatchRenderValue = renderer === '_WATCHRENDERVALUE_';\n this.year = y;\n this.month = m;\n if (renderer === '_WATCHRENDER_') return this.watchRender(payload);\n if (this.range && isWatchRenderValue) {\n if (!Array.isArray((this.value || [])[0])) {\n this.rangeBegin = [];\n this.rangeEnd = [];\n } else {\n this.rangeBegin = [this.value[0][0], this.value[0][1] - 1, this.value[0][2]];\n this.rangeEnd = [this.value[1][0], this.value[1][1] - 1, this.value[1][2]];\n }\n }\n if (isWatchRenderValue && weekSwitch) {\n this.positionWeek = true;\n }\n if (isCustomRender) {\n this.year = y;\n this.month = m;\n this.positionWeek = true;\n if (weekSwitch && !payload) {\n this.startWeekIndex = 0;\n this.weekIndex = 0;\n }\n this.updateHeadMonth();\n }\n let firstDayOfMonth = new Date(y, m, 1).getDay();\n const lastDateOfMonth = new Date(y, m + 1, 0).getDate();\n let lastDayOfLastMonth = new Date(y, m, 0).getDate();\n this.year = y;\n let i = 1, line = 0, temp = [], nextMonthPushDays = 1;\n for (i; i <= lastDateOfMonth; i++) {\n let day = new Date(y, m, i).getDay();\n let k;\n if (day === 0) {\n temp[line] = [];\n } else if (i === 1) {\n temp[line] = [];\n k = lastDayOfLastMonth - firstDayOfMonth + 1;\n for (let j = 0; j < firstDayOfMonth; j++) { //generate prev month surplus option\n temp[line].push(Object.assign(\n this.renderOption(this.computedPrevYear(y, m), this.computedPrevMonth(false, m), k, 'prevMonth'),\n {lastMonth: true}\n ));\n k++;\n }\n }\n\n temp[line].push(this.renderOption(y, m, i)); //generate current month option\n\n if (day === 6 && i < lastDateOfMonth) {\n line++;\n } else if (i === lastDateOfMonth) {\n let k = 1;\n const lastDateOfMonthLength = this.monFirst ? 7 : 6;\n for (let d = day; d < lastDateOfMonthLength; d++) { //generate next month surplus option\n temp[line].push(Object.assign(\n this.renderOption(this.computedNextYear(y, m), this.computedNextMonth(false, m), k, 'nextMonth'),\n {nextMonth: true}\n ));\n k++;\n }\n nextMonthPushDays = k;\n }\n }\n const completion = this.completion;\n if (this.monFirst) {\n if (!firstDayOfMonth) {\n let lastMonthDay = lastDayOfLastMonth;\n const LastMonthItems = [];\n for (let i = 1; i <= 7; i++) {\n LastMonthItems.unshift(Object.assign(\n this.renderOption(this.computedPrevYear(y, m), this.computedPrevMonth(false, m), lastMonthDay, 'prevMonth'),\n {lastMonth: true}\n ));\n lastMonthDay --;\n }\n temp.unshift(LastMonthItems);\n }\n temp.forEach((item, index) => {\n if (!index) {\n return item.splice(0, 1);\n };\n temp[index-1].length < 7 && temp[index-1].push(item.splice(0, 1)[0]);\n });\n if (this.isMonthRange && temp[temp.length - 1][0].nextMonth) {\n temp.splice(temp.length - 1, 1); //if the first day of last line is nextMonth, delete this line\n }\n if (!completion && !weekSwitch) {\n const lastIndex = temp.length - 1;\n const secondToLastIndex = lastIndex - 1;\n const differentMonth = temp[lastIndex][0].date.split('-')[1] !== temp[secondToLastIndex][6].date.split('-')[1];\n differentMonth && temp.splice(lastIndex, 1);\n }\n }\n if (completion && !weekSwitch && temp.length <= 5 && nextMonthPushDays > 0) {\n for (let i = temp.length; i<=5; i++) {\n temp[i] = [];\n let start = nextMonthPushDays + (i - line -1) * 7;\n for (let d = start; d <= start + 6; d++) {\n temp[i].push(Object.assign(\n {day: d, disabled: true, nextMonth: true},\n this.getLunarInfo(this.computedNextYear(), this.computedNextMonth(true), d),\n this.getEvents(this.computedNextYear(), this.computedNextMonth(true), d)\n ));\n }\n }\n }\n if (this.tileContent.length) {\n temp.forEach((item, index) => {\n item.forEach((v, i) => {\n const contents = this.tileContent.find(val => val.date === v.date);\n if (contents) {\n const {className, content} = contents || {};\n v.className = className;\n v.content = content;\n }\n });\n });\n }\n if (weekSwitch) {\n const tempLength = temp.length;\n const lastLineMonth = temp[tempLength - 1][0].date.split('-')[1]; // last line month\n const secondLastMonth = temp[tempLength - 2][0].date.split('-')[1]; // second-to-last line month\n lastLineMonth !== secondLastMonth && temp.splice(tempLength - 1, 1);\n }\n this.monthDays = temp;\n if (weekSwitch && !this.isMonthRange) {\n if (this.positionWeek) {\n let payloadDay = '';\n let searchIndex = true;\n if (Array.isArray(payload)) { //range\n payloadDay = [payload[0], payload[1] + 1, payload[2]].join('-');\n } else if (this.multi || isWatchRenderValue) {\n if (this.thisTimeSelect) {\n payloadDay = this.thisTimeSelect;\n } else {\n payloadDay = this.multi ? this.value[this.value.length - 1].join('-') : this.value.join('-') ;\n }\n }\n if (payload === 'SETTODAY') {\n payloadDay = todayString;\n } else if (isCustomRender) {\n if (typeof payload === 'string') {\n payloadDay = [y, Number(m) + 1, payload].join('-');\n searchIndex = true;\n } else if (typeof payload === 'number') {\n const setIndex = payload > temp.length ? temp.length - 1 : payload;\n this.startWeekIndex = setIndex;\n this.weekIndex = setIndex;\n this.positionWeek = false;\n searchIndex = false;\n }\n }\n const positionDay = payloadDay || todayString;\n if (searchIndex) {\n temp.some((v, i) => {\n const isWeekNow = v.find(vv => vv.date === positionDay);\n if (isWeekNow) {\n this.startWeekIndex = i;\n this.weekIndex = i;\n return true;\n }\n });\n }\n this.positionWeek = false;\n }\n this.days = [temp[this.startWeekIndex]];\n if (this.initRender) {\n this.setMonthRangeofWeekSwitch();\n this.initRender = false;\n }\n } else {\n this.days = temp;\n }\n const todayText = '今';\n if (typeof this.now === 'boolean' && !this.now) {\n this.showToday = {show: false};\n } else if (typeof this.now === 'string') {\n this.showToday = {\n show: true,\n text: this.now || todayText\n };\n } else {\n this.showToday = {\n show: true,\n text: todayText\n };\n }\n this.monthRangeDays = [this.days];\n isWatchRenderValue && this.updateHeadMonth();\n return this.days;\n },\n rendeRange(renderer) {\n const range = [];\n const self = this;\n const monthRange = this.monthRange;\n function formatDateText(fYear, fMonth) {\n const reg = /([y]+)(.*?)([M]+)(.*?)$/i;\n const rangeMonthFormat = self.rangeMonthFormat || 'yyyy-MM';\n reg.exec(rangeMonthFormat);\n return String(fYear).substring(4 - RegExp.$1.length) + RegExp.$2 + String(fMonth).substring(2 - RegExp.$3.length) + RegExp.$4;\n }\n if (monthRange[0] === monthRange[1]) {\n const [y, m] = monthRange[0].split('-');\n range.push([Number(y), Number(m), formatDateText(y, m)])\n } else {\n const monthRangeOfStart = monthRange[0].split('-');\n const monthRangeOfEnd = monthRange[1].split('-');\n let startYear = +monthRangeOfStart[0];\n let startMonth = +monthRangeOfStart[1];\n let endYear = +monthRangeOfEnd[0];\n let endtMonth = +monthRangeOfEnd[1] > 12 ? 12 : +monthRangeOfEnd[1];\n while (startYear < endYear || startMonth <= endtMonth) {\n range.push([startYear, startMonth, formatDateText(startYear, startMonth)]);\n if (startMonth === 12 && startYear !== endYear) {\n startYear++;\n startMonth = 0;\n }\n startMonth++;\n }\n }\n this.rangeOfMonths = range;\n\n const monthsRange = range.map(item => {\n const [yearParam, monthParam] = item;\n return this.render(yearParam, monthParam - 1, renderer);\n });\n this.monthRangeDays = monthsRange;\n },\n isRendeRangeMode(renderer) {\n this.isMonthRange = !!this.monthRange.length;\n if (this.isMonthRange) {\n this.rendeRange(renderer);\n return true;\n }\n },\n renderer(y, m, w) {\n const renderY = y || this.year;\n const renderM = typeof parseInt(m) === 'number' ? (m - 1) : this.month;\n this.initRender = true;\n this.render(renderY, renderM, 'CUSTOMRENDER', w);\n !this.weekSwitch && (this.monthsLoop = this.monthsLoopCopy.concat());\n },\n computedPrevYear(year, month) {\n let value = year;\n if((month - 1) < 0){\n value--;\n }\n return value;\n },\n computedPrevMonth(isString, month) {\n let value = month;\n if((month - 1) < 0){\n value = 11;\n } else {\n value--;\n }\n if(isString) {\n return value + 1;\n }\n return value;\n },\n computedNextYear(year, month) {\n let value = year;\n if((month + 1) > 11){\n value++;\n }\n return value;\n },\n computedNextMonth(isString, month) {\n let value = month;\n if((month + 1) > 11){\n value = 0;\n } else {\n value++;\n }\n if(isString) {\n return value + 1;\n }\n return value;\n },\n getLunarInfo(y, m, d) {\n let lunarInfo = calendar.solar2lunar(y, m, d);\n let yearEve = '';\n if (lunarInfo.lMonth === 12 && lunarInfo.lDay === calendar.monthDays(lunarInfo.lYear, 12)) {\n yearEve = '除夕';\n }\n let lunarValue = lunarInfo.IDayCn;\n let Term = lunarInfo.Term;\n let isLunarFestival = false;\n let isGregorianFestival = false;\n if(this.festival.lunar[lunarInfo.lMonth + \"-\" + lunarInfo.lDay]) {\n lunarValue = this.festival.lunar[lunarInfo.lMonth + \"-\" + lunarInfo.lDay];\n isLunarFestival = true;\n } else if(this.festival.gregorian[m + \"-\" + d]) {\n lunarValue = this.festival.gregorian[m + \"-\" + d];\n isGregorianFestival = true;\n }\n const lunarInfoObj = {\n date: `${y}-${m}-${d}`,\n lunar: yearEve || Term || lunarValue,\n isLunarFestival: isLunarFestival,\n isGregorianFestival: isGregorianFestival,\n isTerm: !!yearEve || lunarInfo.isTerm\n };\n if (Object.keys(this.almanacs).length) {\n Object.assign(lunarInfoObj, {\n almanac: this.almanacs[m + \"-\" + d] || '',\n isAlmanac: !!this.almanacs[m + \"-\" + d]\n });\n }\n return lunarInfoObj;\n },\n getEvents(y, m, d){\n if(Object.keys(this.events).length == 0) return false;\n let eventName = this.events[y + \"-\" + m + \"-\" + d];\n let data = {};\n if(eventName!=undefined){\n data.eventName = eventName;\n }\n return data;\n },\n prev(e) {\n e && e.stopPropagation();\n if (this.isMonthRange) return;\n const weekSwitch = this.weekSwitch;\n const changeMonth = (changed) => {\n if (this.monthIndex === 1) {\n this.oversliding = false;\n this.month = 11;\n this.year = parseInt(this.year) - 1;\n this.monthIndex = this.monthIndex - 1;\n } else if (this.monthIndex === 0) {\n this.oversliding = true;\n this.monthIndex = 12;\n setTimeout(() => this.prev(e), 50);\n return this.updateHeadMonth('custom');\n } else if (this.monthIndex === 13) {\n this.month = 11;\n this.year = parseInt(this.year) - 1;\n this.monthIndex = this.monthIndex - 1;\n } else {\n this.oversliding = false;\n this.month = parseInt(this.month) - 1;\n this.monthIndex = this.monthIndex - 1;\n }\n this.updateHeadMonth('custom');\n this.render(this.year, this.month);\n (typeof changed === 'function') && changed();\n const weekIndex = weekSwitch ? this.weekIndex : undefined;\n this.$emit('prev', this.year, this.month + 1, weekIndex);\n }\n if (!this.weekSwitch) return changeMonth();\n const changeWeek = () => {\n this.weekIndex = this.weekIndex - 1;\n this.days = [this.monthDays[this.weekIndex]];\n this.monthRangeDays = [this.days];\n this.setMonthRangeofWeekSwitch();\n this.$emit('prev', this.year, this.month + 1, this.weekIndex);\n }\n const currentWeek = (this.days[0] || [])[0] || {};\n if (currentWeek.lastMonth || currentWeek.day === 1) {\n const monthChenged = () => {\n const lastMonthLength = this.monthDays.length;\n const startWeekIndex = currentWeek.lastMonth ? lastMonthLength - 1: lastMonthLength;\n this.startWeekIndex = startWeekIndex;\n this.weekIndex = startWeekIndex;\n changeWeek();\n }\n changeMonth(monthChenged);\n } else {\n changeWeek();\n }\n },\n next(e) {\n e && e.stopPropagation();\n if (this.isMonthRange) return;\n const weekSwitch = this.weekSwitch;\n const changeMonth = () => {\n if (this.monthIndex === 12) {\n this.oversliding = false;\n this.month = 0;\n this.year = parseInt(this.year) + 1;\n this.monthIndex = this.monthIndex + 1;\n } else if (this.monthIndex === 0 && this.month === 11) {\n this.oversliding = false;\n this.month = 0;\n this.year = parseInt(this.year) + 1;\n this.monthIndex = this.monthIndex + 1;\n } else if (this.monthIndex === 13) {\n this.oversliding = true;\n this.monthIndex = 1;\n setTimeout(() => this.next(e), 50);\n return this.updateHeadMonth('custom');\n } else {\n this.oversliding = false;\n this.month = parseInt(this.month) + 1;\n this.monthIndex = this.monthIndex + 1;\n }\n this.updateHeadMonth('custom');\n this.render(this.year, this.month);\n const weekIndex = weekSwitch ? this.weekIndex : undefined;\n this.$emit('next', this.year, this.month + 1, weekIndex);\n }\n if (!this.weekSwitch) return changeMonth();\n const changeWeek = () => {\n this.weekIndex = this.weekIndex + 1;\n this.days = [this.monthDays[this.weekIndex]];\n this.monthRangeDays = [this.days];\n this.setMonthRangeofWeekSwitch();\n this.$emit('next', this.year, this.month + 1, this.weekIndex);\n }\n const currentWeek = (this.days[0] || [])[6] || {};\n if (currentWeek.nextMonth || currentWeek.day === (new Date(this.year, this.month + 1, 0).getDate())) {\n const startWeekIndex = currentWeek.nextMonth ? 1 : 0;\n this.startWeekIndex = startWeekIndex;\n this.weekIndex = startWeekIndex;\n changeMonth();\n } else {\n changeWeek();\n }\n },\n select(k1, k2, data, e, monthIndex) {\n e && e.stopPropagation();\n const weekSwitch = this.weekSwitch;\n if (data.lastMonth && !weekSwitch) {\n return this.prev(e);\n } else if (data.nextMonth && !weekSwitch) {\n return this.next(e);\n }\n if (data.disabled) return;\n (data || {}).event = (this.events || {})[data.date] || '';\n const {selected, day, date} = data;\n const selectedDates = date.split('-');\n const selectYear = Number(selectedDates[0]);\n const selectMonth = selectedDates[1] - 1;\n const selectMonthHuman = Number(selectedDates[1]);\n const selectDay = Number(selectedDates[2]);;\n if (this.range) {\n this.isUserSelect = true;\n if (this.rangeBegin.length === 0 || this.rangeEndTemp !== 0) {\n this.rangeBegin = [selectYear, selectMonth, selectDay];\n this.rangeBeginTemp = this.rangeBegin;\n this.rangeEnd = [selectYear, selectMonth, selectDay];\n this.thisTimeSelect = this.rangeEnd;\n this.rangeEndTemp = 0;\n } else {\n this.rangeEnd = [selectYear, selectMonth, selectDay];\n this.thisTimeSelect = [selectYear, selectMonth, selectDay];\n if (this.rangeBegin.join('-') === this.rangeEnd.join('-')) {\n return this.rangeEndTemp = 0;\n }\n this.rangeEndTemp = 1;\n if (+new Date(this.rangeEnd[0], this.rangeEnd[1], this.rangeEnd[2]) < +new Date(this.rangeBegin[0], this.rangeBegin[1], this.rangeBegin[2])) {\n this.rangeBegin = this.rangeEnd;\n this.rangeEnd = this.rangeBeginTemp;\n }\n const rangeDate = (date) => {\n return date.map((v, k) =>{\n const value = k === 1 ? v + 1 : v;\n return this.zero ? this.zeroPad(value) : value;\n });\n }\n const begin = rangeDate(this.rangeBegin);\n const end = rangeDate(this.rangeEnd);\n this.value.splice(0, 1, begin)\n this.value.splice(1, 1, end)\n this.$emit('select', begin, end);\n }\n this.rangeBgHide = !this.rangeEndTemp || (this.rangeBegin.join('-') === this.rangeEnd.join('-'));\n this.positionWeek = true;\n if (this.isMonthRange) {\n this.rendeRange();\n } else {\n this.render(this.year, this.month, undefined, this.thisTimeSelect);\n }\n } else if (this.multi) {\n const filterDayIndex = this.value.findIndex(v => v.join('-') === date);\n if(~filterDayIndex) {\n this.handleMultiDay = this.value.splice(filterDayIndex, 1);\n } else {\n this.value.push([Number(Number(selectedDates[0])), Number(selectedDates[1]), day]);\n }\n this.days[k1][k2].selected = !selected;\n if (this.monthDays[k1][k2].selected) {\n this.multiDaysData.push(data);\n } else {\n this.multiDaysData = this.multiDaysData.filter(item => item.date !== date);\n }\n this.thisTimeSelect = date;\n this.$emit('select', this.value, this.multiDaysData);\n } else {\n const currentSelected = this.value.join('-');\n this.monthRangeDays.some(value => value.some(v => !!v.find(vv => {\n if (vv.date === currentSelected) {\n vv.selected = false;\n return true;\n }\n })));\n this.monthRangeDays[monthIndex][k1][k2].selected = true;\n this.day = day;\n const selectDate = [selectYear, selectMonthHuman, selectDay];\n this.value[0] = selectYear;\n this.value[1] = selectMonthHuman;\n this.value[2] = selectDay;\n this.today = [k1, k2];\n this.$emit('select', selectDate, data);\n }\n },\n changeYear() {\n if(this.yearsShow) {\n this.yearsShow = false;\n return false;\n }\n this.yearsShow = true;\n this.years = [];\n for (let i = this.year - 5; i < this.year + 7; i++){\n this.years.push(i);\n }\n },\n changeMonth(value) {\n this.oversliding && (this.oversliding = false);\n this.yearsShow = false;\n this.month = value;\n this.render(this.year, this.month, 'CUSTOMRENDER', 0);\n this.updateHeadMonth();\n this.weekSwitch && this.setMonthRangeofWeekSwitch();\n this.$emit('selectMonth', this.month + 1, this.year);\n },\n selectYear(value) {\n this.yearsShow = false;\n this.year = value;\n this.render(this.year, this.month);\n this.$emit('selectYear', value);\n },\n setToday() {\n const now = new Date();\n this.year = now.getFullYear();\n this.month = now.getMonth();\n this.day = now.getDate();\n this.positionWeek = true;\n this.render(this.year, this.month, undefined, 'SETTODAY');\n this.updateHeadMonth();\n },\n setMonthRangeofWeekSwitch() {\n this.monthsLoop = this.monthsLoopCopy.concat();\n this.days[0].reduce((prev, current) => {\n if (!prev) return;\n const prveDate = ((prev || {}).date || '').split('-');\n const prevYear = prveDate[0];\n const prevMonth = prveDate[1];\n const currentMonth = ((current || {}).date || '').split('-')[1];\n if (prevMonth === currentMonth) {\n return current;\n } else {\n const prevMonthText = this.months[prevMonth - 1];\n const currentMonthText = this.months[currentMonth - 1];\n this.monthsLoop[this.monthIndex] = prevMonthText + '~' + currentMonthText;\n }\n });\n },\n dateInfo(y, m, d) {\n return calendar.solar2lunar(y, m, d);\n },\n zeroPad(n) {\n return String(n < 10 ? '0' + n : n)\n },\n updateHeadMonth(type) {\n if (!type) this.monthIndex = this.month + 1;\n this.monthPosition = this.monthIndex * this.positionH;\n this.monthText = this.months[this.month];\n },\n addResponsiveListener() {\n window.addEventListener('resize', this.resize);\n },\n resize() {\n const calendar = this.$refs.calendar;\n this.itemWidth = (calendar.clientWidth/7 - 4).toFixed(5);\n }\n }\n }\n</script>\n","import mod from \"-!../../cache-loader/dist/cjs.js??ref--12-0!../../thread-loader/dist/cjs.js!../../babel-loader/lib/index.js!../../cache-loader/dist/cjs.js??ref--0-0!../../vue-loader/lib/index.js??vue-loader-options!./mpvue-calendar.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../cache-loader/dist/cjs.js??ref--12-0!../../thread-loader/dist/cjs.js!../../babel-loader/lib/index.js!../../cache-loader/dist/cjs.js??ref--0-0!../../vue-loader/lib/index.js??vue-loader-options!./mpvue-calendar.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./mpvue-calendar.vue?vue&type=template&id=2947f353&\"\nimport script from \"./mpvue-calendar.vue?vue&type=script&lang=js&\"\nexport * from \"./mpvue-calendar.vue?vue&type=script&lang=js&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","<template>\r\n <div class=\"statistical-page\" ref=\"container\">\r\n <div class=\"navs\">\r\n <div class=\"list\">\r\n <div\r\n class=\"item\"\r\n :class=\"time == 'today' ? 'on' : ''\"\r\n @click=\"setTime('today')\"\r\n >\r\n 今天\r\n </div>\r\n <div\r\n class=\"item\"\r\n :class=\"time == 'yesterday' ? 'on' : ''\"\r\n @click=\"setTime('yesterday')\"\r\n >\r\n 昨天\r\n </div>\r\n <div\r\n class=\"item\"\r\n :class=\"time == 'seven' ? 'on' : ''\"\r\n @click=\"setTime('seven')\"\r\n >\r\n 最近7天\r\n </div>\r\n <div\r\n class=\"item\"\r\n :class=\"time == 'month' ? 'on' : ''\"\r\n @click=\"setTime('month')\"\r\n >\r\n 本月\r\n </div>\r\n <div\r\n class=\"item\"\r\n :class=\"time == 'date' ? 'on' : ''\"\r\n @click=\"dateTitle\"\r\n >\r\n <!-- <span class=\"iconfont icon-xiangxia\"></span>\r\n <span v-for=\"(value, index) in renderValues\" :key=\"index\">\r\n {{ value }}</span\r\n > -->\r\n 自定义\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"wrapper\">\r\n <div class=\"title\">\r\n {{ title }}{{ this.where.type == 1 ? \"营业额(元)\" : \"订单量(份)\" }}\r\n </div>\r\n <div class=\"money\">{{ time_price }}</div>\r\n <div class=\"increase acea-row row-between-wrapper\">\r\n <div>\r\n {{ title }}增长率:<span\r\n :class=\"increase_time_status === 1 ? 'red' : 'green'\"\r\n >{{ increase_time_status === 1 ? \"\" : \"-\" }}{{ growth_rate }}%\r\n <span\r\n class=\"iconfont\"\r\n :class=\"\r\n increase_time_status === 1\r\n ? 'icon-xiangshang1'\r\n : 'icon-xiangxia2'\r\n \"\r\n ></span\r\n ></span>\r\n </div>\r\n <div>\r\n {{ title }}增长:<span\r\n :class=\"increase_time_status === 1 ? 'red' : 'green'\"\r\n >{{ increase_time_status === 1 ? \"\" : \"-\" }}{{ increase_time }}\r\n <span\r\n class=\"iconfont\"\r\n :class=\"\r\n increase_time_status === 1\r\n ? 'icon-xiangshang1'\r\n : 'icon-xiangxia2'\r\n \"\r\n ></span\r\n ></span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"chart\">\r\n <div class=\"company\">\r\n {{ where.type === 1 ? \"单位(元)\" : \"单位(份)\" }}\r\n </div>\r\n <ECharts :options=\"polar\"></ECharts>\r\n </div>\r\n <div class=\"public-wrapper\">\r\n <div class=\"title\">\r\n <span class=\"iconfont icon-xiangxishuju\"></span>详细数据\r\n </div>\r\n <div class=\"nav acea-row row-between-wrapper\">\r\n <div class=\"data\">日期</div>\r\n <div class=\"browse\">订单量</div>\r\n <div class=\"turnover\">成交额</div>\r\n </div>\r\n <div class=\"conter\">\r\n <div\r\n class=\"item acea-row row-between-wrapper\"\r\n v-for=\"(item, index) in list\"\r\n :key=\"index\"\r\n >\r\n <div class=\"data\">{{ item.time }}</div>\r\n <div class=\"browse\">{{ item.count }}</div>\r\n <div class=\"turnover\">{{ item.price }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"calendar-wrapper\" :class=\"current === true ? 'on' : ''\">\r\n <div class=\"calendar\">\r\n <Calendar\r\n :clean=\"clean\"\r\n :lunar=\"lunar\"\r\n ref=\"calendar\"\r\n :range=\"isrange\"\r\n :multi=\"ismulti\"\r\n @select=\"select\"\r\n @next=\"next\"\r\n @prev=\"prev\"\r\n :value=\"value\"\r\n :weekSwitch=\"weekSwitch\"\r\n :monthRange=\"monthRange\"\r\n rangeMonthFormat=\"yyyy年MM月\"\r\n monFirst\r\n responsive\r\n :begin=\"[1992, 5, 20]\"\r\n :end=\"[2049, 5, 20]\"\r\n />\r\n </div>\r\n </div>\r\n <div\r\n class=\"mask\"\r\n @touchmove.prevent\r\n v-show=\"current === true\"\r\n @click=\"close\"\r\n ></div>\r\n <Loading :loaded=\"loaded\" :loading=\"loading\"></Loading>\r\n </div>\r\n</template>\r\n<script>\r\nimport ECharts from \"vue-echarts\";\r\nimport \"echarts/lib/chart/line\";\r\nimport \"echarts/lib/component/polar\";\r\nimport Calendar from \"mpvue-calendar\";\r\nimport \"mpvue-calendar/src/browser-style.css\";\r\nimport { getStatisticsMonth, getStatisticsTime } from \"../../api/admin\";\r\nimport Loading from \"@components/Loading\";\r\nconst year = new Date().getFullYear();\r\nconst month = new Date().getMonth() + 1;\r\nconst day = new Date().getDate();\r\nexport default {\r\n name: \"Statistics\",\r\n components: {\r\n ECharts,\r\n Calendar,\r\n Loading\r\n },\r\n props: {},\r\n data: function() {\r\n return {\r\n polar: {\r\n tooltip: {\r\n trigger: \"axis\"\r\n },\r\n legend: {\r\n data: [\"\"]\r\n },\r\n toolbox: {\r\n show: false,\r\n feature: {\r\n mark: { show: true },\r\n dataView: { show: true, readOnly: false },\r\n magicType: { show: true, type: [\"line\"] },\r\n restore: { show: true },\r\n saveAsImage: { show: true }\r\n }\r\n },\r\n calculable: true,\r\n xAxis: [\r\n {\r\n type: \"category\",\r\n boundaryGap: false,\r\n data: [\"周一\", \"周二\", \"周三\", \"周四\", \"周五\", \"周六\", \"周日\"],\r\n splitLine: {\r\n show: false\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: \"#999\",\r\n width: 1 //这里是为了突出显示加上的\r\n }\r\n }\r\n }\r\n ],\r\n yAxis: [\r\n {\r\n type: \"value\",\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: [\"#f5f5f5\"],\r\n width: 1,\r\n type: \"solid\"\r\n }\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: \"#999\",\r\n width: 1 //这里是为了突出显示加上的\r\n }\r\n }\r\n }\r\n ],\r\n series: [\r\n {\r\n name: \"邮件营销\",\r\n type: \"line\",\r\n stack: \"总量\",\r\n itemStyle: {\r\n normal: {\r\n color: \"#2291f8\", //折点颜色\r\n lineStyle: {\r\n color: \"#2291f8\" //折线颜色\r\n }\r\n }\r\n },\r\n data: [120, 132.5, 101, 134, 90, 150, 30]\r\n }\r\n ],\r\n grid: {\r\n x: 30,\r\n x2: 10,\r\n y: 20,\r\n y2: 110\r\n },\r\n animationDuration: 2000\r\n },\r\n value: [[year, month, day - 1], [year, month, day]],\r\n isrange: true,\r\n weekSwitch: false,\r\n ismulti: false,\r\n monFirst: true,\r\n clean: false, //简洁模式\r\n lunar: false, //显示农历\r\n renderValues: [],\r\n monthRange: [],\r\n current: false,\r\n where: {\r\n start: \"\",\r\n stop: \"\",\r\n type: \"\"\r\n },\r\n types: \"\", //类型|order=订单数|price=营业额\r\n time: \"\", //时间|today=今天|yesterday=昨天|month=本月\r\n title: \"\", //时间|today=今天|yesterday=昨天|month=本月\r\n growth_rate: \"\", //增长率\r\n increase_time: \"\", //增长率\r\n increase_time_status: \"\", //增长率\r\n time_price: \"\", //增长率\r\n loaded: false,\r\n loading: false,\r\n filter: {\r\n page: 1,\r\n limit: 10\r\n },\r\n list: []\r\n };\r\n },\r\n watch: {\r\n \"$route.params\": function(newVal) {\r\n var that = this;\r\n if (newVal != undefined) {\r\n that.setType(newVal.type);\r\n that.setTime(newVal.time);\r\n that.getIndex();\r\n }\r\n }\r\n },\r\n mounted: function() {\r\n this.handelRenderValues();\r\n this.setTime(this.$route.params.time);\r\n this.setType(this.$route.params.type);\r\n // this.getIndex();\r\n this.getInfo();\r\n this.$scroll(this.$refs.container, () => {\r\n !this.loading && this.getInfo();\r\n });\r\n },\r\n computed: {\r\n monthRangeText() {\r\n return this.monthRange.length ? \"固定\" : \"指定范围\";\r\n }\r\n },\r\n methods: {\r\n getIndex: function() {\r\n var that = this;\r\n getStatisticsTime(that.where).then(\r\n res => {\r\n var _info = res.data.chart,\r\n day = [],\r\n num = [];\r\n _info.forEach(function(item) {\r\n day.push(item.time);\r\n num.push(item.num);\r\n });\r\n that.polar.xAxis[0].data = day;\r\n that.polar.series[0].data = num;\r\n that.growth_rate = res.data.growth_rate;\r\n that.increase_time = res.data.increase_time;\r\n that.increase_time_status = res.data.increase_time_status;\r\n that.time_price = res.data.time;\r\n },\r\n error => {\r\n that.$dialog.error(error.msg);\r\n }\r\n );\r\n },\r\n setTime: function(time) {\r\n this.time = time;\r\n var year = new Date().getFullYear(),\r\n month = new Date().getMonth() + 1,\r\n day = new Date().getDate();\r\n switch (time) {\r\n case \"today\":\r\n this.where.start =\r\n new Date(Date.parse(year + \"/\" + month + \"/\" + day)).getTime() /\r\n 1000;\r\n this.where.stop =\r\n new Date(Date.parse(year + \"/\" + month + \"/\" + day)).getTime() /\r\n 1000 +\r\n 24 * 60 * 60 -\r\n 1;\r\n this.title = \"今日\";\r\n this.getIndex();\r\n break;\r\n case \"yesterday\":\r\n this.where.start =\r\n new Date(Date.parse(year + \"/\" + month + \"/\" + day)).getTime() /\r\n 1000 -\r\n 24 * 60 * 60;\r\n this.where.stop =\r\n new Date(Date.parse(year + \"/\" + month + \"/\" + day)).getTime() /\r\n 1000 -\r\n 1;\r\n this.title = \"昨日\";\r\n this.getIndex();\r\n break;\r\n case \"month\":\r\n this.where.start =\r\n new Date(year, new Date().getMonth(), 1).getTime() / 1000;\r\n this.where.stop = new Date(year, month, 1).getTime() / 1000 - 1;\r\n this.title = \"本月\";\r\n this.getIndex();\r\n break;\r\n case \"seven\":\r\n this.where.start =\r\n new Date(Date.parse(year + \"/\" + month + \"/\" + day)).getTime() /\r\n 1000 +\r\n 24 * 60 * 60 -\r\n 7 * 3600;\r\n this.where.stop =\r\n new Date(Date.parse(year + \"/\" + month + \"/\" + day)).getTime() /\r\n 1000 +\r\n 24 * 60 * 60 -\r\n 1;\r\n this.title = \"七日\";\r\n this.getIndex();\r\n break;\r\n }\r\n },\r\n setType: function(type) {\r\n switch (type) {\r\n case \"price\":\r\n this.where.type = 1;\r\n break;\r\n case \"order\":\r\n this.where.type = 2;\r\n break;\r\n }\r\n },\r\n clickSomeThing(data) {\r\n this.value = [[2019, 4, 1], [2019, 4, 8]];\r\n console.log(data);\r\n },\r\n setMonthRange() {\r\n this.monthRange = this.monthRange.length ? [] : [\"2019-4\", \"2020-1\"];\r\n },\r\n switchMode() {\r\n this.weekSwitch = !this.weekSwitch;\r\n setTimeout(() => {\r\n this.$refs.calendar.renderer(2019, 1); //渲染2018年8月份\r\n }, 0);\r\n },\r\n handelRenderValues(data) {\r\n if (this.ismulti) {\r\n this.renderValues = this.value.map(v => v.join(\"-\"));\r\n } else if (this.isrange) {\r\n const values = [];\r\n data || this.value;\r\n this.value.forEach((v, i) => {\r\n values.push(v.join(\"-\"));\r\n if (!i) {\r\n values.push(\"~\");\r\n }\r\n });\r\n this.renderValues = values;\r\n } else {\r\n this.renderValues = [this.value.join(\"-\")];\r\n }\r\n },\r\n multiMode() {\r\n this.ismulti = true;\r\n this.isrange = false;\r\n this.value = [[year, month, 16], [year, month, 18]];\r\n this.handelRenderValues();\r\n this.$refs.calendar.renderer(year, month);\r\n },\r\n rangeMode() {\r\n this.ismulti = false;\r\n this.isrange = true;\r\n this.value = [[year, month, 16], [year, month, 22]];\r\n this.handelRenderValues();\r\n this.$refs.calendar.renderer(year, month);\r\n },\r\n valueMode() {\r\n this.ismulti = false;\r\n this.isrange = false;\r\n this.value = [year, month, 16];\r\n this.handelRenderValues();\r\n this.$refs.calendar.renderer(year, month);\r\n },\r\n selectMonth(month, year) {\r\n console.log(year, month);\r\n },\r\n prev(y, m, w) {\r\n console.log(y, m, w);\r\n },\r\n next(year, month, week) {\r\n console.log(year, month, week);\r\n },\r\n selectYear(year) {\r\n console.log(year);\r\n },\r\n setToday() {\r\n this.$refs.calendar.setToday();\r\n },\r\n dateInfo() {\r\n const info = this.$refs.calendar.dateInfo(2018, 8, 23);\r\n console.log(info);\r\n },\r\n renderer() {\r\n if (this.monthRange.length) {\r\n this.monthRange = [\"2018-8\", \"2018-8\"];\r\n }\r\n this.$refs.calendar.renderer(2018, 8); //渲染2018年8月份\r\n },\r\n select(val, val2) {\r\n if (this.isrange) {\r\n this.handelRenderValues([val, val2]);\r\n } else if (this.ismulti) {\r\n this.handelRenderValues(val);\r\n } else {\r\n this.handelRenderValues([val]);\r\n }\r\n if (\r\n this.where.start != new Date(val) / 1000 ||\r\n this.where.stop != new Date(val2) / 1000 + 24 * 60 * 60 - 1\r\n ) {\r\n this.time = \"date\";\r\n this.title = \"\";\r\n this.where.start =\r\n new Date(Date.parse(val[0] + \"/\" + val[1] + \"/\" + val[2])).getTime() /\r\n 1000;\r\n this.where.stop =\r\n new Date(\r\n Date.parse(val2[0] + \"/\" + val2[1] + \"/\" + val2[2])\r\n ).getTime() /\r\n 1000 +\r\n 24 * 60 * 60 -\r\n 1;\r\n this.getIndex();\r\n }\r\n },\r\n dateTitle: function() {\r\n this.current = true;\r\n },\r\n close: function() {\r\n this.current = false;\r\n },\r\n getInfo: function() {\r\n var that = this;\r\n if (that.loading || that.loaded) return;\r\n that.loading = true;\r\n getStatisticsMonth(that.filter).then(\r\n res => {\r\n that.loading = false;\r\n that.loaded = res.data.length < that.filter.limit;\r\n that.list.push.apply(that.list, res.data);\r\n that.filter.page = that.filter.page + 1;\r\n },\r\n error => {\r\n that.$dialog.message(error.msg);\r\n }\r\n );\r\n }\r\n }\r\n};\r\n</script>\r\n<style scoped>\r\n.echarts {\r\n width: 100%;\r\n height: 5.5rem;\r\n}\r\n.calendar-wrapper {\r\n position: fixed;\r\n bottom: 0;\r\n left: 0;\r\n width: 100%;\r\n z-index: 66;\r\n transform: translate3d(0, 100%, 0);\r\n transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);\r\n}\r\n.calendar-wrapper.on {\r\n transform: translate3d(0, 0, 0);\r\n}\r\n.statistical-page .wrapper .increase {\r\n font-size: 0.26rem;\r\n}\r\n.statistical-page .wrapper .increase .iconfont {\r\n margin-left: 0;\r\n}\r\n</style>\r\n","import mod from \"-!../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../node_modules/thread-loader/dist/cjs.js!../../../node_modules/babel-loader/lib/index.js!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Statistics.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../node_modules/thread-loader/dist/cjs.js!../../../node_modules/babel-loader/lib/index.js!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Statistics.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./Statistics.vue?vue&type=template&id=0c8f63c6&scoped=true&\"\nimport script from \"./Statistics.vue?vue&type=script&lang=js&\"\nexport * from \"./Statistics.vue?vue&type=script&lang=js&\"\nimport style0 from \"./Statistics.vue?vue&type=style&index=0&id=0c8f63c6&scoped=true&lang=css&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"0c8f63c6\",\n null\n \n)\n\nexport default component.exports","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar modelUtil = require(\"../../util/model\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @param {Object} finder contains {seriesIndex, dataIndex, dataIndexInside}\n * @param {module:echarts/model/Global} ecModel\n * @return {Object} {point: [x, y], el: ...} point Will not be null.\n */\nfunction _default(finder, ecModel) {\n var point = [];\n var seriesIndex = finder.seriesIndex;\n var seriesModel;\n\n if (seriesIndex == null || !(seriesModel = ecModel.getSeriesByIndex(seriesIndex))) {\n return {\n point: []\n };\n }\n\n var data = seriesModel.getData();\n var dataIndex = modelUtil.queryDataIndex(data, finder);\n\n if (dataIndex == null || dataIndex < 0 || zrUtil.isArray(dataIndex)) {\n return {\n point: []\n };\n }\n\n var el = data.getItemGraphicEl(dataIndex);\n var coordSys = seriesModel.coordinateSystem;\n\n if (seriesModel.getTooltipPosition) {\n point = seriesModel.getTooltipPosition(dataIndex) || [];\n } else if (coordSys && coordSys.dataToPoint) {\n point = coordSys.dataToPoint(data.getValues(zrUtil.map(coordSys.dimensions, function (dim) {\n return data.mapDimension(dim);\n }), dataIndex, true)) || [];\n } else if (el) {\n // Use graphic bounding rect\n var rect = el.getBoundingRect().clone();\n rect.applyTransform(el.transform);\n point = [rect.x + rect.width / 2, rect.y + rect.height / 2];\n }\n\n return {\n point: point,\n el: el\n };\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar _symbol = require(\"../../util/symbol\");\n\nvar createSymbol = _symbol.createSymbol;\n\nvar graphic = require(\"../../util/graphic\");\n\nvar _number = require(\"../../util/number\");\n\nvar parsePercent = _number.parsePercent;\n\nvar _labelHelper = require(\"./labelHelper\");\n\nvar getDefaultLabel = _labelHelper.getDefaultLabel;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @module echarts/chart/helper/Symbol\n */\n\n/**\n * @constructor\n * @alias {module:echarts/chart/helper/Symbol}\n * @param {module:echarts/data/List} data\n * @param {number} idx\n * @extends {module:zrender/graphic/Group}\n */\nfunction SymbolClz(data, idx, seriesScope) {\n graphic.Group.call(this);\n this.updateData(data, idx, seriesScope);\n}\n\nvar symbolProto = SymbolClz.prototype;\n/**\n * @public\n * @static\n * @param {module:echarts/data/List} data\n * @param {number} dataIndex\n * @return {Array.<number>} [width, height]\n */\n\nvar getSymbolSize = SymbolClz.getSymbolSize = function (data, idx) {\n var symbolSize = data.getItemVisual(idx, 'symbolSize');\n return symbolSize instanceof Array ? symbolSize.slice() : [+symbolSize, +symbolSize];\n};\n\nfunction getScale(symbolSize) {\n return [symbolSize[0] / 2, symbolSize[1] / 2];\n}\n\nfunction driftSymbol(dx, dy) {\n this.parent.drift(dx, dy);\n}\n\nsymbolProto._createSymbol = function (symbolType, data, idx, symbolSize, keepAspect) {\n // Remove paths created before\n this.removeAll();\n var color = data.getItemVisual(idx, 'color'); // var symbolPath = createSymbol(\n // symbolType, -0.5, -0.5, 1, 1, color\n // );\n // If width/height are set too small (e.g., set to 1) on ios10\n // and macOS Sierra, a circle stroke become a rect, no matter what\n // the scale is set. So we set width/height as 2. See #4150.\n\n var symbolPath = createSymbol(symbolType, -1, -1, 2, 2, color, keepAspect);\n symbolPath.attr({\n z2: 100,\n culling: true,\n scale: getScale(symbolSize)\n }); // Rewrite drift method\n\n symbolPath.drift = driftSymbol;\n this._symbolType = symbolType;\n this.add(symbolPath);\n};\n/**\n * Stop animation\n * @param {boolean} toLastFrame\n */\n\n\nsymbolProto.stopSymbolAnimation = function (toLastFrame) {\n this.childAt(0).stopAnimation(toLastFrame);\n};\n/**\n * FIXME:\n * Caution: This method breaks the encapsulation of this module,\n * but it indeed brings convenience. So do not use the method\n * unless you detailedly know all the implements of `Symbol`,\n * especially animation.\n *\n * Get symbol path element.\n */\n\n\nsymbolProto.getSymbolPath = function () {\n return this.childAt(0);\n};\n/**\n * Get scale(aka, current symbol size).\n * Including the change caused by animation\n */\n\n\nsymbolProto.getScale = function () {\n return this.childAt(0).scale;\n};\n/**\n * Highlight symbol\n */\n\n\nsymbolProto.highlight = function () {\n this.childAt(0).trigger('emphasis');\n};\n/**\n * Downplay symbol\n */\n\n\nsymbolProto.downplay = function () {\n this.childAt(0).trigger('normal');\n};\n/**\n * @param {number} zlevel\n * @param {number} z\n */\n\n\nsymbolProto.setZ = function (zlevel, z) {\n var symbolPath = this.childAt(0);\n symbolPath.zlevel = zlevel;\n symbolPath.z = z;\n};\n\nsymbolProto.setDraggable = function (draggable) {\n var symbolPath = this.childAt(0);\n symbolPath.draggable = draggable;\n symbolPath.cursor = draggable ? 'move' : 'pointer';\n};\n/**\n * Update symbol properties\n * @param {module:echarts/data/List} data\n * @param {number} idx\n * @param {Object} [seriesScope]\n * @param {Object} [seriesScope.itemStyle]\n * @param {Object} [seriesScope.hoverItemStyle]\n * @param {Object} [seriesScope.symbolRotate]\n * @param {Object} [seriesScope.symbolOffset]\n * @param {module:echarts/model/Model} [seriesScope.labelModel]\n * @param {module:echarts/model/Model} [seriesScope.hoverLabelModel]\n * @param {boolean} [seriesScope.hoverAnimation]\n * @param {Object} [seriesScope.cursorStyle]\n * @param {module:echarts/model/Model} [seriesScope.itemModel]\n * @param {string} [seriesScope.symbolInnerColor]\n * @param {Object} [seriesScope.fadeIn=false]\n */\n\n\nsymbolProto.updateData = function (data, idx, seriesScope) {\n this.silent = false;\n var symbolType = data.getItemVisual(idx, 'symbol') || 'circle';\n var seriesModel = data.hostModel;\n var symbolSize = getSymbolSize(data, idx);\n var isInit = symbolType !== this._symbolType;\n\n if (isInit) {\n var keepAspect = data.getItemVisual(idx, 'symbolKeepAspect');\n\n this._createSymbol(symbolType, data, idx, symbolSize, keepAspect);\n } else {\n var symbolPath = this.childAt(0);\n symbolPath.silent = false;\n graphic.updateProps(symbolPath, {\n scale: getScale(symbolSize)\n }, seriesModel, idx);\n }\n\n this._updateCommon(data, idx, symbolSize, seriesScope);\n\n if (isInit) {\n var symbolPath = this.childAt(0);\n var fadeIn = seriesScope && seriesScope.fadeIn;\n var target = {\n scale: symbolPath.scale.slice()\n };\n fadeIn && (target.style = {\n opacity: symbolPath.style.opacity\n });\n symbolPath.scale = [0, 0];\n fadeIn && (symbolPath.style.opacity = 0);\n graphic.initProps(symbolPath, target, seriesModel, idx);\n }\n\n this._seriesModel = seriesModel;\n}; // Update common properties\n\n\nvar normalStyleAccessPath = ['itemStyle'];\nvar emphasisStyleAccessPath = ['emphasis', 'itemStyle'];\nvar normalLabelAccessPath = ['label'];\nvar emphasisLabelAccessPath = ['emphasis', 'label'];\n/**\n * @param {module:echarts/data/List} data\n * @param {number} idx\n * @param {Array.<number>} symbolSize\n * @param {Object} [seriesScope]\n */\n\nsymbolProto._updateCommon = function (data, idx, symbolSize, seriesScope) {\n var symbolPath = this.childAt(0);\n var seriesModel = data.hostModel;\n var color = data.getItemVisual(idx, 'color'); // Reset style\n\n if (symbolPath.type !== 'image') {\n symbolPath.useStyle({\n strokeNoScale: true\n });\n }\n\n var itemStyle = seriesScope && seriesScope.itemStyle;\n var hoverItemStyle = seriesScope && seriesScope.hoverItemStyle;\n var symbolRotate = seriesScope && seriesScope.symbolRotate;\n var symbolOffset = seriesScope && seriesScope.symbolOffset;\n var labelModel = seriesScope && seriesScope.labelModel;\n var hoverLabelModel = seriesScope && seriesScope.hoverLabelModel;\n var hoverAnimation = seriesScope && seriesScope.hoverAnimation;\n var cursorStyle = seriesScope && seriesScope.cursorStyle;\n\n if (!seriesScope || data.hasItemOption) {\n var itemModel = seriesScope && seriesScope.itemModel ? seriesScope.itemModel : data.getItemModel(idx); // Color must be excluded.\n // Because symbol provide setColor individually to set fill and stroke\n\n itemStyle = itemModel.getModel(normalStyleAccessPath).getItemStyle(['color']);\n hoverItemStyle = itemModel.getModel(emphasisStyleAccessPath).getItemStyle();\n symbolRotate = itemModel.getShallow('symbolRotate');\n symbolOffset = itemModel.getShallow('symbolOffset');\n labelModel = itemModel.getModel(normalLabelAccessPath);\n hoverLabelModel = itemModel.getModel(emphasisLabelAccessPath);\n hoverAnimation = itemModel.getShallow('hoverAnimation');\n cursorStyle = itemModel.getShallow('cursor');\n } else {\n hoverItemStyle = zrUtil.extend({}, hoverItemStyle);\n }\n\n var elStyle = symbolPath.style;\n symbolPath.attr('rotation', (symbolRotate || 0) * Math.PI / 180 || 0);\n\n if (symbolOffset) {\n symbolPath.attr('position', [parsePercent(symbolOffset[0], symbolSize[0]), parsePercent(symbolOffset[1], symbolSize[1])]);\n }\n\n cursorStyle && symbolPath.attr('cursor', cursorStyle); // PENDING setColor before setStyle!!!\n\n symbolPath.setColor(color, seriesScope && seriesScope.symbolInnerColor);\n symbolPath.setStyle(itemStyle);\n var opacity = data.getItemVisual(idx, 'opacity');\n\n if (opacity != null) {\n elStyle.opacity = opacity;\n }\n\n var liftZ = data.getItemVisual(idx, 'liftZ');\n var z2Origin = symbolPath.__z2Origin;\n\n if (liftZ != null) {\n if (z2Origin == null) {\n symbolPath.__z2Origin = symbolPath.z2;\n symbolPath.z2 += liftZ;\n }\n } else if (z2Origin != null) {\n symbolPath.z2 = z2Origin;\n symbolPath.__z2Origin = null;\n }\n\n var useNameLabel = seriesScope && seriesScope.useNameLabel;\n graphic.setLabelStyle(elStyle, hoverItemStyle, labelModel, hoverLabelModel, {\n labelFetcher: seriesModel,\n labelDataIndex: idx,\n defaultText: getLabelDefaultText,\n isRectText: true,\n autoColor: color\n }); // Do not execute util needed.\n\n function getLabelDefaultText(idx, opt) {\n return useNameLabel ? data.getName(idx) : getDefaultLabel(data, idx);\n }\n\n symbolPath.off('mouseover').off('mouseout').off('emphasis').off('normal');\n symbolPath.hoverStyle = hoverItemStyle; // FIXME\n // Do not use symbol.trigger('emphasis'), but use symbol.highlight() instead.\n\n graphic.setHoverStyle(symbolPath);\n symbolPath.__symbolOriginalScale = getScale(symbolSize);\n\n if (hoverAnimation && seriesModel.isAnimationEnabled()) {\n // Note: consider `off`, should use static function here.\n symbolPath.on('mouseover', onMouseOver).on('mouseout', onMouseOut).on('emphasis', onEmphasis).on('normal', onNormal);\n }\n};\n\nfunction onMouseOver() {\n // see comment in `graphic.isInEmphasis`\n !graphic.isInEmphasis(this) && onEmphasis.call(this);\n}\n\nfunction onMouseOut() {\n // see comment in `graphic.isInEmphasis`\n !graphic.isInEmphasis(this) && onNormal.call(this);\n}\n\nfunction onEmphasis() {\n // Do not support this hover animation util some scenario required.\n // Animation can only be supported in hover layer when using `el.incremetal`.\n if (this.incremental || this.useHoverLayer) {\n return;\n }\n\n var scale = this.__symbolOriginalScale;\n var ratio = scale[1] / scale[0];\n this.animateTo({\n scale: [Math.max(scale[0] * 1.1, scale[0] + 3), Math.max(scale[1] * 1.1, scale[1] + 3 * ratio)]\n }, 400, 'elasticOut');\n}\n\nfunction onNormal() {\n if (this.incremental || this.useHoverLayer) {\n return;\n }\n\n this.animateTo({\n scale: this.__symbolOriginalScale\n }, 400, 'elasticOut');\n}\n/**\n * @param {Function} cb\n * @param {Object} [opt]\n * @param {Object} [opt.keepLabel=true]\n */\n\n\nsymbolProto.fadeOut = function (cb, opt) {\n var symbolPath = this.childAt(0); // Avoid mistaken hover when fading out\n\n this.silent = symbolPath.silent = true; // Not show text when animating\n\n !(opt && opt.keepLabel) && (symbolPath.style.text = null);\n graphic.updateProps(symbolPath, {\n style: {\n opacity: 0\n },\n scale: [0, 0]\n }, this._seriesModel, this.dataIndex, cb);\n};\n\nzrUtil.inherits(SymbolClz, graphic.Group);\nvar _default = SymbolClz;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar graphic = require(\"../../util/graphic\");\n\nvar AxisBuilder = require(\"./AxisBuilder\");\n\nvar AxisView = require(\"./AxisView\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar axisBuilderAttrs = ['axisLine', 'axisTickLabel', 'axisName'];\nvar selfBuilderAttrs = ['splitLine', 'splitArea'];\n\nvar _default = AxisView.extend({\n type: 'radiusAxis',\n axisPointerClass: 'PolarAxisPointer',\n render: function (radiusAxisModel, ecModel) {\n this.group.removeAll();\n\n if (!radiusAxisModel.get('show')) {\n return;\n }\n\n var radiusAxis = radiusAxisModel.axis;\n var polar = radiusAxis.polar;\n var angleAxis = polar.getAngleAxis();\n var ticksCoords = radiusAxis.getTicksCoords();\n var axisAngle = angleAxis.getExtent()[0];\n var radiusExtent = radiusAxis.getExtent();\n var layout = layoutAxis(polar, radiusAxisModel, axisAngle);\n var axisBuilder = new AxisBuilder(radiusAxisModel, layout);\n zrUtil.each(axisBuilderAttrs, axisBuilder.add, axisBuilder);\n this.group.add(axisBuilder.getGroup());\n zrUtil.each(selfBuilderAttrs, function (name) {\n if (radiusAxisModel.get(name + '.show') && !radiusAxis.scale.isBlank()) {\n this['_' + name](radiusAxisModel, polar, axisAngle, radiusExtent, ticksCoords);\n }\n }, this);\n },\n\n /**\n * @private\n */\n _splitLine: function (radiusAxisModel, polar, axisAngle, radiusExtent, ticksCoords) {\n var splitLineModel = radiusAxisModel.getModel('splitLine');\n var lineStyleModel = splitLineModel.getModel('lineStyle');\n var lineColors = lineStyleModel.get('color');\n var lineCount = 0;\n lineColors = lineColors instanceof Array ? lineColors : [lineColors];\n var splitLines = [];\n\n for (var i = 0; i < ticksCoords.length; i++) {\n var colorIndex = lineCount++ % lineColors.length;\n splitLines[colorIndex] = splitLines[colorIndex] || [];\n splitLines[colorIndex].push(new graphic.Circle({\n shape: {\n cx: polar.cx,\n cy: polar.cy,\n r: ticksCoords[i].coord\n },\n silent: true\n }));\n } // Simple optimization\n // Batching the lines if color are the same\n\n\n for (var i = 0; i < splitLines.length; i++) {\n this.group.add(graphic.mergePath(splitLines[i], {\n style: zrUtil.defaults({\n stroke: lineColors[i % lineColors.length],\n fill: null\n }, lineStyleModel.getLineStyle()),\n silent: true\n }));\n }\n },\n\n /**\n * @private\n */\n _splitArea: function (radiusAxisModel, polar, axisAngle, radiusExtent, ticksCoords) {\n if (!ticksCoords.length) {\n return;\n }\n\n var splitAreaModel = radiusAxisModel.getModel('splitArea');\n var areaStyleModel = splitAreaModel.getModel('areaStyle');\n var areaColors = areaStyleModel.get('color');\n var lineCount = 0;\n areaColors = areaColors instanceof Array ? areaColors : [areaColors];\n var splitAreas = [];\n var prevRadius = ticksCoords[0].coord;\n\n for (var i = 1; i < ticksCoords.length; i++) {\n var colorIndex = lineCount++ % areaColors.length;\n splitAreas[colorIndex] = splitAreas[colorIndex] || [];\n splitAreas[colorIndex].push(new graphic.Sector({\n shape: {\n cx: polar.cx,\n cy: polar.cy,\n r0: prevRadius,\n r: ticksCoords[i].coord,\n startAngle: 0,\n endAngle: Math.PI * 2\n },\n silent: true\n }));\n prevRadius = ticksCoords[i].coord;\n } // Simple optimization\n // Batching the lines if color are the same\n\n\n for (var i = 0; i < splitAreas.length; i++) {\n this.group.add(graphic.mergePath(splitAreas[i], {\n style: zrUtil.defaults({\n fill: areaColors[i % areaColors.length]\n }, areaStyleModel.getAreaStyle()),\n silent: true\n }));\n }\n }\n});\n/**\n * @inner\n */\n\n\nfunction layoutAxis(polar, radiusAxisModel, axisAngle) {\n return {\n position: [polar.cx, polar.cy],\n rotation: axisAngle / 180 * Math.PI,\n labelDirection: -1,\n tickDirection: -1,\n nameDirection: 1,\n labelRotate: radiusAxisModel.getModel('axisLabel').get('rotate'),\n // Over splitLine and splitArea\n z2: 1\n };\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar createListFromArray = require(\"./chart/helper/createListFromArray\");\n\nvar axisHelper = require(\"./coord/axisHelper\");\n\nvar axisModelCommonMixin = require(\"./coord/axisModelCommonMixin\");\n\nvar Model = require(\"./model/Model\");\n\nvar _layout = require(\"./util/layout\");\n\nvar getLayoutRect = _layout.getLayoutRect;\nexports.getLayoutRect = _layout.getLayoutRect;\n\nvar _dataStackHelper = require(\"./data/helper/dataStackHelper\");\n\nvar enableDataStack = _dataStackHelper.enableDataStack;\nvar isDimensionStacked = _dataStackHelper.isDimensionStacked;\nvar getStackedDimension = _dataStackHelper.getStackedDimension;\n\nvar _completeDimensions = require(\"./data/helper/completeDimensions\");\n\nexports.completeDimensions = _completeDimensions;\n\nvar _createDimensions = require(\"./data/helper/createDimensions\");\n\nexports.createDimensions = _createDimensions;\n\nvar _symbol = require(\"./util/symbol\");\n\nexports.createSymbol = _symbol.createSymbol;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// import createGraphFromNodeEdge from './chart/helper/createGraphFromNodeEdge';\n\n/**\n * Create a muti dimension List structure from seriesModel.\n * @param {module:echarts/model/Model} seriesModel\n * @return {module:echarts/data/List} list\n */\nfunction createList(seriesModel) {\n return createListFromArray(seriesModel.getSource(), seriesModel);\n} // export function createGraph(seriesModel) {\n// var nodes = seriesModel.get('data');\n// var links = seriesModel.get('links');\n// return createGraphFromNodeEdge(nodes, links, seriesModel);\n// }\n\n\nvar dataStack = {\n isDimensionStacked: isDimensionStacked,\n enableDataStack: enableDataStack,\n getStackedDimension: getStackedDimension\n};\n/**\n * Create a symbol element with given symbol configuration: shape, x, y, width, height, color\n * @see http://echarts.baidu.com/option.html#series-scatter.symbol\n * @param {string} symbolDesc\n * @param {number} x\n * @param {number} y\n * @param {number} w\n * @param {number} h\n * @param {string} color\n */\n\n/**\n * Create scale\n * @param {Array.<number>} dataExtent\n * @param {Object|module:echarts/Model} option\n */\nfunction createScale(dataExtent, option) {\n var axisModel = option;\n\n if (!Model.isInstance(option)) {\n axisModel = new Model(option);\n zrUtil.mixin(axisModel, axisModelCommonMixin);\n }\n\n var scale = axisHelper.createScaleByModel(axisModel);\n scale.setExtent(dataExtent[0], dataExtent[1]);\n axisHelper.niceScaleExtent(scale, axisModel);\n return scale;\n}\n/**\n * Mixin common methods to axis model,\n *\n * Inlcude methods\n * `getFormattedLabels() => Array.<string>`\n * `getCategories() => Array.<string>`\n * `getMin(origin: boolean) => number`\n * `getMax(origin: boolean) => number`\n * `getNeedCrossZero() => boolean`\n * `setRange(start: number, end: number)`\n * `resetRange()`\n */\n\n\nfunction mixinAxisModelCommonMethods(Model) {\n zrUtil.mixin(Model, axisModelCommonMixin);\n}\n\nexports.createList = createList;\nexports.dataStack = dataStack;\nexports.createScale = createScale;\nexports.mixinAxisModelCommonMethods = mixinAxisModelCommonMethods;","/**\n * 3x2矩阵操作类\n * @exports zrender/tool/matrix\n */\nvar ArrayCtor = typeof Float32Array === 'undefined' ? Array : Float32Array;\n/**\n * Create a identity matrix.\n * @return {Float32Array|Array.<number>}\n */\n\nfunction create() {\n var out = new ArrayCtor(6);\n identity(out);\n return out;\n}\n/**\n * 设置矩阵为单位矩阵\n * @param {Float32Array|Array.<number>} out\n */\n\n\nfunction identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n out[4] = 0;\n out[5] = 0;\n return out;\n}\n/**\n * 复制矩阵\n * @param {Float32Array|Array.<number>} out\n * @param {Float32Array|Array.<number>} m\n */\n\n\nfunction copy(out, m) {\n out[0] = m[0];\n out[1] = m[1];\n out[2] = m[2];\n out[3] = m[3];\n out[4] = m[4];\n out[5] = m[5];\n return out;\n}\n/**\n * 矩阵相乘\n * @param {Float32Array|Array.<number>} out\n * @param {Float32Array|Array.<number>} m1\n * @param {Float32Array|Array.<number>} m2\n */\n\n\nfunction mul(out, m1, m2) {\n // Consider matrix.mul(m, m2, m);\n // where out is the same as m2.\n // So use temp variable to escape error.\n var out0 = m1[0] * m2[0] + m1[2] * m2[1];\n var out1 = m1[1] * m2[0] + m1[3] * m2[1];\n var out2 = m1[0] * m2[2] + m1[2] * m2[3];\n var out3 = m1[1] * m2[2] + m1[3] * m2[3];\n var out4 = m1[0] * m2[4] + m1[2] * m2[5] + m1[4];\n var out5 = m1[1] * m2[4] + m1[3] * m2[5] + m1[5];\n out[0] = out0;\n out[1] = out1;\n out[2] = out2;\n out[3] = out3;\n out[4] = out4;\n out[5] = out5;\n return out;\n}\n/**\n * 平移变换\n * @param {Float32Array|Array.<number>} out\n * @param {Float32Array|Array.<number>} a\n * @param {Float32Array|Array.<number>} v\n */\n\n\nfunction translate(out, a, v) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4] + v[0];\n out[5] = a[5] + v[1];\n return out;\n}\n/**\n * 旋转变换\n * @param {Float32Array|Array.<number>} out\n * @param {Float32Array|Array.<number>} a\n * @param {number} rad\n */\n\n\nfunction rotate(out, a, rad) {\n var aa = a[0];\n var ac = a[2];\n var atx = a[4];\n var ab = a[1];\n var ad = a[3];\n var aty = a[5];\n var st = Math.sin(rad);\n var ct = Math.cos(rad);\n out[0] = aa * ct + ab * st;\n out[1] = -aa * st + ab * ct;\n out[2] = ac * ct + ad * st;\n out[3] = -ac * st + ct * ad;\n out[4] = ct * atx + st * aty;\n out[5] = ct * aty - st * atx;\n return out;\n}\n/**\n * 缩放变换\n * @param {Float32Array|Array.<number>} out\n * @param {Float32Array|Array.<number>} a\n * @param {Float32Array|Array.<number>} v\n */\n\n\nfunction scale(out, a, v) {\n var vx = v[0];\n var vy = v[1];\n out[0] = a[0] * vx;\n out[1] = a[1] * vy;\n out[2] = a[2] * vx;\n out[3] = a[3] * vy;\n out[4] = a[4] * vx;\n out[5] = a[5] * vy;\n return out;\n}\n/**\n * 求逆矩阵\n * @param {Float32Array|Array.<number>} out\n * @param {Float32Array|Array.<number>} a\n */\n\n\nfunction invert(out, a) {\n var aa = a[0];\n var ac = a[2];\n var atx = a[4];\n var ab = a[1];\n var ad = a[3];\n var aty = a[5];\n var det = aa * ad - ab * ac;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = ad * det;\n out[1] = -ab * det;\n out[2] = -ac * det;\n out[3] = aa * det;\n out[4] = (ac * aty - ad * atx) * det;\n out[5] = (ab * atx - aa * aty) * det;\n return out;\n}\n/**\n * Clone a new matrix.\n * @param {Float32Array|Array.<number>} a\n */\n\n\nfunction clone(a) {\n var b = create();\n copy(b, a);\n return b;\n}\n\nexports.create = create;\nexports.identity = identity;\nexports.copy = copy;\nexports.mul = mul;\nexports.translate = translate;\nexports.rotate = rotate;\nexports.scale = scale;\nexports.invert = invert;\nexports.clone = clone;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar env = require(\"zrender/lib/core/env\");\n\nvar _model = require(\"../../util/model\");\n\nvar makeInner = _model.makeInner;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar inner = makeInner();\nvar each = zrUtil.each;\n/**\n * @param {string} key\n * @param {module:echarts/ExtensionAPI} api\n * @param {Function} handler\n * param: {string} currTrigger\n * param: {Array.<number>} point\n */\n\nfunction register(key, api, handler) {\n if (env.node) {\n return;\n }\n\n var zr = api.getZr();\n inner(zr).records || (inner(zr).records = {});\n initGlobalListeners(zr, api);\n var record = inner(zr).records[key] || (inner(zr).records[key] = {});\n record.handler = handler;\n}\n\nfunction initGlobalListeners(zr, api) {\n if (inner(zr).initialized) {\n return;\n }\n\n inner(zr).initialized = true;\n useHandler('click', zrUtil.curry(doEnter, 'click'));\n useHandler('mousemove', zrUtil.curry(doEnter, 'mousemove')); // useHandler('mouseout', onLeave);\n\n useHandler('globalout', onLeave);\n\n function useHandler(eventType, cb) {\n zr.on(eventType, function (e) {\n var dis = makeDispatchAction(api);\n each(inner(zr).records, function (record) {\n record && cb(record, e, dis.dispatchAction);\n });\n dispatchTooltipFinally(dis.pendings, api);\n });\n }\n}\n\nfunction dispatchTooltipFinally(pendings, api) {\n var showLen = pendings.showTip.length;\n var hideLen = pendings.hideTip.length;\n var actuallyPayload;\n\n if (showLen) {\n actuallyPayload = pendings.showTip[showLen - 1];\n } else if (hideLen) {\n actuallyPayload = pendings.hideTip[hideLen - 1];\n }\n\n if (actuallyPayload) {\n actuallyPayload.dispatchAction = null;\n api.dispatchAction(actuallyPayload);\n }\n}\n\nfunction onLeave(record, e, dispatchAction) {\n record.handler('leave', null, dispatchAction);\n}\n\nfunction doEnter(currTrigger, record, e, dispatchAction) {\n record.handler(currTrigger, e, dispatchAction);\n}\n\nfunction makeDispatchAction(api) {\n var pendings = {\n showTip: [],\n hideTip: []\n }; // FIXME\n // better approach?\n // 'showTip' and 'hideTip' can be triggered by axisPointer and tooltip,\n // which may be conflict, (axisPointer call showTip but tooltip call hideTip);\n // So we have to add \"final stage\" to merge those dispatched actions.\n\n var dispatchAction = function (payload) {\n var pendingList = pendings[payload.type];\n\n if (pendingList) {\n pendingList.push(payload);\n } else {\n payload.dispatchAction = dispatchAction;\n api.dispatchAction(payload);\n }\n };\n\n return {\n dispatchAction: dispatchAction,\n pendings: pendings\n };\n}\n/**\n * @param {string} key\n * @param {module:echarts/ExtensionAPI} api\n */\n\n\nfunction unregister(key, api) {\n if (env.node) {\n return;\n }\n\n var zr = api.getZr();\n var record = (inner(zr).records || {})[key];\n\n if (record) {\n inner(zr).records[key] = null;\n }\n}\n\nexports.register = register;\nexports.unregister = unregister;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Scale = require(\"./Scale\");\n\nvar OrdinalMeta = require(\"../data/OrdinalMeta\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Linear continuous scale\n * @module echarts/coord/scale/Ordinal\n *\n * http://en.wikipedia.org/wiki/Level_of_measurement\n */\n// FIXME only one data\nvar scaleProto = Scale.prototype;\nvar OrdinalScale = Scale.extend({\n type: 'ordinal',\n\n /**\n * @param {module:echarts/data/OrdianlMeta|Array.<string>} ordinalMeta\n */\n init: function (ordinalMeta, extent) {\n // Caution: Should not use instanceof, consider ec-extensions using\n // import approach to get OrdinalMeta class.\n if (!ordinalMeta || zrUtil.isArray(ordinalMeta)) {\n ordinalMeta = new OrdinalMeta({\n categories: ordinalMeta\n });\n }\n\n this._ordinalMeta = ordinalMeta;\n this._extent = extent || [0, ordinalMeta.categories.length - 1];\n },\n parse: function (val) {\n return typeof val === 'string' ? this._ordinalMeta.getOrdinal(val) // val might be float.\n : Math.round(val);\n },\n contain: function (rank) {\n rank = this.parse(rank);\n return scaleProto.contain.call(this, rank) && this._ordinalMeta.categories[rank] != null;\n },\n\n /**\n * Normalize given rank or name to linear [0, 1]\n * @param {number|string} [val]\n * @return {number}\n */\n normalize: function (val) {\n return scaleProto.normalize.call(this, this.parse(val));\n },\n scale: function (val) {\n return Math.round(scaleProto.scale.call(this, val));\n },\n\n /**\n * @return {Array}\n */\n getTicks: function () {\n var ticks = [];\n var extent = this._extent;\n var rank = extent[0];\n\n while (rank <= extent[1]) {\n ticks.push(rank);\n rank++;\n }\n\n return ticks;\n },\n\n /**\n * Get item on rank n\n * @param {number} n\n * @return {string}\n */\n getLabel: function (n) {\n if (!this.isBlank()) {\n // Note that if no data, ordinalMeta.categories is an empty array.\n return this._ordinalMeta.categories[n];\n }\n },\n\n /**\n * @return {number}\n */\n count: function () {\n return this._extent[1] - this._extent[0] + 1;\n },\n\n /**\n * @override\n */\n unionExtentFromData: function (data, dim) {\n this.unionExtent(data.getApproximateExtent(dim));\n },\n getOrdinalMeta: function () {\n return this._ordinalMeta;\n },\n niceTicks: zrUtil.noop,\n niceExtent: zrUtil.noop\n});\n/**\n * @return {module:echarts/scale/Time}\n */\n\nOrdinalScale.create = function () {\n return new OrdinalScale();\n};\n\nvar _default = OrdinalScale;\nmodule.exports = _default;","var zrUtil = require(\"../core/util\");\n\nvar Style = require(\"./Style\");\n\nvar Element = require(\"../Element\");\n\nvar RectText = require(\"./mixin/RectText\");\n\n/**\n * 可绘制的图形基类\n * Base class of all displayable graphic objects\n * @module zrender/graphic/Displayable\n */\n\n/**\n * @alias module:zrender/graphic/Displayable\n * @extends module:zrender/Element\n * @extends module:zrender/graphic/mixin/RectText\n */\nfunction Displayable(opts) {\n opts = opts || {};\n Element.call(this, opts); // Extend properties\n\n for (var name in opts) {\n if (opts.hasOwnProperty(name) && name !== 'style') {\n this[name] = opts[name];\n }\n }\n /**\n * @type {module:zrender/graphic/Style}\n */\n\n\n this.style = new Style(opts.style, this);\n this._rect = null; // Shapes for cascade clipping.\n\n this.__clipPaths = []; // FIXME Stateful must be mixined after style is setted\n // Stateful.call(this, opts);\n}\n\nDisplayable.prototype = {\n constructor: Displayable,\n type: 'displayable',\n\n /**\n * Displayable 是否为脏,Painter 中会根据该标记判断是否需要是否需要重新绘制\n * Dirty flag. From which painter will determine if this displayable object needs brush\n * @name module:zrender/graphic/Displayable#__dirty\n * @type {boolean}\n */\n __dirty: true,\n\n /**\n * 图形是否可见,为true时不绘制图形,但是仍能触发鼠标事件\n * If ignore drawing of the displayable object. Mouse event will still be triggered\n * @name module:/zrender/graphic/Displayable#invisible\n * @type {boolean}\n * @default false\n */\n invisible: false,\n\n /**\n * @name module:/zrender/graphic/Displayable#z\n * @type {number}\n * @default 0\n */\n z: 0,\n\n /**\n * @name module:/zrender/graphic/Displayable#z\n * @type {number}\n * @default 0\n */\n z2: 0,\n\n /**\n * z层level,决定绘画在哪层canvas中\n * @name module:/zrender/graphic/Displayable#zlevel\n * @type {number}\n * @default 0\n */\n zlevel: 0,\n\n /**\n * 是否可拖拽\n * @name module:/zrender/graphic/Displayable#draggable\n * @type {boolean}\n * @default false\n */\n draggable: false,\n\n /**\n * 是否正在拖拽\n * @name module:/zrender/graphic/Displayable#draggable\n * @type {boolean}\n * @default false\n */\n dragging: false,\n\n /**\n * 是否相应鼠标事件\n * @name module:/zrender/graphic/Displayable#silent\n * @type {boolean}\n * @default false\n */\n silent: false,\n\n /**\n * If enable culling\n * @type {boolean}\n * @default false\n */\n culling: false,\n\n /**\n * Mouse cursor when hovered\n * @name module:/zrender/graphic/Displayable#cursor\n * @type {string}\n */\n cursor: 'pointer',\n\n /**\n * If hover area is bounding rect\n * @name module:/zrender/graphic/Displayable#rectHover\n * @type {string}\n */\n rectHover: false,\n\n /**\n * Render the element progressively when the value >= 0,\n * usefull for large data.\n * @type {boolean}\n */\n progressive: false,\n\n /**\n * @type {boolean}\n */\n incremental: false,\n\n /**\n * Scale ratio for global scale.\n * @type {boolean}\n */\n globalScaleRatio: 1,\n beforeBrush: function (ctx) {},\n afterBrush: function (ctx) {},\n\n /**\n * 图形绘制方法\n * @param {CanvasRenderingContext2D} ctx\n */\n // Interface\n brush: function (ctx, prevEl) {},\n\n /**\n * 获取最小包围盒\n * @return {module:zrender/core/BoundingRect}\n */\n // Interface\n getBoundingRect: function () {},\n\n /**\n * 判断坐标 x, y 是否在图形上\n * If displayable element contain coord x, y\n * @param {number} x\n * @param {number} y\n * @return {boolean}\n */\n contain: function (x, y) {\n return this.rectContain(x, y);\n },\n\n /**\n * @param {Function} cb\n * @param {} context\n */\n traverse: function (cb, context) {\n cb.call(context, this);\n },\n\n /**\n * 判断坐标 x, y 是否在图形的包围盒上\n * If bounding rect of element contain coord x, y\n * @param {number} x\n * @param {number} y\n * @return {boolean}\n */\n rectContain: function (x, y) {\n var coord = this.transformCoordToLocal(x, y);\n var rect = this.getBoundingRect();\n return rect.contain(coord[0], coord[1]);\n },\n\n /**\n * 标记图形元素为脏,并且在下一帧重绘\n * Mark displayable element dirty and refresh next frame\n */\n dirty: function () {\n this.__dirty = this.__dirtyText = true;\n this._rect = null;\n this.__zr && this.__zr.refresh();\n },\n\n /**\n * 图形是否会触发事件\n * If displayable object binded any event\n * @return {boolean}\n */\n // TODO, 通过 bind 绑定的事件\n // isSilent: function () {\n // return !(\n // this.hoverable || this.draggable\n // || this.onmousemove || this.onmouseover || this.onmouseout\n // || this.onmousedown || this.onmouseup || this.onclick\n // || this.ondragenter || this.ondragover || this.ondragleave\n // || this.ondrop\n // );\n // },\n\n /**\n * Alias for animate('style')\n * @param {boolean} loop\n */\n animateStyle: function (loop) {\n return this.animate('style', loop);\n },\n attrKV: function (key, value) {\n if (key !== 'style') {\n Element.prototype.attrKV.call(this, key, value);\n } else {\n this.style.set(value);\n }\n },\n\n /**\n * @param {Object|string} key\n * @param {*} value\n */\n setStyle: function (key, value) {\n this.style.set(key, value);\n this.dirty(false);\n return this;\n },\n\n /**\n * Use given style object\n * @param {Object} obj\n */\n useStyle: function (obj) {\n this.style = new Style(obj, this);\n this.dirty(false);\n return this;\n }\n};\nzrUtil.inherits(Displayable, Element);\nzrUtil.mixin(Displayable, RectText); // zrUtil.mixin(Displayable, Stateful);\n\nvar _default = Displayable;\nmodule.exports = _default;","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Polar = require(\"./Polar\");\n\nvar _number = require(\"../../util/number\");\n\nvar parsePercent = _number.parsePercent;\n\nvar _axisHelper = require(\"../../coord/axisHelper\");\n\nvar createScaleByModel = _axisHelper.createScaleByModel;\nvar niceScaleExtent = _axisHelper.niceScaleExtent;\n\nvar CoordinateSystem = require(\"../../CoordinateSystem\");\n\nvar _dataStackHelper = require(\"../../data/helper/dataStackHelper\");\n\nvar getStackedDimension = _dataStackHelper.getStackedDimension;\n\nrequire(\"./PolarModel\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// TODO Axis scale\n\n/**\n * Resize method bound to the polar\n * @param {module:echarts/coord/polar/PolarModel} polarModel\n * @param {module:echarts/ExtensionAPI} api\n */\nfunction resizePolar(polar, polarModel, api) {\n var center = polarModel.get('center');\n var width = api.getWidth();\n var height = api.getHeight();\n polar.cx = parsePercent(center[0], width);\n polar.cy = parsePercent(center[1], height);\n var radiusAxis = polar.getRadiusAxis();\n var size = Math.min(width, height) / 2;\n var radius = parsePercent(polarModel.get('radius'), size);\n radiusAxis.inverse ? radiusAxis.setExtent(radius, 0) : radiusAxis.setExtent(0, radius);\n}\n/**\n * Update polar\n */\n\n\nfunction updatePolarScale(ecModel, api) {\n var polar = this;\n var angleAxis = polar.getAngleAxis();\n var radiusAxis = polar.getRadiusAxis(); // Reset scale\n\n angleAxis.scale.setExtent(Infinity, -Infinity);\n radiusAxis.scale.setExtent(Infinity, -Infinity);\n ecModel.eachSeries(function (seriesModel) {\n if (seriesModel.coordinateSystem === polar) {\n var data = seriesModel.getData();\n zrUtil.each(data.mapDimension('radius', true), function (dim) {\n radiusAxis.scale.unionExtentFromData(data, getStackedDimension(data, dim));\n });\n zrUtil.each(data.mapDimension('angle', true), function (dim) {\n angleAxis.scale.unionExtentFromData(data, getStackedDimension(data, dim));\n });\n }\n });\n niceScaleExtent(angleAxis.scale, angleAxis.model);\n niceScaleExtent(radiusAxis.scale, radiusAxis.model); // Fix extent of category angle axis\n\n if (angleAxis.type === 'category' && !angleAxis.onBand) {\n var extent = angleAxis.getExtent();\n var diff = 360 / angleAxis.scale.count();\n angleAxis.inverse ? extent[1] += diff : extent[1] -= diff;\n angleAxis.setExtent(extent[0], extent[1]);\n }\n}\n/**\n * Set common axis properties\n * @param {module:echarts/coord/polar/AngleAxis|module:echarts/coord/polar/RadiusAxis}\n * @param {module:echarts/coord/polar/AxisModel}\n * @inner\n */\n\n\nfunction setAxis(axis, axisModel) {\n axis.type = axisModel.get('type');\n axis.scale = createScaleByModel(axisModel);\n axis.onBand = axisModel.get('boundaryGap') && axis.type === 'category';\n axis.inverse = axisModel.get('inverse');\n\n if (axisModel.mainType === 'angleAxis') {\n axis.inverse ^= axisModel.get('clockwise');\n var startAngle = axisModel.get('startAngle');\n axis.setExtent(startAngle, startAngle + (axis.inverse ? -360 : 360));\n } // Inject axis instance\n\n\n axisModel.axis = axis;\n axis.model = axisModel;\n}\n\nvar polarCreator = {\n dimensions: Polar.prototype.dimensions,\n create: function (ecModel, api) {\n var polarList = [];\n ecModel.eachComponent('polar', function (polarModel, idx) {\n var polar = new Polar(idx); // Inject resize and update method\n\n polar.update = updatePolarScale;\n var radiusAxis = polar.getRadiusAxis();\n var angleAxis = polar.getAngleAxis();\n var radiusAxisModel = polarModel.findAxisModel('radiusAxis');\n var angleAxisModel = polarModel.findAxisModel('angleAxis');\n setAxis(radiusAxis, radiusAxisModel);\n setAxis(angleAxis, angleAxisModel);\n resizePolar(polar, polarModel, api);\n polarList.push(polar);\n polarModel.coordinateSystem = polar;\n polar.model = polarModel;\n }); // Inject coordinateSystem to series\n\n ecModel.eachSeries(function (seriesModel) {\n if (seriesModel.get('coordinateSystem') === 'polar') {\n var polarModel = ecModel.queryComponents({\n mainType: 'polar',\n index: seriesModel.get('polarIndex'),\n id: seriesModel.get('polarId')\n })[0];\n seriesModel.coordinateSystem = polarModel.coordinateSystem;\n }\n });\n return polarList;\n }\n};\nCoordinateSystem.register('polar', polarCreator);","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar _number = require(\"../util/number\");\n\nvar parsePercent = _number.parsePercent;\n\nvar _dataStackHelper = require(\"../data/helper/dataStackHelper\");\n\nvar isDimensionStacked = _dataStackHelper.isDimensionStacked;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nfunction getSeriesStackId(seriesModel) {\n return seriesModel.get('stack') || '__ec_stack_' + seriesModel.seriesIndex;\n}\n\nfunction getAxisKey(axis) {\n return axis.dim;\n}\n/**\n * @param {string} seriesType\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n */\n\n\nfunction barLayoutPolar(seriesType, ecModel, api) {\n // FIXME\n // Revert becuase it brings bar progressive bug.\n // The complete fix will be added in the next version.\n var width = api.getWidth();\n var height = api.getHeight();\n var lastStackCoords = {};\n var barWidthAndOffset = calRadialBar(zrUtil.filter(ecModel.getSeriesByType(seriesType), function (seriesModel) {\n return !ecModel.isSeriesFiltered(seriesModel) && seriesModel.coordinateSystem && seriesModel.coordinateSystem.type === 'polar';\n }));\n ecModel.eachSeriesByType(seriesType, function (seriesModel) {\n // Check series coordinate, do layout for polar only\n if (seriesModel.coordinateSystem.type !== 'polar') {\n return;\n }\n\n var data = seriesModel.getData();\n var polar = seriesModel.coordinateSystem;\n var baseAxis = polar.getBaseAxis();\n var stackId = getSeriesStackId(seriesModel);\n var columnLayoutInfo = barWidthAndOffset[getAxisKey(baseAxis)][stackId];\n var columnOffset = columnLayoutInfo.offset;\n var columnWidth = columnLayoutInfo.width;\n var valueAxis = polar.getOtherAxis(baseAxis);\n var cx = seriesModel.coordinateSystem.cx;\n var cy = seriesModel.coordinateSystem.cy;\n var barMinHeight = seriesModel.get('barMinHeight') || 0;\n var barMinAngle = seriesModel.get('barMinAngle') || 0;\n lastStackCoords[stackId] = lastStackCoords[stackId] || [];\n var valueDim = data.mapDimension(valueAxis.dim);\n var baseDim = data.mapDimension(baseAxis.dim);\n var stacked = isDimensionStacked(data, valueDim\n /*, baseDim*/\n );\n var valueAxisStart = valueAxis.getExtent()[0];\n\n for (var idx = 0, len = data.count(); idx < len; idx++) {\n var value = data.get(valueDim, idx);\n var baseValue = data.get(baseDim, idx);\n\n if (isNaN(value)) {\n continue;\n }\n\n var sign = value >= 0 ? 'p' : 'n';\n var baseCoord = valueAxisStart; // Because of the barMinHeight, we can not use the value in\n // stackResultDimension directly.\n // Only ordinal axis can be stacked.\n\n if (stacked) {\n if (!lastStackCoords[stackId][baseValue]) {\n lastStackCoords[stackId][baseValue] = {\n p: valueAxisStart,\n // Positive stack\n n: valueAxisStart // Negative stack\n\n };\n } // Should also consider #4243\n\n\n baseCoord = lastStackCoords[stackId][baseValue][sign];\n }\n\n var r0;\n var r;\n var startAngle;\n var endAngle; // radial sector\n\n if (valueAxis.dim === 'radius') {\n var radiusSpan = valueAxis.dataToRadius(value) - valueAxisStart;\n var angle = baseAxis.dataToAngle(baseValue);\n\n if (Math.abs(radiusSpan) < barMinHeight) {\n radiusSpan = (radiusSpan < 0 ? -1 : 1) * barMinHeight;\n }\n\n r0 = baseCoord;\n r = baseCoord + radiusSpan;\n startAngle = angle - columnOffset;\n endAngle = startAngle - columnWidth;\n stacked && (lastStackCoords[stackId][baseValue][sign] = r);\n } // tangential sector\n else {\n // angleAxis must be clamped.\n var angleSpan = valueAxis.dataToAngle(value, true) - valueAxisStart;\n var radius = baseAxis.dataToRadius(baseValue);\n\n if (Math.abs(angleSpan) < barMinAngle) {\n angleSpan = (angleSpan < 0 ? -1 : 1) * barMinAngle;\n }\n\n r0 = radius + columnOffset;\n r = r0 + columnWidth;\n startAngle = baseCoord;\n endAngle = baseCoord + angleSpan; // if the previous stack is at the end of the ring,\n // add a round to differentiate it from origin\n // var extent = angleAxis.getExtent();\n // var stackCoord = angle;\n // if (stackCoord === extent[0] && value > 0) {\n // stackCoord = extent[1];\n // }\n // else if (stackCoord === extent[1] && value < 0) {\n // stackCoord = extent[0];\n // }\n\n stacked && (lastStackCoords[stackId][baseValue][sign] = endAngle);\n }\n\n data.setItemLayout(idx, {\n cx: cx,\n cy: cy,\n r0: r0,\n r: r,\n // Consider that positive angle is anti-clockwise,\n // while positive radian of sector is clockwise\n startAngle: -startAngle * Math.PI / 180,\n endAngle: -endAngle * Math.PI / 180\n });\n }\n }, this);\n}\n/**\n * Calculate bar width and offset for radial bar charts\n */\n\n\nfunction calRadialBar(barSeries, api) {\n // Columns info on each category axis. Key is polar name\n var columnsMap = {};\n zrUtil.each(barSeries, function (seriesModel, idx) {\n var data = seriesModel.getData();\n var polar = seriesModel.coordinateSystem;\n var baseAxis = polar.getBaseAxis();\n var axisExtent = baseAxis.getExtent();\n var bandWidth = baseAxis.type === 'category' ? baseAxis.getBandWidth() : Math.abs(axisExtent[1] - axisExtent[0]) / data.count();\n var columnsOnAxis = columnsMap[getAxisKey(baseAxis)] || {\n bandWidth: bandWidth,\n remainedWidth: bandWidth,\n autoWidthCount: 0,\n categoryGap: '20%',\n gap: '30%',\n stacks: {}\n };\n var stacks = columnsOnAxis.stacks;\n columnsMap[getAxisKey(baseAxis)] = columnsOnAxis;\n var stackId = getSeriesStackId(seriesModel);\n\n if (!stacks[stackId]) {\n columnsOnAxis.autoWidthCount++;\n }\n\n stacks[stackId] = stacks[stackId] || {\n width: 0,\n maxWidth: 0\n };\n var barWidth = parsePercent(seriesModel.get('barWidth'), bandWidth);\n var barMaxWidth = parsePercent(seriesModel.get('barMaxWidth'), bandWidth);\n var barGap = seriesModel.get('barGap');\n var barCategoryGap = seriesModel.get('barCategoryGap');\n\n if (barWidth && !stacks[stackId].width) {\n barWidth = Math.min(columnsOnAxis.remainedWidth, barWidth);\n stacks[stackId].width = barWidth;\n columnsOnAxis.remainedWidth -= barWidth;\n }\n\n barMaxWidth && (stacks[stackId].maxWidth = barMaxWidth);\n barGap != null && (columnsOnAxis.gap = barGap);\n barCategoryGap != null && (columnsOnAxis.categoryGap = barCategoryGap);\n });\n var result = {};\n zrUtil.each(columnsMap, function (columnsOnAxis, coordSysName) {\n result[coordSysName] = {};\n var stacks = columnsOnAxis.stacks;\n var bandWidth = columnsOnAxis.bandWidth;\n var categoryGap = parsePercent(columnsOnAxis.categoryGap, bandWidth);\n var barGapPercent = parsePercent(columnsOnAxis.gap, 1);\n var remainedWidth = columnsOnAxis.remainedWidth;\n var autoWidthCount = columnsOnAxis.autoWidthCount;\n var autoWidth = (remainedWidth - categoryGap) / (autoWidthCount + (autoWidthCount - 1) * barGapPercent);\n autoWidth = Math.max(autoWidth, 0); // Find if any auto calculated bar exceeded maxBarWidth\n\n zrUtil.each(stacks, function (column, stack) {\n var maxWidth = column.maxWidth;\n\n if (maxWidth && maxWidth < autoWidth) {\n maxWidth = Math.min(maxWidth, remainedWidth);\n\n if (column.width) {\n maxWidth = Math.min(maxWidth, column.width);\n }\n\n remainedWidth -= maxWidth;\n column.width = maxWidth;\n autoWidthCount--;\n }\n }); // Recalculate width again\n\n autoWidth = (remainedWidth - categoryGap) / (autoWidthCount + (autoWidthCount - 1) * barGapPercent);\n autoWidth = Math.max(autoWidth, 0);\n var widthSum = 0;\n var lastColumn;\n zrUtil.each(stacks, function (column, idx) {\n if (!column.width) {\n column.width = autoWidth;\n }\n\n lastColumn = column;\n widthSum += column.width * (1 + barGapPercent);\n });\n\n if (lastColumn) {\n widthSum -= lastColumn.width * barGapPercent;\n }\n\n var offset = -widthSum / 2;\n zrUtil.each(stacks, function (column, stackId) {\n result[coordSysName][stackId] = result[coordSysName][stackId] || {\n offset: offset,\n width: column.width\n };\n offset += column.width * (1 + barGapPercent);\n });\n });\n return result;\n}\n\nvar _default = barLayoutPolar;\nmodule.exports = _default;","import mod from \"-!../../mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../css-loader/index.js??ref--6-oneOf-1-1!../../vue-loader/lib/loaders/stylePostLoader.js!../../postcss-loader/src/index.js??ref--6-oneOf-1-2!../../cache-loader/dist/cjs.js??ref--0-0!../../vue-loader/lib/index.js??vue-loader-options!./ECharts.vue?vue&type=style&index=0&lang=css&\"; export default mod; export * from \"-!../../mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../css-loader/index.js??ref--6-oneOf-1-1!../../vue-loader/lib/loaders/stylePostLoader.js!../../postcss-loader/src/index.js??ref--6-oneOf-1-2!../../cache-loader/dist/cjs.js??ref--0-0!../../vue-loader/lib/index.js??vue-loader-options!./ECharts.vue?vue&type=style&index=0&lang=css&\"","/**\n * Event Mixin\n * @module zrender/mixin/Eventful\n * @author Kener (@Kener-林峰, kener.linfeng@gmail.com)\n * pissang (https://www.github.com/pissang)\n */\nvar arrySlice = Array.prototype.slice;\n/**\n * Event dispatcher.\n *\n * @alias module:zrender/mixin/Eventful\n * @constructor\n * @param {Object} [eventProcessor] The object eventProcessor is the scope when\n * `eventProcessor.xxx` called.\n * @param {Function} [eventProcessor.normalizeQuery]\n * param: {string|Object} Raw query.\n * return: {string|Object} Normalized query.\n * @param {Function} [eventProcessor.filter] Event will be dispatched only\n * if it returns `true`.\n * param: {string} eventType\n * param: {string|Object} query\n * return: {boolean}\n * @param {Function} [eventProcessor.afterTrigger] Call after all handlers called.\n * param: {string} eventType\n */\n\nvar Eventful = function (eventProcessor) {\n this._$handlers = {};\n this._$eventProcessor = eventProcessor;\n};\n\nEventful.prototype = {\n constructor: Eventful,\n\n /**\n * The handler can only be triggered once, then removed.\n *\n * @param {string} event The event name.\n * @param {string|Object} [query] Condition used on event filter.\n * @param {Function} handler The event handler.\n * @param {Object} context\n */\n one: function (event, query, handler, context) {\n return on(this, event, query, handler, context, true);\n },\n\n /**\n * Bind a handler.\n *\n * @param {string} event The event name.\n * @param {string|Object} [query] Condition used on event filter.\n * @param {Function} handler The event handler.\n * @param {Object} [context]\n */\n on: function (event, query, handler, context) {\n return on(this, event, query, handler, context, false);\n },\n\n /**\n * Whether any handler has bound.\n *\n * @param {string} event\n * @return {boolean}\n */\n isSilent: function (event) {\n var _h = this._$handlers;\n return !_h[event] || !_h[event].length;\n },\n\n /**\n * Unbind a event.\n *\n * @param {string} event The event name.\n * @param {Function} [handler] The event handler.\n */\n off: function (event, handler) {\n var _h = this._$handlers;\n\n if (!event) {\n this._$handlers = {};\n return this;\n }\n\n if (handler) {\n if (_h[event]) {\n var newList = [];\n\n for (var i = 0, l = _h[event].length; i < l; i++) {\n if (_h[event][i].h !== handler) {\n newList.push(_h[event][i]);\n }\n }\n\n _h[event] = newList;\n }\n\n if (_h[event] && _h[event].length === 0) {\n delete _h[event];\n }\n } else {\n delete _h[event];\n }\n\n return this;\n },\n\n /**\n * Dispatch a event.\n *\n * @param {string} type The event name.\n */\n trigger: function (type) {\n var _h = this._$handlers[type];\n var eventProcessor = this._$eventProcessor;\n\n if (_h) {\n var args = arguments;\n var argLen = args.length;\n\n if (argLen > 3) {\n args = arrySlice.call(args, 1);\n }\n\n var len = _h.length;\n\n for (var i = 0; i < len;) {\n var hItem = _h[i];\n\n if (eventProcessor && eventProcessor.filter && hItem.query != null && !eventProcessor.filter(type, hItem.query)) {\n i++;\n continue;\n } // Optimize advise from backbone\n\n\n switch (argLen) {\n case 1:\n hItem.h.call(hItem.ctx);\n break;\n\n case 2:\n hItem.h.call(hItem.ctx, args[1]);\n break;\n\n case 3:\n hItem.h.call(hItem.ctx, args[1], args[2]);\n break;\n\n default:\n // have more than 2 given arguments\n hItem.h.apply(hItem.ctx, args);\n break;\n }\n\n if (hItem.one) {\n _h.splice(i, 1);\n\n len--;\n } else {\n i++;\n }\n }\n }\n\n eventProcessor && eventProcessor.afterTrigger && eventProcessor.afterTrigger(type);\n return this;\n },\n\n /**\n * Dispatch a event with context, which is specified at the last parameter.\n *\n * @param {string} type The event name.\n */\n triggerWithContext: function (type) {\n var _h = this._$handlers[type];\n var eventProcessor = this._$eventProcessor;\n\n if (_h) {\n var args = arguments;\n var argLen = args.length;\n\n if (argLen > 4) {\n args = arrySlice.call(args, 1, args.length - 1);\n }\n\n var ctx = args[args.length - 1];\n var len = _h.length;\n\n for (var i = 0; i < len;) {\n var hItem = _h[i];\n\n if (eventProcessor && eventProcessor.filter && hItem.query != null && !eventProcessor.filter(type, hItem.query)) {\n i++;\n continue;\n } // Optimize advise from backbone\n\n\n switch (argLen) {\n case 1:\n hItem.h.call(ctx);\n break;\n\n case 2:\n hItem.h.call(ctx, args[1]);\n break;\n\n case 3:\n hItem.h.call(ctx, args[1], args[2]);\n break;\n\n default:\n // have more than 2 given arguments\n hItem.h.apply(ctx, args);\n break;\n }\n\n if (hItem.one) {\n _h.splice(i, 1);\n\n len--;\n } else {\n i++;\n }\n }\n }\n\n eventProcessor && eventProcessor.afterTrigger && eventProcessor.afterTrigger(type);\n return this;\n }\n};\n\nfunction normalizeQuery(host, query) {\n var eventProcessor = host._$eventProcessor;\n\n if (query != null && eventProcessor && eventProcessor.normalizeQuery) {\n query = eventProcessor.normalizeQuery(query);\n }\n\n return query;\n}\n\nfunction on(eventful, event, query, handler, context, isOnce) {\n var _h = eventful._$handlers;\n\n if (typeof query === 'function') {\n context = handler;\n handler = query;\n query = null;\n }\n\n if (!handler || !event) {\n return eventful;\n }\n\n query = normalizeQuery(eventful, query);\n\n if (!_h[event]) {\n _h[event] = [];\n }\n\n for (var i = 0; i < _h[event].length; i++) {\n if (_h[event][i].h === handler) {\n return eventful;\n }\n }\n\n var wrap = {\n h: handler,\n one: isOnce,\n query: query,\n ctx: context || eventful,\n // FIXME\n // Do not publish this feature util it is proved that it makes sense.\n callAtLast: handler.zrEventfulCallAtLast\n };\n var lastIndex = _h[event].length - 1;\n var lastWrap = _h[event][lastIndex];\n lastWrap && lastWrap.callAtLast ? _h[event].splice(lastIndex, 0, wrap) : _h[event].push(wrap);\n return eventful;\n} // ----------------------\n// The events in zrender\n// ----------------------\n\n/**\n * @event module:zrender/mixin/Eventful#onclick\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#onmouseover\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#onmouseout\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#onmousemove\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#onmousewheel\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#onmousedown\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#onmouseup\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#ondrag\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#ondragstart\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#ondragend\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#ondragenter\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#ondragleave\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#ondragover\n * @type {Function}\n * @default null\n */\n\n/**\n * @event module:zrender/mixin/Eventful#ondrop\n * @type {Function}\n * @default null\n */\n\n\nvar _default = Eventful;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// import * as axisHelper from './axisHelper';\nvar _default = {\n /**\n * @param {boolean} origin\n * @return {number|string} min value or 'dataMin' or null/undefined (means auto) or NaN\n */\n getMin: function (origin) {\n var option = this.option;\n var min = !origin && option.rangeStart != null ? option.rangeStart : option.min;\n\n if (this.axis && min != null && min !== 'dataMin' && typeof min !== 'function' && !zrUtil.eqNaN(min)) {\n min = this.axis.scale.parse(min);\n }\n\n return min;\n },\n\n /**\n * @param {boolean} origin\n * @return {number|string} max value or 'dataMax' or null/undefined (means auto) or NaN\n */\n getMax: function (origin) {\n var option = this.option;\n var max = !origin && option.rangeEnd != null ? option.rangeEnd : option.max;\n\n if (this.axis && max != null && max !== 'dataMax' && typeof max !== 'function' && !zrUtil.eqNaN(max)) {\n max = this.axis.scale.parse(max);\n }\n\n return max;\n },\n\n /**\n * @return {boolean}\n */\n getNeedCrossZero: function () {\n var option = this.option;\n return option.rangeStart != null || option.rangeEnd != null ? false : !option.scale;\n },\n\n /**\n * Should be implemented by each axis model if necessary.\n * @return {module:echarts/model/Component} coordinate system model\n */\n getCoordSysModel: zrUtil.noop,\n\n /**\n * @param {number} rangeStart Can only be finite number or null/undefined or NaN.\n * @param {number} rangeEnd Can only be finite number or null/undefined or NaN.\n */\n setRange: function (rangeStart, rangeEnd) {\n this.option.rangeStart = rangeStart;\n this.option.rangeEnd = rangeEnd;\n },\n\n /**\n * Reset range\n */\n resetRange: function () {\n // rangeStart and rangeEnd is readonly.\n this.option.rangeStart = this.option.rangeEnd = null;\n }\n};\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar coordinateSystemCreators = {};\n\nfunction CoordinateSystemManager() {\n this._coordinateSystems = [];\n}\n\nCoordinateSystemManager.prototype = {\n constructor: CoordinateSystemManager,\n create: function (ecModel, api) {\n var coordinateSystems = [];\n zrUtil.each(coordinateSystemCreators, function (creater, type) {\n var list = creater.create(ecModel, api);\n coordinateSystems = coordinateSystems.concat(list || []);\n });\n this._coordinateSystems = coordinateSystems;\n },\n update: function (ecModel, api) {\n zrUtil.each(this._coordinateSystems, function (coordSys) {\n coordSys.update && coordSys.update(ecModel, api);\n });\n },\n getCoordinateSystems: function () {\n return this._coordinateSystems.slice();\n }\n};\n\nCoordinateSystemManager.register = function (type, coordinateSystemCreator) {\n coordinateSystemCreators[type] = coordinateSystemCreator;\n};\n\nCoordinateSystemManager.get = function (type) {\n return coordinateSystemCreators[type];\n};\n\nvar _default = CoordinateSystemManager;\nmodule.exports = _default;","var curve = require(\"./curve\");\n\nvar vec2 = require(\"./vector\");\n\nvar bbox = require(\"./bbox\");\n\nvar BoundingRect = require(\"./BoundingRect\");\n\nvar _config = require(\"../config\");\n\nvar dpr = _config.devicePixelRatio;\n\n/**\n * Path 代理,可以在`buildPath`中用于替代`ctx`, 会保存每个path操作的命令到pathCommands属性中\n * 可以用于 isInsidePath 判断以及获取boundingRect\n *\n * @module zrender/core/PathProxy\n * @author Yi Shen (http://www.github.com/pissang)\n */\n// TODO getTotalLength, getPointAtLength\nvar CMD = {\n M: 1,\n L: 2,\n C: 3,\n Q: 4,\n A: 5,\n Z: 6,\n // Rect\n R: 7\n}; // var CMD_MEM_SIZE = {\n// M: 3,\n// L: 3,\n// C: 7,\n// Q: 5,\n// A: 9,\n// R: 5,\n// Z: 1\n// };\n\nvar min = [];\nvar max = [];\nvar min2 = [];\nvar max2 = [];\nvar mathMin = Math.min;\nvar mathMax = Math.max;\nvar mathCos = Math.cos;\nvar mathSin = Math.sin;\nvar mathSqrt = Math.sqrt;\nvar mathAbs = Math.abs;\nvar hasTypedArray = typeof Float32Array !== 'undefined';\n/**\n * @alias module:zrender/core/PathProxy\n * @constructor\n */\n\nvar PathProxy = function (notSaveData) {\n this._saveData = !(notSaveData || false);\n\n if (this._saveData) {\n /**\n * Path data. Stored as flat array\n * @type {Array.<Object>}\n */\n this.data = [];\n }\n\n this._ctx = null;\n};\n/**\n * 快速计算Path包围盒(并不是最小包围盒)\n * @return {Object}\n */\n\n\nPathProxy.prototype = {\n constructor: PathProxy,\n _xi: 0,\n _yi: 0,\n _x0: 0,\n _y0: 0,\n // Unit x, Unit y. Provide for avoiding drawing that too short line segment\n _ux: 0,\n _uy: 0,\n _len: 0,\n _lineDash: null,\n _dashOffset: 0,\n _dashIdx: 0,\n _dashSum: 0,\n\n /**\n * @readOnly\n */\n setScale: function (sx, sy) {\n this._ux = mathAbs(1 / dpr / sx) || 0;\n this._uy = mathAbs(1 / dpr / sy) || 0;\n },\n getContext: function () {\n return this._ctx;\n },\n\n /**\n * @param {CanvasRenderingContext2D} ctx\n * @return {module:zrender/core/PathProxy}\n */\n beginPath: function (ctx) {\n this._ctx = ctx;\n ctx && ctx.beginPath();\n ctx && (this.dpr = ctx.dpr); // Reset\n\n if (this._saveData) {\n this._len = 0;\n }\n\n if (this._lineDash) {\n this._lineDash = null;\n this._dashOffset = 0;\n }\n\n return this;\n },\n\n /**\n * @param {number} x\n * @param {number} y\n * @return {module:zrender/core/PathProxy}\n */\n moveTo: function (x, y) {\n this.addData(CMD.M, x, y);\n this._ctx && this._ctx.moveTo(x, y); // x0, y0, xi, yi 是记录在 _dashedXXXXTo 方法中使用\n // xi, yi 记录当前点, x0, y0 在 closePath 的时候回到起始点。\n // 有可能在 beginPath 之后直接调用 lineTo,这时候 x0, y0 需要\n // 在 lineTo 方法中记录,这里先不考虑这种情况,dashed line 也只在 IE10- 中不支持\n\n this._x0 = x;\n this._y0 = y;\n this._xi = x;\n this._yi = y;\n return this;\n },\n\n /**\n * @param {number} x\n * @param {number} y\n * @return {module:zrender/core/PathProxy}\n */\n lineTo: function (x, y) {\n var exceedUnit = mathAbs(x - this._xi) > this._ux || mathAbs(y - this._yi) > this._uy // Force draw the first segment\n || this._len < 5;\n this.addData(CMD.L, x, y);\n\n if (this._ctx && exceedUnit) {\n this._needsDash() ? this._dashedLineTo(x, y) : this._ctx.lineTo(x, y);\n }\n\n if (exceedUnit) {\n this._xi = x;\n this._yi = y;\n }\n\n return this;\n },\n\n /**\n * @param {number} x1\n * @param {number} y1\n * @param {number} x2\n * @param {number} y2\n * @param {number} x3\n * @param {number} y3\n * @return {module:zrender/core/PathProxy}\n */\n bezierCurveTo: function (x1, y1, x2, y2, x3, y3) {\n this.addData(CMD.C, x1, y1, x2, y2, x3, y3);\n\n if (this._ctx) {\n this._needsDash() ? this._dashedBezierTo(x1, y1, x2, y2, x3, y3) : this._ctx.bezierCurveTo(x1, y1, x2, y2, x3, y3);\n }\n\n this._xi = x3;\n this._yi = y3;\n return this;\n },\n\n /**\n * @param {number} x1\n * @param {number} y1\n * @param {number} x2\n * @param {number} y2\n * @return {module:zrender/core/PathProxy}\n */\n quadraticCurveTo: function (x1, y1, x2, y2) {\n this.addData(CMD.Q, x1, y1, x2, y2);\n\n if (this._ctx) {\n this._needsDash() ? this._dashedQuadraticTo(x1, y1, x2, y2) : this._ctx.quadraticCurveTo(x1, y1, x2, y2);\n }\n\n this._xi = x2;\n this._yi = y2;\n return this;\n },\n\n /**\n * @param {number} cx\n * @param {number} cy\n * @param {number} r\n * @param {number} startAngle\n * @param {number} endAngle\n * @param {boolean} anticlockwise\n * @return {module:zrender/core/PathProxy}\n */\n arc: function (cx, cy, r, startAngle, endAngle, anticlockwise) {\n this.addData(CMD.A, cx, cy, r, r, startAngle, endAngle - startAngle, 0, anticlockwise ? 0 : 1);\n this._ctx && this._ctx.arc(cx, cy, r, startAngle, endAngle, anticlockwise);\n this._xi = mathCos(endAngle) * r + cx;\n this._yi = mathSin(endAngle) * r + cy;\n return this;\n },\n // TODO\n arcTo: function (x1, y1, x2, y2, radius) {\n if (this._ctx) {\n this._ctx.arcTo(x1, y1, x2, y2, radius);\n }\n\n return this;\n },\n // TODO\n rect: function (x, y, w, h) {\n this._ctx && this._ctx.rect(x, y, w, h);\n this.addData(CMD.R, x, y, w, h);\n return this;\n },\n\n /**\n * @return {module:zrender/core/PathProxy}\n */\n closePath: function () {\n this.addData(CMD.Z);\n var ctx = this._ctx;\n var x0 = this._x0;\n var y0 = this._y0;\n\n if (ctx) {\n this._needsDash() && this._dashedLineTo(x0, y0);\n ctx.closePath();\n }\n\n this._xi = x0;\n this._yi = y0;\n return this;\n },\n\n /**\n * Context 从外部传入,因为有可能是 rebuildPath 完之后再 fill。\n * stroke 同样\n * @param {CanvasRenderingContext2D} ctx\n * @return {module:zrender/core/PathProxy}\n */\n fill: function (ctx) {\n ctx && ctx.fill();\n this.toStatic();\n },\n\n /**\n * @param {CanvasRenderingContext2D} ctx\n * @return {module:zrender/core/PathProxy}\n */\n stroke: function (ctx) {\n ctx && ctx.stroke();\n this.toStatic();\n },\n\n /**\n * 必须在其它绘制命令前调用\n * Must be invoked before all other path drawing methods\n * @return {module:zrender/core/PathProxy}\n */\n setLineDash: function (lineDash) {\n if (lineDash instanceof Array) {\n this._lineDash = lineDash;\n this._dashIdx = 0;\n var lineDashSum = 0;\n\n for (var i = 0; i < lineDash.length; i++) {\n lineDashSum += lineDash[i];\n }\n\n this._dashSum = lineDashSum;\n }\n\n return this;\n },\n\n /**\n * 必须在其它绘制命令前调用\n * Must be invoked before all other path drawing methods\n * @return {module:zrender/core/PathProxy}\n */\n setLineDashOffset: function (offset) {\n this._dashOffset = offset;\n return this;\n },\n\n /**\n *\n * @return {boolean}\n */\n len: function () {\n return this._len;\n },\n\n /**\n * 直接设置 Path 数据\n */\n setData: function (data) {\n var len = data.length;\n\n if (!(this.data && this.data.length === len) && hasTypedArray) {\n this.data = new Float32Array(len);\n }\n\n for (var i = 0; i < len; i++) {\n this.data[i] = data[i];\n }\n\n this._len = len;\n },\n\n /**\n * 添加子路径\n * @param {module:zrender/core/PathProxy|Array.<module:zrender/core/PathProxy>} path\n */\n appendPath: function (path) {\n if (!(path instanceof Array)) {\n path = [path];\n }\n\n var len = path.length;\n var appendSize = 0;\n var offset = this._len;\n\n for (var i = 0; i < len; i++) {\n appendSize += path[i].len();\n }\n\n if (hasTypedArray && this.data instanceof Float32Array) {\n this.data = new Float32Array(offset + appendSize);\n }\n\n for (var i = 0; i < len; i++) {\n var appendPathData = path[i].data;\n\n for (var k = 0; k < appendPathData.length; k++) {\n this.data[offset++] = appendPathData[k];\n }\n }\n\n this._len = offset;\n },\n\n /**\n * 填充 Path 数据。\n * 尽量复用而不申明新的数组。大部分图形重绘的指令数据长度都是不变的。\n */\n addData: function (cmd) {\n if (!this._saveData) {\n return;\n }\n\n var data = this.data;\n\n if (this._len + arguments.length > data.length) {\n // 因为之前的数组已经转换成静态的 Float32Array\n // 所以不够用时需要扩展一个新的动态数组\n this._expandData();\n\n data = this.data;\n }\n\n for (var i = 0; i < arguments.length; i++) {\n data[this._len++] = arguments[i];\n }\n\n this._prevCmd = cmd;\n },\n _expandData: function () {\n // Only if data is Float32Array\n if (!(this.data instanceof Array)) {\n var newData = [];\n\n for (var i = 0; i < this._len; i++) {\n newData[i] = this.data[i];\n }\n\n this.data = newData;\n }\n },\n\n /**\n * If needs js implemented dashed line\n * @return {boolean}\n * @private\n */\n _needsDash: function () {\n return this._lineDash;\n },\n _dashedLineTo: function (x1, y1) {\n var dashSum = this._dashSum;\n var offset = this._dashOffset;\n var lineDash = this._lineDash;\n var ctx = this._ctx;\n var x0 = this._xi;\n var y0 = this._yi;\n var dx = x1 - x0;\n var dy = y1 - y0;\n var dist = mathSqrt(dx * dx + dy * dy);\n var x = x0;\n var y = y0;\n var dash;\n var nDash = lineDash.length;\n var idx;\n dx /= dist;\n dy /= dist;\n\n if (offset < 0) {\n // Convert to positive offset\n offset = dashSum + offset;\n }\n\n offset %= dashSum;\n x -= offset * dx;\n y -= offset * dy;\n\n while (dx > 0 && x <= x1 || dx < 0 && x >= x1 || dx === 0 && (dy > 0 && y <= y1 || dy < 0 && y >= y1)) {\n idx = this._dashIdx;\n dash = lineDash[idx];\n x += dx * dash;\n y += dy * dash;\n this._dashIdx = (idx + 1) % nDash; // Skip positive offset\n\n if (dx > 0 && x < x0 || dx < 0 && x > x0 || dy > 0 && y < y0 || dy < 0 && y > y0) {\n continue;\n }\n\n ctx[idx % 2 ? 'moveTo' : 'lineTo'](dx >= 0 ? mathMin(x, x1) : mathMax(x, x1), dy >= 0 ? mathMin(y, y1) : mathMax(y, y1));\n } // Offset for next lineTo\n\n\n dx = x - x1;\n dy = y - y1;\n this._dashOffset = -mathSqrt(dx * dx + dy * dy);\n },\n // Not accurate dashed line to\n _dashedBezierTo: function (x1, y1, x2, y2, x3, y3) {\n var dashSum = this._dashSum;\n var offset = this._dashOffset;\n var lineDash = this._lineDash;\n var ctx = this._ctx;\n var x0 = this._xi;\n var y0 = this._yi;\n var t;\n var dx;\n var dy;\n var cubicAt = curve.cubicAt;\n var bezierLen = 0;\n var idx = this._dashIdx;\n var nDash = lineDash.length;\n var x;\n var y;\n var tmpLen = 0;\n\n if (offset < 0) {\n // Convert to positive offset\n offset = dashSum + offset;\n }\n\n offset %= dashSum; // Bezier approx length\n\n for (t = 0; t < 1; t += 0.1) {\n dx = cubicAt(x0, x1, x2, x3, t + 0.1) - cubicAt(x0, x1, x2, x3, t);\n dy = cubicAt(y0, y1, y2, y3, t + 0.1) - cubicAt(y0, y1, y2, y3, t);\n bezierLen += mathSqrt(dx * dx + dy * dy);\n } // Find idx after add offset\n\n\n for (; idx < nDash; idx++) {\n tmpLen += lineDash[idx];\n\n if (tmpLen > offset) {\n break;\n }\n }\n\n t = (tmpLen - offset) / bezierLen;\n\n while (t <= 1) {\n x = cubicAt(x0, x1, x2, x3, t);\n y = cubicAt(y0, y1, y2, y3, t); // Use line to approximate dashed bezier\n // Bad result if dash is long\n\n idx % 2 ? ctx.moveTo(x, y) : ctx.lineTo(x, y);\n t += lineDash[idx] / bezierLen;\n idx = (idx + 1) % nDash;\n } // Finish the last segment and calculate the new offset\n\n\n idx % 2 !== 0 && ctx.lineTo(x3, y3);\n dx = x3 - x;\n dy = y3 - y;\n this._dashOffset = -mathSqrt(dx * dx + dy * dy);\n },\n _dashedQuadraticTo: function (x1, y1, x2, y2) {\n // Convert quadratic to cubic using degree elevation\n var x3 = x2;\n var y3 = y2;\n x2 = (x2 + 2 * x1) / 3;\n y2 = (y2 + 2 * y1) / 3;\n x1 = (this._xi + 2 * x1) / 3;\n y1 = (this._yi + 2 * y1) / 3;\n\n this._dashedBezierTo(x1, y1, x2, y2, x3, y3);\n },\n\n /**\n * 转成静态的 Float32Array 减少堆内存占用\n * Convert dynamic array to static Float32Array\n */\n toStatic: function () {\n var data = this.data;\n\n if (data instanceof Array) {\n data.length = this._len;\n\n if (hasTypedArray) {\n this.data = new Float32Array(data);\n }\n }\n },\n\n /**\n * @return {module:zrender/core/BoundingRect}\n */\n getBoundingRect: function () {\n min[0] = min[1] = min2[0] = min2[1] = Number.MAX_VALUE;\n max[0] = max[1] = max2[0] = max2[1] = -Number.MAX_VALUE;\n var data = this.data;\n var xi = 0;\n var yi = 0;\n var x0 = 0;\n var y0 = 0;\n\n for (var i = 0; i < data.length;) {\n var cmd = data[i++];\n\n if (i === 1) {\n // 如果第一个命令是 L, C, Q\n // 则 previous point 同绘制命令的第一个 point\n //\n // 第一个命令为 Arc 的情况下会在后面特殊处理\n xi = data[i];\n yi = data[i + 1];\n x0 = xi;\n y0 = yi;\n }\n\n switch (cmd) {\n case CMD.M:\n // moveTo 命令重新创建一个新的 subpath, 并且更新新的起点\n // 在 closePath 的时候使用\n x0 = data[i++];\n y0 = data[i++];\n xi = x0;\n yi = y0;\n min2[0] = x0;\n min2[1] = y0;\n max2[0] = x0;\n max2[1] = y0;\n break;\n\n case CMD.L:\n bbox.fromLine(xi, yi, data[i], data[i + 1], min2, max2);\n xi = data[i++];\n yi = data[i++];\n break;\n\n case CMD.C:\n bbox.fromCubic(xi, yi, data[i++], data[i++], data[i++], data[i++], data[i], data[i + 1], min2, max2);\n xi = data[i++];\n yi = data[i++];\n break;\n\n case CMD.Q:\n bbox.fromQuadratic(xi, yi, data[i++], data[i++], data[i], data[i + 1], min2, max2);\n xi = data[i++];\n yi = data[i++];\n break;\n\n case CMD.A:\n // TODO Arc 判断的开销比较大\n var cx = data[i++];\n var cy = data[i++];\n var rx = data[i++];\n var ry = data[i++];\n var startAngle = data[i++];\n var endAngle = data[i++] + startAngle; // TODO Arc 旋转\n\n i += 1;\n var anticlockwise = 1 - data[i++];\n\n if (i === 1) {\n // 直接使用 arc 命令\n // 第一个命令起点还未定义\n x0 = mathCos(startAngle) * rx + cx;\n y0 = mathSin(startAngle) * ry + cy;\n }\n\n bbox.fromArc(cx, cy, rx, ry, startAngle, endAngle, anticlockwise, min2, max2);\n xi = mathCos(endAngle) * rx + cx;\n yi = mathSin(endAngle) * ry + cy;\n break;\n\n case CMD.R:\n x0 = xi = data[i++];\n y0 = yi = data[i++];\n var width = data[i++];\n var height = data[i++]; // Use fromLine\n\n bbox.fromLine(x0, y0, x0 + width, y0 + height, min2, max2);\n break;\n\n case CMD.Z:\n xi = x0;\n yi = y0;\n break;\n } // Union\n\n\n vec2.min(min, min, min2);\n vec2.max(max, max, max2);\n } // No data\n\n\n if (i === 0) {\n min[0] = min[1] = max[0] = max[1] = 0;\n }\n\n return new BoundingRect(min[0], min[1], max[0] - min[0], max[1] - min[1]);\n },\n\n /**\n * Rebuild path from current data\n * Rebuild path will not consider javascript implemented line dash.\n * @param {CanvasRenderingContext2D} ctx\n */\n rebuildPath: function (ctx) {\n var d = this.data;\n var x0, y0;\n var xi, yi;\n var x, y;\n var ux = this._ux;\n var uy = this._uy;\n var len = this._len;\n\n for (var i = 0; i < len;) {\n var cmd = d[i++];\n\n if (i === 1) {\n // 如果第一个命令是 L, C, Q\n // 则 previous point 同绘制命令的第一个 point\n //\n // 第一个命令为 Arc 的情况下会在后面特殊处理\n xi = d[i];\n yi = d[i + 1];\n x0 = xi;\n y0 = yi;\n }\n\n switch (cmd) {\n case CMD.M:\n x0 = xi = d[i++];\n y0 = yi = d[i++];\n ctx.moveTo(xi, yi);\n break;\n\n case CMD.L:\n x = d[i++];\n y = d[i++]; // Not draw too small seg between\n\n if (mathAbs(x - xi) > ux || mathAbs(y - yi) > uy || i === len - 1) {\n ctx.lineTo(x, y);\n xi = x;\n yi = y;\n }\n\n break;\n\n case CMD.C:\n ctx.bezierCurveTo(d[i++], d[i++], d[i++], d[i++], d[i++], d[i++]);\n xi = d[i - 2];\n yi = d[i - 1];\n break;\n\n case CMD.Q:\n ctx.quadraticCurveTo(d[i++], d[i++], d[i++], d[i++]);\n xi = d[i - 2];\n yi = d[i - 1];\n break;\n\n case CMD.A:\n var cx = d[i++];\n var cy = d[i++];\n var rx = d[i++];\n var ry = d[i++];\n var theta = d[i++];\n var dTheta = d[i++];\n var psi = d[i++];\n var fs = d[i++];\n var r = rx > ry ? rx : ry;\n var scaleX = rx > ry ? 1 : rx / ry;\n var scaleY = rx > ry ? ry / rx : 1;\n var isEllipse = Math.abs(rx - ry) > 1e-3;\n var endAngle = theta + dTheta;\n\n if (isEllipse) {\n ctx.translate(cx, cy);\n ctx.rotate(psi);\n ctx.scale(scaleX, scaleY);\n ctx.arc(0, 0, r, theta, endAngle, 1 - fs);\n ctx.scale(1 / scaleX, 1 / scaleY);\n ctx.rotate(-psi);\n ctx.translate(-cx, -cy);\n } else {\n ctx.arc(cx, cy, r, theta, endAngle, 1 - fs);\n }\n\n if (i === 1) {\n // 直接使用 arc 命令\n // 第一个命令起点还未定义\n x0 = mathCos(theta) * rx + cx;\n y0 = mathSin(theta) * ry + cy;\n }\n\n xi = mathCos(endAngle) * rx + cx;\n yi = mathSin(endAngle) * ry + cy;\n break;\n\n case CMD.R:\n x0 = xi = d[i];\n y0 = yi = d[i + 1];\n ctx.rect(d[i++], d[i++], d[i++], d[i++]);\n break;\n\n case CMD.Z:\n ctx.closePath();\n xi = x0;\n yi = y0;\n }\n }\n }\n};\nPathProxy.CMD = CMD;\nvar _default = PathProxy;\nmodule.exports = _default;","'use strict';\n// 22.1.3.9 Array.prototype.findIndex(predicate, thisArg = undefined)\nvar $export = require('./_export');\nvar $find = require('./_array-methods')(6);\nvar KEY = 'findIndex';\nvar forced = true;\n// Shouldn't skip holes\nif (KEY in []) Array(1)[KEY](function () { forced = false; });\n$export($export.P + $export.F * forced, 'Array', {\n findIndex: function findIndex(callbackfn /* , that = undefined */) {\n return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\nrequire('./_add-to-unscopables')(KEY);\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar numberUtil = require(\"../util/number\");\n\nvar formatUtil = require(\"../util/format\");\n\nvar scaleHelper = require(\"./helper\");\n\nvar IntervalScale = require(\"./Interval\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* A third-party license is embeded for some of the code in this file:\n* The \"scaleLevels\" was originally copied from \"d3.js\" with some\n* modifications made for this project.\n* (See more details in the comment on the definition of \"scaleLevels\" below.)\n* The use of the source code of this file is also subject to the terms\n* and consitions of the license of \"d3.js\" (BSD-3Clause, see\n* </licenses/LICENSE-d3>).\n*/\n// [About UTC and local time zone]:\n// In most cases, `number.parseDate` will treat input data string as local time\n// (except time zone is specified in time string). And `format.formateTime` returns\n// local time by default. option.useUTC is false by default. This design have\n// concidered these common case:\n// (1) Time that is persistent in server is in UTC, but it is needed to be diplayed\n// in local time by default.\n// (2) By default, the input data string (e.g., '2011-01-02') should be displayed\n// as its original time, without any time difference.\nvar intervalScaleProto = IntervalScale.prototype;\nvar mathCeil = Math.ceil;\nvar mathFloor = Math.floor;\nvar ONE_SECOND = 1000;\nvar ONE_MINUTE = ONE_SECOND * 60;\nvar ONE_HOUR = ONE_MINUTE * 60;\nvar ONE_DAY = ONE_HOUR * 24; // FIXME 公用?\n\nvar bisect = function (a, x, lo, hi) {\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n\n if (a[mid][1] < x) {\n lo = mid + 1;\n } else {\n hi = mid;\n }\n }\n\n return lo;\n};\n/**\n * @alias module:echarts/coord/scale/Time\n * @constructor\n */\n\n\nvar TimeScale = IntervalScale.extend({\n type: 'time',\n\n /**\n * @override\n */\n getLabel: function (val) {\n var stepLvl = this._stepLvl;\n var date = new Date(val);\n return formatUtil.formatTime(stepLvl[0], date, this.getSetting('useUTC'));\n },\n\n /**\n * @override\n */\n niceExtent: function (opt) {\n var extent = this._extent; // If extent start and end are same, expand them\n\n if (extent[0] === extent[1]) {\n // Expand extent\n extent[0] -= ONE_DAY;\n extent[1] += ONE_DAY;\n } // If there are no data and extent are [Infinity, -Infinity]\n\n\n if (extent[1] === -Infinity && extent[0] === Infinity) {\n var d = new Date();\n extent[1] = +new Date(d.getFullYear(), d.getMonth(), d.getDate());\n extent[0] = extent[1] - ONE_DAY;\n }\n\n this.niceTicks(opt.splitNumber, opt.minInterval, opt.maxInterval); // var extent = this._extent;\n\n var interval = this._interval;\n\n if (!opt.fixMin) {\n extent[0] = numberUtil.round(mathFloor(extent[0] / interval) * interval);\n }\n\n if (!opt.fixMax) {\n extent[1] = numberUtil.round(mathCeil(extent[1] / interval) * interval);\n }\n },\n\n /**\n * @override\n */\n niceTicks: function (approxTickNum, minInterval, maxInterval) {\n approxTickNum = approxTickNum || 10;\n var extent = this._extent;\n var span = extent[1] - extent[0];\n var approxInterval = span / approxTickNum;\n\n if (minInterval != null && approxInterval < minInterval) {\n approxInterval = minInterval;\n }\n\n if (maxInterval != null && approxInterval > maxInterval) {\n approxInterval = maxInterval;\n }\n\n var scaleLevelsLen = scaleLevels.length;\n var idx = bisect(scaleLevels, approxInterval, 0, scaleLevelsLen);\n var level = scaleLevels[Math.min(idx, scaleLevelsLen - 1)];\n var interval = level[1]; // Same with interval scale if span is much larger than 1 year\n\n if (level[0] === 'year') {\n var yearSpan = span / interval; // From \"Nice Numbers for Graph Labels\" of Graphic Gems\n // var niceYearSpan = numberUtil.nice(yearSpan, false);\n\n var yearStep = numberUtil.nice(yearSpan / approxTickNum, true);\n interval *= yearStep;\n }\n\n var timezoneOffset = this.getSetting('useUTC') ? 0 : new Date(+extent[0] || +extent[1]).getTimezoneOffset() * 60 * 1000;\n var niceExtent = [Math.round(mathCeil((extent[0] - timezoneOffset) / interval) * interval + timezoneOffset), Math.round(mathFloor((extent[1] - timezoneOffset) / interval) * interval + timezoneOffset)];\n scaleHelper.fixExtent(niceExtent, extent);\n this._stepLvl = level; // Interval will be used in getTicks\n\n this._interval = interval;\n this._niceExtent = niceExtent;\n },\n parse: function (val) {\n // val might be float.\n return +numberUtil.parseDate(val);\n }\n});\nzrUtil.each(['contain', 'normalize'], function (methodName) {\n TimeScale.prototype[methodName] = function (val) {\n return intervalScaleProto[methodName].call(this, this.parse(val));\n };\n});\n/**\n * This implementation was originally copied from \"d3.js\"\n * <https://github.com/d3/d3/blob/b516d77fb8566b576088e73410437494717ada26/src/time/scale.js>\n * with some modifications made for this program.\n * See the license statement at the head of this file.\n */\n\nvar scaleLevels = [// Format interval\n['hh:mm:ss', ONE_SECOND], // 1s\n['hh:mm:ss', ONE_SECOND * 5], // 5s\n['hh:mm:ss', ONE_SECOND * 10], // 10s\n['hh:mm:ss', ONE_SECOND * 15], // 15s\n['hh:mm:ss', ONE_SECOND * 30], // 30s\n['hh:mm\\nMM-dd', ONE_MINUTE], // 1m\n['hh:mm\\nMM-dd', ONE_MINUTE * 5], // 5m\n['hh:mm\\nMM-dd', ONE_MINUTE * 10], // 10m\n['hh:mm\\nMM-dd', ONE_MINUTE * 15], // 15m\n['hh:mm\\nMM-dd', ONE_MINUTE * 30], // 30m\n['hh:mm\\nMM-dd', ONE_HOUR], // 1h\n['hh:mm\\nMM-dd', ONE_HOUR * 2], // 2h\n['hh:mm\\nMM-dd', ONE_HOUR * 6], // 6h\n['hh:mm\\nMM-dd', ONE_HOUR * 12], // 12h\n['MM-dd\\nyyyy', ONE_DAY], // 1d\n['MM-dd\\nyyyy', ONE_DAY * 2], // 2d\n['MM-dd\\nyyyy', ONE_DAY * 3], // 3d\n['MM-dd\\nyyyy', ONE_DAY * 4], // 4d\n['MM-dd\\nyyyy', ONE_DAY * 5], // 5d\n['MM-dd\\nyyyy', ONE_DAY * 6], // 6d\n['week', ONE_DAY * 7], // 7d\n['MM-dd\\nyyyy', ONE_DAY * 10], // 10d\n['week', ONE_DAY * 14], // 2w\n['week', ONE_DAY * 21], // 3w\n['month', ONE_DAY * 31], // 1M\n['week', ONE_DAY * 42], // 6w\n['month', ONE_DAY * 62], // 2M\n['week', ONE_DAY * 70], // 10w\n['quarter', ONE_DAY * 95], // 3M\n['month', ONE_DAY * 31 * 4], // 4M\n['month', ONE_DAY * 31 * 5], // 5M\n['half-year', ONE_DAY * 380 / 2], // 6M\n['month', ONE_DAY * 31 * 8], // 8M\n['month', ONE_DAY * 31 * 10], // 10M\n['year', ONE_DAY * 380] // 1Y\n];\n/**\n * @param {module:echarts/model/Model}\n * @return {module:echarts/scale/Time}\n */\n\nTimeScale.create = function (model) {\n return new TimeScale({\n useUTC: model.ecModel.get('useUTC')\n });\n};\n\nvar _default = TimeScale;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar createListFromArray = require(\"../helper/createListFromArray\");\n\nvar SeriesModel = require(\"../../model/Series\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar _default = SeriesModel.extend({\n type: 'series.line',\n dependencies: ['grid', 'polar'],\n getInitialData: function (option, ecModel) {\n return createListFromArray(this.getSource(), this);\n },\n defaultOption: {\n zlevel: 0,\n z: 2,\n coordinateSystem: 'cartesian2d',\n legendHoverLink: true,\n hoverAnimation: true,\n // stack: null\n // xAxisIndex: 0,\n // yAxisIndex: 0,\n // polarIndex: 0,\n // If clip the overflow value\n clipOverflow: true,\n // cursor: null,\n label: {\n position: 'top'\n },\n // itemStyle: {\n // },\n lineStyle: {\n width: 2,\n type: 'solid'\n },\n // areaStyle: {\n // origin of areaStyle. Valid values:\n // `'auto'/null/undefined`: from axisLine to data\n // `'start'`: from min to data\n // `'end'`: from data to max\n // origin: 'auto'\n // },\n // false, 'start', 'end', 'middle'\n step: false,\n // Disabled if step is true\n smooth: false,\n smoothMonotone: null,\n symbol: 'emptyCircle',\n symbolSize: 4,\n symbolRotate: null,\n showSymbol: true,\n // `false`: follow the label interval strategy.\n // `true`: show all symbols.\n // `'auto'`: If possible, show all symbols, otherwise\n // follow the label interval strategy.\n showAllSymbol: 'auto',\n // Whether to connect break point.\n connectNulls: false,\n // Sampling for large data. Can be: 'average', 'max', 'min', 'sum'.\n sampling: 'none',\n animationEasing: 'linear',\n // Disable progressive\n progressive: 0,\n hoverLayerThreshold: Infinity\n }\n});\n\nmodule.exports = _default;","/**\n * echarts设备环境识别\n *\n * @desc echarts基于Canvas,纯Javascript图表库,提供直观,生动,可交互,可个性化定制的数据统计图表。\n * @author firede[firede@firede.us]\n * @desc thanks zepto.\n */\nvar env = {};\n\nif (typeof wx === 'object' && typeof wx.getSystemInfoSync === 'function') {\n // In Weixin Application\n env = {\n browser: {},\n os: {},\n node: false,\n wxa: true,\n // Weixin Application\n canvasSupported: true,\n svgSupported: false,\n touchEventsSupported: true,\n domSupported: false\n };\n} else if (typeof document === 'undefined' && typeof self !== 'undefined') {\n // In worker\n env = {\n browser: {},\n os: {},\n node: false,\n worker: true,\n canvasSupported: true,\n domSupported: false\n };\n} else if (typeof navigator === 'undefined') {\n // In node\n env = {\n browser: {},\n os: {},\n node: true,\n worker: false,\n // Assume canvas is supported\n canvasSupported: true,\n svgSupported: true,\n domSupported: false\n };\n} else {\n env = detect(navigator.userAgent);\n}\n\nvar _default = env; // Zepto.js\n// (c) 2010-2013 Thomas Fuchs\n// Zepto.js may be freely distributed under the MIT license.\n\nfunction detect(ua) {\n var os = {};\n var browser = {}; // var webkit = ua.match(/Web[kK]it[\\/]{0,1}([\\d.]+)/);\n // var android = ua.match(/(Android);?[\\s\\/]+([\\d.]+)?/);\n // var ipad = ua.match(/(iPad).*OS\\s([\\d_]+)/);\n // var ipod = ua.match(/(iPod)(.*OS\\s([\\d_]+))?/);\n // var iphone = !ipad && ua.match(/(iPhone\\sOS)\\s([\\d_]+)/);\n // var webos = ua.match(/(webOS|hpwOS)[\\s\\/]([\\d.]+)/);\n // var touchpad = webos && ua.match(/TouchPad/);\n // var kindle = ua.match(/Kindle\\/([\\d.]+)/);\n // var silk = ua.match(/Silk\\/([\\d._]+)/);\n // var blackberry = ua.match(/(BlackBerry).*Version\\/([\\d.]+)/);\n // var bb10 = ua.match(/(BB10).*Version\\/([\\d.]+)/);\n // var rimtabletos = ua.match(/(RIM\\sTablet\\sOS)\\s([\\d.]+)/);\n // var playbook = ua.match(/PlayBook/);\n // var chrome = ua.match(/Chrome\\/([\\d.]+)/) || ua.match(/CriOS\\/([\\d.]+)/);\n\n var firefox = ua.match(/Firefox\\/([\\d.]+)/); // var safari = webkit && ua.match(/Mobile\\//) && !chrome;\n // var webview = ua.match(/(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/) && !chrome;\n\n var ie = ua.match(/MSIE\\s([\\d.]+)/) // IE 11 Trident/7.0; rv:11.0\n || ua.match(/Trident\\/.+?rv:(([\\d.]+))/);\n var edge = ua.match(/Edge\\/([\\d.]+)/); // IE 12 and 12+\n\n var weChat = /micromessenger/i.test(ua); // Todo: clean this up with a better OS/browser seperation:\n // - discern (more) between multiple browsers on android\n // - decide if kindle fire in silk mode is android or not\n // - Firefox on Android doesn't specify the Android version\n // - possibly devide in os, device and browser hashes\n // if (browser.webkit = !!webkit) browser.version = webkit[1];\n // if (android) os.android = true, os.version = android[2];\n // if (iphone && !ipod) os.ios = os.iphone = true, os.version = iphone[2].replace(/_/g, '.');\n // if (ipad) os.ios = os.ipad = true, os.version = ipad[2].replace(/_/g, '.');\n // if (ipod) os.ios = os.ipod = true, os.version = ipod[3] ? ipod[3].replace(/_/g, '.') : null;\n // if (webos) os.webos = true, os.version = webos[2];\n // if (touchpad) os.touchpad = true;\n // if (blackberry) os.blackberry = true, os.version = blackberry[2];\n // if (bb10) os.bb10 = true, os.version = bb10[2];\n // if (rimtabletos) os.rimtabletos = true, os.version = rimtabletos[2];\n // if (playbook) browser.playbook = true;\n // if (kindle) os.kindle = true, os.version = kindle[1];\n // if (silk) browser.silk = true, browser.version = silk[1];\n // if (!silk && os.android && ua.match(/Kindle Fire/)) browser.silk = true;\n // if (chrome) browser.chrome = true, browser.version = chrome[1];\n\n if (firefox) {\n browser.firefox = true;\n browser.version = firefox[1];\n } // if (safari && (ua.match(/Safari/) || !!os.ios)) browser.safari = true;\n // if (webview) browser.webview = true;\n\n\n if (ie) {\n browser.ie = true;\n browser.version = ie[1];\n }\n\n if (edge) {\n browser.edge = true;\n browser.version = edge[1];\n } // It is difficult to detect WeChat in Win Phone precisely, because ua can\n // not be set on win phone. So we do not consider Win Phone.\n\n\n if (weChat) {\n browser.weChat = true;\n } // os.tablet = !!(ipad || playbook || (android && !ua.match(/Mobile/)) ||\n // (firefox && ua.match(/Tablet/)) || (ie && !ua.match(/Phone/) && ua.match(/Touch/)));\n // os.phone = !!(!os.tablet && !os.ipod && (android || iphone || webos ||\n // (chrome && ua.match(/Android/)) || (chrome && ua.match(/CriOS\\/([\\d.]+)/)) ||\n // (firefox && ua.match(/Mobile/)) || (ie && ua.match(/Touch/))));\n\n\n return {\n browser: browser,\n os: os,\n node: false,\n // 原生canvas支持,改极端点了\n // canvasSupported : !(browser.ie && parseFloat(browser.version) < 9)\n canvasSupported: !!document.createElement('canvas').getContext,\n svgSupported: typeof SVGRect !== 'undefined',\n // works on most browsers\n // IE10/11 does not support touch event, and MS Edge supports them but not by\n // default, so we dont check navigator.maxTouchPoints for them here.\n touchEventsSupported: 'ontouchstart' in window && !browser.ie && !browser.edge,\n // <http://caniuse.com/#search=pointer%20event>.\n pointerEventsSupported: 'onpointerdown' in window // Firefox supports pointer but not by default, only MS browsers are reliable on pointer\n // events currently. So we dont use that on other browsers unless tested sufficiently.\n // Although IE 10 supports pointer event, it use old style and is different from the\n // standard. So we exclude that. (IE 10 is hardly used on touch device)\n && (browser.edge || browser.ie && browser.version >= 11),\n // passiveSupported: detectPassiveSupport()\n domSupported: typeof document !== 'undefined'\n };\n} // See https://github.com/WICG/EventListenerOptions/blob/gh-pages/explainer.md#feature-detection\n// function detectPassiveSupport() {\n// // Test via a getter in the options object to see if the passive property is accessed\n// var supportsPassive = false;\n// try {\n// var opts = Object.defineProperty({}, 'passive', {\n// get: function() {\n// supportsPassive = true;\n// }\n// });\n// window.addEventListener('testPassive', function() {}, opts);\n// } catch (e) {\n// }\n// return supportsPassive;\n// }\n\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar pathTool = require(\"zrender/lib/tool/path\");\n\nvar colorTool = require(\"zrender/lib/tool/color\");\n\nvar matrix = require(\"zrender/lib/core/matrix\");\n\nvar vector = require(\"zrender/lib/core/vector\");\n\nvar Path = require(\"zrender/lib/graphic/Path\");\n\nvar Transformable = require(\"zrender/lib/mixin/Transformable\");\n\nvar ZImage = require(\"zrender/lib/graphic/Image\");\n\nexports.Image = ZImage;\n\nvar Group = require(\"zrender/lib/container/Group\");\n\nexports.Group = Group;\n\nvar Text = require(\"zrender/lib/graphic/Text\");\n\nexports.Text = Text;\n\nvar Circle = require(\"zrender/lib/graphic/shape/Circle\");\n\nexports.Circle = Circle;\n\nvar Sector = require(\"zrender/lib/graphic/shape/Sector\");\n\nexports.Sector = Sector;\n\nvar Ring = require(\"zrender/lib/graphic/shape/Ring\");\n\nexports.Ring = Ring;\n\nvar Polygon = require(\"zrender/lib/graphic/shape/Polygon\");\n\nexports.Polygon = Polygon;\n\nvar Polyline = require(\"zrender/lib/graphic/shape/Polyline\");\n\nexports.Polyline = Polyline;\n\nvar Rect = require(\"zrender/lib/graphic/shape/Rect\");\n\nexports.Rect = Rect;\n\nvar Line = require(\"zrender/lib/graphic/shape/Line\");\n\nexports.Line = Line;\n\nvar BezierCurve = require(\"zrender/lib/graphic/shape/BezierCurve\");\n\nexports.BezierCurve = BezierCurve;\n\nvar Arc = require(\"zrender/lib/graphic/shape/Arc\");\n\nexports.Arc = Arc;\n\nvar CompoundPath = require(\"zrender/lib/graphic/CompoundPath\");\n\nexports.CompoundPath = CompoundPath;\n\nvar LinearGradient = require(\"zrender/lib/graphic/LinearGradient\");\n\nexports.LinearGradient = LinearGradient;\n\nvar RadialGradient = require(\"zrender/lib/graphic/RadialGradient\");\n\nexports.RadialGradient = RadialGradient;\n\nvar BoundingRect = require(\"zrender/lib/core/BoundingRect\");\n\nexports.BoundingRect = BoundingRect;\n\nvar IncrementalDisplayable = require(\"zrender/lib/graphic/IncrementalDisplayable\");\n\nexports.IncrementalDisplayable = IncrementalDisplayable;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar round = Math.round;\nvar mathMax = Math.max;\nvar mathMin = Math.min;\nvar EMPTY_OBJ = {};\nvar Z2_EMPHASIS_LIFT = 1;\n/**\n * Extend shape with parameters\n */\n\nfunction extendShape(opts) {\n return Path.extend(opts);\n}\n/**\n * Extend path\n */\n\n\nfunction extendPath(pathData, opts) {\n return pathTool.extendFromString(pathData, opts);\n}\n/**\n * Create a path element from path data string\n * @param {string} pathData\n * @param {Object} opts\n * @param {module:zrender/core/BoundingRect} rect\n * @param {string} [layout=cover] 'center' or 'cover'\n */\n\n\nfunction makePath(pathData, opts, rect, layout) {\n var path = pathTool.createFromString(pathData, opts);\n\n if (rect) {\n if (layout === 'center') {\n rect = centerGraphic(rect, path.getBoundingRect());\n }\n\n resizePath(path, rect);\n }\n\n return path;\n}\n/**\n * Create a image element from image url\n * @param {string} imageUrl image url\n * @param {Object} opts options\n * @param {module:zrender/core/BoundingRect} rect constrain rect\n * @param {string} [layout=cover] 'center' or 'cover'\n */\n\n\nfunction makeImage(imageUrl, rect, layout) {\n var path = new ZImage({\n style: {\n image: imageUrl,\n x: rect.x,\n y: rect.y,\n width: rect.width,\n height: rect.height\n },\n onload: function (img) {\n if (layout === 'center') {\n var boundingRect = {\n width: img.width,\n height: img.height\n };\n path.setStyle(centerGraphic(rect, boundingRect));\n }\n }\n });\n return path;\n}\n/**\n * Get position of centered element in bounding box.\n *\n * @param {Object} rect element local bounding box\n * @param {Object} boundingRect constraint bounding box\n * @return {Object} element position containing x, y, width, and height\n */\n\n\nfunction centerGraphic(rect, boundingRect) {\n // Set rect to center, keep width / height ratio.\n var aspect = boundingRect.width / boundingRect.height;\n var width = rect.height * aspect;\n var height;\n\n if (width <= rect.width) {\n height = rect.height;\n } else {\n width = rect.width;\n height = width / aspect;\n }\n\n var cx = rect.x + rect.width / 2;\n var cy = rect.y + rect.height / 2;\n return {\n x: cx - width / 2,\n y: cy - height / 2,\n width: width,\n height: height\n };\n}\n\nvar mergePath = pathTool.mergePath;\n/**\n * Resize a path to fit the rect\n * @param {module:zrender/graphic/Path} path\n * @param {Object} rect\n */\n\nfunction resizePath(path, rect) {\n if (!path.applyTransform) {\n return;\n }\n\n var pathRect = path.getBoundingRect();\n var m = pathRect.calculateTransform(rect);\n path.applyTransform(m);\n}\n/**\n * Sub pixel optimize line for canvas\n *\n * @param {Object} param\n * @param {Object} [param.shape]\n * @param {number} [param.shape.x1]\n * @param {number} [param.shape.y1]\n * @param {number} [param.shape.x2]\n * @param {number} [param.shape.y2]\n * @param {Object} [param.style]\n * @param {number} [param.style.lineWidth]\n * @return {Object} Modified param\n */\n\n\nfunction subPixelOptimizeLine(param) {\n var shape = param.shape;\n var lineWidth = param.style.lineWidth;\n\n if (round(shape.x1 * 2) === round(shape.x2 * 2)) {\n shape.x1 = shape.x2 = subPixelOptimize(shape.x1, lineWidth, true);\n }\n\n if (round(shape.y1 * 2) === round(shape.y2 * 2)) {\n shape.y1 = shape.y2 = subPixelOptimize(shape.y1, lineWidth, true);\n }\n\n return param;\n}\n/**\n * Sub pixel optimize rect for canvas\n *\n * @param {Object} param\n * @param {Object} [param.shape]\n * @param {number} [param.shape.x]\n * @param {number} [param.shape.y]\n * @param {number} [param.shape.width]\n * @param {number} [param.shape.height]\n * @param {Object} [param.style]\n * @param {number} [param.style.lineWidth]\n * @return {Object} Modified param\n */\n\n\nfunction subPixelOptimizeRect(param) {\n var shape = param.shape;\n var lineWidth = param.style.lineWidth;\n var originX = shape.x;\n var originY = shape.y;\n var originWidth = shape.width;\n var originHeight = shape.height;\n shape.x = subPixelOptimize(shape.x, lineWidth, true);\n shape.y = subPixelOptimize(shape.y, lineWidth, true);\n shape.width = Math.max(subPixelOptimize(originX + originWidth, lineWidth, false) - shape.x, originWidth === 0 ? 0 : 1);\n shape.height = Math.max(subPixelOptimize(originY + originHeight, lineWidth, false) - shape.y, originHeight === 0 ? 0 : 1);\n return param;\n}\n/**\n * Sub pixel optimize for canvas\n *\n * @param {number} position Coordinate, such as x, y\n * @param {number} lineWidth Should be nonnegative integer.\n * @param {boolean=} positiveOrNegative Default false (negative).\n * @return {number} Optimized position.\n */\n\n\nfunction subPixelOptimize(position, lineWidth, positiveOrNegative) {\n // Assure that (position + lineWidth / 2) is near integer edge,\n // otherwise line will be fuzzy in canvas.\n var doubledPosition = round(position * 2);\n return (doubledPosition + round(lineWidth)) % 2 === 0 ? doubledPosition / 2 : (doubledPosition + (positiveOrNegative ? 1 : -1)) / 2;\n}\n\nfunction hasFillOrStroke(fillOrStroke) {\n return fillOrStroke != null && fillOrStroke !== 'none';\n} // Most lifted color are duplicated.\n\n\nvar liftedColorMap = zrUtil.createHashMap();\nvar liftedColorCount = 0;\n\nfunction liftColor(color) {\n if (typeof color !== 'string') {\n return color;\n }\n\n var liftedColor = liftedColorMap.get(color);\n\n if (!liftedColor) {\n liftedColor = colorTool.lift(color, -0.1);\n\n if (liftedColorCount < 10000) {\n liftedColorMap.set(color, liftedColor);\n liftedColorCount++;\n }\n }\n\n return liftedColor;\n}\n\nfunction cacheElementStl(el) {\n if (!el.__hoverStlDirty) {\n return;\n }\n\n el.__hoverStlDirty = false;\n var hoverStyle = el.__hoverStl;\n\n if (!hoverStyle) {\n el.__cachedNormalStl = el.__cachedNormalZ2 = null;\n return;\n }\n\n var normalStyle = el.__cachedNormalStl = {};\n el.__cachedNormalZ2 = el.z2;\n var elStyle = el.style;\n\n for (var name in hoverStyle) {\n // See comment in `doSingleEnterHover`.\n if (hoverStyle[name] != null) {\n normalStyle[name] = elStyle[name];\n }\n } // Always cache fill and stroke to normalStyle for lifting color.\n\n\n normalStyle.fill = elStyle.fill;\n normalStyle.stroke = elStyle.stroke;\n}\n\nfunction doSingleEnterHover(el) {\n var hoverStl = el.__hoverStl;\n\n if (!hoverStl || el.__highlighted) {\n return;\n }\n\n var useHoverLayer = el.useHoverLayer;\n el.__highlighted = useHoverLayer ? 'layer' : 'plain';\n var zr = el.__zr;\n\n if (!zr && useHoverLayer) {\n return;\n }\n\n var elTarget = el;\n var targetStyle = el.style;\n\n if (useHoverLayer) {\n elTarget = zr.addHover(el);\n targetStyle = elTarget.style;\n }\n\n rollbackDefaultTextStyle(targetStyle);\n\n if (!useHoverLayer) {\n cacheElementStl(elTarget);\n } // styles can be:\n // {\n // label: {\n // show: false,\n // position: 'outside',\n // fontSize: 18\n // },\n // emphasis: {\n // label: {\n // show: true\n // }\n // }\n // },\n // where properties of `emphasis` may not appear in `normal`. We previously use\n // module:echarts/util/model#defaultEmphasis to merge `normal` to `emphasis`.\n // But consider rich text and setOption in merge mode, it is impossible to cover\n // all properties in merge. So we use merge mode when setting style here, where\n // only properties that is not `null/undefined` can be set. The disadventage:\n // null/undefined can not be used to remove style any more in `emphasis`.\n\n\n targetStyle.extendFrom(hoverStl);\n setDefaultHoverFillStroke(targetStyle, hoverStl, 'fill');\n setDefaultHoverFillStroke(targetStyle, hoverStl, 'stroke');\n applyDefaultTextStyle(targetStyle);\n\n if (!useHoverLayer) {\n el.dirty(false);\n el.z2 += Z2_EMPHASIS_LIFT;\n }\n}\n\nfunction setDefaultHoverFillStroke(targetStyle, hoverStyle, prop) {\n if (!hasFillOrStroke(hoverStyle[prop]) && hasFillOrStroke(targetStyle[prop])) {\n targetStyle[prop] = liftColor(targetStyle[prop]);\n }\n}\n\nfunction doSingleLeaveHover(el) {\n var highlighted = el.__highlighted;\n\n if (!highlighted) {\n return;\n }\n\n el.__highlighted = false;\n\n if (highlighted === 'layer') {\n el.__zr && el.__zr.removeHover(el);\n } else if (highlighted) {\n var style = el.style;\n var normalStl = el.__cachedNormalStl;\n\n if (normalStl) {\n rollbackDefaultTextStyle(style); // Consider null/undefined value, should use\n // `setStyle` but not `extendFrom(stl, true)`.\n\n el.setStyle(normalStl);\n applyDefaultTextStyle(style);\n } // `__cachedNormalZ2` will not be reset if calling `setElementHoverStyle`\n // when `el` is on emphasis state. So here by comparing with 1, we try\n // hard to make the bug case rare.\n\n\n var normalZ2 = el.__cachedNormalZ2;\n\n if (normalZ2 != null && el.z2 - normalZ2 === Z2_EMPHASIS_LIFT) {\n el.z2 = normalZ2;\n }\n }\n}\n\nfunction traverseCall(el, method) {\n el.isGroup ? el.traverse(function (child) {\n !child.isGroup && method(child);\n }) : method(el);\n}\n/**\n * Set hover style (namely \"emphasis style\") of element, based on the current\n * style of the given `el`.\n * This method should be called after all of the normal styles have been adopted\n * to the `el`. See the reason on `setHoverStyle`.\n *\n * @param {module:zrender/Element} el Should not be `zrender/container/Group`.\n * @param {Object|boolean} [hoverStl] The specified hover style.\n * If set as `false`, disable the hover style.\n * Similarly, The `el.hoverStyle` can alse be set\n * as `false` to disable the hover style.\n * Otherwise, use the default hover style if not provided.\n * @param {Object} [opt]\n * @param {boolean} [opt.hoverSilentOnTouch=false] See `graphic.setAsHoverStyleTrigger`\n */\n\n\nfunction setElementHoverStyle(el, hoverStl) {\n // For performance consideration, it might be better to make the \"hover style\" only the\n // difference properties from the \"normal style\", but not a entire copy of all styles.\n hoverStl = el.__hoverStl = hoverStl !== false && (hoverStl || {});\n el.__hoverStlDirty = true; // FIXME\n // It is not completely right to save \"normal\"/\"emphasis\" flag on elements.\n // It probably should be saved on `data` of series. Consider the cases:\n // (1) A highlighted elements are moved out of the view port and re-enter\n // again by dataZoom.\n // (2) call `setOption` and replace elements totally when they are highlighted.\n\n if (el.__highlighted) {\n // Consider the case:\n // The styles of a highlighted `el` is being updated. The new \"emphasis style\"\n // should be adapted to the `el`. Notice here new \"normal styles\" should have\n // been set outside and the cached \"normal style\" is out of date.\n el.__cachedNormalStl = null; // Do not clear `__cachedNormalZ2` here, because setting `z2` is not a constraint\n // of this method. In most cases, `z2` is not set and hover style should be able\n // to rollback. Of course, that would bring bug, but only in a rare case, see\n // `doSingleLeaveHover` for details.\n\n doSingleLeaveHover(el);\n doSingleEnterHover(el);\n }\n}\n/**\n * Emphasis (called by API) has higher priority than `mouseover`.\n * When element has been called to be entered emphasis, mouse over\n * should not trigger the highlight effect (for example, animation\n * scale) again, and `mouseout` should not downplay the highlight\n * effect. So the listener of `mouseover` and `mouseout` should\n * check `isInEmphasis`.\n *\n * @param {module:zrender/Element} el\n * @return {boolean}\n */\n\n\nfunction isInEmphasis(el) {\n return el && el.__isEmphasisEntered;\n}\n\nfunction onElementMouseOver(e) {\n if (this.__hoverSilentOnTouch && e.zrByTouch) {\n return;\n } // Only if element is not in emphasis status\n\n\n !this.__isEmphasisEntered && traverseCall(this, doSingleEnterHover);\n}\n\nfunction onElementMouseOut(e) {\n if (this.__hoverSilentOnTouch && e.zrByTouch) {\n return;\n } // Only if element is not in emphasis status\n\n\n !this.__isEmphasisEntered && traverseCall(this, doSingleLeaveHover);\n}\n\nfunction enterEmphasis() {\n this.__isEmphasisEntered = true;\n traverseCall(this, doSingleEnterHover);\n}\n\nfunction leaveEmphasis() {\n this.__isEmphasisEntered = false;\n traverseCall(this, doSingleLeaveHover);\n}\n/**\n * Set hover style (namely \"emphasis style\") of element,\n * based on the current style of the given `el`.\n *\n * (1)\n * **CONSTRAINTS** for this method:\n * <A> This method MUST be called after all of the normal styles having been adopted\n * to the `el`.\n * <B> The input `hoverStyle` (that is, \"emphasis style\") MUST be the subset of the\n * \"normal style\" having been set to the el.\n * <C> `color` MUST be one of the \"normal styles\" (because color might be lifted as\n * a default hover style).\n *\n * The reason: this method treat the current style of the `el` as the \"normal style\"\n * and cache them when enter/update the \"emphasis style\". Consider the case: the `el`\n * is in \"emphasis\" state and `setOption`/`dispatchAction` trigger the style updating\n * logic, where the el should shift from the original emphasis style to the new\n * \"emphasis style\" and should be able to \"downplay\" back to the new \"normal style\".\n *\n * Indeed, it is error-prone to make a interface has so many constraints, but I have\n * not found a better solution yet to fit the backward compatibility, performance and\n * the current programming style.\n *\n * (2)\n * Call the method for a \"root\" element once. Do not call it for each descendants.\n * If the descendants elemenets of a group has itself hover style different from the\n * root group, we can simply mount the style on `el.hoverStyle` for them, but should\n * not call this method for them.\n *\n * @param {module:zrender/Element} el\n * @param {Object|boolean} [hoverStyle] See `graphic.setElementHoverStyle`.\n * @param {Object} [opt]\n * @param {boolean} [opt.hoverSilentOnTouch=false] See `graphic.setAsHoverStyleTrigger`.\n */\n\n\nfunction setHoverStyle(el, hoverStyle, opt) {\n el.isGroup ? el.traverse(function (child) {\n // If element has sepcified hoverStyle, then use it instead of given hoverStyle\n // Often used when item group has a label element and it's hoverStyle is different\n !child.isGroup && setElementHoverStyle(child, child.hoverStyle || hoverStyle);\n }) : setElementHoverStyle(el, el.hoverStyle || hoverStyle);\n setAsHoverStyleTrigger(el, opt);\n}\n/**\n * @param {Object|boolean} [opt] If `false`, means disable trigger.\n * @param {boolean} [opt.hoverSilentOnTouch=false]\n * In touch device, mouseover event will be trigger on touchstart event\n * (see module:zrender/dom/HandlerProxy). By this mechanism, we can\n * conveniently use hoverStyle when tap on touch screen without additional\n * code for compatibility.\n * But if the chart/component has select feature, which usually also use\n * hoverStyle, there might be conflict between 'select-highlight' and\n * 'hover-highlight' especially when roam is enabled (see geo for example).\n * In this case, hoverSilentOnTouch should be used to disable hover-highlight\n * on touch device.\n */\n\n\nfunction setAsHoverStyleTrigger(el, opt) {\n var disable = opt === false;\n el.__hoverSilentOnTouch = opt != null && opt.hoverSilentOnTouch; // Simple optimize, since this method might be\n // called for each elements of a group in some cases.\n\n if (!disable || el.__hoverStyleTrigger) {\n var method = disable ? 'off' : 'on'; // Duplicated function will be auto-ignored, see Eventful.js.\n\n el[method]('mouseover', onElementMouseOver)[method]('mouseout', onElementMouseOut); // Emphasis, normal can be triggered manually\n\n el[method]('emphasis', enterEmphasis)[method]('normal', leaveEmphasis);\n el.__hoverStyleTrigger = !disable;\n }\n}\n/**\n * See more info in `setTextStyleCommon`.\n * @param {Object|module:zrender/graphic/Style} normalStyle\n * @param {Object} emphasisStyle\n * @param {module:echarts/model/Model} normalModel\n * @param {module:echarts/model/Model} emphasisModel\n * @param {Object} opt Check `opt` of `setTextStyleCommon` to find other props.\n * @param {string|Function} [opt.defaultText]\n * @param {module:echarts/model/Model} [opt.labelFetcher] Fetch text by\n * `opt.labelFetcher.getFormattedLabel(opt.labelDataIndex, 'normal'/'emphasis', null, opt.labelDimIndex)`\n * @param {module:echarts/model/Model} [opt.labelDataIndex] Fetch text by\n * `opt.textFetcher.getFormattedLabel(opt.labelDataIndex, 'normal'/'emphasis', null, opt.labelDimIndex)`\n * @param {module:echarts/model/Model} [opt.labelDimIndex] Fetch text by\n * `opt.textFetcher.getFormattedLabel(opt.labelDataIndex, 'normal'/'emphasis', null, opt.labelDimIndex)`\n * @param {Object} [normalSpecified]\n * @param {Object} [emphasisSpecified]\n */\n\n\nfunction setLabelStyle(normalStyle, emphasisStyle, normalModel, emphasisModel, opt, normalSpecified, emphasisSpecified) {\n opt = opt || EMPTY_OBJ;\n var labelFetcher = opt.labelFetcher;\n var labelDataIndex = opt.labelDataIndex;\n var labelDimIndex = opt.labelDimIndex; // This scenario, `label.normal.show = true; label.emphasis.show = false`,\n // is not supported util someone requests.\n\n var showNormal = normalModel.getShallow('show');\n var showEmphasis = emphasisModel.getShallow('show'); // Consider performance, only fetch label when necessary.\n // If `normal.show` is `false` and `emphasis.show` is `true` and `emphasis.formatter` is not set,\n // label should be displayed, where text is fetched by `normal.formatter` or `opt.defaultText`.\n\n var baseText;\n\n if (showNormal || showEmphasis) {\n if (labelFetcher) {\n baseText = labelFetcher.getFormattedLabel(labelDataIndex, 'normal', null, labelDimIndex);\n }\n\n if (baseText == null) {\n baseText = zrUtil.isFunction(opt.defaultText) ? opt.defaultText(labelDataIndex, opt) : opt.defaultText;\n }\n }\n\n var normalStyleText = showNormal ? baseText : null;\n var emphasisStyleText = showEmphasis ? zrUtil.retrieve2(labelFetcher ? labelFetcher.getFormattedLabel(labelDataIndex, 'emphasis', null, labelDimIndex) : null, baseText) : null; // Optimize: If style.text is null, text will not be drawn.\n\n if (normalStyleText != null || emphasisStyleText != null) {\n // Always set `textStyle` even if `normalStyle.text` is null, because default\n // values have to be set on `normalStyle`.\n // If we set default values on `emphasisStyle`, consider case:\n // Firstly, `setOption(... label: {normal: {text: null}, emphasis: {show: true}} ...);`\n // Secondly, `setOption(... label: {noraml: {show: true, text: 'abc', color: 'red'} ...);`\n // Then the 'red' will not work on emphasis.\n setTextStyle(normalStyle, normalModel, normalSpecified, opt);\n setTextStyle(emphasisStyle, emphasisModel, emphasisSpecified, opt, true);\n }\n\n normalStyle.text = normalStyleText;\n emphasisStyle.text = emphasisStyleText;\n}\n/**\n * Set basic textStyle properties.\n * See more info in `setTextStyleCommon`.\n * @param {Object|module:zrender/graphic/Style} textStyle\n * @param {module:echarts/model/Model} model\n * @param {Object} [specifiedTextStyle] Can be overrided by settings in model.\n * @param {Object} [opt] See `opt` of `setTextStyleCommon`.\n * @param {boolean} [isEmphasis]\n */\n\n\nfunction setTextStyle(textStyle, textStyleModel, specifiedTextStyle, opt, isEmphasis) {\n setTextStyleCommon(textStyle, textStyleModel, opt, isEmphasis);\n specifiedTextStyle && zrUtil.extend(textStyle, specifiedTextStyle); // textStyle.host && textStyle.host.dirty && textStyle.host.dirty(false);\n\n return textStyle;\n}\n/**\n * Set text option in the style.\n * See more info in `setTextStyleCommon`.\n * @deprecated\n * @param {Object} textStyle\n * @param {module:echarts/model/Model} labelModel\n * @param {string|boolean} defaultColor Default text color.\n * If set as false, it will be processed as a emphasis style.\n */\n\n\nfunction setText(textStyle, labelModel, defaultColor) {\n var opt = {\n isRectText: true\n };\n var isEmphasis;\n\n if (defaultColor === false) {\n isEmphasis = true;\n } else {\n // Support setting color as 'auto' to get visual color.\n opt.autoColor = defaultColor;\n }\n\n setTextStyleCommon(textStyle, labelModel, opt, isEmphasis); // textStyle.host && textStyle.host.dirty && textStyle.host.dirty(false);\n}\n/**\n * The uniform entry of set text style, that is, retrieve style definitions\n * from `model` and set to `textStyle` object.\n *\n * Never in merge mode, but in overwrite mode, that is, all of the text style\n * properties will be set. (Consider the states of normal and emphasis and\n * default value can be adopted, merge would make the logic too complicated\n * to manage.)\n *\n * The `textStyle` object can either be a plain object or an instance of\n * `zrender/src/graphic/Style`, and either be the style of normal or emphasis.\n * After this mothod called, the `textStyle` object can then be used in\n * `el.setStyle(textStyle)` or `el.hoverStyle = textStyle`.\n *\n * Default value will be adopted and `insideRollbackOpt` will be created.\n * See `applyDefaultTextStyle` `rollbackDefaultTextStyle` for more details.\n *\n * opt: {\n * disableBox: boolean, Whether diable drawing box of block (outer most).\n * isRectText: boolean,\n * autoColor: string, specify a color when color is 'auto',\n * for textFill, textStroke, textBackgroundColor, and textBorderColor.\n * If autoColor specified, it is used as default textFill.\n * useInsideStyle:\n * `true`: Use inside style (textFill, textStroke, textStrokeWidth)\n * if `textFill` is not specified.\n * `false`: Do not use inside style.\n * `null/undefined`: use inside style if `isRectText` is true and\n * `textFill` is not specified and textPosition contains `'inside'`.\n * forceRich: boolean\n * }\n */\n\n\nfunction setTextStyleCommon(textStyle, textStyleModel, opt, isEmphasis) {\n // Consider there will be abnormal when merge hover style to normal style if given default value.\n opt = opt || EMPTY_OBJ;\n\n if (opt.isRectText) {\n var textPosition = textStyleModel.getShallow('position') || (isEmphasis ? null : 'inside'); // 'outside' is not a valid zr textPostion value, but used\n // in bar series, and magric type should be considered.\n\n textPosition === 'outside' && (textPosition = 'top');\n textStyle.textPosition = textPosition;\n textStyle.textOffset = textStyleModel.getShallow('offset');\n var labelRotate = textStyleModel.getShallow('rotate');\n labelRotate != null && (labelRotate *= Math.PI / 180);\n textStyle.textRotation = labelRotate;\n textStyle.textDistance = zrUtil.retrieve2(textStyleModel.getShallow('distance'), isEmphasis ? null : 5);\n }\n\n var ecModel = textStyleModel.ecModel;\n var globalTextStyle = ecModel && ecModel.option.textStyle; // Consider case:\n // {\n // data: [{\n // value: 12,\n // label: {\n // rich: {\n // // no 'a' here but using parent 'a'.\n // }\n // }\n // }],\n // rich: {\n // a: { ... }\n // }\n // }\n\n var richItemNames = getRichItemNames(textStyleModel);\n var richResult;\n\n if (richItemNames) {\n richResult = {};\n\n for (var name in richItemNames) {\n if (richItemNames.hasOwnProperty(name)) {\n // Cascade is supported in rich.\n var richTextStyle = textStyleModel.getModel(['rich', name]); // In rich, never `disableBox`.\n\n setTokenTextStyle(richResult[name] = {}, richTextStyle, globalTextStyle, opt, isEmphasis);\n }\n }\n }\n\n textStyle.rich = richResult;\n setTokenTextStyle(textStyle, textStyleModel, globalTextStyle, opt, isEmphasis, true);\n\n if (opt.forceRich && !opt.textStyle) {\n opt.textStyle = {};\n }\n\n return textStyle;\n} // Consider case:\n// {\n// data: [{\n// value: 12,\n// label: {\n// rich: {\n// // no 'a' here but using parent 'a'.\n// }\n// }\n// }],\n// rich: {\n// a: { ... }\n// }\n// }\n\n\nfunction getRichItemNames(textStyleModel) {\n // Use object to remove duplicated names.\n var richItemNameMap;\n\n while (textStyleModel && textStyleModel !== textStyleModel.ecModel) {\n var rich = (textStyleModel.option || EMPTY_OBJ).rich;\n\n if (rich) {\n richItemNameMap = richItemNameMap || {};\n\n for (var name in rich) {\n if (rich.hasOwnProperty(name)) {\n richItemNameMap[name] = 1;\n }\n }\n }\n\n textStyleModel = textStyleModel.parentModel;\n }\n\n return richItemNameMap;\n}\n\nfunction setTokenTextStyle(textStyle, textStyleModel, globalTextStyle, opt, isEmphasis, isBlock) {\n // In merge mode, default value should not be given.\n globalTextStyle = !isEmphasis && globalTextStyle || EMPTY_OBJ;\n textStyle.textFill = getAutoColor(textStyleModel.getShallow('color'), opt) || globalTextStyle.color;\n textStyle.textStroke = getAutoColor(textStyleModel.getShallow('textBorderColor'), opt) || globalTextStyle.textBorderColor;\n textStyle.textStrokeWidth = zrUtil.retrieve2(textStyleModel.getShallow('textBorderWidth'), globalTextStyle.textBorderWidth); // Save original textPosition, because style.textPosition will be repalced by\n // real location (like [10, 30]) in zrender.\n\n textStyle.insideRawTextPosition = textStyle.textPosition;\n\n if (!isEmphasis) {\n if (isBlock) {\n textStyle.insideRollbackOpt = opt;\n applyDefaultTextStyle(textStyle);\n } // Set default finally.\n\n\n if (textStyle.textFill == null) {\n textStyle.textFill = opt.autoColor;\n }\n } // Do not use `getFont` here, because merge should be supported, where\n // part of these properties may be changed in emphasis style, and the\n // others should remain their original value got from normal style.\n\n\n textStyle.fontStyle = textStyleModel.getShallow('fontStyle') || globalTextStyle.fontStyle;\n textStyle.fontWeight = textStyleModel.getShallow('fontWeight') || globalTextStyle.fontWeight;\n textStyle.fontSize = textStyleModel.getShallow('fontSize') || globalTextStyle.fontSize;\n textStyle.fontFamily = textStyleModel.getShallow('fontFamily') || globalTextStyle.fontFamily;\n textStyle.textAlign = textStyleModel.getShallow('align');\n textStyle.textVerticalAlign = textStyleModel.getShallow('verticalAlign') || textStyleModel.getShallow('baseline');\n textStyle.textLineHeight = textStyleModel.getShallow('lineHeight');\n textStyle.textWidth = textStyleModel.getShallow('width');\n textStyle.textHeight = textStyleModel.getShallow('height');\n textStyle.textTag = textStyleModel.getShallow('tag');\n\n if (!isBlock || !opt.disableBox) {\n textStyle.textBackgroundColor = getAutoColor(textStyleModel.getShallow('backgroundColor'), opt);\n textStyle.textPadding = textStyleModel.getShallow('padding');\n textStyle.textBorderColor = getAutoColor(textStyleModel.getShallow('borderColor'), opt);\n textStyle.textBorderWidth = textStyleModel.getShallow('borderWidth');\n textStyle.textBorderRadius = textStyleModel.getShallow('borderRadius');\n textStyle.textBoxShadowColor = textStyleModel.getShallow('shadowColor');\n textStyle.textBoxShadowBlur = textStyleModel.getShallow('shadowBlur');\n textStyle.textBoxShadowOffsetX = textStyleModel.getShallow('shadowOffsetX');\n textStyle.textBoxShadowOffsetY = textStyleModel.getShallow('shadowOffsetY');\n }\n\n textStyle.textShadowColor = textStyleModel.getShallow('textShadowColor') || globalTextStyle.textShadowColor;\n textStyle.textShadowBlur = textStyleModel.getShallow('textShadowBlur') || globalTextStyle.textShadowBlur;\n textStyle.textShadowOffsetX = textStyleModel.getShallow('textShadowOffsetX') || globalTextStyle.textShadowOffsetX;\n textStyle.textShadowOffsetY = textStyleModel.getShallow('textShadowOffsetY') || globalTextStyle.textShadowOffsetY;\n}\n\nfunction getAutoColor(color, opt) {\n return color !== 'auto' ? color : opt && opt.autoColor ? opt.autoColor : null;\n}\n/**\n * Give some default value to the input `textStyle` object, based on the current settings\n * in this `textStyle` object.\n *\n * The Scenario:\n * when text position is `inside` and `textFill` is not specified, we show\n * text border by default for better view. But it should be considered that text position\n * might be changed when hovering or being emphasis, where the `insideRollback` is used to\n * restore the style.\n *\n * Usage (& NOTICE):\n * When a style object (eithor plain object or instance of `zrender/src/graphic/Style`) is\n * about to be modified on its text related properties, `rollbackDefaultTextStyle` should\n * be called before the modification and `applyDefaultTextStyle` should be called after that.\n * (For the case that all of the text related properties is reset, like `setTextStyleCommon`\n * does, `rollbackDefaultTextStyle` is not needed to be called).\n */\n\n\nfunction applyDefaultTextStyle(textStyle) {\n var opt = textStyle.insideRollbackOpt; // Only `insideRollbackOpt` created (in `setTextStyleCommon`),\n // applyDefaultTextStyle works.\n\n if (!opt || textStyle.textFill != null) {\n return;\n }\n\n var useInsideStyle = opt.useInsideStyle;\n var textPosition = textStyle.insideRawTextPosition;\n var insideRollback;\n var autoColor = opt.autoColor;\n\n if (useInsideStyle !== false && (useInsideStyle === true || opt.isRectText && textPosition // textPosition can be [10, 30]\n && typeof textPosition === 'string' && textPosition.indexOf('inside') >= 0)) {\n insideRollback = {\n textFill: null,\n textStroke: textStyle.textStroke,\n textStrokeWidth: textStyle.textStrokeWidth\n };\n textStyle.textFill = '#fff'; // Consider text with #fff overflow its container.\n\n if (textStyle.textStroke == null) {\n textStyle.textStroke = autoColor;\n textStyle.textStrokeWidth == null && (textStyle.textStrokeWidth = 2);\n }\n } else if (autoColor != null) {\n insideRollback = {\n textFill: null\n };\n textStyle.textFill = autoColor;\n } // Always set `insideRollback`, for clearing previous.\n\n\n if (insideRollback) {\n textStyle.insideRollback = insideRollback;\n }\n}\n/**\n * Consider the case: in a scatter,\n * label: {\n * normal: {position: 'inside'},\n * emphasis: {position: 'top'}\n * }\n * In the normal state, the `textFill` will be set as '#fff' for pretty view (see\n * `applyDefaultTextStyle`), but when switching to emphasis state, the `textFill`\n * should be retured to 'autoColor', but not keep '#fff'.\n */\n\n\nfunction rollbackDefaultTextStyle(style) {\n var insideRollback = style.insideRollback;\n\n if (insideRollback) {\n style.textFill = insideRollback.textFill;\n style.textStroke = insideRollback.textStroke;\n style.textStrokeWidth = insideRollback.textStrokeWidth;\n style.insideRollback = null;\n }\n}\n\nfunction getFont(opt, ecModel) {\n // ecModel or default text style model.\n var gTextStyleModel = ecModel || ecModel.getModel('textStyle');\n return zrUtil.trim([// FIXME in node-canvas fontWeight is before fontStyle\n opt.fontStyle || gTextStyleModel && gTextStyleModel.getShallow('fontStyle') || '', opt.fontWeight || gTextStyleModel && gTextStyleModel.getShallow('fontWeight') || '', (opt.fontSize || gTextStyleModel && gTextStyleModel.getShallow('fontSize') || 12) + 'px', opt.fontFamily || gTextStyleModel && gTextStyleModel.getShallow('fontFamily') || 'sans-serif'].join(' '));\n}\n\nfunction animateOrSetProps(isUpdate, el, props, animatableModel, dataIndex, cb) {\n if (typeof dataIndex === 'function') {\n cb = dataIndex;\n dataIndex = null;\n } // Do not check 'animation' property directly here. Consider this case:\n // animation model is an `itemModel`, whose does not have `isAnimationEnabled`\n // but its parent model (`seriesModel`) does.\n\n\n var animationEnabled = animatableModel && animatableModel.isAnimationEnabled();\n\n if (animationEnabled) {\n var postfix = isUpdate ? 'Update' : '';\n var duration = animatableModel.getShallow('animationDuration' + postfix);\n var animationEasing = animatableModel.getShallow('animationEasing' + postfix);\n var animationDelay = animatableModel.getShallow('animationDelay' + postfix);\n\n if (typeof animationDelay === 'function') {\n animationDelay = animationDelay(dataIndex, animatableModel.getAnimationDelayParams ? animatableModel.getAnimationDelayParams(el, dataIndex) : null);\n }\n\n if (typeof duration === 'function') {\n duration = duration(dataIndex);\n }\n\n duration > 0 ? el.animateTo(props, duration, animationDelay || 0, animationEasing, cb, !!cb) : (el.stopAnimation(), el.attr(props), cb && cb());\n } else {\n el.stopAnimation();\n el.attr(props);\n cb && cb();\n }\n}\n/**\n * Update graphic element properties with or without animation according to the\n * configuration in series.\n *\n * Caution: this method will stop previous animation.\n * So if do not use this method to one element twice before\n * animation starts, unless you know what you are doing.\n *\n * @param {module:zrender/Element} el\n * @param {Object} props\n * @param {module:echarts/model/Model} [animatableModel]\n * @param {number} [dataIndex]\n * @param {Function} [cb]\n * @example\n * graphic.updateProps(el, {\n * position: [100, 100]\n * }, seriesModel, dataIndex, function () { console.log('Animation done!'); });\n * // Or\n * graphic.updateProps(el, {\n * position: [100, 100]\n * }, seriesModel, function () { console.log('Animation done!'); });\n */\n\n\nfunction updateProps(el, props, animatableModel, dataIndex, cb) {\n animateOrSetProps(true, el, props, animatableModel, dataIndex, cb);\n}\n/**\n * Init graphic element properties with or without animation according to the\n * configuration in series.\n *\n * Caution: this method will stop previous animation.\n * So if do not use this method to one element twice before\n * animation starts, unless you know what you are doing.\n *\n * @param {module:zrender/Element} el\n * @param {Object} props\n * @param {module:echarts/model/Model} [animatableModel]\n * @param {number} [dataIndex]\n * @param {Function} cb\n */\n\n\nfunction initProps(el, props, animatableModel, dataIndex, cb) {\n animateOrSetProps(false, el, props, animatableModel, dataIndex, cb);\n}\n/**\n * Get transform matrix of target (param target),\n * in coordinate of its ancestor (param ancestor)\n *\n * @param {module:zrender/mixin/Transformable} target\n * @param {module:zrender/mixin/Transformable} [ancestor]\n */\n\n\nfunction getTransform(target, ancestor) {\n var mat = matrix.identity([]);\n\n while (target && target !== ancestor) {\n matrix.mul(mat, target.getLocalTransform(), mat);\n target = target.parent;\n }\n\n return mat;\n}\n/**\n * Apply transform to an vertex.\n * @param {Array.<number>} target [x, y]\n * @param {Array.<number>|TypedArray.<number>|Object} transform Can be:\n * + Transform matrix: like [1, 0, 0, 1, 0, 0]\n * + {position, rotation, scale}, the same as `zrender/Transformable`.\n * @param {boolean=} invert Whether use invert matrix.\n * @return {Array.<number>} [x, y]\n */\n\n\nfunction applyTransform(target, transform, invert) {\n if (transform && !zrUtil.isArrayLike(transform)) {\n transform = Transformable.getLocalTransform(transform);\n }\n\n if (invert) {\n transform = matrix.invert([], transform);\n }\n\n return vector.applyTransform([], target, transform);\n}\n/**\n * @param {string} direction 'left' 'right' 'top' 'bottom'\n * @param {Array.<number>} transform Transform matrix: like [1, 0, 0, 1, 0, 0]\n * @param {boolean=} invert Whether use invert matrix.\n * @return {string} Transformed direction. 'left' 'right' 'top' 'bottom'\n */\n\n\nfunction transformDirection(direction, transform, invert) {\n // Pick a base, ensure that transform result will not be (0, 0).\n var hBase = transform[4] === 0 || transform[5] === 0 || transform[0] === 0 ? 1 : Math.abs(2 * transform[4] / transform[0]);\n var vBase = transform[4] === 0 || transform[5] === 0 || transform[2] === 0 ? 1 : Math.abs(2 * transform[4] / transform[2]);\n var vertex = [direction === 'left' ? -hBase : direction === 'right' ? hBase : 0, direction === 'top' ? -vBase : direction === 'bottom' ? vBase : 0];\n vertex = applyTransform(vertex, transform, invert);\n return Math.abs(vertex[0]) > Math.abs(vertex[1]) ? vertex[0] > 0 ? 'right' : 'left' : vertex[1] > 0 ? 'bottom' : 'top';\n}\n/**\n * Apply group transition animation from g1 to g2.\n * If no animatableModel, no animation.\n */\n\n\nfunction groupTransition(g1, g2, animatableModel, cb) {\n if (!g1 || !g2) {\n return;\n }\n\n function getElMap(g) {\n var elMap = {};\n g.traverse(function (el) {\n if (!el.isGroup && el.anid) {\n elMap[el.anid] = el;\n }\n });\n return elMap;\n }\n\n function getAnimatableProps(el) {\n var obj = {\n position: vector.clone(el.position),\n rotation: el.rotation\n };\n\n if (el.shape) {\n obj.shape = zrUtil.extend({}, el.shape);\n }\n\n return obj;\n }\n\n var elMap1 = getElMap(g1);\n g2.traverse(function (el) {\n if (!el.isGroup && el.anid) {\n var oldEl = elMap1[el.anid];\n\n if (oldEl) {\n var newProp = getAnimatableProps(el);\n el.attr(getAnimatableProps(oldEl));\n updateProps(el, newProp, animatableModel, el.dataIndex);\n } // else {\n // if (el.previousProps) {\n // graphic.updateProps\n // }\n // }\n\n }\n });\n}\n/**\n * @param {Array.<Array.<number>>} points Like: [[23, 44], [53, 66], ...]\n * @param {Object} rect {x, y, width, height}\n * @return {Array.<Array.<number>>} A new clipped points.\n */\n\n\nfunction clipPointsByRect(points, rect) {\n // FIXME: this way migth be incorrect when grpahic clipped by a corner.\n // and when element have border.\n return zrUtil.map(points, function (point) {\n var x = point[0];\n x = mathMax(x, rect.x);\n x = mathMin(x, rect.x + rect.width);\n var y = point[1];\n y = mathMax(y, rect.y);\n y = mathMin(y, rect.y + rect.height);\n return [x, y];\n });\n}\n/**\n * @param {Object} targetRect {x, y, width, height}\n * @param {Object} rect {x, y, width, height}\n * @return {Object} A new clipped rect. If rect size are negative, return undefined.\n */\n\n\nfunction clipRectByRect(targetRect, rect) {\n var x = mathMax(targetRect.x, rect.x);\n var x2 = mathMin(targetRect.x + targetRect.width, rect.x + rect.width);\n var y = mathMax(targetRect.y, rect.y);\n var y2 = mathMin(targetRect.y + targetRect.height, rect.y + rect.height); // If the total rect is cliped, nothing, including the border,\n // should be painted. So return undefined.\n\n if (x2 >= x && y2 >= y) {\n return {\n x: x,\n y: y,\n width: x2 - x,\n height: y2 - y\n };\n }\n}\n/**\n * @param {string} iconStr Support 'image://' or 'path://' or direct svg path.\n * @param {Object} [opt] Properties of `module:zrender/Element`, except `style`.\n * @param {Object} [rect] {x, y, width, height}\n * @return {module:zrender/Element} Icon path or image element.\n */\n\n\nfunction createIcon(iconStr, opt, rect) {\n opt = zrUtil.extend({\n rectHover: true\n }, opt);\n var style = opt.style = {\n strokeNoScale: true\n };\n rect = rect || {\n x: -1,\n y: -1,\n width: 2,\n height: 2\n };\n\n if (iconStr) {\n return iconStr.indexOf('image://') === 0 ? (style.image = iconStr.slice(8), zrUtil.defaults(style, rect), new ZImage(opt)) : makePath(iconStr.replace('path://', ''), opt, rect, 'center');\n }\n}\n\nexports.Z2_EMPHASIS_LIFT = Z2_EMPHASIS_LIFT;\nexports.extendShape = extendShape;\nexports.extendPath = extendPath;\nexports.makePath = makePath;\nexports.makeImage = makeImage;\nexports.mergePath = mergePath;\nexports.resizePath = resizePath;\nexports.subPixelOptimizeLine = subPixelOptimizeLine;\nexports.subPixelOptimizeRect = subPixelOptimizeRect;\nexports.subPixelOptimize = subPixelOptimize;\nexports.setElementHoverStyle = setElementHoverStyle;\nexports.isInEmphasis = isInEmphasis;\nexports.setHoverStyle = setHoverStyle;\nexports.setAsHoverStyleTrigger = setAsHoverStyleTrigger;\nexports.setLabelStyle = setLabelStyle;\nexports.setTextStyle = setTextStyle;\nexports.setText = setText;\nexports.getFont = getFont;\nexports.updateProps = updateProps;\nexports.initProps = initProps;\nexports.getTransform = getTransform;\nexports.applyTransform = applyTransform;\nexports.transformDirection = transformDirection;\nexports.groupTransition = groupTransition;\nexports.clipPointsByRect = clipPointsByRect;\nexports.clipRectByRect = clipRectByRect;\nexports.createIcon = createIcon;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar modelUtil = require(\"../../util/model\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar each = zrUtil.each;\nvar isObject = zrUtil.isObject;\nvar POSSIBLE_STYLES = ['areaStyle', 'lineStyle', 'nodeStyle', 'linkStyle', 'chordStyle', 'label', 'labelLine'];\n\nfunction compatEC2ItemStyle(opt) {\n var itemStyleOpt = opt && opt.itemStyle;\n\n if (!itemStyleOpt) {\n return;\n }\n\n for (var i = 0, len = POSSIBLE_STYLES.length; i < len; i++) {\n var styleName = POSSIBLE_STYLES[i];\n var normalItemStyleOpt = itemStyleOpt.normal;\n var emphasisItemStyleOpt = itemStyleOpt.emphasis;\n\n if (normalItemStyleOpt && normalItemStyleOpt[styleName]) {\n opt[styleName] = opt[styleName] || {};\n\n if (!opt[styleName].normal) {\n opt[styleName].normal = normalItemStyleOpt[styleName];\n } else {\n zrUtil.merge(opt[styleName].normal, normalItemStyleOpt[styleName]);\n }\n\n normalItemStyleOpt[styleName] = null;\n }\n\n if (emphasisItemStyleOpt && emphasisItemStyleOpt[styleName]) {\n opt[styleName] = opt[styleName] || {};\n\n if (!opt[styleName].emphasis) {\n opt[styleName].emphasis = emphasisItemStyleOpt[styleName];\n } else {\n zrUtil.merge(opt[styleName].emphasis, emphasisItemStyleOpt[styleName]);\n }\n\n emphasisItemStyleOpt[styleName] = null;\n }\n }\n}\n\nfunction convertNormalEmphasis(opt, optType, useExtend) {\n if (opt && opt[optType] && (opt[optType].normal || opt[optType].emphasis)) {\n var normalOpt = opt[optType].normal;\n var emphasisOpt = opt[optType].emphasis;\n\n if (normalOpt) {\n // Timeline controlStyle has other properties besides normal and emphasis\n if (useExtend) {\n opt[optType].normal = opt[optType].emphasis = null;\n zrUtil.defaults(opt[optType], normalOpt);\n } else {\n opt[optType] = normalOpt;\n }\n }\n\n if (emphasisOpt) {\n opt.emphasis = opt.emphasis || {};\n opt.emphasis[optType] = emphasisOpt;\n }\n }\n}\n\nfunction removeEC3NormalStatus(opt) {\n convertNormalEmphasis(opt, 'itemStyle');\n convertNormalEmphasis(opt, 'lineStyle');\n convertNormalEmphasis(opt, 'areaStyle');\n convertNormalEmphasis(opt, 'label');\n convertNormalEmphasis(opt, 'labelLine'); // treemap\n\n convertNormalEmphasis(opt, 'upperLabel'); // graph\n\n convertNormalEmphasis(opt, 'edgeLabel');\n}\n\nfunction compatTextStyle(opt, propName) {\n // Check whether is not object (string\\null\\undefined ...)\n var labelOptSingle = isObject(opt) && opt[propName];\n var textStyle = isObject(labelOptSingle) && labelOptSingle.textStyle;\n\n if (textStyle) {\n for (var i = 0, len = modelUtil.TEXT_STYLE_OPTIONS.length; i < len; i++) {\n var propName = modelUtil.TEXT_STYLE_OPTIONS[i];\n\n if (textStyle.hasOwnProperty(propName)) {\n labelOptSingle[propName] = textStyle[propName];\n }\n }\n }\n}\n\nfunction compatEC3CommonStyles(opt) {\n if (opt) {\n removeEC3NormalStatus(opt);\n compatTextStyle(opt, 'label');\n opt.emphasis && compatTextStyle(opt.emphasis, 'label');\n }\n}\n\nfunction processSeries(seriesOpt) {\n if (!isObject(seriesOpt)) {\n return;\n }\n\n compatEC2ItemStyle(seriesOpt);\n removeEC3NormalStatus(seriesOpt);\n compatTextStyle(seriesOpt, 'label'); // treemap\n\n compatTextStyle(seriesOpt, 'upperLabel'); // graph\n\n compatTextStyle(seriesOpt, 'edgeLabel');\n\n if (seriesOpt.emphasis) {\n compatTextStyle(seriesOpt.emphasis, 'label'); // treemap\n\n compatTextStyle(seriesOpt.emphasis, 'upperLabel'); // graph\n\n compatTextStyle(seriesOpt.emphasis, 'edgeLabel');\n }\n\n var markPoint = seriesOpt.markPoint;\n\n if (markPoint) {\n compatEC2ItemStyle(markPoint);\n compatEC3CommonStyles(markPoint);\n }\n\n var markLine = seriesOpt.markLine;\n\n if (markLine) {\n compatEC2ItemStyle(markLine);\n compatEC3CommonStyles(markLine);\n }\n\n var markArea = seriesOpt.markArea;\n\n if (markArea) {\n compatEC3CommonStyles(markArea);\n }\n\n var data = seriesOpt.data; // Break with ec3: if `setOption` again, there may be no `type` in option,\n // then the backward compat based on option type will not be performed.\n\n if (seriesOpt.type === 'graph') {\n data = data || seriesOpt.nodes;\n var edgeData = seriesOpt.links || seriesOpt.edges;\n\n if (edgeData && !zrUtil.isTypedArray(edgeData)) {\n for (var i = 0; i < edgeData.length; i++) {\n compatEC3CommonStyles(edgeData[i]);\n }\n }\n\n zrUtil.each(seriesOpt.categories, function (opt) {\n removeEC3NormalStatus(opt);\n });\n }\n\n if (data && !zrUtil.isTypedArray(data)) {\n for (var i = 0; i < data.length; i++) {\n compatEC3CommonStyles(data[i]);\n }\n } // mark point data\n\n\n var markPoint = seriesOpt.markPoint;\n\n if (markPoint && markPoint.data) {\n var mpData = markPoint.data;\n\n for (var i = 0; i < mpData.length; i++) {\n compatEC3CommonStyles(mpData[i]);\n }\n } // mark line data\n\n\n var markLine = seriesOpt.markLine;\n\n if (markLine && markLine.data) {\n var mlData = markLine.data;\n\n for (var i = 0; i < mlData.length; i++) {\n if (zrUtil.isArray(mlData[i])) {\n compatEC3CommonStyles(mlData[i][0]);\n compatEC3CommonStyles(mlData[i][1]);\n } else {\n compatEC3CommonStyles(mlData[i]);\n }\n }\n } // Series\n\n\n if (seriesOpt.type === 'gauge') {\n compatTextStyle(seriesOpt, 'axisLabel');\n compatTextStyle(seriesOpt, 'title');\n compatTextStyle(seriesOpt, 'detail');\n } else if (seriesOpt.type === 'treemap') {\n convertNormalEmphasis(seriesOpt.breadcrumb, 'itemStyle');\n zrUtil.each(seriesOpt.levels, function (opt) {\n removeEC3NormalStatus(opt);\n });\n } else if (seriesOpt.type === 'tree') {\n removeEC3NormalStatus(seriesOpt.leaves);\n } // sunburst starts from ec4, so it does not need to compat levels.\n\n}\n\nfunction toArr(o) {\n return zrUtil.isArray(o) ? o : o ? [o] : [];\n}\n\nfunction toObj(o) {\n return (zrUtil.isArray(o) ? o[0] : o) || {};\n}\n\nfunction _default(option, isTheme) {\n each(toArr(option.series), function (seriesOpt) {\n isObject(seriesOpt) && processSeries(seriesOpt);\n });\n var axes = ['xAxis', 'yAxis', 'radiusAxis', 'angleAxis', 'singleAxis', 'parallelAxis', 'radar'];\n isTheme && axes.push('valueAxis', 'categoryAxis', 'logAxis', 'timeAxis');\n each(axes, function (axisName) {\n each(toArr(option[axisName]), function (axisOpt) {\n if (axisOpt) {\n compatTextStyle(axisOpt, 'axisLabel');\n compatTextStyle(axisOpt.axisPointer, 'label');\n }\n });\n });\n each(toArr(option.parallel), function (parallelOpt) {\n var parallelAxisDefault = parallelOpt && parallelOpt.parallelAxisDefault;\n compatTextStyle(parallelAxisDefault, 'axisLabel');\n compatTextStyle(parallelAxisDefault && parallelAxisDefault.axisPointer, 'label');\n });\n each(toArr(option.calendar), function (calendarOpt) {\n convertNormalEmphasis(calendarOpt, 'itemStyle');\n compatTextStyle(calendarOpt, 'dayLabel');\n compatTextStyle(calendarOpt, 'monthLabel');\n compatTextStyle(calendarOpt, 'yearLabel');\n }); // radar.name.textStyle\n\n each(toArr(option.radar), function (radarOpt) {\n compatTextStyle(radarOpt, 'name');\n });\n each(toArr(option.geo), function (geoOpt) {\n if (isObject(geoOpt)) {\n compatEC3CommonStyles(geoOpt);\n each(toArr(geoOpt.regions), function (regionObj) {\n compatEC3CommonStyles(regionObj);\n });\n }\n });\n each(toArr(option.timeline), function (timelineOpt) {\n compatEC3CommonStyles(timelineOpt);\n convertNormalEmphasis(timelineOpt, 'label');\n convertNormalEmphasis(timelineOpt, 'itemStyle');\n convertNormalEmphasis(timelineOpt, 'controlStyle', true);\n var data = timelineOpt.data;\n zrUtil.isArray(data) && zrUtil.each(data, function (item) {\n if (zrUtil.isObject(item)) {\n convertNormalEmphasis(item, 'label');\n convertNormalEmphasis(item, 'itemStyle');\n }\n });\n });\n each(toArr(option.toolbox), function (toolboxOpt) {\n convertNormalEmphasis(toolboxOpt, 'iconStyle');\n each(toolboxOpt.feature, function (featureOpt) {\n convertNormalEmphasis(featureOpt, 'iconStyle');\n });\n });\n compatTextStyle(toObj(option.axisPointer), 'label');\n compatTextStyle(toObj(option.tooltip).axisPointer, 'label');\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// TODO Parse shadow style\n// TODO Only shallow path support\nfunction _default(properties) {\n // Normalize\n for (var i = 0; i < properties.length; i++) {\n if (!properties[i][1]) {\n properties[i][1] = properties[i][0];\n }\n }\n\n return function (model, excludes, includes) {\n var style = {};\n\n for (var i = 0; i < properties.length; i++) {\n var propName = properties[i][1];\n\n if (excludes && zrUtil.indexOf(excludes, propName) >= 0 || includes && zrUtil.indexOf(includes, propName) < 0) {\n continue;\n }\n\n var val = model.getShallow(propName);\n\n if (val != null) {\n style[properties[i][0]] = val;\n }\n }\n\n return style;\n };\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar _default = {\n toolbox: {\n brush: {\n title: {\n rect: '矩形选择',\n polygon: '圈选',\n lineX: '横向选择',\n lineY: '纵向选择',\n keep: '保持选择',\n clear: '清除选择'\n }\n },\n dataView: {\n title: '数据视图',\n lang: ['数据视图', '关闭', '刷新']\n },\n dataZoom: {\n title: {\n zoom: '区域缩放',\n back: '区域缩放还原'\n }\n },\n magicType: {\n title: {\n line: '切换为折线图',\n bar: '切换为柱状图',\n stack: '切换为堆叠',\n tiled: '切换为平铺'\n }\n },\n restore: {\n title: '还原'\n },\n saveAsImage: {\n title: '保存为图片',\n lang: ['右键另存为图片']\n }\n },\n series: {\n typeNames: {\n pie: '饼图',\n bar: '柱状图',\n line: '折线图',\n scatter: '散点图',\n effectScatter: '涟漪散点图',\n radar: '雷达图',\n tree: '树图',\n treemap: '矩形树图',\n boxplot: '箱型图',\n candlestick: 'K线图',\n k: 'K线图',\n heatmap: '热力图',\n map: '地图',\n parallel: '平行坐标图',\n lines: '线图',\n graph: '关系图',\n sankey: '桑基图',\n funnel: '漏斗图',\n gauge: '仪表盘图',\n pictorialBar: '象形柱图',\n themeRiver: '主题河流图',\n sunburst: '旭日图'\n }\n },\n aria: {\n general: {\n withTitle: '这是一个关于“{title}”的图表。',\n withoutTitle: '这是一个图表,'\n },\n series: {\n single: {\n prefix: '',\n withName: '图表类型是{seriesType},表示{seriesName}。',\n withoutName: '图表类型是{seriesType}。'\n },\n multiple: {\n prefix: '它由{seriesCount}个图表系列组成。',\n withName: '第{seriesId}个系列是一个表示{seriesName}的{seriesType},',\n withoutName: '第{seriesId}个系列是一个{seriesType},',\n separator: {\n middle: ';',\n end: '。'\n }\n }\n },\n data: {\n allData: '其数据是——',\n partialData: '其中,前{displayCnt}项是——',\n withName: '{name}的数据是{value}',\n withoutName: '{value}',\n separator: {\n middle: ',',\n end: ''\n }\n }\n }\n};\nmodule.exports = _default;","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar isTypedArray = _util.isTypedArray;\nvar extend = _util.extend;\nvar assert = _util.assert;\nvar each = _util.each;\nvar isObject = _util.isObject;\n\nvar _model = require(\"../../util/model\");\n\nvar getDataItemValue = _model.getDataItemValue;\nvar isDataItemOption = _model.isDataItemOption;\n\nvar _number = require(\"../../util/number\");\n\nvar parseDate = _number.parseDate;\n\nvar Source = require(\"../Source\");\n\nvar _sourceType = require(\"./sourceType\");\n\nvar SOURCE_FORMAT_TYPED_ARRAY = _sourceType.SOURCE_FORMAT_TYPED_ARRAY;\nvar SOURCE_FORMAT_ARRAY_ROWS = _sourceType.SOURCE_FORMAT_ARRAY_ROWS;\nvar SOURCE_FORMAT_ORIGINAL = _sourceType.SOURCE_FORMAT_ORIGINAL;\nvar SOURCE_FORMAT_OBJECT_ROWS = _sourceType.SOURCE_FORMAT_OBJECT_ROWS;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// TODO\n// ??? refactor? check the outer usage of data provider.\n// merge with defaultDimValueGetter?\n\n/**\n * If normal array used, mutable chunk size is supported.\n * If typed array used, chunk size must be fixed.\n */\nfunction DefaultDataProvider(source, dimSize) {\n if (!Source.isInstance(source)) {\n source = Source.seriesDataToSource(source);\n }\n\n this._source = source;\n var data = this._data = source.data;\n var sourceFormat = source.sourceFormat; // Typed array. TODO IE10+?\n\n if (sourceFormat === SOURCE_FORMAT_TYPED_ARRAY) {\n this._offset = 0;\n this._dimSize = dimSize;\n this._data = data;\n }\n\n var methods = providerMethods[sourceFormat === SOURCE_FORMAT_ARRAY_ROWS ? sourceFormat + '_' + source.seriesLayoutBy : sourceFormat];\n extend(this, methods);\n}\n\nvar providerProto = DefaultDataProvider.prototype; // If data is pure without style configuration\n\nproviderProto.pure = false; // If data is persistent and will not be released after use.\n\nproviderProto.persistent = true; // ???! FIXME legacy data provider do not has method getSource\n\nproviderProto.getSource = function () {\n return this._source;\n};\n\nvar providerMethods = {\n 'arrayRows_column': {\n pure: true,\n count: function () {\n return Math.max(0, this._data.length - this._source.startIndex);\n },\n getItem: function (idx) {\n return this._data[idx + this._source.startIndex];\n },\n appendData: appendDataSimply\n },\n 'arrayRows_row': {\n pure: true,\n count: function () {\n var row = this._data[0];\n return row ? Math.max(0, row.length - this._source.startIndex) : 0;\n },\n getItem: function (idx) {\n idx += this._source.startIndex;\n var item = [];\n var data = this._data;\n\n for (var i = 0; i < data.length; i++) {\n var row = data[i];\n item.push(row ? row[idx] : null);\n }\n\n return item;\n },\n appendData: function () {\n throw new Error('Do not support appendData when set seriesLayoutBy: \"row\".');\n }\n },\n 'objectRows': {\n pure: true,\n count: countSimply,\n getItem: getItemSimply,\n appendData: appendDataSimply\n },\n 'keyedColumns': {\n pure: true,\n count: function () {\n var dimName = this._source.dimensionsDefine[0].name;\n var col = this._data[dimName];\n return col ? col.length : 0;\n },\n getItem: function (idx) {\n var item = [];\n var dims = this._source.dimensionsDefine;\n\n for (var i = 0; i < dims.length; i++) {\n var col = this._data[dims[i].name];\n item.push(col ? col[idx] : null);\n }\n\n return item;\n },\n appendData: function (newData) {\n var data = this._data;\n each(newData, function (newCol, key) {\n var oldCol = data[key] || (data[key] = []);\n\n for (var i = 0; i < (newCol || []).length; i++) {\n oldCol.push(newCol[i]);\n }\n });\n }\n },\n 'original': {\n count: countSimply,\n getItem: getItemSimply,\n appendData: appendDataSimply\n },\n 'typedArray': {\n persistent: false,\n pure: true,\n count: function () {\n return this._data ? this._data.length / this._dimSize : 0;\n },\n getItem: function (idx, out) {\n idx = idx - this._offset;\n out = out || [];\n var offset = this._dimSize * idx;\n\n for (var i = 0; i < this._dimSize; i++) {\n out[i] = this._data[offset + i];\n }\n\n return out;\n },\n appendData: function (newData) {\n this._data = newData;\n },\n // Clean self if data is already used.\n clean: function () {\n // PENDING\n this._offset += this.count();\n this._data = null;\n }\n }\n};\n\nfunction countSimply() {\n return this._data.length;\n}\n\nfunction getItemSimply(idx) {\n return this._data[idx];\n}\n\nfunction appendDataSimply(newData) {\n for (var i = 0; i < newData.length; i++) {\n this._data.push(newData[i]);\n }\n}\n\nvar rawValueGetters = {\n arrayRows: getRawValueSimply,\n objectRows: function (dataItem, dataIndex, dimIndex, dimName) {\n return dimIndex != null ? dataItem[dimName] : dataItem;\n },\n keyedColumns: getRawValueSimply,\n original: function (dataItem, dataIndex, dimIndex, dimName) {\n // FIXME\n // In some case (markpoint in geo (geo-map.html)), dataItem\n // is {coord: [...]}\n var value = getDataItemValue(dataItem);\n return dimIndex == null || !(value instanceof Array) ? value : value[dimIndex];\n },\n typedArray: getRawValueSimply\n};\n\nfunction getRawValueSimply(dataItem, dataIndex, dimIndex, dimName) {\n return dimIndex != null ? dataItem[dimIndex] : dataItem;\n}\n\nvar defaultDimValueGetters = {\n arrayRows: getDimValueSimply,\n objectRows: function (dataItem, dimName, dataIndex, dimIndex) {\n return converDataValue(dataItem[dimName], this._dimensionInfos[dimName]);\n },\n keyedColumns: getDimValueSimply,\n original: function (dataItem, dimName, dataIndex, dimIndex) {\n // Performance sensitive, do not use modelUtil.getDataItemValue.\n // If dataItem is an plain object with no value field, the var `value`\n // will be assigned with the object, but it will be tread correctly\n // in the `convertDataValue`.\n var value = dataItem && (dataItem.value == null ? dataItem : dataItem.value); // If any dataItem is like { value: 10 }\n\n if (!this._rawData.pure && isDataItemOption(dataItem)) {\n this.hasItemOption = true;\n }\n\n return converDataValue(value instanceof Array ? value[dimIndex] // If value is a single number or something else not array.\n : value, this._dimensionInfos[dimName]);\n },\n typedArray: function (dataItem, dimName, dataIndex, dimIndex) {\n return dataItem[dimIndex];\n }\n};\n\nfunction getDimValueSimply(dataItem, dimName, dataIndex, dimIndex) {\n return converDataValue(dataItem[dimIndex], this._dimensionInfos[dimName]);\n}\n/**\n * This helper method convert value in data.\n * @param {string|number|Date} value\n * @param {Object|string} [dimInfo] If string (like 'x'), dimType defaults 'number'.\n * If \"dimInfo.ordinalParseAndSave\", ordinal value can be parsed.\n */\n\n\nfunction converDataValue(value, dimInfo) {\n // Performance sensitive.\n var dimType = dimInfo && dimInfo.type;\n\n if (dimType === 'ordinal') {\n // If given value is a category string\n var ordinalMeta = dimInfo && dimInfo.ordinalMeta;\n return ordinalMeta ? ordinalMeta.parseAndCollect(value) : value;\n }\n\n if (dimType === 'time' // spead up when using timestamp\n && typeof value !== 'number' && value != null && value !== '-') {\n value = +parseDate(value);\n } // dimType defaults 'number'.\n // If dimType is not ordinal and value is null or undefined or NaN or '-',\n // parse to NaN.\n\n\n return value == null || value === '' ? NaN // If string (like '-'), using '+' parse to NaN\n // If object, also parse to NaN\n : +value;\n} // ??? FIXME can these logic be more neat: getRawValue, getRawDataItem,\n// Consider persistent.\n// Caution: why use raw value to display on label or tooltip?\n// A reason is to avoid format. For example time value we do not know\n// how to format is expected. More over, if stack is used, calculated\n// value may be 0.91000000001, which have brings trouble to display.\n// TODO: consider how to treat null/undefined/NaN when display?\n\n/**\n * @param {module:echarts/data/List} data\n * @param {number} dataIndex\n * @param {string|number} [dim] dimName or dimIndex\n * @return {Array.<number>|string|number} can be null/undefined.\n */\n\n\nfunction retrieveRawValue(data, dataIndex, dim) {\n if (!data) {\n return;\n } // Consider data may be not persistent.\n\n\n var dataItem = data.getRawDataItem(dataIndex);\n\n if (dataItem == null) {\n return;\n }\n\n var sourceFormat = data.getProvider().getSource().sourceFormat;\n var dimName;\n var dimIndex;\n var dimInfo = data.getDimensionInfo(dim);\n\n if (dimInfo) {\n dimName = dimInfo.name;\n dimIndex = dimInfo.index;\n }\n\n return rawValueGetters[sourceFormat](dataItem, dataIndex, dimIndex, dimName);\n}\n/**\n * Compatible with some cases (in pie, map) like:\n * data: [{name: 'xx', value: 5, selected: true}, ...]\n * where only sourceFormat is 'original' and 'objectRows' supported.\n *\n * ??? TODO\n * Supported detail options in data item when using 'arrayRows'.\n *\n * @param {module:echarts/data/List} data\n * @param {number} dataIndex\n * @param {string} attr like 'selected'\n */\n\n\nfunction retrieveRawAttr(data, dataIndex, attr) {\n if (!data) {\n return;\n }\n\n var sourceFormat = data.getProvider().getSource().sourceFormat;\n\n if (sourceFormat !== SOURCE_FORMAT_ORIGINAL && sourceFormat !== SOURCE_FORMAT_OBJECT_ROWS) {\n return;\n }\n\n var dataItem = data.getRawDataItem(dataIndex);\n\n if (sourceFormat === SOURCE_FORMAT_ORIGINAL && !isObject(dataItem)) {\n dataItem = null;\n }\n\n if (dataItem) {\n return dataItem[attr];\n }\n}\n\nexports.DefaultDataProvider = DefaultDataProvider;\nexports.defaultDimValueGetters = defaultDimValueGetters;\nexports.retrieveRawValue = retrieveRawValue;\nexports.retrieveRawAttr = retrieveRawAttr;","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","var fixShadow = require(\"./helper/fixShadow\");\n\nvar _constant = require(\"./constant\");\n\nvar ContextCachedBy = _constant.ContextCachedBy;\nvar STYLE_COMMON_PROPS = [['shadowBlur', 0], ['shadowOffsetX', 0], ['shadowOffsetY', 0], ['shadowColor', '#000'], ['lineCap', 'butt'], ['lineJoin', 'miter'], ['miterLimit', 10]]; // var SHADOW_PROPS = STYLE_COMMON_PROPS.slice(0, 4);\n// var LINE_PROPS = STYLE_COMMON_PROPS.slice(4);\n\nvar Style = function (opts) {\n this.extendFrom(opts, false);\n};\n\nfunction createLinearGradient(ctx, obj, rect) {\n var x = obj.x == null ? 0 : obj.x;\n var x2 = obj.x2 == null ? 1 : obj.x2;\n var y = obj.y == null ? 0 : obj.y;\n var y2 = obj.y2 == null ? 0 : obj.y2;\n\n if (!obj.global) {\n x = x * rect.width + rect.x;\n x2 = x2 * rect.width + rect.x;\n y = y * rect.height + rect.y;\n y2 = y2 * rect.height + rect.y;\n } // Fix NaN when rect is Infinity\n\n\n x = isNaN(x) ? 0 : x;\n x2 = isNaN(x2) ? 1 : x2;\n y = isNaN(y) ? 0 : y;\n y2 = isNaN(y2) ? 0 : y2;\n var canvasGradient = ctx.createLinearGradient(x, y, x2, y2);\n return canvasGradient;\n}\n\nfunction createRadialGradient(ctx, obj, rect) {\n var width = rect.width;\n var height = rect.height;\n var min = Math.min(width, height);\n var x = obj.x == null ? 0.5 : obj.x;\n var y = obj.y == null ? 0.5 : obj.y;\n var r = obj.r == null ? 0.5 : obj.r;\n\n if (!obj.global) {\n x = x * width + rect.x;\n y = y * height + rect.y;\n r = r * min;\n }\n\n var canvasGradient = ctx.createRadialGradient(x, y, 0, x, y, r);\n return canvasGradient;\n}\n\nStyle.prototype = {\n constructor: Style,\n\n /**\n * @type {string}\n */\n fill: '#000',\n\n /**\n * @type {string}\n */\n stroke: null,\n\n /**\n * @type {number}\n */\n opacity: 1,\n\n /**\n * @type {number}\n */\n fillOpacity: null,\n\n /**\n * @type {number}\n */\n strokeOpacity: null,\n\n /**\n * @type {Array.<number>}\n */\n lineDash: null,\n\n /**\n * @type {number}\n */\n lineDashOffset: 0,\n\n /**\n * @type {number}\n */\n shadowBlur: 0,\n\n /**\n * @type {number}\n */\n shadowOffsetX: 0,\n\n /**\n * @type {number}\n */\n shadowOffsetY: 0,\n\n /**\n * @type {number}\n */\n lineWidth: 1,\n\n /**\n * If stroke ignore scale\n * @type {Boolean}\n */\n strokeNoScale: false,\n // Bounding rect text configuration\n // Not affected by element transform\n\n /**\n * @type {string}\n */\n text: null,\n\n /**\n * If `fontSize` or `fontFamily` exists, `font` will be reset by\n * `fontSize`, `fontStyle`, `fontWeight`, `fontFamily`.\n * So do not visit it directly in upper application (like echarts),\n * but use `contain/text#makeFont` instead.\n * @type {string}\n */\n font: null,\n\n /**\n * The same as font. Use font please.\n * @deprecated\n * @type {string}\n */\n textFont: null,\n\n /**\n * It helps merging respectively, rather than parsing an entire font string.\n * @type {string}\n */\n fontStyle: null,\n\n /**\n * It helps merging respectively, rather than parsing an entire font string.\n * @type {string}\n */\n fontWeight: null,\n\n /**\n * It helps merging respectively, rather than parsing an entire font string.\n * Should be 12 but not '12px'.\n * @type {number}\n */\n fontSize: null,\n\n /**\n * It helps merging respectively, rather than parsing an entire font string.\n * @type {string}\n */\n fontFamily: null,\n\n /**\n * Reserved for special functinality, like 'hr'.\n * @type {string}\n */\n textTag: null,\n\n /**\n * @type {string}\n */\n textFill: '#000',\n\n /**\n * @type {string}\n */\n textStroke: null,\n\n /**\n * @type {number}\n */\n textWidth: null,\n\n /**\n * Only for textBackground.\n * @type {number}\n */\n textHeight: null,\n\n /**\n * textStroke may be set as some color as a default\n * value in upper applicaion, where the default value\n * of textStrokeWidth should be 0 to make sure that\n * user can choose to do not use text stroke.\n * @type {number}\n */\n textStrokeWidth: 0,\n\n /**\n * @type {number}\n */\n textLineHeight: null,\n\n /**\n * 'inside', 'left', 'right', 'top', 'bottom'\n * [x, y]\n * Based on x, y of rect.\n * @type {string|Array.<number>}\n * @default 'inside'\n */\n textPosition: 'inside',\n\n /**\n * If not specified, use the boundingRect of a `displayable`.\n * @type {Object}\n */\n textRect: null,\n\n /**\n * [x, y]\n * @type {Array.<number>}\n */\n textOffset: null,\n\n /**\n * @type {string}\n */\n textAlign: null,\n\n /**\n * @type {string}\n */\n textVerticalAlign: null,\n\n /**\n * @type {number}\n */\n textDistance: 5,\n\n /**\n * @type {string}\n */\n textShadowColor: 'transparent',\n\n /**\n * @type {number}\n */\n textShadowBlur: 0,\n\n /**\n * @type {number}\n */\n textShadowOffsetX: 0,\n\n /**\n * @type {number}\n */\n textShadowOffsetY: 0,\n\n /**\n * @type {string}\n */\n textBoxShadowColor: 'transparent',\n\n /**\n * @type {number}\n */\n textBoxShadowBlur: 0,\n\n /**\n * @type {number}\n */\n textBoxShadowOffsetX: 0,\n\n /**\n * @type {number}\n */\n textBoxShadowOffsetY: 0,\n\n /**\n * Whether transform text.\n * Only useful in Path and Image element\n * @type {boolean}\n */\n transformText: false,\n\n /**\n * Text rotate around position of Path or Image\n * Only useful in Path and Image element and transformText is false.\n */\n textRotation: 0,\n\n /**\n * Text origin of text rotation, like [10, 40].\n * Based on x, y of rect.\n * Useful in label rotation of circular symbol.\n * By default, this origin is textPosition.\n * Can be 'center'.\n * @type {string|Array.<number>}\n */\n textOrigin: null,\n\n /**\n * @type {string}\n */\n textBackgroundColor: null,\n\n /**\n * @type {string}\n */\n textBorderColor: null,\n\n /**\n * @type {number}\n */\n textBorderWidth: 0,\n\n /**\n * @type {number}\n */\n textBorderRadius: 0,\n\n /**\n * Can be `2` or `[2, 4]` or `[2, 3, 4, 5]`\n * @type {number|Array.<number>}\n */\n textPadding: null,\n\n /**\n * Text styles for rich text.\n * @type {Object}\n */\n rich: null,\n\n /**\n * {outerWidth, outerHeight, ellipsis, placeholder}\n * @type {Object}\n */\n truncate: null,\n\n /**\n * https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/globalCompositeOperation\n * @type {string}\n */\n blend: null,\n\n /**\n * @param {CanvasRenderingContext2D} ctx\n */\n bind: function (ctx, el, prevEl) {\n var style = this;\n var prevStyle = prevEl && prevEl.style; // If no prevStyle, it means first draw.\n // Only apply cache if the last time cachced by this function.\n\n var notCheckCache = !prevStyle || ctx.__attrCachedBy !== ContextCachedBy.STYLE_BIND;\n ctx.__attrCachedBy = ContextCachedBy.STYLE_BIND;\n\n for (var i = 0; i < STYLE_COMMON_PROPS.length; i++) {\n var prop = STYLE_COMMON_PROPS[i];\n var styleName = prop[0];\n\n if (notCheckCache || style[styleName] !== prevStyle[styleName]) {\n // FIXME Invalid property value will cause style leak from previous element.\n ctx[styleName] = fixShadow(ctx, styleName, style[styleName] || prop[1]);\n }\n }\n\n if (notCheckCache || style.fill !== prevStyle.fill) {\n ctx.fillStyle = style.fill;\n }\n\n if (notCheckCache || style.stroke !== prevStyle.stroke) {\n ctx.strokeStyle = style.stroke;\n }\n\n if (notCheckCache || style.opacity !== prevStyle.opacity) {\n ctx.globalAlpha = style.opacity == null ? 1 : style.opacity;\n }\n\n if (notCheckCache || style.blend !== prevStyle.blend) {\n ctx.globalCompositeOperation = style.blend || 'source-over';\n }\n\n if (this.hasStroke()) {\n var lineWidth = style.lineWidth;\n ctx.lineWidth = lineWidth / (this.strokeNoScale && el && el.getLineScale ? el.getLineScale() : 1);\n }\n },\n hasFill: function () {\n var fill = this.fill;\n return fill != null && fill !== 'none';\n },\n hasStroke: function () {\n var stroke = this.stroke;\n return stroke != null && stroke !== 'none' && this.lineWidth > 0;\n },\n\n /**\n * Extend from other style\n * @param {zrender/graphic/Style} otherStyle\n * @param {boolean} overwrite true: overwrirte any way.\n * false: overwrite only when !target.hasOwnProperty\n * others: overwrite when property is not null/undefined.\n */\n extendFrom: function (otherStyle, overwrite) {\n if (otherStyle) {\n for (var name in otherStyle) {\n if (otherStyle.hasOwnProperty(name) && (overwrite === true || (overwrite === false ? !this.hasOwnProperty(name) : otherStyle[name] != null))) {\n this[name] = otherStyle[name];\n }\n }\n }\n },\n\n /**\n * Batch setting style with a given object\n * @param {Object|string} obj\n * @param {*} [obj]\n */\n set: function (obj, value) {\n if (typeof obj === 'string') {\n this[obj] = value;\n } else {\n this.extendFrom(obj, true);\n }\n },\n\n /**\n * Clone\n * @return {zrender/graphic/Style} [description]\n */\n clone: function () {\n var newStyle = new this.constructor();\n newStyle.extendFrom(this, true);\n return newStyle;\n },\n getGradient: function (ctx, obj, rect) {\n var method = obj.type === 'radial' ? createRadialGradient : createLinearGradient;\n var canvasGradient = method(ctx, obj, rect);\n var colorStops = obj.colorStops;\n\n for (var i = 0; i < colorStops.length; i++) {\n canvasGradient.addColorStop(colorStops[i].offset, colorStops[i].color);\n }\n\n return canvasGradient;\n }\n};\nvar styleProto = Style.prototype;\n\nfor (var i = 0; i < STYLE_COMMON_PROPS.length; i++) {\n var prop = STYLE_COMMON_PROPS[i];\n\n if (!(prop[0] in styleProto)) {\n styleProto[prop[0]] = prop[1];\n }\n} // Provide for others\n\n\nStyle.getGradient = styleProto.getGradient;\nvar _default = Style;\nmodule.exports = _default;","var dpr = 1; // If in browser environment\n\nif (typeof window !== 'undefined') {\n dpr = Math.max(window.devicePixelRatio || 1, 1);\n}\n/**\n * config默认配置项\n * @exports zrender/config\n * @author Kener (@Kener-林峰, kener.linfeng@gmail.com)\n */\n\n/**\n * debug日志选项:catchBrushException为true下有效\n * 0 : 不生成debug数据,发布用\n * 1 : 异常抛出,调试用\n * 2 : 控制台输出,调试用\n */\n\n\nvar debugMode = 0; // retina 屏幕优化\n\nvar devicePixelRatio = dpr;\nexports.debugMode = debugMode;\nexports.devicePixelRatio = devicePixelRatio;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar each = _util.each;\nvar createHashMap = _util.createHashMap;\nvar assert = _util.assert;\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar OTHER_DIMENSIONS = createHashMap(['tooltip', 'label', 'itemName', 'itemId', 'seriesName']);\n\nfunction summarizeDimensions(data) {\n var summary = {};\n var encode = summary.encode = {};\n var notExtraCoordDimMap = createHashMap();\n var defaultedLabel = [];\n var defaultedTooltip = [];\n each(data.dimensions, function (dimName) {\n var dimItem = data.getDimensionInfo(dimName);\n var coordDim = dimItem.coordDim;\n\n if (coordDim) {\n var coordDimArr = encode[coordDim];\n\n if (!encode.hasOwnProperty(coordDim)) {\n coordDimArr = encode[coordDim] = [];\n }\n\n coordDimArr[dimItem.coordDimIndex] = dimName;\n\n if (!dimItem.isExtraCoord) {\n notExtraCoordDimMap.set(coordDim, 1); // Use the last coord dim (and label friendly) as default label,\n // because when dataset is used, it is hard to guess which dimension\n // can be value dimension. If both show x, y on label is not look good,\n // and conventionally y axis is focused more.\n\n if (mayLabelDimType(dimItem.type)) {\n defaultedLabel[0] = dimName;\n }\n }\n\n if (dimItem.defaultTooltip) {\n defaultedTooltip.push(dimName);\n }\n }\n\n OTHER_DIMENSIONS.each(function (v, otherDim) {\n var otherDimArr = encode[otherDim];\n\n if (!encode.hasOwnProperty(otherDim)) {\n otherDimArr = encode[otherDim] = [];\n }\n\n var dimIndex = dimItem.otherDims[otherDim];\n\n if (dimIndex != null && dimIndex !== false) {\n otherDimArr[dimIndex] = dimItem.name;\n }\n });\n });\n var dataDimsOnCoord = [];\n var encodeFirstDimNotExtra = {};\n notExtraCoordDimMap.each(function (v, coordDim) {\n var dimArr = encode[coordDim]; // ??? FIXME extra coord should not be set in dataDimsOnCoord.\n // But should fix the case that radar axes: simplify the logic\n // of `completeDimension`, remove `extraPrefix`.\n\n encodeFirstDimNotExtra[coordDim] = dimArr[0]; // Not necessary to remove duplicate, because a data\n // dim canot on more than one coordDim.\n\n dataDimsOnCoord = dataDimsOnCoord.concat(dimArr);\n });\n summary.dataDimsOnCoord = dataDimsOnCoord;\n summary.encodeFirstDimNotExtra = encodeFirstDimNotExtra;\n var encodeLabel = encode.label; // FIXME `encode.label` is not recommanded, because formatter can not be set\n // in this way. Use label.formatter instead. May be remove this approach someday.\n\n if (encodeLabel && encodeLabel.length) {\n defaultedLabel = encodeLabel.slice();\n }\n\n var encodeTooltip = encode.tooltip;\n\n if (encodeTooltip && encodeTooltip.length) {\n defaultedTooltip = encodeTooltip.slice();\n } else if (!defaultedTooltip.length) {\n defaultedTooltip = defaultedLabel.slice();\n }\n\n encode.defaultedLabel = defaultedLabel;\n encode.defaultedTooltip = defaultedTooltip;\n return summary;\n}\n\nfunction getDimensionTypeByAxis(axisType) {\n return axisType === 'category' ? 'ordinal' : axisType === 'time' ? 'time' : 'float';\n}\n\nfunction mayLabelDimType(dimType) {\n // In most cases, ordinal and time do not suitable for label.\n // Ordinal info can be displayed on axis. Time is too long.\n return !(dimType === 'ordinal' || dimType === 'time');\n} // function findTheLastDimMayLabel(data) {\n// // Get last value dim\n// var dimensions = data.dimensions.slice();\n// var valueType;\n// var valueDim;\n// while (dimensions.length && (\n// valueDim = dimensions.pop(),\n// valueType = data.getDimensionInfo(valueDim).type,\n// valueType === 'ordinal' || valueType === 'time'\n// )) {} // jshint ignore:line\n// return valueDim;\n// }\n\n\nexports.OTHER_DIMENSIONS = OTHER_DIMENSIONS;\nexports.summarizeDimensions = summarizeDimensions;\nexports.getDimensionTypeByAxis = getDimensionTypeByAxis;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar echarts = require(\"../echarts\");\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar barPolar = require(\"../layout/barPolar\");\n\nrequire(\"../coord/polar/polarCreator\");\n\nrequire(\"./angleAxis\");\n\nrequire(\"./radiusAxis\");\n\nrequire(\"./axisPointer\");\n\nrequire(\"./axisPointer/PolarAxisPointer\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// For reducing size of echarts.min, barLayoutPolar is required by polar.\necharts.registerLayout(zrUtil.curry(barPolar, 'bar')); // Polar view\n\necharts.extendComponentView({\n type: 'polar'\n});","var Group = require(\"../container/Group\");\n\nvar ZImage = require(\"../graphic/Image\");\n\nvar Text = require(\"../graphic/Text\");\n\nvar Circle = require(\"../graphic/shape/Circle\");\n\nvar Rect = require(\"../graphic/shape/Rect\");\n\nvar Ellipse = require(\"../graphic/shape/Ellipse\");\n\nvar Line = require(\"../graphic/shape/Line\");\n\nvar Path = require(\"../graphic/Path\");\n\nvar Polygon = require(\"../graphic/shape/Polygon\");\n\nvar Polyline = require(\"../graphic/shape/Polyline\");\n\nvar LinearGradient = require(\"../graphic/LinearGradient\");\n\nvar Style = require(\"../graphic/Style\");\n\nvar matrix = require(\"../core/matrix\");\n\nvar _path = require(\"./path\");\n\nvar createFromString = _path.createFromString;\n\nvar _util = require(\"../core/util\");\n\nvar isString = _util.isString;\nvar extend = _util.extend;\nvar defaults = _util.defaults;\nvar trim = _util.trim;\nvar each = _util.each;\n// import RadialGradient from '../graphic/RadialGradient';\n// import Pattern from '../graphic/Pattern';\n// import * as vector from '../core/vector';\n// Most of the values can be separated by comma and/or white space.\nvar DILIMITER_REG = /[\\s,]+/;\n/**\n * For big svg string, this method might be time consuming.\n *\n * @param {string} svg xml string\n * @return {Object} xml root.\n */\n\nfunction parseXML(svg) {\n if (isString(svg)) {\n var parser = new DOMParser();\n svg = parser.parseFromString(svg, 'text/xml');\n } // Document node. If using $.get, doc node may be input.\n\n\n if (svg.nodeType === 9) {\n svg = svg.firstChild;\n } // nodeName of <!DOCTYPE svg> is also 'svg'.\n\n\n while (svg.nodeName.toLowerCase() !== 'svg' || svg.nodeType !== 1) {\n svg = svg.nextSibling;\n }\n\n return svg;\n}\n\nfunction SVGParser() {\n this._defs = {};\n this._root = null;\n this._isDefine = false;\n this._isText = false;\n}\n\nSVGParser.prototype.parse = function (xml, opt) {\n opt = opt || {};\n var svg = parseXML(xml);\n\n if (!svg) {\n throw new Error('Illegal svg');\n }\n\n var root = new Group();\n this._root = root; // parse view port\n\n var viewBox = svg.getAttribute('viewBox') || ''; // If width/height not specified, means \"100%\" of `opt.width/height`.\n // TODO: Other percent value not supported yet.\n\n var width = parseFloat(svg.getAttribute('width') || opt.width);\n var height = parseFloat(svg.getAttribute('height') || opt.height); // If width/height not specified, set as null for output.\n\n isNaN(width) && (width = null);\n isNaN(height) && (height = null); // Apply inline style on svg element.\n\n parseAttributes(svg, root, null, true);\n var child = svg.firstChild;\n\n while (child) {\n this._parseNode(child, root);\n\n child = child.nextSibling;\n }\n\n var viewBoxRect;\n var viewBoxTransform;\n\n if (viewBox) {\n var viewBoxArr = trim(viewBox).split(DILIMITER_REG); // Some invalid case like viewBox: 'none'.\n\n if (viewBoxArr.length >= 4) {\n viewBoxRect = {\n x: parseFloat(viewBoxArr[0] || 0),\n y: parseFloat(viewBoxArr[1] || 0),\n width: parseFloat(viewBoxArr[2]),\n height: parseFloat(viewBoxArr[3])\n };\n }\n }\n\n if (viewBoxRect && width != null && height != null) {\n viewBoxTransform = makeViewBoxTransform(viewBoxRect, width, height);\n\n if (!opt.ignoreViewBox) {\n // If set transform on the output group, it probably bring trouble when\n // some users only intend to show the clipped content inside the viewBox,\n // but not intend to transform the output group. So we keep the output\n // group no transform. If the user intend to use the viewBox as a\n // camera, just set `opt.ignoreViewBox` as `true` and set transfrom\n // manually according to the viewBox info in the output of this method.\n var elRoot = root;\n root = new Group();\n root.add(elRoot);\n elRoot.scale = viewBoxTransform.scale.slice();\n elRoot.position = viewBoxTransform.position.slice();\n }\n } // Some shapes might be overflow the viewport, which should be\n // clipped despite whether the viewBox is used, as the SVG does.\n\n\n if (!opt.ignoreRootClip && width != null && height != null) {\n root.setClipPath(new Rect({\n shape: {\n x: 0,\n y: 0,\n width: width,\n height: height\n }\n }));\n } // Set width/height on group just for output the viewport size.\n\n\n return {\n root: root,\n width: width,\n height: height,\n viewBoxRect: viewBoxRect,\n viewBoxTransform: viewBoxTransform\n };\n};\n\nSVGParser.prototype._parseNode = function (xmlNode, parentGroup) {\n var nodeName = xmlNode.nodeName.toLowerCase(); // TODO\n // support <style>...</style> in svg, where nodeName is 'style',\n // CSS classes is defined globally wherever the style tags are declared.\n\n if (nodeName === 'defs') {\n // define flag\n this._isDefine = true;\n } else if (nodeName === 'text') {\n this._isText = true;\n }\n\n var el;\n\n if (this._isDefine) {\n var parser = defineParsers[nodeName];\n\n if (parser) {\n var def = parser.call(this, xmlNode);\n var id = xmlNode.getAttribute('id');\n\n if (id) {\n this._defs[id] = def;\n }\n }\n } else {\n var parser = nodeParsers[nodeName];\n\n if (parser) {\n el = parser.call(this, xmlNode, parentGroup);\n parentGroup.add(el);\n }\n }\n\n var child = xmlNode.firstChild;\n\n while (child) {\n if (child.nodeType === 1) {\n this._parseNode(child, el);\n } // Is text\n\n\n if (child.nodeType === 3 && this._isText) {\n this._parseText(child, el);\n }\n\n child = child.nextSibling;\n } // Quit define\n\n\n if (nodeName === 'defs') {\n this._isDefine = false;\n } else if (nodeName === 'text') {\n this._isText = false;\n }\n};\n\nSVGParser.prototype._parseText = function (xmlNode, parentGroup) {\n if (xmlNode.nodeType === 1) {\n var dx = xmlNode.getAttribute('dx') || 0;\n var dy = xmlNode.getAttribute('dy') || 0;\n this._textX += parseFloat(dx);\n this._textY += parseFloat(dy);\n }\n\n var text = new Text({\n style: {\n text: xmlNode.textContent,\n transformText: true\n },\n position: [this._textX || 0, this._textY || 0]\n });\n inheritStyle(parentGroup, text);\n parseAttributes(xmlNode, text, this._defs);\n var fontSize = text.style.fontSize;\n\n if (fontSize && fontSize < 9) {\n // PENDING\n text.style.fontSize = 9;\n text.scale = text.scale || [1, 1];\n text.scale[0] *= fontSize / 9;\n text.scale[1] *= fontSize / 9;\n }\n\n var rect = text.getBoundingRect();\n this._textX += rect.width;\n parentGroup.add(text);\n return text;\n};\n\nvar nodeParsers = {\n 'g': function (xmlNode, parentGroup) {\n var g = new Group();\n inheritStyle(parentGroup, g);\n parseAttributes(xmlNode, g, this._defs);\n return g;\n },\n 'rect': function (xmlNode, parentGroup) {\n var rect = new Rect();\n inheritStyle(parentGroup, rect);\n parseAttributes(xmlNode, rect, this._defs);\n rect.setShape({\n x: parseFloat(xmlNode.getAttribute('x') || 0),\n y: parseFloat(xmlNode.getAttribute('y') || 0),\n width: parseFloat(xmlNode.getAttribute('width') || 0),\n height: parseFloat(xmlNode.getAttribute('height') || 0)\n }); // console.log(xmlNode.getAttribute('transform'));\n // console.log(rect.transform);\n\n return rect;\n },\n 'circle': function (xmlNode, parentGroup) {\n var circle = new Circle();\n inheritStyle(parentGroup, circle);\n parseAttributes(xmlNode, circle, this._defs);\n circle.setShape({\n cx: parseFloat(xmlNode.getAttribute('cx') || 0),\n cy: parseFloat(xmlNode.getAttribute('cy') || 0),\n r: parseFloat(xmlNode.getAttribute('r') || 0)\n });\n return circle;\n },\n 'line': function (xmlNode, parentGroup) {\n var line = new Line();\n inheritStyle(parentGroup, line);\n parseAttributes(xmlNode, line, this._defs);\n line.setShape({\n x1: parseFloat(xmlNode.getAttribute('x1') || 0),\n y1: parseFloat(xmlNode.getAttribute('y1') || 0),\n x2: parseFloat(xmlNode.getAttribute('x2') || 0),\n y2: parseFloat(xmlNode.getAttribute('y2') || 0)\n });\n return line;\n },\n 'ellipse': function (xmlNode, parentGroup) {\n var ellipse = new Ellipse();\n inheritStyle(parentGroup, ellipse);\n parseAttributes(xmlNode, ellipse, this._defs);\n ellipse.setShape({\n cx: parseFloat(xmlNode.getAttribute('cx') || 0),\n cy: parseFloat(xmlNode.getAttribute('cy') || 0),\n rx: parseFloat(xmlNode.getAttribute('rx') || 0),\n ry: parseFloat(xmlNode.getAttribute('ry') || 0)\n });\n return ellipse;\n },\n 'polygon': function (xmlNode, parentGroup) {\n var points = xmlNode.getAttribute('points');\n\n if (points) {\n points = parsePoints(points);\n }\n\n var polygon = new Polygon({\n shape: {\n points: points || []\n }\n });\n inheritStyle(parentGroup, polygon);\n parseAttributes(xmlNode, polygon, this._defs);\n return polygon;\n },\n 'polyline': function (xmlNode, parentGroup) {\n var path = new Path();\n inheritStyle(parentGroup, path);\n parseAttributes(xmlNode, path, this._defs);\n var points = xmlNode.getAttribute('points');\n\n if (points) {\n points = parsePoints(points);\n }\n\n var polyline = new Polyline({\n shape: {\n points: points || []\n }\n });\n return polyline;\n },\n 'image': function (xmlNode, parentGroup) {\n var img = new ZImage();\n inheritStyle(parentGroup, img);\n parseAttributes(xmlNode, img, this._defs);\n img.setStyle({\n image: xmlNode.getAttribute('xlink:href'),\n x: xmlNode.getAttribute('x'),\n y: xmlNode.getAttribute('y'),\n width: xmlNode.getAttribute('width'),\n height: xmlNode.getAttribute('height')\n });\n return img;\n },\n 'text': function (xmlNode, parentGroup) {\n var x = xmlNode.getAttribute('x') || 0;\n var y = xmlNode.getAttribute('y') || 0;\n var dx = xmlNode.getAttribute('dx') || 0;\n var dy = xmlNode.getAttribute('dy') || 0;\n this._textX = parseFloat(x) + parseFloat(dx);\n this._textY = parseFloat(y) + parseFloat(dy);\n var g = new Group();\n inheritStyle(parentGroup, g);\n parseAttributes(xmlNode, g, this._defs);\n return g;\n },\n 'tspan': function (xmlNode, parentGroup) {\n var x = xmlNode.getAttribute('x');\n var y = xmlNode.getAttribute('y');\n\n if (x != null) {\n // new offset x\n this._textX = parseFloat(x);\n }\n\n if (y != null) {\n // new offset y\n this._textY = parseFloat(y);\n }\n\n var dx = xmlNode.getAttribute('dx') || 0;\n var dy = xmlNode.getAttribute('dy') || 0;\n var g = new Group();\n inheritStyle(parentGroup, g);\n parseAttributes(xmlNode, g, this._defs);\n this._textX += dx;\n this._textY += dy;\n return g;\n },\n 'path': function (xmlNode, parentGroup) {\n // TODO svg fill rule\n // https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/fill-rule\n // path.style.globalCompositeOperation = 'xor';\n var d = xmlNode.getAttribute('d') || ''; // Performance sensitive.\n\n var path = createFromString(d);\n inheritStyle(parentGroup, path);\n parseAttributes(xmlNode, path, this._defs);\n return path;\n }\n};\nvar defineParsers = {\n 'lineargradient': function (xmlNode) {\n var x1 = parseInt(xmlNode.getAttribute('x1') || 0, 10);\n var y1 = parseInt(xmlNode.getAttribute('y1') || 0, 10);\n var x2 = parseInt(xmlNode.getAttribute('x2') || 10, 10);\n var y2 = parseInt(xmlNode.getAttribute('y2') || 0, 10);\n var gradient = new LinearGradient(x1, y1, x2, y2);\n\n _parseGradientColorStops(xmlNode, gradient);\n\n return gradient;\n },\n 'radialgradient': function (xmlNode) {}\n};\n\nfunction _parseGradientColorStops(xmlNode, gradient) {\n var stop = xmlNode.firstChild;\n\n while (stop) {\n if (stop.nodeType === 1) {\n var offset = stop.getAttribute('offset');\n\n if (offset.indexOf('%') > 0) {\n // percentage\n offset = parseInt(offset, 10) / 100;\n } else if (offset) {\n // number from 0 to 1\n offset = parseFloat(offset);\n } else {\n offset = 0;\n }\n\n var stopColor = stop.getAttribute('stop-color') || '#000000';\n gradient.addColorStop(offset, stopColor);\n }\n\n stop = stop.nextSibling;\n }\n}\n\nfunction inheritStyle(parent, child) {\n if (parent && parent.__inheritedStyle) {\n if (!child.__inheritedStyle) {\n child.__inheritedStyle = {};\n }\n\n defaults(child.__inheritedStyle, parent.__inheritedStyle);\n }\n}\n\nfunction parsePoints(pointsString) {\n var list = trim(pointsString).split(DILIMITER_REG);\n var points = [];\n\n for (var i = 0; i < list.length; i += 2) {\n var x = parseFloat(list[i]);\n var y = parseFloat(list[i + 1]);\n points.push([x, y]);\n }\n\n return points;\n}\n\nvar attributesMap = {\n 'fill': 'fill',\n 'stroke': 'stroke',\n 'stroke-width': 'lineWidth',\n 'opacity': 'opacity',\n 'fill-opacity': 'fillOpacity',\n 'stroke-opacity': 'strokeOpacity',\n 'stroke-dasharray': 'lineDash',\n 'stroke-dashoffset': 'lineDashOffset',\n 'stroke-linecap': 'lineCap',\n 'stroke-linejoin': 'lineJoin',\n 'stroke-miterlimit': 'miterLimit',\n 'font-family': 'fontFamily',\n 'font-size': 'fontSize',\n 'font-style': 'fontStyle',\n 'font-weight': 'fontWeight',\n 'text-align': 'textAlign',\n 'alignment-baseline': 'textBaseline'\n};\n\nfunction parseAttributes(xmlNode, el, defs, onlyInlineStyle) {\n var zrStyle = el.__inheritedStyle || {};\n var isTextEl = el.type === 'text'; // TODO Shadow\n\n if (xmlNode.nodeType === 1) {\n parseTransformAttribute(xmlNode, el);\n extend(zrStyle, parseStyleAttribute(xmlNode));\n\n if (!onlyInlineStyle) {\n for (var svgAttrName in attributesMap) {\n if (attributesMap.hasOwnProperty(svgAttrName)) {\n var attrValue = xmlNode.getAttribute(svgAttrName);\n\n if (attrValue != null) {\n zrStyle[attributesMap[svgAttrName]] = attrValue;\n }\n }\n }\n }\n }\n\n var elFillProp = isTextEl ? 'textFill' : 'fill';\n var elStrokeProp = isTextEl ? 'textStroke' : 'stroke';\n el.style = el.style || new Style();\n var elStyle = el.style;\n zrStyle.fill != null && elStyle.set(elFillProp, getPaint(zrStyle.fill, defs));\n zrStyle.stroke != null && elStyle.set(elStrokeProp, getPaint(zrStyle.stroke, defs));\n each(['lineWidth', 'opacity', 'fillOpacity', 'strokeOpacity', 'miterLimit', 'fontSize'], function (propName) {\n var elPropName = propName === 'lineWidth' && isTextEl ? 'textStrokeWidth' : propName;\n zrStyle[propName] != null && elStyle.set(elPropName, parseFloat(zrStyle[propName]));\n });\n\n if (!zrStyle.textBaseline || zrStyle.textBaseline === 'auto') {\n zrStyle.textBaseline = 'alphabetic';\n }\n\n if (zrStyle.textBaseline === 'alphabetic') {\n zrStyle.textBaseline = 'bottom';\n }\n\n if (zrStyle.textAlign === 'start') {\n zrStyle.textAlign = 'left';\n }\n\n if (zrStyle.textAlign === 'end') {\n zrStyle.textAlign = 'right';\n }\n\n each(['lineDashOffset', 'lineCap', 'lineJoin', 'fontWeight', 'fontFamily', 'fontStyle', 'textAlign', 'textBaseline'], function (propName) {\n zrStyle[propName] != null && elStyle.set(propName, zrStyle[propName]);\n });\n\n if (zrStyle.lineDash) {\n el.style.lineDash = trim(zrStyle.lineDash).split(DILIMITER_REG);\n }\n\n if (elStyle[elStrokeProp] && elStyle[elStrokeProp] !== 'none') {\n // enable stroke\n el[elStrokeProp] = true;\n }\n\n el.__inheritedStyle = zrStyle;\n}\n\nvar urlRegex = /url\\(\\s*#(.*?)\\)/;\n\nfunction getPaint(str, defs) {\n // if (str === 'none') {\n // return;\n // }\n var urlMatch = defs && str && str.match(urlRegex);\n\n if (urlMatch) {\n var url = trim(urlMatch[1]);\n var def = defs[url];\n return def;\n }\n\n return str;\n}\n\nvar transformRegex = /(translate|scale|rotate|skewX|skewY|matrix)\\(([\\-\\s0-9\\.e,]*)\\)/g;\n\nfunction parseTransformAttribute(xmlNode, node) {\n var transform = xmlNode.getAttribute('transform');\n\n if (transform) {\n transform = transform.replace(/,/g, ' ');\n var m = null;\n var transformOps = [];\n transform.replace(transformRegex, function (str, type, value) {\n transformOps.push(type, value);\n });\n\n for (var i = transformOps.length - 1; i > 0; i -= 2) {\n var value = transformOps[i];\n var type = transformOps[i - 1];\n m = m || matrix.create();\n\n switch (type) {\n case 'translate':\n value = trim(value).split(DILIMITER_REG);\n matrix.translate(m, m, [parseFloat(value[0]), parseFloat(value[1] || 0)]);\n break;\n\n case 'scale':\n value = trim(value).split(DILIMITER_REG);\n matrix.scale(m, m, [parseFloat(value[0]), parseFloat(value[1] || value[0])]);\n break;\n\n case 'rotate':\n value = trim(value).split(DILIMITER_REG);\n matrix.rotate(m, m, parseFloat(value[0]));\n break;\n\n case 'skew':\n value = trim(value).split(DILIMITER_REG);\n console.warn('Skew transform is not supported yet');\n break;\n\n case 'matrix':\n var value = trim(value).split(DILIMITER_REG);\n m[0] = parseFloat(value[0]);\n m[1] = parseFloat(value[1]);\n m[2] = parseFloat(value[2]);\n m[3] = parseFloat(value[3]);\n m[4] = parseFloat(value[4]);\n m[5] = parseFloat(value[5]);\n break;\n }\n }\n\n node.setLocalTransform(m);\n }\n} // Value may contain space.\n\n\nvar styleRegex = /([^\\s:;]+)\\s*:\\s*([^:;]+)/g;\n\nfunction parseStyleAttribute(xmlNode) {\n var style = xmlNode.getAttribute('style');\n var result = {};\n\n if (!style) {\n return result;\n }\n\n var styleList = {};\n styleRegex.lastIndex = 0;\n var styleRegResult;\n\n while ((styleRegResult = styleRegex.exec(style)) != null) {\n styleList[styleRegResult[1]] = styleRegResult[2];\n }\n\n for (var svgAttrName in attributesMap) {\n if (attributesMap.hasOwnProperty(svgAttrName) && styleList[svgAttrName] != null) {\n result[attributesMap[svgAttrName]] = styleList[svgAttrName];\n }\n }\n\n return result;\n}\n/**\n * @param {Array.<number>} viewBoxRect\n * @param {number} width\n * @param {number} height\n * @return {Object} {scale, position}\n */\n\n\nfunction makeViewBoxTransform(viewBoxRect, width, height) {\n var scaleX = width / viewBoxRect.width;\n var scaleY = height / viewBoxRect.height;\n var scale = Math.min(scaleX, scaleY); // preserveAspectRatio 'xMidYMid'\n\n var viewBoxScale = [scale, scale];\n var viewBoxPosition = [-(viewBoxRect.x + viewBoxRect.width / 2) * scale + width / 2, -(viewBoxRect.y + viewBoxRect.height / 2) * scale + height / 2];\n return {\n scale: viewBoxScale,\n position: viewBoxPosition\n };\n}\n/**\n * @param {string|XMLElement} xml\n * @param {Object} [opt]\n * @param {number} [opt.width] Default width if svg width not specified or is a percent value.\n * @param {number} [opt.height] Default height if svg height not specified or is a percent value.\n * @param {boolean} [opt.ignoreViewBox]\n * @param {boolean} [opt.ignoreRootClip]\n * @return {Object} result:\n * {\n * root: Group, The root of the the result tree of zrender shapes,\n * width: number, the viewport width of the SVG,\n * height: number, the viewport height of the SVG,\n * viewBoxRect: {x, y, width, height}, the declared viewBox rect of the SVG, if exists,\n * viewBoxTransform: the {scale, position} calculated by viewBox and viewport, is exists.\n * }\n */\n\n\nfunction parseSVG(xml, opt) {\n var parser = new SVGParser();\n return parser.parse(xml, opt);\n}\n\nexports.parseXML = parseXML;\nexports.makeViewBoxTransform = makeViewBoxTransform;\nexports.parseSVG = parseSVG;","var util = require(\"../core/util\");\n\nvar _event = require(\"../core/event\");\n\nvar Dispatcher = _event.Dispatcher;\n\nvar requestAnimationFrame = require(\"./requestAnimationFrame\");\n\nvar Animator = require(\"./Animator\");\n\n/**\n * 动画主类, 调度和管理所有动画控制器\n *\n * @module zrender/animation/Animation\n * @author pissang(https://github.com/pissang)\n */\n// TODO Additive animation\n// http://iosoteric.com/additive-animations-animatewithduration-in-ios-8/\n// https://developer.apple.com/videos/wwdc2014/#236\n\n/**\n * @typedef {Object} IZRenderStage\n * @property {Function} update\n */\n\n/**\n * @alias module:zrender/animation/Animation\n * @constructor\n * @param {Object} [options]\n * @param {Function} [options.onframe]\n * @param {IZRenderStage} [options.stage]\n * @example\n * var animation = new Animation();\n * var obj = {\n * x: 100,\n * y: 100\n * };\n * animation.animate(node.position)\n * .when(1000, {\n * x: 500,\n * y: 500\n * })\n * .when(2000, {\n * x: 100,\n * y: 100\n * })\n * .start('spline');\n */\nvar Animation = function (options) {\n options = options || {};\n this.stage = options.stage || {};\n\n this.onframe = options.onframe || function () {}; // private properties\n\n\n this._clips = [];\n this._running = false;\n this._time;\n this._pausedTime;\n this._pauseStart;\n this._paused = false;\n Dispatcher.call(this);\n};\n\nAnimation.prototype = {\n constructor: Animation,\n\n /**\n * 添加 clip\n * @param {module:zrender/animation/Clip} clip\n */\n addClip: function (clip) {\n this._clips.push(clip);\n },\n\n /**\n * 添加 animator\n * @param {module:zrender/animation/Animator} animator\n */\n addAnimator: function (animator) {\n animator.animation = this;\n var clips = animator.getClips();\n\n for (var i = 0; i < clips.length; i++) {\n this.addClip(clips[i]);\n }\n },\n\n /**\n * 删除动画片段\n * @param {module:zrender/animation/Clip} clip\n */\n removeClip: function (clip) {\n var idx = util.indexOf(this._clips, clip);\n\n if (idx >= 0) {\n this._clips.splice(idx, 1);\n }\n },\n\n /**\n * 删除动画片段\n * @param {module:zrender/animation/Animator} animator\n */\n removeAnimator: function (animator) {\n var clips = animator.getClips();\n\n for (var i = 0; i < clips.length; i++) {\n this.removeClip(clips[i]);\n }\n\n animator.animation = null;\n },\n _update: function () {\n var time = new Date().getTime() - this._pausedTime;\n\n var delta = time - this._time;\n var clips = this._clips;\n var len = clips.length;\n var deferredEvents = [];\n var deferredClips = [];\n\n for (var i = 0; i < len; i++) {\n var clip = clips[i];\n var e = clip.step(time, delta); // Throw out the events need to be called after\n // stage.update, like destroy\n\n if (e) {\n deferredEvents.push(e);\n deferredClips.push(clip);\n }\n } // Remove the finished clip\n\n\n for (var i = 0; i < len;) {\n if (clips[i]._needsRemove) {\n clips[i] = clips[len - 1];\n clips.pop();\n len--;\n } else {\n i++;\n }\n }\n\n len = deferredEvents.length;\n\n for (var i = 0; i < len; i++) {\n deferredClips[i].fire(deferredEvents[i]);\n }\n\n this._time = time;\n this.onframe(delta); // 'frame' should be triggered before stage, because upper application\n // depends on the sequence (e.g., echarts-stream and finish\n // event judge)\n\n this.trigger('frame', delta);\n\n if (this.stage.update) {\n this.stage.update();\n }\n },\n _startLoop: function () {\n var self = this;\n this._running = true;\n\n function step() {\n if (self._running) {\n requestAnimationFrame(step);\n !self._paused && self._update();\n }\n }\n\n requestAnimationFrame(step);\n },\n\n /**\n * Start animation.\n */\n start: function () {\n this._time = new Date().getTime();\n this._pausedTime = 0;\n\n this._startLoop();\n },\n\n /**\n * Stop animation.\n */\n stop: function () {\n this._running = false;\n },\n\n /**\n * Pause animation.\n */\n pause: function () {\n if (!this._paused) {\n this._pauseStart = new Date().getTime();\n this._paused = true;\n }\n },\n\n /**\n * Resume animation.\n */\n resume: function () {\n if (this._paused) {\n this._pausedTime += new Date().getTime() - this._pauseStart;\n this._paused = false;\n }\n },\n\n /**\n * Clear animation.\n */\n clear: function () {\n this._clips = [];\n },\n\n /**\n * Whether animation finished.\n */\n isFinished: function () {\n return !this._clips.length;\n },\n\n /**\n * Creat animator for a target, whose props can be animated.\n *\n * @param {Object} target\n * @param {Object} options\n * @param {boolean} [options.loop=false] Whether loop animation.\n * @param {Function} [options.getter=null] Get value from target.\n * @param {Function} [options.setter=null] Set value to target.\n * @return {module:zrender/animation/Animation~Animator}\n */\n // TODO Gap\n animate: function (target, options) {\n options = options || {};\n var animator = new Animator(target, options.loop, options.getter, options.setter);\n this.addAnimator(animator);\n return animator;\n }\n};\nutil.mixin(Animation, Dispatcher);\nvar _default = Animation;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar List = require(\"../../data/List\");\n\nvar createDimensions = require(\"../../data/helper/createDimensions\");\n\nvar _sourceType = require(\"../../data/helper/sourceType\");\n\nvar SOURCE_FORMAT_ORIGINAL = _sourceType.SOURCE_FORMAT_ORIGINAL;\n\nvar _dimensionHelper = require(\"../../data/helper/dimensionHelper\");\n\nvar getDimensionTypeByAxis = _dimensionHelper.getDimensionTypeByAxis;\n\nvar _model = require(\"../../util/model\");\n\nvar getDataItemValue = _model.getDataItemValue;\n\nvar CoordinateSystem = require(\"../../CoordinateSystem\");\n\nvar _referHelper = require(\"../../model/referHelper\");\n\nvar getCoordSysDefineBySeries = _referHelper.getCoordSysDefineBySeries;\n\nvar Source = require(\"../../data/Source\");\n\nvar _dataStackHelper = require(\"../../data/helper/dataStackHelper\");\n\nvar enableDataStack = _dataStackHelper.enableDataStack;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @param {module:echarts/data/Source|Array} source Or raw data.\n * @param {module:echarts/model/Series} seriesModel\n * @param {Object} [opt]\n * @param {string} [opt.generateCoord]\n */\nfunction createListFromArray(source, seriesModel, opt) {\n opt = opt || {};\n\n if (!Source.isInstance(source)) {\n source = Source.seriesDataToSource(source);\n }\n\n var coordSysName = seriesModel.get('coordinateSystem');\n var registeredCoordSys = CoordinateSystem.get(coordSysName);\n var coordSysDefine = getCoordSysDefineBySeries(seriesModel);\n var coordSysDimDefs;\n\n if (coordSysDefine) {\n coordSysDimDefs = zrUtil.map(coordSysDefine.coordSysDims, function (dim) {\n var dimInfo = {\n name: dim\n };\n var axisModel = coordSysDefine.axisMap.get(dim);\n\n if (axisModel) {\n var axisType = axisModel.get('type');\n dimInfo.type = getDimensionTypeByAxis(axisType); // dimInfo.stackable = isStackable(axisType);\n }\n\n return dimInfo;\n });\n }\n\n if (!coordSysDimDefs) {\n // Get dimensions from registered coordinate system\n coordSysDimDefs = registeredCoordSys && (registeredCoordSys.getDimensionsInfo ? registeredCoordSys.getDimensionsInfo() : registeredCoordSys.dimensions.slice()) || ['x', 'y'];\n }\n\n var dimInfoList = createDimensions(source, {\n coordDimensions: coordSysDimDefs,\n generateCoord: opt.generateCoord\n });\n var firstCategoryDimIndex;\n var hasNameEncode;\n coordSysDefine && zrUtil.each(dimInfoList, function (dimInfo, dimIndex) {\n var coordDim = dimInfo.coordDim;\n var categoryAxisModel = coordSysDefine.categoryAxisMap.get(coordDim);\n\n if (categoryAxisModel) {\n if (firstCategoryDimIndex == null) {\n firstCategoryDimIndex = dimIndex;\n }\n\n dimInfo.ordinalMeta = categoryAxisModel.getOrdinalMeta();\n }\n\n if (dimInfo.otherDims.itemName != null) {\n hasNameEncode = true;\n }\n });\n\n if (!hasNameEncode && firstCategoryDimIndex != null) {\n dimInfoList[firstCategoryDimIndex].otherDims.itemName = 0;\n }\n\n var stackCalculationInfo = enableDataStack(seriesModel, dimInfoList);\n var list = new List(dimInfoList, seriesModel);\n list.setCalculationInfo(stackCalculationInfo);\n var dimValueGetter = firstCategoryDimIndex != null && isNeedCompleteOrdinalData(source) ? function (itemOpt, dimName, dataIndex, dimIndex) {\n // Use dataIndex as ordinal value in categoryAxis\n return dimIndex === firstCategoryDimIndex ? dataIndex : this.defaultDimValueGetter(itemOpt, dimName, dataIndex, dimIndex);\n } : null;\n list.hasItemOption = false;\n list.initData(source, null, dimValueGetter);\n return list;\n}\n\nfunction isNeedCompleteOrdinalData(source) {\n if (source.sourceFormat === SOURCE_FORMAT_ORIGINAL) {\n var sampleItem = firstDataNotNull(source.data || []);\n return sampleItem != null && !zrUtil.isArray(getDataItemValue(sampleItem));\n }\n}\n\nfunction firstDataNotNull(data) {\n var i = 0;\n\n while (i < data.length && data[i] == null) {\n i++;\n }\n\n return data[i];\n}\n\nvar _default = createListFromArray;\nmodule.exports = _default;","var Path = require(\"../graphic/Path\");\n\nvar PathProxy = require(\"../core/PathProxy\");\n\nvar transformPath = require(\"./transformPath\");\n\n// command chars\n// var cc = [\n// 'm', 'M', 'l', 'L', 'v', 'V', 'h', 'H', 'z', 'Z',\n// 'c', 'C', 'q', 'Q', 't', 'T', 's', 'S', 'a', 'A'\n// ];\nvar mathSqrt = Math.sqrt;\nvar mathSin = Math.sin;\nvar mathCos = Math.cos;\nvar PI = Math.PI;\n\nvar vMag = function (v) {\n return Math.sqrt(v[0] * v[0] + v[1] * v[1]);\n};\n\nvar vRatio = function (u, v) {\n return (u[0] * v[0] + u[1] * v[1]) / (vMag(u) * vMag(v));\n};\n\nvar vAngle = function (u, v) {\n return (u[0] * v[1] < u[1] * v[0] ? -1 : 1) * Math.acos(vRatio(u, v));\n};\n\nfunction processArc(x1, y1, x2, y2, fa, fs, rx, ry, psiDeg, cmd, path) {\n var psi = psiDeg * (PI / 180.0);\n var xp = mathCos(psi) * (x1 - x2) / 2.0 + mathSin(psi) * (y1 - y2) / 2.0;\n var yp = -1 * mathSin(psi) * (x1 - x2) / 2.0 + mathCos(psi) * (y1 - y2) / 2.0;\n var lambda = xp * xp / (rx * rx) + yp * yp / (ry * ry);\n\n if (lambda > 1) {\n rx *= mathSqrt(lambda);\n ry *= mathSqrt(lambda);\n }\n\n var f = (fa === fs ? -1 : 1) * mathSqrt((rx * rx * (ry * ry) - rx * rx * (yp * yp) - ry * ry * (xp * xp)) / (rx * rx * (yp * yp) + ry * ry * (xp * xp))) || 0;\n var cxp = f * rx * yp / ry;\n var cyp = f * -ry * xp / rx;\n var cx = (x1 + x2) / 2.0 + mathCos(psi) * cxp - mathSin(psi) * cyp;\n var cy = (y1 + y2) / 2.0 + mathSin(psi) * cxp + mathCos(psi) * cyp;\n var theta = vAngle([1, 0], [(xp - cxp) / rx, (yp - cyp) / ry]);\n var u = [(xp - cxp) / rx, (yp - cyp) / ry];\n var v = [(-1 * xp - cxp) / rx, (-1 * yp - cyp) / ry];\n var dTheta = vAngle(u, v);\n\n if (vRatio(u, v) <= -1) {\n dTheta = PI;\n }\n\n if (vRatio(u, v) >= 1) {\n dTheta = 0;\n }\n\n if (fs === 0 && dTheta > 0) {\n dTheta = dTheta - 2 * PI;\n }\n\n if (fs === 1 && dTheta < 0) {\n dTheta = dTheta + 2 * PI;\n }\n\n path.addData(cmd, cx, cy, rx, ry, theta, dTheta, psi, fs);\n}\n\nvar commandReg = /([mlvhzcqtsa])([^mlvhzcqtsa]*)/ig; // Consider case:\n// (1) delimiter can be comma or space, where continuous commas\n// or spaces should be seen as one comma.\n// (2) value can be like:\n// '2e-4', 'l.5.9' (ignore 0), 'M-10-10', 'l-2.43e-1,34.9983',\n// 'l-.5E1,54', '121-23-44-11' (no delimiter)\n\nvar numberReg = /-?([0-9]*\\.)?[0-9]+([eE]-?[0-9]+)?/g; // var valueSplitReg = /[\\s,]+/;\n\nfunction createPathProxyFromString(data) {\n if (!data) {\n return new PathProxy();\n } // var data = data.replace(/-/g, ' -')\n // .replace(/ /g, ' ')\n // .replace(/ /g, ',')\n // .replace(/,,/g, ',');\n // var n;\n // create pipes so that we can split the data\n // for (n = 0; n < cc.length; n++) {\n // cs = cs.replace(new RegExp(cc[n], 'g'), '|' + cc[n]);\n // }\n // data = data.replace(/-/g, ',-');\n // create array\n // var arr = cs.split('|');\n // init context point\n\n\n var cpx = 0;\n var cpy = 0;\n var subpathX = cpx;\n var subpathY = cpy;\n var prevCmd;\n var path = new PathProxy();\n var CMD = PathProxy.CMD; // commandReg.lastIndex = 0;\n // var cmdResult;\n // while ((cmdResult = commandReg.exec(data)) != null) {\n // var cmdStr = cmdResult[1];\n // var cmdContent = cmdResult[2];\n\n var cmdList = data.match(commandReg);\n\n for (var l = 0; l < cmdList.length; l++) {\n var cmdText = cmdList[l];\n var cmdStr = cmdText.charAt(0);\n var cmd; // String#split is faster a little bit than String#replace or RegExp#exec.\n // var p = cmdContent.split(valueSplitReg);\n // var pLen = 0;\n // for (var i = 0; i < p.length; i++) {\n // // '' and other invalid str => NaN\n // var val = parseFloat(p[i]);\n // !isNaN(val) && (p[pLen++] = val);\n // }\n\n var p = cmdText.match(numberReg) || [];\n var pLen = p.length;\n\n for (var i = 0; i < pLen; i++) {\n p[i] = parseFloat(p[i]);\n }\n\n var off = 0;\n\n while (off < pLen) {\n var ctlPtx;\n var ctlPty;\n var rx;\n var ry;\n var psi;\n var fa;\n var fs;\n var x1 = cpx;\n var y1 = cpy; // convert l, H, h, V, and v to L\n\n switch (cmdStr) {\n case 'l':\n cpx += p[off++];\n cpy += p[off++];\n cmd = CMD.L;\n path.addData(cmd, cpx, cpy);\n break;\n\n case 'L':\n cpx = p[off++];\n cpy = p[off++];\n cmd = CMD.L;\n path.addData(cmd, cpx, cpy);\n break;\n\n case 'm':\n cpx += p[off++];\n cpy += p[off++];\n cmd = CMD.M;\n path.addData(cmd, cpx, cpy);\n subpathX = cpx;\n subpathY = cpy;\n cmdStr = 'l';\n break;\n\n case 'M':\n cpx = p[off++];\n cpy = p[off++];\n cmd = CMD.M;\n path.addData(cmd, cpx, cpy);\n subpathX = cpx;\n subpathY = cpy;\n cmdStr = 'L';\n break;\n\n case 'h':\n cpx += p[off++];\n cmd = CMD.L;\n path.addData(cmd, cpx, cpy);\n break;\n\n case 'H':\n cpx = p[off++];\n cmd = CMD.L;\n path.addData(cmd, cpx, cpy);\n break;\n\n case 'v':\n cpy += p[off++];\n cmd = CMD.L;\n path.addData(cmd, cpx, cpy);\n break;\n\n case 'V':\n cpy = p[off++];\n cmd = CMD.L;\n path.addData(cmd, cpx, cpy);\n break;\n\n case 'C':\n cmd = CMD.C;\n path.addData(cmd, p[off++], p[off++], p[off++], p[off++], p[off++], p[off++]);\n cpx = p[off - 2];\n cpy = p[off - 1];\n break;\n\n case 'c':\n cmd = CMD.C;\n path.addData(cmd, p[off++] + cpx, p[off++] + cpy, p[off++] + cpx, p[off++] + cpy, p[off++] + cpx, p[off++] + cpy);\n cpx += p[off - 2];\n cpy += p[off - 1];\n break;\n\n case 'S':\n ctlPtx = cpx;\n ctlPty = cpy;\n var len = path.len();\n var pathData = path.data;\n\n if (prevCmd === CMD.C) {\n ctlPtx += cpx - pathData[len - 4];\n ctlPty += cpy - pathData[len - 3];\n }\n\n cmd = CMD.C;\n x1 = p[off++];\n y1 = p[off++];\n cpx = p[off++];\n cpy = p[off++];\n path.addData(cmd, ctlPtx, ctlPty, x1, y1, cpx, cpy);\n break;\n\n case 's':\n ctlPtx = cpx;\n ctlPty = cpy;\n var len = path.len();\n var pathData = path.data;\n\n if (prevCmd === CMD.C) {\n ctlPtx += cpx - pathData[len - 4];\n ctlPty += cpy - pathData[len - 3];\n }\n\n cmd = CMD.C;\n x1 = cpx + p[off++];\n y1 = cpy + p[off++];\n cpx += p[off++];\n cpy += p[off++];\n path.addData(cmd, ctlPtx, ctlPty, x1, y1, cpx, cpy);\n break;\n\n case 'Q':\n x1 = p[off++];\n y1 = p[off++];\n cpx = p[off++];\n cpy = p[off++];\n cmd = CMD.Q;\n path.addData(cmd, x1, y1, cpx, cpy);\n break;\n\n case 'q':\n x1 = p[off++] + cpx;\n y1 = p[off++] + cpy;\n cpx += p[off++];\n cpy += p[off++];\n cmd = CMD.Q;\n path.addData(cmd, x1, y1, cpx, cpy);\n break;\n\n case 'T':\n ctlPtx = cpx;\n ctlPty = cpy;\n var len = path.len();\n var pathData = path.data;\n\n if (prevCmd === CMD.Q) {\n ctlPtx += cpx - pathData[len - 4];\n ctlPty += cpy - pathData[len - 3];\n }\n\n cpx = p[off++];\n cpy = p[off++];\n cmd = CMD.Q;\n path.addData(cmd, ctlPtx, ctlPty, cpx, cpy);\n break;\n\n case 't':\n ctlPtx = cpx;\n ctlPty = cpy;\n var len = path.len();\n var pathData = path.data;\n\n if (prevCmd === CMD.Q) {\n ctlPtx += cpx - pathData[len - 4];\n ctlPty += cpy - pathData[len - 3];\n }\n\n cpx += p[off++];\n cpy += p[off++];\n cmd = CMD.Q;\n path.addData(cmd, ctlPtx, ctlPty, cpx, cpy);\n break;\n\n case 'A':\n rx = p[off++];\n ry = p[off++];\n psi = p[off++];\n fa = p[off++];\n fs = p[off++];\n x1 = cpx, y1 = cpy;\n cpx = p[off++];\n cpy = p[off++];\n cmd = CMD.A;\n processArc(x1, y1, cpx, cpy, fa, fs, rx, ry, psi, cmd, path);\n break;\n\n case 'a':\n rx = p[off++];\n ry = p[off++];\n psi = p[off++];\n fa = p[off++];\n fs = p[off++];\n x1 = cpx, y1 = cpy;\n cpx += p[off++];\n cpy += p[off++];\n cmd = CMD.A;\n processArc(x1, y1, cpx, cpy, fa, fs, rx, ry, psi, cmd, path);\n break;\n }\n }\n\n if (cmdStr === 'z' || cmdStr === 'Z') {\n cmd = CMD.Z;\n path.addData(cmd); // z may be in the middle of the path.\n\n cpx = subpathX;\n cpy = subpathY;\n }\n\n prevCmd = cmd;\n }\n\n path.toStatic();\n return path;\n} // TODO Optimize double memory cost problem\n\n\nfunction createPathOptions(str, opts) {\n var pathProxy = createPathProxyFromString(str);\n opts = opts || {};\n\n opts.buildPath = function (path) {\n if (path.setData) {\n path.setData(pathProxy.data); // Svg and vml renderer don't have context\n\n var ctx = path.getContext();\n\n if (ctx) {\n path.rebuildPath(ctx);\n }\n } else {\n var ctx = path;\n pathProxy.rebuildPath(ctx);\n }\n };\n\n opts.applyTransform = function (m) {\n transformPath(pathProxy, m);\n this.dirty(true);\n };\n\n return opts;\n}\n/**\n * Create a Path object from path string data\n * http://www.w3.org/TR/SVG/paths.html#PathData\n * @param {Object} opts Other options\n */\n\n\nfunction createFromString(str, opts) {\n return new Path(createPathOptions(str, opts));\n}\n/**\n * Create a Path class from path string data\n * @param {string} str\n * @param {Object} opts Other options\n */\n\n\nfunction extendFromString(str, opts) {\n return Path.extend(createPathOptions(str, opts));\n}\n/**\n * Merge multiple paths\n */\n// TODO Apply transform\n// TODO stroke dash\n// TODO Optimize double memory cost problem\n\n\nfunction mergePath(pathEls, opts) {\n var pathList = [];\n var len = pathEls.length;\n\n for (var i = 0; i < len; i++) {\n var pathEl = pathEls[i];\n\n if (!pathEl.path) {\n pathEl.createPathProxy();\n }\n\n if (pathEl.__dirtyPath) {\n pathEl.buildPath(pathEl.path, pathEl.shape, true);\n }\n\n pathList.push(pathEl.path);\n }\n\n var pathBundle = new Path(opts); // Need path proxy.\n\n pathBundle.createPathProxy();\n\n pathBundle.buildPath = function (path) {\n path.appendPath(pathList); // Svg and vml renderer don't have context\n\n var ctx = path.getContext();\n\n if (ctx) {\n path.rebuildPath(ctx);\n }\n };\n\n return pathBundle;\n}\n\nexports.createFromString = createFromString;\nexports.extendFromString = extendFromString;\nexports.mergePath = mergePath;","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* A third-party license is embeded for some of the code in this file:\n* The method \"quantile\" was copied from \"d3.js\".\n* (See more details in the comment of the method below.)\n* The use of the source code of this file is also subject to the terms\n* and consitions of the license of \"d3.js\" (BSD-3Clause, see\n* </licenses/LICENSE-d3>).\n*/\nvar RADIAN_EPSILON = 1e-4;\n\nfunction _trim(str) {\n return str.replace(/^\\s+/, '').replace(/\\s+$/, '');\n}\n/**\n * Linear mapping a value from domain to range\n * @memberOf module:echarts/util/number\n * @param {(number|Array.<number>)} val\n * @param {Array.<number>} domain Domain extent domain[0] can be bigger than domain[1]\n * @param {Array.<number>} range Range extent range[0] can be bigger than range[1]\n * @param {boolean} clamp\n * @return {(number|Array.<number>}\n */\n\n\nfunction linearMap(val, domain, range, clamp) {\n var subDomain = domain[1] - domain[0];\n var subRange = range[1] - range[0];\n\n if (subDomain === 0) {\n return subRange === 0 ? range[0] : (range[0] + range[1]) / 2;\n } // Avoid accuracy problem in edge, such as\n // 146.39 - 62.83 === 83.55999999999999.\n // See echarts/test/ut/spec/util/number.js#linearMap#accuracyError\n // It is a little verbose for efficiency considering this method\n // is a hotspot.\n\n\n if (clamp) {\n if (subDomain > 0) {\n if (val <= domain[0]) {\n return range[0];\n } else if (val >= domain[1]) {\n return range[1];\n }\n } else {\n if (val >= domain[0]) {\n return range[0];\n } else if (val <= domain[1]) {\n return range[1];\n }\n }\n } else {\n if (val === domain[0]) {\n return range[0];\n }\n\n if (val === domain[1]) {\n return range[1];\n }\n }\n\n return (val - domain[0]) / subDomain * subRange + range[0];\n}\n/**\n * Convert a percent string to absolute number.\n * Returns NaN if percent is not a valid string or number\n * @memberOf module:echarts/util/number\n * @param {string|number} percent\n * @param {number} all\n * @return {number}\n */\n\n\nfunction parsePercent(percent, all) {\n switch (percent) {\n case 'center':\n case 'middle':\n percent = '50%';\n break;\n\n case 'left':\n case 'top':\n percent = '0%';\n break;\n\n case 'right':\n case 'bottom':\n percent = '100%';\n break;\n }\n\n if (typeof percent === 'string') {\n if (_trim(percent).match(/%$/)) {\n return parseFloat(percent) / 100 * all;\n }\n\n return parseFloat(percent);\n }\n\n return percent == null ? NaN : +percent;\n}\n/**\n * (1) Fix rounding error of float numbers.\n * (2) Support return string to avoid scientific notation like '3.5e-7'.\n *\n * @param {number} x\n * @param {number} [precision]\n * @param {boolean} [returnStr]\n * @return {number|string}\n */\n\n\nfunction round(x, precision, returnStr) {\n if (precision == null) {\n precision = 10;\n } // Avoid range error\n\n\n precision = Math.min(Math.max(0, precision), 20);\n x = (+x).toFixed(precision);\n return returnStr ? x : +x;\n}\n\nfunction asc(arr) {\n arr.sort(function (a, b) {\n return a - b;\n });\n return arr;\n}\n/**\n * Get precision\n * @param {number} val\n */\n\n\nfunction getPrecision(val) {\n val = +val;\n\n if (isNaN(val)) {\n return 0;\n } // It is much faster than methods converting number to string as follows\n // var tmp = val.toString();\n // return tmp.length - 1 - tmp.indexOf('.');\n // especially when precision is low\n\n\n var e = 1;\n var count = 0;\n\n while (Math.round(val * e) / e !== val) {\n e *= 10;\n count++;\n }\n\n return count;\n}\n/**\n * @param {string|number} val\n * @return {number}\n */\n\n\nfunction getPrecisionSafe(val) {\n var str = val.toString(); // Consider scientific notation: '3.4e-12' '3.4e+12'\n\n var eIndex = str.indexOf('e');\n\n if (eIndex > 0) {\n var precision = +str.slice(eIndex + 1);\n return precision < 0 ? -precision : 0;\n } else {\n var dotIndex = str.indexOf('.');\n return dotIndex < 0 ? 0 : str.length - 1 - dotIndex;\n }\n}\n/**\n * Minimal dicernible data precisioin according to a single pixel.\n *\n * @param {Array.<number>} dataExtent\n * @param {Array.<number>} pixelExtent\n * @return {number} precision\n */\n\n\nfunction getPixelPrecision(dataExtent, pixelExtent) {\n var log = Math.log;\n var LN10 = Math.LN10;\n var dataQuantity = Math.floor(log(dataExtent[1] - dataExtent[0]) / LN10);\n var sizeQuantity = Math.round(log(Math.abs(pixelExtent[1] - pixelExtent[0])) / LN10); // toFixed() digits argument must be between 0 and 20.\n\n var precision = Math.min(Math.max(-dataQuantity + sizeQuantity, 0), 20);\n return !isFinite(precision) ? 20 : precision;\n}\n/**\n * Get a data of given precision, assuring the sum of percentages\n * in valueList is 1.\n * The largest remainer method is used.\n * https://en.wikipedia.org/wiki/Largest_remainder_method\n *\n * @param {Array.<number>} valueList a list of all data\n * @param {number} idx index of the data to be processed in valueList\n * @param {number} precision integer number showing digits of precision\n * @return {number} percent ranging from 0 to 100\n */\n\n\nfunction getPercentWithPrecision(valueList, idx, precision) {\n if (!valueList[idx]) {\n return 0;\n }\n\n var sum = zrUtil.reduce(valueList, function (acc, val) {\n return acc + (isNaN(val) ? 0 : val);\n }, 0);\n\n if (sum === 0) {\n return 0;\n }\n\n var digits = Math.pow(10, precision);\n var votesPerQuota = zrUtil.map(valueList, function (val) {\n return (isNaN(val) ? 0 : val) / sum * digits * 100;\n });\n var targetSeats = digits * 100;\n var seats = zrUtil.map(votesPerQuota, function (votes) {\n // Assign automatic seats.\n return Math.floor(votes);\n });\n var currentSum = zrUtil.reduce(seats, function (acc, val) {\n return acc + val;\n }, 0);\n var remainder = zrUtil.map(votesPerQuota, function (votes, idx) {\n return votes - seats[idx];\n }); // Has remainding votes.\n\n while (currentSum < targetSeats) {\n // Find next largest remainder.\n var max = Number.NEGATIVE_INFINITY;\n var maxId = null;\n\n for (var i = 0, len = remainder.length; i < len; ++i) {\n if (remainder[i] > max) {\n max = remainder[i];\n maxId = i;\n }\n } // Add a vote to max remainder.\n\n\n ++seats[maxId];\n remainder[maxId] = 0;\n ++currentSum;\n }\n\n return seats[idx] / digits;\n} // Number.MAX_SAFE_INTEGER, ie do not support.\n\n\nvar MAX_SAFE_INTEGER = 9007199254740991;\n/**\n * To 0 - 2 * PI, considering negative radian.\n * @param {number} radian\n * @return {number}\n */\n\nfunction remRadian(radian) {\n var pi2 = Math.PI * 2;\n return (radian % pi2 + pi2) % pi2;\n}\n/**\n * @param {type} radian\n * @return {boolean}\n */\n\n\nfunction isRadianAroundZero(val) {\n return val > -RADIAN_EPSILON && val < RADIAN_EPSILON;\n}\n/* eslint-disable */\n\n\nvar TIME_REG = /^(?:(\\d{4})(?:[-\\/](\\d{1,2})(?:[-\\/](\\d{1,2})(?:[T ](\\d{1,2})(?::(\\d\\d)(?::(\\d\\d)(?:[.,](\\d+))?)?)?(Z|[\\+\\-]\\d\\d:?\\d\\d)?)?)?)?)?$/; // jshint ignore:line\n\n/* eslint-enable */\n\n/**\n * @param {string|Date|number} value These values can be accepted:\n * + An instance of Date, represent a time in its own time zone.\n * + Or string in a subset of ISO 8601, only including:\n * + only year, month, date: '2012-03', '2012-03-01', '2012-03-01 05', '2012-03-01 05:06',\n * + separated with T or space: '2012-03-01T12:22:33.123', '2012-03-01 12:22:33.123',\n * + time zone: '2012-03-01T12:22:33Z', '2012-03-01T12:22:33+8000', '2012-03-01T12:22:33-05:00',\n * all of which will be treated as local time if time zone is not specified\n * (see <https://momentjs.com/>).\n * + Or other string format, including (all of which will be treated as loacal time):\n * '2012', '2012-3-1', '2012/3/1', '2012/03/01',\n * '2009/6/12 2:00', '2009/6/12 2:05:08', '2009/6/12 2:05:08.123'\n * + a timestamp, which represent a time in UTC.\n * @return {Date} date\n */\n\nfunction parseDate(value) {\n if (value instanceof Date) {\n return value;\n } else if (typeof value === 'string') {\n // Different browsers parse date in different way, so we parse it manually.\n // Some other issues:\n // new Date('1970-01-01') is UTC,\n // new Date('1970/01/01') and new Date('1970-1-01') is local.\n // See issue #3623\n var match = TIME_REG.exec(value);\n\n if (!match) {\n // return Invalid Date.\n return new Date(NaN);\n } // Use local time when no timezone offset specifed.\n\n\n if (!match[8]) {\n // match[n] can only be string or undefined.\n // But take care of '12' + 1 => '121'.\n return new Date(+match[1], +(match[2] || 1) - 1, +match[3] || 1, +match[4] || 0, +(match[5] || 0), +match[6] || 0, +match[7] || 0);\n } // Timezoneoffset of Javascript Date has considered DST (Daylight Saving Time,\n // https://tc39.github.io/ecma262/#sec-daylight-saving-time-adjustment).\n // For example, system timezone is set as \"Time Zone: America/Toronto\",\n // then these code will get different result:\n // `new Date(1478411999999).getTimezoneOffset(); // get 240`\n // `new Date(1478412000000).getTimezoneOffset(); // get 300`\n // So we should not use `new Date`, but use `Date.UTC`.\n else {\n var hour = +match[4] || 0;\n\n if (match[8].toUpperCase() !== 'Z') {\n hour -= match[8].slice(0, 3);\n }\n\n return new Date(Date.UTC(+match[1], +(match[2] || 1) - 1, +match[3] || 1, hour, +(match[5] || 0), +match[6] || 0, +match[7] || 0));\n }\n } else if (value == null) {\n return new Date(NaN);\n }\n\n return new Date(Math.round(value));\n}\n/**\n * Quantity of a number. e.g. 0.1, 1, 10, 100\n *\n * @param {number} val\n * @return {number}\n */\n\n\nfunction quantity(val) {\n return Math.pow(10, quantityExponent(val));\n}\n\nfunction quantityExponent(val) {\n return Math.floor(Math.log(val) / Math.LN10);\n}\n/**\n * find a “nice” number approximately equal to x. Round the number if round = true,\n * take ceiling if round = false. The primary observation is that the “nicest”\n * numbers in decimal are 1, 2, and 5, and all power-of-ten multiples of these numbers.\n *\n * See \"Nice Numbers for Graph Labels\" of Graphic Gems.\n *\n * @param {number} val Non-negative value.\n * @param {boolean} round\n * @return {number}\n */\n\n\nfunction nice(val, round) {\n var exponent = quantityExponent(val);\n var exp10 = Math.pow(10, exponent);\n var f = val / exp10; // 1 <= f < 10\n\n var nf;\n\n if (round) {\n if (f < 1.5) {\n nf = 1;\n } else if (f < 2.5) {\n nf = 2;\n } else if (f < 4) {\n nf = 3;\n } else if (f < 7) {\n nf = 5;\n } else {\n nf = 10;\n }\n } else {\n if (f < 1) {\n nf = 1;\n } else if (f < 2) {\n nf = 2;\n } else if (f < 3) {\n nf = 3;\n } else if (f < 5) {\n nf = 5;\n } else {\n nf = 10;\n }\n }\n\n val = nf * exp10; // Fix 3 * 0.1 === 0.30000000000000004 issue (see IEEE 754).\n // 20 is the uppper bound of toFixed.\n\n return exponent >= -20 ? +val.toFixed(exponent < 0 ? -exponent : 0) : val;\n}\n/**\n * This code was copied from \"d3.js\"\n * <https://github.com/d3/d3/blob/9cc9a875e636a1dcf36cc1e07bdf77e1ad6e2c74/src/arrays/quantile.js>.\n * See the license statement at the head of this file.\n * @param {Array.<number>} ascArr\n */\n\n\nfunction quantile(ascArr, p) {\n var H = (ascArr.length - 1) * p + 1;\n var h = Math.floor(H);\n var v = +ascArr[h - 1];\n var e = H - h;\n return e ? v + e * (ascArr[h] - v) : v;\n}\n/**\n * Order intervals asc, and split them when overlap.\n * expect(numberUtil.reformIntervals([\n * {interval: [18, 62], close: [1, 1]},\n * {interval: [-Infinity, -70], close: [0, 0]},\n * {interval: [-70, -26], close: [1, 1]},\n * {interval: [-26, 18], close: [1, 1]},\n * {interval: [62, 150], close: [1, 1]},\n * {interval: [106, 150], close: [1, 1]},\n * {interval: [150, Infinity], close: [0, 0]}\n * ])).toEqual([\n * {interval: [-Infinity, -70], close: [0, 0]},\n * {interval: [-70, -26], close: [1, 1]},\n * {interval: [-26, 18], close: [0, 1]},\n * {interval: [18, 62], close: [0, 1]},\n * {interval: [62, 150], close: [0, 1]},\n * {interval: [150, Infinity], close: [0, 0]}\n * ]);\n * @param {Array.<Object>} list, where `close` mean open or close\n * of the interval, and Infinity can be used.\n * @return {Array.<Object>} The origin list, which has been reformed.\n */\n\n\nfunction reformIntervals(list) {\n list.sort(function (a, b) {\n return littleThan(a, b, 0) ? -1 : 1;\n });\n var curr = -Infinity;\n var currClose = 1;\n\n for (var i = 0; i < list.length;) {\n var interval = list[i].interval;\n var close = list[i].close;\n\n for (var lg = 0; lg < 2; lg++) {\n if (interval[lg] <= curr) {\n interval[lg] = curr;\n close[lg] = !lg ? 1 - currClose : 1;\n }\n\n curr = interval[lg];\n currClose = close[lg];\n }\n\n if (interval[0] === interval[1] && close[0] * close[1] !== 1) {\n list.splice(i, 1);\n } else {\n i++;\n }\n }\n\n return list;\n\n function littleThan(a, b, lg) {\n return a.interval[lg] < b.interval[lg] || a.interval[lg] === b.interval[lg] && (a.close[lg] - b.close[lg] === (!lg ? 1 : -1) || !lg && littleThan(a, b, 1));\n }\n}\n/**\n * parseFloat NaNs numeric-cast false positives (null|true|false|\"\")\n * ...but misinterprets leading-number strings, particularly hex literals (\"0x...\")\n * subtraction forces infinities to NaN\n *\n * @param {*} v\n * @return {boolean}\n */\n\n\nfunction isNumeric(v) {\n return v - parseFloat(v) >= 0;\n}\n\nexports.linearMap = linearMap;\nexports.parsePercent = parsePercent;\nexports.round = round;\nexports.asc = asc;\nexports.getPrecision = getPrecision;\nexports.getPrecisionSafe = getPrecisionSafe;\nexports.getPixelPrecision = getPixelPrecision;\nexports.getPercentWithPrecision = getPercentWithPrecision;\nexports.MAX_SAFE_INTEGER = MAX_SAFE_INTEGER;\nexports.remRadian = remRadian;\nexports.isRadianAroundZero = isRadianAroundZero;\nexports.parseDate = parseDate;\nexports.quantity = quantity;\nexports.nice = nice;\nexports.quantile = quantile;\nexports.reformIntervals = reformIntervals;\nexports.isNumeric = isNumeric;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _dataProvider = require(\"../../data/helper/dataProvider\");\n\nvar retrieveRawValue = _dataProvider.retrieveRawValue;\n\nvar _format = require(\"../../util/format\");\n\nvar getTooltipMarker = _format.getTooltipMarker;\nvar formatTpl = _format.formatTpl;\n\nvar _model = require(\"../../util/model\");\n\nvar getTooltipRenderMode = _model.getTooltipRenderMode;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar DIMENSION_LABEL_REG = /\\{@(.+?)\\}/g; // PENDING A little ugly\n\nvar _default = {\n /**\n * Get params for formatter\n * @param {number} dataIndex\n * @param {string} [dataType]\n * @return {Object}\n */\n getDataParams: function (dataIndex, dataType) {\n var data = this.getData(dataType);\n var rawValue = this.getRawValue(dataIndex, dataType);\n var rawDataIndex = data.getRawIndex(dataIndex);\n var name = data.getName(dataIndex);\n var itemOpt = data.getRawDataItem(dataIndex);\n var color = data.getItemVisual(dataIndex, 'color');\n var tooltipModel = this.ecModel.getComponent('tooltip');\n var renderModeOption = tooltipModel && tooltipModel.get('renderMode');\n var renderMode = getTooltipRenderMode(renderModeOption);\n var mainType = this.mainType;\n var isSeries = mainType === 'series';\n return {\n componentType: mainType,\n componentSubType: this.subType,\n componentIndex: this.componentIndex,\n seriesType: isSeries ? this.subType : null,\n seriesIndex: this.seriesIndex,\n seriesId: isSeries ? this.id : null,\n seriesName: isSeries ? this.name : null,\n name: name,\n dataIndex: rawDataIndex,\n data: itemOpt,\n dataType: dataType,\n value: rawValue,\n color: color,\n marker: getTooltipMarker({\n color: color,\n renderMode: renderMode\n }),\n // Param name list for mapping `a`, `b`, `c`, `d`, `e`\n $vars: ['seriesName', 'name', 'value']\n };\n },\n\n /**\n * Format label\n * @param {number} dataIndex\n * @param {string} [status='normal'] 'normal' or 'emphasis'\n * @param {string} [dataType]\n * @param {number} [dimIndex]\n * @param {string} [labelProp='label']\n * @return {string} If not formatter, return null/undefined\n */\n getFormattedLabel: function (dataIndex, status, dataType, dimIndex, labelProp) {\n status = status || 'normal';\n var data = this.getData(dataType);\n var itemModel = data.getItemModel(dataIndex);\n var params = this.getDataParams(dataIndex, dataType);\n\n if (dimIndex != null && params.value instanceof Array) {\n params.value = params.value[dimIndex];\n }\n\n var formatter = itemModel.get(status === 'normal' ? [labelProp || 'label', 'formatter'] : [status, labelProp || 'label', 'formatter']);\n\n if (typeof formatter === 'function') {\n params.status = status;\n return formatter(params);\n } else if (typeof formatter === 'string') {\n var str = formatTpl(formatter, params); // Support 'aaa{@[3]}bbb{@product}ccc'.\n // Do not support '}' in dim name util have to.\n\n return str.replace(DIMENSION_LABEL_REG, function (origin, dim) {\n var len = dim.length;\n\n if (dim.charAt(0) === '[' && dim.charAt(len - 1) === ']') {\n dim = +dim.slice(1, len - 1); // Also: '[]' => 0\n }\n\n return retrieveRawValue(data, dataIndex, dim);\n });\n }\n },\n\n /**\n * Get raw value in option\n * @param {number} idx\n * @param {string} [dataType]\n * @return {Array|number|string}\n */\n getRawValue: function (idx, dataType) {\n return retrieveRawValue(this.getData(dataType), idx);\n },\n\n /**\n * Should be implemented.\n * @param {number} dataIndex\n * @param {boolean} [multipleSeries=false]\n * @param {number} [dataType]\n * @return {string} tooltip string\n */\n formatTooltip: function () {// Empty function\n }\n};\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar makeStyleMapper = require(\"./makeStyleMapper\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar getLineStyle = makeStyleMapper([['lineWidth', 'width'], ['stroke', 'color'], ['opacity'], ['shadowBlur'], ['shadowOffsetX'], ['shadowOffsetY'], ['shadowColor']]);\nvar _default = {\n getLineStyle: function (excludes) {\n var style = getLineStyle(this, excludes);\n var lineDash = this.getLineDash(style.lineWidth);\n lineDash && (style.lineDash = lineDash);\n return style;\n },\n getLineDash: function (lineWidth) {\n if (lineWidth == null) {\n lineWidth = 1;\n }\n\n var lineType = this.get('type');\n var dotSize = Math.max(lineWidth, 2);\n var dashSize = lineWidth * 4;\n return lineType === 'solid' || lineType == null ? null : lineType === 'dashed' ? [dashSize, dashSize] : [dotSize, dotSize];\n }\n};\nmodule.exports = _default;","var _util = require(\"../core/util\");\n\nvar inherits = _util.inherits;\n\nvar Displayble = require(\"./Displayable\");\n\nvar BoundingRect = require(\"../core/BoundingRect\");\n\n/**\n * Displayable for incremental rendering. It will be rendered in a separate layer\n * IncrementalDisplay have two main methods. `clearDisplayables` and `addDisplayables`\n * addDisplayables will render the added displayables incremetally.\n *\n * It use a not clearFlag to tell the painter don't clear the layer if it's the first element.\n */\n// TODO Style override ?\nfunction IncrementalDisplayble(opts) {\n Displayble.call(this, opts);\n this._displayables = [];\n this._temporaryDisplayables = [];\n this._cursor = 0;\n this.notClear = true;\n}\n\nIncrementalDisplayble.prototype.incremental = true;\n\nIncrementalDisplayble.prototype.clearDisplaybles = function () {\n this._displayables = [];\n this._temporaryDisplayables = [];\n this._cursor = 0;\n this.dirty();\n this.notClear = false;\n};\n\nIncrementalDisplayble.prototype.addDisplayable = function (displayable, notPersistent) {\n if (notPersistent) {\n this._temporaryDisplayables.push(displayable);\n } else {\n this._displayables.push(displayable);\n }\n\n this.dirty();\n};\n\nIncrementalDisplayble.prototype.addDisplayables = function (displayables, notPersistent) {\n notPersistent = notPersistent || false;\n\n for (var i = 0; i < displayables.length; i++) {\n this.addDisplayable(displayables[i], notPersistent);\n }\n};\n\nIncrementalDisplayble.prototype.eachPendingDisplayable = function (cb) {\n for (var i = this._cursor; i < this._displayables.length; i++) {\n cb && cb(this._displayables[i]);\n }\n\n for (var i = 0; i < this._temporaryDisplayables.length; i++) {\n cb && cb(this._temporaryDisplayables[i]);\n }\n};\n\nIncrementalDisplayble.prototype.update = function () {\n this.updateTransform();\n\n for (var i = this._cursor; i < this._displayables.length; i++) {\n var displayable = this._displayables[i]; // PENDING\n\n displayable.parent = this;\n displayable.update();\n displayable.parent = null;\n }\n\n for (var i = 0; i < this._temporaryDisplayables.length; i++) {\n var displayable = this._temporaryDisplayables[i]; // PENDING\n\n displayable.parent = this;\n displayable.update();\n displayable.parent = null;\n }\n};\n\nIncrementalDisplayble.prototype.brush = function (ctx, prevEl) {\n // Render persistant displayables.\n for (var i = this._cursor; i < this._displayables.length; i++) {\n var displayable = this._displayables[i];\n displayable.beforeBrush && displayable.beforeBrush(ctx);\n displayable.brush(ctx, i === this._cursor ? null : this._displayables[i - 1]);\n displayable.afterBrush && displayable.afterBrush(ctx);\n }\n\n this._cursor = i; // Render temporary displayables.\n\n for (var i = 0; i < this._temporaryDisplayables.length; i++) {\n var displayable = this._temporaryDisplayables[i];\n displayable.beforeBrush && displayable.beforeBrush(ctx);\n displayable.brush(ctx, i === 0 ? null : this._temporaryDisplayables[i - 1]);\n displayable.afterBrush && displayable.afterBrush(ctx);\n }\n\n this._temporaryDisplayables = [];\n this.notClear = true;\n};\n\nvar m = [];\n\nIncrementalDisplayble.prototype.getBoundingRect = function () {\n if (!this._rect) {\n var rect = new BoundingRect(Infinity, Infinity, -Infinity, -Infinity);\n\n for (var i = 0; i < this._displayables.length; i++) {\n var displayable = this._displayables[i];\n var childRect = displayable.getBoundingRect().clone();\n\n if (displayable.needLocalTransform()) {\n childRect.applyTransform(displayable.getLocalTransform(m));\n }\n\n rect.union(childRect);\n }\n\n this._rect = rect;\n }\n\n return this._rect;\n};\n\nIncrementalDisplayble.prototype.contain = function (x, y) {\n var localPos = this.transformCoordToLocal(x, y);\n var rect = this.getBoundingRect();\n\n if (rect.contain(localPos[0], localPos[1])) {\n for (var i = 0; i < this._displayables.length; i++) {\n var displayable = this._displayables[i];\n\n if (displayable.contain(x, y)) {\n return true;\n }\n }\n }\n\n return false;\n};\n\ninherits(IncrementalDisplayble, Displayble);\nvar _default = IncrementalDisplayble;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"./config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar zrender = require(\"zrender/lib/zrender\");\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar colorTool = require(\"zrender/lib/tool/color\");\n\nvar env = require(\"zrender/lib/core/env\");\n\nvar timsort = require(\"zrender/lib/core/timsort\");\n\nvar Eventful = require(\"zrender/lib/mixin/Eventful\");\n\nvar GlobalModel = require(\"./model/Global\");\n\nvar ExtensionAPI = require(\"./ExtensionAPI\");\n\nvar CoordinateSystemManager = require(\"./CoordinateSystem\");\n\nvar OptionManager = require(\"./model/OptionManager\");\n\nvar backwardCompat = require(\"./preprocessor/backwardCompat\");\n\nvar dataStack = require(\"./processor/dataStack\");\n\nvar ComponentModel = require(\"./model/Component\");\n\nvar SeriesModel = require(\"./model/Series\");\n\nvar ComponentView = require(\"./view/Component\");\n\nvar ChartView = require(\"./view/Chart\");\n\nvar graphic = require(\"./util/graphic\");\n\nvar modelUtil = require(\"./util/model\");\n\nvar _throttle = require(\"./util/throttle\");\n\nvar throttle = _throttle.throttle;\n\nvar seriesColor = require(\"./visual/seriesColor\");\n\nvar aria = require(\"./visual/aria\");\n\nvar loadingDefault = require(\"./loading/default\");\n\nvar Scheduler = require(\"./stream/Scheduler\");\n\nvar lightTheme = require(\"./theme/light\");\n\nvar darkTheme = require(\"./theme/dark\");\n\nrequire(\"./component/dataset\");\n\nvar mapDataStorage = require(\"./coord/geo/mapDataStorage\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar assert = zrUtil.assert;\nvar each = zrUtil.each;\nvar isFunction = zrUtil.isFunction;\nvar isObject = zrUtil.isObject;\nvar parseClassType = ComponentModel.parseClassType;\nvar version = '4.2.1';\nvar dependencies = {\n zrender: '4.0.6'\n};\nvar TEST_FRAME_REMAIN_TIME = 1;\nvar PRIORITY_PROCESSOR_FILTER = 1000;\nvar PRIORITY_PROCESSOR_STATISTIC = 5000;\nvar PRIORITY_VISUAL_LAYOUT = 1000;\nvar PRIORITY_VISUAL_GLOBAL = 2000;\nvar PRIORITY_VISUAL_CHART = 3000;\nvar PRIORITY_VISUAL_COMPONENT = 4000; // FIXME\n// necessary?\n\nvar PRIORITY_VISUAL_BRUSH = 5000;\nvar PRIORITY = {\n PROCESSOR: {\n FILTER: PRIORITY_PROCESSOR_FILTER,\n STATISTIC: PRIORITY_PROCESSOR_STATISTIC\n },\n VISUAL: {\n LAYOUT: PRIORITY_VISUAL_LAYOUT,\n GLOBAL: PRIORITY_VISUAL_GLOBAL,\n CHART: PRIORITY_VISUAL_CHART,\n COMPONENT: PRIORITY_VISUAL_COMPONENT,\n BRUSH: PRIORITY_VISUAL_BRUSH\n }\n}; // Main process have three entries: `setOption`, `dispatchAction` and `resize`,\n// where they must not be invoked nestedly, except the only case: invoke\n// dispatchAction with updateMethod \"none\" in main process.\n// This flag is used to carry out this rule.\n// All events will be triggered out side main process (i.e. when !this[IN_MAIN_PROCESS]).\n\nvar IN_MAIN_PROCESS = '__flagInMainProcess';\nvar OPTION_UPDATED = '__optionUpdated';\nvar ACTION_REG = /^[a-zA-Z0-9_]+$/;\n\nfunction createRegisterEventWithLowercaseName(method) {\n return function (eventName, handler, context) {\n // Event name is all lowercase\n eventName = eventName && eventName.toLowerCase();\n Eventful.prototype[method].call(this, eventName, handler, context);\n };\n}\n/**\n * @module echarts~MessageCenter\n */\n\n\nfunction MessageCenter() {\n Eventful.call(this);\n}\n\nMessageCenter.prototype.on = createRegisterEventWithLowercaseName('on');\nMessageCenter.prototype.off = createRegisterEventWithLowercaseName('off');\nMessageCenter.prototype.one = createRegisterEventWithLowercaseName('one');\nzrUtil.mixin(MessageCenter, Eventful);\n/**\n * @module echarts~ECharts\n */\n\nfunction ECharts(dom, theme, opts) {\n opts = opts || {}; // Get theme by name\n\n if (typeof theme === 'string') {\n theme = themeStorage[theme];\n }\n /**\n * @type {string}\n */\n\n\n this.id;\n /**\n * Group id\n * @type {string}\n */\n\n this.group;\n /**\n * @type {HTMLElement}\n * @private\n */\n\n this._dom = dom;\n var defaultRenderer = 'canvas';\n\n /**\n * @type {module:zrender/ZRender}\n * @private\n */\n var zr = this._zr = zrender.init(dom, {\n renderer: opts.renderer || defaultRenderer,\n devicePixelRatio: opts.devicePixelRatio,\n width: opts.width,\n height: opts.height\n });\n /**\n * Expect 60 pfs.\n * @type {Function}\n * @private\n */\n\n this._throttledZrFlush = throttle(zrUtil.bind(zr.flush, zr), 17);\n var theme = zrUtil.clone(theme);\n theme && backwardCompat(theme, true);\n /**\n * @type {Object}\n * @private\n */\n\n this._theme = theme;\n /**\n * @type {Array.<module:echarts/view/Chart>}\n * @private\n */\n\n this._chartsViews = [];\n /**\n * @type {Object.<string, module:echarts/view/Chart>}\n * @private\n */\n\n this._chartsMap = {};\n /**\n * @type {Array.<module:echarts/view/Component>}\n * @private\n */\n\n this._componentsViews = [];\n /**\n * @type {Object.<string, module:echarts/view/Component>}\n * @private\n */\n\n this._componentsMap = {};\n /**\n * @type {module:echarts/CoordinateSystem}\n * @private\n */\n\n this._coordSysMgr = new CoordinateSystemManager();\n /**\n * @type {module:echarts/ExtensionAPI}\n * @private\n */\n\n var api = this._api = createExtensionAPI(this); // Sort on demand\n\n function prioritySortFunc(a, b) {\n return a.__prio - b.__prio;\n }\n\n timsort(visualFuncs, prioritySortFunc);\n timsort(dataProcessorFuncs, prioritySortFunc);\n /**\n * @type {module:echarts/stream/Scheduler}\n */\n\n this._scheduler = new Scheduler(this, api, dataProcessorFuncs, visualFuncs);\n Eventful.call(this, this._ecEventProcessor = new EventProcessor());\n /**\n * @type {module:echarts~MessageCenter}\n * @private\n */\n\n this._messageCenter = new MessageCenter(); // Init mouse events\n\n this._initEvents(); // In case some people write `window.onresize = chart.resize`\n\n\n this.resize = zrUtil.bind(this.resize, this); // Can't dispatch action during rendering procedure\n\n this._pendingActions = [];\n zr.animation.on('frame', this._onframe, this);\n bindRenderedEvent(zr, this); // ECharts instance can be used as value.\n\n zrUtil.setAsPrimitive(this);\n}\n\nvar echartsProto = ECharts.prototype;\n\nechartsProto._onframe = function () {\n if (this._disposed) {\n return;\n }\n\n var scheduler = this._scheduler; // Lazy update\n\n if (this[OPTION_UPDATED]) {\n var silent = this[OPTION_UPDATED].silent;\n this[IN_MAIN_PROCESS] = true;\n prepare(this);\n updateMethods.update.call(this);\n this[IN_MAIN_PROCESS] = false;\n this[OPTION_UPDATED] = false;\n flushPendingActions.call(this, silent);\n triggerUpdatedEvent.call(this, silent);\n } // Avoid do both lazy update and progress in one frame.\n else if (scheduler.unfinished) {\n // Stream progress.\n var remainTime = TEST_FRAME_REMAIN_TIME;\n var ecModel = this._model;\n var api = this._api;\n scheduler.unfinished = false;\n\n do {\n var startTime = +new Date();\n scheduler.performSeriesTasks(ecModel); // Currently dataProcessorFuncs do not check threshold.\n\n scheduler.performDataProcessorTasks(ecModel);\n updateStreamModes(this, ecModel); // Do not update coordinate system here. Because that coord system update in\n // each frame is not a good user experience. So we follow the rule that\n // the extent of the coordinate system is determin in the first frame (the\n // frame is executed immedietely after task reset.\n // this._coordSysMgr.update(ecModel, api);\n // console.log('--- ec frame visual ---', remainTime);\n\n scheduler.performVisualTasks(ecModel);\n renderSeries(this, this._model, api, 'remain');\n remainTime -= +new Date() - startTime;\n } while (remainTime > 0 && scheduler.unfinished); // Call flush explicitly for trigger finished event.\n\n\n if (!scheduler.unfinished) {\n this._zr.flush();\n } // Else, zr flushing be ensue within the same frame,\n // because zr flushing is after onframe event.\n\n }\n};\n/**\n * @return {HTMLElement}\n */\n\n\nechartsProto.getDom = function () {\n return this._dom;\n};\n/**\n * @return {module:zrender~ZRender}\n */\n\n\nechartsProto.getZr = function () {\n return this._zr;\n};\n/**\n * Usage:\n * chart.setOption(option, notMerge, lazyUpdate);\n * chart.setOption(option, {\n * notMerge: ...,\n * lazyUpdate: ...,\n * silent: ...\n * });\n *\n * @param {Object} option\n * @param {Object|boolean} [opts] opts or notMerge.\n * @param {boolean} [opts.notMerge=false]\n * @param {boolean} [opts.lazyUpdate=false] Useful when setOption frequently.\n */\n\n\nechartsProto.setOption = function (option, notMerge, lazyUpdate) {\n var silent;\n\n if (isObject(notMerge)) {\n lazyUpdate = notMerge.lazyUpdate;\n silent = notMerge.silent;\n notMerge = notMerge.notMerge;\n }\n\n this[IN_MAIN_PROCESS] = true;\n\n if (!this._model || notMerge) {\n var optionManager = new OptionManager(this._api);\n var theme = this._theme;\n var ecModel = this._model = new GlobalModel(null, null, theme, optionManager);\n ecModel.scheduler = this._scheduler;\n ecModel.init(null, null, theme, optionManager);\n }\n\n this._model.setOption(option, optionPreprocessorFuncs);\n\n if (lazyUpdate) {\n this[OPTION_UPDATED] = {\n silent: silent\n };\n this[IN_MAIN_PROCESS] = false;\n } else {\n prepare(this);\n updateMethods.update.call(this); // Ensure zr refresh sychronously, and then pixel in canvas can be\n // fetched after `setOption`.\n\n this._zr.flush();\n\n this[OPTION_UPDATED] = false;\n this[IN_MAIN_PROCESS] = false;\n flushPendingActions.call(this, silent);\n triggerUpdatedEvent.call(this, silent);\n }\n};\n/**\n * @DEPRECATED\n */\n\n\nechartsProto.setTheme = function () {\n console.error('ECharts#setTheme() is DEPRECATED in ECharts 3.0');\n};\n/**\n * @return {module:echarts/model/Global}\n */\n\n\nechartsProto.getModel = function () {\n return this._model;\n};\n/**\n * @return {Object}\n */\n\n\nechartsProto.getOption = function () {\n return this._model && this._model.getOption();\n};\n/**\n * @return {number}\n */\n\n\nechartsProto.getWidth = function () {\n return this._zr.getWidth();\n};\n/**\n * @return {number}\n */\n\n\nechartsProto.getHeight = function () {\n return this._zr.getHeight();\n};\n/**\n * @return {number}\n */\n\n\nechartsProto.getDevicePixelRatio = function () {\n return this._zr.painter.dpr || window.devicePixelRatio || 1;\n};\n/**\n * Get canvas which has all thing rendered\n * @param {Object} opts\n * @param {string} [opts.backgroundColor]\n * @return {string}\n */\n\n\nechartsProto.getRenderedCanvas = function (opts) {\n if (!env.canvasSupported) {\n return;\n }\n\n opts = opts || {};\n opts.pixelRatio = opts.pixelRatio || 1;\n opts.backgroundColor = opts.backgroundColor || this._model.get('backgroundColor');\n var zr = this._zr; // var list = zr.storage.getDisplayList();\n // Stop animations\n // Never works before in init animation, so remove it.\n // zrUtil.each(list, function (el) {\n // el.stopAnimation(true);\n // });\n\n return zr.painter.getRenderedCanvas(opts);\n};\n/**\n * Get svg data url\n * @return {string}\n */\n\n\nechartsProto.getSvgDataUrl = function () {\n if (!env.svgSupported) {\n return;\n }\n\n var zr = this._zr;\n var list = zr.storage.getDisplayList(); // Stop animations\n\n zrUtil.each(list, function (el) {\n el.stopAnimation(true);\n });\n return zr.painter.pathToDataUrl();\n};\n/**\n * @return {string}\n * @param {Object} opts\n * @param {string} [opts.type='png']\n * @param {string} [opts.pixelRatio=1]\n * @param {string} [opts.backgroundColor]\n * @param {string} [opts.excludeComponents]\n */\n\n\nechartsProto.getDataURL = function (opts) {\n opts = opts || {};\n var excludeComponents = opts.excludeComponents;\n var ecModel = this._model;\n var excludesComponentViews = [];\n var self = this;\n each(excludeComponents, function (componentType) {\n ecModel.eachComponent({\n mainType: componentType\n }, function (component) {\n var view = self._componentsMap[component.__viewId];\n\n if (!view.group.ignore) {\n excludesComponentViews.push(view);\n view.group.ignore = true;\n }\n });\n });\n var url = this._zr.painter.getType() === 'svg' ? this.getSvgDataUrl() : this.getRenderedCanvas(opts).toDataURL('image/' + (opts && opts.type || 'png'));\n each(excludesComponentViews, function (view) {\n view.group.ignore = false;\n });\n return url;\n};\n/**\n * @return {string}\n * @param {Object} opts\n * @param {string} [opts.type='png']\n * @param {string} [opts.pixelRatio=1]\n * @param {string} [opts.backgroundColor]\n */\n\n\nechartsProto.getConnectedDataURL = function (opts) {\n if (!env.canvasSupported) {\n return;\n }\n\n var groupId = this.group;\n var mathMin = Math.min;\n var mathMax = Math.max;\n var MAX_NUMBER = Infinity;\n\n if (connectedGroups[groupId]) {\n var left = MAX_NUMBER;\n var top = MAX_NUMBER;\n var right = -MAX_NUMBER;\n var bottom = -MAX_NUMBER;\n var canvasList = [];\n var dpr = opts && opts.pixelRatio || 1;\n zrUtil.each(instances, function (chart, id) {\n if (chart.group === groupId) {\n var canvas = chart.getRenderedCanvas(zrUtil.clone(opts));\n var boundingRect = chart.getDom().getBoundingClientRect();\n left = mathMin(boundingRect.left, left);\n top = mathMin(boundingRect.top, top);\n right = mathMax(boundingRect.right, right);\n bottom = mathMax(boundingRect.bottom, bottom);\n canvasList.push({\n dom: canvas,\n left: boundingRect.left,\n top: boundingRect.top\n });\n }\n });\n left *= dpr;\n top *= dpr;\n right *= dpr;\n bottom *= dpr;\n var width = right - left;\n var height = bottom - top;\n var targetCanvas = zrUtil.createCanvas();\n targetCanvas.width = width;\n targetCanvas.height = height;\n var zr = zrender.init(targetCanvas);\n each(canvasList, function (item) {\n var img = new graphic.Image({\n style: {\n x: item.left * dpr - left,\n y: item.top * dpr - top,\n image: item.dom\n }\n });\n zr.add(img);\n });\n zr.refreshImmediately();\n return targetCanvas.toDataURL('image/' + (opts && opts.type || 'png'));\n } else {\n return this.getDataURL(opts);\n }\n};\n/**\n * Convert from logical coordinate system to pixel coordinate system.\n * See CoordinateSystem#convertToPixel.\n * @param {string|Object} finder\n * If string, e.g., 'geo', means {geoIndex: 0}.\n * If Object, could contain some of these properties below:\n * {\n * seriesIndex / seriesId / seriesName,\n * geoIndex / geoId, geoName,\n * bmapIndex / bmapId / bmapName,\n * xAxisIndex / xAxisId / xAxisName,\n * yAxisIndex / yAxisId / yAxisName,\n * gridIndex / gridId / gridName,\n * ... (can be extended)\n * }\n * @param {Array|number} value\n * @return {Array|number} result\n */\n\n\nechartsProto.convertToPixel = zrUtil.curry(doConvertPixel, 'convertToPixel');\n/**\n * Convert from pixel coordinate system to logical coordinate system.\n * See CoordinateSystem#convertFromPixel.\n * @param {string|Object} finder\n * If string, e.g., 'geo', means {geoIndex: 0}.\n * If Object, could contain some of these properties below:\n * {\n * seriesIndex / seriesId / seriesName,\n * geoIndex / geoId / geoName,\n * bmapIndex / bmapId / bmapName,\n * xAxisIndex / xAxisId / xAxisName,\n * yAxisIndex / yAxisId / yAxisName\n * gridIndex / gridId / gridName,\n * ... (can be extended)\n * }\n * @param {Array|number} value\n * @return {Array|number} result\n */\n\nechartsProto.convertFromPixel = zrUtil.curry(doConvertPixel, 'convertFromPixel');\n\nfunction doConvertPixel(methodName, finder, value) {\n var ecModel = this._model;\n\n var coordSysList = this._coordSysMgr.getCoordinateSystems();\n\n var result;\n finder = modelUtil.parseFinder(ecModel, finder);\n\n for (var i = 0; i < coordSysList.length; i++) {\n var coordSys = coordSysList[i];\n\n if (coordSys[methodName] && (result = coordSys[methodName](ecModel, finder, value)) != null) {\n return result;\n }\n }\n}\n/**\n * Is the specified coordinate systems or components contain the given pixel point.\n * @param {string|Object} finder\n * If string, e.g., 'geo', means {geoIndex: 0}.\n * If Object, could contain some of these properties below:\n * {\n * seriesIndex / seriesId / seriesName,\n * geoIndex / geoId / geoName,\n * bmapIndex / bmapId / bmapName,\n * xAxisIndex / xAxisId / xAxisName,\n * yAxisIndex / yAxisId / yAxisName,\n * gridIndex / gridId / gridName,\n * ... (can be extended)\n * }\n * @param {Array|number} value\n * @return {boolean} result\n */\n\n\nechartsProto.containPixel = function (finder, value) {\n var ecModel = this._model;\n var result;\n finder = modelUtil.parseFinder(ecModel, finder);\n zrUtil.each(finder, function (models, key) {\n key.indexOf('Models') >= 0 && zrUtil.each(models, function (model) {\n var coordSys = model.coordinateSystem;\n\n if (coordSys && coordSys.containPoint) {\n result |= !!coordSys.containPoint(value);\n } else if (key === 'seriesModels') {\n var view = this._chartsMap[model.__viewId];\n\n if (view && view.containPoint) {\n result |= view.containPoint(value, model);\n } else {}\n } else {}\n }, this);\n }, this);\n return !!result;\n};\n/**\n * Get visual from series or data.\n * @param {string|Object} finder\n * If string, e.g., 'series', means {seriesIndex: 0}.\n * If Object, could contain some of these properties below:\n * {\n * seriesIndex / seriesId / seriesName,\n * dataIndex / dataIndexInside\n * }\n * If dataIndex is not specified, series visual will be fetched,\n * but not data item visual.\n * If all of seriesIndex, seriesId, seriesName are not specified,\n * visual will be fetched from first series.\n * @param {string} visualType 'color', 'symbol', 'symbolSize'\n */\n\n\nechartsProto.getVisual = function (finder, visualType) {\n var ecModel = this._model;\n finder = modelUtil.parseFinder(ecModel, finder, {\n defaultMainType: 'series'\n });\n var seriesModel = finder.seriesModel;\n var data = seriesModel.getData();\n var dataIndexInside = finder.hasOwnProperty('dataIndexInside') ? finder.dataIndexInside : finder.hasOwnProperty('dataIndex') ? data.indexOfRawIndex(finder.dataIndex) : null;\n return dataIndexInside != null ? data.getItemVisual(dataIndexInside, visualType) : data.getVisual(visualType);\n};\n/**\n * Get view of corresponding component model\n * @param {module:echarts/model/Component} componentModel\n * @return {module:echarts/view/Component}\n */\n\n\nechartsProto.getViewOfComponentModel = function (componentModel) {\n return this._componentsMap[componentModel.__viewId];\n};\n/**\n * Get view of corresponding series model\n * @param {module:echarts/model/Series} seriesModel\n * @return {module:echarts/view/Chart}\n */\n\n\nechartsProto.getViewOfSeriesModel = function (seriesModel) {\n return this._chartsMap[seriesModel.__viewId];\n};\n\nvar updateMethods = {\n prepareAndUpdate: function (payload) {\n prepare(this);\n updateMethods.update.call(this, payload);\n },\n\n /**\n * @param {Object} payload\n * @private\n */\n update: function (payload) {\n // console.profile && console.profile('update');\n var ecModel = this._model;\n var api = this._api;\n var zr = this._zr;\n var coordSysMgr = this._coordSysMgr;\n var scheduler = this._scheduler; // update before setOption\n\n if (!ecModel) {\n return;\n }\n\n scheduler.restoreData(ecModel, payload);\n scheduler.performSeriesTasks(ecModel); // TODO\n // Save total ecModel here for undo/redo (after restoring data and before processing data).\n // Undo (restoration of total ecModel) can be carried out in 'action' or outside API call.\n // Create new coordinate system each update\n // In LineView may save the old coordinate system and use it to get the orignal point\n\n coordSysMgr.create(ecModel, api);\n scheduler.performDataProcessorTasks(ecModel, payload); // Current stream render is not supported in data process. So we can update\n // stream modes after data processing, where the filtered data is used to\n // deteming whether use progressive rendering.\n\n updateStreamModes(this, ecModel); // We update stream modes before coordinate system updated, then the modes info\n // can be fetched when coord sys updating (consider the barGrid extent fix). But\n // the drawback is the full coord info can not be fetched. Fortunately this full\n // coord is not requied in stream mode updater currently.\n\n coordSysMgr.update(ecModel, api);\n clearColorPalette(ecModel);\n scheduler.performVisualTasks(ecModel, payload);\n render(this, ecModel, api, payload); // Set background\n\n var backgroundColor = ecModel.get('backgroundColor') || 'transparent'; // In IE8\n\n if (!env.canvasSupported) {\n var colorArr = colorTool.parse(backgroundColor);\n backgroundColor = colorTool.stringify(colorArr, 'rgb');\n\n if (colorArr[3] === 0) {\n backgroundColor = 'transparent';\n }\n } else {\n zr.setBackgroundColor(backgroundColor);\n }\n\n performPostUpdateFuncs(ecModel, api); // console.profile && console.profileEnd('update');\n },\n\n /**\n * @param {Object} payload\n * @private\n */\n updateTransform: function (payload) {\n var ecModel = this._model;\n var ecIns = this;\n var api = this._api; // update before setOption\n\n if (!ecModel) {\n return;\n } // ChartView.markUpdateMethod(payload, 'updateTransform');\n\n\n var componentDirtyList = [];\n ecModel.eachComponent(function (componentType, componentModel) {\n var componentView = ecIns.getViewOfComponentModel(componentModel);\n\n if (componentView && componentView.__alive) {\n if (componentView.updateTransform) {\n var result = componentView.updateTransform(componentModel, ecModel, api, payload);\n result && result.update && componentDirtyList.push(componentView);\n } else {\n componentDirtyList.push(componentView);\n }\n }\n });\n var seriesDirtyMap = zrUtil.createHashMap();\n ecModel.eachSeries(function (seriesModel) {\n var chartView = ecIns._chartsMap[seriesModel.__viewId];\n\n if (chartView.updateTransform) {\n var result = chartView.updateTransform(seriesModel, ecModel, api, payload);\n result && result.update && seriesDirtyMap.set(seriesModel.uid, 1);\n } else {\n seriesDirtyMap.set(seriesModel.uid, 1);\n }\n });\n clearColorPalette(ecModel); // Keep pipe to the exist pipeline because it depends on the render task of the full pipeline.\n // this._scheduler.performVisualTasks(ecModel, payload, 'layout', true);\n\n this._scheduler.performVisualTasks(ecModel, payload, {\n setDirty: true,\n dirtyMap: seriesDirtyMap\n }); // Currently, not call render of components. Geo render cost a lot.\n // renderComponents(ecIns, ecModel, api, payload, componentDirtyList);\n\n\n renderSeries(ecIns, ecModel, api, payload, seriesDirtyMap);\n performPostUpdateFuncs(ecModel, this._api);\n },\n\n /**\n * @param {Object} payload\n * @private\n */\n updateView: function (payload) {\n var ecModel = this._model; // update before setOption\n\n if (!ecModel) {\n return;\n }\n\n ChartView.markUpdateMethod(payload, 'updateView');\n clearColorPalette(ecModel); // Keep pipe to the exist pipeline because it depends on the render task of the full pipeline.\n\n this._scheduler.performVisualTasks(ecModel, payload, {\n setDirty: true\n });\n\n render(this, this._model, this._api, payload);\n performPostUpdateFuncs(ecModel, this._api);\n },\n\n /**\n * @param {Object} payload\n * @private\n */\n updateVisual: function (payload) {\n updateMethods.update.call(this, payload); // var ecModel = this._model;\n // // update before setOption\n // if (!ecModel) {\n // return;\n // }\n // ChartView.markUpdateMethod(payload, 'updateVisual');\n // clearColorPalette(ecModel);\n // // Keep pipe to the exist pipeline because it depends on the render task of the full pipeline.\n // this._scheduler.performVisualTasks(ecModel, payload, {visualType: 'visual', setDirty: true});\n // render(this, this._model, this._api, payload);\n // performPostUpdateFuncs(ecModel, this._api);\n },\n\n /**\n * @param {Object} payload\n * @private\n */\n updateLayout: function (payload) {\n updateMethods.update.call(this, payload); // var ecModel = this._model;\n // // update before setOption\n // if (!ecModel) {\n // return;\n // }\n // ChartView.markUpdateMethod(payload, 'updateLayout');\n // // Keep pipe to the exist pipeline because it depends on the render task of the full pipeline.\n // // this._scheduler.performVisualTasks(ecModel, payload, 'layout', true);\n // this._scheduler.performVisualTasks(ecModel, payload, {setDirty: true});\n // render(this, this._model, this._api, payload);\n // performPostUpdateFuncs(ecModel, this._api);\n }\n};\n\nfunction prepare(ecIns) {\n var ecModel = ecIns._model;\n var scheduler = ecIns._scheduler;\n scheduler.restorePipelines(ecModel);\n scheduler.prepareStageTasks();\n prepareView(ecIns, 'component', ecModel, scheduler);\n prepareView(ecIns, 'chart', ecModel, scheduler);\n scheduler.plan();\n}\n/**\n * @private\n */\n\n\nfunction updateDirectly(ecIns, method, payload, mainType, subType) {\n var ecModel = ecIns._model; // broadcast\n\n if (!mainType) {\n // FIXME\n // Chart will not be update directly here, except set dirty.\n // But there is no such scenario now.\n each(ecIns._componentsViews.concat(ecIns._chartsViews), callView);\n return;\n }\n\n var query = {};\n query[mainType + 'Id'] = payload[mainType + 'Id'];\n query[mainType + 'Index'] = payload[mainType + 'Index'];\n query[mainType + 'Name'] = payload[mainType + 'Name'];\n var condition = {\n mainType: mainType,\n query: query\n };\n subType && (condition.subType = subType); // subType may be '' by parseClassType;\n\n var excludeSeriesId = payload.excludeSeriesId;\n\n if (excludeSeriesId != null) {\n excludeSeriesId = zrUtil.createHashMap(modelUtil.normalizeToArray(excludeSeriesId));\n } // If dispatchAction before setOption, do nothing.\n\n\n ecModel && ecModel.eachComponent(condition, function (model) {\n if (!excludeSeriesId || excludeSeriesId.get(model.id) == null) {\n callView(ecIns[mainType === 'series' ? '_chartsMap' : '_componentsMap'][model.__viewId]);\n }\n }, ecIns);\n\n function callView(view) {\n view && view.__alive && view[method] && view[method](view.__model, ecModel, ecIns._api, payload);\n }\n}\n/**\n * Resize the chart\n * @param {Object} opts\n * @param {number} [opts.width] Can be 'auto' (the same as null/undefined)\n * @param {number} [opts.height] Can be 'auto' (the same as null/undefined)\n * @param {boolean} [opts.silent=false]\n */\n\n\nechartsProto.resize = function (opts) {\n this._zr.resize(opts);\n\n var ecModel = this._model; // Resize loading effect\n\n this._loadingFX && this._loadingFX.resize();\n\n if (!ecModel) {\n return;\n }\n\n var optionChanged = ecModel.resetOption('media');\n var silent = opts && opts.silent;\n this[IN_MAIN_PROCESS] = true;\n optionChanged && prepare(this);\n updateMethods.update.call(this);\n this[IN_MAIN_PROCESS] = false;\n flushPendingActions.call(this, silent);\n triggerUpdatedEvent.call(this, silent);\n};\n\nfunction updateStreamModes(ecIns, ecModel) {\n var chartsMap = ecIns._chartsMap;\n var scheduler = ecIns._scheduler;\n ecModel.eachSeries(function (seriesModel) {\n scheduler.updateStreamModes(seriesModel, chartsMap[seriesModel.__viewId]);\n });\n}\n/**\n * Show loading effect\n * @param {string} [name='default']\n * @param {Object} [cfg]\n */\n\n\nechartsProto.showLoading = function (name, cfg) {\n if (isObject(name)) {\n cfg = name;\n name = '';\n }\n\n name = name || 'default';\n this.hideLoading();\n\n if (!loadingEffects[name]) {\n return;\n }\n\n var el = loadingEffects[name](this._api, cfg);\n var zr = this._zr;\n this._loadingFX = el;\n zr.add(el);\n};\n/**\n * Hide loading effect\n */\n\n\nechartsProto.hideLoading = function () {\n this._loadingFX && this._zr.remove(this._loadingFX);\n this._loadingFX = null;\n};\n/**\n * @param {Object} eventObj\n * @return {Object}\n */\n\n\nechartsProto.makeActionFromEvent = function (eventObj) {\n var payload = zrUtil.extend({}, eventObj);\n payload.type = eventActionMap[eventObj.type];\n return payload;\n};\n/**\n * @pubilc\n * @param {Object} payload\n * @param {string} [payload.type] Action type\n * @param {Object|boolean} [opt] If pass boolean, means opt.silent\n * @param {boolean} [opt.silent=false] Whether trigger events.\n * @param {boolean} [opt.flush=undefined]\n * true: Flush immediately, and then pixel in canvas can be fetched\n * immediately. Caution: it might affect performance.\n * false: Not not flush.\n * undefined: Auto decide whether perform flush.\n */\n\n\nechartsProto.dispatchAction = function (payload, opt) {\n if (!isObject(opt)) {\n opt = {\n silent: !!opt\n };\n }\n\n if (!actions[payload.type]) {\n return;\n } // Avoid dispatch action before setOption. Especially in `connect`.\n\n\n if (!this._model) {\n return;\n } // May dispatchAction in rendering procedure\n\n\n if (this[IN_MAIN_PROCESS]) {\n this._pendingActions.push(payload);\n\n return;\n }\n\n doDispatchAction.call(this, payload, opt.silent);\n\n if (opt.flush) {\n this._zr.flush(true);\n } else if (opt.flush !== false && env.browser.weChat) {\n // In WeChat embeded browser, `requestAnimationFrame` and `setInterval`\n // hang when sliding page (on touch event), which cause that zr does not\n // refresh util user interaction finished, which is not expected.\n // But `dispatchAction` may be called too frequently when pan on touch\n // screen, which impacts performance if do not throttle them.\n this._throttledZrFlush();\n }\n\n flushPendingActions.call(this, opt.silent);\n triggerUpdatedEvent.call(this, opt.silent);\n};\n\nfunction doDispatchAction(payload, silent) {\n var payloadType = payload.type;\n var escapeConnect = payload.escapeConnect;\n var actionWrap = actions[payloadType];\n var actionInfo = actionWrap.actionInfo;\n var cptType = (actionInfo.update || 'update').split(':');\n var updateMethod = cptType.pop();\n cptType = cptType[0] != null && parseClassType(cptType[0]);\n this[IN_MAIN_PROCESS] = true;\n var payloads = [payload];\n var batched = false; // Batch action\n\n if (payload.batch) {\n batched = true;\n payloads = zrUtil.map(payload.batch, function (item) {\n item = zrUtil.defaults(zrUtil.extend({}, item), payload);\n item.batch = null;\n return item;\n });\n }\n\n var eventObjBatch = [];\n var eventObj;\n var isHighDown = payloadType === 'highlight' || payloadType === 'downplay';\n each(payloads, function (batchItem) {\n // Action can specify the event by return it.\n eventObj = actionWrap.action(batchItem, this._model, this._api); // Emit event outside\n\n eventObj = eventObj || zrUtil.extend({}, batchItem); // Convert type to eventType\n\n eventObj.type = actionInfo.event || eventObj.type;\n eventObjBatch.push(eventObj); // light update does not perform data process, layout and visual.\n\n if (isHighDown) {\n // method, payload, mainType, subType\n updateDirectly(this, updateMethod, batchItem, 'series');\n } else if (cptType) {\n updateDirectly(this, updateMethod, batchItem, cptType.main, cptType.sub);\n }\n }, this);\n\n if (updateMethod !== 'none' && !isHighDown && !cptType) {\n // Still dirty\n if (this[OPTION_UPDATED]) {\n // FIXME Pass payload ?\n prepare(this);\n updateMethods.update.call(this, payload);\n this[OPTION_UPDATED] = false;\n } else {\n updateMethods[updateMethod].call(this, payload);\n }\n } // Follow the rule of action batch\n\n\n if (batched) {\n eventObj = {\n type: actionInfo.event || payloadType,\n escapeConnect: escapeConnect,\n batch: eventObjBatch\n };\n } else {\n eventObj = eventObjBatch[0];\n }\n\n this[IN_MAIN_PROCESS] = false;\n !silent && this._messageCenter.trigger(eventObj.type, eventObj);\n}\n\nfunction flushPendingActions(silent) {\n var pendingActions = this._pendingActions;\n\n while (pendingActions.length) {\n var payload = pendingActions.shift();\n doDispatchAction.call(this, payload, silent);\n }\n}\n\nfunction triggerUpdatedEvent(silent) {\n !silent && this.trigger('updated');\n}\n/**\n * Event `rendered` is triggered when zr\n * rendered. It is useful for realtime\n * snapshot (reflect animation).\n *\n * Event `finished` is triggered when:\n * (1) zrender rendering finished.\n * (2) initial animation finished.\n * (3) progressive rendering finished.\n * (4) no pending action.\n * (5) no delayed setOption needs to be processed.\n */\n\n\nfunction bindRenderedEvent(zr, ecIns) {\n zr.on('rendered', function () {\n ecIns.trigger('rendered'); // The `finished` event should not be triggered repeatly,\n // so it should only be triggered when rendering indeed happend\n // in zrender. (Consider the case that dipatchAction is keep\n // triggering when mouse move).\n\n if ( // Although zr is dirty if initial animation is not finished\n // and this checking is called on frame, we also check\n // animation finished for robustness.\n zr.animation.isFinished() && !ecIns[OPTION_UPDATED] && !ecIns._scheduler.unfinished && !ecIns._pendingActions.length) {\n ecIns.trigger('finished');\n }\n });\n}\n/**\n * @param {Object} params\n * @param {number} params.seriesIndex\n * @param {Array|TypedArray} params.data\n */\n\n\nechartsProto.appendData = function (params) {\n var seriesIndex = params.seriesIndex;\n var ecModel = this.getModel();\n var seriesModel = ecModel.getSeriesByIndex(seriesIndex);\n seriesModel.appendData(params); // Note: `appendData` does not support that update extent of coordinate\n // system, util some scenario require that. In the expected usage of\n // `appendData`, the initial extent of coordinate system should better\n // be fixed by axis `min`/`max` setting or initial data, otherwise if\n // the extent changed while `appendData`, the location of the painted\n // graphic elements have to be changed, which make the usage of\n // `appendData` meaningless.\n\n this._scheduler.unfinished = true;\n};\n/**\n * Register event\n * @method\n */\n\n\nechartsProto.on = createRegisterEventWithLowercaseName('on');\nechartsProto.off = createRegisterEventWithLowercaseName('off');\nechartsProto.one = createRegisterEventWithLowercaseName('one');\n/**\n * Prepare view instances of charts and components\n * @param {module:echarts/model/Global} ecModel\n * @private\n */\n\nfunction prepareView(ecIns, type, ecModel, scheduler) {\n var isComponent = type === 'component';\n var viewList = isComponent ? ecIns._componentsViews : ecIns._chartsViews;\n var viewMap = isComponent ? ecIns._componentsMap : ecIns._chartsMap;\n var zr = ecIns._zr;\n var api = ecIns._api;\n\n for (var i = 0; i < viewList.length; i++) {\n viewList[i].__alive = false;\n }\n\n isComponent ? ecModel.eachComponent(function (componentType, model) {\n componentType !== 'series' && doPrepare(model);\n }) : ecModel.eachSeries(doPrepare);\n\n function doPrepare(model) {\n // Consider: id same and type changed.\n var viewId = '_ec_' + model.id + '_' + model.type;\n var view = viewMap[viewId];\n\n if (!view) {\n var classType = parseClassType(model.type);\n var Clazz = isComponent ? ComponentView.getClass(classType.main, classType.sub) : ChartView.getClass(classType.sub);\n view = new Clazz();\n view.init(ecModel, api);\n viewMap[viewId] = view;\n viewList.push(view);\n zr.add(view.group);\n }\n\n model.__viewId = view.__id = viewId;\n view.__alive = true;\n view.__model = model;\n view.group.__ecComponentInfo = {\n mainType: model.mainType,\n index: model.componentIndex\n };\n !isComponent && scheduler.prepareView(view, model, ecModel, api);\n }\n\n for (var i = 0; i < viewList.length;) {\n var view = viewList[i];\n\n if (!view.__alive) {\n !isComponent && view.renderTask.dispose();\n zr.remove(view.group);\n view.dispose(ecModel, api);\n viewList.splice(i, 1);\n delete viewMap[view.__id];\n view.__id = view.group.__ecComponentInfo = null;\n } else {\n i++;\n }\n }\n} // /**\n// * Encode visual infomation from data after data processing\n// *\n// * @param {module:echarts/model/Global} ecModel\n// * @param {object} layout\n// * @param {boolean} [layoutFilter] `true`: only layout,\n// * `false`: only not layout,\n// * `null`/`undefined`: all.\n// * @param {string} taskBaseTag\n// * @private\n// */\n// function startVisualEncoding(ecIns, ecModel, api, payload, layoutFilter) {\n// each(visualFuncs, function (visual, index) {\n// var isLayout = visual.isLayout;\n// if (layoutFilter == null\n// || (layoutFilter === false && !isLayout)\n// || (layoutFilter === true && isLayout)\n// ) {\n// visual.func(ecModel, api, payload);\n// }\n// });\n// }\n\n\nfunction clearColorPalette(ecModel) {\n ecModel.clearColorPalette();\n ecModel.eachSeries(function (seriesModel) {\n seriesModel.clearColorPalette();\n });\n}\n\nfunction render(ecIns, ecModel, api, payload) {\n renderComponents(ecIns, ecModel, api, payload);\n each(ecIns._chartsViews, function (chart) {\n chart.__alive = false;\n });\n renderSeries(ecIns, ecModel, api, payload); // Remove groups of unrendered charts\n\n each(ecIns._chartsViews, function (chart) {\n if (!chart.__alive) {\n chart.remove(ecModel, api);\n }\n });\n}\n\nfunction renderComponents(ecIns, ecModel, api, payload, dirtyList) {\n each(dirtyList || ecIns._componentsViews, function (componentView) {\n var componentModel = componentView.__model;\n componentView.render(componentModel, ecModel, api, payload);\n updateZ(componentModel, componentView);\n });\n}\n/**\n * Render each chart and component\n * @private\n */\n\n\nfunction renderSeries(ecIns, ecModel, api, payload, dirtyMap) {\n // Render all charts\n var scheduler = ecIns._scheduler;\n var unfinished;\n ecModel.eachSeries(function (seriesModel) {\n var chartView = ecIns._chartsMap[seriesModel.__viewId];\n chartView.__alive = true;\n var renderTask = chartView.renderTask;\n scheduler.updatePayload(renderTask, payload);\n\n if (dirtyMap && dirtyMap.get(seriesModel.uid)) {\n renderTask.dirty();\n }\n\n unfinished |= renderTask.perform(scheduler.getPerformArgs(renderTask));\n chartView.group.silent = !!seriesModel.get('silent');\n updateZ(seriesModel, chartView);\n updateBlend(seriesModel, chartView);\n });\n scheduler.unfinished |= unfinished; // If use hover layer\n\n updateHoverLayerStatus(ecIns._zr, ecModel); // Add aria\n\n aria(ecIns._zr.dom, ecModel);\n}\n\nfunction performPostUpdateFuncs(ecModel, api) {\n each(postUpdateFuncs, function (func) {\n func(ecModel, api);\n });\n}\n\nvar MOUSE_EVENT_NAMES = ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove', 'mousedown', 'mouseup', 'globalout', 'contextmenu'];\n/**\n * @private\n */\n\nechartsProto._initEvents = function () {\n each(MOUSE_EVENT_NAMES, function (eveName) {\n var handler = function (e) {\n var ecModel = this.getModel();\n var el = e.target;\n var params;\n var isGlobalOut = eveName === 'globalout'; // no e.target when 'globalout'.\n\n if (isGlobalOut) {\n params = {};\n } else if (el && el.dataIndex != null) {\n var dataModel = el.dataModel || ecModel.getSeriesByIndex(el.seriesIndex);\n params = dataModel && dataModel.getDataParams(el.dataIndex, el.dataType, el) || {};\n } // If element has custom eventData of components\n else if (el && el.eventData) {\n params = zrUtil.extend({}, el.eventData);\n } // Contract: if params prepared in mouse event,\n // these properties must be specified:\n // {\n // componentType: string (component main type)\n // componentIndex: number\n // }\n // Otherwise event query can not work.\n\n\n if (params) {\n var componentType = params.componentType;\n var componentIndex = params.componentIndex; // Special handling for historic reason: when trigger by\n // markLine/markPoint/markArea, the componentType is\n // 'markLine'/'markPoint'/'markArea', but we should better\n // enable them to be queried by seriesIndex, since their\n // option is set in each series.\n\n if (componentType === 'markLine' || componentType === 'markPoint' || componentType === 'markArea') {\n componentType = 'series';\n componentIndex = params.seriesIndex;\n }\n\n var model = componentType && componentIndex != null && ecModel.getComponent(componentType, componentIndex);\n var view = model && this[model.mainType === 'series' ? '_chartsMap' : '_componentsMap'][model.__viewId];\n params.event = e;\n params.type = eveName;\n this._ecEventProcessor.eventInfo = {\n targetEl: el,\n packedEvent: params,\n model: model,\n view: view\n };\n this.trigger(eveName, params);\n }\n }; // Consider that some component (like tooltip, brush, ...)\n // register zr event handler, but user event handler might\n // do anything, such as call `setOption` or `dispatchAction`,\n // which probably update any of the content and probably\n // cause problem if it is called previous other inner handlers.\n\n\n handler.zrEventfulCallAtLast = true;\n\n this._zr.on(eveName, handler, this);\n }, this);\n each(eventActionMap, function (actionType, eventType) {\n this._messageCenter.on(eventType, function (event) {\n this.trigger(eventType, event);\n }, this);\n }, this);\n};\n/**\n * @return {boolean}\n */\n\n\nechartsProto.isDisposed = function () {\n return this._disposed;\n};\n/**\n * Clear\n */\n\n\nechartsProto.clear = function () {\n this.setOption({\n series: []\n }, true);\n};\n/**\n * Dispose instance\n */\n\n\nechartsProto.dispose = function () {\n if (this._disposed) {\n return;\n }\n\n this._disposed = true;\n modelUtil.setAttribute(this.getDom(), DOM_ATTRIBUTE_KEY, '');\n var api = this._api;\n var ecModel = this._model;\n each(this._componentsViews, function (component) {\n component.dispose(ecModel, api);\n });\n each(this._chartsViews, function (chart) {\n chart.dispose(ecModel, api);\n }); // Dispose after all views disposed\n\n this._zr.dispose();\n\n delete instances[this.id];\n};\n\nzrUtil.mixin(ECharts, Eventful);\n\nfunction updateHoverLayerStatus(zr, ecModel) {\n var storage = zr.storage;\n var elCount = 0;\n storage.traverse(function (el) {\n if (!el.isGroup) {\n elCount++;\n }\n });\n\n if (elCount > ecModel.get('hoverLayerThreshold') && !env.node) {\n storage.traverse(function (el) {\n if (!el.isGroup) {\n // Don't switch back.\n el.useHoverLayer = true;\n }\n });\n }\n}\n/**\n * Update chart progressive and blend.\n * @param {module:echarts/model/Series|module:echarts/model/Component} model\n * @param {module:echarts/view/Component|module:echarts/view/Chart} view\n */\n\n\nfunction updateBlend(seriesModel, chartView) {\n var blendMode = seriesModel.get('blendMode') || null;\n chartView.group.traverse(function (el) {\n // FIXME marker and other components\n if (!el.isGroup) {\n // Only set if blendMode is changed. In case element is incremental and don't wan't to rerender.\n if (el.style.blend !== blendMode) {\n el.setStyle('blend', blendMode);\n }\n }\n\n if (el.eachPendingDisplayable) {\n el.eachPendingDisplayable(function (displayable) {\n displayable.setStyle('blend', blendMode);\n });\n }\n });\n}\n/**\n * @param {module:echarts/model/Series|module:echarts/model/Component} model\n * @param {module:echarts/view/Component|module:echarts/view/Chart} view\n */\n\n\nfunction updateZ(model, view) {\n var z = model.get('z');\n var zlevel = model.get('zlevel'); // Set z and zlevel\n\n view.group.traverse(function (el) {\n if (el.type !== 'group') {\n z != null && (el.z = z);\n zlevel != null && (el.zlevel = zlevel);\n }\n });\n}\n\nfunction createExtensionAPI(ecInstance) {\n var coordSysMgr = ecInstance._coordSysMgr;\n return zrUtil.extend(new ExtensionAPI(ecInstance), {\n // Inject methods\n getCoordinateSystems: zrUtil.bind(coordSysMgr.getCoordinateSystems, coordSysMgr),\n getComponentByElement: function (el) {\n while (el) {\n var modelInfo = el.__ecComponentInfo;\n\n if (modelInfo != null) {\n return ecInstance._model.getComponent(modelInfo.mainType, modelInfo.index);\n }\n\n el = el.parent;\n }\n }\n });\n}\n/**\n * @class\n * Usage of query:\n * `chart.on('click', query, handler);`\n * The `query` can be:\n * + The component type query string, only `mainType` or `mainType.subType`,\n * like: 'xAxis', 'series', 'xAxis.category' or 'series.line'.\n * + The component query object, like:\n * `{seriesIndex: 2}`, `{seriesName: 'xx'}`, `{seriesId: 'some'}`,\n * `{xAxisIndex: 2}`, `{xAxisName: 'xx'}`, `{xAxisId: 'some'}`.\n * + The data query object, like:\n * `{dataIndex: 123}`, `{dataType: 'link'}`, `{name: 'some'}`.\n * + The other query object (cmponent customized query), like:\n * `{element: 'some'}` (only available in custom series).\n *\n * Caveat: If a prop in the `query` object is `null/undefined`, it is the\n * same as there is no such prop in the `query` object.\n */\n\n\nfunction EventProcessor() {\n // These info required: targetEl, packedEvent, model, view\n this.eventInfo;\n}\n\nEventProcessor.prototype = {\n constructor: EventProcessor,\n normalizeQuery: function (query) {\n var cptQuery = {};\n var dataQuery = {};\n var otherQuery = {}; // `query` is `mainType` or `mainType.subType` of component.\n\n if (zrUtil.isString(query)) {\n var condCptType = parseClassType(query); // `.main` and `.sub` may be ''.\n\n cptQuery.mainType = condCptType.main || null;\n cptQuery.subType = condCptType.sub || null;\n } // `query` is an object, convert to {mainType, index, name, id}.\n else {\n // `xxxIndex`, `xxxName`, `xxxId`, `name`, `dataIndex`, `dataType` is reserved,\n // can not be used in `compomentModel.filterForExposedEvent`.\n var suffixes = ['Index', 'Name', 'Id'];\n var dataKeys = {\n name: 1,\n dataIndex: 1,\n dataType: 1\n };\n zrUtil.each(query, function (val, key) {\n var reserved = false;\n\n for (var i = 0; i < suffixes.length; i++) {\n var propSuffix = suffixes[i];\n var suffixPos = key.lastIndexOf(propSuffix);\n\n if (suffixPos > 0 && suffixPos === key.length - propSuffix.length) {\n var mainType = key.slice(0, suffixPos); // Consider `dataIndex`.\n\n if (mainType !== 'data') {\n cptQuery.mainType = mainType;\n cptQuery[propSuffix.toLowerCase()] = val;\n reserved = true;\n }\n }\n }\n\n if (dataKeys.hasOwnProperty(key)) {\n dataQuery[key] = val;\n reserved = true;\n }\n\n if (!reserved) {\n otherQuery[key] = val;\n }\n });\n }\n\n return {\n cptQuery: cptQuery,\n dataQuery: dataQuery,\n otherQuery: otherQuery\n };\n },\n filter: function (eventType, query, args) {\n // They should be assigned before each trigger call.\n var eventInfo = this.eventInfo;\n\n if (!eventInfo) {\n return true;\n }\n\n var targetEl = eventInfo.targetEl;\n var packedEvent = eventInfo.packedEvent;\n var model = eventInfo.model;\n var view = eventInfo.view; // For event like 'globalout'.\n\n if (!model || !view) {\n return true;\n }\n\n var cptQuery = query.cptQuery;\n var dataQuery = query.dataQuery;\n return check(cptQuery, model, 'mainType') && check(cptQuery, model, 'subType') && check(cptQuery, model, 'index', 'componentIndex') && check(cptQuery, model, 'name') && check(cptQuery, model, 'id') && check(dataQuery, packedEvent, 'name') && check(dataQuery, packedEvent, 'dataIndex') && check(dataQuery, packedEvent, 'dataType') && (!view.filterForExposedEvent || view.filterForExposedEvent(eventType, query.otherQuery, targetEl, packedEvent));\n\n function check(query, host, prop, propOnHost) {\n return query[prop] == null || host[propOnHost || prop] === query[prop];\n }\n },\n afterTrigger: function () {\n // Make sure the eventInfo wont be used in next trigger.\n this.eventInfo = null;\n }\n};\n/**\n * @type {Object} key: actionType.\n * @inner\n */\n\nvar actions = {};\n/**\n * Map eventType to actionType\n * @type {Object}\n */\n\nvar eventActionMap = {};\n/**\n * Data processor functions of each stage\n * @type {Array.<Object.<string, Function>>}\n * @inner\n */\n\nvar dataProcessorFuncs = [];\n/**\n * @type {Array.<Function>}\n * @inner\n */\n\nvar optionPreprocessorFuncs = [];\n/**\n * @type {Array.<Function>}\n * @inner\n */\n\nvar postUpdateFuncs = [];\n/**\n * Visual encoding functions of each stage\n * @type {Array.<Object.<string, Function>>}\n */\n\nvar visualFuncs = [];\n/**\n * Theme storage\n * @type {Object.<key, Object>}\n */\n\nvar themeStorage = {};\n/**\n * Loading effects\n */\n\nvar loadingEffects = {};\nvar instances = {};\nvar connectedGroups = {};\nvar idBase = new Date() - 0;\nvar groupIdBase = new Date() - 0;\nvar DOM_ATTRIBUTE_KEY = '_echarts_instance_';\n\nfunction enableConnect(chart) {\n var STATUS_PENDING = 0;\n var STATUS_UPDATING = 1;\n var STATUS_UPDATED = 2;\n var STATUS_KEY = '__connectUpdateStatus';\n\n function updateConnectedChartsStatus(charts, status) {\n for (var i = 0; i < charts.length; i++) {\n var otherChart = charts[i];\n otherChart[STATUS_KEY] = status;\n }\n }\n\n each(eventActionMap, function (actionType, eventType) {\n chart._messageCenter.on(eventType, function (event) {\n if (connectedGroups[chart.group] && chart[STATUS_KEY] !== STATUS_PENDING) {\n if (event && event.escapeConnect) {\n return;\n }\n\n var action = chart.makeActionFromEvent(event);\n var otherCharts = [];\n each(instances, function (otherChart) {\n if (otherChart !== chart && otherChart.group === chart.group) {\n otherCharts.push(otherChart);\n }\n });\n updateConnectedChartsStatus(otherCharts, STATUS_PENDING);\n each(otherCharts, function (otherChart) {\n if (otherChart[STATUS_KEY] !== STATUS_UPDATING) {\n otherChart.dispatchAction(action);\n }\n });\n updateConnectedChartsStatus(otherCharts, STATUS_UPDATED);\n }\n });\n });\n}\n/**\n * @param {HTMLElement} dom\n * @param {Object} [theme]\n * @param {Object} opts\n * @param {number} [opts.devicePixelRatio] Use window.devicePixelRatio by default\n * @param {string} [opts.renderer] Currently only 'canvas' is supported.\n * @param {number} [opts.width] Use clientWidth of the input `dom` by default.\n * Can be 'auto' (the same as null/undefined)\n * @param {number} [opts.height] Use clientHeight of the input `dom` by default.\n * Can be 'auto' (the same as null/undefined)\n */\n\n\nfunction init(dom, theme, opts) {\n var existInstance = getInstanceByDom(dom);\n\n if (existInstance) {\n return existInstance;\n }\n\n var chart = new ECharts(dom, theme, opts);\n chart.id = 'ec_' + idBase++;\n instances[chart.id] = chart;\n modelUtil.setAttribute(dom, DOM_ATTRIBUTE_KEY, chart.id);\n enableConnect(chart);\n return chart;\n}\n/**\n * @return {string|Array.<module:echarts~ECharts>} groupId\n */\n\n\nfunction connect(groupId) {\n // Is array of charts\n if (zrUtil.isArray(groupId)) {\n var charts = groupId;\n groupId = null; // If any chart has group\n\n each(charts, function (chart) {\n if (chart.group != null) {\n groupId = chart.group;\n }\n });\n groupId = groupId || 'g_' + groupIdBase++;\n each(charts, function (chart) {\n chart.group = groupId;\n });\n }\n\n connectedGroups[groupId] = true;\n return groupId;\n}\n/**\n * @DEPRECATED\n * @return {string} groupId\n */\n\n\nfunction disConnect(groupId) {\n connectedGroups[groupId] = false;\n}\n/**\n * @return {string} groupId\n */\n\n\nvar disconnect = disConnect;\n/**\n * Dispose a chart instance\n * @param {module:echarts~ECharts|HTMLDomElement|string} chart\n */\n\nfunction dispose(chart) {\n if (typeof chart === 'string') {\n chart = instances[chart];\n } else if (!(chart instanceof ECharts)) {\n // Try to treat as dom\n chart = getInstanceByDom(chart);\n }\n\n if (chart instanceof ECharts && !chart.isDisposed()) {\n chart.dispose();\n }\n}\n/**\n * @param {HTMLElement} dom\n * @return {echarts~ECharts}\n */\n\n\nfunction getInstanceByDom(dom) {\n return instances[modelUtil.getAttribute(dom, DOM_ATTRIBUTE_KEY)];\n}\n/**\n * @param {string} key\n * @return {echarts~ECharts}\n */\n\n\nfunction getInstanceById(key) {\n return instances[key];\n}\n/**\n * Register theme\n */\n\n\nfunction registerTheme(name, theme) {\n themeStorage[name] = theme;\n}\n/**\n * Register option preprocessor\n * @param {Function} preprocessorFunc\n */\n\n\nfunction registerPreprocessor(preprocessorFunc) {\n optionPreprocessorFuncs.push(preprocessorFunc);\n}\n/**\n * @param {number} [priority=1000]\n * @param {Object|Function} processor\n */\n\n\nfunction registerProcessor(priority, processor) {\n normalizeRegister(dataProcessorFuncs, priority, processor, PRIORITY_PROCESSOR_FILTER);\n}\n/**\n * Register postUpdater\n * @param {Function} postUpdateFunc\n */\n\n\nfunction registerPostUpdate(postUpdateFunc) {\n postUpdateFuncs.push(postUpdateFunc);\n}\n/**\n * Usage:\n * registerAction('someAction', 'someEvent', function () { ... });\n * registerAction('someAction', function () { ... });\n * registerAction(\n * {type: 'someAction', event: 'someEvent', update: 'updateView'},\n * function () { ... }\n * );\n *\n * @param {(string|Object)} actionInfo\n * @param {string} actionInfo.type\n * @param {string} [actionInfo.event]\n * @param {string} [actionInfo.update]\n * @param {string} [eventName]\n * @param {Function} action\n */\n\n\nfunction registerAction(actionInfo, eventName, action) {\n if (typeof eventName === 'function') {\n action = eventName;\n eventName = '';\n }\n\n var actionType = isObject(actionInfo) ? actionInfo.type : [actionInfo, actionInfo = {\n event: eventName\n }][0]; // Event name is all lowercase\n\n actionInfo.event = (actionInfo.event || actionType).toLowerCase();\n eventName = actionInfo.event; // Validate action type and event name.\n\n assert(ACTION_REG.test(actionType) && ACTION_REG.test(eventName));\n\n if (!actions[actionType]) {\n actions[actionType] = {\n action: action,\n actionInfo: actionInfo\n };\n }\n\n eventActionMap[eventName] = actionType;\n}\n/**\n * @param {string} type\n * @param {*} CoordinateSystem\n */\n\n\nfunction registerCoordinateSystem(type, CoordinateSystem) {\n CoordinateSystemManager.register(type, CoordinateSystem);\n}\n/**\n * Get dimensions of specified coordinate system.\n * @param {string} type\n * @return {Array.<string|Object>}\n */\n\n\nfunction getCoordinateSystemDimensions(type) {\n var coordSysCreator = CoordinateSystemManager.get(type);\n\n if (coordSysCreator) {\n return coordSysCreator.getDimensionsInfo ? coordSysCreator.getDimensionsInfo() : coordSysCreator.dimensions.slice();\n }\n}\n/**\n * Layout is a special stage of visual encoding\n * Most visual encoding like color are common for different chart\n * But each chart has it's own layout algorithm\n *\n * @param {number} [priority=1000]\n * @param {Function} layoutTask\n */\n\n\nfunction registerLayout(priority, layoutTask) {\n normalizeRegister(visualFuncs, priority, layoutTask, PRIORITY_VISUAL_LAYOUT, 'layout');\n}\n/**\n * @param {number} [priority=3000]\n * @param {module:echarts/stream/Task} visualTask\n */\n\n\nfunction registerVisual(priority, visualTask) {\n normalizeRegister(visualFuncs, priority, visualTask, PRIORITY_VISUAL_CHART, 'visual');\n}\n/**\n * @param {Object|Function} fn: {seriesType, createOnAllSeries, performRawSeries, reset}\n */\n\n\nfunction normalizeRegister(targetList, priority, fn, defaultPriority, visualType) {\n if (isFunction(priority) || isObject(priority)) {\n fn = priority;\n priority = defaultPriority;\n }\n\n var stageHandler = Scheduler.wrapStageHandler(fn, visualType);\n stageHandler.__prio = priority;\n stageHandler.__raw = fn;\n targetList.push(stageHandler);\n return stageHandler;\n}\n/**\n * @param {string} name\n */\n\n\nfunction registerLoading(name, loadingFx) {\n loadingEffects[name] = loadingFx;\n}\n/**\n * @param {Object} opts\n * @param {string} [superClass]\n */\n\n\nfunction extendComponentModel(opts\n/*, superClass*/\n) {\n // var Clazz = ComponentModel;\n // if (superClass) {\n // var classType = parseClassType(superClass);\n // Clazz = ComponentModel.getClass(classType.main, classType.sub, true);\n // }\n return ComponentModel.extend(opts);\n}\n/**\n * @param {Object} opts\n * @param {string} [superClass]\n */\n\n\nfunction extendComponentView(opts\n/*, superClass*/\n) {\n // var Clazz = ComponentView;\n // if (superClass) {\n // var classType = parseClassType(superClass);\n // Clazz = ComponentView.getClass(classType.main, classType.sub, true);\n // }\n return ComponentView.extend(opts);\n}\n/**\n * @param {Object} opts\n * @param {string} [superClass]\n */\n\n\nfunction extendSeriesModel(opts\n/*, superClass*/\n) {\n // var Clazz = SeriesModel;\n // if (superClass) {\n // superClass = 'series.' + superClass.replace('series.', '');\n // var classType = parseClassType(superClass);\n // Clazz = ComponentModel.getClass(classType.main, classType.sub, true);\n // }\n return SeriesModel.extend(opts);\n}\n/**\n * @param {Object} opts\n * @param {string} [superClass]\n */\n\n\nfunction extendChartView(opts\n/*, superClass*/\n) {\n // var Clazz = ChartView;\n // if (superClass) {\n // superClass = superClass.replace('series.', '');\n // var classType = parseClassType(superClass);\n // Clazz = ChartView.getClass(classType.main, true);\n // }\n return ChartView.extend(opts);\n}\n/**\n * ZRender need a canvas context to do measureText.\n * But in node environment canvas may be created by node-canvas.\n * So we need to specify how to create a canvas instead of using document.createElement('canvas')\n *\n * Be careful of using it in the browser.\n *\n * @param {Function} creator\n * @example\n * var Canvas = require('canvas');\n * var echarts = require('echarts');\n * echarts.setCanvasCreator(function () {\n * // Small size is enough.\n * return new Canvas(32, 32);\n * });\n */\n\n\nfunction setCanvasCreator(creator) {\n zrUtil.$override('createCanvas', creator);\n}\n/**\n * @param {string} mapName\n * @param {Array.<Object>|Object|string} geoJson\n * @param {Object} [specialAreas]\n *\n * @example GeoJSON\n * $.get('USA.json', function (geoJson) {\n * echarts.registerMap('USA', geoJson);\n * // Or\n * echarts.registerMap('USA', {\n * geoJson: geoJson,\n * specialAreas: {}\n * })\n * });\n *\n * $.get('airport.svg', function (svg) {\n * echarts.registerMap('airport', {\n * svg: svg\n * }\n * });\n *\n * echarts.registerMap('eu', [\n * {svg: eu-topographic.svg},\n * {geoJSON: eu.json}\n * ])\n */\n\n\nfunction registerMap(mapName, geoJson, specialAreas) {\n mapDataStorage.registerMap(mapName, geoJson, specialAreas);\n}\n/**\n * @param {string} mapName\n * @return {Object}\n */\n\n\nfunction getMap(mapName) {\n // For backward compatibility, only return the first one.\n var records = mapDataStorage.retrieveMap(mapName);\n return records && records[0] && {\n geoJson: records[0].geoJSON,\n specialAreas: records[0].specialAreas\n };\n}\n\nregisterVisual(PRIORITY_VISUAL_GLOBAL, seriesColor);\nregisterPreprocessor(backwardCompat);\nregisterProcessor(PRIORITY_PROCESSOR_STATISTIC, dataStack);\nregisterLoading('default', loadingDefault); // Default actions\n\nregisterAction({\n type: 'highlight',\n event: 'highlight',\n update: 'highlight'\n}, zrUtil.noop);\nregisterAction({\n type: 'downplay',\n event: 'downplay',\n update: 'downplay'\n}, zrUtil.noop); // Default theme\n\nregisterTheme('light', lightTheme);\nregisterTheme('dark', darkTheme); // For backward compatibility, where the namespace `dataTool` will\n// be mounted on `echarts` is the extension `dataTool` is imported.\n\nvar dataTool = {};\nexports.version = version;\nexports.dependencies = dependencies;\nexports.PRIORITY = PRIORITY;\nexports.init = init;\nexports.connect = connect;\nexports.disConnect = disConnect;\nexports.disconnect = disconnect;\nexports.dispose = dispose;\nexports.getInstanceByDom = getInstanceByDom;\nexports.getInstanceById = getInstanceById;\nexports.registerTheme = registerTheme;\nexports.registerPreprocessor = registerPreprocessor;\nexports.registerProcessor = registerProcessor;\nexports.registerPostUpdate = registerPostUpdate;\nexports.registerAction = registerAction;\nexports.registerCoordinateSystem = registerCoordinateSystem;\nexports.getCoordinateSystemDimensions = getCoordinateSystemDimensions;\nexports.registerLayout = registerLayout;\nexports.registerVisual = registerVisual;\nexports.registerLoading = registerLoading;\nexports.extendComponentModel = extendComponentModel;\nexports.extendComponentView = extendComponentView;\nexports.extendSeriesModel = extendSeriesModel;\nexports.extendChartView = extendChartView;\nexports.setCanvasCreator = setCanvasCreator;\nexports.registerMap = registerMap;\nexports.getMap = getMap;\nexports.dataTool = dataTool;\nvar ___ec_export = require(\"./export\");\n(function () {\n for (var key in ___ec_export) {\n if (___ec_export.hasOwnProperty(key)) {\n exports[key] = ___ec_export[key];\n }\n }\n})();","var ArrayCtor = typeof Float32Array === 'undefined' ? Array : Float32Array;\n/**\n * 创建一个向量\n * @param {number} [x=0]\n * @param {number} [y=0]\n * @return {Vector2}\n */\n\nfunction create(x, y) {\n var out = new ArrayCtor(2);\n\n if (x == null) {\n x = 0;\n }\n\n if (y == null) {\n y = 0;\n }\n\n out[0] = x;\n out[1] = y;\n return out;\n}\n/**\n * 复制向量数据\n * @param {Vector2} out\n * @param {Vector2} v\n * @return {Vector2}\n */\n\n\nfunction copy(out, v) {\n out[0] = v[0];\n out[1] = v[1];\n return out;\n}\n/**\n * 克隆一个向量\n * @param {Vector2} v\n * @return {Vector2}\n */\n\n\nfunction clone(v) {\n var out = new ArrayCtor(2);\n out[0] = v[0];\n out[1] = v[1];\n return out;\n}\n/**\n * 设置向量的两个项\n * @param {Vector2} out\n * @param {number} a\n * @param {number} b\n * @return {Vector2} 结果\n */\n\n\nfunction set(out, a, b) {\n out[0] = a;\n out[1] = b;\n return out;\n}\n/**\n * 向量相加\n * @param {Vector2} out\n * @param {Vector2} v1\n * @param {Vector2} v2\n */\n\n\nfunction add(out, v1, v2) {\n out[0] = v1[0] + v2[0];\n out[1] = v1[1] + v2[1];\n return out;\n}\n/**\n * 向量缩放后相加\n * @param {Vector2} out\n * @param {Vector2} v1\n * @param {Vector2} v2\n * @param {number} a\n */\n\n\nfunction scaleAndAdd(out, v1, v2, a) {\n out[0] = v1[0] + v2[0] * a;\n out[1] = v1[1] + v2[1] * a;\n return out;\n}\n/**\n * 向量相减\n * @param {Vector2} out\n * @param {Vector2} v1\n * @param {Vector2} v2\n */\n\n\nfunction sub(out, v1, v2) {\n out[0] = v1[0] - v2[0];\n out[1] = v1[1] - v2[1];\n return out;\n}\n/**\n * 向量长度\n * @param {Vector2} v\n * @return {number}\n */\n\n\nfunction len(v) {\n return Math.sqrt(lenSquare(v));\n}\n\nvar length = len; // jshint ignore:line\n\n/**\n * 向量长度平方\n * @param {Vector2} v\n * @return {number}\n */\n\nfunction lenSquare(v) {\n return v[0] * v[0] + v[1] * v[1];\n}\n\nvar lengthSquare = lenSquare;\n/**\n * 向量乘法\n * @param {Vector2} out\n * @param {Vector2} v1\n * @param {Vector2} v2\n */\n\nfunction mul(out, v1, v2) {\n out[0] = v1[0] * v2[0];\n out[1] = v1[1] * v2[1];\n return out;\n}\n/**\n * 向量除法\n * @param {Vector2} out\n * @param {Vector2} v1\n * @param {Vector2} v2\n */\n\n\nfunction div(out, v1, v2) {\n out[0] = v1[0] / v2[0];\n out[1] = v1[1] / v2[1];\n return out;\n}\n/**\n * 向量点乘\n * @param {Vector2} v1\n * @param {Vector2} v2\n * @return {number}\n */\n\n\nfunction dot(v1, v2) {\n return v1[0] * v2[0] + v1[1] * v2[1];\n}\n/**\n * 向量缩放\n * @param {Vector2} out\n * @param {Vector2} v\n * @param {number} s\n */\n\n\nfunction scale(out, v, s) {\n out[0] = v[0] * s;\n out[1] = v[1] * s;\n return out;\n}\n/**\n * 向量归一化\n * @param {Vector2} out\n * @param {Vector2} v\n */\n\n\nfunction normalize(out, v) {\n var d = len(v);\n\n if (d === 0) {\n out[0] = 0;\n out[1] = 0;\n } else {\n out[0] = v[0] / d;\n out[1] = v[1] / d;\n }\n\n return out;\n}\n/**\n * 计算向量间距离\n * @param {Vector2} v1\n * @param {Vector2} v2\n * @return {number}\n */\n\n\nfunction distance(v1, v2) {\n return Math.sqrt((v1[0] - v2[0]) * (v1[0] - v2[0]) + (v1[1] - v2[1]) * (v1[1] - v2[1]));\n}\n\nvar dist = distance;\n/**\n * 向量距离平方\n * @param {Vector2} v1\n * @param {Vector2} v2\n * @return {number}\n */\n\nfunction distanceSquare(v1, v2) {\n return (v1[0] - v2[0]) * (v1[0] - v2[0]) + (v1[1] - v2[1]) * (v1[1] - v2[1]);\n}\n\nvar distSquare = distanceSquare;\n/**\n * 求负向量\n * @param {Vector2} out\n * @param {Vector2} v\n */\n\nfunction negate(out, v) {\n out[0] = -v[0];\n out[1] = -v[1];\n return out;\n}\n/**\n * 插值两个点\n * @param {Vector2} out\n * @param {Vector2} v1\n * @param {Vector2} v2\n * @param {number} t\n */\n\n\nfunction lerp(out, v1, v2, t) {\n out[0] = v1[0] + t * (v2[0] - v1[0]);\n out[1] = v1[1] + t * (v2[1] - v1[1]);\n return out;\n}\n/**\n * 矩阵左乘向量\n * @param {Vector2} out\n * @param {Vector2} v\n * @param {Vector2} m\n */\n\n\nfunction applyTransform(out, v, m) {\n var x = v[0];\n var y = v[1];\n out[0] = m[0] * x + m[2] * y + m[4];\n out[1] = m[1] * x + m[3] * y + m[5];\n return out;\n}\n/**\n * 求两个向量最小值\n * @param {Vector2} out\n * @param {Vector2} v1\n * @param {Vector2} v2\n */\n\n\nfunction min(out, v1, v2) {\n out[0] = Math.min(v1[0], v2[0]);\n out[1] = Math.min(v1[1], v2[1]);\n return out;\n}\n/**\n * 求两个向量最大值\n * @param {Vector2} out\n * @param {Vector2} v1\n * @param {Vector2} v2\n */\n\n\nfunction max(out, v1, v2) {\n out[0] = Math.max(v1[0], v2[0]);\n out[1] = Math.max(v1[1], v2[1]);\n return out;\n}\n\nexports.create = create;\nexports.copy = copy;\nexports.clone = clone;\nexports.set = set;\nexports.add = add;\nexports.scaleAndAdd = scaleAndAdd;\nexports.sub = sub;\nexports.len = len;\nexports.length = length;\nexports.lenSquare = lenSquare;\nexports.lengthSquare = lengthSquare;\nexports.mul = mul;\nexports.div = div;\nexports.dot = dot;\nexports.scale = scale;\nexports.normalize = normalize;\nexports.distance = distance;\nexports.dist = dist;\nexports.distanceSquare = distanceSquare;\nexports.distSquare = distSquare;\nexports.negate = negate;\nexports.lerp = lerp;\nexports.applyTransform = applyTransform;\nexports.min = min;\nexports.max = max;","var root = require('./_root');\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\nmodule.exports = now;\n","var LRU = require(\"../core/LRU\");\n\nvar kCSSColorTable = {\n 'transparent': [0, 0, 0, 0],\n 'aliceblue': [240, 248, 255, 1],\n 'antiquewhite': [250, 235, 215, 1],\n 'aqua': [0, 255, 255, 1],\n 'aquamarine': [127, 255, 212, 1],\n 'azure': [240, 255, 255, 1],\n 'beige': [245, 245, 220, 1],\n 'bisque': [255, 228, 196, 1],\n 'black': [0, 0, 0, 1],\n 'blanchedalmond': [255, 235, 205, 1],\n 'blue': [0, 0, 255, 1],\n 'blueviolet': [138, 43, 226, 1],\n 'brown': [165, 42, 42, 1],\n 'burlywood': [222, 184, 135, 1],\n 'cadetblue': [95, 158, 160, 1],\n 'chartreuse': [127, 255, 0, 1],\n 'chocolate': [210, 105, 30, 1],\n 'coral': [255, 127, 80, 1],\n 'cornflowerblue': [100, 149, 237, 1],\n 'cornsilk': [255, 248, 220, 1],\n 'crimson': [220, 20, 60, 1],\n 'cyan': [0, 255, 255, 1],\n 'darkblue': [0, 0, 139, 1],\n 'darkcyan': [0, 139, 139, 1],\n 'darkgoldenrod': [184, 134, 11, 1],\n 'darkgray': [169, 169, 169, 1],\n 'darkgreen': [0, 100, 0, 1],\n 'darkgrey': [169, 169, 169, 1],\n 'darkkhaki': [189, 183, 107, 1],\n 'darkmagenta': [139, 0, 139, 1],\n 'darkolivegreen': [85, 107, 47, 1],\n 'darkorange': [255, 140, 0, 1],\n 'darkorchid': [153, 50, 204, 1],\n 'darkred': [139, 0, 0, 1],\n 'darksalmon': [233, 150, 122, 1],\n 'darkseagreen': [143, 188, 143, 1],\n 'darkslateblue': [72, 61, 139, 1],\n 'darkslategray': [47, 79, 79, 1],\n 'darkslategrey': [47, 79, 79, 1],\n 'darkturquoise': [0, 206, 209, 1],\n 'darkviolet': [148, 0, 211, 1],\n 'deeppink': [255, 20, 147, 1],\n 'deepskyblue': [0, 191, 255, 1],\n 'dimgray': [105, 105, 105, 1],\n 'dimgrey': [105, 105, 105, 1],\n 'dodgerblue': [30, 144, 255, 1],\n 'firebrick': [178, 34, 34, 1],\n 'floralwhite': [255, 250, 240, 1],\n 'forestgreen': [34, 139, 34, 1],\n 'fuchsia': [255, 0, 255, 1],\n 'gainsboro': [220, 220, 220, 1],\n 'ghostwhite': [248, 248, 255, 1],\n 'gold': [255, 215, 0, 1],\n 'goldenrod': [218, 165, 32, 1],\n 'gray': [128, 128, 128, 1],\n 'green': [0, 128, 0, 1],\n 'greenyellow': [173, 255, 47, 1],\n 'grey': [128, 128, 128, 1],\n 'honeydew': [240, 255, 240, 1],\n 'hotpink': [255, 105, 180, 1],\n 'indianred': [205, 92, 92, 1],\n 'indigo': [75, 0, 130, 1],\n 'ivory': [255, 255, 240, 1],\n 'khaki': [240, 230, 140, 1],\n 'lavender': [230, 230, 250, 1],\n 'lavenderblush': [255, 240, 245, 1],\n 'lawngreen': [124, 252, 0, 1],\n 'lemonchiffon': [255, 250, 205, 1],\n 'lightblue': [173, 216, 230, 1],\n 'lightcoral': [240, 128, 128, 1],\n 'lightcyan': [224, 255, 255, 1],\n 'lightgoldenrodyellow': [250, 250, 210, 1],\n 'lightgray': [211, 211, 211, 1],\n 'lightgreen': [144, 238, 144, 1],\n 'lightgrey': [211, 211, 211, 1],\n 'lightpink': [255, 182, 193, 1],\n 'lightsalmon': [255, 160, 122, 1],\n 'lightseagreen': [32, 178, 170, 1],\n 'lightskyblue': [135, 206, 250, 1],\n 'lightslategray': [119, 136, 153, 1],\n 'lightslategrey': [119, 136, 153, 1],\n 'lightsteelblue': [176, 196, 222, 1],\n 'lightyellow': [255, 255, 224, 1],\n 'lime': [0, 255, 0, 1],\n 'limegreen': [50, 205, 50, 1],\n 'linen': [250, 240, 230, 1],\n 'magenta': [255, 0, 255, 1],\n 'maroon': [128, 0, 0, 1],\n 'mediumaquamarine': [102, 205, 170, 1],\n 'mediumblue': [0, 0, 205, 1],\n 'mediumorchid': [186, 85, 211, 1],\n 'mediumpurple': [147, 112, 219, 1],\n 'mediumseagreen': [60, 179, 113, 1],\n 'mediumslateblue': [123, 104, 238, 1],\n 'mediumspringgreen': [0, 250, 154, 1],\n 'mediumturquoise': [72, 209, 204, 1],\n 'mediumvioletred': [199, 21, 133, 1],\n 'midnightblue': [25, 25, 112, 1],\n 'mintcream': [245, 255, 250, 1],\n 'mistyrose': [255, 228, 225, 1],\n 'moccasin': [255, 228, 181, 1],\n 'navajowhite': [255, 222, 173, 1],\n 'navy': [0, 0, 128, 1],\n 'oldlace': [253, 245, 230, 1],\n 'olive': [128, 128, 0, 1],\n 'olivedrab': [107, 142, 35, 1],\n 'orange': [255, 165, 0, 1],\n 'orangered': [255, 69, 0, 1],\n 'orchid': [218, 112, 214, 1],\n 'palegoldenrod': [238, 232, 170, 1],\n 'palegreen': [152, 251, 152, 1],\n 'paleturquoise': [175, 238, 238, 1],\n 'palevioletred': [219, 112, 147, 1],\n 'papayawhip': [255, 239, 213, 1],\n 'peachpuff': [255, 218, 185, 1],\n 'peru': [205, 133, 63, 1],\n 'pink': [255, 192, 203, 1],\n 'plum': [221, 160, 221, 1],\n 'powderblue': [176, 224, 230, 1],\n 'purple': [128, 0, 128, 1],\n 'red': [255, 0, 0, 1],\n 'rosybrown': [188, 143, 143, 1],\n 'royalblue': [65, 105, 225, 1],\n 'saddlebrown': [139, 69, 19, 1],\n 'salmon': [250, 128, 114, 1],\n 'sandybrown': [244, 164, 96, 1],\n 'seagreen': [46, 139, 87, 1],\n 'seashell': [255, 245, 238, 1],\n 'sienna': [160, 82, 45, 1],\n 'silver': [192, 192, 192, 1],\n 'skyblue': [135, 206, 235, 1],\n 'slateblue': [106, 90, 205, 1],\n 'slategray': [112, 128, 144, 1],\n 'slategrey': [112, 128, 144, 1],\n 'snow': [255, 250, 250, 1],\n 'springgreen': [0, 255, 127, 1],\n 'steelblue': [70, 130, 180, 1],\n 'tan': [210, 180, 140, 1],\n 'teal': [0, 128, 128, 1],\n 'thistle': [216, 191, 216, 1],\n 'tomato': [255, 99, 71, 1],\n 'turquoise': [64, 224, 208, 1],\n 'violet': [238, 130, 238, 1],\n 'wheat': [245, 222, 179, 1],\n 'white': [255, 255, 255, 1],\n 'whitesmoke': [245, 245, 245, 1],\n 'yellow': [255, 255, 0, 1],\n 'yellowgreen': [154, 205, 50, 1]\n};\n\nfunction clampCssByte(i) {\n // Clamp to integer 0 .. 255.\n i = Math.round(i); // Seems to be what Chrome does (vs truncation).\n\n return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clampCssAngle(i) {\n // Clamp to integer 0 .. 360.\n i = Math.round(i); // Seems to be what Chrome does (vs truncation).\n\n return i < 0 ? 0 : i > 360 ? 360 : i;\n}\n\nfunction clampCssFloat(f) {\n // Clamp to float 0.0 .. 1.0.\n return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parseCssInt(str) {\n // int or percentage.\n if (str.length && str.charAt(str.length - 1) === '%') {\n return clampCssByte(parseFloat(str) / 100 * 255);\n }\n\n return clampCssByte(parseInt(str, 10));\n}\n\nfunction parseCssFloat(str) {\n // float or percentage.\n if (str.length && str.charAt(str.length - 1) === '%') {\n return clampCssFloat(parseFloat(str) / 100);\n }\n\n return clampCssFloat(parseFloat(str));\n}\n\nfunction cssHueToRgb(m1, m2, h) {\n if (h < 0) {\n h += 1;\n } else if (h > 1) {\n h -= 1;\n }\n\n if (h * 6 < 1) {\n return m1 + (m2 - m1) * h * 6;\n }\n\n if (h * 2 < 1) {\n return m2;\n }\n\n if (h * 3 < 2) {\n return m1 + (m2 - m1) * (2 / 3 - h) * 6;\n }\n\n return m1;\n}\n\nfunction lerpNumber(a, b, p) {\n return a + (b - a) * p;\n}\n\nfunction setRgba(out, r, g, b, a) {\n out[0] = r;\n out[1] = g;\n out[2] = b;\n out[3] = a;\n return out;\n}\n\nfunction copyRgba(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n\nvar colorCache = new LRU(20);\nvar lastRemovedArr = null;\n\nfunction putToCache(colorStr, rgbaArr) {\n // Reuse removed array\n if (lastRemovedArr) {\n copyRgba(lastRemovedArr, rgbaArr);\n }\n\n lastRemovedArr = colorCache.put(colorStr, lastRemovedArr || rgbaArr.slice());\n}\n/**\n * @param {string} colorStr\n * @param {Array.<number>} out\n * @return {Array.<number>}\n * @memberOf module:zrender/util/color\n */\n\n\nfunction parse(colorStr, rgbaArr) {\n if (!colorStr) {\n return;\n }\n\n rgbaArr = rgbaArr || [];\n var cached = colorCache.get(colorStr);\n\n if (cached) {\n return copyRgba(rgbaArr, cached);\n } // colorStr may be not string\n\n\n colorStr = colorStr + ''; // Remove all whitespace, not compliant, but should just be more accepting.\n\n var str = colorStr.replace(/ /g, '').toLowerCase(); // Color keywords (and transparent) lookup.\n\n if (str in kCSSColorTable) {\n copyRgba(rgbaArr, kCSSColorTable[str]);\n putToCache(colorStr, rgbaArr);\n return rgbaArr;\n } // #abc and #abc123 syntax.\n\n\n if (str.charAt(0) === '#') {\n if (str.length === 4) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n\n if (!(iv >= 0 && iv <= 0xfff)) {\n setRgba(rgbaArr, 0, 0, 0, 1);\n return; // Covers NaN.\n }\n\n setRgba(rgbaArr, (iv & 0xf00) >> 4 | (iv & 0xf00) >> 8, iv & 0xf0 | (iv & 0xf0) >> 4, iv & 0xf | (iv & 0xf) << 4, 1);\n putToCache(colorStr, rgbaArr);\n return rgbaArr;\n } else if (str.length === 7) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n\n if (!(iv >= 0 && iv <= 0xffffff)) {\n setRgba(rgbaArr, 0, 0, 0, 1);\n return; // Covers NaN.\n }\n\n setRgba(rgbaArr, (iv & 0xff0000) >> 16, (iv & 0xff00) >> 8, iv & 0xff, 1);\n putToCache(colorStr, rgbaArr);\n return rgbaArr;\n }\n\n return;\n }\n\n var op = str.indexOf('(');\n var ep = str.indexOf(')');\n\n if (op !== -1 && ep + 1 === str.length) {\n var fname = str.substr(0, op);\n var params = str.substr(op + 1, ep - (op + 1)).split(',');\n var alpha = 1; // To allow case fallthrough.\n\n switch (fname) {\n case 'rgba':\n if (params.length !== 4) {\n setRgba(rgbaArr, 0, 0, 0, 1);\n return;\n }\n\n alpha = parseCssFloat(params.pop());\n // jshint ignore:line\n // Fall through.\n\n case 'rgb':\n if (params.length !== 3) {\n setRgba(rgbaArr, 0, 0, 0, 1);\n return;\n }\n\n setRgba(rgbaArr, parseCssInt(params[0]), parseCssInt(params[1]), parseCssInt(params[2]), alpha);\n putToCache(colorStr, rgbaArr);\n return rgbaArr;\n\n case 'hsla':\n if (params.length !== 4) {\n setRgba(rgbaArr, 0, 0, 0, 1);\n return;\n }\n\n params[3] = parseCssFloat(params[3]);\n hsla2rgba(params, rgbaArr);\n putToCache(colorStr, rgbaArr);\n return rgbaArr;\n\n case 'hsl':\n if (params.length !== 3) {\n setRgba(rgbaArr, 0, 0, 0, 1);\n return;\n }\n\n hsla2rgba(params, rgbaArr);\n putToCache(colorStr, rgbaArr);\n return rgbaArr;\n\n default:\n return;\n }\n }\n\n setRgba(rgbaArr, 0, 0, 0, 1);\n return;\n}\n/**\n * @param {Array.<number>} hsla\n * @param {Array.<number>} rgba\n * @return {Array.<number>} rgba\n */\n\n\nfunction hsla2rgba(hsla, rgba) {\n var h = (parseFloat(hsla[0]) % 360 + 360) % 360 / 360; // 0 .. 1\n // NOTE(deanm): According to the CSS spec s/l should only be\n // percentages, but we don't bother and let float or percentage.\n\n var s = parseCssFloat(hsla[1]);\n var l = parseCssFloat(hsla[2]);\n var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n var m1 = l * 2 - m2;\n rgba = rgba || [];\n setRgba(rgba, clampCssByte(cssHueToRgb(m1, m2, h + 1 / 3) * 255), clampCssByte(cssHueToRgb(m1, m2, h) * 255), clampCssByte(cssHueToRgb(m1, m2, h - 1 / 3) * 255), 1);\n\n if (hsla.length === 4) {\n rgba[3] = hsla[3];\n }\n\n return rgba;\n}\n/**\n * @param {Array.<number>} rgba\n * @return {Array.<number>} hsla\n */\n\n\nfunction rgba2hsla(rgba) {\n if (!rgba) {\n return;\n } // RGB from 0 to 255\n\n\n var R = rgba[0] / 255;\n var G = rgba[1] / 255;\n var B = rgba[2] / 255;\n var vMin = Math.min(R, G, B); // Min. value of RGB\n\n var vMax = Math.max(R, G, B); // Max. value of RGB\n\n var delta = vMax - vMin; // Delta RGB value\n\n var L = (vMax + vMin) / 2;\n var H;\n var S; // HSL results from 0 to 1\n\n if (delta === 0) {\n H = 0;\n S = 0;\n } else {\n if (L < 0.5) {\n S = delta / (vMax + vMin);\n } else {\n S = delta / (2 - vMax - vMin);\n }\n\n var deltaR = ((vMax - R) / 6 + delta / 2) / delta;\n var deltaG = ((vMax - G) / 6 + delta / 2) / delta;\n var deltaB = ((vMax - B) / 6 + delta / 2) / delta;\n\n if (R === vMax) {\n H = deltaB - deltaG;\n } else if (G === vMax) {\n H = 1 / 3 + deltaR - deltaB;\n } else if (B === vMax) {\n H = 2 / 3 + deltaG - deltaR;\n }\n\n if (H < 0) {\n H += 1;\n }\n\n if (H > 1) {\n H -= 1;\n }\n }\n\n var hsla = [H * 360, S, L];\n\n if (rgba[3] != null) {\n hsla.push(rgba[3]);\n }\n\n return hsla;\n}\n/**\n * @param {string} color\n * @param {number} level\n * @return {string}\n * @memberOf module:zrender/util/color\n */\n\n\nfunction lift(color, level) {\n var colorArr = parse(color);\n\n if (colorArr) {\n for (var i = 0; i < 3; i++) {\n if (level < 0) {\n colorArr[i] = colorArr[i] * (1 - level) | 0;\n } else {\n colorArr[i] = (255 - colorArr[i]) * level + colorArr[i] | 0;\n }\n\n if (colorArr[i] > 255) {\n colorArr[i] = 255;\n } else if (color[i] < 0) {\n colorArr[i] = 0;\n }\n }\n\n return stringify(colorArr, colorArr.length === 4 ? 'rgba' : 'rgb');\n }\n}\n/**\n * @param {string} color\n * @return {string}\n * @memberOf module:zrender/util/color\n */\n\n\nfunction toHex(color) {\n var colorArr = parse(color);\n\n if (colorArr) {\n return ((1 << 24) + (colorArr[0] << 16) + (colorArr[1] << 8) + +colorArr[2]).toString(16).slice(1);\n }\n}\n/**\n * Map value to color. Faster than lerp methods because color is represented by rgba array.\n * @param {number} normalizedValue A float between 0 and 1.\n * @param {Array.<Array.<number>>} colors List of rgba color array\n * @param {Array.<number>} [out] Mapped gba color array\n * @return {Array.<number>} will be null/undefined if input illegal.\n */\n\n\nfunction fastLerp(normalizedValue, colors, out) {\n if (!(colors && colors.length) || !(normalizedValue >= 0 && normalizedValue <= 1)) {\n return;\n }\n\n out = out || [];\n var value = normalizedValue * (colors.length - 1);\n var leftIndex = Math.floor(value);\n var rightIndex = Math.ceil(value);\n var leftColor = colors[leftIndex];\n var rightColor = colors[rightIndex];\n var dv = value - leftIndex;\n out[0] = clampCssByte(lerpNumber(leftColor[0], rightColor[0], dv));\n out[1] = clampCssByte(lerpNumber(leftColor[1], rightColor[1], dv));\n out[2] = clampCssByte(lerpNumber(leftColor[2], rightColor[2], dv));\n out[3] = clampCssFloat(lerpNumber(leftColor[3], rightColor[3], dv));\n return out;\n}\n/**\n * @deprecated\n */\n\n\nvar fastMapToColor = fastLerp;\n/**\n * @param {number} normalizedValue A float between 0 and 1.\n * @param {Array.<string>} colors Color list.\n * @param {boolean=} fullOutput Default false.\n * @return {(string|Object)} Result color. If fullOutput,\n * return {color: ..., leftIndex: ..., rightIndex: ..., value: ...},\n * @memberOf module:zrender/util/color\n */\n\nfunction lerp(normalizedValue, colors, fullOutput) {\n if (!(colors && colors.length) || !(normalizedValue >= 0 && normalizedValue <= 1)) {\n return;\n }\n\n var value = normalizedValue * (colors.length - 1);\n var leftIndex = Math.floor(value);\n var rightIndex = Math.ceil(value);\n var leftColor = parse(colors[leftIndex]);\n var rightColor = parse(colors[rightIndex]);\n var dv = value - leftIndex;\n var color = stringify([clampCssByte(lerpNumber(leftColor[0], rightColor[0], dv)), clampCssByte(lerpNumber(leftColor[1], rightColor[1], dv)), clampCssByte(lerpNumber(leftColor[2], rightColor[2], dv)), clampCssFloat(lerpNumber(leftColor[3], rightColor[3], dv))], 'rgba');\n return fullOutput ? {\n color: color,\n leftIndex: leftIndex,\n rightIndex: rightIndex,\n value: value\n } : color;\n}\n/**\n * @deprecated\n */\n\n\nvar mapToColor = lerp;\n/**\n * @param {string} color\n * @param {number=} h 0 ~ 360, ignore when null.\n * @param {number=} s 0 ~ 1, ignore when null.\n * @param {number=} l 0 ~ 1, ignore when null.\n * @return {string} Color string in rgba format.\n * @memberOf module:zrender/util/color\n */\n\nfunction modifyHSL(color, h, s, l) {\n color = parse(color);\n\n if (color) {\n color = rgba2hsla(color);\n h != null && (color[0] = clampCssAngle(h));\n s != null && (color[1] = parseCssFloat(s));\n l != null && (color[2] = parseCssFloat(l));\n return stringify(hsla2rgba(color), 'rgba');\n }\n}\n/**\n * @param {string} color\n * @param {number=} alpha 0 ~ 1\n * @return {string} Color string in rgba format.\n * @memberOf module:zrender/util/color\n */\n\n\nfunction modifyAlpha(color, alpha) {\n color = parse(color);\n\n if (color && alpha != null) {\n color[3] = clampCssFloat(alpha);\n return stringify(color, 'rgba');\n }\n}\n/**\n * @param {Array.<number>} arrColor like [12,33,44,0.4]\n * @param {string} type 'rgba', 'hsva', ...\n * @return {string} Result color. (If input illegal, return undefined).\n */\n\n\nfunction stringify(arrColor, type) {\n if (!arrColor || !arrColor.length) {\n return;\n }\n\n var colorStr = arrColor[0] + ',' + arrColor[1] + ',' + arrColor[2];\n\n if (type === 'rgba' || type === 'hsva' || type === 'hsla') {\n colorStr += ',' + arrColor[3];\n }\n\n return type + '(' + colorStr + ')';\n}\n\nexports.parse = parse;\nexports.lift = lift;\nexports.toHex = toHex;\nexports.fastLerp = fastLerp;\nexports.fastMapToColor = fastMapToColor;\nexports.lerp = lerp;\nexports.mapToColor = mapToColor;\nexports.modifyHSL = modifyHSL;\nexports.modifyAlpha = modifyAlpha;\nexports.stringify = stringify;","/**\n * @param {Array.<Object>} colorStops\n */\nvar Gradient = function (colorStops) {\n this.colorStops = colorStops || [];\n};\n\nGradient.prototype = {\n constructor: Gradient,\n addColorStop: function (offset, color) {\n this.colorStops.push({\n offset: offset,\n color: color\n });\n }\n};\nvar _default = Gradient;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar env = require(\"zrender/lib/core/env\");\n\nvar _model = require(\"../util/model\");\n\nvar makeInner = _model.makeInner;\n\nvar _clazz = require(\"../util/clazz\");\n\nvar enableClassExtend = _clazz.enableClassExtend;\nvar enableClassCheck = _clazz.enableClassCheck;\n\nvar lineStyleMixin = require(\"./mixin/lineStyle\");\n\nvar areaStyleMixin = require(\"./mixin/areaStyle\");\n\nvar textStyleMixin = require(\"./mixin/textStyle\");\n\nvar itemStyleMixin = require(\"./mixin/itemStyle\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @module echarts/model/Model\n */\nvar mixin = zrUtil.mixin;\nvar inner = makeInner();\n/**\n * @alias module:echarts/model/Model\n * @constructor\n * @param {Object} [option]\n * @param {module:echarts/model/Model} [parentModel]\n * @param {module:echarts/model/Global} [ecModel]\n */\n\nfunction Model(option, parentModel, ecModel) {\n /**\n * @type {module:echarts/model/Model}\n * @readOnly\n */\n this.parentModel = parentModel;\n /**\n * @type {module:echarts/model/Global}\n * @readOnly\n */\n\n this.ecModel = ecModel;\n /**\n * @type {Object}\n * @protected\n */\n\n this.option = option; // Simple optimization\n // if (this.init) {\n // if (arguments.length <= 4) {\n // this.init(option, parentModel, ecModel, extraOpt);\n // }\n // else {\n // this.init.apply(this, arguments);\n // }\n // }\n}\n\nModel.prototype = {\n constructor: Model,\n\n /**\n * Model 的初始化函数\n * @param {Object} option\n */\n init: null,\n\n /**\n * 从新的 Option merge\n */\n mergeOption: function (option) {\n zrUtil.merge(this.option, option, true);\n },\n\n /**\n * @param {string|Array.<string>} path\n * @param {boolean} [ignoreParent=false]\n * @return {*}\n */\n get: function (path, ignoreParent) {\n if (path == null) {\n return this.option;\n }\n\n return doGet(this.option, this.parsePath(path), !ignoreParent && getParent(this, path));\n },\n\n /**\n * @param {string} key\n * @param {boolean} [ignoreParent=false]\n * @return {*}\n */\n getShallow: function (key, ignoreParent) {\n var option = this.option;\n var val = option == null ? option : option[key];\n var parentModel = !ignoreParent && getParent(this, key);\n\n if (val == null && parentModel) {\n val = parentModel.getShallow(key);\n }\n\n return val;\n },\n\n /**\n * @param {string|Array.<string>} [path]\n * @param {module:echarts/model/Model} [parentModel]\n * @return {module:echarts/model/Model}\n */\n getModel: function (path, parentModel) {\n var obj = path == null ? this.option : doGet(this.option, path = this.parsePath(path));\n var thisParentModel;\n parentModel = parentModel || (thisParentModel = getParent(this, path)) && thisParentModel.getModel(path);\n return new Model(obj, parentModel, this.ecModel);\n },\n\n /**\n * If model has option\n */\n isEmpty: function () {\n return this.option == null;\n },\n restoreData: function () {},\n // Pending\n clone: function () {\n var Ctor = this.constructor;\n return new Ctor(zrUtil.clone(this.option));\n },\n setReadOnly: function (properties) {// clazzUtil.setReadOnly(this, properties);\n },\n // If path is null/undefined, return null/undefined.\n parsePath: function (path) {\n if (typeof path === 'string') {\n path = path.split('.');\n }\n\n return path;\n },\n\n /**\n * @param {Function} getParentMethod\n * param {Array.<string>|string} path\n * return {module:echarts/model/Model}\n */\n customizeGetParent: function (getParentMethod) {\n inner(this).getParent = getParentMethod;\n },\n isAnimationEnabled: function () {\n if (!env.node) {\n if (this.option.animation != null) {\n return !!this.option.animation;\n } else if (this.parentModel) {\n return this.parentModel.isAnimationEnabled();\n }\n }\n }\n};\n\nfunction doGet(obj, pathArr, parentModel) {\n for (var i = 0; i < pathArr.length; i++) {\n // Ignore empty\n if (!pathArr[i]) {\n continue;\n } // obj could be number/string/... (like 0)\n\n\n obj = obj && typeof obj === 'object' ? obj[pathArr[i]] : null;\n\n if (obj == null) {\n break;\n }\n }\n\n if (obj == null && parentModel) {\n obj = parentModel.get(pathArr);\n }\n\n return obj;\n} // `path` can be null/undefined\n\n\nfunction getParent(model, path) {\n var getParentMethod = inner(model).getParent;\n return getParentMethod ? getParentMethod.call(model, path) : model.parentModel;\n} // Enable Model.extend.\n\n\nenableClassExtend(Model);\nenableClassCheck(Model);\nmixin(Model, lineStyleMixin);\nmixin(Model, areaStyleMixin);\nmixin(Model, textStyleMixin);\nmixin(Model, itemStyleMixin);\nvar _default = Model;\nmodule.exports = _default;","var easingFuncs = require(\"./easing\");\n\n/**\n * 动画主控制器\n * @config target 动画对象,可以是数组,如果是数组的话会批量分发onframe等事件\n * @config life(1000) 动画时长\n * @config delay(0) 动画延迟时间\n * @config loop(true)\n * @config gap(0) 循环的间隔时间\n * @config onframe\n * @config easing(optional)\n * @config ondestroy(optional)\n * @config onrestart(optional)\n *\n * TODO pause\n */\nfunction Clip(options) {\n this._target = options.target; // 生命周期\n\n this._life = options.life || 1000; // 延时\n\n this._delay = options.delay || 0; // 开始时间\n // this._startTime = new Date().getTime() + this._delay;// 单位毫秒\n\n this._initialized = false; // 是否循环\n\n this.loop = options.loop == null ? false : options.loop;\n this.gap = options.gap || 0;\n this.easing = options.easing || 'Linear';\n this.onframe = options.onframe;\n this.ondestroy = options.ondestroy;\n this.onrestart = options.onrestart;\n this._pausedTime = 0;\n this._paused = false;\n}\n\nClip.prototype = {\n constructor: Clip,\n step: function (globalTime, deltaTime) {\n // Set startTime on first step, or _startTime may has milleseconds different between clips\n // PENDING\n if (!this._initialized) {\n this._startTime = globalTime + this._delay;\n this._initialized = true;\n }\n\n if (this._paused) {\n this._pausedTime += deltaTime;\n return;\n }\n\n var percent = (globalTime - this._startTime - this._pausedTime) / this._life; // 还没开始\n\n if (percent < 0) {\n return;\n }\n\n percent = Math.min(percent, 1);\n var easing = this.easing;\n var easingFunc = typeof easing === 'string' ? easingFuncs[easing] : easing;\n var schedule = typeof easingFunc === 'function' ? easingFunc(percent) : percent;\n this.fire('frame', schedule); // 结束\n\n if (percent === 1) {\n if (this.loop) {\n this.restart(globalTime); // 重新开始周期\n // 抛出而不是直接调用事件直到 stage.update 后再统一调用这些事件\n\n return 'restart';\n } // 动画完成将这个控制器标识为待删除\n // 在Animation.update中进行批量删除\n\n\n this._needsRemove = true;\n return 'destroy';\n }\n\n return null;\n },\n restart: function (globalTime) {\n var remainder = (globalTime - this._startTime - this._pausedTime) % this._life;\n this._startTime = globalTime - remainder + this.gap;\n this._pausedTime = 0;\n this._needsRemove = false;\n },\n fire: function (eventType, arg) {\n eventType = 'on' + eventType;\n\n if (this[eventType]) {\n this[eventType](this._target, arg);\n }\n },\n pause: function () {\n this._paused = true;\n },\n resume: function () {\n this._paused = false;\n }\n};\nvar _default = Clip;\nmodule.exports = _default;","var Path = require(\"../Path\");\n\n/**\n * 圆环\n * @module zrender/graphic/shape/Ring\n */\nvar _default = Path.extend({\n type: 'ring',\n shape: {\n cx: 0,\n cy: 0,\n r: 0,\n r0: 0\n },\n buildPath: function (ctx, shape) {\n var x = shape.cx;\n var y = shape.cy;\n var PI2 = Math.PI * 2;\n ctx.moveTo(x + shape.r, y);\n ctx.arc(x, y, shape.r, 0, PI2, false);\n ctx.moveTo(x + shape.r0, y);\n ctx.arc(x, y, shape.r0, 0, PI2, true);\n }\n});\n\nmodule.exports = _default;","require('../modules/web.dom.iterable');\nrequire('../modules/es6.string.iterator');\nmodule.exports = require('../modules/core.get-iterator');\n","var zrUtil = require(\"../core/util\");\n\nvar Gradient = require(\"./Gradient\");\n\n/**\n * x, y, x2, y2 are all percent from 0 to 1\n * @param {number} [x=0]\n * @param {number} [y=0]\n * @param {number} [x2=1]\n * @param {number} [y2=0]\n * @param {Array.<Object>} colorStops\n * @param {boolean} [globalCoord=false]\n */\nvar LinearGradient = function (x, y, x2, y2, colorStops, globalCoord) {\n // Should do nothing more in this constructor. Because gradient can be\n // declard by `color: {type: 'linear', colorStops: ...}`, where\n // this constructor will not be called.\n this.x = x == null ? 0 : x;\n this.y = y == null ? 0 : y;\n this.x2 = x2 == null ? 1 : x2;\n this.y2 = y2 == null ? 0 : y2; // Can be cloned\n\n this.type = 'linear'; // If use global coord\n\n this.global = globalCoord || false;\n Gradient.call(this, colorStops);\n};\n\nLinearGradient.prototype = {\n constructor: LinearGradient\n};\nzrUtil.inherits(LinearGradient, Gradient);\nvar _default = LinearGradient;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar echarts = require(\"../../echarts\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar AxisPointerModel = echarts.extendComponentModel({\n type: 'axisPointer',\n coordSysAxesInfo: null,\n defaultOption: {\n // 'auto' means that show when triggered by tooltip or handle.\n show: 'auto',\n // 'click' | 'mousemove' | 'none'\n triggerOn: null,\n // set default in AxisPonterView.js\n zlevel: 0,\n z: 50,\n type: 'line',\n // 'line' 'shadow' 'cross' 'none'.\n // axispointer triggered by tootip determine snap automatically,\n // see `modelHelper`.\n snap: false,\n triggerTooltip: true,\n value: null,\n status: null,\n // Init value depends on whether handle is used.\n // [group0, group1, ...]\n // Each group can be: {\n // mapper: function () {},\n // singleTooltip: 'multiple', // 'multiple' or 'single'\n // xAxisId: ...,\n // yAxisName: ...,\n // angleAxisIndex: ...\n // }\n // mapper: can be ignored.\n // input: {axisInfo, value}\n // output: {axisInfo, value}\n link: [],\n // Do not set 'auto' here, otherwise global animation: false\n // will not effect at this axispointer.\n animation: null,\n animationDurationUpdate: 200,\n lineStyle: {\n color: '#aaa',\n width: 1,\n type: 'solid'\n },\n shadowStyle: {\n color: 'rgba(150,150,150,0.3)'\n },\n label: {\n show: true,\n formatter: null,\n // string | Function\n precision: 'auto',\n // Or a number like 0, 1, 2 ...\n margin: 3,\n color: '#fff',\n padding: [5, 7, 5, 7],\n backgroundColor: 'auto',\n // default: axis line color\n borderColor: null,\n borderWidth: 0,\n shadowBlur: 3,\n shadowColor: '#aaa' // Considering applicability, common style should\n // better not have shadowOffset.\n // shadowOffsetX: 0,\n // shadowOffsetY: 2\n\n },\n handle: {\n show: false,\n\n /* eslint-disable */\n icon: 'M10.7,11.9v-1.3H9.3v1.3c-4.9,0.3-8.8,4.4-8.8,9.4c0,5,3.9,9.1,8.8,9.4h1.3c4.9-0.3,8.8-4.4,8.8-9.4C19.5,16.3,15.6,12.2,10.7,11.9z M13.3,24.4H6.7v-1.2h6.6z M13.3,22H6.7v-1.2h6.6z M13.3,19.6H6.7v-1.2h6.6z',\n // jshint ignore:line\n\n /* eslint-enable */\n size: 45,\n // handle margin is from symbol center to axis, which is stable when circular move.\n margin: 50,\n // color: '#1b8bbd'\n // color: '#2f4554'\n color: '#333',\n shadowBlur: 3,\n shadowColor: '#aaa',\n shadowOffsetX: 0,\n shadowOffsetY: 2,\n // For mobile performance\n throttle: 40\n }\n }\n});\nvar _default = AxisPointerModel;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar ComponentModel = require(\"../../model/Component\");\n\nvar axisModelCreator = require(\"../axisModelCreator\");\n\nvar axisModelCommonMixin = require(\"../axisModelCommonMixin\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar AxisModel = ComponentModel.extend({\n type: 'cartesian2dAxis',\n\n /**\n * @type {module:echarts/coord/cartesian/Axis2D}\n */\n axis: null,\n\n /**\n * @override\n */\n init: function () {\n AxisModel.superApply(this, 'init', arguments);\n this.resetRange();\n },\n\n /**\n * @override\n */\n mergeOption: function () {\n AxisModel.superApply(this, 'mergeOption', arguments);\n this.resetRange();\n },\n\n /**\n * @override\n */\n restoreData: function () {\n AxisModel.superApply(this, 'restoreData', arguments);\n this.resetRange();\n },\n\n /**\n * @override\n * @return {module:echarts/model/Component}\n */\n getCoordSysModel: function () {\n return this.ecModel.queryComponents({\n mainType: 'grid',\n index: this.option.gridIndex,\n id: this.option.gridId\n })[0];\n }\n});\n\nfunction getAxisType(axisDim, option) {\n // Default axis with data is category axis\n return option.type || (option.data ? 'category' : 'value');\n}\n\nzrUtil.merge(AxisModel.prototype, axisModelCommonMixin);\nvar extraOption = {\n // gridIndex: 0,\n // gridId: '',\n // Offset is for multiple axis on the same position\n offset: 0\n};\naxisModelCreator('x', AxisModel, getAxisType, extraOption);\naxisModelCreator('y', AxisModel, getAxisType, extraOption);\nvar _default = AxisModel;\nmodule.exports = _default;","var _config = require(\"../config\");\n\nvar debugMode = _config.debugMode;\n\nvar log = function () {};\n\nif (debugMode === 1) {\n log = function () {\n for (var k in arguments) {\n throw new Error(arguments[k]);\n }\n };\n} else if (debugMode > 1) {\n log = function () {\n for (var k in arguments) {\n console.log(arguments[k]);\n }\n };\n}\n\nvar _default = log;\nmodule.exports = _default;","var _vector = require(\"./vector\");\n\nvar v2Create = _vector.create;\nvar v2DistSquare = _vector.distSquare;\n\n/**\n * 曲线辅助模块\n * @module zrender/core/curve\n * @author pissang(https://www.github.com/pissang)\n */\nvar mathPow = Math.pow;\nvar mathSqrt = Math.sqrt;\nvar EPSILON = 1e-8;\nvar EPSILON_NUMERIC = 1e-4;\nvar THREE_SQRT = mathSqrt(3);\nvar ONE_THIRD = 1 / 3; // 临时变量\n\nvar _v0 = v2Create();\n\nvar _v1 = v2Create();\n\nvar _v2 = v2Create();\n\nfunction isAroundZero(val) {\n return val > -EPSILON && val < EPSILON;\n}\n\nfunction isNotAroundZero(val) {\n return val > EPSILON || val < -EPSILON;\n}\n/**\n * 计算三次贝塞尔值\n * @memberOf module:zrender/core/curve\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} p3\n * @param {number} t\n * @return {number}\n */\n\n\nfunction cubicAt(p0, p1, p2, p3, t) {\n var onet = 1 - t;\n return onet * onet * (onet * p0 + 3 * t * p1) + t * t * (t * p3 + 3 * onet * p2);\n}\n/**\n * 计算三次贝塞尔导数值\n * @memberOf module:zrender/core/curve\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} p3\n * @param {number} t\n * @return {number}\n */\n\n\nfunction cubicDerivativeAt(p0, p1, p2, p3, t) {\n var onet = 1 - t;\n return 3 * (((p1 - p0) * onet + 2 * (p2 - p1) * t) * onet + (p3 - p2) * t * t);\n}\n/**\n * 计算三次贝塞尔方程根,使用盛金公式\n * @memberOf module:zrender/core/curve\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} p3\n * @param {number} val\n * @param {Array.<number>} roots\n * @return {number} 有效根数目\n */\n\n\nfunction cubicRootAt(p0, p1, p2, p3, val, roots) {\n // Evaluate roots of cubic functions\n var a = p3 + 3 * (p1 - p2) - p0;\n var b = 3 * (p2 - p1 * 2 + p0);\n var c = 3 * (p1 - p0);\n var d = p0 - val;\n var A = b * b - 3 * a * c;\n var B = b * c - 9 * a * d;\n var C = c * c - 3 * b * d;\n var n = 0;\n\n if (isAroundZero(A) && isAroundZero(B)) {\n if (isAroundZero(b)) {\n roots[0] = 0;\n } else {\n var t1 = -c / b; //t1, t2, t3, b is not zero\n\n if (t1 >= 0 && t1 <= 1) {\n roots[n++] = t1;\n }\n }\n } else {\n var disc = B * B - 4 * A * C;\n\n if (isAroundZero(disc)) {\n var K = B / A;\n var t1 = -b / a + K; // t1, a is not zero\n\n var t2 = -K / 2; // t2, t3\n\n if (t1 >= 0 && t1 <= 1) {\n roots[n++] = t1;\n }\n\n if (t2 >= 0 && t2 <= 1) {\n roots[n++] = t2;\n }\n } else if (disc > 0) {\n var discSqrt = mathSqrt(disc);\n var Y1 = A * b + 1.5 * a * (-B + discSqrt);\n var Y2 = A * b + 1.5 * a * (-B - discSqrt);\n\n if (Y1 < 0) {\n Y1 = -mathPow(-Y1, ONE_THIRD);\n } else {\n Y1 = mathPow(Y1, ONE_THIRD);\n }\n\n if (Y2 < 0) {\n Y2 = -mathPow(-Y2, ONE_THIRD);\n } else {\n Y2 = mathPow(Y2, ONE_THIRD);\n }\n\n var t1 = (-b - (Y1 + Y2)) / (3 * a);\n\n if (t1 >= 0 && t1 <= 1) {\n roots[n++] = t1;\n }\n } else {\n var T = (2 * A * b - 3 * a * B) / (2 * mathSqrt(A * A * A));\n var theta = Math.acos(T) / 3;\n var ASqrt = mathSqrt(A);\n var tmp = Math.cos(theta);\n var t1 = (-b - 2 * ASqrt * tmp) / (3 * a);\n var t2 = (-b + ASqrt * (tmp + THREE_SQRT * Math.sin(theta))) / (3 * a);\n var t3 = (-b + ASqrt * (tmp - THREE_SQRT * Math.sin(theta))) / (3 * a);\n\n if (t1 >= 0 && t1 <= 1) {\n roots[n++] = t1;\n }\n\n if (t2 >= 0 && t2 <= 1) {\n roots[n++] = t2;\n }\n\n if (t3 >= 0 && t3 <= 1) {\n roots[n++] = t3;\n }\n }\n }\n\n return n;\n}\n/**\n * 计算三次贝塞尔方程极限值的位置\n * @memberOf module:zrender/core/curve\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} p3\n * @param {Array.<number>} extrema\n * @return {number} 有效数目\n */\n\n\nfunction cubicExtrema(p0, p1, p2, p3, extrema) {\n var b = 6 * p2 - 12 * p1 + 6 * p0;\n var a = 9 * p1 + 3 * p3 - 3 * p0 - 9 * p2;\n var c = 3 * p1 - 3 * p0;\n var n = 0;\n\n if (isAroundZero(a)) {\n if (isNotAroundZero(b)) {\n var t1 = -c / b;\n\n if (t1 >= 0 && t1 <= 1) {\n extrema[n++] = t1;\n }\n }\n } else {\n var disc = b * b - 4 * a * c;\n\n if (isAroundZero(disc)) {\n extrema[0] = -b / (2 * a);\n } else if (disc > 0) {\n var discSqrt = mathSqrt(disc);\n var t1 = (-b + discSqrt) / (2 * a);\n var t2 = (-b - discSqrt) / (2 * a);\n\n if (t1 >= 0 && t1 <= 1) {\n extrema[n++] = t1;\n }\n\n if (t2 >= 0 && t2 <= 1) {\n extrema[n++] = t2;\n }\n }\n }\n\n return n;\n}\n/**\n * 细分三次贝塞尔曲线\n * @memberOf module:zrender/core/curve\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} p3\n * @param {number} t\n * @param {Array.<number>} out\n */\n\n\nfunction cubicSubdivide(p0, p1, p2, p3, t, out) {\n var p01 = (p1 - p0) * t + p0;\n var p12 = (p2 - p1) * t + p1;\n var p23 = (p3 - p2) * t + p2;\n var p012 = (p12 - p01) * t + p01;\n var p123 = (p23 - p12) * t + p12;\n var p0123 = (p123 - p012) * t + p012; // Seg0\n\n out[0] = p0;\n out[1] = p01;\n out[2] = p012;\n out[3] = p0123; // Seg1\n\n out[4] = p0123;\n out[5] = p123;\n out[6] = p23;\n out[7] = p3;\n}\n/**\n * 投射点到三次贝塞尔曲线上,返回投射距离。\n * 投射点有可能会有一个或者多个,这里只返回其中距离最短的一个。\n * @param {number} x0\n * @param {number} y0\n * @param {number} x1\n * @param {number} y1\n * @param {number} x2\n * @param {number} y2\n * @param {number} x3\n * @param {number} y3\n * @param {number} x\n * @param {number} y\n * @param {Array.<number>} [out] 投射点\n * @return {number}\n */\n\n\nfunction cubicProjectPoint(x0, y0, x1, y1, x2, y2, x3, y3, x, y, out) {\n // http://pomax.github.io/bezierinfo/#projections\n var t;\n var interval = 0.005;\n var d = Infinity;\n var prev;\n var next;\n var d1;\n var d2;\n _v0[0] = x;\n _v0[1] = y; // 先粗略估计一下可能的最小距离的 t 值\n // PENDING\n\n for (var _t = 0; _t < 1; _t += 0.05) {\n _v1[0] = cubicAt(x0, x1, x2, x3, _t);\n _v1[1] = cubicAt(y0, y1, y2, y3, _t);\n d1 = v2DistSquare(_v0, _v1);\n\n if (d1 < d) {\n t = _t;\n d = d1;\n }\n }\n\n d = Infinity; // At most 32 iteration\n\n for (var i = 0; i < 32; i++) {\n if (interval < EPSILON_NUMERIC) {\n break;\n }\n\n prev = t - interval;\n next = t + interval; // t - interval\n\n _v1[0] = cubicAt(x0, x1, x2, x3, prev);\n _v1[1] = cubicAt(y0, y1, y2, y3, prev);\n d1 = v2DistSquare(_v1, _v0);\n\n if (prev >= 0 && d1 < d) {\n t = prev;\n d = d1;\n } else {\n // t + interval\n _v2[0] = cubicAt(x0, x1, x2, x3, next);\n _v2[1] = cubicAt(y0, y1, y2, y3, next);\n d2 = v2DistSquare(_v2, _v0);\n\n if (next <= 1 && d2 < d) {\n t = next;\n d = d2;\n } else {\n interval *= 0.5;\n }\n }\n } // t\n\n\n if (out) {\n out[0] = cubicAt(x0, x1, x2, x3, t);\n out[1] = cubicAt(y0, y1, y2, y3, t);\n } // console.log(interval, i);\n\n\n return mathSqrt(d);\n}\n/**\n * 计算二次方贝塞尔值\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} t\n * @return {number}\n */\n\n\nfunction quadraticAt(p0, p1, p2, t) {\n var onet = 1 - t;\n return onet * (onet * p0 + 2 * t * p1) + t * t * p2;\n}\n/**\n * 计算二次方贝塞尔导数值\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} t\n * @return {number}\n */\n\n\nfunction quadraticDerivativeAt(p0, p1, p2, t) {\n return 2 * ((1 - t) * (p1 - p0) + t * (p2 - p1));\n}\n/**\n * 计算二次方贝塞尔方程根\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} t\n * @param {Array.<number>} roots\n * @return {number} 有效根数目\n */\n\n\nfunction quadraticRootAt(p0, p1, p2, val, roots) {\n var a = p0 - 2 * p1 + p2;\n var b = 2 * (p1 - p0);\n var c = p0 - val;\n var n = 0;\n\n if (isAroundZero(a)) {\n if (isNotAroundZero(b)) {\n var t1 = -c / b;\n\n if (t1 >= 0 && t1 <= 1) {\n roots[n++] = t1;\n }\n }\n } else {\n var disc = b * b - 4 * a * c;\n\n if (isAroundZero(disc)) {\n var t1 = -b / (2 * a);\n\n if (t1 >= 0 && t1 <= 1) {\n roots[n++] = t1;\n }\n } else if (disc > 0) {\n var discSqrt = mathSqrt(disc);\n var t1 = (-b + discSqrt) / (2 * a);\n var t2 = (-b - discSqrt) / (2 * a);\n\n if (t1 >= 0 && t1 <= 1) {\n roots[n++] = t1;\n }\n\n if (t2 >= 0 && t2 <= 1) {\n roots[n++] = t2;\n }\n }\n }\n\n return n;\n}\n/**\n * 计算二次贝塞尔方程极限值\n * @memberOf module:zrender/core/curve\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @return {number}\n */\n\n\nfunction quadraticExtremum(p0, p1, p2) {\n var divider = p0 + p2 - 2 * p1;\n\n if (divider === 0) {\n // p1 is center of p0 and p2\n return 0.5;\n } else {\n return (p0 - p1) / divider;\n }\n}\n/**\n * 细分二次贝塞尔曲线\n * @memberOf module:zrender/core/curve\n * @param {number} p0\n * @param {number} p1\n * @param {number} p2\n * @param {number} t\n * @param {Array.<number>} out\n */\n\n\nfunction quadraticSubdivide(p0, p1, p2, t, out) {\n var p01 = (p1 - p0) * t + p0;\n var p12 = (p2 - p1) * t + p1;\n var p012 = (p12 - p01) * t + p01; // Seg0\n\n out[0] = p0;\n out[1] = p01;\n out[2] = p012; // Seg1\n\n out[3] = p012;\n out[4] = p12;\n out[5] = p2;\n}\n/**\n * 投射点到二次贝塞尔曲线上,返回投射距离。\n * 投射点有可能会有一个或者多个,这里只返回其中距离最短的一个。\n * @param {number} x0\n * @param {number} y0\n * @param {number} x1\n * @param {number} y1\n * @param {number} x2\n * @param {number} y2\n * @param {number} x\n * @param {number} y\n * @param {Array.<number>} out 投射点\n * @return {number}\n */\n\n\nfunction quadraticProjectPoint(x0, y0, x1, y1, x2, y2, x, y, out) {\n // http://pomax.github.io/bezierinfo/#projections\n var t;\n var interval = 0.005;\n var d = Infinity;\n _v0[0] = x;\n _v0[1] = y; // 先粗略估计一下可能的最小距离的 t 值\n // PENDING\n\n for (var _t = 0; _t < 1; _t += 0.05) {\n _v1[0] = quadraticAt(x0, x1, x2, _t);\n _v1[1] = quadraticAt(y0, y1, y2, _t);\n var d1 = v2DistSquare(_v0, _v1);\n\n if (d1 < d) {\n t = _t;\n d = d1;\n }\n }\n\n d = Infinity; // At most 32 iteration\n\n for (var i = 0; i < 32; i++) {\n if (interval < EPSILON_NUMERIC) {\n break;\n }\n\n var prev = t - interval;\n var next = t + interval; // t - interval\n\n _v1[0] = quadraticAt(x0, x1, x2, prev);\n _v1[1] = quadraticAt(y0, y1, y2, prev);\n var d1 = v2DistSquare(_v1, _v0);\n\n if (prev >= 0 && d1 < d) {\n t = prev;\n d = d1;\n } else {\n // t + interval\n _v2[0] = quadraticAt(x0, x1, x2, next);\n _v2[1] = quadraticAt(y0, y1, y2, next);\n var d2 = v2DistSquare(_v2, _v0);\n\n if (next <= 1 && d2 < d) {\n t = next;\n d = d2;\n } else {\n interval *= 0.5;\n }\n }\n } // t\n\n\n if (out) {\n out[0] = quadraticAt(x0, x1, x2, t);\n out[1] = quadraticAt(y0, y1, y2, t);\n } // console.log(interval, i);\n\n\n return mathSqrt(d);\n}\n\nexports.cubicAt = cubicAt;\nexports.cubicDerivativeAt = cubicDerivativeAt;\nexports.cubicRootAt = cubicRootAt;\nexports.cubicExtrema = cubicExtrema;\nexports.cubicSubdivide = cubicSubdivide;\nexports.cubicProjectPoint = cubicProjectPoint;\nexports.quadraticAt = quadraticAt;\nexports.quadraticDerivativeAt = quadraticDerivativeAt;\nexports.quadraticRootAt = quadraticRootAt;\nexports.quadraticExtremum = quadraticExtremum;\nexports.quadraticSubdivide = quadraticSubdivide;\nexports.quadraticProjectPoint = quadraticProjectPoint;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar graphic = require(\"../../util/graphic\");\n\nvar BaseAxisPointer = require(\"./BaseAxisPointer\");\n\nvar viewHelper = require(\"./viewHelper\");\n\nvar cartesianAxisHelper = require(\"../../coord/cartesian/cartesianAxisHelper\");\n\nvar AxisView = require(\"../axis/AxisView\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar CartesianAxisPointer = BaseAxisPointer.extend({\n /**\n * @override\n */\n makeElOption: function (elOption, value, axisModel, axisPointerModel, api) {\n var axis = axisModel.axis;\n var grid = axis.grid;\n var axisPointerType = axisPointerModel.get('type');\n var otherExtent = getCartesian(grid, axis).getOtherAxis(axis).getGlobalExtent();\n var pixelValue = axis.toGlobalCoord(axis.dataToCoord(value, true));\n\n if (axisPointerType && axisPointerType !== 'none') {\n var elStyle = viewHelper.buildElStyle(axisPointerModel);\n var pointerOption = pointerShapeBuilder[axisPointerType](axis, pixelValue, otherExtent, elStyle);\n pointerOption.style = elStyle;\n elOption.graphicKey = pointerOption.type;\n elOption.pointer = pointerOption;\n }\n\n var layoutInfo = cartesianAxisHelper.layout(grid.model, axisModel);\n viewHelper.buildCartesianSingleLabelElOption(value, elOption, layoutInfo, axisModel, axisPointerModel, api);\n },\n\n /**\n * @override\n */\n getHandleTransform: function (value, axisModel, axisPointerModel) {\n var layoutInfo = cartesianAxisHelper.layout(axisModel.axis.grid.model, axisModel, {\n labelInside: false\n });\n layoutInfo.labelMargin = axisPointerModel.get('handle.margin');\n return {\n position: viewHelper.getTransformedPosition(axisModel.axis, value, layoutInfo),\n rotation: layoutInfo.rotation + (layoutInfo.labelDirection < 0 ? Math.PI : 0)\n };\n },\n\n /**\n * @override\n */\n updateHandleTransform: function (transform, delta, axisModel, axisPointerModel) {\n var axis = axisModel.axis;\n var grid = axis.grid;\n var axisExtent = axis.getGlobalExtent(true);\n var otherExtent = getCartesian(grid, axis).getOtherAxis(axis).getGlobalExtent();\n var dimIndex = axis.dim === 'x' ? 0 : 1;\n var currPosition = transform.position;\n currPosition[dimIndex] += delta[dimIndex];\n currPosition[dimIndex] = Math.min(axisExtent[1], currPosition[dimIndex]);\n currPosition[dimIndex] = Math.max(axisExtent[0], currPosition[dimIndex]);\n var cursorOtherValue = (otherExtent[1] + otherExtent[0]) / 2;\n var cursorPoint = [cursorOtherValue, cursorOtherValue];\n cursorPoint[dimIndex] = currPosition[dimIndex]; // Make tooltip do not overlap axisPointer and in the middle of the grid.\n\n var tooltipOptions = [{\n verticalAlign: 'middle'\n }, {\n align: 'center'\n }];\n return {\n position: currPosition,\n rotation: transform.rotation,\n cursorPoint: cursorPoint,\n tooltipOption: tooltipOptions[dimIndex]\n };\n }\n});\n\nfunction getCartesian(grid, axis) {\n var opt = {};\n opt[axis.dim + 'AxisIndex'] = axis.index;\n return grid.getCartesian(opt);\n}\n\nvar pointerShapeBuilder = {\n line: function (axis, pixelValue, otherExtent, elStyle) {\n var targetShape = viewHelper.makeLineShape([pixelValue, otherExtent[0]], [pixelValue, otherExtent[1]], getAxisDimIndex(axis));\n graphic.subPixelOptimizeLine({\n shape: targetShape,\n style: elStyle\n });\n return {\n type: 'Line',\n shape: targetShape\n };\n },\n shadow: function (axis, pixelValue, otherExtent, elStyle) {\n var bandWidth = Math.max(1, axis.getBandWidth());\n var span = otherExtent[1] - otherExtent[0];\n return {\n type: 'Rect',\n shape: viewHelper.makeRectShape([pixelValue - bandWidth / 2, otherExtent[0]], [bandWidth, span], getAxisDimIndex(axis))\n };\n }\n};\n\nfunction getAxisDimIndex(axis) {\n return axis.dim === 'x' ? 0 : 1;\n}\n\nAxisView.registerAxisPointerClass('CartesianAxisPointer', CartesianAxisPointer);\nvar _default = CartesianAxisPointer;\nmodule.exports = _default;","var Path = require(\"../Path\");\n\nvar fixClipWithShadow = require(\"../helper/fixClipWithShadow\");\n\n/**\n * 扇形\n * @module zrender/graphic/shape/Sector\n */\nvar _default = Path.extend({\n type: 'sector',\n shape: {\n cx: 0,\n cy: 0,\n r0: 0,\n r: 0,\n startAngle: 0,\n endAngle: Math.PI * 2,\n clockwise: true\n },\n brush: fixClipWithShadow(Path.prototype.brush),\n buildPath: function (ctx, shape) {\n var x = shape.cx;\n var y = shape.cy;\n var r0 = Math.max(shape.r0 || 0, 0);\n var r = Math.max(shape.r, 0);\n var startAngle = shape.startAngle;\n var endAngle = shape.endAngle;\n var clockwise = shape.clockwise;\n var unitX = Math.cos(startAngle);\n var unitY = Math.sin(startAngle);\n ctx.moveTo(unitX * r0 + x, unitY * r0 + y);\n ctx.lineTo(unitX * r + x, unitY * r + y);\n ctx.arc(x, y, r, startAngle, endAngle, !clockwise);\n ctx.lineTo(Math.cos(endAngle) * r0 + x, Math.sin(endAngle) * r0 + y);\n\n if (r0 !== 0) {\n ctx.arc(x, y, r0, endAngle, startAngle, clockwise);\n }\n\n ctx.closePath();\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// (1) The code `if (__DEV__) ...` can be removed by build tool.\n// (2) If intend to use `__DEV__`, this module should be imported. Use a global\n// variable `__DEV__` may cause that miss the declaration (see #6535), or the\n// declaration is behind of the using position (for example in `Model.extent`,\n// And tools like rollup can not analysis the dependency if not import).\nvar dev; // In browser\n\nif (typeof window !== 'undefined') {\n dev = window.__DEV__;\n} // In node\nelse if (typeof global !== 'undefined') {\n dev = global.__DEV__;\n }\n\nif (typeof dev === 'undefined') {\n dev = true;\n}\n\nvar __DEV__ = dev;\nexports.__DEV__ = __DEV__;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar env = require(\"zrender/lib/core/env\");\n\nvar _format = require(\"../util/format\");\n\nvar formatTime = _format.formatTime;\nvar encodeHTML = _format.encodeHTML;\nvar addCommas = _format.addCommas;\nvar getTooltipMarker = _format.getTooltipMarker;\n\nvar modelUtil = require(\"../util/model\");\n\nvar ComponentModel = require(\"./Component\");\n\nvar colorPaletteMixin = require(\"./mixin/colorPalette\");\n\nvar dataFormatMixin = require(\"../model/mixin/dataFormat\");\n\nvar _layout = require(\"../util/layout\");\n\nvar getLayoutParams = _layout.getLayoutParams;\nvar mergeLayoutParam = _layout.mergeLayoutParam;\n\nvar _task = require(\"../stream/task\");\n\nvar createTask = _task.createTask;\n\nvar _sourceHelper = require(\"../data/helper/sourceHelper\");\n\nvar prepareSource = _sourceHelper.prepareSource;\nvar getSource = _sourceHelper.getSource;\n\nvar _dataProvider = require(\"../data/helper/dataProvider\");\n\nvar retrieveRawValue = _dataProvider.retrieveRawValue;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar inner = modelUtil.makeInner();\nvar SeriesModel = ComponentModel.extend({\n type: 'series.__base__',\n\n /**\n * @readOnly\n */\n seriesIndex: 0,\n // coodinateSystem will be injected in the echarts/CoordinateSystem\n coordinateSystem: null,\n\n /**\n * @type {Object}\n * @protected\n */\n defaultOption: null,\n\n /**\n * Data provided for legend\n * @type {Function}\n */\n // PENDING\n legendDataProvider: null,\n\n /**\n * Access path of color for visual\n */\n visualColorAccessPath: 'itemStyle.color',\n\n /**\n * Support merge layout params.\n * Only support 'box' now (left/right/top/bottom/width/height).\n * @type {string|Object} Object can be {ignoreSize: true}\n * @readOnly\n */\n layoutMode: null,\n init: function (option, parentModel, ecModel, extraOpt) {\n /**\n * @type {number}\n * @readOnly\n */\n this.seriesIndex = this.componentIndex;\n this.dataTask = createTask({\n count: dataTaskCount,\n reset: dataTaskReset\n });\n this.dataTask.context = {\n model: this\n };\n this.mergeDefaultAndTheme(option, ecModel);\n prepareSource(this);\n var data = this.getInitialData(option, ecModel);\n wrapData(data, this);\n this.dataTask.context.data = data;\n\n /**\n * @type {module:echarts/data/List|module:echarts/data/Tree|module:echarts/data/Graph}\n * @private\n */\n inner(this).dataBeforeProcessed = data; // If we reverse the order (make data firstly, and then make\n // dataBeforeProcessed by cloneShallow), cloneShallow will\n // cause data.graph.data !== data when using\n // module:echarts/data/Graph or module:echarts/data/Tree.\n // See module:echarts/data/helper/linkList\n // Theoretically, it is unreasonable to call `seriesModel.getData()` in the model\n // init or merge stage, because the data can be restored. So we do not `restoreData`\n // and `setData` here, which forbids calling `seriesModel.getData()` in this stage.\n // Call `seriesModel.getRawData()` instead.\n // this.restoreData();\n\n autoSeriesName(this);\n },\n\n /**\n * Util for merge default and theme to option\n * @param {Object} option\n * @param {module:echarts/model/Global} ecModel\n */\n mergeDefaultAndTheme: function (option, ecModel) {\n var layoutMode = this.layoutMode;\n var inputPositionParams = layoutMode ? getLayoutParams(option) : {}; // Backward compat: using subType on theme.\n // But if name duplicate between series subType\n // (for example: parallel) add component mainType,\n // add suffix 'Series'.\n\n var themeSubType = this.subType;\n\n if (ComponentModel.hasClass(themeSubType)) {\n themeSubType += 'Series';\n }\n\n zrUtil.merge(option, ecModel.getTheme().get(this.subType));\n zrUtil.merge(option, this.getDefaultOption()); // Default label emphasis `show`\n\n modelUtil.defaultEmphasis(option, 'label', ['show']);\n this.fillDataTextStyle(option.data);\n\n if (layoutMode) {\n mergeLayoutParam(option, inputPositionParams, layoutMode);\n }\n },\n mergeOption: function (newSeriesOption, ecModel) {\n // this.settingTask.dirty();\n newSeriesOption = zrUtil.merge(this.option, newSeriesOption, true);\n this.fillDataTextStyle(newSeriesOption.data);\n var layoutMode = this.layoutMode;\n\n if (layoutMode) {\n mergeLayoutParam(this.option, newSeriesOption, layoutMode);\n }\n\n prepareSource(this);\n var data = this.getInitialData(newSeriesOption, ecModel);\n wrapData(data, this);\n this.dataTask.dirty();\n this.dataTask.context.data = data;\n inner(this).dataBeforeProcessed = data;\n autoSeriesName(this);\n },\n fillDataTextStyle: function (data) {\n // Default data label emphasis `show`\n // FIXME Tree structure data ?\n // FIXME Performance ?\n if (data && !zrUtil.isTypedArray(data)) {\n var props = ['show'];\n\n for (var i = 0; i < data.length; i++) {\n if (data[i] && data[i].label) {\n modelUtil.defaultEmphasis(data[i], 'label', props);\n }\n }\n }\n },\n\n /**\n * Init a data structure from data related option in series\n * Must be overwritten\n */\n getInitialData: function () {},\n\n /**\n * Append data to list\n * @param {Object} params\n * @param {Array|TypedArray} params.data\n */\n appendData: function (params) {\n // FIXME ???\n // (1) If data from dataset, forbidden append.\n // (2) support append data of dataset.\n var data = this.getRawData();\n data.appendData(params.data);\n },\n\n /**\n * Consider some method like `filter`, `map` need make new data,\n * We should make sure that `seriesModel.getData()` get correct\n * data in the stream procedure. So we fetch data from upstream\n * each time `task.perform` called.\n * @param {string} [dataType]\n * @return {module:echarts/data/List}\n */\n getData: function (dataType) {\n var task = getCurrentTask(this);\n\n if (task) {\n var data = task.context.data;\n return dataType == null ? data : data.getLinkedData(dataType);\n } else {\n // When series is not alive (that may happen when click toolbox\n // restore or setOption with not merge mode), series data may\n // be still need to judge animation or something when graphic\n // elements want to know whether fade out.\n return inner(this).data;\n }\n },\n\n /**\n * @param {module:echarts/data/List} data\n */\n setData: function (data) {\n var task = getCurrentTask(this);\n\n if (task) {\n var context = task.context; // Consider case: filter, data sample.\n\n if (context.data !== data && task.modifyOutputEnd) {\n task.setOutputEnd(data.count());\n }\n\n context.outputData = data; // Caution: setData should update context.data,\n // Because getData may be called multiply in a\n // single stage and expect to get the data just\n // set. (For example, AxisProxy, x y both call\n // getData and setDate sequentially).\n // So the context.data should be fetched from\n // upstream each time when a stage starts to be\n // performed.\n\n if (task !== this.dataTask) {\n context.data = data;\n }\n }\n\n inner(this).data = data;\n },\n\n /**\n * @see {module:echarts/data/helper/sourceHelper#getSource}\n * @return {module:echarts/data/Source} source\n */\n getSource: function () {\n return getSource(this);\n },\n\n /**\n * Get data before processed\n * @return {module:echarts/data/List}\n */\n getRawData: function () {\n return inner(this).dataBeforeProcessed;\n },\n\n /**\n * Get base axis if has coordinate system and has axis.\n * By default use coordSys.getBaseAxis();\n * Can be overrided for some chart.\n * @return {type} description\n */\n getBaseAxis: function () {\n var coordSys = this.coordinateSystem;\n return coordSys && coordSys.getBaseAxis && coordSys.getBaseAxis();\n },\n // FIXME\n\n /**\n * Default tooltip formatter\n *\n * @param {number} dataIndex\n * @param {boolean} [multipleSeries=false]\n * @param {number} [dataType]\n * @param {string} [renderMode='html'] valid values: 'html' and 'richText'.\n * 'html' is used for rendering tooltip in extra DOM form, and the result\n * string is used as DOM HTML content.\n * 'richText' is used for rendering tooltip in rich text form, for those where\n * DOM operation is not supported.\n * @return {Object} formatted tooltip with `html` and `markers`\n */\n formatTooltip: function (dataIndex, multipleSeries, dataType, renderMode) {\n var series = this;\n renderMode = renderMode || 'html';\n var newLine = renderMode === 'html' ? '<br/>' : '\\n';\n var isRichText = renderMode === 'richText';\n var markers = {};\n var markerId = 0;\n\n function formatArrayValue(value) {\n // ??? TODO refactor these logic.\n // check: category-no-encode-has-axis-data in dataset.html\n var vertially = zrUtil.reduce(value, function (vertially, val, idx) {\n var dimItem = data.getDimensionInfo(idx);\n return vertially |= dimItem && dimItem.tooltip !== false && dimItem.displayName != null;\n }, 0);\n var result = [];\n tooltipDims.length ? zrUtil.each(tooltipDims, function (dim) {\n setEachItem(retrieveRawValue(data, dataIndex, dim), dim);\n }) // By default, all dims is used on tooltip.\n : zrUtil.each(value, setEachItem);\n\n function setEachItem(val, dim) {\n var dimInfo = data.getDimensionInfo(dim); // If `dimInfo.tooltip` is not set, show tooltip.\n\n if (!dimInfo || dimInfo.otherDims.tooltip === false) {\n return;\n }\n\n var dimType = dimInfo.type;\n var markName = 'sub' + series.seriesIndex + 'at' + markerId;\n var dimHead = getTooltipMarker({\n color: color,\n type: 'subItem',\n renderMode: renderMode,\n markerId: markName\n });\n var dimHeadStr = typeof dimHead === 'string' ? dimHead : dimHead.content;\n var valStr = (vertially ? dimHeadStr + encodeHTML(dimInfo.displayName || '-') + ': ' : '') + // FIXME should not format time for raw data?\n encodeHTML(dimType === 'ordinal' ? val + '' : dimType === 'time' ? multipleSeries ? '' : formatTime('yyyy/MM/dd hh:mm:ss', val) : addCommas(val));\n valStr && result.push(valStr);\n\n if (isRichText) {\n markers[markName] = color;\n ++markerId;\n }\n }\n\n var newLine = vertially ? isRichText ? '\\n' : '<br/>' : '';\n var content = newLine + result.join(newLine || ', ');\n return {\n renderMode: renderMode,\n content: content,\n style: markers\n };\n }\n\n function formatSingleValue(val) {\n // return encodeHTML(addCommas(val));\n return {\n renderMode: renderMode,\n content: encodeHTML(addCommas(val)),\n style: markers\n };\n }\n\n var data = this.getData();\n var tooltipDims = data.mapDimension('defaultedTooltip', true);\n var tooltipDimLen = tooltipDims.length;\n var value = this.getRawValue(dataIndex);\n var isValueArr = zrUtil.isArray(value);\n var color = data.getItemVisual(dataIndex, 'color');\n\n if (zrUtil.isObject(color) && color.colorStops) {\n color = (color.colorStops[0] || {}).color;\n }\n\n color = color || 'transparent'; // Complicated rule for pretty tooltip.\n\n var formattedValue = tooltipDimLen > 1 || isValueArr && !tooltipDimLen ? formatArrayValue(value) : tooltipDimLen ? formatSingleValue(retrieveRawValue(data, dataIndex, tooltipDims[0])) : formatSingleValue(isValueArr ? value[0] : value);\n var content = formattedValue.content;\n var markName = series.seriesIndex + 'at' + markerId;\n var colorEl = getTooltipMarker({\n color: color,\n type: 'item',\n renderMode: renderMode,\n markerId: markName\n });\n markers[markName] = color;\n ++markerId;\n var name = data.getName(dataIndex);\n var seriesName = this.name;\n\n if (!modelUtil.isNameSpecified(this)) {\n seriesName = '';\n }\n\n seriesName = seriesName ? encodeHTML(seriesName) + (!multipleSeries ? newLine : ': ') : '';\n var colorStr = typeof colorEl === 'string' ? colorEl : colorEl.content;\n var html = !multipleSeries ? seriesName + colorStr + (name ? encodeHTML(name) + ': ' + content : content) : colorStr + seriesName + content;\n return {\n html: html,\n markers: markers\n };\n },\n\n /**\n * @return {boolean}\n */\n isAnimationEnabled: function () {\n if (env.node) {\n return false;\n }\n\n var animationEnabled = this.getShallow('animation');\n\n if (animationEnabled) {\n if (this.getData().count() > this.getShallow('animationThreshold')) {\n animationEnabled = false;\n }\n }\n\n return animationEnabled;\n },\n restoreData: function () {\n this.dataTask.dirty();\n },\n getColorFromPalette: function (name, scope, requestColorNum) {\n var ecModel = this.ecModel; // PENDING\n\n var color = colorPaletteMixin.getColorFromPalette.call(this, name, scope, requestColorNum);\n\n if (!color) {\n color = ecModel.getColorFromPalette(name, scope, requestColorNum);\n }\n\n return color;\n },\n\n /**\n * Use `data.mapDimension(coordDim, true)` instead.\n * @deprecated\n */\n coordDimToDataDim: function (coordDim) {\n return this.getRawData().mapDimension(coordDim, true);\n },\n\n /**\n * Get progressive rendering count each step\n * @return {number}\n */\n getProgressive: function () {\n return this.get('progressive');\n },\n\n /**\n * Get progressive rendering count each step\n * @return {number}\n */\n getProgressiveThreshold: function () {\n return this.get('progressiveThreshold');\n },\n\n /**\n * Get data indices for show tooltip content. See tooltip.\n * @abstract\n * @param {Array.<string>|string} dim\n * @param {Array.<number>} value\n * @param {module:echarts/coord/single/SingleAxis} baseAxis\n * @return {Object} {dataIndices, nestestValue}.\n */\n getAxisTooltipData: null,\n\n /**\n * See tooltip.\n * @abstract\n * @param {number} dataIndex\n * @return {Array.<number>} Point of tooltip. null/undefined can be returned.\n */\n getTooltipPosition: null,\n\n /**\n * @see {module:echarts/stream/Scheduler}\n */\n pipeTask: null,\n\n /**\n * Convinient for override in extended class.\n * @protected\n * @type {Function}\n */\n preventIncremental: null,\n\n /**\n * @public\n * @readOnly\n * @type {Object}\n */\n pipelineContext: null\n});\nzrUtil.mixin(SeriesModel, dataFormatMixin);\nzrUtil.mixin(SeriesModel, colorPaletteMixin);\n/**\n * MUST be called after `prepareSource` called\n * Here we need to make auto series, especially for auto legend. But we\n * do not modify series.name in option to avoid side effects.\n */\n\nfunction autoSeriesName(seriesModel) {\n // User specified name has higher priority, otherwise it may cause\n // series can not be queried unexpectedly.\n var name = seriesModel.name;\n\n if (!modelUtil.isNameSpecified(seriesModel)) {\n seriesModel.name = getSeriesAutoName(seriesModel) || name;\n }\n}\n\nfunction getSeriesAutoName(seriesModel) {\n var data = seriesModel.getRawData();\n var dataDims = data.mapDimension('seriesName', true);\n var nameArr = [];\n zrUtil.each(dataDims, function (dataDim) {\n var dimInfo = data.getDimensionInfo(dataDim);\n dimInfo.displayName && nameArr.push(dimInfo.displayName);\n });\n return nameArr.join(' ');\n}\n\nfunction dataTaskCount(context) {\n return context.model.getRawData().count();\n}\n\nfunction dataTaskReset(context) {\n var seriesModel = context.model;\n seriesModel.setData(seriesModel.getRawData().cloneShallow());\n return dataTaskProgress;\n}\n\nfunction dataTaskProgress(param, context) {\n // Avoid repead cloneShallow when data just created in reset.\n if (param.end > context.outputData.count()) {\n context.model.getRawData().cloneShallow(context.outputData);\n }\n} // TODO refactor\n\n\nfunction wrapData(data, seriesModel) {\n zrUtil.each(data.CHANGABLE_METHODS, function (methodName) {\n data.wrapMethod(methodName, zrUtil.curry(onDataSelfChange, seriesModel));\n });\n}\n\nfunction onDataSelfChange(seriesModel) {\n var task = getCurrentTask(seriesModel);\n\n if (task) {\n // Consider case: filter, selectRange\n task.setOutputEnd(this.count());\n }\n}\n\nfunction getCurrentTask(seriesModel) {\n var scheduler = (seriesModel.ecModel || {}).scheduler;\n var pipeline = scheduler && scheduler.getPipeline(seriesModel.uid);\n\n if (pipeline) {\n // When pipline finished, the currrentTask keep the last\n // task (renderTask).\n var task = pipeline.currentTask;\n\n if (task) {\n var agentStubMap = task.agentStubMap;\n\n if (agentStubMap) {\n task = agentStubMap.get(seriesModel.uid);\n }\n }\n\n return task;\n }\n}\n\nvar _default = SeriesModel;\nmodule.exports = _default;","var smoothSpline = require(\"./smoothSpline\");\n\nvar smoothBezier = require(\"./smoothBezier\");\n\nfunction buildPath(ctx, shape, closePath) {\n var points = shape.points;\n var smooth = shape.smooth;\n\n if (points && points.length >= 2) {\n if (smooth && smooth !== 'spline') {\n var controlPoints = smoothBezier(points, smooth, closePath, shape.smoothConstraint);\n ctx.moveTo(points[0][0], points[0][1]);\n var len = points.length;\n\n for (var i = 0; i < (closePath ? len : len - 1); i++) {\n var cp1 = controlPoints[i * 2];\n var cp2 = controlPoints[i * 2 + 1];\n var p = points[(i + 1) % len];\n ctx.bezierCurveTo(cp1[0], cp1[1], cp2[0], cp2[1], p[0], p[1]);\n }\n } else {\n if (smooth === 'spline') {\n points = smoothSpline(points, closePath);\n }\n\n ctx.moveTo(points[0][0], points[0][1]);\n\n for (var i = 1, l = points.length; i < l; i++) {\n ctx.lineTo(points[i][0], points[i][1]);\n }\n }\n\n closePath && ctx.closePath();\n }\n}\n\nexports.buildPath = buildPath;","import request from \"@utils/request\";\r\n\r\n/**\r\n * 统计数据\r\n */\r\nexport function getStatisticsInfo() {\r\n return request.get(\"/admin/order/statistics\", {}, { login: true });\r\n}\r\n/**\r\n * 订单月统计\r\n */\r\nexport function getStatisticsMonth(where) {\r\n return request.get(\"/admin/order/data\", where, { login: true });\r\n}\r\n/**\r\n * 订单月统计\r\n */\r\nexport function getAdminOrderList(where) {\r\n return request.get(\"/admin/order/list\", where, { login: true });\r\n}\r\n/**\r\n * 订单改价\r\n */\r\nexport function setAdminOrderPrice(data) {\r\n return request.post(\"/admin/order/price\", data, { login: true });\r\n}\r\n/**\r\n * 订单备注\r\n */\r\nexport function setAdminOrderRemark(data) {\r\n return request.post(\"/admin/order/remark\", data, { login: true });\r\n}\r\n/**\r\n * 订单详情\r\n */\r\nexport function getAdminOrderDetail(orderId) {\r\n return request.get(\"/admin/order/detail/\" + orderId, {}, { login: true });\r\n}\r\n/**\r\n * 订单发货信息获取\r\n */\r\nexport function getAdminOrderDelivery(orderId) {\r\n return request.get(\r\n \"/admin/order/delivery/gain/\" + orderId,\r\n {},\r\n { login: true }\r\n );\r\n}\r\n\r\n/**\r\n * 订单发货保存\r\n */\r\nexport function setAdminOrderDelivery(data) {\r\n return request.post(\"/admin/order/delivery/keep\", data, { login: true });\r\n}\r\n/**\r\n * 订单统计图\r\n */\r\nexport function getStatisticsTime(data) {\r\n return request.get(\"/admin/order/time\", data, { login: true });\r\n}\r\n/**\r\n * 线下付款订单确认付款\r\n */\r\nexport function setOfflinePay(data) {\r\n return request.post(\"/admin/order/offline\", data, { login: true });\r\n}\r\n/**\r\n * 订单确认退款\r\n */\r\nexport function setOrderRefund(data) {\r\n return request.post(\"/admin/order/refund\", data, { login: true });\r\n}\r\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar makeStyleMapper = require(\"./makeStyleMapper\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar getItemStyle = makeStyleMapper([['fill', 'color'], ['stroke', 'borderColor'], ['lineWidth', 'borderWidth'], ['opacity'], ['shadowBlur'], ['shadowOffsetX'], ['shadowOffsetY'], ['shadowColor'], ['textPosition'], ['textAlign']]);\nvar _default = {\n getItemStyle: function (excludes, includes) {\n var style = getItemStyle(this, excludes, includes);\n var lineDash = this.getBorderLineDash();\n lineDash && (style.lineDash = lineDash);\n return style;\n },\n getBorderLineDash: function () {\n var lineType = this.get('borderType');\n return lineType === 'solid' || lineType == null ? null : lineType === 'dashed' ? [5, 5] : [1, 1];\n }\n};\nmodule.exports = _default;","/**\n * @param {Object} ctx\n * @param {Object} shape\n * @param {number} shape.x\n * @param {number} shape.y\n * @param {number} shape.width\n * @param {number} shape.height\n * @param {number} shape.r\n */\nfunction buildPath(ctx, shape) {\n var x = shape.x;\n var y = shape.y;\n var width = shape.width;\n var height = shape.height;\n var r = shape.r;\n var r1;\n var r2;\n var r3;\n var r4; // Convert width and height to positive for better borderRadius\n\n if (width < 0) {\n x = x + width;\n width = -width;\n }\n\n if (height < 0) {\n y = y + height;\n height = -height;\n }\n\n if (typeof r === 'number') {\n r1 = r2 = r3 = r4 = r;\n } else if (r instanceof Array) {\n if (r.length === 1) {\n r1 = r2 = r3 = r4 = r[0];\n } else if (r.length === 2) {\n r1 = r3 = r[0];\n r2 = r4 = r[1];\n } else if (r.length === 3) {\n r1 = r[0];\n r2 = r4 = r[1];\n r3 = r[2];\n } else {\n r1 = r[0];\n r2 = r[1];\n r3 = r[2];\n r4 = r[3];\n }\n } else {\n r1 = r2 = r3 = r4 = 0;\n }\n\n var total;\n\n if (r1 + r2 > width) {\n total = r1 + r2;\n r1 *= width / total;\n r2 *= width / total;\n }\n\n if (r3 + r4 > width) {\n total = r3 + r4;\n r3 *= width / total;\n r4 *= width / total;\n }\n\n if (r2 + r3 > height) {\n total = r2 + r3;\n r2 *= height / total;\n r3 *= height / total;\n }\n\n if (r1 + r4 > height) {\n total = r1 + r4;\n r1 *= height / total;\n r4 *= height / total;\n }\n\n ctx.moveTo(x + r1, y);\n ctx.lineTo(x + width - r2, y);\n r2 !== 0 && ctx.arc(x + width - r2, y + r2, r2, -Math.PI / 2, 0);\n ctx.lineTo(x + width, y + height - r3);\n r3 !== 0 && ctx.arc(x + width - r3, y + height - r3, r3, 0, Math.PI / 2);\n ctx.lineTo(x + r4, y + height);\n r4 !== 0 && ctx.arc(x + r4, y + height - r4, r4, Math.PI / 2, Math.PI);\n ctx.lineTo(x, y + r1);\n r1 !== 0 && ctx.arc(x + r1, y + r1, r1, Math.PI, Math.PI * 1.5);\n}\n\nexports.buildPath = buildPath;","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar isObject = _util.isObject;\nvar each = _util.each;\nvar map = _util.map;\nvar indexOf = _util.indexOf;\nvar retrieve = _util.retrieve;\n\nvar _layout = require(\"../../util/layout\");\n\nvar getLayoutRect = _layout.getLayoutRect;\n\nvar _axisHelper = require(\"../../coord/axisHelper\");\n\nvar createScaleByModel = _axisHelper.createScaleByModel;\nvar ifAxisCrossZero = _axisHelper.ifAxisCrossZero;\nvar niceScaleExtent = _axisHelper.niceScaleExtent;\nvar estimateLabelUnionRect = _axisHelper.estimateLabelUnionRect;\n\nvar Cartesian2D = require(\"./Cartesian2D\");\n\nvar Axis2D = require(\"./Axis2D\");\n\nvar CoordinateSystem = require(\"../../CoordinateSystem\");\n\nvar _dataStackHelper = require(\"../../data/helper/dataStackHelper\");\n\nvar getStackedDimension = _dataStackHelper.getStackedDimension;\n\nrequire(\"./GridModel\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Grid is a region which contains at most 4 cartesian systems\n *\n * TODO Default cartesian\n */\n// Depends on GridModel, AxisModel, which performs preprocess.\n\n/**\n * Check if the axis is used in the specified grid\n * @inner\n */\nfunction isAxisUsedInTheGrid(axisModel, gridModel, ecModel) {\n return axisModel.getCoordSysModel() === gridModel;\n}\n\nfunction Grid(gridModel, ecModel, api) {\n /**\n * @type {Object.<string, module:echarts/coord/cartesian/Cartesian2D>}\n * @private\n */\n this._coordsMap = {};\n /**\n * @type {Array.<module:echarts/coord/cartesian/Cartesian>}\n * @private\n */\n\n this._coordsList = [];\n /**\n * @type {Object.<string, module:echarts/coord/cartesian/Axis2D>}\n * @private\n */\n\n this._axesMap = {};\n /**\n * @type {Array.<module:echarts/coord/cartesian/Axis2D>}\n * @private\n */\n\n this._axesList = [];\n\n this._initCartesian(gridModel, ecModel, api);\n\n this.model = gridModel;\n}\n\nvar gridProto = Grid.prototype;\ngridProto.type = 'grid';\ngridProto.axisPointerEnabled = true;\n\ngridProto.getRect = function () {\n return this._rect;\n};\n\ngridProto.update = function (ecModel, api) {\n var axesMap = this._axesMap;\n\n this._updateScale(ecModel, this.model);\n\n each(axesMap.x, function (xAxis) {\n niceScaleExtent(xAxis.scale, xAxis.model);\n });\n each(axesMap.y, function (yAxis) {\n niceScaleExtent(yAxis.scale, yAxis.model);\n }); // Key: axisDim_axisIndex, value: boolean, whether onZero target.\n\n var onZeroRecords = {};\n each(axesMap.x, function (xAxis) {\n fixAxisOnZero(axesMap, 'y', xAxis, onZeroRecords);\n });\n each(axesMap.y, function (yAxis) {\n fixAxisOnZero(axesMap, 'x', yAxis, onZeroRecords);\n }); // Resize again if containLabel is enabled\n // FIXME It may cause getting wrong grid size in data processing stage\n\n this.resize(this.model, api);\n};\n\nfunction fixAxisOnZero(axesMap, otherAxisDim, axis, onZeroRecords) {\n axis.getAxesOnZeroOf = function () {\n // TODO: onZero of multiple axes.\n return otherAxisOnZeroOf ? [otherAxisOnZeroOf] : [];\n }; // onZero can not be enabled in these two situations:\n // 1. When any other axis is a category axis.\n // 2. When no axis is cross 0 point.\n\n\n var otherAxes = axesMap[otherAxisDim];\n var otherAxisOnZeroOf;\n var axisModel = axis.model;\n var onZero = axisModel.get('axisLine.onZero');\n var onZeroAxisIndex = axisModel.get('axisLine.onZeroAxisIndex');\n\n if (!onZero) {\n return;\n } // If target axis is specified.\n\n\n if (onZeroAxisIndex != null) {\n if (canOnZeroToAxis(otherAxes[onZeroAxisIndex])) {\n otherAxisOnZeroOf = otherAxes[onZeroAxisIndex];\n }\n } else {\n // Find the first available other axis.\n for (var idx in otherAxes) {\n if (otherAxes.hasOwnProperty(idx) && canOnZeroToAxis(otherAxes[idx]) // Consider that two Y axes on one value axis,\n // if both onZero, the two Y axes overlap.\n && !onZeroRecords[getOnZeroRecordKey(otherAxes[idx])]) {\n otherAxisOnZeroOf = otherAxes[idx];\n break;\n }\n }\n }\n\n if (otherAxisOnZeroOf) {\n onZeroRecords[getOnZeroRecordKey(otherAxisOnZeroOf)] = true;\n }\n\n function getOnZeroRecordKey(axis) {\n return axis.dim + '_' + axis.index;\n }\n}\n\nfunction canOnZeroToAxis(axis) {\n return axis && axis.type !== 'category' && axis.type !== 'time' && ifAxisCrossZero(axis);\n}\n/**\n * Resize the grid\n * @param {module:echarts/coord/cartesian/GridModel} gridModel\n * @param {module:echarts/ExtensionAPI} api\n */\n\n\ngridProto.resize = function (gridModel, api, ignoreContainLabel) {\n var gridRect = getLayoutRect(gridModel.getBoxLayoutParams(), {\n width: api.getWidth(),\n height: api.getHeight()\n });\n this._rect = gridRect;\n var axesList = this._axesList;\n adjustAxes(); // Minus label size\n\n if (!ignoreContainLabel && gridModel.get('containLabel')) {\n each(axesList, function (axis) {\n if (!axis.model.get('axisLabel.inside')) {\n var labelUnionRect = estimateLabelUnionRect(axis);\n\n if (labelUnionRect) {\n var dim = axis.isHorizontal() ? 'height' : 'width';\n var margin = axis.model.get('axisLabel.margin');\n gridRect[dim] -= labelUnionRect[dim] + margin;\n\n if (axis.position === 'top') {\n gridRect.y += labelUnionRect.height + margin;\n } else if (axis.position === 'left') {\n gridRect.x += labelUnionRect.width + margin;\n }\n }\n }\n });\n adjustAxes();\n }\n\n function adjustAxes() {\n each(axesList, function (axis) {\n var isHorizontal = axis.isHorizontal();\n var extent = isHorizontal ? [0, gridRect.width] : [0, gridRect.height];\n var idx = axis.inverse ? 1 : 0;\n axis.setExtent(extent[idx], extent[1 - idx]);\n updateAxisTransform(axis, isHorizontal ? gridRect.x : gridRect.y);\n });\n }\n};\n/**\n * @param {string} axisType\n * @param {number} [axisIndex]\n */\n\n\ngridProto.getAxis = function (axisType, axisIndex) {\n var axesMapOnDim = this._axesMap[axisType];\n\n if (axesMapOnDim != null) {\n if (axisIndex == null) {\n // Find first axis\n for (var name in axesMapOnDim) {\n if (axesMapOnDim.hasOwnProperty(name)) {\n return axesMapOnDim[name];\n }\n }\n }\n\n return axesMapOnDim[axisIndex];\n }\n};\n/**\n * @return {Array.<module:echarts/coord/Axis>}\n */\n\n\ngridProto.getAxes = function () {\n return this._axesList.slice();\n};\n/**\n * Usage:\n * grid.getCartesian(xAxisIndex, yAxisIndex);\n * grid.getCartesian(xAxisIndex);\n * grid.getCartesian(null, yAxisIndex);\n * grid.getCartesian({xAxisIndex: ..., yAxisIndex: ...});\n *\n * @param {number|Object} [xAxisIndex]\n * @param {number} [yAxisIndex]\n */\n\n\ngridProto.getCartesian = function (xAxisIndex, yAxisIndex) {\n if (xAxisIndex != null && yAxisIndex != null) {\n var key = 'x' + xAxisIndex + 'y' + yAxisIndex;\n return this._coordsMap[key];\n }\n\n if (isObject(xAxisIndex)) {\n yAxisIndex = xAxisIndex.yAxisIndex;\n xAxisIndex = xAxisIndex.xAxisIndex;\n } // When only xAxisIndex or yAxisIndex given, find its first cartesian.\n\n\n for (var i = 0, coordList = this._coordsList; i < coordList.length; i++) {\n if (coordList[i].getAxis('x').index === xAxisIndex || coordList[i].getAxis('y').index === yAxisIndex) {\n return coordList[i];\n }\n }\n};\n\ngridProto.getCartesians = function () {\n return this._coordsList.slice();\n};\n/**\n * @implements\n * see {module:echarts/CoodinateSystem}\n */\n\n\ngridProto.convertToPixel = function (ecModel, finder, value) {\n var target = this._findConvertTarget(ecModel, finder);\n\n return target.cartesian ? target.cartesian.dataToPoint(value) : target.axis ? target.axis.toGlobalCoord(target.axis.dataToCoord(value)) : null;\n};\n/**\n * @implements\n * see {module:echarts/CoodinateSystem}\n */\n\n\ngridProto.convertFromPixel = function (ecModel, finder, value) {\n var target = this._findConvertTarget(ecModel, finder);\n\n return target.cartesian ? target.cartesian.pointToData(value) : target.axis ? target.axis.coordToData(target.axis.toLocalCoord(value)) : null;\n};\n/**\n * @inner\n */\n\n\ngridProto._findConvertTarget = function (ecModel, finder) {\n var seriesModel = finder.seriesModel;\n var xAxisModel = finder.xAxisModel || seriesModel && seriesModel.getReferringComponents('xAxis')[0];\n var yAxisModel = finder.yAxisModel || seriesModel && seriesModel.getReferringComponents('yAxis')[0];\n var gridModel = finder.gridModel;\n var coordsList = this._coordsList;\n var cartesian;\n var axis;\n\n if (seriesModel) {\n cartesian = seriesModel.coordinateSystem;\n indexOf(coordsList, cartesian) < 0 && (cartesian = null);\n } else if (xAxisModel && yAxisModel) {\n cartesian = this.getCartesian(xAxisModel.componentIndex, yAxisModel.componentIndex);\n } else if (xAxisModel) {\n axis = this.getAxis('x', xAxisModel.componentIndex);\n } else if (yAxisModel) {\n axis = this.getAxis('y', yAxisModel.componentIndex);\n } // Lowest priority.\n else if (gridModel) {\n var grid = gridModel.coordinateSystem;\n\n if (grid === this) {\n cartesian = this._coordsList[0];\n }\n }\n\n return {\n cartesian: cartesian,\n axis: axis\n };\n};\n/**\n * @implements\n * see {module:echarts/CoodinateSystem}\n */\n\n\ngridProto.containPoint = function (point) {\n var coord = this._coordsList[0];\n\n if (coord) {\n return coord.containPoint(point);\n }\n};\n/**\n * Initialize cartesian coordinate systems\n * @private\n */\n\n\ngridProto._initCartesian = function (gridModel, ecModel, api) {\n var axisPositionUsed = {\n left: false,\n right: false,\n top: false,\n bottom: false\n };\n var axesMap = {\n x: {},\n y: {}\n };\n var axesCount = {\n x: 0,\n y: 0\n }; /// Create axis\n\n ecModel.eachComponent('xAxis', createAxisCreator('x'), this);\n ecModel.eachComponent('yAxis', createAxisCreator('y'), this);\n\n if (!axesCount.x || !axesCount.y) {\n // Roll back when there no either x or y axis\n this._axesMap = {};\n this._axesList = [];\n return;\n }\n\n this._axesMap = axesMap; /// Create cartesian2d\n\n each(axesMap.x, function (xAxis, xAxisIndex) {\n each(axesMap.y, function (yAxis, yAxisIndex) {\n var key = 'x' + xAxisIndex + 'y' + yAxisIndex;\n var cartesian = new Cartesian2D(key);\n cartesian.grid = this;\n cartesian.model = gridModel;\n this._coordsMap[key] = cartesian;\n\n this._coordsList.push(cartesian);\n\n cartesian.addAxis(xAxis);\n cartesian.addAxis(yAxis);\n }, this);\n }, this);\n\n function createAxisCreator(axisType) {\n return function (axisModel, idx) {\n if (!isAxisUsedInTheGrid(axisModel, gridModel, ecModel)) {\n return;\n }\n\n var axisPosition = axisModel.get('position');\n\n if (axisType === 'x') {\n // Fix position\n if (axisPosition !== 'top' && axisPosition !== 'bottom') {\n // Default bottom of X\n axisPosition = 'bottom';\n\n if (axisPositionUsed[axisPosition]) {\n axisPosition = axisPosition === 'top' ? 'bottom' : 'top';\n }\n }\n } else {\n // Fix position\n if (axisPosition !== 'left' && axisPosition !== 'right') {\n // Default left of Y\n axisPosition = 'left';\n\n if (axisPositionUsed[axisPosition]) {\n axisPosition = axisPosition === 'left' ? 'right' : 'left';\n }\n }\n }\n\n axisPositionUsed[axisPosition] = true;\n var axis = new Axis2D(axisType, createScaleByModel(axisModel), [0, 0], axisModel.get('type'), axisPosition);\n var isCategory = axis.type === 'category';\n axis.onBand = isCategory && axisModel.get('boundaryGap');\n axis.inverse = axisModel.get('inverse'); // Inject axis into axisModel\n\n axisModel.axis = axis; // Inject axisModel into axis\n\n axis.model = axisModel; // Inject grid info axis\n\n axis.grid = this; // Index of axis, can be used as key\n\n axis.index = idx;\n\n this._axesList.push(axis);\n\n axesMap[axisType][idx] = axis;\n axesCount[axisType]++;\n };\n }\n};\n/**\n * Update cartesian properties from series\n * @param {module:echarts/model/Option} option\n * @private\n */\n\n\ngridProto._updateScale = function (ecModel, gridModel) {\n // Reset scale\n each(this._axesList, function (axis) {\n axis.scale.setExtent(Infinity, -Infinity);\n });\n ecModel.eachSeries(function (seriesModel) {\n if (isCartesian2D(seriesModel)) {\n var axesModels = findAxesModels(seriesModel, ecModel);\n var xAxisModel = axesModels[0];\n var yAxisModel = axesModels[1];\n\n if (!isAxisUsedInTheGrid(xAxisModel, gridModel, ecModel) || !isAxisUsedInTheGrid(yAxisModel, gridModel, ecModel)) {\n return;\n }\n\n var cartesian = this.getCartesian(xAxisModel.componentIndex, yAxisModel.componentIndex);\n var data = seriesModel.getData();\n var xAxis = cartesian.getAxis('x');\n var yAxis = cartesian.getAxis('y');\n\n if (data.type === 'list') {\n unionExtent(data, xAxis, seriesModel);\n unionExtent(data, yAxis, seriesModel);\n }\n }\n }, this);\n\n function unionExtent(data, axis, seriesModel) {\n each(data.mapDimension(axis.dim, true), function (dim) {\n axis.scale.unionExtentFromData( // For example, the extent of the orginal dimension\n // is [0.1, 0.5], the extent of the `stackResultDimension`\n // is [7, 9], the final extent should not include [0.1, 0.5].\n data, getStackedDimension(data, dim));\n });\n }\n};\n/**\n * @param {string} [dim] 'x' or 'y' or 'auto' or null/undefined\n * @return {Object} {baseAxes: [], otherAxes: []}\n */\n\n\ngridProto.getTooltipAxes = function (dim) {\n var baseAxes = [];\n var otherAxes = [];\n each(this.getCartesians(), function (cartesian) {\n var baseAxis = dim != null && dim !== 'auto' ? cartesian.getAxis(dim) : cartesian.getBaseAxis();\n var otherAxis = cartesian.getOtherAxis(baseAxis);\n indexOf(baseAxes, baseAxis) < 0 && baseAxes.push(baseAxis);\n indexOf(otherAxes, otherAxis) < 0 && otherAxes.push(otherAxis);\n });\n return {\n baseAxes: baseAxes,\n otherAxes: otherAxes\n };\n};\n/**\n * @inner\n */\n\n\nfunction updateAxisTransform(axis, coordBase) {\n var axisExtent = axis.getExtent();\n var axisExtentSum = axisExtent[0] + axisExtent[1]; // Fast transform\n\n axis.toGlobalCoord = axis.dim === 'x' ? function (coord) {\n return coord + coordBase;\n } : function (coord) {\n return axisExtentSum - coord + coordBase;\n };\n axis.toLocalCoord = axis.dim === 'x' ? function (coord) {\n return coord - coordBase;\n } : function (coord) {\n return axisExtentSum - coord + coordBase;\n };\n}\n\nvar axesTypes = ['xAxis', 'yAxis'];\n/**\n * @inner\n */\n\nfunction findAxesModels(seriesModel, ecModel) {\n return map(axesTypes, function (axisType) {\n var axisModel = seriesModel.getReferringComponents(axisType)[0];\n return axisModel;\n });\n}\n/**\n * @inner\n */\n\n\nfunction isCartesian2D(seriesModel) {\n return seriesModel.get('coordinateSystem') === 'cartesian2d';\n}\n\nGrid.create = function (ecModel, api) {\n var grids = [];\n ecModel.eachComponent('grid', function (gridModel, idx) {\n var grid = new Grid(gridModel, ecModel, api);\n grid.name = 'grid_' + idx; // dataSampling requires axis extent, so resize\n // should be performed in create stage.\n\n grid.resize(gridModel, api, true);\n gridModel.coordinateSystem = grid;\n grids.push(grid);\n }); // Inject the coordinateSystems into seriesModel\n\n ecModel.eachSeries(function (seriesModel) {\n if (!isCartesian2D(seriesModel)) {\n return;\n }\n\n var axesModels = findAxesModels(seriesModel, ecModel);\n var xAxisModel = axesModels[0];\n var yAxisModel = axesModels[1];\n var gridModel = xAxisModel.getCoordSysModel();\n var grid = gridModel.coordinateSystem;\n seriesModel.coordinateSystem = grid.getCartesian(xAxisModel.componentIndex, yAxisModel.componentIndex);\n });\n return grids;\n}; // For deciding which dimensions to use when creating list data\n\n\nGrid.dimensions = Grid.prototype.dimensions = Cartesian2D.prototype.dimensions;\nCoordinateSystem.register('cartesian2d', Grid);\nvar _default = Grid;\nmodule.exports = _default;","module.exports = require(\"core-js/library/fn/get-iterator\");","var util = require(\"./core/util\");\n\nvar _config = require(\"./config\");\n\nvar devicePixelRatio = _config.devicePixelRatio;\n\nvar Style = require(\"./graphic/Style\");\n\nvar Pattern = require(\"./graphic/Pattern\");\n\n/**\n * @module zrender/Layer\n * @author pissang(https://www.github.com/pissang)\n */\nfunction returnFalse() {\n return false;\n}\n/**\n * 创建dom\n *\n * @inner\n * @param {string} id dom id 待用\n * @param {Painter} painter painter instance\n * @param {number} number\n */\n\n\nfunction createDom(id, painter, dpr) {\n var newDom = util.createCanvas();\n var width = painter.getWidth();\n var height = painter.getHeight();\n var newDomStyle = newDom.style;\n\n if (newDomStyle) {\n // In node or some other non-browser environment\n newDomStyle.position = 'absolute';\n newDomStyle.left = 0;\n newDomStyle.top = 0;\n newDomStyle.width = width + 'px';\n newDomStyle.height = height + 'px';\n newDom.setAttribute('data-zr-dom-id', id);\n }\n\n newDom.width = width * dpr;\n newDom.height = height * dpr;\n return newDom;\n}\n/**\n * @alias module:zrender/Layer\n * @constructor\n * @extends module:zrender/mixin/Transformable\n * @param {string} id\n * @param {module:zrender/Painter} painter\n * @param {number} [dpr]\n */\n\n\nvar Layer = function (id, painter, dpr) {\n var dom;\n dpr = dpr || devicePixelRatio;\n\n if (typeof id === 'string') {\n dom = createDom(id, painter, dpr);\n } // Not using isDom because in node it will return false\n else if (util.isObject(id)) {\n dom = id;\n id = dom.id;\n }\n\n this.id = id;\n this.dom = dom;\n var domStyle = dom.style;\n\n if (domStyle) {\n // Not in node\n dom.onselectstart = returnFalse; // 避免页面选中的尴尬\n\n domStyle['-webkit-user-select'] = 'none';\n domStyle['user-select'] = 'none';\n domStyle['-webkit-touch-callout'] = 'none';\n domStyle['-webkit-tap-highlight-color'] = 'rgba(0,0,0,0)';\n domStyle['padding'] = 0;\n domStyle['margin'] = 0;\n domStyle['border-width'] = 0;\n }\n\n this.domBack = null;\n this.ctxBack = null;\n this.painter = painter;\n this.config = null; // Configs\n\n /**\n * 每次清空画布的颜色\n * @type {string}\n * @default 0\n */\n\n this.clearColor = 0;\n /**\n * 是否开启动态模糊\n * @type {boolean}\n * @default false\n */\n\n this.motionBlur = false;\n /**\n * 在开启动态模糊的时候使用,与上一帧混合的alpha值,值越大尾迹越明显\n * @type {number}\n * @default 0.7\n */\n\n this.lastFrameAlpha = 0.7;\n /**\n * Layer dpr\n * @type {number}\n */\n\n this.dpr = dpr;\n};\n\nLayer.prototype = {\n constructor: Layer,\n __dirty: true,\n __used: false,\n __drawIndex: 0,\n __startIndex: 0,\n __endIndex: 0,\n incremental: false,\n getElementCount: function () {\n return this.__endIndex - this.__startIndex;\n },\n initContext: function () {\n this.ctx = this.dom.getContext('2d');\n this.ctx.dpr = this.dpr;\n },\n createBackBuffer: function () {\n var dpr = this.dpr;\n this.domBack = createDom('back-' + this.id, this.painter, dpr);\n this.ctxBack = this.domBack.getContext('2d');\n\n if (dpr !== 1) {\n this.ctxBack.scale(dpr, dpr);\n }\n },\n\n /**\n * @param {number} width\n * @param {number} height\n */\n resize: function (width, height) {\n var dpr = this.dpr;\n var dom = this.dom;\n var domStyle = dom.style;\n var domBack = this.domBack;\n\n if (domStyle) {\n domStyle.width = width + 'px';\n domStyle.height = height + 'px';\n }\n\n dom.width = width * dpr;\n dom.height = height * dpr;\n\n if (domBack) {\n domBack.width = width * dpr;\n domBack.height = height * dpr;\n\n if (dpr !== 1) {\n this.ctxBack.scale(dpr, dpr);\n }\n }\n },\n\n /**\n * 清空该层画布\n * @param {boolean} [clearAll]=false Clear all with out motion blur\n * @param {Color} [clearColor]\n */\n clear: function (clearAll, clearColor) {\n var dom = this.dom;\n var ctx = this.ctx;\n var width = dom.width;\n var height = dom.height;\n var clearColor = clearColor || this.clearColor;\n var haveMotionBLur = this.motionBlur && !clearAll;\n var lastFrameAlpha = this.lastFrameAlpha;\n var dpr = this.dpr;\n\n if (haveMotionBLur) {\n if (!this.domBack) {\n this.createBackBuffer();\n }\n\n this.ctxBack.globalCompositeOperation = 'copy';\n this.ctxBack.drawImage(dom, 0, 0, width / dpr, height / dpr);\n }\n\n ctx.clearRect(0, 0, width, height);\n\n if (clearColor && clearColor !== 'transparent') {\n var clearColorGradientOrPattern; // Gradient\n\n if (clearColor.colorStops) {\n // Cache canvas gradient\n clearColorGradientOrPattern = clearColor.__canvasGradient || Style.getGradient(ctx, clearColor, {\n x: 0,\n y: 0,\n width: width,\n height: height\n });\n clearColor.__canvasGradient = clearColorGradientOrPattern;\n } // Pattern\n else if (clearColor.image) {\n clearColorGradientOrPattern = Pattern.prototype.getCanvasPattern.call(clearColor, ctx);\n }\n\n ctx.save();\n ctx.fillStyle = clearColorGradientOrPattern || clearColor;\n ctx.fillRect(0, 0, width, height);\n ctx.restore();\n }\n\n if (haveMotionBLur) {\n var domBack = this.domBack;\n ctx.save();\n ctx.globalAlpha = lastFrameAlpha;\n ctx.drawImage(domBack, 0, 0, width, height);\n ctx.restore();\n }\n }\n};\nvar _default = Layer;\nmodule.exports = _default;","var LRU = require(\"../../core/LRU\");\n\nvar globalImageCache = new LRU(50);\n/**\n * @param {string|HTMLImageElement|HTMLCanvasElement|Canvas} newImageOrSrc\n * @return {HTMLImageElement|HTMLCanvasElement|Canvas} image\n */\n\nfunction findExistImage(newImageOrSrc) {\n if (typeof newImageOrSrc === 'string') {\n var cachedImgObj = globalImageCache.get(newImageOrSrc);\n return cachedImgObj && cachedImgObj.image;\n } else {\n return newImageOrSrc;\n }\n}\n/**\n * Caution: User should cache loaded images, but not just count on LRU.\n * Consider if required images more than LRU size, will dead loop occur?\n *\n * @param {string|HTMLImageElement|HTMLCanvasElement|Canvas} newImageOrSrc\n * @param {HTMLImageElement|HTMLCanvasElement|Canvas} image Existent image.\n * @param {module:zrender/Element} [hostEl] For calling `dirty`.\n * @param {Function} [cb] params: (image, cbPayload)\n * @param {Object} [cbPayload] Payload on cb calling.\n * @return {HTMLImageElement|HTMLCanvasElement|Canvas} image\n */\n\n\nfunction createOrUpdateImage(newImageOrSrc, image, hostEl, cb, cbPayload) {\n if (!newImageOrSrc) {\n return image;\n } else if (typeof newImageOrSrc === 'string') {\n // Image should not be loaded repeatly.\n if (image && image.__zrImageSrc === newImageOrSrc || !hostEl) {\n return image;\n } // Only when there is no existent image or existent image src\n // is different, this method is responsible for load.\n\n\n var cachedImgObj = globalImageCache.get(newImageOrSrc);\n var pendingWrap = {\n hostEl: hostEl,\n cb: cb,\n cbPayload: cbPayload\n };\n\n if (cachedImgObj) {\n image = cachedImgObj.image;\n !isImageReady(image) && cachedImgObj.pending.push(pendingWrap);\n } else {\n image = new Image();\n image.onload = image.onerror = imageOnLoad;\n globalImageCache.put(newImageOrSrc, image.__cachedImgObj = {\n image: image,\n pending: [pendingWrap]\n });\n image.src = image.__zrImageSrc = newImageOrSrc;\n }\n\n return image;\n } // newImageOrSrc is an HTMLImageElement or HTMLCanvasElement or Canvas\n else {\n return newImageOrSrc;\n }\n}\n\nfunction imageOnLoad() {\n var cachedImgObj = this.__cachedImgObj;\n this.onload = this.onerror = this.__cachedImgObj = null;\n\n for (var i = 0; i < cachedImgObj.pending.length; i++) {\n var pendingWrap = cachedImgObj.pending[i];\n var cb = pendingWrap.cb;\n cb && cb(this, pendingWrap.cbPayload);\n pendingWrap.hostEl.dirty();\n }\n\n cachedImgObj.pending.length = 0;\n}\n\nfunction isImageReady(image) {\n return image && image.width && image.height;\n}\n\nexports.findExistImage = findExistImage;\nexports.createOrUpdateImage = createOrUpdateImage;\nexports.isImageReady = isImageReady;","var Eventful = require(\"../mixin/Eventful\");\n\nexports.Dispatcher = Eventful;\n\nvar env = require(\"./env\");\n\n/**\n * 事件辅助类\n * @module zrender/core/event\n * @author Kener (@Kener-林峰, kener.linfeng@gmail.com)\n */\nvar isDomLevel2 = typeof window !== 'undefined' && !!window.addEventListener;\nvar MOUSE_EVENT_REG = /^(?:mouse|pointer|contextmenu|drag|drop)|click/;\n\nfunction getBoundingClientRect(el) {\n // BlackBerry 5, iOS 3 (original iPhone) don't have getBoundingRect\n return el.getBoundingClientRect ? el.getBoundingClientRect() : {\n left: 0,\n top: 0\n };\n} // `calculate` is optional, default false\n\n\nfunction clientToLocal(el, e, out, calculate) {\n out = out || {}; // According to the W3C Working Draft, offsetX and offsetY should be relative\n // to the padding edge of the target element. The only browser using this convention\n // is IE. Webkit uses the border edge, Opera uses the content edge, and FireFox does\n // not support the properties.\n // (see http://www.jacklmoore.com/notes/mouse-position/)\n // In zr painter.dom, padding edge equals to border edge.\n // FIXME\n // When mousemove event triggered on ec tooltip, target is not zr painter.dom, and\n // offsetX/Y is relative to e.target, where the calculation of zrX/Y via offsetX/Y\n // is too complex. So css-transfrom dont support in this case temporarily.\n\n if (calculate || !env.canvasSupported) {\n defaultGetZrXY(el, e, out);\n } // Caution: In FireFox, layerX/layerY Mouse position relative to the closest positioned\n // ancestor element, so we should make sure el is positioned (e.g., not position:static).\n // BTW1, Webkit don't return the same results as FF in non-simple cases (like add\n // zoom-factor, overflow / opacity layers, transforms ...)\n // BTW2, (ev.offsetY || ev.pageY - $(ev.target).offset().top) is not correct in preserve-3d.\n // <https://bugs.jquery.com/ticket/8523#comment:14>\n // BTW3, In ff, offsetX/offsetY is always 0.\n else if (env.browser.firefox && e.layerX != null && e.layerX !== e.offsetX) {\n out.zrX = e.layerX;\n out.zrY = e.layerY;\n } // For IE6+, chrome, safari, opera. (When will ff support offsetX?)\n else if (e.offsetX != null) {\n out.zrX = e.offsetX;\n out.zrY = e.offsetY;\n } // For some other device, e.g., IOS safari.\n else {\n defaultGetZrXY(el, e, out);\n }\n\n return out;\n}\n\nfunction defaultGetZrXY(el, e, out) {\n // This well-known method below does not support css transform.\n var box = getBoundingClientRect(el);\n out.zrX = e.clientX - box.left;\n out.zrY = e.clientY - box.top;\n}\n/**\n * 如果存在第三方嵌入的一些dom触发的事件,或touch事件,需要转换一下事件坐标.\n * `calculate` is optional, default false.\n */\n\n\nfunction normalizeEvent(el, e, calculate) {\n e = e || window.event;\n\n if (e.zrX != null) {\n return e;\n }\n\n var eventType = e.type;\n var isTouch = eventType && eventType.indexOf('touch') >= 0;\n\n if (!isTouch) {\n clientToLocal(el, e, e, calculate);\n e.zrDelta = e.wheelDelta ? e.wheelDelta / 120 : -(e.detail || 0) / 3;\n } else {\n var touch = eventType !== 'touchend' ? e.targetTouches[0] : e.changedTouches[0];\n touch && clientToLocal(el, touch, e, calculate);\n } // Add which for click: 1 === left; 2 === middle; 3 === right; otherwise: 0;\n // See jQuery: https://github.com/jquery/jquery/blob/master/src/event.js\n // If e.which has been defined, if may be readonly,\n // see: https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/which\n\n\n var button = e.button;\n\n if (e.which == null && button !== undefined && MOUSE_EVENT_REG.test(e.type)) {\n e.which = button & 1 ? 1 : button & 2 ? 3 : button & 4 ? 2 : 0;\n } // [Caution]: `e.which` from browser is not always reliable. For example,\n // when press left button and `mousemove (pointermove)` in Edge, the `e.which`\n // is 65536 and the `e.button` is -1. But the `mouseup (pointerup)` and\n // `mousedown (pointerdown)` is the same as Chrome does.\n\n\n return e;\n}\n/**\n * @param {HTMLElement} el\n * @param {string} name\n * @param {Function} handler\n */\n\n\nfunction addEventListener(el, name, handler) {\n if (isDomLevel2) {\n // Reproduct the console warning:\n // [Violation] Added non-passive event listener to a scroll-blocking <some> event.\n // Consider marking event handler as 'passive' to make the page more responsive.\n // Just set console log level: verbose in chrome dev tool.\n // then the warning log will be printed when addEventListener called.\n // See https://github.com/WICG/EventListenerOptions/blob/gh-pages/explainer.md\n // We have not yet found a neat way to using passive. Because in zrender the dom event\n // listener delegate all of the upper events of element. Some of those events need\n // to prevent default. For example, the feature `preventDefaultMouseMove` of echarts.\n // Before passive can be adopted, these issues should be considered:\n // (1) Whether and how a zrender user specifies an event listener passive. And by default,\n // passive or not.\n // (2) How to tread that some zrender event listener is passive, and some is not. If\n // we use other way but not preventDefault of mousewheel and touchmove, browser\n // compatibility should be handled.\n // var opts = (env.passiveSupported && name === 'mousewheel')\n // ? {passive: true}\n // // By default, the third param of el.addEventListener is `capture: false`.\n // : void 0;\n // el.addEventListener(name, handler /* , opts */);\n el.addEventListener(name, handler);\n } else {\n el.attachEvent('on' + name, handler);\n }\n}\n\nfunction removeEventListener(el, name, handler) {\n if (isDomLevel2) {\n el.removeEventListener(name, handler);\n } else {\n el.detachEvent('on' + name, handler);\n }\n}\n/**\n * preventDefault and stopPropagation.\n * Notice: do not do that in zrender. Upper application\n * do that if necessary.\n *\n * @memberOf module:zrender/core/event\n * @method\n * @param {Event} e : event对象\n */\n\n\nvar stop = isDomLevel2 ? function (e) {\n e.preventDefault();\n e.stopPropagation();\n e.cancelBubble = true;\n} : function (e) {\n e.returnValue = false;\n e.cancelBubble = true;\n};\n/**\n * This method only works for mouseup and mousedown. The functionality is restricted\n * for fault tolerance, See the `e.which` compatibility above.\n *\n * @param {MouseEvent} e\n * @return {boolean}\n */\n\nfunction isMiddleOrRightButtonOnMouseUpDown(e) {\n return e.which === 2 || e.which === 3;\n}\n/**\n * To be removed.\n * @deprecated\n */\n\n\nfunction notLeftMouse(e) {\n // If e.which is undefined, considered as left mouse event.\n return e.which > 1;\n} // 做向上兼容\n\n\nexports.clientToLocal = clientToLocal;\nexports.normalizeEvent = normalizeEvent;\nexports.addEventListener = addEventListener;\nexports.removeEventListener = removeEventListener;\nexports.stop = stop;\nexports.isMiddleOrRightButtonOnMouseUpDown = isMiddleOrRightButtonOnMouseUpDown;\nexports.notLeftMouse = notLeftMouse;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Model = require(\"../model/Model\");\n\nvar DataDiffer = require(\"./DataDiffer\");\n\nvar Source = require(\"./Source\");\n\nvar _dataProvider = require(\"./helper/dataProvider\");\n\nvar defaultDimValueGetters = _dataProvider.defaultDimValueGetters;\nvar DefaultDataProvider = _dataProvider.DefaultDataProvider;\n\nvar _dimensionHelper = require(\"./helper/dimensionHelper\");\n\nvar summarizeDimensions = _dimensionHelper.summarizeDimensions;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/* global Float64Array, Int32Array, Uint32Array, Uint16Array */\n\n/**\n * List for data storage\n * @module echarts/data/List\n */\nvar isObject = zrUtil.isObject;\nvar UNDEFINED = 'undefined';\nvar INDEX_NOT_FOUND = -1; // Use prefix to avoid index to be the same as otherIdList[idx],\n// which will cause weird udpate animation.\n\nvar ID_PREFIX = 'e\\0\\0';\nvar dataCtors = {\n 'float': typeof Float64Array === UNDEFINED ? Array : Float64Array,\n 'int': typeof Int32Array === UNDEFINED ? Array : Int32Array,\n // Ordinal data type can be string or int\n 'ordinal': Array,\n 'number': Array,\n 'time': Array\n}; // Caution: MUST not use `new CtorUint32Array(arr, 0, len)`, because the Ctor of array is\n// different from the Ctor of typed array.\n\nvar CtorUint32Array = typeof Uint32Array === UNDEFINED ? Array : Uint32Array;\nvar CtorInt32Array = typeof Int32Array === UNDEFINED ? Array : Int32Array;\nvar CtorUint16Array = typeof Uint16Array === UNDEFINED ? Array : Uint16Array;\n\nfunction getIndicesCtor(list) {\n // The possible max value in this._indicies is always this._rawCount despite of filtering.\n return list._rawCount > 65535 ? CtorUint32Array : CtorUint16Array;\n}\n\nfunction cloneChunk(originalChunk) {\n var Ctor = originalChunk.constructor; // Only shallow clone is enough when Array.\n\n return Ctor === Array ? originalChunk.slice() : new Ctor(originalChunk);\n}\n\nvar TRANSFERABLE_PROPERTIES = ['hasItemOption', '_nameList', '_idList', '_invertedIndicesMap', '_rawData', '_chunkSize', '_chunkCount', '_dimValueGetter', '_count', '_rawCount', '_nameDimIdx', '_idDimIdx'];\nvar CLONE_PROPERTIES = ['_extent', '_approximateExtent', '_rawExtent'];\n\nfunction transferProperties(target, source) {\n zrUtil.each(TRANSFERABLE_PROPERTIES.concat(source.__wrappedMethods || []), function (propName) {\n if (source.hasOwnProperty(propName)) {\n target[propName] = source[propName];\n }\n });\n target.__wrappedMethods = source.__wrappedMethods;\n zrUtil.each(CLONE_PROPERTIES, function (propName) {\n target[propName] = zrUtil.clone(source[propName]);\n });\n target._calculationInfo = zrUtil.extend(source._calculationInfo);\n}\n/**\n * @constructor\n * @alias module:echarts/data/List\n *\n * @param {Array.<string|Object>} dimensions\n * For example, ['someDimName', {name: 'someDimName', type: 'someDimType'}, ...].\n * Dimensions should be concrete names like x, y, z, lng, lat, angle, radius\n * Spetial fields: {\n * ordinalMeta: <module:echarts/data/OrdinalMeta>\n * createInvertedIndices: <boolean>\n * }\n * @param {module:echarts/model/Model} hostModel\n */\n\n\nvar List = function (dimensions, hostModel) {\n dimensions = dimensions || ['x', 'y'];\n var dimensionInfos = {};\n var dimensionNames = [];\n var invertedIndicesMap = {};\n\n for (var i = 0; i < dimensions.length; i++) {\n // Use the original dimensions[i], where other flag props may exists.\n var dimensionInfo = dimensions[i];\n\n if (zrUtil.isString(dimensionInfo)) {\n dimensionInfo = {\n name: dimensionInfo\n };\n }\n\n var dimensionName = dimensionInfo.name;\n dimensionInfo.type = dimensionInfo.type || 'float';\n\n if (!dimensionInfo.coordDim) {\n dimensionInfo.coordDim = dimensionName;\n dimensionInfo.coordDimIndex = 0;\n }\n\n dimensionInfo.otherDims = dimensionInfo.otherDims || {};\n dimensionNames.push(dimensionName);\n dimensionInfos[dimensionName] = dimensionInfo;\n dimensionInfo.index = i;\n\n if (dimensionInfo.createInvertedIndices) {\n invertedIndicesMap[dimensionName] = [];\n }\n }\n /**\n * @readOnly\n * @type {Array.<string>}\n */\n\n\n this.dimensions = dimensionNames;\n /**\n * Infomation of each data dimension, like data type.\n * @type {Object}\n */\n\n this._dimensionInfos = dimensionInfos;\n /**\n * @type {module:echarts/model/Model}\n */\n\n this.hostModel = hostModel;\n /**\n * @type {module:echarts/model/Model}\n */\n\n this.dataType;\n /**\n * Indices stores the indices of data subset after filtered.\n * This data subset will be used in chart.\n * @type {Array.<number>}\n * @readOnly\n */\n\n this._indices = null;\n this._count = 0;\n this._rawCount = 0;\n /**\n * Data storage\n * @type {Object.<key, Array.<TypedArray|Array>>}\n * @private\n */\n\n this._storage = {};\n /**\n * @type {Array.<string>}\n */\n\n this._nameList = [];\n /**\n * @type {Array.<string>}\n */\n\n this._idList = [];\n /**\n * Models of data option is stored sparse for optimizing memory cost\n * @type {Array.<module:echarts/model/Model>}\n * @private\n */\n\n this._optionModels = [];\n /**\n * Global visual properties after visual coding\n * @type {Object}\n * @private\n */\n\n this._visual = {};\n /**\n * Globel layout properties.\n * @type {Object}\n * @private\n */\n\n this._layout = {};\n /**\n * Item visual properties after visual coding\n * @type {Array.<Object>}\n * @private\n */\n\n this._itemVisuals = [];\n /**\n * Key: visual type, Value: boolean\n * @type {Object}\n * @readOnly\n */\n\n this.hasItemVisual = {};\n /**\n * Item layout properties after layout\n * @type {Array.<Object>}\n * @private\n */\n\n this._itemLayouts = [];\n /**\n * Graphic elemnents\n * @type {Array.<module:zrender/Element>}\n * @private\n */\n\n this._graphicEls = [];\n /**\n * Max size of each chunk.\n * @type {number}\n * @private\n */\n\n this._chunkSize = 1e5;\n /**\n * @type {number}\n * @private\n */\n\n this._chunkCount = 0;\n /**\n * @type {Array.<Array|Object>}\n * @private\n */\n\n this._rawData;\n /**\n * Raw extent will not be cloned, but only transfered.\n * It will not be calculated util needed.\n * key: dim,\n * value: {end: number, extent: Array.<number>}\n * @type {Object}\n * @private\n */\n\n this._rawExtent = {};\n /**\n * @type {Object}\n * @private\n */\n\n this._extent = {};\n /**\n * key: dim\n * value: extent\n * @type {Object}\n * @private\n */\n\n this._approximateExtent = {};\n /**\n * Cache summary info for fast visit. See \"dimensionHelper\".\n * @type {Object}\n * @private\n */\n\n this._dimensionsSummary = summarizeDimensions(this);\n /**\n * @type {Object.<Array|TypedArray>}\n * @private\n */\n\n this._invertedIndicesMap = invertedIndicesMap;\n /**\n * @type {Object}\n * @private\n */\n\n this._calculationInfo = {};\n};\n\nvar listProto = List.prototype;\nlistProto.type = 'list';\n/**\n * If each data item has it's own option\n * @type {boolean}\n */\n\nlistProto.hasItemOption = true;\n/**\n * Get dimension name\n * @param {string|number} dim\n * Dimension can be concrete names like x, y, z, lng, lat, angle, radius\n * Or a ordinal number. For example getDimensionInfo(0) will return 'x' or 'lng' or 'radius'\n * @return {string} Concrete dim name.\n */\n\nlistProto.getDimension = function (dim) {\n if (!isNaN(dim)) {\n dim = this.dimensions[dim] || dim;\n }\n\n return dim;\n};\n/**\n * Get type and calculation info of particular dimension\n * @param {string|number} dim\n * Dimension can be concrete names like x, y, z, lng, lat, angle, radius\n * Or a ordinal number. For example getDimensionInfo(0) will return 'x' or 'lng' or 'radius'\n */\n\n\nlistProto.getDimensionInfo = function (dim) {\n // Do not clone, because there may be categories in dimInfo.\n return this._dimensionInfos[this.getDimension(dim)];\n};\n/**\n * @return {Array.<string>} concrete dimension name list on coord.\n */\n\n\nlistProto.getDimensionsOnCoord = function () {\n return this._dimensionsSummary.dataDimsOnCoord.slice();\n};\n/**\n * @param {string} coordDim\n * @param {number} [idx] A coordDim may map to more than one data dim.\n * If idx is `true`, return a array of all mapped dims.\n * If idx is not specified, return the first dim not extra.\n * @return {string|Array.<string>} concrete data dim.\n * If idx is number, and not found, return null/undefined.\n * If idx is `true`, and not found, return empty array (always return array).\n */\n\n\nlistProto.mapDimension = function (coordDim, idx) {\n var dimensionsSummary = this._dimensionsSummary;\n\n if (idx == null) {\n return dimensionsSummary.encodeFirstDimNotExtra[coordDim];\n }\n\n var dims = dimensionsSummary.encode[coordDim];\n return idx === true // always return array if idx is `true`\n ? (dims || []).slice() : dims && dims[idx];\n};\n/**\n * Initialize from data\n * @param {Array.<Object|number|Array>} data source or data or data provider.\n * @param {Array.<string>} [nameLIst] The name of a datum is used on data diff and\n * defualt label/tooltip.\n * A name can be specified in encode.itemName,\n * or dataItem.name (only for series option data),\n * or provided in nameList from outside.\n * @param {Function} [dimValueGetter] (dataItem, dimName, dataIndex, dimIndex) => number\n */\n\n\nlistProto.initData = function (data, nameList, dimValueGetter) {\n var notProvider = Source.isInstance(data) || zrUtil.isArrayLike(data);\n\n if (notProvider) {\n data = new DefaultDataProvider(data, this.dimensions.length);\n }\n\n this._rawData = data; // Clear\n\n this._storage = {};\n this._indices = null;\n this._nameList = nameList || [];\n this._idList = [];\n this._nameRepeatCount = {};\n\n if (!dimValueGetter) {\n this.hasItemOption = false;\n }\n /**\n * @readOnly\n */\n\n\n this.defaultDimValueGetter = defaultDimValueGetters[this._rawData.getSource().sourceFormat]; // Default dim value getter\n\n this._dimValueGetter = dimValueGetter = dimValueGetter || this.defaultDimValueGetter;\n this._dimValueGetterArrayRows = defaultDimValueGetters.arrayRows; // Reset raw extent.\n\n this._rawExtent = {};\n\n this._initDataFromProvider(0, data.count()); // If data has no item option.\n\n\n if (data.pure) {\n this.hasItemOption = false;\n }\n};\n\nlistProto.getProvider = function () {\n return this._rawData;\n};\n/**\n * Caution: Can be only called on raw data (before `this._indices` created).\n */\n\n\nlistProto.appendData = function (data) {\n var rawData = this._rawData;\n var start = this.count();\n rawData.appendData(data);\n var end = rawData.count();\n\n if (!rawData.persistent) {\n end += start;\n }\n\n this._initDataFromProvider(start, end);\n};\n/**\n * Caution: Can be only called on raw data (before `this._indices` created).\n * This method does not modify `rawData` (`dataProvider`), but only\n * add values to storage.\n *\n * The final count will be increased by `Math.max(values.length, names.length)`.\n *\n * @param {Array.<Array.<*>>} values That is the SourceType: 'arrayRows', like\n * [\n * [12, 33, 44],\n * [NaN, 43, 1],\n * ['-', 'asdf', 0]\n * ]\n * Each item is exaclty cooresponding to a dimension.\n * @param {Array.<string>} [names]\n */\n\n\nlistProto.appendValues = function (values, names) {\n var chunkSize = this._chunkSize;\n var storage = this._storage;\n var dimensions = this.dimensions;\n var dimLen = dimensions.length;\n var rawExtent = this._rawExtent;\n var start = this.count();\n var end = start + Math.max(values.length, names ? names.length : 0);\n var originalChunkCount = this._chunkCount;\n\n for (var i = 0; i < dimLen; i++) {\n var dim = dimensions[i];\n\n if (!rawExtent[dim]) {\n rawExtent[dim] = getInitialExtent();\n }\n\n if (!storage[dim]) {\n storage[dim] = [];\n }\n\n prepareChunks(storage, this._dimensionInfos[dim], chunkSize, originalChunkCount, end);\n this._chunkCount = storage[dim].length;\n }\n\n var emptyDataItem = new Array(dimLen);\n\n for (var idx = start; idx < end; idx++) {\n var sourceIdx = idx - start;\n var chunkIndex = Math.floor(idx / chunkSize);\n var chunkOffset = idx % chunkSize; // Store the data by dimensions\n\n for (var k = 0; k < dimLen; k++) {\n var dim = dimensions[k];\n\n var val = this._dimValueGetterArrayRows(values[sourceIdx] || emptyDataItem, dim, sourceIdx, k);\n\n storage[dim][chunkIndex][chunkOffset] = val;\n var dimRawExtent = rawExtent[dim];\n val < dimRawExtent[0] && (dimRawExtent[0] = val);\n val > dimRawExtent[1] && (dimRawExtent[1] = val);\n }\n\n if (names) {\n this._nameList[idx] = names[sourceIdx];\n }\n }\n\n this._rawCount = this._count = end; // Reset data extent\n\n this._extent = {};\n prepareInvertedIndex(this);\n};\n\nlistProto._initDataFromProvider = function (start, end) {\n // Optimize.\n if (start >= end) {\n return;\n }\n\n var chunkSize = this._chunkSize;\n var rawData = this._rawData;\n var storage = this._storage;\n var dimensions = this.dimensions;\n var dimLen = dimensions.length;\n var dimensionInfoMap = this._dimensionInfos;\n var nameList = this._nameList;\n var idList = this._idList;\n var rawExtent = this._rawExtent;\n var nameRepeatCount = this._nameRepeatCount = {};\n var nameDimIdx;\n var originalChunkCount = this._chunkCount;\n\n for (var i = 0; i < dimLen; i++) {\n var dim = dimensions[i];\n\n if (!rawExtent[dim]) {\n rawExtent[dim] = getInitialExtent();\n }\n\n var dimInfo = dimensionInfoMap[dim];\n\n if (dimInfo.otherDims.itemName === 0) {\n nameDimIdx = this._nameDimIdx = i;\n }\n\n if (dimInfo.otherDims.itemId === 0) {\n this._idDimIdx = i;\n }\n\n if (!storage[dim]) {\n storage[dim] = [];\n }\n\n prepareChunks(storage, dimInfo, chunkSize, originalChunkCount, end);\n this._chunkCount = storage[dim].length;\n }\n\n var dataItem = new Array(dimLen);\n\n for (var idx = start; idx < end; idx++) {\n // NOTICE: Try not to write things into dataItem\n dataItem = rawData.getItem(idx, dataItem); // Each data item is value\n // [1, 2]\n // 2\n // Bar chart, line chart which uses category axis\n // only gives the 'y' value. 'x' value is the indices of category\n // Use a tempValue to normalize the value to be a (x, y) value\n\n var chunkIndex = Math.floor(idx / chunkSize);\n var chunkOffset = idx % chunkSize; // Store the data by dimensions\n\n for (var k = 0; k < dimLen; k++) {\n var dim = dimensions[k];\n var dimStorage = storage[dim][chunkIndex]; // PENDING NULL is empty or zero\n\n var val = this._dimValueGetter(dataItem, dim, idx, k);\n\n dimStorage[chunkOffset] = val;\n var dimRawExtent = rawExtent[dim];\n val < dimRawExtent[0] && (dimRawExtent[0] = val);\n val > dimRawExtent[1] && (dimRawExtent[1] = val);\n } // ??? FIXME not check by pure but sourceFormat?\n // TODO refactor these logic.\n\n\n if (!rawData.pure) {\n var name = nameList[idx];\n\n if (dataItem && name == null) {\n // If dataItem is {name: ...}, it has highest priority.\n // That is appropriate for many common cases.\n if (dataItem.name != null) {\n // There is no other place to persistent dataItem.name,\n // so save it to nameList.\n nameList[idx] = name = dataItem.name;\n } else if (nameDimIdx != null) {\n var nameDim = dimensions[nameDimIdx];\n var nameDimChunk = storage[nameDim][chunkIndex];\n\n if (nameDimChunk) {\n name = nameDimChunk[chunkOffset];\n var ordinalMeta = dimensionInfoMap[nameDim].ordinalMeta;\n\n if (ordinalMeta && ordinalMeta.categories.length) {\n name = ordinalMeta.categories[name];\n }\n }\n }\n } // Try using the id in option\n // id or name is used on dynamical data, mapping old and new items.\n\n\n var id = dataItem == null ? null : dataItem.id;\n\n if (id == null && name != null) {\n // Use name as id and add counter to avoid same name\n nameRepeatCount[name] = nameRepeatCount[name] || 0;\n id = name;\n\n if (nameRepeatCount[name] > 0) {\n id += '__ec__' + nameRepeatCount[name];\n }\n\n nameRepeatCount[name]++;\n }\n\n id != null && (idList[idx] = id);\n }\n }\n\n if (!rawData.persistent && rawData.clean) {\n // Clean unused data if data source is typed array.\n rawData.clean();\n }\n\n this._rawCount = this._count = end; // Reset data extent\n\n this._extent = {};\n prepareInvertedIndex(this);\n};\n\nfunction prepareChunks(storage, dimInfo, chunkSize, chunkCount, end) {\n var DataCtor = dataCtors[dimInfo.type];\n var lastChunkIndex = chunkCount - 1;\n var dim = dimInfo.name;\n var resizeChunkArray = storage[dim][lastChunkIndex];\n\n if (resizeChunkArray && resizeChunkArray.length < chunkSize) {\n var newStore = new DataCtor(Math.min(end - lastChunkIndex * chunkSize, chunkSize)); // The cost of the copy is probably inconsiderable\n // within the initial chunkSize.\n\n for (var j = 0; j < resizeChunkArray.length; j++) {\n newStore[j] = resizeChunkArray[j];\n }\n\n storage[dim][lastChunkIndex] = newStore;\n } // Create new chunks.\n\n\n for (var k = chunkCount * chunkSize; k < end; k += chunkSize) {\n storage[dim].push(new DataCtor(Math.min(end - k, chunkSize)));\n }\n}\n\nfunction prepareInvertedIndex(list) {\n var invertedIndicesMap = list._invertedIndicesMap;\n zrUtil.each(invertedIndicesMap, function (invertedIndices, dim) {\n var dimInfo = list._dimensionInfos[dim]; // Currently, only dimensions that has ordinalMeta can create inverted indices.\n\n var ordinalMeta = dimInfo.ordinalMeta;\n\n if (ordinalMeta) {\n invertedIndices = invertedIndicesMap[dim] = new CtorInt32Array(ordinalMeta.categories.length); // The default value of TypedArray is 0. To avoid miss\n // mapping to 0, we should set it as INDEX_NOT_FOUND.\n\n for (var i = 0; i < invertedIndices.length; i++) {\n invertedIndices[i] = INDEX_NOT_FOUND;\n }\n\n for (var i = 0; i < list._count; i++) {\n // Only support the case that all values are distinct.\n invertedIndices[list.get(dim, i)] = i;\n }\n }\n });\n}\n\nfunction getRawValueFromStore(list, dimIndex, rawIndex) {\n var val;\n\n if (dimIndex != null) {\n var chunkSize = list._chunkSize;\n var chunkIndex = Math.floor(rawIndex / chunkSize);\n var chunkOffset = rawIndex % chunkSize;\n var dim = list.dimensions[dimIndex];\n var chunk = list._storage[dim][chunkIndex];\n\n if (chunk) {\n val = chunk[chunkOffset];\n var ordinalMeta = list._dimensionInfos[dim].ordinalMeta;\n\n if (ordinalMeta && ordinalMeta.categories.length) {\n val = ordinalMeta.categories[val];\n }\n }\n }\n\n return val;\n}\n/**\n * @return {number}\n */\n\n\nlistProto.count = function () {\n return this._count;\n};\n\nlistProto.getIndices = function () {\n var newIndices;\n var indices = this._indices;\n\n if (indices) {\n var Ctor = indices.constructor;\n var thisCount = this._count; // `new Array(a, b, c)` is different from `new Uint32Array(a, b, c)`.\n\n if (Ctor === Array) {\n newIndices = new Ctor(thisCount);\n\n for (var i = 0; i < thisCount; i++) {\n newIndices[i] = indices[i];\n }\n } else {\n newIndices = new Ctor(indices.buffer, 0, thisCount);\n }\n } else {\n var Ctor = getIndicesCtor(this);\n var newIndices = new Ctor(this.count());\n\n for (var i = 0; i < newIndices.length; i++) {\n newIndices[i] = i;\n }\n }\n\n return newIndices;\n};\n/**\n * Get value. Return NaN if idx is out of range.\n * @param {string} dim Dim must be concrete name.\n * @param {number} idx\n * @param {boolean} stack\n * @return {number}\n */\n\n\nlistProto.get = function (dim, idx\n/*, stack */\n) {\n if (!(idx >= 0 && idx < this._count)) {\n return NaN;\n }\n\n var storage = this._storage;\n\n if (!storage[dim]) {\n // TODO Warn ?\n return NaN;\n }\n\n idx = this.getRawIndex(idx);\n var chunkIndex = Math.floor(idx / this._chunkSize);\n var chunkOffset = idx % this._chunkSize;\n var chunkStore = storage[dim][chunkIndex];\n var value = chunkStore[chunkOffset]; // FIXME ordinal data type is not stackable\n // if (stack) {\n // var dimensionInfo = this._dimensionInfos[dim];\n // if (dimensionInfo && dimensionInfo.stackable) {\n // var stackedOn = this.stackedOn;\n // while (stackedOn) {\n // // Get no stacked data of stacked on\n // var stackedValue = stackedOn.get(dim, idx);\n // // Considering positive stack, negative stack and empty data\n // if ((value >= 0 && stackedValue > 0) // Positive stack\n // || (value <= 0 && stackedValue < 0) // Negative stack\n // ) {\n // value += stackedValue;\n // }\n // stackedOn = stackedOn.stackedOn;\n // }\n // }\n // }\n\n return value;\n};\n/**\n * @param {string} dim concrete dim\n * @param {number} rawIndex\n * @return {number|string}\n */\n\n\nlistProto.getByRawIndex = function (dim, rawIdx) {\n if (!(rawIdx >= 0 && rawIdx < this._rawCount)) {\n return NaN;\n }\n\n var dimStore = this._storage[dim];\n\n if (!dimStore) {\n // TODO Warn ?\n return NaN;\n }\n\n var chunkIndex = Math.floor(rawIdx / this._chunkSize);\n var chunkOffset = rawIdx % this._chunkSize;\n var chunkStore = dimStore[chunkIndex];\n return chunkStore[chunkOffset];\n};\n/**\n * FIXME Use `get` on chrome maybe slow(in filterSelf and selectRange).\n * Hack a much simpler _getFast\n * @private\n */\n\n\nlistProto._getFast = function (dim, rawIdx) {\n var chunkIndex = Math.floor(rawIdx / this._chunkSize);\n var chunkOffset = rawIdx % this._chunkSize;\n var chunkStore = this._storage[dim][chunkIndex];\n return chunkStore[chunkOffset];\n};\n/**\n * Get value for multi dimensions.\n * @param {Array.<string>} [dimensions] If ignored, using all dimensions.\n * @param {number} idx\n * @return {number}\n */\n\n\nlistProto.getValues = function (dimensions, idx\n/*, stack */\n) {\n var values = [];\n\n if (!zrUtil.isArray(dimensions)) {\n // stack = idx;\n idx = dimensions;\n dimensions = this.dimensions;\n }\n\n for (var i = 0, len = dimensions.length; i < len; i++) {\n values.push(this.get(dimensions[i], idx\n /*, stack */\n ));\n }\n\n return values;\n};\n/**\n * If value is NaN. Inlcuding '-'\n * Only check the coord dimensions.\n * @param {string} dim\n * @param {number} idx\n * @return {number}\n */\n\n\nlistProto.hasValue = function (idx) {\n var dataDimsOnCoord = this._dimensionsSummary.dataDimsOnCoord;\n var dimensionInfos = this._dimensionInfos;\n\n for (var i = 0, len = dataDimsOnCoord.length; i < len; i++) {\n if ( // Ordinal type can be string or number\n dimensionInfos[dataDimsOnCoord[i]].type !== 'ordinal' // FIXME check ordinal when using index?\n && isNaN(this.get(dataDimsOnCoord[i], idx))) {\n return false;\n }\n }\n\n return true;\n};\n/**\n * Get extent of data in one dimension\n * @param {string} dim\n * @param {boolean} stack\n */\n\n\nlistProto.getDataExtent = function (dim\n/*, stack */\n) {\n // Make sure use concrete dim as cache name.\n dim = this.getDimension(dim);\n var dimData = this._storage[dim];\n var initialExtent = getInitialExtent(); // stack = !!((stack || false) && this.getCalculationInfo(dim));\n\n if (!dimData) {\n return initialExtent;\n } // Make more strict checkings to ensure hitting cache.\n\n\n var currEnd = this.count(); // var cacheName = [dim, !!stack].join('_');\n // var cacheName = dim;\n // Consider the most cases when using data zoom, `getDataExtent`\n // happened before filtering. We cache raw extent, which is not\n // necessary to be cleared and recalculated when restore data.\n\n var useRaw = !this._indices; // && !stack;\n\n var dimExtent;\n\n if (useRaw) {\n return this._rawExtent[dim].slice();\n }\n\n dimExtent = this._extent[dim];\n\n if (dimExtent) {\n return dimExtent.slice();\n }\n\n dimExtent = initialExtent;\n var min = dimExtent[0];\n var max = dimExtent[1];\n\n for (var i = 0; i < currEnd; i++) {\n // var value = stack ? this.get(dim, i, true) : this._getFast(dim, this.getRawIndex(i));\n var value = this._getFast(dim, this.getRawIndex(i));\n\n value < min && (min = value);\n value > max && (max = value);\n }\n\n dimExtent = [min, max];\n this._extent[dim] = dimExtent;\n return dimExtent;\n};\n/**\n * Optimize for the scenario that data is filtered by a given extent.\n * Consider that if data amount is more than hundreds of thousand,\n * extent calculation will cost more than 10ms and the cache will\n * be erased because of the filtering.\n */\n\n\nlistProto.getApproximateExtent = function (dim\n/*, stack */\n) {\n dim = this.getDimension(dim);\n return this._approximateExtent[dim] || this.getDataExtent(dim\n /*, stack */\n );\n};\n\nlistProto.setApproximateExtent = function (extent, dim\n/*, stack */\n) {\n dim = this.getDimension(dim);\n this._approximateExtent[dim] = extent.slice();\n};\n/**\n * @param {string} key\n * @return {*}\n */\n\n\nlistProto.getCalculationInfo = function (key) {\n return this._calculationInfo[key];\n};\n/**\n * @param {string|Object} key or k-v object\n * @param {*} [value]\n */\n\n\nlistProto.setCalculationInfo = function (key, value) {\n isObject(key) ? zrUtil.extend(this._calculationInfo, key) : this._calculationInfo[key] = value;\n};\n/**\n * Get sum of data in one dimension\n * @param {string} dim\n */\n\n\nlistProto.getSum = function (dim\n/*, stack */\n) {\n var dimData = this._storage[dim];\n var sum = 0;\n\n if (dimData) {\n for (var i = 0, len = this.count(); i < len; i++) {\n var value = this.get(dim, i\n /*, stack */\n );\n\n if (!isNaN(value)) {\n sum += value;\n }\n }\n }\n\n return sum;\n};\n/**\n * Get median of data in one dimension\n * @param {string} dim\n */\n\n\nlistProto.getMedian = function (dim\n/*, stack */\n) {\n var dimDataArray = []; // map all data of one dimension\n\n this.each(dim, function (val, idx) {\n if (!isNaN(val)) {\n dimDataArray.push(val);\n }\n }); // TODO\n // Use quick select?\n // immutability & sort\n\n var sortedDimDataArray = [].concat(dimDataArray).sort(function (a, b) {\n return a - b;\n });\n var len = this.count(); // calculate median\n\n return len === 0 ? 0 : len % 2 === 1 ? sortedDimDataArray[(len - 1) / 2] : (sortedDimDataArray[len / 2] + sortedDimDataArray[len / 2 - 1]) / 2;\n}; // /**\n// * Retreive the index with given value\n// * @param {string} dim Concrete dimension.\n// * @param {number} value\n// * @return {number}\n// */\n// Currently incorrect: should return dataIndex but not rawIndex.\n// Do not fix it until this method is to be used somewhere.\n// FIXME Precision of float value\n// listProto.indexOf = function (dim, value) {\n// var storage = this._storage;\n// var dimData = storage[dim];\n// var chunkSize = this._chunkSize;\n// if (dimData) {\n// for (var i = 0, len = this.count(); i < len; i++) {\n// var chunkIndex = Math.floor(i / chunkSize);\n// var chunkOffset = i % chunkSize;\n// if (dimData[chunkIndex][chunkOffset] === value) {\n// return i;\n// }\n// }\n// }\n// return -1;\n// };\n\n/**\n * Only support the dimension which inverted index created.\n * Do not support other cases until required.\n * @param {string} concrete dim\n * @param {number|string} value\n * @return {number} rawIndex\n */\n\n\nlistProto.rawIndexOf = function (dim, value) {\n var invertedIndices = dim && this._invertedIndicesMap[dim];\n var rawIndex = invertedIndices[value];\n\n if (rawIndex == null || isNaN(rawIndex)) {\n return INDEX_NOT_FOUND;\n }\n\n return rawIndex;\n};\n/**\n * Retreive the index with given name\n * @param {number} idx\n * @param {number} name\n * @return {number}\n */\n\n\nlistProto.indexOfName = function (name) {\n for (var i = 0, len = this.count(); i < len; i++) {\n if (this.getName(i) === name) {\n return i;\n }\n }\n\n return -1;\n};\n/**\n * Retreive the index with given raw data index\n * @param {number} idx\n * @param {number} name\n * @return {number}\n */\n\n\nlistProto.indexOfRawIndex = function (rawIndex) {\n if (!this._indices) {\n return rawIndex;\n }\n\n if (rawIndex >= this._rawCount || rawIndex < 0) {\n return -1;\n } // Indices are ascending\n\n\n var indices = this._indices; // If rawIndex === dataIndex\n\n var rawDataIndex = indices[rawIndex];\n\n if (rawDataIndex != null && rawDataIndex < this._count && rawDataIndex === rawIndex) {\n return rawIndex;\n }\n\n var left = 0;\n var right = this._count - 1;\n\n while (left <= right) {\n var mid = (left + right) / 2 | 0;\n\n if (indices[mid] < rawIndex) {\n left = mid + 1;\n } else if (indices[mid] > rawIndex) {\n right = mid - 1;\n } else {\n return mid;\n }\n }\n\n return -1;\n};\n/**\n * Retreive the index of nearest value\n * @param {string} dim\n * @param {number} value\n * @param {number} [maxDistance=Infinity]\n * @return {Array.<number>} Considere multiple points has the same value.\n */\n\n\nlistProto.indicesOfNearest = function (dim, value, maxDistance) {\n var storage = this._storage;\n var dimData = storage[dim];\n var nearestIndices = [];\n\n if (!dimData) {\n return nearestIndices;\n }\n\n if (maxDistance == null) {\n maxDistance = Infinity;\n }\n\n var minDist = Number.MAX_VALUE;\n var minDiff = -1;\n\n for (var i = 0, len = this.count(); i < len; i++) {\n var diff = value - this.get(dim, i\n /*, stack */\n );\n var dist = Math.abs(diff);\n\n if (diff <= maxDistance && dist <= minDist) {\n // For the case of two data are same on xAxis, which has sequence data.\n // Show the nearest index\n // https://github.com/ecomfe/echarts/issues/2869\n if (dist < minDist || diff >= 0 && minDiff < 0) {\n minDist = dist;\n minDiff = diff;\n nearestIndices.length = 0;\n }\n\n nearestIndices.push(i);\n }\n }\n\n return nearestIndices;\n};\n/**\n * Get raw data index\n * @param {number} idx\n * @return {number}\n */\n\n\nlistProto.getRawIndex = getRawIndexWithoutIndices;\n\nfunction getRawIndexWithoutIndices(idx) {\n return idx;\n}\n\nfunction getRawIndexWithIndices(idx) {\n if (idx < this._count && idx >= 0) {\n return this._indices[idx];\n }\n\n return -1;\n}\n/**\n * Get raw data item\n * @param {number} idx\n * @return {number}\n */\n\n\nlistProto.getRawDataItem = function (idx) {\n if (!this._rawData.persistent) {\n var val = [];\n\n for (var i = 0; i < this.dimensions.length; i++) {\n var dim = this.dimensions[i];\n val.push(this.get(dim, idx));\n }\n\n return val;\n } else {\n return this._rawData.getItem(this.getRawIndex(idx));\n }\n};\n/**\n * @param {number} idx\n * @param {boolean} [notDefaultIdx=false]\n * @return {string}\n */\n\n\nlistProto.getName = function (idx) {\n var rawIndex = this.getRawIndex(idx);\n return this._nameList[rawIndex] || getRawValueFromStore(this, this._nameDimIdx, rawIndex) || '';\n};\n/**\n * @param {number} idx\n * @param {boolean} [notDefaultIdx=false]\n * @return {string}\n */\n\n\nlistProto.getId = function (idx) {\n return getId(this, this.getRawIndex(idx));\n};\n\nfunction getId(list, rawIndex) {\n var id = list._idList[rawIndex];\n\n if (id == null) {\n id = getRawValueFromStore(list, list._idDimIdx, rawIndex);\n }\n\n if (id == null) {\n // FIXME Check the usage in graph, should not use prefix.\n id = ID_PREFIX + rawIndex;\n }\n\n return id;\n}\n\nfunction normalizeDimensions(dimensions) {\n if (!zrUtil.isArray(dimensions)) {\n dimensions = [dimensions];\n }\n\n return dimensions;\n}\n\nfunction validateDimensions(list, dims) {\n for (var i = 0; i < dims.length; i++) {\n // stroage may be empty when no data, so use\n // dimensionInfos to check.\n if (!list._dimensionInfos[dims[i]]) {\n console.error('Unkown dimension ' + dims[i]);\n }\n }\n}\n/**\n * Data iteration\n * @param {string|Array.<string>}\n * @param {Function} cb\n * @param {*} [context=this]\n *\n * @example\n * list.each('x', function (x, idx) {});\n * list.each(['x', 'y'], function (x, y, idx) {});\n * list.each(function (idx) {})\n */\n\n\nlistProto.each = function (dims, cb, context, contextCompat) {\n 'use strict';\n\n if (!this._count) {\n return;\n }\n\n if (typeof dims === 'function') {\n contextCompat = context;\n context = cb;\n cb = dims;\n dims = [];\n } // contextCompat just for compat echarts3\n\n\n context = context || contextCompat || this;\n dims = zrUtil.map(normalizeDimensions(dims), this.getDimension, this);\n var dimSize = dims.length;\n\n for (var i = 0; i < this.count(); i++) {\n // Simple optimization\n switch (dimSize) {\n case 0:\n cb.call(context, i);\n break;\n\n case 1:\n cb.call(context, this.get(dims[0], i), i);\n break;\n\n case 2:\n cb.call(context, this.get(dims[0], i), this.get(dims[1], i), i);\n break;\n\n default:\n var k = 0;\n var value = [];\n\n for (; k < dimSize; k++) {\n value[k] = this.get(dims[k], i);\n } // Index\n\n\n value[k] = i;\n cb.apply(context, value);\n }\n }\n};\n/**\n * Data filter\n * @param {string|Array.<string>}\n * @param {Function} cb\n * @param {*} [context=this]\n */\n\n\nlistProto.filterSelf = function (dimensions, cb, context, contextCompat) {\n 'use strict';\n\n if (!this._count) {\n return;\n }\n\n if (typeof dimensions === 'function') {\n contextCompat = context;\n context = cb;\n cb = dimensions;\n dimensions = [];\n } // contextCompat just for compat echarts3\n\n\n context = context || contextCompat || this;\n dimensions = zrUtil.map(normalizeDimensions(dimensions), this.getDimension, this);\n var count = this.count();\n var Ctor = getIndicesCtor(this);\n var newIndices = new Ctor(count);\n var value = [];\n var dimSize = dimensions.length;\n var offset = 0;\n var dim0 = dimensions[0];\n\n for (var i = 0; i < count; i++) {\n var keep;\n var rawIdx = this.getRawIndex(i); // Simple optimization\n\n if (dimSize === 0) {\n keep = cb.call(context, i);\n } else if (dimSize === 1) {\n var val = this._getFast(dim0, rawIdx);\n\n keep = cb.call(context, val, i);\n } else {\n for (var k = 0; k < dimSize; k++) {\n value[k] = this._getFast(dim0, rawIdx);\n }\n\n value[k] = i;\n keep = cb.apply(context, value);\n }\n\n if (keep) {\n newIndices[offset++] = rawIdx;\n }\n } // Set indices after filtered.\n\n\n if (offset < count) {\n this._indices = newIndices;\n }\n\n this._count = offset; // Reset data extent\n\n this._extent = {};\n this.getRawIndex = this._indices ? getRawIndexWithIndices : getRawIndexWithoutIndices;\n return this;\n};\n/**\n * Select data in range. (For optimization of filter)\n * (Manually inline code, support 5 million data filtering in data zoom.)\n */\n\n\nlistProto.selectRange = function (range) {\n 'use strict';\n\n if (!this._count) {\n return;\n }\n\n var dimensions = [];\n\n for (var dim in range) {\n if (range.hasOwnProperty(dim)) {\n dimensions.push(dim);\n }\n }\n\n var dimSize = dimensions.length;\n\n if (!dimSize) {\n return;\n }\n\n var originalCount = this.count();\n var Ctor = getIndicesCtor(this);\n var newIndices = new Ctor(originalCount);\n var offset = 0;\n var dim0 = dimensions[0];\n var min = range[dim0][0];\n var max = range[dim0][1];\n var quickFinished = false;\n\n if (!this._indices) {\n // Extreme optimization for common case. About 2x faster in chrome.\n var idx = 0;\n\n if (dimSize === 1) {\n var dimStorage = this._storage[dimensions[0]];\n\n for (var k = 0; k < this._chunkCount; k++) {\n var chunkStorage = dimStorage[k];\n var len = Math.min(this._count - k * this._chunkSize, this._chunkSize);\n\n for (var i = 0; i < len; i++) {\n var val = chunkStorage[i]; // NaN will not be filtered. Consider the case, in line chart, empty\n // value indicates the line should be broken. But for the case like\n // scatter plot, a data item with empty value will not be rendered,\n // but the axis extent may be effected if some other dim of the data\n // item has value. Fortunately it is not a significant negative effect.\n\n if (val >= min && val <= max || isNaN(val)) {\n newIndices[offset++] = idx;\n }\n\n idx++;\n }\n }\n\n quickFinished = true;\n } else if (dimSize === 2) {\n var dimStorage = this._storage[dim0];\n var dimStorage2 = this._storage[dimensions[1]];\n var min2 = range[dimensions[1]][0];\n var max2 = range[dimensions[1]][1];\n\n for (var k = 0; k < this._chunkCount; k++) {\n var chunkStorage = dimStorage[k];\n var chunkStorage2 = dimStorage2[k];\n var len = Math.min(this._count - k * this._chunkSize, this._chunkSize);\n\n for (var i = 0; i < len; i++) {\n var val = chunkStorage[i];\n var val2 = chunkStorage2[i]; // Do not filter NaN, see comment above.\n\n if ((val >= min && val <= max || isNaN(val)) && (val2 >= min2 && val2 <= max2 || isNaN(val2))) {\n newIndices[offset++] = idx;\n }\n\n idx++;\n }\n }\n\n quickFinished = true;\n }\n }\n\n if (!quickFinished) {\n if (dimSize === 1) {\n for (var i = 0; i < originalCount; i++) {\n var rawIndex = this.getRawIndex(i);\n\n var val = this._getFast(dim0, rawIndex); // Do not filter NaN, see comment above.\n\n\n if (val >= min && val <= max || isNaN(val)) {\n newIndices[offset++] = rawIndex;\n }\n }\n } else {\n for (var i = 0; i < originalCount; i++) {\n var keep = true;\n var rawIndex = this.getRawIndex(i);\n\n for (var k = 0; k < dimSize; k++) {\n var dimk = dimensions[k];\n\n var val = this._getFast(dim, rawIndex); // Do not filter NaN, see comment above.\n\n\n if (val < range[dimk][0] || val > range[dimk][1]) {\n keep = false;\n }\n }\n\n if (keep) {\n newIndices[offset++] = this.getRawIndex(i);\n }\n }\n }\n } // Set indices after filtered.\n\n\n if (offset < originalCount) {\n this._indices = newIndices;\n }\n\n this._count = offset; // Reset data extent\n\n this._extent = {};\n this.getRawIndex = this._indices ? getRawIndexWithIndices : getRawIndexWithoutIndices;\n return this;\n};\n/**\n * Data mapping to a plain array\n * @param {string|Array.<string>} [dimensions]\n * @param {Function} cb\n * @param {*} [context=this]\n * @return {Array}\n */\n\n\nlistProto.mapArray = function (dimensions, cb, context, contextCompat) {\n 'use strict';\n\n if (typeof dimensions === 'function') {\n contextCompat = context;\n context = cb;\n cb = dimensions;\n dimensions = [];\n } // contextCompat just for compat echarts3\n\n\n context = context || contextCompat || this;\n var result = [];\n this.each(dimensions, function () {\n result.push(cb && cb.apply(this, arguments));\n }, context);\n return result;\n}; // Data in excludeDimensions is copied, otherwise transfered.\n\n\nfunction cloneListForMapAndSample(original, excludeDimensions) {\n var allDimensions = original.dimensions;\n var list = new List(zrUtil.map(allDimensions, original.getDimensionInfo, original), original.hostModel); // FIXME If needs stackedOn, value may already been stacked\n\n transferProperties(list, original);\n var storage = list._storage = {};\n var originalStorage = original._storage; // Init storage\n\n for (var i = 0; i < allDimensions.length; i++) {\n var dim = allDimensions[i];\n\n if (originalStorage[dim]) {\n // Notice that we do not reset invertedIndicesMap here, becuase\n // there is no scenario of mapping or sampling ordinal dimension.\n if (zrUtil.indexOf(excludeDimensions, dim) >= 0) {\n storage[dim] = cloneDimStore(originalStorage[dim]);\n list._rawExtent[dim] = getInitialExtent();\n list._extent[dim] = null;\n } else {\n // Direct reference for other dimensions\n storage[dim] = originalStorage[dim];\n }\n }\n }\n\n return list;\n}\n\nfunction cloneDimStore(originalDimStore) {\n var newDimStore = new Array(originalDimStore.length);\n\n for (var j = 0; j < originalDimStore.length; j++) {\n newDimStore[j] = cloneChunk(originalDimStore[j]);\n }\n\n return newDimStore;\n}\n\nfunction getInitialExtent() {\n return [Infinity, -Infinity];\n}\n/**\n * Data mapping to a new List with given dimensions\n * @param {string|Array.<string>} dimensions\n * @param {Function} cb\n * @param {*} [context=this]\n * @return {Array}\n */\n\n\nlistProto.map = function (dimensions, cb, context, contextCompat) {\n 'use strict'; // contextCompat just for compat echarts3\n\n context = context || contextCompat || this;\n dimensions = zrUtil.map(normalizeDimensions(dimensions), this.getDimension, this);\n var list = cloneListForMapAndSample(this, dimensions); // Following properties are all immutable.\n // So we can reference to the same value\n\n list._indices = this._indices;\n list.getRawIndex = list._indices ? getRawIndexWithIndices : getRawIndexWithoutIndices;\n var storage = list._storage;\n var tmpRetValue = [];\n var chunkSize = this._chunkSize;\n var dimSize = dimensions.length;\n var dataCount = this.count();\n var values = [];\n var rawExtent = list._rawExtent;\n\n for (var dataIndex = 0; dataIndex < dataCount; dataIndex++) {\n for (var dimIndex = 0; dimIndex < dimSize; dimIndex++) {\n values[dimIndex] = this.get(dimensions[dimIndex], dataIndex\n /*, stack */\n );\n }\n\n values[dimSize] = dataIndex;\n var retValue = cb && cb.apply(context, values);\n\n if (retValue != null) {\n // a number or string (in oridinal dimension)?\n if (typeof retValue !== 'object') {\n tmpRetValue[0] = retValue;\n retValue = tmpRetValue;\n }\n\n var rawIndex = this.getRawIndex(dataIndex);\n var chunkIndex = Math.floor(rawIndex / chunkSize);\n var chunkOffset = rawIndex % chunkSize;\n\n for (var i = 0; i < retValue.length; i++) {\n var dim = dimensions[i];\n var val = retValue[i];\n var rawExtentOnDim = rawExtent[dim];\n var dimStore = storage[dim];\n\n if (dimStore) {\n dimStore[chunkIndex][chunkOffset] = val;\n }\n\n if (val < rawExtentOnDim[0]) {\n rawExtentOnDim[0] = val;\n }\n\n if (val > rawExtentOnDim[1]) {\n rawExtentOnDim[1] = val;\n }\n }\n }\n }\n\n return list;\n};\n/**\n * Large data down sampling on given dimension\n * @param {string} dimension\n * @param {number} rate\n * @param {Function} sampleValue\n * @param {Function} sampleIndex Sample index for name and id\n */\n\n\nlistProto.downSample = function (dimension, rate, sampleValue, sampleIndex) {\n var list = cloneListForMapAndSample(this, [dimension]);\n var targetStorage = list._storage;\n var frameValues = [];\n var frameSize = Math.floor(1 / rate);\n var dimStore = targetStorage[dimension];\n var len = this.count();\n var chunkSize = this._chunkSize;\n var rawExtentOnDim = list._rawExtent[dimension];\n var newIndices = new (getIndicesCtor(this))(len);\n var offset = 0;\n\n for (var i = 0; i < len; i += frameSize) {\n // Last frame\n if (frameSize > len - i) {\n frameSize = len - i;\n frameValues.length = frameSize;\n }\n\n for (var k = 0; k < frameSize; k++) {\n var dataIdx = this.getRawIndex(i + k);\n var originalChunkIndex = Math.floor(dataIdx / chunkSize);\n var originalChunkOffset = dataIdx % chunkSize;\n frameValues[k] = dimStore[originalChunkIndex][originalChunkOffset];\n }\n\n var value = sampleValue(frameValues);\n var sampleFrameIdx = this.getRawIndex(Math.min(i + sampleIndex(frameValues, value) || 0, len - 1));\n var sampleChunkIndex = Math.floor(sampleFrameIdx / chunkSize);\n var sampleChunkOffset = sampleFrameIdx % chunkSize; // Only write value on the filtered data\n\n dimStore[sampleChunkIndex][sampleChunkOffset] = value;\n\n if (value < rawExtentOnDim[0]) {\n rawExtentOnDim[0] = value;\n }\n\n if (value > rawExtentOnDim[1]) {\n rawExtentOnDim[1] = value;\n }\n\n newIndices[offset++] = sampleFrameIdx;\n }\n\n list._count = offset;\n list._indices = newIndices;\n list.getRawIndex = getRawIndexWithIndices;\n return list;\n};\n/**\n * Get model of one data item.\n *\n * @param {number} idx\n */\n// FIXME Model proxy ?\n\n\nlistProto.getItemModel = function (idx) {\n var hostModel = this.hostModel;\n return new Model(this.getRawDataItem(idx), hostModel, hostModel && hostModel.ecModel);\n};\n/**\n * Create a data differ\n * @param {module:echarts/data/List} otherList\n * @return {module:echarts/data/DataDiffer}\n */\n\n\nlistProto.diff = function (otherList) {\n var thisList = this;\n return new DataDiffer(otherList ? otherList.getIndices() : [], this.getIndices(), function (idx) {\n return getId(otherList, idx);\n }, function (idx) {\n return getId(thisList, idx);\n });\n};\n/**\n * Get visual property.\n * @param {string} key\n */\n\n\nlistProto.getVisual = function (key) {\n var visual = this._visual;\n return visual && visual[key];\n};\n/**\n * Set visual property\n * @param {string|Object} key\n * @param {*} [value]\n *\n * @example\n * setVisual('color', color);\n * setVisual({\n * 'color': color\n * });\n */\n\n\nlistProto.setVisual = function (key, val) {\n if (isObject(key)) {\n for (var name in key) {\n if (key.hasOwnProperty(name)) {\n this.setVisual(name, key[name]);\n }\n }\n\n return;\n }\n\n this._visual = this._visual || {};\n this._visual[key] = val;\n};\n/**\n * Set layout property.\n * @param {string|Object} key\n * @param {*} [val]\n */\n\n\nlistProto.setLayout = function (key, val) {\n if (isObject(key)) {\n for (var name in key) {\n if (key.hasOwnProperty(name)) {\n this.setLayout(name, key[name]);\n }\n }\n\n return;\n }\n\n this._layout[key] = val;\n};\n/**\n * Get layout property.\n * @param {string} key.\n * @return {*}\n */\n\n\nlistProto.getLayout = function (key) {\n return this._layout[key];\n};\n/**\n * Get layout of single data item\n * @param {number} idx\n */\n\n\nlistProto.getItemLayout = function (idx) {\n return this._itemLayouts[idx];\n};\n/**\n * Set layout of single data item\n * @param {number} idx\n * @param {Object} layout\n * @param {boolean=} [merge=false]\n */\n\n\nlistProto.setItemLayout = function (idx, layout, merge) {\n this._itemLayouts[idx] = merge ? zrUtil.extend(this._itemLayouts[idx] || {}, layout) : layout;\n};\n/**\n * Clear all layout of single data item\n */\n\n\nlistProto.clearItemLayouts = function () {\n this._itemLayouts.length = 0;\n};\n/**\n * Get visual property of single data item\n * @param {number} idx\n * @param {string} key\n * @param {boolean} [ignoreParent=false]\n */\n\n\nlistProto.getItemVisual = function (idx, key, ignoreParent) {\n var itemVisual = this._itemVisuals[idx];\n var val = itemVisual && itemVisual[key];\n\n if (val == null && !ignoreParent) {\n // Use global visual property\n return this.getVisual(key);\n }\n\n return val;\n};\n/**\n * Set visual property of single data item\n *\n * @param {number} idx\n * @param {string|Object} key\n * @param {*} [value]\n *\n * @example\n * setItemVisual(0, 'color', color);\n * setItemVisual(0, {\n * 'color': color\n * });\n */\n\n\nlistProto.setItemVisual = function (idx, key, value) {\n var itemVisual = this._itemVisuals[idx] || {};\n var hasItemVisual = this.hasItemVisual;\n this._itemVisuals[idx] = itemVisual;\n\n if (isObject(key)) {\n for (var name in key) {\n if (key.hasOwnProperty(name)) {\n itemVisual[name] = key[name];\n hasItemVisual[name] = true;\n }\n }\n\n return;\n }\n\n itemVisual[key] = value;\n hasItemVisual[key] = true;\n};\n/**\n * Clear itemVisuals and list visual.\n */\n\n\nlistProto.clearAllVisual = function () {\n this._visual = {};\n this._itemVisuals = [];\n this.hasItemVisual = {};\n};\n\nvar setItemDataAndSeriesIndex = function (child) {\n child.seriesIndex = this.seriesIndex;\n child.dataIndex = this.dataIndex;\n child.dataType = this.dataType;\n};\n/**\n * Set graphic element relative to data. It can be set as null\n * @param {number} idx\n * @param {module:zrender/Element} [el]\n */\n\n\nlistProto.setItemGraphicEl = function (idx, el) {\n var hostModel = this.hostModel;\n\n if (el) {\n // Add data index and series index for indexing the data by element\n // Useful in tooltip\n el.dataIndex = idx;\n el.dataType = this.dataType;\n el.seriesIndex = hostModel && hostModel.seriesIndex;\n\n if (el.type === 'group') {\n el.traverse(setItemDataAndSeriesIndex, el);\n }\n }\n\n this._graphicEls[idx] = el;\n};\n/**\n * @param {number} idx\n * @return {module:zrender/Element}\n */\n\n\nlistProto.getItemGraphicEl = function (idx) {\n return this._graphicEls[idx];\n};\n/**\n * @param {Function} cb\n * @param {*} context\n */\n\n\nlistProto.eachItemGraphicEl = function (cb, context) {\n zrUtil.each(this._graphicEls, function (el, idx) {\n if (el) {\n cb && cb.call(context, el, idx);\n }\n });\n};\n/**\n * Shallow clone a new list except visual and layout properties, and graph elements.\n * New list only change the indices.\n */\n\n\nlistProto.cloneShallow = function (list) {\n if (!list) {\n var dimensionInfoList = zrUtil.map(this.dimensions, this.getDimensionInfo, this);\n list = new List(dimensionInfoList, this.hostModel);\n } // FIXME\n\n\n list._storage = this._storage;\n transferProperties(list, this); // Clone will not change the data extent and indices\n\n if (this._indices) {\n var Ctor = this._indices.constructor;\n list._indices = new Ctor(this._indices);\n } else {\n list._indices = null;\n }\n\n list.getRawIndex = list._indices ? getRawIndexWithIndices : getRawIndexWithoutIndices;\n return list;\n};\n/**\n * Wrap some method to add more feature\n * @param {string} methodName\n * @param {Function} injectFunction\n */\n\n\nlistProto.wrapMethod = function (methodName, injectFunction) {\n var originalMethod = this[methodName];\n\n if (typeof originalMethod !== 'function') {\n return;\n }\n\n this.__wrappedMethods = this.__wrappedMethods || [];\n\n this.__wrappedMethods.push(methodName);\n\n this[methodName] = function () {\n var res = originalMethod.apply(this, arguments);\n return injectFunction.apply(this, [res].concat(zrUtil.slice(arguments)));\n };\n}; // Methods that create a new list based on this list should be listed here.\n// Notice that those method should `RETURN` the new list.\n\n\nlistProto.TRANSFERABLE_METHODS = ['cloneShallow', 'downSample', 'map']; // Methods that change indices of this list should be listed here.\n\nlistProto.CHANGABLE_METHODS = ['filterSelf', 'selectRange'];\nvar _default = List;\nmodule.exports = _default;","var _vector = require(\"../../core/vector\");\n\nvar v2Distance = _vector.distance;\n\n/**\n * Catmull-Rom spline 插值折线\n * @module zrender/shape/util/smoothSpline\n * @author pissang (https://www.github.com/pissang)\n * Kener (@Kener-林峰, kener.linfeng@gmail.com)\n * errorrik (errorrik@gmail.com)\n */\n\n/**\n * @inner\n */\nfunction interpolate(p0, p1, p2, p3, t, t2, t3) {\n var v0 = (p2 - p0) * 0.5;\n var v1 = (p3 - p1) * 0.5;\n return (2 * (p1 - p2) + v0 + v1) * t3 + (-3 * (p1 - p2) - 2 * v0 - v1) * t2 + v0 * t + p1;\n}\n/**\n * @alias module:zrender/shape/util/smoothSpline\n * @param {Array} points 线段顶点数组\n * @param {boolean} isLoop\n * @return {Array}\n */\n\n\nfunction _default(points, isLoop) {\n var len = points.length;\n var ret = [];\n var distance = 0;\n\n for (var i = 1; i < len; i++) {\n distance += v2Distance(points[i - 1], points[i]);\n }\n\n var segs = distance / 2;\n segs = segs < len ? len : segs;\n\n for (var i = 0; i < segs; i++) {\n var pos = i / (segs - 1) * (isLoop ? len : len - 1);\n var idx = Math.floor(pos);\n var w = pos - idx;\n var p0;\n var p1 = points[idx % len];\n var p2;\n var p3;\n\n if (!isLoop) {\n p0 = points[idx === 0 ? idx : idx - 1];\n p2 = points[idx > len - 2 ? len - 1 : idx + 1];\n p3 = points[idx > len - 3 ? len - 1 : idx + 2];\n } else {\n p0 = points[(idx - 1 + len) % len];\n p2 = points[(idx + 1) % len];\n p3 = points[(idx + 2) % len];\n }\n\n var w2 = w * w;\n var w3 = w * w2;\n ret.push([interpolate(p0[0], p1[0], p2[0], p3[0], w, w2, w3), interpolate(p0[1], p1[1], p2[1], p3[1], w, w2, w3)]);\n }\n\n return ret;\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar TYPE_DELIMITER = '.';\nvar IS_CONTAINER = '___EC__COMPONENT__CONTAINER___';\n/**\n * Notice, parseClassType('') should returns {main: '', sub: ''}\n * @public\n */\n\nfunction parseClassType(componentType) {\n var ret = {\n main: '',\n sub: ''\n };\n\n if (componentType) {\n componentType = componentType.split(TYPE_DELIMITER);\n ret.main = componentType[0] || '';\n ret.sub = componentType[1] || '';\n }\n\n return ret;\n}\n/**\n * @public\n */\n\n\nfunction checkClassType(componentType) {\n zrUtil.assert(/^[a-zA-Z0-9_]+([.][a-zA-Z0-9_]+)?$/.test(componentType), 'componentType \"' + componentType + '\" illegal');\n}\n/**\n * @public\n */\n\n\nfunction enableClassExtend(RootClass, mandatoryMethods) {\n RootClass.$constructor = RootClass;\n\n RootClass.extend = function (proto) {\n var superClass = this;\n\n var ExtendedClass = function () {\n if (!proto.$constructor) {\n superClass.apply(this, arguments);\n } else {\n proto.$constructor.apply(this, arguments);\n }\n };\n\n zrUtil.extend(ExtendedClass.prototype, proto);\n ExtendedClass.extend = this.extend;\n ExtendedClass.superCall = superCall;\n ExtendedClass.superApply = superApply;\n zrUtil.inherits(ExtendedClass, this);\n ExtendedClass.superClass = superClass;\n return ExtendedClass;\n };\n}\n\nvar classBase = 0;\n/**\n * Can not use instanceof, consider different scope by\n * cross domain or es module import in ec extensions.\n * Mount a method \"isInstance()\" to Clz.\n */\n\nfunction enableClassCheck(Clz) {\n var classAttr = ['__\\0is_clz', classBase++, Math.random().toFixed(3)].join('_');\n Clz.prototype[classAttr] = true;\n\n Clz.isInstance = function (obj) {\n return !!(obj && obj[classAttr]);\n };\n} // superCall should have class info, which can not be fetch from 'this'.\n// Consider this case:\n// class A has method f,\n// class B inherits class A, overrides method f, f call superApply('f'),\n// class C inherits class B, do not overrides method f,\n// then when method of class C is called, dead loop occured.\n\n\nfunction superCall(context, methodName) {\n var args = zrUtil.slice(arguments, 2);\n return this.superClass.prototype[methodName].apply(context, args);\n}\n\nfunction superApply(context, methodName, args) {\n return this.superClass.prototype[methodName].apply(context, args);\n}\n/**\n * @param {Object} entity\n * @param {Object} options\n * @param {boolean} [options.registerWhenExtend]\n * @public\n */\n\n\nfunction enableClassManagement(entity, options) {\n options = options || {};\n /**\n * Component model classes\n * key: componentType,\n * value:\n * componentClass, when componentType is 'xxx'\n * or Object.<subKey, componentClass>, when componentType is 'xxx.yy'\n * @type {Object}\n */\n\n var storage = {};\n\n entity.registerClass = function (Clazz, componentType) {\n if (componentType) {\n checkClassType(componentType);\n componentType = parseClassType(componentType);\n\n if (!componentType.sub) {\n storage[componentType.main] = Clazz;\n } else if (componentType.sub !== IS_CONTAINER) {\n var container = makeContainer(componentType);\n container[componentType.sub] = Clazz;\n }\n }\n\n return Clazz;\n };\n\n entity.getClass = function (componentMainType, subType, throwWhenNotFound) {\n var Clazz = storage[componentMainType];\n\n if (Clazz && Clazz[IS_CONTAINER]) {\n Clazz = subType ? Clazz[subType] : null;\n }\n\n if (throwWhenNotFound && !Clazz) {\n throw new Error(!subType ? componentMainType + '.' + 'type should be specified.' : 'Component ' + componentMainType + '.' + (subType || '') + ' not exists. Load it first.');\n }\n\n return Clazz;\n };\n\n entity.getClassesByMainType = function (componentType) {\n componentType = parseClassType(componentType);\n var result = [];\n var obj = storage[componentType.main];\n\n if (obj && obj[IS_CONTAINER]) {\n zrUtil.each(obj, function (o, type) {\n type !== IS_CONTAINER && result.push(o);\n });\n } else {\n result.push(obj);\n }\n\n return result;\n };\n\n entity.hasClass = function (componentType) {\n // Just consider componentType.main.\n componentType = parseClassType(componentType);\n return !!storage[componentType.main];\n };\n /**\n * @return {Array.<string>} Like ['aa', 'bb'], but can not be ['aa.xx']\n */\n\n\n entity.getAllClassMainTypes = function () {\n var types = [];\n zrUtil.each(storage, function (obj, type) {\n types.push(type);\n });\n return types;\n };\n /**\n * If a main type is container and has sub types\n * @param {string} mainType\n * @return {boolean}\n */\n\n\n entity.hasSubTypes = function (componentType) {\n componentType = parseClassType(componentType);\n var obj = storage[componentType.main];\n return obj && obj[IS_CONTAINER];\n };\n\n entity.parseClassType = parseClassType;\n\n function makeContainer(componentType) {\n var container = storage[componentType.main];\n\n if (!container || !container[IS_CONTAINER]) {\n container = storage[componentType.main] = {};\n container[IS_CONTAINER] = true;\n }\n\n return container;\n }\n\n if (options.registerWhenExtend) {\n var originalExtend = entity.extend;\n\n if (originalExtend) {\n entity.extend = function (proto) {\n var ExtendedClass = originalExtend.call(this, proto);\n return entity.registerClass(ExtendedClass, proto.type);\n };\n }\n }\n\n return entity;\n}\n/**\n * @param {string|Array.<string>} properties\n */\n\n\nfunction setReadOnly(obj, properties) {// FIXME It seems broken in IE8 simulation of IE11\n // if (!zrUtil.isArray(properties)) {\n // properties = properties != null ? [properties] : [];\n // }\n // zrUtil.each(properties, function (prop) {\n // var value = obj[prop];\n // Object.defineProperty\n // && Object.defineProperty(obj, prop, {\n // value: value, writable: false\n // });\n // zrUtil.isArray(obj[prop])\n // && Object.freeze\n // && Object.freeze(obj[prop]);\n // });\n}\n\nexports.parseClassType = parseClassType;\nexports.enableClassExtend = enableClassExtend;\nexports.enableClassCheck = enableClassCheck;\nexports.enableClassManagement = enableClassManagement;\nexports.setReadOnly = setReadOnly;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar echarts = require(\"../../echarts\");\n\nvar axisPointerModelHelper = require(\"../axisPointer/modelHelper\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Base class of AxisView.\n */\nvar AxisView = echarts.extendComponentView({\n type: 'axis',\n\n /**\n * @private\n */\n _axisPointer: null,\n\n /**\n * @protected\n * @type {string}\n */\n axisPointerClass: null,\n\n /**\n * @override\n */\n render: function (axisModel, ecModel, api, payload) {\n // FIXME\n // This process should proformed after coordinate systems updated\n // (axis scale updated), and should be performed each time update.\n // So put it here temporarily, although it is not appropriate to\n // put a model-writing procedure in `view`.\n this.axisPointerClass && axisPointerModelHelper.fixValue(axisModel);\n AxisView.superApply(this, 'render', arguments);\n updateAxisPointer(this, axisModel, ecModel, api, payload, true);\n },\n\n /**\n * Action handler.\n * @public\n * @param {module:echarts/coord/cartesian/AxisModel} axisModel\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n * @param {Object} payload\n */\n updateAxisPointer: function (axisModel, ecModel, api, payload, force) {\n updateAxisPointer(this, axisModel, ecModel, api, payload, false);\n },\n\n /**\n * @override\n */\n remove: function (ecModel, api) {\n var axisPointer = this._axisPointer;\n axisPointer && axisPointer.remove(api);\n AxisView.superApply(this, 'remove', arguments);\n },\n\n /**\n * @override\n */\n dispose: function (ecModel, api) {\n disposeAxisPointer(this, api);\n AxisView.superApply(this, 'dispose', arguments);\n }\n});\n\nfunction updateAxisPointer(axisView, axisModel, ecModel, api, payload, forceRender) {\n var Clazz = AxisView.getAxisPointerClass(axisView.axisPointerClass);\n\n if (!Clazz) {\n return;\n }\n\n var axisPointerModel = axisPointerModelHelper.getAxisPointerModel(axisModel);\n axisPointerModel ? (axisView._axisPointer || (axisView._axisPointer = new Clazz())).render(axisModel, axisPointerModel, api, forceRender) : disposeAxisPointer(axisView, api);\n}\n\nfunction disposeAxisPointer(axisView, ecModel, api) {\n var axisPointer = axisView._axisPointer;\n axisPointer && axisPointer.dispose(ecModel, api);\n axisView._axisPointer = null;\n}\n\nvar axisPointerClazz = [];\n\nAxisView.registerAxisPointerClass = function (type, clazz) {\n axisPointerClazz[type] = clazz;\n};\n\nAxisView.getAxisPointerClass = function (type) {\n return type && axisPointerClazz[type];\n};\n\nvar _default = AxisView;\nmodule.exports = _default;","var _curve = require(\"../core/curve\");\n\nvar quadraticProjectPoint = _curve.quadraticProjectPoint;\n\n/**\n * 二次贝塞尔曲线描边包含判断\n * @param {number} x0\n * @param {number} y0\n * @param {number} x1\n * @param {number} y1\n * @param {number} x2\n * @param {number} y2\n * @param {number} lineWidth\n * @param {number} x\n * @param {number} y\n * @return {boolean}\n */\nfunction containStroke(x0, y0, x1, y1, x2, y2, lineWidth, x, y) {\n if (lineWidth === 0) {\n return false;\n }\n\n var _l = lineWidth; // Quick reject\n\n if (y > y0 + _l && y > y1 + _l && y > y2 + _l || y < y0 - _l && y < y1 - _l && y < y2 - _l || x > x0 + _l && x > x1 + _l && x > x2 + _l || x < x0 - _l && x < x1 - _l && x < x2 - _l) {\n return false;\n }\n\n var d = quadraticProjectPoint(x0, y0, x1, y1, x2, y2, x, y, null);\n return d <= _l / 2;\n}\n\nexports.containStroke = containStroke;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar OrdinalScale = require(\"../scale/Ordinal\");\n\nvar IntervalScale = require(\"../scale/Interval\");\n\nvar Scale = require(\"../scale/Scale\");\n\nvar numberUtil = require(\"../util/number\");\n\nvar _barGrid = require(\"../layout/barGrid\");\n\nvar prepareLayoutBarSeries = _barGrid.prepareLayoutBarSeries;\nvar makeColumnLayout = _barGrid.makeColumnLayout;\nvar retrieveColumnLayout = _barGrid.retrieveColumnLayout;\n\nvar BoundingRect = require(\"zrender/lib/core/BoundingRect\");\n\nrequire(\"../scale/Time\");\n\nrequire(\"../scale/Log\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Get axis scale extent before niced.\n * Item of returned array can only be number (including Infinity and NaN).\n */\nfunction getScaleExtent(scale, model) {\n var scaleType = scale.type;\n var min = model.getMin();\n var max = model.getMax();\n var fixMin = min != null;\n var fixMax = max != null;\n var originalExtent = scale.getExtent();\n var axisDataLen;\n var boundaryGap;\n var span;\n\n if (scaleType === 'ordinal') {\n axisDataLen = model.getCategories().length;\n } else {\n boundaryGap = model.get('boundaryGap');\n\n if (!zrUtil.isArray(boundaryGap)) {\n boundaryGap = [boundaryGap || 0, boundaryGap || 0];\n }\n\n if (typeof boundaryGap[0] === 'boolean') {\n boundaryGap = [0, 0];\n }\n\n boundaryGap[0] = numberUtil.parsePercent(boundaryGap[0], 1);\n boundaryGap[1] = numberUtil.parsePercent(boundaryGap[1], 1);\n span = originalExtent[1] - originalExtent[0] || Math.abs(originalExtent[0]);\n } // Notice: When min/max is not set (that is, when there are null/undefined,\n // which is the most common case), these cases should be ensured:\n // (1) For 'ordinal', show all axis.data.\n // (2) For others:\n // + `boundaryGap` is applied (if min/max set, boundaryGap is\n // disabled).\n // + If `needCrossZero`, min/max should be zero, otherwise, min/max should\n // be the result that originalExtent enlarged by boundaryGap.\n // (3) If no data, it should be ensured that `scale.setBlank` is set.\n // FIXME\n // (1) When min/max is 'dataMin' or 'dataMax', should boundaryGap be able to used?\n // (2) When `needCrossZero` and all data is positive/negative, should it be ensured\n // that the results processed by boundaryGap are positive/negative?\n\n\n if (min == null) {\n min = scaleType === 'ordinal' ? axisDataLen ? 0 : NaN : originalExtent[0] - boundaryGap[0] * span;\n }\n\n if (max == null) {\n max = scaleType === 'ordinal' ? axisDataLen ? axisDataLen - 1 : NaN : originalExtent[1] + boundaryGap[1] * span;\n }\n\n if (min === 'dataMin') {\n min = originalExtent[0];\n } else if (typeof min === 'function') {\n min = min({\n min: originalExtent[0],\n max: originalExtent[1]\n });\n }\n\n if (max === 'dataMax') {\n max = originalExtent[1];\n } else if (typeof max === 'function') {\n max = max({\n min: originalExtent[0],\n max: originalExtent[1]\n });\n }\n\n (min == null || !isFinite(min)) && (min = NaN);\n (max == null || !isFinite(max)) && (max = NaN);\n scale.setBlank(zrUtil.eqNaN(min) || zrUtil.eqNaN(max) || scaleType === 'ordinal' && !scale.getOrdinalMeta().categories.length); // Evaluate if axis needs cross zero\n\n if (model.getNeedCrossZero()) {\n // Axis is over zero and min is not set\n if (min > 0 && max > 0 && !fixMin) {\n min = 0;\n } // Axis is under zero and max is not set\n\n\n if (min < 0 && max < 0 && !fixMax) {\n max = 0;\n }\n } // If bars are placed on a base axis of type time or interval account for axis boundary overflow and current axis\n // is base axis\n // FIXME\n // (1) Consider support value axis, where below zero and axis `onZero` should be handled properly.\n // (2) Refactor the logic with `barGrid`. Is it not need to `makeBarWidthAndOffsetInfo` twice with different extent?\n // Should not depend on series type `bar`?\n // (3) Fix that might overlap when using dataZoom.\n // (4) Consider other chart types using `barGrid`?\n // See #6728, #4862, `test/bar-overflow-time-plot.html`\n\n\n var ecModel = model.ecModel;\n\n if (ecModel && scaleType === 'time'\n /*|| scaleType === 'interval' */\n ) {\n var barSeriesModels = prepareLayoutBarSeries('bar', ecModel);\n var isBaseAxisAndHasBarSeries;\n zrUtil.each(barSeriesModels, function (seriesModel) {\n isBaseAxisAndHasBarSeries |= seriesModel.getBaseAxis() === model.axis;\n });\n\n if (isBaseAxisAndHasBarSeries) {\n // Calculate placement of bars on axis\n var barWidthAndOffset = makeColumnLayout(barSeriesModels); // Adjust axis min and max to account for overflow\n\n var adjustedScale = adjustScaleForOverflow(min, max, model, barWidthAndOffset);\n min = adjustedScale.min;\n max = adjustedScale.max;\n }\n }\n\n return [min, max];\n}\n\nfunction adjustScaleForOverflow(min, max, model, barWidthAndOffset) {\n // Get Axis Length\n var axisExtent = model.axis.getExtent();\n var axisLength = axisExtent[1] - axisExtent[0]; // Get bars on current base axis and calculate min and max overflow\n\n var barsOnCurrentAxis = retrieveColumnLayout(barWidthAndOffset, model.axis);\n\n if (barsOnCurrentAxis === undefined) {\n return {\n min: min,\n max: max\n };\n }\n\n var minOverflow = Infinity;\n zrUtil.each(barsOnCurrentAxis, function (item) {\n minOverflow = Math.min(item.offset, minOverflow);\n });\n var maxOverflow = -Infinity;\n zrUtil.each(barsOnCurrentAxis, function (item) {\n maxOverflow = Math.max(item.offset + item.width, maxOverflow);\n });\n minOverflow = Math.abs(minOverflow);\n maxOverflow = Math.abs(maxOverflow);\n var totalOverFlow = minOverflow + maxOverflow; // Calulate required buffer based on old range and overflow\n\n var oldRange = max - min;\n var oldRangePercentOfNew = 1 - (minOverflow + maxOverflow) / axisLength;\n var overflowBuffer = oldRange / oldRangePercentOfNew - oldRange;\n max += overflowBuffer * (maxOverflow / totalOverFlow);\n min -= overflowBuffer * (minOverflow / totalOverFlow);\n return {\n min: min,\n max: max\n };\n}\n\nfunction niceScaleExtent(scale, model) {\n var extent = getScaleExtent(scale, model);\n var fixMin = model.getMin() != null;\n var fixMax = model.getMax() != null;\n var splitNumber = model.get('splitNumber');\n\n if (scale.type === 'log') {\n scale.base = model.get('logBase');\n }\n\n var scaleType = scale.type;\n scale.setExtent(extent[0], extent[1]);\n scale.niceExtent({\n splitNumber: splitNumber,\n fixMin: fixMin,\n fixMax: fixMax,\n minInterval: scaleType === 'interval' || scaleType === 'time' ? model.get('minInterval') : null,\n maxInterval: scaleType === 'interval' || scaleType === 'time' ? model.get('maxInterval') : null\n }); // If some one specified the min, max. And the default calculated interval\n // is not good enough. He can specify the interval. It is often appeared\n // in angle axis with angle 0 - 360. Interval calculated in interval scale is hard\n // to be 60.\n // FIXME\n\n var interval = model.get('interval');\n\n if (interval != null) {\n scale.setInterval && scale.setInterval(interval);\n }\n}\n/**\n * @param {module:echarts/model/Model} model\n * @param {string} [axisType] Default retrieve from model.type\n * @return {module:echarts/scale/*}\n */\n\n\nfunction createScaleByModel(model, axisType) {\n axisType = axisType || model.get('type');\n\n if (axisType) {\n switch (axisType) {\n // Buildin scale\n case 'category':\n return new OrdinalScale(model.getOrdinalMeta ? model.getOrdinalMeta() : model.getCategories(), [Infinity, -Infinity]);\n\n case 'value':\n return new IntervalScale();\n // Extended scale, like time and log\n\n default:\n return (Scale.getClass(axisType) || IntervalScale).create(model);\n }\n }\n}\n/**\n * Check if the axis corss 0\n */\n\n\nfunction ifAxisCrossZero(axis) {\n var dataExtent = axis.scale.getExtent();\n var min = dataExtent[0];\n var max = dataExtent[1];\n return !(min > 0 && max > 0 || min < 0 && max < 0);\n}\n/**\n * @param {module:echarts/coord/Axis} axis\n * @return {Function} Label formatter function.\n * param: {number} tickValue,\n * param: {number} idx, the index in all ticks.\n * If category axis, this param is not requied.\n * return: {string} label string.\n */\n\n\nfunction makeLabelFormatter(axis) {\n var labelFormatter = axis.getLabelModel().get('formatter');\n var categoryTickStart = axis.type === 'category' ? axis.scale.getExtent()[0] : null;\n\n if (typeof labelFormatter === 'string') {\n labelFormatter = function (tpl) {\n return function (val) {\n // For category axis, get raw value; for numeric axis,\n // get foramtted label like '1,333,444'.\n val = axis.scale.getLabel(val);\n return tpl.replace('{value}', val != null ? val : '');\n };\n }(labelFormatter); // Consider empty array\n\n\n return labelFormatter;\n } else if (typeof labelFormatter === 'function') {\n return function (tickValue, idx) {\n // The original intention of `idx` is \"the index of the tick in all ticks\".\n // But the previous implementation of category axis do not consider the\n // `axisLabel.interval`, which cause that, for example, the `interval` is\n // `1`, then the ticks \"name5\", \"name7\", \"name9\" are displayed, where the\n // corresponding `idx` are `0`, `2`, `4`, but not `0`, `1`, `2`. So we keep\n // the definition here for back compatibility.\n if (categoryTickStart != null) {\n idx = tickValue - categoryTickStart;\n }\n\n return labelFormatter(getAxisRawValue(axis, tickValue), idx);\n };\n } else {\n return function (tick) {\n return axis.scale.getLabel(tick);\n };\n }\n}\n\nfunction getAxisRawValue(axis, value) {\n // In category axis with data zoom, tick is not the original\n // index of axis.data. So tick should not be exposed to user\n // in category axis.\n return axis.type === 'category' ? axis.scale.getLabel(value) : value;\n}\n/**\n * @param {module:echarts/coord/Axis} axis\n * @return {module:zrender/core/BoundingRect} Be null/undefined if no labels.\n */\n\n\nfunction estimateLabelUnionRect(axis) {\n var axisModel = axis.model;\n var scale = axis.scale;\n\n if (!axisModel.get('axisLabel.show') || scale.isBlank()) {\n return;\n }\n\n var isCategory = axis.type === 'category';\n var realNumberScaleTicks;\n var tickCount;\n var categoryScaleExtent = scale.getExtent(); // Optimize for large category data, avoid call `getTicks()`.\n\n if (isCategory) {\n tickCount = scale.count();\n } else {\n realNumberScaleTicks = scale.getTicks();\n tickCount = realNumberScaleTicks.length;\n }\n\n var axisLabelModel = axis.getLabelModel();\n var labelFormatter = makeLabelFormatter(axis);\n var rect;\n var step = 1; // Simple optimization for large amount of labels\n\n if (tickCount > 40) {\n step = Math.ceil(tickCount / 40);\n }\n\n for (var i = 0; i < tickCount; i += step) {\n var tickValue = realNumberScaleTicks ? realNumberScaleTicks[i] : categoryScaleExtent[0] + i;\n var label = labelFormatter(tickValue);\n var unrotatedSingleRect = axisLabelModel.getTextRect(label);\n var singleRect = rotateTextRect(unrotatedSingleRect, axisLabelModel.get('rotate') || 0);\n rect ? rect.union(singleRect) : rect = singleRect;\n }\n\n return rect;\n}\n\nfunction rotateTextRect(textRect, rotate) {\n var rotateRadians = rotate * Math.PI / 180;\n var boundingBox = textRect.plain();\n var beforeWidth = boundingBox.width;\n var beforeHeight = boundingBox.height;\n var afterWidth = beforeWidth * Math.cos(rotateRadians) + beforeHeight * Math.sin(rotateRadians);\n var afterHeight = beforeWidth * Math.sin(rotateRadians) + beforeHeight * Math.cos(rotateRadians);\n var rotatedRect = new BoundingRect(boundingBox.x, boundingBox.y, afterWidth, afterHeight);\n return rotatedRect;\n}\n/**\n * @param {module:echarts/src/model/Model} model axisLabelModel or axisTickModel\n * @return {number|String} Can be null|'auto'|number|function\n */\n\n\nfunction getOptionCategoryInterval(model) {\n var interval = model.get('interval');\n return interval == null ? 'auto' : interval;\n}\n/**\n * Set `categoryInterval` as 0 implicitly indicates that\n * show all labels reguardless of overlap.\n * @param {Object} axis axisModel.axis\n * @return {boolean}\n */\n\n\nfunction shouldShowAllLabels(axis) {\n return axis.type === 'category' && getOptionCategoryInterval(axis.getLabelModel()) === 0;\n}\n\nexports.getScaleExtent = getScaleExtent;\nexports.niceScaleExtent = niceScaleExtent;\nexports.createScaleByModel = createScaleByModel;\nexports.ifAxisCrossZero = ifAxisCrossZero;\nexports.makeLabelFormatter = makeLabelFormatter;\nexports.getAxisRawValue = getAxisRawValue;\nexports.estimateLabelUnionRect = estimateLabelUnionRect;\nexports.getOptionCategoryInterval = getOptionCategoryInterval;\nexports.shouldShowAllLabels = shouldShowAllLabels;","var guid = require(\"./core/guid\");\n\nvar env = require(\"./core/env\");\n\nvar zrUtil = require(\"./core/util\");\n\nvar Handler = require(\"./Handler\");\n\nvar Storage = require(\"./Storage\");\n\nvar Painter = require(\"./Painter\");\n\nvar Animation = require(\"./animation/Animation\");\n\nvar HandlerProxy = require(\"./dom/HandlerProxy\");\n\n/*!\n* ZRender, a high performance 2d drawing library.\n*\n* Copyright (c) 2013, Baidu Inc.\n* All rights reserved.\n*\n* LICENSE\n* https://github.com/ecomfe/zrender/blob/master/LICENSE.txt\n*/\nvar useVML = !env.canvasSupported;\nvar painterCtors = {\n canvas: Painter\n};\nvar instances = {}; // ZRender实例map索引\n\n/**\n * @type {string}\n */\n\nvar version = '4.0.7';\n/**\n * Initializing a zrender instance\n * @param {HTMLElement} dom\n * @param {Object} [opts]\n * @param {string} [opts.renderer='canvas'] 'canvas' or 'svg'\n * @param {number} [opts.devicePixelRatio]\n * @param {number|string} [opts.width] Can be 'auto' (the same as null/undefined)\n * @param {number|string} [opts.height] Can be 'auto' (the same as null/undefined)\n * @return {module:zrender/ZRender}\n */\n\nfunction init(dom, opts) {\n var zr = new ZRender(guid(), dom, opts);\n instances[zr.id] = zr;\n return zr;\n}\n/**\n * Dispose zrender instance\n * @param {module:zrender/ZRender} zr\n */\n\n\nfunction dispose(zr) {\n if (zr) {\n zr.dispose();\n } else {\n for (var key in instances) {\n if (instances.hasOwnProperty(key)) {\n instances[key].dispose();\n }\n }\n\n instances = {};\n }\n\n return this;\n}\n/**\n * Get zrender instance by id\n * @param {string} id zrender instance id\n * @return {module:zrender/ZRender}\n */\n\n\nfunction getInstance(id) {\n return instances[id];\n}\n\nfunction registerPainter(name, Ctor) {\n painterCtors[name] = Ctor;\n}\n\nfunction delInstance(id) {\n delete instances[id];\n}\n/**\n * @module zrender/ZRender\n */\n\n/**\n * @constructor\n * @alias module:zrender/ZRender\n * @param {string} id\n * @param {HTMLElement} dom\n * @param {Object} opts\n * @param {string} [opts.renderer='canvas'] 'canvas' or 'svg'\n * @param {number} [opts.devicePixelRatio]\n * @param {number} [opts.width] Can be 'auto' (the same as null/undefined)\n * @param {number} [opts.height] Can be 'auto' (the same as null/undefined)\n */\n\n\nvar ZRender = function (id, dom, opts) {\n opts = opts || {};\n /**\n * @type {HTMLDomElement}\n */\n\n this.dom = dom;\n /**\n * @type {string}\n */\n\n this.id = id;\n var self = this;\n var storage = new Storage();\n var rendererType = opts.renderer; // TODO WebGL\n\n if (useVML) {\n if (!painterCtors.vml) {\n throw new Error('You need to require \\'zrender/vml/vml\\' to support IE8');\n }\n\n rendererType = 'vml';\n } else if (!rendererType || !painterCtors[rendererType]) {\n rendererType = 'canvas';\n }\n\n var painter = new painterCtors[rendererType](dom, storage, opts, id);\n this.storage = storage;\n this.painter = painter;\n var handerProxy = !env.node && !env.worker ? new HandlerProxy(painter.getViewportRoot()) : null;\n this.handler = new Handler(storage, painter, handerProxy, painter.root);\n /**\n * @type {module:zrender/animation/Animation}\n */\n\n this.animation = new Animation({\n stage: {\n update: zrUtil.bind(this.flush, this)\n }\n });\n this.animation.start();\n /**\n * @type {boolean}\n * @private\n */\n\n this._needsRefresh; // 修改 storage.delFromStorage, 每次删除元素之前删除动画\n // FIXME 有点ugly\n\n var oldDelFromStorage = storage.delFromStorage;\n var oldAddToStorage = storage.addToStorage;\n\n storage.delFromStorage = function (el) {\n oldDelFromStorage.call(storage, el);\n el && el.removeSelfFromZr(self);\n };\n\n storage.addToStorage = function (el) {\n oldAddToStorage.call(storage, el);\n el.addSelfToZr(self);\n };\n};\n\nZRender.prototype = {\n constructor: ZRender,\n\n /**\n * 获取实例唯一标识\n * @return {string}\n */\n getId: function () {\n return this.id;\n },\n\n /**\n * 添加元素\n * @param {module:zrender/Element} el\n */\n add: function (el) {\n this.storage.addRoot(el);\n this._needsRefresh = true;\n },\n\n /**\n * 删除元素\n * @param {module:zrender/Element} el\n */\n remove: function (el) {\n this.storage.delRoot(el);\n this._needsRefresh = true;\n },\n\n /**\n * Change configuration of layer\n * @param {string} zLevel\n * @param {Object} config\n * @param {string} [config.clearColor=0] Clear color\n * @param {string} [config.motionBlur=false] If enable motion blur\n * @param {number} [config.lastFrameAlpha=0.7] Motion blur factor. Larger value cause longer trailer\n */\n configLayer: function (zLevel, config) {\n if (this.painter.configLayer) {\n this.painter.configLayer(zLevel, config);\n }\n\n this._needsRefresh = true;\n },\n\n /**\n * Set background color\n * @param {string} backgroundColor\n */\n setBackgroundColor: function (backgroundColor) {\n if (this.painter.setBackgroundColor) {\n this.painter.setBackgroundColor(backgroundColor);\n }\n\n this._needsRefresh = true;\n },\n\n /**\n * Repaint the canvas immediately\n */\n refreshImmediately: function () {\n // var start = new Date();\n // Clear needsRefresh ahead to avoid something wrong happens in refresh\n // Or it will cause zrender refreshes again and again.\n this._needsRefresh = false;\n this.painter.refresh();\n /**\n * Avoid trigger zr.refresh in Element#beforeUpdate hook\n */\n\n this._needsRefresh = false; // var end = new Date();\n // var log = document.getElementById('log');\n // if (log) {\n // log.innerHTML = log.innerHTML + '<br>' + (end - start);\n // }\n },\n\n /**\n * Mark and repaint the canvas in the next frame of browser\n */\n refresh: function () {\n this._needsRefresh = true;\n },\n\n /**\n * Perform all refresh\n */\n flush: function () {\n var triggerRendered;\n\n if (this._needsRefresh) {\n triggerRendered = true;\n this.refreshImmediately();\n }\n\n if (this._needsRefreshHover) {\n triggerRendered = true;\n this.refreshHoverImmediately();\n }\n\n triggerRendered && this.trigger('rendered');\n },\n\n /**\n * Add element to hover layer\n * @param {module:zrender/Element} el\n * @param {Object} style\n */\n addHover: function (el, style) {\n if (this.painter.addHover) {\n var elMirror = this.painter.addHover(el, style);\n this.refreshHover();\n return elMirror;\n }\n },\n\n /**\n * Add element from hover layer\n * @param {module:zrender/Element} el\n */\n removeHover: function (el) {\n if (this.painter.removeHover) {\n this.painter.removeHover(el);\n this.refreshHover();\n }\n },\n\n /**\n * Clear all hover elements in hover layer\n * @param {module:zrender/Element} el\n */\n clearHover: function () {\n if (this.painter.clearHover) {\n this.painter.clearHover();\n this.refreshHover();\n }\n },\n\n /**\n * Refresh hover in next frame\n */\n refreshHover: function () {\n this._needsRefreshHover = true;\n },\n\n /**\n * Refresh hover immediately\n */\n refreshHoverImmediately: function () {\n this._needsRefreshHover = false;\n this.painter.refreshHover && this.painter.refreshHover();\n },\n\n /**\n * Resize the canvas.\n * Should be invoked when container size is changed\n * @param {Object} [opts]\n * @param {number|string} [opts.width] Can be 'auto' (the same as null/undefined)\n * @param {number|string} [opts.height] Can be 'auto' (the same as null/undefined)\n */\n resize: function (opts) {\n opts = opts || {};\n this.painter.resize(opts.width, opts.height);\n this.handler.resize();\n },\n\n /**\n * Stop and clear all animation immediately\n */\n clearAnimation: function () {\n this.animation.clear();\n },\n\n /**\n * Get container width\n */\n getWidth: function () {\n return this.painter.getWidth();\n },\n\n /**\n * Get container height\n */\n getHeight: function () {\n return this.painter.getHeight();\n },\n\n /**\n * Export the canvas as Base64 URL\n * @param {string} type\n * @param {string} [backgroundColor='#fff']\n * @return {string} Base64 URL\n */\n // toDataURL: function(type, backgroundColor) {\n // return this.painter.getRenderedCanvas({\n // backgroundColor: backgroundColor\n // }).toDataURL(type);\n // },\n\n /**\n * Converting a path to image.\n * It has much better performance of drawing image rather than drawing a vector path.\n * @param {module:zrender/graphic/Path} e\n * @param {number} width\n * @param {number} height\n */\n pathToImage: function (e, dpr) {\n return this.painter.pathToImage(e, dpr);\n },\n\n /**\n * Set default cursor\n * @param {string} [cursorStyle='default'] 例如 crosshair\n */\n setCursorStyle: function (cursorStyle) {\n this.handler.setCursorStyle(cursorStyle);\n },\n\n /**\n * Find hovered element\n * @param {number} x\n * @param {number} y\n * @return {Object} {target, topTarget}\n */\n findHover: function (x, y) {\n return this.handler.findHover(x, y);\n },\n\n /**\n * Bind event\n *\n * @param {string} eventName Event name\n * @param {Function} eventHandler Handler function\n * @param {Object} [context] Context object\n */\n on: function (eventName, eventHandler, context) {\n this.handler.on(eventName, eventHandler, context);\n },\n\n /**\n * Unbind event\n * @param {string} eventName Event name\n * @param {Function} [eventHandler] Handler function\n */\n off: function (eventName, eventHandler) {\n this.handler.off(eventName, eventHandler);\n },\n\n /**\n * Trigger event manually\n *\n * @param {string} eventName Event name\n * @param {event=} event Event object\n */\n trigger: function (eventName, event) {\n this.handler.trigger(eventName, event);\n },\n\n /**\n * Clear all objects and the canvas.\n */\n clear: function () {\n this.storage.delRoot();\n this.painter.clear();\n },\n\n /**\n * Dispose self.\n */\n dispose: function () {\n this.animation.stop();\n this.clear();\n this.storage.dispose();\n this.painter.dispose();\n this.handler.dispose();\n this.animation = this.storage = this.painter = this.handler = null;\n delInstance(this.id);\n }\n};\nexports.version = version;\nexports.init = init;\nexports.dispose = dispose;\nexports.getInstance = getInstance;\nexports.registerPainter = registerPainter;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar each = _util.each;\nvar map = _util.map;\nvar isFunction = _util.isFunction;\nvar createHashMap = _util.createHashMap;\nvar noop = _util.noop;\n\nvar _task = require(\"./task\");\n\nvar createTask = _task.createTask;\n\nvar _component = require(\"../util/component\");\n\nvar getUID = _component.getUID;\n\nvar GlobalModel = require(\"../model/Global\");\n\nvar ExtensionAPI = require(\"../ExtensionAPI\");\n\nvar _model = require(\"../util/model\");\n\nvar normalizeToArray = _model.normalizeToArray;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @module echarts/stream/Scheduler\n */\n\n/**\n * @constructor\n */\nfunction Scheduler(ecInstance, api, dataProcessorHandlers, visualHandlers) {\n this.ecInstance = ecInstance;\n this.api = api;\n this.unfinished; // Fix current processors in case that in some rear cases that\n // processors might be registered after echarts instance created.\n // Register processors incrementally for a echarts instance is\n // not supported by this stream architecture.\n\n var dataProcessorHandlers = this._dataProcessorHandlers = dataProcessorHandlers.slice();\n var visualHandlers = this._visualHandlers = visualHandlers.slice();\n this._allHandlers = dataProcessorHandlers.concat(visualHandlers);\n /**\n * @private\n * @type {\n * [handlerUID: string]: {\n * seriesTaskMap?: {\n * [seriesUID: string]: Task\n * },\n * overallTask?: Task\n * }\n * }\n */\n\n this._stageTaskMap = createHashMap();\n}\n\nvar proto = Scheduler.prototype;\n/**\n * @param {module:echarts/model/Global} ecModel\n * @param {Object} payload\n */\n\nproto.restoreData = function (ecModel, payload) {\n // TODO: Only restroe needed series and components, but not all components.\n // Currently `restoreData` of all of the series and component will be called.\n // But some independent components like `title`, `legend`, `graphic`, `toolbox`,\n // `tooltip`, `axisPointer`, etc, do not need series refresh when `setOption`,\n // and some components like coordinate system, axes, dataZoom, visualMap only\n // need their target series refresh.\n // (1) If we are implementing this feature some day, we should consider these cases:\n // if a data processor depends on a component (e.g., dataZoomProcessor depends\n // on the settings of `dataZoom`), it should be re-performed if the component\n // is modified by `setOption`.\n // (2) If a processor depends on sevral series, speicified by its `getTargetSeries`,\n // it should be re-performed when the result array of `getTargetSeries` changed.\n // We use `dependencies` to cover these issues.\n // (3) How to update target series when coordinate system related components modified.\n // TODO: simply the dirty mechanism? Check whether only the case here can set tasks dirty,\n // and this case all of the tasks will be set as dirty.\n ecModel.restoreData(payload); // Theoretically an overall task not only depends on each of its target series, but also\n // depends on all of the series.\n // The overall task is not in pipeline, and `ecModel.restoreData` only set pipeline tasks\n // dirty. If `getTargetSeries` of an overall task returns nothing, we should also ensure\n // that the overall task is set as dirty and to be performed, otherwise it probably cause\n // state chaos. So we have to set dirty of all of the overall tasks manually, otherwise it\n // probably cause state chaos (consider `dataZoomProcessor`).\n\n this._stageTaskMap.each(function (taskRecord) {\n var overallTask = taskRecord.overallTask;\n overallTask && overallTask.dirty();\n });\n}; // If seriesModel provided, incremental threshold is check by series data.\n\n\nproto.getPerformArgs = function (task, isBlock) {\n // For overall task\n if (!task.__pipeline) {\n return;\n }\n\n var pipeline = this._pipelineMap.get(task.__pipeline.id);\n\n var pCtx = pipeline.context;\n var incremental = !isBlock && pipeline.progressiveEnabled && (!pCtx || pCtx.progressiveRender) && task.__idxInPipeline > pipeline.blockIndex;\n var step = incremental ? pipeline.step : null;\n var modDataCount = pCtx && pCtx.modDataCount;\n var modBy = modDataCount != null ? Math.ceil(modDataCount / step) : null;\n return {\n step: step,\n modBy: modBy,\n modDataCount: modDataCount\n };\n};\n\nproto.getPipeline = function (pipelineId) {\n return this._pipelineMap.get(pipelineId);\n};\n/**\n * Current, progressive rendering starts from visual and layout.\n * Always detect render mode in the same stage, avoiding that incorrect\n * detection caused by data filtering.\n * Caution:\n * `updateStreamModes` use `seriesModel.getData()`.\n */\n\n\nproto.updateStreamModes = function (seriesModel, view) {\n var pipeline = this._pipelineMap.get(seriesModel.uid);\n\n var data = seriesModel.getData();\n var dataLen = data.count(); // `progressiveRender` means that can render progressively in each\n // animation frame. Note that some types of series do not provide\n // `view.incrementalPrepareRender` but support `chart.appendData`. We\n // use the term `incremental` but not `progressive` to describe the\n // case that `chart.appendData`.\n\n var progressiveRender = pipeline.progressiveEnabled && view.incrementalPrepareRender && dataLen >= pipeline.threshold;\n var large = seriesModel.get('large') && dataLen >= seriesModel.get('largeThreshold'); // TODO: modDataCount should not updated if `appendData`, otherwise cause whole repaint.\n // see `test/candlestick-large3.html`\n\n var modDataCount = seriesModel.get('progressiveChunkMode') === 'mod' ? dataLen : null;\n seriesModel.pipelineContext = pipeline.context = {\n progressiveRender: progressiveRender,\n modDataCount: modDataCount,\n large: large\n };\n};\n\nproto.restorePipelines = function (ecModel) {\n var scheduler = this;\n var pipelineMap = scheduler._pipelineMap = createHashMap();\n ecModel.eachSeries(function (seriesModel) {\n var progressive = seriesModel.getProgressive();\n var pipelineId = seriesModel.uid;\n pipelineMap.set(pipelineId, {\n id: pipelineId,\n head: null,\n tail: null,\n threshold: seriesModel.getProgressiveThreshold(),\n progressiveEnabled: progressive && !(seriesModel.preventIncremental && seriesModel.preventIncremental()),\n blockIndex: -1,\n step: Math.round(progressive || 700),\n count: 0\n });\n pipe(scheduler, seriesModel, seriesModel.dataTask);\n });\n};\n\nproto.prepareStageTasks = function () {\n var stageTaskMap = this._stageTaskMap;\n var ecModel = this.ecInstance.getModel();\n var api = this.api;\n each(this._allHandlers, function (handler) {\n var record = stageTaskMap.get(handler.uid) || stageTaskMap.set(handler.uid, []);\n handler.reset && createSeriesStageTask(this, handler, record, ecModel, api);\n handler.overallReset && createOverallStageTask(this, handler, record, ecModel, api);\n }, this);\n};\n\nproto.prepareView = function (view, model, ecModel, api) {\n var renderTask = view.renderTask;\n var context = renderTask.context;\n context.model = model;\n context.ecModel = ecModel;\n context.api = api;\n renderTask.__block = !view.incrementalPrepareRender;\n pipe(this, model, renderTask);\n};\n\nproto.performDataProcessorTasks = function (ecModel, payload) {\n // If we do not use `block` here, it should be considered when to update modes.\n performStageTasks(this, this._dataProcessorHandlers, ecModel, payload, {\n block: true\n });\n}; // opt\n// opt.visualType: 'visual' or 'layout'\n// opt.setDirty\n\n\nproto.performVisualTasks = function (ecModel, payload, opt) {\n performStageTasks(this, this._visualHandlers, ecModel, payload, opt);\n};\n\nfunction performStageTasks(scheduler, stageHandlers, ecModel, payload, opt) {\n opt = opt || {};\n var unfinished;\n each(stageHandlers, function (stageHandler, idx) {\n if (opt.visualType && opt.visualType !== stageHandler.visualType) {\n return;\n }\n\n var stageHandlerRecord = scheduler._stageTaskMap.get(stageHandler.uid);\n\n var seriesTaskMap = stageHandlerRecord.seriesTaskMap;\n var overallTask = stageHandlerRecord.overallTask;\n\n if (overallTask) {\n var overallNeedDirty;\n var agentStubMap = overallTask.agentStubMap;\n agentStubMap.each(function (stub) {\n if (needSetDirty(opt, stub)) {\n stub.dirty();\n overallNeedDirty = true;\n }\n });\n overallNeedDirty && overallTask.dirty();\n updatePayload(overallTask, payload);\n var performArgs = scheduler.getPerformArgs(overallTask, opt.block); // Execute stubs firstly, which may set the overall task dirty,\n // then execute the overall task. And stub will call seriesModel.setData,\n // which ensures that in the overallTask seriesModel.getData() will not\n // return incorrect data.\n\n agentStubMap.each(function (stub) {\n stub.perform(performArgs);\n });\n unfinished |= overallTask.perform(performArgs);\n } else if (seriesTaskMap) {\n seriesTaskMap.each(function (task, pipelineId) {\n if (needSetDirty(opt, task)) {\n task.dirty();\n }\n\n var performArgs = scheduler.getPerformArgs(task, opt.block);\n performArgs.skip = !stageHandler.performRawSeries && ecModel.isSeriesFiltered(task.context.model);\n updatePayload(task, payload);\n unfinished |= task.perform(performArgs);\n });\n }\n });\n\n function needSetDirty(opt, task) {\n return opt.setDirty && (!opt.dirtyMap || opt.dirtyMap.get(task.__pipeline.id));\n }\n\n scheduler.unfinished |= unfinished;\n}\n\nproto.performSeriesTasks = function (ecModel) {\n var unfinished;\n ecModel.eachSeries(function (seriesModel) {\n // Progress to the end for dataInit and dataRestore.\n unfinished |= seriesModel.dataTask.perform();\n });\n this.unfinished |= unfinished;\n};\n\nproto.plan = function () {\n // Travel pipelines, check block.\n this._pipelineMap.each(function (pipeline) {\n var task = pipeline.tail;\n\n do {\n if (task.__block) {\n pipeline.blockIndex = task.__idxInPipeline;\n break;\n }\n\n task = task.getUpstream();\n } while (task);\n });\n};\n\nvar updatePayload = proto.updatePayload = function (task, payload) {\n payload !== 'remain' && (task.context.payload = payload);\n};\n\nfunction createSeriesStageTask(scheduler, stageHandler, stageHandlerRecord, ecModel, api) {\n var seriesTaskMap = stageHandlerRecord.seriesTaskMap || (stageHandlerRecord.seriesTaskMap = createHashMap());\n var seriesType = stageHandler.seriesType;\n var getTargetSeries = stageHandler.getTargetSeries; // If a stageHandler should cover all series, `createOnAllSeries` should be declared mandatorily,\n // to avoid some typo or abuse. Otherwise if an extension do not specify a `seriesType`,\n // it works but it may cause other irrelevant charts blocked.\n\n if (stageHandler.createOnAllSeries) {\n ecModel.eachRawSeries(create);\n } else if (seriesType) {\n ecModel.eachRawSeriesByType(seriesType, create);\n } else if (getTargetSeries) {\n getTargetSeries(ecModel, api).each(create);\n }\n\n function create(seriesModel) {\n var pipelineId = seriesModel.uid; // Init tasks for each seriesModel only once.\n // Reuse original task instance.\n\n var task = seriesTaskMap.get(pipelineId) || seriesTaskMap.set(pipelineId, createTask({\n plan: seriesTaskPlan,\n reset: seriesTaskReset,\n count: seriesTaskCount\n }));\n task.context = {\n model: seriesModel,\n ecModel: ecModel,\n api: api,\n useClearVisual: stageHandler.isVisual && !stageHandler.isLayout,\n plan: stageHandler.plan,\n reset: stageHandler.reset,\n scheduler: scheduler\n };\n pipe(scheduler, seriesModel, task);\n } // Clear unused series tasks.\n\n\n var pipelineMap = scheduler._pipelineMap;\n seriesTaskMap.each(function (task, pipelineId) {\n if (!pipelineMap.get(pipelineId)) {\n task.dispose();\n seriesTaskMap.removeKey(pipelineId);\n }\n });\n}\n\nfunction createOverallStageTask(scheduler, stageHandler, stageHandlerRecord, ecModel, api) {\n var overallTask = stageHandlerRecord.overallTask = stageHandlerRecord.overallTask // For overall task, the function only be called on reset stage.\n || createTask({\n reset: overallTaskReset\n });\n overallTask.context = {\n ecModel: ecModel,\n api: api,\n overallReset: stageHandler.overallReset,\n scheduler: scheduler\n }; // Reuse orignal stubs.\n\n var agentStubMap = overallTask.agentStubMap = overallTask.agentStubMap || createHashMap();\n var seriesType = stageHandler.seriesType;\n var getTargetSeries = stageHandler.getTargetSeries;\n var overallProgress = true;\n var modifyOutputEnd = stageHandler.modifyOutputEnd; // An overall task with seriesType detected or has `getTargetSeries`, we add\n // stub in each pipelines, it will set the overall task dirty when the pipeline\n // progress. Moreover, to avoid call the overall task each frame (too frequent),\n // we set the pipeline block.\n\n if (seriesType) {\n ecModel.eachRawSeriesByType(seriesType, createStub);\n } else if (getTargetSeries) {\n getTargetSeries(ecModel, api).each(createStub);\n } // Otherwise, (usually it is legancy case), the overall task will only be\n // executed when upstream dirty. Otherwise the progressive rendering of all\n // pipelines will be disabled unexpectedly. But it still needs stubs to receive\n // dirty info from upsteam.\n else {\n overallProgress = false;\n each(ecModel.getSeries(), createStub);\n }\n\n function createStub(seriesModel) {\n var pipelineId = seriesModel.uid;\n var stub = agentStubMap.get(pipelineId);\n\n if (!stub) {\n stub = agentStubMap.set(pipelineId, createTask({\n reset: stubReset,\n onDirty: stubOnDirty\n })); // When the result of `getTargetSeries` changed, the overallTask\n // should be set as dirty and re-performed.\n\n overallTask.dirty();\n }\n\n stub.context = {\n model: seriesModel,\n overallProgress: overallProgress,\n modifyOutputEnd: modifyOutputEnd\n };\n stub.agent = overallTask;\n stub.__block = overallProgress;\n pipe(scheduler, seriesModel, stub);\n } // Clear unused stubs.\n\n\n var pipelineMap = scheduler._pipelineMap;\n agentStubMap.each(function (stub, pipelineId) {\n if (!pipelineMap.get(pipelineId)) {\n stub.dispose(); // When the result of `getTargetSeries` changed, the overallTask\n // should be set as dirty and re-performed.\n\n overallTask.dirty();\n agentStubMap.removeKey(pipelineId);\n }\n });\n}\n\nfunction overallTaskReset(context) {\n context.overallReset(context.ecModel, context.api, context.payload);\n}\n\nfunction stubReset(context, upstreamContext) {\n return context.overallProgress && stubProgress;\n}\n\nfunction stubProgress() {\n this.agent.dirty();\n this.getDownstream().dirty();\n}\n\nfunction stubOnDirty() {\n this.agent && this.agent.dirty();\n}\n\nfunction seriesTaskPlan(context) {\n return context.plan && context.plan(context.model, context.ecModel, context.api, context.payload);\n}\n\nfunction seriesTaskReset(context) {\n if (context.useClearVisual) {\n context.data.clearAllVisual();\n }\n\n var resetDefines = context.resetDefines = normalizeToArray(context.reset(context.model, context.ecModel, context.api, context.payload));\n return resetDefines.length > 1 ? map(resetDefines, function (v, idx) {\n return makeSeriesTaskProgress(idx);\n }) : singleSeriesTaskProgress;\n}\n\nvar singleSeriesTaskProgress = makeSeriesTaskProgress(0);\n\nfunction makeSeriesTaskProgress(resetDefineIdx) {\n return function (params, context) {\n var data = context.data;\n var resetDefine = context.resetDefines[resetDefineIdx];\n\n if (resetDefine && resetDefine.dataEach) {\n for (var i = params.start; i < params.end; i++) {\n resetDefine.dataEach(data, i);\n }\n } else if (resetDefine && resetDefine.progress) {\n resetDefine.progress(params, data);\n }\n };\n}\n\nfunction seriesTaskCount(context) {\n return context.data.count();\n}\n\nfunction pipe(scheduler, seriesModel, task) {\n var pipelineId = seriesModel.uid;\n\n var pipeline = scheduler._pipelineMap.get(pipelineId);\n\n !pipeline.head && (pipeline.head = task);\n pipeline.tail && pipeline.tail.pipe(task);\n pipeline.tail = task;\n task.__idxInPipeline = pipeline.count++;\n task.__pipeline = pipeline;\n}\n\nScheduler.wrapStageHandler = function (stageHandler, visualType) {\n if (isFunction(stageHandler)) {\n stageHandler = {\n overallReset: stageHandler,\n seriesType: detectSeriseType(stageHandler)\n };\n }\n\n stageHandler.uid = getUID('stageHandler');\n visualType && (stageHandler.visualType = visualType);\n return stageHandler;\n};\n/**\n * Only some legacy stage handlers (usually in echarts extensions) are pure function.\n * To ensure that they can work normally, they should work in block mode, that is,\n * they should not be started util the previous tasks finished. So they cause the\n * progressive rendering disabled. We try to detect the series type, to narrow down\n * the block range to only the series type they concern, but not all series.\n */\n\n\nfunction detectSeriseType(legacyFunc) {\n seriesType = null;\n\n try {\n // Assume there is no async when calling `eachSeriesByType`.\n legacyFunc(ecModelMock, apiMock);\n } catch (e) {}\n\n return seriesType;\n}\n\nvar ecModelMock = {};\nvar apiMock = {};\nvar seriesType;\nmockMethods(ecModelMock, GlobalModel);\nmockMethods(apiMock, ExtensionAPI);\n\necModelMock.eachSeriesByType = ecModelMock.eachRawSeriesByType = function (type) {\n seriesType = type;\n};\n\necModelMock.eachComponent = function (cond) {\n if (cond.mainType === 'series' && cond.subType) {\n seriesType = cond.subType;\n }\n};\n\nfunction mockMethods(target, Clz) {\n /* eslint-disable */\n for (var name in Clz.prototype) {\n // Do not use hasOwnProperty\n target[name] = noop;\n }\n /* eslint-enable */\n\n}\n\nvar _default = Scheduler;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar formatUtil = require(\"../../util/format\");\n\nvar BaseAxisPointer = require(\"./BaseAxisPointer\");\n\nvar graphic = require(\"../../util/graphic\");\n\nvar viewHelper = require(\"./viewHelper\");\n\nvar matrix = require(\"zrender/lib/core/matrix\");\n\nvar AxisBuilder = require(\"../axis/AxisBuilder\");\n\nvar AxisView = require(\"../axis/AxisView\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar PolarAxisPointer = BaseAxisPointer.extend({\n /**\n * @override\n */\n makeElOption: function (elOption, value, axisModel, axisPointerModel, api) {\n var axis = axisModel.axis;\n\n if (axis.dim === 'angle') {\n this.animationThreshold = Math.PI / 18;\n }\n\n var polar = axis.polar;\n var otherAxis = polar.getOtherAxis(axis);\n var otherExtent = otherAxis.getExtent();\n var coordValue;\n coordValue = axis['dataTo' + formatUtil.capitalFirst(axis.dim)](value);\n var axisPointerType = axisPointerModel.get('type');\n\n if (axisPointerType && axisPointerType !== 'none') {\n var elStyle = viewHelper.buildElStyle(axisPointerModel);\n var pointerOption = pointerShapeBuilder[axisPointerType](axis, polar, coordValue, otherExtent, elStyle);\n pointerOption.style = elStyle;\n elOption.graphicKey = pointerOption.type;\n elOption.pointer = pointerOption;\n }\n\n var labelMargin = axisPointerModel.get('label.margin');\n var labelPos = getLabelPosition(value, axisModel, axisPointerModel, polar, labelMargin);\n viewHelper.buildLabelElOption(elOption, axisModel, axisPointerModel, api, labelPos);\n } // Do not support handle, utill any user requires it.\n\n});\n\nfunction getLabelPosition(value, axisModel, axisPointerModel, polar, labelMargin) {\n var axis = axisModel.axis;\n var coord = axis.dataToCoord(value);\n var axisAngle = polar.getAngleAxis().getExtent()[0];\n axisAngle = axisAngle / 180 * Math.PI;\n var radiusExtent = polar.getRadiusAxis().getExtent();\n var position;\n var align;\n var verticalAlign;\n\n if (axis.dim === 'radius') {\n var transform = matrix.create();\n matrix.rotate(transform, transform, axisAngle);\n matrix.translate(transform, transform, [polar.cx, polar.cy]);\n position = graphic.applyTransform([coord, -labelMargin], transform);\n var labelRotation = axisModel.getModel('axisLabel').get('rotate') || 0;\n var labelLayout = AxisBuilder.innerTextLayout(axisAngle, labelRotation * Math.PI / 180, -1);\n align = labelLayout.textAlign;\n verticalAlign = labelLayout.textVerticalAlign;\n } else {\n // angle axis\n var r = radiusExtent[1];\n position = polar.coordToPoint([r + labelMargin, coord]);\n var cx = polar.cx;\n var cy = polar.cy;\n align = Math.abs(position[0] - cx) / r < 0.3 ? 'center' : position[0] > cx ? 'left' : 'right';\n verticalAlign = Math.abs(position[1] - cy) / r < 0.3 ? 'middle' : position[1] > cy ? 'top' : 'bottom';\n }\n\n return {\n position: position,\n align: align,\n verticalAlign: verticalAlign\n };\n}\n\nvar pointerShapeBuilder = {\n line: function (axis, polar, coordValue, otherExtent, elStyle) {\n return axis.dim === 'angle' ? {\n type: 'Line',\n shape: viewHelper.makeLineShape(polar.coordToPoint([otherExtent[0], coordValue]), polar.coordToPoint([otherExtent[1], coordValue]))\n } : {\n type: 'Circle',\n shape: {\n cx: polar.cx,\n cy: polar.cy,\n r: coordValue\n }\n };\n },\n shadow: function (axis, polar, coordValue, otherExtent, elStyle) {\n var bandWidth = Math.max(1, axis.getBandWidth());\n var radian = Math.PI / 180;\n return axis.dim === 'angle' ? {\n type: 'Sector',\n shape: viewHelper.makeSectorShape(polar.cx, polar.cy, otherExtent[0], otherExtent[1], // In ECharts y is negative if angle is positive\n (-coordValue - bandWidth / 2) * radian, (-coordValue + bandWidth / 2) * radian)\n } : {\n type: 'Sector',\n shape: viewHelper.makeSectorShape(polar.cx, polar.cy, coordValue - bandWidth / 2, coordValue + bandWidth / 2, 0, Math.PI * 2)\n };\n }\n};\nAxisView.registerAxisPointerClass('PolarAxisPointer', PolarAxisPointer);\nvar _default = PolarAxisPointer;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Model = require(\"./Model\");\n\nvar componentUtil = require(\"../util/component\");\n\nvar _clazz = require(\"../util/clazz\");\n\nvar enableClassManagement = _clazz.enableClassManagement;\nvar parseClassType = _clazz.parseClassType;\n\nvar _model = require(\"../util/model\");\n\nvar makeInner = _model.makeInner;\n\nvar layout = require(\"../util/layout\");\n\nvar boxLayoutMixin = require(\"./mixin/boxLayout\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Component model\n *\n * @module echarts/model/Component\n */\nvar inner = makeInner();\n/**\n * @alias module:echarts/model/Component\n * @constructor\n * @param {Object} option\n * @param {module:echarts/model/Model} parentModel\n * @param {module:echarts/model/Model} ecModel\n */\n\nvar ComponentModel = Model.extend({\n type: 'component',\n\n /**\n * @readOnly\n * @type {string}\n */\n id: '',\n\n /**\n * Because simplified concept is probably better, series.name (or component.name)\n * has been having too many resposibilities:\n * (1) Generating id (which requires name in option should not be modified).\n * (2) As an index to mapping series when merging option or calling API (a name\n * can refer to more then one components, which is convinient is some case).\n * (3) Display.\n * @readOnly\n */\n name: '',\n\n /**\n * @readOnly\n * @type {string}\n */\n mainType: '',\n\n /**\n * @readOnly\n * @type {string}\n */\n subType: '',\n\n /**\n * @readOnly\n * @type {number}\n */\n componentIndex: 0,\n\n /**\n * @type {Object}\n * @protected\n */\n defaultOption: null,\n\n /**\n * @type {module:echarts/model/Global}\n * @readOnly\n */\n ecModel: null,\n\n /**\n * key: componentType\n * value: Component model list, can not be null.\n * @type {Object.<string, Array.<module:echarts/model/Model>>}\n * @readOnly\n */\n dependentModels: [],\n\n /**\n * @type {string}\n * @readOnly\n */\n uid: null,\n\n /**\n * Support merge layout params.\n * Only support 'box' now (left/right/top/bottom/width/height).\n * @type {string|Object} Object can be {ignoreSize: true}\n * @readOnly\n */\n layoutMode: null,\n $constructor: function (option, parentModel, ecModel, extraOpt) {\n Model.call(this, option, parentModel, ecModel, extraOpt);\n this.uid = componentUtil.getUID('ec_cpt_model');\n },\n init: function (option, parentModel, ecModel, extraOpt) {\n this.mergeDefaultAndTheme(option, ecModel);\n },\n mergeDefaultAndTheme: function (option, ecModel) {\n var layoutMode = this.layoutMode;\n var inputPositionParams = layoutMode ? layout.getLayoutParams(option) : {};\n var themeModel = ecModel.getTheme();\n zrUtil.merge(option, themeModel.get(this.mainType));\n zrUtil.merge(option, this.getDefaultOption());\n\n if (layoutMode) {\n layout.mergeLayoutParam(option, inputPositionParams, layoutMode);\n }\n },\n mergeOption: function (option, extraOpt) {\n zrUtil.merge(this.option, option, true);\n var layoutMode = this.layoutMode;\n\n if (layoutMode) {\n layout.mergeLayoutParam(this.option, option, layoutMode);\n }\n },\n // Hooker after init or mergeOption\n optionUpdated: function (newCptOption, isInit) {},\n getDefaultOption: function () {\n var fields = inner(this);\n\n if (!fields.defaultOption) {\n var optList = [];\n var Class = this.constructor;\n\n while (Class) {\n var opt = Class.prototype.defaultOption;\n opt && optList.push(opt);\n Class = Class.superClass;\n }\n\n var defaultOption = {};\n\n for (var i = optList.length - 1; i >= 0; i--) {\n defaultOption = zrUtil.merge(defaultOption, optList[i], true);\n }\n\n fields.defaultOption = defaultOption;\n }\n\n return fields.defaultOption;\n },\n getReferringComponents: function (mainType) {\n return this.ecModel.queryComponents({\n mainType: mainType,\n index: this.get(mainType + 'Index', true),\n id: this.get(mainType + 'Id', true)\n });\n }\n}); // Reset ComponentModel.extend, add preConstruct.\n// clazzUtil.enableClassExtend(\n// ComponentModel,\n// function (option, parentModel, ecModel, extraOpt) {\n// // Set dependentModels, componentIndex, name, id, mainType, subType.\n// zrUtil.extend(this, extraOpt);\n// this.uid = componentUtil.getUID('componentModel');\n// // this.setReadOnly([\n// // 'type', 'id', 'uid', 'name', 'mainType', 'subType',\n// // 'dependentModels', 'componentIndex'\n// // ]);\n// }\n// );\n// Add capability of registerClass, getClass, hasClass, registerSubTypeDefaulter and so on.\n\nenableClassManagement(ComponentModel, {\n registerWhenExtend: true\n});\ncomponentUtil.enableSubTypeDefaulter(ComponentModel); // Add capability of ComponentModel.topologicalTravel.\n\ncomponentUtil.enableTopologicalTravel(ComponentModel, getDependencies);\n\nfunction getDependencies(componentType) {\n var deps = [];\n zrUtil.each(ComponentModel.getClassesByMainType(componentType), function (Clazz) {\n deps = deps.concat(Clazz.prototype.dependencies || []);\n }); // Ensure main type.\n\n deps = zrUtil.map(deps, function (type) {\n return parseClassType(type).main;\n }); // Hack dataset for convenience.\n\n if (componentType !== 'dataset' && zrUtil.indexOf(deps, 'dataset') <= 0) {\n deps.unshift('dataset');\n }\n\n return deps;\n}\n\nzrUtil.mixin(ComponentModel, boxLayoutMixin);\nvar _default = ComponentModel;\nmodule.exports = _default;","/**\n * @module zrender/core/util\n */\n// 用于处理merge时无法遍历Date等对象的问题\nvar BUILTIN_OBJECT = {\n '[object Function]': 1,\n '[object RegExp]': 1,\n '[object Date]': 1,\n '[object Error]': 1,\n '[object CanvasGradient]': 1,\n '[object CanvasPattern]': 1,\n // For node-canvas\n '[object Image]': 1,\n '[object Canvas]': 1\n};\nvar TYPED_ARRAY = {\n '[object Int8Array]': 1,\n '[object Uint8Array]': 1,\n '[object Uint8ClampedArray]': 1,\n '[object Int16Array]': 1,\n '[object Uint16Array]': 1,\n '[object Int32Array]': 1,\n '[object Uint32Array]': 1,\n '[object Float32Array]': 1,\n '[object Float64Array]': 1\n};\nvar objToString = Object.prototype.toString;\nvar arrayProto = Array.prototype;\nvar nativeForEach = arrayProto.forEach;\nvar nativeFilter = arrayProto.filter;\nvar nativeSlice = arrayProto.slice;\nvar nativeMap = arrayProto.map;\nvar nativeReduce = arrayProto.reduce; // Avoid assign to an exported variable, for transforming to cjs.\n\nvar methods = {};\n\nfunction $override(name, fn) {\n // Clear ctx instance for different environment\n if (name === 'createCanvas') {\n _ctx = null;\n }\n\n methods[name] = fn;\n}\n/**\n * Those data types can be cloned:\n * Plain object, Array, TypedArray, number, string, null, undefined.\n * Those data types will be assgined using the orginal data:\n * BUILTIN_OBJECT\n * Instance of user defined class will be cloned to a plain object, without\n * properties in prototype.\n * Other data types is not supported (not sure what will happen).\n *\n * Caution: do not support clone Date, for performance consideration.\n * (There might be a large number of date in `series.data`).\n * So date should not be modified in and out of echarts.\n *\n * @param {*} source\n * @return {*} new\n */\n\n\nfunction clone(source) {\n if (source == null || typeof source !== 'object') {\n return source;\n }\n\n var result = source;\n var typeStr = objToString.call(source);\n\n if (typeStr === '[object Array]') {\n if (!isPrimitive(source)) {\n result = [];\n\n for (var i = 0, len = source.length; i < len; i++) {\n result[i] = clone(source[i]);\n }\n }\n } else if (TYPED_ARRAY[typeStr]) {\n if (!isPrimitive(source)) {\n var Ctor = source.constructor;\n\n if (source.constructor.from) {\n result = Ctor.from(source);\n } else {\n result = new Ctor(source.length);\n\n for (var i = 0, len = source.length; i < len; i++) {\n result[i] = clone(source[i]);\n }\n }\n }\n } else if (!BUILTIN_OBJECT[typeStr] && !isPrimitive(source) && !isDom(source)) {\n result = {};\n\n for (var key in source) {\n if (source.hasOwnProperty(key)) {\n result[key] = clone(source[key]);\n }\n }\n }\n\n return result;\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {*} target\n * @param {*} source\n * @param {boolean} [overwrite=false]\n */\n\n\nfunction merge(target, source, overwrite) {\n // We should escapse that source is string\n // and enter for ... in ...\n if (!isObject(source) || !isObject(target)) {\n return overwrite ? clone(source) : target;\n }\n\n for (var key in source) {\n if (source.hasOwnProperty(key)) {\n var targetProp = target[key];\n var sourceProp = source[key];\n\n if (isObject(sourceProp) && isObject(targetProp) && !isArray(sourceProp) && !isArray(targetProp) && !isDom(sourceProp) && !isDom(targetProp) && !isBuiltInObject(sourceProp) && !isBuiltInObject(targetProp) && !isPrimitive(sourceProp) && !isPrimitive(targetProp)) {\n // 如果需要递归覆盖,就递归调用merge\n merge(targetProp, sourceProp, overwrite);\n } else if (overwrite || !(key in target)) {\n // 否则只处理overwrite为true,或者在目标对象中没有此属性的情况\n // NOTE,在 target[key] 不存在的时候也是直接覆盖\n target[key] = clone(source[key], true);\n }\n }\n }\n\n return target;\n}\n/**\n * @param {Array} targetAndSources The first item is target, and the rests are source.\n * @param {boolean} [overwrite=false]\n * @return {*} target\n */\n\n\nfunction mergeAll(targetAndSources, overwrite) {\n var result = targetAndSources[0];\n\n for (var i = 1, len = targetAndSources.length; i < len; i++) {\n result = merge(result, targetAndSources[i], overwrite);\n }\n\n return result;\n}\n/**\n * @param {*} target\n * @param {*} source\n * @memberOf module:zrender/core/util\n */\n\n\nfunction extend(target, source) {\n for (var key in source) {\n if (source.hasOwnProperty(key)) {\n target[key] = source[key];\n }\n }\n\n return target;\n}\n/**\n * @param {*} target\n * @param {*} source\n * @param {boolean} [overlay=false]\n * @memberOf module:zrender/core/util\n */\n\n\nfunction defaults(target, source, overlay) {\n for (var key in source) {\n if (source.hasOwnProperty(key) && (overlay ? source[key] != null : target[key] == null)) {\n target[key] = source[key];\n }\n }\n\n return target;\n}\n\nvar createCanvas = function () {\n return methods.createCanvas();\n};\n\nmethods.createCanvas = function () {\n return document.createElement('canvas');\n}; // FIXME\n\n\nvar _ctx;\n\nfunction getContext() {\n if (!_ctx) {\n // Use util.createCanvas instead of createCanvas\n // because createCanvas may be overwritten in different environment\n _ctx = createCanvas().getContext('2d');\n }\n\n return _ctx;\n}\n/**\n * 查询数组中元素的index\n * @memberOf module:zrender/core/util\n */\n\n\nfunction indexOf(array, value) {\n if (array) {\n if (array.indexOf) {\n return array.indexOf(value);\n }\n\n for (var i = 0, len = array.length; i < len; i++) {\n if (array[i] === value) {\n return i;\n }\n }\n }\n\n return -1;\n}\n/**\n * 构造类继承关系\n *\n * @memberOf module:zrender/core/util\n * @param {Function} clazz 源类\n * @param {Function} baseClazz 基类\n */\n\n\nfunction inherits(clazz, baseClazz) {\n var clazzPrototype = clazz.prototype;\n\n function F() {}\n\n F.prototype = baseClazz.prototype;\n clazz.prototype = new F();\n\n for (var prop in clazzPrototype) {\n clazz.prototype[prop] = clazzPrototype[prop];\n }\n\n clazz.prototype.constructor = clazz;\n clazz.superClass = baseClazz;\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {Object|Function} target\n * @param {Object|Function} sorce\n * @param {boolean} overlay\n */\n\n\nfunction mixin(target, source, overlay) {\n target = 'prototype' in target ? target.prototype : target;\n source = 'prototype' in source ? source.prototype : source;\n defaults(target, source, overlay);\n}\n/**\n * Consider typed array.\n * @param {Array|TypedArray} data\n */\n\n\nfunction isArrayLike(data) {\n if (!data) {\n return;\n }\n\n if (typeof data === 'string') {\n return false;\n }\n\n return typeof data.length === 'number';\n}\n/**\n * 数组或对象遍历\n * @memberOf module:zrender/core/util\n * @param {Object|Array} obj\n * @param {Function} cb\n * @param {*} [context]\n */\n\n\nfunction each(obj, cb, context) {\n if (!(obj && cb)) {\n return;\n }\n\n if (obj.forEach && obj.forEach === nativeForEach) {\n obj.forEach(cb, context);\n } else if (obj.length === +obj.length) {\n for (var i = 0, len = obj.length; i < len; i++) {\n cb.call(context, obj[i], i, obj);\n }\n } else {\n for (var key in obj) {\n if (obj.hasOwnProperty(key)) {\n cb.call(context, obj[key], key, obj);\n }\n }\n }\n}\n/**\n * 数组映射\n * @memberOf module:zrender/core/util\n * @param {Array} obj\n * @param {Function} cb\n * @param {*} [context]\n * @return {Array}\n */\n\n\nfunction map(obj, cb, context) {\n if (!(obj && cb)) {\n return;\n }\n\n if (obj.map && obj.map === nativeMap) {\n return obj.map(cb, context);\n } else {\n var result = [];\n\n for (var i = 0, len = obj.length; i < len; i++) {\n result.push(cb.call(context, obj[i], i, obj));\n }\n\n return result;\n }\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {Array} obj\n * @param {Function} cb\n * @param {Object} [memo]\n * @param {*} [context]\n * @return {Array}\n */\n\n\nfunction reduce(obj, cb, memo, context) {\n if (!(obj && cb)) {\n return;\n }\n\n if (obj.reduce && obj.reduce === nativeReduce) {\n return obj.reduce(cb, memo, context);\n } else {\n for (var i = 0, len = obj.length; i < len; i++) {\n memo = cb.call(context, memo, obj[i], i, obj);\n }\n\n return memo;\n }\n}\n/**\n * 数组过滤\n * @memberOf module:zrender/core/util\n * @param {Array} obj\n * @param {Function} cb\n * @param {*} [context]\n * @return {Array}\n */\n\n\nfunction filter(obj, cb, context) {\n if (!(obj && cb)) {\n return;\n }\n\n if (obj.filter && obj.filter === nativeFilter) {\n return obj.filter(cb, context);\n } else {\n var result = [];\n\n for (var i = 0, len = obj.length; i < len; i++) {\n if (cb.call(context, obj[i], i, obj)) {\n result.push(obj[i]);\n }\n }\n\n return result;\n }\n}\n/**\n * 数组项查找\n * @memberOf module:zrender/core/util\n * @param {Array} obj\n * @param {Function} cb\n * @param {*} [context]\n * @return {*}\n */\n\n\nfunction find(obj, cb, context) {\n if (!(obj && cb)) {\n return;\n }\n\n for (var i = 0, len = obj.length; i < len; i++) {\n if (cb.call(context, obj[i], i, obj)) {\n return obj[i];\n }\n }\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {Function} func\n * @param {*} context\n * @return {Function}\n */\n\n\nfunction bind(func, context) {\n var args = nativeSlice.call(arguments, 2);\n return function () {\n return func.apply(context, args.concat(nativeSlice.call(arguments)));\n };\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {Function} func\n * @return {Function}\n */\n\n\nfunction curry(func) {\n var args = nativeSlice.call(arguments, 1);\n return function () {\n return func.apply(this, args.concat(nativeSlice.call(arguments)));\n };\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction isArray(value) {\n return objToString.call(value) === '[object Array]';\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction isFunction(value) {\n return typeof value === 'function';\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction isString(value) {\n return objToString.call(value) === '[object String]';\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction isObject(value) {\n // Avoid a V8 JIT bug in Chrome 19-20.\n // See https://code.google.com/p/v8/issues/detail?id=2291 for more details.\n var type = typeof value;\n return type === 'function' || !!value && type === 'object';\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction isBuiltInObject(value) {\n return !!BUILTIN_OBJECT[objToString.call(value)];\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction isTypedArray(value) {\n return !!TYPED_ARRAY[objToString.call(value)];\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction isDom(value) {\n return typeof value === 'object' && typeof value.nodeType === 'number' && typeof value.ownerDocument === 'object';\n}\n/**\n * Whether is exactly NaN. Notice isNaN('a') returns true.\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction eqNaN(value) {\n return value !== value;\n}\n/**\n * If value1 is not null, then return value1, otherwise judget rest of values.\n * Low performance.\n * @memberOf module:zrender/core/util\n * @return {*} Final value\n */\n\n\nfunction retrieve(values) {\n for (var i = 0, len = arguments.length; i < len; i++) {\n if (arguments[i] != null) {\n return arguments[i];\n }\n }\n}\n\nfunction retrieve2(value0, value1) {\n return value0 != null ? value0 : value1;\n}\n\nfunction retrieve3(value0, value1, value2) {\n return value0 != null ? value0 : value1 != null ? value1 : value2;\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {Array} arr\n * @param {number} startIndex\n * @param {number} endIndex\n * @return {Array}\n */\n\n\nfunction slice() {\n return Function.call.apply(nativeSlice, arguments);\n}\n/**\n * Normalize css liked array configuration\n * e.g.\n * 3 => [3, 3, 3, 3]\n * [4, 2] => [4, 2, 4, 2]\n * [4, 3, 2] => [4, 3, 2, 3]\n * @param {number|Array.<number>} val\n * @return {Array.<number>}\n */\n\n\nfunction normalizeCssArray(val) {\n if (typeof val === 'number') {\n return [val, val, val, val];\n }\n\n var len = val.length;\n\n if (len === 2) {\n // vertical | horizontal\n return [val[0], val[1], val[0], val[1]];\n } else if (len === 3) {\n // top | horizontal | bottom\n return [val[0], val[1], val[2], val[1]];\n }\n\n return val;\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {boolean} condition\n * @param {string} message\n */\n\n\nfunction assert(condition, message) {\n if (!condition) {\n throw new Error(message);\n }\n}\n/**\n * @memberOf module:zrender/core/util\n * @param {string} str string to be trimed\n * @return {string} trimed string\n */\n\n\nfunction trim(str) {\n if (str == null) {\n return null;\n } else if (typeof str.trim === 'function') {\n return str.trim();\n } else {\n return str.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '');\n }\n}\n\nvar primitiveKey = '__ec_primitive__';\n/**\n * Set an object as primitive to be ignored traversing children in clone or merge\n */\n\nfunction setAsPrimitive(obj) {\n obj[primitiveKey] = true;\n}\n\nfunction isPrimitive(obj) {\n return obj[primitiveKey];\n}\n/**\n * @constructor\n * @param {Object} obj Only apply `ownProperty`.\n */\n\n\nfunction HashMap(obj) {\n var isArr = isArray(obj); // Key should not be set on this, otherwise\n // methods get/set/... may be overrided.\n\n this.data = {};\n var thisMap = this;\n obj instanceof HashMap ? obj.each(visit) : obj && each(obj, visit);\n\n function visit(value, key) {\n isArr ? thisMap.set(value, key) : thisMap.set(key, value);\n }\n}\n\nHashMap.prototype = {\n constructor: HashMap,\n // Do not provide `has` method to avoid defining what is `has`.\n // (We usually treat `null` and `undefined` as the same, different\n // from ES6 Map).\n get: function (key) {\n return this.data.hasOwnProperty(key) ? this.data[key] : null;\n },\n set: function (key, value) {\n // Comparing with invocation chaining, `return value` is more commonly\n // used in this case: `var someVal = map.set('a', genVal());`\n return this.data[key] = value;\n },\n // Although util.each can be performed on this hashMap directly, user\n // should not use the exposed keys, who are prefixed.\n each: function (cb, context) {\n context !== void 0 && (cb = bind(cb, context));\n\n for (var key in this.data) {\n this.data.hasOwnProperty(key) && cb(this.data[key], key);\n }\n },\n // Do not use this method if performance sensitive.\n removeKey: function (key) {\n delete this.data[key];\n }\n};\n\nfunction createHashMap(obj) {\n return new HashMap(obj);\n}\n\nfunction concatArray(a, b) {\n var newArray = new a.constructor(a.length + b.length);\n\n for (var i = 0; i < a.length; i++) {\n newArray[i] = a[i];\n }\n\n var offset = a.length;\n\n for (i = 0; i < b.length; i++) {\n newArray[i + offset] = b[i];\n }\n\n return newArray;\n}\n\nfunction noop() {}\n\nexports.$override = $override;\nexports.clone = clone;\nexports.merge = merge;\nexports.mergeAll = mergeAll;\nexports.extend = extend;\nexports.defaults = defaults;\nexports.createCanvas = createCanvas;\nexports.getContext = getContext;\nexports.indexOf = indexOf;\nexports.inherits = inherits;\nexports.mixin = mixin;\nexports.isArrayLike = isArrayLike;\nexports.each = each;\nexports.map = map;\nexports.reduce = reduce;\nexports.filter = filter;\nexports.find = find;\nexports.bind = bind;\nexports.curry = curry;\nexports.isArray = isArray;\nexports.isFunction = isFunction;\nexports.isString = isString;\nexports.isObject = isObject;\nexports.isBuiltInObject = isBuiltInObject;\nexports.isTypedArray = isTypedArray;\nexports.isDom = isDom;\nexports.eqNaN = eqNaN;\nexports.retrieve = retrieve;\nexports.retrieve2 = retrieve2;\nexports.retrieve3 = retrieve3;\nexports.slice = slice;\nexports.normalizeCssArray = normalizeCssArray;\nexports.assert = assert;\nexports.trim = trim;\nexports.setAsPrimitive = setAsPrimitive;\nexports.isPrimitive = isPrimitive;\nexports.createHashMap = createHashMap;\nexports.concatArray = concatArray;\nexports.noop = noop;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar defaultOption = {\n show: true,\n zlevel: 0,\n z: 0,\n // Inverse the axis.\n inverse: false,\n // Axis name displayed.\n name: '',\n // 'start' | 'middle' | 'end'\n nameLocation: 'end',\n // By degree. By defualt auto rotate by nameLocation.\n nameRotate: null,\n nameTruncate: {\n maxWidth: null,\n ellipsis: '...',\n placeholder: '.'\n },\n // Use global text style by default.\n nameTextStyle: {},\n // The gap between axisName and axisLine.\n nameGap: 15,\n // Default `false` to support tooltip.\n silent: false,\n // Default `false` to avoid legacy user event listener fail.\n triggerEvent: false,\n tooltip: {\n show: false\n },\n axisPointer: {},\n axisLine: {\n show: true,\n onZero: true,\n onZeroAxisIndex: null,\n lineStyle: {\n color: '#333',\n width: 1,\n type: 'solid'\n },\n // The arrow at both ends the the axis.\n symbol: ['none', 'none'],\n symbolSize: [10, 15]\n },\n axisTick: {\n show: true,\n // Whether axisTick is inside the grid or outside the grid.\n inside: false,\n // The length of axisTick.\n length: 5,\n lineStyle: {\n width: 1\n }\n },\n axisLabel: {\n show: true,\n // Whether axisLabel is inside the grid or outside the grid.\n inside: false,\n rotate: 0,\n // true | false | null/undefined (auto)\n showMinLabel: null,\n // true | false | null/undefined (auto)\n showMaxLabel: null,\n margin: 8,\n // formatter: null,\n fontSize: 12\n },\n splitLine: {\n show: true,\n lineStyle: {\n color: ['#ccc'],\n width: 1,\n type: 'solid'\n }\n },\n splitArea: {\n show: false,\n areaStyle: {\n color: ['rgba(250,250,250,0.3)', 'rgba(200,200,200,0.3)']\n }\n }\n};\nvar axisDefault = {};\naxisDefault.categoryAxis = zrUtil.merge({\n // The gap at both ends of the axis. For categoryAxis, boolean.\n boundaryGap: true,\n // Set false to faster category collection.\n // Only usefull in the case like: category is\n // ['2012-01-01', '2012-01-02', ...], where the input\n // data has been ensured not duplicate and is large data.\n // null means \"auto\":\n // if axis.data provided, do not deduplication,\n // else do deduplication.\n deduplication: null,\n // splitArea: {\n // show: false\n // },\n splitLine: {\n show: false\n },\n axisTick: {\n // If tick is align with label when boundaryGap is true\n alignWithLabel: false,\n interval: 'auto'\n },\n axisLabel: {\n interval: 'auto'\n }\n}, defaultOption);\naxisDefault.valueAxis = zrUtil.merge({\n // The gap at both ends of the axis. For value axis, [GAP, GAP], where\n // `GAP` can be an absolute pixel number (like `35`), or percent (like `'30%'`)\n boundaryGap: [0, 0],\n // TODO\n // min/max: [30, datamin, 60] or [20, datamin] or [datamin, 60]\n // Min value of the axis. can be:\n // + a number\n // + 'dataMin': use the min value in data.\n // + null/undefined: auto decide min value (consider pretty look and boundaryGap).\n // min: null,\n // Max value of the axis. can be:\n // + a number\n // + 'dataMax': use the max value in data.\n // + null/undefined: auto decide max value (consider pretty look and boundaryGap).\n // max: null,\n // Readonly prop, specifies start value of the range when using data zoom.\n // rangeStart: null\n // Readonly prop, specifies end value of the range when using data zoom.\n // rangeEnd: null\n // Optional value can be:\n // + `false`: always include value 0.\n // + `true`: the extent do not consider value 0.\n // scale: false,\n // AxisTick and axisLabel and splitLine are caculated based on splitNumber.\n splitNumber: 5 // Interval specifies the span of the ticks is mandatorily.\n // interval: null\n // Specify min interval when auto calculate tick interval.\n // minInterval: null\n // Specify max interval when auto calculate tick interval.\n // maxInterval: null\n\n}, defaultOption);\naxisDefault.timeAxis = zrUtil.defaults({\n scale: true,\n min: 'dataMin',\n max: 'dataMax'\n}, axisDefault.valueAxis);\naxisDefault.logAxis = zrUtil.defaults({\n scale: true,\n logBase: 10\n}, axisDefault.valueAxis);\nvar _default = axisDefault;\nmodule.exports = _default;","/**\n * 缓动代码来自 https://github.com/sole/tween.js/blob/master/src/Tween.js\n * @see http://sole.github.io/tween.js/examples/03_graphs.html\n * @exports zrender/animation/easing\n */\nvar easing = {\n /**\n * @param {number} k\n * @return {number}\n */\n linear: function (k) {\n return k;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n quadraticIn: function (k) {\n return k * k;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n quadraticOut: function (k) {\n return k * (2 - k);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n quadraticInOut: function (k) {\n if ((k *= 2) < 1) {\n return 0.5 * k * k;\n }\n\n return -0.5 * (--k * (k - 2) - 1);\n },\n // 三次方的缓动(t^3)\n\n /**\n * @param {number} k\n * @return {number}\n */\n cubicIn: function (k) {\n return k * k * k;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n cubicOut: function (k) {\n return --k * k * k + 1;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n cubicInOut: function (k) {\n if ((k *= 2) < 1) {\n return 0.5 * k * k * k;\n }\n\n return 0.5 * ((k -= 2) * k * k + 2);\n },\n // 四次方的缓动(t^4)\n\n /**\n * @param {number} k\n * @return {number}\n */\n quarticIn: function (k) {\n return k * k * k * k;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n quarticOut: function (k) {\n return 1 - --k * k * k * k;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n quarticInOut: function (k) {\n if ((k *= 2) < 1) {\n return 0.5 * k * k * k * k;\n }\n\n return -0.5 * ((k -= 2) * k * k * k - 2);\n },\n // 五次方的缓动(t^5)\n\n /**\n * @param {number} k\n * @return {number}\n */\n quinticIn: function (k) {\n return k * k * k * k * k;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n quinticOut: function (k) {\n return --k * k * k * k * k + 1;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n quinticInOut: function (k) {\n if ((k *= 2) < 1) {\n return 0.5 * k * k * k * k * k;\n }\n\n return 0.5 * ((k -= 2) * k * k * k * k + 2);\n },\n // 正弦曲线的缓动(sin(t))\n\n /**\n * @param {number} k\n * @return {number}\n */\n sinusoidalIn: function (k) {\n return 1 - Math.cos(k * Math.PI / 2);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n sinusoidalOut: function (k) {\n return Math.sin(k * Math.PI / 2);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n sinusoidalInOut: function (k) {\n return 0.5 * (1 - Math.cos(Math.PI * k));\n },\n // 指数曲线的缓动(2^t)\n\n /**\n * @param {number} k\n * @return {number}\n */\n exponentialIn: function (k) {\n return k === 0 ? 0 : Math.pow(1024, k - 1);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n exponentialOut: function (k) {\n return k === 1 ? 1 : 1 - Math.pow(2, -10 * k);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n exponentialInOut: function (k) {\n if (k === 0) {\n return 0;\n }\n\n if (k === 1) {\n return 1;\n }\n\n if ((k *= 2) < 1) {\n return 0.5 * Math.pow(1024, k - 1);\n }\n\n return 0.5 * (-Math.pow(2, -10 * (k - 1)) + 2);\n },\n // 圆形曲线的缓动(sqrt(1-t^2))\n\n /**\n * @param {number} k\n * @return {number}\n */\n circularIn: function (k) {\n return 1 - Math.sqrt(1 - k * k);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n circularOut: function (k) {\n return Math.sqrt(1 - --k * k);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n circularInOut: function (k) {\n if ((k *= 2) < 1) {\n return -0.5 * (Math.sqrt(1 - k * k) - 1);\n }\n\n return 0.5 * (Math.sqrt(1 - (k -= 2) * k) + 1);\n },\n // 创建类似于弹簧在停止前来回振荡的动画\n\n /**\n * @param {number} k\n * @return {number}\n */\n elasticIn: function (k) {\n var s;\n var a = 0.1;\n var p = 0.4;\n\n if (k === 0) {\n return 0;\n }\n\n if (k === 1) {\n return 1;\n }\n\n if (!a || a < 1) {\n a = 1;\n s = p / 4;\n } else {\n s = p * Math.asin(1 / a) / (2 * Math.PI);\n }\n\n return -(a * Math.pow(2, 10 * (k -= 1)) * Math.sin((k - s) * (2 * Math.PI) / p));\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n elasticOut: function (k) {\n var s;\n var a = 0.1;\n var p = 0.4;\n\n if (k === 0) {\n return 0;\n }\n\n if (k === 1) {\n return 1;\n }\n\n if (!a || a < 1) {\n a = 1;\n s = p / 4;\n } else {\n s = p * Math.asin(1 / a) / (2 * Math.PI);\n }\n\n return a * Math.pow(2, -10 * k) * Math.sin((k - s) * (2 * Math.PI) / p) + 1;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n elasticInOut: function (k) {\n var s;\n var a = 0.1;\n var p = 0.4;\n\n if (k === 0) {\n return 0;\n }\n\n if (k === 1) {\n return 1;\n }\n\n if (!a || a < 1) {\n a = 1;\n s = p / 4;\n } else {\n s = p * Math.asin(1 / a) / (2 * Math.PI);\n }\n\n if ((k *= 2) < 1) {\n return -0.5 * (a * Math.pow(2, 10 * (k -= 1)) * Math.sin((k - s) * (2 * Math.PI) / p));\n }\n\n return a * Math.pow(2, -10 * (k -= 1)) * Math.sin((k - s) * (2 * Math.PI) / p) * 0.5 + 1;\n },\n // 在某一动画开始沿指示的路径进行动画处理前稍稍收回该动画的移动\n\n /**\n * @param {number} k\n * @return {number}\n */\n backIn: function (k) {\n var s = 1.70158;\n return k * k * ((s + 1) * k - s);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n backOut: function (k) {\n var s = 1.70158;\n return --k * k * ((s + 1) * k + s) + 1;\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n backInOut: function (k) {\n var s = 1.70158 * 1.525;\n\n if ((k *= 2) < 1) {\n return 0.5 * (k * k * ((s + 1) * k - s));\n }\n\n return 0.5 * ((k -= 2) * k * ((s + 1) * k + s) + 2);\n },\n // 创建弹跳效果\n\n /**\n * @param {number} k\n * @return {number}\n */\n bounceIn: function (k) {\n return 1 - easing.bounceOut(1 - k);\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n bounceOut: function (k) {\n if (k < 1 / 2.75) {\n return 7.5625 * k * k;\n } else if (k < 2 / 2.75) {\n return 7.5625 * (k -= 1.5 / 2.75) * k + 0.75;\n } else if (k < 2.5 / 2.75) {\n return 7.5625 * (k -= 2.25 / 2.75) * k + 0.9375;\n } else {\n return 7.5625 * (k -= 2.625 / 2.75) * k + 0.984375;\n }\n },\n\n /**\n * @param {number} k\n * @return {number}\n */\n bounceInOut: function (k) {\n if (k < 0.5) {\n return easing.bounceIn(k * 2) * 0.5;\n }\n\n return easing.bounceOut(k * 2 - 1) * 0.5 + 0.5;\n }\n};\nvar _default = easing;\nmodule.exports = _default;","'use strict';\n// 22.1.3.8 Array.prototype.find(predicate, thisArg = undefined)\nvar $export = require('./_export');\nvar $find = require('./_array-methods')(5);\nvar KEY = 'find';\nvar forced = true;\n// Shouldn't skip holes\nif (KEY in []) Array(1)[KEY](function () { forced = false; });\n$export($export.P + $export.F * forced, 'Array', {\n find: function find(callbackfn /* , that = undefined */) {\n return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\nrequire('./_add-to-unscopables')(KEY);\n","var Displayable = require(\"./Displayable\");\n\nvar zrUtil = require(\"../core/util\");\n\nvar textContain = require(\"../contain/text\");\n\nvar textHelper = require(\"./helper/text\");\n\nvar _constant = require(\"./constant\");\n\nvar ContextCachedBy = _constant.ContextCachedBy;\n\n/**\n * @alias zrender/graphic/Text\n * @extends module:zrender/graphic/Displayable\n * @constructor\n * @param {Object} opts\n */\nvar Text = function (opts) {\n // jshint ignore:line\n Displayable.call(this, opts);\n};\n\nText.prototype = {\n constructor: Text,\n type: 'text',\n brush: function (ctx, prevEl) {\n var style = this.style; // Optimize, avoid normalize every time.\n\n this.__dirty && textHelper.normalizeTextStyle(style, true); // Use props with prefix 'text'.\n\n style.fill = style.stroke = style.shadowBlur = style.shadowColor = style.shadowOffsetX = style.shadowOffsetY = null;\n var text = style.text; // Convert to string\n\n text != null && (text += ''); // Do not apply style.bind in Text node. Because the real bind job\n // is in textHelper.renderText, and performance of text render should\n // be considered.\n // style.bind(ctx, this, prevEl);\n\n if (!textHelper.needDrawText(text, style)) {\n // The current el.style is not applied\n // and should not be used as cache.\n ctx.__attrCachedBy = ContextCachedBy.NONE;\n return;\n }\n\n this.setTransform(ctx);\n textHelper.renderText(this, ctx, text, style, null, prevEl);\n this.restoreTransform(ctx);\n },\n getBoundingRect: function () {\n var style = this.style; // Optimize, avoid normalize every time.\n\n this.__dirty && textHelper.normalizeTextStyle(style, true);\n\n if (!this._rect) {\n var text = style.text;\n text != null ? text += '' : text = '';\n var rect = textContain.getBoundingRect(style.text + '', style.font, style.textAlign, style.textVerticalAlign, style.textPadding, style.textLineHeight, style.rich);\n rect.x += style.x || 0;\n rect.y += style.y || 0;\n\n if (textHelper.getStroke(style.textStroke, style.textStrokeWidth)) {\n var w = style.textStrokeWidth;\n rect.x -= w / 2;\n rect.y -= w / 2;\n rect.width += w;\n rect.height += w;\n }\n\n this._rect = rect;\n }\n\n return this._rect;\n }\n};\nzrUtil.inherits(Text, Displayable);\nvar _default = Text;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar echarts = require(\"../../echarts\");\n\nrequire(\"./AxisModel\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar _default = echarts.extendComponentModel({\n type: 'polar',\n dependencies: ['polarAxis', 'angleAxis'],\n\n /**\n * @type {module:echarts/coord/polar/Polar}\n */\n coordinateSystem: null,\n\n /**\n * @param {string} axisType\n * @return {module:echarts/coord/polar/AxisModel}\n */\n findAxisModel: function (axisType) {\n var foundAxisModel;\n var ecModel = this.ecModel;\n ecModel.eachComponent(axisType, function (axisModel) {\n if (axisModel.getCoordSysModel() === this) {\n foundAxisModel = axisModel;\n }\n }, this);\n return foundAxisModel;\n },\n defaultOption: {\n zlevel: 0,\n z: 0,\n center: ['50%', '50%'],\n radius: '80%'\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nrequire(\"../coord/polar/polarCreator\");\n\nrequire(\"./axis/RadiusAxisView\");","var SHADOW_PROPS = {\n 'shadowBlur': 1,\n 'shadowOffsetX': 1,\n 'shadowOffsetY': 1,\n 'textShadowBlur': 1,\n 'textShadowOffsetX': 1,\n 'textShadowOffsetY': 1,\n 'textBoxShadowBlur': 1,\n 'textBoxShadowOffsetX': 1,\n 'textBoxShadowOffsetY': 1\n};\n\nfunction _default(ctx, propName, value) {\n if (SHADOW_PROPS.hasOwnProperty(propName)) {\n return value *= ctx.dpr;\n }\n\n return value;\n}\n\nmodule.exports = _default;","var anObject = require('./_an-object');\nvar get = require('./core.get-iterator-method');\nmodule.exports = require('./_core').getIterator = function (it) {\n var iterFn = get(it);\n if (typeof iterFn != 'function') throw TypeError(it + ' is not iterable!');\n return anObject(iterFn.call(it));\n};\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar each = _util.each;\nvar filter = _util.filter;\nvar map = _util.map;\nvar isArray = _util.isArray;\nvar indexOf = _util.indexOf;\nvar isObject = _util.isObject;\nvar isString = _util.isString;\nvar createHashMap = _util.createHashMap;\nvar assert = _util.assert;\nvar clone = _util.clone;\nvar merge = _util.merge;\nvar extend = _util.extend;\nvar mixin = _util.mixin;\n\nvar modelUtil = require(\"../util/model\");\n\nvar Model = require(\"./Model\");\n\nvar ComponentModel = require(\"./Component\");\n\nvar globalDefault = require(\"./globalDefault\");\n\nvar colorPaletteMixin = require(\"./mixin/colorPalette\");\n\nvar _sourceHelper = require(\"../data/helper/sourceHelper\");\n\nvar resetSourceDefaulter = _sourceHelper.resetSourceDefaulter;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * ECharts global model\n *\n * @module {echarts/model/Global}\n */\n\n/**\n * Caution: If the mechanism should be changed some day, these cases\n * should be considered:\n *\n * (1) In `merge option` mode, if using the same option to call `setOption`\n * many times, the result should be the same (try our best to ensure that).\n * (2) In `merge option` mode, if a component has no id/name specified, it\n * will be merged by index, and the result sequence of the components is\n * consistent to the original sequence.\n * (3) `reset` feature (in toolbox). Find detailed info in comments about\n * `mergeOption` in module:echarts/model/OptionManager.\n */\nvar OPTION_INNER_KEY = '\\0_ec_inner';\n/**\n * @alias module:echarts/model/Global\n *\n * @param {Object} option\n * @param {module:echarts/model/Model} parentModel\n * @param {Object} theme\n */\n\nvar GlobalModel = Model.extend({\n init: function (option, parentModel, theme, optionManager) {\n theme = theme || {};\n this.option = null; // Mark as not initialized.\n\n /**\n * @type {module:echarts/model/Model}\n * @private\n */\n\n this._theme = new Model(theme);\n /**\n * @type {module:echarts/model/OptionManager}\n */\n\n this._optionManager = optionManager;\n },\n setOption: function (option, optionPreprocessorFuncs) {\n assert(!(OPTION_INNER_KEY in option), 'please use chart.getOption()');\n\n this._optionManager.setOption(option, optionPreprocessorFuncs);\n\n this.resetOption(null);\n },\n\n /**\n * @param {string} type null/undefined: reset all.\n * 'recreate': force recreate all.\n * 'timeline': only reset timeline option\n * 'media': only reset media query option\n * @return {boolean} Whether option changed.\n */\n resetOption: function (type) {\n var optionChanged = false;\n var optionManager = this._optionManager;\n\n if (!type || type === 'recreate') {\n var baseOption = optionManager.mountOption(type === 'recreate');\n\n if (!this.option || type === 'recreate') {\n initBase.call(this, baseOption);\n } else {\n this.restoreData();\n this.mergeOption(baseOption);\n }\n\n optionChanged = true;\n }\n\n if (type === 'timeline' || type === 'media') {\n this.restoreData();\n }\n\n if (!type || type === 'recreate' || type === 'timeline') {\n var timelineOption = optionManager.getTimelineOption(this);\n timelineOption && (this.mergeOption(timelineOption), optionChanged = true);\n }\n\n if (!type || type === 'recreate' || type === 'media') {\n var mediaOptions = optionManager.getMediaOption(this, this._api);\n\n if (mediaOptions.length) {\n each(mediaOptions, function (mediaOption) {\n this.mergeOption(mediaOption, optionChanged = true);\n }, this);\n }\n }\n\n return optionChanged;\n },\n\n /**\n * @protected\n */\n mergeOption: function (newOption) {\n var option = this.option;\n var componentsMap = this._componentsMap;\n var newCptTypes = [];\n resetSourceDefaulter(this); // If no component class, merge directly.\n // For example: color, animaiton options, etc.\n\n each(newOption, function (componentOption, mainType) {\n if (componentOption == null) {\n return;\n }\n\n if (!ComponentModel.hasClass(mainType)) {\n // globalSettingTask.dirty();\n option[mainType] = option[mainType] == null ? clone(componentOption) : merge(option[mainType], componentOption, true);\n } else if (mainType) {\n newCptTypes.push(mainType);\n }\n });\n ComponentModel.topologicalTravel(newCptTypes, ComponentModel.getAllClassMainTypes(), visitComponent, this);\n\n function visitComponent(mainType, dependencies) {\n var newCptOptionList = modelUtil.normalizeToArray(newOption[mainType]);\n var mapResult = modelUtil.mappingToExists(componentsMap.get(mainType), newCptOptionList);\n modelUtil.makeIdAndName(mapResult); // Set mainType and complete subType.\n\n each(mapResult, function (item, index) {\n var opt = item.option;\n\n if (isObject(opt)) {\n item.keyInfo.mainType = mainType;\n item.keyInfo.subType = determineSubType(mainType, opt, item.exist);\n }\n });\n var dependentModels = getComponentsByTypes(componentsMap, dependencies);\n option[mainType] = [];\n componentsMap.set(mainType, []);\n each(mapResult, function (resultItem, index) {\n var componentModel = resultItem.exist;\n var newCptOption = resultItem.option;\n assert(isObject(newCptOption) || componentModel, 'Empty component definition'); // Consider where is no new option and should be merged using {},\n // see removeEdgeAndAdd in topologicalTravel and\n // ComponentModel.getAllClassMainTypes.\n\n if (!newCptOption) {\n componentModel.mergeOption({}, this);\n componentModel.optionUpdated({}, false);\n } else {\n var ComponentModelClass = ComponentModel.getClass(mainType, resultItem.keyInfo.subType, true);\n\n if (componentModel && componentModel instanceof ComponentModelClass) {\n componentModel.name = resultItem.keyInfo.name; // componentModel.settingTask && componentModel.settingTask.dirty();\n\n componentModel.mergeOption(newCptOption, this);\n componentModel.optionUpdated(newCptOption, false);\n } else {\n // PENDING Global as parent ?\n var extraOpt = extend({\n dependentModels: dependentModels,\n componentIndex: index\n }, resultItem.keyInfo);\n componentModel = new ComponentModelClass(newCptOption, this, this, extraOpt);\n extend(componentModel, extraOpt);\n componentModel.init(newCptOption, this, this, extraOpt); // Call optionUpdated after init.\n // newCptOption has been used as componentModel.option\n // and may be merged with theme and default, so pass null\n // to avoid confusion.\n\n componentModel.optionUpdated(null, true);\n }\n }\n\n componentsMap.get(mainType)[index] = componentModel;\n option[mainType][index] = componentModel.option;\n }, this); // Backup series for filtering.\n\n if (mainType === 'series') {\n createSeriesIndices(this, componentsMap.get('series'));\n }\n }\n\n this._seriesIndicesMap = createHashMap(this._seriesIndices = this._seriesIndices || []);\n },\n\n /**\n * Get option for output (cloned option and inner info removed)\n * @public\n * @return {Object}\n */\n getOption: function () {\n var option = clone(this.option);\n each(option, function (opts, mainType) {\n if (ComponentModel.hasClass(mainType)) {\n var opts = modelUtil.normalizeToArray(opts);\n\n for (var i = opts.length - 1; i >= 0; i--) {\n // Remove options with inner id.\n if (modelUtil.isIdInner(opts[i])) {\n opts.splice(i, 1);\n }\n }\n\n option[mainType] = opts;\n }\n });\n delete option[OPTION_INNER_KEY];\n return option;\n },\n\n /**\n * @return {module:echarts/model/Model}\n */\n getTheme: function () {\n return this._theme;\n },\n\n /**\n * @param {string} mainType\n * @param {number} [idx=0]\n * @return {module:echarts/model/Component}\n */\n getComponent: function (mainType, idx) {\n var list = this._componentsMap.get(mainType);\n\n if (list) {\n return list[idx || 0];\n }\n },\n\n /**\n * If none of index and id and name used, return all components with mainType.\n * @param {Object} condition\n * @param {string} condition.mainType\n * @param {string} [condition.subType] If ignore, only query by mainType\n * @param {number|Array.<number>} [condition.index] Either input index or id or name.\n * @param {string|Array.<string>} [condition.id] Either input index or id or name.\n * @param {string|Array.<string>} [condition.name] Either input index or id or name.\n * @return {Array.<module:echarts/model/Component>}\n */\n queryComponents: function (condition) {\n var mainType = condition.mainType;\n\n if (!mainType) {\n return [];\n }\n\n var index = condition.index;\n var id = condition.id;\n var name = condition.name;\n\n var cpts = this._componentsMap.get(mainType);\n\n if (!cpts || !cpts.length) {\n return [];\n }\n\n var result;\n\n if (index != null) {\n if (!isArray(index)) {\n index = [index];\n }\n\n result = filter(map(index, function (idx) {\n return cpts[idx];\n }), function (val) {\n return !!val;\n });\n } else if (id != null) {\n var isIdArray = isArray(id);\n result = filter(cpts, function (cpt) {\n return isIdArray && indexOf(id, cpt.id) >= 0 || !isIdArray && cpt.id === id;\n });\n } else if (name != null) {\n var isNameArray = isArray(name);\n result = filter(cpts, function (cpt) {\n return isNameArray && indexOf(name, cpt.name) >= 0 || !isNameArray && cpt.name === name;\n });\n } else {\n // Return all components with mainType\n result = cpts.slice();\n }\n\n return filterBySubType(result, condition);\n },\n\n /**\n * The interface is different from queryComponents,\n * which is convenient for inner usage.\n *\n * @usage\n * var result = findComponents(\n * {mainType: 'dataZoom', query: {dataZoomId: 'abc'}}\n * );\n * var result = findComponents(\n * {mainType: 'series', subType: 'pie', query: {seriesName: 'uio'}}\n * );\n * var result = findComponents(\n * {mainType: 'series'},\n * function (model, index) {...}\n * );\n * // result like [component0, componnet1, ...]\n *\n * @param {Object} condition\n * @param {string} condition.mainType Mandatory.\n * @param {string} [condition.subType] Optional.\n * @param {Object} [condition.query] like {xxxIndex, xxxId, xxxName},\n * where xxx is mainType.\n * If query attribute is null/undefined or has no index/id/name,\n * do not filtering by query conditions, which is convenient for\n * no-payload situations or when target of action is global.\n * @param {Function} [condition.filter] parameter: component, return boolean.\n * @return {Array.<module:echarts/model/Component>}\n */\n findComponents: function (condition) {\n var query = condition.query;\n var mainType = condition.mainType;\n var queryCond = getQueryCond(query);\n var result = queryCond ? this.queryComponents(queryCond) : this._componentsMap.get(mainType);\n return doFilter(filterBySubType(result, condition));\n\n function getQueryCond(q) {\n var indexAttr = mainType + 'Index';\n var idAttr = mainType + 'Id';\n var nameAttr = mainType + 'Name';\n return q && (q[indexAttr] != null || q[idAttr] != null || q[nameAttr] != null) ? {\n mainType: mainType,\n // subType will be filtered finally.\n index: q[indexAttr],\n id: q[idAttr],\n name: q[nameAttr]\n } : null;\n }\n\n function doFilter(res) {\n return condition.filter ? filter(res, condition.filter) : res;\n }\n },\n\n /**\n * @usage\n * eachComponent('legend', function (legendModel, index) {\n * ...\n * });\n * eachComponent(function (componentType, model, index) {\n * // componentType does not include subType\n * // (componentType is 'xxx' but not 'xxx.aa')\n * });\n * eachComponent(\n * {mainType: 'dataZoom', query: {dataZoomId: 'abc'}},\n * function (model, index) {...}\n * );\n * eachComponent(\n * {mainType: 'series', subType: 'pie', query: {seriesName: 'uio'}},\n * function (model, index) {...}\n * );\n *\n * @param {string|Object=} mainType When mainType is object, the definition\n * is the same as the method 'findComponents'.\n * @param {Function} cb\n * @param {*} context\n */\n eachComponent: function (mainType, cb, context) {\n var componentsMap = this._componentsMap;\n\n if (typeof mainType === 'function') {\n context = cb;\n cb = mainType;\n componentsMap.each(function (components, componentType) {\n each(components, function (component, index) {\n cb.call(context, componentType, component, index);\n });\n });\n } else if (isString(mainType)) {\n each(componentsMap.get(mainType), cb, context);\n } else if (isObject(mainType)) {\n var queryResult = this.findComponents(mainType);\n each(queryResult, cb, context);\n }\n },\n\n /**\n * @param {string} name\n * @return {Array.<module:echarts/model/Series>}\n */\n getSeriesByName: function (name) {\n var series = this._componentsMap.get('series');\n\n return filter(series, function (oneSeries) {\n return oneSeries.name === name;\n });\n },\n\n /**\n * @param {number} seriesIndex\n * @return {module:echarts/model/Series}\n */\n getSeriesByIndex: function (seriesIndex) {\n return this._componentsMap.get('series')[seriesIndex];\n },\n\n /**\n * Get series list before filtered by type.\n * FIXME: rename to getRawSeriesByType?\n *\n * @param {string} subType\n * @return {Array.<module:echarts/model/Series>}\n */\n getSeriesByType: function (subType) {\n var series = this._componentsMap.get('series');\n\n return filter(series, function (oneSeries) {\n return oneSeries.subType === subType;\n });\n },\n\n /**\n * @return {Array.<module:echarts/model/Series>}\n */\n getSeries: function () {\n return this._componentsMap.get('series').slice();\n },\n\n /**\n * @return {number}\n */\n getSeriesCount: function () {\n return this._componentsMap.get('series').length;\n },\n\n /**\n * After filtering, series may be different\n * frome raw series.\n *\n * @param {Function} cb\n * @param {*} context\n */\n eachSeries: function (cb, context) {\n assertSeriesInitialized(this);\n each(this._seriesIndices, function (rawSeriesIndex) {\n var series = this._componentsMap.get('series')[rawSeriesIndex];\n\n cb.call(context, series, rawSeriesIndex);\n }, this);\n },\n\n /**\n * Iterate raw series before filtered.\n *\n * @param {Function} cb\n * @param {*} context\n */\n eachRawSeries: function (cb, context) {\n each(this._componentsMap.get('series'), cb, context);\n },\n\n /**\n * After filtering, series may be different.\n * frome raw series.\n *\n * @parma {string} subType\n * @param {Function} cb\n * @param {*} context\n */\n eachSeriesByType: function (subType, cb, context) {\n assertSeriesInitialized(this);\n each(this._seriesIndices, function (rawSeriesIndex) {\n var series = this._componentsMap.get('series')[rawSeriesIndex];\n\n if (series.subType === subType) {\n cb.call(context, series, rawSeriesIndex);\n }\n }, this);\n },\n\n /**\n * Iterate raw series before filtered of given type.\n *\n * @parma {string} subType\n * @param {Function} cb\n * @param {*} context\n */\n eachRawSeriesByType: function (subType, cb, context) {\n return each(this.getSeriesByType(subType), cb, context);\n },\n\n /**\n * @param {module:echarts/model/Series} seriesModel\n */\n isSeriesFiltered: function (seriesModel) {\n assertSeriesInitialized(this);\n return this._seriesIndicesMap.get(seriesModel.componentIndex) == null;\n },\n\n /**\n * @return {Array.<number>}\n */\n getCurrentSeriesIndices: function () {\n return (this._seriesIndices || []).slice();\n },\n\n /**\n * @param {Function} cb\n * @param {*} context\n */\n filterSeries: function (cb, context) {\n assertSeriesInitialized(this);\n var filteredSeries = filter(this._componentsMap.get('series'), cb, context);\n createSeriesIndices(this, filteredSeries);\n },\n restoreData: function (payload) {\n var componentsMap = this._componentsMap;\n createSeriesIndices(this, componentsMap.get('series'));\n var componentTypes = [];\n componentsMap.each(function (components, componentType) {\n componentTypes.push(componentType);\n });\n ComponentModel.topologicalTravel(componentTypes, ComponentModel.getAllClassMainTypes(), function (componentType, dependencies) {\n each(componentsMap.get(componentType), function (component) {\n (componentType !== 'series' || !isNotTargetSeries(component, payload)) && component.restoreData();\n });\n });\n }\n});\n\nfunction isNotTargetSeries(seriesModel, payload) {\n if (payload) {\n var index = payload.seiresIndex;\n var id = payload.seriesId;\n var name = payload.seriesName;\n return index != null && seriesModel.componentIndex !== index || id != null && seriesModel.id !== id || name != null && seriesModel.name !== name;\n }\n}\n/**\n * @inner\n */\n\n\nfunction mergeTheme(option, theme) {\n // PENDING\n // NOT use `colorLayer` in theme if option has `color`\n var notMergeColorLayer = option.color && !option.colorLayer;\n each(theme, function (themeItem, name) {\n if (name === 'colorLayer' && notMergeColorLayer) {\n return;\n } // 如果有 component model 则把具体的 merge 逻辑交给该 model 处理\n\n\n if (!ComponentModel.hasClass(name)) {\n if (typeof themeItem === 'object') {\n option[name] = !option[name] ? clone(themeItem) : merge(option[name], themeItem, false);\n } else {\n if (option[name] == null) {\n option[name] = themeItem;\n }\n }\n }\n });\n}\n\nfunction initBase(baseOption) {\n baseOption = baseOption; // Using OPTION_INNER_KEY to mark that this option can not be used outside,\n // i.e. `chart.setOption(chart.getModel().option);` is forbiden.\n\n this.option = {};\n this.option[OPTION_INNER_KEY] = 1;\n /**\n * Init with series: [], in case of calling findSeries method\n * before series initialized.\n * @type {Object.<string, Array.<module:echarts/model/Model>>}\n * @private\n */\n\n this._componentsMap = createHashMap({\n series: []\n });\n /**\n * Mapping between filtered series list and raw series list.\n * key: filtered series indices, value: raw series indices.\n * @type {Array.<nubmer>}\n * @private\n */\n\n this._seriesIndices;\n this._seriesIndicesMap;\n mergeTheme(baseOption, this._theme.option); // TODO Needs clone when merging to the unexisted property\n\n merge(baseOption, globalDefault, false);\n this.mergeOption(baseOption);\n}\n/**\n * @inner\n * @param {Array.<string>|string} types model types\n * @return {Object} key: {string} type, value: {Array.<Object>} models\n */\n\n\nfunction getComponentsByTypes(componentsMap, types) {\n if (!isArray(types)) {\n types = types ? [types] : [];\n }\n\n var ret = {};\n each(types, function (type) {\n ret[type] = (componentsMap.get(type) || []).slice();\n });\n return ret;\n}\n/**\n * @inner\n */\n\n\nfunction determineSubType(mainType, newCptOption, existComponent) {\n var subType = newCptOption.type ? newCptOption.type : existComponent ? existComponent.subType // Use determineSubType only when there is no existComponent.\n : ComponentModel.determineSubType(mainType, newCptOption); // tooltip, markline, markpoint may always has no subType\n\n return subType;\n}\n/**\n * @inner\n */\n\n\nfunction createSeriesIndices(ecModel, seriesModels) {\n ecModel._seriesIndicesMap = createHashMap(ecModel._seriesIndices = map(seriesModels, function (series) {\n return series.componentIndex;\n }) || []);\n}\n/**\n * @inner\n */\n\n\nfunction filterBySubType(components, condition) {\n // Using hasOwnProperty for restrict. Consider\n // subType is undefined in user payload.\n return condition.hasOwnProperty('subType') ? filter(components, function (cpt) {\n return cpt.subType === condition.subType;\n }) : components;\n}\n/**\n * @inner\n */\n\n\nfunction assertSeriesInitialized(ecModel) {}\n\nmixin(GlobalModel, colorPaletteMixin);\nvar _default = GlobalModel;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nfunction _default(seriesType, defaultSymbolType, legendSymbol) {\n // Encoding visual for all series include which is filtered for legend drawing\n return {\n seriesType: seriesType,\n // For legend.\n performRawSeries: true,\n reset: function (seriesModel, ecModel, api) {\n var data = seriesModel.getData();\n var symbolType = seriesModel.get('symbol') || defaultSymbolType;\n var symbolSize = seriesModel.get('symbolSize');\n var keepAspect = seriesModel.get('symbolKeepAspect');\n data.setVisual({\n legendSymbol: legendSymbol || symbolType,\n symbol: symbolType,\n symbolSize: symbolSize,\n symbolKeepAspect: keepAspect\n }); // Only visible series has each data be visual encoded\n\n if (ecModel.isSeriesFiltered(seriesModel)) {\n return;\n }\n\n var hasCallback = typeof symbolSize === 'function';\n\n function dataEach(data, idx) {\n if (typeof symbolSize === 'function') {\n var rawValue = seriesModel.getRawValue(idx); // FIXME\n\n var params = seriesModel.getDataParams(idx);\n data.setItemVisual(idx, 'symbolSize', symbolSize(rawValue, params));\n }\n\n if (data.hasItemOption) {\n var itemModel = data.getItemModel(idx);\n var itemSymbolType = itemModel.getShallow('symbol', true);\n var itemSymbolSize = itemModel.getShallow('symbolSize', true);\n var itemSymbolKeepAspect = itemModel.getShallow('symbolKeepAspect', true); // If has item symbol\n\n if (itemSymbolType != null) {\n data.setItemVisual(idx, 'symbol', itemSymbolType);\n }\n\n if (itemSymbolSize != null) {\n // PENDING Transform symbolSize ?\n data.setItemVisual(idx, 'symbolSize', itemSymbolSize);\n }\n\n if (itemSymbolKeepAspect != null) {\n data.setItemVisual(idx, 'symbolKeepAspect', itemSymbolKeepAspect);\n }\n }\n }\n\n return {\n dataEach: data.hasItemOption || hasCallback ? dataEach : null\n };\n }\n };\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nfunction defaultKeyGetter(item) {\n return item;\n}\n/**\n * @param {Array} oldArr\n * @param {Array} newArr\n * @param {Function} oldKeyGetter\n * @param {Function} newKeyGetter\n * @param {Object} [context] Can be visited by this.context in callback.\n */\n\n\nfunction DataDiffer(oldArr, newArr, oldKeyGetter, newKeyGetter, context) {\n this._old = oldArr;\n this._new = newArr;\n this._oldKeyGetter = oldKeyGetter || defaultKeyGetter;\n this._newKeyGetter = newKeyGetter || defaultKeyGetter;\n this.context = context;\n}\n\nDataDiffer.prototype = {\n constructor: DataDiffer,\n\n /**\n * Callback function when add a data\n */\n add: function (func) {\n this._add = func;\n return this;\n },\n\n /**\n * Callback function when update a data\n */\n update: function (func) {\n this._update = func;\n return this;\n },\n\n /**\n * Callback function when remove a data\n */\n remove: function (func) {\n this._remove = func;\n return this;\n },\n execute: function () {\n var oldArr = this._old;\n var newArr = this._new;\n var oldDataIndexMap = {};\n var newDataIndexMap = {};\n var oldDataKeyArr = [];\n var newDataKeyArr = [];\n var i;\n initIndexMap(oldArr, oldDataIndexMap, oldDataKeyArr, '_oldKeyGetter', this);\n initIndexMap(newArr, newDataIndexMap, newDataKeyArr, '_newKeyGetter', this); // Travel by inverted order to make sure order consistency\n // when duplicate keys exists (consider newDataIndex.pop() below).\n // For performance consideration, these code below do not look neat.\n\n for (i = 0; i < oldArr.length; i++) {\n var key = oldDataKeyArr[i];\n var idx = newDataIndexMap[key]; // idx can never be empty array here. see 'set null' logic below.\n\n if (idx != null) {\n // Consider there is duplicate key (for example, use dataItem.name as key).\n // We should make sure every item in newArr and oldArr can be visited.\n var len = idx.length;\n\n if (len) {\n len === 1 && (newDataIndexMap[key] = null);\n idx = idx.unshift();\n } else {\n newDataIndexMap[key] = null;\n }\n\n this._update && this._update(idx, i);\n } else {\n this._remove && this._remove(i);\n }\n }\n\n for (var i = 0; i < newDataKeyArr.length; i++) {\n var key = newDataKeyArr[i];\n\n if (newDataIndexMap.hasOwnProperty(key)) {\n var idx = newDataIndexMap[key];\n\n if (idx == null) {\n continue;\n } // idx can never be empty array here. see 'set null' logic above.\n\n\n if (!idx.length) {\n this._add && this._add(idx);\n } else {\n for (var j = 0, len = idx.length; j < len; j++) {\n this._add && this._add(idx[j]);\n }\n }\n }\n }\n }\n};\n\nfunction initIndexMap(arr, map, keyArr, keyGetterName, dataDiffer) {\n for (var i = 0; i < arr.length; i++) {\n // Add prefix to avoid conflict with Object.prototype.\n var key = '_ec_' + dataDiffer[keyGetterName](arr[i], i);\n var existence = map[key];\n\n if (existence == null) {\n keyArr.push(key);\n map[key] = i;\n } else {\n if (!existence.length) {\n map[key] = existence = [existence];\n }\n\n existence.push(i);\n }\n }\n}\n\nvar _default = DataDiffer;\nmodule.exports = _default;","var ContextCachedBy = {\n NONE: 0,\n STYLE_BIND: 1,\n PLAIN_TEXT: 2\n}; // Avoid confused with 0/false.\n\nvar WILL_BE_RESTORED = 9;\nexports.ContextCachedBy = ContextCachedBy;\nexports.WILL_BE_RESTORED = WILL_BE_RESTORED;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar echartsAPIList = ['getDom', 'getZr', 'getWidth', 'getHeight', 'getDevicePixelRatio', 'dispatchAction', 'isDisposed', 'on', 'off', 'getDataURL', 'getConnectedDataURL', 'getModel', 'getOption', 'getViewOfComponentModel', 'getViewOfSeriesModel']; // And `getCoordinateSystems` and `getComponentByElement` will be injected in echarts.js\n\nfunction ExtensionAPI(chartInstance) {\n zrUtil.each(echartsAPIList, function (name) {\n this[name] = zrUtil.bind(chartInstance[name], chartInstance);\n }, this);\n}\n\nvar _default = ExtensionAPI;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar each = _util.each;\nvar map = _util.map;\n\nvar _number = require(\"../util/number\");\n\nvar linearMap = _number.linearMap;\nvar getPixelPrecision = _number.getPixelPrecision;\n\nvar _axisTickLabelBuilder = require(\"./axisTickLabelBuilder\");\n\nvar createAxisTicks = _axisTickLabelBuilder.createAxisTicks;\nvar createAxisLabels = _axisTickLabelBuilder.createAxisLabels;\nvar calculateCategoryInterval = _axisTickLabelBuilder.calculateCategoryInterval;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar NORMALIZED_EXTENT = [0, 1];\n/**\n * Base class of Axis.\n * @constructor\n */\n\nvar Axis = function (dim, scale, extent) {\n /**\n * Axis dimension. Such as 'x', 'y', 'z', 'angle', 'radius'.\n * @type {string}\n */\n this.dim = dim;\n /**\n * Axis scale\n * @type {module:echarts/coord/scale/*}\n */\n\n this.scale = scale;\n /**\n * @type {Array.<number>}\n * @private\n */\n\n this._extent = extent || [0, 0];\n /**\n * @type {boolean}\n */\n\n this.inverse = false;\n /**\n * Usually true when axis has a ordinal scale\n * @type {boolean}\n */\n\n this.onBand = false;\n};\n\nAxis.prototype = {\n constructor: Axis,\n\n /**\n * If axis extent contain given coord\n * @param {number} coord\n * @return {boolean}\n */\n contain: function (coord) {\n var extent = this._extent;\n var min = Math.min(extent[0], extent[1]);\n var max = Math.max(extent[0], extent[1]);\n return coord >= min && coord <= max;\n },\n\n /**\n * If axis extent contain given data\n * @param {number} data\n * @return {boolean}\n */\n containData: function (data) {\n return this.contain(this.dataToCoord(data));\n },\n\n /**\n * Get coord extent.\n * @return {Array.<number>}\n */\n getExtent: function () {\n return this._extent.slice();\n },\n\n /**\n * Get precision used for formatting\n * @param {Array.<number>} [dataExtent]\n * @return {number}\n */\n getPixelPrecision: function (dataExtent) {\n return getPixelPrecision(dataExtent || this.scale.getExtent(), this._extent);\n },\n\n /**\n * Set coord extent\n * @param {number} start\n * @param {number} end\n */\n setExtent: function (start, end) {\n var extent = this._extent;\n extent[0] = start;\n extent[1] = end;\n },\n\n /**\n * Convert data to coord. Data is the rank if it has an ordinal scale\n * @param {number} data\n * @param {boolean} clamp\n * @return {number}\n */\n dataToCoord: function (data, clamp) {\n var extent = this._extent;\n var scale = this.scale;\n data = scale.normalize(data);\n\n if (this.onBand && scale.type === 'ordinal') {\n extent = extent.slice();\n fixExtentWithBands(extent, scale.count());\n }\n\n return linearMap(data, NORMALIZED_EXTENT, extent, clamp);\n },\n\n /**\n * Convert coord to data. Data is the rank if it has an ordinal scale\n * @param {number} coord\n * @param {boolean} clamp\n * @return {number}\n */\n coordToData: function (coord, clamp) {\n var extent = this._extent;\n var scale = this.scale;\n\n if (this.onBand && scale.type === 'ordinal') {\n extent = extent.slice();\n fixExtentWithBands(extent, scale.count());\n }\n\n var t = linearMap(coord, extent, NORMALIZED_EXTENT, clamp);\n return this.scale.scale(t);\n },\n\n /**\n * Convert pixel point to data in axis\n * @param {Array.<number>} point\n * @param {boolean} clamp\n * @return {number} data\n */\n pointToData: function (point, clamp) {// Should be implemented in derived class if necessary.\n },\n\n /**\n * Different from `zrUtil.map(axis.getTicks(), axis.dataToCoord, axis)`,\n * `axis.getTicksCoords` considers `onBand`, which is used by\n * `boundaryGap:true` of category axis and splitLine and splitArea.\n * @param {Object} [opt]\n * @param {number} [opt.tickModel=axis.model.getModel('axisTick')]\n * @param {boolean} [opt.clamp] If `true`, the first and the last\n * tick must be at the axis end points. Otherwise, clip ticks\n * that outside the axis extent.\n * @return {Array.<Object>} [{\n * coord: ...,\n * tickValue: ...\n * }, ...]\n */\n getTicksCoords: function (opt) {\n opt = opt || {};\n var tickModel = opt.tickModel || this.getTickModel();\n var result = createAxisTicks(this, tickModel);\n var ticks = result.ticks;\n var ticksCoords = map(ticks, function (tickValue) {\n return {\n coord: this.dataToCoord(tickValue),\n tickValue: tickValue\n };\n }, this);\n var alignWithLabel = tickModel.get('alignWithLabel');\n fixOnBandTicksCoords(this, ticksCoords, result.tickCategoryInterval, alignWithLabel, opt.clamp);\n return ticksCoords;\n },\n\n /**\n * @return {Array.<Object>} [{\n * formattedLabel: string,\n * rawLabel: axis.scale.getLabel(tickValue)\n * tickValue: number\n * }, ...]\n */\n getViewLabels: function () {\n return createAxisLabels(this).labels;\n },\n\n /**\n * @return {module:echarts/coord/model/Model}\n */\n getLabelModel: function () {\n return this.model.getModel('axisLabel');\n },\n\n /**\n * Notice here we only get the default tick model. For splitLine\n * or splitArea, we should pass the splitLineModel or splitAreaModel\n * manually when calling `getTicksCoords`.\n * In GL, this method may be overrided to:\n * `axisModel.getModel('axisTick', grid3DModel.getModel('axisTick'));`\n * @return {module:echarts/coord/model/Model}\n */\n getTickModel: function () {\n return this.model.getModel('axisTick');\n },\n\n /**\n * Get width of band\n * @return {number}\n */\n getBandWidth: function () {\n var axisExtent = this._extent;\n var dataExtent = this.scale.getExtent();\n var len = dataExtent[1] - dataExtent[0] + (this.onBand ? 1 : 0); // Fix #2728, avoid NaN when only one data.\n\n len === 0 && (len = 1);\n var size = Math.abs(axisExtent[1] - axisExtent[0]);\n return Math.abs(size) / len;\n },\n\n /**\n * @abstract\n * @return {boolean} Is horizontal\n */\n isHorizontal: null,\n\n /**\n * @abstract\n * @return {number} Get axis rotate, by degree.\n */\n getRotate: null,\n\n /**\n * Only be called in category axis.\n * Can be overrided, consider other axes like in 3D.\n * @return {number} Auto interval for cateogry axis tick and label\n */\n calculateCategoryInterval: function () {\n return calculateCategoryInterval(this);\n }\n};\n\nfunction fixExtentWithBands(extent, nTick) {\n var size = extent[1] - extent[0];\n var len = nTick;\n var margin = size / len / 2;\n extent[0] += margin;\n extent[1] -= margin;\n} // If axis has labels [1, 2, 3, 4]. Bands on the axis are\n// |---1---|---2---|---3---|---4---|.\n// So the displayed ticks and splitLine/splitArea should between\n// each data item, otherwise cause misleading (e.g., split tow bars\n// of a single data item when there are two bar series).\n// Also consider if tickCategoryInterval > 0 and onBand, ticks and\n// splitLine/spliteArea should layout appropriately corresponding\n// to displayed labels. (So we should not use `getBandWidth` in this\n// case).\n\n\nfunction fixOnBandTicksCoords(axis, ticksCoords, tickCategoryInterval, alignWithLabel, clamp) {\n var ticksLen = ticksCoords.length;\n\n if (!axis.onBand || alignWithLabel || !ticksLen) {\n return;\n }\n\n var axisExtent = axis.getExtent();\n var last;\n\n if (ticksLen === 1) {\n ticksCoords[0].coord = axisExtent[0];\n last = ticksCoords[1] = {\n coord: axisExtent[0]\n };\n } else {\n var shift = ticksCoords[1].coord - ticksCoords[0].coord;\n each(ticksCoords, function (ticksItem) {\n ticksItem.coord -= shift / 2;\n var tickCategoryInterval = tickCategoryInterval || 0; // Avoid split a single data item when odd interval.\n\n if (tickCategoryInterval % 2 > 0) {\n ticksItem.coord -= shift / ((tickCategoryInterval + 1) * 2);\n }\n });\n last = {\n coord: ticksCoords[ticksLen - 1].coord + shift\n };\n ticksCoords.push(last);\n }\n\n var inverse = axisExtent[0] > axisExtent[1];\n\n if (littleThan(ticksCoords[0].coord, axisExtent[0])) {\n clamp ? ticksCoords[0].coord = axisExtent[0] : ticksCoords.shift();\n }\n\n if (clamp && littleThan(axisExtent[0], ticksCoords[0].coord)) {\n ticksCoords.unshift({\n coord: axisExtent[0]\n });\n }\n\n if (littleThan(axisExtent[1], last.coord)) {\n clamp ? last.coord = axisExtent[1] : ticksCoords.pop();\n }\n\n if (clamp && littleThan(last.coord, axisExtent[1])) {\n ticksCoords.push({\n coord: axisExtent[1]\n });\n }\n\n function littleThan(a, b) {\n return inverse ? a > b : a < b;\n }\n}\n\nvar _default = Axis;\nmodule.exports = _default;","var PI2 = Math.PI * 2;\n\nfunction normalizeRadian(angle) {\n angle %= PI2;\n\n if (angle < 0) {\n angle += PI2;\n }\n\n return angle;\n}\n\nexports.normalizeRadian = normalizeRadian;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar createHashMap = _util.createHashMap;\nvar each = _util.each;\nvar isString = _util.isString;\nvar defaults = _util.defaults;\nvar extend = _util.extend;\nvar isObject = _util.isObject;\nvar clone = _util.clone;\n\nvar _model = require(\"../../util/model\");\n\nvar normalizeToArray = _model.normalizeToArray;\n\nvar _sourceHelper = require(\"./sourceHelper\");\n\nvar guessOrdinal = _sourceHelper.guessOrdinal;\n\nvar Source = require(\"../Source\");\n\nvar _dimensionHelper = require(\"./dimensionHelper\");\n\nvar OTHER_DIMENSIONS = _dimensionHelper.OTHER_DIMENSIONS;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @deprecated\n * Use `echarts/data/helper/createDimensions` instead.\n */\n\n/**\n * @see {module:echarts/test/ut/spec/data/completeDimensions}\n *\n * Complete the dimensions array, by user defined `dimension` and `encode`,\n * and guessing from the data structure.\n * If no 'value' dimension specified, the first no-named dimension will be\n * named as 'value'.\n *\n * @param {Array.<string>} sysDims Necessary dimensions, like ['x', 'y'], which\n * provides not only dim template, but also default order.\n * properties: 'name', 'type', 'displayName'.\n * `name` of each item provides default coord name.\n * [{dimsDef: [string|Object, ...]}, ...] dimsDef of sysDim item provides default dim name, and\n * provide dims count that the sysDim required.\n * [{ordinalMeta}] can be specified.\n * @param {module:echarts/data/Source|Array|Object} source or data (for compatibal with pervious)\n * @param {Object} [opt]\n * @param {Array.<Object|string>} [opt.dimsDef] option.series.dimensions User defined dimensions\n * For example: ['asdf', {name, type}, ...].\n * @param {Object|HashMap} [opt.encodeDef] option.series.encode {x: 2, y: [3, 1], tooltip: [1, 2], label: 3}\n * @param {string} [opt.generateCoord] Generate coord dim with the given name.\n * If not specified, extra dim names will be:\n * 'value', 'value0', 'value1', ...\n * @param {number} [opt.generateCoordCount] By default, the generated dim name is `generateCoord`.\n * If `generateCoordCount` specified, the generated dim names will be:\n * `generateCoord` + 0, `generateCoord` + 1, ...\n * can be Infinity, indicate that use all of the remain columns.\n * @param {number} [opt.dimCount] If not specified, guess by the first data item.\n * @param {number} [opt.encodeDefaulter] If not specified, auto find the next available data dim.\n * @return {Array.<Object>} [{\n * name: string mandatory,\n * displayName: string, the origin name in dimsDef, see source helper.\n * If displayName given, the tooltip will displayed vertically.\n * coordDim: string mandatory,\n * coordDimIndex: number mandatory,\n * type: string optional,\n * otherDims: { never null/undefined\n * tooltip: number optional,\n * label: number optional,\n * itemName: number optional,\n * seriesName: number optional,\n * },\n * isExtraCoord: boolean true if coord is generated\n * (not specified in encode and not series specified)\n * other props ...\n * }]\n */\nfunction completeDimensions(sysDims, source, opt) {\n if (!Source.isInstance(source)) {\n source = Source.seriesDataToSource(source);\n }\n\n opt = opt || {};\n sysDims = (sysDims || []).slice();\n var dimsDef = (opt.dimsDef || []).slice();\n var encodeDef = createHashMap(opt.encodeDef);\n var dataDimNameMap = createHashMap();\n var coordDimNameMap = createHashMap(); // var valueCandidate;\n\n var result = [];\n var dimCount = getDimCount(source, sysDims, dimsDef, opt.dimCount); // Apply user defined dims (`name` and `type`) and init result.\n\n for (var i = 0; i < dimCount; i++) {\n var dimDefItem = dimsDef[i] = extend({}, isObject(dimsDef[i]) ? dimsDef[i] : {\n name: dimsDef[i]\n });\n var userDimName = dimDefItem.name;\n var resultItem = result[i] = {\n otherDims: {}\n }; // Name will be applied later for avoiding duplication.\n\n if (userDimName != null && dataDimNameMap.get(userDimName) == null) {\n // Only if `series.dimensions` is defined in option\n // displayName, will be set, and dimension will be diplayed vertically in\n // tooltip by default.\n resultItem.name = resultItem.displayName = userDimName;\n dataDimNameMap.set(userDimName, i);\n }\n\n dimDefItem.type != null && (resultItem.type = dimDefItem.type);\n dimDefItem.displayName != null && (resultItem.displayName = dimDefItem.displayName);\n } // Set `coordDim` and `coordDimIndex` by `encodeDef` and normalize `encodeDef`.\n\n\n encodeDef.each(function (dataDims, coordDim) {\n dataDims = normalizeToArray(dataDims).slice(); // Note: It is allowed that `dataDims.length` is `0`, e.g., options is\n // `{encode: {x: -1, y: 1}}`. Should not filter anything in\n // this case.\n\n if (dataDims.length === 1 && dataDims[0] < 0) {\n encodeDef.set(coordDim, false);\n return;\n }\n\n var validDataDims = encodeDef.set(coordDim, []);\n each(dataDims, function (resultDimIdx, idx) {\n // The input resultDimIdx can be dim name or index.\n isString(resultDimIdx) && (resultDimIdx = dataDimNameMap.get(resultDimIdx));\n\n if (resultDimIdx != null && resultDimIdx < dimCount) {\n validDataDims[idx] = resultDimIdx;\n applyDim(result[resultDimIdx], coordDim, idx);\n }\n });\n }); // Apply templetes and default order from `sysDims`.\n\n var availDimIdx = 0;\n each(sysDims, function (sysDimItem, sysDimIndex) {\n var coordDim;\n var sysDimItem;\n var sysDimItemDimsDef;\n var sysDimItemOtherDims;\n\n if (isString(sysDimItem)) {\n coordDim = sysDimItem;\n sysDimItem = {};\n } else {\n coordDim = sysDimItem.name;\n var ordinalMeta = sysDimItem.ordinalMeta;\n sysDimItem.ordinalMeta = null;\n sysDimItem = clone(sysDimItem);\n sysDimItem.ordinalMeta = ordinalMeta; // `coordDimIndex` should not be set directly.\n\n sysDimItemDimsDef = sysDimItem.dimsDef;\n sysDimItemOtherDims = sysDimItem.otherDims;\n sysDimItem.name = sysDimItem.coordDim = sysDimItem.coordDimIndex = sysDimItem.dimsDef = sysDimItem.otherDims = null;\n }\n\n var dataDims = encodeDef.get(coordDim); // negative resultDimIdx means no need to mapping.\n\n if (dataDims === false) {\n return;\n }\n\n var dataDims = normalizeToArray(dataDims); // dimensions provides default dim sequences.\n\n if (!dataDims.length) {\n for (var i = 0; i < (sysDimItemDimsDef && sysDimItemDimsDef.length || 1); i++) {\n while (availDimIdx < result.length && result[availDimIdx].coordDim != null) {\n availDimIdx++;\n }\n\n availDimIdx < result.length && dataDims.push(availDimIdx++);\n }\n } // Apply templates.\n\n\n each(dataDims, function (resultDimIdx, coordDimIndex) {\n var resultItem = result[resultDimIdx];\n applyDim(defaults(resultItem, sysDimItem), coordDim, coordDimIndex);\n\n if (resultItem.name == null && sysDimItemDimsDef) {\n var sysDimItemDimsDefItem = sysDimItemDimsDef[coordDimIndex];\n !isObject(sysDimItemDimsDefItem) && (sysDimItemDimsDefItem = {\n name: sysDimItemDimsDefItem\n });\n resultItem.name = resultItem.displayName = sysDimItemDimsDefItem.name;\n resultItem.defaultTooltip = sysDimItemDimsDefItem.defaultTooltip;\n } // FIXME refactor, currently only used in case: {otherDims: {tooltip: false}}\n\n\n sysDimItemOtherDims && defaults(resultItem.otherDims, sysDimItemOtherDims);\n });\n });\n\n function applyDim(resultItem, coordDim, coordDimIndex) {\n if (OTHER_DIMENSIONS.get(coordDim) != null) {\n resultItem.otherDims[coordDim] = coordDimIndex;\n } else {\n resultItem.coordDim = coordDim;\n resultItem.coordDimIndex = coordDimIndex;\n coordDimNameMap.set(coordDim, true);\n }\n } // Make sure the first extra dim is 'value'.\n\n\n var generateCoord = opt.generateCoord;\n var generateCoordCount = opt.generateCoordCount;\n var fromZero = generateCoordCount != null;\n generateCoordCount = generateCoord ? generateCoordCount || 1 : 0;\n var extra = generateCoord || 'value'; // Set dim `name` and other `coordDim` and other props.\n\n for (var resultDimIdx = 0; resultDimIdx < dimCount; resultDimIdx++) {\n var resultItem = result[resultDimIdx] = result[resultDimIdx] || {};\n var coordDim = resultItem.coordDim;\n\n if (coordDim == null) {\n resultItem.coordDim = genName(extra, coordDimNameMap, fromZero);\n resultItem.coordDimIndex = 0;\n\n if (!generateCoord || generateCoordCount <= 0) {\n resultItem.isExtraCoord = true;\n }\n\n generateCoordCount--;\n }\n\n resultItem.name == null && (resultItem.name = genName(resultItem.coordDim, dataDimNameMap));\n\n if (resultItem.type == null && guessOrdinal(source, resultDimIdx, resultItem.name)) {\n resultItem.type = 'ordinal';\n }\n }\n\n return result;\n} // ??? TODO\n// Originally detect dimCount by data[0]. Should we\n// optimize it to only by sysDims and dimensions and encode.\n// So only necessary dims will be initialized.\n// But\n// (1) custom series should be considered. where other dims\n// may be visited.\n// (2) sometimes user need to calcualte bubble size or use visualMap\n// on other dimensions besides coordSys needed.\n// So, dims that is not used by system, should be shared in storage?\n\n\nfunction getDimCount(source, sysDims, dimsDef, optDimCount) {\n // Note that the result dimCount should not small than columns count\n // of data, otherwise `dataDimNameMap` checking will be incorrect.\n var dimCount = Math.max(source.dimensionsDetectCount || 1, sysDims.length, dimsDef.length, optDimCount || 0);\n each(sysDims, function (sysDimItem) {\n var sysDimItemDimsDef = sysDimItem.dimsDef;\n sysDimItemDimsDef && (dimCount = Math.max(dimCount, sysDimItemDimsDef.length));\n });\n return dimCount;\n}\n\nfunction genName(name, map, fromZero) {\n if (fromZero || map.get(name) != null) {\n var i = 0;\n\n while (map.get(name + i) != null) {\n i++;\n }\n\n name += i;\n }\n\n map.set(name, true);\n return name;\n}\n\nvar _default = completeDimensions;\nmodule.exports = _default;","function windingLine(x0, y0, x1, y1, x, y) {\n if (y > y0 && y > y1 || y < y0 && y < y1) {\n return 0;\n } // Ignore horizontal line\n\n\n if (y1 === y0) {\n return 0;\n }\n\n var dir = y1 < y0 ? 1 : -1;\n var t = (y - y0) / (y1 - y0); // Avoid winding error when intersection point is the connect point of two line of polygon\n\n if (t === 1 || t === 0) {\n dir = y1 < y0 ? 0.5 : -0.5;\n }\n\n var x_ = t * (x1 - x0) + x0; // If (x, y) on the line, considered as \"contain\".\n\n return x_ === x ? Infinity : x_ > x ? dir : 0;\n}\n\nmodule.exports = windingLine;","var Path = require(\"../Path\");\n\nvar polyHelper = require(\"../helper/poly\");\n\n/**\n * 多边形\n * @module zrender/shape/Polygon\n */\nvar _default = Path.extend({\n type: 'polygon',\n shape: {\n points: null,\n smooth: false,\n smoothConstraint: null\n },\n buildPath: function (ctx, shape) {\n polyHelper.buildPath(ctx, shape, true);\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar map = _util.map;\n\nvar createRenderPlanner = require(\"../chart/helper/createRenderPlanner\");\n\nvar _dataStackHelper = require(\"../data/helper/dataStackHelper\");\n\nvar isDimensionStacked = _dataStackHelper.isDimensionStacked;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/* global Float32Array */\nfunction _default(seriesType) {\n return {\n seriesType: seriesType,\n plan: createRenderPlanner(),\n reset: function (seriesModel) {\n var data = seriesModel.getData();\n var coordSys = seriesModel.coordinateSystem;\n var pipelineContext = seriesModel.pipelineContext;\n var isLargeRender = pipelineContext.large;\n\n if (!coordSys) {\n return;\n }\n\n var dims = map(coordSys.dimensions, function (dim) {\n return data.mapDimension(dim);\n }).slice(0, 2);\n var dimLen = dims.length;\n var stackResultDim = data.getCalculationInfo('stackResultDimension');\n\n if (isDimensionStacked(data, dims[0]\n /*, dims[1]*/\n )) {\n dims[0] = stackResultDim;\n }\n\n if (isDimensionStacked(data, dims[1]\n /*, dims[0]*/\n )) {\n dims[1] = stackResultDim;\n }\n\n function progress(params, data) {\n var segCount = params.end - params.start;\n var points = isLargeRender && new Float32Array(segCount * dimLen);\n\n for (var i = params.start, offset = 0, tmpIn = [], tmpOut = []; i < params.end; i++) {\n var point;\n\n if (dimLen === 1) {\n var x = data.get(dims[0], i);\n point = !isNaN(x) && coordSys.dataToPoint(x, null, tmpOut);\n } else {\n var x = tmpIn[0] = data.get(dims[0], i);\n var y = tmpIn[1] = data.get(dims[1], i); // Also {Array.<number>}, not undefined to avoid if...else... statement\n\n point = !isNaN(x) && !isNaN(y) && coordSys.dataToPoint(tmpIn, null, tmpOut);\n }\n\n if (isLargeRender) {\n points[offset++] = point ? point[0] : NaN;\n points[offset++] = point ? point[1] : NaN;\n } else {\n data.setItemLayout(i, point && point.slice() || [NaN, NaN]);\n }\n }\n\n isLargeRender && data.setLayout('symbolPoints', points);\n }\n\n return dimLen && {\n progress: progress\n };\n }\n };\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar ORIGIN_METHOD = '\\0__throttleOriginMethod';\nvar RATE = '\\0__throttleRate';\nvar THROTTLE_TYPE = '\\0__throttleType';\n/**\n * @public\n * @param {(Function)} fn\n * @param {number} [delay=0] Unit: ms.\n * @param {boolean} [debounce=false]\n * true: If call interval less than `delay`, only the last call works.\n * false: If call interval less than `delay, call works on fixed rate.\n * @return {(Function)} throttled fn.\n */\n\nfunction throttle(fn, delay, debounce) {\n var currCall;\n var lastCall = 0;\n var lastExec = 0;\n var timer = null;\n var diff;\n var scope;\n var args;\n var debounceNextCall;\n delay = delay || 0;\n\n function exec() {\n lastExec = new Date().getTime();\n timer = null;\n fn.apply(scope, args || []);\n }\n\n var cb = function () {\n currCall = new Date().getTime();\n scope = this;\n args = arguments;\n var thisDelay = debounceNextCall || delay;\n var thisDebounce = debounceNextCall || debounce;\n debounceNextCall = null;\n diff = currCall - (thisDebounce ? lastCall : lastExec) - thisDelay;\n clearTimeout(timer); // Here we should make sure that: the `exec` SHOULD NOT be called later\n // than a new call of `cb`, that is, preserving the command order. Consider\n // calculating \"scale rate\" when roaming as an example. When a call of `cb`\n // happens, either the `exec` is called dierectly, or the call is delayed.\n // But the delayed call should never be later than next call of `cb`. Under\n // this assurance, we can simply update view state each time `dispatchAction`\n // triggered by user roaming, but not need to add extra code to avoid the\n // state being \"rolled-back\".\n\n if (thisDebounce) {\n timer = setTimeout(exec, thisDelay);\n } else {\n if (diff >= 0) {\n exec();\n } else {\n timer = setTimeout(exec, -diff);\n }\n }\n\n lastCall = currCall;\n };\n /**\n * Clear throttle.\n * @public\n */\n\n\n cb.clear = function () {\n if (timer) {\n clearTimeout(timer);\n timer = null;\n }\n };\n /**\n * Enable debounce once.\n */\n\n\n cb.debounceNextCall = function (debounceDelay) {\n debounceNextCall = debounceDelay;\n };\n\n return cb;\n}\n/**\n * Create throttle method or update throttle rate.\n *\n * @example\n * ComponentView.prototype.render = function () {\n * ...\n * throttle.createOrUpdate(\n * this,\n * '_dispatchAction',\n * this.model.get('throttle'),\n * 'fixRate'\n * );\n * };\n * ComponentView.prototype.remove = function () {\n * throttle.clear(this, '_dispatchAction');\n * };\n * ComponentView.prototype.dispose = function () {\n * throttle.clear(this, '_dispatchAction');\n * };\n *\n * @public\n * @param {Object} obj\n * @param {string} fnAttr\n * @param {number} [rate]\n * @param {string} [throttleType='fixRate'] 'fixRate' or 'debounce'\n * @return {Function} throttled function.\n */\n\n\nfunction createOrUpdate(obj, fnAttr, rate, throttleType) {\n var fn = obj[fnAttr];\n\n if (!fn) {\n return;\n }\n\n var originFn = fn[ORIGIN_METHOD] || fn;\n var lastThrottleType = fn[THROTTLE_TYPE];\n var lastRate = fn[RATE];\n\n if (lastRate !== rate || lastThrottleType !== throttleType) {\n if (rate == null || !throttleType) {\n return obj[fnAttr] = originFn;\n }\n\n fn = obj[fnAttr] = throttle(originFn, rate, throttleType === 'debounce');\n fn[ORIGIN_METHOD] = originFn;\n fn[THROTTLE_TYPE] = throttleType;\n fn[RATE] = rate;\n }\n\n return fn;\n}\n/**\n * Clear throttle. Example see throttle.createOrUpdate.\n *\n * @public\n * @param {Object} obj\n * @param {string} fnAttr\n */\n\n\nfunction clear(obj, fnAttr) {\n var fn = obj[fnAttr];\n\n if (fn && fn[ORIGIN_METHOD]) {\n obj[fnAttr] = fn[ORIGIN_METHOD];\n }\n}\n\nexports.throttle = throttle;\nexports.createOrUpdate = createOrUpdate;\nexports.clear = clear;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar _clazz = require(\"./clazz\");\n\nvar parseClassType = _clazz.parseClassType;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar base = 0;\n/**\n * @public\n * @param {string} type\n * @return {string}\n */\n\nfunction getUID(type) {\n // Considering the case of crossing js context,\n // use Math.random to make id as unique as possible.\n return [type || '', base++, Math.random().toFixed(5)].join('_');\n}\n/**\n * @inner\n */\n\n\nfunction enableSubTypeDefaulter(entity) {\n var subTypeDefaulters = {};\n\n entity.registerSubTypeDefaulter = function (componentType, defaulter) {\n componentType = parseClassType(componentType);\n subTypeDefaulters[componentType.main] = defaulter;\n };\n\n entity.determineSubType = function (componentType, option) {\n var type = option.type;\n\n if (!type) {\n var componentTypeMain = parseClassType(componentType).main;\n\n if (entity.hasSubTypes(componentType) && subTypeDefaulters[componentTypeMain]) {\n type = subTypeDefaulters[componentTypeMain](option);\n }\n }\n\n return type;\n };\n\n return entity;\n}\n/**\n * Topological travel on Activity Network (Activity On Vertices).\n * Dependencies is defined in Model.prototype.dependencies, like ['xAxis', 'yAxis'].\n *\n * If 'xAxis' or 'yAxis' is absent in componentTypeList, just ignore it in topology.\n *\n * If there is circle dependencey, Error will be thrown.\n *\n */\n\n\nfunction enableTopologicalTravel(entity, dependencyGetter) {\n /**\n * @public\n * @param {Array.<string>} targetNameList Target Component type list.\n * Can be ['aa', 'bb', 'aa.xx']\n * @param {Array.<string>} fullNameList By which we can build dependency graph.\n * @param {Function} callback Params: componentType, dependencies.\n * @param {Object} context Scope of callback.\n */\n entity.topologicalTravel = function (targetNameList, fullNameList, callback, context) {\n if (!targetNameList.length) {\n return;\n }\n\n var result = makeDepndencyGraph(fullNameList);\n var graph = result.graph;\n var stack = result.noEntryList;\n var targetNameSet = {};\n zrUtil.each(targetNameList, function (name) {\n targetNameSet[name] = true;\n });\n\n while (stack.length) {\n var currComponentType = stack.pop();\n var currVertex = graph[currComponentType];\n var isInTargetNameSet = !!targetNameSet[currComponentType];\n\n if (isInTargetNameSet) {\n callback.call(context, currComponentType, currVertex.originalDeps.slice());\n delete targetNameSet[currComponentType];\n }\n\n zrUtil.each(currVertex.successor, isInTargetNameSet ? removeEdgeAndAdd : removeEdge);\n }\n\n zrUtil.each(targetNameSet, function () {\n throw new Error('Circle dependency may exists');\n });\n\n function removeEdge(succComponentType) {\n graph[succComponentType].entryCount--;\n\n if (graph[succComponentType].entryCount === 0) {\n stack.push(succComponentType);\n }\n } // Consider this case: legend depends on series, and we call\n // chart.setOption({series: [...]}), where only series is in option.\n // If we do not have 'removeEdgeAndAdd', legendModel.mergeOption will\n // not be called, but only sereis.mergeOption is called. Thus legend\n // have no chance to update its local record about series (like which\n // name of series is available in legend).\n\n\n function removeEdgeAndAdd(succComponentType) {\n targetNameSet[succComponentType] = true;\n removeEdge(succComponentType);\n }\n };\n /**\n * DepndencyGraph: {Object}\n * key: conponentType,\n * value: {\n * successor: [conponentTypes...],\n * originalDeps: [conponentTypes...],\n * entryCount: {number}\n * }\n */\n\n\n function makeDepndencyGraph(fullNameList) {\n var graph = {};\n var noEntryList = [];\n zrUtil.each(fullNameList, function (name) {\n var thisItem = createDependencyGraphItem(graph, name);\n var originalDeps = thisItem.originalDeps = dependencyGetter(name);\n var availableDeps = getAvailableDependencies(originalDeps, fullNameList);\n thisItem.entryCount = availableDeps.length;\n\n if (thisItem.entryCount === 0) {\n noEntryList.push(name);\n }\n\n zrUtil.each(availableDeps, function (dependentName) {\n if (zrUtil.indexOf(thisItem.predecessor, dependentName) < 0) {\n thisItem.predecessor.push(dependentName);\n }\n\n var thatItem = createDependencyGraphItem(graph, dependentName);\n\n if (zrUtil.indexOf(thatItem.successor, dependentName) < 0) {\n thatItem.successor.push(name);\n }\n });\n });\n return {\n graph: graph,\n noEntryList: noEntryList\n };\n }\n\n function createDependencyGraphItem(graph, name) {\n if (!graph[name]) {\n graph[name] = {\n predecessor: [],\n successor: []\n };\n }\n\n return graph[name];\n }\n\n function getAvailableDependencies(originalDeps, fullNameList) {\n var availableDeps = [];\n zrUtil.each(originalDeps, function (dep) {\n zrUtil.indexOf(fullNameList, dep) >= 0 && availableDeps.push(dep);\n });\n return availableDeps;\n }\n}\n\nexports.getUID = getUID;\nexports.enableSubTypeDefaulter = enableSubTypeDefaulter;\nexports.enableTopologicalTravel = enableTopologicalTravel;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar platform = ''; // Navigator not exists in node\n\nif (typeof navigator !== 'undefined') {\n platform = navigator.platform || '';\n}\n\nvar _default = {\n // backgroundColor: 'rgba(0,0,0,0)',\n // https://dribbble.com/shots/1065960-Infographic-Pie-chart-visualization\n // color: ['#5793f3', '#d14a61', '#fd9c35', '#675bba', '#fec42c', '#dd4444', '#d4df5a', '#cd4870'],\n // Light colors:\n // color: ['#bcd3bb', '#e88f70', '#edc1a5', '#9dc5c8', '#e1e8c8', '#7b7c68', '#e5b5b5', '#f0b489', '#928ea8', '#bda29a'],\n // color: ['#cc5664', '#9bd6ec', '#ea946e', '#8acaaa', '#f1ec64', '#ee8686', '#a48dc1', '#5da6bc', '#b9dcae'],\n // Dark colors:\n color: ['#c23531', '#2f4554', '#61a0a8', '#d48265', '#91c7ae', '#749f83', '#ca8622', '#bda29a', '#6e7074', '#546570', '#c4ccd3'],\n gradientColor: ['#f6efa6', '#d88273', '#bf444c'],\n // If xAxis and yAxis declared, grid is created by default.\n // grid: {},\n textStyle: {\n // color: '#000',\n // decoration: 'none',\n // PENDING\n fontFamily: platform.match(/^Win/) ? 'Microsoft YaHei' : 'sans-serif',\n // fontFamily: 'Arial, Verdana, sans-serif',\n fontSize: 12,\n fontStyle: 'normal',\n fontWeight: 'normal'\n },\n // http://blogs.adobe.com/webplatform/2014/02/24/using-blend-modes-in-html-canvas/\n // https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/globalCompositeOperation\n // Default is source-over\n blendMode: null,\n animation: 'auto',\n animationDuration: 1000,\n animationDurationUpdate: 300,\n animationEasing: 'exponentialOut',\n animationEasingUpdate: 'cubicOut',\n animationThreshold: 2000,\n // Configuration for progressive/incremental rendering\n progressiveThreshold: 3000,\n progressive: 400,\n // Threshold of if use single hover layer to optimize.\n // It is recommended that `hoverLayerThreshold` is equivalent to or less than\n // `progressiveThreshold`, otherwise hover will cause restart of progressive,\n // which is unexpected.\n // see example <echarts/test/heatmap-large.html>.\n hoverLayerThreshold: 3000,\n // See: module:echarts/scale/Time\n useUTC: false\n};\nmodule.exports = _default;","var env = require(\"../../core/env\");\n\n// Fix weird bug in some version of IE11 (like 11.0.9600.178**),\n// where exception \"unexpected call to method or property access\"\n// might be thrown when calling ctx.fill or ctx.stroke after a path\n// whose area size is zero is drawn and ctx.clip() is called and\n// shadowBlur is set. See #4572, #3112, #5777.\n// (e.g.,\n// ctx.moveTo(10, 10);\n// ctx.lineTo(20, 10);\n// ctx.closePath();\n// ctx.clip();\n// ctx.shadowBlur = 10;\n// ...\n// ctx.fill();\n// )\nvar shadowTemp = [['shadowBlur', 0], ['shadowColor', '#000'], ['shadowOffsetX', 0], ['shadowOffsetY', 0]];\n\nfunction _default(orignalBrush) {\n // version string can be: '11.0'\n return env.browser.ie && env.browser.version >= 11 ? function () {\n var clipPaths = this.__clipPaths;\n var style = this.style;\n var modified;\n\n if (clipPaths) {\n for (var i = 0; i < clipPaths.length; i++) {\n var clipPath = clipPaths[i];\n var shape = clipPath && clipPath.shape;\n var type = clipPath && clipPath.type;\n\n if (shape && (type === 'sector' && shape.startAngle === shape.endAngle || type === 'rect' && (!shape.width || !shape.height))) {\n for (var j = 0; j < shadowTemp.length; j++) {\n // It is save to put shadowTemp static, because shadowTemp\n // will be all modified each item brush called.\n shadowTemp[j][2] = style[shadowTemp[j][0]];\n style[shadowTemp[j][0]] = shadowTemp[j][1];\n }\n\n modified = true;\n break;\n }\n }\n }\n\n orignalBrush.apply(this, arguments);\n\n if (modified) {\n for (var j = 0; j < shadowTemp.length; j++) {\n style[shadowTemp[j][0]] = shadowTemp[j][2];\n }\n }\n } : orignalBrush;\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar numberUtil = require(\"../util/number\");\n\nvar formatUtil = require(\"../util/format\");\n\nvar Scale = require(\"./Scale\");\n\nvar helper = require(\"./helper\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Interval scale\n * @module echarts/scale/Interval\n */\nvar roundNumber = numberUtil.round;\n/**\n * @alias module:echarts/coord/scale/Interval\n * @constructor\n */\n\nvar IntervalScale = Scale.extend({\n type: 'interval',\n _interval: 0,\n _intervalPrecision: 2,\n setExtent: function (start, end) {\n var thisExtent = this._extent; //start,end may be a Number like '25',so...\n\n if (!isNaN(start)) {\n thisExtent[0] = parseFloat(start);\n }\n\n if (!isNaN(end)) {\n thisExtent[1] = parseFloat(end);\n }\n },\n unionExtent: function (other) {\n var extent = this._extent;\n other[0] < extent[0] && (extent[0] = other[0]);\n other[1] > extent[1] && (extent[1] = other[1]); // unionExtent may called by it's sub classes\n\n IntervalScale.prototype.setExtent.call(this, extent[0], extent[1]);\n },\n\n /**\n * Get interval\n */\n getInterval: function () {\n return this._interval;\n },\n\n /**\n * Set interval\n */\n setInterval: function (interval) {\n this._interval = interval; // Dropped auto calculated niceExtent and use user setted extent\n // We assume user wan't to set both interval, min, max to get a better result\n\n this._niceExtent = this._extent.slice();\n this._intervalPrecision = helper.getIntervalPrecision(interval);\n },\n\n /**\n * @return {Array.<number>}\n */\n getTicks: function () {\n return helper.intervalScaleGetTicks(this._interval, this._extent, this._niceExtent, this._intervalPrecision);\n },\n\n /**\n * @param {number} data\n * @param {Object} [opt]\n * @param {number|string} [opt.precision] If 'auto', use nice presision.\n * @param {boolean} [opt.pad] returns 1.50 but not 1.5 if precision is 2.\n * @return {string}\n */\n getLabel: function (data, opt) {\n if (data == null) {\n return '';\n }\n\n var precision = opt && opt.precision;\n\n if (precision == null) {\n precision = numberUtil.getPrecisionSafe(data) || 0;\n } else if (precision === 'auto') {\n // Should be more precise then tick.\n precision = this._intervalPrecision;\n } // (1) If `precision` is set, 12.005 should be display as '12.00500'.\n // (2) Use roundNumber (toFixed) to avoid scientific notation like '3.5e-7'.\n\n\n data = roundNumber(data, precision, true);\n return formatUtil.addCommas(data);\n },\n\n /**\n * Update interval and extent of intervals for nice ticks\n *\n * @param {number} [splitNumber = 5] Desired number of ticks\n * @param {number} [minInterval]\n * @param {number} [maxInterval]\n */\n niceTicks: function (splitNumber, minInterval, maxInterval) {\n splitNumber = splitNumber || 5;\n var extent = this._extent;\n var span = extent[1] - extent[0];\n\n if (!isFinite(span)) {\n return;\n } // User may set axis min 0 and data are all negative\n // FIXME If it needs to reverse ?\n\n\n if (span < 0) {\n span = -span;\n extent.reverse();\n }\n\n var result = helper.intervalScaleNiceTicks(extent, splitNumber, minInterval, maxInterval);\n this._intervalPrecision = result.intervalPrecision;\n this._interval = result.interval;\n this._niceExtent = result.niceTickExtent;\n },\n\n /**\n * Nice extent.\n * @param {Object} opt\n * @param {number} [opt.splitNumber = 5] Given approx tick number\n * @param {boolean} [opt.fixMin=false]\n * @param {boolean} [opt.fixMax=false]\n * @param {boolean} [opt.minInterval]\n * @param {boolean} [opt.maxInterval]\n */\n niceExtent: function (opt) {\n var extent = this._extent; // If extent start and end are same, expand them\n\n if (extent[0] === extent[1]) {\n if (extent[0] !== 0) {\n // Expand extent\n var expandSize = extent[0]; // In the fowllowing case\n // Axis has been fixed max 100\n // Plus data are all 100 and axis extent are [100, 100].\n // Extend to the both side will cause expanded max is larger than fixed max.\n // So only expand to the smaller side.\n\n if (!opt.fixMax) {\n extent[1] += expandSize / 2;\n extent[0] -= expandSize / 2;\n } else {\n extent[0] -= expandSize / 2;\n }\n } else {\n extent[1] = 1;\n }\n }\n\n var span = extent[1] - extent[0]; // If there are no data and extent are [Infinity, -Infinity]\n\n if (!isFinite(span)) {\n extent[0] = 0;\n extent[1] = 1;\n }\n\n this.niceTicks(opt.splitNumber, opt.minInterval, opt.maxInterval); // var extent = this._extent;\n\n var interval = this._interval;\n\n if (!opt.fixMin) {\n extent[0] = roundNumber(Math.floor(extent[0] / interval) * interval);\n }\n\n if (!opt.fixMax) {\n extent[1] = roundNumber(Math.ceil(extent[1] / interval) * interval);\n }\n }\n});\n/**\n * @return {module:echarts/scale/Time}\n */\n\nIntervalScale.create = function () {\n return new IntervalScale();\n};\n\nvar _default = IntervalScale;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar createHashMap = _util.createHashMap;\nvar retrieve = _util.retrieve;\nvar each = _util.each;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Helper for model references.\n * There are many manners to refer axis/coordSys.\n */\n// TODO\n// merge relevant logic to this file?\n// check: \"modelHelper\" of tooltip and \"BrushTargetManager\".\n\n/**\n * @return {Object} For example:\n * {\n * coordSysName: 'cartesian2d',\n * coordSysDims: ['x', 'y', ...],\n * axisMap: HashMap({\n * x: xAxisModel,\n * y: yAxisModel\n * }),\n * categoryAxisMap: HashMap({\n * x: xAxisModel,\n * y: undefined\n * }),\n * // It also indicate that whether there is category axis.\n * firstCategoryDimIndex: 1,\n * // To replace user specified encode.\n * }\n */\nfunction getCoordSysDefineBySeries(seriesModel) {\n var coordSysName = seriesModel.get('coordinateSystem');\n var result = {\n coordSysName: coordSysName,\n coordSysDims: [],\n axisMap: createHashMap(),\n categoryAxisMap: createHashMap()\n };\n var fetch = fetchers[coordSysName];\n\n if (fetch) {\n fetch(seriesModel, result, result.axisMap, result.categoryAxisMap);\n return result;\n }\n}\n\nvar fetchers = {\n cartesian2d: function (seriesModel, result, axisMap, categoryAxisMap) {\n var xAxisModel = seriesModel.getReferringComponents('xAxis')[0];\n var yAxisModel = seriesModel.getReferringComponents('yAxis')[0];\n result.coordSysDims = ['x', 'y'];\n axisMap.set('x', xAxisModel);\n axisMap.set('y', yAxisModel);\n\n if (isCategory(xAxisModel)) {\n categoryAxisMap.set('x', xAxisModel);\n result.firstCategoryDimIndex = 0;\n }\n\n if (isCategory(yAxisModel)) {\n categoryAxisMap.set('y', yAxisModel);\n result.firstCategoryDimIndex = 1;\n }\n },\n singleAxis: function (seriesModel, result, axisMap, categoryAxisMap) {\n var singleAxisModel = seriesModel.getReferringComponents('singleAxis')[0];\n result.coordSysDims = ['single'];\n axisMap.set('single', singleAxisModel);\n\n if (isCategory(singleAxisModel)) {\n categoryAxisMap.set('single', singleAxisModel);\n result.firstCategoryDimIndex = 0;\n }\n },\n polar: function (seriesModel, result, axisMap, categoryAxisMap) {\n var polarModel = seriesModel.getReferringComponents('polar')[0];\n var radiusAxisModel = polarModel.findAxisModel('radiusAxis');\n var angleAxisModel = polarModel.findAxisModel('angleAxis');\n result.coordSysDims = ['radius', 'angle'];\n axisMap.set('radius', radiusAxisModel);\n axisMap.set('angle', angleAxisModel);\n\n if (isCategory(radiusAxisModel)) {\n categoryAxisMap.set('radius', radiusAxisModel);\n result.firstCategoryDimIndex = 0;\n }\n\n if (isCategory(angleAxisModel)) {\n categoryAxisMap.set('angle', angleAxisModel);\n result.firstCategoryDimIndex = 1;\n }\n },\n geo: function (seriesModel, result, axisMap, categoryAxisMap) {\n result.coordSysDims = ['lng', 'lat'];\n },\n parallel: function (seriesModel, result, axisMap, categoryAxisMap) {\n var ecModel = seriesModel.ecModel;\n var parallelModel = ecModel.getComponent('parallel', seriesModel.get('parallelIndex'));\n var coordSysDims = result.coordSysDims = parallelModel.dimensions.slice();\n each(parallelModel.parallelAxisIndex, function (axisIndex, index) {\n var axisModel = ecModel.getComponent('parallelAxis', axisIndex);\n var axisDim = coordSysDims[index];\n axisMap.set(axisDim, axisModel);\n\n if (isCategory(axisModel) && result.firstCategoryDimIndex == null) {\n categoryAxisMap.set(axisDim, axisModel);\n result.firstCategoryDimIndex = index;\n }\n });\n }\n};\n\nfunction isCategory(axisModel) {\n return axisModel.get('type') === 'category';\n}\n\nexports.getCoordSysDefineBySeries = getCoordSysDefineBySeries;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Scale = require(\"./Scale\");\n\nvar numberUtil = require(\"../util/number\");\n\nvar IntervalScale = require(\"./Interval\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Log scale\n * @module echarts/scale/Log\n */\n// Use some method of IntervalScale\nvar scaleProto = Scale.prototype;\nvar intervalScaleProto = IntervalScale.prototype;\nvar getPrecisionSafe = numberUtil.getPrecisionSafe;\nvar roundingErrorFix = numberUtil.round;\nvar mathFloor = Math.floor;\nvar mathCeil = Math.ceil;\nvar mathPow = Math.pow;\nvar mathLog = Math.log;\nvar LogScale = Scale.extend({\n type: 'log',\n base: 10,\n $constructor: function () {\n Scale.apply(this, arguments);\n this._originalScale = new IntervalScale();\n },\n\n /**\n * @return {Array.<number>}\n */\n getTicks: function () {\n var originalScale = this._originalScale;\n var extent = this._extent;\n var originalExtent = originalScale.getExtent();\n return zrUtil.map(intervalScaleProto.getTicks.call(this), function (val) {\n var powVal = numberUtil.round(mathPow(this.base, val)); // Fix #4158\n\n powVal = val === extent[0] && originalScale.__fixMin ? fixRoundingError(powVal, originalExtent[0]) : powVal;\n powVal = val === extent[1] && originalScale.__fixMax ? fixRoundingError(powVal, originalExtent[1]) : powVal;\n return powVal;\n }, this);\n },\n\n /**\n * @param {number} val\n * @return {string}\n */\n getLabel: intervalScaleProto.getLabel,\n\n /**\n * @param {number} val\n * @return {number}\n */\n scale: function (val) {\n val = scaleProto.scale.call(this, val);\n return mathPow(this.base, val);\n },\n\n /**\n * @param {number} start\n * @param {number} end\n */\n setExtent: function (start, end) {\n var base = this.base;\n start = mathLog(start) / mathLog(base);\n end = mathLog(end) / mathLog(base);\n intervalScaleProto.setExtent.call(this, start, end);\n },\n\n /**\n * @return {number} end\n */\n getExtent: function () {\n var base = this.base;\n var extent = scaleProto.getExtent.call(this);\n extent[0] = mathPow(base, extent[0]);\n extent[1] = mathPow(base, extent[1]); // Fix #4158\n\n var originalScale = this._originalScale;\n var originalExtent = originalScale.getExtent();\n originalScale.__fixMin && (extent[0] = fixRoundingError(extent[0], originalExtent[0]));\n originalScale.__fixMax && (extent[1] = fixRoundingError(extent[1], originalExtent[1]));\n return extent;\n },\n\n /**\n * @param {Array.<number>} extent\n */\n unionExtent: function (extent) {\n this._originalScale.unionExtent(extent);\n\n var base = this.base;\n extent[0] = mathLog(extent[0]) / mathLog(base);\n extent[1] = mathLog(extent[1]) / mathLog(base);\n scaleProto.unionExtent.call(this, extent);\n },\n\n /**\n * @override\n */\n unionExtentFromData: function (data, dim) {\n // TODO\n // filter value that <= 0\n this.unionExtent(data.getApproximateExtent(dim));\n },\n\n /**\n * Update interval and extent of intervals for nice ticks\n * @param {number} [approxTickNum = 10] Given approx tick number\n */\n niceTicks: function (approxTickNum) {\n approxTickNum = approxTickNum || 10;\n var extent = this._extent;\n var span = extent[1] - extent[0];\n\n if (span === Infinity || span <= 0) {\n return;\n }\n\n var interval = numberUtil.quantity(span);\n var err = approxTickNum / span * interval; // Filter ticks to get closer to the desired count.\n\n if (err <= 0.5) {\n interval *= 10;\n } // Interval should be integer\n\n\n while (!isNaN(interval) && Math.abs(interval) < 1 && Math.abs(interval) > 0) {\n interval *= 10;\n }\n\n var niceExtent = [numberUtil.round(mathCeil(extent[0] / interval) * interval), numberUtil.round(mathFloor(extent[1] / interval) * interval)];\n this._interval = interval;\n this._niceExtent = niceExtent;\n },\n\n /**\n * Nice extent.\n * @override\n */\n niceExtent: function (opt) {\n intervalScaleProto.niceExtent.call(this, opt);\n var originalScale = this._originalScale;\n originalScale.__fixMin = opt.fixMin;\n originalScale.__fixMax = opt.fixMax;\n }\n});\nzrUtil.each(['contain', 'normalize'], function (methodName) {\n LogScale.prototype[methodName] = function (val) {\n val = mathLog(val) / mathLog(this.base);\n return scaleProto[methodName].call(this, val);\n };\n});\n\nLogScale.create = function () {\n return new LogScale();\n};\n\nfunction fixRoundingError(val, originalVal) {\n return roundingErrorFix(val, getPrecisionSafe(originalVal));\n}\n\nvar _default = LogScale;\nmodule.exports = _default;","var Path = require(\"../Path\");\n\n/**\n * 圆弧\n * @module zrender/graphic/shape/Arc\n */\nvar _default = Path.extend({\n type: 'arc',\n shape: {\n cx: 0,\n cy: 0,\n r: 0,\n startAngle: 0,\n endAngle: Math.PI * 2,\n clockwise: true\n },\n style: {\n stroke: '#000',\n fill: null\n },\n buildPath: function (ctx, shape) {\n var x = shape.cx;\n var y = shape.cy;\n var r = Math.max(shape.r, 0);\n var startAngle = shape.startAngle;\n var endAngle = shape.endAngle;\n var clockwise = shape.clockwise;\n var unitX = Math.cos(startAngle);\n var unitY = Math.sin(startAngle);\n ctx.moveTo(unitX * r + x, unitY * r + y);\n ctx.arc(x, y, r, startAngle, endAngle, !clockwise);\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar createHashMap = _util.createHashMap;\nvar isObject = _util.isObject;\nvar map = _util.map;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @constructor\n * @param {Object} [opt]\n * @param {Object} [opt.categories=[]]\n * @param {Object} [opt.needCollect=false]\n * @param {Object} [opt.deduplication=false]\n */\nfunction OrdinalMeta(opt) {\n /**\n * @readOnly\n * @type {Array.<string>}\n */\n this.categories = opt.categories || [];\n /**\n * @private\n * @type {boolean}\n */\n\n this._needCollect = opt.needCollect;\n /**\n * @private\n * @type {boolean}\n */\n\n this._deduplication = opt.deduplication;\n /**\n * @private\n * @type {boolean}\n */\n\n this._map;\n}\n/**\n * @param {module:echarts/model/Model} axisModel\n * @return {module:echarts/data/OrdinalMeta}\n */\n\n\nOrdinalMeta.createByAxisModel = function (axisModel) {\n var option = axisModel.option;\n var data = option.data;\n var categories = data && map(data, getName);\n return new OrdinalMeta({\n categories: categories,\n needCollect: !categories,\n // deduplication is default in axis.\n deduplication: option.dedplication !== false\n });\n};\n\nvar proto = OrdinalMeta.prototype;\n/**\n * @param {string} category\n * @return {number} ordinal\n */\n\nproto.getOrdinal = function (category) {\n return getOrCreateMap(this).get(category);\n};\n/**\n * @param {*} category\n * @return {number} The ordinal. If not found, return NaN.\n */\n\n\nproto.parseAndCollect = function (category) {\n var index;\n var needCollect = this._needCollect; // The value of category dim can be the index of the given category set.\n // This feature is only supported when !needCollect, because we should\n // consider a common case: a value is 2017, which is a number but is\n // expected to be tread as a category. This case usually happen in dataset,\n // where it happent to be no need of the index feature.\n\n if (typeof category !== 'string' && !needCollect) {\n return category;\n } // Optimize for the scenario:\n // category is ['2012-01-01', '2012-01-02', ...], where the input\n // data has been ensured not duplicate and is large data.\n // Notice, if a dataset dimension provide categroies, usually echarts\n // should remove duplication except user tell echarts dont do that\n // (set axis.deduplication = false), because echarts do not know whether\n // the values in the category dimension has duplication (consider the\n // parallel-aqi example)\n\n\n if (needCollect && !this._deduplication) {\n index = this.categories.length;\n this.categories[index] = category;\n return index;\n }\n\n var map = getOrCreateMap(this);\n index = map.get(category);\n\n if (index == null) {\n if (needCollect) {\n index = this.categories.length;\n this.categories[index] = category;\n map.set(category, index);\n } else {\n index = NaN;\n }\n }\n\n return index;\n}; // Consider big data, do not create map until needed.\n\n\nfunction getOrCreateMap(ordinalMeta) {\n return ordinalMeta._map || (ordinalMeta._map = createHashMap(ordinalMeta.categories));\n}\n\nfunction getName(obj) {\n if (isObject(obj) && obj.value != null) {\n return obj.value;\n } else {\n return obj + '';\n }\n}\n\nvar _default = OrdinalMeta;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nrequire(\"./AxisModel\");\n\nvar ComponentModel = require(\"../../model/Component\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// Grid 是在有直角坐标系的时候必须要存在的\n// 所以这里也要被 Cartesian2D 依赖\nvar _default = ComponentModel.extend({\n type: 'grid',\n dependencies: ['xAxis', 'yAxis'],\n layoutMode: 'box',\n\n /**\n * @type {module:echarts/coord/cartesian/Grid}\n */\n coordinateSystem: null,\n defaultOption: {\n show: false,\n zlevel: 0,\n z: 0,\n left: '10%',\n top: 60,\n right: '10%',\n bottom: 60,\n // If grid size contain label\n containLabel: false,\n // width: {totalWidth} - left - right,\n // height: {totalHeight} - top - bottom,\n backgroundColor: 'rgba(0,0,0,0)',\n borderWidth: 1,\n borderColor: '#ccc'\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Axis = require(\"../Axis\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nfunction RadiusAxis(scale, radiusExtent) {\n Axis.call(this, 'radius', scale, radiusExtent);\n /**\n * Axis type\n * - 'category'\n * - 'value'\n * - 'time'\n * - 'log'\n * @type {string}\n */\n\n this.type = 'category';\n}\n\nRadiusAxis.prototype = {\n constructor: RadiusAxis,\n\n /**\n * @override\n */\n pointToData: function (point, clamp) {\n return this.polar.pointToData(point, clamp)[this.dim === 'radius' ? 0 : 1];\n },\n dataToRadius: Axis.prototype.dataToCoord,\n radiusToData: Axis.prototype.coordToData\n};\nzrUtil.inherits(RadiusAxis, Axis);\nvar _default = RadiusAxis;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// Avoid typo.\nvar SOURCE_FORMAT_ORIGINAL = 'original';\nvar SOURCE_FORMAT_ARRAY_ROWS = 'arrayRows';\nvar SOURCE_FORMAT_OBJECT_ROWS = 'objectRows';\nvar SOURCE_FORMAT_KEYED_COLUMNS = 'keyedColumns';\nvar SOURCE_FORMAT_UNKNOWN = 'unknown'; // ??? CHANGE A NAME\n\nvar SOURCE_FORMAT_TYPED_ARRAY = 'typedArray';\nvar SERIES_LAYOUT_BY_COLUMN = 'column';\nvar SERIES_LAYOUT_BY_ROW = 'row';\nexports.SOURCE_FORMAT_ORIGINAL = SOURCE_FORMAT_ORIGINAL;\nexports.SOURCE_FORMAT_ARRAY_ROWS = SOURCE_FORMAT_ARRAY_ROWS;\nexports.SOURCE_FORMAT_OBJECT_ROWS = SOURCE_FORMAT_OBJECT_ROWS;\nexports.SOURCE_FORMAT_KEYED_COLUMNS = SOURCE_FORMAT_KEYED_COLUMNS;\nexports.SOURCE_FORMAT_UNKNOWN = SOURCE_FORMAT_UNKNOWN;\nexports.SOURCE_FORMAT_TYPED_ARRAY = SOURCE_FORMAT_TYPED_ARRAY;\nexports.SERIES_LAYOUT_BY_COLUMN = SERIES_LAYOUT_BY_COLUMN;\nexports.SERIES_LAYOUT_BY_ROW = SERIES_LAYOUT_BY_ROW;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar numberUtil = require(\"../util/number\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * For testable.\n */\nvar roundNumber = numberUtil.round;\n/**\n * @param {Array.<number>} extent Both extent[0] and extent[1] should be valid number.\n * Should be extent[0] < extent[1].\n * @param {number} splitNumber splitNumber should be >= 1.\n * @param {number} [minInterval]\n * @param {number} [maxInterval]\n * @return {Object} {interval, intervalPrecision, niceTickExtent}\n */\n\nfunction intervalScaleNiceTicks(extent, splitNumber, minInterval, maxInterval) {\n var result = {};\n var span = extent[1] - extent[0];\n var interval = result.interval = numberUtil.nice(span / splitNumber, true);\n\n if (minInterval != null && interval < minInterval) {\n interval = result.interval = minInterval;\n }\n\n if (maxInterval != null && interval > maxInterval) {\n interval = result.interval = maxInterval;\n } // Tow more digital for tick.\n\n\n var precision = result.intervalPrecision = getIntervalPrecision(interval); // Niced extent inside original extent\n\n var niceTickExtent = result.niceTickExtent = [roundNumber(Math.ceil(extent[0] / interval) * interval, precision), roundNumber(Math.floor(extent[1] / interval) * interval, precision)];\n fixExtent(niceTickExtent, extent);\n return result;\n}\n/**\n * @param {number} interval\n * @return {number} interval precision\n */\n\n\nfunction getIntervalPrecision(interval) {\n // Tow more digital for tick.\n return numberUtil.getPrecisionSafe(interval) + 2;\n}\n\nfunction clamp(niceTickExtent, idx, extent) {\n niceTickExtent[idx] = Math.max(Math.min(niceTickExtent[idx], extent[1]), extent[0]);\n} // In some cases (e.g., splitNumber is 1), niceTickExtent may be out of extent.\n\n\nfunction fixExtent(niceTickExtent, extent) {\n !isFinite(niceTickExtent[0]) && (niceTickExtent[0] = extent[0]);\n !isFinite(niceTickExtent[1]) && (niceTickExtent[1] = extent[1]);\n clamp(niceTickExtent, 0, extent);\n clamp(niceTickExtent, 1, extent);\n\n if (niceTickExtent[0] > niceTickExtent[1]) {\n niceTickExtent[0] = niceTickExtent[1];\n }\n}\n\nfunction intervalScaleGetTicks(interval, extent, niceTickExtent, intervalPrecision) {\n var ticks = []; // If interval is 0, return [];\n\n if (!interval) {\n return ticks;\n } // Consider this case: using dataZoom toolbox, zoom and zoom.\n\n\n var safeLimit = 10000;\n\n if (extent[0] < niceTickExtent[0]) {\n ticks.push(extent[0]);\n }\n\n var tick = niceTickExtent[0];\n\n while (tick <= niceTickExtent[1]) {\n ticks.push(tick); // Avoid rounding error\n\n tick = roundNumber(tick + interval, intervalPrecision);\n\n if (tick === ticks[ticks.length - 1]) {\n // Consider out of safe float point, e.g.,\n // -3711126.9907707 + 2e-10 === -3711126.9907707\n break;\n }\n\n if (ticks.length > safeLimit) {\n return [];\n }\n } // Consider this case: the last item of ticks is smaller\n // than niceTickExtent[1] and niceTickExtent[1] === extent[1].\n\n\n if (extent[1] > (ticks.length ? ticks[ticks.length - 1] : niceTickExtent[1])) {\n ticks.push(extent[1]);\n }\n\n return ticks;\n}\n\nexports.intervalScaleNiceTicks = intervalScaleNiceTicks;\nexports.getIntervalPrecision = getIntervalPrecision;\nexports.fixExtent = fixExtent;\nexports.intervalScaleGetTicks = intervalScaleGetTicks;","/**\n * 线段包含判断\n * @param {number} x0\n * @param {number} y0\n * @param {number} x1\n * @param {number} y1\n * @param {number} lineWidth\n * @param {number} x\n * @param {number} y\n * @return {boolean}\n */\nfunction containStroke(x0, y0, x1, y1, lineWidth, x, y) {\n if (lineWidth === 0) {\n return false;\n }\n\n var _l = lineWidth;\n var _a = 0;\n var _b = x0; // Quick reject\n\n if (y > y0 + _l && y > y1 + _l || y < y0 - _l && y < y1 - _l || x > x0 + _l && x > x1 + _l || x < x0 - _l && x < x1 - _l) {\n return false;\n }\n\n if (x0 !== x1) {\n _a = (y0 - y1) / (x0 - x1);\n _b = (x0 * y1 - x1 * y0) / (x0 - x1);\n } else {\n return Math.abs(x - x0) <= _l / 2;\n }\n\n var tmp = _a * x - y + _b;\n\n var _s = tmp * tmp / (_a * _a + 1);\n\n return _s <= _l / 2 * _l / 2;\n}\n\nexports.containStroke = containStroke;","var vec2 = require(\"./vector\");\n\nvar matrix = require(\"./matrix\");\n\n/**\n * @module echarts/core/BoundingRect\n */\nvar v2ApplyTransform = vec2.applyTransform;\nvar mathMin = Math.min;\nvar mathMax = Math.max;\n/**\n * @alias module:echarts/core/BoundingRect\n */\n\nfunction BoundingRect(x, y, width, height) {\n if (width < 0) {\n x = x + width;\n width = -width;\n }\n\n if (height < 0) {\n y = y + height;\n height = -height;\n }\n /**\n * @type {number}\n */\n\n\n this.x = x;\n /**\n * @type {number}\n */\n\n this.y = y;\n /**\n * @type {number}\n */\n\n this.width = width;\n /**\n * @type {number}\n */\n\n this.height = height;\n}\n\nBoundingRect.prototype = {\n constructor: BoundingRect,\n\n /**\n * @param {module:echarts/core/BoundingRect} other\n */\n union: function (other) {\n var x = mathMin(other.x, this.x);\n var y = mathMin(other.y, this.y);\n this.width = mathMax(other.x + other.width, this.x + this.width) - x;\n this.height = mathMax(other.y + other.height, this.y + this.height) - y;\n this.x = x;\n this.y = y;\n },\n\n /**\n * @param {Array.<number>} m\n * @methods\n */\n applyTransform: function () {\n var lt = [];\n var rb = [];\n var lb = [];\n var rt = [];\n return function (m) {\n // In case usage like this\n // el.getBoundingRect().applyTransform(el.transform)\n // And element has no transform\n if (!m) {\n return;\n }\n\n lt[0] = lb[0] = this.x;\n lt[1] = rt[1] = this.y;\n rb[0] = rt[0] = this.x + this.width;\n rb[1] = lb[1] = this.y + this.height;\n v2ApplyTransform(lt, lt, m);\n v2ApplyTransform(rb, rb, m);\n v2ApplyTransform(lb, lb, m);\n v2ApplyTransform(rt, rt, m);\n this.x = mathMin(lt[0], rb[0], lb[0], rt[0]);\n this.y = mathMin(lt[1], rb[1], lb[1], rt[1]);\n var maxX = mathMax(lt[0], rb[0], lb[0], rt[0]);\n var maxY = mathMax(lt[1], rb[1], lb[1], rt[1]);\n this.width = maxX - this.x;\n this.height = maxY - this.y;\n };\n }(),\n\n /**\n * Calculate matrix of transforming from self to target rect\n * @param {module:zrender/core/BoundingRect} b\n * @return {Array.<number>}\n */\n calculateTransform: function (b) {\n var a = this;\n var sx = b.width / a.width;\n var sy = b.height / a.height;\n var m = matrix.create(); // 矩阵右乘\n\n matrix.translate(m, m, [-a.x, -a.y]);\n matrix.scale(m, m, [sx, sy]);\n matrix.translate(m, m, [b.x, b.y]);\n return m;\n },\n\n /**\n * @param {(module:echarts/core/BoundingRect|Object)} b\n * @return {boolean}\n */\n intersect: function (b) {\n if (!b) {\n return false;\n }\n\n if (!(b instanceof BoundingRect)) {\n // Normalize negative width/height.\n b = BoundingRect.create(b);\n }\n\n var a = this;\n var ax0 = a.x;\n var ax1 = a.x + a.width;\n var ay0 = a.y;\n var ay1 = a.y + a.height;\n var bx0 = b.x;\n var bx1 = b.x + b.width;\n var by0 = b.y;\n var by1 = b.y + b.height;\n return !(ax1 < bx0 || bx1 < ax0 || ay1 < by0 || by1 < ay0);\n },\n contain: function (x, y) {\n var rect = this;\n return x >= rect.x && x <= rect.x + rect.width && y >= rect.y && y <= rect.y + rect.height;\n },\n\n /**\n * @return {module:echarts/core/BoundingRect}\n */\n clone: function () {\n return new BoundingRect(this.x, this.y, this.width, this.height);\n },\n\n /**\n * Copy from another rect\n */\n copy: function (other) {\n this.x = other.x;\n this.y = other.y;\n this.width = other.width;\n this.height = other.height;\n },\n plain: function () {\n return {\n x: this.x,\n y: this.y,\n width: this.width,\n height: this.height\n };\n }\n};\n/**\n * @param {Object|module:zrender/core/BoundingRect} rect\n * @param {number} rect.x\n * @param {number} rect.y\n * @param {number} rect.width\n * @param {number} rect.height\n * @return {module:zrender/core/BoundingRect}\n */\n\nBoundingRect.create = function (rect) {\n return new BoundingRect(rect.x, rect.y, rect.width, rect.height);\n};\n\nvar _default = BoundingRect;\nmodule.exports = _default;","var _default = typeof window !== 'undefined' && (window.requestAnimationFrame && window.requestAnimationFrame.bind(window) || // https://github.com/ecomfe/zrender/issues/189#issuecomment-224919809\nwindow.msRequestAnimationFrame && window.msRequestAnimationFrame.bind(window) || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame) || function (func) {\n setTimeout(func, 16);\n};\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar graphic = require(\"../util/graphic\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar PI = Math.PI;\n/**\n * @param {module:echarts/ExtensionAPI} api\n * @param {Object} [opts]\n * @param {string} [opts.text]\n * @param {string} [opts.color]\n * @param {string} [opts.textColor]\n * @return {module:zrender/Element}\n */\n\nfunction _default(api, opts) {\n opts = opts || {};\n zrUtil.defaults(opts, {\n text: 'loading',\n color: '#c23531',\n textColor: '#000',\n maskColor: 'rgba(255, 255, 255, 0.8)',\n zlevel: 0\n });\n var mask = new graphic.Rect({\n style: {\n fill: opts.maskColor\n },\n zlevel: opts.zlevel,\n z: 10000\n });\n var arc = new graphic.Arc({\n shape: {\n startAngle: -PI / 2,\n endAngle: -PI / 2 + 0.1,\n r: 10\n },\n style: {\n stroke: opts.color,\n lineCap: 'round',\n lineWidth: 5\n },\n zlevel: opts.zlevel,\n z: 10001\n });\n var labelRect = new graphic.Rect({\n style: {\n fill: 'none',\n text: opts.text,\n textPosition: 'right',\n textDistance: 10,\n textFill: opts.textColor\n },\n zlevel: opts.zlevel,\n z: 10001\n });\n arc.animateShape(true).when(1000, {\n endAngle: PI * 3 / 2\n }).start('circularInOut');\n arc.animateShape(true).when(1000, {\n startAngle: PI * 3 / 2\n }).delay(300).start('circularInOut');\n var group = new graphic.Group();\n group.add(arc);\n group.add(labelRect);\n group.add(mask); // Inject resize\n\n group.resize = function () {\n var cx = api.getWidth() / 2;\n var cy = api.getHeight() / 2;\n arc.setShape({\n cx: cx,\n cy: cy\n });\n var r = arc.shape.r;\n labelRect.setShape({\n x: cx - r,\n y: cy - r,\n width: r * 2,\n height: r * 2\n });\n mask.setShape({\n x: 0,\n y: 0,\n width: api.getWidth(),\n height: api.getHeight()\n });\n };\n\n group.resize();\n return group;\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar makeStyleMapper = require(\"./makeStyleMapper\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar getAreaStyle = makeStyleMapper([['fill', 'color'], ['shadowBlur'], ['shadowOffsetX'], ['shadowOffsetY'], ['opacity'], ['shadowColor']]);\nvar _default = {\n getAreaStyle: function (excludes, includes) {\n return getAreaStyle(this, excludes, includes);\n }\n};\nmodule.exports = _default;","var _vector = require(\"../../core/vector\");\n\nvar v2Min = _vector.min;\nvar v2Max = _vector.max;\nvar v2Scale = _vector.scale;\nvar v2Distance = _vector.distance;\nvar v2Add = _vector.add;\nvar v2Clone = _vector.clone;\nvar v2Sub = _vector.sub;\n\n/**\n * 贝塞尔平滑曲线\n * @module zrender/shape/util/smoothBezier\n * @author pissang (https://www.github.com/pissang)\n * Kener (@Kener-林峰, kener.linfeng@gmail.com)\n * errorrik (errorrik@gmail.com)\n */\n\n/**\n * 贝塞尔平滑曲线\n * @alias module:zrender/shape/util/smoothBezier\n * @param {Array} points 线段顶点数组\n * @param {number} smooth 平滑等级, 0-1\n * @param {boolean} isLoop\n * @param {Array} constraint 将计算出来的控制点约束在一个包围盒内\n * 比如 [[0, 0], [100, 100]], 这个包围盒会与\n * 整个折线的包围盒做一个并集用来约束控制点。\n * @param {Array} 计算出来的控制点数组\n */\nfunction _default(points, smooth, isLoop, constraint) {\n var cps = [];\n var v = [];\n var v1 = [];\n var v2 = [];\n var prevPoint;\n var nextPoint;\n var min;\n var max;\n\n if (constraint) {\n min = [Infinity, Infinity];\n max = [-Infinity, -Infinity];\n\n for (var i = 0, len = points.length; i < len; i++) {\n v2Min(min, min, points[i]);\n v2Max(max, max, points[i]);\n } // 与指定的包围盒做并集\n\n\n v2Min(min, min, constraint[0]);\n v2Max(max, max, constraint[1]);\n }\n\n for (var i = 0, len = points.length; i < len; i++) {\n var point = points[i];\n\n if (isLoop) {\n prevPoint = points[i ? i - 1 : len - 1];\n nextPoint = points[(i + 1) % len];\n } else {\n if (i === 0 || i === len - 1) {\n cps.push(v2Clone(points[i]));\n continue;\n } else {\n prevPoint = points[i - 1];\n nextPoint = points[i + 1];\n }\n }\n\n v2Sub(v, nextPoint, prevPoint); // use degree to scale the handle length\n\n v2Scale(v, v, smooth);\n var d0 = v2Distance(point, prevPoint);\n var d1 = v2Distance(point, nextPoint);\n var sum = d0 + d1;\n\n if (sum !== 0) {\n d0 /= sum;\n d1 /= sum;\n }\n\n v2Scale(v1, v, -d0);\n v2Scale(v2, v, d1);\n var cp0 = v2Add([], point, v1);\n var cp1 = v2Add([], point, v2);\n\n if (constraint) {\n v2Max(cp0, cp0, min);\n v2Min(cp0, cp0, max);\n v2Max(cp1, cp1, min);\n v2Min(cp1, cp1, max);\n }\n\n cps.push(cp0);\n cps.push(cp1);\n }\n\n if (isLoop) {\n cps.push(cps.shift());\n }\n\n return cps;\n}\n\nmodule.exports = _default;","/**\n * Sub-pixel optimize for canvas rendering, prevent from blur\n * when rendering a thin vertical/horizontal line.\n */\nvar round = Math.round;\n/**\n * Sub pixel optimize line for canvas\n *\n * @param {Object} outputShape The modification will be performed on `outputShape`.\n * `outputShape` and `inputShape` can be the same object.\n * `outputShape` object can be used repeatly, because all of\n * the `x1`, `x2`, `y1`, `y2` will be assigned in this method.\n * @param {Object} [inputShape]\n * @param {number} [inputShape.x1]\n * @param {number} [inputShape.y1]\n * @param {number} [inputShape.x2]\n * @param {number} [inputShape.y2]\n * @param {Object} [style]\n * @param {number} [style.lineWidth]\n */\n\nfunction subPixelOptimizeLine(outputShape, inputShape, style) {\n var lineWidth = style && style.lineWidth;\n\n if (!inputShape || !lineWidth) {\n return;\n }\n\n var x1 = inputShape.x1;\n var x2 = inputShape.x2;\n var y1 = inputShape.y1;\n var y2 = inputShape.y2;\n\n if (round(x1 * 2) === round(x2 * 2)) {\n outputShape.x1 = outputShape.x2 = subPixelOptimize(x1, lineWidth, true);\n } else {\n outputShape.x1 = x1;\n outputShape.x2 = x2;\n }\n\n if (round(y1 * 2) === round(y2 * 2)) {\n outputShape.y1 = outputShape.y2 = subPixelOptimize(y1, lineWidth, true);\n } else {\n outputShape.y1 = y1;\n outputShape.y2 = y2;\n }\n}\n/**\n * Sub pixel optimize rect for canvas\n *\n * @param {Object} outputShape The modification will be performed on `outputShape`.\n * `outputShape` and `inputShape` can be the same object.\n * `outputShape` object can be used repeatly, because all of\n * the `x`, `y`, `width`, `height` will be assigned in this method.\n * @param {Object} [inputShape]\n * @param {number} [inputShape.x]\n * @param {number} [inputShape.y]\n * @param {number} [inputShape.width]\n * @param {number} [inputShape.height]\n * @param {Object} [style]\n * @param {number} [style.lineWidth]\n */\n\n\nfunction subPixelOptimizeRect(outputShape, inputShape, style) {\n var lineWidth = style && style.lineWidth;\n\n if (!inputShape || !lineWidth) {\n return;\n }\n\n var originX = inputShape.x;\n var originY = inputShape.y;\n var originWidth = inputShape.width;\n var originHeight = inputShape.height;\n outputShape.x = subPixelOptimize(originX, lineWidth, true);\n outputShape.y = subPixelOptimize(originY, lineWidth, true);\n outputShape.width = Math.max(subPixelOptimize(originX + originWidth, lineWidth, false) - outputShape.x, originWidth === 0 ? 0 : 1);\n outputShape.height = Math.max(subPixelOptimize(originY + originHeight, lineWidth, false) - outputShape.y, originHeight === 0 ? 0 : 1);\n}\n/**\n * Sub pixel optimize for canvas\n *\n * @param {number} position Coordinate, such as x, y\n * @param {number} lineWidth Should be nonnegative integer.\n * @param {boolean=} positiveOrNegative Default false (negative).\n * @return {number} Optimized position.\n */\n\n\nfunction subPixelOptimize(position, lineWidth, positiveOrNegative) {\n // Assure that (position + lineWidth / 2) is near integer edge,\n // otherwise line will be fuzzy in canvas.\n var doubledPosition = round(position * 2);\n return (doubledPosition + round(lineWidth)) % 2 === 0 ? doubledPosition / 2 : (doubledPosition + (positiveOrNegative ? 1 : -1)) / 2;\n}\n\nexports.subPixelOptimizeLine = subPixelOptimizeLine;\nexports.subPixelOptimizeRect = subPixelOptimizeRect;\nexports.subPixelOptimize = subPixelOptimize;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar _number = require(\"../util/number\");\n\nvar parsePercent = _number.parsePercent;\n\nvar _dataStackHelper = require(\"../data/helper/dataStackHelper\");\n\nvar isDimensionStacked = _dataStackHelper.isDimensionStacked;\n\nvar createRenderPlanner = require(\"../chart/helper/createRenderPlanner\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/* global Float32Array */\nvar STACK_PREFIX = '__ec_stack_';\nvar LARGE_BAR_MIN_WIDTH = 0.5;\nvar LargeArr = typeof Float32Array !== 'undefined' ? Float32Array : Array;\n\nfunction getSeriesStackId(seriesModel) {\n return seriesModel.get('stack') || STACK_PREFIX + seriesModel.seriesIndex;\n}\n\nfunction getAxisKey(axis) {\n return axis.dim + axis.index;\n}\n/**\n * @param {Object} opt\n * @param {module:echarts/coord/Axis} opt.axis Only support category axis currently.\n * @param {number} opt.count Positive interger.\n * @param {number} [opt.barWidth]\n * @param {number} [opt.barMaxWidth]\n * @param {number} [opt.barGap]\n * @param {number} [opt.barCategoryGap]\n * @return {Object} {width, offset, offsetCenter} If axis.type is not 'category', return undefined.\n */\n\n\nfunction getLayoutOnAxis(opt) {\n var params = [];\n var baseAxis = opt.axis;\n var axisKey = 'axis0';\n\n if (baseAxis.type !== 'category') {\n return;\n }\n\n var bandWidth = baseAxis.getBandWidth();\n\n for (var i = 0; i < opt.count || 0; i++) {\n params.push(zrUtil.defaults({\n bandWidth: bandWidth,\n axisKey: axisKey,\n stackId: STACK_PREFIX + i\n }, opt));\n }\n\n var widthAndOffsets = doCalBarWidthAndOffset(params);\n var result = [];\n\n for (var i = 0; i < opt.count; i++) {\n var item = widthAndOffsets[axisKey][STACK_PREFIX + i];\n item.offsetCenter = item.offset + item.width / 2;\n result.push(item);\n }\n\n return result;\n}\n\nfunction prepareLayoutBarSeries(seriesType, ecModel) {\n var seriesModels = [];\n ecModel.eachSeriesByType(seriesType, function (seriesModel) {\n // Check series coordinate, do layout for cartesian2d only\n if (isOnCartesian(seriesModel) && !isInLargeMode(seriesModel)) {\n seriesModels.push(seriesModel);\n }\n });\n return seriesModels;\n}\n\nfunction makeColumnLayout(barSeries) {\n var seriesInfoList = [];\n zrUtil.each(barSeries, function (seriesModel) {\n var data = seriesModel.getData();\n var cartesian = seriesModel.coordinateSystem;\n var baseAxis = cartesian.getBaseAxis();\n var axisExtent = baseAxis.getExtent();\n var bandWidth = baseAxis.type === 'category' ? baseAxis.getBandWidth() : Math.abs(axisExtent[1] - axisExtent[0]) / data.count();\n var barWidth = parsePercent(seriesModel.get('barWidth'), bandWidth);\n var barMaxWidth = parsePercent(seriesModel.get('barMaxWidth'), bandWidth);\n var barGap = seriesModel.get('barGap');\n var barCategoryGap = seriesModel.get('barCategoryGap');\n seriesInfoList.push({\n bandWidth: bandWidth,\n barWidth: barWidth,\n barMaxWidth: barMaxWidth,\n barGap: barGap,\n barCategoryGap: barCategoryGap,\n axisKey: getAxisKey(baseAxis),\n stackId: getSeriesStackId(seriesModel)\n });\n });\n return doCalBarWidthAndOffset(seriesInfoList);\n}\n\nfunction doCalBarWidthAndOffset(seriesInfoList) {\n // Columns info on each category axis. Key is cartesian name\n var columnsMap = {};\n zrUtil.each(seriesInfoList, function (seriesInfo, idx) {\n var axisKey = seriesInfo.axisKey;\n var bandWidth = seriesInfo.bandWidth;\n var columnsOnAxis = columnsMap[axisKey] || {\n bandWidth: bandWidth,\n remainedWidth: bandWidth,\n autoWidthCount: 0,\n categoryGap: '20%',\n gap: '30%',\n stacks: {}\n };\n var stacks = columnsOnAxis.stacks;\n columnsMap[axisKey] = columnsOnAxis;\n var stackId = seriesInfo.stackId;\n\n if (!stacks[stackId]) {\n columnsOnAxis.autoWidthCount++;\n }\n\n stacks[stackId] = stacks[stackId] || {\n width: 0,\n maxWidth: 0\n }; // Caution: In a single coordinate system, these barGrid attributes\n // will be shared by series. Consider that they have default values,\n // only the attributes set on the last series will work.\n // Do not change this fact unless there will be a break change.\n // TODO\n\n var barWidth = seriesInfo.barWidth;\n\n if (barWidth && !stacks[stackId].width) {\n // See #6312, do not restrict width.\n stacks[stackId].width = barWidth;\n barWidth = Math.min(columnsOnAxis.remainedWidth, barWidth);\n columnsOnAxis.remainedWidth -= barWidth;\n }\n\n var barMaxWidth = seriesInfo.barMaxWidth;\n barMaxWidth && (stacks[stackId].maxWidth = barMaxWidth);\n var barGap = seriesInfo.barGap;\n barGap != null && (columnsOnAxis.gap = barGap);\n var barCategoryGap = seriesInfo.barCategoryGap;\n barCategoryGap != null && (columnsOnAxis.categoryGap = barCategoryGap);\n });\n var result = {};\n zrUtil.each(columnsMap, function (columnsOnAxis, coordSysName) {\n result[coordSysName] = {};\n var stacks = columnsOnAxis.stacks;\n var bandWidth = columnsOnAxis.bandWidth;\n var categoryGap = parsePercent(columnsOnAxis.categoryGap, bandWidth);\n var barGapPercent = parsePercent(columnsOnAxis.gap, 1);\n var remainedWidth = columnsOnAxis.remainedWidth;\n var autoWidthCount = columnsOnAxis.autoWidthCount;\n var autoWidth = (remainedWidth - categoryGap) / (autoWidthCount + (autoWidthCount - 1) * barGapPercent);\n autoWidth = Math.max(autoWidth, 0); // Find if any auto calculated bar exceeded maxBarWidth\n\n zrUtil.each(stacks, function (column, stack) {\n var maxWidth = column.maxWidth;\n\n if (maxWidth && maxWidth < autoWidth) {\n maxWidth = Math.min(maxWidth, remainedWidth);\n\n if (column.width) {\n maxWidth = Math.min(maxWidth, column.width);\n }\n\n remainedWidth -= maxWidth;\n column.width = maxWidth;\n autoWidthCount--;\n }\n }); // Recalculate width again\n\n autoWidth = (remainedWidth - categoryGap) / (autoWidthCount + (autoWidthCount - 1) * barGapPercent);\n autoWidth = Math.max(autoWidth, 0);\n var widthSum = 0;\n var lastColumn;\n zrUtil.each(stacks, function (column, idx) {\n if (!column.width) {\n column.width = autoWidth;\n }\n\n lastColumn = column;\n widthSum += column.width * (1 + barGapPercent);\n });\n\n if (lastColumn) {\n widthSum -= lastColumn.width * barGapPercent;\n }\n\n var offset = -widthSum / 2;\n zrUtil.each(stacks, function (column, stackId) {\n result[coordSysName][stackId] = result[coordSysName][stackId] || {\n offset: offset,\n width: column.width\n };\n offset += column.width * (1 + barGapPercent);\n });\n });\n return result;\n}\n/**\n * @param {Object} barWidthAndOffset The result of makeColumnLayout\n * @param {module:echarts/coord/Axis} axis\n * @param {module:echarts/model/Series} [seriesModel] If not provided, return all.\n * @return {Object} {stackId: {offset, width}} or {offset, width} if seriesModel provided.\n */\n\n\nfunction retrieveColumnLayout(barWidthAndOffset, axis, seriesModel) {\n if (barWidthAndOffset && axis) {\n var result = barWidthAndOffset[getAxisKey(axis)];\n\n if (result != null && seriesModel != null) {\n result = result[getSeriesStackId(seriesModel)];\n }\n\n return result;\n }\n}\n/**\n * @param {string} seriesType\n * @param {module:echarts/model/Global} ecModel\n */\n\n\nfunction layout(seriesType, ecModel) {\n var seriesModels = prepareLayoutBarSeries(seriesType, ecModel);\n var barWidthAndOffset = makeColumnLayout(seriesModels);\n var lastStackCoords = {};\n var lastStackCoordsOrigin = {};\n zrUtil.each(seriesModels, function (seriesModel) {\n var data = seriesModel.getData();\n var cartesian = seriesModel.coordinateSystem;\n var baseAxis = cartesian.getBaseAxis();\n var stackId = getSeriesStackId(seriesModel);\n var columnLayoutInfo = barWidthAndOffset[getAxisKey(baseAxis)][stackId];\n var columnOffset = columnLayoutInfo.offset;\n var columnWidth = columnLayoutInfo.width;\n var valueAxis = cartesian.getOtherAxis(baseAxis);\n var barMinHeight = seriesModel.get('barMinHeight') || 0;\n lastStackCoords[stackId] = lastStackCoords[stackId] || [];\n lastStackCoordsOrigin[stackId] = lastStackCoordsOrigin[stackId] || []; // Fix #4243\n\n data.setLayout({\n offset: columnOffset,\n size: columnWidth\n });\n var valueDim = data.mapDimension(valueAxis.dim);\n var baseDim = data.mapDimension(baseAxis.dim);\n var stacked = isDimensionStacked(data, valueDim\n /*, baseDim*/\n );\n var isValueAxisH = valueAxis.isHorizontal();\n var valueAxisStart = getValueAxisStart(baseAxis, valueAxis, stacked);\n\n for (var idx = 0, len = data.count(); idx < len; idx++) {\n var value = data.get(valueDim, idx);\n var baseValue = data.get(baseDim, idx);\n\n if (isNaN(value)) {\n continue;\n }\n\n var sign = value >= 0 ? 'p' : 'n';\n var baseCoord = valueAxisStart; // Because of the barMinHeight, we can not use the value in\n // stackResultDimension directly.\n\n if (stacked) {\n // Only ordinal axis can be stacked.\n if (!lastStackCoords[stackId][baseValue]) {\n lastStackCoords[stackId][baseValue] = {\n p: valueAxisStart,\n // Positive stack\n n: valueAxisStart // Negative stack\n\n };\n } // Should also consider #4243\n\n\n baseCoord = lastStackCoords[stackId][baseValue][sign];\n }\n\n var x;\n var y;\n var width;\n var height;\n\n if (isValueAxisH) {\n var coord = cartesian.dataToPoint([value, baseValue]);\n x = baseCoord;\n y = coord[1] + columnOffset;\n width = coord[0] - valueAxisStart;\n height = columnWidth;\n\n if (Math.abs(width) < barMinHeight) {\n width = (width < 0 ? -1 : 1) * barMinHeight;\n }\n\n stacked && (lastStackCoords[stackId][baseValue][sign] += width);\n } else {\n var coord = cartesian.dataToPoint([baseValue, value]);\n x = coord[0] + columnOffset;\n y = baseCoord;\n width = columnWidth;\n height = coord[1] - valueAxisStart;\n\n if (Math.abs(height) < barMinHeight) {\n // Include zero to has a positive bar\n height = (height <= 0 ? -1 : 1) * barMinHeight;\n }\n\n stacked && (lastStackCoords[stackId][baseValue][sign] += height);\n }\n\n data.setItemLayout(idx, {\n x: x,\n y: y,\n width: width,\n height: height\n });\n }\n }, this);\n} // TODO: Do not support stack in large mode yet.\n\n\nvar largeLayout = {\n seriesType: 'bar',\n plan: createRenderPlanner(),\n reset: function (seriesModel) {\n if (!isOnCartesian(seriesModel) || !isInLargeMode(seriesModel)) {\n return;\n }\n\n var data = seriesModel.getData();\n var cartesian = seriesModel.coordinateSystem;\n var baseAxis = cartesian.getBaseAxis();\n var valueAxis = cartesian.getOtherAxis(baseAxis);\n var valueDim = data.mapDimension(valueAxis.dim);\n var baseDim = data.mapDimension(baseAxis.dim);\n var valueAxisHorizontal = valueAxis.isHorizontal();\n var valueDimIdx = valueAxisHorizontal ? 0 : 1;\n var barWidth = retrieveColumnLayout(makeColumnLayout([seriesModel]), baseAxis, seriesModel).width;\n\n if (!(barWidth > LARGE_BAR_MIN_WIDTH)) {\n // jshint ignore:line\n barWidth = LARGE_BAR_MIN_WIDTH;\n }\n\n return {\n progress: progress\n };\n\n function progress(params, data) {\n var largePoints = new LargeArr(params.count * 2);\n var dataIndex;\n var coord = [];\n var valuePair = [];\n var offset = 0;\n\n while ((dataIndex = params.next()) != null) {\n valuePair[valueDimIdx] = data.get(valueDim, dataIndex);\n valuePair[1 - valueDimIdx] = data.get(baseDim, dataIndex);\n coord = cartesian.dataToPoint(valuePair, null, coord);\n largePoints[offset++] = coord[0];\n largePoints[offset++] = coord[1];\n }\n\n data.setLayout({\n largePoints: largePoints,\n barWidth: barWidth,\n valueAxisStart: getValueAxisStart(baseAxis, valueAxis, false),\n valueAxisHorizontal: valueAxisHorizontal\n });\n }\n }\n};\n\nfunction isOnCartesian(seriesModel) {\n return seriesModel.coordinateSystem && seriesModel.coordinateSystem.type === 'cartesian2d';\n}\n\nfunction isInLargeMode(seriesModel) {\n return seriesModel.pipelineContext && seriesModel.pipelineContext.large;\n} // See cases in `test/bar-start.html` and `#7412`, `#8747`.\n\n\nfunction getValueAxisStart(baseAxis, valueAxis, stacked) {\n var extent = valueAxis.getGlobalExtent();\n var min;\n var max;\n\n if (extent[0] > extent[1]) {\n min = extent[1];\n max = extent[0];\n } else {\n min = extent[0];\n max = extent[1];\n }\n\n var valueStart = valueAxis.toGlobalCoord(valueAxis.dataToCoord(0));\n valueStart < min && (valueStart = min);\n valueStart > max && (valueStart = max);\n return valueStart;\n}\n\nexports.getLayoutOnAxis = getLayoutOnAxis;\nexports.prepareLayoutBarSeries = prepareLayoutBarSeries;\nexports.makeColumnLayout = makeColumnLayout;\nexports.retrieveColumnLayout = retrieveColumnLayout;\nexports.layout = layout;\nexports.largeLayout = largeLayout;","var textHelper = require(\"../helper/text\");\n\nvar BoundingRect = require(\"../../core/BoundingRect\");\n\nvar _constant = require(\"../constant\");\n\nvar WILL_BE_RESTORED = _constant.WILL_BE_RESTORED;\n\n/**\n * Mixin for drawing text in a element bounding rect\n * @module zrender/mixin/RectText\n */\nvar tmpRect = new BoundingRect();\n\nvar RectText = function () {};\n\nRectText.prototype = {\n constructor: RectText,\n\n /**\n * Draw text in a rect with specified position.\n * @param {CanvasRenderingContext2D} ctx\n * @param {Object} rect Displayable rect\n */\n drawRectText: function (ctx, rect) {\n var style = this.style;\n rect = style.textRect || rect; // Optimize, avoid normalize every time.\n\n this.__dirty && textHelper.normalizeTextStyle(style, true);\n var text = style.text; // Convert to string\n\n text != null && (text += '');\n\n if (!textHelper.needDrawText(text, style)) {\n return;\n } // FIXME\n // Do not provide prevEl to `textHelper.renderText` for ctx prop cache,\n // but use `ctx.save()` and `ctx.restore()`. Because the cache for rect\n // text propably break the cache for its host elements.\n\n\n ctx.save(); // Transform rect to view space\n\n var transform = this.transform;\n\n if (!style.transformText) {\n if (transform) {\n tmpRect.copy(rect);\n tmpRect.applyTransform(transform);\n rect = tmpRect;\n }\n } else {\n this.setTransform(ctx);\n } // transformText and textRotation can not be used at the same time.\n\n\n textHelper.renderText(this, ctx, text, style, rect, WILL_BE_RESTORED);\n ctx.restore();\n }\n};\nvar _default = RectText;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar axisDefault = require(\"./axisDefault\");\n\nvar ComponentModel = require(\"../model/Component\");\n\nvar _layout = require(\"../util/layout\");\n\nvar getLayoutParams = _layout.getLayoutParams;\nvar mergeLayoutParam = _layout.mergeLayoutParam;\n\nvar OrdinalMeta = require(\"../data/OrdinalMeta\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// FIXME axisType is fixed ?\nvar AXIS_TYPES = ['value', 'category', 'time', 'log'];\n/**\n * Generate sub axis model class\n * @param {string} axisName 'x' 'y' 'radius' 'angle' 'parallel'\n * @param {module:echarts/model/Component} BaseAxisModelClass\n * @param {Function} axisTypeDefaulter\n * @param {Object} [extraDefaultOption]\n */\n\nfunction _default(axisName, BaseAxisModelClass, axisTypeDefaulter, extraDefaultOption) {\n zrUtil.each(AXIS_TYPES, function (axisType) {\n BaseAxisModelClass.extend({\n /**\n * @readOnly\n */\n type: axisName + 'Axis.' + axisType,\n mergeDefaultAndTheme: function (option, ecModel) {\n var layoutMode = this.layoutMode;\n var inputPositionParams = layoutMode ? getLayoutParams(option) : {};\n var themeModel = ecModel.getTheme();\n zrUtil.merge(option, themeModel.get(axisType + 'Axis'));\n zrUtil.merge(option, this.getDefaultOption());\n option.type = axisTypeDefaulter(axisName, option);\n\n if (layoutMode) {\n mergeLayoutParam(option, inputPositionParams, layoutMode);\n }\n },\n\n /**\n * @override\n */\n optionUpdated: function () {\n var thisOption = this.option;\n\n if (thisOption.type === 'category') {\n this.__ordinalMeta = OrdinalMeta.createByAxisModel(this);\n }\n },\n\n /**\n * Should not be called before all of 'getInitailData' finished.\n * Because categories are collected during initializing data.\n */\n getCategories: function (rawData) {\n var option = this.option; // FIXME\n // warning if called before all of 'getInitailData' finished.\n\n if (option.type === 'category') {\n if (rawData) {\n return option.data;\n }\n\n return this.__ordinalMeta.categories;\n }\n },\n getOrdinalMeta: function () {\n return this.__ordinalMeta;\n },\n defaultOption: zrUtil.mergeAll([{}, axisDefault[axisType + 'Axis'], extraDefaultOption], true)\n });\n });\n ComponentModel.registerSubTypeDefaulter(axisName + 'Axis', zrUtil.curry(axisTypeDefaulter, axisName));\n}\n\nmodule.exports = _default;","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var _util = require(\"./util\");\n\nvar normalizeRadian = _util.normalizeRadian;\nvar PI2 = Math.PI * 2;\n/**\n * 圆弧描边包含判断\n * @param {number} cx\n * @param {number} cy\n * @param {number} r\n * @param {number} startAngle\n * @param {number} endAngle\n * @param {boolean} anticlockwise\n * @param {number} lineWidth\n * @param {number} x\n * @param {number} y\n * @return {Boolean}\n */\n\nfunction containStroke(cx, cy, r, startAngle, endAngle, anticlockwise, lineWidth, x, y) {\n if (lineWidth === 0) {\n return false;\n }\n\n var _l = lineWidth;\n x -= cx;\n y -= cy;\n var d = Math.sqrt(x * x + y * y);\n\n if (d - _l > r || d + _l < r) {\n return false;\n }\n\n if (Math.abs(startAngle - endAngle) % PI2 < 1e-4) {\n // Is a circle\n return true;\n }\n\n if (anticlockwise) {\n var tmp = startAngle;\n startAngle = normalizeRadian(endAngle);\n endAngle = normalizeRadian(tmp);\n } else {\n startAngle = normalizeRadian(startAngle);\n endAngle = normalizeRadian(endAngle);\n }\n\n if (startAngle > endAngle) {\n endAngle += PI2;\n }\n\n var angle = Math.atan2(y, x);\n\n if (angle < 0) {\n angle += PI2;\n }\n\n return angle >= startAngle && angle <= endAngle || angle + PI2 >= startAngle && angle + PI2 <= endAngle;\n}\n\nexports.containStroke = containStroke;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _dataStackHelper = require(\"../../data/helper/dataStackHelper\");\n\nvar isDimensionStacked = _dataStackHelper.isDimensionStacked;\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar map = _util.map;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @param {Object} coordSys\n * @param {module:echarts/data/List} data\n * @param {string} valueOrigin lineSeries.option.areaStyle.origin\n */\nfunction prepareDataCoordInfo(coordSys, data, valueOrigin) {\n var baseAxis = coordSys.getBaseAxis();\n var valueAxis = coordSys.getOtherAxis(baseAxis);\n var valueStart = getValueStart(valueAxis, valueOrigin);\n var baseAxisDim = baseAxis.dim;\n var valueAxisDim = valueAxis.dim;\n var valueDim = data.mapDimension(valueAxisDim);\n var baseDim = data.mapDimension(baseAxisDim);\n var baseDataOffset = valueAxisDim === 'x' || valueAxisDim === 'radius' ? 1 : 0;\n var dims = map(coordSys.dimensions, function (coordDim) {\n return data.mapDimension(coordDim);\n });\n var stacked;\n var stackResultDim = data.getCalculationInfo('stackResultDimension');\n\n if (stacked |= isDimensionStacked(data, dims[0]\n /*, dims[1]*/\n )) {\n // jshint ignore:line\n dims[0] = stackResultDim;\n }\n\n if (stacked |= isDimensionStacked(data, dims[1]\n /*, dims[0]*/\n )) {\n // jshint ignore:line\n dims[1] = stackResultDim;\n }\n\n return {\n dataDimsForPoint: dims,\n valueStart: valueStart,\n valueAxisDim: valueAxisDim,\n baseAxisDim: baseAxisDim,\n stacked: !!stacked,\n valueDim: valueDim,\n baseDim: baseDim,\n baseDataOffset: baseDataOffset,\n stackedOverDimension: data.getCalculationInfo('stackedOverDimension')\n };\n}\n\nfunction getValueStart(valueAxis, valueOrigin) {\n var valueStart = 0;\n var extent = valueAxis.scale.getExtent();\n\n if (valueOrigin === 'start') {\n valueStart = extent[0];\n } else if (valueOrigin === 'end') {\n valueStart = extent[1];\n } // auto\n else {\n // Both positive\n if (extent[0] > 0) {\n valueStart = extent[0];\n } // Both negative\n else if (extent[1] < 0) {\n valueStart = extent[1];\n } // If is one positive, and one negative, onZero shall be true\n\n }\n\n return valueStart;\n}\n\nfunction getStackedOnPoint(dataCoordInfo, coordSys, data, idx) {\n var value = NaN;\n\n if (dataCoordInfo.stacked) {\n value = data.get(data.getCalculationInfo('stackedOverDimension'), idx);\n }\n\n if (isNaN(value)) {\n value = dataCoordInfo.valueStart;\n }\n\n var baseDataOffset = dataCoordInfo.baseDataOffset;\n var stackedData = [];\n stackedData[baseDataOffset] = data.get(dataCoordInfo.baseDim, idx);\n stackedData[1 - baseDataOffset] = value;\n return coordSys.dataToPoint(stackedData);\n}\n\nexports.prepareDataCoordInfo = prepareDataCoordInfo;\nexports.getStackedOnPoint = getStackedOnPoint;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar graphic = require(\"./graphic\");\n\nvar BoundingRect = require(\"zrender/lib/core/BoundingRect\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// Symbol factory\n\n/**\n * Triangle shape\n * @inner\n */\nvar Triangle = graphic.extendShape({\n type: 'triangle',\n shape: {\n cx: 0,\n cy: 0,\n width: 0,\n height: 0\n },\n buildPath: function (path, shape) {\n var cx = shape.cx;\n var cy = shape.cy;\n var width = shape.width / 2;\n var height = shape.height / 2;\n path.moveTo(cx, cy - height);\n path.lineTo(cx + width, cy + height);\n path.lineTo(cx - width, cy + height);\n path.closePath();\n }\n});\n/**\n * Diamond shape\n * @inner\n */\n\nvar Diamond = graphic.extendShape({\n type: 'diamond',\n shape: {\n cx: 0,\n cy: 0,\n width: 0,\n height: 0\n },\n buildPath: function (path, shape) {\n var cx = shape.cx;\n var cy = shape.cy;\n var width = shape.width / 2;\n var height = shape.height / 2;\n path.moveTo(cx, cy - height);\n path.lineTo(cx + width, cy);\n path.lineTo(cx, cy + height);\n path.lineTo(cx - width, cy);\n path.closePath();\n }\n});\n/**\n * Pin shape\n * @inner\n */\n\nvar Pin = graphic.extendShape({\n type: 'pin',\n shape: {\n // x, y on the cusp\n x: 0,\n y: 0,\n width: 0,\n height: 0\n },\n buildPath: function (path, shape) {\n var x = shape.x;\n var y = shape.y;\n var w = shape.width / 5 * 3; // Height must be larger than width\n\n var h = Math.max(w, shape.height);\n var r = w / 2; // Dist on y with tangent point and circle center\n\n var dy = r * r / (h - r);\n var cy = y - h + r + dy;\n var angle = Math.asin(dy / r); // Dist on x with tangent point and circle center\n\n var dx = Math.cos(angle) * r;\n var tanX = Math.sin(angle);\n var tanY = Math.cos(angle);\n var cpLen = r * 0.6;\n var cpLen2 = r * 0.7;\n path.moveTo(x - dx, cy + dy);\n path.arc(x, cy, r, Math.PI - angle, Math.PI * 2 + angle);\n path.bezierCurveTo(x + dx - tanX * cpLen, cy + dy + tanY * cpLen, x, y - cpLen2, x, y);\n path.bezierCurveTo(x, y - cpLen2, x - dx + tanX * cpLen, cy + dy + tanY * cpLen, x - dx, cy + dy);\n path.closePath();\n }\n});\n/**\n * Arrow shape\n * @inner\n */\n\nvar Arrow = graphic.extendShape({\n type: 'arrow',\n shape: {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n },\n buildPath: function (ctx, shape) {\n var height = shape.height;\n var width = shape.width;\n var x = shape.x;\n var y = shape.y;\n var dx = width / 3 * 2;\n ctx.moveTo(x, y);\n ctx.lineTo(x + dx, y + height);\n ctx.lineTo(x, y + height / 4 * 3);\n ctx.lineTo(x - dx, y + height);\n ctx.lineTo(x, y);\n ctx.closePath();\n }\n});\n/**\n * Map of path contructors\n * @type {Object.<string, module:zrender/graphic/Path>}\n */\n\nvar symbolCtors = {\n line: graphic.Line,\n rect: graphic.Rect,\n roundRect: graphic.Rect,\n square: graphic.Rect,\n circle: graphic.Circle,\n diamond: Diamond,\n pin: Pin,\n arrow: Arrow,\n triangle: Triangle\n};\nvar symbolShapeMakers = {\n line: function (x, y, w, h, shape) {\n // FIXME\n shape.x1 = x;\n shape.y1 = y + h / 2;\n shape.x2 = x + w;\n shape.y2 = y + h / 2;\n },\n rect: function (x, y, w, h, shape) {\n shape.x = x;\n shape.y = y;\n shape.width = w;\n shape.height = h;\n },\n roundRect: function (x, y, w, h, shape) {\n shape.x = x;\n shape.y = y;\n shape.width = w;\n shape.height = h;\n shape.r = Math.min(w, h) / 4;\n },\n square: function (x, y, w, h, shape) {\n var size = Math.min(w, h);\n shape.x = x;\n shape.y = y;\n shape.width = size;\n shape.height = size;\n },\n circle: function (x, y, w, h, shape) {\n // Put circle in the center of square\n shape.cx = x + w / 2;\n shape.cy = y + h / 2;\n shape.r = Math.min(w, h) / 2;\n },\n diamond: function (x, y, w, h, shape) {\n shape.cx = x + w / 2;\n shape.cy = y + h / 2;\n shape.width = w;\n shape.height = h;\n },\n pin: function (x, y, w, h, shape) {\n shape.x = x + w / 2;\n shape.y = y + h / 2;\n shape.width = w;\n shape.height = h;\n },\n arrow: function (x, y, w, h, shape) {\n shape.x = x + w / 2;\n shape.y = y + h / 2;\n shape.width = w;\n shape.height = h;\n },\n triangle: function (x, y, w, h, shape) {\n shape.cx = x + w / 2;\n shape.cy = y + h / 2;\n shape.width = w;\n shape.height = h;\n }\n};\nvar symbolBuildProxies = {};\nzrUtil.each(symbolCtors, function (Ctor, name) {\n symbolBuildProxies[name] = new Ctor();\n});\nvar SymbolClz = graphic.extendShape({\n type: 'symbol',\n shape: {\n symbolType: '',\n x: 0,\n y: 0,\n width: 0,\n height: 0\n },\n beforeBrush: function () {\n var style = this.style;\n var shape = this.shape; // FIXME\n\n if (shape.symbolType === 'pin' && style.textPosition === 'inside') {\n style.textPosition = ['50%', '40%'];\n style.textAlign = 'center';\n style.textVerticalAlign = 'middle';\n }\n },\n buildPath: function (ctx, shape, inBundle) {\n var symbolType = shape.symbolType;\n var proxySymbol = symbolBuildProxies[symbolType];\n\n if (shape.symbolType !== 'none') {\n if (!proxySymbol) {\n // Default rect\n symbolType = 'rect';\n proxySymbol = symbolBuildProxies[symbolType];\n }\n\n symbolShapeMakers[symbolType](shape.x, shape.y, shape.width, shape.height, proxySymbol.shape);\n proxySymbol.buildPath(ctx, proxySymbol.shape, inBundle);\n }\n }\n}); // Provide setColor helper method to avoid determine if set the fill or stroke outside\n\nfunction symbolPathSetColor(color, innerColor) {\n if (this.type !== 'image') {\n var symbolStyle = this.style;\n var symbolShape = this.shape;\n\n if (symbolShape && symbolShape.symbolType === 'line') {\n symbolStyle.stroke = color;\n } else if (this.__isEmptyBrush) {\n symbolStyle.stroke = color;\n symbolStyle.fill = innerColor || '#fff';\n } else {\n // FIXME 判断图形默认是填充还是描边,使用 onlyStroke ?\n symbolStyle.fill && (symbolStyle.fill = color);\n symbolStyle.stroke && (symbolStyle.stroke = color);\n }\n\n this.dirty(false);\n }\n}\n/**\n * Create a symbol element with given symbol configuration: shape, x, y, width, height, color\n * @param {string} symbolType\n * @param {number} x\n * @param {number} y\n * @param {number} w\n * @param {number} h\n * @param {string} color\n * @param {boolean} [keepAspect=false] whether to keep the ratio of w/h,\n * for path and image only.\n */\n\n\nfunction createSymbol(symbolType, x, y, w, h, color, keepAspect) {\n // TODO Support image object, DynamicImage.\n var isEmpty = symbolType.indexOf('empty') === 0;\n\n if (isEmpty) {\n symbolType = symbolType.substr(5, 1).toLowerCase() + symbolType.substr(6);\n }\n\n var symbolPath;\n\n if (symbolType.indexOf('image://') === 0) {\n symbolPath = graphic.makeImage(symbolType.slice(8), new BoundingRect(x, y, w, h), keepAspect ? 'center' : 'cover');\n } else if (symbolType.indexOf('path://') === 0) {\n symbolPath = graphic.makePath(symbolType.slice(7), {}, new BoundingRect(x, y, w, h), keepAspect ? 'center' : 'cover');\n } else {\n symbolPath = new SymbolClz({\n shape: {\n symbolType: symbolType,\n x: x,\n y: y,\n width: w,\n height: h\n }\n });\n }\n\n symbolPath.__isEmptyBrush = isEmpty;\n symbolPath.setColor = symbolPathSetColor;\n symbolPath.setColor(color);\n return symbolPath;\n}\n\nexports.createSymbol = createSymbol;","var _util = require(\"../../core/util\");\n\nvar retrieve2 = _util.retrieve2;\nvar retrieve3 = _util.retrieve3;\nvar each = _util.each;\nvar normalizeCssArray = _util.normalizeCssArray;\nvar isString = _util.isString;\nvar isObject = _util.isObject;\n\nvar textContain = require(\"../../contain/text\");\n\nvar roundRectHelper = require(\"./roundRect\");\n\nvar imageHelper = require(\"./image\");\n\nvar fixShadow = require(\"./fixShadow\");\n\nvar _constant = require(\"../constant\");\n\nvar ContextCachedBy = _constant.ContextCachedBy;\nvar WILL_BE_RESTORED = _constant.WILL_BE_RESTORED;\nvar DEFAULT_FONT = textContain.DEFAULT_FONT; // TODO: Have not support 'start', 'end' yet.\n\nvar VALID_TEXT_ALIGN = {\n left: 1,\n right: 1,\n center: 1\n};\nvar VALID_TEXT_VERTICAL_ALIGN = {\n top: 1,\n bottom: 1,\n middle: 1\n}; // Different from `STYLE_COMMON_PROPS` of `graphic/Style`,\n// the default value of shadowColor is `'transparent'`.\n\nvar SHADOW_STYLE_COMMON_PROPS = [['textShadowBlur', 'shadowBlur', 0], ['textShadowOffsetX', 'shadowOffsetX', 0], ['textShadowOffsetY', 'shadowOffsetY', 0], ['textShadowColor', 'shadowColor', 'transparent']];\n/**\n * @param {module:zrender/graphic/Style} style\n * @return {module:zrender/graphic/Style} The input style.\n */\n\nfunction normalizeTextStyle(style) {\n normalizeStyle(style);\n each(style.rich, normalizeStyle);\n return style;\n}\n\nfunction normalizeStyle(style) {\n if (style) {\n style.font = textContain.makeFont(style);\n var textAlign = style.textAlign;\n textAlign === 'middle' && (textAlign = 'center');\n style.textAlign = textAlign == null || VALID_TEXT_ALIGN[textAlign] ? textAlign : 'left'; // Compatible with textBaseline.\n\n var textVerticalAlign = style.textVerticalAlign || style.textBaseline;\n textVerticalAlign === 'center' && (textVerticalAlign = 'middle');\n style.textVerticalAlign = textVerticalAlign == null || VALID_TEXT_VERTICAL_ALIGN[textVerticalAlign] ? textVerticalAlign : 'top';\n var textPadding = style.textPadding;\n\n if (textPadding) {\n style.textPadding = normalizeCssArray(style.textPadding);\n }\n }\n}\n/**\n * @param {CanvasRenderingContext2D} ctx\n * @param {string} text\n * @param {module:zrender/graphic/Style} style\n * @param {Object|boolean} [rect] {x, y, width, height}\n * If set false, rect text is not used.\n * @param {Element|module:zrender/graphic/helper/constant.WILL_BE_RESTORED} [prevEl] For ctx prop cache.\n */\n\n\nfunction renderText(hostEl, ctx, text, style, rect, prevEl) {\n style.rich ? renderRichText(hostEl, ctx, text, style, rect, prevEl) : renderPlainText(hostEl, ctx, text, style, rect, prevEl);\n} // Avoid setting to ctx according to prevEl if possible for\n// performance in scenarios of large amount text.\n\n\nfunction renderPlainText(hostEl, ctx, text, style, rect, prevEl) {\n 'use strict';\n\n var needDrawBg = needDrawBackground(style);\n var prevStyle;\n var checkCache = false;\n var cachedByMe = ctx.__attrCachedBy === ContextCachedBy.PLAIN_TEXT; // Only take and check cache for `Text` el, but not RectText.\n\n if (prevEl !== WILL_BE_RESTORED) {\n if (prevEl) {\n prevStyle = prevEl.style;\n checkCache = !needDrawBg && cachedByMe && prevStyle;\n } // Prevent from using cache in `Style::bind`, because of the case:\n // ctx property is modified by other properties than `Style::bind`\n // used, and Style::bind is called next.\n\n\n ctx.__attrCachedBy = needDrawBg ? ContextCachedBy.NONE : ContextCachedBy.PLAIN_TEXT;\n } // Since this will be restored, prevent from using these props to check cache in the next\n // entering of this method. But do not need to clear other cache like `Style::bind`.\n else if (cachedByMe) {\n ctx.__attrCachedBy = ContextCachedBy.NONE;\n }\n\n var styleFont = style.font || DEFAULT_FONT; // PENDING\n // Only `Text` el set `font` and keep it (`RectText` will restore). So theoretically\n // we can make font cache on ctx, which can cache for text el that are discontinuous.\n // But layer save/restore needed to be considered.\n // if (styleFont !== ctx.__fontCache) {\n // ctx.font = styleFont;\n // if (prevEl !== WILL_BE_RESTORED) {\n // ctx.__fontCache = styleFont;\n // }\n // }\n\n if (!checkCache || styleFont !== (prevStyle.font || DEFAULT_FONT)) {\n ctx.font = styleFont;\n } // Use the final font from context-2d, because the final\n // font might not be the style.font when it is illegal.\n // But get `ctx.font` might be time consuming.\n\n\n var computedFont = hostEl.__computedFont;\n\n if (hostEl.__styleFont !== styleFont) {\n hostEl.__styleFont = styleFont;\n computedFont = hostEl.__computedFont = ctx.font;\n }\n\n var textPadding = style.textPadding;\n var textLineHeight = style.textLineHeight;\n var contentBlock = hostEl.__textCotentBlock;\n\n if (!contentBlock || hostEl.__dirtyText) {\n contentBlock = hostEl.__textCotentBlock = textContain.parsePlainText(text, computedFont, textPadding, textLineHeight, style.truncate);\n }\n\n var outerHeight = contentBlock.outerHeight;\n var textLines = contentBlock.lines;\n var lineHeight = contentBlock.lineHeight;\n var boxPos = getBoxPosition(outerHeight, style, rect);\n var baseX = boxPos.baseX;\n var baseY = boxPos.baseY;\n var textAlign = boxPos.textAlign || 'left';\n var textVerticalAlign = boxPos.textVerticalAlign; // Origin of textRotation should be the base point of text drawing.\n\n applyTextRotation(ctx, style, rect, baseX, baseY);\n var boxY = textContain.adjustTextY(baseY, outerHeight, textVerticalAlign);\n var textX = baseX;\n var textY = boxY;\n\n if (needDrawBg || textPadding) {\n // Consider performance, do not call getTextWidth util necessary.\n var textWidth = textContain.getWidth(text, computedFont);\n var outerWidth = textWidth;\n textPadding && (outerWidth += textPadding[1] + textPadding[3]);\n var boxX = textContain.adjustTextX(baseX, outerWidth, textAlign);\n needDrawBg && drawBackground(hostEl, ctx, style, boxX, boxY, outerWidth, outerHeight);\n\n if (textPadding) {\n textX = getTextXForPadding(baseX, textAlign, textPadding);\n textY += textPadding[0];\n }\n } // Always set textAlign and textBase line, because it is difficute to calculate\n // textAlign from prevEl, and we dont sure whether textAlign will be reset if\n // font set happened.\n\n\n ctx.textAlign = textAlign; // Force baseline to be \"middle\". Otherwise, if using \"top\", the\n // text will offset downward a little bit in font \"Microsoft YaHei\".\n\n ctx.textBaseline = 'middle'; // Set text opacity\n\n ctx.globalAlpha = style.opacity || 1; // Always set shadowBlur and shadowOffset to avoid leak from displayable.\n\n for (var i = 0; i < SHADOW_STYLE_COMMON_PROPS.length; i++) {\n var propItem = SHADOW_STYLE_COMMON_PROPS[i];\n var styleProp = propItem[0];\n var ctxProp = propItem[1];\n var val = style[styleProp];\n\n if (!checkCache || val !== prevStyle[styleProp]) {\n ctx[ctxProp] = fixShadow(ctx, ctxProp, val || propItem[2]);\n }\n } // `textBaseline` is set as 'middle'.\n\n\n textY += lineHeight / 2;\n var textStrokeWidth = style.textStrokeWidth;\n var textStrokeWidthPrev = checkCache ? prevStyle.textStrokeWidth : null;\n var strokeWidthChanged = !checkCache || textStrokeWidth !== textStrokeWidthPrev;\n var strokeChanged = !checkCache || strokeWidthChanged || style.textStroke !== prevStyle.textStroke;\n var textStroke = getStroke(style.textStroke, textStrokeWidth);\n var textFill = getFill(style.textFill);\n\n if (textStroke) {\n if (strokeWidthChanged) {\n ctx.lineWidth = textStrokeWidth;\n }\n\n if (strokeChanged) {\n ctx.strokeStyle = textStroke;\n }\n }\n\n if (textFill) {\n if (!checkCache || style.textFill !== prevStyle.textFill) {\n ctx.fillStyle = textFill;\n }\n } // Optimize simply, in most cases only one line exists.\n\n\n if (textLines.length === 1) {\n // Fill after stroke so the outline will not cover the main part.\n textStroke && ctx.strokeText(textLines[0], textX, textY);\n textFill && ctx.fillText(textLines[0], textX, textY);\n } else {\n for (var i = 0; i < textLines.length; i++) {\n // Fill after stroke so the outline will not cover the main part.\n textStroke && ctx.strokeText(textLines[i], textX, textY);\n textFill && ctx.fillText(textLines[i], textX, textY);\n textY += lineHeight;\n }\n }\n}\n\nfunction renderRichText(hostEl, ctx, text, style, rect, prevEl) {\n // Do not do cache for rich text because of the complexity.\n // But `RectText` this will be restored, do not need to clear other cache like `Style::bind`.\n if (prevEl !== WILL_BE_RESTORED) {\n ctx.__attrCachedBy = ContextCachedBy.NONE;\n }\n\n var contentBlock = hostEl.__textCotentBlock;\n\n if (!contentBlock || hostEl.__dirtyText) {\n contentBlock = hostEl.__textCotentBlock = textContain.parseRichText(text, style);\n }\n\n drawRichText(hostEl, ctx, contentBlock, style, rect);\n}\n\nfunction drawRichText(hostEl, ctx, contentBlock, style, rect) {\n var contentWidth = contentBlock.width;\n var outerWidth = contentBlock.outerWidth;\n var outerHeight = contentBlock.outerHeight;\n var textPadding = style.textPadding;\n var boxPos = getBoxPosition(outerHeight, style, rect);\n var baseX = boxPos.baseX;\n var baseY = boxPos.baseY;\n var textAlign = boxPos.textAlign;\n var textVerticalAlign = boxPos.textVerticalAlign; // Origin of textRotation should be the base point of text drawing.\n\n applyTextRotation(ctx, style, rect, baseX, baseY);\n var boxX = textContain.adjustTextX(baseX, outerWidth, textAlign);\n var boxY = textContain.adjustTextY(baseY, outerHeight, textVerticalAlign);\n var xLeft = boxX;\n var lineTop = boxY;\n\n if (textPadding) {\n xLeft += textPadding[3];\n lineTop += textPadding[0];\n }\n\n var xRight = xLeft + contentWidth;\n needDrawBackground(style) && drawBackground(hostEl, ctx, style, boxX, boxY, outerWidth, outerHeight);\n\n for (var i = 0; i < contentBlock.lines.length; i++) {\n var line = contentBlock.lines[i];\n var tokens = line.tokens;\n var tokenCount = tokens.length;\n var lineHeight = line.lineHeight;\n var usedWidth = line.width;\n var leftIndex = 0;\n var lineXLeft = xLeft;\n var lineXRight = xRight;\n var rightIndex = tokenCount - 1;\n var token;\n\n while (leftIndex < tokenCount && (token = tokens[leftIndex], !token.textAlign || token.textAlign === 'left')) {\n placeToken(hostEl, ctx, token, style, lineHeight, lineTop, lineXLeft, 'left');\n usedWidth -= token.width;\n lineXLeft += token.width;\n leftIndex++;\n }\n\n while (rightIndex >= 0 && (token = tokens[rightIndex], token.textAlign === 'right')) {\n placeToken(hostEl, ctx, token, style, lineHeight, lineTop, lineXRight, 'right');\n usedWidth -= token.width;\n lineXRight -= token.width;\n rightIndex--;\n } // The other tokens are placed as textAlign 'center' if there is enough space.\n\n\n lineXLeft += (contentWidth - (lineXLeft - xLeft) - (xRight - lineXRight) - usedWidth) / 2;\n\n while (leftIndex <= rightIndex) {\n token = tokens[leftIndex]; // Consider width specified by user, use 'center' rather than 'left'.\n\n placeToken(hostEl, ctx, token, style, lineHeight, lineTop, lineXLeft + token.width / 2, 'center');\n lineXLeft += token.width;\n leftIndex++;\n }\n\n lineTop += lineHeight;\n }\n}\n\nfunction applyTextRotation(ctx, style, rect, x, y) {\n // textRotation only apply in RectText.\n if (rect && style.textRotation) {\n var origin = style.textOrigin;\n\n if (origin === 'center') {\n x = rect.width / 2 + rect.x;\n y = rect.height / 2 + rect.y;\n } else if (origin) {\n x = origin[0] + rect.x;\n y = origin[1] + rect.y;\n }\n\n ctx.translate(x, y); // Positive: anticlockwise\n\n ctx.rotate(-style.textRotation);\n ctx.translate(-x, -y);\n }\n}\n\nfunction placeToken(hostEl, ctx, token, style, lineHeight, lineTop, x, textAlign) {\n var tokenStyle = style.rich[token.styleName] || {};\n tokenStyle.text = token.text; // 'ctx.textBaseline' is always set as 'middle', for sake of\n // the bias of \"Microsoft YaHei\".\n\n var textVerticalAlign = token.textVerticalAlign;\n var y = lineTop + lineHeight / 2;\n\n if (textVerticalAlign === 'top') {\n y = lineTop + token.height / 2;\n } else if (textVerticalAlign === 'bottom') {\n y = lineTop + lineHeight - token.height / 2;\n }\n\n !token.isLineHolder && needDrawBackground(tokenStyle) && drawBackground(hostEl, ctx, tokenStyle, textAlign === 'right' ? x - token.width : textAlign === 'center' ? x - token.width / 2 : x, y - token.height / 2, token.width, token.height);\n var textPadding = token.textPadding;\n\n if (textPadding) {\n x = getTextXForPadding(x, textAlign, textPadding);\n y -= token.height / 2 - textPadding[2] - token.textHeight / 2;\n }\n\n setCtx(ctx, 'shadowBlur', retrieve3(tokenStyle.textShadowBlur, style.textShadowBlur, 0));\n setCtx(ctx, 'shadowColor', tokenStyle.textShadowColor || style.textShadowColor || 'transparent');\n setCtx(ctx, 'shadowOffsetX', retrieve3(tokenStyle.textShadowOffsetX, style.textShadowOffsetX, 0));\n setCtx(ctx, 'shadowOffsetY', retrieve3(tokenStyle.textShadowOffsetY, style.textShadowOffsetY, 0));\n setCtx(ctx, 'textAlign', textAlign); // Force baseline to be \"middle\". Otherwise, if using \"top\", the\n // text will offset downward a little bit in font \"Microsoft YaHei\".\n\n setCtx(ctx, 'textBaseline', 'middle');\n setCtx(ctx, 'font', token.font || DEFAULT_FONT);\n var textStroke = getStroke(tokenStyle.textStroke || style.textStroke, textStrokeWidth);\n var textFill = getFill(tokenStyle.textFill || style.textFill);\n var textStrokeWidth = retrieve2(tokenStyle.textStrokeWidth, style.textStrokeWidth); // Fill after stroke so the outline will not cover the main part.\n\n if (textStroke) {\n setCtx(ctx, 'lineWidth', textStrokeWidth);\n setCtx(ctx, 'strokeStyle', textStroke);\n ctx.strokeText(token.text, x, y);\n }\n\n if (textFill) {\n setCtx(ctx, 'fillStyle', textFill);\n ctx.fillText(token.text, x, y);\n }\n}\n\nfunction needDrawBackground(style) {\n return !!(style.textBackgroundColor || style.textBorderWidth && style.textBorderColor);\n} // style: {textBackgroundColor, textBorderWidth, textBorderColor, textBorderRadius, text}\n// shape: {x, y, width, height}\n\n\nfunction drawBackground(hostEl, ctx, style, x, y, width, height) {\n var textBackgroundColor = style.textBackgroundColor;\n var textBorderWidth = style.textBorderWidth;\n var textBorderColor = style.textBorderColor;\n var isPlainBg = isString(textBackgroundColor);\n setCtx(ctx, 'shadowBlur', style.textBoxShadowBlur || 0);\n setCtx(ctx, 'shadowColor', style.textBoxShadowColor || 'transparent');\n setCtx(ctx, 'shadowOffsetX', style.textBoxShadowOffsetX || 0);\n setCtx(ctx, 'shadowOffsetY', style.textBoxShadowOffsetY || 0);\n\n if (isPlainBg || textBorderWidth && textBorderColor) {\n ctx.beginPath();\n var textBorderRadius = style.textBorderRadius;\n\n if (!textBorderRadius) {\n ctx.rect(x, y, width, height);\n } else {\n roundRectHelper.buildPath(ctx, {\n x: x,\n y: y,\n width: width,\n height: height,\n r: textBorderRadius\n });\n }\n\n ctx.closePath();\n }\n\n if (isPlainBg) {\n setCtx(ctx, 'fillStyle', textBackgroundColor);\n\n if (style.fillOpacity != null) {\n var originalGlobalAlpha = ctx.globalAlpha;\n ctx.globalAlpha = style.fillOpacity * style.opacity;\n ctx.fill();\n ctx.globalAlpha = originalGlobalAlpha;\n } else {\n ctx.fill();\n }\n } else if (isObject(textBackgroundColor)) {\n var image = textBackgroundColor.image;\n image = imageHelper.createOrUpdateImage(image, null, hostEl, onBgImageLoaded, textBackgroundColor);\n\n if (image && imageHelper.isImageReady(image)) {\n ctx.drawImage(image, x, y, width, height);\n }\n }\n\n if (textBorderWidth && textBorderColor) {\n setCtx(ctx, 'lineWidth', textBorderWidth);\n setCtx(ctx, 'strokeStyle', textBorderColor);\n\n if (style.strokeOpacity != null) {\n var originalGlobalAlpha = ctx.globalAlpha;\n ctx.globalAlpha = style.strokeOpacity * style.opacity;\n ctx.stroke();\n ctx.globalAlpha = originalGlobalAlpha;\n } else {\n ctx.stroke();\n }\n }\n}\n\nfunction onBgImageLoaded(image, textBackgroundColor) {\n // Replace image, so that `contain/text.js#parseRichText`\n // will get correct result in next tick.\n textBackgroundColor.image = image;\n}\n\nfunction getBoxPosition(blockHeiht, style, rect) {\n var baseX = style.x || 0;\n var baseY = style.y || 0;\n var textAlign = style.textAlign;\n var textVerticalAlign = style.textVerticalAlign; // Text position represented by coord\n\n if (rect) {\n var textPosition = style.textPosition;\n\n if (textPosition instanceof Array) {\n // Percent\n baseX = rect.x + parsePercent(textPosition[0], rect.width);\n baseY = rect.y + parsePercent(textPosition[1], rect.height);\n } else {\n var res = textContain.adjustTextPositionOnRect(textPosition, rect, style.textDistance);\n baseX = res.x;\n baseY = res.y; // Default align and baseline when has textPosition\n\n textAlign = textAlign || res.textAlign;\n textVerticalAlign = textVerticalAlign || res.textVerticalAlign;\n } // textOffset is only support in RectText, otherwise\n // we have to adjust boundingRect for textOffset.\n\n\n var textOffset = style.textOffset;\n\n if (textOffset) {\n baseX += textOffset[0];\n baseY += textOffset[1];\n }\n }\n\n return {\n baseX: baseX,\n baseY: baseY,\n textAlign: textAlign,\n textVerticalAlign: textVerticalAlign\n };\n}\n\nfunction setCtx(ctx, prop, value) {\n ctx[prop] = fixShadow(ctx, prop, value);\n return ctx[prop];\n}\n/**\n * @param {string} [stroke] If specified, do not check style.textStroke.\n * @param {string} [lineWidth] If specified, do not check style.textStroke.\n * @param {number} style\n */\n\n\nfunction getStroke(stroke, lineWidth) {\n return stroke == null || lineWidth <= 0 || stroke === 'transparent' || stroke === 'none' ? null // TODO pattern and gradient?\n : stroke.image || stroke.colorStops ? '#000' : stroke;\n}\n\nfunction getFill(fill) {\n return fill == null || fill === 'none' ? null // TODO pattern and gradient?\n : fill.image || fill.colorStops ? '#000' : fill;\n}\n\nfunction parsePercent(value, maxValue) {\n if (typeof value === 'string') {\n if (value.lastIndexOf('%') >= 0) {\n return parseFloat(value) / 100 * maxValue;\n }\n\n return parseFloat(value);\n }\n\n return value;\n}\n\nfunction getTextXForPadding(x, textAlign, textPadding) {\n return textAlign === 'right' ? x - textPadding[1] : textAlign === 'center' ? x + textPadding[3] / 2 - textPadding[1] / 2 : x + textPadding[3];\n}\n/**\n * @param {string} text\n * @param {module:zrender/Style} style\n * @return {boolean}\n */\n\n\nfunction needDrawText(text, style) {\n return text != null && (text || style.textBackgroundColor || style.textBorderWidth && style.textBorderColor || style.textPadding);\n}\n\nexports.normalizeTextStyle = normalizeTextStyle;\nexports.renderText = renderText;\nexports.getStroke = getStroke;\nexports.getFill = getFill;\nexports.needDrawText = needDrawText;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar textContain = require(\"zrender/lib/contain/text\");\n\nvar Axis = require(\"../Axis\");\n\nvar _model = require(\"../../util/model\");\n\nvar makeInner = _model.makeInner;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar inner = makeInner();\n\nfunction AngleAxis(scale, angleExtent) {\n angleExtent = angleExtent || [0, 360];\n Axis.call(this, 'angle', scale, angleExtent);\n /**\n * Axis type\n * - 'category'\n * - 'value'\n * - 'time'\n * - 'log'\n * @type {string}\n */\n\n this.type = 'category';\n}\n\nAngleAxis.prototype = {\n constructor: AngleAxis,\n\n /**\n * @override\n */\n pointToData: function (point, clamp) {\n return this.polar.pointToData(point, clamp)[this.dim === 'radius' ? 0 : 1];\n },\n dataToAngle: Axis.prototype.dataToCoord,\n angleToData: Axis.prototype.coordToData,\n\n /**\n * Only be called in category axis.\n * Angle axis uses text height to decide interval\n *\n * @override\n * @return {number} Auto interval for cateogry axis tick and label\n */\n calculateCategoryInterval: function () {\n var axis = this;\n var labelModel = axis.getLabelModel();\n var ordinalScale = axis.scale;\n var ordinalExtent = ordinalScale.getExtent(); // Providing this method is for optimization:\n // avoid generating a long array by `getTicks`\n // in large category data case.\n\n var tickCount = ordinalScale.count();\n\n if (ordinalExtent[1] - ordinalExtent[0] < 1) {\n return 0;\n }\n\n var tickValue = ordinalExtent[0];\n var unitSpan = axis.dataToCoord(tickValue + 1) - axis.dataToCoord(tickValue);\n var unitH = Math.abs(unitSpan); // Not precise, just use height as text width\n // and each distance from axis line yet.\n\n var rect = textContain.getBoundingRect(tickValue, labelModel.getFont(), 'center', 'top');\n var maxH = Math.max(rect.height, 7);\n var dh = maxH / unitH; // 0/0 is NaN, 1/0 is Infinity.\n\n isNaN(dh) && (dh = Infinity);\n var interval = Math.max(0, Math.floor(dh));\n var cache = inner(axis.model);\n var lastAutoInterval = cache.lastAutoInterval;\n var lastTickCount = cache.lastTickCount; // Use cache to keep interval stable while moving zoom window,\n // otherwise the calculated interval might jitter when the zoom\n // window size is close to the interval-changing size.\n\n if (lastAutoInterval != null && lastTickCount != null && Math.abs(lastAutoInterval - interval) <= 1 && Math.abs(lastTickCount - tickCount) <= 1 // Always choose the bigger one, otherwise the critical\n // point is not the same when zooming in or zooming out.\n && lastAutoInterval > interval) {\n interval = lastAutoInterval;\n } // Only update cache if cache not used, otherwise the\n // changing of interval is too insensitive.\n else {\n cache.lastTickCount = tickCount;\n cache.lastAutoInterval = interval;\n }\n\n return interval;\n }\n};\nzrUtil.inherits(AngleAxis, Axis);\nvar _default = AngleAxis;\nmodule.exports = _default;","var Path = require(\"../Path\");\n\nvar vec2 = require(\"../../core/vector\");\n\nvar _curve = require(\"../../core/curve\");\n\nvar quadraticSubdivide = _curve.quadraticSubdivide;\nvar cubicSubdivide = _curve.cubicSubdivide;\nvar quadraticAt = _curve.quadraticAt;\nvar cubicAt = _curve.cubicAt;\nvar quadraticDerivativeAt = _curve.quadraticDerivativeAt;\nvar cubicDerivativeAt = _curve.cubicDerivativeAt;\n\n/**\n * 贝塞尔曲线\n * @module zrender/shape/BezierCurve\n */\nvar out = [];\n\nfunction someVectorAt(shape, t, isTangent) {\n var cpx2 = shape.cpx2;\n var cpy2 = shape.cpy2;\n\n if (cpx2 === null || cpy2 === null) {\n return [(isTangent ? cubicDerivativeAt : cubicAt)(shape.x1, shape.cpx1, shape.cpx2, shape.x2, t), (isTangent ? cubicDerivativeAt : cubicAt)(shape.y1, shape.cpy1, shape.cpy2, shape.y2, t)];\n } else {\n return [(isTangent ? quadraticDerivativeAt : quadraticAt)(shape.x1, shape.cpx1, shape.x2, t), (isTangent ? quadraticDerivativeAt : quadraticAt)(shape.y1, shape.cpy1, shape.y2, t)];\n }\n}\n\nvar _default = Path.extend({\n type: 'bezier-curve',\n shape: {\n x1: 0,\n y1: 0,\n x2: 0,\n y2: 0,\n cpx1: 0,\n cpy1: 0,\n // cpx2: 0,\n // cpy2: 0\n // Curve show percent, for animating\n percent: 1\n },\n style: {\n stroke: '#000',\n fill: null\n },\n buildPath: function (ctx, shape) {\n var x1 = shape.x1;\n var y1 = shape.y1;\n var x2 = shape.x2;\n var y2 = shape.y2;\n var cpx1 = shape.cpx1;\n var cpy1 = shape.cpy1;\n var cpx2 = shape.cpx2;\n var cpy2 = shape.cpy2;\n var percent = shape.percent;\n\n if (percent === 0) {\n return;\n }\n\n ctx.moveTo(x1, y1);\n\n if (cpx2 == null || cpy2 == null) {\n if (percent < 1) {\n quadraticSubdivide(x1, cpx1, x2, percent, out);\n cpx1 = out[1];\n x2 = out[2];\n quadraticSubdivide(y1, cpy1, y2, percent, out);\n cpy1 = out[1];\n y2 = out[2];\n }\n\n ctx.quadraticCurveTo(cpx1, cpy1, x2, y2);\n } else {\n if (percent < 1) {\n cubicSubdivide(x1, cpx1, cpx2, x2, percent, out);\n cpx1 = out[1];\n cpx2 = out[2];\n x2 = out[3];\n cubicSubdivide(y1, cpy1, cpy2, y2, percent, out);\n cpy1 = out[1];\n cpy2 = out[2];\n y2 = out[3];\n }\n\n ctx.bezierCurveTo(cpx1, cpy1, cpx2, cpy2, x2, y2);\n }\n },\n\n /**\n * Get point at percent\n * @param {number} t\n * @return {Array.<number>}\n */\n pointAt: function (t) {\n return someVectorAt(this.shape, t, false);\n },\n\n /**\n * Get tangent at percent\n * @param {number} t\n * @return {Array.<number>}\n */\n tangentAt: function (t) {\n var p = someVectorAt(this.shape, t, true);\n return vec2.normalize(p, p);\n }\n});\n\nmodule.exports = _default;","var Path = require(\"../Path\");\n\n/**\n * 椭圆形状\n * @module zrender/graphic/shape/Ellipse\n */\nvar _default = Path.extend({\n type: 'ellipse',\n shape: {\n cx: 0,\n cy: 0,\n rx: 0,\n ry: 0\n },\n buildPath: function (ctx, shape) {\n var k = 0.5522848;\n var x = shape.cx;\n var y = shape.cy;\n var a = shape.rx;\n var b = shape.ry;\n var ox = a * k; // 水平控制点偏移量\n\n var oy = b * k; // 垂直控制点偏移量\n // 从椭圆的左端点开始顺时针绘制四条三次贝塞尔曲线\n\n ctx.moveTo(x - a, y);\n ctx.bezierCurveTo(x - a, y - oy, x - ox, y - b, x, y - b);\n ctx.bezierCurveTo(x + ox, y - b, x + a, y - oy, x + a, y);\n ctx.bezierCurveTo(x + a, y + oy, x + ox, y + b, x, y + b);\n ctx.bezierCurveTo(x - ox, y + b, x - a, y + oy, x - a, y);\n ctx.closePath();\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nrequire(\"../coord/cartesian/AxisModel\");\n\nrequire(\"./axis/CartesianAxisView\");","var util = require(\"./core/util\");\n\nvar env = require(\"./core/env\");\n\nvar Group = require(\"./container/Group\");\n\nvar timsort = require(\"./core/timsort\");\n\n// Use timsort because in most case elements are partially sorted\n// https://jsfiddle.net/pissang/jr4x7mdm/8/\nfunction shapeCompareFunc(a, b) {\n if (a.zlevel === b.zlevel) {\n if (a.z === b.z) {\n // if (a.z2 === b.z2) {\n // // FIXME Slow has renderidx compare\n // // http://stackoverflow.com/questions/20883421/sorting-in-javascript-should-every-compare-function-have-a-return-0-statement\n // // https://github.com/v8/v8/blob/47cce544a31ed5577ffe2963f67acb4144ee0232/src/js/array.js#L1012\n // return a.__renderidx - b.__renderidx;\n // }\n return a.z2 - b.z2;\n }\n\n return a.z - b.z;\n }\n\n return a.zlevel - b.zlevel;\n}\n/**\n * 内容仓库 (M)\n * @alias module:zrender/Storage\n * @constructor\n */\n\n\nvar Storage = function () {\n // jshint ignore:line\n this._roots = [];\n this._displayList = [];\n this._displayListLen = 0;\n};\n\nStorage.prototype = {\n constructor: Storage,\n\n /**\n * @param {Function} cb\n *\n */\n traverse: function (cb, context) {\n for (var i = 0; i < this._roots.length; i++) {\n this._roots[i].traverse(cb, context);\n }\n },\n\n /**\n * 返回所有图形的绘制队列\n * @param {boolean} [update=false] 是否在返回前更新该数组\n * @param {boolean} [includeIgnore=false] 是否包含 ignore 的数组, 在 update 为 true 的时候有效\n *\n * 详见{@link module:zrender/graphic/Displayable.prototype.updateDisplayList}\n * @return {Array.<module:zrender/graphic/Displayable>}\n */\n getDisplayList: function (update, includeIgnore) {\n includeIgnore = includeIgnore || false;\n\n if (update) {\n this.updateDisplayList(includeIgnore);\n }\n\n return this._displayList;\n },\n\n /**\n * 更新图形的绘制队列。\n * 每次绘制前都会调用,该方法会先深度优先遍历整个树,更新所有Group和Shape的变换并且把所有可见的Shape保存到数组中,\n * 最后根据绘制的优先级(zlevel > z > 插入顺序)排序得到绘制队列\n * @param {boolean} [includeIgnore=false] 是否包含 ignore 的数组\n */\n updateDisplayList: function (includeIgnore) {\n this._displayListLen = 0;\n var roots = this._roots;\n var displayList = this._displayList;\n\n for (var i = 0, len = roots.length; i < len; i++) {\n this._updateAndAddDisplayable(roots[i], null, includeIgnore);\n }\n\n displayList.length = this._displayListLen;\n env.canvasSupported && timsort(displayList, shapeCompareFunc);\n },\n _updateAndAddDisplayable: function (el, clipPaths, includeIgnore) {\n if (el.ignore && !includeIgnore) {\n return;\n }\n\n el.beforeUpdate();\n\n if (el.__dirty) {\n el.update();\n }\n\n el.afterUpdate();\n var userSetClipPath = el.clipPath;\n\n if (userSetClipPath) {\n // FIXME 效率影响\n if (clipPaths) {\n clipPaths = clipPaths.slice();\n } else {\n clipPaths = [];\n }\n\n var currentClipPath = userSetClipPath;\n var parentClipPath = el; // Recursively add clip path\n\n while (currentClipPath) {\n // clipPath 的变换是基于使用这个 clipPath 的元素\n currentClipPath.parent = parentClipPath;\n currentClipPath.updateTransform();\n clipPaths.push(currentClipPath);\n parentClipPath = currentClipPath;\n currentClipPath = currentClipPath.clipPath;\n }\n }\n\n if (el.isGroup) {\n var children = el._children;\n\n for (var i = 0; i < children.length; i++) {\n var child = children[i]; // Force to mark as dirty if group is dirty\n // FIXME __dirtyPath ?\n\n if (el.__dirty) {\n child.__dirty = true;\n }\n\n this._updateAndAddDisplayable(child, clipPaths, includeIgnore);\n } // Mark group clean here\n\n\n el.__dirty = false;\n } else {\n el.__clipPaths = clipPaths;\n this._displayList[this._displayListLen++] = el;\n }\n },\n\n /**\n * 添加图形(Shape)或者组(Group)到根节点\n * @param {module:zrender/Element} el\n */\n addRoot: function (el) {\n if (el.__storage === this) {\n return;\n }\n\n if (el instanceof Group) {\n el.addChildrenToStorage(this);\n }\n\n this.addToStorage(el);\n\n this._roots.push(el);\n },\n\n /**\n * 删除指定的图形(Shape)或者组(Group)\n * @param {string|Array.<string>} [el] 如果为空清空整个Storage\n */\n delRoot: function (el) {\n if (el == null) {\n // 不指定el清空\n for (var i = 0; i < this._roots.length; i++) {\n var root = this._roots[i];\n\n if (root instanceof Group) {\n root.delChildrenFromStorage(this);\n }\n }\n\n this._roots = [];\n this._displayList = [];\n this._displayListLen = 0;\n return;\n }\n\n if (el instanceof Array) {\n for (var i = 0, l = el.length; i < l; i++) {\n this.delRoot(el[i]);\n }\n\n return;\n }\n\n var idx = util.indexOf(this._roots, el);\n\n if (idx >= 0) {\n this.delFromStorage(el);\n\n this._roots.splice(idx, 1);\n\n if (el instanceof Group) {\n el.delChildrenFromStorage(this);\n }\n }\n },\n addToStorage: function (el) {\n if (el) {\n el.__storage = this;\n el.dirty(false);\n }\n\n return this;\n },\n delFromStorage: function (el) {\n if (el) {\n el.__storage = null;\n }\n\n return this;\n },\n\n /**\n * 清空并且释放Storage\n */\n dispose: function () {\n this._renderList = this._roots = null;\n },\n displayableSortFunc: shapeCompareFunc\n};\nvar _default = Storage;\nmodule.exports = _default;","var isObject = require('./isObject'),\n now = require('./now'),\n toNumber = require('./toNumber');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\nmodule.exports = debounce;\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar Group = require(\"zrender/lib/container/Group\");\n\nvar componentUtil = require(\"../util/component\");\n\nvar clazzUtil = require(\"../util/clazz\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar Component = function () {\n /**\n * @type {module:zrender/container/Group}\n * @readOnly\n */\n this.group = new Group();\n /**\n * @type {string}\n * @readOnly\n */\n\n this.uid = componentUtil.getUID('viewComponent');\n};\n\nComponent.prototype = {\n constructor: Component,\n init: function (ecModel, api) {},\n render: function (componentModel, ecModel, api, payload) {},\n dispose: function () {},\n\n /**\n * @param {string} eventType\n * @param {Object} query\n * @param {module:zrender/Element} targetEl\n * @param {Object} packedEvent\n * @return {boolen} Pass only when return `true`.\n */\n filterForExposedEvent: null\n};\nvar componentProto = Component.prototype;\n\ncomponentProto.updateView = componentProto.updateLayout = componentProto.updateVisual = function (seriesModel, ecModel, api, payload) {// Do nothing;\n}; // Enable Component.extend.\n\n\nclazzUtil.enableClassExtend(Component); // Enable capability of registerClass, getClass, hasClass, registerSubTypeDefaulter and so on.\n\nclazzUtil.enableClassManagement(Component, {\n registerWhenExtend: true\n});\nvar _default = Component;\nmodule.exports = _default;","import mod from \"-!../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../../node_modules/css-loader/index.js??ref--6-oneOf-1-1!../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Statistics.vue?vue&type=style&index=0&id=0c8f63c6&scoped=true&lang=css&\"; export default mod; export * from \"-!../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../../node_modules/css-loader/index.js??ref--6-oneOf-1-1!../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Statistics.vue?vue&type=style&index=0&id=0c8f63c6&scoped=true&lang=css&\"","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar completeDimensions = require(\"./completeDimensions\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Substitute `completeDimensions`.\n * `completeDimensions` is to be deprecated.\n */\n\n/**\n * @param {module:echarts/data/Source|module:echarts/data/List} source or data.\n * @param {Object|Array} [opt]\n * @param {Array.<string|Object>} [opt.coordDimensions=[]]\n * @param {number} [opt.dimensionsCount]\n * @param {string} [opt.generateCoord]\n * @param {string} [opt.generateCoordCount]\n * @param {Array.<string|Object>} [opt.dimensionsDefine=source.dimensionsDefine] Overwrite source define.\n * @param {Object|HashMap} [opt.encodeDefine=source.encodeDefine] Overwrite source define.\n * @return {Array.<Object>} dimensionsInfo\n */\nfunction _default(source, opt) {\n opt = opt || {};\n return completeDimensions(opt.coordDimensions || [], source, {\n dimsDef: opt.dimensionsDefine || source.dimensionsDefine,\n encodeDef: opt.encodeDefine || source.encodeDefine,\n dimCount: opt.dimensionsCount,\n generateCoord: opt.generateCoord,\n generateCoordCount: opt.generateCoordCount\n });\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar graphic = require(\"../../util/graphic\");\n\nvar Model = require(\"../../model/Model\");\n\nvar AxisView = require(\"./AxisView\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar elementList = ['axisLine', 'axisLabel', 'axisTick', 'splitLine', 'splitArea'];\n\nfunction getAxisLineShape(polar, rExtent, angle) {\n rExtent[1] > rExtent[0] && (rExtent = rExtent.slice().reverse());\n var start = polar.coordToPoint([rExtent[0], angle]);\n var end = polar.coordToPoint([rExtent[1], angle]);\n return {\n x1: start[0],\n y1: start[1],\n x2: end[0],\n y2: end[1]\n };\n}\n\nfunction getRadiusIdx(polar) {\n var radiusAxis = polar.getRadiusAxis();\n return radiusAxis.inverse ? 0 : 1;\n} // Remove the last tick which will overlap the first tick\n\n\nfunction fixAngleOverlap(list) {\n var firstItem = list[0];\n var lastItem = list[list.length - 1];\n\n if (firstItem && lastItem && Math.abs(Math.abs(firstItem.coord - lastItem.coord) - 360) < 1e-4) {\n list.pop();\n }\n}\n\nvar _default = AxisView.extend({\n type: 'angleAxis',\n axisPointerClass: 'PolarAxisPointer',\n render: function (angleAxisModel, ecModel) {\n this.group.removeAll();\n\n if (!angleAxisModel.get('show')) {\n return;\n }\n\n var angleAxis = angleAxisModel.axis;\n var polar = angleAxis.polar;\n var radiusExtent = polar.getRadiusAxis().getExtent();\n var ticksAngles = angleAxis.getTicksCoords();\n var labels = zrUtil.map(angleAxis.getViewLabels(), function (labelItem) {\n var labelItem = zrUtil.clone(labelItem);\n labelItem.coord = angleAxis.dataToCoord(labelItem.tickValue);\n return labelItem;\n });\n fixAngleOverlap(labels);\n fixAngleOverlap(ticksAngles);\n zrUtil.each(elementList, function (name) {\n if (angleAxisModel.get(name + '.show') && (!angleAxis.scale.isBlank() || name === 'axisLine')) {\n this['_' + name](angleAxisModel, polar, ticksAngles, radiusExtent, labels);\n }\n }, this);\n },\n\n /**\n * @private\n */\n _axisLine: function (angleAxisModel, polar, ticksAngles, radiusExtent) {\n var lineStyleModel = angleAxisModel.getModel('axisLine.lineStyle');\n var circle = new graphic.Circle({\n shape: {\n cx: polar.cx,\n cy: polar.cy,\n r: radiusExtent[getRadiusIdx(polar)]\n },\n style: lineStyleModel.getLineStyle(),\n z2: 1,\n silent: true\n });\n circle.style.fill = null;\n this.group.add(circle);\n },\n\n /**\n * @private\n */\n _axisTick: function (angleAxisModel, polar, ticksAngles, radiusExtent) {\n var tickModel = angleAxisModel.getModel('axisTick');\n var tickLen = (tickModel.get('inside') ? -1 : 1) * tickModel.get('length');\n var radius = radiusExtent[getRadiusIdx(polar)];\n var lines = zrUtil.map(ticksAngles, function (tickAngleItem) {\n return new graphic.Line({\n shape: getAxisLineShape(polar, [radius, radius + tickLen], tickAngleItem.coord)\n });\n });\n this.group.add(graphic.mergePath(lines, {\n style: zrUtil.defaults(tickModel.getModel('lineStyle').getLineStyle(), {\n stroke: angleAxisModel.get('axisLine.lineStyle.color')\n })\n }));\n },\n\n /**\n * @private\n */\n _axisLabel: function (angleAxisModel, polar, ticksAngles, radiusExtent, labels) {\n var rawCategoryData = angleAxisModel.getCategories(true);\n var commonLabelModel = angleAxisModel.getModel('axisLabel');\n var labelMargin = commonLabelModel.get('margin'); // Use length of ticksAngles because it may remove the last tick to avoid overlapping\n\n zrUtil.each(labels, function (labelItem, idx) {\n var labelModel = commonLabelModel;\n var tickValue = labelItem.tickValue;\n var r = radiusExtent[getRadiusIdx(polar)];\n var p = polar.coordToPoint([r + labelMargin, labelItem.coord]);\n var cx = polar.cx;\n var cy = polar.cy;\n var labelTextAlign = Math.abs(p[0] - cx) / r < 0.3 ? 'center' : p[0] > cx ? 'left' : 'right';\n var labelTextVerticalAlign = Math.abs(p[1] - cy) / r < 0.3 ? 'middle' : p[1] > cy ? 'top' : 'bottom';\n\n if (rawCategoryData && rawCategoryData[tickValue] && rawCategoryData[tickValue].textStyle) {\n labelModel = new Model(rawCategoryData[tickValue].textStyle, commonLabelModel, commonLabelModel.ecModel);\n }\n\n var textEl = new graphic.Text({\n silent: true\n });\n this.group.add(textEl);\n graphic.setTextStyle(textEl.style, labelModel, {\n x: p[0],\n y: p[1],\n textFill: labelModel.getTextColor() || angleAxisModel.get('axisLine.lineStyle.color'),\n text: labelItem.formattedLabel,\n textAlign: labelTextAlign,\n textVerticalAlign: labelTextVerticalAlign\n });\n }, this);\n },\n\n /**\n * @private\n */\n _splitLine: function (angleAxisModel, polar, ticksAngles, radiusExtent) {\n var splitLineModel = angleAxisModel.getModel('splitLine');\n var lineStyleModel = splitLineModel.getModel('lineStyle');\n var lineColors = lineStyleModel.get('color');\n var lineCount = 0;\n lineColors = lineColors instanceof Array ? lineColors : [lineColors];\n var splitLines = [];\n\n for (var i = 0; i < ticksAngles.length; i++) {\n var colorIndex = lineCount++ % lineColors.length;\n splitLines[colorIndex] = splitLines[colorIndex] || [];\n splitLines[colorIndex].push(new graphic.Line({\n shape: getAxisLineShape(polar, radiusExtent, ticksAngles[i].coord)\n }));\n } // Simple optimization\n // Batching the lines if color are the same\n\n\n for (var i = 0; i < splitLines.length; i++) {\n this.group.add(graphic.mergePath(splitLines[i], {\n style: zrUtil.defaults({\n stroke: lineColors[i % lineColors.length]\n }, lineStyleModel.getLineStyle()),\n silent: true,\n z: angleAxisModel.get('z')\n }));\n }\n },\n\n /**\n * @private\n */\n _splitArea: function (angleAxisModel, polar, ticksAngles, radiusExtent) {\n if (!ticksAngles.length) {\n return;\n }\n\n var splitAreaModel = angleAxisModel.getModel('splitArea');\n var areaStyleModel = splitAreaModel.getModel('areaStyle');\n var areaColors = areaStyleModel.get('color');\n var lineCount = 0;\n areaColors = areaColors instanceof Array ? areaColors : [areaColors];\n var splitAreas = [];\n var RADIAN = Math.PI / 180;\n var prevAngle = -ticksAngles[0].coord * RADIAN;\n var r0 = Math.min(radiusExtent[0], radiusExtent[1]);\n var r1 = Math.max(radiusExtent[0], radiusExtent[1]);\n var clockwise = angleAxisModel.get('clockwise');\n\n for (var i = 1; i < ticksAngles.length; i++) {\n var colorIndex = lineCount++ % areaColors.length;\n splitAreas[colorIndex] = splitAreas[colorIndex] || [];\n splitAreas[colorIndex].push(new graphic.Sector({\n shape: {\n cx: polar.cx,\n cy: polar.cy,\n r0: r0,\n r: r1,\n startAngle: prevAngle,\n endAngle: -ticksAngles[i].coord * RADIAN,\n clockwise: clockwise\n },\n silent: true\n }));\n prevAngle = -ticksAngles[i].coord * RADIAN;\n } // Simple optimization\n // Batching the lines if color are the same\n\n\n for (var i = 0; i < splitAreas.length; i++) {\n this.group.add(graphic.mergePath(splitAreas[i], {\n style: zrUtil.defaults({\n fill: areaColors[i % areaColors.length]\n }, areaStyleModel.getAreaStyle()),\n silent: true\n }));\n }\n }\n});\n\nmodule.exports = _default;","var isObject = require('./isObject'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = value.replace(reTrim, '');\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrender = require(\"zrender/lib/zrender\");\n\nexports.zrender = zrender;\n\nvar matrix = require(\"zrender/lib/core/matrix\");\n\nexports.matrix = matrix;\n\nvar vector = require(\"zrender/lib/core/vector\");\n\nexports.vector = vector;\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar colorTool = require(\"zrender/lib/tool/color\");\n\nexports.color = colorTool;\n\nvar graphicUtil = require(\"./util/graphic\");\n\nvar numberUtil = require(\"./util/number\");\n\nexports.number = numberUtil;\n\nvar formatUtil = require(\"./util/format\");\n\nexports.format = formatUtil;\n\nvar _throttle = require(\"./util/throttle\");\n\nvar throttle = _throttle.throttle;\nexports.throttle = _throttle.throttle;\n\nvar ecHelper = require(\"./helper\");\n\nexports.helper = ecHelper;\n\nvar parseGeoJSON = require(\"./coord/geo/parseGeoJson\");\n\nexports.parseGeoJSON = parseGeoJSON;\n\nvar _List = require(\"./data/List\");\n\nexports.List = _List;\n\nvar _Model = require(\"./model/Model\");\n\nexports.Model = _Model;\n\nvar _Axis = require(\"./coord/Axis\");\n\nexports.Axis = _Axis;\n\nvar _env = require(\"zrender/lib/core/env\");\n\nexports.env = _env;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Do not mount those modules on 'src/echarts' for better tree shaking.\n */\nvar parseGeoJson = parseGeoJSON;\nvar ecUtil = {};\nzrUtil.each(['map', 'each', 'filter', 'indexOf', 'inherits', 'reduce', 'filter', 'bind', 'curry', 'isArray', 'isString', 'isObject', 'isFunction', 'extend', 'defaults', 'clone', 'merge'], function (name) {\n ecUtil[name] = zrUtil[name];\n});\nvar graphic = {};\nzrUtil.each(['extendShape', 'extendPath', 'makePath', 'makeImage', 'mergePath', 'resizePath', 'createIcon', 'setHoverStyle', 'setLabelStyle', 'setTextStyle', 'setText', 'getFont', 'updateProps', 'initProps', 'getTransform', 'clipPointsByRect', 'clipRectByRect', 'Group', 'Image', 'Text', 'Circle', 'Sector', 'Ring', 'Polygon', 'Polyline', 'Rect', 'Line', 'BezierCurve', 'Arc', 'IncrementalDisplayable', 'CompoundPath', 'LinearGradient', 'RadialGradient', 'BoundingRect'], function (name) {\n graphic[name] = graphicUtil[name];\n});\nexports.parseGeoJson = parseGeoJson;\nexports.util = ecUtil;\nexports.graphic = graphic;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar lang = require(\"../lang\");\n\nvar _dataProvider = require(\"../data/helper/dataProvider\");\n\nvar retrieveRawValue = _dataProvider.retrieveRawValue;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nfunction _default(dom, ecModel) {\n var ariaModel = ecModel.getModel('aria');\n\n if (!ariaModel.get('show')) {\n return;\n } else if (ariaModel.get('description')) {\n dom.setAttribute('aria-label', ariaModel.get('description'));\n return;\n }\n\n var seriesCnt = 0;\n ecModel.eachSeries(function (seriesModel, idx) {\n ++seriesCnt;\n }, this);\n var maxDataCnt = ariaModel.get('data.maxCount') || 10;\n var maxSeriesCnt = ariaModel.get('series.maxCount') || 10;\n var displaySeriesCnt = Math.min(seriesCnt, maxSeriesCnt);\n var ariaLabel;\n\n if (seriesCnt < 1) {\n // No series, no aria label\n return;\n } else {\n var title = getTitle();\n\n if (title) {\n ariaLabel = replace(getConfig('general.withTitle'), {\n title: title\n });\n } else {\n ariaLabel = getConfig('general.withoutTitle');\n }\n\n var seriesLabels = [];\n var prefix = seriesCnt > 1 ? 'series.multiple.prefix' : 'series.single.prefix';\n ariaLabel += replace(getConfig(prefix), {\n seriesCount: seriesCnt\n });\n ecModel.eachSeries(function (seriesModel, idx) {\n if (idx < displaySeriesCnt) {\n var seriesLabel;\n var seriesName = seriesModel.get('name');\n var seriesTpl = 'series.' + (seriesCnt > 1 ? 'multiple' : 'single') + '.';\n seriesLabel = getConfig(seriesName ? seriesTpl + 'withName' : seriesTpl + 'withoutName');\n seriesLabel = replace(seriesLabel, {\n seriesId: seriesModel.seriesIndex,\n seriesName: seriesModel.get('name'),\n seriesType: getSeriesTypeName(seriesModel.subType)\n });\n var data = seriesModel.getData();\n window.data = data;\n\n if (data.count() > maxDataCnt) {\n // Show part of data\n seriesLabel += replace(getConfig('data.partialData'), {\n displayCnt: maxDataCnt\n });\n } else {\n seriesLabel += getConfig('data.allData');\n }\n\n var dataLabels = [];\n\n for (var i = 0; i < data.count(); i++) {\n if (i < maxDataCnt) {\n var name = data.getName(i);\n var value = retrieveRawValue(data, i);\n dataLabels.push(replace(name ? getConfig('data.withName') : getConfig('data.withoutName'), {\n name: name,\n value: value\n }));\n }\n }\n\n seriesLabel += dataLabels.join(getConfig('data.separator.middle')) + getConfig('data.separator.end');\n seriesLabels.push(seriesLabel);\n }\n });\n ariaLabel += seriesLabels.join(getConfig('series.multiple.separator.middle')) + getConfig('series.multiple.separator.end');\n dom.setAttribute('aria-label', ariaLabel);\n }\n\n function replace(str, keyValues) {\n if (typeof str !== 'string') {\n return str;\n }\n\n var result = str;\n zrUtil.each(keyValues, function (value, key) {\n result = result.replace(new RegExp('\\\\{\\\\s*' + key + '\\\\s*\\\\}', 'g'), value);\n });\n return result;\n }\n\n function getConfig(path) {\n var userConfig = ariaModel.get(path);\n\n if (userConfig == null) {\n var pathArr = path.split('.');\n var result = lang.aria;\n\n for (var i = 0; i < pathArr.length; ++i) {\n result = result[pathArr[i]];\n }\n\n return result;\n } else {\n return userConfig;\n }\n }\n\n function getTitle() {\n var title = ecModel.getModel('title').option;\n\n if (title && title.length) {\n title = title[0];\n }\n\n return title && title.text;\n }\n\n function getSeriesTypeName(type) {\n return lang.series.typeNames[type] || '自定义图';\n }\n}\n\nmodule.exports = _default;","var Animator = require(\"../animation/Animator\");\n\nvar log = require(\"../core/log\");\n\nvar _util = require(\"../core/util\");\n\nvar isString = _util.isString;\nvar isFunction = _util.isFunction;\nvar isObject = _util.isObject;\nvar isArrayLike = _util.isArrayLike;\nvar indexOf = _util.indexOf;\n\n/**\n * @alias modue:zrender/mixin/Animatable\n * @constructor\n */\nvar Animatable = function () {\n /**\n * @type {Array.<module:zrender/animation/Animator>}\n * @readOnly\n */\n this.animators = [];\n};\n\nAnimatable.prototype = {\n constructor: Animatable,\n\n /**\n * 动画\n *\n * @param {string} path The path to fetch value from object, like 'a.b.c'.\n * @param {boolean} [loop] Whether to loop animation.\n * @return {module:zrender/animation/Animator}\n * @example:\n * el.animate('style', false)\n * .when(1000, {x: 10} )\n * .done(function(){ // Animation done })\n * .start()\n */\n animate: function (path, loop) {\n var target;\n var animatingShape = false;\n var el = this;\n var zr = this.__zr;\n\n if (path) {\n var pathSplitted = path.split('.');\n var prop = el; // If animating shape\n\n animatingShape = pathSplitted[0] === 'shape';\n\n for (var i = 0, l = pathSplitted.length; i < l; i++) {\n if (!prop) {\n continue;\n }\n\n prop = prop[pathSplitted[i]];\n }\n\n if (prop) {\n target = prop;\n }\n } else {\n target = el;\n }\n\n if (!target) {\n log('Property \"' + path + '\" is not existed in element ' + el.id);\n return;\n }\n\n var animators = el.animators;\n var animator = new Animator(target, loop);\n animator.during(function (target) {\n el.dirty(animatingShape);\n }).done(function () {\n // FIXME Animator will not be removed if use `Animator#stop` to stop animation\n animators.splice(indexOf(animators, animator), 1);\n });\n animators.push(animator); // If animate after added to the zrender\n\n if (zr) {\n zr.animation.addAnimator(animator);\n }\n\n return animator;\n },\n\n /**\n * 停止动画\n * @param {boolean} forwardToLast If move to last frame before stop\n */\n stopAnimation: function (forwardToLast) {\n var animators = this.animators;\n var len = animators.length;\n\n for (var i = 0; i < len; i++) {\n animators[i].stop(forwardToLast);\n }\n\n animators.length = 0;\n return this;\n },\n\n /**\n * Caution: this method will stop previous animation.\n * So do not use this method to one element twice before\n * animation starts, unless you know what you are doing.\n * @param {Object} target\n * @param {number} [time=500] Time in ms\n * @param {string} [easing='linear']\n * @param {number} [delay=0]\n * @param {Function} [callback]\n * @param {Function} [forceAnimate] Prevent stop animation and callback\n * immediently when target values are the same as current values.\n *\n * @example\n * // Animate position\n * el.animateTo({\n * position: [10, 10]\n * }, function () { // done })\n *\n * // Animate shape, style and position in 100ms, delayed 100ms, with cubicOut easing\n * el.animateTo({\n * shape: {\n * width: 500\n * },\n * style: {\n * fill: 'red'\n * }\n * position: [10, 10]\n * }, 100, 100, 'cubicOut', function () { // done })\n */\n // TODO Return animation key\n animateTo: function (target, time, delay, easing, callback, forceAnimate) {\n animateTo(this, target, time, delay, easing, callback, forceAnimate);\n },\n\n /**\n * Animate from the target state to current state.\n * The params and the return value are the same as `this.animateTo`.\n */\n animateFrom: function (target, time, delay, easing, callback, forceAnimate) {\n animateTo(this, target, time, delay, easing, callback, forceAnimate, true);\n }\n};\n\nfunction animateTo(animatable, target, time, delay, easing, callback, forceAnimate, reverse) {\n // animateTo(target, time, easing, callback);\n if (isString(delay)) {\n callback = easing;\n easing = delay;\n delay = 0;\n } // animateTo(target, time, delay, callback);\n else if (isFunction(easing)) {\n callback = easing;\n easing = 'linear';\n delay = 0;\n } // animateTo(target, time, callback);\n else if (isFunction(delay)) {\n callback = delay;\n delay = 0;\n } // animateTo(target, callback)\n else if (isFunction(time)) {\n callback = time;\n time = 500;\n } // animateTo(target)\n else if (!time) {\n time = 500;\n } // Stop all previous animations\n\n\n animatable.stopAnimation();\n animateToShallow(animatable, '', animatable, target, time, delay, reverse); // Animators may be removed immediately after start\n // if there is nothing to animate\n\n var animators = animatable.animators.slice();\n var count = animators.length;\n\n function done() {\n count--;\n\n if (!count) {\n callback && callback();\n }\n } // No animators. This should be checked before animators[i].start(),\n // because 'done' may be executed immediately if no need to animate.\n\n\n if (!count) {\n callback && callback();\n } // Start after all animators created\n // Incase any animator is done immediately when all animation properties are not changed\n\n\n for (var i = 0; i < animators.length; i++) {\n animators[i].done(done).start(easing, forceAnimate);\n }\n}\n/**\n * @param {string} path=''\n * @param {Object} source=animatable\n * @param {Object} target\n * @param {number} [time=500]\n * @param {number} [delay=0]\n * @param {boolean} [reverse] If `true`, animate\n * from the `target` to current state.\n *\n * @example\n * // Animate position\n * el._animateToShallow({\n * position: [10, 10]\n * })\n *\n * // Animate shape, style and position in 100ms, delayed 100ms\n * el._animateToShallow({\n * shape: {\n * width: 500\n * },\n * style: {\n * fill: 'red'\n * }\n * position: [10, 10]\n * }, 100, 100)\n */\n\n\nfunction animateToShallow(animatable, path, source, target, time, delay, reverse) {\n var objShallow = {};\n var propertyCount = 0;\n\n for (var name in target) {\n if (!target.hasOwnProperty(name)) {\n continue;\n }\n\n if (source[name] != null) {\n if (isObject(target[name]) && !isArrayLike(target[name])) {\n animateToShallow(animatable, path ? path + '.' + name : name, source[name], target[name], time, delay, reverse);\n } else {\n if (reverse) {\n objShallow[name] = source[name];\n setAttrByPath(animatable, path, name, target[name]);\n } else {\n objShallow[name] = target[name];\n }\n\n propertyCount++;\n }\n } else if (target[name] != null && !reverse) {\n setAttrByPath(animatable, path, name, target[name]);\n }\n }\n\n if (propertyCount > 0) {\n animatable.animate(path, false).when(time == null ? 500 : time, objShallow).delay(delay || 0);\n }\n}\n\nfunction setAttrByPath(el, path, name, value) {\n // Attr directly if not has property\n // FIXME, if some property not needed for element ?\n if (!path) {\n el.attr(name, value);\n } else {\n // Only support set shape or style\n var props = {};\n props[path] = {};\n props[path][name] = value;\n el.attr(props);\n }\n}\n\nvar _default = Animatable;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Region = require(\"./Region\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Parse and decode geo json\n * @module echarts/coord/geo/parseGeoJson\n */\nfunction decode(json) {\n if (!json.UTF8Encoding) {\n return json;\n }\n\n var encodeScale = json.UTF8Scale;\n\n if (encodeScale == null) {\n encodeScale = 1024;\n }\n\n var features = json.features;\n\n for (var f = 0; f < features.length; f++) {\n var feature = features[f];\n var geometry = feature.geometry;\n var coordinates = geometry.coordinates;\n var encodeOffsets = geometry.encodeOffsets;\n\n for (var c = 0; c < coordinates.length; c++) {\n var coordinate = coordinates[c];\n\n if (geometry.type === 'Polygon') {\n coordinates[c] = decodePolygon(coordinate, encodeOffsets[c], encodeScale);\n } else if (geometry.type === 'MultiPolygon') {\n for (var c2 = 0; c2 < coordinate.length; c2++) {\n var polygon = coordinate[c2];\n coordinate[c2] = decodePolygon(polygon, encodeOffsets[c][c2], encodeScale);\n }\n }\n }\n } // Has been decoded\n\n\n json.UTF8Encoding = false;\n return json;\n}\n\nfunction decodePolygon(coordinate, encodeOffsets, encodeScale) {\n var result = [];\n var prevX = encodeOffsets[0];\n var prevY = encodeOffsets[1];\n\n for (var i = 0; i < coordinate.length; i += 2) {\n var x = coordinate.charCodeAt(i) - 64;\n var y = coordinate.charCodeAt(i + 1) - 64; // ZigZag decoding\n\n x = x >> 1 ^ -(x & 1);\n y = y >> 1 ^ -(y & 1); // Delta deocding\n\n x += prevX;\n y += prevY;\n prevX = x;\n prevY = y; // Dequantize\n\n result.push([x / encodeScale, y / encodeScale]);\n }\n\n return result;\n}\n/**\n * @alias module:echarts/coord/geo/parseGeoJson\n * @param {Object} geoJson\n * @return {module:zrender/container/Group}\n */\n\n\nfunction _default(geoJson) {\n decode(geoJson);\n return zrUtil.map(zrUtil.filter(geoJson.features, function (featureObj) {\n // Output of mapshaper may have geometry null\n return featureObj.geometry && featureObj.properties && featureObj.geometry.coordinates.length > 0;\n }), function (featureObj) {\n var properties = featureObj.properties;\n var geo = featureObj.geometry;\n var coordinates = geo.coordinates;\n var geometries = [];\n\n if (geo.type === 'Polygon') {\n geometries.push({\n type: 'polygon',\n // According to the GeoJSON specification.\n // First must be exterior, and the rest are all interior(holes).\n exterior: coordinates[0],\n interiors: coordinates.slice(1)\n });\n }\n\n if (geo.type === 'MultiPolygon') {\n zrUtil.each(coordinates, function (item) {\n if (item[0]) {\n geometries.push({\n type: 'polygon',\n exterior: item[0],\n interiors: item.slice(1)\n });\n }\n });\n }\n\n var region = new Region(properties.name, geometries, properties.cp);\n region.properties = properties;\n return region;\n });\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar colorAll = ['#37A2DA', '#32C5E9', '#67E0E3', '#9FE6B8', '#FFDB5C', '#ff9f7f', '#fb7293', '#E062AE', '#E690D1', '#e7bcf3', '#9d96f5', '#8378EA', '#96BFFF'];\nvar _default = {\n color: colorAll,\n colorLayer: [['#37A2DA', '#ffd85c', '#fd7b5f'], ['#37A2DA', '#67E0E3', '#FFDB5C', '#ff9f7f', '#E062AE', '#9d96f5'], ['#37A2DA', '#32C5E9', '#9FE6B8', '#FFDB5C', '#ff9f7f', '#fb7293', '#e7bcf3', '#8378EA', '#96BFFF'], colorAll]\n};\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _dataProvider = require(\"../../data/helper/dataProvider\");\n\nvar retrieveRawValue = _dataProvider.retrieveRawValue;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @param {module:echarts/data/List} data\n * @param {number} dataIndex\n * @return {string} label string. Not null/undefined\n */\nfunction getDefaultLabel(data, dataIndex) {\n var labelDims = data.mapDimension('defaultedLabel', true);\n var len = labelDims.length; // Simple optimization (in lots of cases, label dims length is 1)\n\n if (len === 1) {\n return retrieveRawValue(data, dataIndex, labelDims[0]);\n } else if (len) {\n var vals = [];\n\n for (var i = 0; i < labelDims.length; i++) {\n var val = retrieveRawValue(data, dataIndex, labelDims[i]);\n vals.push(val);\n }\n\n return vals.join(' ');\n }\n}\n\nexports.getDefaultLabel = getDefaultLabel;","var Path = require(\"../Path\");\n\nvar roundRectHelper = require(\"../helper/roundRect\");\n\nvar _subPixelOptimize = require(\"../helper/subPixelOptimize\");\n\nvar subPixelOptimizeRect = _subPixelOptimize.subPixelOptimizeRect;\n\n/**\n * 矩形\n * @module zrender/graphic/shape/Rect\n */\n// Avoid create repeatly.\nvar subPixelOptimizeOutputShape = {};\n\nvar _default = Path.extend({\n type: 'rect',\n shape: {\n // 左上、右上、右下、左下角的半径依次为r1、r2、r3、r4\n // r缩写为1 相当于 [1, 1, 1, 1]\n // r缩写为[1] 相当于 [1, 1, 1, 1]\n // r缩写为[1, 2] 相当于 [1, 2, 1, 2]\n // r缩写为[1, 2, 3] 相当于 [1, 2, 3, 2]\n r: 0,\n x: 0,\n y: 0,\n width: 0,\n height: 0\n },\n buildPath: function (ctx, shape) {\n var x;\n var y;\n var width;\n var height;\n\n if (this.subPixelOptimize) {\n subPixelOptimizeRect(subPixelOptimizeOutputShape, shape, this.style);\n x = subPixelOptimizeOutputShape.x;\n y = subPixelOptimizeOutputShape.y;\n width = subPixelOptimizeOutputShape.width;\n height = subPixelOptimizeOutputShape.height;\n subPixelOptimizeOutputShape.r = shape.r;\n shape = subPixelOptimizeOutputShape;\n } else {\n x = shape.x;\n y = shape.y;\n width = shape.width;\n height = shape.height;\n }\n\n if (!shape.r) {\n ctx.rect(x, y, width, height);\n } else {\n roundRectHelper.buildPath(ctx, shape);\n }\n\n ctx.closePath();\n return;\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar modelUtil = require(\"../util/model\");\n\nvar ComponentModel = require(\"./Component\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * ECharts option manager\n *\n * @module {echarts/model/OptionManager}\n */\nvar each = zrUtil.each;\nvar clone = zrUtil.clone;\nvar map = zrUtil.map;\nvar merge = zrUtil.merge;\nvar QUERY_REG = /^(min|max)?(.+)$/;\n/**\n * TERM EXPLANATIONS:\n *\n * [option]:\n *\n * An object that contains definitions of components. For example:\n * var option = {\n * title: {...},\n * legend: {...},\n * visualMap: {...},\n * series: [\n * {data: [...]},\n * {data: [...]},\n * ...\n * ]\n * };\n *\n * [rawOption]:\n *\n * An object input to echarts.setOption. 'rawOption' may be an\n * 'option', or may be an object contains multi-options. For example:\n * var option = {\n * baseOption: {\n * title: {...},\n * legend: {...},\n * series: [\n * {data: [...]},\n * {data: [...]},\n * ...\n * ]\n * },\n * timeline: {...},\n * options: [\n * {title: {...}, series: {data: [...]}},\n * {title: {...}, series: {data: [...]}},\n * ...\n * ],\n * media: [\n * {\n * query: {maxWidth: 320},\n * option: {series: {x: 20}, visualMap: {show: false}}\n * },\n * {\n * query: {minWidth: 320, maxWidth: 720},\n * option: {series: {x: 500}, visualMap: {show: true}}\n * },\n * {\n * option: {series: {x: 1200}, visualMap: {show: true}}\n * }\n * ]\n * };\n *\n * @alias module:echarts/model/OptionManager\n * @param {module:echarts/ExtensionAPI} api\n */\n\nfunction OptionManager(api) {\n /**\n * @private\n * @type {module:echarts/ExtensionAPI}\n */\n this._api = api;\n /**\n * @private\n * @type {Array.<number>}\n */\n\n this._timelineOptions = [];\n /**\n * @private\n * @type {Array.<Object>}\n */\n\n this._mediaList = [];\n /**\n * @private\n * @type {Object}\n */\n\n this._mediaDefault;\n /**\n * -1, means default.\n * empty means no media.\n * @private\n * @type {Array.<number>}\n */\n\n this._currentMediaIndices = [];\n /**\n * @private\n * @type {Object}\n */\n\n this._optionBackup;\n /**\n * @private\n * @type {Object}\n */\n\n this._newBaseOption;\n} // timeline.notMerge is not supported in ec3. Firstly there is rearly\n// case that notMerge is needed. Secondly supporting 'notMerge' requires\n// rawOption cloned and backuped when timeline changed, which does no\n// good to performance. What's more, that both timeline and setOption\n// method supply 'notMerge' brings complex and some problems.\n// Consider this case:\n// (step1) chart.setOption({timeline: {notMerge: false}, ...}, false);\n// (step2) chart.setOption({timeline: {notMerge: true}, ...}, false);\n\n\nOptionManager.prototype = {\n constructor: OptionManager,\n\n /**\n * @public\n * @param {Object} rawOption Raw option.\n * @param {module:echarts/model/Global} ecModel\n * @param {Array.<Function>} optionPreprocessorFuncs\n * @return {Object} Init option\n */\n setOption: function (rawOption, optionPreprocessorFuncs) {\n if (rawOption) {\n // That set dat primitive is dangerous if user reuse the data when setOption again.\n zrUtil.each(modelUtil.normalizeToArray(rawOption.series), function (series) {\n series && series.data && zrUtil.isTypedArray(series.data) && zrUtil.setAsPrimitive(series.data);\n });\n } // Caution: some series modify option data, if do not clone,\n // it should ensure that the repeat modify correctly\n // (create a new object when modify itself).\n\n\n rawOption = clone(rawOption, true); // FIXME\n // 如果 timeline options 或者 media 中设置了某个属性,而baseOption中没有设置,则进行警告。\n\n var oldOptionBackup = this._optionBackup;\n var newParsedOption = parseRawOption.call(this, rawOption, optionPreprocessorFuncs, !oldOptionBackup);\n this._newBaseOption = newParsedOption.baseOption; // For setOption at second time (using merge mode);\n\n if (oldOptionBackup) {\n // Only baseOption can be merged.\n mergeOption(oldOptionBackup.baseOption, newParsedOption.baseOption); // For simplicity, timeline options and media options do not support merge,\n // that is, if you `setOption` twice and both has timeline options, the latter\n // timeline opitons will not be merged to the formers, but just substitude them.\n\n if (newParsedOption.timelineOptions.length) {\n oldOptionBackup.timelineOptions = newParsedOption.timelineOptions;\n }\n\n if (newParsedOption.mediaList.length) {\n oldOptionBackup.mediaList = newParsedOption.mediaList;\n }\n\n if (newParsedOption.mediaDefault) {\n oldOptionBackup.mediaDefault = newParsedOption.mediaDefault;\n }\n } else {\n this._optionBackup = newParsedOption;\n }\n },\n\n /**\n * @param {boolean} isRecreate\n * @return {Object}\n */\n mountOption: function (isRecreate) {\n var optionBackup = this._optionBackup; // TODO\n // 如果没有reset功能则不clone。\n\n this._timelineOptions = map(optionBackup.timelineOptions, clone);\n this._mediaList = map(optionBackup.mediaList, clone);\n this._mediaDefault = clone(optionBackup.mediaDefault);\n this._currentMediaIndices = [];\n return clone(isRecreate // this._optionBackup.baseOption, which is created at the first `setOption`\n // called, and is merged into every new option by inner method `mergeOption`\n // each time `setOption` called, can be only used in `isRecreate`, because\n // its reliability is under suspicion. In other cases option merge is\n // performed by `model.mergeOption`.\n ? optionBackup.baseOption : this._newBaseOption);\n },\n\n /**\n * @param {module:echarts/model/Global} ecModel\n * @return {Object}\n */\n getTimelineOption: function (ecModel) {\n var option;\n var timelineOptions = this._timelineOptions;\n\n if (timelineOptions.length) {\n // getTimelineOption can only be called after ecModel inited,\n // so we can get currentIndex from timelineModel.\n var timelineModel = ecModel.getComponent('timeline');\n\n if (timelineModel) {\n option = clone(timelineOptions[timelineModel.getCurrentIndex()], true);\n }\n }\n\n return option;\n },\n\n /**\n * @param {module:echarts/model/Global} ecModel\n * @return {Array.<Object>}\n */\n getMediaOption: function (ecModel) {\n var ecWidth = this._api.getWidth();\n\n var ecHeight = this._api.getHeight();\n\n var mediaList = this._mediaList;\n var mediaDefault = this._mediaDefault;\n var indices = [];\n var result = []; // No media defined.\n\n if (!mediaList.length && !mediaDefault) {\n return result;\n } // Multi media may be applied, the latter defined media has higher priority.\n\n\n for (var i = 0, len = mediaList.length; i < len; i++) {\n if (applyMediaQuery(mediaList[i].query, ecWidth, ecHeight)) {\n indices.push(i);\n }\n } // FIXME\n // 是否mediaDefault应该强制用户设置,否则可能修改不能回归。\n\n\n if (!indices.length && mediaDefault) {\n indices = [-1];\n }\n\n if (indices.length && !indicesEquals(indices, this._currentMediaIndices)) {\n result = map(indices, function (index) {\n return clone(index === -1 ? mediaDefault.option : mediaList[index].option);\n });\n } // Otherwise return nothing.\n\n\n this._currentMediaIndices = indices;\n return result;\n }\n};\n\nfunction parseRawOption(rawOption, optionPreprocessorFuncs, isNew) {\n var timelineOptions = [];\n var mediaList = [];\n var mediaDefault;\n var baseOption; // Compatible with ec2.\n\n var timelineOpt = rawOption.timeline;\n\n if (rawOption.baseOption) {\n baseOption = rawOption.baseOption;\n } // For timeline\n\n\n if (timelineOpt || rawOption.options) {\n baseOption = baseOption || {};\n timelineOptions = (rawOption.options || []).slice();\n } // For media query\n\n\n if (rawOption.media) {\n baseOption = baseOption || {};\n var media = rawOption.media;\n each(media, function (singleMedia) {\n if (singleMedia && singleMedia.option) {\n if (singleMedia.query) {\n mediaList.push(singleMedia);\n } else if (!mediaDefault) {\n // Use the first media default.\n mediaDefault = singleMedia;\n }\n }\n });\n } // For normal option\n\n\n if (!baseOption) {\n baseOption = rawOption;\n } // Set timelineOpt to baseOption in ec3,\n // which is convenient for merge option.\n\n\n if (!baseOption.timeline) {\n baseOption.timeline = timelineOpt;\n } // Preprocess.\n\n\n each([baseOption].concat(timelineOptions).concat(zrUtil.map(mediaList, function (media) {\n return media.option;\n })), function (option) {\n each(optionPreprocessorFuncs, function (preProcess) {\n preProcess(option, isNew);\n });\n });\n return {\n baseOption: baseOption,\n timelineOptions: timelineOptions,\n mediaDefault: mediaDefault,\n mediaList: mediaList\n };\n}\n/**\n * @see <http://www.w3.org/TR/css3-mediaqueries/#media1>\n * Support: width, height, aspectRatio\n * Can use max or min as prefix.\n */\n\n\nfunction applyMediaQuery(query, ecWidth, ecHeight) {\n var realMap = {\n width: ecWidth,\n height: ecHeight,\n aspectratio: ecWidth / ecHeight // lowser case for convenientce.\n\n };\n var applicatable = true;\n zrUtil.each(query, function (value, attr) {\n var matched = attr.match(QUERY_REG);\n\n if (!matched || !matched[1] || !matched[2]) {\n return;\n }\n\n var operator = matched[1];\n var realAttr = matched[2].toLowerCase();\n\n if (!compare(realMap[realAttr], value, operator)) {\n applicatable = false;\n }\n });\n return applicatable;\n}\n\nfunction compare(real, expect, operator) {\n if (operator === 'min') {\n return real >= expect;\n } else if (operator === 'max') {\n return real <= expect;\n } else {\n // Equals\n return real === expect;\n }\n}\n\nfunction indicesEquals(indices1, indices2) {\n // indices is always order by asc and has only finite number.\n return indices1.join(',') === indices2.join(',');\n}\n/**\n * Consider case:\n * `chart.setOption(opt1);`\n * Then user do some interaction like dataZoom, dataView changing.\n * `chart.setOption(opt2);`\n * Then user press 'reset button' in toolbox.\n *\n * After doing that all of the interaction effects should be reset, the\n * chart should be the same as the result of invoke\n * `chart.setOption(opt1); chart.setOption(opt2);`.\n *\n * Although it is not able ensure that\n * `chart.setOption(opt1); chart.setOption(opt2);` is equivalents to\n * `chart.setOption(merge(opt1, opt2));` exactly,\n * this might be the only simple way to implement that feature.\n *\n * MEMO: We've considered some other approaches:\n * 1. Each model handle its self restoration but not uniform treatment.\n * (Too complex in logic and error-prone)\n * 2. Use a shadow ecModel. (Performace expensive)\n */\n\n\nfunction mergeOption(oldOption, newOption) {\n newOption = newOption || {};\n each(newOption, function (newCptOpt, mainType) {\n if (newCptOpt == null) {\n return;\n }\n\n var oldCptOpt = oldOption[mainType];\n\n if (!ComponentModel.hasClass(mainType)) {\n oldOption[mainType] = merge(oldCptOpt, newCptOpt, true);\n } else {\n newCptOpt = modelUtil.normalizeToArray(newCptOpt);\n oldCptOpt = modelUtil.normalizeToArray(oldCptOpt);\n var mapResult = modelUtil.mappingToExists(oldCptOpt, newCptOpt);\n oldOption[mainType] = map(mapResult, function (item) {\n return item.option && item.exist ? merge(item.exist, item.option, true) : item.exist || item.option;\n });\n }\n });\n}\n\nvar _default = OptionManager;\nmodule.exports = _default;","var Path = require(\"../Path\");\n\nvar _subPixelOptimize = require(\"../helper/subPixelOptimize\");\n\nvar subPixelOptimizeLine = _subPixelOptimize.subPixelOptimizeLine;\n\n/**\n * 直线\n * @module zrender/graphic/shape/Line\n */\n// Avoid create repeatly.\nvar subPixelOptimizeOutputShape = {};\n\nvar _default = Path.extend({\n type: 'line',\n shape: {\n // Start point\n x1: 0,\n y1: 0,\n // End point\n x2: 0,\n y2: 0,\n percent: 1\n },\n style: {\n stroke: '#000',\n fill: null\n },\n buildPath: function (ctx, shape) {\n var x1;\n var y1;\n var x2;\n var y2;\n\n if (this.subPixelOptimize) {\n subPixelOptimizeLine(subPixelOptimizeOutputShape, shape, this.style);\n x1 = subPixelOptimizeOutputShape.x1;\n y1 = subPixelOptimizeOutputShape.y1;\n x2 = subPixelOptimizeOutputShape.x2;\n y2 = subPixelOptimizeOutputShape.y2;\n } else {\n x1 = shape.x1;\n y1 = shape.y1;\n x2 = shape.x2;\n y2 = shape.y2;\n }\n\n var percent = shape.percent;\n\n if (percent === 0) {\n return;\n }\n\n ctx.moveTo(x1, y1);\n\n if (percent < 1) {\n x2 = x1 * (1 - percent) + x2 * percent;\n y2 = y1 * (1 - percent) + y2 * percent;\n }\n\n ctx.lineTo(x2, y2);\n },\n\n /**\n * Get point at percent\n * @param {number} percent\n * @return {Array.<number>}\n */\n pointAt: function (p) {\n var shape = this.shape;\n return [shape.x1 * (1 - p) + shape.x2 * p, shape.y1 * (1 - p) + shape.y2 * p];\n }\n});\n\nmodule.exports = _default;","// TODO Draggable for group\n// FIXME Draggable on element which has parent rotation or scale\nfunction Draggable() {\n this.on('mousedown', this._dragStart, this);\n this.on('mousemove', this._drag, this);\n this.on('mouseup', this._dragEnd, this);\n this.on('globalout', this._dragEnd, this); // this._dropTarget = null;\n // this._draggingTarget = null;\n // this._x = 0;\n // this._y = 0;\n}\n\nDraggable.prototype = {\n constructor: Draggable,\n _dragStart: function (e) {\n var draggingTarget = e.target;\n\n if (draggingTarget && draggingTarget.draggable) {\n this._draggingTarget = draggingTarget;\n draggingTarget.dragging = true;\n this._x = e.offsetX;\n this._y = e.offsetY;\n this.dispatchToElement(param(draggingTarget, e), 'dragstart', e.event);\n }\n },\n _drag: function (e) {\n var draggingTarget = this._draggingTarget;\n\n if (draggingTarget) {\n var x = e.offsetX;\n var y = e.offsetY;\n var dx = x - this._x;\n var dy = y - this._y;\n this._x = x;\n this._y = y;\n draggingTarget.drift(dx, dy, e);\n this.dispatchToElement(param(draggingTarget, e), 'drag', e.event);\n var dropTarget = this.findHover(x, y, draggingTarget).target;\n var lastDropTarget = this._dropTarget;\n this._dropTarget = dropTarget;\n\n if (draggingTarget !== dropTarget) {\n if (lastDropTarget && dropTarget !== lastDropTarget) {\n this.dispatchToElement(param(lastDropTarget, e), 'dragleave', e.event);\n }\n\n if (dropTarget && dropTarget !== lastDropTarget) {\n this.dispatchToElement(param(dropTarget, e), 'dragenter', e.event);\n }\n }\n }\n },\n _dragEnd: function (e) {\n var draggingTarget = this._draggingTarget;\n\n if (draggingTarget) {\n draggingTarget.dragging = false;\n }\n\n this.dispatchToElement(param(draggingTarget, e), 'dragend', e.event);\n\n if (this._dropTarget) {\n this.dispatchToElement(param(this._dropTarget, e), 'drop', e.event);\n }\n\n this._draggingTarget = null;\n this._dropTarget = null;\n }\n};\n\nfunction param(target, e) {\n return {\n target: target,\n topTarget: e && e.topTarget\n };\n}\n\nvar _default = Draggable;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar echarts = require(\"../echarts\");\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar axisPointerModelHelper = require(\"./axisPointer/modelHelper\");\n\nvar axisTrigger = require(\"./axisPointer/axisTrigger\");\n\nrequire(\"./axisPointer/AxisPointerModel\");\n\nrequire(\"./axisPointer/AxisPointerView\");\n\nrequire(\"./axisPointer/CartesianAxisPointer\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// CartesianAxisPointer is not supposed to be required here. But consider\n// echarts.simple.js and online build tooltip, which only require gridSimple,\n// CartesianAxisPointer should be able to required somewhere.\necharts.registerPreprocessor(function (option) {\n // Always has a global axisPointerModel for default setting.\n if (option) {\n (!option.axisPointer || option.axisPointer.length === 0) && (option.axisPointer = {});\n var link = option.axisPointer.link; // Normalize to array to avoid object mergin. But if link\n // is not set, remain null/undefined, otherwise it will\n // override existent link setting.\n\n if (link && !zrUtil.isArray(link)) {\n option.axisPointer.link = [link];\n }\n }\n}); // This process should proformed after coordinate systems created\n// and series data processed. So put it on statistic processing stage.\n\necharts.registerProcessor(echarts.PRIORITY.PROCESSOR.STATISTIC, function (ecModel, api) {\n // Build axisPointerModel, mergin tooltip.axisPointer model for each axis.\n // allAxesInfo should be updated when setOption performed.\n ecModel.getComponent('axisPointer').coordSysAxesInfo = axisPointerModelHelper.collect(ecModel, api);\n}); // Broadcast to all views.\n\necharts.registerAction({\n type: 'updateAxisPointer',\n event: 'updateAxisPointer',\n update: ':updateAxisPointer'\n}, axisTrigger);","var Displayable = require(\"./Displayable\");\n\nvar zrUtil = require(\"../core/util\");\n\nvar PathProxy = require(\"../core/PathProxy\");\n\nvar pathContain = require(\"../contain/path\");\n\nvar Pattern = require(\"./Pattern\");\n\nvar getCanvasPattern = Pattern.prototype.getCanvasPattern;\nvar abs = Math.abs;\nvar pathProxyForDraw = new PathProxy(true);\n/**\n * @alias module:zrender/graphic/Path\n * @extends module:zrender/graphic/Displayable\n * @constructor\n * @param {Object} opts\n */\n\nfunction Path(opts) {\n Displayable.call(this, opts);\n /**\n * @type {module:zrender/core/PathProxy}\n * @readOnly\n */\n\n this.path = null;\n}\n\nPath.prototype = {\n constructor: Path,\n type: 'path',\n __dirtyPath: true,\n strokeContainThreshold: 5,\n\n /**\n * See `module:zrender/src/graphic/helper/subPixelOptimize`.\n * @type {boolean}\n */\n subPixelOptimize: false,\n brush: function (ctx, prevEl) {\n var style = this.style;\n var path = this.path || pathProxyForDraw;\n var hasStroke = style.hasStroke();\n var hasFill = style.hasFill();\n var fill = style.fill;\n var stroke = style.stroke;\n var hasFillGradient = hasFill && !!fill.colorStops;\n var hasStrokeGradient = hasStroke && !!stroke.colorStops;\n var hasFillPattern = hasFill && !!fill.image;\n var hasStrokePattern = hasStroke && !!stroke.image;\n style.bind(ctx, this, prevEl);\n this.setTransform(ctx);\n\n if (this.__dirty) {\n var rect; // Update gradient because bounding rect may changed\n\n if (hasFillGradient) {\n rect = rect || this.getBoundingRect();\n this._fillGradient = style.getGradient(ctx, fill, rect);\n }\n\n if (hasStrokeGradient) {\n rect = rect || this.getBoundingRect();\n this._strokeGradient = style.getGradient(ctx, stroke, rect);\n }\n } // Use the gradient or pattern\n\n\n if (hasFillGradient) {\n // PENDING If may have affect the state\n ctx.fillStyle = this._fillGradient;\n } else if (hasFillPattern) {\n ctx.fillStyle = getCanvasPattern.call(fill, ctx);\n }\n\n if (hasStrokeGradient) {\n ctx.strokeStyle = this._strokeGradient;\n } else if (hasStrokePattern) {\n ctx.strokeStyle = getCanvasPattern.call(stroke, ctx);\n }\n\n var lineDash = style.lineDash;\n var lineDashOffset = style.lineDashOffset;\n var ctxLineDash = !!ctx.setLineDash; // Update path sx, sy\n\n var scale = this.getGlobalScale();\n path.setScale(scale[0], scale[1]); // Proxy context\n // Rebuild path in following 2 cases\n // 1. Path is dirty\n // 2. Path needs javascript implemented lineDash stroking.\n // In this case, lineDash information will not be saved in PathProxy\n\n if (this.__dirtyPath || lineDash && !ctxLineDash && hasStroke) {\n path.beginPath(ctx); // Setting line dash before build path\n\n if (lineDash && !ctxLineDash) {\n path.setLineDash(lineDash);\n path.setLineDashOffset(lineDashOffset);\n }\n\n this.buildPath(path, this.shape, false); // Clear path dirty flag\n\n if (this.path) {\n this.__dirtyPath = false;\n }\n } else {\n // Replay path building\n ctx.beginPath();\n this.path.rebuildPath(ctx);\n }\n\n if (hasFill) {\n if (style.fillOpacity != null) {\n var originalGlobalAlpha = ctx.globalAlpha;\n ctx.globalAlpha = style.fillOpacity * style.opacity;\n path.fill(ctx);\n ctx.globalAlpha = originalGlobalAlpha;\n } else {\n path.fill(ctx);\n }\n }\n\n if (lineDash && ctxLineDash) {\n ctx.setLineDash(lineDash);\n ctx.lineDashOffset = lineDashOffset;\n }\n\n if (hasStroke) {\n if (style.strokeOpacity != null) {\n var originalGlobalAlpha = ctx.globalAlpha;\n ctx.globalAlpha = style.strokeOpacity * style.opacity;\n path.stroke(ctx);\n ctx.globalAlpha = originalGlobalAlpha;\n } else {\n path.stroke(ctx);\n }\n }\n\n if (lineDash && ctxLineDash) {\n // PENDING\n // Remove lineDash\n ctx.setLineDash([]);\n } // Draw rect text\n\n\n if (style.text != null) {\n // Only restore transform when needs draw text.\n this.restoreTransform(ctx);\n this.drawRectText(ctx, this.getBoundingRect());\n }\n },\n // When bundling path, some shape may decide if use moveTo to begin a new subpath or closePath\n // Like in circle\n buildPath: function (ctx, shapeCfg, inBundle) {},\n createPathProxy: function () {\n this.path = new PathProxy();\n },\n getBoundingRect: function () {\n var rect = this._rect;\n var style = this.style;\n var needsUpdateRect = !rect;\n\n if (needsUpdateRect) {\n var path = this.path;\n\n if (!path) {\n // Create path on demand.\n path = this.path = new PathProxy();\n }\n\n if (this.__dirtyPath) {\n path.beginPath();\n this.buildPath(path, this.shape, false);\n }\n\n rect = path.getBoundingRect();\n }\n\n this._rect = rect;\n\n if (style.hasStroke()) {\n // Needs update rect with stroke lineWidth when\n // 1. Element changes scale or lineWidth\n // 2. Shape is changed\n var rectWithStroke = this._rectWithStroke || (this._rectWithStroke = rect.clone());\n\n if (this.__dirty || needsUpdateRect) {\n rectWithStroke.copy(rect); // FIXME Must after updateTransform\n\n var w = style.lineWidth; // PENDING, Min line width is needed when line is horizontal or vertical\n\n var lineScale = style.strokeNoScale ? this.getLineScale() : 1; // Only add extra hover lineWidth when there are no fill\n\n if (!style.hasFill()) {\n w = Math.max(w, this.strokeContainThreshold || 4);\n } // Consider line width\n // Line scale can't be 0;\n\n\n if (lineScale > 1e-10) {\n rectWithStroke.width += w / lineScale;\n rectWithStroke.height += w / lineScale;\n rectWithStroke.x -= w / lineScale / 2;\n rectWithStroke.y -= w / lineScale / 2;\n }\n } // Return rect with stroke\n\n\n return rectWithStroke;\n }\n\n return rect;\n },\n contain: function (x, y) {\n var localPos = this.transformCoordToLocal(x, y);\n var rect = this.getBoundingRect();\n var style = this.style;\n x = localPos[0];\n y = localPos[1];\n\n if (rect.contain(x, y)) {\n var pathData = this.path.data;\n\n if (style.hasStroke()) {\n var lineWidth = style.lineWidth;\n var lineScale = style.strokeNoScale ? this.getLineScale() : 1; // Line scale can't be 0;\n\n if (lineScale > 1e-10) {\n // Only add extra hover lineWidth when there are no fill\n if (!style.hasFill()) {\n lineWidth = Math.max(lineWidth, this.strokeContainThreshold);\n }\n\n if (pathContain.containStroke(pathData, lineWidth / lineScale, x, y)) {\n return true;\n }\n }\n }\n\n if (style.hasFill()) {\n return pathContain.contain(pathData, x, y);\n }\n }\n\n return false;\n },\n\n /**\n * @param {boolean} dirtyPath\n */\n dirty: function (dirtyPath) {\n if (dirtyPath == null) {\n dirtyPath = true;\n } // Only mark dirty, not mark clean\n\n\n if (dirtyPath) {\n this.__dirtyPath = dirtyPath;\n this._rect = null;\n }\n\n this.__dirty = this.__dirtyText = true;\n this.__zr && this.__zr.refresh(); // Used as a clipping path\n\n if (this.__clipTarget) {\n this.__clipTarget.dirty();\n }\n },\n\n /**\n * Alias for animate('shape')\n * @param {boolean} loop\n */\n animateShape: function (loop) {\n return this.animate('shape', loop);\n },\n // Overwrite attrKV\n attrKV: function (key, value) {\n // FIXME\n if (key === 'shape') {\n this.setShape(value);\n this.__dirtyPath = true;\n this._rect = null;\n } else {\n Displayable.prototype.attrKV.call(this, key, value);\n }\n },\n\n /**\n * @param {Object|string} key\n * @param {*} value\n */\n setShape: function (key, value) {\n var shape = this.shape; // Path from string may not have shape\n\n if (shape) {\n if (zrUtil.isObject(key)) {\n for (var name in key) {\n if (key.hasOwnProperty(name)) {\n shape[name] = key[name];\n }\n }\n } else {\n shape[key] = value;\n }\n\n this.dirty(true);\n }\n\n return this;\n },\n getLineScale: function () {\n var m = this.transform; // Get the line scale.\n // Determinant of `m` means how much the area is enlarged by the\n // transformation. So its square root can be used as a scale factor\n // for width.\n\n return m && abs(m[0] - 1) > 1e-10 && abs(m[3] - 1) > 1e-10 ? Math.sqrt(abs(m[0] * m[3] - m[2] * m[1])) : 1;\n }\n};\n/**\n * 扩展一个 Path element, 比如星形,圆等。\n * Extend a path element\n * @param {Object} props\n * @param {string} props.type Path type\n * @param {Function} props.init Initialize\n * @param {Function} props.buildPath Overwrite buildPath method\n * @param {Object} [props.style] Extended default style config\n * @param {Object} [props.shape] Extended default shape config\n */\n\nPath.extend = function (defaults) {\n var Sub = function (opts) {\n Path.call(this, opts);\n\n if (defaults.style) {\n // Extend default style\n this.style.extendFrom(defaults.style, false);\n } // Extend default shape\n\n\n var defaultShape = defaults.shape;\n\n if (defaultShape) {\n this.shape = this.shape || {};\n var thisShape = this.shape;\n\n for (var name in defaultShape) {\n if (!thisShape.hasOwnProperty(name) && defaultShape.hasOwnProperty(name)) {\n thisShape[name] = defaultShape[name];\n }\n }\n }\n\n defaults.init && defaults.init.call(this, opts);\n };\n\n zrUtil.inherits(Sub, Path); // FIXME 不能 extend position, rotation 等引用对象\n\n for (var name in defaults) {\n // Extending prototype values and methods\n if (name !== 'style' && name !== 'shape') {\n Sub.prototype[name] = defaults[name];\n }\n }\n\n return Sub;\n};\n\nzrUtil.inherits(Path, Displayable);\nvar _default = Path;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Cartesian = require(\"./Cartesian\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nfunction Cartesian2D(name) {\n Cartesian.call(this, name);\n}\n\nCartesian2D.prototype = {\n constructor: Cartesian2D,\n type: 'cartesian2d',\n\n /**\n * @type {Array.<string>}\n * @readOnly\n */\n dimensions: ['x', 'y'],\n\n /**\n * Base axis will be used on stacking.\n *\n * @return {module:echarts/coord/cartesian/Axis2D}\n */\n getBaseAxis: function () {\n return this.getAxesByScale('ordinal')[0] || this.getAxesByScale('time')[0] || this.getAxis('x');\n },\n\n /**\n * If contain point\n * @param {Array.<number>} point\n * @return {boolean}\n */\n containPoint: function (point) {\n var axisX = this.getAxis('x');\n var axisY = this.getAxis('y');\n return axisX.contain(axisX.toLocalCoord(point[0])) && axisY.contain(axisY.toLocalCoord(point[1]));\n },\n\n /**\n * If contain data\n * @param {Array.<number>} data\n * @return {boolean}\n */\n containData: function (data) {\n return this.getAxis('x').containData(data[0]) && this.getAxis('y').containData(data[1]);\n },\n\n /**\n * @param {Array.<number>} data\n * @param {Array.<number>} out\n * @return {Array.<number>}\n */\n dataToPoint: function (data, reserved, out) {\n var xAxis = this.getAxis('x');\n var yAxis = this.getAxis('y');\n out = out || [];\n out[0] = xAxis.toGlobalCoord(xAxis.dataToCoord(data[0]));\n out[1] = yAxis.toGlobalCoord(yAxis.dataToCoord(data[1]));\n return out;\n },\n\n /**\n * @param {Array.<number>} data\n * @param {Array.<number>} out\n * @return {Array.<number>}\n */\n clampData: function (data, out) {\n var xScale = this.getAxis('x').scale;\n var yScale = this.getAxis('y').scale;\n var xAxisExtent = xScale.getExtent();\n var yAxisExtent = yScale.getExtent();\n var x = xScale.parse(data[0]);\n var y = yScale.parse(data[1]);\n out = out || [];\n out[0] = Math.min(Math.max(Math.min(xAxisExtent[0], xAxisExtent[1]), x), Math.max(xAxisExtent[0], xAxisExtent[1]));\n out[1] = Math.min(Math.max(Math.min(yAxisExtent[0], yAxisExtent[1]), y), Math.max(yAxisExtent[0], yAxisExtent[1]));\n return out;\n },\n\n /**\n * @param {Array.<number>} point\n * @param {Array.<number>} out\n * @return {Array.<number>}\n */\n pointToData: function (point, out) {\n var xAxis = this.getAxis('x');\n var yAxis = this.getAxis('y');\n out = out || [];\n out[0] = xAxis.coordToData(xAxis.toLocalCoord(point[0]));\n out[1] = yAxis.coordToData(yAxis.toLocalCoord(point[1]));\n return out;\n },\n\n /**\n * Get other axis\n * @param {module:echarts/coord/cartesian/Axis2D} axis\n */\n getOtherAxis: function (axis) {\n return this.getAxis(axis.dim === 'x' ? 'y' : 'x');\n }\n};\nzrUtil.inherits(Cartesian2D, Cartesian);\nvar _default = Cartesian2D;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _model = require(\"../../util/model\");\n\nvar makeInner = _model.makeInner;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @return {string} If large mode changed, return string 'reset';\n */\nfunction _default() {\n var inner = makeInner();\n return function (seriesModel) {\n var fields = inner(seriesModel);\n var pipelineContext = seriesModel.pipelineContext;\n var originalLarge = fields.large;\n var originalProgressive = fields.progressiveRender;\n var large = fields.large = pipelineContext.large;\n var progressive = fields.progressiveRender = pipelineContext.progressiveRender;\n return !!(originalLarge ^ large || originalProgressive ^ progressive) && 'reset';\n };\n}\n\nmodule.exports = _default;","// 9.4.2.3 ArraySpeciesCreate(originalArray, length)\nvar speciesConstructor = require('./_array-species-constructor');\n\nmodule.exports = function (original, length) {\n return new (speciesConstructor(original))(length);\n};\n","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Model = require(\"../../model/Model\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar each = zrUtil.each;\nvar curry = zrUtil.curry; // Build axisPointerModel, mergin tooltip.axisPointer model for each axis.\n// allAxesInfo should be updated when setOption performed.\n\nfunction collect(ecModel, api) {\n var result = {\n /**\n * key: makeKey(axis.model)\n * value: {\n * axis,\n * coordSys,\n * axisPointerModel,\n * triggerTooltip,\n * involveSeries,\n * snap,\n * seriesModels,\n * seriesDataCount\n * }\n */\n axesInfo: {},\n seriesInvolved: false,\n\n /**\n * key: makeKey(coordSys.model)\n * value: Object: key makeKey(axis.model), value: axisInfo\n */\n coordSysAxesInfo: {},\n coordSysMap: {}\n };\n collectAxesInfo(result, ecModel, api); // Check seriesInvolved for performance, in case too many series in some chart.\n\n result.seriesInvolved && collectSeriesInfo(result, ecModel);\n return result;\n}\n\nfunction collectAxesInfo(result, ecModel, api) {\n var globalTooltipModel = ecModel.getComponent('tooltip');\n var globalAxisPointerModel = ecModel.getComponent('axisPointer'); // links can only be set on global.\n\n var linksOption = globalAxisPointerModel.get('link', true) || [];\n var linkGroups = []; // Collect axes info.\n\n each(api.getCoordinateSystems(), function (coordSys) {\n // Some coordinate system do not support axes, like geo.\n if (!coordSys.axisPointerEnabled) {\n return;\n }\n\n var coordSysKey = makeKey(coordSys.model);\n var axesInfoInCoordSys = result.coordSysAxesInfo[coordSysKey] = {};\n result.coordSysMap[coordSysKey] = coordSys; // Set tooltip (like 'cross') is a convienent way to show axisPointer\n // for user. So we enable seting tooltip on coordSys model.\n\n var coordSysModel = coordSys.model;\n var baseTooltipModel = coordSysModel.getModel('tooltip', globalTooltipModel);\n each(coordSys.getAxes(), curry(saveTooltipAxisInfo, false, null)); // If axis tooltip used, choose tooltip axis for each coordSys.\n // Notice this case: coordSys is `grid` but not `cartesian2D` here.\n\n if (coordSys.getTooltipAxes && globalTooltipModel // If tooltip.showContent is set as false, tooltip will not\n // show but axisPointer will show as normal.\n && baseTooltipModel.get('show')) {\n // Compatible with previous logic. But series.tooltip.trigger: 'axis'\n // or series.data[n].tooltip.trigger: 'axis' are not support any more.\n var triggerAxis = baseTooltipModel.get('trigger') === 'axis';\n var cross = baseTooltipModel.get('axisPointer.type') === 'cross';\n var tooltipAxes = coordSys.getTooltipAxes(baseTooltipModel.get('axisPointer.axis'));\n\n if (triggerAxis || cross) {\n each(tooltipAxes.baseAxes, curry(saveTooltipAxisInfo, cross ? 'cross' : true, triggerAxis));\n }\n\n if (cross) {\n each(tooltipAxes.otherAxes, curry(saveTooltipAxisInfo, 'cross', false));\n }\n } // fromTooltip: true | false | 'cross'\n // triggerTooltip: true | false | null\n\n\n function saveTooltipAxisInfo(fromTooltip, triggerTooltip, axis) {\n var axisPointerModel = axis.model.getModel('axisPointer', globalAxisPointerModel);\n var axisPointerShow = axisPointerModel.get('show');\n\n if (!axisPointerShow || axisPointerShow === 'auto' && !fromTooltip && !isHandleTrigger(axisPointerModel)) {\n return;\n }\n\n if (triggerTooltip == null) {\n triggerTooltip = axisPointerModel.get('triggerTooltip');\n }\n\n axisPointerModel = fromTooltip ? makeAxisPointerModel(axis, baseTooltipModel, globalAxisPointerModel, ecModel, fromTooltip, triggerTooltip) : axisPointerModel;\n var snap = axisPointerModel.get('snap');\n var key = makeKey(axis.model);\n var involveSeries = triggerTooltip || snap || axis.type === 'category'; // If result.axesInfo[key] exist, override it (tooltip has higher priority).\n\n var axisInfo = result.axesInfo[key] = {\n key: key,\n axis: axis,\n coordSys: coordSys,\n axisPointerModel: axisPointerModel,\n triggerTooltip: triggerTooltip,\n involveSeries: involveSeries,\n snap: snap,\n useHandle: isHandleTrigger(axisPointerModel),\n seriesModels: []\n };\n axesInfoInCoordSys[key] = axisInfo;\n result.seriesInvolved |= involveSeries;\n var groupIndex = getLinkGroupIndex(linksOption, axis);\n\n if (groupIndex != null) {\n var linkGroup = linkGroups[groupIndex] || (linkGroups[groupIndex] = {\n axesInfo: {}\n });\n linkGroup.axesInfo[key] = axisInfo;\n linkGroup.mapper = linksOption[groupIndex].mapper;\n axisInfo.linkGroup = linkGroup;\n }\n }\n });\n}\n\nfunction makeAxisPointerModel(axis, baseTooltipModel, globalAxisPointerModel, ecModel, fromTooltip, triggerTooltip) {\n var tooltipAxisPointerModel = baseTooltipModel.getModel('axisPointer');\n var volatileOption = {};\n each(['type', 'snap', 'lineStyle', 'shadowStyle', 'label', 'animation', 'animationDurationUpdate', 'animationEasingUpdate', 'z'], function (field) {\n volatileOption[field] = zrUtil.clone(tooltipAxisPointerModel.get(field));\n }); // category axis do not auto snap, otherwise some tick that do not\n // has value can not be hovered. value/time/log axis default snap if\n // triggered from tooltip and trigger tooltip.\n\n volatileOption.snap = axis.type !== 'category' && !!triggerTooltip; // Compatibel with previous behavior, tooltip axis do not show label by default.\n // Only these properties can be overrided from tooltip to axisPointer.\n\n if (tooltipAxisPointerModel.get('type') === 'cross') {\n volatileOption.type = 'line';\n }\n\n var labelOption = volatileOption.label || (volatileOption.label = {}); // Follow the convention, do not show label when triggered by tooltip by default.\n\n labelOption.show == null && (labelOption.show = false);\n\n if (fromTooltip === 'cross') {\n // When 'cross', both axes show labels.\n var tooltipAxisPointerLabelShow = tooltipAxisPointerModel.get('label.show');\n labelOption.show = tooltipAxisPointerLabelShow != null ? tooltipAxisPointerLabelShow : true; // If triggerTooltip, this is a base axis, which should better not use cross style\n // (cross style is dashed by default)\n\n if (!triggerTooltip) {\n var crossStyle = volatileOption.lineStyle = tooltipAxisPointerModel.get('crossStyle');\n crossStyle && zrUtil.defaults(labelOption, crossStyle.textStyle);\n }\n }\n\n return axis.model.getModel('axisPointer', new Model(volatileOption, globalAxisPointerModel, ecModel));\n}\n\nfunction collectSeriesInfo(result, ecModel) {\n // Prepare data for axis trigger\n ecModel.eachSeries(function (seriesModel) {\n // Notice this case: this coordSys is `cartesian2D` but not `grid`.\n var coordSys = seriesModel.coordinateSystem;\n var seriesTooltipTrigger = seriesModel.get('tooltip.trigger', true);\n var seriesTooltipShow = seriesModel.get('tooltip.show', true);\n\n if (!coordSys || seriesTooltipTrigger === 'none' || seriesTooltipTrigger === false || seriesTooltipTrigger === 'item' || seriesTooltipShow === false || seriesModel.get('axisPointer.show', true) === false) {\n return;\n }\n\n each(result.coordSysAxesInfo[makeKey(coordSys.model)], function (axisInfo) {\n var axis = axisInfo.axis;\n\n if (coordSys.getAxis(axis.dim) === axis) {\n axisInfo.seriesModels.push(seriesModel);\n axisInfo.seriesDataCount == null && (axisInfo.seriesDataCount = 0);\n axisInfo.seriesDataCount += seriesModel.getData().count();\n }\n });\n }, this);\n}\n/**\n * For example:\n * {\n * axisPointer: {\n * links: [{\n * xAxisIndex: [2, 4],\n * yAxisIndex: 'all'\n * }, {\n * xAxisId: ['a5', 'a7'],\n * xAxisName: 'xxx'\n * }]\n * }\n * }\n */\n\n\nfunction getLinkGroupIndex(linksOption, axis) {\n var axisModel = axis.model;\n var dim = axis.dim;\n\n for (var i = 0; i < linksOption.length; i++) {\n var linkOption = linksOption[i] || {};\n\n if (checkPropInLink(linkOption[dim + 'AxisId'], axisModel.id) || checkPropInLink(linkOption[dim + 'AxisIndex'], axisModel.componentIndex) || checkPropInLink(linkOption[dim + 'AxisName'], axisModel.name)) {\n return i;\n }\n }\n}\n\nfunction checkPropInLink(linkPropValue, axisPropValue) {\n return linkPropValue === 'all' || zrUtil.isArray(linkPropValue) && zrUtil.indexOf(linkPropValue, axisPropValue) >= 0 || linkPropValue === axisPropValue;\n}\n\nfunction fixValue(axisModel) {\n var axisInfo = getAxisInfo(axisModel);\n\n if (!axisInfo) {\n return;\n }\n\n var axisPointerModel = axisInfo.axisPointerModel;\n var scale = axisInfo.axis.scale;\n var option = axisPointerModel.option;\n var status = axisPointerModel.get('status');\n var value = axisPointerModel.get('value'); // Parse init value for category and time axis.\n\n if (value != null) {\n value = scale.parse(value);\n }\n\n var useHandle = isHandleTrigger(axisPointerModel); // If `handle` used, `axisPointer` will always be displayed, so value\n // and status should be initialized.\n\n if (status == null) {\n option.status = useHandle ? 'show' : 'hide';\n }\n\n var extent = scale.getExtent().slice();\n extent[0] > extent[1] && extent.reverse();\n\n if ( // Pick a value on axis when initializing.\n value == null // If both `handle` and `dataZoom` are used, value may be out of axis extent,\n // where we should re-pick a value to keep `handle` displaying normally.\n || value > extent[1]) {\n // Make handle displayed on the end of the axis when init, which looks better.\n value = extent[1];\n }\n\n if (value < extent[0]) {\n value = extent[0];\n }\n\n option.value = value;\n\n if (useHandle) {\n option.status = axisInfo.axis.scale.isBlank() ? 'hide' : 'show';\n }\n}\n\nfunction getAxisInfo(axisModel) {\n var coordSysAxesInfo = (axisModel.ecModel.getComponent('axisPointer') || {}).coordSysAxesInfo;\n return coordSysAxesInfo && coordSysAxesInfo.axesInfo[makeKey(axisModel)];\n}\n\nfunction getAxisPointerModel(axisModel) {\n var axisInfo = getAxisInfo(axisModel);\n return axisInfo && axisInfo.axisPointerModel;\n}\n\nfunction isHandleTrigger(axisPointerModel) {\n return !!axisPointerModel.get('handle.show');\n}\n/**\n * @param {module:echarts/model/Model} model\n * @return {string} unique key\n */\n\n\nfunction makeKey(model) {\n return model.type + '||' + model.id;\n}\n\nexports.collect = collect;\nexports.fixValue = fixValue;\nexports.getAxisInfo = getAxisInfo;\nexports.getAxisPointerModel = getAxisPointerModel;\nexports.makeKey = makeKey;","var _event = require(\"../core/event\");\n\nvar addEventListener = _event.addEventListener;\nvar removeEventListener = _event.removeEventListener;\nvar normalizeEvent = _event.normalizeEvent;\n\nvar zrUtil = require(\"../core/util\");\n\nvar Eventful = require(\"../mixin/Eventful\");\n\nvar env = require(\"../core/env\");\n\nvar TOUCH_CLICK_DELAY = 300;\nvar mouseHandlerNames = ['click', 'dblclick', 'mousewheel', 'mouseout', 'mouseup', 'mousedown', 'mousemove', 'contextmenu'];\nvar touchHandlerNames = ['touchstart', 'touchend', 'touchmove'];\nvar pointerEventNames = {\n pointerdown: 1,\n pointerup: 1,\n pointermove: 1,\n pointerout: 1\n};\nvar pointerHandlerNames = zrUtil.map(mouseHandlerNames, function (name) {\n var nm = name.replace('mouse', 'pointer');\n return pointerEventNames[nm] ? nm : name;\n});\n\nfunction eventNameFix(name) {\n return name === 'mousewheel' && env.browser.firefox ? 'DOMMouseScroll' : name;\n} // function onMSGestureChange(proxy, event) {\n// if (event.translationX || event.translationY) {\n// // mousemove is carried by MSGesture to reduce the sensitivity.\n// proxy.handler.dispatchToElement(event.target, 'mousemove', event);\n// }\n// if (event.scale !== 1) {\n// event.pinchX = event.offsetX;\n// event.pinchY = event.offsetY;\n// event.pinchScale = event.scale;\n// proxy.handler.dispatchToElement(event.target, 'pinch', event);\n// }\n// }\n\n/**\n * Prevent mouse event from being dispatched after Touch Events action\n * @see <https://github.com/deltakosh/handjs/blob/master/src/hand.base.js>\n * 1. Mobile browsers dispatch mouse events 300ms after touchend.\n * 2. Chrome for Android dispatch mousedown for long-touch about 650ms\n * Result: Blocking Mouse Events for 700ms.\n */\n\n\nfunction setTouchTimer(instance) {\n instance._touching = true;\n clearTimeout(instance._touchTimer);\n instance._touchTimer = setTimeout(function () {\n instance._touching = false;\n }, 700);\n}\n\nvar domHandlers = {\n /**\n * Mouse move handler\n * @inner\n * @param {Event} event\n */\n mousemove: function (event) {\n event = normalizeEvent(this.dom, event);\n this.trigger('mousemove', event);\n },\n\n /**\n * Mouse out handler\n * @inner\n * @param {Event} event\n */\n mouseout: function (event) {\n event = normalizeEvent(this.dom, event);\n var element = event.toElement || event.relatedTarget;\n\n if (element !== this.dom) {\n while (element && element.nodeType !== 9) {\n // 忽略包含在root中的dom引起的mouseOut\n if (element === this.dom) {\n return;\n }\n\n element = element.parentNode;\n }\n }\n\n this.trigger('mouseout', event);\n },\n\n /**\n * Touch开始响应函数\n * @inner\n * @param {Event} event\n */\n touchstart: function (event) {\n // Default mouse behaviour should not be disabled here.\n // For example, page may needs to be slided.\n event = normalizeEvent(this.dom, event); // Mark touch, which is useful in distinguish touch and\n // mouse event in upper applicatoin.\n\n event.zrByTouch = true;\n this._lastTouchMoment = new Date();\n this.handler.processGesture(this, event, 'start'); // In touch device, trigger `mousemove`(`mouseover`) should\n // be triggered, and must before `mousedown` triggered.\n\n domHandlers.mousemove.call(this, event);\n domHandlers.mousedown.call(this, event);\n setTouchTimer(this);\n },\n\n /**\n * Touch移动响应函数\n * @inner\n * @param {Event} event\n */\n touchmove: function (event) {\n event = normalizeEvent(this.dom, event); // Mark touch, which is useful in distinguish touch and\n // mouse event in upper applicatoin.\n\n event.zrByTouch = true;\n this.handler.processGesture(this, event, 'change'); // Mouse move should always be triggered no matter whether\n // there is gestrue event, because mouse move and pinch may\n // be used at the same time.\n\n domHandlers.mousemove.call(this, event);\n setTouchTimer(this);\n },\n\n /**\n * Touch结束响应函数\n * @inner\n * @param {Event} event\n */\n touchend: function (event) {\n event = normalizeEvent(this.dom, event); // Mark touch, which is useful in distinguish touch and\n // mouse event in upper applicatoin.\n\n event.zrByTouch = true;\n this.handler.processGesture(this, event, 'end');\n domHandlers.mouseup.call(this, event); // Do not trigger `mouseout` here, in spite of `mousemove`(`mouseover`) is\n // triggered in `touchstart`. This seems to be illogical, but by this mechanism,\n // we can conveniently implement \"hover style\" in both PC and touch device just\n // by listening to `mouseover` to add \"hover style\" and listening to `mouseout`\n // to remove \"hover style\" on an element, without any additional code for\n // compatibility. (`mouseout` will not be triggered in `touchend`, so \"hover\n // style\" will remain for user view)\n // click event should always be triggered no matter whether\n // there is gestrue event. System click can not be prevented.\n\n if (+new Date() - this._lastTouchMoment < TOUCH_CLICK_DELAY) {\n domHandlers.click.call(this, event);\n }\n\n setTouchTimer(this);\n },\n pointerdown: function (event) {\n domHandlers.mousedown.call(this, event); // if (useMSGuesture(this, event)) {\n // this._msGesture.addPointer(event.pointerId);\n // }\n },\n pointermove: function (event) {\n // FIXME\n // pointermove is so sensitive that it always triggered when\n // tap(click) on touch screen, which affect some judgement in\n // upper application. So, we dont support mousemove on MS touch\n // device yet.\n if (!isPointerFromTouch(event)) {\n domHandlers.mousemove.call(this, event);\n }\n },\n pointerup: function (event) {\n domHandlers.mouseup.call(this, event);\n },\n pointerout: function (event) {\n // pointerout will be triggered when tap on touch screen\n // (IE11+/Edge on MS Surface) after click event triggered,\n // which is inconsistent with the mousout behavior we defined\n // in touchend. So we unify them.\n // (check domHandlers.touchend for detailed explanation)\n if (!isPointerFromTouch(event)) {\n domHandlers.mouseout.call(this, event);\n }\n }\n};\n\nfunction isPointerFromTouch(event) {\n var pointerType = event.pointerType;\n return pointerType === 'pen' || pointerType === 'touch';\n} // function useMSGuesture(handlerProxy, event) {\n// return isPointerFromTouch(event) && !!handlerProxy._msGesture;\n// }\n// Common handlers\n\n\nzrUtil.each(['click', 'mousedown', 'mouseup', 'mousewheel', 'dblclick', 'contextmenu'], function (name) {\n domHandlers[name] = function (event) {\n event = normalizeEvent(this.dom, event);\n this.trigger(name, event);\n };\n});\n/**\n * 为控制类实例初始化dom 事件处理函数\n *\n * @inner\n * @param {module:zrender/Handler} instance 控制类实例\n */\n\nfunction initDomHandler(instance) {\n zrUtil.each(touchHandlerNames, function (name) {\n instance._handlers[name] = zrUtil.bind(domHandlers[name], instance);\n });\n zrUtil.each(pointerHandlerNames, function (name) {\n instance._handlers[name] = zrUtil.bind(domHandlers[name], instance);\n });\n zrUtil.each(mouseHandlerNames, function (name) {\n instance._handlers[name] = makeMouseHandler(domHandlers[name], instance);\n });\n\n function makeMouseHandler(fn, instance) {\n return function () {\n if (instance._touching) {\n return;\n }\n\n return fn.apply(instance, arguments);\n };\n }\n}\n\nfunction HandlerDomProxy(dom) {\n Eventful.call(this);\n this.dom = dom;\n /**\n * @private\n * @type {boolean}\n */\n\n this._touching = false;\n /**\n * @private\n * @type {number}\n */\n\n this._touchTimer;\n this._handlers = {};\n initDomHandler(this);\n\n if (env.pointerEventsSupported) {\n // Only IE11+/Edge\n // 1. On devices that both enable touch and mouse (e.g., MS Surface and lenovo X240),\n // IE11+/Edge do not trigger touch event, but trigger pointer event and mouse event\n // at the same time.\n // 2. On MS Surface, it probablely only trigger mousedown but no mouseup when tap on\n // screen, which do not occurs in pointer event.\n // So we use pointer event to both detect touch gesture and mouse behavior.\n mountHandlers(pointerHandlerNames, this); // FIXME\n // Note: MS Gesture require CSS touch-action set. But touch-action is not reliable,\n // which does not prevent defuault behavior occasionally (which may cause view port\n // zoomed in but use can not zoom it back). And event.preventDefault() does not work.\n // So we have to not to use MSGesture and not to support touchmove and pinch on MS\n // touch screen. And we only support click behavior on MS touch screen now.\n // MS Gesture Event is only supported on IE11+/Edge and on Windows 8+.\n // We dont support touch on IE on win7.\n // See <https://msdn.microsoft.com/en-us/library/dn433243(v=vs.85).aspx>\n // if (typeof MSGesture === 'function') {\n // (this._msGesture = new MSGesture()).target = dom; // jshint ignore:line\n // dom.addEventListener('MSGestureChange', onMSGestureChange);\n // }\n } else {\n if (env.touchEventsSupported) {\n mountHandlers(touchHandlerNames, this); // Handler of 'mouseout' event is needed in touch mode, which will be mounted below.\n // addEventListener(root, 'mouseout', this._mouseoutHandler);\n } // 1. Considering some devices that both enable touch and mouse event (like on MS Surface\n // and lenovo X240, @see #2350), we make mouse event be always listened, otherwise\n // mouse event can not be handle in those devices.\n // 2. On MS Surface, Chrome will trigger both touch event and mouse event. How to prevent\n // mouseevent after touch event triggered, see `setTouchTimer`.\n\n\n mountHandlers(mouseHandlerNames, this);\n }\n\n function mountHandlers(handlerNames, instance) {\n zrUtil.each(handlerNames, function (name) {\n addEventListener(dom, eventNameFix(name), instance._handlers[name]);\n }, instance);\n }\n}\n\nvar handlerDomProxyProto = HandlerDomProxy.prototype;\n\nhandlerDomProxyProto.dispose = function () {\n var handlerNames = mouseHandlerNames.concat(touchHandlerNames);\n\n for (var i = 0; i < handlerNames.length; i++) {\n var name = handlerNames[i];\n removeEventListener(this.dom, eventNameFix(name), this._handlers[name]);\n }\n};\n\nhandlerDomProxyProto.setCursor = function (cursorStyle) {\n this.dom.style && (this.dom.style.cursor = cursorStyle || 'default');\n};\n\nzrUtil.mixin(HandlerDomProxy, Eventful);\nvar _default = HandlerDomProxy;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Cartesian coordinate system\n * @module echarts/coord/Cartesian\n *\n */\nfunction dimAxisMapper(dim) {\n return this._axes[dim];\n}\n/**\n * @alias module:echarts/coord/Cartesian\n * @constructor\n */\n\n\nvar Cartesian = function (name) {\n this._axes = {};\n this._dimList = [];\n /**\n * @type {string}\n */\n\n this.name = name || '';\n};\n\nCartesian.prototype = {\n constructor: Cartesian,\n type: 'cartesian',\n\n /**\n * Get axis\n * @param {number|string} dim\n * @return {module:echarts/coord/Cartesian~Axis}\n */\n getAxis: function (dim) {\n return this._axes[dim];\n },\n\n /**\n * Get axes list\n * @return {Array.<module:echarts/coord/Cartesian~Axis>}\n */\n getAxes: function () {\n return zrUtil.map(this._dimList, dimAxisMapper, this);\n },\n\n /**\n * Get axes list by given scale type\n */\n getAxesByScale: function (scaleType) {\n scaleType = scaleType.toLowerCase();\n return zrUtil.filter(this.getAxes(), function (axis) {\n return axis.scale.type === scaleType;\n });\n },\n\n /**\n * Add axis\n * @param {module:echarts/coord/Cartesian.Axis}\n */\n addAxis: function (axis) {\n var dim = axis.dim;\n this._axes[dim] = axis;\n\n this._dimList.push(dim);\n },\n\n /**\n * Convert data to coord in nd space\n * @param {Array.<number>|Object.<string, number>} val\n * @return {Array.<number>|Object.<string, number>}\n */\n dataToCoord: function (val) {\n return this._dataCoordConvert(val, 'dataToCoord');\n },\n\n /**\n * Convert coord in nd space to data\n * @param {Array.<number>|Object.<string, number>} val\n * @return {Array.<number>|Object.<string, number>}\n */\n coordToData: function (val) {\n return this._dataCoordConvert(val, 'coordToData');\n },\n _dataCoordConvert: function (input, method) {\n var dimList = this._dimList;\n var output = input instanceof Array ? [] : {};\n\n for (var i = 0; i < dimList.length; i++) {\n var dim = dimList[i];\n var axis = this._axes[dim];\n output[dim] = axis[method](input[dim]);\n }\n\n return output;\n }\n};\nvar _default = Cartesian;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar createHashMap = _util.createHashMap;\nvar each = _util.each;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// (1) [Caution]: the logic is correct based on the premises:\n// data processing stage is blocked in stream.\n// See <module:echarts/stream/Scheduler#performDataProcessorTasks>\n// (2) Only register once when import repeatly.\n// Should be executed before after series filtered and before stack calculation.\nfunction _default(ecModel) {\n var stackInfoMap = createHashMap();\n ecModel.eachSeries(function (seriesModel) {\n var stack = seriesModel.get('stack'); // Compatibal: when `stack` is set as '', do not stack.\n\n if (stack) {\n var stackInfoList = stackInfoMap.get(stack) || stackInfoMap.set(stack, []);\n var data = seriesModel.getData();\n var stackInfo = {\n // Used for calculate axis extent automatically.\n stackResultDimension: data.getCalculationInfo('stackResultDimension'),\n stackedOverDimension: data.getCalculationInfo('stackedOverDimension'),\n stackedDimension: data.getCalculationInfo('stackedDimension'),\n stackedByDimension: data.getCalculationInfo('stackedByDimension'),\n isStackedByIndex: data.getCalculationInfo('isStackedByIndex'),\n data: data,\n seriesModel: seriesModel\n }; // If stacked on axis that do not support data stack.\n\n if (!stackInfo.stackedDimension || !(stackInfo.isStackedByIndex || stackInfo.stackedByDimension)) {\n return;\n }\n\n stackInfoList.length && data.setCalculationInfo('stackedOnSeries', stackInfoList[stackInfoList.length - 1].seriesModel);\n stackInfoList.push(stackInfo);\n }\n });\n stackInfoMap.each(calculateStack);\n}\n\nfunction calculateStack(stackInfoList) {\n each(stackInfoList, function (targetStackInfo, idxInStack) {\n var resultVal = [];\n var resultNaN = [NaN, NaN];\n var dims = [targetStackInfo.stackResultDimension, targetStackInfo.stackedOverDimension];\n var targetData = targetStackInfo.data;\n var isStackedByIndex = targetStackInfo.isStackedByIndex; // Should not write on raw data, because stack series model list changes\n // depending on legend selection.\n\n var newData = targetData.map(dims, function (v0, v1, dataIndex) {\n var sum = targetData.get(targetStackInfo.stackedDimension, dataIndex); // Consider `connectNulls` of line area, if value is NaN, stackedOver\n // should also be NaN, to draw a appropriate belt area.\n\n if (isNaN(sum)) {\n return resultNaN;\n }\n\n var byValue;\n var stackedDataRawIndex;\n\n if (isStackedByIndex) {\n stackedDataRawIndex = targetData.getRawIndex(dataIndex);\n } else {\n byValue = targetData.get(targetStackInfo.stackedByDimension, dataIndex);\n } // If stackOver is NaN, chart view will render point on value start.\n\n\n var stackedOver = NaN;\n\n for (var j = idxInStack - 1; j >= 0; j--) {\n var stackInfo = stackInfoList[j]; // Has been optimized by inverted indices on `stackedByDimension`.\n\n if (!isStackedByIndex) {\n stackedDataRawIndex = stackInfo.data.rawIndexOf(stackInfo.stackedByDimension, byValue);\n }\n\n if (stackedDataRawIndex >= 0) {\n var val = stackInfo.data.getByRawIndex(stackInfo.stackResultDimension, stackedDataRawIndex); // Considering positive stack, negative stack and empty data\n\n if (sum >= 0 && val > 0 || // Positive stack\n sum <= 0 && val < 0 // Negative stack\n ) {\n sum += val;\n stackedOver = val;\n break;\n }\n }\n }\n\n resultVal[0] = sum;\n resultVal[1] = stackedOver;\n return resultVal;\n });\n targetData.hostModel.setData(newData); // Update for consequent calculation\n\n targetStackInfo.data = newData;\n });\n}\n\nmodule.exports = _default;","var util = require(\"./core/util\");\n\nvar vec2 = require(\"./core/vector\");\n\nvar Draggable = require(\"./mixin/Draggable\");\n\nvar Eventful = require(\"./mixin/Eventful\");\n\nvar eventTool = require(\"./core/event\");\n\nvar GestureMgr = require(\"./core/GestureMgr\");\n\nvar SILENT = 'silent';\n\nfunction makeEventPacket(eveType, targetInfo, event) {\n return {\n type: eveType,\n event: event,\n // target can only be an element that is not silent.\n target: targetInfo.target,\n // topTarget can be a silent element.\n topTarget: targetInfo.topTarget,\n cancelBubble: false,\n offsetX: event.zrX,\n offsetY: event.zrY,\n gestureEvent: event.gestureEvent,\n pinchX: event.pinchX,\n pinchY: event.pinchY,\n pinchScale: event.pinchScale,\n wheelDelta: event.zrDelta,\n zrByTouch: event.zrByTouch,\n which: event.which,\n stop: stopEvent\n };\n}\n\nfunction stopEvent(event) {\n eventTool.stop(this.event);\n}\n\nfunction EmptyProxy() {}\n\nEmptyProxy.prototype.dispose = function () {};\n\nvar handlerNames = ['click', 'dblclick', 'mousewheel', 'mouseout', 'mouseup', 'mousedown', 'mousemove', 'contextmenu'];\n/**\n * @alias module:zrender/Handler\n * @constructor\n * @extends module:zrender/mixin/Eventful\n * @param {module:zrender/Storage} storage Storage instance.\n * @param {module:zrender/Painter} painter Painter instance.\n * @param {module:zrender/dom/HandlerProxy} proxy HandlerProxy instance.\n * @param {HTMLElement} painterRoot painter.root (not painter.getViewportRoot()).\n */\n\nvar Handler = function (storage, painter, proxy, painterRoot) {\n Eventful.call(this);\n this.storage = storage;\n this.painter = painter;\n this.painterRoot = painterRoot;\n proxy = proxy || new EmptyProxy();\n /**\n * Proxy of event. can be Dom, WebGLSurface, etc.\n */\n\n this.proxy = null;\n /**\n * {target, topTarget, x, y}\n * @private\n * @type {Object}\n */\n\n this._hovered = {};\n /**\n * @private\n * @type {Date}\n */\n\n this._lastTouchMoment;\n /**\n * @private\n * @type {number}\n */\n\n this._lastX;\n /**\n * @private\n * @type {number}\n */\n\n this._lastY;\n /**\n * @private\n * @type {module:zrender/core/GestureMgr}\n */\n\n this._gestureMgr;\n Draggable.call(this);\n this.setHandlerProxy(proxy);\n};\n\nHandler.prototype = {\n constructor: Handler,\n setHandlerProxy: function (proxy) {\n if (this.proxy) {\n this.proxy.dispose();\n }\n\n if (proxy) {\n util.each(handlerNames, function (name) {\n proxy.on && proxy.on(name, this[name], this);\n }, this); // Attach handler\n\n proxy.handler = this;\n }\n\n this.proxy = proxy;\n },\n mousemove: function (event) {\n var x = event.zrX;\n var y = event.zrY;\n var lastHovered = this._hovered;\n var lastHoveredTarget = lastHovered.target; // If lastHoveredTarget is removed from zr (detected by '__zr') by some API call\n // (like 'setOption' or 'dispatchAction') in event handlers, we should find\n // lastHovered again here. Otherwise 'mouseout' can not be triggered normally.\n // See #6198.\n\n if (lastHoveredTarget && !lastHoveredTarget.__zr) {\n lastHovered = this.findHover(lastHovered.x, lastHovered.y);\n lastHoveredTarget = lastHovered.target;\n }\n\n var hovered = this._hovered = this.findHover(x, y);\n var hoveredTarget = hovered.target;\n var proxy = this.proxy;\n proxy.setCursor && proxy.setCursor(hoveredTarget ? hoveredTarget.cursor : 'default'); // Mouse out on previous hovered element\n\n if (lastHoveredTarget && hoveredTarget !== lastHoveredTarget) {\n this.dispatchToElement(lastHovered, 'mouseout', event);\n } // Mouse moving on one element\n\n\n this.dispatchToElement(hovered, 'mousemove', event); // Mouse over on a new element\n\n if (hoveredTarget && hoveredTarget !== lastHoveredTarget) {\n this.dispatchToElement(hovered, 'mouseover', event);\n }\n },\n mouseout: function (event) {\n this.dispatchToElement(this._hovered, 'mouseout', event); // There might be some doms created by upper layer application\n // at the same level of painter.getViewportRoot() (e.g., tooltip\n // dom created by echarts), where 'globalout' event should not\n // be triggered when mouse enters these doms. (But 'mouseout'\n // should be triggered at the original hovered element as usual).\n\n var element = event.toElement || event.relatedTarget;\n var innerDom;\n\n do {\n element = element && element.parentNode;\n } while (element && element.nodeType !== 9 && !(innerDom = element === this.painterRoot));\n\n !innerDom && this.trigger('globalout', {\n event: event\n });\n },\n\n /**\n * Resize\n */\n resize: function (event) {\n this._hovered = {};\n },\n\n /**\n * Dispatch event\n * @param {string} eventName\n * @param {event=} eventArgs\n */\n dispatch: function (eventName, eventArgs) {\n var handler = this[eventName];\n handler && handler.call(this, eventArgs);\n },\n\n /**\n * Dispose\n */\n dispose: function () {\n this.proxy.dispose();\n this.storage = this.proxy = this.painter = null;\n },\n\n /**\n * 设置默认的cursor style\n * @param {string} [cursorStyle='default'] 例如 crosshair\n */\n setCursorStyle: function (cursorStyle) {\n var proxy = this.proxy;\n proxy.setCursor && proxy.setCursor(cursorStyle);\n },\n\n /**\n * 事件分发代理\n *\n * @private\n * @param {Object} targetInfo {target, topTarget} 目标图形元素\n * @param {string} eventName 事件名称\n * @param {Object} event 事件对象\n */\n dispatchToElement: function (targetInfo, eventName, event) {\n targetInfo = targetInfo || {};\n var el = targetInfo.target;\n\n if (el && el.silent) {\n return;\n }\n\n var eventHandler = 'on' + eventName;\n var eventPacket = makeEventPacket(eventName, targetInfo, event);\n\n while (el) {\n el[eventHandler] && (eventPacket.cancelBubble = el[eventHandler].call(el, eventPacket));\n el.trigger(eventName, eventPacket);\n el = el.parent;\n\n if (eventPacket.cancelBubble) {\n break;\n }\n }\n\n if (!eventPacket.cancelBubble) {\n // 冒泡到顶级 zrender 对象\n this.trigger(eventName, eventPacket); // 分发事件到用户自定义层\n // 用户有可能在全局 click 事件中 dispose,所以需要判断下 painter 是否存在\n\n this.painter && this.painter.eachOtherLayer(function (layer) {\n if (typeof layer[eventHandler] === 'function') {\n layer[eventHandler].call(layer, eventPacket);\n }\n\n if (layer.trigger) {\n layer.trigger(eventName, eventPacket);\n }\n });\n }\n },\n\n /**\n * @private\n * @param {number} x\n * @param {number} y\n * @param {module:zrender/graphic/Displayable} exclude\n * @return {model:zrender/Element}\n * @method\n */\n findHover: function (x, y, exclude) {\n var list = this.storage.getDisplayList();\n var out = {\n x: x,\n y: y\n };\n\n for (var i = list.length - 1; i >= 0; i--) {\n var hoverCheckResult;\n\n if (list[i] !== exclude // getDisplayList may include ignored item in VML mode\n && !list[i].ignore && (hoverCheckResult = isHover(list[i], x, y))) {\n !out.topTarget && (out.topTarget = list[i]);\n\n if (hoverCheckResult !== SILENT) {\n out.target = list[i];\n break;\n }\n }\n }\n\n return out;\n },\n processGesture: function (event, stage) {\n if (!this._gestureMgr) {\n this._gestureMgr = new GestureMgr();\n }\n\n var gestureMgr = this._gestureMgr;\n stage === 'start' && gestureMgr.clear();\n var gestureInfo = gestureMgr.recognize(event, this.findHover(event.zrX, event.zrY, null).target, this.proxy.dom);\n stage === 'end' && gestureMgr.clear(); // Do not do any preventDefault here. Upper application do that if necessary.\n\n if (gestureInfo) {\n var type = gestureInfo.type;\n event.gestureEvent = type;\n this.dispatchToElement({\n target: gestureInfo.target\n }, type, gestureInfo.event);\n }\n }\n}; // Common handlers\n\nutil.each(['click', 'mousedown', 'mouseup', 'mousewheel', 'dblclick', 'contextmenu'], function (name) {\n Handler.prototype[name] = function (event) {\n // Find hover again to avoid click event is dispatched manually. Or click is triggered without mouseover\n var hovered = this.findHover(event.zrX, event.zrY);\n var hoveredTarget = hovered.target;\n\n if (name === 'mousedown') {\n this._downEl = hoveredTarget;\n this._downPoint = [event.zrX, event.zrY]; // In case click triggered before mouseup\n\n this._upEl = hoveredTarget;\n } else if (name === 'mouseup') {\n this._upEl = hoveredTarget;\n } else if (name === 'click') {\n if (this._downEl !== this._upEl // Original click event is triggered on the whole canvas element,\n // including the case that `mousedown` - `mousemove` - `mouseup`,\n // which should be filtered, otherwise it will bring trouble to\n // pan and zoom.\n || !this._downPoint // Arbitrary value\n || vec2.dist(this._downPoint, [event.zrX, event.zrY]) > 4) {\n return;\n }\n\n this._downPoint = null;\n }\n\n this.dispatchToElement(hovered, name, event);\n };\n});\n\nfunction isHover(displayable, x, y) {\n if (displayable[displayable.rectHover ? 'rectContain' : 'contain'](x, y)) {\n var el = displayable;\n var isSilent;\n\n while (el) {\n // If clipped by ancestor.\n // FIXME: If clipPath has neither stroke nor fill,\n // el.clipPath.contain(x, y) will always return false.\n if (el.clipPath && !el.clipPath.contain(x, y)) {\n return false;\n }\n\n if (el.silent) {\n isSilent = true;\n }\n\n el = el.parent;\n }\n\n return isSilent ? SILENT : true;\n }\n\n return false;\n}\n\nutil.mixin(Handler, Eventful);\nutil.mixin(Handler, Draggable);\nvar _default = Handler;\nmodule.exports = _default;","var Path = require(\"../Path\");\n\nvar polyHelper = require(\"../helper/poly\");\n\n/**\n * @module zrender/graphic/shape/Polyline\n */\nvar _default = Path.extend({\n type: 'polyline',\n shape: {\n points: null,\n smooth: false,\n smoothConstraint: null\n },\n style: {\n stroke: '#000',\n fill: null\n },\n buildPath: function (ctx, shape) {\n polyHelper.buildPath(ctx, shape, false);\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar echarts = require(\"../../echarts\");\n\nvar globalListener = require(\"./globalListener\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar AxisPointerView = echarts.extendComponentView({\n type: 'axisPointer',\n render: function (globalAxisPointerModel, ecModel, api) {\n var globalTooltipModel = ecModel.getComponent('tooltip');\n var triggerOn = globalAxisPointerModel.get('triggerOn') || globalTooltipModel && globalTooltipModel.get('triggerOn') || 'mousemove|click'; // Register global listener in AxisPointerView to enable\n // AxisPointerView to be independent to Tooltip.\n\n globalListener.register('axisPointer', api, function (currTrigger, e, dispatchAction) {\n // If 'none', it is not controlled by mouse totally.\n if (triggerOn !== 'none' && (currTrigger === 'leave' || triggerOn.indexOf(currTrigger) >= 0)) {\n dispatchAction({\n type: 'updateAxisPointer',\n currTrigger: currTrigger,\n x: e && e.offsetX,\n y: e && e.offsetY\n });\n }\n });\n },\n\n /**\n * @override\n */\n remove: function (ecModel, api) {\n globalListener.unregister(api.getZr(), 'axisPointer');\n AxisPointerView.superApply(this._model, 'remove', arguments);\n },\n\n /**\n * @override\n */\n dispose: function (ecModel, api) {\n globalListener.unregister('axisPointer', api);\n AxisPointerView.superApply(this._model, 'dispose', arguments);\n }\n});\nvar _default = AxisPointerView;\nmodule.exports = _default;","var Path = require(\"./Path\");\n\n// CompoundPath to improve performance\nvar _default = Path.extend({\n type: 'compound',\n shape: {\n paths: null\n },\n _updatePathDirty: function () {\n var dirtyPath = this.__dirtyPath;\n var paths = this.shape.paths;\n\n for (var i = 0; i < paths.length; i++) {\n // Mark as dirty if any subpath is dirty\n dirtyPath = dirtyPath || paths[i].__dirtyPath;\n }\n\n this.__dirtyPath = dirtyPath;\n this.__dirty = this.__dirty || dirtyPath;\n },\n beforeBrush: function () {\n this._updatePathDirty();\n\n var paths = this.shape.paths || [];\n var scale = this.getGlobalScale(); // Update path scale\n\n for (var i = 0; i < paths.length; i++) {\n if (!paths[i].path) {\n paths[i].createPathProxy();\n }\n\n paths[i].path.setScale(scale[0], scale[1]);\n }\n },\n buildPath: function (ctx, shape) {\n var paths = shape.paths || [];\n\n for (var i = 0; i < paths.length; i++) {\n paths[i].buildPath(ctx, paths[i].shape, true);\n }\n },\n afterBrush: function () {\n var paths = this.shape.paths || [];\n\n for (var i = 0; i < paths.length; i++) {\n paths[i].__dirtyPath = false;\n }\n },\n getBoundingRect: function () {\n this._updatePathDirty();\n\n return Path.prototype.getBoundingRect.call(this);\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar Path = require(\"zrender/lib/graphic/Path\");\n\nvar vec2 = require(\"zrender/lib/core/vector\");\n\nvar fixClipWithShadow = require(\"zrender/lib/graphic/helper/fixClipWithShadow\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// Poly path support NaN point\nvar vec2Min = vec2.min;\nvar vec2Max = vec2.max;\nvar scaleAndAdd = vec2.scaleAndAdd;\nvar v2Copy = vec2.copy; // Temporary variable\n\nvar v = [];\nvar cp0 = [];\nvar cp1 = [];\n\nfunction isPointNull(p) {\n return isNaN(p[0]) || isNaN(p[1]);\n}\n\nfunction drawSegment(ctx, points, start, segLen, allLen, dir, smoothMin, smoothMax, smooth, smoothMonotone, connectNulls) {\n // if (smoothMonotone == null) {\n // if (isMono(points, 'x')) {\n // return drawMono(ctx, points, start, segLen, allLen,\n // dir, smoothMin, smoothMax, smooth, 'x', connectNulls);\n // }\n // else if (isMono(points, 'y')) {\n // return drawMono(ctx, points, start, segLen, allLen,\n // dir, smoothMin, smoothMax, smooth, 'y', connectNulls);\n // }\n // else {\n // return drawNonMono.apply(this, arguments);\n // }\n // }\n // else if (smoothMonotone !== 'none' && isMono(points, smoothMonotone)) {\n // return drawMono.apply(this, arguments);\n // }\n // else {\n // return drawNonMono.apply(this, arguments);\n // }\n if (smoothMonotone === 'none' || !smoothMonotone) {\n return drawNonMono.apply(this, arguments);\n } else {\n return drawMono.apply(this, arguments);\n }\n}\n/**\n * Check if points is in monotone.\n *\n * @param {number[][]} points Array of points which is in [x, y] form\n * @param {string} smoothMonotone 'x', 'y', or 'none', stating for which\n * dimension that is checking.\n * If is 'none', `drawNonMono` should be\n * called.\n * If is undefined, either being monotone\n * in 'x' or 'y' will call `drawMono`.\n */\n// function isMono(points, smoothMonotone) {\n// if (points.length <= 1) {\n// return true;\n// }\n// var dim = smoothMonotone === 'x' ? 0 : 1;\n// var last = points[0][dim];\n// var lastDiff = 0;\n// for (var i = 1; i < points.length; ++i) {\n// var diff = points[i][dim] - last;\n// if (!isNaN(diff) && !isNaN(lastDiff)\n// && diff !== 0 && lastDiff !== 0\n// && ((diff >= 0) !== (lastDiff >= 0))\n// ) {\n// return false;\n// }\n// if (!isNaN(diff) && diff !== 0) {\n// lastDiff = diff;\n// last = points[i][dim];\n// }\n// }\n// return true;\n// }\n\n/**\n * Draw smoothed line in monotone, in which only vertical or horizontal bezier\n * control points will be used. This should be used when points are monotone\n * either in x or y dimension.\n */\n\n\nfunction drawMono(ctx, points, start, segLen, allLen, dir, smoothMin, smoothMax, smooth, smoothMonotone, connectNulls) {\n var prevIdx = 0;\n var idx = start;\n\n for (var k = 0; k < segLen; k++) {\n var p = points[idx];\n\n if (idx >= allLen || idx < 0) {\n break;\n }\n\n if (isPointNull(p)) {\n if (connectNulls) {\n idx += dir;\n continue;\n }\n\n break;\n }\n\n if (idx === start) {\n ctx[dir > 0 ? 'moveTo' : 'lineTo'](p[0], p[1]);\n } else {\n if (smooth > 0) {\n var prevP = points[prevIdx];\n var dim = smoothMonotone === 'y' ? 1 : 0; // Length of control point to p, either in x or y, but not both\n\n var ctrlLen = (p[dim] - prevP[dim]) * smooth;\n v2Copy(cp0, prevP);\n cp0[dim] = prevP[dim] + ctrlLen;\n v2Copy(cp1, p);\n cp1[dim] = p[dim] - ctrlLen;\n ctx.bezierCurveTo(cp0[0], cp0[1], cp1[0], cp1[1], p[0], p[1]);\n } else {\n ctx.lineTo(p[0], p[1]);\n }\n }\n\n prevIdx = idx;\n idx += dir;\n }\n\n return k;\n}\n/**\n * Draw smoothed line in non-monotone, in may cause undesired curve in extreme\n * situations. This should be used when points are non-monotone neither in x or\n * y dimension.\n */\n\n\nfunction drawNonMono(ctx, points, start, segLen, allLen, dir, smoothMin, smoothMax, smooth, smoothMonotone, connectNulls) {\n var prevIdx = 0;\n var idx = start;\n\n for (var k = 0; k < segLen; k++) {\n var p = points[idx];\n\n if (idx >= allLen || idx < 0) {\n break;\n }\n\n if (isPointNull(p)) {\n if (connectNulls) {\n idx += dir;\n continue;\n }\n\n break;\n }\n\n if (idx === start) {\n ctx[dir > 0 ? 'moveTo' : 'lineTo'](p[0], p[1]);\n v2Copy(cp0, p);\n } else {\n if (smooth > 0) {\n var nextIdx = idx + dir;\n var nextP = points[nextIdx];\n\n if (connectNulls) {\n // Find next point not null\n while (nextP && isPointNull(points[nextIdx])) {\n nextIdx += dir;\n nextP = points[nextIdx];\n }\n }\n\n var ratioNextSeg = 0.5;\n var prevP = points[prevIdx];\n var nextP = points[nextIdx]; // Last point\n\n if (!nextP || isPointNull(nextP)) {\n v2Copy(cp1, p);\n } else {\n // If next data is null in not connect case\n if (isPointNull(nextP) && !connectNulls) {\n nextP = p;\n }\n\n vec2.sub(v, nextP, prevP);\n var lenPrevSeg;\n var lenNextSeg;\n\n if (smoothMonotone === 'x' || smoothMonotone === 'y') {\n var dim = smoothMonotone === 'x' ? 0 : 1;\n lenPrevSeg = Math.abs(p[dim] - prevP[dim]);\n lenNextSeg = Math.abs(p[dim] - nextP[dim]);\n } else {\n lenPrevSeg = vec2.dist(p, prevP);\n lenNextSeg = vec2.dist(p, nextP);\n } // Use ratio of seg length\n\n\n ratioNextSeg = lenNextSeg / (lenNextSeg + lenPrevSeg);\n scaleAndAdd(cp1, p, v, -smooth * (1 - ratioNextSeg));\n } // Smooth constraint\n\n\n vec2Min(cp0, cp0, smoothMax);\n vec2Max(cp0, cp0, smoothMin);\n vec2Min(cp1, cp1, smoothMax);\n vec2Max(cp1, cp1, smoothMin);\n ctx.bezierCurveTo(cp0[0], cp0[1], cp1[0], cp1[1], p[0], p[1]); // cp0 of next segment\n\n scaleAndAdd(cp0, p, v, smooth * ratioNextSeg);\n } else {\n ctx.lineTo(p[0], p[1]);\n }\n }\n\n prevIdx = idx;\n idx += dir;\n }\n\n return k;\n}\n\nfunction getBoundingBox(points, smoothConstraint) {\n var ptMin = [Infinity, Infinity];\n var ptMax = [-Infinity, -Infinity];\n\n if (smoothConstraint) {\n for (var i = 0; i < points.length; i++) {\n var pt = points[i];\n\n if (pt[0] < ptMin[0]) {\n ptMin[0] = pt[0];\n }\n\n if (pt[1] < ptMin[1]) {\n ptMin[1] = pt[1];\n }\n\n if (pt[0] > ptMax[0]) {\n ptMax[0] = pt[0];\n }\n\n if (pt[1] > ptMax[1]) {\n ptMax[1] = pt[1];\n }\n }\n }\n\n return {\n min: smoothConstraint ? ptMin : ptMax,\n max: smoothConstraint ? ptMax : ptMin\n };\n}\n\nvar Polyline = Path.extend({\n type: 'ec-polyline',\n shape: {\n points: [],\n smooth: 0,\n smoothConstraint: true,\n smoothMonotone: null,\n connectNulls: false\n },\n style: {\n fill: null,\n stroke: '#000'\n },\n brush: fixClipWithShadow(Path.prototype.brush),\n buildPath: function (ctx, shape) {\n var points = shape.points;\n var i = 0;\n var len = points.length;\n var result = getBoundingBox(points, shape.smoothConstraint);\n\n if (shape.connectNulls) {\n // Must remove first and last null values avoid draw error in polygon\n for (; len > 0; len--) {\n if (!isPointNull(points[len - 1])) {\n break;\n }\n }\n\n for (; i < len; i++) {\n if (!isPointNull(points[i])) {\n break;\n }\n }\n }\n\n while (i < len) {\n i += drawSegment(ctx, points, i, len, len, 1, result.min, result.max, shape.smooth, shape.smoothMonotone, shape.connectNulls) + 1;\n }\n }\n});\nvar Polygon = Path.extend({\n type: 'ec-polygon',\n shape: {\n points: [],\n // Offset between stacked base points and points\n stackedOnPoints: [],\n smooth: 0,\n stackedOnSmooth: 0,\n smoothConstraint: true,\n smoothMonotone: null,\n connectNulls: false\n },\n brush: fixClipWithShadow(Path.prototype.brush),\n buildPath: function (ctx, shape) {\n var points = shape.points;\n var stackedOnPoints = shape.stackedOnPoints;\n var i = 0;\n var len = points.length;\n var smoothMonotone = shape.smoothMonotone;\n var bbox = getBoundingBox(points, shape.smoothConstraint);\n var stackedOnBBox = getBoundingBox(stackedOnPoints, shape.smoothConstraint);\n\n if (shape.connectNulls) {\n // Must remove first and last null values avoid draw error in polygon\n for (; len > 0; len--) {\n if (!isPointNull(points[len - 1])) {\n break;\n }\n }\n\n for (; i < len; i++) {\n if (!isPointNull(points[i])) {\n break;\n }\n }\n }\n\n while (i < len) {\n var k = drawSegment(ctx, points, i, len, len, 1, bbox.min, bbox.max, shape.smooth, smoothMonotone, shape.connectNulls);\n drawSegment(ctx, stackedOnPoints, i + k - 1, k, len, -1, stackedOnBBox.min, stackedOnBBox.max, shape.stackedOnSmooth, smoothMonotone, shape.connectNulls);\n i += k + 1;\n ctx.closePath();\n }\n }\n});\nexports.Polyline = Polyline;\nexports.Polygon = Polygon;","// Simple LRU cache use doubly linked list\n// @module zrender/core/LRU\n\n/**\n * Simple double linked list. Compared with array, it has O(1) remove operation.\n * @constructor\n */\nvar LinkedList = function () {\n /**\n * @type {module:zrender/core/LRU~Entry}\n */\n this.head = null;\n /**\n * @type {module:zrender/core/LRU~Entry}\n */\n\n this.tail = null;\n this._len = 0;\n};\n\nvar linkedListProto = LinkedList.prototype;\n/**\n * Insert a new value at the tail\n * @param {} val\n * @return {module:zrender/core/LRU~Entry}\n */\n\nlinkedListProto.insert = function (val) {\n var entry = new Entry(val);\n this.insertEntry(entry);\n return entry;\n};\n/**\n * Insert an entry at the tail\n * @param {module:zrender/core/LRU~Entry} entry\n */\n\n\nlinkedListProto.insertEntry = function (entry) {\n if (!this.head) {\n this.head = this.tail = entry;\n } else {\n this.tail.next = entry;\n entry.prev = this.tail;\n entry.next = null;\n this.tail = entry;\n }\n\n this._len++;\n};\n/**\n * Remove entry.\n * @param {module:zrender/core/LRU~Entry} entry\n */\n\n\nlinkedListProto.remove = function (entry) {\n var prev = entry.prev;\n var next = entry.next;\n\n if (prev) {\n prev.next = next;\n } else {\n // Is head\n this.head = next;\n }\n\n if (next) {\n next.prev = prev;\n } else {\n // Is tail\n this.tail = prev;\n }\n\n entry.next = entry.prev = null;\n this._len--;\n};\n/**\n * @return {number}\n */\n\n\nlinkedListProto.len = function () {\n return this._len;\n};\n/**\n * Clear list\n */\n\n\nlinkedListProto.clear = function () {\n this.head = this.tail = null;\n this._len = 0;\n};\n/**\n * @constructor\n * @param {} val\n */\n\n\nvar Entry = function (val) {\n /**\n * @type {}\n */\n this.value = val;\n /**\n * @type {module:zrender/core/LRU~Entry}\n */\n\n this.next;\n /**\n * @type {module:zrender/core/LRU~Entry}\n */\n\n this.prev;\n};\n/**\n * LRU Cache\n * @constructor\n * @alias module:zrender/core/LRU\n */\n\n\nvar LRU = function (maxSize) {\n this._list = new LinkedList();\n this._map = {};\n this._maxSize = maxSize || 10;\n this._lastRemovedEntry = null;\n};\n\nvar LRUProto = LRU.prototype;\n/**\n * @param {string} key\n * @param {} value\n * @return {} Removed value\n */\n\nLRUProto.put = function (key, value) {\n var list = this._list;\n var map = this._map;\n var removed = null;\n\n if (map[key] == null) {\n var len = list.len(); // Reuse last removed entry\n\n var entry = this._lastRemovedEntry;\n\n if (len >= this._maxSize && len > 0) {\n // Remove the least recently used\n var leastUsedEntry = list.head;\n list.remove(leastUsedEntry);\n delete map[leastUsedEntry.key];\n removed = leastUsedEntry.value;\n this._lastRemovedEntry = leastUsedEntry;\n }\n\n if (entry) {\n entry.value = value;\n } else {\n entry = new Entry(value);\n }\n\n entry.key = key;\n list.insertEntry(entry);\n map[key] = entry;\n }\n\n return removed;\n};\n/**\n * @param {string} key\n * @return {}\n */\n\n\nLRUProto.get = function (key) {\n var entry = this._map[key];\n var list = this._list;\n\n if (entry != null) {\n // Put the latest used entry in the tail\n if (entry !== list.tail) {\n list.remove(entry);\n list.insertEntry(entry);\n }\n\n return entry.value;\n }\n};\n/**\n * Clear the cache\n */\n\n\nLRUProto.clear = function () {\n this._list.clear();\n\n this._map = {};\n};\n\nvar _default = LRU;\nmodule.exports = _default;","var guid = require(\"./core/guid\");\n\nvar Eventful = require(\"./mixin/Eventful\");\n\nvar Transformable = require(\"./mixin/Transformable\");\n\nvar Animatable = require(\"./mixin/Animatable\");\n\nvar zrUtil = require(\"./core/util\");\n\n/**\n * @alias module:zrender/Element\n * @constructor\n * @extends {module:zrender/mixin/Animatable}\n * @extends {module:zrender/mixin/Transformable}\n * @extends {module:zrender/mixin/Eventful}\n */\nvar Element = function (opts) {\n // jshint ignore:line\n Transformable.call(this, opts);\n Eventful.call(this, opts);\n Animatable.call(this, opts);\n /**\n * 画布元素ID\n * @type {string}\n */\n\n this.id = opts.id || guid();\n};\n\nElement.prototype = {\n /**\n * 元素类型\n * Element type\n * @type {string}\n */\n type: 'element',\n\n /**\n * 元素名字\n * Element name\n * @type {string}\n */\n name: '',\n\n /**\n * ZRender 实例对象,会在 element 添加到 zrender 实例中后自动赋值\n * ZRender instance will be assigned when element is associated with zrender\n * @name module:/zrender/Element#__zr\n * @type {module:zrender/ZRender}\n */\n __zr: null,\n\n /**\n * 图形是否忽略,为true时忽略图形的绘制以及事件触发\n * If ignore drawing and events of the element object\n * @name module:/zrender/Element#ignore\n * @type {boolean}\n * @default false\n */\n ignore: false,\n\n /**\n * 用于裁剪的路径(shape),所有 Group 内的路径在绘制时都会被这个路径裁剪\n * 该路径会继承被裁减对象的变换\n * @type {module:zrender/graphic/Path}\n * @see http://www.w3.org/TR/2dcontext/#clipping-region\n * @readOnly\n */\n clipPath: null,\n\n /**\n * 是否是 Group\n * @type {boolean}\n */\n isGroup: false,\n\n /**\n * Drift element\n * @param {number} dx dx on the global space\n * @param {number} dy dy on the global space\n */\n drift: function (dx, dy) {\n switch (this.draggable) {\n case 'horizontal':\n dy = 0;\n break;\n\n case 'vertical':\n dx = 0;\n break;\n }\n\n var m = this.transform;\n\n if (!m) {\n m = this.transform = [1, 0, 0, 1, 0, 0];\n }\n\n m[4] += dx;\n m[5] += dy;\n this.decomposeTransform();\n this.dirty(false);\n },\n\n /**\n * Hook before update\n */\n beforeUpdate: function () {},\n\n /**\n * Hook after update\n */\n afterUpdate: function () {},\n\n /**\n * Update each frame\n */\n update: function () {\n this.updateTransform();\n },\n\n /**\n * @param {Function} cb\n * @param {} context\n */\n traverse: function (cb, context) {},\n\n /**\n * @protected\n */\n attrKV: function (key, value) {\n if (key === 'position' || key === 'scale' || key === 'origin') {\n // Copy the array\n if (value) {\n var target = this[key];\n\n if (!target) {\n target = this[key] = [];\n }\n\n target[0] = value[0];\n target[1] = value[1];\n }\n } else {\n this[key] = value;\n }\n },\n\n /**\n * Hide the element\n */\n hide: function () {\n this.ignore = true;\n this.__zr && this.__zr.refresh();\n },\n\n /**\n * Show the element\n */\n show: function () {\n this.ignore = false;\n this.__zr && this.__zr.refresh();\n },\n\n /**\n * @param {string|Object} key\n * @param {*} value\n */\n attr: function (key, value) {\n if (typeof key === 'string') {\n this.attrKV(key, value);\n } else if (zrUtil.isObject(key)) {\n for (var name in key) {\n if (key.hasOwnProperty(name)) {\n this.attrKV(name, key[name]);\n }\n }\n }\n\n this.dirty(false);\n return this;\n },\n\n /**\n * @param {module:zrender/graphic/Path} clipPath\n */\n setClipPath: function (clipPath) {\n var zr = this.__zr;\n\n if (zr) {\n clipPath.addSelfToZr(zr);\n } // Remove previous clip path\n\n\n if (this.clipPath && this.clipPath !== clipPath) {\n this.removeClipPath();\n }\n\n this.clipPath = clipPath;\n clipPath.__zr = zr;\n clipPath.__clipTarget = this;\n this.dirty(false);\n },\n\n /**\n */\n removeClipPath: function () {\n var clipPath = this.clipPath;\n\n if (clipPath) {\n if (clipPath.__zr) {\n clipPath.removeSelfFromZr(clipPath.__zr);\n }\n\n clipPath.__zr = null;\n clipPath.__clipTarget = null;\n this.clipPath = null;\n this.dirty(false);\n }\n },\n\n /**\n * Add self from zrender instance.\n * Not recursively because it will be invoked when element added to storage.\n * @param {module:zrender/ZRender} zr\n */\n addSelfToZr: function (zr) {\n this.__zr = zr; // 添加动画\n\n var animators = this.animators;\n\n if (animators) {\n for (var i = 0; i < animators.length; i++) {\n zr.animation.addAnimator(animators[i]);\n }\n }\n\n if (this.clipPath) {\n this.clipPath.addSelfToZr(zr);\n }\n },\n\n /**\n * Remove self from zrender instance.\n * Not recursively because it will be invoked when element added to storage.\n * @param {module:zrender/ZRender} zr\n */\n removeSelfFromZr: function (zr) {\n this.__zr = null; // 移除动画\n\n var animators = this.animators;\n\n if (animators) {\n for (var i = 0; i < animators.length; i++) {\n zr.animation.removeAnimator(animators[i]);\n }\n }\n\n if (this.clipPath) {\n this.clipPath.removeSelfFromZr(zr);\n }\n }\n};\nzrUtil.mixin(Element, Animatable);\nzrUtil.mixin(Element, Transformable);\nzrUtil.mixin(Element, Eventful);\nvar _default = Element;\nmodule.exports = _default;","var PathProxy = require(\"../core/PathProxy\");\n\nvar line = require(\"./line\");\n\nvar cubic = require(\"./cubic\");\n\nvar quadratic = require(\"./quadratic\");\n\nvar arc = require(\"./arc\");\n\nvar _util = require(\"./util\");\n\nvar normalizeRadian = _util.normalizeRadian;\n\nvar curve = require(\"../core/curve\");\n\nvar windingLine = require(\"./windingLine\");\n\nvar CMD = PathProxy.CMD;\nvar PI2 = Math.PI * 2;\nvar EPSILON = 1e-4;\n\nfunction isAroundEqual(a, b) {\n return Math.abs(a - b) < EPSILON;\n} // 临时数组\n\n\nvar roots = [-1, -1, -1];\nvar extrema = [-1, -1];\n\nfunction swapExtrema() {\n var tmp = extrema[0];\n extrema[0] = extrema[1];\n extrema[1] = tmp;\n}\n\nfunction windingCubic(x0, y0, x1, y1, x2, y2, x3, y3, x, y) {\n // Quick reject\n if (y > y0 && y > y1 && y > y2 && y > y3 || y < y0 && y < y1 && y < y2 && y < y3) {\n return 0;\n }\n\n var nRoots = curve.cubicRootAt(y0, y1, y2, y3, y, roots);\n\n if (nRoots === 0) {\n return 0;\n } else {\n var w = 0;\n var nExtrema = -1;\n var y0_;\n var y1_;\n\n for (var i = 0; i < nRoots; i++) {\n var t = roots[i]; // Avoid winding error when intersection point is the connect point of two line of polygon\n\n var unit = t === 0 || t === 1 ? 0.5 : 1;\n var x_ = curve.cubicAt(x0, x1, x2, x3, t);\n\n if (x_ < x) {\n // Quick reject\n continue;\n }\n\n if (nExtrema < 0) {\n nExtrema = curve.cubicExtrema(y0, y1, y2, y3, extrema);\n\n if (extrema[1] < extrema[0] && nExtrema > 1) {\n swapExtrema();\n }\n\n y0_ = curve.cubicAt(y0, y1, y2, y3, extrema[0]);\n\n if (nExtrema > 1) {\n y1_ = curve.cubicAt(y0, y1, y2, y3, extrema[1]);\n }\n }\n\n if (nExtrema === 2) {\n // 分成三段单调函数\n if (t < extrema[0]) {\n w += y0_ < y0 ? unit : -unit;\n } else if (t < extrema[1]) {\n w += y1_ < y0_ ? unit : -unit;\n } else {\n w += y3 < y1_ ? unit : -unit;\n }\n } else {\n // 分成两段单调函数\n if (t < extrema[0]) {\n w += y0_ < y0 ? unit : -unit;\n } else {\n w += y3 < y0_ ? unit : -unit;\n }\n }\n }\n\n return w;\n }\n}\n\nfunction windingQuadratic(x0, y0, x1, y1, x2, y2, x, y) {\n // Quick reject\n if (y > y0 && y > y1 && y > y2 || y < y0 && y < y1 && y < y2) {\n return 0;\n }\n\n var nRoots = curve.quadraticRootAt(y0, y1, y2, y, roots);\n\n if (nRoots === 0) {\n return 0;\n } else {\n var t = curve.quadraticExtremum(y0, y1, y2);\n\n if (t >= 0 && t <= 1) {\n var w = 0;\n var y_ = curve.quadraticAt(y0, y1, y2, t);\n\n for (var i = 0; i < nRoots; i++) {\n // Remove one endpoint.\n var unit = roots[i] === 0 || roots[i] === 1 ? 0.5 : 1;\n var x_ = curve.quadraticAt(x0, x1, x2, roots[i]);\n\n if (x_ < x) {\n // Quick reject\n continue;\n }\n\n if (roots[i] < t) {\n w += y_ < y0 ? unit : -unit;\n } else {\n w += y2 < y_ ? unit : -unit;\n }\n }\n\n return w;\n } else {\n // Remove one endpoint.\n var unit = roots[0] === 0 || roots[0] === 1 ? 0.5 : 1;\n var x_ = curve.quadraticAt(x0, x1, x2, roots[0]);\n\n if (x_ < x) {\n // Quick reject\n return 0;\n }\n\n return y2 < y0 ? unit : -unit;\n }\n }\n} // TODO\n// Arc 旋转\n\n\nfunction windingArc(cx, cy, r, startAngle, endAngle, anticlockwise, x, y) {\n y -= cy;\n\n if (y > r || y < -r) {\n return 0;\n }\n\n var tmp = Math.sqrt(r * r - y * y);\n roots[0] = -tmp;\n roots[1] = tmp;\n var diff = Math.abs(startAngle - endAngle);\n\n if (diff < 1e-4) {\n return 0;\n }\n\n if (diff % PI2 < 1e-4) {\n // Is a circle\n startAngle = 0;\n endAngle = PI2;\n var dir = anticlockwise ? 1 : -1;\n\n if (x >= roots[0] + cx && x <= roots[1] + cx) {\n return dir;\n } else {\n return 0;\n }\n }\n\n if (anticlockwise) {\n var tmp = startAngle;\n startAngle = normalizeRadian(endAngle);\n endAngle = normalizeRadian(tmp);\n } else {\n startAngle = normalizeRadian(startAngle);\n endAngle = normalizeRadian(endAngle);\n }\n\n if (startAngle > endAngle) {\n endAngle += PI2;\n }\n\n var w = 0;\n\n for (var i = 0; i < 2; i++) {\n var x_ = roots[i];\n\n if (x_ + cx > x) {\n var angle = Math.atan2(y, x_);\n var dir = anticlockwise ? 1 : -1;\n\n if (angle < 0) {\n angle = PI2 + angle;\n }\n\n if (angle >= startAngle && angle <= endAngle || angle + PI2 >= startAngle && angle + PI2 <= endAngle) {\n if (angle > Math.PI / 2 && angle < Math.PI * 1.5) {\n dir = -dir;\n }\n\n w += dir;\n }\n }\n }\n\n return w;\n}\n\nfunction containPath(data, lineWidth, isStroke, x, y) {\n var w = 0;\n var xi = 0;\n var yi = 0;\n var x0 = 0;\n var y0 = 0;\n\n for (var i = 0; i < data.length;) {\n var cmd = data[i++]; // Begin a new subpath\n\n if (cmd === CMD.M && i > 1) {\n // Close previous subpath\n if (!isStroke) {\n w += windingLine(xi, yi, x0, y0, x, y);\n } // 如果被任何一个 subpath 包含\n // if (w !== 0) {\n // return true;\n // }\n\n }\n\n if (i === 1) {\n // 如果第一个命令是 L, C, Q\n // 则 previous point 同绘制命令的第一个 point\n //\n // 第一个命令为 Arc 的情况下会在后面特殊处理\n xi = data[i];\n yi = data[i + 1];\n x0 = xi;\n y0 = yi;\n }\n\n switch (cmd) {\n case CMD.M:\n // moveTo 命令重新创建一个新的 subpath, 并且更新新的起点\n // 在 closePath 的时候使用\n x0 = data[i++];\n y0 = data[i++];\n xi = x0;\n yi = y0;\n break;\n\n case CMD.L:\n if (isStroke) {\n if (line.containStroke(xi, yi, data[i], data[i + 1], lineWidth, x, y)) {\n return true;\n }\n } else {\n // NOTE 在第一个命令为 L, C, Q 的时候会计算出 NaN\n w += windingLine(xi, yi, data[i], data[i + 1], x, y) || 0;\n }\n\n xi = data[i++];\n yi = data[i++];\n break;\n\n case CMD.C:\n if (isStroke) {\n if (cubic.containStroke(xi, yi, data[i++], data[i++], data[i++], data[i++], data[i], data[i + 1], lineWidth, x, y)) {\n return true;\n }\n } else {\n w += windingCubic(xi, yi, data[i++], data[i++], data[i++], data[i++], data[i], data[i + 1], x, y) || 0;\n }\n\n xi = data[i++];\n yi = data[i++];\n break;\n\n case CMD.Q:\n if (isStroke) {\n if (quadratic.containStroke(xi, yi, data[i++], data[i++], data[i], data[i + 1], lineWidth, x, y)) {\n return true;\n }\n } else {\n w += windingQuadratic(xi, yi, data[i++], data[i++], data[i], data[i + 1], x, y) || 0;\n }\n\n xi = data[i++];\n yi = data[i++];\n break;\n\n case CMD.A:\n // TODO Arc 判断的开销比较大\n var cx = data[i++];\n var cy = data[i++];\n var rx = data[i++];\n var ry = data[i++];\n var theta = data[i++];\n var dTheta = data[i++]; // TODO Arc 旋转\n\n i += 1;\n var anticlockwise = 1 - data[i++];\n var x1 = Math.cos(theta) * rx + cx;\n var y1 = Math.sin(theta) * ry + cy; // 不是直接使用 arc 命令\n\n if (i > 1) {\n w += windingLine(xi, yi, x1, y1, x, y);\n } else {\n // 第一个命令起点还未定义\n x0 = x1;\n y0 = y1;\n } // zr 使用scale来模拟椭圆, 这里也对x做一定的缩放\n\n\n var _x = (x - cx) * ry / rx + cx;\n\n if (isStroke) {\n if (arc.containStroke(cx, cy, ry, theta, theta + dTheta, anticlockwise, lineWidth, _x, y)) {\n return true;\n }\n } else {\n w += windingArc(cx, cy, ry, theta, theta + dTheta, anticlockwise, _x, y);\n }\n\n xi = Math.cos(theta + dTheta) * rx + cx;\n yi = Math.sin(theta + dTheta) * ry + cy;\n break;\n\n case CMD.R:\n x0 = xi = data[i++];\n y0 = yi = data[i++];\n var width = data[i++];\n var height = data[i++];\n var x1 = x0 + width;\n var y1 = y0 + height;\n\n if (isStroke) {\n if (line.containStroke(x0, y0, x1, y0, lineWidth, x, y) || line.containStroke(x1, y0, x1, y1, lineWidth, x, y) || line.containStroke(x1, y1, x0, y1, lineWidth, x, y) || line.containStroke(x0, y1, x0, y0, lineWidth, x, y)) {\n return true;\n }\n } else {\n // FIXME Clockwise ?\n w += windingLine(x1, y0, x1, y1, x, y);\n w += windingLine(x0, y1, x0, y0, x, y);\n }\n\n break;\n\n case CMD.Z:\n if (isStroke) {\n if (line.containStroke(xi, yi, x0, y0, lineWidth, x, y)) {\n return true;\n }\n } else {\n // Close a subpath\n w += windingLine(xi, yi, x0, y0, x, y); // 如果被任何一个 subpath 包含\n // FIXME subpaths may overlap\n // if (w !== 0) {\n // return true;\n // }\n }\n\n xi = x0;\n yi = y0;\n break;\n }\n }\n\n if (!isStroke && !isAroundEqual(yi, y0)) {\n w += windingLine(xi, yi, x0, y0, x, y) || 0;\n }\n\n return w !== 0;\n}\n\nfunction contain(pathData, x, y) {\n return containPath(pathData, 0, false, x, y);\n}\n\nfunction containStroke(pathData, lineWidth, x, y) {\n return containPath(pathData, lineWidth, true, x, y);\n}\n\nexports.contain = contain;\nexports.containStroke = containStroke;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar ComponentModel = require(\"../../model/Component\");\n\nvar axisModelCreator = require(\"../axisModelCreator\");\n\nvar axisModelCommonMixin = require(\"../axisModelCommonMixin\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar PolarAxisModel = ComponentModel.extend({\n type: 'polarAxis',\n\n /**\n * @type {module:echarts/coord/polar/AngleAxis|module:echarts/coord/polar/RadiusAxis}\n */\n axis: null,\n\n /**\n * @override\n */\n getCoordSysModel: function () {\n return this.ecModel.queryComponents({\n mainType: 'polar',\n index: this.option.polarIndex,\n id: this.option.polarId\n })[0];\n }\n});\nzrUtil.merge(PolarAxisModel.prototype, axisModelCommonMixin);\nvar polarAxisDefaultExtendedOption = {\n angle: {\n // polarIndex: 0,\n // polarId: '',\n startAngle: 90,\n clockwise: true,\n splitNumber: 12,\n axisLabel: {\n rotate: false\n }\n },\n radius: {\n // polarIndex: 0,\n // polarId: '',\n splitNumber: 5\n }\n};\n\nfunction getAxisType(axisDim, option) {\n // Default axis with data is category axis\n return option.type || (option.data ? 'category' : 'value');\n}\n\naxisModelCreator('angle', PolarAxisModel, getAxisType, polarAxisDefaultExtendedOption.angle);\naxisModelCreator('radius', PolarAxisModel, getAxisType, polarAxisDefaultExtendedOption.radius);","var Path = require(\"../Path\");\n\n/**\n * 圆形\n * @module zrender/shape/Circle\n */\nvar _default = Path.extend({\n type: 'circle',\n shape: {\n cx: 0,\n cy: 0,\n r: 0\n },\n buildPath: function (ctx, shape, inBundle) {\n // Better stroking in ShapeBundle\n // Always do it may have performence issue ( fill may be 2x more cost)\n if (inBundle) {\n ctx.moveTo(shape.cx + shape.r, shape.cy);\n } // else {\n // if (ctx.allocate && !ctx.data.length) {\n // ctx.allocate(ctx.CMD_MEM_SIZE.A);\n // }\n // }\n // Better stroking in ShapeBundle\n // ctx.moveTo(shape.cx + shape.r, shape.cy);\n\n\n ctx.arc(shape.cx, shape.cy, shape.r, 0, Math.PI * 2, true);\n }\n});\n\nmodule.exports = _default;","var Pattern = function (image, repeat) {\n // Should do nothing more in this constructor. Because gradient can be\n // declard by `color: {image: ...}`, where this constructor will not be called.\n this.image = image;\n this.repeat = repeat; // Can be cloned\n\n this.type = 'pattern';\n};\n\nPattern.prototype.getCanvasPattern = function (ctx) {\n return ctx.createPattern(this.image, this.repeat || 'repeat');\n};\n\nvar _default = Pattern;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar clazzUtil = require(\"../../util/clazz\");\n\nvar graphic = require(\"../../util/graphic\");\n\nvar axisPointerModelHelper = require(\"./modelHelper\");\n\nvar eventTool = require(\"zrender/lib/core/event\");\n\nvar throttleUtil = require(\"../../util/throttle\");\n\nvar _model = require(\"../../util/model\");\n\nvar makeInner = _model.makeInner;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar inner = makeInner();\nvar clone = zrUtil.clone;\nvar bind = zrUtil.bind;\n/**\n * Base axis pointer class in 2D.\n * Implemenents {module:echarts/component/axis/IAxisPointer}.\n */\n\nfunction BaseAxisPointer() {}\n\nBaseAxisPointer.prototype = {\n /**\n * @private\n */\n _group: null,\n\n /**\n * @private\n */\n _lastGraphicKey: null,\n\n /**\n * @private\n */\n _handle: null,\n\n /**\n * @private\n */\n _dragging: false,\n\n /**\n * @private\n */\n _lastValue: null,\n\n /**\n * @private\n */\n _lastStatus: null,\n\n /**\n * @private\n */\n _payloadInfo: null,\n\n /**\n * In px, arbitrary value. Do not set too small,\n * no animation is ok for most cases.\n * @protected\n */\n animationThreshold: 15,\n\n /**\n * @implement\n */\n render: function (axisModel, axisPointerModel, api, forceRender) {\n var value = axisPointerModel.get('value');\n var status = axisPointerModel.get('status'); // Bind them to `this`, not in closure, otherwise they will not\n // be replaced when user calling setOption in not merge mode.\n\n this._axisModel = axisModel;\n this._axisPointerModel = axisPointerModel;\n this._api = api; // Optimize: `render` will be called repeatly during mouse move.\n // So it is power consuming if performing `render` each time,\n // especially on mobile device.\n\n if (!forceRender && this._lastValue === value && this._lastStatus === status) {\n return;\n }\n\n this._lastValue = value;\n this._lastStatus = status;\n var group = this._group;\n var handle = this._handle;\n\n if (!status || status === 'hide') {\n // Do not clear here, for animation better.\n group && group.hide();\n handle && handle.hide();\n return;\n }\n\n group && group.show();\n handle && handle.show(); // Otherwise status is 'show'\n\n var elOption = {};\n this.makeElOption(elOption, value, axisModel, axisPointerModel, api); // Enable change axis pointer type.\n\n var graphicKey = elOption.graphicKey;\n\n if (graphicKey !== this._lastGraphicKey) {\n this.clear(api);\n }\n\n this._lastGraphicKey = graphicKey;\n var moveAnimation = this._moveAnimation = this.determineAnimation(axisModel, axisPointerModel);\n\n if (!group) {\n group = this._group = new graphic.Group();\n this.createPointerEl(group, elOption, axisModel, axisPointerModel);\n this.createLabelEl(group, elOption, axisModel, axisPointerModel);\n api.getZr().add(group);\n } else {\n var doUpdateProps = zrUtil.curry(updateProps, axisPointerModel, moveAnimation);\n this.updatePointerEl(group, elOption, doUpdateProps, axisPointerModel);\n this.updateLabelEl(group, elOption, doUpdateProps, axisPointerModel);\n }\n\n updateMandatoryProps(group, axisPointerModel, true);\n\n this._renderHandle(value);\n },\n\n /**\n * @implement\n */\n remove: function (api) {\n this.clear(api);\n },\n\n /**\n * @implement\n */\n dispose: function (api) {\n this.clear(api);\n },\n\n /**\n * @protected\n */\n determineAnimation: function (axisModel, axisPointerModel) {\n var animation = axisPointerModel.get('animation');\n var axis = axisModel.axis;\n var isCategoryAxis = axis.type === 'category';\n var useSnap = axisPointerModel.get('snap'); // Value axis without snap always do not snap.\n\n if (!useSnap && !isCategoryAxis) {\n return false;\n }\n\n if (animation === 'auto' || animation == null) {\n var animationThreshold = this.animationThreshold;\n\n if (isCategoryAxis && axis.getBandWidth() > animationThreshold) {\n return true;\n } // It is important to auto animation when snap used. Consider if there is\n // a dataZoom, animation will be disabled when too many points exist, while\n // it will be enabled for better visual effect when little points exist.\n\n\n if (useSnap) {\n var seriesDataCount = axisPointerModelHelper.getAxisInfo(axisModel).seriesDataCount;\n var axisExtent = axis.getExtent(); // Approximate band width\n\n return Math.abs(axisExtent[0] - axisExtent[1]) / seriesDataCount > animationThreshold;\n }\n\n return false;\n }\n\n return animation === true;\n },\n\n /**\n * add {pointer, label, graphicKey} to elOption\n * @protected\n */\n makeElOption: function (elOption, value, axisModel, axisPointerModel, api) {// Shoule be implemenented by sub-class.\n },\n\n /**\n * @protected\n */\n createPointerEl: function (group, elOption, axisModel, axisPointerModel) {\n var pointerOption = elOption.pointer;\n\n if (pointerOption) {\n var pointerEl = inner(group).pointerEl = new graphic[pointerOption.type](clone(elOption.pointer));\n group.add(pointerEl);\n }\n },\n\n /**\n * @protected\n */\n createLabelEl: function (group, elOption, axisModel, axisPointerModel) {\n if (elOption.label) {\n var labelEl = inner(group).labelEl = new graphic.Rect(clone(elOption.label));\n group.add(labelEl);\n updateLabelShowHide(labelEl, axisPointerModel);\n }\n },\n\n /**\n * @protected\n */\n updatePointerEl: function (group, elOption, updateProps) {\n var pointerEl = inner(group).pointerEl;\n\n if (pointerEl) {\n pointerEl.setStyle(elOption.pointer.style);\n updateProps(pointerEl, {\n shape: elOption.pointer.shape\n });\n }\n },\n\n /**\n * @protected\n */\n updateLabelEl: function (group, elOption, updateProps, axisPointerModel) {\n var labelEl = inner(group).labelEl;\n\n if (labelEl) {\n labelEl.setStyle(elOption.label.style);\n updateProps(labelEl, {\n // Consider text length change in vertical axis, animation should\n // be used on shape, otherwise the effect will be weird.\n shape: elOption.label.shape,\n position: elOption.label.position\n });\n updateLabelShowHide(labelEl, axisPointerModel);\n }\n },\n\n /**\n * @private\n */\n _renderHandle: function (value) {\n if (this._dragging || !this.updateHandleTransform) {\n return;\n }\n\n var axisPointerModel = this._axisPointerModel;\n\n var zr = this._api.getZr();\n\n var handle = this._handle;\n var handleModel = axisPointerModel.getModel('handle');\n var status = axisPointerModel.get('status');\n\n if (!handleModel.get('show') || !status || status === 'hide') {\n handle && zr.remove(handle);\n this._handle = null;\n return;\n }\n\n var isInit;\n\n if (!this._handle) {\n isInit = true;\n handle = this._handle = graphic.createIcon(handleModel.get('icon'), {\n cursor: 'move',\n draggable: true,\n onmousemove: function (e) {\n // Fot mobile devicem, prevent screen slider on the button.\n eventTool.stop(e.event);\n },\n onmousedown: bind(this._onHandleDragMove, this, 0, 0),\n drift: bind(this._onHandleDragMove, this),\n ondragend: bind(this._onHandleDragEnd, this)\n });\n zr.add(handle);\n }\n\n updateMandatoryProps(handle, axisPointerModel, false); // update style\n\n var includeStyles = ['color', 'borderColor', 'borderWidth', 'opacity', 'shadowColor', 'shadowBlur', 'shadowOffsetX', 'shadowOffsetY'];\n handle.setStyle(handleModel.getItemStyle(null, includeStyles)); // update position\n\n var handleSize = handleModel.get('size');\n\n if (!zrUtil.isArray(handleSize)) {\n handleSize = [handleSize, handleSize];\n }\n\n handle.attr('scale', [handleSize[0] / 2, handleSize[1] / 2]);\n throttleUtil.createOrUpdate(this, '_doDispatchAxisPointer', handleModel.get('throttle') || 0, 'fixRate');\n\n this._moveHandleToValue(value, isInit);\n },\n\n /**\n * @private\n */\n _moveHandleToValue: function (value, isInit) {\n updateProps(this._axisPointerModel, !isInit && this._moveAnimation, this._handle, getHandleTransProps(this.getHandleTransform(value, this._axisModel, this._axisPointerModel)));\n },\n\n /**\n * @private\n */\n _onHandleDragMove: function (dx, dy) {\n var handle = this._handle;\n\n if (!handle) {\n return;\n }\n\n this._dragging = true; // Persistent for throttle.\n\n var trans = this.updateHandleTransform(getHandleTransProps(handle), [dx, dy], this._axisModel, this._axisPointerModel);\n this._payloadInfo = trans;\n handle.stopAnimation();\n handle.attr(getHandleTransProps(trans));\n inner(handle).lastProp = null;\n\n this._doDispatchAxisPointer();\n },\n\n /**\n * Throttled method.\n * @private\n */\n _doDispatchAxisPointer: function () {\n var handle = this._handle;\n\n if (!handle) {\n return;\n }\n\n var payloadInfo = this._payloadInfo;\n var axisModel = this._axisModel;\n\n this._api.dispatchAction({\n type: 'updateAxisPointer',\n x: payloadInfo.cursorPoint[0],\n y: payloadInfo.cursorPoint[1],\n tooltipOption: payloadInfo.tooltipOption,\n axesInfo: [{\n axisDim: axisModel.axis.dim,\n axisIndex: axisModel.componentIndex\n }]\n });\n },\n\n /**\n * @private\n */\n _onHandleDragEnd: function (moveAnimation) {\n this._dragging = false;\n var handle = this._handle;\n\n if (!handle) {\n return;\n }\n\n var value = this._axisPointerModel.get('value'); // Consider snap or categroy axis, handle may be not consistent with\n // axisPointer. So move handle to align the exact value position when\n // drag ended.\n\n\n this._moveHandleToValue(value); // For the effect: tooltip will be shown when finger holding on handle\n // button, and will be hidden after finger left handle button.\n\n\n this._api.dispatchAction({\n type: 'hideTip'\n });\n },\n\n /**\n * Should be implemenented by sub-class if support `handle`.\n * @protected\n * @param {number} value\n * @param {module:echarts/model/Model} axisModel\n * @param {module:echarts/model/Model} axisPointerModel\n * @return {Object} {position: [x, y], rotation: 0}\n */\n getHandleTransform: null,\n\n /**\n * * Should be implemenented by sub-class if support `handle`.\n * @protected\n * @param {Object} transform {position, rotation}\n * @param {Array.<number>} delta [dx, dy]\n * @param {module:echarts/model/Model} axisModel\n * @param {module:echarts/model/Model} axisPointerModel\n * @return {Object} {position: [x, y], rotation: 0, cursorPoint: [x, y]}\n */\n updateHandleTransform: null,\n\n /**\n * @private\n */\n clear: function (api) {\n this._lastValue = null;\n this._lastStatus = null;\n var zr = api.getZr();\n var group = this._group;\n var handle = this._handle;\n\n if (zr && group) {\n this._lastGraphicKey = null;\n group && zr.remove(group);\n handle && zr.remove(handle);\n this._group = null;\n this._handle = null;\n this._payloadInfo = null;\n }\n },\n\n /**\n * @protected\n */\n doClear: function () {// Implemented by sub-class if necessary.\n },\n\n /**\n * @protected\n * @param {Array.<number>} xy\n * @param {Array.<number>} wh\n * @param {number} [xDimIndex=0] or 1\n */\n buildLabel: function (xy, wh, xDimIndex) {\n xDimIndex = xDimIndex || 0;\n return {\n x: xy[xDimIndex],\n y: xy[1 - xDimIndex],\n width: wh[xDimIndex],\n height: wh[1 - xDimIndex]\n };\n }\n};\nBaseAxisPointer.prototype.constructor = BaseAxisPointer;\n\nfunction updateProps(animationModel, moveAnimation, el, props) {\n // Animation optimize.\n if (!propsEqual(inner(el).lastProp, props)) {\n inner(el).lastProp = props;\n moveAnimation ? graphic.updateProps(el, props, animationModel) : (el.stopAnimation(), el.attr(props));\n }\n}\n\nfunction propsEqual(lastProps, newProps) {\n if (zrUtil.isObject(lastProps) && zrUtil.isObject(newProps)) {\n var equals = true;\n zrUtil.each(newProps, function (item, key) {\n equals = equals && propsEqual(lastProps[key], item);\n });\n return !!equals;\n } else {\n return lastProps === newProps;\n }\n}\n\nfunction updateLabelShowHide(labelEl, axisPointerModel) {\n labelEl[axisPointerModel.get('label.show') ? 'show' : 'hide']();\n}\n\nfunction getHandleTransProps(trans) {\n return {\n position: trans.position.slice(),\n rotation: trans.rotation || 0\n };\n}\n\nfunction updateMandatoryProps(group, axisPointerModel, silent) {\n var z = axisPointerModel.get('z');\n var zlevel = axisPointerModel.get('zlevel');\n group && group.traverse(function (el) {\n if (el.type !== 'group') {\n z != null && (el.z = z);\n zlevel != null && (el.zlevel = zlevel);\n el.silent = silent;\n }\n });\n}\n\nclazzUtil.enableClassExtend(BaseAxisPointer);\nvar _default = BaseAxisPointer;\nmodule.exports = _default;","var zrUtil = require(\"../core/util\");\n\nvar Gradient = require(\"./Gradient\");\n\n/**\n * x, y, r are all percent from 0 to 1\n * @param {number} [x=0.5]\n * @param {number} [y=0.5]\n * @param {number} [r=0.5]\n * @param {Array.<Object>} [colorStops]\n * @param {boolean} [globalCoord=false]\n */\nvar RadialGradient = function (x, y, r, colorStops, globalCoord) {\n // Should do nothing more in this constructor. Because gradient can be\n // declard by `color: {type: 'radial', colorStops: ...}`, where\n // this constructor will not be called.\n this.x = x == null ? 0.5 : x;\n this.y = y == null ? 0.5 : y;\n this.r = r == null ? 0.5 : r; // Can be cloned\n\n this.type = 'radial'; // If use global coord\n\n this.global = globalCoord || false;\n Gradient.call(this, colorStops);\n};\n\nRadialGradient.prototype = {\n constructor: RadialGradient\n};\nzrUtil.inherits(RadialGradient, Gradient);\nvar _default = RadialGradient;\nmodule.exports = _default;","/**\n * zrender: 生成唯一id\n *\n * @author errorrik (errorrik@gmail.com)\n */\nvar idStart = 0x0907;\n\nfunction _default() {\n return idStart++;\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar _default = {\n getBoxLayoutParams: function () {\n return {\n left: this.get('left'),\n top: this.get('top'),\n right: this.get('right'),\n bottom: this.get('bottom'),\n width: this.get('width'),\n height: this.get('height')\n };\n }\n};\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar textContain = require(\"zrender/lib/contain/text\");\n\nvar _model = require(\"../util/model\");\n\nvar makeInner = _model.makeInner;\n\nvar _axisHelper = require(\"./axisHelper\");\n\nvar makeLabelFormatter = _axisHelper.makeLabelFormatter;\nvar getOptionCategoryInterval = _axisHelper.getOptionCategoryInterval;\nvar shouldShowAllLabels = _axisHelper.shouldShowAllLabels;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar inner = makeInner();\n/**\n * @param {module:echats/coord/Axis} axis\n * @return {Object} {\n * labels: [{\n * formattedLabel: string,\n * rawLabel: string,\n * tickValue: number\n * }, ...],\n * labelCategoryInterval: number\n * }\n */\n\nfunction createAxisLabels(axis) {\n // Only ordinal scale support tick interval\n return axis.type === 'category' ? makeCategoryLabels(axis) : makeRealNumberLabels(axis);\n}\n/**\n * @param {module:echats/coord/Axis} axis\n * @param {module:echarts/model/Model} tickModel For example, can be axisTick, splitLine, splitArea.\n * @return {Object} {\n * ticks: Array.<number>\n * tickCategoryInterval: number\n * }\n */\n\n\nfunction createAxisTicks(axis, tickModel) {\n // Only ordinal scale support tick interval\n return axis.type === 'category' ? makeCategoryTicks(axis, tickModel) : {\n ticks: axis.scale.getTicks()\n };\n}\n\nfunction makeCategoryLabels(axis) {\n var labelModel = axis.getLabelModel();\n var result = makeCategoryLabelsActually(axis, labelModel);\n return !labelModel.get('show') || axis.scale.isBlank() ? {\n labels: [],\n labelCategoryInterval: result.labelCategoryInterval\n } : result;\n}\n\nfunction makeCategoryLabelsActually(axis, labelModel) {\n var labelsCache = getListCache(axis, 'labels');\n var optionLabelInterval = getOptionCategoryInterval(labelModel);\n var result = listCacheGet(labelsCache, optionLabelInterval);\n\n if (result) {\n return result;\n }\n\n var labels;\n var numericLabelInterval;\n\n if (zrUtil.isFunction(optionLabelInterval)) {\n labels = makeLabelsByCustomizedCategoryInterval(axis, optionLabelInterval);\n } else {\n numericLabelInterval = optionLabelInterval === 'auto' ? makeAutoCategoryInterval(axis) : optionLabelInterval;\n labels = makeLabelsByNumericCategoryInterval(axis, numericLabelInterval);\n } // Cache to avoid calling interval function repeatly.\n\n\n return listCacheSet(labelsCache, optionLabelInterval, {\n labels: labels,\n labelCategoryInterval: numericLabelInterval\n });\n}\n\nfunction makeCategoryTicks(axis, tickModel) {\n var ticksCache = getListCache(axis, 'ticks');\n var optionTickInterval = getOptionCategoryInterval(tickModel);\n var result = listCacheGet(ticksCache, optionTickInterval);\n\n if (result) {\n return result;\n }\n\n var ticks;\n var tickCategoryInterval; // Optimize for the case that large category data and no label displayed,\n // we should not return all ticks.\n\n if (!tickModel.get('show') || axis.scale.isBlank()) {\n ticks = [];\n }\n\n if (zrUtil.isFunction(optionTickInterval)) {\n ticks = makeLabelsByCustomizedCategoryInterval(axis, optionTickInterval, true);\n } // Always use label interval by default despite label show. Consider this\n // scenario, Use multiple grid with the xAxis sync, and only one xAxis shows\n // labels. `splitLine` and `axisTick` should be consistent in this case.\n else if (optionTickInterval === 'auto') {\n var labelsResult = makeCategoryLabelsActually(axis, axis.getLabelModel());\n tickCategoryInterval = labelsResult.labelCategoryInterval;\n ticks = zrUtil.map(labelsResult.labels, function (labelItem) {\n return labelItem.tickValue;\n });\n } else {\n tickCategoryInterval = optionTickInterval;\n ticks = makeLabelsByNumericCategoryInterval(axis, tickCategoryInterval, true);\n } // Cache to avoid calling interval function repeatly.\n\n\n return listCacheSet(ticksCache, optionTickInterval, {\n ticks: ticks,\n tickCategoryInterval: tickCategoryInterval\n });\n}\n\nfunction makeRealNumberLabels(axis) {\n var ticks = axis.scale.getTicks();\n var labelFormatter = makeLabelFormatter(axis);\n return {\n labels: zrUtil.map(ticks, function (tickValue, idx) {\n return {\n formattedLabel: labelFormatter(tickValue, idx),\n rawLabel: axis.scale.getLabel(tickValue),\n tickValue: tickValue\n };\n })\n };\n} // Large category data calculation is performence sensitive, and ticks and label\n// probably be fetched by multiple times. So we cache the result.\n// axis is created each time during a ec process, so we do not need to clear cache.\n\n\nfunction getListCache(axis, prop) {\n // Because key can be funciton, and cache size always be small, we use array cache.\n return inner(axis)[prop] || (inner(axis)[prop] = []);\n}\n\nfunction listCacheGet(cache, key) {\n for (var i = 0; i < cache.length; i++) {\n if (cache[i].key === key) {\n return cache[i].value;\n }\n }\n}\n\nfunction listCacheSet(cache, key, value) {\n cache.push({\n key: key,\n value: value\n });\n return value;\n}\n\nfunction makeAutoCategoryInterval(axis) {\n var result = inner(axis).autoInterval;\n return result != null ? result : inner(axis).autoInterval = axis.calculateCategoryInterval();\n}\n/**\n * Calculate interval for category axis ticks and labels.\n * To get precise result, at least one of `getRotate` and `isHorizontal`\n * should be implemented in axis.\n */\n\n\nfunction calculateCategoryInterval(axis) {\n var params = fetchAutoCategoryIntervalCalculationParams(axis);\n var labelFormatter = makeLabelFormatter(axis);\n var rotation = (params.axisRotate - params.labelRotate) / 180 * Math.PI;\n var ordinalScale = axis.scale;\n var ordinalExtent = ordinalScale.getExtent(); // Providing this method is for optimization:\n // avoid generating a long array by `getTicks`\n // in large category data case.\n\n var tickCount = ordinalScale.count();\n\n if (ordinalExtent[1] - ordinalExtent[0] < 1) {\n return 0;\n }\n\n var step = 1; // Simple optimization. Empirical value: tick count should less than 40.\n\n if (tickCount > 40) {\n step = Math.max(1, Math.floor(tickCount / 40));\n }\n\n var tickValue = ordinalExtent[0];\n var unitSpan = axis.dataToCoord(tickValue + 1) - axis.dataToCoord(tickValue);\n var unitW = Math.abs(unitSpan * Math.cos(rotation));\n var unitH = Math.abs(unitSpan * Math.sin(rotation));\n var maxW = 0;\n var maxH = 0; // Caution: Performance sensitive for large category data.\n // Consider dataZoom, we should make appropriate step to avoid O(n) loop.\n\n for (; tickValue <= ordinalExtent[1]; tickValue += step) {\n var width = 0;\n var height = 0; // Not precise, do not consider align and vertical align\n // and each distance from axis line yet.\n\n var rect = textContain.getBoundingRect(labelFormatter(tickValue), params.font, 'center', 'top'); // Magic number\n\n width = rect.width * 1.3;\n height = rect.height * 1.3; // Min size, void long loop.\n\n maxW = Math.max(maxW, width, 7);\n maxH = Math.max(maxH, height, 7);\n }\n\n var dw = maxW / unitW;\n var dh = maxH / unitH; // 0/0 is NaN, 1/0 is Infinity.\n\n isNaN(dw) && (dw = Infinity);\n isNaN(dh) && (dh = Infinity);\n var interval = Math.max(0, Math.floor(Math.min(dw, dh)));\n var cache = inner(axis.model);\n var lastAutoInterval = cache.lastAutoInterval;\n var lastTickCount = cache.lastTickCount; // Use cache to keep interval stable while moving zoom window,\n // otherwise the calculated interval might jitter when the zoom\n // window size is close to the interval-changing size.\n\n if (lastAutoInterval != null && lastTickCount != null && Math.abs(lastAutoInterval - interval) <= 1 && Math.abs(lastTickCount - tickCount) <= 1 // Always choose the bigger one, otherwise the critical\n // point is not the same when zooming in or zooming out.\n && lastAutoInterval > interval) {\n interval = lastAutoInterval;\n } // Only update cache if cache not used, otherwise the\n // changing of interval is too insensitive.\n else {\n cache.lastTickCount = tickCount;\n cache.lastAutoInterval = interval;\n }\n\n return interval;\n}\n\nfunction fetchAutoCategoryIntervalCalculationParams(axis) {\n var labelModel = axis.getLabelModel();\n return {\n axisRotate: axis.getRotate ? axis.getRotate() : axis.isHorizontal && !axis.isHorizontal() ? 90 : 0,\n labelRotate: labelModel.get('rotate') || 0,\n font: labelModel.getFont()\n };\n}\n\nfunction makeLabelsByNumericCategoryInterval(axis, categoryInterval, onlyTick) {\n var labelFormatter = makeLabelFormatter(axis);\n var ordinalScale = axis.scale;\n var ordinalExtent = ordinalScale.getExtent();\n var labelModel = axis.getLabelModel();\n var result = []; // TODO: axisType: ordinalTime, pick the tick from each month/day/year/...\n\n var step = Math.max((categoryInterval || 0) + 1, 1);\n var startTick = ordinalExtent[0];\n var tickCount = ordinalScale.count(); // Calculate start tick based on zero if possible to keep label consistent\n // while zooming and moving while interval > 0. Otherwise the selection\n // of displayable ticks and symbols probably keep changing.\n // 3 is empirical value.\n\n if (startTick !== 0 && step > 1 && tickCount / step > 2) {\n startTick = Math.round(Math.ceil(startTick / step) * step);\n } // (1) Only add min max label here but leave overlap checking\n // to render stage, which also ensure the returned list\n // suitable for splitLine and splitArea rendering.\n // (2) Scales except category always contain min max label so\n // do not need to perform this process.\n\n\n var showAllLabel = shouldShowAllLabels(axis);\n var includeMinLabel = labelModel.get('showMinLabel') || showAllLabel;\n var includeMaxLabel = labelModel.get('showMaxLabel') || showAllLabel;\n\n if (includeMinLabel && startTick !== ordinalExtent[0]) {\n addItem(ordinalExtent[0]);\n } // Optimize: avoid generating large array by `ordinalScale.getTicks()`.\n\n\n var tickValue = startTick;\n\n for (; tickValue <= ordinalExtent[1]; tickValue += step) {\n addItem(tickValue);\n }\n\n if (includeMaxLabel && tickValue !== ordinalExtent[1]) {\n addItem(ordinalExtent[1]);\n }\n\n function addItem(tVal) {\n result.push(onlyTick ? tVal : {\n formattedLabel: labelFormatter(tVal),\n rawLabel: ordinalScale.getLabel(tVal),\n tickValue: tVal\n });\n }\n\n return result;\n} // When interval is function, the result `false` means ignore the tick.\n// It is time consuming for large category data.\n\n\nfunction makeLabelsByCustomizedCategoryInterval(axis, categoryInterval, onlyTick) {\n var ordinalScale = axis.scale;\n var labelFormatter = makeLabelFormatter(axis);\n var result = [];\n zrUtil.each(ordinalScale.getTicks(), function (tickValue) {\n var rawLabel = ordinalScale.getLabel(tickValue);\n\n if (categoryInterval(tickValue, rawLabel)) {\n result.push(onlyTick ? tickValue : {\n formattedLabel: labelFormatter(tickValue),\n rawLabel: rawLabel,\n tickValue: tickValue\n });\n }\n });\n return result;\n}\n\nexports.createAxisLabels = createAxisLabels;\nexports.createAxisTicks = createAxisTicks;\nexports.calculateCategoryInterval = calculateCategoryInterval;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar env = require(\"zrender/lib/core/env\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar each = zrUtil.each;\nvar isObject = zrUtil.isObject;\nvar isArray = zrUtil.isArray;\n/**\n * Make the name displayable. But we should\n * make sure it is not duplicated with user\n * specified name, so use '\\0';\n */\n\nvar DUMMY_COMPONENT_NAME_PREFIX = 'series\\0';\n/**\n * If value is not array, then translate it to array.\n * @param {*} value\n * @return {Array} [value] or value\n */\n\nfunction normalizeToArray(value) {\n return value instanceof Array ? value : value == null ? [] : [value];\n}\n/**\n * Sync default option between normal and emphasis like `position` and `show`\n * In case some one will write code like\n * label: {\n * show: false,\n * position: 'outside',\n * fontSize: 18\n * },\n * emphasis: {\n * label: { show: true }\n * }\n * @param {Object} opt\n * @param {string} key\n * @param {Array.<string>} subOpts\n */\n\n\nfunction defaultEmphasis(opt, key, subOpts) {\n // Caution: performance sensitive.\n if (opt) {\n opt[key] = opt[key] || {};\n opt.emphasis = opt.emphasis || {};\n opt.emphasis[key] = opt.emphasis[key] || {}; // Default emphasis option from normal\n\n for (var i = 0, len = subOpts.length; i < len; i++) {\n var subOptName = subOpts[i];\n\n if (!opt.emphasis[key].hasOwnProperty(subOptName) && opt[key].hasOwnProperty(subOptName)) {\n opt.emphasis[key][subOptName] = opt[key][subOptName];\n }\n }\n }\n}\n\nvar TEXT_STYLE_OPTIONS = ['fontStyle', 'fontWeight', 'fontSize', 'fontFamily', 'rich', 'tag', 'color', 'textBorderColor', 'textBorderWidth', 'width', 'height', 'lineHeight', 'align', 'verticalAlign', 'baseline', 'shadowColor', 'shadowBlur', 'shadowOffsetX', 'shadowOffsetY', 'textShadowColor', 'textShadowBlur', 'textShadowOffsetX', 'textShadowOffsetY', 'backgroundColor', 'borderColor', 'borderWidth', 'borderRadius', 'padding']; // modelUtil.LABEL_OPTIONS = modelUtil.TEXT_STYLE_OPTIONS.concat([\n// 'position', 'offset', 'rotate', 'origin', 'show', 'distance', 'formatter',\n// 'fontStyle', 'fontWeight', 'fontSize', 'fontFamily',\n// // FIXME: deprecated, check and remove it.\n// 'textStyle'\n// ]);\n\n/**\n * The method do not ensure performance.\n * data could be [12, 2323, {value: 223}, [1221, 23], {value: [2, 23]}]\n * This helper method retieves value from data.\n * @param {string|number|Date|Array|Object} dataItem\n * @return {number|string|Date|Array.<number|string|Date>}\n */\n\nfunction getDataItemValue(dataItem) {\n return isObject(dataItem) && !isArray(dataItem) && !(dataItem instanceof Date) ? dataItem.value : dataItem;\n}\n/**\n * data could be [12, 2323, {value: 223}, [1221, 23], {value: [2, 23]}]\n * This helper method determine if dataItem has extra option besides value\n * @param {string|number|Date|Array|Object} dataItem\n */\n\n\nfunction isDataItemOption(dataItem) {\n return isObject(dataItem) && !(dataItem instanceof Array); // // markLine data can be array\n // && !(dataItem[0] && isObject(dataItem[0]) && !(dataItem[0] instanceof Array));\n}\n/**\n * Mapping to exists for merge.\n *\n * @public\n * @param {Array.<Object>|Array.<module:echarts/model/Component>} exists\n * @param {Object|Array.<Object>} newCptOptions\n * @return {Array.<Object>} Result, like [{exist: ..., option: ...}, {}],\n * index of which is the same as exists.\n */\n\n\nfunction mappingToExists(exists, newCptOptions) {\n // Mapping by the order by original option (but not order of\n // new option) in merge mode. Because we should ensure\n // some specified index (like xAxisIndex) is consistent with\n // original option, which is easy to understand, espatially in\n // media query. And in most case, merge option is used to\n // update partial option but not be expected to change order.\n newCptOptions = (newCptOptions || []).slice();\n var result = zrUtil.map(exists || [], function (obj, index) {\n return {\n exist: obj\n };\n }); // Mapping by id or name if specified.\n\n each(newCptOptions, function (cptOption, index) {\n if (!isObject(cptOption)) {\n return;\n } // id has highest priority.\n\n\n for (var i = 0; i < result.length; i++) {\n if (!result[i].option // Consider name: two map to one.\n && cptOption.id != null && result[i].exist.id === cptOption.id + '') {\n result[i].option = cptOption;\n newCptOptions[index] = null;\n return;\n }\n }\n\n for (var i = 0; i < result.length; i++) {\n var exist = result[i].exist;\n\n if (!result[i].option // Consider name: two map to one.\n // Can not match when both ids exist but different.\n && (exist.id == null || cptOption.id == null) && cptOption.name != null && !isIdInner(cptOption) && !isIdInner(exist) && exist.name === cptOption.name + '') {\n result[i].option = cptOption;\n newCptOptions[index] = null;\n return;\n }\n }\n }); // Otherwise mapping by index.\n\n each(newCptOptions, function (cptOption, index) {\n if (!isObject(cptOption)) {\n return;\n }\n\n var i = 0;\n\n for (; i < result.length; i++) {\n var exist = result[i].exist;\n\n if (!result[i].option // Existing model that already has id should be able to\n // mapped to (because after mapping performed model may\n // be assigned with a id, whish should not affect next\n // mapping), except those has inner id.\n && !isIdInner(exist) // Caution:\n // Do not overwrite id. But name can be overwritten,\n // because axis use name as 'show label text'.\n // 'exist' always has id and name and we dont\n // need to check it.\n && cptOption.id == null) {\n result[i].option = cptOption;\n break;\n }\n }\n\n if (i >= result.length) {\n result.push({\n option: cptOption\n });\n }\n });\n return result;\n}\n/**\n * Make id and name for mapping result (result of mappingToExists)\n * into `keyInfo` field.\n *\n * @public\n * @param {Array.<Object>} Result, like [{exist: ..., option: ...}, {}],\n * which order is the same as exists.\n * @return {Array.<Object>} The input.\n */\n\n\nfunction makeIdAndName(mapResult) {\n // We use this id to hash component models and view instances\n // in echarts. id can be specified by user, or auto generated.\n // The id generation rule ensures new view instance are able\n // to mapped to old instance when setOption are called in\n // no-merge mode. So we generate model id by name and plus\n // type in view id.\n // name can be duplicated among components, which is convenient\n // to specify multi components (like series) by one name.\n // Ensure that each id is distinct.\n var idMap = zrUtil.createHashMap();\n each(mapResult, function (item, index) {\n var existCpt = item.exist;\n existCpt && idMap.set(existCpt.id, item);\n });\n each(mapResult, function (item, index) {\n var opt = item.option;\n zrUtil.assert(!opt || opt.id == null || !idMap.get(opt.id) || idMap.get(opt.id) === item, 'id duplicates: ' + (opt && opt.id));\n opt && opt.id != null && idMap.set(opt.id, item);\n !item.keyInfo && (item.keyInfo = {});\n }); // Make name and id.\n\n each(mapResult, function (item, index) {\n var existCpt = item.exist;\n var opt = item.option;\n var keyInfo = item.keyInfo;\n\n if (!isObject(opt)) {\n return;\n } // name can be overwitten. Consider case: axis.name = '20km'.\n // But id generated by name will not be changed, which affect\n // only in that case: setOption with 'not merge mode' and view\n // instance will be recreated, which can be accepted.\n\n\n keyInfo.name = opt.name != null ? opt.name + '' : existCpt ? existCpt.name // Avoid diffferent series has the same name,\n // because name may be used like in color pallet.\n : DUMMY_COMPONENT_NAME_PREFIX + index;\n\n if (existCpt) {\n keyInfo.id = existCpt.id;\n } else if (opt.id != null) {\n keyInfo.id = opt.id + '';\n } else {\n // Consider this situatoin:\n // optionA: [{name: 'a'}, {name: 'a'}, {..}]\n // optionB [{..}, {name: 'a'}, {name: 'a'}]\n // Series with the same name between optionA and optionB\n // should be mapped.\n var idNum = 0;\n\n do {\n keyInfo.id = '\\0' + keyInfo.name + '\\0' + idNum++;\n } while (idMap.get(keyInfo.id));\n }\n\n idMap.set(keyInfo.id, item);\n });\n}\n\nfunction isNameSpecified(componentModel) {\n var name = componentModel.name; // Is specified when `indexOf` get -1 or > 0.\n\n return !!(name && name.indexOf(DUMMY_COMPONENT_NAME_PREFIX));\n}\n/**\n * @public\n * @param {Object} cptOption\n * @return {boolean}\n */\n\n\nfunction isIdInner(cptOption) {\n return isObject(cptOption) && cptOption.id && (cptOption.id + '').indexOf('\\0_ec_\\0') === 0;\n}\n/**\n * A helper for removing duplicate items between batchA and batchB,\n * and in themselves, and categorize by series.\n *\n * @param {Array.<Object>} batchA Like: [{seriesId: 2, dataIndex: [32, 4, 5]}, ...]\n * @param {Array.<Object>} batchB Like: [{seriesId: 2, dataIndex: [32, 4, 5]}, ...]\n * @return {Array.<Array.<Object>, Array.<Object>>} result: [resultBatchA, resultBatchB]\n */\n\n\nfunction compressBatches(batchA, batchB) {\n var mapA = {};\n var mapB = {};\n makeMap(batchA || [], mapA);\n makeMap(batchB || [], mapB, mapA);\n return [mapToArray(mapA), mapToArray(mapB)];\n\n function makeMap(sourceBatch, map, otherMap) {\n for (var i = 0, len = sourceBatch.length; i < len; i++) {\n var seriesId = sourceBatch[i].seriesId;\n var dataIndices = normalizeToArray(sourceBatch[i].dataIndex);\n var otherDataIndices = otherMap && otherMap[seriesId];\n\n for (var j = 0, lenj = dataIndices.length; j < lenj; j++) {\n var dataIndex = dataIndices[j];\n\n if (otherDataIndices && otherDataIndices[dataIndex]) {\n otherDataIndices[dataIndex] = null;\n } else {\n (map[seriesId] || (map[seriesId] = {}))[dataIndex] = 1;\n }\n }\n }\n }\n\n function mapToArray(map, isData) {\n var result = [];\n\n for (var i in map) {\n if (map.hasOwnProperty(i) && map[i] != null) {\n if (isData) {\n result.push(+i);\n } else {\n var dataIndices = mapToArray(map[i], true);\n dataIndices.length && result.push({\n seriesId: i,\n dataIndex: dataIndices\n });\n }\n }\n }\n\n return result;\n }\n}\n/**\n * @param {module:echarts/data/List} data\n * @param {Object} payload Contains dataIndex (means rawIndex) / dataIndexInside / name\n * each of which can be Array or primary type.\n * @return {number|Array.<number>} dataIndex If not found, return undefined/null.\n */\n\n\nfunction queryDataIndex(data, payload) {\n if (payload.dataIndexInside != null) {\n return payload.dataIndexInside;\n } else if (payload.dataIndex != null) {\n return zrUtil.isArray(payload.dataIndex) ? zrUtil.map(payload.dataIndex, function (value) {\n return data.indexOfRawIndex(value);\n }) : data.indexOfRawIndex(payload.dataIndex);\n } else if (payload.name != null) {\n return zrUtil.isArray(payload.name) ? zrUtil.map(payload.name, function (value) {\n return data.indexOfName(value);\n }) : data.indexOfName(payload.name);\n }\n}\n/**\n * Enable property storage to any host object.\n * Notice: Serialization is not supported.\n *\n * For example:\n * var inner = zrUitl.makeInner();\n *\n * function some1(hostObj) {\n * inner(hostObj).someProperty = 1212;\n * ...\n * }\n * function some2() {\n * var fields = inner(this);\n * fields.someProperty1 = 1212;\n * fields.someProperty2 = 'xx';\n * ...\n * }\n *\n * @return {Function}\n */\n\n\nfunction makeInner() {\n // Consider different scope by es module import.\n var key = '__\\0ec_inner_' + innerUniqueIndex++ + '_' + Math.random().toFixed(5);\n return function (hostObj) {\n return hostObj[key] || (hostObj[key] = {});\n };\n}\n\nvar innerUniqueIndex = 0;\n/**\n * @param {module:echarts/model/Global} ecModel\n * @param {string|Object} finder\n * If string, e.g., 'geo', means {geoIndex: 0}.\n * If Object, could contain some of these properties below:\n * {\n * seriesIndex, seriesId, seriesName,\n * geoIndex, geoId, geoName,\n * bmapIndex, bmapId, bmapName,\n * xAxisIndex, xAxisId, xAxisName,\n * yAxisIndex, yAxisId, yAxisName,\n * gridIndex, gridId, gridName,\n * ... (can be extended)\n * }\n * Each properties can be number|string|Array.<number>|Array.<string>\n * For example, a finder could be\n * {\n * seriesIndex: 3,\n * geoId: ['aa', 'cc'],\n * gridName: ['xx', 'rr']\n * }\n * xxxIndex can be set as 'all' (means all xxx) or 'none' (means not specify)\n * If nothing or null/undefined specified, return nothing.\n * @param {Object} [opt]\n * @param {string} [opt.defaultMainType]\n * @param {Array.<string>} [opt.includeMainTypes]\n * @return {Object} result like:\n * {\n * seriesModels: [seriesModel1, seriesModel2],\n * seriesModel: seriesModel1, // The first model\n * geoModels: [geoModel1, geoModel2],\n * geoModel: geoModel1, // The first model\n * ...\n * }\n */\n\nfunction parseFinder(ecModel, finder, opt) {\n if (zrUtil.isString(finder)) {\n var obj = {};\n obj[finder + 'Index'] = 0;\n finder = obj;\n }\n\n var defaultMainType = opt && opt.defaultMainType;\n\n if (defaultMainType && !has(finder, defaultMainType + 'Index') && !has(finder, defaultMainType + 'Id') && !has(finder, defaultMainType + 'Name')) {\n finder[defaultMainType + 'Index'] = 0;\n }\n\n var result = {};\n each(finder, function (value, key) {\n var value = finder[key]; // Exclude 'dataIndex' and other illgal keys.\n\n if (key === 'dataIndex' || key === 'dataIndexInside') {\n result[key] = value;\n return;\n }\n\n var parsedKey = key.match(/^(\\w+)(Index|Id|Name)$/) || [];\n var mainType = parsedKey[1];\n var queryType = (parsedKey[2] || '').toLowerCase();\n\n if (!mainType || !queryType || value == null || queryType === 'index' && value === 'none' || opt && opt.includeMainTypes && zrUtil.indexOf(opt.includeMainTypes, mainType) < 0) {\n return;\n }\n\n var queryParam = {\n mainType: mainType\n };\n\n if (queryType !== 'index' || value !== 'all') {\n queryParam[queryType] = value;\n }\n\n var models = ecModel.queryComponents(queryParam);\n result[mainType + 'Models'] = models;\n result[mainType + 'Model'] = models[0];\n });\n return result;\n}\n\nfunction has(obj, prop) {\n return obj && obj.hasOwnProperty(prop);\n}\n\nfunction setAttribute(dom, key, value) {\n dom.setAttribute ? dom.setAttribute(key, value) : dom[key] = value;\n}\n\nfunction getAttribute(dom, key) {\n return dom.getAttribute ? dom.getAttribute(key) : dom[key];\n}\n\nfunction getTooltipRenderMode(renderModeOption) {\n if (renderModeOption === 'auto') {\n // Using html when `document` exists, use richText otherwise\n return env.domSupported ? 'html' : 'richText';\n } else {\n return renderModeOption || 'html';\n }\n}\n/**\n * Group a list by key.\n *\n * @param {Array} array\n * @param {Function} getKey\n * param {*} Array item\n * return {string} key\n * @return {Object} Result\n * {Array}: keys,\n * {module:zrender/core/util/HashMap} buckets: {key -> Array}\n */\n\n\nfunction groupData(array, getKey) {\n var buckets = zrUtil.createHashMap();\n var keys = [];\n zrUtil.each(array, function (item) {\n var key = getKey(item);\n (buckets.get(key) || (keys.push(key), buckets.set(key, []))).push(item);\n });\n return {\n keys: keys,\n buckets: buckets\n };\n}\n\nexports.normalizeToArray = normalizeToArray;\nexports.defaultEmphasis = defaultEmphasis;\nexports.TEXT_STYLE_OPTIONS = TEXT_STYLE_OPTIONS;\nexports.getDataItemValue = getDataItemValue;\nexports.isDataItemOption = isDataItemOption;\nexports.mappingToExists = mappingToExists;\nexports.makeIdAndName = makeIdAndName;\nexports.isNameSpecified = isNameSpecified;\nexports.isIdInner = isIdInner;\nexports.compressBatches = compressBatches;\nexports.queryDataIndex = queryDataIndex;\nexports.makeInner = makeInner;\nexports.parseFinder = parseFinder;\nexports.setAttribute = setAttribute;\nexports.getAttribute = getAttribute;\nexports.getTooltipRenderMode = getTooltipRenderMode;\nexports.groupData = groupData;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar clazzUtil = require(\"../util/clazz\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * // Scale class management\n * @module echarts/scale/Scale\n */\n\n/**\n * @param {Object} [setting]\n */\nfunction Scale(setting) {\n this._setting = setting || {};\n /**\n * Extent\n * @type {Array.<number>}\n * @protected\n */\n\n this._extent = [Infinity, -Infinity];\n /**\n * Step is calculated in adjustExtent\n * @type {Array.<number>}\n * @protected\n */\n\n this._interval = 0;\n this.init && this.init.apply(this, arguments);\n}\n/**\n * Parse input val to valid inner number.\n * @param {*} val\n * @return {number}\n */\n\n\nScale.prototype.parse = function (val) {\n // Notice: This would be a trap here, If the implementation\n // of this method depends on extent, and this method is used\n // before extent set (like in dataZoom), it would be wrong.\n // Nevertheless, parse does not depend on extent generally.\n return val;\n};\n\nScale.prototype.getSetting = function (name) {\n return this._setting[name];\n};\n\nScale.prototype.contain = function (val) {\n var extent = this._extent;\n return val >= extent[0] && val <= extent[1];\n};\n/**\n * Normalize value to linear [0, 1], return 0.5 if extent span is 0\n * @param {number} val\n * @return {number}\n */\n\n\nScale.prototype.normalize = function (val) {\n var extent = this._extent;\n\n if (extent[1] === extent[0]) {\n return 0.5;\n }\n\n return (val - extent[0]) / (extent[1] - extent[0]);\n};\n/**\n * Scale normalized value\n * @param {number} val\n * @return {number}\n */\n\n\nScale.prototype.scale = function (val) {\n var extent = this._extent;\n return val * (extent[1] - extent[0]) + extent[0];\n};\n/**\n * Set extent from data\n * @param {Array.<number>} other\n */\n\n\nScale.prototype.unionExtent = function (other) {\n var extent = this._extent;\n other[0] < extent[0] && (extent[0] = other[0]);\n other[1] > extent[1] && (extent[1] = other[1]); // not setExtent because in log axis it may transformed to power\n // this.setExtent(extent[0], extent[1]);\n};\n/**\n * Set extent from data\n * @param {module:echarts/data/List} data\n * @param {string} dim\n */\n\n\nScale.prototype.unionExtentFromData = function (data, dim) {\n this.unionExtent(data.getApproximateExtent(dim));\n};\n/**\n * Get extent\n * @return {Array.<number>}\n */\n\n\nScale.prototype.getExtent = function () {\n return this._extent.slice();\n};\n/**\n * Set extent\n * @param {number} start\n * @param {number} end\n */\n\n\nScale.prototype.setExtent = function (start, end) {\n var thisExtent = this._extent;\n\n if (!isNaN(start)) {\n thisExtent[0] = start;\n }\n\n if (!isNaN(end)) {\n thisExtent[1] = end;\n }\n};\n/**\n * When axis extent depends on data and no data exists,\n * axis ticks should not be drawn, which is named 'blank'.\n */\n\n\nScale.prototype.isBlank = function () {\n return this._isBlank;\n},\n/**\n * When axis extent depends on data and no data exists,\n * axis ticks should not be drawn, which is named 'blank'.\n */\nScale.prototype.setBlank = function (isBlank) {\n this._isBlank = isBlank;\n};\n/**\n * @abstract\n * @param {*} tick\n * @return {string} label of the tick.\n */\n\nScale.prototype.getLabel = null;\nclazzUtil.enableClassExtend(Scale);\nclazzUtil.enableClassManagement(Scale, {\n registerWhenExtend: true\n});\nvar _default = Scale;\nmodule.exports = _default;","var zrUtil = require(\"../core/util\");\n\nvar Element = require(\"../Element\");\n\nvar BoundingRect = require(\"../core/BoundingRect\");\n\n/**\n * Group是一个容器,可以插入子节点,Group的变换也会被应用到子节点上\n * @module zrender/graphic/Group\n * @example\n * var Group = require('zrender/container/Group');\n * var Circle = require('zrender/graphic/shape/Circle');\n * var g = new Group();\n * g.position[0] = 100;\n * g.position[1] = 100;\n * g.add(new Circle({\n * style: {\n * x: 100,\n * y: 100,\n * r: 20,\n * }\n * }));\n * zr.add(g);\n */\n\n/**\n * @alias module:zrender/graphic/Group\n * @constructor\n * @extends module:zrender/mixin/Transformable\n * @extends module:zrender/mixin/Eventful\n */\nvar Group = function (opts) {\n opts = opts || {};\n Element.call(this, opts);\n\n for (var key in opts) {\n if (opts.hasOwnProperty(key)) {\n this[key] = opts[key];\n }\n }\n\n this._children = [];\n this.__storage = null;\n this.__dirty = true;\n};\n\nGroup.prototype = {\n constructor: Group,\n isGroup: true,\n\n /**\n * @type {string}\n */\n type: 'group',\n\n /**\n * 所有子孙元素是否响应鼠标事件\n * @name module:/zrender/container/Group#silent\n * @type {boolean}\n * @default false\n */\n silent: false,\n\n /**\n * @return {Array.<module:zrender/Element>}\n */\n children: function () {\n return this._children.slice();\n },\n\n /**\n * 获取指定 index 的儿子节点\n * @param {number} idx\n * @return {module:zrender/Element}\n */\n childAt: function (idx) {\n return this._children[idx];\n },\n\n /**\n * 获取指定名字的儿子节点\n * @param {string} name\n * @return {module:zrender/Element}\n */\n childOfName: function (name) {\n var children = this._children;\n\n for (var i = 0; i < children.length; i++) {\n if (children[i].name === name) {\n return children[i];\n }\n }\n },\n\n /**\n * @return {number}\n */\n childCount: function () {\n return this._children.length;\n },\n\n /**\n * 添加子节点到最后\n * @param {module:zrender/Element} child\n */\n add: function (child) {\n if (child && child !== this && child.parent !== this) {\n this._children.push(child);\n\n this._doAdd(child);\n }\n\n return this;\n },\n\n /**\n * 添加子节点在 nextSibling 之前\n * @param {module:zrender/Element} child\n * @param {module:zrender/Element} nextSibling\n */\n addBefore: function (child, nextSibling) {\n if (child && child !== this && child.parent !== this && nextSibling && nextSibling.parent === this) {\n var children = this._children;\n var idx = children.indexOf(nextSibling);\n\n if (idx >= 0) {\n children.splice(idx, 0, child);\n\n this._doAdd(child);\n }\n }\n\n return this;\n },\n _doAdd: function (child) {\n if (child.parent) {\n child.parent.remove(child);\n }\n\n child.parent = this;\n var storage = this.__storage;\n var zr = this.__zr;\n\n if (storage && storage !== child.__storage) {\n storage.addToStorage(child);\n\n if (child instanceof Group) {\n child.addChildrenToStorage(storage);\n }\n }\n\n zr && zr.refresh();\n },\n\n /**\n * 移除子节点\n * @param {module:zrender/Element} child\n */\n remove: function (child) {\n var zr = this.__zr;\n var storage = this.__storage;\n var children = this._children;\n var idx = zrUtil.indexOf(children, child);\n\n if (idx < 0) {\n return this;\n }\n\n children.splice(idx, 1);\n child.parent = null;\n\n if (storage) {\n storage.delFromStorage(child);\n\n if (child instanceof Group) {\n child.delChildrenFromStorage(storage);\n }\n }\n\n zr && zr.refresh();\n return this;\n },\n\n /**\n * 移除所有子节点\n */\n removeAll: function () {\n var children = this._children;\n var storage = this.__storage;\n var child;\n var i;\n\n for (i = 0; i < children.length; i++) {\n child = children[i];\n\n if (storage) {\n storage.delFromStorage(child);\n\n if (child instanceof Group) {\n child.delChildrenFromStorage(storage);\n }\n }\n\n child.parent = null;\n }\n\n children.length = 0;\n return this;\n },\n\n /**\n * 遍历所有子节点\n * @param {Function} cb\n * @param {} context\n */\n eachChild: function (cb, context) {\n var children = this._children;\n\n for (var i = 0; i < children.length; i++) {\n var child = children[i];\n cb.call(context, child, i);\n }\n\n return this;\n },\n\n /**\n * 深度优先遍历所有子孙节点\n * @param {Function} cb\n * @param {} context\n */\n traverse: function (cb, context) {\n for (var i = 0; i < this._children.length; i++) {\n var child = this._children[i];\n cb.call(context, child);\n\n if (child.type === 'group') {\n child.traverse(cb, context);\n }\n }\n\n return this;\n },\n addChildrenToStorage: function (storage) {\n for (var i = 0; i < this._children.length; i++) {\n var child = this._children[i];\n storage.addToStorage(child);\n\n if (child instanceof Group) {\n child.addChildrenToStorage(storage);\n }\n }\n },\n delChildrenFromStorage: function (storage) {\n for (var i = 0; i < this._children.length; i++) {\n var child = this._children[i];\n storage.delFromStorage(child);\n\n if (child instanceof Group) {\n child.delChildrenFromStorage(storage);\n }\n }\n },\n dirty: function () {\n this.__dirty = true;\n this.__zr && this.__zr.refresh();\n return this;\n },\n\n /**\n * @return {module:zrender/core/BoundingRect}\n */\n getBoundingRect: function (includeChildren) {\n // TODO Caching\n var rect = null;\n var tmpRect = new BoundingRect(0, 0, 0, 0);\n var children = includeChildren || this._children;\n var tmpMat = [];\n\n for (var i = 0; i < children.length; i++) {\n var child = children[i];\n\n if (child.ignore || child.invisible) {\n continue;\n }\n\n var childRect = child.getBoundingRect();\n var transform = child.getLocalTransform(tmpMat); // TODO\n // The boundingRect cacluated by transforming original\n // rect may be bigger than the actual bundingRect when rotation\n // is used. (Consider a circle rotated aginst its center, where\n // the actual boundingRect should be the same as that not be\n // rotated.) But we can not find better approach to calculate\n // actual boundingRect yet, considering performance.\n\n if (transform) {\n tmpRect.copy(childRect);\n tmpRect.applyTransform(transform);\n rect = rect || tmpRect.clone();\n rect.union(tmpRect);\n } else {\n rect = rect || childRect.clone();\n rect.union(childRect);\n }\n }\n\n return rect || tmpRect;\n }\n};\nzrUtil.inherits(Group, Element);\nvar _default = Group;\nmodule.exports = _default;","var vec2 = require(\"./vector\");\n\nvar curve = require(\"./curve\");\n\n/**\n * @author Yi Shen(https://github.com/pissang)\n */\nvar mathMin = Math.min;\nvar mathMax = Math.max;\nvar mathSin = Math.sin;\nvar mathCos = Math.cos;\nvar PI2 = Math.PI * 2;\nvar start = vec2.create();\nvar end = vec2.create();\nvar extremity = vec2.create();\n/**\n * 从顶点数组中计算出最小包围盒,写入`min`和`max`中\n * @module zrender/core/bbox\n * @param {Array<Object>} points 顶点数组\n * @param {number} min\n * @param {number} max\n */\n\nfunction fromPoints(points, min, max) {\n if (points.length === 0) {\n return;\n }\n\n var p = points[0];\n var left = p[0];\n var right = p[0];\n var top = p[1];\n var bottom = p[1];\n var i;\n\n for (i = 1; i < points.length; i++) {\n p = points[i];\n left = mathMin(left, p[0]);\n right = mathMax(right, p[0]);\n top = mathMin(top, p[1]);\n bottom = mathMax(bottom, p[1]);\n }\n\n min[0] = left;\n min[1] = top;\n max[0] = right;\n max[1] = bottom;\n}\n/**\n * @memberOf module:zrender/core/bbox\n * @param {number} x0\n * @param {number} y0\n * @param {number} x1\n * @param {number} y1\n * @param {Array.<number>} min\n * @param {Array.<number>} max\n */\n\n\nfunction fromLine(x0, y0, x1, y1, min, max) {\n min[0] = mathMin(x0, x1);\n min[1] = mathMin(y0, y1);\n max[0] = mathMax(x0, x1);\n max[1] = mathMax(y0, y1);\n}\n\nvar xDim = [];\nvar yDim = [];\n/**\n * 从三阶贝塞尔曲线(p0, p1, p2, p3)中计算出最小包围盒,写入`min`和`max`中\n * @memberOf module:zrender/core/bbox\n * @param {number} x0\n * @param {number} y0\n * @param {number} x1\n * @param {number} y1\n * @param {number} x2\n * @param {number} y2\n * @param {number} x3\n * @param {number} y3\n * @param {Array.<number>} min\n * @param {Array.<number>} max\n */\n\nfunction fromCubic(x0, y0, x1, y1, x2, y2, x3, y3, min, max) {\n var cubicExtrema = curve.cubicExtrema;\n var cubicAt = curve.cubicAt;\n var i;\n var n = cubicExtrema(x0, x1, x2, x3, xDim);\n min[0] = Infinity;\n min[1] = Infinity;\n max[0] = -Infinity;\n max[1] = -Infinity;\n\n for (i = 0; i < n; i++) {\n var x = cubicAt(x0, x1, x2, x3, xDim[i]);\n min[0] = mathMin(x, min[0]);\n max[0] = mathMax(x, max[0]);\n }\n\n n = cubicExtrema(y0, y1, y2, y3, yDim);\n\n for (i = 0; i < n; i++) {\n var y = cubicAt(y0, y1, y2, y3, yDim[i]);\n min[1] = mathMin(y, min[1]);\n max[1] = mathMax(y, max[1]);\n }\n\n min[0] = mathMin(x0, min[0]);\n max[0] = mathMax(x0, max[0]);\n min[0] = mathMin(x3, min[0]);\n max[0] = mathMax(x3, max[0]);\n min[1] = mathMin(y0, min[1]);\n max[1] = mathMax(y0, max[1]);\n min[1] = mathMin(y3, min[1]);\n max[1] = mathMax(y3, max[1]);\n}\n/**\n * 从二阶贝塞尔曲线(p0, p1, p2)中计算出最小包围盒,写入`min`和`max`中\n * @memberOf module:zrender/core/bbox\n * @param {number} x0\n * @param {number} y0\n * @param {number} x1\n * @param {number} y1\n * @param {number} x2\n * @param {number} y2\n * @param {Array.<number>} min\n * @param {Array.<number>} max\n */\n\n\nfunction fromQuadratic(x0, y0, x1, y1, x2, y2, min, max) {\n var quadraticExtremum = curve.quadraticExtremum;\n var quadraticAt = curve.quadraticAt; // Find extremities, where derivative in x dim or y dim is zero\n\n var tx = mathMax(mathMin(quadraticExtremum(x0, x1, x2), 1), 0);\n var ty = mathMax(mathMin(quadraticExtremum(y0, y1, y2), 1), 0);\n var x = quadraticAt(x0, x1, x2, tx);\n var y = quadraticAt(y0, y1, y2, ty);\n min[0] = mathMin(x0, x2, x);\n min[1] = mathMin(y0, y2, y);\n max[0] = mathMax(x0, x2, x);\n max[1] = mathMax(y0, y2, y);\n}\n/**\n * 从圆弧中计算出最小包围盒,写入`min`和`max`中\n * @method\n * @memberOf module:zrender/core/bbox\n * @param {number} x\n * @param {number} y\n * @param {number} rx\n * @param {number} ry\n * @param {number} startAngle\n * @param {number} endAngle\n * @param {number} anticlockwise\n * @param {Array.<number>} min\n * @param {Array.<number>} max\n */\n\n\nfunction fromArc(x, y, rx, ry, startAngle, endAngle, anticlockwise, min, max) {\n var vec2Min = vec2.min;\n var vec2Max = vec2.max;\n var diff = Math.abs(startAngle - endAngle);\n\n if (diff % PI2 < 1e-4 && diff > 1e-4) {\n // Is a circle\n min[0] = x - rx;\n min[1] = y - ry;\n max[0] = x + rx;\n max[1] = y + ry;\n return;\n }\n\n start[0] = mathCos(startAngle) * rx + x;\n start[1] = mathSin(startAngle) * ry + y;\n end[0] = mathCos(endAngle) * rx + x;\n end[1] = mathSin(endAngle) * ry + y;\n vec2Min(min, start, end);\n vec2Max(max, start, end); // Thresh to [0, Math.PI * 2]\n\n startAngle = startAngle % PI2;\n\n if (startAngle < 0) {\n startAngle = startAngle + PI2;\n }\n\n endAngle = endAngle % PI2;\n\n if (endAngle < 0) {\n endAngle = endAngle + PI2;\n }\n\n if (startAngle > endAngle && !anticlockwise) {\n endAngle += PI2;\n } else if (startAngle < endAngle && anticlockwise) {\n startAngle += PI2;\n }\n\n if (anticlockwise) {\n var tmp = endAngle;\n endAngle = startAngle;\n startAngle = tmp;\n } // var number = 0;\n // var step = (anticlockwise ? -Math.PI : Math.PI) / 2;\n\n\n for (var angle = 0; angle < endAngle; angle += Math.PI / 2) {\n if (angle > startAngle) {\n extremity[0] = mathCos(angle) * rx + x;\n extremity[1] = mathSin(angle) * ry + y;\n vec2Min(min, extremity, min);\n vec2Max(max, extremity, max);\n }\n }\n}\n\nexports.fromPoints = fromPoints;\nexports.fromLine = fromLine;\nexports.fromCubic = fromCubic;\nexports.fromQuadratic = fromQuadratic;\nexports.fromArc = fromArc;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _model = require(\"../../util/model\");\n\nvar makeInner = _model.makeInner;\nvar normalizeToArray = _model.normalizeToArray;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar inner = makeInner();\n\nfunction getNearestColorPalette(colors, requestColorNum) {\n var paletteNum = colors.length; // TODO colors must be in order\n\n for (var i = 0; i < paletteNum; i++) {\n if (colors[i].length > requestColorNum) {\n return colors[i];\n }\n }\n\n return colors[paletteNum - 1];\n}\n\nvar _default = {\n clearColorPalette: function () {\n inner(this).colorIdx = 0;\n inner(this).colorNameMap = {};\n },\n\n /**\n * @param {string} name MUST NOT be null/undefined. Otherwise call this function\n * twise with the same parameters will get different result.\n * @param {Object} [scope=this]\n * @param {Object} [requestColorNum]\n * @return {string} color string.\n */\n getColorFromPalette: function (name, scope, requestColorNum) {\n scope = scope || this;\n var scopeFields = inner(scope);\n var colorIdx = scopeFields.colorIdx || 0;\n var colorNameMap = scopeFields.colorNameMap = scopeFields.colorNameMap || {}; // Use `hasOwnProperty` to avoid conflict with Object.prototype.\n\n if (colorNameMap.hasOwnProperty(name)) {\n return colorNameMap[name];\n }\n\n var defaultColorPalette = normalizeToArray(this.get('color', true));\n var layeredColorPalette = this.get('colorLayer', true);\n var colorPalette = requestColorNum == null || !layeredColorPalette ? defaultColorPalette : getNearestColorPalette(layeredColorPalette, requestColorNum); // In case can't find in layered color palette.\n\n colorPalette = colorPalette || defaultColorPalette;\n\n if (!colorPalette || !colorPalette.length) {\n return;\n }\n\n var color = colorPalette[colorIdx];\n\n if (name) {\n colorNameMap[name] = color;\n }\n\n scopeFields.colorIdx = (colorIdx + 1) % colorPalette.length;\n return color;\n }\n};\nmodule.exports = _default;","var curve = require(\"../core/curve\");\n\n/**\n * 三次贝塞尔曲线描边包含判断\n * @param {number} x0\n * @param {number} y0\n * @param {number} x1\n * @param {number} y1\n * @param {number} x2\n * @param {number} y2\n * @param {number} x3\n * @param {number} y3\n * @param {number} lineWidth\n * @param {number} x\n * @param {number} y\n * @return {boolean}\n */\nfunction containStroke(x0, y0, x1, y1, x2, y2, x3, y3, lineWidth, x, y) {\n if (lineWidth === 0) {\n return false;\n }\n\n var _l = lineWidth; // Quick reject\n\n if (y > y0 + _l && y > y1 + _l && y > y2 + _l && y > y3 + _l || y < y0 - _l && y < y1 - _l && y < y2 - _l && y < y3 - _l || x > x0 + _l && x > x1 + _l && x > x2 + _l && x > x3 + _l || x < x0 - _l && x < x1 - _l && x < x2 - _l && x < x3 - _l) {\n return false;\n }\n\n var d = curve.cubicProjectPoint(x0, y0, x1, y1, x2, y2, x3, y3, x, y, null);\n return d <= _l / 2;\n}\n\nexports.containStroke = containStroke;","var isObject = require('./_is-object');\nvar isArray = require('./_is-array');\nvar SPECIES = require('./_wks')('species');\n\nmodule.exports = function (original) {\n var C;\n if (isArray(original)) {\n C = original.constructor;\n // cross-realm fallback\n if (typeof C == 'function' && (C === Array || isArray(C.prototype))) C = undefined;\n if (isObject(C)) {\n C = C[SPECIES];\n if (C === null) C = undefined;\n }\n } return C === undefined ? Array : C;\n};\n","var BoundingRect = require(\"../core/BoundingRect\");\n\nvar imageHelper = require(\"../graphic/helper/image\");\n\nvar _util = require(\"../core/util\");\n\nvar getContext = _util.getContext;\nvar extend = _util.extend;\nvar retrieve2 = _util.retrieve2;\nvar retrieve3 = _util.retrieve3;\nvar trim = _util.trim;\nvar textWidthCache = {};\nvar textWidthCacheCounter = 0;\nvar TEXT_CACHE_MAX = 5000;\nvar STYLE_REG = /\\{([a-zA-Z0-9_]+)\\|([^}]*)\\}/g;\nvar DEFAULT_FONT = '12px sans-serif'; // Avoid assign to an exported variable, for transforming to cjs.\n\nvar methods = {};\n\nfunction $override(name, fn) {\n methods[name] = fn;\n}\n/**\n * @public\n * @param {string} text\n * @param {string} font\n * @return {number} width\n */\n\n\nfunction getWidth(text, font) {\n font = font || DEFAULT_FONT;\n var key = text + ':' + font;\n\n if (textWidthCache[key]) {\n return textWidthCache[key];\n }\n\n var textLines = (text + '').split('\\n');\n var width = 0;\n\n for (var i = 0, l = textLines.length; i < l; i++) {\n // textContain.measureText may be overrided in SVG or VML\n width = Math.max(measureText(textLines[i], font).width, width);\n }\n\n if (textWidthCacheCounter > TEXT_CACHE_MAX) {\n textWidthCacheCounter = 0;\n textWidthCache = {};\n }\n\n textWidthCacheCounter++;\n textWidthCache[key] = width;\n return width;\n}\n/**\n * @public\n * @param {string} text\n * @param {string} font\n * @param {string} [textAlign='left']\n * @param {string} [textVerticalAlign='top']\n * @param {Array.<number>} [textPadding]\n * @param {Object} [rich]\n * @param {Object} [truncate]\n * @return {Object} {x, y, width, height, lineHeight}\n */\n\n\nfunction getBoundingRect(text, font, textAlign, textVerticalAlign, textPadding, textLineHeight, rich, truncate) {\n return rich ? getRichTextRect(text, font, textAlign, textVerticalAlign, textPadding, textLineHeight, rich, truncate) : getPlainTextRect(text, font, textAlign, textVerticalAlign, textPadding, textLineHeight, truncate);\n}\n\nfunction getPlainTextRect(text, font, textAlign, textVerticalAlign, textPadding, textLineHeight, truncate) {\n var contentBlock = parsePlainText(text, font, textPadding, textLineHeight, truncate);\n var outerWidth = getWidth(text, font);\n\n if (textPadding) {\n outerWidth += textPadding[1] + textPadding[3];\n }\n\n var outerHeight = contentBlock.outerHeight;\n var x = adjustTextX(0, outerWidth, textAlign);\n var y = adjustTextY(0, outerHeight, textVerticalAlign);\n var rect = new BoundingRect(x, y, outerWidth, outerHeight);\n rect.lineHeight = contentBlock.lineHeight;\n return rect;\n}\n\nfunction getRichTextRect(text, font, textAlign, textVerticalAlign, textPadding, textLineHeight, rich, truncate) {\n var contentBlock = parseRichText(text, {\n rich: rich,\n truncate: truncate,\n font: font,\n textAlign: textAlign,\n textPadding: textPadding,\n textLineHeight: textLineHeight\n });\n var outerWidth = contentBlock.outerWidth;\n var outerHeight = contentBlock.outerHeight;\n var x = adjustTextX(0, outerWidth, textAlign);\n var y = adjustTextY(0, outerHeight, textVerticalAlign);\n return new BoundingRect(x, y, outerWidth, outerHeight);\n}\n/**\n * @public\n * @param {number} x\n * @param {number} width\n * @param {string} [textAlign='left']\n * @return {number} Adjusted x.\n */\n\n\nfunction adjustTextX(x, width, textAlign) {\n // FIXME Right to left language\n if (textAlign === 'right') {\n x -= width;\n } else if (textAlign === 'center') {\n x -= width / 2;\n }\n\n return x;\n}\n/**\n * @public\n * @param {number} y\n * @param {number} height\n * @param {string} [textVerticalAlign='top']\n * @return {number} Adjusted y.\n */\n\n\nfunction adjustTextY(y, height, textVerticalAlign) {\n if (textVerticalAlign === 'middle') {\n y -= height / 2;\n } else if (textVerticalAlign === 'bottom') {\n y -= height;\n }\n\n return y;\n}\n/**\n * @public\n * @param {stirng} textPosition\n * @param {Object} rect {x, y, width, height}\n * @param {number} distance\n * @return {Object} {x, y, textAlign, textVerticalAlign}\n */\n\n\nfunction adjustTextPositionOnRect(textPosition, rect, distance) {\n var x = rect.x;\n var y = rect.y;\n var height = rect.height;\n var width = rect.width;\n var halfHeight = height / 2;\n var textAlign = 'left';\n var textVerticalAlign = 'top';\n\n switch (textPosition) {\n case 'left':\n x -= distance;\n y += halfHeight;\n textAlign = 'right';\n textVerticalAlign = 'middle';\n break;\n\n case 'right':\n x += distance + width;\n y += halfHeight;\n textVerticalAlign = 'middle';\n break;\n\n case 'top':\n x += width / 2;\n y -= distance;\n textAlign = 'center';\n textVerticalAlign = 'bottom';\n break;\n\n case 'bottom':\n x += width / 2;\n y += height + distance;\n textAlign = 'center';\n break;\n\n case 'inside':\n x += width / 2;\n y += halfHeight;\n textAlign = 'center';\n textVerticalAlign = 'middle';\n break;\n\n case 'insideLeft':\n x += distance;\n y += halfHeight;\n textVerticalAlign = 'middle';\n break;\n\n case 'insideRight':\n x += width - distance;\n y += halfHeight;\n textAlign = 'right';\n textVerticalAlign = 'middle';\n break;\n\n case 'insideTop':\n x += width / 2;\n y += distance;\n textAlign = 'center';\n break;\n\n case 'insideBottom':\n x += width / 2;\n y += height - distance;\n textAlign = 'center';\n textVerticalAlign = 'bottom';\n break;\n\n case 'insideTopLeft':\n x += distance;\n y += distance;\n break;\n\n case 'insideTopRight':\n x += width - distance;\n y += distance;\n textAlign = 'right';\n break;\n\n case 'insideBottomLeft':\n x += distance;\n y += height - distance;\n textVerticalAlign = 'bottom';\n break;\n\n case 'insideBottomRight':\n x += width - distance;\n y += height - distance;\n textAlign = 'right';\n textVerticalAlign = 'bottom';\n break;\n }\n\n return {\n x: x,\n y: y,\n textAlign: textAlign,\n textVerticalAlign: textVerticalAlign\n };\n}\n/**\n * Show ellipsis if overflow.\n *\n * @public\n * @param {string} text\n * @param {string} containerWidth\n * @param {string} font\n * @param {number} [ellipsis='...']\n * @param {Object} [options]\n * @param {number} [options.maxIterations=3]\n * @param {number} [options.minChar=0] If truncate result are less\n * then minChar, ellipsis will not show, which is\n * better for user hint in some cases.\n * @param {number} [options.placeholder=''] When all truncated, use the placeholder.\n * @return {string}\n */\n\n\nfunction truncateText(text, containerWidth, font, ellipsis, options) {\n if (!containerWidth) {\n return '';\n }\n\n var textLines = (text + '').split('\\n');\n options = prepareTruncateOptions(containerWidth, font, ellipsis, options); // FIXME\n // It is not appropriate that every line has '...' when truncate multiple lines.\n\n for (var i = 0, len = textLines.length; i < len; i++) {\n textLines[i] = truncateSingleLine(textLines[i], options);\n }\n\n return textLines.join('\\n');\n}\n\nfunction prepareTruncateOptions(containerWidth, font, ellipsis, options) {\n options = extend({}, options);\n options.font = font;\n var ellipsis = retrieve2(ellipsis, '...');\n options.maxIterations = retrieve2(options.maxIterations, 2);\n var minChar = options.minChar = retrieve2(options.minChar, 0); // FIXME\n // Other languages?\n\n options.cnCharWidth = getWidth('国', font); // FIXME\n // Consider proportional font?\n\n var ascCharWidth = options.ascCharWidth = getWidth('a', font);\n options.placeholder = retrieve2(options.placeholder, ''); // Example 1: minChar: 3, text: 'asdfzxcv', truncate result: 'asdf', but not: 'a...'.\n // Example 2: minChar: 3, text: '维度', truncate result: '维', but not: '...'.\n\n var contentWidth = containerWidth = Math.max(0, containerWidth - 1); // Reserve some gap.\n\n for (var i = 0; i < minChar && contentWidth >= ascCharWidth; i++) {\n contentWidth -= ascCharWidth;\n }\n\n var ellipsisWidth = getWidth(ellipsis, font);\n\n if (ellipsisWidth > contentWidth) {\n ellipsis = '';\n ellipsisWidth = 0;\n }\n\n contentWidth = containerWidth - ellipsisWidth;\n options.ellipsis = ellipsis;\n options.ellipsisWidth = ellipsisWidth;\n options.contentWidth = contentWidth;\n options.containerWidth = containerWidth;\n return options;\n}\n\nfunction truncateSingleLine(textLine, options) {\n var containerWidth = options.containerWidth;\n var font = options.font;\n var contentWidth = options.contentWidth;\n\n if (!containerWidth) {\n return '';\n }\n\n var lineWidth = getWidth(textLine, font);\n\n if (lineWidth <= containerWidth) {\n return textLine;\n }\n\n for (var j = 0;; j++) {\n if (lineWidth <= contentWidth || j >= options.maxIterations) {\n textLine += options.ellipsis;\n break;\n }\n\n var subLength = j === 0 ? estimateLength(textLine, contentWidth, options.ascCharWidth, options.cnCharWidth) : lineWidth > 0 ? Math.floor(textLine.length * contentWidth / lineWidth) : 0;\n textLine = textLine.substr(0, subLength);\n lineWidth = getWidth(textLine, font);\n }\n\n if (textLine === '') {\n textLine = options.placeholder;\n }\n\n return textLine;\n}\n\nfunction estimateLength(text, contentWidth, ascCharWidth, cnCharWidth) {\n var width = 0;\n var i = 0;\n\n for (var len = text.length; i < len && width < contentWidth; i++) {\n var charCode = text.charCodeAt(i);\n width += 0 <= charCode && charCode <= 127 ? ascCharWidth : cnCharWidth;\n }\n\n return i;\n}\n/**\n * @public\n * @param {string} font\n * @return {number} line height\n */\n\n\nfunction getLineHeight(font) {\n // FIXME A rough approach.\n return getWidth('国', font);\n}\n/**\n * @public\n * @param {string} text\n * @param {string} font\n * @return {Object} width\n */\n\n\nfunction measureText(text, font) {\n return methods.measureText(text, font);\n} // Avoid assign to an exported variable, for transforming to cjs.\n\n\nmethods.measureText = function (text, font) {\n var ctx = getContext();\n ctx.font = font || DEFAULT_FONT;\n return ctx.measureText(text);\n};\n/**\n * @public\n * @param {string} text\n * @param {string} font\n * @param {Object} [truncate]\n * @return {Object} block: {lineHeight, lines, height, outerHeight}\n * Notice: for performance, do not calculate outerWidth util needed.\n */\n\n\nfunction parsePlainText(text, font, padding, textLineHeight, truncate) {\n text != null && (text += '');\n var lineHeight = retrieve2(textLineHeight, getLineHeight(font));\n var lines = text ? text.split('\\n') : [];\n var height = lines.length * lineHeight;\n var outerHeight = height;\n\n if (padding) {\n outerHeight += padding[0] + padding[2];\n }\n\n if (text && truncate) {\n var truncOuterHeight = truncate.outerHeight;\n var truncOuterWidth = truncate.outerWidth;\n\n if (truncOuterHeight != null && outerHeight > truncOuterHeight) {\n text = '';\n lines = [];\n } else if (truncOuterWidth != null) {\n var options = prepareTruncateOptions(truncOuterWidth - (padding ? padding[1] + padding[3] : 0), font, truncate.ellipsis, {\n minChar: truncate.minChar,\n placeholder: truncate.placeholder\n }); // FIXME\n // It is not appropriate that every line has '...' when truncate multiple lines.\n\n for (var i = 0, len = lines.length; i < len; i++) {\n lines[i] = truncateSingleLine(lines[i], options);\n }\n }\n }\n\n return {\n lines: lines,\n height: height,\n outerHeight: outerHeight,\n lineHeight: lineHeight\n };\n}\n/**\n * For example: 'some text {a|some text}other text{b|some text}xxx{c|}xxx'\n * Also consider 'bbbb{a|xxx\\nzzz}xxxx\\naaaa'.\n *\n * @public\n * @param {string} text\n * @param {Object} style\n * @return {Object} block\n * {\n * width,\n * height,\n * lines: [{\n * lineHeight,\n * width,\n * tokens: [[{\n * styleName,\n * text,\n * width, // include textPadding\n * height, // include textPadding\n * textWidth, // pure text width\n * textHeight, // pure text height\n * lineHeihgt,\n * font,\n * textAlign,\n * textVerticalAlign\n * }], [...], ...]\n * }, ...]\n * }\n * If styleName is undefined, it is plain text.\n */\n\n\nfunction parseRichText(text, style) {\n var contentBlock = {\n lines: [],\n width: 0,\n height: 0\n };\n text != null && (text += '');\n\n if (!text) {\n return contentBlock;\n }\n\n var lastIndex = STYLE_REG.lastIndex = 0;\n var result;\n\n while ((result = STYLE_REG.exec(text)) != null) {\n var matchedIndex = result.index;\n\n if (matchedIndex > lastIndex) {\n pushTokens(contentBlock, text.substring(lastIndex, matchedIndex));\n }\n\n pushTokens(contentBlock, result[2], result[1]);\n lastIndex = STYLE_REG.lastIndex;\n }\n\n if (lastIndex < text.length) {\n pushTokens(contentBlock, text.substring(lastIndex, text.length));\n }\n\n var lines = contentBlock.lines;\n var contentHeight = 0;\n var contentWidth = 0; // For `textWidth: 100%`\n\n var pendingList = [];\n var stlPadding = style.textPadding;\n var truncate = style.truncate;\n var truncateWidth = truncate && truncate.outerWidth;\n var truncateHeight = truncate && truncate.outerHeight;\n\n if (stlPadding) {\n truncateWidth != null && (truncateWidth -= stlPadding[1] + stlPadding[3]);\n truncateHeight != null && (truncateHeight -= stlPadding[0] + stlPadding[2]);\n } // Calculate layout info of tokens.\n\n\n for (var i = 0; i < lines.length; i++) {\n var line = lines[i];\n var lineHeight = 0;\n var lineWidth = 0;\n\n for (var j = 0; j < line.tokens.length; j++) {\n var token = line.tokens[j];\n var tokenStyle = token.styleName && style.rich[token.styleName] || {}; // textPadding should not inherit from style.\n\n var textPadding = token.textPadding = tokenStyle.textPadding; // textFont has been asigned to font by `normalizeStyle`.\n\n var font = token.font = tokenStyle.font || style.font; // textHeight can be used when textVerticalAlign is specified in token.\n\n var tokenHeight = token.textHeight = retrieve2( // textHeight should not be inherited, consider it can be specified\n // as box height of the block.\n tokenStyle.textHeight, getLineHeight(font));\n textPadding && (tokenHeight += textPadding[0] + textPadding[2]);\n token.height = tokenHeight;\n token.lineHeight = retrieve3(tokenStyle.textLineHeight, style.textLineHeight, tokenHeight);\n token.textAlign = tokenStyle && tokenStyle.textAlign || style.textAlign;\n token.textVerticalAlign = tokenStyle && tokenStyle.textVerticalAlign || 'middle';\n\n if (truncateHeight != null && contentHeight + token.lineHeight > truncateHeight) {\n return {\n lines: [],\n width: 0,\n height: 0\n };\n }\n\n token.textWidth = getWidth(token.text, font);\n var tokenWidth = tokenStyle.textWidth;\n var tokenWidthNotSpecified = tokenWidth == null || tokenWidth === 'auto'; // Percent width, can be `100%`, can be used in drawing separate\n // line when box width is needed to be auto.\n\n if (typeof tokenWidth === 'string' && tokenWidth.charAt(tokenWidth.length - 1) === '%') {\n token.percentWidth = tokenWidth;\n pendingList.push(token);\n tokenWidth = 0; // Do not truncate in this case, because there is no user case\n // and it is too complicated.\n } else {\n if (tokenWidthNotSpecified) {\n tokenWidth = token.textWidth; // FIXME: If image is not loaded and textWidth is not specified, calling\n // `getBoundingRect()` will not get correct result.\n\n var textBackgroundColor = tokenStyle.textBackgroundColor;\n var bgImg = textBackgroundColor && textBackgroundColor.image; // Use cases:\n // (1) If image is not loaded, it will be loaded at render phase and call\n // `dirty()` and `textBackgroundColor.image` will be replaced with the loaded\n // image, and then the right size will be calculated here at the next tick.\n // See `graphic/helper/text.js`.\n // (2) If image loaded, and `textBackgroundColor.image` is image src string,\n // use `imageHelper.findExistImage` to find cached image.\n // `imageHelper.findExistImage` will always be called here before\n // `imageHelper.createOrUpdateImage` in `graphic/helper/text.js#renderRichText`\n // which ensures that image will not be rendered before correct size calcualted.\n\n if (bgImg) {\n bgImg = imageHelper.findExistImage(bgImg);\n\n if (imageHelper.isImageReady(bgImg)) {\n tokenWidth = Math.max(tokenWidth, bgImg.width * tokenHeight / bgImg.height);\n }\n }\n }\n\n var paddingW = textPadding ? textPadding[1] + textPadding[3] : 0;\n tokenWidth += paddingW;\n var remianTruncWidth = truncateWidth != null ? truncateWidth - lineWidth : null;\n\n if (remianTruncWidth != null && remianTruncWidth < tokenWidth) {\n if (!tokenWidthNotSpecified || remianTruncWidth < paddingW) {\n token.text = '';\n token.textWidth = tokenWidth = 0;\n } else {\n token.text = truncateText(token.text, remianTruncWidth - paddingW, font, truncate.ellipsis, {\n minChar: truncate.minChar\n });\n token.textWidth = getWidth(token.text, font);\n tokenWidth = token.textWidth + paddingW;\n }\n }\n }\n\n lineWidth += token.width = tokenWidth;\n tokenStyle && (lineHeight = Math.max(lineHeight, token.lineHeight));\n }\n\n line.width = lineWidth;\n line.lineHeight = lineHeight;\n contentHeight += lineHeight;\n contentWidth = Math.max(contentWidth, lineWidth);\n }\n\n contentBlock.outerWidth = contentBlock.width = retrieve2(style.textWidth, contentWidth);\n contentBlock.outerHeight = contentBlock.height = retrieve2(style.textHeight, contentHeight);\n\n if (stlPadding) {\n contentBlock.outerWidth += stlPadding[1] + stlPadding[3];\n contentBlock.outerHeight += stlPadding[0] + stlPadding[2];\n }\n\n for (var i = 0; i < pendingList.length; i++) {\n var token = pendingList[i];\n var percentWidth = token.percentWidth; // Should not base on outerWidth, because token can not be placed out of padding.\n\n token.width = parseInt(percentWidth, 10) / 100 * contentWidth;\n }\n\n return contentBlock;\n}\n\nfunction pushTokens(block, str, styleName) {\n var isEmptyStr = str === '';\n var strs = str.split('\\n');\n var lines = block.lines;\n\n for (var i = 0; i < strs.length; i++) {\n var text = strs[i];\n var token = {\n styleName: styleName,\n text: text,\n isLineHolder: !text && !isEmptyStr\n }; // The first token should be appended to the last line.\n\n if (!i) {\n var tokens = (lines[lines.length - 1] || (lines[0] = {\n tokens: []\n })).tokens; // Consider cases:\n // (1) ''.split('\\n') => ['', '\\n', ''], the '' at the first item\n // (which is a placeholder) should be replaced by new token.\n // (2) A image backage, where token likes {a|}.\n // (3) A redundant '' will affect textAlign in line.\n // (4) tokens with the same tplName should not be merged, because\n // they should be displayed in different box (with border and padding).\n\n var tokensLen = tokens.length;\n tokensLen === 1 && tokens[0].isLineHolder ? tokens[0] = token : // Consider text is '', only insert when it is the \"lineHolder\" or\n // \"emptyStr\". Otherwise a redundant '' will affect textAlign in line.\n (text || !tokensLen || isEmptyStr) && tokens.push(token);\n } // Other tokens always start a new line.\n else {\n // If there is '', insert it as a placeholder.\n lines.push({\n tokens: [token]\n });\n }\n }\n}\n\nfunction makeFont(style) {\n // FIXME in node-canvas fontWeight is before fontStyle\n // Use `fontSize` `fontFamily` to check whether font properties are defined.\n var font = (style.fontSize || style.fontFamily) && [style.fontStyle, style.fontWeight, (style.fontSize || 12) + 'px', // If font properties are defined, `fontFamily` should not be ignored.\n style.fontFamily || 'sans-serif'].join(' ');\n return font && trim(font) || style.textFont || style.font;\n}\n\nexports.DEFAULT_FONT = DEFAULT_FONT;\nexports.$override = $override;\nexports.getWidth = getWidth;\nexports.getBoundingRect = getBoundingRect;\nexports.adjustTextX = adjustTextX;\nexports.adjustTextY = adjustTextY;\nexports.adjustTextPositionOnRect = adjustTextPositionOnRect;\nexports.truncateText = truncateText;\nexports.getLineHeight = getLineHeight;\nexports.measureText = measureText;\nexports.parsePlainText = parsePlainText;\nexports.parseRichText = parseRichText;\nexports.makeFont = makeFont;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar each = _util.each;\n\nvar Group = require(\"zrender/lib/container/Group\");\n\nvar componentUtil = require(\"../util/component\");\n\nvar clazzUtil = require(\"../util/clazz\");\n\nvar modelUtil = require(\"../util/model\");\n\nvar _task = require(\"../stream/task\");\n\nvar createTask = _task.createTask;\n\nvar createRenderPlanner = require(\"../chart/helper/createRenderPlanner\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar inner = modelUtil.makeInner();\nvar renderPlanner = createRenderPlanner();\n\nfunction Chart() {\n /**\n * @type {module:zrender/container/Group}\n * @readOnly\n */\n this.group = new Group();\n /**\n * @type {string}\n * @readOnly\n */\n\n this.uid = componentUtil.getUID('viewChart');\n this.renderTask = createTask({\n plan: renderTaskPlan,\n reset: renderTaskReset\n });\n this.renderTask.context = {\n view: this\n };\n}\n\nChart.prototype = {\n type: 'chart',\n\n /**\n * Init the chart.\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n */\n init: function (ecModel, api) {},\n\n /**\n * Render the chart.\n * @param {module:echarts/model/Series} seriesModel\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n * @param {Object} payload\n */\n render: function (seriesModel, ecModel, api, payload) {},\n\n /**\n * Highlight series or specified data item.\n * @param {module:echarts/model/Series} seriesModel\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n * @param {Object} payload\n */\n highlight: function (seriesModel, ecModel, api, payload) {\n toggleHighlight(seriesModel.getData(), payload, 'emphasis');\n },\n\n /**\n * Downplay series or specified data item.\n * @param {module:echarts/model/Series} seriesModel\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n * @param {Object} payload\n */\n downplay: function (seriesModel, ecModel, api, payload) {\n toggleHighlight(seriesModel.getData(), payload, 'normal');\n },\n\n /**\n * Remove self.\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n */\n remove: function (ecModel, api) {\n this.group.removeAll();\n },\n\n /**\n * Dispose self.\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n */\n dispose: function () {},\n\n /**\n * Rendering preparation in progressive mode.\n * @param {module:echarts/model/Series} seriesModel\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n * @param {Object} payload\n */\n incrementalPrepareRender: null,\n\n /**\n * Render in progressive mode.\n * @param {Object} params See taskParams in `stream/task.js`\n * @param {module:echarts/model/Series} seriesModel\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n * @param {Object} payload\n */\n incrementalRender: null,\n\n /**\n * Update transform directly.\n * @param {module:echarts/model/Series} seriesModel\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n * @param {Object} payload\n * @return {Object} {update: true}\n */\n updateTransform: null,\n\n /**\n * The view contains the given point.\n * @interface\n * @param {Array.<number>} point\n * @return {boolean}\n */\n // containPoint: function () {}\n\n /**\n * @param {string} eventType\n * @param {Object} query\n * @param {module:zrender/Element} targetEl\n * @param {Object} packedEvent\n * @return {boolen} Pass only when return `true`.\n */\n filterForExposedEvent: null\n};\nvar chartProto = Chart.prototype;\n\nchartProto.updateView = chartProto.updateLayout = chartProto.updateVisual = function (seriesModel, ecModel, api, payload) {\n this.render(seriesModel, ecModel, api, payload);\n};\n/**\n * Set state of single element\n * @param {module:zrender/Element} el\n * @param {string} state\n */\n\n\nfunction elSetState(el, state) {\n if (el) {\n el.trigger(state);\n\n if (el.type === 'group') {\n for (var i = 0; i < el.childCount(); i++) {\n elSetState(el.childAt(i), state);\n }\n }\n }\n}\n/**\n * @param {module:echarts/data/List} data\n * @param {Object} payload\n * @param {string} state 'normal'|'emphasis'\n */\n\n\nfunction toggleHighlight(data, payload, state) {\n var dataIndex = modelUtil.queryDataIndex(data, payload);\n\n if (dataIndex != null) {\n each(modelUtil.normalizeToArray(dataIndex), function (dataIdx) {\n elSetState(data.getItemGraphicEl(dataIdx), state);\n });\n } else {\n data.eachItemGraphicEl(function (el) {\n elSetState(el, state);\n });\n }\n} // Enable Chart.extend.\n\n\nclazzUtil.enableClassExtend(Chart, ['dispose']); // Add capability of registerClass, getClass, hasClass, registerSubTypeDefaulter and so on.\n\nclazzUtil.enableClassManagement(Chart, {\n registerWhenExtend: true\n});\n\nChart.markUpdateMethod = function (payload, methodName) {\n inner(payload).updateMethod = methodName;\n};\n\nfunction renderTaskPlan(context) {\n return renderPlanner(context.model);\n}\n\nfunction renderTaskReset(context) {\n var seriesModel = context.model;\n var ecModel = context.ecModel;\n var api = context.api;\n var payload = context.payload; // ???! remove updateView updateVisual\n\n var progressiveRender = seriesModel.pipelineContext.progressiveRender;\n var view = context.view;\n var updateMethod = payload && inner(payload).updateMethod;\n var methodName = progressiveRender ? 'incrementalPrepareRender' : updateMethod && view[updateMethod] ? updateMethod // `appendData` is also supported when data amount\n // is less than progressive threshold.\n : 'render';\n\n if (methodName !== 'render') {\n view[methodName](seriesModel, ecModel, api, payload);\n }\n\n return progressMethodMap[methodName];\n}\n\nvar progressMethodMap = {\n incrementalPrepareRender: {\n progress: function (params, context) {\n context.view.incrementalRender(params, context.model, context.ecModel, context.api, context.payload);\n }\n },\n render: {\n // Put view.render in `progress` to support appendData. But in this case\n // view.render should not be called in reset, otherwise it will be called\n // twise. Use `forceFirstProgress` to make sure that view.render is called\n // in any cases.\n forceFirstProgress: true,\n progress: function (params, context) {\n context.view.render(context.model, context.ecModel, context.api, context.payload);\n }\n }\n};\nvar _default = Chart;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar _model = require(\"../../util/model\");\n\nvar makeInner = _model.makeInner;\n\nvar modelHelper = require(\"./modelHelper\");\n\nvar findPointFromSeries = require(\"./findPointFromSeries\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar each = zrUtil.each;\nvar curry = zrUtil.curry;\nvar inner = makeInner();\n/**\n * Basic logic: check all axis, if they do not demand show/highlight,\n * then hide/downplay them.\n *\n * @param {Object} coordSysAxesInfo\n * @param {Object} payload\n * @param {string} [payload.currTrigger] 'click' | 'mousemove' | 'leave'\n * @param {Array.<number>} [payload.x] x and y, which are mandatory, specify a point to\n * trigger axisPointer and tooltip.\n * @param {Array.<number>} [payload.y] x and y, which are mandatory, specify a point to\n * trigger axisPointer and tooltip.\n * @param {Object} [payload.seriesIndex] finder, optional, restrict target axes.\n * @param {Object} [payload.dataIndex] finder, restrict target axes.\n * @param {Object} [payload.axesInfo] finder, restrict target axes.\n * [{\n * axisDim: 'x'|'y'|'angle'|...,\n * axisIndex: ...,\n * value: ...\n * }, ...]\n * @param {Function} [payload.dispatchAction]\n * @param {Object} [payload.tooltipOption]\n * @param {Object|Array.<number>|Function} [payload.position] Tooltip position,\n * which can be specified in dispatchAction\n * @param {module:echarts/model/Global} ecModel\n * @param {module:echarts/ExtensionAPI} api\n * @return {Object} content of event obj for echarts.connect.\n */\n\nfunction _default(payload, ecModel, api) {\n var currTrigger = payload.currTrigger;\n var point = [payload.x, payload.y];\n var finder = payload;\n var dispatchAction = payload.dispatchAction || zrUtil.bind(api.dispatchAction, api);\n var coordSysAxesInfo = ecModel.getComponent('axisPointer').coordSysAxesInfo; // Pending\n // See #6121. But we are not able to reproduce it yet.\n\n if (!coordSysAxesInfo) {\n return;\n }\n\n if (illegalPoint(point)) {\n // Used in the default behavior of `connection`: use the sample seriesIndex\n // and dataIndex. And also used in the tooltipView trigger.\n point = findPointFromSeries({\n seriesIndex: finder.seriesIndex,\n // Do not use dataIndexInside from other ec instance.\n // FIXME: auto detect it?\n dataIndex: finder.dataIndex\n }, ecModel).point;\n }\n\n var isIllegalPoint = illegalPoint(point); // Axis and value can be specified when calling dispatchAction({type: 'updateAxisPointer'}).\n // Notice: In this case, it is difficult to get the `point` (which is necessary to show\n // tooltip, so if point is not given, we just use the point found by sample seriesIndex\n // and dataIndex.\n\n var inputAxesInfo = finder.axesInfo;\n var axesInfo = coordSysAxesInfo.axesInfo;\n var shouldHide = currTrigger === 'leave' || illegalPoint(point);\n var outputFinder = {};\n var showValueMap = {};\n var dataByCoordSys = {\n list: [],\n map: {}\n };\n var updaters = {\n showPointer: curry(showPointer, showValueMap),\n showTooltip: curry(showTooltip, dataByCoordSys)\n }; // Process for triggered axes.\n\n each(coordSysAxesInfo.coordSysMap, function (coordSys, coordSysKey) {\n // If a point given, it must be contained by the coordinate system.\n var coordSysContainsPoint = isIllegalPoint || coordSys.containPoint(point);\n each(coordSysAxesInfo.coordSysAxesInfo[coordSysKey], function (axisInfo, key) {\n var axis = axisInfo.axis;\n var inputAxisInfo = findInputAxisInfo(inputAxesInfo, axisInfo); // If no inputAxesInfo, no axis is restricted.\n\n if (!shouldHide && coordSysContainsPoint && (!inputAxesInfo || inputAxisInfo)) {\n var val = inputAxisInfo && inputAxisInfo.value;\n\n if (val == null && !isIllegalPoint) {\n val = axis.pointToData(point);\n }\n\n val != null && processOnAxis(axisInfo, val, updaters, false, outputFinder);\n }\n });\n }); // Process for linked axes.\n\n var linkTriggers = {};\n each(axesInfo, function (tarAxisInfo, tarKey) {\n var linkGroup = tarAxisInfo.linkGroup; // If axis has been triggered in the previous stage, it should not be triggered by link.\n\n if (linkGroup && !showValueMap[tarKey]) {\n each(linkGroup.axesInfo, function (srcAxisInfo, srcKey) {\n var srcValItem = showValueMap[srcKey]; // If srcValItem exist, source axis is triggered, so link to target axis.\n\n if (srcAxisInfo !== tarAxisInfo && srcValItem) {\n var val = srcValItem.value;\n linkGroup.mapper && (val = tarAxisInfo.axis.scale.parse(linkGroup.mapper(val, makeMapperParam(srcAxisInfo), makeMapperParam(tarAxisInfo))));\n linkTriggers[tarAxisInfo.key] = val;\n }\n });\n }\n });\n each(linkTriggers, function (val, tarKey) {\n processOnAxis(axesInfo[tarKey], val, updaters, true, outputFinder);\n });\n updateModelActually(showValueMap, axesInfo, outputFinder);\n dispatchTooltipActually(dataByCoordSys, point, payload, dispatchAction);\n dispatchHighDownActually(axesInfo, dispatchAction, api);\n return outputFinder;\n}\n\nfunction processOnAxis(axisInfo, newValue, updaters, dontSnap, outputFinder) {\n var axis = axisInfo.axis;\n\n if (axis.scale.isBlank() || !axis.containData(newValue)) {\n return;\n }\n\n if (!axisInfo.involveSeries) {\n updaters.showPointer(axisInfo, newValue);\n return;\n } // Heavy calculation. So put it after axis.containData checking.\n\n\n var payloadInfo = buildPayloadsBySeries(newValue, axisInfo);\n var payloadBatch = payloadInfo.payloadBatch;\n var snapToValue = payloadInfo.snapToValue; // Fill content of event obj for echarts.connect.\n // By defualt use the first involved series data as a sample to connect.\n\n if (payloadBatch[0] && outputFinder.seriesIndex == null) {\n zrUtil.extend(outputFinder, payloadBatch[0]);\n } // If no linkSource input, this process is for collecting link\n // target, where snap should not be accepted.\n\n\n if (!dontSnap && axisInfo.snap) {\n if (axis.containData(snapToValue) && snapToValue != null) {\n newValue = snapToValue;\n }\n }\n\n updaters.showPointer(axisInfo, newValue, payloadBatch, outputFinder); // Tooltip should always be snapToValue, otherwise there will be\n // incorrect \"axis value ~ series value\" mapping displayed in tooltip.\n\n updaters.showTooltip(axisInfo, payloadInfo, snapToValue);\n}\n\nfunction buildPayloadsBySeries(value, axisInfo) {\n var axis = axisInfo.axis;\n var dim = axis.dim;\n var snapToValue = value;\n var payloadBatch = [];\n var minDist = Number.MAX_VALUE;\n var minDiff = -1;\n each(axisInfo.seriesModels, function (series, idx) {\n var dataDim = series.getData().mapDimension(dim, true);\n var seriesNestestValue;\n var dataIndices;\n\n if (series.getAxisTooltipData) {\n var result = series.getAxisTooltipData(dataDim, value, axis);\n dataIndices = result.dataIndices;\n seriesNestestValue = result.nestestValue;\n } else {\n dataIndices = series.getData().indicesOfNearest(dataDim[0], value, // Add a threshold to avoid find the wrong dataIndex\n // when data length is not same.\n // false,\n axis.type === 'category' ? 0.5 : null);\n\n if (!dataIndices.length) {\n return;\n }\n\n seriesNestestValue = series.getData().get(dataDim[0], dataIndices[0]);\n }\n\n if (seriesNestestValue == null || !isFinite(seriesNestestValue)) {\n return;\n }\n\n var diff = value - seriesNestestValue;\n var dist = Math.abs(diff); // Consider category case\n\n if (dist <= minDist) {\n if (dist < minDist || diff >= 0 && minDiff < 0) {\n minDist = dist;\n minDiff = diff;\n snapToValue = seriesNestestValue;\n payloadBatch.length = 0;\n }\n\n each(dataIndices, function (dataIndex) {\n payloadBatch.push({\n seriesIndex: series.seriesIndex,\n dataIndexInside: dataIndex,\n dataIndex: series.getData().getRawIndex(dataIndex)\n });\n });\n }\n });\n return {\n payloadBatch: payloadBatch,\n snapToValue: snapToValue\n };\n}\n\nfunction showPointer(showValueMap, axisInfo, value, payloadBatch) {\n showValueMap[axisInfo.key] = {\n value: value,\n payloadBatch: payloadBatch\n };\n}\n\nfunction showTooltip(dataByCoordSys, axisInfo, payloadInfo, value) {\n var payloadBatch = payloadInfo.payloadBatch;\n var axis = axisInfo.axis;\n var axisModel = axis.model;\n var axisPointerModel = axisInfo.axisPointerModel; // If no data, do not create anything in dataByCoordSys,\n // whose length will be used to judge whether dispatch action.\n\n if (!axisInfo.triggerTooltip || !payloadBatch.length) {\n return;\n }\n\n var coordSysModel = axisInfo.coordSys.model;\n var coordSysKey = modelHelper.makeKey(coordSysModel);\n var coordSysItem = dataByCoordSys.map[coordSysKey];\n\n if (!coordSysItem) {\n coordSysItem = dataByCoordSys.map[coordSysKey] = {\n coordSysId: coordSysModel.id,\n coordSysIndex: coordSysModel.componentIndex,\n coordSysType: coordSysModel.type,\n coordSysMainType: coordSysModel.mainType,\n dataByAxis: []\n };\n dataByCoordSys.list.push(coordSysItem);\n }\n\n coordSysItem.dataByAxis.push({\n axisDim: axis.dim,\n axisIndex: axisModel.componentIndex,\n axisType: axisModel.type,\n axisId: axisModel.id,\n value: value,\n // Caustion: viewHelper.getValueLabel is actually on \"view stage\", which\n // depends that all models have been updated. So it should not be performed\n // here. Considering axisPointerModel used here is volatile, which is hard\n // to be retrieve in TooltipView, we prepare parameters here.\n valueLabelOpt: {\n precision: axisPointerModel.get('label.precision'),\n formatter: axisPointerModel.get('label.formatter')\n },\n seriesDataIndices: payloadBatch.slice()\n });\n}\n\nfunction updateModelActually(showValueMap, axesInfo, outputFinder) {\n var outputAxesInfo = outputFinder.axesInfo = []; // Basic logic: If no 'show' required, 'hide' this axisPointer.\n\n each(axesInfo, function (axisInfo, key) {\n var option = axisInfo.axisPointerModel.option;\n var valItem = showValueMap[key];\n\n if (valItem) {\n !axisInfo.useHandle && (option.status = 'show');\n option.value = valItem.value; // For label formatter param and highlight.\n\n option.seriesDataIndices = (valItem.payloadBatch || []).slice();\n } // When always show (e.g., handle used), remain\n // original value and status.\n else {\n // If hide, value still need to be set, consider\n // click legend to toggle axis blank.\n !axisInfo.useHandle && (option.status = 'hide');\n } // If status is 'hide', should be no info in payload.\n\n\n option.status === 'show' && outputAxesInfo.push({\n axisDim: axisInfo.axis.dim,\n axisIndex: axisInfo.axis.model.componentIndex,\n value: option.value\n });\n });\n}\n\nfunction dispatchTooltipActually(dataByCoordSys, point, payload, dispatchAction) {\n // Basic logic: If no showTip required, hideTip will be dispatched.\n if (illegalPoint(point) || !dataByCoordSys.list.length) {\n dispatchAction({\n type: 'hideTip'\n });\n return;\n } // In most case only one axis (or event one series is used). It is\n // convinient to fetch payload.seriesIndex and payload.dataIndex\n // dirtectly. So put the first seriesIndex and dataIndex of the first\n // axis on the payload.\n\n\n var sampleItem = ((dataByCoordSys.list[0].dataByAxis[0] || {}).seriesDataIndices || [])[0] || {};\n dispatchAction({\n type: 'showTip',\n escapeConnect: true,\n x: point[0],\n y: point[1],\n tooltipOption: payload.tooltipOption,\n position: payload.position,\n dataIndexInside: sampleItem.dataIndexInside,\n dataIndex: sampleItem.dataIndex,\n seriesIndex: sampleItem.seriesIndex,\n dataByCoordSys: dataByCoordSys.list\n });\n}\n\nfunction dispatchHighDownActually(axesInfo, dispatchAction, api) {\n // FIXME\n // highlight status modification shoule be a stage of main process?\n // (Consider confilct (e.g., legend and axisPointer) and setOption)\n var zr = api.getZr();\n var highDownKey = 'axisPointerLastHighlights';\n var lastHighlights = inner(zr)[highDownKey] || {};\n var newHighlights = inner(zr)[highDownKey] = {}; // Update highlight/downplay status according to axisPointer model.\n // Build hash map and remove duplicate incidentally.\n\n each(axesInfo, function (axisInfo, key) {\n var option = axisInfo.axisPointerModel.option;\n option.status === 'show' && each(option.seriesDataIndices, function (batchItem) {\n var key = batchItem.seriesIndex + ' | ' + batchItem.dataIndex;\n newHighlights[key] = batchItem;\n });\n }); // Diff.\n\n var toHighlight = [];\n var toDownplay = [];\n zrUtil.each(lastHighlights, function (batchItem, key) {\n !newHighlights[key] && toDownplay.push(batchItem);\n });\n zrUtil.each(newHighlights, function (batchItem, key) {\n !lastHighlights[key] && toHighlight.push(batchItem);\n });\n toDownplay.length && api.dispatchAction({\n type: 'downplay',\n escapeConnect: true,\n batch: toDownplay\n });\n toHighlight.length && api.dispatchAction({\n type: 'highlight',\n escapeConnect: true,\n batch: toHighlight\n });\n}\n\nfunction findInputAxisInfo(inputAxesInfo, axisInfo) {\n for (var i = 0; i < (inputAxesInfo || []).length; i++) {\n var inputAxisInfo = inputAxesInfo[i];\n\n if (axisInfo.axis.dim === inputAxisInfo.axisDim && axisInfo.axis.model.componentIndex === inputAxisInfo.axisIndex) {\n return inputAxisInfo;\n }\n }\n}\n\nfunction makeMapperParam(axisInfo) {\n var axisModel = axisInfo.axis.model;\n var item = {};\n var dim = item.axisDim = axisInfo.axis.dim;\n item.axisIndex = item[dim + 'AxisIndex'] = axisModel.componentIndex;\n item.axisName = item[dim + 'AxisName'] = axisModel.name;\n item.axisId = item[dim + 'AxisId'] = axisModel.id;\n return item;\n}\n\nfunction illegalPoint(point) {\n return !point || point[0] == null || isNaN(point[0]) || point[1] == null || isNaN(point[1]);\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar Axis = require(\"../Axis\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Extend axis 2d\n * @constructor module:echarts/coord/cartesian/Axis2D\n * @extends {module:echarts/coord/cartesian/Axis}\n * @param {string} dim\n * @param {*} scale\n * @param {Array.<number>} coordExtent\n * @param {string} axisType\n * @param {string} position\n */\nvar Axis2D = function (dim, scale, coordExtent, axisType, position) {\n Axis.call(this, dim, scale, coordExtent);\n /**\n * Axis type\n * - 'category'\n * - 'value'\n * - 'time'\n * - 'log'\n * @type {string}\n */\n\n this.type = axisType || 'value';\n /**\n * Axis position\n * - 'top'\n * - 'bottom'\n * - 'left'\n * - 'right'\n */\n\n this.position = position || 'bottom';\n};\n\nAxis2D.prototype = {\n constructor: Axis2D,\n\n /**\n * Index of axis, can be used as key\n */\n index: 0,\n\n /**\n * Implemented in <module:echarts/coord/cartesian/Grid>.\n * @return {Array.<module:echarts/coord/cartesian/Axis2D>}\n * If not on zero of other axis, return null/undefined.\n * If no axes, return an empty array.\n */\n getAxesOnZeroOf: null,\n\n /**\n * Axis model\n * @param {module:echarts/coord/cartesian/AxisModel}\n */\n model: null,\n isHorizontal: function () {\n var position = this.position;\n return position === 'top' || position === 'bottom';\n },\n\n /**\n * Each item cooresponds to this.getExtent(), which\n * means globalExtent[0] may greater than globalExtent[1],\n * unless `asc` is input.\n *\n * @param {boolean} [asc]\n * @return {Array.<number>}\n */\n getGlobalExtent: function (asc) {\n var ret = this.getExtent();\n ret[0] = this.toGlobalCoord(ret[0]);\n ret[1] = this.toGlobalCoord(ret[1]);\n asc && ret[0] > ret[1] && ret.reverse();\n return ret;\n },\n getOtherAxis: function () {\n this.grid.getOtherAxis();\n },\n\n /**\n * @override\n */\n pointToData: function (point, clamp) {\n return this.coordToData(this.toLocalCoord(point[this.dim === 'x' ? 0 : 1]), clamp);\n },\n\n /**\n * Transform global coord to local coord,\n * i.e. var localCoord = axis.toLocalCoord(80);\n * designate by module:echarts/coord/cartesian/Grid.\n * @type {Function}\n */\n toLocalCoord: null,\n\n /**\n * Transform global coord to local coord,\n * i.e. var globalCoord = axis.toLocalCoord(40);\n * designate by module:echarts/coord/cartesian/Grid.\n * @type {Function}\n */\n toGlobalCoord: null\n};\nzrUtil.inherits(Axis2D, Axis);\nvar _default = Axis2D;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar createHashMap = _util.createHashMap;\nvar isString = _util.isString;\nvar isArray = _util.isArray;\nvar each = _util.each;\nvar assert = _util.assert;\n\nvar _parseSVG = require(\"zrender/lib/tool/parseSVG\");\n\nvar parseXML = _parseSVG.parseXML;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar storage = createHashMap(); // For minimize the code size of common echarts package,\n// do not put too much logic in this module.\n\nvar _default = {\n // The format of record: see `echarts.registerMap`.\n // Compatible with previous `echarts.registerMap`.\n registerMap: function (mapName, rawGeoJson, rawSpecialAreas) {\n var records;\n\n if (isArray(rawGeoJson)) {\n records = rawGeoJson;\n } else if (rawGeoJson.svg) {\n records = [{\n type: 'svg',\n source: rawGeoJson.svg,\n specialAreas: rawGeoJson.specialAreas\n }];\n } else {\n // Backward compatibility.\n if (rawGeoJson.geoJson && !rawGeoJson.features) {\n rawSpecialAreas = rawGeoJson.specialAreas;\n rawGeoJson = rawGeoJson.geoJson;\n }\n\n records = [{\n type: 'geoJSON',\n source: rawGeoJson,\n specialAreas: rawSpecialAreas\n }];\n }\n\n each(records, function (record) {\n var type = record.type;\n type === 'geoJson' && (type = record.type = 'geoJSON');\n var parse = parsers[type];\n parse(record);\n });\n return storage.set(mapName, records);\n },\n retrieveMap: function (mapName) {\n return storage.get(mapName);\n }\n};\nvar parsers = {\n geoJSON: function (record) {\n var source = record.source;\n record.geoJSON = !isString(source) ? source : typeof JSON !== 'undefined' && JSON.parse ? JSON.parse(source) : new Function('return (' + source + ');')();\n },\n // Only perform parse to XML object here, which might be time\n // consiming for large SVG.\n // Although convert XML to zrender element is also time consiming,\n // if we do it here, the clone of zrender elements has to be\n // required. So we do it once for each geo instance, util real\n // performance issues call for optimizing it.\n svg: function (record) {\n record.svgXML = parseXML(record.source);\n }\n};\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar createHashMap = _util.createHashMap;\nvar isTypedArray = _util.isTypedArray;\n\nvar _clazz = require(\"../util/clazz\");\n\nvar enableClassCheck = _clazz.enableClassCheck;\n\nvar _sourceType = require(\"./helper/sourceType\");\n\nvar SOURCE_FORMAT_ORIGINAL = _sourceType.SOURCE_FORMAT_ORIGINAL;\nvar SERIES_LAYOUT_BY_COLUMN = _sourceType.SERIES_LAYOUT_BY_COLUMN;\nvar SOURCE_FORMAT_UNKNOWN = _sourceType.SOURCE_FORMAT_UNKNOWN;\nvar SOURCE_FORMAT_TYPED_ARRAY = _sourceType.SOURCE_FORMAT_TYPED_ARRAY;\nvar SOURCE_FORMAT_KEYED_COLUMNS = _sourceType.SOURCE_FORMAT_KEYED_COLUMNS;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * [sourceFormat]\n *\n * + \"original\":\n * This format is only used in series.data, where\n * itemStyle can be specified in data item.\n *\n * + \"arrayRows\":\n * [\n * ['product', 'score', 'amount'],\n * ['Matcha Latte', 89.3, 95.8],\n * ['Milk Tea', 92.1, 89.4],\n * ['Cheese Cocoa', 94.4, 91.2],\n * ['Walnut Brownie', 85.4, 76.9]\n * ]\n *\n * + \"objectRows\":\n * [\n * {product: 'Matcha Latte', score: 89.3, amount: 95.8},\n * {product: 'Milk Tea', score: 92.1, amount: 89.4},\n * {product: 'Cheese Cocoa', score: 94.4, amount: 91.2},\n * {product: 'Walnut Brownie', score: 85.4, amount: 76.9}\n * ]\n *\n * + \"keyedColumns\":\n * {\n * 'product': ['Matcha Latte', 'Milk Tea', 'Cheese Cocoa', 'Walnut Brownie'],\n * 'count': [823, 235, 1042, 988],\n * 'score': [95.8, 81.4, 91.2, 76.9]\n * }\n *\n * + \"typedArray\"\n *\n * + \"unknown\"\n */\n\n/**\n * @constructor\n * @param {Object} fields\n * @param {string} fields.sourceFormat\n * @param {Array|Object} fields.fromDataset\n * @param {Array|Object} [fields.data]\n * @param {string} [seriesLayoutBy='column']\n * @param {Array.<Object|string>} [dimensionsDefine]\n * @param {Objet|HashMap} [encodeDefine]\n * @param {number} [startIndex=0]\n * @param {number} [dimensionsDetectCount]\n */\nfunction Source(fields) {\n /**\n * @type {boolean}\n */\n this.fromDataset = fields.fromDataset;\n /**\n * Not null/undefined.\n * @type {Array|Object}\n */\n\n this.data = fields.data || (fields.sourceFormat === SOURCE_FORMAT_KEYED_COLUMNS ? {} : []);\n /**\n * See also \"detectSourceFormat\".\n * Not null/undefined.\n * @type {string}\n */\n\n this.sourceFormat = fields.sourceFormat || SOURCE_FORMAT_UNKNOWN;\n /**\n * 'row' or 'column'\n * Not null/undefined.\n * @type {string} seriesLayoutBy\n */\n\n this.seriesLayoutBy = fields.seriesLayoutBy || SERIES_LAYOUT_BY_COLUMN;\n /**\n * dimensions definition in option.\n * can be null/undefined.\n * @type {Array.<Object|string>}\n */\n\n this.dimensionsDefine = fields.dimensionsDefine;\n /**\n * encode definition in option.\n * can be null/undefined.\n * @type {Objet|HashMap}\n */\n\n this.encodeDefine = fields.encodeDefine && createHashMap(fields.encodeDefine);\n /**\n * Not null/undefined, uint.\n * @type {number}\n */\n\n this.startIndex = fields.startIndex || 0;\n /**\n * Can be null/undefined (when unknown), uint.\n * @type {number}\n */\n\n this.dimensionsDetectCount = fields.dimensionsDetectCount;\n}\n/**\n * Wrap original series data for some compatibility cases.\n */\n\n\nSource.seriesDataToSource = function (data) {\n return new Source({\n data: data,\n sourceFormat: isTypedArray(data) ? SOURCE_FORMAT_TYPED_ARRAY : SOURCE_FORMAT_ORIGINAL,\n fromDataset: false\n });\n};\n\nenableClassCheck(Source);\nvar _default = Source;\nmodule.exports = _default;","var _config = require(\"./config\");\n\nvar devicePixelRatio = _config.devicePixelRatio;\n\nvar util = require(\"./core/util\");\n\nvar log = require(\"./core/log\");\n\nvar BoundingRect = require(\"./core/BoundingRect\");\n\nvar timsort = require(\"./core/timsort\");\n\nvar Layer = require(\"./Layer\");\n\nvar requestAnimationFrame = require(\"./animation/requestAnimationFrame\");\n\nvar Image = require(\"./graphic/Image\");\n\nvar env = require(\"./core/env\");\n\nvar HOVER_LAYER_ZLEVEL = 1e5;\nvar CANVAS_ZLEVEL = 314159;\nvar EL_AFTER_INCREMENTAL_INC = 0.01;\nvar INCREMENTAL_INC = 0.001;\n\nfunction parseInt10(val) {\n return parseInt(val, 10);\n}\n\nfunction isLayerValid(layer) {\n if (!layer) {\n return false;\n }\n\n if (layer.__builtin__) {\n return true;\n }\n\n if (typeof layer.resize !== 'function' || typeof layer.refresh !== 'function') {\n return false;\n }\n\n return true;\n}\n\nvar tmpRect = new BoundingRect(0, 0, 0, 0);\nvar viewRect = new BoundingRect(0, 0, 0, 0);\n\nfunction isDisplayableCulled(el, width, height) {\n tmpRect.copy(el.getBoundingRect());\n\n if (el.transform) {\n tmpRect.applyTransform(el.transform);\n }\n\n viewRect.width = width;\n viewRect.height = height;\n return !tmpRect.intersect(viewRect);\n}\n\nfunction isClipPathChanged(clipPaths, prevClipPaths) {\n if (clipPaths === prevClipPaths) {\n // Can both be null or undefined\n return false;\n }\n\n if (!clipPaths || !prevClipPaths || clipPaths.length !== prevClipPaths.length) {\n return true;\n }\n\n for (var i = 0; i < clipPaths.length; i++) {\n if (clipPaths[i] !== prevClipPaths[i]) {\n return true;\n }\n }\n}\n\nfunction doClip(clipPaths, ctx) {\n for (var i = 0; i < clipPaths.length; i++) {\n var clipPath = clipPaths[i];\n clipPath.setTransform(ctx);\n ctx.beginPath();\n clipPath.buildPath(ctx, clipPath.shape);\n ctx.clip(); // Transform back\n\n clipPath.restoreTransform(ctx);\n }\n}\n\nfunction createRoot(width, height) {\n var domRoot = document.createElement('div'); // domRoot.onselectstart = returnFalse; // 避免页面选中的尴尬\n\n domRoot.style.cssText = ['position:relative', 'overflow:hidden', 'width:' + width + 'px', 'height:' + height + 'px', 'padding:0', 'margin:0', 'border-width:0'].join(';') + ';';\n return domRoot;\n}\n/**\n * @alias module:zrender/Painter\n * @constructor\n * @param {HTMLElement} root 绘图容器\n * @param {module:zrender/Storage} storage\n * @param {Object} opts\n */\n\n\nvar Painter = function (root, storage, opts) {\n this.type = 'canvas'; // In node environment using node-canvas\n\n var singleCanvas = !root.nodeName // In node ?\n || root.nodeName.toUpperCase() === 'CANVAS';\n this._opts = opts = util.extend({}, opts || {});\n /**\n * @type {number}\n */\n\n this.dpr = opts.devicePixelRatio || devicePixelRatio;\n /**\n * @type {boolean}\n * @private\n */\n\n this._singleCanvas = singleCanvas;\n /**\n * 绘图容器\n * @type {HTMLElement}\n */\n\n this.root = root;\n var rootStyle = root.style;\n\n if (rootStyle) {\n rootStyle['-webkit-tap-highlight-color'] = 'transparent';\n rootStyle['-webkit-user-select'] = rootStyle['user-select'] = rootStyle['-webkit-touch-callout'] = 'none';\n root.innerHTML = '';\n }\n /**\n * @type {module:zrender/Storage}\n */\n\n\n this.storage = storage;\n /**\n * @type {Array.<number>}\n * @private\n */\n\n var zlevelList = this._zlevelList = [];\n /**\n * @type {Object.<string, module:zrender/Layer>}\n * @private\n */\n\n var layers = this._layers = {};\n /**\n * @type {Object.<string, Object>}\n * @private\n */\n\n this._layerConfig = {};\n /**\n * zrender will do compositing when root is a canvas and have multiple zlevels.\n */\n\n this._needsManuallyCompositing = false;\n\n if (!singleCanvas) {\n this._width = this._getSize(0);\n this._height = this._getSize(1);\n var domRoot = this._domRoot = createRoot(this._width, this._height);\n root.appendChild(domRoot);\n } else {\n var width = root.width;\n var height = root.height;\n\n if (opts.width != null) {\n width = opts.width;\n }\n\n if (opts.height != null) {\n height = opts.height;\n }\n\n this.dpr = opts.devicePixelRatio || 1; // Use canvas width and height directly\n\n root.width = width * this.dpr;\n root.height = height * this.dpr;\n this._width = width;\n this._height = height; // Create layer if only one given canvas\n // Device can be specified to create a high dpi image.\n\n var mainLayer = new Layer(root, this, this.dpr);\n mainLayer.__builtin__ = true;\n mainLayer.initContext(); // FIXME Use canvas width and height\n // mainLayer.resize(width, height);\n\n layers[CANVAS_ZLEVEL] = mainLayer;\n mainLayer.zlevel = CANVAS_ZLEVEL; // Not use common zlevel.\n\n zlevelList.push(CANVAS_ZLEVEL);\n this._domRoot = root;\n }\n /**\n * @type {module:zrender/Layer}\n * @private\n */\n\n\n this._hoverlayer = null;\n this._hoverElements = [];\n};\n\nPainter.prototype = {\n constructor: Painter,\n getType: function () {\n return 'canvas';\n },\n\n /**\n * If painter use a single canvas\n * @return {boolean}\n */\n isSingleCanvas: function () {\n return this._singleCanvas;\n },\n\n /**\n * @return {HTMLDivElement}\n */\n getViewportRoot: function () {\n return this._domRoot;\n },\n getViewportRootOffset: function () {\n var viewportRoot = this.getViewportRoot();\n\n if (viewportRoot) {\n return {\n offsetLeft: viewportRoot.offsetLeft || 0,\n offsetTop: viewportRoot.offsetTop || 0\n };\n }\n },\n\n /**\n * 刷新\n * @param {boolean} [paintAll=false] 强制绘制所有displayable\n */\n refresh: function (paintAll) {\n var list = this.storage.getDisplayList(true);\n var zlevelList = this._zlevelList;\n this._redrawId = Math.random();\n\n this._paintList(list, paintAll, this._redrawId); // Paint custum layers\n\n\n for (var i = 0; i < zlevelList.length; i++) {\n var z = zlevelList[i];\n var layer = this._layers[z];\n\n if (!layer.__builtin__ && layer.refresh) {\n var clearColor = i === 0 ? this._backgroundColor : null;\n layer.refresh(clearColor);\n }\n }\n\n this.refreshHover();\n return this;\n },\n addHover: function (el, hoverStyle) {\n if (el.__hoverMir) {\n return;\n }\n\n var elMirror = new el.constructor({\n style: el.style,\n shape: el.shape,\n z: el.z,\n z2: el.z2,\n silent: el.silent\n });\n elMirror.__from = el;\n el.__hoverMir = elMirror;\n hoverStyle && elMirror.setStyle(hoverStyle);\n\n this._hoverElements.push(elMirror);\n\n return elMirror;\n },\n removeHover: function (el) {\n var elMirror = el.__hoverMir;\n var hoverElements = this._hoverElements;\n var idx = util.indexOf(hoverElements, elMirror);\n\n if (idx >= 0) {\n hoverElements.splice(idx, 1);\n }\n\n el.__hoverMir = null;\n },\n clearHover: function (el) {\n var hoverElements = this._hoverElements;\n\n for (var i = 0; i < hoverElements.length; i++) {\n var from = hoverElements[i].__from;\n\n if (from) {\n from.__hoverMir = null;\n }\n }\n\n hoverElements.length = 0;\n },\n refreshHover: function () {\n var hoverElements = this._hoverElements;\n var len = hoverElements.length;\n var hoverLayer = this._hoverlayer;\n hoverLayer && hoverLayer.clear();\n\n if (!len) {\n return;\n }\n\n timsort(hoverElements, this.storage.displayableSortFunc); // Use a extream large zlevel\n // FIXME?\n\n if (!hoverLayer) {\n hoverLayer = this._hoverlayer = this.getLayer(HOVER_LAYER_ZLEVEL);\n }\n\n var scope = {};\n hoverLayer.ctx.save();\n\n for (var i = 0; i < len;) {\n var el = hoverElements[i];\n var originalEl = el.__from; // Original el is removed\n // PENDING\n\n if (!(originalEl && originalEl.__zr)) {\n hoverElements.splice(i, 1);\n originalEl.__hoverMir = null;\n len--;\n continue;\n }\n\n i++; // Use transform\n // FIXME style and shape ?\n\n if (!originalEl.invisible) {\n el.transform = originalEl.transform;\n el.invTransform = originalEl.invTransform;\n el.__clipPaths = originalEl.__clipPaths; // el.\n\n this._doPaintEl(el, hoverLayer, true, scope);\n }\n }\n\n hoverLayer.ctx.restore();\n },\n getHoverLayer: function () {\n return this.getLayer(HOVER_LAYER_ZLEVEL);\n },\n _paintList: function (list, paintAll, redrawId) {\n if (this._redrawId !== redrawId) {\n return;\n }\n\n paintAll = paintAll || false;\n\n this._updateLayerStatus(list);\n\n var finished = this._doPaintList(list, paintAll);\n\n if (this._needsManuallyCompositing) {\n this._compositeManually();\n }\n\n if (!finished) {\n var self = this;\n requestAnimationFrame(function () {\n self._paintList(list, paintAll, redrawId);\n });\n }\n },\n _compositeManually: function () {\n var ctx = this.getLayer(CANVAS_ZLEVEL).ctx;\n var width = this._domRoot.width;\n var height = this._domRoot.height;\n ctx.clearRect(0, 0, width, height); // PENDING, If only builtin layer?\n\n this.eachBuiltinLayer(function (layer) {\n if (layer.virtual) {\n ctx.drawImage(layer.dom, 0, 0, width, height);\n }\n });\n },\n _doPaintList: function (list, paintAll) {\n var layerList = [];\n\n for (var zi = 0; zi < this._zlevelList.length; zi++) {\n var zlevel = this._zlevelList[zi];\n var layer = this._layers[zlevel];\n\n if (layer.__builtin__ && layer !== this._hoverlayer && (layer.__dirty || paintAll)) {\n layerList.push(layer);\n }\n }\n\n var finished = true;\n\n for (var k = 0; k < layerList.length; k++) {\n var layer = layerList[k];\n var ctx = layer.ctx;\n var scope = {};\n ctx.save();\n var start = paintAll ? layer.__startIndex : layer.__drawIndex;\n var useTimer = !paintAll && layer.incremental && Date.now;\n var startTime = useTimer && Date.now();\n var clearColor = layer.zlevel === this._zlevelList[0] ? this._backgroundColor : null; // All elements in this layer are cleared.\n\n if (layer.__startIndex === layer.__endIndex) {\n layer.clear(false, clearColor);\n } else if (start === layer.__startIndex) {\n var firstEl = list[start];\n\n if (!firstEl.incremental || !firstEl.notClear || paintAll) {\n layer.clear(false, clearColor);\n }\n }\n\n if (start === -1) {\n console.error('For some unknown reason. drawIndex is -1');\n start = layer.__startIndex;\n }\n\n for (var i = start; i < layer.__endIndex; i++) {\n var el = list[i];\n\n this._doPaintEl(el, layer, paintAll, scope);\n\n el.__dirty = el.__dirtyText = false;\n\n if (useTimer) {\n // Date.now can be executed in 13,025,305 ops/second.\n var dTime = Date.now() - startTime; // Give 15 millisecond to draw.\n // The rest elements will be drawn in the next frame.\n\n if (dTime > 15) {\n break;\n }\n }\n }\n\n layer.__drawIndex = i;\n\n if (layer.__drawIndex < layer.__endIndex) {\n finished = false;\n }\n\n if (scope.prevElClipPaths) {\n // Needs restore the state. If last drawn element is in the clipping area.\n ctx.restore();\n }\n\n ctx.restore();\n }\n\n if (env.wxa) {\n // Flush for weixin application\n util.each(this._layers, function (layer) {\n if (layer && layer.ctx && layer.ctx.draw) {\n layer.ctx.draw();\n }\n });\n }\n\n return finished;\n },\n _doPaintEl: function (el, currentLayer, forcePaint, scope) {\n var ctx = currentLayer.ctx;\n var m = el.transform;\n\n if ((currentLayer.__dirty || forcePaint) && // Ignore invisible element\n !el.invisible // Ignore transparent element\n && el.style.opacity !== 0 // Ignore scale 0 element, in some environment like node-canvas\n // Draw a scale 0 element can cause all following draw wrong\n // And setTransform with scale 0 will cause set back transform failed.\n && !(m && !m[0] && !m[3]) // Ignore culled element\n && !(el.culling && isDisplayableCulled(el, this._width, this._height))) {\n var clipPaths = el.__clipPaths; // Optimize when clipping on group with several elements\n\n if (!scope.prevElClipPaths || isClipPathChanged(clipPaths, scope.prevElClipPaths)) {\n // If has previous clipping state, restore from it\n if (scope.prevElClipPaths) {\n currentLayer.ctx.restore();\n scope.prevElClipPaths = null; // Reset prevEl since context has been restored\n\n scope.prevEl = null;\n } // New clipping state\n\n\n if (clipPaths) {\n ctx.save();\n doClip(clipPaths, ctx);\n scope.prevElClipPaths = clipPaths;\n }\n }\n\n el.beforeBrush && el.beforeBrush(ctx);\n el.brush(ctx, scope.prevEl || null);\n scope.prevEl = el;\n el.afterBrush && el.afterBrush(ctx);\n }\n },\n\n /**\n * 获取 zlevel 所在层,如果不存在则会创建一个新的层\n * @param {number} zlevel\n * @param {boolean} virtual Virtual layer will not be inserted into dom.\n * @return {module:zrender/Layer}\n */\n getLayer: function (zlevel, virtual) {\n if (this._singleCanvas && !this._needsManuallyCompositing) {\n zlevel = CANVAS_ZLEVEL;\n }\n\n var layer = this._layers[zlevel];\n\n if (!layer) {\n // Create a new layer\n layer = new Layer('zr_' + zlevel, this, this.dpr);\n layer.zlevel = zlevel;\n layer.__builtin__ = true;\n\n if (this._layerConfig[zlevel]) {\n util.merge(layer, this._layerConfig[zlevel], true);\n }\n\n if (virtual) {\n layer.virtual = virtual;\n }\n\n this.insertLayer(zlevel, layer); // Context is created after dom inserted to document\n // Or excanvas will get 0px clientWidth and clientHeight\n\n layer.initContext();\n }\n\n return layer;\n },\n insertLayer: function (zlevel, layer) {\n var layersMap = this._layers;\n var zlevelList = this._zlevelList;\n var len = zlevelList.length;\n var prevLayer = null;\n var i = -1;\n var domRoot = this._domRoot;\n\n if (layersMap[zlevel]) {\n log('ZLevel ' + zlevel + ' has been used already');\n return;\n } // Check if is a valid layer\n\n\n if (!isLayerValid(layer)) {\n log('Layer of zlevel ' + zlevel + ' is not valid');\n return;\n }\n\n if (len > 0 && zlevel > zlevelList[0]) {\n for (i = 0; i < len - 1; i++) {\n if (zlevelList[i] < zlevel && zlevelList[i + 1] > zlevel) {\n break;\n }\n }\n\n prevLayer = layersMap[zlevelList[i]];\n }\n\n zlevelList.splice(i + 1, 0, zlevel);\n layersMap[zlevel] = layer; // Vitual layer will not directly show on the screen.\n // (It can be a WebGL layer and assigned to a ZImage element)\n // But it still under management of zrender.\n\n if (!layer.virtual) {\n if (prevLayer) {\n var prevDom = prevLayer.dom;\n\n if (prevDom.nextSibling) {\n domRoot.insertBefore(layer.dom, prevDom.nextSibling);\n } else {\n domRoot.appendChild(layer.dom);\n }\n } else {\n if (domRoot.firstChild) {\n domRoot.insertBefore(layer.dom, domRoot.firstChild);\n } else {\n domRoot.appendChild(layer.dom);\n }\n }\n }\n },\n // Iterate each layer\n eachLayer: function (cb, context) {\n var zlevelList = this._zlevelList;\n var z;\n var i;\n\n for (i = 0; i < zlevelList.length; i++) {\n z = zlevelList[i];\n cb.call(context, this._layers[z], z);\n }\n },\n // Iterate each buildin layer\n eachBuiltinLayer: function (cb, context) {\n var zlevelList = this._zlevelList;\n var layer;\n var z;\n var i;\n\n for (i = 0; i < zlevelList.length; i++) {\n z = zlevelList[i];\n layer = this._layers[z];\n\n if (layer.__builtin__) {\n cb.call(context, layer, z);\n }\n }\n },\n // Iterate each other layer except buildin layer\n eachOtherLayer: function (cb, context) {\n var zlevelList = this._zlevelList;\n var layer;\n var z;\n var i;\n\n for (i = 0; i < zlevelList.length; i++) {\n z = zlevelList[i];\n layer = this._layers[z];\n\n if (!layer.__builtin__) {\n cb.call(context, layer, z);\n }\n }\n },\n\n /**\n * 获取所有已创建的层\n * @param {Array.<module:zrender/Layer>} [prevLayer]\n */\n getLayers: function () {\n return this._layers;\n },\n _updateLayerStatus: function (list) {\n this.eachBuiltinLayer(function (layer, z) {\n layer.__dirty = layer.__used = false;\n });\n\n function updatePrevLayer(idx) {\n if (prevLayer) {\n if (prevLayer.__endIndex !== idx) {\n prevLayer.__dirty = true;\n }\n\n prevLayer.__endIndex = idx;\n }\n }\n\n if (this._singleCanvas) {\n for (var i = 1; i < list.length; i++) {\n var el = list[i];\n\n if (el.zlevel !== list[i - 1].zlevel || el.incremental) {\n this._needsManuallyCompositing = true;\n break;\n }\n }\n }\n\n var prevLayer = null;\n var incrementalLayerCount = 0;\n\n for (var i = 0; i < list.length; i++) {\n var el = list[i];\n var zlevel = el.zlevel;\n var layer; // PENDING If change one incremental element style ?\n // TODO Where there are non-incremental elements between incremental elements.\n\n if (el.incremental) {\n layer = this.getLayer(zlevel + INCREMENTAL_INC, this._needsManuallyCompositing);\n layer.incremental = true;\n incrementalLayerCount = 1;\n } else {\n layer = this.getLayer(zlevel + (incrementalLayerCount > 0 ? EL_AFTER_INCREMENTAL_INC : 0), this._needsManuallyCompositing);\n }\n\n if (!layer.__builtin__) {\n log('ZLevel ' + zlevel + ' has been used by unkown layer ' + layer.id);\n }\n\n if (layer !== prevLayer) {\n layer.__used = true;\n\n if (layer.__startIndex !== i) {\n layer.__dirty = true;\n }\n\n layer.__startIndex = i;\n\n if (!layer.incremental) {\n layer.__drawIndex = i;\n } else {\n // Mark layer draw index needs to update.\n layer.__drawIndex = -1;\n }\n\n updatePrevLayer(i);\n prevLayer = layer;\n }\n\n if (el.__dirty) {\n layer.__dirty = true;\n\n if (layer.incremental && layer.__drawIndex < 0) {\n // Start draw from the first dirty element.\n layer.__drawIndex = i;\n }\n }\n }\n\n updatePrevLayer(i);\n this.eachBuiltinLayer(function (layer, z) {\n // Used in last frame but not in this frame. Needs clear\n if (!layer.__used && layer.getElementCount() > 0) {\n layer.__dirty = true;\n layer.__startIndex = layer.__endIndex = layer.__drawIndex = 0;\n } // For incremental layer. In case start index changed and no elements are dirty.\n\n\n if (layer.__dirty && layer.__drawIndex < 0) {\n layer.__drawIndex = layer.__startIndex;\n }\n });\n },\n\n /**\n * 清除hover层外所有内容\n */\n clear: function () {\n this.eachBuiltinLayer(this._clearLayer);\n return this;\n },\n _clearLayer: function (layer) {\n layer.clear();\n },\n setBackgroundColor: function (backgroundColor) {\n this._backgroundColor = backgroundColor;\n },\n\n /**\n * 修改指定zlevel的绘制参数\n *\n * @param {string} zlevel\n * @param {Object} config 配置对象\n * @param {string} [config.clearColor=0] 每次清空画布的颜色\n * @param {string} [config.motionBlur=false] 是否开启动态模糊\n * @param {number} [config.lastFrameAlpha=0.7]\n * 在开启动态模糊的时候使用,与上一帧混合的alpha值,值越大尾迹越明显\n */\n configLayer: function (zlevel, config) {\n if (config) {\n var layerConfig = this._layerConfig;\n\n if (!layerConfig[zlevel]) {\n layerConfig[zlevel] = config;\n } else {\n util.merge(layerConfig[zlevel], config, true);\n }\n\n for (var i = 0; i < this._zlevelList.length; i++) {\n var _zlevel = this._zlevelList[i];\n\n if (_zlevel === zlevel || _zlevel === zlevel + EL_AFTER_INCREMENTAL_INC) {\n var layer = this._layers[_zlevel];\n util.merge(layer, layerConfig[zlevel], true);\n }\n }\n }\n },\n\n /**\n * 删除指定层\n * @param {number} zlevel 层所在的zlevel\n */\n delLayer: function (zlevel) {\n var layers = this._layers;\n var zlevelList = this._zlevelList;\n var layer = layers[zlevel];\n\n if (!layer) {\n return;\n }\n\n layer.dom.parentNode.removeChild(layer.dom);\n delete layers[zlevel];\n zlevelList.splice(util.indexOf(zlevelList, zlevel), 1);\n },\n\n /**\n * 区域大小变化后重绘\n */\n resize: function (width, height) {\n if (!this._domRoot.style) {\n // Maybe in node or worker\n if (width == null || height == null) {\n return;\n }\n\n this._width = width;\n this._height = height;\n this.getLayer(CANVAS_ZLEVEL).resize(width, height);\n } else {\n var domRoot = this._domRoot; // FIXME Why ?\n\n domRoot.style.display = 'none'; // Save input w/h\n\n var opts = this._opts;\n width != null && (opts.width = width);\n height != null && (opts.height = height);\n width = this._getSize(0);\n height = this._getSize(1);\n domRoot.style.display = ''; // 优化没有实际改变的resize\n\n if (this._width !== width || height !== this._height) {\n domRoot.style.width = width + 'px';\n domRoot.style.height = height + 'px';\n\n for (var id in this._layers) {\n if (this._layers.hasOwnProperty(id)) {\n this._layers[id].resize(width, height);\n }\n }\n\n util.each(this._progressiveLayers, function (layer) {\n layer.resize(width, height);\n });\n this.refresh(true);\n }\n\n this._width = width;\n this._height = height;\n }\n\n return this;\n },\n\n /**\n * 清除单独的一个层\n * @param {number} zlevel\n */\n clearLayer: function (zlevel) {\n var layer = this._layers[zlevel];\n\n if (layer) {\n layer.clear();\n }\n },\n\n /**\n * 释放\n */\n dispose: function () {\n this.root.innerHTML = '';\n this.root = this.storage = this._domRoot = this._layers = null;\n },\n\n /**\n * Get canvas which has all thing rendered\n * @param {Object} opts\n * @param {string} [opts.backgroundColor]\n * @param {number} [opts.pixelRatio]\n */\n getRenderedCanvas: function (opts) {\n opts = opts || {};\n\n if (this._singleCanvas && !this._compositeManually) {\n return this._layers[CANVAS_ZLEVEL].dom;\n }\n\n var imageLayer = new Layer('image', this, opts.pixelRatio || this.dpr);\n imageLayer.initContext();\n imageLayer.clear(false, opts.backgroundColor || this._backgroundColor);\n\n if (opts.pixelRatio <= this.dpr) {\n this.refresh();\n var width = imageLayer.dom.width;\n var height = imageLayer.dom.height;\n var ctx = imageLayer.ctx;\n this.eachLayer(function (layer) {\n if (layer.__builtin__) {\n ctx.drawImage(layer.dom, 0, 0, width, height);\n } else if (layer.renderToCanvas) {\n imageLayer.ctx.save();\n layer.renderToCanvas(imageLayer.ctx);\n imageLayer.ctx.restore();\n }\n });\n } else {\n // PENDING, echarts-gl and incremental rendering.\n var scope = {};\n var displayList = this.storage.getDisplayList(true);\n\n for (var i = 0; i < displayList.length; i++) {\n var el = displayList[i];\n\n this._doPaintEl(el, imageLayer, true, scope);\n }\n }\n\n return imageLayer.dom;\n },\n\n /**\n * 获取绘图区域宽度\n */\n getWidth: function () {\n return this._width;\n },\n\n /**\n * 获取绘图区域高度\n */\n getHeight: function () {\n return this._height;\n },\n _getSize: function (whIdx) {\n var opts = this._opts;\n var wh = ['width', 'height'][whIdx];\n var cwh = ['clientWidth', 'clientHeight'][whIdx];\n var plt = ['paddingLeft', 'paddingTop'][whIdx];\n var prb = ['paddingRight', 'paddingBottom'][whIdx];\n\n if (opts[wh] != null && opts[wh] !== 'auto') {\n return parseFloat(opts[wh]);\n }\n\n var root = this.root; // IE8 does not support getComputedStyle, but it use VML.\n\n var stl = document.defaultView.getComputedStyle(root);\n return (root[cwh] || parseInt10(stl[wh]) || parseInt10(root.style[wh])) - (parseInt10(stl[plt]) || 0) - (parseInt10(stl[prb]) || 0) | 0;\n },\n pathToImage: function (path, dpr) {\n dpr = dpr || this.dpr;\n var canvas = document.createElement('canvas');\n var ctx = canvas.getContext('2d');\n var rect = path.getBoundingRect();\n var style = path.style;\n var shadowBlurSize = style.shadowBlur * dpr;\n var shadowOffsetX = style.shadowOffsetX * dpr;\n var shadowOffsetY = style.shadowOffsetY * dpr;\n var lineWidth = style.hasStroke() ? style.lineWidth : 0;\n var leftMargin = Math.max(lineWidth / 2, -shadowOffsetX + shadowBlurSize);\n var rightMargin = Math.max(lineWidth / 2, shadowOffsetX + shadowBlurSize);\n var topMargin = Math.max(lineWidth / 2, -shadowOffsetY + shadowBlurSize);\n var bottomMargin = Math.max(lineWidth / 2, shadowOffsetY + shadowBlurSize);\n var width = rect.width + leftMargin + rightMargin;\n var height = rect.height + topMargin + bottomMargin;\n canvas.width = width * dpr;\n canvas.height = height * dpr;\n ctx.scale(dpr, dpr);\n ctx.clearRect(0, 0, width, height);\n ctx.dpr = dpr;\n var pathTransform = {\n position: path.position,\n rotation: path.rotation,\n scale: path.scale\n };\n path.position = [leftMargin - rect.x, topMargin - rect.y];\n path.rotation = 0;\n path.scale = [1, 1];\n path.updateTransform();\n\n if (path) {\n path.brush(ctx);\n }\n\n var ImageShape = Image;\n var imgShape = new ImageShape({\n style: {\n x: 0,\n y: 0,\n image: canvas\n }\n });\n\n if (pathTransform.position != null) {\n imgShape.position = path.position = pathTransform.position;\n }\n\n if (pathTransform.rotation != null) {\n imgShape.rotation = path.rotation = pathTransform.rotation;\n }\n\n if (pathTransform.scale != null) {\n imgShape.scale = path.scale = pathTransform.scale;\n }\n\n return imgShape;\n }\n};\nvar _default = Painter;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar textContain = require(\"zrender/lib/contain/text\");\n\nvar numberUtil = require(\"./number\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// import Text from 'zrender/src/graphic/Text';\n\n/**\n * 每三位默认加,格式化\n * @param {string|number} x\n * @return {string}\n */\nfunction addCommas(x) {\n if (isNaN(x)) {\n return '-';\n }\n\n x = (x + '').split('.');\n return x[0].replace(/(\\d{1,3})(?=(?:\\d{3})+(?!\\d))/g, '$1,') + (x.length > 1 ? '.' + x[1] : '');\n}\n/**\n * @param {string} str\n * @param {boolean} [upperCaseFirst=false]\n * @return {string} str\n */\n\n\nfunction toCamelCase(str, upperCaseFirst) {\n str = (str || '').toLowerCase().replace(/-(.)/g, function (match, group1) {\n return group1.toUpperCase();\n });\n\n if (upperCaseFirst && str) {\n str = str.charAt(0).toUpperCase() + str.slice(1);\n }\n\n return str;\n}\n\nvar normalizeCssArray = zrUtil.normalizeCssArray;\nvar replaceReg = /([&<>\"'])/g;\nvar replaceMap = {\n '&': '&amp;',\n '<': '&lt;',\n '>': '&gt;',\n '\"': '&quot;',\n '\\'': '&#39;'\n};\n\nfunction encodeHTML(source) {\n return source == null ? '' : (source + '').replace(replaceReg, function (str, c) {\n return replaceMap[c];\n });\n}\n\nvar TPL_VAR_ALIAS = ['a', 'b', 'c', 'd', 'e', 'f', 'g'];\n\nvar wrapVar = function (varName, seriesIdx) {\n return '{' + varName + (seriesIdx == null ? '' : seriesIdx) + '}';\n};\n/**\n * Template formatter\n * @param {string} tpl\n * @param {Array.<Object>|Object} paramsList\n * @param {boolean} [encode=false]\n * @return {string}\n */\n\n\nfunction formatTpl(tpl, paramsList, encode) {\n if (!zrUtil.isArray(paramsList)) {\n paramsList = [paramsList];\n }\n\n var seriesLen = paramsList.length;\n\n if (!seriesLen) {\n return '';\n }\n\n var $vars = paramsList[0].$vars || [];\n\n for (var i = 0; i < $vars.length; i++) {\n var alias = TPL_VAR_ALIAS[i];\n tpl = tpl.replace(wrapVar(alias), wrapVar(alias, 0));\n }\n\n for (var seriesIdx = 0; seriesIdx < seriesLen; seriesIdx++) {\n for (var k = 0; k < $vars.length; k++) {\n var val = paramsList[seriesIdx][$vars[k]];\n tpl = tpl.replace(wrapVar(TPL_VAR_ALIAS[k], seriesIdx), encode ? encodeHTML(val) : val);\n }\n }\n\n return tpl;\n}\n/**\n * simple Template formatter\n *\n * @param {string} tpl\n * @param {Object} param\n * @param {boolean} [encode=false]\n * @return {string}\n */\n\n\nfunction formatTplSimple(tpl, param, encode) {\n zrUtil.each(param, function (value, key) {\n tpl = tpl.replace('{' + key + '}', encode ? encodeHTML(value) : value);\n });\n return tpl;\n}\n/**\n * @param {Object|string} [opt] If string, means color.\n * @param {string} [opt.color]\n * @param {string} [opt.extraCssText]\n * @param {string} [opt.type='item'] 'item' or 'subItem'\n * @param {string} [opt.renderMode='html'] render mode of tooltip, 'html' or 'richText'\n * @param {string} [opt.markerId='X'] id name for marker. If only one marker is in a rich text, this can be omitted.\n * @return {string}\n */\n\n\nfunction getTooltipMarker(opt, extraCssText) {\n opt = zrUtil.isString(opt) ? {\n color: opt,\n extraCssText: extraCssText\n } : opt || {};\n var color = opt.color;\n var type = opt.type;\n var extraCssText = opt.extraCssText;\n var renderMode = opt.renderMode || 'html';\n var markerId = opt.markerId || 'X';\n\n if (!color) {\n return '';\n }\n\n if (renderMode === 'html') {\n return type === 'subItem' ? '<span style=\"display:inline-block;vertical-align:middle;margin-right:8px;margin-left:3px;' + 'border-radius:4px;width:4px;height:4px;background-color:' + encodeHTML(color) + ';' + (extraCssText || '') + '\"></span>' : '<span style=\"display:inline-block;margin-right:5px;' + 'border-radius:10px;width:10px;height:10px;background-color:' + encodeHTML(color) + ';' + (extraCssText || '') + '\"></span>';\n } else {\n // Space for rich element marker\n return {\n renderMode: renderMode,\n content: '{marker' + markerId + '|} ',\n style: {\n color: color\n }\n };\n }\n}\n\nfunction pad(str, len) {\n str += '';\n return '0000'.substr(0, len - str.length) + str;\n}\n/**\n * ISO Date format\n * @param {string} tpl\n * @param {number} value\n * @param {boolean} [isUTC=false] Default in local time.\n * see `module:echarts/scale/Time`\n * and `module:echarts/util/number#parseDate`.\n * @inner\n */\n\n\nfunction formatTime(tpl, value, isUTC) {\n if (tpl === 'week' || tpl === 'month' || tpl === 'quarter' || tpl === 'half-year' || tpl === 'year') {\n tpl = 'MM-dd\\nyyyy';\n }\n\n var date = numberUtil.parseDate(value);\n var utc = isUTC ? 'UTC' : '';\n var y = date['get' + utc + 'FullYear']();\n var M = date['get' + utc + 'Month']() + 1;\n var d = date['get' + utc + 'Date']();\n var h = date['get' + utc + 'Hours']();\n var m = date['get' + utc + 'Minutes']();\n var s = date['get' + utc + 'Seconds']();\n var S = date['get' + utc + 'Milliseconds']();\n tpl = tpl.replace('MM', pad(M, 2)).replace('M', M).replace('yyyy', y).replace('yy', y % 100).replace('dd', pad(d, 2)).replace('d', d).replace('hh', pad(h, 2)).replace('h', h).replace('mm', pad(m, 2)).replace('m', m).replace('ss', pad(s, 2)).replace('s', s).replace('SSS', pad(S, 3));\n return tpl;\n}\n/**\n * Capital first\n * @param {string} str\n * @return {string}\n */\n\n\nfunction capitalFirst(str) {\n return str ? str.charAt(0).toUpperCase() + str.substr(1) : str;\n}\n\nvar truncateText = textContain.truncateText;\n/**\n * @public\n * @param {Object} opt\n * @param {string} opt.text\n * @param {string} opt.font\n * @param {string} [opt.textAlign='left']\n * @param {string} [opt.textVerticalAlign='top']\n * @param {Array.<number>} [opt.textPadding]\n * @param {number} [opt.textLineHeight]\n * @param {Object} [opt.rich]\n * @param {Object} [opt.truncate]\n * @return {Object} {x, y, width, height, lineHeight}\n */\n\nfunction getTextBoundingRect(opt) {\n return textContain.getBoundingRect(opt.text, opt.font, opt.textAlign, opt.textVerticalAlign, opt.textPadding, opt.textLineHeight, opt.rich, opt.truncate);\n}\n/**\n * @deprecated\n * the `textLineHeight` was added later.\n * For backward compatiblility, put it as the last parameter.\n * But deprecated this interface. Please use `getTextBoundingRect` instead.\n */\n\n\nfunction getTextRect(text, font, textAlign, textVerticalAlign, textPadding, rich, truncate, textLineHeight) {\n return textContain.getBoundingRect(text, font, textAlign, textVerticalAlign, textPadding, textLineHeight, rich, truncate);\n}\n\nexports.addCommas = addCommas;\nexports.toCamelCase = toCamelCase;\nexports.normalizeCssArray = normalizeCssArray;\nexports.encodeHTML = encodeHTML;\nexports.formatTpl = formatTpl;\nexports.formatTplSimple = formatTplSimple;\nexports.getTooltipMarker = getTooltipMarker;\nexports.formatTime = formatTime;\nexports.capitalFirst = capitalFirst;\nexports.truncateText = truncateText;\nexports.getTextBoundingRect = getTextBoundingRect;\nexports.getTextRect = getTextRect;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar each = _util.each;\nvar isString = _util.isString;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * Note that it is too complicated to support 3d stack by value\n * (have to create two-dimension inverted index), so in 3d case\n * we just support that stacked by index.\n *\n * @param {module:echarts/model/Series} seriesModel\n * @param {Array.<string|Object>} dimensionInfoList The same as the input of <module:echarts/data/List>.\n * The input dimensionInfoList will be modified.\n * @param {Object} [opt]\n * @param {boolean} [opt.stackedCoordDimension=''] Specify a coord dimension if needed.\n * @param {boolean} [opt.byIndex=false]\n * @return {Object} calculationInfo\n * {\n * stackedDimension: string\n * stackedByDimension: string\n * isStackedByIndex: boolean\n * stackedOverDimension: string\n * stackResultDimension: string\n * }\n */\nfunction enableDataStack(seriesModel, dimensionInfoList, opt) {\n opt = opt || {};\n var byIndex = opt.byIndex;\n var stackedCoordDimension = opt.stackedCoordDimension; // Compatibal: when `stack` is set as '', do not stack.\n\n var mayStack = !!(seriesModel && seriesModel.get('stack'));\n var stackedByDimInfo;\n var stackedDimInfo;\n var stackResultDimension;\n var stackedOverDimension;\n each(dimensionInfoList, function (dimensionInfo, index) {\n if (isString(dimensionInfo)) {\n dimensionInfoList[index] = dimensionInfo = {\n name: dimensionInfo\n };\n }\n\n if (mayStack && !dimensionInfo.isExtraCoord) {\n // Find the first ordinal dimension as the stackedByDimInfo.\n if (!byIndex && !stackedByDimInfo && dimensionInfo.ordinalMeta) {\n stackedByDimInfo = dimensionInfo;\n } // Find the first stackable dimension as the stackedDimInfo.\n\n\n if (!stackedDimInfo && dimensionInfo.type !== 'ordinal' && dimensionInfo.type !== 'time' && (!stackedCoordDimension || stackedCoordDimension === dimensionInfo.coordDim)) {\n stackedDimInfo = dimensionInfo;\n }\n }\n });\n\n if (stackedDimInfo && !byIndex && !stackedByDimInfo) {\n // Compatible with previous design, value axis (time axis) only stack by index.\n // It may make sense if the user provides elaborately constructed data.\n byIndex = true;\n } // Add stack dimension, they can be both calculated by coordinate system in `unionExtent`.\n // That put stack logic in List is for using conveniently in echarts extensions, but it\n // might not be a good way.\n\n\n if (stackedDimInfo) {\n // Use a weird name that not duplicated with other names.\n stackResultDimension = '__\\0ecstackresult';\n stackedOverDimension = '__\\0ecstackedover'; // Create inverted index to fast query index by value.\n\n if (stackedByDimInfo) {\n stackedByDimInfo.createInvertedIndices = true;\n }\n\n var stackedDimCoordDim = stackedDimInfo.coordDim;\n var stackedDimType = stackedDimInfo.type;\n var stackedDimCoordIndex = 0;\n each(dimensionInfoList, function (dimensionInfo) {\n if (dimensionInfo.coordDim === stackedDimCoordDim) {\n stackedDimCoordIndex++;\n }\n });\n dimensionInfoList.push({\n name: stackResultDimension,\n coordDim: stackedDimCoordDim,\n coordDimIndex: stackedDimCoordIndex,\n type: stackedDimType,\n isExtraCoord: true,\n isCalculationCoord: true\n });\n stackedDimCoordIndex++;\n dimensionInfoList.push({\n name: stackedOverDimension,\n // This dimension contains stack base (generally, 0), so do not set it as\n // `stackedDimCoordDim` to avoid extent calculation, consider log scale.\n coordDim: stackedOverDimension,\n coordDimIndex: stackedDimCoordIndex,\n type: stackedDimType,\n isExtraCoord: true,\n isCalculationCoord: true\n });\n }\n\n return {\n stackedDimension: stackedDimInfo && stackedDimInfo.name,\n stackedByDimension: stackedByDimInfo && stackedByDimInfo.name,\n isStackedByIndex: byIndex,\n stackedOverDimension: stackedOverDimension,\n stackResultDimension: stackResultDimension\n };\n}\n/**\n * @param {module:echarts/data/List} data\n * @param {string} stackedDim\n */\n\n\nfunction isDimensionStacked(data, stackedDim\n/*, stackedByDim*/\n) {\n // Each single series only maps to one pair of axis. So we do not need to\n // check stackByDim, whatever stacked by a dimension or stacked by index.\n return !!stackedDim && stackedDim === data.getCalculationInfo('stackedDimension'); // && (\n // stackedByDim != null\n // ? stackedByDim === data.getCalculationInfo('stackedByDimension')\n // : data.getCalculationInfo('isStackedByIndex')\n // );\n}\n/**\n * @param {module:echarts/data/List} data\n * @param {string} targetDim\n * @param {string} [stackedByDim] If not input this parameter, check whether\n * stacked by index.\n * @return {string} dimension\n */\n\n\nfunction getStackedDimension(data, targetDim) {\n return isDimensionStacked(data, targetDim) ? data.getCalculationInfo('stackResultDimension') : targetDim;\n}\n\nexports.enableDataStack = enableDataStack;\nexports.isDimensionStacked = isDimensionStacked;\nexports.getStackedDimension = getStackedDimension;","var PathProxy = require(\"../core/PathProxy\");\n\nvar _vector = require(\"../core/vector\");\n\nvar v2ApplyTransform = _vector.applyTransform;\nvar CMD = PathProxy.CMD;\nvar points = [[], [], []];\nvar mathSqrt = Math.sqrt;\nvar mathAtan2 = Math.atan2;\n\nfunction _default(path, m) {\n var data = path.data;\n var cmd;\n var nPoint;\n var i;\n var j;\n var k;\n var p;\n var M = CMD.M;\n var C = CMD.C;\n var L = CMD.L;\n var R = CMD.R;\n var A = CMD.A;\n var Q = CMD.Q;\n\n for (i = 0, j = 0; i < data.length;) {\n cmd = data[i++];\n j = i;\n nPoint = 0;\n\n switch (cmd) {\n case M:\n nPoint = 1;\n break;\n\n case L:\n nPoint = 1;\n break;\n\n case C:\n nPoint = 3;\n break;\n\n case Q:\n nPoint = 2;\n break;\n\n case A:\n var x = m[4];\n var y = m[5];\n var sx = mathSqrt(m[0] * m[0] + m[1] * m[1]);\n var sy = mathSqrt(m[2] * m[2] + m[3] * m[3]);\n var angle = mathAtan2(-m[1] / sy, m[0] / sx); // cx\n\n data[i] *= sx;\n data[i++] += x; // cy\n\n data[i] *= sy;\n data[i++] += y; // Scale rx and ry\n // FIXME Assume psi is 0 here\n\n data[i++] *= sx;\n data[i++] *= sy; // Start angle\n\n data[i++] += angle; // end angle\n\n data[i++] += angle; // FIXME psi\n\n i += 2;\n j = i;\n break;\n\n case R:\n // x0, y0\n p[0] = data[i++];\n p[1] = data[i++];\n v2ApplyTransform(p, p, m);\n data[j++] = p[0];\n data[j++] = p[1]; // x1, y1\n\n p[0] += data[i++];\n p[1] += data[i++];\n v2ApplyTransform(p, p, m);\n data[j++] = p[0];\n data[j++] = p[1];\n }\n\n for (k = 0; k < nPoint; k++) {\n var p = points[k];\n p[0] = data[i++];\n p[1] = data[i++];\n v2ApplyTransform(p, p, m); // Write back\n\n data[j++] = p[0];\n data[j++] = p[1];\n }\n }\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar echarts = require(\"../echarts\");\n\nrequire(\"./line/LineSeries\");\n\nrequire(\"./line/LineView\");\n\nvar visualSymbol = require(\"../visual/symbol\");\n\nvar layoutPoints = require(\"../layout/points\");\n\nvar dataSample = require(\"../processor/dataSample\");\n\nrequire(\"../component/gridSimple\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// In case developer forget to include grid component\necharts.registerVisual(visualSymbol('line', 'circle', 'line'));\necharts.registerLayout(layoutPoints('line')); // Down sample after filter\n\necharts.registerProcessor(echarts.PRIORITY.PROCESSOR.STATISTIC, dataSample('line'));","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _helper = require(\"./helper\");\n\nvar prepareDataCoordInfo = _helper.prepareDataCoordInfo;\nvar getStackedOnPoint = _helper.getStackedOnPoint;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// var arrayDiff = require('zrender/src/core/arrayDiff');\n// 'zrender/src/core/arrayDiff' has been used before, but it did\n// not do well in performance when roam with fixed dataZoom window.\n// function convertToIntId(newIdList, oldIdList) {\n// // Generate int id instead of string id.\n// // Compare string maybe slow in score function of arrDiff\n// // Assume id in idList are all unique\n// var idIndicesMap = {};\n// var idx = 0;\n// for (var i = 0; i < newIdList.length; i++) {\n// idIndicesMap[newIdList[i]] = idx;\n// newIdList[i] = idx++;\n// }\n// for (var i = 0; i < oldIdList.length; i++) {\n// var oldId = oldIdList[i];\n// // Same with newIdList\n// if (idIndicesMap[oldId]) {\n// oldIdList[i] = idIndicesMap[oldId];\n// }\n// else {\n// oldIdList[i] = idx++;\n// }\n// }\n// }\nfunction diffData(oldData, newData) {\n var diffResult = [];\n newData.diff(oldData).add(function (idx) {\n diffResult.push({\n cmd: '+',\n idx: idx\n });\n }).update(function (newIdx, oldIdx) {\n diffResult.push({\n cmd: '=',\n idx: oldIdx,\n idx1: newIdx\n });\n }).remove(function (idx) {\n diffResult.push({\n cmd: '-',\n idx: idx\n });\n }).execute();\n return diffResult;\n}\n\nfunction _default(oldData, newData, oldStackedOnPoints, newStackedOnPoints, oldCoordSys, newCoordSys, oldValueOrigin, newValueOrigin) {\n var diff = diffData(oldData, newData); // var newIdList = newData.mapArray(newData.getId);\n // var oldIdList = oldData.mapArray(oldData.getId);\n // convertToIntId(newIdList, oldIdList);\n // // FIXME One data ?\n // diff = arrayDiff(oldIdList, newIdList);\n\n var currPoints = [];\n var nextPoints = []; // Points for stacking base line\n\n var currStackedPoints = [];\n var nextStackedPoints = [];\n var status = [];\n var sortedIndices = [];\n var rawIndices = [];\n var newDataOldCoordInfo = prepareDataCoordInfo(oldCoordSys, newData, oldValueOrigin);\n var oldDataNewCoordInfo = prepareDataCoordInfo(newCoordSys, oldData, newValueOrigin);\n\n for (var i = 0; i < diff.length; i++) {\n var diffItem = diff[i];\n var pointAdded = true; // FIXME, animation is not so perfect when dataZoom window moves fast\n // Which is in case remvoing or add more than one data in the tail or head\n\n switch (diffItem.cmd) {\n case '=':\n var currentPt = oldData.getItemLayout(diffItem.idx);\n var nextPt = newData.getItemLayout(diffItem.idx1); // If previous data is NaN, use next point directly\n\n if (isNaN(currentPt[0]) || isNaN(currentPt[1])) {\n currentPt = nextPt.slice();\n }\n\n currPoints.push(currentPt);\n nextPoints.push(nextPt);\n currStackedPoints.push(oldStackedOnPoints[diffItem.idx]);\n nextStackedPoints.push(newStackedOnPoints[diffItem.idx1]);\n rawIndices.push(newData.getRawIndex(diffItem.idx1));\n break;\n\n case '+':\n var idx = diffItem.idx;\n currPoints.push(oldCoordSys.dataToPoint([newData.get(newDataOldCoordInfo.dataDimsForPoint[0], idx), newData.get(newDataOldCoordInfo.dataDimsForPoint[1], idx)]));\n nextPoints.push(newData.getItemLayout(idx).slice());\n currStackedPoints.push(getStackedOnPoint(newDataOldCoordInfo, oldCoordSys, newData, idx));\n nextStackedPoints.push(newStackedOnPoints[idx]);\n rawIndices.push(newData.getRawIndex(idx));\n break;\n\n case '-':\n var idx = diffItem.idx;\n var rawIndex = oldData.getRawIndex(idx); // Data is replaced. In the case of dynamic data queue\n // FIXME FIXME FIXME\n\n if (rawIndex !== idx) {\n currPoints.push(oldData.getItemLayout(idx));\n nextPoints.push(newCoordSys.dataToPoint([oldData.get(oldDataNewCoordInfo.dataDimsForPoint[0], idx), oldData.get(oldDataNewCoordInfo.dataDimsForPoint[1], idx)]));\n currStackedPoints.push(oldStackedOnPoints[idx]);\n nextStackedPoints.push(getStackedOnPoint(oldDataNewCoordInfo, newCoordSys, oldData, idx));\n rawIndices.push(rawIndex);\n } else {\n pointAdded = false;\n }\n\n } // Original indices\n\n\n if (pointAdded) {\n status.push(diffItem);\n sortedIndices.push(sortedIndices.length);\n }\n } // Diff result may be crossed if all items are changed\n // Sort by data index\n\n\n sortedIndices.sort(function (a, b) {\n return rawIndices[a] - rawIndices[b];\n });\n var sortedCurrPoints = [];\n var sortedNextPoints = [];\n var sortedCurrStackedPoints = [];\n var sortedNextStackedPoints = [];\n var sortedStatus = [];\n\n for (var i = 0; i < sortedIndices.length; i++) {\n var idx = sortedIndices[i];\n sortedCurrPoints[i] = currPoints[idx];\n sortedNextPoints[i] = nextPoints[idx];\n sortedCurrStackedPoints[i] = currStackedPoints[idx];\n sortedNextStackedPoints[i] = nextStackedPoints[idx];\n sortedStatus[i] = status[idx];\n }\n\n return {\n current: sortedCurrPoints,\n next: sortedNextPoints,\n stackedOnCurrent: sortedCurrStackedPoints,\n stackedOnNext: sortedNextStackedPoints,\n status: sortedStatus\n };\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _config = require(\"../../config\");\n\nvar __DEV__ = _config.__DEV__;\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar SymbolDraw = require(\"../helper/SymbolDraw\");\n\nvar SymbolClz = require(\"../helper/Symbol\");\n\nvar lineAnimationDiff = require(\"./lineAnimationDiff\");\n\nvar graphic = require(\"../../util/graphic\");\n\nvar modelUtil = require(\"../../util/model\");\n\nvar _poly = require(\"./poly\");\n\nvar Polyline = _poly.Polyline;\nvar Polygon = _poly.Polygon;\n\nvar ChartView = require(\"../../view/Chart\");\n\nvar _number = require(\"../../util/number\");\n\nvar round = _number.round;\n\nvar _helper = require(\"./helper\");\n\nvar prepareDataCoordInfo = _helper.prepareDataCoordInfo;\nvar getStackedOnPoint = _helper.getStackedOnPoint;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// FIXME step not support polar\nfunction isPointsSame(points1, points2) {\n if (points1.length !== points2.length) {\n return;\n }\n\n for (var i = 0; i < points1.length; i++) {\n var p1 = points1[i];\n var p2 = points2[i];\n\n if (p1[0] !== p2[0] || p1[1] !== p2[1]) {\n return;\n }\n }\n\n return true;\n}\n\nfunction getSmooth(smooth) {\n return typeof smooth === 'number' ? smooth : smooth ? 0.5 : 0;\n}\n\nfunction getAxisExtentWithGap(axis) {\n var extent = axis.getGlobalExtent();\n\n if (axis.onBand) {\n // Remove extra 1px to avoid line miter in clipped edge\n var halfBandWidth = axis.getBandWidth() / 2 - 1;\n var dir = extent[1] > extent[0] ? 1 : -1;\n extent[0] += dir * halfBandWidth;\n extent[1] -= dir * halfBandWidth;\n }\n\n return extent;\n}\n/**\n * @param {module:echarts/coord/cartesian/Cartesian2D|module:echarts/coord/polar/Polar} coordSys\n * @param {module:echarts/data/List} data\n * @param {Object} dataCoordInfo\n * @param {Array.<Array.<number>>} points\n */\n\n\nfunction getStackedOnPoints(coordSys, data, dataCoordInfo) {\n if (!dataCoordInfo.valueDim) {\n return [];\n }\n\n var points = [];\n\n for (var idx = 0, len = data.count(); idx < len; idx++) {\n points.push(getStackedOnPoint(dataCoordInfo, coordSys, data, idx));\n }\n\n return points;\n}\n\nfunction createGridClipShape(cartesian, hasAnimation, forSymbol, seriesModel) {\n var xExtent = getAxisExtentWithGap(cartesian.getAxis('x'));\n var yExtent = getAxisExtentWithGap(cartesian.getAxis('y'));\n var isHorizontal = cartesian.getBaseAxis().isHorizontal();\n var x = Math.min(xExtent[0], xExtent[1]);\n var y = Math.min(yExtent[0], yExtent[1]);\n var width = Math.max(xExtent[0], xExtent[1]) - x;\n var height = Math.max(yExtent[0], yExtent[1]) - y; // Avoid float number rounding error for symbol on the edge of axis extent.\n // See #7913 and `test/dataZoom-clip.html`.\n\n if (forSymbol) {\n x -= 0.5;\n width += 0.5;\n y -= 0.5;\n height += 0.5;\n } else {\n var lineWidth = seriesModel.get('lineStyle.width') || 2; // Expand clip shape to avoid clipping when line value exceeds axis\n\n var expandSize = seriesModel.get('clipOverflow') ? lineWidth / 2 : Math.max(width, height);\n\n if (isHorizontal) {\n y -= expandSize;\n height += expandSize * 2;\n } else {\n x -= expandSize;\n width += expandSize * 2;\n }\n }\n\n var clipPath = new graphic.Rect({\n shape: {\n x: x,\n y: y,\n width: width,\n height: height\n }\n });\n\n if (hasAnimation) {\n clipPath.shape[isHorizontal ? 'width' : 'height'] = 0;\n graphic.initProps(clipPath, {\n shape: {\n width: width,\n height: height\n }\n }, seriesModel);\n }\n\n return clipPath;\n}\n\nfunction createPolarClipShape(polar, hasAnimation, forSymbol, seriesModel) {\n var angleAxis = polar.getAngleAxis();\n var radiusAxis = polar.getRadiusAxis();\n var radiusExtent = radiusAxis.getExtent().slice();\n radiusExtent[0] > radiusExtent[1] && radiusExtent.reverse();\n var angleExtent = angleAxis.getExtent();\n var RADIAN = Math.PI / 180; // Avoid float number rounding error for symbol on the edge of axis extent.\n\n if (forSymbol) {\n radiusExtent[0] -= 0.5;\n radiusExtent[1] += 0.5;\n }\n\n var clipPath = new graphic.Sector({\n shape: {\n cx: round(polar.cx, 1),\n cy: round(polar.cy, 1),\n r0: round(radiusExtent[0], 1),\n r: round(radiusExtent[1], 1),\n startAngle: -angleExtent[0] * RADIAN,\n endAngle: -angleExtent[1] * RADIAN,\n clockwise: angleAxis.inverse\n }\n });\n\n if (hasAnimation) {\n clipPath.shape.endAngle = -angleExtent[0] * RADIAN;\n graphic.initProps(clipPath, {\n shape: {\n endAngle: -angleExtent[1] * RADIAN\n }\n }, seriesModel);\n }\n\n return clipPath;\n}\n\nfunction createClipShape(coordSys, hasAnimation, forSymbol, seriesModel) {\n return coordSys.type === 'polar' ? createPolarClipShape(coordSys, hasAnimation, forSymbol, seriesModel) : createGridClipShape(coordSys, hasAnimation, forSymbol, seriesModel);\n}\n\nfunction turnPointsIntoStep(points, coordSys, stepTurnAt) {\n var baseAxis = coordSys.getBaseAxis();\n var baseIndex = baseAxis.dim === 'x' || baseAxis.dim === 'radius' ? 0 : 1;\n var stepPoints = [];\n\n for (var i = 0; i < points.length - 1; i++) {\n var nextPt = points[i + 1];\n var pt = points[i];\n stepPoints.push(pt);\n var stepPt = [];\n\n switch (stepTurnAt) {\n case 'end':\n stepPt[baseIndex] = nextPt[baseIndex];\n stepPt[1 - baseIndex] = pt[1 - baseIndex]; // default is start\n\n stepPoints.push(stepPt);\n break;\n\n case 'middle':\n // default is start\n var middle = (pt[baseIndex] + nextPt[baseIndex]) / 2;\n var stepPt2 = [];\n stepPt[baseIndex] = stepPt2[baseIndex] = middle;\n stepPt[1 - baseIndex] = pt[1 - baseIndex];\n stepPt2[1 - baseIndex] = nextPt[1 - baseIndex];\n stepPoints.push(stepPt);\n stepPoints.push(stepPt2);\n break;\n\n default:\n stepPt[baseIndex] = pt[baseIndex];\n stepPt[1 - baseIndex] = nextPt[1 - baseIndex]; // default is start\n\n stepPoints.push(stepPt);\n }\n } // Last points\n\n\n points[i] && stepPoints.push(points[i]);\n return stepPoints;\n}\n\nfunction getVisualGradient(data, coordSys) {\n var visualMetaList = data.getVisual('visualMeta');\n\n if (!visualMetaList || !visualMetaList.length || !data.count()) {\n // When data.count() is 0, gradient range can not be calculated.\n return;\n }\n\n if (coordSys.type !== 'cartesian2d') {\n return;\n }\n\n var coordDim;\n var visualMeta;\n\n for (var i = visualMetaList.length - 1; i >= 0; i--) {\n var dimIndex = visualMetaList[i].dimension;\n var dimName = data.dimensions[dimIndex];\n var dimInfo = data.getDimensionInfo(dimName);\n coordDim = dimInfo && dimInfo.coordDim; // Can only be x or y\n\n if (coordDim === 'x' || coordDim === 'y') {\n visualMeta = visualMetaList[i];\n break;\n }\n }\n\n if (!visualMeta) {\n return;\n } // If the area to be rendered is bigger than area defined by LinearGradient,\n // the canvas spec prescribes that the color of the first stop and the last\n // stop should be used. But if two stops are added at offset 0, in effect\n // browsers use the color of the second stop to render area outside\n // LinearGradient. So we can only infinitesimally extend area defined in\n // LinearGradient to render `outerColors`.\n\n\n var axis = coordSys.getAxis(coordDim); // dataToCoor mapping may not be linear, but must be monotonic.\n\n var colorStops = zrUtil.map(visualMeta.stops, function (stop) {\n return {\n coord: axis.toGlobalCoord(axis.dataToCoord(stop.value)),\n color: stop.color\n };\n });\n var stopLen = colorStops.length;\n var outerColors = visualMeta.outerColors.slice();\n\n if (stopLen && colorStops[0].coord > colorStops[stopLen - 1].coord) {\n colorStops.reverse();\n outerColors.reverse();\n }\n\n var tinyExtent = 10; // Arbitrary value: 10px\n\n var minCoord = colorStops[0].coord - tinyExtent;\n var maxCoord = colorStops[stopLen - 1].coord + tinyExtent;\n var coordSpan = maxCoord - minCoord;\n\n if (coordSpan < 1e-3) {\n return 'transparent';\n }\n\n zrUtil.each(colorStops, function (stop) {\n stop.offset = (stop.coord - minCoord) / coordSpan;\n });\n colorStops.push({\n offset: stopLen ? colorStops[stopLen - 1].offset : 0.5,\n color: outerColors[1] || 'transparent'\n });\n colorStops.unshift({\n // notice colorStops.length have been changed.\n offset: stopLen ? colorStops[0].offset : 0.5,\n color: outerColors[0] || 'transparent'\n }); // zrUtil.each(colorStops, function (colorStop) {\n // // Make sure each offset has rounded px to avoid not sharp edge\n // colorStop.offset = (Math.round(colorStop.offset * (end - start) + start) - start) / (end - start);\n // });\n\n var gradient = new graphic.LinearGradient(0, 0, 0, 0, colorStops, true);\n gradient[coordDim] = minCoord;\n gradient[coordDim + '2'] = maxCoord;\n return gradient;\n}\n\nfunction getIsIgnoreFunc(seriesModel, data, coordSys) {\n var showAllSymbol = seriesModel.get('showAllSymbol');\n var isAuto = showAllSymbol === 'auto';\n\n if (showAllSymbol && !isAuto) {\n return;\n }\n\n var categoryAxis = coordSys.getAxesByScale('ordinal')[0];\n\n if (!categoryAxis) {\n return;\n } // Note that category label interval strategy might bring some weird effect\n // in some scenario: users may wonder why some of the symbols are not\n // displayed. So we show all symbols as possible as we can.\n\n\n if (isAuto // Simplify the logic, do not determine label overlap here.\n && canShowAllSymbolForCategory(categoryAxis, data)) {\n return;\n } // Otherwise follow the label interval strategy on category axis.\n\n\n var categoryDataDim = data.mapDimension(categoryAxis.dim);\n var labelMap = {};\n zrUtil.each(categoryAxis.getViewLabels(), function (labelItem) {\n labelMap[labelItem.tickValue] = 1;\n });\n return function (dataIndex) {\n return !labelMap.hasOwnProperty(data.get(categoryDataDim, dataIndex));\n };\n}\n\nfunction canShowAllSymbolForCategory(categoryAxis, data) {\n // In mose cases, line is monotonous on category axis, and the label size\n // is close with each other. So we check the symbol size and some of the\n // label size alone with the category axis to estimate whether all symbol\n // can be shown without overlap.\n var axisExtent = categoryAxis.getExtent();\n var availSize = Math.abs(axisExtent[1] - axisExtent[0]) / categoryAxis.scale.count();\n isNaN(availSize) && (availSize = 0); // 0/0 is NaN.\n // Sampling some points, max 5.\n\n var dataLen = data.count();\n var step = Math.max(1, Math.round(dataLen / 5));\n\n for (var dataIndex = 0; dataIndex < dataLen; dataIndex += step) {\n if (SymbolClz.getSymbolSize(data, dataIndex // Only for cartesian, where `isHorizontal` exists.\n )[categoryAxis.isHorizontal() ? 1 : 0] // Empirical number\n * 1.5 > availSize) {\n return false;\n }\n }\n\n return true;\n}\n\nvar _default = ChartView.extend({\n type: 'line',\n init: function () {\n var lineGroup = new graphic.Group();\n var symbolDraw = new SymbolDraw();\n this.group.add(symbolDraw.group);\n this._symbolDraw = symbolDraw;\n this._lineGroup = lineGroup;\n },\n render: function (seriesModel, ecModel, api) {\n var coordSys = seriesModel.coordinateSystem;\n var group = this.group;\n var data = seriesModel.getData();\n var lineStyleModel = seriesModel.getModel('lineStyle');\n var areaStyleModel = seriesModel.getModel('areaStyle');\n var points = data.mapArray(data.getItemLayout);\n var isCoordSysPolar = coordSys.type === 'polar';\n var prevCoordSys = this._coordSys;\n var symbolDraw = this._symbolDraw;\n var polyline = this._polyline;\n var polygon = this._polygon;\n var lineGroup = this._lineGroup;\n var hasAnimation = seriesModel.get('animation');\n var isAreaChart = !areaStyleModel.isEmpty();\n var valueOrigin = areaStyleModel.get('origin');\n var dataCoordInfo = prepareDataCoordInfo(coordSys, data, valueOrigin);\n var stackedOnPoints = getStackedOnPoints(coordSys, data, dataCoordInfo);\n var showSymbol = seriesModel.get('showSymbol');\n var isIgnoreFunc = showSymbol && !isCoordSysPolar && getIsIgnoreFunc(seriesModel, data, coordSys); // Remove temporary symbols\n\n var oldData = this._data;\n oldData && oldData.eachItemGraphicEl(function (el, idx) {\n if (el.__temp) {\n group.remove(el);\n oldData.setItemGraphicEl(idx, null);\n }\n }); // Remove previous created symbols if showSymbol changed to false\n\n if (!showSymbol) {\n symbolDraw.remove();\n }\n\n group.add(lineGroup); // FIXME step not support polar\n\n var step = !isCoordSysPolar && seriesModel.get('step'); // Initialization animation or coordinate system changed\n\n if (!(polyline && prevCoordSys.type === coordSys.type && step === this._step)) {\n showSymbol && symbolDraw.updateData(data, {\n isIgnore: isIgnoreFunc,\n clipShape: createClipShape(coordSys, false, true, seriesModel)\n });\n\n if (step) {\n // TODO If stacked series is not step\n points = turnPointsIntoStep(points, coordSys, step);\n stackedOnPoints = turnPointsIntoStep(stackedOnPoints, coordSys, step);\n }\n\n polyline = this._newPolyline(points, coordSys, hasAnimation);\n\n if (isAreaChart) {\n polygon = this._newPolygon(points, stackedOnPoints, coordSys, hasAnimation);\n }\n\n lineGroup.setClipPath(createClipShape(coordSys, true, false, seriesModel));\n } else {\n if (isAreaChart && !polygon) {\n // If areaStyle is added\n polygon = this._newPolygon(points, stackedOnPoints, coordSys, hasAnimation);\n } else if (polygon && !isAreaChart) {\n // If areaStyle is removed\n lineGroup.remove(polygon);\n polygon = this._polygon = null;\n } // Update clipPath\n\n\n lineGroup.setClipPath(createClipShape(coordSys, false, false, seriesModel)); // Always update, or it is wrong in the case turning on legend\n // because points are not changed\n\n showSymbol && symbolDraw.updateData(data, {\n isIgnore: isIgnoreFunc,\n clipShape: createClipShape(coordSys, false, true, seriesModel)\n }); // Stop symbol animation and sync with line points\n // FIXME performance?\n\n data.eachItemGraphicEl(function (el) {\n el.stopAnimation(true);\n }); // In the case data zoom triggerred refreshing frequently\n // Data may not change if line has a category axis. So it should animate nothing\n\n if (!isPointsSame(this._stackedOnPoints, stackedOnPoints) || !isPointsSame(this._points, points)) {\n if (hasAnimation) {\n this._updateAnimation(data, stackedOnPoints, coordSys, api, step, valueOrigin);\n } else {\n // Not do it in update with animation\n if (step) {\n // TODO If stacked series is not step\n points = turnPointsIntoStep(points, coordSys, step);\n stackedOnPoints = turnPointsIntoStep(stackedOnPoints, coordSys, step);\n }\n\n polyline.setShape({\n points: points\n });\n polygon && polygon.setShape({\n points: points,\n stackedOnPoints: stackedOnPoints\n });\n }\n }\n }\n\n var visualColor = getVisualGradient(data, coordSys) || data.getVisual('color');\n polyline.useStyle(zrUtil.defaults( // Use color in lineStyle first\n lineStyleModel.getLineStyle(), {\n fill: 'none',\n stroke: visualColor,\n lineJoin: 'bevel'\n }));\n var smooth = seriesModel.get('smooth');\n smooth = getSmooth(seriesModel.get('smooth'));\n polyline.setShape({\n smooth: smooth,\n smoothMonotone: seriesModel.get('smoothMonotone'),\n connectNulls: seriesModel.get('connectNulls')\n });\n\n if (polygon) {\n var stackedOnSeries = data.getCalculationInfo('stackedOnSeries');\n var stackedOnSmooth = 0;\n polygon.useStyle(zrUtil.defaults(areaStyleModel.getAreaStyle(), {\n fill: visualColor,\n opacity: 0.7,\n lineJoin: 'bevel'\n }));\n\n if (stackedOnSeries) {\n stackedOnSmooth = getSmooth(stackedOnSeries.get('smooth'));\n }\n\n polygon.setShape({\n smooth: smooth,\n stackedOnSmooth: stackedOnSmooth,\n smoothMonotone: seriesModel.get('smoothMonotone'),\n connectNulls: seriesModel.get('connectNulls')\n });\n }\n\n this._data = data; // Save the coordinate system for transition animation when data changed\n\n this._coordSys = coordSys;\n this._stackedOnPoints = stackedOnPoints;\n this._points = points;\n this._step = step;\n this._valueOrigin = valueOrigin;\n },\n dispose: function () {},\n highlight: function (seriesModel, ecModel, api, payload) {\n var data = seriesModel.getData();\n var dataIndex = modelUtil.queryDataIndex(data, payload);\n\n if (!(dataIndex instanceof Array) && dataIndex != null && dataIndex >= 0) {\n var symbol = data.getItemGraphicEl(dataIndex);\n\n if (!symbol) {\n // Create a temporary symbol if it is not exists\n var pt = data.getItemLayout(dataIndex);\n\n if (!pt) {\n // Null data\n return;\n }\n\n symbol = new SymbolClz(data, dataIndex);\n symbol.position = pt;\n symbol.setZ(seriesModel.get('zlevel'), seriesModel.get('z'));\n symbol.ignore = isNaN(pt[0]) || isNaN(pt[1]);\n symbol.__temp = true;\n data.setItemGraphicEl(dataIndex, symbol); // Stop scale animation\n\n symbol.stopSymbolAnimation(true);\n this.group.add(symbol);\n }\n\n symbol.highlight();\n } else {\n // Highlight whole series\n ChartView.prototype.highlight.call(this, seriesModel, ecModel, api, payload);\n }\n },\n downplay: function (seriesModel, ecModel, api, payload) {\n var data = seriesModel.getData();\n var dataIndex = modelUtil.queryDataIndex(data, payload);\n\n if (dataIndex != null && dataIndex >= 0) {\n var symbol = data.getItemGraphicEl(dataIndex);\n\n if (symbol) {\n if (symbol.__temp) {\n data.setItemGraphicEl(dataIndex, null);\n this.group.remove(symbol);\n } else {\n symbol.downplay();\n }\n }\n } else {\n // FIXME\n // can not downplay completely.\n // Downplay whole series\n ChartView.prototype.downplay.call(this, seriesModel, ecModel, api, payload);\n }\n },\n\n /**\n * @param {module:zrender/container/Group} group\n * @param {Array.<Array.<number>>} points\n * @private\n */\n _newPolyline: function (points) {\n var polyline = this._polyline; // Remove previous created polyline\n\n if (polyline) {\n this._lineGroup.remove(polyline);\n }\n\n polyline = new Polyline({\n shape: {\n points: points\n },\n silent: true,\n z2: 10\n });\n\n this._lineGroup.add(polyline);\n\n this._polyline = polyline;\n return polyline;\n },\n\n /**\n * @param {module:zrender/container/Group} group\n * @param {Array.<Array.<number>>} stackedOnPoints\n * @param {Array.<Array.<number>>} points\n * @private\n */\n _newPolygon: function (points, stackedOnPoints) {\n var polygon = this._polygon; // Remove previous created polygon\n\n if (polygon) {\n this._lineGroup.remove(polygon);\n }\n\n polygon = new Polygon({\n shape: {\n points: points,\n stackedOnPoints: stackedOnPoints\n },\n silent: true\n });\n\n this._lineGroup.add(polygon);\n\n this._polygon = polygon;\n return polygon;\n },\n\n /**\n * @private\n */\n // FIXME Two value axis\n _updateAnimation: function (data, stackedOnPoints, coordSys, api, step, valueOrigin) {\n var polyline = this._polyline;\n var polygon = this._polygon;\n var seriesModel = data.hostModel;\n var diff = lineAnimationDiff(this._data, data, this._stackedOnPoints, stackedOnPoints, this._coordSys, coordSys, this._valueOrigin, valueOrigin);\n var current = diff.current;\n var stackedOnCurrent = diff.stackedOnCurrent;\n var next = diff.next;\n var stackedOnNext = diff.stackedOnNext;\n\n if (step) {\n // TODO If stacked series is not step\n current = turnPointsIntoStep(diff.current, coordSys, step);\n stackedOnCurrent = turnPointsIntoStep(diff.stackedOnCurrent, coordSys, step);\n next = turnPointsIntoStep(diff.next, coordSys, step);\n stackedOnNext = turnPointsIntoStep(diff.stackedOnNext, coordSys, step);\n } // `diff.current` is subset of `current` (which should be ensured by\n // turnPointsIntoStep), so points in `__points` can be updated when\n // points in `current` are update during animation.\n\n\n polyline.shape.__points = diff.current;\n polyline.shape.points = current;\n graphic.updateProps(polyline, {\n shape: {\n points: next\n }\n }, seriesModel);\n\n if (polygon) {\n polygon.setShape({\n points: current,\n stackedOnPoints: stackedOnCurrent\n });\n graphic.updateProps(polygon, {\n shape: {\n points: next,\n stackedOnPoints: stackedOnNext\n }\n }, seriesModel);\n }\n\n var updatedDataInfo = [];\n var diffStatus = diff.status;\n\n for (var i = 0; i < diffStatus.length; i++) {\n var cmd = diffStatus[i].cmd;\n\n if (cmd === '=') {\n var el = data.getItemGraphicEl(diffStatus[i].idx1);\n\n if (el) {\n updatedDataInfo.push({\n el: el,\n ptIdx: i // Index of points\n\n });\n }\n }\n }\n\n if (polyline.animators && polyline.animators.length) {\n polyline.animators[0].during(function () {\n for (var i = 0; i < updatedDataInfo.length; i++) {\n var el = updatedDataInfo[i].el;\n el.attr('position', polyline.shape.__points[updatedDataInfo[i].ptIdx]);\n }\n });\n }\n },\n remove: function (ecModel) {\n var group = this.group;\n var oldData = this._data;\n\n this._lineGroup.removeAll();\n\n this._symbolDraw.remove(true); // Remove temporary created elements when highlighting\n\n\n oldData && oldData.eachItemGraphicEl(function (el, idx) {\n if (el.__temp) {\n group.remove(el);\n oldData.setItemGraphicEl(idx, null);\n }\n });\n this._polyline = this._polygon = this._coordSys = this._points = this._stackedOnPoints = this._data = null;\n }\n});\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar contrastColor = '#eee';\n\nvar axisCommon = function () {\n return {\n axisLine: {\n lineStyle: {\n color: contrastColor\n }\n },\n axisTick: {\n lineStyle: {\n color: contrastColor\n }\n },\n axisLabel: {\n textStyle: {\n color: contrastColor\n }\n },\n splitLine: {\n lineStyle: {\n type: 'dashed',\n color: '#aaa'\n }\n },\n splitArea: {\n areaStyle: {\n color: contrastColor\n }\n }\n };\n};\n\nvar colorPalette = ['#dd6b66', '#759aa0', '#e69d87', '#8dc1a9', '#ea7e53', '#eedd78', '#73a373', '#73b9bc', '#7289ab', '#91ca8c', '#f49f42'];\nvar theme = {\n color: colorPalette,\n backgroundColor: '#333',\n tooltip: {\n axisPointer: {\n lineStyle: {\n color: contrastColor\n },\n crossStyle: {\n color: contrastColor\n }\n }\n },\n legend: {\n textStyle: {\n color: contrastColor\n }\n },\n textStyle: {\n color: contrastColor\n },\n title: {\n textStyle: {\n color: contrastColor\n }\n },\n toolbox: {\n iconStyle: {\n normal: {\n borderColor: contrastColor\n }\n }\n },\n dataZoom: {\n textStyle: {\n color: contrastColor\n }\n },\n visualMap: {\n textStyle: {\n color: contrastColor\n }\n },\n timeline: {\n lineStyle: {\n color: contrastColor\n },\n itemStyle: {\n normal: {\n color: colorPalette[1]\n }\n },\n label: {\n normal: {\n textStyle: {\n color: contrastColor\n }\n }\n },\n controlStyle: {\n normal: {\n color: contrastColor,\n borderColor: contrastColor\n }\n }\n },\n timeAxis: axisCommon(),\n logAxis: axisCommon(),\n valueAxis: axisCommon(),\n categoryAxis: axisCommon(),\n line: {\n symbol: 'circle'\n },\n graph: {\n color: colorPalette\n },\n gauge: {\n title: {\n textStyle: {\n color: contrastColor\n }\n }\n },\n candlestick: {\n itemStyle: {\n normal: {\n color: '#FD1050',\n color0: '#0CF49B',\n borderColor: '#FD1050',\n borderColor0: '#0CF49B'\n }\n }\n }\n};\ntheme.categoryAxis.splitLine.show = false;\nvar _default = theme;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar graphic = require(\"../../util/graphic\");\n\nvar AxisBuilder = require(\"./AxisBuilder\");\n\nvar AxisView = require(\"./AxisView\");\n\nvar cartesianAxisHelper = require(\"../../coord/cartesian/cartesianAxisHelper\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar axisBuilderAttrs = ['axisLine', 'axisTickLabel', 'axisName'];\nvar selfBuilderAttrs = ['splitArea', 'splitLine']; // function getAlignWithLabel(model, axisModel) {\n// var alignWithLabel = model.get('alignWithLabel');\n// if (alignWithLabel === 'auto') {\n// alignWithLabel = axisModel.get('axisTick.alignWithLabel');\n// }\n// return alignWithLabel;\n// }\n\nvar CartesianAxisView = AxisView.extend({\n type: 'cartesianAxis',\n axisPointerClass: 'CartesianAxisPointer',\n\n /**\n * @override\n */\n render: function (axisModel, ecModel, api, payload) {\n this.group.removeAll();\n var oldAxisGroup = this._axisGroup;\n this._axisGroup = new graphic.Group();\n this.group.add(this._axisGroup);\n\n if (!axisModel.get('show')) {\n return;\n }\n\n var gridModel = axisModel.getCoordSysModel();\n var layout = cartesianAxisHelper.layout(gridModel, axisModel);\n var axisBuilder = new AxisBuilder(axisModel, layout);\n zrUtil.each(axisBuilderAttrs, axisBuilder.add, axisBuilder);\n\n this._axisGroup.add(axisBuilder.getGroup());\n\n zrUtil.each(selfBuilderAttrs, function (name) {\n if (axisModel.get(name + '.show')) {\n this['_' + name](axisModel, gridModel);\n }\n }, this);\n graphic.groupTransition(oldAxisGroup, this._axisGroup, axisModel);\n CartesianAxisView.superCall(this, 'render', axisModel, ecModel, api, payload);\n },\n remove: function () {\n this._splitAreaColors = null;\n },\n\n /**\n * @param {module:echarts/coord/cartesian/AxisModel} axisModel\n * @param {module:echarts/coord/cartesian/GridModel} gridModel\n * @private\n */\n _splitLine: function (axisModel, gridModel) {\n var axis = axisModel.axis;\n\n if (axis.scale.isBlank()) {\n return;\n }\n\n var splitLineModel = axisModel.getModel('splitLine');\n var lineStyleModel = splitLineModel.getModel('lineStyle');\n var lineColors = lineStyleModel.get('color');\n lineColors = zrUtil.isArray(lineColors) ? lineColors : [lineColors];\n var gridRect = gridModel.coordinateSystem.getRect();\n var isHorizontal = axis.isHorizontal();\n var lineCount = 0;\n var ticksCoords = axis.getTicksCoords({\n tickModel: splitLineModel\n });\n var p1 = [];\n var p2 = []; // Simple optimization\n // Batching the lines if color are the same\n\n var lineStyle = lineStyleModel.getLineStyle();\n\n for (var i = 0; i < ticksCoords.length; i++) {\n var tickCoord = axis.toGlobalCoord(ticksCoords[i].coord);\n\n if (isHorizontal) {\n p1[0] = tickCoord;\n p1[1] = gridRect.y;\n p2[0] = tickCoord;\n p2[1] = gridRect.y + gridRect.height;\n } else {\n p1[0] = gridRect.x;\n p1[1] = tickCoord;\n p2[0] = gridRect.x + gridRect.width;\n p2[1] = tickCoord;\n }\n\n var colorIndex = lineCount++ % lineColors.length;\n var tickValue = ticksCoords[i].tickValue;\n\n this._axisGroup.add(new graphic.Line(graphic.subPixelOptimizeLine({\n anid: tickValue != null ? 'line_' + ticksCoords[i].tickValue : null,\n shape: {\n x1: p1[0],\n y1: p1[1],\n x2: p2[0],\n y2: p2[1]\n },\n style: zrUtil.defaults({\n stroke: lineColors[colorIndex]\n }, lineStyle),\n silent: true\n })));\n }\n },\n\n /**\n * @param {module:echarts/coord/cartesian/AxisModel} axisModel\n * @param {module:echarts/coord/cartesian/GridModel} gridModel\n * @private\n */\n _splitArea: function (axisModel, gridModel) {\n var axis = axisModel.axis;\n\n if (axis.scale.isBlank()) {\n return;\n }\n\n var splitAreaModel = axisModel.getModel('splitArea');\n var areaStyleModel = splitAreaModel.getModel('areaStyle');\n var areaColors = areaStyleModel.get('color');\n var gridRect = gridModel.coordinateSystem.getRect();\n var ticksCoords = axis.getTicksCoords({\n tickModel: splitAreaModel,\n clamp: true\n });\n\n if (!ticksCoords.length) {\n return;\n } // For Making appropriate splitArea animation, the color and anid\n // should be corresponding to previous one if possible.\n\n\n var areaColorsLen = areaColors.length;\n var lastSplitAreaColors = this._splitAreaColors;\n var newSplitAreaColors = zrUtil.createHashMap();\n var colorIndex = 0;\n\n if (lastSplitAreaColors) {\n for (var i = 0; i < ticksCoords.length; i++) {\n var cIndex = lastSplitAreaColors.get(ticksCoords[i].tickValue);\n\n if (cIndex != null) {\n colorIndex = (cIndex + (areaColorsLen - 1) * i) % areaColorsLen;\n break;\n }\n }\n }\n\n var prev = axis.toGlobalCoord(ticksCoords[0].coord);\n var areaStyle = areaStyleModel.getAreaStyle();\n areaColors = zrUtil.isArray(areaColors) ? areaColors : [areaColors];\n\n for (var i = 1; i < ticksCoords.length; i++) {\n var tickCoord = axis.toGlobalCoord(ticksCoords[i].coord);\n var x;\n var y;\n var width;\n var height;\n\n if (axis.isHorizontal()) {\n x = prev;\n y = gridRect.y;\n width = tickCoord - x;\n height = gridRect.height;\n prev = x + width;\n } else {\n x = gridRect.x;\n y = prev;\n width = gridRect.width;\n height = tickCoord - y;\n prev = y + height;\n }\n\n var tickValue = ticksCoords[i - 1].tickValue;\n tickValue != null && newSplitAreaColors.set(tickValue, colorIndex);\n\n this._axisGroup.add(new graphic.Rect({\n anid: tickValue != null ? 'area_' + tickValue : null,\n shape: {\n x: x,\n y: y,\n width: width,\n height: height\n },\n style: zrUtil.defaults({\n fill: areaColors[colorIndex]\n }, areaStyle),\n silent: true\n }));\n\n colorIndex = (colorIndex + 1) % areaColorsLen;\n }\n\n this._splitAreaColors = newSplitAreaColors;\n }\n});\nCartesianAxisView.extend({\n type: 'xAxis'\n});\nCartesianAxisView.extend({\n type: 'yAxis'\n});","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar BoundingRect = require(\"zrender/lib/core/BoundingRect\");\n\nvar bbox = require(\"zrender/lib/core/bbox\");\n\nvar vec2 = require(\"zrender/lib/core/vector\");\n\nvar polygonContain = require(\"zrender/lib/contain/polygon\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @module echarts/coord/geo/Region\n */\n\n/**\n * @param {string|Region} name\n * @param {Array} geometries\n * @param {Array.<number>} cp\n */\nfunction Region(name, geometries, cp) {\n /**\n * @type {string}\n * @readOnly\n */\n this.name = name;\n /**\n * @type {Array.<Array>}\n * @readOnly\n */\n\n this.geometries = geometries;\n\n if (!cp) {\n var rect = this.getBoundingRect();\n cp = [rect.x + rect.width / 2, rect.y + rect.height / 2];\n } else {\n cp = [cp[0], cp[1]];\n }\n /**\n * @type {Array.<number>}\n */\n\n\n this.center = cp;\n}\n\nRegion.prototype = {\n constructor: Region,\n properties: null,\n\n /**\n * @return {module:zrender/core/BoundingRect}\n */\n getBoundingRect: function () {\n var rect = this._rect;\n\n if (rect) {\n return rect;\n }\n\n var MAX_NUMBER = Number.MAX_VALUE;\n var min = [MAX_NUMBER, MAX_NUMBER];\n var max = [-MAX_NUMBER, -MAX_NUMBER];\n var min2 = [];\n var max2 = [];\n var geometries = this.geometries;\n\n for (var i = 0; i < geometries.length; i++) {\n // Only support polygon\n if (geometries[i].type !== 'polygon') {\n continue;\n } // Doesn't consider hole\n\n\n var exterior = geometries[i].exterior;\n bbox.fromPoints(exterior, min2, max2);\n vec2.min(min, min, min2);\n vec2.max(max, max, max2);\n } // No data\n\n\n if (i === 0) {\n min[0] = min[1] = max[0] = max[1] = 0;\n }\n\n return this._rect = new BoundingRect(min[0], min[1], max[0] - min[0], max[1] - min[1]);\n },\n\n /**\n * @param {<Array.<number>} coord\n * @return {boolean}\n */\n contain: function (coord) {\n var rect = this.getBoundingRect();\n var geometries = this.geometries;\n\n if (!rect.contain(coord[0], coord[1])) {\n return false;\n }\n\n loopGeo: for (var i = 0, len = geometries.length; i < len; i++) {\n // Only support polygon.\n if (geometries[i].type !== 'polygon') {\n continue;\n }\n\n var exterior = geometries[i].exterior;\n var interiors = geometries[i].interiors;\n\n if (polygonContain.contain(exterior, coord[0], coord[1])) {\n // Not in the region if point is in the hole.\n for (var k = 0; k < (interiors ? interiors.length : 0); k++) {\n if (polygonContain.contain(interiors[k])) {\n continue loopGeo;\n }\n }\n\n return true;\n }\n }\n\n return false;\n },\n transformTo: function (x, y, width, height) {\n var rect = this.getBoundingRect();\n var aspect = rect.width / rect.height;\n\n if (!width) {\n width = aspect * height;\n } else if (!height) {\n height = width / aspect;\n }\n\n var target = new BoundingRect(x, y, width, height);\n var transform = rect.calculateTransform(target);\n var geometries = this.geometries;\n\n for (var i = 0; i < geometries.length; i++) {\n // Only support polygon.\n if (geometries[i].type !== 'polygon') {\n continue;\n }\n\n var exterior = geometries[i].exterior;\n var interiors = geometries[i].interiors;\n\n for (var p = 0; p < exterior.length; p++) {\n vec2.applyTransform(exterior[p], exterior[p], transform);\n }\n\n for (var h = 0; h < (interiors ? interiors.length : 0); h++) {\n for (var p = 0; p < interiors[h].length; p++) {\n vec2.applyTransform(interiors[h][p], interiors[h][p], transform);\n }\n }\n }\n\n rect = this._rect;\n rect.copy(target); // Update center\n\n this.center = [rect.x + rect.width / 2, rect.y + rect.height / 2];\n },\n cloneShallow: function (name) {\n name == null && (name = this.name);\n var newRegion = new Region(name, this.geometries, this.center);\n newRegion._rect = this._rect;\n newRegion.transformTo = null; // Simply avoid to be called.\n\n return newRegion;\n }\n};\nvar _default = Region;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar assert = _util.assert;\nvar isArray = _util.isArray;\n\nvar _config = require(\"../config\");\n\nvar __DEV__ = _config.__DEV__;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @param {Object} define\n * @return See the return of `createTask`.\n */\nfunction createTask(define) {\n return new Task(define);\n}\n/**\n * @constructor\n * @param {Object} define\n * @param {Function} define.reset Custom reset\n * @param {Function} [define.plan] Returns 'reset' indicate reset immediately.\n * @param {Function} [define.count] count is used to determin data task.\n * @param {Function} [define.onDirty] count is used to determin data task.\n */\n\n\nfunction Task(define) {\n define = define || {};\n this._reset = define.reset;\n this._plan = define.plan;\n this._count = define.count;\n this._onDirty = define.onDirty;\n this._dirty = true; // Context must be specified implicitly, to\n // avoid miss update context when model changed.\n\n this.context;\n}\n\nvar taskProto = Task.prototype;\n/**\n * @param {Object} performArgs\n * @param {number} [performArgs.step] Specified step.\n * @param {number} [performArgs.skip] Skip customer perform call.\n * @param {number} [performArgs.modBy] Sampling window size.\n * @param {number} [performArgs.modDataCount] Sampling count.\n */\n\ntaskProto.perform = function (performArgs) {\n var upTask = this._upstream;\n var skip = performArgs && performArgs.skip; // TODO some refactor.\n // Pull data. Must pull data each time, because context.data\n // may be updated by Series.setData.\n\n if (this._dirty && upTask) {\n var context = this.context;\n context.data = context.outputData = upTask.context.outputData;\n }\n\n if (this.__pipeline) {\n this.__pipeline.currentTask = this;\n }\n\n var planResult;\n\n if (this._plan && !skip) {\n planResult = this._plan(this.context);\n } // Support sharding by mod, which changes the render sequence and makes the rendered graphic\n // elements uniformed distributed when progress, especially when moving or zooming.\n\n\n var lastModBy = normalizeModBy(this._modBy);\n var lastModDataCount = this._modDataCount || 0;\n var modBy = normalizeModBy(performArgs && performArgs.modBy);\n var modDataCount = performArgs && performArgs.modDataCount || 0;\n\n if (lastModBy !== modBy || lastModDataCount !== modDataCount) {\n planResult = 'reset';\n }\n\n function normalizeModBy(val) {\n !(val >= 1) && (val = 1); // jshint ignore:line\n\n return val;\n }\n\n var forceFirstProgress;\n\n if (this._dirty || planResult === 'reset') {\n this._dirty = false;\n forceFirstProgress = reset(this, skip);\n }\n\n this._modBy = modBy;\n this._modDataCount = modDataCount;\n var step = performArgs && performArgs.step;\n\n if (upTask) {\n this._dueEnd = upTask._outputDueEnd;\n } // DataTask or overallTask\n else {\n this._dueEnd = this._count ? this._count(this.context) : Infinity;\n } // Note: Stubs, that its host overall task let it has progress, has progress.\n // If no progress, pass index from upstream to downstream each time plan called.\n\n\n if (this._progress) {\n var start = this._dueIndex;\n var end = Math.min(step != null ? this._dueIndex + step : Infinity, this._dueEnd);\n\n if (!skip && (forceFirstProgress || start < end)) {\n var progress = this._progress;\n\n if (isArray(progress)) {\n for (var i = 0; i < progress.length; i++) {\n doProgress(this, progress[i], start, end, modBy, modDataCount);\n }\n } else {\n doProgress(this, progress, start, end, modBy, modDataCount);\n }\n }\n\n this._dueIndex = end; // If no `outputDueEnd`, assume that output data and\n // input data is the same, so use `dueIndex` as `outputDueEnd`.\n\n var outputDueEnd = this._settedOutputEnd != null ? this._settedOutputEnd : end;\n this._outputDueEnd = outputDueEnd;\n } else {\n // (1) Some overall task has no progress.\n // (2) Stubs, that its host overall task do not let it has progress, has no progress.\n // This should always be performed so it can be passed to downstream.\n this._dueIndex = this._outputDueEnd = this._settedOutputEnd != null ? this._settedOutputEnd : this._dueEnd;\n }\n\n return this.unfinished();\n};\n\nvar iterator = function () {\n var end;\n var current;\n var modBy;\n var modDataCount;\n var winCount;\n var it = {\n reset: function (s, e, sStep, sCount) {\n current = s;\n end = e;\n modBy = sStep;\n modDataCount = sCount;\n winCount = Math.ceil(modDataCount / modBy);\n it.next = modBy > 1 && modDataCount > 0 ? modNext : sequentialNext;\n }\n };\n return it;\n\n function sequentialNext() {\n return current < end ? current++ : null;\n }\n\n function modNext() {\n var dataIndex = current % winCount * modBy + Math.ceil(current / winCount);\n var result = current >= end ? null : dataIndex < modDataCount ? dataIndex // If modDataCount is smaller than data.count() (consider `appendData` case),\n // Use normal linear rendering mode.\n : current;\n current++;\n return result;\n }\n}();\n\ntaskProto.dirty = function () {\n this._dirty = true;\n this._onDirty && this._onDirty(this.context);\n};\n\nfunction doProgress(taskIns, progress, start, end, modBy, modDataCount) {\n iterator.reset(start, end, modBy, modDataCount);\n taskIns._callingProgress = progress;\n\n taskIns._callingProgress({\n start: start,\n end: end,\n count: end - start,\n next: iterator.next\n }, taskIns.context);\n}\n\nfunction reset(taskIns, skip) {\n taskIns._dueIndex = taskIns._outputDueEnd = taskIns._dueEnd = 0;\n taskIns._settedOutputEnd = null;\n var progress;\n var forceFirstProgress;\n\n if (!skip && taskIns._reset) {\n progress = taskIns._reset(taskIns.context);\n\n if (progress && progress.progress) {\n forceFirstProgress = progress.forceFirstProgress;\n progress = progress.progress;\n } // To simplify no progress checking, array must has item.\n\n\n if (isArray(progress) && !progress.length) {\n progress = null;\n }\n }\n\n taskIns._progress = progress;\n taskIns._modBy = taskIns._modDataCount = null;\n var downstream = taskIns._downstream;\n downstream && downstream.dirty();\n return forceFirstProgress;\n}\n/**\n * @return {boolean}\n */\n\n\ntaskProto.unfinished = function () {\n return this._progress && this._dueIndex < this._dueEnd;\n};\n/**\n * @param {Object} downTask The downstream task.\n * @return {Object} The downstream task.\n */\n\n\ntaskProto.pipe = function (downTask) {\n // If already downstream, do not dirty downTask.\n if (this._downstream !== downTask || this._dirty) {\n this._downstream = downTask;\n downTask._upstream = this;\n downTask.dirty();\n }\n};\n\ntaskProto.dispose = function () {\n if (this._disposed) {\n return;\n }\n\n this._upstream && (this._upstream._downstream = null);\n this._downstream && (this._downstream._upstream = null);\n this._dirty = false;\n this._disposed = true;\n};\n\ntaskProto.getUpstream = function () {\n return this._upstream;\n};\n\ntaskProto.getDownstream = function () {\n return this._downstream;\n};\n\ntaskProto.setOutputEnd = function (end) {\n // This only happend in dataTask, dataZoom, map, currently.\n // where dataZoom do not set end each time, but only set\n // when reset. So we should record the setted end, in case\n // that the stub of dataZoom perform again and earse the\n // setted end by upstream.\n this._outputDueEnd = this._settedOutputEnd = end;\n}; ///////////////////////////////////////////////////////////\n// For stream debug (Should be commented out after used!)\n// Usage: printTask(this, 'begin');\n// Usage: printTask(this, null, {someExtraProp});\n// function printTask(task, prefix, extra) {\n// window.ecTaskUID == null && (window.ecTaskUID = 0);\n// task.uidDebug == null && (task.uidDebug = `task_${window.ecTaskUID++}`);\n// task.agent && task.agent.uidDebug == null && (task.agent.uidDebug = `task_${window.ecTaskUID++}`);\n// var props = [];\n// if (task.__pipeline) {\n// var val = `${task.__idxInPipeline}/${task.__pipeline.tail.__idxInPipeline} ${task.agent ? '(stub)' : ''}`;\n// props.push({text: 'idx', value: val});\n// } else {\n// var stubCount = 0;\n// task.agentStubMap.each(() => stubCount++);\n// props.push({text: 'idx', value: `overall (stubs: ${stubCount})`});\n// }\n// props.push({text: 'uid', value: task.uidDebug});\n// if (task.__pipeline) {\n// props.push({text: 'pid', value: task.__pipeline.id});\n// task.agent && props.push(\n// {text: 'stubFor', value: task.agent.uidDebug}\n// );\n// }\n// props.push(\n// {text: 'dirty', value: task._dirty},\n// {text: 'dueIndex', value: task._dueIndex},\n// {text: 'dueEnd', value: task._dueEnd},\n// {text: 'outputDueEnd', value: task._outputDueEnd}\n// );\n// if (extra) {\n// Object.keys(extra).forEach(key => {\n// props.push({text: key, value: extra[key]});\n// });\n// }\n// var args = ['color: blue'];\n// var msg = `%c[${prefix || 'T'}] %c` + props.map(item => (\n// args.push('color: black', 'color: red'),\n// `${item.text}: %c${item.value}`\n// )).join('%c, ');\n// console.log.apply(console, [msg].concat(args));\n// // console.log(this);\n// }\n\n\nexports.createTask = createTask;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nrequire(\"../coord/polar/polarCreator\");\n\nrequire(\"./axis/AngleAxisView\");","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar graphic = require(\"../../util/graphic\");\n\nvar SymbolClz = require(\"./Symbol\");\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar isObject = _util.isObject;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @module echarts/chart/helper/SymbolDraw\n */\n\n/**\n * @constructor\n * @alias module:echarts/chart/helper/SymbolDraw\n * @param {module:zrender/graphic/Group} [symbolCtor]\n */\nfunction SymbolDraw(symbolCtor) {\n this.group = new graphic.Group();\n this._symbolCtor = symbolCtor || SymbolClz;\n}\n\nvar symbolDrawProto = SymbolDraw.prototype;\n\nfunction symbolNeedsDraw(data, point, idx, opt) {\n return point && !isNaN(point[0]) && !isNaN(point[1]) && !(opt.isIgnore && opt.isIgnore(idx)) // We do not set clipShape on group, because it will cut part of\n // the symbol element shape. We use the same clip shape here as\n // the line clip.\n && !(opt.clipShape && !opt.clipShape.contain(point[0], point[1])) && data.getItemVisual(idx, 'symbol') !== 'none';\n}\n/**\n * Update symbols draw by new data\n * @param {module:echarts/data/List} data\n * @param {Object} [opt] Or isIgnore\n * @param {Function} [opt.isIgnore]\n * @param {Object} [opt.clipShape]\n */\n\n\nsymbolDrawProto.updateData = function (data, opt) {\n opt = normalizeUpdateOpt(opt);\n var group = this.group;\n var seriesModel = data.hostModel;\n var oldData = this._data;\n var SymbolCtor = this._symbolCtor;\n var seriesScope = makeSeriesScope(data); // There is no oldLineData only when first rendering or switching from\n // stream mode to normal mode, where previous elements should be removed.\n\n if (!oldData) {\n group.removeAll();\n }\n\n data.diff(oldData).add(function (newIdx) {\n var point = data.getItemLayout(newIdx);\n\n if (symbolNeedsDraw(data, point, newIdx, opt)) {\n var symbolEl = new SymbolCtor(data, newIdx, seriesScope);\n symbolEl.attr('position', point);\n data.setItemGraphicEl(newIdx, symbolEl);\n group.add(symbolEl);\n }\n }).update(function (newIdx, oldIdx) {\n var symbolEl = oldData.getItemGraphicEl(oldIdx);\n var point = data.getItemLayout(newIdx);\n\n if (!symbolNeedsDraw(data, point, newIdx, opt)) {\n group.remove(symbolEl);\n return;\n }\n\n if (!symbolEl) {\n symbolEl = new SymbolCtor(data, newIdx);\n symbolEl.attr('position', point);\n } else {\n symbolEl.updateData(data, newIdx, seriesScope);\n graphic.updateProps(symbolEl, {\n position: point\n }, seriesModel);\n } // Add back\n\n\n group.add(symbolEl);\n data.setItemGraphicEl(newIdx, symbolEl);\n }).remove(function (oldIdx) {\n var el = oldData.getItemGraphicEl(oldIdx);\n el && el.fadeOut(function () {\n group.remove(el);\n });\n }).execute();\n this._data = data;\n};\n\nsymbolDrawProto.isPersistent = function () {\n return true;\n};\n\nsymbolDrawProto.updateLayout = function () {\n var data = this._data;\n\n if (data) {\n // Not use animation\n data.eachItemGraphicEl(function (el, idx) {\n var point = data.getItemLayout(idx);\n el.attr('position', point);\n });\n }\n};\n\nsymbolDrawProto.incrementalPrepareUpdate = function (data) {\n this._seriesScope = makeSeriesScope(data);\n this._data = null;\n this.group.removeAll();\n};\n/**\n * Update symbols draw by new data\n * @param {module:echarts/data/List} data\n * @param {Object} [opt] Or isIgnore\n * @param {Function} [opt.isIgnore]\n * @param {Object} [opt.clipShape]\n */\n\n\nsymbolDrawProto.incrementalUpdate = function (taskParams, data, opt) {\n opt = normalizeUpdateOpt(opt);\n\n function updateIncrementalAndHover(el) {\n if (!el.isGroup) {\n el.incremental = el.useHoverLayer = true;\n }\n }\n\n for (var idx = taskParams.start; idx < taskParams.end; idx++) {\n var point = data.getItemLayout(idx);\n\n if (symbolNeedsDraw(data, point, idx, opt)) {\n var el = new this._symbolCtor(data, idx, this._seriesScope);\n el.traverse(updateIncrementalAndHover);\n el.attr('position', point);\n this.group.add(el);\n data.setItemGraphicEl(idx, el);\n }\n }\n};\n\nfunction normalizeUpdateOpt(opt) {\n if (opt != null && !isObject(opt)) {\n opt = {\n isIgnore: opt\n };\n }\n\n return opt || {};\n}\n\nsymbolDrawProto.remove = function (enableAnimation) {\n var group = this.group;\n var data = this._data; // Incremental model do not have this._data.\n\n if (data && enableAnimation) {\n data.eachItemGraphicEl(function (el) {\n el.fadeOut(function () {\n group.remove(el);\n });\n });\n } else {\n group.removeAll();\n }\n};\n\nfunction makeSeriesScope(data) {\n var seriesModel = data.hostModel;\n return {\n itemStyle: seriesModel.getModel('itemStyle').getItemStyle(['color']),\n hoverItemStyle: seriesModel.getModel('emphasis.itemStyle').getItemStyle(),\n symbolRotate: seriesModel.get('symbolRotate'),\n symbolOffset: seriesModel.get('symbolOffset'),\n hoverAnimation: seriesModel.get('hoverAnimation'),\n labelModel: seriesModel.getModel('label'),\n hoverLabelModel: seriesModel.getModel('emphasis.label'),\n cursorStyle: seriesModel.get('cursor')\n };\n}\n\nvar _default = SymbolDraw;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar BoundingRect = require(\"zrender/lib/core/BoundingRect\");\n\nvar _number = require(\"./number\");\n\nvar parsePercent = _number.parsePercent;\n\nvar formatUtil = require(\"./format\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// Layout helpers for each component positioning\nvar each = zrUtil.each;\n/**\n * @public\n */\n\nvar LOCATION_PARAMS = ['left', 'right', 'top', 'bottom', 'width', 'height'];\n/**\n * @public\n */\n\nvar HV_NAMES = [['width', 'left', 'right'], ['height', 'top', 'bottom']];\n\nfunction boxLayout(orient, group, gap, maxWidth, maxHeight) {\n var x = 0;\n var y = 0;\n\n if (maxWidth == null) {\n maxWidth = Infinity;\n }\n\n if (maxHeight == null) {\n maxHeight = Infinity;\n }\n\n var currentLineMaxSize = 0;\n group.eachChild(function (child, idx) {\n var position = child.position;\n var rect = child.getBoundingRect();\n var nextChild = group.childAt(idx + 1);\n var nextChildRect = nextChild && nextChild.getBoundingRect();\n var nextX;\n var nextY;\n\n if (orient === 'horizontal') {\n var moveX = rect.width + (nextChildRect ? -nextChildRect.x + rect.x : 0);\n nextX = x + moveX; // Wrap when width exceeds maxWidth or meet a `newline` group\n // FIXME compare before adding gap?\n\n if (nextX > maxWidth || child.newline) {\n x = 0;\n nextX = moveX;\n y += currentLineMaxSize + gap;\n currentLineMaxSize = rect.height;\n } else {\n // FIXME: consider rect.y is not `0`?\n currentLineMaxSize = Math.max(currentLineMaxSize, rect.height);\n }\n } else {\n var moveY = rect.height + (nextChildRect ? -nextChildRect.y + rect.y : 0);\n nextY = y + moveY; // Wrap when width exceeds maxHeight or meet a `newline` group\n\n if (nextY > maxHeight || child.newline) {\n x += currentLineMaxSize + gap;\n y = 0;\n nextY = moveY;\n currentLineMaxSize = rect.width;\n } else {\n currentLineMaxSize = Math.max(currentLineMaxSize, rect.width);\n }\n }\n\n if (child.newline) {\n return;\n }\n\n position[0] = x;\n position[1] = y;\n orient === 'horizontal' ? x = nextX + gap : y = nextY + gap;\n });\n}\n/**\n * VBox or HBox layouting\n * @param {string} orient\n * @param {module:zrender/container/Group} group\n * @param {number} gap\n * @param {number} [width=Infinity]\n * @param {number} [height=Infinity]\n */\n\n\nvar box = boxLayout;\n/**\n * VBox layouting\n * @param {module:zrender/container/Group} group\n * @param {number} gap\n * @param {number} [width=Infinity]\n * @param {number} [height=Infinity]\n */\n\nvar vbox = zrUtil.curry(boxLayout, 'vertical');\n/**\n * HBox layouting\n * @param {module:zrender/container/Group} group\n * @param {number} gap\n * @param {number} [width=Infinity]\n * @param {number} [height=Infinity]\n */\n\nvar hbox = zrUtil.curry(boxLayout, 'horizontal');\n/**\n * If x or x2 is not specified or 'center' 'left' 'right',\n * the width would be as long as possible.\n * If y or y2 is not specified or 'middle' 'top' 'bottom',\n * the height would be as long as possible.\n *\n * @param {Object} positionInfo\n * @param {number|string} [positionInfo.x]\n * @param {number|string} [positionInfo.y]\n * @param {number|string} [positionInfo.x2]\n * @param {number|string} [positionInfo.y2]\n * @param {Object} containerRect {width, height}\n * @param {string|number} margin\n * @return {Object} {width, height}\n */\n\nfunction getAvailableSize(positionInfo, containerRect, margin) {\n var containerWidth = containerRect.width;\n var containerHeight = containerRect.height;\n var x = parsePercent(positionInfo.x, containerWidth);\n var y = parsePercent(positionInfo.y, containerHeight);\n var x2 = parsePercent(positionInfo.x2, containerWidth);\n var y2 = parsePercent(positionInfo.y2, containerHeight);\n (isNaN(x) || isNaN(parseFloat(positionInfo.x))) && (x = 0);\n (isNaN(x2) || isNaN(parseFloat(positionInfo.x2))) && (x2 = containerWidth);\n (isNaN(y) || isNaN(parseFloat(positionInfo.y))) && (y = 0);\n (isNaN(y2) || isNaN(parseFloat(positionInfo.y2))) && (y2 = containerHeight);\n margin = formatUtil.normalizeCssArray(margin || 0);\n return {\n width: Math.max(x2 - x - margin[1] - margin[3], 0),\n height: Math.max(y2 - y - margin[0] - margin[2], 0)\n };\n}\n/**\n * Parse position info.\n *\n * @param {Object} positionInfo\n * @param {number|string} [positionInfo.left]\n * @param {number|string} [positionInfo.top]\n * @param {number|string} [positionInfo.right]\n * @param {number|string} [positionInfo.bottom]\n * @param {number|string} [positionInfo.width]\n * @param {number|string} [positionInfo.height]\n * @param {number|string} [positionInfo.aspect] Aspect is width / height\n * @param {Object} containerRect\n * @param {string|number} [margin]\n *\n * @return {module:zrender/core/BoundingRect}\n */\n\n\nfunction getLayoutRect(positionInfo, containerRect, margin) {\n margin = formatUtil.normalizeCssArray(margin || 0);\n var containerWidth = containerRect.width;\n var containerHeight = containerRect.height;\n var left = parsePercent(positionInfo.left, containerWidth);\n var top = parsePercent(positionInfo.top, containerHeight);\n var right = parsePercent(positionInfo.right, containerWidth);\n var bottom = parsePercent(positionInfo.bottom, containerHeight);\n var width = parsePercent(positionInfo.width, containerWidth);\n var height = parsePercent(positionInfo.height, containerHeight);\n var verticalMargin = margin[2] + margin[0];\n var horizontalMargin = margin[1] + margin[3];\n var aspect = positionInfo.aspect; // If width is not specified, calculate width from left and right\n\n if (isNaN(width)) {\n width = containerWidth - right - horizontalMargin - left;\n }\n\n if (isNaN(height)) {\n height = containerHeight - bottom - verticalMargin - top;\n }\n\n if (aspect != null) {\n // If width and height are not given\n // 1. Graph should not exceeds the container\n // 2. Aspect must be keeped\n // 3. Graph should take the space as more as possible\n // FIXME\n // Margin is not considered, because there is no case that both\n // using margin and aspect so far.\n if (isNaN(width) && isNaN(height)) {\n if (aspect > containerWidth / containerHeight) {\n width = containerWidth * 0.8;\n } else {\n height = containerHeight * 0.8;\n }\n } // Calculate width or height with given aspect\n\n\n if (isNaN(width)) {\n width = aspect * height;\n }\n\n if (isNaN(height)) {\n height = width / aspect;\n }\n } // If left is not specified, calculate left from right and width\n\n\n if (isNaN(left)) {\n left = containerWidth - right - width - horizontalMargin;\n }\n\n if (isNaN(top)) {\n top = containerHeight - bottom - height - verticalMargin;\n } // Align left and top\n\n\n switch (positionInfo.left || positionInfo.right) {\n case 'center':\n left = containerWidth / 2 - width / 2 - margin[3];\n break;\n\n case 'right':\n left = containerWidth - width - horizontalMargin;\n break;\n }\n\n switch (positionInfo.top || positionInfo.bottom) {\n case 'middle':\n case 'center':\n top = containerHeight / 2 - height / 2 - margin[0];\n break;\n\n case 'bottom':\n top = containerHeight - height - verticalMargin;\n break;\n } // If something is wrong and left, top, width, height are calculated as NaN\n\n\n left = left || 0;\n top = top || 0;\n\n if (isNaN(width)) {\n // Width may be NaN if only one value is given except width\n width = containerWidth - horizontalMargin - left - (right || 0);\n }\n\n if (isNaN(height)) {\n // Height may be NaN if only one value is given except height\n height = containerHeight - verticalMargin - top - (bottom || 0);\n }\n\n var rect = new BoundingRect(left + margin[3], top + margin[0], width, height);\n rect.margin = margin;\n return rect;\n}\n/**\n * Position a zr element in viewport\n * Group position is specified by either\n * {left, top}, {right, bottom}\n * If all properties exists, right and bottom will be igonred.\n *\n * Logic:\n * 1. Scale (against origin point in parent coord)\n * 2. Rotate (against origin point in parent coord)\n * 3. Traslate (with el.position by this method)\n * So this method only fixes the last step 'Traslate', which does not affect\n * scaling and rotating.\n *\n * If be called repeatly with the same input el, the same result will be gotten.\n *\n * @param {module:zrender/Element} el Should have `getBoundingRect` method.\n * @param {Object} positionInfo\n * @param {number|string} [positionInfo.left]\n * @param {number|string} [positionInfo.top]\n * @param {number|string} [positionInfo.right]\n * @param {number|string} [positionInfo.bottom]\n * @param {number|string} [positionInfo.width] Only for opt.boundingModel: 'raw'\n * @param {number|string} [positionInfo.height] Only for opt.boundingModel: 'raw'\n * @param {Object} containerRect\n * @param {string|number} margin\n * @param {Object} [opt]\n * @param {Array.<number>} [opt.hv=[1,1]] Only horizontal or only vertical.\n * @param {Array.<number>} [opt.boundingMode='all']\n * Specify how to calculate boundingRect when locating.\n * 'all': Position the boundingRect that is transformed and uioned\n * both itself and its descendants.\n * This mode simplies confine the elements in the bounding\n * of their container (e.g., using 'right: 0').\n * 'raw': Position the boundingRect that is not transformed and only itself.\n * This mode is useful when you want a element can overflow its\n * container. (Consider a rotated circle needs to be located in a corner.)\n * In this mode positionInfo.width/height can only be number.\n */\n\n\nfunction positionElement(el, positionInfo, containerRect, margin, opt) {\n var h = !opt || !opt.hv || opt.hv[0];\n var v = !opt || !opt.hv || opt.hv[1];\n var boundingMode = opt && opt.boundingMode || 'all';\n\n if (!h && !v) {\n return;\n }\n\n var rect;\n\n if (boundingMode === 'raw') {\n rect = el.type === 'group' ? new BoundingRect(0, 0, +positionInfo.width || 0, +positionInfo.height || 0) : el.getBoundingRect();\n } else {\n rect = el.getBoundingRect();\n\n if (el.needLocalTransform()) {\n var transform = el.getLocalTransform(); // Notice: raw rect may be inner object of el,\n // which should not be modified.\n\n rect = rect.clone();\n rect.applyTransform(transform);\n }\n } // The real width and height can not be specified but calculated by the given el.\n\n\n positionInfo = getLayoutRect(zrUtil.defaults({\n width: rect.width,\n height: rect.height\n }, positionInfo), containerRect, margin); // Because 'tranlate' is the last step in transform\n // (see zrender/core/Transformable#getLocalTransform),\n // we can just only modify el.position to get final result.\n\n var elPos = el.position;\n var dx = h ? positionInfo.x - rect.x : 0;\n var dy = v ? positionInfo.y - rect.y : 0;\n el.attr('position', boundingMode === 'raw' ? [dx, dy] : [elPos[0] + dx, elPos[1] + dy]);\n}\n/**\n * @param {Object} option Contains some of the properties in HV_NAMES.\n * @param {number} hvIdx 0: horizontal; 1: vertical.\n */\n\n\nfunction sizeCalculable(option, hvIdx) {\n return option[HV_NAMES[hvIdx][0]] != null || option[HV_NAMES[hvIdx][1]] != null && option[HV_NAMES[hvIdx][2]] != null;\n}\n/**\n * Consider Case:\n * When defulat option has {left: 0, width: 100}, and we set {right: 0}\n * through setOption or media query, using normal zrUtil.merge will cause\n * {right: 0} does not take effect.\n *\n * @example\n * ComponentModel.extend({\n * init: function () {\n * ...\n * var inputPositionParams = layout.getLayoutParams(option);\n * this.mergeOption(inputPositionParams);\n * },\n * mergeOption: function (newOption) {\n * newOption && zrUtil.merge(thisOption, newOption, true);\n * layout.mergeLayoutParam(thisOption, newOption);\n * }\n * });\n *\n * @param {Object} targetOption\n * @param {Object} newOption\n * @param {Object|string} [opt]\n * @param {boolean|Array.<boolean>} [opt.ignoreSize=false] Used for the components\n * that width (or height) should not be calculated by left and right (or top and bottom).\n */\n\n\nfunction mergeLayoutParam(targetOption, newOption, opt) {\n !zrUtil.isObject(opt) && (opt = {});\n var ignoreSize = opt.ignoreSize;\n !zrUtil.isArray(ignoreSize) && (ignoreSize = [ignoreSize, ignoreSize]);\n var hResult = merge(HV_NAMES[0], 0);\n var vResult = merge(HV_NAMES[1], 1);\n copy(HV_NAMES[0], targetOption, hResult);\n copy(HV_NAMES[1], targetOption, vResult);\n\n function merge(names, hvIdx) {\n var newParams = {};\n var newValueCount = 0;\n var merged = {};\n var mergedValueCount = 0;\n var enoughParamNumber = 2;\n each(names, function (name) {\n merged[name] = targetOption[name];\n });\n each(names, function (name) {\n // Consider case: newOption.width is null, which is\n // set by user for removing width setting.\n hasProp(newOption, name) && (newParams[name] = merged[name] = newOption[name]);\n hasValue(newParams, name) && newValueCount++;\n hasValue(merged, name) && mergedValueCount++;\n });\n\n if (ignoreSize[hvIdx]) {\n // Only one of left/right is premitted to exist.\n if (hasValue(newOption, names[1])) {\n merged[names[2]] = null;\n } else if (hasValue(newOption, names[2])) {\n merged[names[1]] = null;\n }\n\n return merged;\n } // Case: newOption: {width: ..., right: ...},\n // or targetOption: {right: ...} and newOption: {width: ...},\n // There is no conflict when merged only has params count\n // little than enoughParamNumber.\n\n\n if (mergedValueCount === enoughParamNumber || !newValueCount) {\n return merged;\n } // Case: newOption: {width: ..., right: ...},\n // Than we can make sure user only want those two, and ignore\n // all origin params in targetOption.\n else if (newValueCount >= enoughParamNumber) {\n return newParams;\n } else {\n // Chose another param from targetOption by priority.\n for (var i = 0; i < names.length; i++) {\n var name = names[i];\n\n if (!hasProp(newParams, name) && hasProp(targetOption, name)) {\n newParams[name] = targetOption[name];\n break;\n }\n }\n\n return newParams;\n }\n }\n\n function hasProp(obj, name) {\n return obj.hasOwnProperty(name);\n }\n\n function hasValue(obj, name) {\n return obj[name] != null && obj[name] !== 'auto';\n }\n\n function copy(names, target, source) {\n each(names, function (name) {\n target[name] = source[name];\n });\n }\n}\n/**\n * Retrieve 'left', 'right', 'top', 'bottom', 'width', 'height' from object.\n * @param {Object} source\n * @return {Object} Result contains those props.\n */\n\n\nfunction getLayoutParams(source) {\n return copyLayoutParams({}, source);\n}\n/**\n * Retrieve 'left', 'right', 'top', 'bottom', 'width', 'height' from object.\n * @param {Object} source\n * @return {Object} Result contains those props.\n */\n\n\nfunction copyLayoutParams(target, source) {\n source && target && each(LOCATION_PARAMS, function (name) {\n source.hasOwnProperty(name) && (target[name] = source[name]);\n });\n return target;\n}\n\nexports.LOCATION_PARAMS = LOCATION_PARAMS;\nexports.HV_NAMES = HV_NAMES;\nexports.box = box;\nexports.vbox = vbox;\nexports.hbox = hbox;\nexports.getAvailableSize = getAvailableSize;\nexports.getLayoutRect = getLayoutRect;\nexports.positionElement = positionElement;\nexports.sizeCalculable = sizeCalculable;\nexports.mergeLayoutParam = mergeLayoutParam;\nexports.getLayoutParams = getLayoutParams;\nexports.copyLayoutParams = copyLayoutParams;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar retrieve = _util.retrieve;\nvar defaults = _util.defaults;\nvar extend = _util.extend;\nvar each = _util.each;\n\nvar formatUtil = require(\"../../util/format\");\n\nvar graphic = require(\"../../util/graphic\");\n\nvar Model = require(\"../../model/Model\");\n\nvar _number = require(\"../../util/number\");\n\nvar isRadianAroundZero = _number.isRadianAroundZero;\nvar remRadian = _number.remRadian;\n\nvar _symbol = require(\"../../util/symbol\");\n\nvar createSymbol = _symbol.createSymbol;\n\nvar matrixUtil = require(\"zrender/lib/core/matrix\");\n\nvar _vector = require(\"zrender/lib/core/vector\");\n\nvar v2ApplyTransform = _vector.applyTransform;\n\nvar _axisHelper = require(\"../../coord/axisHelper\");\n\nvar shouldShowAllLabels = _axisHelper.shouldShowAllLabels;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar PI = Math.PI;\n\nfunction makeAxisEventDataBase(axisModel) {\n var eventData = {\n componentType: axisModel.mainType,\n componentIndex: axisModel.componentIndex\n };\n eventData[axisModel.mainType + 'Index'] = axisModel.componentIndex;\n return eventData;\n}\n/**\n * A final axis is translated and rotated from a \"standard axis\".\n * So opt.position and opt.rotation is required.\n *\n * A standard axis is and axis from [0, 0] to [0, axisExtent[1]],\n * for example: (0, 0) ------------> (0, 50)\n *\n * nameDirection or tickDirection or labelDirection is 1 means tick\n * or label is below the standard axis, whereas is -1 means above\n * the standard axis. labelOffset means offset between label and axis,\n * which is useful when 'onZero', where axisLabel is in the grid and\n * label in outside grid.\n *\n * Tips: like always,\n * positive rotation represents anticlockwise, and negative rotation\n * represents clockwise.\n * The direction of position coordinate is the same as the direction\n * of screen coordinate.\n *\n * Do not need to consider axis 'inverse', which is auto processed by\n * axis extent.\n *\n * @param {module:zrender/container/Group} group\n * @param {Object} axisModel\n * @param {Object} opt Standard axis parameters.\n * @param {Array.<number>} opt.position [x, y]\n * @param {number} opt.rotation by radian\n * @param {number} [opt.nameDirection=1] 1 or -1 Used when nameLocation is 'middle' or 'center'.\n * @param {number} [opt.tickDirection=1] 1 or -1\n * @param {number} [opt.labelDirection=1] 1 or -1\n * @param {number} [opt.labelOffset=0] Usefull when onZero.\n * @param {string} [opt.axisLabelShow] default get from axisModel.\n * @param {string} [opt.axisName] default get from axisModel.\n * @param {number} [opt.axisNameAvailableWidth]\n * @param {number} [opt.labelRotate] by degree, default get from axisModel.\n * @param {number} [opt.strokeContainThreshold] Default label interval when label\n * @param {number} [opt.nameTruncateMaxWidth]\n */\n\n\nvar AxisBuilder = function (axisModel, opt) {\n /**\n * @readOnly\n */\n this.opt = opt;\n /**\n * @readOnly\n */\n\n this.axisModel = axisModel; // Default value\n\n defaults(opt, {\n labelOffset: 0,\n nameDirection: 1,\n tickDirection: 1,\n labelDirection: 1,\n silent: true\n });\n /**\n * @readOnly\n */\n\n this.group = new graphic.Group(); // FIXME Not use a seperate text group?\n\n var dumbGroup = new graphic.Group({\n position: opt.position.slice(),\n rotation: opt.rotation\n }); // this.group.add(dumbGroup);\n // this._dumbGroup = dumbGroup;\n\n dumbGroup.updateTransform();\n this._transform = dumbGroup.transform;\n this._dumbGroup = dumbGroup;\n};\n\nAxisBuilder.prototype = {\n constructor: AxisBuilder,\n hasBuilder: function (name) {\n return !!builders[name];\n },\n add: function (name) {\n builders[name].call(this);\n },\n getGroup: function () {\n return this.group;\n }\n};\nvar builders = {\n /**\n * @private\n */\n axisLine: function () {\n var opt = this.opt;\n var axisModel = this.axisModel;\n\n if (!axisModel.get('axisLine.show')) {\n return;\n }\n\n var extent = this.axisModel.axis.getExtent();\n var matrix = this._transform;\n var pt1 = [extent[0], 0];\n var pt2 = [extent[1], 0];\n\n if (matrix) {\n v2ApplyTransform(pt1, pt1, matrix);\n v2ApplyTransform(pt2, pt2, matrix);\n }\n\n var lineStyle = extend({\n lineCap: 'round'\n }, axisModel.getModel('axisLine.lineStyle').getLineStyle());\n this.group.add(new graphic.Line(graphic.subPixelOptimizeLine({\n // Id for animation\n anid: 'line',\n shape: {\n x1: pt1[0],\n y1: pt1[1],\n x2: pt2[0],\n y2: pt2[1]\n },\n style: lineStyle,\n strokeContainThreshold: opt.strokeContainThreshold || 5,\n silent: true,\n z2: 1\n })));\n var arrows = axisModel.get('axisLine.symbol');\n var arrowSize = axisModel.get('axisLine.symbolSize');\n var arrowOffset = axisModel.get('axisLine.symbolOffset') || 0;\n\n if (typeof arrowOffset === 'number') {\n arrowOffset = [arrowOffset, arrowOffset];\n }\n\n if (arrows != null) {\n if (typeof arrows === 'string') {\n // Use the same arrow for start and end point\n arrows = [arrows, arrows];\n }\n\n if (typeof arrowSize === 'string' || typeof arrowSize === 'number') {\n // Use the same size for width and height\n arrowSize = [arrowSize, arrowSize];\n }\n\n var symbolWidth = arrowSize[0];\n var symbolHeight = arrowSize[1];\n each([{\n rotate: opt.rotation + Math.PI / 2,\n offset: arrowOffset[0],\n r: 0\n }, {\n rotate: opt.rotation - Math.PI / 2,\n offset: arrowOffset[1],\n r: Math.sqrt((pt1[0] - pt2[0]) * (pt1[0] - pt2[0]) + (pt1[1] - pt2[1]) * (pt1[1] - pt2[1]))\n }], function (point, index) {\n if (arrows[index] !== 'none' && arrows[index] != null) {\n var symbol = createSymbol(arrows[index], -symbolWidth / 2, -symbolHeight / 2, symbolWidth, symbolHeight, lineStyle.stroke, true); // Calculate arrow position with offset\n\n var r = point.r + point.offset;\n var pos = [pt1[0] + r * Math.cos(opt.rotation), pt1[1] - r * Math.sin(opt.rotation)];\n symbol.attr({\n rotation: point.rotate,\n position: pos,\n silent: true,\n z2: 11\n });\n this.group.add(symbol);\n }\n }, this);\n }\n },\n\n /**\n * @private\n */\n axisTickLabel: function () {\n var axisModel = this.axisModel;\n var opt = this.opt;\n var tickEls = buildAxisTick(this, axisModel, opt);\n var labelEls = buildAxisLabel(this, axisModel, opt);\n fixMinMaxLabelShow(axisModel, labelEls, tickEls);\n },\n\n /**\n * @private\n */\n axisName: function () {\n var opt = this.opt;\n var axisModel = this.axisModel;\n var name = retrieve(opt.axisName, axisModel.get('name'));\n\n if (!name) {\n return;\n }\n\n var nameLocation = axisModel.get('nameLocation');\n var nameDirection = opt.nameDirection;\n var textStyleModel = axisModel.getModel('nameTextStyle');\n var gap = axisModel.get('nameGap') || 0;\n var extent = this.axisModel.axis.getExtent();\n var gapSignal = extent[0] > extent[1] ? -1 : 1;\n var pos = [nameLocation === 'start' ? extent[0] - gapSignal * gap : nameLocation === 'end' ? extent[1] + gapSignal * gap : (extent[0] + extent[1]) / 2, // 'middle'\n // Reuse labelOffset.\n isNameLocationCenter(nameLocation) ? opt.labelOffset + nameDirection * gap : 0];\n var labelLayout;\n var nameRotation = axisModel.get('nameRotate');\n\n if (nameRotation != null) {\n nameRotation = nameRotation * PI / 180; // To radian.\n }\n\n var axisNameAvailableWidth;\n\n if (isNameLocationCenter(nameLocation)) {\n labelLayout = innerTextLayout(opt.rotation, nameRotation != null ? nameRotation : opt.rotation, // Adapt to axis.\n nameDirection);\n } else {\n labelLayout = endTextLayout(opt, nameLocation, nameRotation || 0, extent);\n axisNameAvailableWidth = opt.axisNameAvailableWidth;\n\n if (axisNameAvailableWidth != null) {\n axisNameAvailableWidth = Math.abs(axisNameAvailableWidth / Math.sin(labelLayout.rotation));\n !isFinite(axisNameAvailableWidth) && (axisNameAvailableWidth = null);\n }\n }\n\n var textFont = textStyleModel.getFont();\n var truncateOpt = axisModel.get('nameTruncate', true) || {};\n var ellipsis = truncateOpt.ellipsis;\n var maxWidth = retrieve(opt.nameTruncateMaxWidth, truncateOpt.maxWidth, axisNameAvailableWidth); // FIXME\n // truncate rich text? (consider performance)\n\n var truncatedText = ellipsis != null && maxWidth != null ? formatUtil.truncateText(name, maxWidth, textFont, ellipsis, {\n minChar: 2,\n placeholder: truncateOpt.placeholder\n }) : name;\n var tooltipOpt = axisModel.get('tooltip', true);\n var mainType = axisModel.mainType;\n var formatterParams = {\n componentType: mainType,\n name: name,\n $vars: ['name']\n };\n formatterParams[mainType + 'Index'] = axisModel.componentIndex;\n var textEl = new graphic.Text({\n // Id for animation\n anid: 'name',\n __fullText: name,\n __truncatedText: truncatedText,\n position: pos,\n rotation: labelLayout.rotation,\n silent: isSilent(axisModel),\n z2: 1,\n tooltip: tooltipOpt && tooltipOpt.show ? extend({\n content: name,\n formatter: function () {\n return name;\n },\n formatterParams: formatterParams\n }, tooltipOpt) : null\n });\n graphic.setTextStyle(textEl.style, textStyleModel, {\n text: truncatedText,\n textFont: textFont,\n textFill: textStyleModel.getTextColor() || axisModel.get('axisLine.lineStyle.color'),\n textAlign: labelLayout.textAlign,\n textVerticalAlign: labelLayout.textVerticalAlign\n });\n\n if (axisModel.get('triggerEvent')) {\n textEl.eventData = makeAxisEventDataBase(axisModel);\n textEl.eventData.targetType = 'axisName';\n textEl.eventData.name = name;\n } // FIXME\n\n\n this._dumbGroup.add(textEl);\n\n textEl.updateTransform();\n this.group.add(textEl);\n textEl.decomposeTransform();\n }\n};\n/**\n * @public\n * @static\n * @param {Object} opt\n * @param {number} axisRotation in radian\n * @param {number} textRotation in radian\n * @param {number} direction\n * @return {Object} {\n * rotation, // according to axis\n * textAlign,\n * textVerticalAlign\n * }\n */\n\nvar innerTextLayout = AxisBuilder.innerTextLayout = function (axisRotation, textRotation, direction) {\n var rotationDiff = remRadian(textRotation - axisRotation);\n var textAlign;\n var textVerticalAlign;\n\n if (isRadianAroundZero(rotationDiff)) {\n // Label is parallel with axis line.\n textVerticalAlign = direction > 0 ? 'top' : 'bottom';\n textAlign = 'center';\n } else if (isRadianAroundZero(rotationDiff - PI)) {\n // Label is inverse parallel with axis line.\n textVerticalAlign = direction > 0 ? 'bottom' : 'top';\n textAlign = 'center';\n } else {\n textVerticalAlign = 'middle';\n\n if (rotationDiff > 0 && rotationDiff < PI) {\n textAlign = direction > 0 ? 'right' : 'left';\n } else {\n textAlign = direction > 0 ? 'left' : 'right';\n }\n }\n\n return {\n rotation: rotationDiff,\n textAlign: textAlign,\n textVerticalAlign: textVerticalAlign\n };\n};\n\nfunction endTextLayout(opt, textPosition, textRotate, extent) {\n var rotationDiff = remRadian(textRotate - opt.rotation);\n var textAlign;\n var textVerticalAlign;\n var inverse = extent[0] > extent[1];\n var onLeft = textPosition === 'start' && !inverse || textPosition !== 'start' && inverse;\n\n if (isRadianAroundZero(rotationDiff - PI / 2)) {\n textVerticalAlign = onLeft ? 'bottom' : 'top';\n textAlign = 'center';\n } else if (isRadianAroundZero(rotationDiff - PI * 1.5)) {\n textVerticalAlign = onLeft ? 'top' : 'bottom';\n textAlign = 'center';\n } else {\n textVerticalAlign = 'middle';\n\n if (rotationDiff < PI * 1.5 && rotationDiff > PI / 2) {\n textAlign = onLeft ? 'left' : 'right';\n } else {\n textAlign = onLeft ? 'right' : 'left';\n }\n }\n\n return {\n rotation: rotationDiff,\n textAlign: textAlign,\n textVerticalAlign: textVerticalAlign\n };\n}\n\nfunction isSilent(axisModel) {\n var tooltipOpt = axisModel.get('tooltip');\n return axisModel.get('silent') // Consider mouse cursor, add these restrictions.\n || !(axisModel.get('triggerEvent') || tooltipOpt && tooltipOpt.show);\n}\n\nfunction fixMinMaxLabelShow(axisModel, labelEls, tickEls) {\n if (shouldShowAllLabels(axisModel.axis)) {\n return;\n } // If min or max are user set, we need to check\n // If the tick on min(max) are overlap on their neighbour tick\n // If they are overlapped, we need to hide the min(max) tick label\n\n\n var showMinLabel = axisModel.get('axisLabel.showMinLabel');\n var showMaxLabel = axisModel.get('axisLabel.showMaxLabel'); // FIXME\n // Have not consider onBand yet, where tick els is more than label els.\n\n labelEls = labelEls || [];\n tickEls = tickEls || [];\n var firstLabel = labelEls[0];\n var nextLabel = labelEls[1];\n var lastLabel = labelEls[labelEls.length - 1];\n var prevLabel = labelEls[labelEls.length - 2];\n var firstTick = tickEls[0];\n var nextTick = tickEls[1];\n var lastTick = tickEls[tickEls.length - 1];\n var prevTick = tickEls[tickEls.length - 2];\n\n if (showMinLabel === false) {\n ignoreEl(firstLabel);\n ignoreEl(firstTick);\n } else if (isTwoLabelOverlapped(firstLabel, nextLabel)) {\n if (showMinLabel) {\n ignoreEl(nextLabel);\n ignoreEl(nextTick);\n } else {\n ignoreEl(firstLabel);\n ignoreEl(firstTick);\n }\n }\n\n if (showMaxLabel === false) {\n ignoreEl(lastLabel);\n ignoreEl(lastTick);\n } else if (isTwoLabelOverlapped(prevLabel, lastLabel)) {\n if (showMaxLabel) {\n ignoreEl(prevLabel);\n ignoreEl(prevTick);\n } else {\n ignoreEl(lastLabel);\n ignoreEl(lastTick);\n }\n }\n}\n\nfunction ignoreEl(el) {\n el && (el.ignore = true);\n}\n\nfunction isTwoLabelOverlapped(current, next, labelLayout) {\n // current and next has the same rotation.\n var firstRect = current && current.getBoundingRect().clone();\n var nextRect = next && next.getBoundingRect().clone();\n\n if (!firstRect || !nextRect) {\n return;\n } // When checking intersect of two rotated labels, we use mRotationBack\n // to avoid that boundingRect is enlarge when using `boundingRect.applyTransform`.\n\n\n var mRotationBack = matrixUtil.identity([]);\n matrixUtil.rotate(mRotationBack, mRotationBack, -current.rotation);\n firstRect.applyTransform(matrixUtil.mul([], mRotationBack, current.getLocalTransform()));\n nextRect.applyTransform(matrixUtil.mul([], mRotationBack, next.getLocalTransform()));\n return firstRect.intersect(nextRect);\n}\n\nfunction isNameLocationCenter(nameLocation) {\n return nameLocation === 'middle' || nameLocation === 'center';\n}\n\nfunction buildAxisTick(axisBuilder, axisModel, opt) {\n var axis = axisModel.axis;\n\n if (!axisModel.get('axisTick.show') || axis.scale.isBlank()) {\n return;\n }\n\n var tickModel = axisModel.getModel('axisTick');\n var lineStyleModel = tickModel.getModel('lineStyle');\n var tickLen = tickModel.get('length');\n var ticksCoords = axis.getTicksCoords();\n var pt1 = [];\n var pt2 = [];\n var matrix = axisBuilder._transform;\n var tickEls = [];\n\n for (var i = 0; i < ticksCoords.length; i++) {\n var tickCoord = ticksCoords[i].coord;\n pt1[0] = tickCoord;\n pt1[1] = 0;\n pt2[0] = tickCoord;\n pt2[1] = opt.tickDirection * tickLen;\n\n if (matrix) {\n v2ApplyTransform(pt1, pt1, matrix);\n v2ApplyTransform(pt2, pt2, matrix);\n } // Tick line, Not use group transform to have better line draw\n\n\n var tickEl = new graphic.Line(graphic.subPixelOptimizeLine({\n // Id for animation\n anid: 'tick_' + ticksCoords[i].tickValue,\n shape: {\n x1: pt1[0],\n y1: pt1[1],\n x2: pt2[0],\n y2: pt2[1]\n },\n style: defaults(lineStyleModel.getLineStyle(), {\n stroke: axisModel.get('axisLine.lineStyle.color')\n }),\n z2: 2,\n silent: true\n }));\n axisBuilder.group.add(tickEl);\n tickEls.push(tickEl);\n }\n\n return tickEls;\n}\n\nfunction buildAxisLabel(axisBuilder, axisModel, opt) {\n var axis = axisModel.axis;\n var show = retrieve(opt.axisLabelShow, axisModel.get('axisLabel.show'));\n\n if (!show || axis.scale.isBlank()) {\n return;\n }\n\n var labelModel = axisModel.getModel('axisLabel');\n var labelMargin = labelModel.get('margin');\n var labels = axis.getViewLabels(); // Special label rotate.\n\n var labelRotation = (retrieve(opt.labelRotate, labelModel.get('rotate')) || 0) * PI / 180;\n var labelLayout = innerTextLayout(opt.rotation, labelRotation, opt.labelDirection);\n var rawCategoryData = axisModel.getCategories(true);\n var labelEls = [];\n var silent = isSilent(axisModel);\n var triggerEvent = axisModel.get('triggerEvent');\n each(labels, function (labelItem, index) {\n var tickValue = labelItem.tickValue;\n var formattedLabel = labelItem.formattedLabel;\n var rawLabel = labelItem.rawLabel;\n var itemLabelModel = labelModel;\n\n if (rawCategoryData && rawCategoryData[tickValue] && rawCategoryData[tickValue].textStyle) {\n itemLabelModel = new Model(rawCategoryData[tickValue].textStyle, labelModel, axisModel.ecModel);\n }\n\n var textColor = itemLabelModel.getTextColor() || axisModel.get('axisLine.lineStyle.color');\n var tickCoord = axis.dataToCoord(tickValue);\n var pos = [tickCoord, opt.labelOffset + opt.labelDirection * labelMargin];\n var textEl = new graphic.Text({\n // Id for animation\n anid: 'label_' + tickValue,\n position: pos,\n rotation: labelLayout.rotation,\n silent: silent,\n z2: 10\n });\n graphic.setTextStyle(textEl.style, itemLabelModel, {\n text: formattedLabel,\n textAlign: itemLabelModel.getShallow('align', true) || labelLayout.textAlign,\n textVerticalAlign: itemLabelModel.getShallow('verticalAlign', true) || itemLabelModel.getShallow('baseline', true) || labelLayout.textVerticalAlign,\n textFill: typeof textColor === 'function' ? textColor( // (1) In category axis with data zoom, tick is not the original\n // index of axis.data. So tick should not be exposed to user\n // in category axis.\n // (2) Compatible with previous version, which always use formatted label as\n // input. But in interval scale the formatted label is like '223,445', which\n // maked user repalce ','. So we modify it to return original val but remain\n // it as 'string' to avoid error in replacing.\n axis.type === 'category' ? rawLabel : axis.type === 'value' ? tickValue + '' : tickValue, index) : textColor\n }); // Pack data for mouse event\n\n if (triggerEvent) {\n textEl.eventData = makeAxisEventDataBase(axisModel);\n textEl.eventData.targetType = 'axisLabel';\n textEl.eventData.value = rawLabel;\n } // FIXME\n\n\n axisBuilder._dumbGroup.add(textEl);\n\n textEl.updateTransform();\n labelEls.push(textEl);\n axisBuilder.group.add(textEl);\n textEl.decomposeTransform();\n });\n return labelEls;\n}\n\nvar _default = AxisBuilder;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar _util = require(\"zrender/lib/core/util\");\n\nvar each = _util.each;\nvar isArray = _util.isArray;\nvar isObject = _util.isObject;\n\nvar compatStyle = require(\"./helper/compatStyle\");\n\nvar _model = require(\"../util/model\");\n\nvar normalizeToArray = _model.normalizeToArray;\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n// Compatitable with 2.0\nfunction get(opt, path) {\n path = path.split(',');\n var obj = opt;\n\n for (var i = 0; i < path.length; i++) {\n obj = obj && obj[path[i]];\n\n if (obj == null) {\n break;\n }\n }\n\n return obj;\n}\n\nfunction set(opt, path, val, overwrite) {\n path = path.split(',');\n var obj = opt;\n var key;\n\n for (var i = 0; i < path.length - 1; i++) {\n key = path[i];\n\n if (obj[key] == null) {\n obj[key] = {};\n }\n\n obj = obj[key];\n }\n\n if (overwrite || obj[path[i]] == null) {\n obj[path[i]] = val;\n }\n}\n\nfunction compatLayoutProperties(option) {\n each(LAYOUT_PROPERTIES, function (prop) {\n if (prop[0] in option && !(prop[1] in option)) {\n option[prop[1]] = option[prop[0]];\n }\n });\n}\n\nvar LAYOUT_PROPERTIES = [['x', 'left'], ['y', 'top'], ['x2', 'right'], ['y2', 'bottom']];\nvar COMPATITABLE_COMPONENTS = ['grid', 'geo', 'parallel', 'legend', 'toolbox', 'title', 'visualMap', 'dataZoom', 'timeline'];\n\nfunction _default(option, isTheme) {\n compatStyle(option, isTheme); // Make sure series array for model initialization.\n\n option.series = normalizeToArray(option.series);\n each(option.series, function (seriesOpt) {\n if (!isObject(seriesOpt)) {\n return;\n }\n\n var seriesType = seriesOpt.type;\n\n if (seriesType === 'pie' || seriesType === 'gauge') {\n if (seriesOpt.clockWise != null) {\n seriesOpt.clockwise = seriesOpt.clockWise;\n }\n }\n\n if (seriesType === 'gauge') {\n var pointerColor = get(seriesOpt, 'pointer.color');\n pointerColor != null && set(seriesOpt, 'itemStyle.normal.color', pointerColor);\n }\n\n compatLayoutProperties(seriesOpt);\n }); // dataRange has changed to visualMap\n\n if (option.dataRange) {\n option.visualMap = option.dataRange;\n }\n\n each(COMPATITABLE_COMPONENTS, function (componentName) {\n var options = option[componentName];\n\n if (options) {\n if (!isArray(options)) {\n options = [options];\n }\n\n each(options, function (option) {\n compatLayoutProperties(option);\n });\n }\n });\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar RadiusAxis = require(\"./RadiusAxis\");\n\nvar AngleAxis = require(\"./AngleAxis\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @module echarts/coord/polar/Polar\n */\n\n/**\n * @alias {module:echarts/coord/polar/Polar}\n * @constructor\n * @param {string} name\n */\nvar Polar = function (name) {\n /**\n * @type {string}\n */\n this.name = name || '';\n /**\n * x of polar center\n * @type {number}\n */\n\n this.cx = 0;\n /**\n * y of polar center\n * @type {number}\n */\n\n this.cy = 0;\n /**\n * @type {module:echarts/coord/polar/RadiusAxis}\n * @private\n */\n\n this._radiusAxis = new RadiusAxis();\n /**\n * @type {module:echarts/coord/polar/AngleAxis}\n * @private\n */\n\n this._angleAxis = new AngleAxis();\n this._radiusAxis.polar = this._angleAxis.polar = this;\n};\n\nPolar.prototype = {\n type: 'polar',\n axisPointerEnabled: true,\n constructor: Polar,\n\n /**\n * @param {Array.<string>}\n * @readOnly\n */\n dimensions: ['radius', 'angle'],\n\n /**\n * @type {module:echarts/coord/PolarModel}\n */\n model: null,\n\n /**\n * If contain coord\n * @param {Array.<number>} point\n * @return {boolean}\n */\n containPoint: function (point) {\n var coord = this.pointToCoord(point);\n return this._radiusAxis.contain(coord[0]) && this._angleAxis.contain(coord[1]);\n },\n\n /**\n * If contain data\n * @param {Array.<number>} data\n * @return {boolean}\n */\n containData: function (data) {\n return this._radiusAxis.containData(data[0]) && this._angleAxis.containData(data[1]);\n },\n\n /**\n * @param {string} dim\n * @return {module:echarts/coord/polar/AngleAxis|module:echarts/coord/polar/RadiusAxis}\n */\n getAxis: function (dim) {\n return this['_' + dim + 'Axis'];\n },\n\n /**\n * @return {Array.<module:echarts/coord/Axis>}\n */\n getAxes: function () {\n return [this._radiusAxis, this._angleAxis];\n },\n\n /**\n * Get axes by type of scale\n * @param {string} scaleType\n * @return {module:echarts/coord/polar/AngleAxis|module:echarts/coord/polar/RadiusAxis}\n */\n getAxesByScale: function (scaleType) {\n var axes = [];\n var angleAxis = this._angleAxis;\n var radiusAxis = this._radiusAxis;\n angleAxis.scale.type === scaleType && axes.push(angleAxis);\n radiusAxis.scale.type === scaleType && axes.push(radiusAxis);\n return axes;\n },\n\n /**\n * @return {module:echarts/coord/polar/AngleAxis}\n */\n getAngleAxis: function () {\n return this._angleAxis;\n },\n\n /**\n * @return {module:echarts/coord/polar/RadiusAxis}\n */\n getRadiusAxis: function () {\n return this._radiusAxis;\n },\n\n /**\n * @param {module:echarts/coord/polar/Axis}\n * @return {module:echarts/coord/polar/Axis}\n */\n getOtherAxis: function (axis) {\n var angleAxis = this._angleAxis;\n return axis === angleAxis ? this._radiusAxis : angleAxis;\n },\n\n /**\n * Base axis will be used on stacking.\n *\n * @return {module:echarts/coord/polar/Axis}\n */\n getBaseAxis: function () {\n return this.getAxesByScale('ordinal')[0] || this.getAxesByScale('time')[0] || this.getAngleAxis();\n },\n\n /**\n * @param {string} [dim] 'radius' or 'angle' or 'auto' or null/undefined\n * @return {Object} {baseAxes: [], otherAxes: []}\n */\n getTooltipAxes: function (dim) {\n var baseAxis = dim != null && dim !== 'auto' ? this.getAxis(dim) : this.getBaseAxis();\n return {\n baseAxes: [baseAxis],\n otherAxes: [this.getOtherAxis(baseAxis)]\n };\n },\n\n /**\n * Convert a single data item to (x, y) point.\n * Parameter data is an array which the first element is radius and the second is angle\n * @param {Array.<number>} data\n * @param {boolean} [clamp=false]\n * @return {Array.<number>}\n */\n dataToPoint: function (data, clamp) {\n return this.coordToPoint([this._radiusAxis.dataToRadius(data[0], clamp), this._angleAxis.dataToAngle(data[1], clamp)]);\n },\n\n /**\n * Convert a (x, y) point to data\n * @param {Array.<number>} point\n * @param {boolean} [clamp=false]\n * @return {Array.<number>}\n */\n pointToData: function (point, clamp) {\n var coord = this.pointToCoord(point);\n return [this._radiusAxis.radiusToData(coord[0], clamp), this._angleAxis.angleToData(coord[1], clamp)];\n },\n\n /**\n * Convert a (x, y) point to (radius, angle) coord\n * @param {Array.<number>} point\n * @return {Array.<number>}\n */\n pointToCoord: function (point) {\n var dx = point[0] - this.cx;\n var dy = point[1] - this.cy;\n var angleAxis = this.getAngleAxis();\n var extent = angleAxis.getExtent();\n var minAngle = Math.min(extent[0], extent[1]);\n var maxAngle = Math.max(extent[0], extent[1]); // Fix fixed extent in polarCreator\n // FIXME\n\n angleAxis.inverse ? minAngle = maxAngle - 360 : maxAngle = minAngle + 360;\n var radius = Math.sqrt(dx * dx + dy * dy);\n dx /= radius;\n dy /= radius;\n var radian = Math.atan2(-dy, dx) / Math.PI * 180; // move to angleExtent\n\n var dir = radian < minAngle ? 1 : -1;\n\n while (radian < minAngle || radian > maxAngle) {\n radian += dir * 360;\n }\n\n return [radius, radian];\n },\n\n /**\n * Convert a (radius, angle) coord to (x, y) point\n * @param {Array.<number>} coord\n * @return {Array.<number>}\n */\n coordToPoint: function (coord) {\n var radius = coord[0];\n var radian = coord[1] / 180 * Math.PI;\n var x = Math.cos(radian) * radius + this.cx; // Inverse the y\n\n var y = -Math.sin(radian) * radius + this.cy;\n return [x, y];\n }\n};\nvar _default = Polar;\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar Gradient = require(\"zrender/lib/graphic/Gradient\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar _default = {\n createOnAllSeries: true,\n performRawSeries: true,\n reset: function (seriesModel, ecModel) {\n var data = seriesModel.getData();\n var colorAccessPath = (seriesModel.visualColorAccessPath || 'itemStyle.color').split('.');\n var color = seriesModel.get(colorAccessPath) // Set in itemStyle\n || seriesModel.getColorFromPalette( // TODO series count changed.\n seriesModel.name, null, ecModel.getSeriesCount()); // Default color\n // FIXME Set color function or use the platte color\n\n data.setVisual('color', color); // Only visible series has each data be visual encoded\n\n if (!ecModel.isSeriesFiltered(seriesModel)) {\n if (typeof color === 'function' && !(color instanceof Gradient)) {\n data.each(function (idx) {\n data.setItemVisual(idx, 'color', color(seriesModel.getDataParams(idx)));\n });\n } // itemStyle in each data item\n\n\n var dataEach = function (data, idx) {\n var itemModel = data.getItemModel(idx);\n var color = itemModel.get(colorAccessPath, true);\n\n if (color != null) {\n data.setItemVisual(idx, 'color', color);\n }\n };\n\n return {\n dataEach: data.hasItemOption ? dataEach : null\n };\n }\n }\n};\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar samplers = {\n average: function (frame) {\n var sum = 0;\n var count = 0;\n\n for (var i = 0; i < frame.length; i++) {\n if (!isNaN(frame[i])) {\n sum += frame[i];\n count++;\n }\n } // Return NaN if count is 0\n\n\n return count === 0 ? NaN : sum / count;\n },\n sum: function (frame) {\n var sum = 0;\n\n for (var i = 0; i < frame.length; i++) {\n // Ignore NaN\n sum += frame[i] || 0;\n }\n\n return sum;\n },\n max: function (frame) {\n var max = -Infinity;\n\n for (var i = 0; i < frame.length; i++) {\n frame[i] > max && (max = frame[i]);\n } // NaN will cause illegal axis extent.\n\n\n return isFinite(max) ? max : NaN;\n },\n min: function (frame) {\n var min = Infinity;\n\n for (var i = 0; i < frame.length; i++) {\n frame[i] < min && (min = frame[i]);\n } // NaN will cause illegal axis extent.\n\n\n return isFinite(min) ? min : NaN;\n },\n // TODO\n // Median\n nearest: function (frame) {\n return frame[0];\n }\n};\n\nvar indexSampler = function (frame, value) {\n return Math.round(frame.length / 2);\n};\n\nfunction _default(seriesType) {\n return {\n seriesType: seriesType,\n modifyOutputEnd: true,\n reset: function (seriesModel, ecModel, api) {\n var data = seriesModel.getData();\n var sampling = seriesModel.get('sampling');\n var coordSys = seriesModel.coordinateSystem; // Only cartesian2d support down sampling\n\n if (coordSys.type === 'cartesian2d' && sampling) {\n var baseAxis = coordSys.getBaseAxis();\n var valueAxis = coordSys.getOtherAxis(baseAxis);\n var extent = baseAxis.getExtent(); // Coordinste system has been resized\n\n var size = extent[1] - extent[0];\n var rate = Math.round(data.count() / size);\n\n if (rate > 1) {\n var sampler;\n\n if (typeof sampling === 'string') {\n sampler = samplers[sampling];\n } else if (typeof sampling === 'function') {\n sampler = sampling;\n }\n\n if (sampler) {\n // Only support sample the first dim mapped from value axis.\n seriesModel.setData(data.downSample(data.mapDimension(valueAxis.dim), 1 / rate, sampler, indexSampler));\n }\n }\n }\n }\n };\n}\n\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar textContain = require(\"zrender/lib/contain/text\");\n\nvar graphicUtil = require(\"../../util/graphic\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\nvar PATH_COLOR = ['textStyle', 'color'];\nvar _default = {\n /**\n * Get color property or get color from option.textStyle.color\n * @param {boolean} [isEmphasis]\n * @return {string}\n */\n getTextColor: function (isEmphasis) {\n var ecModel = this.ecModel;\n return this.getShallow('color') || (!isEmphasis && ecModel ? ecModel.get(PATH_COLOR) : null);\n },\n\n /**\n * Create font string from fontStyle, fontWeight, fontSize, fontFamily\n * @return {string}\n */\n getFont: function () {\n return graphicUtil.getFont({\n fontStyle: this.getShallow('fontStyle'),\n fontWeight: this.getShallow('fontWeight'),\n fontSize: this.getShallow('fontSize'),\n fontFamily: this.getShallow('fontFamily')\n }, this.ecModel);\n },\n getTextRect: function (text) {\n return textContain.getBoundingRect(text, this.getFont(), this.getShallow('align'), this.getShallow('verticalAlign') || this.getShallow('baseline'), this.getShallow('padding'), this.getShallow('lineHeight'), this.getShallow('rich'), this.getShallow('truncateText'));\n }\n};\nmodule.exports = _default;","\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\nvar zrUtil = require(\"zrender/lib/core/util\");\n\nvar graphic = require(\"../../util/graphic\");\n\nvar textContain = require(\"zrender/lib/contain/text\");\n\nvar formatUtil = require(\"../../util/format\");\n\nvar matrix = require(\"zrender/lib/core/matrix\");\n\nvar axisHelper = require(\"../../coord/axisHelper\");\n\nvar AxisBuilder = require(\"../axis/AxisBuilder\");\n\n/*\n* Licensed to the Apache Software Foundation (ASF) under one\n* or more contributor license agreements. See the NOTICE file\n* distributed with this work for additional information\n* regarding copyright ownership. The ASF licenses this file\n* to you under the Apache License, Version 2.0 (the\n* \"License\"); you may not use this file except in compliance\n* with the License. You may obtain a copy of the License at\n*\n* http://www.apache.org/licenses/LICENSE-2.0\n*\n* Unless required by applicable law or agreed to in writing,\n* software distributed under the License is distributed on an\n* \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n* KIND, either express or implied. See the License for the\n* specific language governing permissions and limitations\n* under the License.\n*/\n\n/**\n * @param {module:echarts/model/Model} axisPointerModel\n */\nfunction buildElStyle(axisPointerModel) {\n var axisPointerType = axisPointerModel.get('type');\n var styleModel = axisPointerModel.getModel(axisPointerType + 'Style');\n var style;\n\n if (axisPointerType === 'line') {\n style = styleModel.getLineStyle();\n style.fill = null;\n } else if (axisPointerType === 'shadow') {\n style = styleModel.getAreaStyle();\n style.stroke = null;\n }\n\n return style;\n}\n/**\n * @param {Function} labelPos {align, verticalAlign, position}\n */\n\n\nfunction buildLabelElOption(elOption, axisModel, axisPointerModel, api, labelPos) {\n var value = axisPointerModel.get('value');\n var text = getValueLabel(value, axisModel.axis, axisModel.ecModel, axisPointerModel.get('seriesDataIndices'), {\n precision: axisPointerModel.get('label.precision'),\n formatter: axisPointerModel.get('label.formatter')\n });\n var labelModel = axisPointerModel.getModel('label');\n var paddings = formatUtil.normalizeCssArray(labelModel.get('padding') || 0);\n var font = labelModel.getFont();\n var textRect = textContain.getBoundingRect(text, font);\n var position = labelPos.position;\n var width = textRect.width + paddings[1] + paddings[3];\n var height = textRect.height + paddings[0] + paddings[2]; // Adjust by align.\n\n var align = labelPos.align;\n align === 'right' && (position[0] -= width);\n align === 'center' && (position[0] -= width / 2);\n var verticalAlign = labelPos.verticalAlign;\n verticalAlign === 'bottom' && (position[1] -= height);\n verticalAlign === 'middle' && (position[1] -= height / 2); // Not overflow ec container\n\n confineInContainer(position, width, height, api);\n var bgColor = labelModel.get('backgroundColor');\n\n if (!bgColor || bgColor === 'auto') {\n bgColor = axisModel.get('axisLine.lineStyle.color');\n }\n\n elOption.label = {\n shape: {\n x: 0,\n y: 0,\n width: width,\n height: height,\n r: labelModel.get('borderRadius')\n },\n position: position.slice(),\n // TODO: rich\n style: {\n text: text,\n textFont: font,\n textFill: labelModel.getTextColor(),\n textPosition: 'inside',\n fill: bgColor,\n stroke: labelModel.get('borderColor') || 'transparent',\n lineWidth: labelModel.get('borderWidth') || 0,\n shadowBlur: labelModel.get('shadowBlur'),\n shadowColor: labelModel.get('shadowColor'),\n shadowOffsetX: labelModel.get('shadowOffsetX'),\n shadowOffsetY: labelModel.get('shadowOffsetY')\n },\n // Lable should be over axisPointer.\n z2: 10\n };\n} // Do not overflow ec container\n\n\nfunction confineInContainer(position, width, height, api) {\n var viewWidth = api.getWidth();\n var viewHeight = api.getHeight();\n position[0] = Math.min(position[0] + width, viewWidth) - width;\n position[1] = Math.min(position[1] + height, viewHeight) - height;\n position[0] = Math.max(position[0], 0);\n position[1] = Math.max(position[1], 0);\n}\n/**\n * @param {number} value\n * @param {module:echarts/coord/Axis} axis\n * @param {module:echarts/model/Global} ecModel\n * @param {Object} opt\n * @param {Array.<Object>} seriesDataIndices\n * @param {number|string} opt.precision 'auto' or a number\n * @param {string|Function} opt.formatter label formatter\n */\n\n\nfunction getValueLabel(value, axis, ecModel, seriesDataIndices, opt) {\n value = axis.scale.parse(value);\n var text = axis.scale.getLabel( // If `precision` is set, width can be fixed (like '12.00500'), which\n // helps to debounce when when moving label.\n value, {\n precision: opt.precision\n });\n var formatter = opt.formatter;\n\n if (formatter) {\n var params = {\n value: axisHelper.getAxisRawValue(axis, value),\n seriesData: []\n };\n zrUtil.each(seriesDataIndices, function (idxItem) {\n var series = ecModel.getSeriesByIndex(idxItem.seriesIndex);\n var dataIndex = idxItem.dataIndexInside;\n var dataParams = series && series.getDataParams(dataIndex);\n dataParams && params.seriesData.push(dataParams);\n });\n\n if (zrUtil.isString(formatter)) {\n text = formatter.replace('{value}', text);\n } else if (zrUtil.isFunction(formatter)) {\n text = formatter(params);\n }\n }\n\n return text;\n}\n/**\n * @param {module:echarts/coord/Axis} axis\n * @param {number} value\n * @param {Object} layoutInfo {\n * rotation, position, labelOffset, labelDirection, labelMargin\n * }\n */\n\n\nfunction getTransformedPosition(axis, value, layoutInfo) {\n var transform = matrix.create();\n matrix.rotate(transform, transform, layoutInfo.rotation);\n matrix.translate(transform, transform, layoutInfo.position);\n return graphic.applyTransform([axis.dataToCoord(value), (layoutInfo.labelOffset || 0) + (layoutInfo.labelDirection || 1) * (layoutInfo.labelMargin || 0)], transform);\n}\n\nfunction buildCartesianSingleLabelElOption(value, elOption, layoutInfo, axisModel, axisPointerModel, api) {\n var textLayout = AxisBuilder.innerTextLayout(layoutInfo.rotation, 0, layoutInfo.labelDirection);\n layoutInfo.labelMargin = axisPointerModel.get('label.margin');\n buildLabelElOption(elOption, axisModel, axisPointerModel, api, {\n position: getTransformedPosition(axisModel.axis, value, layoutInfo),\n align: textLayout.textAlign,\n verticalAlign: textLayout.textVerticalAlign\n });\n}\n/**\n * @param {Array.<number>} p1\n * @param {Array.<number>} p2\n * @param {number} [xDimIndex=0] or 1\n */\n\n\nfunction makeLineShape(p1, p2, xDimIndex) {\n xDimIndex = xDimIndex || 0;\n return {\n x1: p1[xDimIndex],\n y1: p1[1 - xDimIndex],\n x2: p2[xDimIndex],\n y2: p2[1 - xDimIndex]\n };\n}\n/**\n * @param {Array.<number>} xy\n * @param {Array.<number>} wh\n * @param {number} [xDimIndex=0] or 1\n */\n\n\nfunction makeRectShape(xy, wh, xDimIndex) {\n xDimIndex = xDimIndex || 0;\n return {\n x: xy[xDimIndex],\n y: xy[1 - xDimIndex],\n width: wh[xDimIndex],\n height: wh[1 - xDimIndex]\n };\n}\n\nfunction makeSectorShape(cx, cy, r0, r, startAngle, endAngle) {\n return {\n cx: cx,\n cy: cy,\n r0: r0,\n r: r,\n startAngle: startAngle,\n endAngle: endAngle,\n clockwise: true\n };\n}\n\nexports.buildElStyle = buildElStyle;\nexports.buildLabelElOption = buildLabelElOption;\nexports.getValueLabel = getValueLabel;\nexports.getTransformedPosition = getTransformedPosition;\nexports.buildCartesianSingleLabelElOption = buildCartesianSingleLabelElOption;\nexports.makeLineShape = makeLineShape;\nexports.makeRectShape = makeRectShape;\nexports.makeSectorShape = makeSectorShape;","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n"],"sourceRoot":""}