Skip to content

features tooltip

ν™μœ μ • edited this page Oct 30, 2017 · 13 revisions

Tooltip Feature

  • This section introduces about feature of tooltip.

Tooltip align

Using tooltip.align option, you can set base position.

Example
//...
var options = {
    tooltip: {
        align: 'center top'
    }
};
tui.chart.barChart(container, data, options);

Tooltip positioning

Using tooltip.offsetX, tooltip.offsetY option, you can moving a tooltip to four direction like top, bottom, left and right. Deprecated tooltip.position option.

Example
//...
var options = {
    tooltip: {
        // Recommended
        offsetX: 10,
        offsetY: -10

        // Deprecated
        position: {
            left: 10,
            top: -10
        }
    }
};
tui.chart.barChart(container, data, options);

Using group tooltip

Using tooltip.grouped option, you can use group tooltip.

Example
//...
var options = {
    tooltip: {
        grouped: true
    }
};
tui.chart.lineChart(container, data, options);

Group Tooltip


Setting template of tooltip

Using tooltip.template option, you can change template of tooltip.
This option can be set to function, and must returns HTML string.

Setting template of basic tooltip

The basic tooltip template receives category and item({value: String, legend: String}) information.

Example
//...
var options = {
    tooltip: {
        template: function(category, item, categoryTimestamp) {
            var head = '<div>' + category + </div>',
                body = '<div>' + item.value + ':' + item.legend + '</div>';
            return head + body;
        }
    }
};
tui.chart.lineChart(container, data, options);

Setting template of group tooltip

The group tooltip template receives category and items(Array.<{value: String, legend: String}>) information.

Example
//...
var options = {
    tooltip: {
        grouped: true,
        template: function(category, items, categoryTimestamp) {
            var head = '<div>' + category + '</div>',
                body = tui.util.map(items, function(item) {
                    return '<div>' + item.value + ':' + item.legend + '</div>'
                }),join('');
            return head + body;
        }
    }
};
tui.chart.lineChart(container, data, options);

Customizing a category dateFormat by tooltip.template

If category's type is datetime, tooltip.template function sends timestamp as a 3rd parameter. By using it, category could be formatted different to Axes's date format.

Example
//...
var options = {
    tooltip: {
        template: function(category, item, timestamp) {
            var date = new Date(timestamp);
            var head = '<div>' + date.getYear() + '-' + date.getMonth() + '</div>',
                body = '<div>' + item.value + ':' + item.legend + '</div>';
            return head + body;
        }
    }
};
tui.chart.lineChart(container, data, options);

Dynamically change position of tooltip

Using some user event(.beforeShowTooltip, .afterShowTooltip) and some method(.setTooltipOffset, .resetTooltipOffset), you can dynamically change position of tooltip.

Example
//...
var chart = tui.chart.barChart(data);

chart.on('beforeShowTooltip', function(info) {
    if (info.legendIndex === 0) {
        // Recommended
        chart.setTooltipOffset({
            x: 20,
            y: -10
        });

        // Deprecated
        chart.setTooltipPosition({
            left: 20,
            top: -10
        });
    }
});

chart.on('afterShowTooltip', function(info) {
    // Recommended
    chart.resetTooltipOffset();

    // Deprecated
    chart.resetTooltipPosition();
});
Clone this wiki locally