@v-charts2/sankey
Version:
echarts 桑葚图
8 lines (7 loc) • 13.1 kB
JavaScript
/* eslint-disable */
/**
* name: @v-charts2/sankey
* version: v1.0.1-alpha.4
* author: vxhly <pengchengou@gmail.com>
*/
var __defProp=Object.defineProperty,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(e,t,n)=>t in e?__defProp(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,__spreadValues=(e,t)=>{for(var n in t||(t={}))__hasOwnProp.call(t,n)&&__defNormalProp(e,n,t[n]);if(__getOwnPropSymbols)for(var n of __getOwnPropSymbols(t))__propIsEnum.call(t,n)&&__defNormalProp(e,n,t[n]);return e};!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("numerify"),require("utils-lite"),require("echarts/components"),require("echarts/core"),require("echarts/features"),require("echarts/renderers"),require("echarts/charts")):"function"==typeof define&&define.amd?define(["exports","numerify","utils-lite","echarts/components","echarts/core","echarts/features","echarts/renderers","echarts/charts"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["@v-charts2/sankey"]=e["@v-charts2/sankey"]||{},e.numerify,e.utilsLite,e["echarts/components"],e.echartsLib,e["echarts/features"],e["echarts/renderers"],e["echarts/charts"])}(this,(function(e,t,n,r,i,o,a,s){"use strict";function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function c(e){if(e&&e.__esModule)return e;var t={__proto__:null,[Symbol.toStringTag]:"Module"};return e&&Object.keys(e).forEach((function(n){if("default"!==n){var r=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,r.get?r:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var p=l(t),h=c(i);const d={categoryAxis:{axisLine:{show:!1},axisTick:{show:!1},splitLine:{show:!1}},valueAxis:{axisLine:{show:!1}},line:{smooth:!0},legend:{top:20},grid:{containLabel:!0,top:100,left:20,right:20,bottom:20}},u=["#19d4ae","#5ab1ef","#fa6e86","#ffb980","#0067a6","#c4b4e4","#d87a80","#9cbbff","#d9d0c7","#87a997","#d49ea2","#5b4947","#7ba3a8"],y=["initOptions","loading","dataEmpty","judgeWidth","widthChangeDelay"],b=["grid","dataZoom","visualMap","toolbox","title","legend","xAxis","yAxis","radar","tooltip","axisPointer","brush","geo","timeline","graphic","series","backgroundColor","textStyle"];h.use([r.TitleComponent,r.TooltipComponent,r.GridComponent,r.DatasetComponent,r.TransformComponent,o.LabelLayout,o.UniversalTransition,a.SVGRenderer,a.CanvasRenderer,r.LegendComponent]);const f=(e,t,r,i="-")=>{if(isNaN(e))return i;if(!t)return e;if(n.isFunction(t))return t(e,p.default);r=isNaN(r)?0:++r;const o=`.[${new Array(r).join(0)}]`;let a=t;switch(t){case"KMB":a=r?`0,0${o}a`:"0,0a";break;case"normal":a=r?`0,0${o}`:"0,0";break;case"percent":a=r?`0,0${o}%`:"0,0.[00]%"}return p.default(e,a)};const g=(e,t,n,r)=>{const{links:i,dimension:o=e[0],metrics:a=e[1],dataType:s=["normal","normal"],digit:l=2,valueFull:c=!1,useDataValue:p=!1,label:h,itemStyle:d,lineStyle:u}=n;if(!i)return;const y=function(e){const{itemDataType:t,linksDataType:n,digit:r}=e;return{trigger:"item",formatter(e){const i=[],{name:o,data:a,value:s,color:l}=e;return i.push((e=>['<span style="',`background-color:${e};`,"display: inline-block;","width: 10px;","height: 10px;","border-radius: 50%;","margin-right:2px;",'"></span>'].join(""))(l)),i.push(`${o} : `),a&&a.source?i.push(`${f(s,n,r)}<br />`):i.push(`${f(s,t,r)}<br />`),i.join("")}}}({itemDataType:s[0],linksDataType:s[1],digit:l}),b=function(e){const{rows:t,dimension:n,metrics:r,links:i,valueFull:o,useDataValue:a,label:s,itemStyle:l,lineStyle:c}=e,p={},h=t.map((e=>(p[e[n]]=e[r],{name:e[n],value:e[r]})));let d=null;d=a?i.map((e=>Object.assign({},e,{value:p[e.target]}))):o?i:i.map((e=>null==e.value?Object.assign({},e,{value:p[e.target]}):e));const u={type:"sankey",data:h,links:d};return s&&(u.label=s),l&&(u.itemStyle=l),c&&(u.lineStyle=c),[u]}({rows:t,dimension:o,metrics:a,links:i,valueFull:c,useDataValue:p,label:h,itemStyle:d,lineStyle:u});return{tooltip:y,series:b}},m={data:{type:[Object,Array],default:()=>({})},settings:{type:Object,default:()=>({})},width:{type:String,default:"auto"},height:{type:String,default:"400px"},beforeConfig:{type:Function},afterConfig:{type:Function},afterSetOption:{type:Function},afterSetOptionOnce:{type:Function},events:{type:Object},grid:{type:[Object,Array]},colors:{type:Array},tooltipVisible:{type:Boolean,default:!0},legendVisible:{type:Boolean,default:!0},legendPosition:{type:String},markLine:{type:Object},markArea:{type:Object},markPoint:{type:Object},visualMap:{type:[Object,Array]},dataZoom:{type:[Object,Array]},toolbox:{type:[Object,Array]},initOptions:{type:Object,default:()=>({})},title:[Object,Array],legend:[Object,Array],xAxis:[Object,Array],yAxis:[Object,Array],radar:Object,tooltip:Object,axisPointer:[Object,Array],brush:[Object,Array],geo:[Object,Array],timeline:[Object,Array],graphic:[Object,Array],series:[Object,Array],backgroundColor:[Object,String],textStyle:[Object,Array],animation:Object,theme:Object,themeName:String,loading:Boolean,dataEmpty:Boolean,extend:Object,judgeWidth:{type:Boolean,default:!1},widthChangeDelay:{type:Number,default:300},tooltipFormatter:{type:Function},resizeable:{type:Boolean,default:!0},resizeDelay:{type:Number,default:200},changeDelay:{type:Number,default:0},setOptionOpts:{type:[Boolean,Object],default:!0},cancelResizeCheck:Boolean,notSetUnchange:Array,log:Boolean,renderer:{type:String,default:"canvas",validator:e=>["svg","canvas"].indexOf(e)>-1}};function v(e,t){Object.keys(t).forEach((n=>{t[n]&&(e[n]=t[n])}))}const O=({echarts:e,props:t,canvas:n,options:r}={})=>{if(e)return;const{registeredEvents:i,_once:o,el:a}=r,s=(null==t?void 0:t.themeName)||(null==t?void 0:t.theme)||d;return e=h.init(n,s,__spreadValues({renderer:null==t?void 0:t.renderer},null==t?void 0:t.initOptions)),(null==t?void 0:t.data)&&_({props:t,options:r,echarts:e}),k({registeredEvents:i,echarts:e,props:t}),(null==t?void 0:t.resizeable)&&x({_once:o,props:t,el:a,echarts:e}),{echarts:e}},_=({props:e,options:t,echarts:r}={})=>n.debounce(w({props:e,options:t,echarts:r}),null==e?void 0:e.changeDelay),j=({props:e,el:t,echarts:r}={})=>n.debounce(A({props:e,el:t,echarts:r}),null==e?void 0:e.resizeDelay),k=({registeredEvents:e,echarts:t,props:n})=>{const r=Object.keys((null==n?void 0:n.events)||{});r.length&&r.forEach((r=>{var i;-1===e.indexOf(r)&&(e.push(r),t.on(r,(i=r,function(...e){i in n.events&&(null==n||n.events[i].apply(null,e))})))}))},x=({_once:e,props:t,el:n,echarts:r})=>{window.addEventListener("resize",(()=>j({props:t,el:n,echarts:r}))),e.onresize=!0},S=({_once:e})=>{window.removeEventListener("resize",j),e.onresize=!1},w=({props:e,options:t,echarts:n}={})=>{const{chartHandler:r,chartColor:i,_once:o}=t;if(!r)return;let a=null==e?void 0:e.data;const{columns:s=[],rows:l=[]}=a,c={tooltipVisible:null==e?void 0:e.tooltipVisible,legendVisible:null==e?void 0:e.legendVisible,echarts:n,color:i,tooltipFormatter:null==e?void 0:e.tooltipFormatter,_once:o};(null==e?void 0:e.beforeConfig)&&(a=null==e?void 0:e.beforeConfig(a));const p=r(s,l,null==e?void 0:e.settings,c);p&&("function"==typeof p.then?p.then((r=>{P({chartOptions:r,props:e,options:t,echarts:n})})):P({chartOptions:p,props:e,options:t,echarts:n}))},P=({chartOptions:e,props:t,options:r,echarts:i,nextTick:o})=>{const{chartColor:a,_store:s,_once:l,el:c,readyCallback:p,readyOnceCallback:d}=r;if((null==t?void 0:t.legendPosition)&&e.legend&&(e.legend[null==t?void 0:t.legendPosition]=10,~["left","right"].indexOf(null==t?void 0:t.legendPosition)&&(e.legend.top="middle",e.legend.orient="vertical")),e.color=a,b.forEach((n=>{(null==t?void 0:t[n])&&(e[n]=null==t?void 0:t[n])})),(null==t?void 0:t.animation)&&function(e,t){Object.keys(t).forEach((n=>{e[n]=t[n]}))}(e,null==t?void 0:t.animation),(null==t?void 0:t.markArea)||(null==t?void 0:t.markLine)||(null==t?void 0:t.markPoint)){const r={markArea:null==t?void 0:t.markArea,markLine:null==t?void 0:t.markLine,markPoint:null==t?void 0:t.markPoint},i=e.series;n.isArray(i)?i.forEach((e=>{v(e,r)})):n.isObject(i)&&v(i,r)}(null==t?void 0:t.extend)&&function(e,t){Object.keys(t).forEach((r=>{const i=t[r];~r.indexOf(".")?n.set(e,r,i):"function"==typeof i?e[r]=i(e[r]):n.isArray(e[r])&&n.isObject(e[r][0])?e[r].forEach(((t,n)=>{e[r][n]=Object.assign({},t,i)})):n.isObject(e[r])?e[r]=Object.assign({},e[r],i):e[r]=i}))}(e,null==t?void 0:t.extend),(null==t?void 0:t.afterConfig)&&(e=null==t?void 0:t.afterConfig(e));let u=null==t?void 0:t.setOptionOpts;!(null==t?void 0:t.settings.bmap)&&!(null==t?void 0:t.settings.amap)||n.isObject(u)||(u=!1),(null==t?void 0:t.notSetUnchange)&&(null==t?void 0:t.notSetUnchange.length)&&(null==t||t.notSetUnchange.forEach((t=>{const r=e[t];r&&(n.isEqual(r,s[t])?e[t]=void 0:s[t]=n.cloneDeep(r))})),n.isObject(u)?u.notMerge=!1:u=!1),null==t||t.log,i.setOption(e,u),p instanceof Function&&p(i,e,h),l["ready-once"]||(l["ready-once"]=!0,d instanceof Function&&d(i,e,h)),(null==t?void 0:t.judgeWidth)&&T({props:t,el:c,nextTick:o,echarts:i}),(null==t?void 0:t.afterSetOption)&&(null==t||t.afterSetOption(i,e,h)),(null==t?void 0:t.afterSetOptionOnce)&&!l.afterSetOptionOnce&&(l.afterSetOptionOnce=!0,null==t||t.afterSetOptionOnce(i,e,h))},T=({props:e,el:t,nextTick:n,echarts:r})=>{t.clientWidth||t.clientHeight?A({props:e,el:t,echarts:r}):n((()=>{t.clientWidth||t.clientHeight?A({props:e,el:t,echarts:r}):setTimeout((()=>{A({props:e,el:t,echarts:r}),!t.clientWidth||t.clientHeight}),null==e?void 0:e.widthChangeDelay)}))},A=({props:e,el:t,echarts:n}={})=>{((null==e?void 0:e.cancelResizeCheck)||t&&t.clientWidth&&t.clientHeight)&&$(n)},$=e=>{e&&e.resize()},C=(e,t)=>{let{echarts:n,option:{_once:r}}=e;E({echarts:n,props:t,_once:r}),n=null,O(e)},E=({echarts:e,props:t,_once:n})=>{(null==t?void 0:t.resizeable)&&S({_once:n}),e&&e.dispose()};var z={render(e){return e("div",{class:[n.camelToKebab(this.$options.name||this.$options._componentTag)],style:this.canvasStyle},[e("div",{style:this.canvasStyle,class:{"v-charts-mask-status":this.dataEmpty||this.loading},ref:"canvas"}),e("div",{class:"v-charts-data-empty",style:{display:this.dataEmpty?"":"none"}},"暂无数据"),e("div",{style:{display:this.loading?"":"none"},class:"v-charts-component-loading"},[e("div",{class:"loader"},[e("div",{class:"loading-spinner"},[e("svg",{class:"circular",attrs:{viewBox:"25 25 50 50"}},[e("circle",{class:"path",attrs:{cx:"50",cy:"50",r:"20",fill:"none"}})])])])]),this.$slots.default])},props:m,created(){this.echarts=null,this.registeredEvents=[],this._once={},this._store={},this._watchers=[],this.initPayload={}},data:()=>({chartLib:null,echarts:null,registeredEvents:[],_once:{},_store:{},_watchers:[],initPayload:{}}),watch:{data:{deep:!0,handler(e){e&&_({props:this.$props,options:this.initPayload.options,echarts:this.echarts})}},settings:{deep:!0,handler(e){e.type&&this.chartLib&&(this.chartHandler=this.chartLib[e.type]),this.initPayload.options.chartHandler=this.chartLib[e.type],_({props:this.$props,options:this.initPayload.options,echarts:this.echarts})}},width:"nextTickResize",height:"nextTickResize",events:{deep:!0,handler(){k({registeredEvents:this.registeredEvents,echarts:this.echarts,props:this.$props})}},theme:{deep:!0,handler(e){C(this.initPayload,m)}},themeName:e=>{C(globalThis.initPayload,m)},resizeable:e=>{globalThis.$nextTick((()=>{(({resizeable:e,_once:t,props:n,el:r,echarts:i})=>{e&&!t.onresize&&x({_once:t,props:n,el:r,echarts:i}),!e&&t.onresize&&S({_once:t})})({resizeable:globalThis.resizeable,_once:globalThis._once,props:globalThis.$props,el:globalThis.$el,echarts:globalThis.echarts})}))}},computed:{canvasStyle(){return{width:this.width,height:this.height,position:"relative"}},chartColor(){return this.colors||this.theme&&this.theme.color||u}},mounted(){const{echarts:e,$props:t,$el:n,registeredEvents:r,chartHandler:i,_once:o,_store:a,$nextTick:s,_watchers:l}=this,c={echarts:e,props:t,canvas:this.$refs.canvas,options:{el:n,registeredEvents:r,chartHandler:i,chartColor:this.chartColor,_once:o,_store:a,readyCallback:(e,t,n)=>{this.$emit("ready",e,t,n)},readyOnceCallback:(e,t,n)=>{this.$emit("ready-once",e,t,n)}},nextTick:s},{echarts:p}=O(c);this.echarts=p,this.initPayload=c,this.addWatchToProps({_watchers:l,props:t,options:c.options,echarts:this.echarts})},beforeDestroy(){E({echarts:this.echarts,props:this.$props,_once:this._once})},methods:{addWatchToProps(){const e=this._watchers.map((e=>e.expression));Object.keys(this.$props).forEach((t=>{if(!~e.indexOf(t)&&!~y.indexOf(t)){const e={};~["[object Object]","[object Array]"].indexOf(n.getType(this.$props[t]))&&(e.deep=!0),this.$watch(t,(()=>{_({props:this.$props,options:this.initPayload.options,echarts:this.echarts})}),e)}}))},nextTickResize(){this.$nextTick(A({props:this.$props,el:this.$el,echarts:this.echarts}))}},_numerify:p.default};h.use([s.SankeyChart]);const L=Object.assign({},z,{name:"VeSankey",data(){return this.chartHandler=g,{}}});L.install=e=>{e.component(L.name,L)},e.default=L,Object.defineProperty(e,"__esModule",{value:!0}),e[Symbol.toStringTag]="Module"}));