@v-charts2/sankey
Version:
echarts 桑葚图
8 lines (7 loc) • 12.6 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,n,o,i,a,r,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 o=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,o.get?o:{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([o.TitleComponent,o.TooltipComponent,o.GridComponent,o.DatasetComponent,o.TransformComponent,a.LabelLayout,a.UniversalTransition,r.SVGRenderer,r.CanvasRenderer,o.LegendComponent]);const g=(e,t,o,i="-")=>{if(isNaN(e))return i;if(!t)return e;if(n.isFunction(t))return t(e,p.default);o=isNaN(o)?0:++o;const a=`.[${new Array(o).join(0)}]`;let r=t;switch(t){case"KMB":r=o?`0,0${a}a`:"0,0a";break;case"normal":r=o?`0,0${a}`:"0,0";break;case"percent":r=o?`0,0${a}%`:"0,0.[00]%"}return p.default(e,r)};const f=(e,t,n,o)=>{const{links:i,dimension:a=e[0],metrics:r=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:o}=e;return{trigger:"item",formatter(e){const i=[],{name:a,data:r,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(`${a} : `),r&&r.source?i.push(`${g(s,n,o)}<br />`):i.push(`${g(s,t,o)}<br />`),i.join("")}}}({itemDataType:s[0],linksDataType:s[1],digit:l}),b=function(e){const{rows:t,dimension:n,metrics:o,links:i,valueFull:a,useDataValue:r,label:s,itemStyle:l,lineStyle:c}=e,p={},h=t.map((e=>(p[e[n]]=e[o],{name:e[n],value:e[o]})));let d=null;d=r?i.map((e=>Object.assign({},e,{value:p[e.target]}))):a?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:a,metrics:r,links:i,valueFull:c,useDataValue:p,label:h,itemStyle:d,lineStyle:u});return{tooltip:y,series:b}},v={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 m(e,t){Object.keys(t).forEach((n=>{t[n]&&(e[n]=t[n])}))}const O=({echarts:e,props:t,canvas:n,options:o}={})=>{if(e)return;const{registeredEvents:i,_once:a,el:r}=o,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:o,echarts:e}),k({registeredEvents:i,echarts:e,props:t}),(null==t?void 0:t.resizeable)&&x({_once:a,props:t,el:r,echarts:e}),{echarts:e}},_=({props:e,options:t,echarts:o}={})=>n.debounce(w({props:e,options:t,echarts:o}),null==e?void 0:e.changeDelay),j=({props:e,el:t,echarts:o}={})=>n.debounce(A({props:e,el:t,echarts:o}),null==e?void 0:e.resizeDelay),k=({registeredEvents:e,echarts:t,props:n})=>{const o=Object.keys((null==n?void 0:n.events)||{});o.length&&o.forEach((o=>{var i;-1===e.indexOf(o)&&(e.push(o),t.on(o,(i=o,function(...e){i in n.events&&(null==n||n.events[i].apply(null,e))})))}))},x=({_once:e,props:t,el:n,echarts:o})=>{window.addEventListener("resize",(()=>j({props:t,el:n,echarts:o}))),e.onresize=!0},S=({_once:e})=>{window.removeEventListener("resize",j),e.onresize=!1},w=({props:e,options:t,echarts:n}={})=>{const{chartHandler:o,chartColor:i,_once:a}=t;if(!o)return;let r=null==e?void 0:e.data;const{columns:s=[],rows:l=[]}=r,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:a};(null==e?void 0:e.beforeConfig)&&(r=null==e?void 0:e.beforeConfig(r));const p=o(s,l,null==e?void 0:e.settings,c);p&&("function"==typeof p.then?p.then((o=>{P({chartOptions:o,props:e,options:t,echarts:n})})):P({chartOptions:p,props:e,options:t,echarts:n}))},P=({chartOptions:e,props:t,options:o,echarts:i,nextTick:a})=>{const{chartColor:r,_store:s,_once:l,el:c,readyCallback:p,readyOnceCallback:d}=o;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=r,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 o={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=>{m(e,o)})):n.isObject(i)&&m(i,o)}(null==t?void 0:t.extend)&&function(e,t){Object.keys(t).forEach((o=>{const i=t[o];~o.indexOf(".")?n.set(e,o,i):"function"==typeof i?e[o]=i(e[o]):n.isArray(e[o])&&n.isObject(e[o][0])?e[o].forEach(((t,n)=>{e[o][n]=Object.assign({},t,i)})):n.isObject(e[o])?e[o]=Object.assign({},e[o],i):e[o]=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 o=e[t];o&&(n.isEqual(o,s[t])?e[t]=void 0:s[t]=n.cloneDeep(o))})),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:a,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:o})=>{t.clientWidth||t.clientHeight?A({props:e,el:t,echarts:o}):n((()=>{t.clientWidth||t.clientHeight?A({props:e,el:t,echarts:o}):setTimeout((()=>{A({props:e,el:t,echarts:o}),!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:o}}=e;E({echarts:n,props:t,_once:o}),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:v,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,v)}},themeName:e=>{C(globalThis.initPayload,v)},resizeable:e=>{globalThis.$nextTick((()=>{(({resizeable:e,_once:t,props:n,el:o,echarts:i})=>{e&&!t.onresize&&x({_once:t,props:n,el:o,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:o,chartHandler:i,_once:a,_store:r,$nextTick:s,_watchers:l}=this,c={echarts:e,props:t,canvas:this.$refs.canvas,options:{el:n,registeredEvents:o,chartHandler:i,chartColor:this.chartColor,_once:a,_store:r,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=f,{}}});L.install=e=>{e.component(L.name,L)},e.default=L,Object.defineProperty(e,"__esModule",{value:!0}),e[Symbol.toStringTag]="Module"}(this["@v-charts2/sankey"]=this["@v-charts2/sankey"]||{},numerify,utilsLite,echarts/components,echartsLib,echarts/features,echarts/renderers,echarts/charts);