Milestone trend analysis visual in Power BI with Deneb
Context
If you are reading this blog post, I assume that you already know what a milestone trend analysis is and its benefits to track progress in project management. Therefore, I will not cover it here and if you want to know more about the theory behind it you can just google it or ask ChatGPT :)
This blog post is about how to develop a milestone trend analysis in Power BI with Deneb.
Deneb and Vega-Lite code
I developed this milestone trend analysis visual with Deneb using Vega-Lite. Before we talk about how to develop the visual, let’s take a look what we want to achieve. See below the Power BI report:
You can find below the complete code used to create the chart. But don’t worry, we are going to go through the code. Just to be clear, I am not an expert in Deneb Vega-Lite, so there might be more efficient ways to write the code below.
Let’s break down the code into 4 sections:
Section 1: Create a dynamic line to calculate the min value for reporting date and max value for the forecast date for the selected milestones
See below the explanation about the following section of the code:
As we can see from the code, I created the dynamic line inside a layer. It is important to create this layer, because we want to create two different visuals on top of each other. For more details about layer in Vega-Lite refer to the documentation here.
Section 2: Create a parameter to be used later to have an interactive legend
See below the explanation about creating the parameter. As you can see below, I created a measure called “Filtered Milestone”, this measure checks if any milestone is selected from the slicer. In this case, if the user doesn’t select any milestone from the slicer, the legend of the visual returns nothing in order to avoid visual clutter. I got this idea from a great blog post from Nikola Ilic, for more details refer to his blog post here.
Section 3: Create a line chart with “Reporting Date” and milestone forecast
See below the code and the explanation to create the line chart with the reporting date and with the DAX measure with the milestone forecast.
Section 4: Create the interactive legend and tooltip
This is the final step to create the milestone trend analysis visual. See below the explanation of the final section of the code:
Configuration properties of the visual
It is possible to add configuration properties for a visual to create a consistent theme. See below the configuration properties used to create this milestone trend analysis visual:
Last updated on December 24, 2023