diff --git a/frontend/app/components/Charts/SankeyChart.tsx b/frontend/app/components/Charts/SankeyChart.tsx index 4f74bf8f7..e9abbc2a6 100644 --- a/frontend/app/components/Charts/SankeyChart.tsx +++ b/frontend/app/components/Charts/SankeyChart.tsx @@ -183,6 +183,7 @@ const EChartsSankey: React.FC = (props) => { }, series: [ { + animation: false, layoutIterations: 0, type: 'sankey', data: echartNodes, @@ -193,6 +194,7 @@ const EChartsSankey: React.FC = (props) => { opacity: 0.5, }, }, + top: 40, label: { show: true, position: 'top', @@ -216,18 +218,27 @@ const EChartsSankey: React.FC = (props) => { '...' + params.name.slice(-(maxLen / 2 - 2)) : params.name; + const nodeType = params.data.type; + + const icon = getIcon(nodeType) return ( - `{header|${safeName}}\n` + + `${icon}{header|${safeName}}\n` + `{body|}{percentage|${percentage}} {sessions|${nodeVal}}` ); }, rich: { + container: { + height: 20, + width: 14, + }, header: { fontWeight: '600', fontSize: 12, color: '#333', overflow: 'truncate', paddingBottom: '.5rem', + paddingLeft: '14px', + position: 'relative', }, body: { fontSize: 12, @@ -242,6 +253,34 @@ const EChartsSankey: React.FC = (props) => { fontFamily: "mono, 'monospace', sans-serif", color: '#999999', }, + clickIcon: { + backgroundColor: { + image: '' + }, + height: 20, + width: 14, + } }, }, tooltip: { @@ -445,4 +484,26 @@ const EChartsSankey: React.FC = (props) => { ); }; +const icons = { + LOCATION: 'locationIcon', + INPUT: 'inputIcon', + CUSTOM_EVENT: 'customEventIcon', + CLICK: 'clickIcon', +} +function getIcon(type: string) { + if (type === 'LOCATION') { + return '{locationIcon|}' + } + if (type === 'INPUT') { + return '{inputIcon|}' + } + if (type === 'CUSTOM_EVENT') { + return '{customEventIcon|}' + } + if (type === 'CLICK') { + return '{clickIcon|}'; + } + return '' +} + export default EChartsSankey;