diff --git a/packages/mermaid/src/diagrams/flowchart/flowRenderer-v2.js b/packages/mermaid/src/diagrams/flowchart/flowRenderer-v2.js index 1dce1391ef..0a8f7521fa 100644 --- a/packages/mermaid/src/diagrams/flowchart/flowRenderer-v2.js +++ b/packages/mermaid/src/diagrams/flowchart/flowRenderer-v2.js @@ -265,6 +265,16 @@ export const addEdges = async function (edges, g, _diagObj) { let style = ''; let labelStyle = ''; + let isAnimatedProducerNode = g.node(edge.start).class.split(' ').includes('producer'); + let isAnimatedConsumerNode = g.node(edge.end).class.split(' ').includes('consumer'); + + let linkAnimatedDashClass = + edge.stroke === 'dotted' && + edge.type === 'arrow_point' && + isAnimatedProducerNode && + isAnimatedConsumerNode + ? 'animated' + : ''; switch (edge.stroke) { case 'normal': @@ -329,7 +339,9 @@ export const addEdges = async function (edges, g, _diagObj) { edgeData.labelStyle = edgeData.labelStyle.replace('color:', 'fill:'); edgeData.id = linkId; - edgeData.classes = 'flowchart-link ' + linkNameStart + ' ' + linkNameEnd; + edgeData.classes = ['flowchart-link', linkAnimatedDashClass, linkNameStart, linkNameEnd].join( + ' ' + ); // Add the edge to the graph g.setEdge(edge.start, edge.end, edgeData, cnt); diff --git a/packages/mermaid/src/diagrams/flowchart/styles.ts b/packages/mermaid/src/diagrams/flowchart/styles.ts index b30c0b9bc7..fcce1644c2 100644 --- a/packages/mermaid/src/diagrams/flowchart/styles.ts +++ b/packages/mermaid/src/diagrams/flowchart/styles.ts @@ -106,7 +106,6 @@ const getStyles = (options: FlowChartStyleOptions) => /* For html labels only */ .labelBkg { background-color: ${fade(options.edgeLabelBackground, 0.5)}; - // background-color: } .cluster rect { @@ -145,6 +144,15 @@ const getStyles = (options: FlowChartStyleOptions) => font-size: 18px; fill: ${options.textColor}; } + + .animated { + animation: animate-dash-line 5s linear infinite; + } + + @keyframes animate-dash-line { + from { stroke-dashoffset: 102; } + to { stroke-dashoffset: 0; } + } `; export default getStyles;