HTML Component
The HTML Component serves as a fundamental building block in dashboards. It offers the versatility to incorporate diverse HTML content. It is a simple yet potent tool for constructing dashboards with dynamic content. The configuration structure resembles an Abstract Syntax Tree (AST), enabling definition of tag names, attributes, and nested elements or can be defined as a string representing the HTML code.
Using the HTML component
1. Installation
The HTML component is the simplest component available in Highcharts Dashboards. You can find it in the main Highcharts Dashboards package.
To use it through the CDN, you need to load the following files
<script src="https://code.highcharts.com/dashboards/dashboards.js"></script>
<script src="https://code.highcharts.com/dashboards/modules/layout.js"></script>Alternatively, you can download the NPM package like:
npm install @highcharts/dashboardsand import it in your project like:
import * as Dashboards from '@highcharts/dashboards';
import LayoutModule from '@highcharts/dashboards/modules/layout';
LayoutModule(Dashboards);2. Layout
After loading the necessary files, define a cell using a unique identifier for the cell, e.g. dashboard-col-0. This cell will be used to place the component in the dashboard.
gui: {
layouts: [{
id: 'layout-1',
rows: [{
cells: [{
id: 'dashboard-col-0'
}]
}]
}]
}3. Options
When the placeholder is ready, component options can be defined. To do so, set the type of the component to HTML. The type is case-sensitive, so make sure to use the exact spelling.
Apart from the type property, the component requires the cell property to be defined. The cell property is used to specify the cell in which the component should be placed.
4. HTML elements
Now, you can define the HTML elements that will be rendered in the component.
HTML content can be defined in two ways:
- The
elementsarray is an array of objects, where each object represents a single HTML element. The object usually contains thetagNamewhich is the name of the HTML tag, e.g.div,img,p, etc. and theattributesof the element. If the text should be rendered inside the element, thetextContentproperty can be used.
components: [{
type: 'HTML',
renderTo: 'dashboard-col-0',
elements: [{
tagName: 'h1',
textContent: 'Your text',
attributes: {
id: 'main-title',
}
}]
}]- The
htmlproperty can be used to define the HTML code as a string.
components: [{
type: 'HTML',
renderTo: 'dashboard-col-0',
html: '<h1 id="main-title">Your text</h1>'
}]Nested elements
If more than one element is required, the children property can be used. The children property is an array of elements that will be nested inside the parent element. Each element can have its own children elements and is configured in the same way as the parent element.
elements: [{
tagName: 'div',
children: [{
tagName: 'h1',
textContent: 'Title',
attributes: {
id: 'main-title',
}
}, {
tagName: 'p',
textContent: 'Description',
attributes: {
id: 'description',
}
}]
}]Styling the HTML component
The most common way to style the HTML component is to use the CSS and utilize the className or id attributes.
#main-title {
color: #4b4b4b;
}
#description {
text-decoration: underline;
}Extending the HTML component
If some of the HTML elements are used frequently or require to be more customizable, it is possible to create a custom component that will simplify the configuration. The custom component can be created by extending the basic HTML component.
More in the Custom Component section.
Components synchronization
The HTML Component is the only component that does not support any of the predefined synchronization types. However, you can define your own sync types as needed. You can read more about it here .
API options
For the full set of available options, see the API .