123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- /**
- * @license Highcharts JS v7.0.2 (2019-01-17)
- * StaticScale
- *
- * (c) 2016-2019 Torstein Honsi, Lars A. V. Cabrera
- *
- * License: www.highcharts.com/license
- */
- 'use strict';
- (function (factory) {
- if (typeof module === 'object' && module.exports) {
- factory['default'] = factory;
- module.exports = factory;
- } else if (typeof define === 'function' && define.amd) {
- define(function () {
- return factory;
- });
- } else {
- factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);
- }
- }(function (Highcharts) {
- (function (H) {
- /* *
- * (c) 2016-2019 Torstein Honsi, Lars Cabrera
- *
- * License: www.highcharts.com/license
- */
- var Chart = H.Chart,
- pick = H.pick;
- /**
- * 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
- */
- H.addEvent(H.Axis, 'afterSetOptions', function () {
- if (
- !this.horiz &&
- H.isNumber(this.options.staticScale) &&
- !this.chart.options.chart.height
- ) {
- 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 && H.defined(axis.min)) {
- height = pick(
- axis.unitLength,
- axis.max + axis.tickInterval - axis.min
- ) * staticScale;
- // Minimum height is 1 x staticScale.
- height = Math.max(height, staticScale);
- diff = height - chart.plotHeight;
- if (Math.abs(diff) >= 1) {
- chart.plotHeight = height;
- chart.redrawTrigger = 'adjustHeight';
- chart.setSize(undefined, 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[series.sharedClipKey];
- if (clipRect) {
- clipRect.attr({
- height: chart.plotHeight
- });
- }
- });
- }
- });
- this.initiatedScale = true;
- }
- this.redrawTrigger = null;
- };
- H.addEvent(Chart, 'render', Chart.prototype.adjustHeight);
- }(Highcharts));
- return (function () {
- }());
- }));
|