@nivo/sankey
Advanced tools
Comparing version 0.81.0 to 0.82.0
@@ -1,2 +0,2 @@ | ||
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("lodash/uniq"),o=require("react"),n=require("@nivo/core"),t=require("@nivo/legends"),i=require("d3-sankey"),r=require("@nivo/tooltip"),a=require("react/jsx-runtime"),l=require("lodash/cloneDeep"),d=require("@nivo/colors"),s=require("@react-spring/web"),c=require("d3-shape");function u(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var h=u(e),p=u(l);function v(){return v=Object.assign||function(e){for(var o=1;o<arguments.length;o++){var n=arguments[o];for(var t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=n[t])}return e},v.apply(this,arguments)}var g={container:{display:"flex",alignItems:"center"},sourceChip:{marginRight:7},targetChip:{marginLeft:7,marginRight:7}},y={center:i.sankeyCenter,justify:i.sankeyJustify,start:i.sankeyLeft,end:i.sankeyRight},f=Object.keys(y),k=function(e){return y[e]},x={layout:"horizontal",align:"center",sort:"auto",colors:{scheme:"nivo"},nodeOpacity:.75,nodeHoverOpacity:1,nodeHoverOthersOpacity:.15,nodeThickness:12,nodeSpacing:12,nodeInnerPadding:0,nodeBorderWidth:1,nodeBorderColor:{from:"color",modifiers:[["darker",.5]]},nodeBorderRadius:0,linkOpacity:.25,linkHoverOpacity:.6,linkHoverOthersOpacity:.15,linkContract:0,linkBlendMode:"multiply",enableLinkGradient:!1,enableLabels:!0,label:"id",labelPosition:"inside",labelPadding:9,labelOrientation:"horizontal",labelTextColor:{from:"color",modifiers:[["darker",.8]]},isInteractive:!0,nodeTooltip:function(e){var o=e.node;return a.jsx(r.BasicTooltip,{id:o.label,enableChip:!0,color:o.color})},linkTooltip:function(e){var o=e.link;return a.jsx(r.BasicTooltip,{id:a.jsxs("span",{style:g.container,children:[a.jsx(r.Chip,{color:o.source.color,style:g.sourceChip}),a.jsx("strong",{children:o.source.label})," > ",a.jsx("strong",{children:o.target.label}),a.jsx(r.Chip,{color:o.target.color,style:g.targetChip}),a.jsx("strong",{children:o.formattedValue})]})})},legends:[],layers:["links","nodes","labels","legends"],role:"img",animate:!0,motionConfig:"gentle"},m=function(e){return e.id},b=function(e){var t=e.data,r=e.valueFormat,a=e.layout,l=e.width,s=e.height,c=e.sort,u=e.align,h=e.colors,v=e.nodeThickness,g=e.nodeSpacing,y=e.nodeInnerPadding,f=e.nodeBorderColor,x=e.label,b=e.labelTextColor,C=o.useState(null),O=C[0],j=C[1],M=o.useState(null),L=M[0],T=M[1],B=o.useMemo((function(){if("auto"!==c)return"input"===c?null:"ascending"===c?function(e,o){return e.value-o.value}:"descending"===c?function(e,o){return o.value-e.value}:c}),[c]),I="input"===c?null:void 0,w=o.useMemo((function(){return"function"==typeof u?u:k(u)}),[u]),P=n.useTheme(),H=d.useOrdinalColorScale(h,"id"),S=d.useInheritedColor(f,P),W=n.usePropertyAccessor(x),F=d.useInheritedColor(b,P),N=n.useValueFormatter(r),E=o.useMemo((function(){return function(e){var o=e.data,n=e.formatValue,t=e.layout,r=e.alignFunction,a=e.sortFunction,l=e.linkSortMode,d=e.nodeThickness,s=e.nodeSpacing,c=e.nodeInnerPadding,u=e.width,h=e.height,v=e.getColor,g=e.getLabel,y=i.sankey().nodeAlign(r).nodeSort(a).linkSort(l).nodeWidth(d).nodePadding(s).size("horizontal"===t?[u,h]:[h,u]).nodeId(m),f=p.default(o);return y(f),f.nodes.forEach((function(e){if(e.color=v(e),e.label=g(e),e.formattedValue=n(e.value),"horizontal"===t)e.x=e.x0+c,e.y=e.y0,e.width=Math.max(e.x1-e.x0-2*c,0),e.height=Math.max(e.y1-e.y0,0);else{e.x=e.y0,e.y=e.x0+c,e.width=Math.max(e.y1-e.y0,0),e.height=Math.max(e.x1-e.x0-2*c,0);var o=e.x0,i=e.x1;e.x0=e.y0,e.x1=e.y1,e.y0=o,e.y1=i}})),f.links.forEach((function(e){e.formattedValue=n(e.value),e.color=e.source.color,e.pos0=e.y0,e.pos1=e.y1,e.thickness=e.width,delete e.y0,delete e.y1,delete e.width})),f}({data:t,formatValue:N,layout:a,alignFunction:w,sortFunction:B,linkSortMode:I,nodeThickness:v,nodeSpacing:g,nodeInnerPadding:y,width:l,height:s,getColor:H,getLabel:W})}),[t,N,a,w,B,I,v,g,y,l,s,H,W]),R=E.nodes,q=E.links,A=o.useMemo((function(){return R.map((function(e){return{id:e.id,label:e.label,color:e.color}}))}),[R]);return{nodes:R,links:q,legendData:A,getNodeBorderColor:S,currentNode:O,setCurrentNode:j,currentLink:L,setCurrentLink:T,getLabelTextColor:F}},C=function(e){var t=e.node,i=e.x,l=e.y,d=e.width,c=e.height,u=e.color,h=e.opacity,p=e.borderWidth,v=e.borderColor,g=e.borderRadius,y=e.setCurrent,f=e.isInteractive,k=e.onClick,x=e.tooltip,m=n.useMotionConfig(),b=m.animate,C=m.config,O=s.useSpring({x:i,y:l,width:d,height:c,opacity:h,color:u,config:C,immediate:!b}),j=r.useTooltip(),M=j.showTooltipFromEvent,L=j.hideTooltip,T=o.useCallback((function(e){y(t),M(o.createElement(x,{node:t}),e,"left")}),[y,t,M,x]),B=o.useCallback((function(e){M(o.createElement(x,{node:t}),e,"left")}),[M,t,x]),I=o.useCallback((function(){y(null),L()}),[y,L]),w=o.useCallback((function(e){null==k||k(t,e)}),[k,t]);return a.jsx(s.animated.rect,{x:O.x,y:O.y,rx:g,ry:g,width:O.width.to((function(e){return Math.max(e,0)})),height:O.height.to((function(e){return Math.max(e,0)})),fill:O.color,fillOpacity:O.opacity,strokeWidth:p,stroke:v,strokeOpacity:h,onMouseEnter:f?T:void 0,onMouseMove:f?B:void 0,onMouseLeave:f?I:void 0,onClick:f?w:void 0})},O=function(e){var o=e.nodes,n=e.nodeOpacity,t=e.nodeHoverOpacity,i=e.nodeHoverOthersOpacity,r=e.borderWidth,l=e.getBorderColor,d=e.borderRadius,s=e.setCurrentNode,c=e.currentNode,u=e.currentLink,h=e.isCurrentNode,p=e.isInteractive,v=e.onClick,g=e.tooltip,y=function(e){return c||u?h(e)?t:i:n};return a.jsx(a.Fragment,{children:o.map((function(e){return a.jsx(C,{node:e,x:e.x,y:e.y,width:e.width,height:e.height,color:e.color,opacity:y(e),borderWidth:r,borderColor:l(e),borderRadius:d,setCurrent:s,isInteractive:p,onClick:v,tooltip:g},e.id)}))})},j=function(e){var o,n=e.id,t=e.layout,i=e.startColor,r=e.endColor;return o="horizontal"===t?{x1:"0%",x2:"100%",y1:"0%",y2:"0%"}:{x1:"0%",x2:"0%",y1:"0%",y2:"100%"},a.jsxs("linearGradient",v({id:n,spreadMethod:"pad"},o,{children:[a.jsx("stop",{offset:"0%",stopColor:i}),a.jsx("stop",{offset:"100%",stopColor:r})]}))},M=function(e){var t=e.link,i=e.layout,l=e.path,d=e.color,c=e.opacity,u=e.blendMode,h=e.enableGradient,p=e.setCurrent,v=e.tooltip,g=e.isInteractive,y=e.onClick,f=t.source.id+"."+t.target.id+"."+t.index,k=n.useMotionConfig(),x=k.animate,m=k.config,b=n.useAnimatedPath(l),C=s.useSpring({color:d,opacity:c,config:m,immediate:!x}),O=r.useTooltip(),M=O.showTooltipFromEvent,L=O.hideTooltip,T=o.useCallback((function(e){p(t),M(o.createElement(v,{link:t}),e,"left")}),[p,t,M,v]),B=o.useCallback((function(e){M(o.createElement(v,{link:t}),e,"left")}),[M,t,v]),I=o.useCallback((function(){p(null),L()}),[p,L]),w=o.useCallback((function(e){null==y||y(t,e)}),[y,t]);return a.jsxs(a.Fragment,{children:[h&&a.jsx(j,{id:f,layout:i,startColor:t.startColor||t.source.color,endColor:t.endColor||t.target.color}),a.jsx(s.animated.path,{fill:h?'url("#'+encodeURI(f)+'")':C.color,d:b,fillOpacity:C.opacity,onMouseEnter:g?T:void 0,onMouseMove:g?B:void 0,onMouseLeave:g?I:void 0,onClick:g?w:void 0,style:{mixBlendMode:u}})]})},L=function(e){var n=e.links,t=e.layout,i=e.linkOpacity,r=e.linkHoverOpacity,l=e.linkHoverOthersOpacity,d=e.linkContract,s=e.linkBlendMode,u=e.enableLinkGradient,h=e.setCurrentLink,p=e.currentLink,v=e.currentNode,g=e.isCurrentLink,y=e.isInteractive,f=e.onClick,k=e.tooltip,x=function(e){return v||p?g(e)?r:l:i},m=o.useMemo((function(){return"horizontal"===t?(e=c.line().curve(c.curveMonotoneX),function(o,n){var t=Math.max(1,o.thickness-2*n)/2,i=.12*(o.target.x0-o.source.x1),r=[[o.source.x1,o.pos0-t],[o.source.x1+i,o.pos0-t],[o.target.x0-i,o.pos1-t],[o.target.x0,o.pos1-t],[o.target.x0,o.pos1+t],[o.target.x0-i,o.pos1+t],[o.source.x1+i,o.pos0+t],[o.source.x1,o.pos0+t],[o.source.x1,o.pos0-t]];return e(r)+"Z"}):function(){var e=c.line().curve(c.curveMonotoneY);return function(o,n){var t=Math.max(1,o.thickness-2*n)/2,i=.12*(o.target.y0-o.source.y1),r=[[o.pos0+t,o.source.y1],[o.pos0+t,o.source.y1+i],[o.pos1+t,o.target.y0-i],[o.pos1+t,o.target.y0],[o.pos1-t,o.target.y0],[o.pos1-t,o.target.y0-i],[o.pos0-t,o.source.y1+i],[o.pos0-t,o.source.y1],[o.pos0+t,o.source.y1]];return e(r)+"Z"}}();var e}),[t]);return a.jsx(a.Fragment,{children:n.map((function(e){return a.jsx(M,{link:e,layout:t,path:m(e,d),color:e.color,opacity:x(e),blendMode:s,enableGradient:u,setCurrent:h,isInteractive:y,onClick:f,tooltip:k},e.source.id+"."+e.target.id+"."+e.index)}))})},T=function(e){var o=e.nodes,t=e.layout,i=e.width,r=e.height,l=e.labelPosition,d=e.labelPadding,c=e.labelOrientation,u=e.getLabelTextColor,h=n.useTheme(),p="vertical"===c?-90:0,g=o.map((function(e){var o,n,a;return"horizontal"===t?(n=e.y+e.height/2,e.x<i/2?"inside"===l?(o=e.x1+d,a="vertical"===c?"middle":"start"):(o=e.x-d,a="vertical"===c?"middle":"end"):"inside"===l?(o=e.x-d,a="vertical"===c?"middle":"end"):(o=e.x1+d,a="vertical"===c?"middle":"start")):"vertical"===t&&(o=e.x+e.width/2,e.y<r/2?"inside"===l?(n=e.y1+d,a="vertical"===c?"end":"middle"):(n=e.y-d,a="vertical"===c?"start":"middle"):"inside"===l?(n=e.y-d,a="vertical"===c?"start":"middle"):(n=e.y1+d,a="vertical"===c?"end":"middle")),{id:e.id,label:e.label,x:o,y:n,textAnchor:a,color:u(e)}})),y=n.useMotionConfig(),f=y.animate,k=y.config,x=s.useSprings(g.length,g.map((function(e){return{transform:"translate("+e.x+", "+e.y+") rotate("+p+")",color:e.color,config:k,immediate:!f}})));return a.jsx(a.Fragment,{children:x.map((function(e,o){var n=g[o];return a.jsx(s.animated.text,{dominantBaseline:"central",textAnchor:n.textAnchor,transform:e.transform,style:v({},h.labels.text,{fill:e.color,pointerEvents:"none"}),children:n.label},n.id)}))})},B=["isInteractive","animate","motionConfig","theme","renderWrapper"],I=function(e){var i=e.data,r=e.valueFormat,l=e.layout,d=void 0===l?x.layout:l,s=e.sort,c=void 0===s?x.sort:s,u=e.align,p=void 0===u?x.align:u,g=e.width,y=e.height,f=e.margin,k=e.colors,m=void 0===k?x.colors:k,C=e.nodeThickness,j=void 0===C?x.nodeThickness:C,M=e.nodeSpacing,B=void 0===M?x.nodeThickness:M,I=e.nodeInnerPadding,w=void 0===I?x.nodeInnerPadding:I,P=e.nodeBorderColor,H=void 0===P?x.nodeBorderColor:P,S=e.nodeOpacity,W=void 0===S?x.nodeOpacity:S,F=e.nodeHoverOpacity,N=void 0===F?x.nodeHoverOpacity:F,E=e.nodeHoverOthersOpacity,R=void 0===E?x.nodeHoverOthersOpacity:E,q=e.nodeBorderWidth,A=void 0===q?x.nodeBorderWidth:q,z=e.nodeBorderRadius,G=void 0===z?x.nodeBorderRadius:z,D=e.linkOpacity,V=void 0===D?x.linkOpacity:D,Z=e.linkHoverOpacity,_=void 0===Z?x.linkHoverOpacity:Z,J=e.linkHoverOthersOpacity,K=void 0===J?x.linkHoverOthersOpacity:J,U=e.linkContract,X=void 0===U?x.linkContract:U,Y=e.linkBlendMode,Q=void 0===Y?x.linkBlendMode:Y,$=e.enableLinkGradient,ee=void 0===$?x.enableLinkGradient:$,oe=e.enableLabels,ne=void 0===oe?x.enableLabels:oe,te=e.labelPosition,ie=void 0===te?x.labelPosition:te,re=e.labelPadding,ae=void 0===re?x.labelPadding:re,le=e.labelOrientation,de=void 0===le?x.labelOrientation:le,se=e.label,ce=void 0===se?x.label:se,ue=e.labelTextColor,he=void 0===ue?x.labelTextColor:ue,pe=e.nodeTooltip,ve=void 0===pe?x.nodeTooltip:pe,ge=e.linkTooltip,ye=void 0===ge?x.linkTooltip:ge,fe=e.isInteractive,ke=void 0===fe?x.isInteractive:fe,xe=e.onClick,me=e.legends,be=void 0===me?x.legends:me,Ce=e.layers,Oe=void 0===Ce?x.layers:Ce,je=e.role,Me=void 0===je?x.role:je,Le=e.ariaLabel,Te=e.ariaLabelledBy,Be=e.ariaDescribedBy,Ie=n.useDimensions(g,y,f),we=Ie.margin,Pe=Ie.innerWidth,He=Ie.innerHeight,Se=Ie.outerWidth,We=Ie.outerHeight,Fe=b({data:i,valueFormat:r,layout:d,width:Pe,height:He,sort:c,align:p,colors:m,nodeThickness:j,nodeSpacing:B,nodeInnerPadding:w,nodeBorderColor:H,label:ce,labelTextColor:he}),Ne=Fe.nodes,Ee=Fe.links,Re=Fe.legendData,qe=Fe.getNodeBorderColor,Ae=Fe.currentNode,ze=Fe.setCurrentNode,Ge=Fe.currentLink,De=Fe.setCurrentLink,Ve=Fe.getLabelTextColor,Ze=function(){return!1},_e=function(){return!1};if(Ge&&(Ze=function(e){var o=e.id;return o===Ge.source.id||o===Ge.target.id},_e=function(e){var o=e.source,n=e.target;return o.id===Ge.source.id&&n.id===Ge.target.id}),Ae){var Je=[Ae.id];Ee.filter((function(e){var o=e.source,n=e.target;return o.id===Ae.id||n.id===Ae.id})).forEach((function(e){var o=e.source,n=e.target;Je.push(o.id),Je.push(n.id)})),Je=h.default(Je),Ze=function(e){var o=e.id;return Je.includes(o)},_e=function(e){var o=e.source,n=e.target;return o.id===Ae.id||n.id===Ae.id}}var Ke={links:Ee,nodes:Ne,margin:we,width:g,height:y,outerWidth:Se,outerHeight:We},Ue={links:null,nodes:null,labels:null,legends:null};return Oe.includes("links")&&(Ue.links=a.jsx(L,{links:Ee,layout:d,linkContract:X,linkOpacity:V,linkHoverOpacity:_,linkHoverOthersOpacity:K,linkBlendMode:Q,enableLinkGradient:ee,setCurrentLink:De,currentNode:Ae,currentLink:Ge,isCurrentLink:_e,isInteractive:ke,onClick:xe,tooltip:ye},"links")),Oe.includes("nodes")&&(Ue.nodes=a.jsx(O,{nodes:Ne,nodeOpacity:W,nodeHoverOpacity:N,nodeHoverOthersOpacity:R,borderWidth:A,borderRadius:G,getBorderColor:qe,setCurrentNode:ze,currentNode:Ae,currentLink:Ge,isCurrentNode:Ze,isInteractive:ke,onClick:xe,tooltip:ve},"nodes")),Oe.includes("labels")&&ne&&(Ue.labels=a.jsx(T,{nodes:Ne,layout:d,width:Pe,height:He,labelPosition:ie,labelPadding:ae,labelOrientation:de,getLabelTextColor:Ve},"labels")),Oe.includes("legends")&&(Ue.legends=a.jsx(o.Fragment,{children:be.map((function(e,o){return a.jsx(t.BoxLegendSvg,v({},e,{containerWidth:Pe,containerHeight:He,data:Re}),"legend"+o)}))},"legends")),a.jsx(n.SvgWrapper,{width:Se,height:We,margin:we,role:Me,ariaLabel:Le,ariaLabelledBy:Te,ariaDescribedBy:Be,children:Oe.map((function(e,n){var t;return"function"==typeof e?a.jsx(o.Fragment,{children:o.createElement(e,Ke)},n):null!=(t=null==Ue?void 0:Ue[e])?t:null}))})},w=function(e){var o=e.isInteractive,t=void 0===o?x.isInteractive:o,i=e.animate,r=void 0===i?x.animate:i,l=e.motionConfig,d=void 0===l?x.motionConfig:l,s=e.theme,c=e.renderWrapper,u=function(e,o){if(null==e)return{};var n,t,i={},r=Object.keys(e);for(t=0;t<r.length;t++)n=r[t],o.indexOf(n)>=0||(i[n]=e[n]);return i}(e,B);return a.jsx(n.Container,{animate:r,isInteractive:t,motionConfig:d,renderWrapper:c,theme:s,children:a.jsx(I,v({isInteractive:t},u))})};exports.ResponsiveSankey=function(e){return a.jsx(n.ResponsiveWrapper,{children:function(o){var n=o.width,t=o.height;return a.jsx(w,v({width:n,height:t},e))}})},exports.Sankey=w,exports.sankeyAlignmentFromProp=k,exports.sankeyAlignmentPropKeys=f,exports.sankeyAlignmentPropMapping=y,exports.svgDefaultProps=x; | ||
"use strict";var e=require("react"),o=require("lodash"),n=require("@nivo/core"),t=require("@nivo/legends"),i=require("d3-sankey"),r=require("@nivo/tooltip"),a=require("react/jsx-runtime"),l=require("@nivo/colors"),d=require("@react-spring/web"),s=require("d3-shape");function c(){return c=Object.assign?Object.assign.bind():function(e){for(var o=1;o<arguments.length;o++){var n=arguments[o];for(var t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=n[t])}return e},c.apply(this,arguments)}var u={container:{display:"flex",alignItems:"center"},sourceChip:{marginRight:7},targetChip:{marginLeft:7,marginRight:7}},h={center:i.sankeyCenter,justify:i.sankeyJustify,start:i.sankeyLeft,end:i.sankeyRight},p=Object.keys(h),v=function(e){return h[e]},g={layout:"horizontal",align:"center",sort:"auto",colors:{scheme:"nivo"},nodeOpacity:.75,nodeHoverOpacity:1,nodeHoverOthersOpacity:.15,nodeThickness:12,nodeSpacing:12,nodeInnerPadding:0,nodeBorderWidth:1,nodeBorderColor:{from:"color",modifiers:[["darker",.5]]},nodeBorderRadius:0,linkOpacity:.25,linkHoverOpacity:.6,linkHoverOthersOpacity:.15,linkContract:0,linkBlendMode:"multiply",enableLinkGradient:!1,enableLabels:!0,label:"id",labelPosition:"inside",labelPadding:9,labelOrientation:"horizontal",labelTextColor:{from:"color",modifiers:[["darker",.8]]},isInteractive:!0,nodeTooltip:function(e){var o=e.node;return a.jsx(r.BasicTooltip,{id:o.label,enableChip:!0,color:o.color})},linkTooltip:function(e){var o=e.link;return a.jsx(r.BasicTooltip,{id:a.jsxs("span",{style:u.container,children:[a.jsx(r.Chip,{color:o.source.color,style:u.sourceChip}),a.jsx("strong",{children:o.source.label})," > ",a.jsx("strong",{children:o.target.label}),a.jsx(r.Chip,{color:o.target.color,style:u.targetChip}),a.jsx("strong",{children:o.formattedValue})]})})},legends:[],layers:["links","nodes","labels","legends"],role:"img",animate:!0,motionConfig:"gentle"},y=function(e){return e.id},f=function(t){var r=t.data,a=t.valueFormat,d=t.layout,s=t.width,c=t.height,u=t.sort,h=t.align,p=t.colors,g=t.nodeThickness,f=t.nodeSpacing,k=t.nodeInnerPadding,x=t.nodeBorderColor,m=t.label,b=t.labelTextColor,C=e.useState(null),O=C[0],j=C[1],M=e.useState(null),L=M[0],T=M[1],B=e.useMemo((function(){if("auto"!==u)return"input"===u?null:"ascending"===u?function(e,o){return e.value-o.value}:"descending"===u?function(e,o){return o.value-e.value}:u}),[u]),I="input"===u?null:void 0,w=e.useMemo((function(){return"function"==typeof h?h:v(h)}),[h]),P=n.useTheme(),H=l.useOrdinalColorScale(p,"id"),S=l.useInheritedColor(x,P),W=n.usePropertyAccessor(m),F=l.useInheritedColor(b,P),N=n.useValueFormatter(a),E=e.useMemo((function(){return function(e){var n=e.data,t=e.formatValue,r=e.layout,a=e.alignFunction,l=e.sortFunction,d=e.linkSortMode,s=e.nodeThickness,c=e.nodeSpacing,u=e.nodeInnerPadding,h=e.width,p=e.height,v=e.getColor,g=e.getLabel,f=i.sankey().nodeAlign(a).nodeSort(l).linkSort(d).nodeWidth(s).nodePadding(c).size("horizontal"===r?[h,p]:[p,h]).nodeId(y),k=o.cloneDeep(n);return f(k),k.nodes.forEach((function(e){if(e.color=v(e),e.label=g(e),e.formattedValue=t(e.value),"horizontal"===r)e.x=e.x0+u,e.y=e.y0,e.width=Math.max(e.x1-e.x0-2*u,0),e.height=Math.max(e.y1-e.y0,0);else{e.x=e.y0,e.y=e.x0+u,e.width=Math.max(e.y1-e.y0,0),e.height=Math.max(e.x1-e.x0-2*u,0);var o=e.x0,n=e.x1;e.x0=e.y0,e.x1=e.y1,e.y0=o,e.y1=n}})),k.links.forEach((function(e){e.formattedValue=t(e.value),e.color=e.source.color,e.pos0=e.y0,e.pos1=e.y1,e.thickness=e.width,delete e.y0,delete e.y1,delete e.width})),k}({data:r,formatValue:N,layout:d,alignFunction:w,sortFunction:B,linkSortMode:I,nodeThickness:g,nodeSpacing:f,nodeInnerPadding:k,width:s,height:c,getColor:H,getLabel:W})}),[r,N,d,w,B,I,g,f,k,s,c,H,W]),R=E.nodes,q=E.links,A=e.useMemo((function(){return R.map((function(e){return{id:e.id,label:e.label,color:e.color}}))}),[R]);return{nodes:R,links:q,legendData:A,getNodeBorderColor:S,currentNode:O,setCurrentNode:j,currentLink:L,setCurrentLink:T,getLabelTextColor:F}},k=function(o){var t=o.node,i=o.x,l=o.y,s=o.width,c=o.height,u=o.color,h=o.opacity,p=o.borderWidth,v=o.borderColor,g=o.borderRadius,y=o.setCurrent,f=o.isInteractive,k=o.onClick,x=o.tooltip,m=n.useMotionConfig(),b=m.animate,C=m.config,O=d.useSpring({x:i,y:l,width:s,height:c,opacity:h,color:u,config:C,immediate:!b}),j=r.useTooltip(),M=j.showTooltipFromEvent,L=j.hideTooltip,T=e.useCallback((function(o){y(t),M(e.createElement(x,{node:t}),o,"left")}),[y,t,M,x]),B=e.useCallback((function(o){M(e.createElement(x,{node:t}),o,"left")}),[M,t,x]),I=e.useCallback((function(){y(null),L()}),[y,L]),w=e.useCallback((function(e){null==k||k(t,e)}),[k,t]);return a.jsx(d.animated.rect,{x:O.x,y:O.y,rx:g,ry:g,width:O.width.to((function(e){return Math.max(e,0)})),height:O.height.to((function(e){return Math.max(e,0)})),fill:O.color,fillOpacity:O.opacity,strokeWidth:p,stroke:v,strokeOpacity:h,onMouseEnter:f?T:void 0,onMouseMove:f?B:void 0,onMouseLeave:f?I:void 0,onClick:f?w:void 0})},x=function(e){var o=e.nodes,n=e.nodeOpacity,t=e.nodeHoverOpacity,i=e.nodeHoverOthersOpacity,r=e.borderWidth,l=e.getBorderColor,d=e.borderRadius,s=e.setCurrentNode,c=e.currentNode,u=e.currentLink,h=e.isCurrentNode,p=e.isInteractive,v=e.onClick,g=e.tooltip,y=function(e){return c||u?h(e)?t:i:n};return a.jsx(a.Fragment,{children:o.map((function(e){return a.jsx(k,{node:e,x:e.x,y:e.y,width:e.width,height:e.height,color:e.color,opacity:y(e),borderWidth:r,borderColor:l(e),borderRadius:d,setCurrent:s,isInteractive:p,onClick:v,tooltip:g},e.id)}))})},m=function(e){var o,n=e.id,t=e.layout,i=e.startColor,r=e.endColor;return o="horizontal"===t?{x1:"0%",x2:"100%",y1:"0%",y2:"0%"}:{x1:"0%",x2:"0%",y1:"0%",y2:"100%"},a.jsxs("linearGradient",c({id:n,spreadMethod:"pad"},o,{children:[a.jsx("stop",{offset:"0%",stopColor:i}),a.jsx("stop",{offset:"100%",stopColor:r})]}))},b=function(o){var t=o.link,i=o.layout,l=o.path,s=o.color,c=o.opacity,u=o.blendMode,h=o.enableGradient,p=o.setCurrent,v=o.tooltip,g=o.isInteractive,y=o.onClick,f=t.source.id+"."+t.target.id+"."+t.index,k=n.useMotionConfig(),x=k.animate,b=k.config,C=n.useAnimatedPath(l),O=d.useSpring({color:s,opacity:c,config:b,immediate:!x}),j=r.useTooltip(),M=j.showTooltipFromEvent,L=j.hideTooltip,T=e.useCallback((function(o){p(t),M(e.createElement(v,{link:t}),o,"left")}),[p,t,M,v]),B=e.useCallback((function(o){M(e.createElement(v,{link:t}),o,"left")}),[M,t,v]),I=e.useCallback((function(){p(null),L()}),[p,L]),w=e.useCallback((function(e){null==y||y(t,e)}),[y,t]);return a.jsxs(a.Fragment,{children:[h&&a.jsx(m,{id:f,layout:i,startColor:t.startColor||t.source.color,endColor:t.endColor||t.target.color}),a.jsx(d.animated.path,{fill:h?'url("#'+encodeURI(f)+'")':O.color,d:C,fillOpacity:O.opacity,onMouseEnter:g?T:void 0,onMouseMove:g?B:void 0,onMouseLeave:g?I:void 0,onClick:g?w:void 0,style:{mixBlendMode:u}})]})},C=function(o){var n=o.links,t=o.layout,i=o.linkOpacity,r=o.linkHoverOpacity,l=o.linkHoverOthersOpacity,d=o.linkContract,c=o.linkBlendMode,u=o.enableLinkGradient,h=o.setCurrentLink,p=o.currentLink,v=o.currentNode,g=o.isCurrentLink,y=o.isInteractive,f=o.onClick,k=o.tooltip,x=function(e){return v||p?g(e)?r:l:i},m=e.useMemo((function(){return"horizontal"===t?(e=s.line().curve(s.curveMonotoneX),function(o,n){var t=Math.max(1,o.thickness-2*n)/2,i=.12*(o.target.x0-o.source.x1),r=[[o.source.x1,o.pos0-t],[o.source.x1+i,o.pos0-t],[o.target.x0-i,o.pos1-t],[o.target.x0,o.pos1-t],[o.target.x0,o.pos1+t],[o.target.x0-i,o.pos1+t],[o.source.x1+i,o.pos0+t],[o.source.x1,o.pos0+t],[o.source.x1,o.pos0-t]];return e(r)+"Z"}):function(){var e=s.line().curve(s.curveMonotoneY);return function(o,n){var t=Math.max(1,o.thickness-2*n)/2,i=.12*(o.target.y0-o.source.y1),r=[[o.pos0+t,o.source.y1],[o.pos0+t,o.source.y1+i],[o.pos1+t,o.target.y0-i],[o.pos1+t,o.target.y0],[o.pos1-t,o.target.y0],[o.pos1-t,o.target.y0-i],[o.pos0-t,o.source.y1+i],[o.pos0-t,o.source.y1],[o.pos0+t,o.source.y1]];return e(r)+"Z"}}();var e}),[t]);return a.jsx(a.Fragment,{children:n.map((function(e){return a.jsx(b,{link:e,layout:t,path:m(e,d),color:e.color,opacity:x(e),blendMode:c,enableGradient:u,setCurrent:h,isInteractive:y,onClick:f,tooltip:k},e.source.id+"."+e.target.id+"."+e.index)}))})},O=function(e){var o=e.nodes,t=e.layout,i=e.width,r=e.height,l=e.labelPosition,s=e.labelPadding,u=e.labelOrientation,h=e.getLabelTextColor,p=n.useTheme(),v="vertical"===u?-90:0,g=o.map((function(e){var o,n,a;return"horizontal"===t?(n=e.y+e.height/2,e.x<i/2?"inside"===l?(o=e.x1+s,a="vertical"===u?"middle":"start"):(o=e.x-s,a="vertical"===u?"middle":"end"):"inside"===l?(o=e.x-s,a="vertical"===u?"middle":"end"):(o=e.x1+s,a="vertical"===u?"middle":"start")):"vertical"===t&&(o=e.x+e.width/2,e.y<r/2?"inside"===l?(n=e.y1+s,a="vertical"===u?"end":"middle"):(n=e.y-s,a="vertical"===u?"start":"middle"):"inside"===l?(n=e.y-s,a="vertical"===u?"start":"middle"):(n=e.y1+s,a="vertical"===u?"end":"middle")),{id:e.id,label:e.label,x:o,y:n,textAnchor:a,color:h(e)}})),y=n.useMotionConfig(),f=y.animate,k=y.config,x=d.useSprings(g.length,g.map((function(e){return{transform:"translate("+e.x+", "+e.y+") rotate("+v+")",color:e.color,config:k,immediate:!f}})));return a.jsx(a.Fragment,{children:x.map((function(e,o){var n=g[o];return a.jsx(d.animated.text,{dominantBaseline:"central",textAnchor:n.textAnchor,transform:e.transform,style:c({},p.labels.text,{fill:e.color,pointerEvents:"none"}),children:n.label},n.id)}))})},j=["isInteractive","animate","motionConfig","theme","renderWrapper"],M=function(i){var r=i.data,l=i.valueFormat,d=i.layout,s=void 0===d?g.layout:d,u=i.sort,h=void 0===u?g.sort:u,p=i.align,v=void 0===p?g.align:p,y=i.width,k=i.height,m=i.margin,b=i.colors,j=void 0===b?g.colors:b,M=i.nodeThickness,L=void 0===M?g.nodeThickness:M,T=i.nodeSpacing,B=void 0===T?g.nodeThickness:T,I=i.nodeInnerPadding,w=void 0===I?g.nodeInnerPadding:I,P=i.nodeBorderColor,H=void 0===P?g.nodeBorderColor:P,S=i.nodeOpacity,W=void 0===S?g.nodeOpacity:S,F=i.nodeHoverOpacity,N=void 0===F?g.nodeHoverOpacity:F,E=i.nodeHoverOthersOpacity,R=void 0===E?g.nodeHoverOthersOpacity:E,q=i.nodeBorderWidth,A=void 0===q?g.nodeBorderWidth:q,z=i.nodeBorderRadius,G=void 0===z?g.nodeBorderRadius:z,D=i.linkOpacity,V=void 0===D?g.linkOpacity:D,Z=i.linkHoverOpacity,J=void 0===Z?g.linkHoverOpacity:Z,K=i.linkHoverOthersOpacity,U=void 0===K?g.linkHoverOthersOpacity:K,X=i.linkContract,Y=void 0===X?g.linkContract:X,Q=i.linkBlendMode,$=void 0===Q?g.linkBlendMode:Q,_=i.enableLinkGradient,ee=void 0===_?g.enableLinkGradient:_,oe=i.enableLabels,ne=void 0===oe?g.enableLabels:oe,te=i.labelPosition,ie=void 0===te?g.labelPosition:te,re=i.labelPadding,ae=void 0===re?g.labelPadding:re,le=i.labelOrientation,de=void 0===le?g.labelOrientation:le,se=i.label,ce=void 0===se?g.label:se,ue=i.labelTextColor,he=void 0===ue?g.labelTextColor:ue,pe=i.nodeTooltip,ve=void 0===pe?g.nodeTooltip:pe,ge=i.linkTooltip,ye=void 0===ge?g.linkTooltip:ge,fe=i.isInteractive,ke=void 0===fe?g.isInteractive:fe,xe=i.onClick,me=i.legends,be=void 0===me?g.legends:me,Ce=i.layers,Oe=void 0===Ce?g.layers:Ce,je=i.role,Me=void 0===je?g.role:je,Le=i.ariaLabel,Te=i.ariaLabelledBy,Be=i.ariaDescribedBy,Ie=n.useDimensions(y,k,m),we=Ie.margin,Pe=Ie.innerWidth,He=Ie.innerHeight,Se=Ie.outerWidth,We=Ie.outerHeight,Fe=f({data:r,valueFormat:l,layout:s,width:Pe,height:He,sort:h,align:v,colors:j,nodeThickness:L,nodeSpacing:B,nodeInnerPadding:w,nodeBorderColor:H,label:ce,labelTextColor:he}),Ne=Fe.nodes,Ee=Fe.links,Re=Fe.legendData,qe=Fe.getNodeBorderColor,Ae=Fe.currentNode,ze=Fe.setCurrentNode,Ge=Fe.currentLink,De=Fe.setCurrentLink,Ve=Fe.getLabelTextColor,Ze=function(){return!1},Je=function(){return!1};if(Ge&&(Ze=function(e){var o=e.id;return o===Ge.source.id||o===Ge.target.id},Je=function(e){var o=e.source,n=e.target;return o.id===Ge.source.id&&n.id===Ge.target.id}),Ae){var Ke=[Ae.id];Ee.filter((function(e){var o=e.source,n=e.target;return o.id===Ae.id||n.id===Ae.id})).forEach((function(e){var o=e.source,n=e.target;Ke.push(o.id),Ke.push(n.id)})),Ke=o.uniq(Ke),Ze=function(e){var o=e.id;return Ke.includes(o)},Je=function(e){var o=e.source,n=e.target;return o.id===Ae.id||n.id===Ae.id}}var Ue={links:Ee,nodes:Ne,margin:we,width:y,height:k,outerWidth:Se,outerHeight:We},Xe={links:null,nodes:null,labels:null,legends:null};return Oe.includes("links")&&(Xe.links=a.jsx(C,{links:Ee,layout:s,linkContract:Y,linkOpacity:V,linkHoverOpacity:J,linkHoverOthersOpacity:U,linkBlendMode:$,enableLinkGradient:ee,setCurrentLink:De,currentNode:Ae,currentLink:Ge,isCurrentLink:Je,isInteractive:ke,onClick:xe,tooltip:ye},"links")),Oe.includes("nodes")&&(Xe.nodes=a.jsx(x,{nodes:Ne,nodeOpacity:W,nodeHoverOpacity:N,nodeHoverOthersOpacity:R,borderWidth:A,borderRadius:G,getBorderColor:qe,setCurrentNode:ze,currentNode:Ae,currentLink:Ge,isCurrentNode:Ze,isInteractive:ke,onClick:xe,tooltip:ve},"nodes")),Oe.includes("labels")&&ne&&(Xe.labels=a.jsx(O,{nodes:Ne,layout:s,width:Pe,height:He,labelPosition:ie,labelPadding:ae,labelOrientation:de,getLabelTextColor:Ve},"labels")),Oe.includes("legends")&&(Xe.legends=a.jsx(e.Fragment,{children:be.map((function(e,o){return a.jsx(t.BoxLegendSvg,c({},e,{containerWidth:Pe,containerHeight:He,data:Re}),"legend"+o)}))},"legends")),a.jsx(n.SvgWrapper,{width:Se,height:We,margin:we,role:Me,ariaLabel:Le,ariaLabelledBy:Te,ariaDescribedBy:Be,children:Oe.map((function(o,n){var t;return"function"==typeof o?a.jsx(e.Fragment,{children:e.createElement(o,Ue)},n):null!=(t=null==Xe?void 0:Xe[o])?t:null}))})},L=function(e){var o=e.isInteractive,t=void 0===o?g.isInteractive:o,i=e.animate,r=void 0===i?g.animate:i,l=e.motionConfig,d=void 0===l?g.motionConfig:l,s=e.theme,u=e.renderWrapper,h=function(e,o){if(null==e)return{};var n,t,i={},r=Object.keys(e);for(t=0;t<r.length;t++)n=r[t],o.indexOf(n)>=0||(i[n]=e[n]);return i}(e,j);return a.jsx(n.Container,{animate:r,isInteractive:t,motionConfig:d,renderWrapper:u,theme:s,children:a.jsx(M,c({isInteractive:t},h))})};exports.ResponsiveSankey=function(e){return a.jsx(n.ResponsiveWrapper,{children:function(o){var n=o.width,t=o.height;return a.jsx(L,c({width:n,height:t},e))}})},exports.Sankey=L,exports.sankeyAlignmentFromProp=v,exports.sankeyAlignmentPropKeys=p,exports.sankeyAlignmentPropMapping=h,exports.svgDefaultProps=g; | ||
//# sourceMappingURL=nivo-sankey.cjs.js.map |
@@ -1,2 +0,2 @@ | ||
import e from"lodash/uniq";import{useState as o,useMemo as n,useCallback as t,createElement as i,Fragment as r}from"react";import{useTheme as l,usePropertyAccessor as a,useValueFormatter as d,useMotionConfig as c,useAnimatedPath as s,Container as u,useDimensions as h,SvgWrapper as v,ResponsiveWrapper as p}from"@nivo/core";import{BoxLegendSvg as g}from"@nivo/legends";import{sankeyCenter as f,sankeyJustify as y,sankeyLeft as m,sankeyRight as k,sankey as b}from"d3-sankey";import{BasicTooltip as C,Chip as x,useTooltip as O}from"@nivo/tooltip";import{jsx as L,jsxs as M,Fragment as T}from"react/jsx-runtime";import w from"lodash/cloneDeep";import{useOrdinalColorScale as B,useInheritedColor as I}from"@nivo/colors";import{useSpring as H,animated as P,useSprings as W}from"@react-spring/web";import{line as N,curveMonotoneX as F,curveMonotoneY as R}from"d3-shape";function S(){return S=Object.assign||function(e){for(var o=1;o<arguments.length;o++){var n=arguments[o];for(var t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=n[t])}return e},S.apply(this,arguments)}var z={container:{display:"flex",alignItems:"center"},sourceChip:{marginRight:7},targetChip:{marginLeft:7,marginRight:7}},E={center:f,justify:y,start:m,end:k},G=Object.keys(E),j=function(e){return E[e]},D={layout:"horizontal",align:"center",sort:"auto",colors:{scheme:"nivo"},nodeOpacity:.75,nodeHoverOpacity:1,nodeHoverOthersOpacity:.15,nodeThickness:12,nodeSpacing:12,nodeInnerPadding:0,nodeBorderWidth:1,nodeBorderColor:{from:"color",modifiers:[["darker",.5]]},nodeBorderRadius:0,linkOpacity:.25,linkHoverOpacity:.6,linkHoverOthersOpacity:.15,linkContract:0,linkBlendMode:"multiply",enableLinkGradient:!1,enableLabels:!0,label:"id",labelPosition:"inside",labelPadding:9,labelOrientation:"horizontal",labelTextColor:{from:"color",modifiers:[["darker",.8]]},isInteractive:!0,nodeTooltip:function(e){var o=e.node;return L(C,{id:o.label,enableChip:!0,color:o.color})},linkTooltip:function(e){var o=e.link;return L(C,{id:M("span",{style:z.container,children:[L(x,{color:o.source.color,style:z.sourceChip}),L("strong",{children:o.source.label})," > ",L("strong",{children:o.target.label}),L(x,{color:o.target.color,style:z.targetChip}),L("strong",{children:o.formattedValue})]})})},legends:[],layers:["links","nodes","labels","legends"],role:"img",animate:!0,motionConfig:"gentle"},V=function(e){return e.id},A=function(e){var t=e.data,i=e.valueFormat,r=e.layout,c=e.width,s=e.height,u=e.sort,h=e.align,v=e.colors,p=e.nodeThickness,g=e.nodeSpacing,f=e.nodeInnerPadding,y=e.nodeBorderColor,m=e.label,k=e.labelTextColor,C=o(null),x=C[0],O=C[1],L=o(null),M=L[0],T=L[1],H=n((function(){if("auto"!==u)return"input"===u?null:"ascending"===u?function(e,o){return e.value-o.value}:"descending"===u?function(e,o){return o.value-e.value}:u}),[u]),P="input"===u?null:void 0,W=n((function(){return"function"==typeof h?h:j(h)}),[h]),N=l(),F=B(v,"id"),R=I(y,N),S=a(m),z=I(k,N),E=d(i),G=n((function(){return function(e){var o=e.data,n=e.formatValue,t=e.layout,i=e.alignFunction,r=e.sortFunction,l=e.linkSortMode,a=e.nodeThickness,d=e.nodeSpacing,c=e.nodeInnerPadding,s=e.width,u=e.height,h=e.getColor,v=e.getLabel,p=b().nodeAlign(i).nodeSort(r).linkSort(l).nodeWidth(a).nodePadding(d).size("horizontal"===t?[s,u]:[u,s]).nodeId(V),g=w(o);return p(g),g.nodes.forEach((function(e){if(e.color=h(e),e.label=v(e),e.formattedValue=n(e.value),"horizontal"===t)e.x=e.x0+c,e.y=e.y0,e.width=Math.max(e.x1-e.x0-2*c,0),e.height=Math.max(e.y1-e.y0,0);else{e.x=e.y0,e.y=e.x0+c,e.width=Math.max(e.y1-e.y0,0),e.height=Math.max(e.x1-e.x0-2*c,0);var o=e.x0,i=e.x1;e.x0=e.y0,e.x1=e.y1,e.y0=o,e.y1=i}})),g.links.forEach((function(e){e.formattedValue=n(e.value),e.color=e.source.color,e.pos0=e.y0,e.pos1=e.y1,e.thickness=e.width,delete e.y0,delete e.y1,delete e.width})),g}({data:t,formatValue:E,layout:r,alignFunction:W,sortFunction:H,linkSortMode:P,nodeThickness:p,nodeSpacing:g,nodeInnerPadding:f,width:c,height:s,getColor:F,getLabel:S})}),[t,E,r,W,H,P,p,g,f,c,s,F,S]),D=G.nodes,A=G.links,Z=n((function(){return D.map((function(e){return{id:e.id,label:e.label,color:e.color}}))}),[D]);return{nodes:D,links:A,legendData:Z,getNodeBorderColor:R,currentNode:x,setCurrentNode:O,currentLink:M,setCurrentLink:T,getLabelTextColor:z}},Z=function(e){var o=e.node,n=e.x,r=e.y,l=e.width,a=e.height,d=e.color,s=e.opacity,u=e.borderWidth,h=e.borderColor,v=e.borderRadius,p=e.setCurrent,g=e.isInteractive,f=e.onClick,y=e.tooltip,m=c(),k=m.animate,b=m.config,C=H({x:n,y:r,width:l,height:a,opacity:s,color:d,config:b,immediate:!k}),x=O(),M=x.showTooltipFromEvent,T=x.hideTooltip,w=t((function(e){p(o),M(i(y,{node:o}),e,"left")}),[p,o,M,y]),B=t((function(e){M(i(y,{node:o}),e,"left")}),[M,o,y]),I=t((function(){p(null),T()}),[p,T]),W=t((function(e){null==f||f(o,e)}),[f,o]);return L(P.rect,{x:C.x,y:C.y,rx:v,ry:v,width:C.width.to((function(e){return Math.max(e,0)})),height:C.height.to((function(e){return Math.max(e,0)})),fill:C.color,fillOpacity:C.opacity,strokeWidth:u,stroke:h,strokeOpacity:s,onMouseEnter:g?w:void 0,onMouseMove:g?B:void 0,onMouseLeave:g?I:void 0,onClick:g?W:void 0})},q=function(e){var o=e.nodes,n=e.nodeOpacity,t=e.nodeHoverOpacity,i=e.nodeHoverOthersOpacity,r=e.borderWidth,l=e.getBorderColor,a=e.borderRadius,d=e.setCurrentNode,c=e.currentNode,s=e.currentLink,u=e.isCurrentNode,h=e.isInteractive,v=e.onClick,p=e.tooltip,g=function(e){return c||s?u(e)?t:i:n};return L(T,{children:o.map((function(e){return L(Z,{node:e,x:e.x,y:e.y,width:e.width,height:e.height,color:e.color,opacity:g(e),borderWidth:r,borderColor:l(e),borderRadius:a,setCurrent:d,isInteractive:h,onClick:v,tooltip:p},e.id)}))})},U=function(e){var o=e.id,n=e.layout,t=e.startColor,i=e.endColor;return M("linearGradient",S({id:o,spreadMethod:"pad"},"horizontal"===n?{x1:"0%",x2:"100%",y1:"0%",y2:"0%"}:{x1:"0%",x2:"0%",y1:"0%",y2:"100%"},{children:[L("stop",{offset:"0%",stopColor:t}),L("stop",{offset:"100%",stopColor:i})]}))},J=function(e){var o=e.link,n=e.layout,r=e.path,l=e.color,a=e.opacity,d=e.blendMode,u=e.enableGradient,h=e.setCurrent,v=e.tooltip,p=e.isInteractive,g=e.onClick,f=o.source.id+"."+o.target.id+"."+o.index,y=c(),m=y.animate,k=y.config,b=s(r),C=H({color:l,opacity:a,config:k,immediate:!m}),x=O(),w=x.showTooltipFromEvent,B=x.hideTooltip,I=t((function(e){h(o),w(i(v,{link:o}),e,"left")}),[h,o,w,v]),W=t((function(e){w(i(v,{link:o}),e,"left")}),[w,o,v]),N=t((function(){h(null),B()}),[h,B]),F=t((function(e){null==g||g(o,e)}),[g,o]);return M(T,{children:[u&&L(U,{id:f,layout:n,startColor:o.startColor||o.source.color,endColor:o.endColor||o.target.color}),L(P.path,{fill:u?'url("#'+encodeURI(f)+'")':C.color,d:b,fillOpacity:C.opacity,onMouseEnter:p?I:void 0,onMouseMove:p?W:void 0,onMouseLeave:p?N:void 0,onClick:p?F:void 0,style:{mixBlendMode:d}})]})},K=function(e){var o=e.links,t=e.layout,i=e.linkOpacity,r=e.linkHoverOpacity,l=e.linkHoverOthersOpacity,a=e.linkContract,d=e.linkBlendMode,c=e.enableLinkGradient,s=e.setCurrentLink,u=e.currentLink,h=e.currentNode,v=e.isCurrentLink,p=e.isInteractive,g=e.onClick,f=e.tooltip,y=function(e){return h||u?v(e)?r:l:i},m=n((function(){return"horizontal"===t?(e=N().curve(F),function(o,n){var t=Math.max(1,o.thickness-2*n)/2,i=.12*(o.target.x0-o.source.x1),r=[[o.source.x1,o.pos0-t],[o.source.x1+i,o.pos0-t],[o.target.x0-i,o.pos1-t],[o.target.x0,o.pos1-t],[o.target.x0,o.pos1+t],[o.target.x0-i,o.pos1+t],[o.source.x1+i,o.pos0+t],[o.source.x1,o.pos0+t],[o.source.x1,o.pos0-t]];return e(r)+"Z"}):function(){var e=N().curve(R);return function(o,n){var t=Math.max(1,o.thickness-2*n)/2,i=.12*(o.target.y0-o.source.y1),r=[[o.pos0+t,o.source.y1],[o.pos0+t,o.source.y1+i],[o.pos1+t,o.target.y0-i],[o.pos1+t,o.target.y0],[o.pos1-t,o.target.y0],[o.pos1-t,o.target.y0-i],[o.pos0-t,o.source.y1+i],[o.pos0-t,o.source.y1],[o.pos0+t,o.source.y1]];return e(r)+"Z"}}();var e}),[t]);return L(T,{children:o.map((function(e){return L(J,{link:e,layout:t,path:m(e,a),color:e.color,opacity:y(e),blendMode:d,enableGradient:c,setCurrent:s,isInteractive:p,onClick:g,tooltip:f},e.source.id+"."+e.target.id+"."+e.index)}))})},Q=function(e){var o=e.nodes,n=e.layout,t=e.width,i=e.height,r=e.labelPosition,a=e.labelPadding,d=e.labelOrientation,s=e.getLabelTextColor,u=l(),h="vertical"===d?-90:0,v=o.map((function(e){var o,l,c;return"horizontal"===n?(l=e.y+e.height/2,e.x<t/2?"inside"===r?(o=e.x1+a,c="vertical"===d?"middle":"start"):(o=e.x-a,c="vertical"===d?"middle":"end"):"inside"===r?(o=e.x-a,c="vertical"===d?"middle":"end"):(o=e.x1+a,c="vertical"===d?"middle":"start")):"vertical"===n&&(o=e.x+e.width/2,e.y<i/2?"inside"===r?(l=e.y1+a,c="vertical"===d?"end":"middle"):(l=e.y-a,c="vertical"===d?"start":"middle"):"inside"===r?(l=e.y-a,c="vertical"===d?"start":"middle"):(l=e.y1+a,c="vertical"===d?"end":"middle")),{id:e.id,label:e.label,x:o,y:l,textAnchor:c,color:s(e)}})),p=c(),g=p.animate,f=p.config,y=W(v.length,v.map((function(e){return{transform:"translate("+e.x+", "+e.y+") rotate("+h+")",color:e.color,config:f,immediate:!g}})));return L(T,{children:y.map((function(e,o){var n=v[o];return L(P.text,{dominantBaseline:"central",textAnchor:n.textAnchor,transform:e.transform,style:S({},u.labels.text,{fill:e.color,pointerEvents:"none"}),children:n.label},n.id)}))})},X=["isInteractive","animate","motionConfig","theme","renderWrapper"],Y=function(o){var n=o.data,t=o.valueFormat,l=o.layout,a=void 0===l?D.layout:l,d=o.sort,c=void 0===d?D.sort:d,s=o.align,u=void 0===s?D.align:s,p=o.width,f=o.height,y=o.margin,m=o.colors,k=void 0===m?D.colors:m,b=o.nodeThickness,C=void 0===b?D.nodeThickness:b,x=o.nodeSpacing,O=void 0===x?D.nodeThickness:x,M=o.nodeInnerPadding,T=void 0===M?D.nodeInnerPadding:M,w=o.nodeBorderColor,B=void 0===w?D.nodeBorderColor:w,I=o.nodeOpacity,H=void 0===I?D.nodeOpacity:I,P=o.nodeHoverOpacity,W=void 0===P?D.nodeHoverOpacity:P,N=o.nodeHoverOthersOpacity,F=void 0===N?D.nodeHoverOthersOpacity:N,R=o.nodeBorderWidth,z=void 0===R?D.nodeBorderWidth:R,E=o.nodeBorderRadius,G=void 0===E?D.nodeBorderRadius:E,j=o.linkOpacity,V=void 0===j?D.linkOpacity:j,Z=o.linkHoverOpacity,U=void 0===Z?D.linkHoverOpacity:Z,J=o.linkHoverOthersOpacity,X=void 0===J?D.linkHoverOthersOpacity:J,Y=o.linkContract,$=void 0===Y?D.linkContract:Y,_=o.linkBlendMode,ee=void 0===_?D.linkBlendMode:_,oe=o.enableLinkGradient,ne=void 0===oe?D.enableLinkGradient:oe,te=o.enableLabels,ie=void 0===te?D.enableLabels:te,re=o.labelPosition,le=void 0===re?D.labelPosition:re,ae=o.labelPadding,de=void 0===ae?D.labelPadding:ae,ce=o.labelOrientation,se=void 0===ce?D.labelOrientation:ce,ue=o.label,he=void 0===ue?D.label:ue,ve=o.labelTextColor,pe=void 0===ve?D.labelTextColor:ve,ge=o.nodeTooltip,fe=void 0===ge?D.nodeTooltip:ge,ye=o.linkTooltip,me=void 0===ye?D.linkTooltip:ye,ke=o.isInteractive,be=void 0===ke?D.isInteractive:ke,Ce=o.onClick,xe=o.legends,Oe=void 0===xe?D.legends:xe,Le=o.layers,Me=void 0===Le?D.layers:Le,Te=o.role,we=void 0===Te?D.role:Te,Be=o.ariaLabel,Ie=o.ariaLabelledBy,He=o.ariaDescribedBy,Pe=h(p,f,y),We=Pe.margin,Ne=Pe.innerWidth,Fe=Pe.innerHeight,Re=Pe.outerWidth,Se=Pe.outerHeight,ze=A({data:n,valueFormat:t,layout:a,width:Ne,height:Fe,sort:c,align:u,colors:k,nodeThickness:C,nodeSpacing:O,nodeInnerPadding:T,nodeBorderColor:B,label:he,labelTextColor:pe}),Ee=ze.nodes,Ge=ze.links,je=ze.legendData,De=ze.getNodeBorderColor,Ve=ze.currentNode,Ae=ze.setCurrentNode,Ze=ze.currentLink,qe=ze.setCurrentLink,Ue=ze.getLabelTextColor,Je=function(){return!1},Ke=function(){return!1};if(Ze&&(Je=function(e){var o=e.id;return o===Ze.source.id||o===Ze.target.id},Ke=function(e){var o=e.source,n=e.target;return o.id===Ze.source.id&&n.id===Ze.target.id}),Ve){var Qe=[Ve.id];Ge.filter((function(e){var o=e.source,n=e.target;return o.id===Ve.id||n.id===Ve.id})).forEach((function(e){var o=e.source,n=e.target;Qe.push(o.id),Qe.push(n.id)})),Qe=e(Qe),Je=function(e){var o=e.id;return Qe.includes(o)},Ke=function(e){var o=e.source,n=e.target;return o.id===Ve.id||n.id===Ve.id}}var Xe={links:Ge,nodes:Ee,margin:We,width:p,height:f,outerWidth:Re,outerHeight:Se},Ye={links:null,nodes:null,labels:null,legends:null};return Me.includes("links")&&(Ye.links=L(K,{links:Ge,layout:a,linkContract:$,linkOpacity:V,linkHoverOpacity:U,linkHoverOthersOpacity:X,linkBlendMode:ee,enableLinkGradient:ne,setCurrentLink:qe,currentNode:Ve,currentLink:Ze,isCurrentLink:Ke,isInteractive:be,onClick:Ce,tooltip:me},"links")),Me.includes("nodes")&&(Ye.nodes=L(q,{nodes:Ee,nodeOpacity:H,nodeHoverOpacity:W,nodeHoverOthersOpacity:F,borderWidth:z,borderRadius:G,getBorderColor:De,setCurrentNode:Ae,currentNode:Ve,currentLink:Ze,isCurrentNode:Je,isInteractive:be,onClick:Ce,tooltip:fe},"nodes")),Me.includes("labels")&&ie&&(Ye.labels=L(Q,{nodes:Ee,layout:a,width:Ne,height:Fe,labelPosition:le,labelPadding:de,labelOrientation:se,getLabelTextColor:Ue},"labels")),Me.includes("legends")&&(Ye.legends=L(r,{children:Oe.map((function(e,o){return L(g,S({},e,{containerWidth:Ne,containerHeight:Fe,data:je}),"legend"+o)}))},"legends")),L(v,{width:Re,height:Se,margin:We,role:we,ariaLabel:Be,ariaLabelledBy:Ie,ariaDescribedBy:He,children:Me.map((function(e,o){var n;return"function"==typeof e?L(r,{children:i(e,Xe)},o):null!=(n=null==Ye?void 0:Ye[e])?n:null}))})},$=function(e){var o=e.isInteractive,n=void 0===o?D.isInteractive:o,t=e.animate,i=void 0===t?D.animate:t,r=e.motionConfig,l=void 0===r?D.motionConfig:r,a=e.theme,d=e.renderWrapper,c=function(e,o){if(null==e)return{};var n,t,i={},r=Object.keys(e);for(t=0;t<r.length;t++)n=r[t],o.indexOf(n)>=0||(i[n]=e[n]);return i}(e,X);return L(u,{animate:i,isInteractive:n,motionConfig:l,renderWrapper:d,theme:a,children:L(Y,S({isInteractive:n},c))})},_=function(e){return L(p,{children:function(o){var n=o.width,t=o.height;return L($,S({width:n,height:t},e))}})};export{_ as ResponsiveSankey,$ as Sankey,j as sankeyAlignmentFromProp,G as sankeyAlignmentPropKeys,E as sankeyAlignmentPropMapping,D as svgDefaultProps}; | ||
import{useState as e,useMemo as o,useCallback as n,createElement as t,Fragment as i}from"react";import{cloneDeep as r,uniq as l}from"lodash";import{useTheme as a,usePropertyAccessor as d,useValueFormatter as c,useMotionConfig as s,useAnimatedPath as u,Container as h,useDimensions as v,SvgWrapper as p,ResponsiveWrapper as g}from"@nivo/core";import{BoxLegendSvg as y}from"@nivo/legends";import{sankeyCenter as f,sankeyJustify as m,sankeyLeft as k,sankeyRight as b,sankey as C}from"d3-sankey";import{BasicTooltip as x,Chip as O,useTooltip as L}from"@nivo/tooltip";import{jsx as M,jsxs as T,Fragment as w}from"react/jsx-runtime";import{useOrdinalColorScale as B,useInheritedColor as I}from"@nivo/colors";import{useSpring as H,animated as P,useSprings as W}from"@react-spring/web";import{line as N,curveMonotoneX as F,curveMonotoneY as R}from"d3-shape";function S(){return S=Object.assign?Object.assign.bind():function(e){for(var o=1;o<arguments.length;o++){var n=arguments[o];for(var t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=n[t])}return e},S.apply(this,arguments)}var z={container:{display:"flex",alignItems:"center"},sourceChip:{marginRight:7},targetChip:{marginLeft:7,marginRight:7}},E={center:f,justify:m,start:k,end:b},G=Object.keys(E),j=function(e){return E[e]},V={layout:"horizontal",align:"center",sort:"auto",colors:{scheme:"nivo"},nodeOpacity:.75,nodeHoverOpacity:1,nodeHoverOthersOpacity:.15,nodeThickness:12,nodeSpacing:12,nodeInnerPadding:0,nodeBorderWidth:1,nodeBorderColor:{from:"color",modifiers:[["darker",.5]]},nodeBorderRadius:0,linkOpacity:.25,linkHoverOpacity:.6,linkHoverOthersOpacity:.15,linkContract:0,linkBlendMode:"multiply",enableLinkGradient:!1,enableLabels:!0,label:"id",labelPosition:"inside",labelPadding:9,labelOrientation:"horizontal",labelTextColor:{from:"color",modifiers:[["darker",.8]]},isInteractive:!0,nodeTooltip:function(e){var o=e.node;return M(x,{id:o.label,enableChip:!0,color:o.color})},linkTooltip:function(e){var o=e.link;return M(x,{id:T("span",{style:z.container,children:[M(O,{color:o.source.color,style:z.sourceChip}),M("strong",{children:o.source.label})," > ",M("strong",{children:o.target.label}),M(O,{color:o.target.color,style:z.targetChip}),M("strong",{children:o.formattedValue})]})})},legends:[],layers:["links","nodes","labels","legends"],role:"img",animate:!0,motionConfig:"gentle"},A=function(e){return e.id},D=function(n){var t=n.data,i=n.valueFormat,l=n.layout,s=n.width,u=n.height,h=n.sort,v=n.align,p=n.colors,g=n.nodeThickness,y=n.nodeSpacing,f=n.nodeInnerPadding,m=n.nodeBorderColor,k=n.label,b=n.labelTextColor,x=e(null),O=x[0],L=x[1],M=e(null),T=M[0],w=M[1],H=o((function(){if("auto"!==h)return"input"===h?null:"ascending"===h?function(e,o){return e.value-o.value}:"descending"===h?function(e,o){return o.value-e.value}:h}),[h]),P="input"===h?null:void 0,W=o((function(){return"function"==typeof v?v:j(v)}),[v]),N=a(),F=B(p,"id"),R=I(m,N),S=d(k),z=I(b,N),E=c(i),G=o((function(){return function(e){var o=e.data,n=e.formatValue,t=e.layout,i=e.alignFunction,l=e.sortFunction,a=e.linkSortMode,d=e.nodeThickness,c=e.nodeSpacing,s=e.nodeInnerPadding,u=e.width,h=e.height,v=e.getColor,p=e.getLabel,g=C().nodeAlign(i).nodeSort(l).linkSort(a).nodeWidth(d).nodePadding(c).size("horizontal"===t?[u,h]:[h,u]).nodeId(A),y=r(o);return g(y),y.nodes.forEach((function(e){if(e.color=v(e),e.label=p(e),e.formattedValue=n(e.value),"horizontal"===t)e.x=e.x0+s,e.y=e.y0,e.width=Math.max(e.x1-e.x0-2*s,0),e.height=Math.max(e.y1-e.y0,0);else{e.x=e.y0,e.y=e.x0+s,e.width=Math.max(e.y1-e.y0,0),e.height=Math.max(e.x1-e.x0-2*s,0);var o=e.x0,i=e.x1;e.x0=e.y0,e.x1=e.y1,e.y0=o,e.y1=i}})),y.links.forEach((function(e){e.formattedValue=n(e.value),e.color=e.source.color,e.pos0=e.y0,e.pos1=e.y1,e.thickness=e.width,delete e.y0,delete e.y1,delete e.width})),y}({data:t,formatValue:E,layout:l,alignFunction:W,sortFunction:H,linkSortMode:P,nodeThickness:g,nodeSpacing:y,nodeInnerPadding:f,width:s,height:u,getColor:F,getLabel:S})}),[t,E,l,W,H,P,g,y,f,s,u,F,S]),V=G.nodes,D=G.links,Z=o((function(){return V.map((function(e){return{id:e.id,label:e.label,color:e.color}}))}),[V]);return{nodes:V,links:D,legendData:Z,getNodeBorderColor:R,currentNode:O,setCurrentNode:L,currentLink:T,setCurrentLink:w,getLabelTextColor:z}},Z=function(e){var o=e.node,i=e.x,r=e.y,l=e.width,a=e.height,d=e.color,c=e.opacity,u=e.borderWidth,h=e.borderColor,v=e.borderRadius,p=e.setCurrent,g=e.isInteractive,y=e.onClick,f=e.tooltip,m=s(),k=m.animate,b=m.config,C=H({x:i,y:r,width:l,height:a,opacity:c,color:d,config:b,immediate:!k}),x=L(),O=x.showTooltipFromEvent,T=x.hideTooltip,w=n((function(e){p(o),O(t(f,{node:o}),e,"left")}),[p,o,O,f]),B=n((function(e){O(t(f,{node:o}),e,"left")}),[O,o,f]),I=n((function(){p(null),T()}),[p,T]),W=n((function(e){null==y||y(o,e)}),[y,o]);return M(P.rect,{x:C.x,y:C.y,rx:v,ry:v,width:C.width.to((function(e){return Math.max(e,0)})),height:C.height.to((function(e){return Math.max(e,0)})),fill:C.color,fillOpacity:C.opacity,strokeWidth:u,stroke:h,strokeOpacity:c,onMouseEnter:g?w:void 0,onMouseMove:g?B:void 0,onMouseLeave:g?I:void 0,onClick:g?W:void 0})},U=function(e){var o=e.nodes,n=e.nodeOpacity,t=e.nodeHoverOpacity,i=e.nodeHoverOthersOpacity,r=e.borderWidth,l=e.getBorderColor,a=e.borderRadius,d=e.setCurrentNode,c=e.currentNode,s=e.currentLink,u=e.isCurrentNode,h=e.isInteractive,v=e.onClick,p=e.tooltip,g=function(e){return c||s?u(e)?t:i:n};return M(w,{children:o.map((function(e){return M(Z,{node:e,x:e.x,y:e.y,width:e.width,height:e.height,color:e.color,opacity:g(e),borderWidth:r,borderColor:l(e),borderRadius:a,setCurrent:d,isInteractive:h,onClick:v,tooltip:p},e.id)}))})},q=function(e){var o=e.id,n=e.layout,t=e.startColor,i=e.endColor;return T("linearGradient",S({id:o,spreadMethod:"pad"},"horizontal"===n?{x1:"0%",x2:"100%",y1:"0%",y2:"0%"}:{x1:"0%",x2:"0%",y1:"0%",y2:"100%"},{children:[M("stop",{offset:"0%",stopColor:t}),M("stop",{offset:"100%",stopColor:i})]}))},J=function(e){var o=e.link,i=e.layout,r=e.path,l=e.color,a=e.opacity,d=e.blendMode,c=e.enableGradient,h=e.setCurrent,v=e.tooltip,p=e.isInteractive,g=e.onClick,y=o.source.id+"."+o.target.id+"."+o.index,f=s(),m=f.animate,k=f.config,b=u(r),C=H({color:l,opacity:a,config:k,immediate:!m}),x=L(),O=x.showTooltipFromEvent,B=x.hideTooltip,I=n((function(e){h(o),O(t(v,{link:o}),e,"left")}),[h,o,O,v]),W=n((function(e){O(t(v,{link:o}),e,"left")}),[O,o,v]),N=n((function(){h(null),B()}),[h,B]),F=n((function(e){null==g||g(o,e)}),[g,o]);return T(w,{children:[c&&M(q,{id:y,layout:i,startColor:o.startColor||o.source.color,endColor:o.endColor||o.target.color}),M(P.path,{fill:c?'url("#'+encodeURI(y)+'")':C.color,d:b,fillOpacity:C.opacity,onMouseEnter:p?I:void 0,onMouseMove:p?W:void 0,onMouseLeave:p?N:void 0,onClick:p?F:void 0,style:{mixBlendMode:d}})]})},K=function(e){var n=e.links,t=e.layout,i=e.linkOpacity,r=e.linkHoverOpacity,l=e.linkHoverOthersOpacity,a=e.linkContract,d=e.linkBlendMode,c=e.enableLinkGradient,s=e.setCurrentLink,u=e.currentLink,h=e.currentNode,v=e.isCurrentLink,p=e.isInteractive,g=e.onClick,y=e.tooltip,f=function(e){return h||u?v(e)?r:l:i},m=o((function(){return"horizontal"===t?(e=N().curve(F),function(o,n){var t=Math.max(1,o.thickness-2*n)/2,i=.12*(o.target.x0-o.source.x1),r=[[o.source.x1,o.pos0-t],[o.source.x1+i,o.pos0-t],[o.target.x0-i,o.pos1-t],[o.target.x0,o.pos1-t],[o.target.x0,o.pos1+t],[o.target.x0-i,o.pos1+t],[o.source.x1+i,o.pos0+t],[o.source.x1,o.pos0+t],[o.source.x1,o.pos0-t]];return e(r)+"Z"}):function(){var e=N().curve(R);return function(o,n){var t=Math.max(1,o.thickness-2*n)/2,i=.12*(o.target.y0-o.source.y1),r=[[o.pos0+t,o.source.y1],[o.pos0+t,o.source.y1+i],[o.pos1+t,o.target.y0-i],[o.pos1+t,o.target.y0],[o.pos1-t,o.target.y0],[o.pos1-t,o.target.y0-i],[o.pos0-t,o.source.y1+i],[o.pos0-t,o.source.y1],[o.pos0+t,o.source.y1]];return e(r)+"Z"}}();var e}),[t]);return M(w,{children:n.map((function(e){return M(J,{link:e,layout:t,path:m(e,a),color:e.color,opacity:f(e),blendMode:d,enableGradient:c,setCurrent:s,isInteractive:p,onClick:g,tooltip:y},e.source.id+"."+e.target.id+"."+e.index)}))})},Q=function(e){var o=e.nodes,n=e.layout,t=e.width,i=e.height,r=e.labelPosition,l=e.labelPadding,d=e.labelOrientation,c=e.getLabelTextColor,u=a(),h="vertical"===d?-90:0,v=o.map((function(e){var o,a,s;return"horizontal"===n?(a=e.y+e.height/2,e.x<t/2?"inside"===r?(o=e.x1+l,s="vertical"===d?"middle":"start"):(o=e.x-l,s="vertical"===d?"middle":"end"):"inside"===r?(o=e.x-l,s="vertical"===d?"middle":"end"):(o=e.x1+l,s="vertical"===d?"middle":"start")):"vertical"===n&&(o=e.x+e.width/2,e.y<i/2?"inside"===r?(a=e.y1+l,s="vertical"===d?"end":"middle"):(a=e.y-l,s="vertical"===d?"start":"middle"):"inside"===r?(a=e.y-l,s="vertical"===d?"start":"middle"):(a=e.y1+l,s="vertical"===d?"end":"middle")),{id:e.id,label:e.label,x:o,y:a,textAnchor:s,color:c(e)}})),p=s(),g=p.animate,y=p.config,f=W(v.length,v.map((function(e){return{transform:"translate("+e.x+", "+e.y+") rotate("+h+")",color:e.color,config:y,immediate:!g}})));return M(w,{children:f.map((function(e,o){var n=v[o];return M(P.text,{dominantBaseline:"central",textAnchor:n.textAnchor,transform:e.transform,style:S({},u.labels.text,{fill:e.color,pointerEvents:"none"}),children:n.label},n.id)}))})},X=["isInteractive","animate","motionConfig","theme","renderWrapper"],Y=function(e){var o=e.data,n=e.valueFormat,r=e.layout,a=void 0===r?V.layout:r,d=e.sort,c=void 0===d?V.sort:d,s=e.align,u=void 0===s?V.align:s,h=e.width,g=e.height,f=e.margin,m=e.colors,k=void 0===m?V.colors:m,b=e.nodeThickness,C=void 0===b?V.nodeThickness:b,x=e.nodeSpacing,O=void 0===x?V.nodeThickness:x,L=e.nodeInnerPadding,T=void 0===L?V.nodeInnerPadding:L,w=e.nodeBorderColor,B=void 0===w?V.nodeBorderColor:w,I=e.nodeOpacity,H=void 0===I?V.nodeOpacity:I,P=e.nodeHoverOpacity,W=void 0===P?V.nodeHoverOpacity:P,N=e.nodeHoverOthersOpacity,F=void 0===N?V.nodeHoverOthersOpacity:N,R=e.nodeBorderWidth,z=void 0===R?V.nodeBorderWidth:R,E=e.nodeBorderRadius,G=void 0===E?V.nodeBorderRadius:E,j=e.linkOpacity,A=void 0===j?V.linkOpacity:j,Z=e.linkHoverOpacity,q=void 0===Z?V.linkHoverOpacity:Z,J=e.linkHoverOthersOpacity,X=void 0===J?V.linkHoverOthersOpacity:J,Y=e.linkContract,$=void 0===Y?V.linkContract:Y,_=e.linkBlendMode,ee=void 0===_?V.linkBlendMode:_,oe=e.enableLinkGradient,ne=void 0===oe?V.enableLinkGradient:oe,te=e.enableLabels,ie=void 0===te?V.enableLabels:te,re=e.labelPosition,le=void 0===re?V.labelPosition:re,ae=e.labelPadding,de=void 0===ae?V.labelPadding:ae,ce=e.labelOrientation,se=void 0===ce?V.labelOrientation:ce,ue=e.label,he=void 0===ue?V.label:ue,ve=e.labelTextColor,pe=void 0===ve?V.labelTextColor:ve,ge=e.nodeTooltip,ye=void 0===ge?V.nodeTooltip:ge,fe=e.linkTooltip,me=void 0===fe?V.linkTooltip:fe,ke=e.isInteractive,be=void 0===ke?V.isInteractive:ke,Ce=e.onClick,xe=e.legends,Oe=void 0===xe?V.legends:xe,Le=e.layers,Me=void 0===Le?V.layers:Le,Te=e.role,we=void 0===Te?V.role:Te,Be=e.ariaLabel,Ie=e.ariaLabelledBy,He=e.ariaDescribedBy,Pe=v(h,g,f),We=Pe.margin,Ne=Pe.innerWidth,Fe=Pe.innerHeight,Re=Pe.outerWidth,Se=Pe.outerHeight,ze=D({data:o,valueFormat:n,layout:a,width:Ne,height:Fe,sort:c,align:u,colors:k,nodeThickness:C,nodeSpacing:O,nodeInnerPadding:T,nodeBorderColor:B,label:he,labelTextColor:pe}),Ee=ze.nodes,Ge=ze.links,je=ze.legendData,Ve=ze.getNodeBorderColor,Ae=ze.currentNode,De=ze.setCurrentNode,Ze=ze.currentLink,Ue=ze.setCurrentLink,qe=ze.getLabelTextColor,Je=function(){return!1},Ke=function(){return!1};if(Ze&&(Je=function(e){var o=e.id;return o===Ze.source.id||o===Ze.target.id},Ke=function(e){var o=e.source,n=e.target;return o.id===Ze.source.id&&n.id===Ze.target.id}),Ae){var Qe=[Ae.id];Ge.filter((function(e){var o=e.source,n=e.target;return o.id===Ae.id||n.id===Ae.id})).forEach((function(e){var o=e.source,n=e.target;Qe.push(o.id),Qe.push(n.id)})),Qe=l(Qe),Je=function(e){var o=e.id;return Qe.includes(o)},Ke=function(e){var o=e.source,n=e.target;return o.id===Ae.id||n.id===Ae.id}}var Xe={links:Ge,nodes:Ee,margin:We,width:h,height:g,outerWidth:Re,outerHeight:Se},Ye={links:null,nodes:null,labels:null,legends:null};return Me.includes("links")&&(Ye.links=M(K,{links:Ge,layout:a,linkContract:$,linkOpacity:A,linkHoverOpacity:q,linkHoverOthersOpacity:X,linkBlendMode:ee,enableLinkGradient:ne,setCurrentLink:Ue,currentNode:Ae,currentLink:Ze,isCurrentLink:Ke,isInteractive:be,onClick:Ce,tooltip:me},"links")),Me.includes("nodes")&&(Ye.nodes=M(U,{nodes:Ee,nodeOpacity:H,nodeHoverOpacity:W,nodeHoverOthersOpacity:F,borderWidth:z,borderRadius:G,getBorderColor:Ve,setCurrentNode:De,currentNode:Ae,currentLink:Ze,isCurrentNode:Je,isInteractive:be,onClick:Ce,tooltip:ye},"nodes")),Me.includes("labels")&&ie&&(Ye.labels=M(Q,{nodes:Ee,layout:a,width:Ne,height:Fe,labelPosition:le,labelPadding:de,labelOrientation:se,getLabelTextColor:qe},"labels")),Me.includes("legends")&&(Ye.legends=M(i,{children:Oe.map((function(e,o){return M(y,S({},e,{containerWidth:Ne,containerHeight:Fe,data:je}),"legend"+o)}))},"legends")),M(p,{width:Re,height:Se,margin:We,role:we,ariaLabel:Be,ariaLabelledBy:Ie,ariaDescribedBy:He,children:Me.map((function(e,o){var n;return"function"==typeof e?M(i,{children:t(e,Xe)},o):null!=(n=null==Ye?void 0:Ye[e])?n:null}))})},$=function(e){var o=e.isInteractive,n=void 0===o?V.isInteractive:o,t=e.animate,i=void 0===t?V.animate:t,r=e.motionConfig,l=void 0===r?V.motionConfig:r,a=e.theme,d=e.renderWrapper,c=function(e,o){if(null==e)return{};var n,t,i={},r=Object.keys(e);for(t=0;t<r.length;t++)n=r[t],o.indexOf(n)>=0||(i[n]=e[n]);return i}(e,X);return M(h,{animate:i,isInteractive:n,motionConfig:l,renderWrapper:d,theme:a,children:M(Y,S({isInteractive:n},c))})},_=function(e){return M(g,{children:function(o){var n=o.width,t=o.height;return M($,S({width:n,height:t},e))}})};export{_ as ResponsiveSankey,$ as Sankey,j as sankeyAlignmentFromProp,G as sankeyAlignmentPropKeys,E as sankeyAlignmentPropMapping,V as svgDefaultProps}; | ||
//# sourceMappingURL=nivo-sankey.es.js.map |
@@ -26,4 +26,4 @@ import { AriaAttributes, MouseEvent, FunctionComponent } from 'react'; | ||
} | ||
declare type ExtraLinkProps<L extends DefaultLink> = Omit<L, 'source' | 'target' | 'value'>; | ||
export declare type SankeyLinkDatum<N extends DefaultNode, L extends DefaultLink> = ExtraLinkProps<L> & { | ||
type ExtraLinkProps<L extends DefaultLink> = Omit<L, 'source' | 'target' | 'value'>; | ||
export type SankeyLinkDatum<N extends DefaultNode, L extends DefaultLink> = ExtraLinkProps<L> & { | ||
value: number; | ||
@@ -41,3 +41,3 @@ index: number; | ||
}; | ||
export declare type SankeyNodeDatum<N extends DefaultNode, L extends DefaultLink> = N & { | ||
export type SankeyNodeDatum<N extends DefaultNode, L extends DefaultLink> = N & { | ||
depth: number; | ||
@@ -67,8 +67,8 @@ index: number; | ||
} | ||
export declare type SankeyLayerId = 'links' | 'nodes' | 'labels' | 'legends'; | ||
export declare type SankeyMouseHandler = <N extends DefaultNode, L extends DefaultLink>(data: SankeyNodeDatum<N, L> | SankeyLinkDatum<N, L>, event: MouseEvent) => void; | ||
export declare type SankeyAlignType = 'center' | 'justify' | 'start' | 'end'; | ||
export declare type SankeyAlignFunction = (node: SankeyNodeMinimal<any, any>, n: number) => number; | ||
export declare type SankeySortType = 'auto' | 'input' | 'ascending' | 'descending'; | ||
export declare type SankeySortFunction<N extends DefaultNode, L extends DefaultLink> = (a: SankeyNodeDatum<N, L>, b: SankeyNodeDatum<N, L>) => number; | ||
export type SankeyLayerId = 'links' | 'nodes' | 'labels' | 'legends'; | ||
export type SankeyMouseHandler = <N extends DefaultNode, L extends DefaultLink>(data: SankeyNodeDatum<N, L> | SankeyLinkDatum<N, L>, event: MouseEvent) => void; | ||
export type SankeyAlignType = 'center' | 'justify' | 'start' | 'end'; | ||
export type SankeyAlignFunction = (node: SankeyNodeMinimal<any, any>, n: number) => number; | ||
export type SankeySortType = 'auto' | 'input' | 'ascending' | 'descending'; | ||
export type SankeySortFunction<N extends DefaultNode, L extends DefaultLink> = (a: SankeyNodeDatum<N, L>, b: SankeyNodeDatum<N, L>) => number; | ||
export interface SankeyCommonProps<N extends DefaultNode, L extends DefaultLink> { | ||
@@ -119,4 +119,4 @@ valueFormat: ValueFormat<number>; | ||
} | ||
export declare type SankeySvgProps<N extends DefaultNode, L extends DefaultLink> = Partial<SankeyCommonProps<N, L>> & SankeyDataProps<N, L> & Dimensions & ModernMotionProps; | ||
export type SankeySvgProps<N extends DefaultNode, L extends DefaultLink> = Partial<SankeyCommonProps<N, L>> & SankeyDataProps<N, L> & Dimensions & ModernMotionProps; | ||
export {}; | ||
//# sourceMappingURL=types.d.ts.map |
101
package.json
{ | ||
"name": "@nivo/sankey", | ||
"version": "0.81.0", | ||
"license": "MIT", | ||
"author": { | ||
"name": "Raphaël Benitte", | ||
"url": "https://github.com/plouc" | ||
}, | ||
"repository": { | ||
"type": "git", | ||
"url": "https://github.com/plouc/nivo.git", | ||
"directory": "packages/sankey" | ||
}, | ||
"keywords": [ | ||
"nivo", | ||
"dataviz", | ||
"react", | ||
"d3", | ||
"charts", | ||
"sankey-diagram" | ||
], | ||
"main": "./dist/nivo-sankey.cjs.js", | ||
"module": "./dist/nivo-sankey.es.js", | ||
"typings": "./dist/types/index.d.ts", | ||
"files": [ | ||
"README.md", | ||
"LICENSE.md", | ||
"dist/", | ||
"!dist/tsconfig.tsbuildinfo" | ||
], | ||
"dependencies": { | ||
"@nivo/colors": "0.81.0", | ||
"@nivo/legends": "0.81.0", | ||
"@nivo/tooltip": "0.81.0", | ||
"@react-spring/web": "9.4.5 || ^9.7.2", | ||
"d3-sankey": "^0.12.3", | ||
"d3-shape": "^1.3.5", | ||
"lodash": "^4.17.21" | ||
}, | ||
"devDependencies": { | ||
"@nivo/core": "0.81.0", | ||
"@types/d3-sankey": "^0.11.2" | ||
}, | ||
"peerDependencies": { | ||
"@nivo/core": "0.81.0", | ||
"react": ">= 16.14.0 < 19.0.0" | ||
}, | ||
"publishConfig": { | ||
"access": "public" | ||
}, | ||
"gitHead": "56db9cb7738f406a21085c11ab28716044fceb5b" | ||
"name": "@nivo/sankey", | ||
"version": "0.82.0", | ||
"license": "MIT", | ||
"author": { | ||
"name": "Raphaël Benitte", | ||
"url": "https://github.com/plouc" | ||
}, | ||
"repository": { | ||
"type": "git", | ||
"url": "https://github.com/plouc/nivo.git", | ||
"directory": "packages/sankey" | ||
}, | ||
"keywords": [ | ||
"nivo", | ||
"dataviz", | ||
"react", | ||
"d3", | ||
"charts", | ||
"sankey-diagram" | ||
], | ||
"main": "./dist/nivo-sankey.cjs.js", | ||
"module": "./dist/nivo-sankey.es.js", | ||
"types": "./dist/types/index.d.ts", | ||
"files": [ | ||
"README.md", | ||
"LICENSE.md", | ||
"dist/", | ||
"!dist/tsconfig.tsbuildinfo" | ||
], | ||
"dependencies": { | ||
"@nivo/colors": "0.82.0", | ||
"@nivo/legends": "0.82.0", | ||
"@nivo/tooltip": "0.82.0", | ||
"@react-spring/web": "9.4.5 || ^9.7.2", | ||
"@types/d3-sankey": "^0.11.2", | ||
"@types/d3-shape": "^2.0.0", | ||
"d3-sankey": "^0.12.3", | ||
"d3-shape": "^1.3.5", | ||
"lodash": "^4.17.21" | ||
}, | ||
"peerDependencies": { | ||
"@nivo/core": "workspace:*", | ||
"react": ">= 16.14.0 < 19.0.0" | ||
}, | ||
"devDependencies": { | ||
"@nivo/core": "0.82.0" | ||
}, | ||
"publishConfig": { | ||
"access": "public" | ||
}, | ||
"gitHead": "579fc012df24e154a387243559165e344b6523da" | ||
} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Minified code
QualityThis package contains minified code. This may be harmless in some cases where minified code is included in packaged libraries, however packages on npm should not minify code.
Found 1 instance in 1 package
Minified code
QualityThis package contains minified code. This may be harmless in some cases where minified code is included in packaged libraries, however packages on npm should not minify code.
Found 1 instance in 1 package
1
198107
11
38
518
+ Added@types/d3-sankey@^0.11.2
+ Added@types/d3-shape@^2.0.0
+ Added@nivo/colors@0.82.0(transitive)
+ Added@nivo/tooltip@0.82.0(transitive)
+ Added@types/d3-color@2.0.6(transitive)
+ Added@types/d3-path@1.0.112.0.4(transitive)
+ Added@types/d3-sankey@0.11.2(transitive)
+ Added@types/d3-scale@3.3.5(transitive)
+ Added@types/d3-scale-chromatic@2.0.4(transitive)
+ Added@types/d3-shape@1.3.122.1.7(transitive)
+ Added@types/d3-time@2.1.4(transitive)
+ Added@types/prop-types@15.7.14(transitive)
+ Addedd3-format@2.0.0(transitive)
- Removed@nivo/colors@0.81.0(transitive)
- Removed@nivo/core@0.81.0(transitive)
- Removed@nivo/recompose@0.81.0(transitive)
- Removed@nivo/tooltip@0.81.0(transitive)
- Removedd3-format@1.4.5(transitive)
- Removedreact-lifecycles-compat@3.0.4(transitive)
Updated@nivo/colors@0.82.0
Updated@nivo/legends@0.82.0
Updated@nivo/tooltip@0.82.0