Analytics Widgets
Analytics Widgets UI Extension for Umbraco Commerce
Last updated
Was this helpful?
Analytics Widgets UI Extension for Umbraco Commerce
Last updated
Was this helpful?
Analytics Widgets allow you to display custom charts and reports in the analytics section to track your important KPIs.
import { UcManifestAnalyticsWidget } from "@umbraco-commerce/backoffice";
export const manifests : UcManifestAnalyticsWidget[] = [
{
type: 'ucAnalyticsWidget',
alias: 'Uc.AnalyticsWidget.TotalOrders',
name: 'Total Orders',
element: () => import('./total-orders-widget.element.js'),
meta: {
label: '#ucAnalytics_totalOrdersHeadline',
description: '#ucAnalytics_totalOrdersDescription'
}
}
];
extensionRegistry.register(manifests);
Each entry must have a type of ucAnalyticsWidget
along with a unique alias
and name
. An element
key should be defined to import the implementation of the UcAnalyticsWidget
component interface.
A meta
entry provides configuration options for the widget
label
A label for this widget (supports the #
prefix localization string syntax)
description
A description for this widget (supports the #
prefix localization string syntax)
In order to define the UI for a widget, you'll need to define a component that implements the UcAnalyticsWidget
interface. This interface is defined as
export interface UcAnalyticsWidget extends UmbControllerHostElement {
storeId:string;
manifest: UcManifestAnalyticsWidget;
timeframe: UcAnalyticsTimeframe;
}
This provides widget implementations with access to the current storeId
, the defined manifest
, and the current selected timeframe
for which the widget should show relevant data.
An example implementation would be
// total-orders-widget.element.js
import { customElement, html, property, state } from "@umbraco-cms/backoffice/external/lit";
import { UmbLitElement } from "@umbraco-cms/backoffice/lit-element";
import { UcAnalyticsTimeframe, UcAnalyticsWidget, UcManifestAnalyticsWidget } from "@umbraco-commerce/backoffice";
@customElement('uc-total-orders-widget')
export class UcTotalOrdersWidgetElement extends UmbLitElement implements UcAnalyticsWidget {
@property({ type:String })
storeId!:string;
@property({ type: Object, attribute: false })
manifest?: UcManifestAnalyticsWidget;
@property({ type: Object, attribute: false })
set timeframe(timeframe: UcAnalyticsTimeframe) {
this._timeframe = timeframe;
this.#fetchData();
}
private _timeframe?: UcAnalyticsTimeframe;
@state()
private _data?:any[];
#fetchData = async () => {
// Fetch data using this._timeframe properties as a filter
// and store the result in this._data
}
render() {
if (!this._data) return;
return html`-- WIDGET MARKUP GOES HERE --`;
}
}
export default UcTotalOrdersWidgetElement;
declare global {
interface HTMLElementTagNameMap {
'uc-total-orders-widget': UcTotalOrdersWidgetElement;
}
}
When an alternative timeframe is selected from the widget dashboard, all widget's timeframe
properties will be updated to re-fetch and render the widget.