Loading...

Get insights about Power Apps usage with Microsoft Clarity PCF code component

Get insights about Power Apps usage with Microsoft Clarity PCF code component

Getting insights on user behavior in Power Apps canvas apps can be in various ways - for instance, you can analyze app telemetry with Azure Application Insights and trace events. If you are more interested in visual heatmaps and session recordings, you might already have had a look at Microsoft Clarity, which exactly provides that:

What is Microsoft Clarity and how do I connect it to a Power Apps canvas app?

Clarity is a user behavior analytics tool that helps you understand how users are interacting with a website through features such as session replays and heatmaps. It is installed by adding a tracking code into the <head> section of the website.

As a Power Apps canvas app running in the browser is also still just a website, we only need to find a way on how to inject the Clarity JavaScript script into the head of our canvas app.

Unfortunately, there is no connector for Microsoft Clarity, but we can leverage the Power Apps component framework for that.

Power Apps component framework to the rescue

With Power Apps component framework we can create code components for Power Apps. I created a code component for Microsoft Clarity, so that we can use Clarity in our canvas apps.

High level overview

To give you an idea on how to create this, here is high level overview- it’s not meant to replace extensive learning with very detailed step-by-step instructions though. I will link to resources though if this is your first code component - it was my first :-)

  • Sign up for a free Clarity account
  • Set up your project

new Clarity project

  • Use Power Platform CLI to create the code component
  • In the scaffolded project, locate ControlManifest.Input.xml and index.ts
  • Update the ControlManifest.Input.xml file to
<?xml version="1.0" encoding="utf-8" ?>
<manifest>
<control namespace="ClarityNameSpace" constructor="ClarityCodeSnippet" version="1.0.0" display-name-key="ClarityLovesPowerApps" description-key="Clarity Code Component to analyze user behavior" control-type="standard" >
<property name="YourClarityProjectID" display-name-key="<your-clarity-project-id>" description-key="description" of-type="SingleLine.Text" usage="bound" required="true" />
<external-service-usage enabled="false">
</external-service-usage>
<resources>
<code path="index.ts" order="1"/>
</resources>
</control>
</manifest>
  • In the index.ts file, we first need a private _Container: HTMLDivElement; above the constructor
  • then add the following code to the init method
 public init(context: ComponentFramework.Context<IInputs>, notifyOutputChanged: () => void, state: ComponentFramework.Dictionary, container:HTMLDivElement): void
{
const head = document.getElementsByTagName('head')[0];
const script = document.createElement('script');
script.innerHTML = '(function(c,l,a,r,i,t,y){c[a]=c[a]||function(){(c[a].q=c[a].q||[]).push(arguments)};t=l.createElement(r);t.async=1;t.src="https://www.clarity.ms/tag/"+i;y=l.getElementsByTagName(r)[0];y.parentNode.insertBefore(t,y);})(window, document, "clarity", "script", "<your clarity project id>");'
head.insertBefore(script, head.firstChild);
const textDiv = "<div>We are tracking this app with Microsoft clarity, have a lovely day!</div>"
this._Container = document.createElement("div");
this._Container.id = "ClarityDivID";
this._Container.innerHTML = textDiv;
container.appendChild(this._Container);
}

When you now use the app, you can open Edge Dev tools on the Network tab and see the work Clarity is doing:

Clarity in Edge Dev tools

How does this now look like in our Canvas app?

In your Canvas app, you can either style your code component or you can set the Visible property to false to hide it.

Clarity properties

It takes a decent while (I guess about 90 minutes) for data to arrive for the first time in Clarity, but after that it runs smoothly - here is how the dashboard then looks like:

Clarity dashboard

If we now want get more into the details of users are interacting with our apps (sometimes easier than asking them), we can watch a replay of the session recordings:

Clarity recording

This gives us information on where users click, scroll and type.

Heatmaps are a valuable feature to determine which parts of an app are most selected:

Clarity heatmap

Where to find the component

You can find this component on my GitHub - Let me know if you have questions! If you found this blog post useful, please also subscribe to my newsletter - news coming about every 2 months, I promise to not spam you!

Published on:

Learn more
Luise Freese: Consultant & MVP
Luise Freese: Consultant & MVP

Recent content on Luise Freese: Consultant & MVP

Share post:

Related posts

Style Your Fluent UI 9 PCFs for Power Apps

In my other blog I’ve wrote about how to apply Theming to a PCF made with Fluent UI 9. Today I’ll concentrate on how to make the P...

2 days ago

Approvals in Power Apps with Power Automate, Teams, and Adaptive Cards

Table of Contents Introduction Are you looking for a simple and extensible no-code solution for handling approvals in Power Apps? The post App...

7 days ago

How to use custom sorting in canvas apps

Records can be easily sorted in an ascending or descending order. Learn how to implement a complex custom sorting in canvas apps! The post How...

7 days ago

Power Apps | Canvas Apps and Pages Not Displaying Data

Some of our Canvas Apps and Pages stopped displaying data (refer to the screenshots below) after installing a managed solution. Upon checking ...

8 days ago

How to Maximize Your Business Efficiency with Power BI, Power Apps, Power Automate?

In today’s fast-paced world, to remain ahead of the edge as a business means ensuring you are ahead in all parameters. Like automating workflo...

9 days ago

Have you played Connect 4? In Power Apps?

The famous Connect 4 game recreated in Power Apps! With simple game play and fancy UI! Learn how I did it! The post Have you played Connect 4?...

13 days ago

Clear all objects feature in Power Apps Solutions

A new feature has been released in Microsoft Power Apps to Clear all objects in the Solution, while adding the existing Table’s componen...

13 days ago

Get the Largest Divisor in Power Apps

Last week I someone ask me about calculating the largest divisor for a number within Power Apps. This had to be fast! With the right approach,...

13 days ago
Stay up to date with latest Microsoft Dynamics 365 and Power Platform news!
* Yes, I agree to the privacy policy