Power BI is turning 10! Tune in for a special live episode on July 24 with behind-the-scenes stories, product evolution highlights, and a sneak peek at what’s in store for the future.
Save the dateEnhance your career with this limited time 50% discount on Fabric and Power BI exams. Ends August 31st. Request your voucher.
Hi everyone,
I am trying to do a report that will automatically update at the start of each month. Within this report there are some charts, like the one attached.
For the graph selected i want it to match the legend below using conditional formatting. This is because every month i want the colour to remain the same, whereby the earliest month in the data set is orange, the latest month in the data set is blue and the other month is black. I have been finding it difficult to write the correct DAX that will do this. Is it possible or is there perhaps a way to work around it. I am also attaching two more screenshots if they help?
Any help would be appreciated
Thank you,
Luke
Solved! Go to Solution.
hi @Anonymous ,
Not sure if i fully get you. Supposing you have a data table like:
date | amt |
12/1/2022 | 1 |
12/2/2022 | 1 |
1/1/2023 | 2 |
1/2/2023 | 2 |
2/1/2023 | 3 |
2/2/2023 | 3 |
3/1/2023 | 4 |
3/2/2023 | 4 |
4/1/2023 | 5 |
4/2/2023 | 5 |
5/1/2023 | 6 |
5/2/2023 | 6 |
Try to
1) create a calculated dates table like below and connect with data[date].
dates =
ADDCOLUMNS(
CALENDAR(MIN(data[date]), MAX(data[date])),
"YYMM", FORMAT([Date], "yy/mm")
)
2) create another calculated slicer table like below and keep it unrelated:
slicer = dates
3) plot a slicer with slicer[date] column;
4) plot a column chart with dates[yymm] and data[amt] column, and apply conditional formatting for the column color with a measure like:
Color =
VAR _minsliceddate = MIN(slicer[date])
VAR _maxsliceddate = MAX(slicer[date])
VAR _minslicedmonth = YEAR(_minsliceddate)*12+MONTH(_minsliceddate)
VAR _maxslicedmonth = YEAR(_maxsliceddate)*12+MONTH(_maxsliceddate)
VAR _currentdate = MAX(dates[date])
VAR _currentmonth = YEAR(_currentdate)*12+MONTH(_currentdate)
VAR _result =
SWITCH(
TRUE(),
_currentmonth =_minslicedmonth, "Orange",
_currentmonth=_maxslicedmonth, "Blue",
_currentmonth=_maxslicedmonth-1, "Black",
"Gray"
)
RETURN _result
it worked like:
hi @Anonymous ,
Not sure if i fully get you. Supposing you have a data table like:
date | amt |
12/1/2022 | 1 |
12/2/2022 | 1 |
1/1/2023 | 2 |
1/2/2023 | 2 |
2/1/2023 | 3 |
2/2/2023 | 3 |
3/1/2023 | 4 |
3/2/2023 | 4 |
4/1/2023 | 5 |
4/2/2023 | 5 |
5/1/2023 | 6 |
5/2/2023 | 6 |
Try to
1) create a calculated dates table like below and connect with data[date].
dates =
ADDCOLUMNS(
CALENDAR(MIN(data[date]), MAX(data[date])),
"YYMM", FORMAT([Date], "yy/mm")
)
2) create another calculated slicer table like below and keep it unrelated:
slicer = dates
3) plot a slicer with slicer[date] column;
4) plot a column chart with dates[yymm] and data[amt] column, and apply conditional formatting for the column color with a measure like:
Color =
VAR _minsliceddate = MIN(slicer[date])
VAR _maxsliceddate = MAX(slicer[date])
VAR _minslicedmonth = YEAR(_minsliceddate)*12+MONTH(_minsliceddate)
VAR _maxslicedmonth = YEAR(_maxsliceddate)*12+MONTH(_maxsliceddate)
VAR _currentdate = MAX(dates[date])
VAR _currentmonth = YEAR(_currentdate)*12+MONTH(_currentdate)
VAR _result =
SWITCH(
TRUE(),
_currentmonth =_minslicedmonth, "Orange",
_currentmonth=_maxslicedmonth, "Blue",
_currentmonth=_maxslicedmonth-1, "Black",
"Gray"
)
RETURN _result
it worked like:
hello @Anonymous ,
you could try to create a measure that forms the conditional formatting for you
measure = if( AND([month] = 9, [year] = 2022), "orange", if(AND([month] = 9, [year] = 2023),"blue","black"))
then add this measure in the fx color setting in your bar as a field value option and you will get the colors for each legend
Hi @eliasayyy ,
I need a measure that will still work without me having to go in and change anything when the data automatically updates at the start of each month. for example the most recent months report is October (10)
Check out the July 2025 Power BI update to learn about new features.
This is your chance to engage directly with the engineering team behind Fabric and Power BI. Share your experiences and shape the future.
User | Count |
---|---|
21 | |
7 | |
6 | |
5 | |
5 |
User | Count |
---|---|
27 | |
10 | |
10 | |
9 | |
6 |