12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- /* *
- *
- * (c) 2016-2021 Torstein Honsi, Lars Cabrera
- *
- * License: www.highcharts.com/license
- *
- * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
- *
- * */
- 'use strict';
- import Axis from '../Core/Axis/Axis.js';
- import Chart from '../Core/Chart/Chart.js';
- import U from '../Core/Utilities.js';
- var addEvent = U.addEvent, defined = U.defined, isNumber = U.isNumber, pick = U.pick;
- /* eslint-disable no-invalid-this */
- /**
- * For vertical axes only. Setting the static scale ensures that each tick unit
- * is translated into a fixed pixel height. For example, setting the static
- * scale to 24 results in each Y axis category taking up 24 pixels, and the
- * height of the chart adjusts. Adding or removing items will make the chart
- * resize.
- *
- * @sample gantt/xrange-series/demo/
- * X-range series with static scale
- *
- * @type {number}
- * @default 50
- * @since 6.2.0
- * @product gantt
- * @apioption yAxis.staticScale
- */
- addEvent(Axis, 'afterSetOptions', function () {
- var chartOptions = this.chart.options.chart;
- if (!this.horiz &&
- isNumber(this.options.staticScale) &&
- (!chartOptions.height ||
- (chartOptions.scrollablePlotArea &&
- chartOptions.scrollablePlotArea.minHeight))) {
- this.staticScale = this.options.staticScale;
- }
- });
- Chart.prototype.adjustHeight = function () {
- if (this.redrawTrigger !== 'adjustHeight') {
- (this.axes || []).forEach(function (axis) {
- var chart = axis.chart, animate = !!chart.initiatedScale &&
- chart.options.animation, staticScale = axis.options.staticScale, height, diff;
- if (axis.staticScale && defined(axis.min)) {
- height = pick(axis.brokenAxis && axis.brokenAxis.unitLength, axis.max + axis.tickInterval - axis.min) * staticScale;
- // Minimum height is 1 x staticScale.
- height = Math.max(height, staticScale);
- diff = height - chart.plotHeight;
- if (!chart.scrollablePixelsY && Math.abs(diff) >= 1) {
- chart.plotHeight = height;
- chart.redrawTrigger = 'adjustHeight';
- chart.setSize(void 0, chart.chartHeight + diff, animate);
- }
- // Make sure clip rects have the right height before initial
- // animation.
- axis.series.forEach(function (series) {
- var clipRect = series.sharedClipKey &&
- chart.sharedClips[series.sharedClipKey];
- if (clipRect) {
- clipRect.attr(chart.inverted ? {
- width: chart.plotHeight
- } : {
- height: chart.plotHeight
- });
- }
- });
- }
- });
- this.initiatedScale = true;
- }
- this.redrawTrigger = null;
- };
- addEvent(Chart, 'render', Chart.prototype.adjustHeight);
|