all files / chart/series/ column-series.js

100% Statements 62/62
93.18% Branches 41/44
100% Functions 15/15
100% Lines 59/59
11 statements, 6 functions, 9 branches Ignored     
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89          567× 567× 567×   1104× 1104× 1104× 7124× 7124×   1104×   7144× 7144× 7144× 6991× 6991×   6991×   6991× 6991× 6991× 6990× 6990×   207×   6990× 6990× 6990× 71×         71×         20× 20× 20×   20× 20× 20×       53×   43938×          
/* istanbul ignore next */ 
var __extends = (this && this.__extends) || (function () {
    var extendStatics = function (d, b) {
        extendStatics = Object.setPrototypeOf ||
            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
            function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
        return extendStatics(d, b);
    };
    return function (d, b) {
        extendStatics(d, b);
        function __() { this.constructor = d; }
        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
    };
})();
define(["require", "exports", "../../common/utils/helper", "@syncfusion/ej2-svg-base", "./column-base"], function (require, exports, helper_1, ej2_svg_base_1, column_base_1) {
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    var ColumnSeries = (function (_super) {
        __extends(ColumnSeries, _super);
        function ColumnSeries() {
            var _this = _super !== null && _super.apply(this, arguments) || this;
            _this.sideBySideInfo = [];
            return _this;
        }
        ColumnSeries.prototype.render = function (series) {
            this.sideBySideInfo[series.index] = this.getSideBySideInfo(series);
            var origin = Math.max(series.yAxis.visibleRange.min, 0);
            for (var _i = 0, _a = series.points; _i < _a.length; _i++) {
                var pointColumn = _a[_i];
                this.renderPoint(series, pointColumn, this.sideBySideInfo[series.index], origin);
            }
            this.renderMarker(series);
        };
        ColumnSeries.prototype.renderPoint = function (series, pointColumn, sideBySideInfo, origin) {
            pointColumn.symbolLocations = [];
            pointColumn.regions = [];
            if (pointColumn.visible && helper_1.withInRange(series.points[pointColumn.index - 1], pointColumn, series.points[pointColumn.index + 1], series)) {
                this.rect = this.getRectangle(pointColumn.xValue + sideBySideInfo.start, pointColumn.yValue, pointColumn.xValue + sideBySideInfo.end, origin, series);
                this.rect.width = series.columnWidthInPixel ? (series.columnWidthInPixel - (series.chart.enableSideBySidePlacement ?
                    series.columnWidthInPixel * series.columnSpacing : 0)) : this.rect.width;
                this.rect.x = series.columnWidthInPixel ? this.rect.x - (((series.columnWidthInPixel / 2) * series.rectCount) -
                    (series.columnWidthInPixel * series.index)) : this.rect.x;
                var color = series.category === 'Indicator' ? pointColumn.color : series.interior;
                var argsData = this.triggerEvent(series, pointColumn, color, { width: series.border.width, color: series.border.color });
                if (!argsData.cancel) {
                    var adjustedYPosition = this.rect.y;
                    if (pointColumn.yValue < origin && pointColumn.yValue >= 0 && series.chart.zoomModule &&
                        series.chart.zoomModule.isAxisZoomed(series.chart.axisCollections)) {
                        adjustedYPosition = helper_1.getPoint(pointColumn.xValue + sideBySideInfo.start, pointColumn.yValue, series.xAxis, series.yAxis, series.chart.requireInvertedAxis).y;
                    }
                    this.updateSymbolLocation(pointColumn, new ej2_svg_base_1.Rect(this.rect.x, adjustedYPosition, this.rect.width, this.rect.height), series);
                    this.drawRectangle(series, pointColumn, this.rect, argsData);
                    if (series.columnFacet === 'Cylinder') {
                        var cylinderSeriesOption = {
                            'isColumn': true,
                            'stacking': false,
                            'isLastSeries': true
                        };
                        this.drawCylinder(this.options, this.element, cylinderSeriesOption, this.rect, series);
                    }
                }
            }
        };
        ColumnSeries.prototype.updateDirection = function (series, point) {
            var origin = Math.max(series.yAxis.visibleRange.min, 0);
            for (var i = 0; i < point.length; i++) {
                this.renderPoint(series, series.points[point[i]], this.sideBySideInfo[series.index], origin);
                Eif (series.marker && series.marker.visible) {
                    series.chart.markerRender.renderMarker(series, series.points[point[i]], series.points[point[i]].symbolLocations[0], null, true);
                }
                Eif (series.marker.dataLabel.visible && series.chart.dataLabelModule) {
                    series.chart.dataLabelModule.commonId = series.chart.element.id + '_Series_' + series.index + '_Point_';
                    series.chart.dataLabelModule.renderDataLabel(series, series.points[point[i]], null, series.marker.dataLabel);
                }
            }
        };
        ColumnSeries.prototype.doAnimation = function (series) {
            this.animate(series);
        };
        ColumnSeries.prototype.getModuleName = function () {
            return 'ColumnSeries';
        };
        ColumnSeries.prototype.destroy = function () {
        };
        return ColumnSeries;
    }(column_base_1.ColumnBase));
    exports.ColumnSeries = ColumnSeries;
});