all files / smithchart/series/ tooltip.js

100% Statements 83/83
86.67% Branches 39/45
100% Functions 10/10
100% Lines 83/83
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 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135                         15× 15× 15× 15× 15× 15× 15×             15× 15× 15× 15×         15×                                       15× 15× 15× 15× 15× 15× 15× 14×     15× 15×   66× 66× 66× 66× 66× 66× 66× 66×       414×          
define(["require", "exports", "../../smithchart/utils/utils", "@syncfusion/ej2-svg-base", "@syncfusion/ej2-base"], function (require, exports, utils_1, ej2_svg_base_1, ej2_base_1) {
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    var TooltipRender = (function () {
        function TooltipRender() {
        }
        TooltipRender.prototype.smithchartMouseMove = function (smithchart, e) {
            var touchArg;
            var pageX;
            var pageY;
            if (e.type === 'touchend' || e.type === 'touchmove') {
                touchArg = e;
                pageX = touchArg.changedTouches[0].clientX;
                pageY = touchArg.changedTouches[0].clientY;
                this.tooltipElement = undefined;
            }
            else {
                pageY = e.clientY;
                pageX = e.clientX;
            }
            this.setMouseXY(smithchart, pageX, pageY);
            for (var i = 0; i < smithchart.series.length; i++) {
                var series = smithchart.series[i];
                var seriesIndex = i;
                var closestPoint = new utils_1.ClosestPoint();
                closestPoint = this.closestPointXY(smithchart, this.mouseX, this.mouseY, series, seriesIndex);
                if (closestPoint.location && series.tooltip.visible && series.visibility === 'visible') {
                    this.createTooltip(smithchart, e, closestPoint.index, seriesIndex, series);
                    break;
                }
                else if (this.tooltipElement) {
                    if (this.tooltipElement.enable && !series.tooltip.template) {
                        this.tooltipElement.enable = false;
                    }
                    this.tooltipElement.fadeOut();
                }
            }
            return this.tooltipElement;
        };
        TooltipRender.prototype.setMouseXY = function (smithchart, pageX, pageY) {
            var svgRectElement = document.getElementById(smithchart.element.id + '_svg');
            Eif (smithchart.element && svgRectElement) {
                var rect = smithchart.element.getBoundingClientRect();
                var svgRect = svgRectElement.getBoundingClientRect();
                this.mouseX = (pageX - rect.left) - Math.max(svgRect.left - rect.left, 0);
                this.mouseY = (pageY - rect.top) - Math.max(svgRect.top - rect.top, 0);
            }
        };
        TooltipRender.prototype.createTooltip = function (smithchart, e, pointIndex, seriesindex, series) {
            var _this = this;
            var currentPoint = series.points[pointIndex];
            var pointX = currentPoint.resistance;
            var pointY = currentPoint.reactance;
            var tooltip = currentPoint.tooltip ? [currentPoint.tooltip] : null;
            var tooltipText = [pointX + ' : ' + (smithchart.theme.indexOf('Tailwind3') > -1 ? pointY : '<b>' + pointY + '</b>')];
            var argsData = {
                cancel: false, name: 'tooltipRender',
                text: tooltip || tooltipText,
                headerText: smithchart.theme.indexOf('Tailwind3') > -1 ? series.name : '<b>' + series.name + '</b>',
                template: series.tooltip.template,
                point: currentPoint
            };
            var smithChartTooltipSuccess = function (argsData) {
                var markerHeight = smithchart.series[seriesindex].marker.height / 2;
                var div = document.getElementById(smithchart.element.id + '_smithchart_tooltip_div');
                if (ej2_base_1.isNullOrUndefined(div)) {
                    div = ej2_base_1.createElement('div', {
                        id: smithchart.element.id + '_smithchart_tooltip_div',
                        styles: 'pointer-events: none; position: absolute;z-index:1;'
                    });
                    document.getElementById(smithchart.element.id + '_Secondary_Element').appendChild(div);
                }
                _this.tooltipElement = new ej2_svg_base_1.Tooltip({
                    enable: true,
                    header: argsData.headerText,
                    content: argsData.text,
                    border: series.tooltip.border,
                    fill: series.tooltip.fill || smithchart.themeStyle.tooltipFill,
                    opacity: series.tooltip.opacity,
                    data: currentPoint,
                    template: argsData.template,
                    location: {
                        x: _this.locationX + smithchart.element.offsetLeft,
                        y: _this.locationY - markerHeight + smithchart.element.offsetTop
                    },
                    shared: false,
                    areaBounds: new utils_1.SmithchartRect(smithchart.bounds.x, smithchart.bounds.y, smithchart.bounds.width, smithchart.bounds.height),
                    palette: [series.fill || smithchart.seriesColors[seriesindex % smithchart.seriesColors.length]],
                    shapes: ['Circle'],
                    availableSize: smithchart.availableSize,
                    theme: smithchart.theme
                });
                _this.tooltipElement.opacity = smithchart.themeStyle.tooltipFillOpacity || _this.tooltipElement.opacity;
                _this.tooltipElement.textStyle.fontFamily = smithchart.themeStyle.fontFamily || 'Roboto, Segoe UI, Noto, Sans-serif';
                _this.tooltipElement.textStyle.size = smithchart.themeStyle.tooltipFontSize || '13px';
                _this.tooltipElement.textStyle.color = smithchart.themeStyle.tooltipBoldLabel || _this.tooltipElement.textStyle.color;
                _this.tooltipElement.appendTo(div);
                var element = document.getElementById(smithchart.element.id + '_smithchart_tooltip_div_Trackball_0');
                if (element) {
                    element.setAttribute('role', 'img');
                }
            };
            smithChartTooltipSuccess.bind(this, smithchart);
            smithchart.trigger('tooltipRender', argsData, smithChartTooltipSuccess);
        };
        TooltipRender.prototype.closestPointXY = function (smithchart, x, y, series, seriesindex) {
            var pointIndex;
            var chartPoint;
            var closePoint;
            for (var j = 0; j < series.points.length; j++) {
                chartPoint = smithchart.seriesrender.getLocation(seriesindex, j);
                this.locationX = chartPoint.x;
                this.locationY = chartPoint.y;
                pointIndex = j;
                var a = x - chartPoint.x;
                var b = y - chartPoint.y;
                var distance = Math.abs(Math.sqrt((a * a) + (b * b)));
                if (distance < series.marker.width) {
                    closePoint = chartPoint;
                    pointIndex = j;
                    break;
                }
            }
            return { location: closePoint, index: pointIndex };
        };
        TooltipRender.prototype.getModuleName = function () {
            return 'TooltipRender';
        };
        TooltipRender.prototype.destroy = function () {
        };
        return TooltipRender;
    }());
    exports.TooltipRender = TooltipRender;
});