Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started

Reply
andrjohns
Helper I
Helper I

Conditional Formatting - createDataViewWildcardSelector with Grouped Data

Hi All!

 

I'm having some issues using the recommended `createDataViewWildcardSelector` when implementing conditional formatting for data with groupings.

 

Using the `CircleCard` demo visual (from `pbiviz new CircleCard`), if I add conditional formatting support for font size using:

 

    fontSize = new formattingSettings.NumUpDown({
        name: "fontSize",
        displayName: "Text Size",
        value: 12,
        selector: dataViewWildcard.createDataViewWildcardSelector(dataViewWildcard.DataViewWildcardMatchingOption.InstancesAndTotals),
        instanceKind: powerbi.VisualEnumerationInstanceKinds.ConstantOrRule
    });

 

The resulting dataview (as expected) has `objects` bound to each category:

andrjohns_0-1722251707387.png

 

However, if I update the dataview mapping to additionally group values:

    "dataViewMappings": [
        {
            "categorical": {
                "categories": {
                    "for": {
                        "in": "category"
                    },
                    "dataReductionAlgorithm": {
                        "top": {}
                    }
                },
                "values": {
                    "group": {
                        "by": "grouping",
                        "select": [
                            {
                                "for": {
                                    "in": "measure"
                                }
                            }
                        ]
                    }
                }
            }
        }
    ]

 

Then `objects` is no longer bound to the `categories` (or anywhere in the dataview, for that matter):

andrjohns_1-1722251965809.png

 

Is there an alternate method that should be used for grouping/series? I've been trying different ways of specifying the `selector` input, but have had no luck so far.

 

If it would be helpful, here's a repo with the (slightly) modified CircleCard example that reproduces the behaviour:
https://github.com/andrjohns/circleCard-demo

 

Thanks!

 

3 REPLIES 3
andrjohns
Helper I
Helper I

For any that come across this thread in the future, the solution that I found was to use a different kind of 'Wildcard' selector.

 

I found that the visuals API defined different types of data repetition selectors, specifically a role wildcard

 

So where the original implementation was:

    fontSize = new formattingSettings.NumUpDown({
        name: "fontSize",
        displayName: "Text Size",
        value: 12,
        selector: dataViewWildcard.createDataViewWildcardSelector(dataViewWildcard.DataViewWildcardMatchingOption.InstancesAndTotals),
        instanceKind: powerbi.VisualEnumerationInstanceKinds.ConstantOrRule
    });



I followed the definition for creating the dataview wildcard selector and replaced the selector definition with:

 

    fontSize = new formattingSettings.NumUpDown({
        name: "fontSize",
        displayName: "Text Size",
        value: 12,
        selector: { data: [{ roles: ["category"] }] },
        instanceKind: powerbi.VisualEnumerationInstanceKinds.ConstantOrRule
    });

 

With this change, the conditional formatting objects were then bound to 'categories' as before, even when a grouping series is used

dm-p
Super User
Super User

Hi @andrjohns,

 

I've spent a little while looking at this. Your code looks good to me, and I think it's probably worth checking with MS to see if this is supported or a bug. This repo is a good way for them to quickly confirm if something is wrong, or if there is something else to do to make it work.

 

For groupings, I would expect the DataViewValueColumnGroup returned by categorical.values.grouped() to contain an objects property with the derived conditional formatting values. This does not happen.

 

To show my working, I have downloaded your repo and created a data set that looks like this:

 

dmp_0-1722289009656.png

 

So:

 

  • Category = Month Name (Date.Month Name)
  • Grouping = Calendar Year (Date.Calendar Year)
  • Measure = Deviation from Reference (Temperature Deviations.Deviation from Reference)

In my data view metadata, I get what I might expect: one entry for each field I added, then an additional four entries for the intersection of grouping x measure:

 

dmp_1-1722289179227.png

 

Expanding the last entry to confirm groupName of 2024 (last value of Calendar Year):

 

dmp_2-1722289246694.png

 

As I say, it's not a great example, but should hopefully demonstrate that things are happening as I expect so far.

 

When I try to add a measure to the conditional formatting field (we'll do an implicit measure of count of Calendar Year, because we have less entries in 2024 and can check the number is right), the array changes as follows:

 

dmp_3-1722289571297.png

 

Hopefully you will see that our array length is now 12 (up from 7). This is:

 

  • One entry for the implicit measure (index #3)
  • Four additional entries for measure x calendar year (entries #5, #7, #9 and #11)

 

If we expand the final entry, we can see that it is indeed for groupName = 2024, and there is an additional property called relatedObjects (which I have also expended for youto show its structure):

 

dmp_4-1722289786176.png

 

You should be able to see that this has dataPoint.fontSize in its structure.

 

However, this is not part of the API, so we shouldn't rely on it. We can also see that there is no corresponding derived value in there anyway.

 

This is as much as I could find in the data view (I also downloaded the raw data view to check for occurrences of the fontSize object and it's definitely not there).

 

So, long story short, I'd contact MS at pbicvsupport@microsoft.com, to see if they can confirm what is gong wrong here, and if it isn't a bug, what the correct implementation should be for this use case. It would defininitely be useful to provide them with your repo and this thread for reference.

 

Good luck,

 

Daniel

 

 

 

 





Did I answer your question? Mark my post as a solution!

Proud to be a Super User!


My course: Introduction to Developing Power BI Visuals


On how to ask a technical question, if you really want an answer (courtesy of SQLBI)




Hi Daniel,

 

Thanks for taking the time to dive in and investigate, it's much appreciated! Great to hear that it's not just me missing something obvious, I'll contact support and see what they say.

 

Thanks again!

Helpful resources

Announcements
Europe Fabric Conference

Europe’s largest Microsoft Fabric Community Conference

Join the community in Stockholm for expert Microsoft Fabric learning including a very exciting keynote from Arun Ulag, Corporate Vice President, Azure Data.

AugPowerBI_Carousel

Power BI Monthly Update - August 2024

Check out the August 2024 Power BI update to learn about new features.

August Carousel

Fabric Community Update - August 2024

Find out what's new and trending in the Fabric Community.

Top Kudoed Authors