/* * * * (c) 2010-2021 Torstein Honsi * * License: www.highcharts.com/license * * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!! * * */ 'use strict'; import H from '../Core/Globals.js'; import Chart from '../Core/Chart/Chart.js'; import U from '../Core/Utilities.js'; var addEvent = U.addEvent, isNumber = U.isNumber, setOptions = U.setOptions; setOptions({ /** * @optionparent chart */ chart: { /** * Whether to display errors on the chart. When `false`, the errors will * be shown only in the console. * * @sample highcharts/chart/display-errors/ * Show errors on chart * * @since 7.0.0 * @requires modules/debugger */ displayErrors: true } }); /* eslint-disable no-invalid-this */ addEvent(Chart, 'displayError', function (e) { var chart = this, code = e.code, msg, options = chart.options.chart, renderer = chart.renderer, chartWidth, chartHeight; if (chart.errorElements) { (chart.errorElements).forEach(function (el) { if (el) { el.destroy(); } }); } if (options && options.displayErrors && renderer) { chart.errorElements = []; msg = isNumber(code) ? ('Highcharts error #' + code + ': ' + H.errorMessages[code].text) : code; chartWidth = chart.chartWidth; chartHeight = chart.chartHeight; // Format msg so SVGRenderer can handle it msg = msg .replace(/
/g, '')
.replace(/<\/p>/g, '
');
// Render red chart frame.
chart.errorElements[0] = renderer.rect(2, 2, chartWidth - 4, chartHeight - 4).attr({
'stroke-width': 4,
stroke: '#ff0000',
zIndex: 3
}).add();
// Render error message
chart.errorElements[1] = renderer.label(msg, 0, 0, 'rect', void 0, void 0, void 0, void 0, 'debugger').css({
color: '#ffffff',
width: (chartWidth - 16) + 'px',
padding: 0
}).attr({
fill: 'rgba(255, 0, 0, 0.9)',
width: chartWidth,
padding: 8,
zIndex: 10
}).add();
chart.errorElements[1].attr({
y: chartHeight - this.errorElements[1].getBBox().height
});
}
});
addEvent(Chart, 'beforeRedraw', function () {
var errorElements = this.errorElements;
if (errorElements && errorElements.length) {
errorElements.forEach(function (el) {
el.destroy();
});
}
this.errorElements = null;
});