UNPKG

highcharts

Version:
189 lines (188 loc) 5.93 kB
/* * * * (c) 2010-2024 Torstein Honsi * * License: www.highcharts.com/license * * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!! * * */ 'use strict'; import U from '../Utilities.js'; const { addEvent, normalizeTickInterval, pick } = U; /* * * * Class * * */ /** * @private */ var LogarithmicAxis; (function (LogarithmicAxis) { /* * * * Declarations * * */ /* * * * Functions * * */ /** * Provides logarithmic support for axes. * @private */ function compose(AxisClass) { if (!AxisClass.keepProps.includes('logarithmic')) { AxisClass.keepProps.push('logarithmic'); addEvent(AxisClass, 'afterSetType', onAfterSetType); addEvent(AxisClass, 'afterInit', onAfterInit); } return AxisClass; } LogarithmicAxis.compose = compose; /** * @private */ function onAfterSetType() { if (this.type !== 'logarithmic') { this.logarithmic = void 0; } else { this.logarithmic ?? (this.logarithmic = new Additions(this)); } } /** * @private */ function onAfterInit() { const axis = this; const log = axis.logarithmic; // Extend logarithmic axis if (log) { axis.lin2val = function (num) { return log.lin2log(num); }; axis.val2lin = function (num) { return log.log2lin(num); }; } } /* * * * Class * * */ /** * Provides logarithmic support for axes. * @private * @class */ class Additions { /* * * * Constructors * * */ constructor(axis) { this.axis = axis; } /* * * * Functions * * */ /** * Set the tick positions of a logarithmic axis. */ getLogTickPositions(interval, min, max, minor) { const log = this; const axis = log.axis; const axisLength = axis.len; const options = axis.options; // Since we use this method for both major and minor ticks, // use a local variable and return the result let positions = []; // Reset if (!minor) { log.minorAutoInterval = void 0; } // First case: All ticks fall on whole logarithms: 1, 10, 100 etc. if (interval >= 0.5) { interval = Math.round(interval); positions = axis.getLinearTickPositions(interval, min, max); // Second case: We need intermediary ticks. For example // 1, 2, 4, 6, 8, 10, 20, 40 etc. } else if (interval >= 0.08) { const roundedMin = Math.floor(min); let intermediate, i, j, len, pos, lastPos, break2; if (interval > 0.3) { intermediate = [1, 2, 4]; // 0.2 equals five minor ticks per 1, 10, 100 etc } else if (interval > 0.15) { intermediate = [1, 2, 4, 6, 8]; } else { // 0.1 equals ten minor ticks per 1, 10, 100 etc intermediate = [1, 2, 3, 4, 5, 6, 7, 8, 9]; } for (i = roundedMin; i < max + 1 && !break2; i++) { len = intermediate.length; for (j = 0; j < len && !break2; j++) { pos = log.log2lin(log.lin2log(i) * intermediate[j]); // #1670, lastPos is #3113 if (pos > min && (!minor || lastPos <= max) && typeof lastPos !== 'undefined') { positions.push(lastPos); } if (lastPos > max) { break2 = true; } lastPos = pos; } } // Third case: We are so deep in between whole logarithmic values, // that we might as well handle the tick positions like a linear // axis. For example 1.01, 1.02, 1.03, 1.04. } else { const realMin = log.lin2log(min), realMax = log.lin2log(max), tickIntervalOption = minor ? axis.getMinorTickInterval() : options.tickInterval, filteredTickIntervalOption = tickIntervalOption === 'auto' ? null : tickIntervalOption, tickPixelIntervalOption = options.tickPixelInterval / (minor ? 5 : 1), totalPixelLength = minor ? axisLength / axis.tickPositions.length : axisLength; interval = pick(filteredTickIntervalOption, log.minorAutoInterval, (realMax - realMin) * tickPixelIntervalOption / (totalPixelLength || 1)); interval = normalizeTickInterval(interval); positions = axis.getLinearTickPositions(interval, realMin, realMax).map(log.log2lin); if (!minor) { log.minorAutoInterval = interval / 5; } } // Set the axis-level tickInterval variable if (!minor) { axis.tickInterval = interval; } return positions; } lin2log(num) { return Math.pow(10, num); } log2lin(num) { return Math.log(num) / Math.LN10; } } LogarithmicAxis.Additions = Additions; })(LogarithmicAxis || (LogarithmicAxis = {})); /* * * * Default Export * * */ export default LogarithmicAxis;