highcharts
Version:
JavaScript charting framework
132 lines (131 loc) • 4.05 kB
JavaScript
/* *
*
* (c) 2010-2021 Torstein Honsi
*
* License: www.highcharts.com/license
*
* !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
*
* */
;
import H from '../Globals.js';
import O from '../Options.js';
var defaultOptions = O.defaultOptions;
import Point from './Point.js';
import U from '../Utilities.js';
var error = U.error, extendClass = U.extendClass, merge = U.merge;
/* *
*
* Namespace
*
* */
var SeriesRegistry;
(function (SeriesRegistry) {
/* *
*
* Static Properties
*
* */
SeriesRegistry.seriesTypes = {};
/* *
*
* Static Functions
*
* */
/* eslint-disable valid-jsdoc */
/**
* Internal function to initialize an individual series.
* @private
*/
function getSeries(chart, options) {
if (options === void 0) { options = {}; }
var optionsChart = chart.options.chart, type = (options.type ||
optionsChart.type ||
optionsChart.defaultSeriesType ||
''), SeriesClass = SeriesRegistry.seriesTypes[type];
// No such series type
if (!SeriesRegistry) {
error(17, true, chart, { missingModuleFor: type });
}
var series = new SeriesClass();
if (typeof series.init === 'function') {
series.init(chart, options);
}
return series;
}
SeriesRegistry.getSeries = getSeries;
/**
* Registers class pattern of a series.
*
* @private
*/
function registerSeriesType(seriesType, seriesClass) {
var defaultPlotOptions = defaultOptions.plotOptions || {}, seriesOptions = seriesClass.defaultOptions;
if (!seriesClass.prototype.pointClass) {
seriesClass.prototype.pointClass = Point;
}
seriesClass.prototype.type = seriesType;
if (seriesOptions) {
defaultPlotOptions[seriesType] = seriesOptions;
}
SeriesRegistry.seriesTypes[seriesType] = seriesClass;
}
SeriesRegistry.registerSeriesType = registerSeriesType;
/**
* Old factory to create new series prototypes.
*
* @deprecated
* @function Highcharts.seriesType
*
* @param {string} type
* The series type name.
*
* @param {string} parent
* The parent series type name. Use `line` to inherit from the basic
* {@link Series} object.
*
* @param {Highcharts.SeriesOptionsType|Highcharts.Dictionary<*>} options
* The additional default options that are merged with the parent's options.
*
* @param {Highcharts.Dictionary<*>} [props]
* The properties (functions and primitives) to set on the new prototype.
*
* @param {Highcharts.Dictionary<*>} [pointProps]
* Members for a series-specific extension of the {@link Point} prototype if
* needed.
*
* @return {Highcharts.Series}
* The newly created prototype as extended from {@link Series} or its
* derivatives.
*/
function seriesType(type, parent, options, seriesProto, pointProto) {
var defaultPlotOptions = defaultOptions.plotOptions || {};
parent = parent || '';
// Merge the options
defaultPlotOptions[type] = merge(defaultPlotOptions[parent], options);
// Create the class
registerSeriesType(type, extendClass(SeriesRegistry.seriesTypes[parent] || function () { }, seriesProto));
SeriesRegistry.seriesTypes[type].prototype.type = type;
// Create the point class if needed
if (pointProto) {
SeriesRegistry.seriesTypes[type].prototype.pointClass =
extendClass(Point, pointProto);
}
return SeriesRegistry.seriesTypes[type];
}
SeriesRegistry.seriesType = seriesType;
/* eslint-enable valid-jsdoc */
})(SeriesRegistry || (SeriesRegistry = {}));
/* *
*
* Compatibility
*
* */
H.seriesType = SeriesRegistry.seriesType;
H.seriesTypes = SeriesRegistry.seriesTypes;
/* *
*
* Export
*
* */
export default SeriesRegistry;