Highcharts

Start your Highcharts journey today

立即试用
立即购买
Skip to Content

KPI Component

The KPI component allows you to visualize key performance indicators.

How to start

Load Dashboards

To be able to use KPIComponent you first have to load the main Dashboards  package.

Define HTML cell

Define a cell using a unique identifier for example renderTo: 'dashboard-col-0'. You can find more information how to create a layout in dashboard here .

Configuration

The last thing that you have to do is to specify the type: 'KPI' and value: <value> in the component’s config. See the full example below.

Dashboards.board('container', { gui: { layouts: [{ id: 'layout-1', rows: [{ cells: [{ id: 'dashboard-col-0' }] }] }] }, components: [{ renderTo: 'dashboard-col-0', type: 'KPI', title: 'My KPI', value: 10 }] });

KPI with chart

KPIComponent supports inclusion of a Hicgcharts chart.

Required imports

To be able to use Highcharts in KPI you first have to load Highcharts .

<script src="https://code.highcharts.com/highcharts.js"></script> <script src="https://code.highcharts.com/dashboards/dashboards.js"></script> <script src="https://code.highcharts.com/dashboards/modules/layout.js"></script>

Alternatively, you can also use the NPM package.

npm install highcharts @highcharts/dashboards

and import it in your project like:

import * as Dashboards from '@highcharts/dashboards'; import * as Highcharts from 'highcharts'; import LayoutModule from '@highcharts/dashboards/modules/layout'; LayoutModule(Dashboards); Dashboards.HighchartsPlugin.custom.connectHighcharts(Highcharts); Dashboards.PluginHandler.addPlugin(Dashboards.HighchartsPlugin);

No chart styled mode

From version v3.0.0 the KPIComponent with chart does not use styledMode  by default, no need to load the set of CSS styles to display Highcharts properly.

Importing only dashboards CSS file is enough:

@import url("https://code.highcharts.com/dashboards/css/dashboards.css");

Also, be aware that we prepared the component so it was minimalist. To achieve that, some of the chart options are already set. You can find the defaultChartOptions in the API .

Chart options

Define chart options for the KPI. For the full set of available chart options, see the Highcharts API 

Dashboards.board('container', { gui: { layouts: [{ id: 'layout-1', rows: [{ cells: [{ id: 'dashboard-col-0' }] }] }] }, components: [{ renderTo: 'dashboard-col-0', title: 'My KPI', type: 'KPI', value: 10, linkedValueTo: { enabled: false }, chartOptions: { series: [{ data: [734, 244, 685, 250, 920, 320, 200, 150] }] } }] });

By default, the KPI value is synchronized with the Y value of the first point in the first series. To turn off the synchronization, disable the linkedValueTo  option as in the example above.

You can also use this option to change the point to be synchronized with the value, setting its index and the index of the series it belongs to.

Working with data

You can either define static data, as you would do in the basic KPI Component (the value parameter), or use the dataPool  to connect some dynamic data. The KPIComponent reflects the last value from the column (declared by columnName param) as a value itself.

Here is an example  that uses as connector.

Dashboards.board('container', { dataPool: { connectors: [{ id: 'value', type: 'CSV', options: { csv: `Date,Value 2019-01-01,100 2019-01-02,200 2019-01-03,300 2019-01-04,400` } }] }, components: [{ renderTo: 'kpi', type: 'KPI', title: 'Last day\'s value', columnName: 'Value', connector: { id: 'value' } }], gui: { layouts: [{ rows: [{ cells: [{ id: 'kpi' }] }] }] } });

Configuring options

The value can be customized by:

  • valueFormat - a format string for the value text.
valueFormat: '{value} km/h',
  • valueFormatter - a function to format the text of the value from scratch.
valueFormatter: function () { return this.options.value + ' km/h'; },

Sync with other components

The KPI Component allows users to sync the component with other components in Dashboards. You can find more information about it in the sync article .

API options

For the full set of available options, see the API .