all files / maps/user-interaction/ highlight.js

99.24% Statements 131/132
92.06% Branches 116/126
100% Functions 14/14
99.24% Lines 131/132
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 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225   55× 55×   55×     55× 55×   54× 13×   41× 41×           47× 47× 47× 47×             26× 26× 26× 26× 26× 26× 19× 19×     19× 19× 19×                   26× 24×             21×       17×     11×           25×   16×   25×   25× 24×     25× 25× 25× 25×   25× 25× 25×   25×             25×                     25× 19×   25×                     25× 25× 25× 25× 25× 25× 25× 25×     25×     23×     23×     22×   23×     3452×   54× 54× 54×        
define(["require", "exports", "../index", "@syncfusion/ej2-base", "../utils/helper"], function (require, exports, index_1, ej2_base_1, helper_1) {
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    var Highlight = (function () {
        function Highlight(maps) {
            this.maps = maps;
            this.addEventListener();
        }
        Highlight.prototype.addEventListener = function () {
            Iif (this.maps.isDestroyed) {
                return;
            }
            this.maps.on(ej2_base_1.Browser.touchMoveEvent, this.mouseMove, this);
            this.maps.on(ej2_base_1.Browser.touchStartEvent, this.mouseMove, this);
        };
        Highlight.prototype.removeEventListener = function () {
            if (this.maps.isDestroyed) {
                return;
            }
            this.maps.off(ej2_base_1.Browser.touchMoveEvent, this.mouseMove);
            this.maps.off(ej2_base_1.Browser.touchStartEvent, this.mouseMove);
        };
        Highlight.prototype.addHighlight = function (layerIndex, name, enable) {
            var targetEle = helper_1.getTargetElement(layerIndex, name, enable, this.maps);
            if (enable) {
                this.mapHighlight(targetEle, null, null);
            }
            else {
                helper_1.removeClass(targetEle);
            }
        };
        Highlight.prototype.mouseMove = function (e) {
            var targetEle = e.target;
            var layerIndex;
            var isTouch = e.pointerType === 'touch' || e.pointerType === '2' || (e.type.indexOf('touch') > -1);
            if ((targetEle.id.indexOf('LayerIndex') !== -1 || targetEle.id.indexOf('NavigationIndex') > -1) &&
                targetEle.getAttribute('class') !== 'ShapeselectionMapStyle' && !isTouch &&
                targetEle.getAttribute('class') !== 'MarkerselectionMapStyle' &&
                targetEle.getAttribute('class') !== 'BubbleselectionMapStyle' &&
                targetEle.getAttribute('class') !== 'navigationlineselectionMapStyle' &&
                targetEle.getAttribute('class') !== 'PolygonselectionMapStyle' &&
                targetEle.getAttribute('class') !== 'LineselectionMapStyle') {
                layerIndex = parseInt(targetEle.id.split('_LayerIndex_')[1].split('_')[0], 10);
                var shapeData = void 0;
                var data = void 0;
                var shapeIn = void 0;
                var dataIndex = void 0;
                if (targetEle.id.indexOf('shapeIndex') > -1) {
                    shapeIn = parseInt(targetEle.id.split('_shapeIndex_')[1].split('_')[0], 10);
                    shapeData = this.maps.layers[layerIndex].shapeData['features'] &&
                        !ej2_base_1.isNullOrUndefined(this.maps.layersCollection[layerIndex].layerData[shapeIn]) ?
                        this.maps.layersCollection[layerIndex].layerData[shapeIn]['property'] : null;
                    dataIndex = parseInt(targetEle.id.split('_dataIndex_')[1].split('_')[0], 10);
                    data = ej2_base_1.isNullOrUndefined(dataIndex) ? null : this.maps.layers[layerIndex].dataSource[dataIndex];
                    this.highlightSettings = this.maps.layers[layerIndex].highlightSettings;
                }
                else if (targetEle.id.indexOf('BubbleIndex') > -1) {
                    var bubble = parseInt(targetEle.id.split('_BubbleIndex_')[1].split('_')[0], 10);
                    dataIndex = parseInt(targetEle.id.split('_dataIndex_')[1].split('_')[0], 10);
                    data = this.maps.layers[layerIndex].bubbleSettings[bubble].dataSource[dataIndex];
                    this.highlightSettings = this.maps.layers[layerIndex].bubbleSettings[bubble].highlightSettings;
                }
                else if (targetEle.id.indexOf('MarkerIndex') > -1) {
                    var marker = parseInt(targetEle.id.split('_MarkerIndex_')[1].split('_')[0], 10);
                    dataIndex = parseInt(targetEle.id.split('_dataIndex_')[1].split('_')[0], 10);
                    data = this.maps.layers[layerIndex].markerSettings[marker].dataSource[dataIndex];
                    this.highlightSettings = this.maps.layers[layerIndex].markerSettings[marker].highlightSettings;
                }
                else if (targetEle.id.indexOf('_PolygonIndex_') > -1) {
                    dataIndex = parseInt(targetEle.id.split('_PolygonIndex_')[1].split('_')[0], 10);
                    data = this.maps.layers[layerIndex].polygonSettings.polygons[dataIndex].points;
                    this.highlightSettings = this.maps.layers[layerIndex].polygonSettings.highlightSettings;
                }
                else {
                    var index = parseInt(targetEle.id.split('_NavigationIndex_')[1].split('_')[0], 10);
                    layerIndex = parseInt(targetEle.id.split('_LayerIndex_')[1].split('_')[0], 10);
                    shapeData = null;
                    data = {
                        latitude: this.maps.layers[layerIndex].navigationLineSettings[index].latitude,
                        longitude: this.maps.layers[layerIndex].navigationLineSettings[index].longitude
                    };
                    this.highlightSettings = this.maps.layers[layerIndex].navigationLineSettings[index].highlightSettings;
                }
                if (this.highlightSettings.enable) {
                    this.handleHighlight(targetEle, layerIndex, data, shapeData);
                }
                else {
                    var element = document.getElementsByClassName('highlightMapStyle')[0];
                    if (!ej2_base_1.isNullOrUndefined(element)) {
                        helper_1.removeClass(element);
                        Eif (element.id.indexOf('NavigationIndex') > -1) {
                            var index = parseInt(element.id.split('_NavigationIndex_')[1].split('_')[0], 10);
                            var layerIndex_1 = parseInt(element.parentElement.id.split('_LayerIndex_')[1].split('_')[0], 10);
                            element.setAttribute('stroke-width', this.maps.layers[layerIndex_1].navigationLineSettings[index].width.toString());
                            element.setAttribute('stroke', this.maps.layers[layerIndex_1].navigationLineSettings[index].color);
                        }
                    }
                }
            }
            else if (helper_1.getElementsByClassName('highlightMapStyle').length > 0) {
                targetEle = helper_1.getElementsByClassName('highlightMapStyle')[0];
                if (targetEle.id.indexOf('NavigationIndex') > -1) {
                    var index = parseInt(targetEle.id.split('_NavigationIndex_')[1].split('_')[0], 10);
                    layerIndex = parseInt(targetEle.parentElement.id.split('_LayerIndex_')[1].split('_')[0], 10);
                    targetEle.setAttribute('stroke-width', this.maps.layers[layerIndex].navigationLineSettings[index].width.toString());
                    targetEle.setAttribute('stroke', this.maps.layers[layerIndex].navigationLineSettings[index].color);
                }
                helper_1.removeClass(targetEle);
                if (this.maps.legendSettings.visible && this.maps.legendModule) {
                    this.maps.legendModule.removeShapeHighlightCollection();
                }
            }
            else if ((targetEle.id.indexOf(this.maps.element.id + '_Legend_Shape_Index') !== -1 ||
                targetEle.id.indexOf(this.maps.element.id + '_Legend_Index') !== -1) && this.maps.legendModule &&
                this.maps.legendSettings.visible && targetEle.id.indexOf('_Text') === -1) {
                this.maps.legendModule.legendHighLightAndSelection(targetEle, 'highlight');
            }
            else {
                if (this.maps.legendSettings.visible && this.maps.legendModule) {
                    this.maps.legendModule.removeLegendHighlightCollection();
                }
            }
        };
        Highlight.prototype.handleHighlight = function (targetElement, layerIndex, data, shapeData) {
            if (this.maps.legendSettings.visible && targetElement.id.indexOf('_MarkerIndex_') === -1 && this.maps.legendModule
                && this.maps.legendSettings.type === 'Layers') {
                this.maps.legendModule.shapeHighLightAndSelection(targetElement, data, this.highlightSettings, 'highlight', layerIndex);
            }
            var selectHighLight = targetElement.id.indexOf('shapeIndex') > -1 && (this.maps.legendSettings.visible && this.maps.legendModule) ?
                this.maps.legendModule.shapeToggled : true;
            if (selectHighLight) {
                this.mapHighlight(targetElement, shapeData, data);
            }
        };
        Highlight.prototype.mapHighlight = function (targetEle, shapeData, data) {
            var _this = this;
            var layerIndex = parseInt(targetEle.id.split('_LayerIndex_')[1].split('_')[0], 10);
            var isMarkerSelect = false;
            if (targetEle.id.indexOf('MarkerIndex') > -1) {
                var marker = parseInt(targetEle.id.split('_MarkerIndex_')[1].split('_')[0], 10);
                isMarkerSelect = this.maps.layers[layerIndex].markerSettings[marker].highlightSettings.enable;
            }
            var borderColor = (targetEle.parentElement.id.indexOf('LineString') === -1) ? this.highlightSettings.border.color : (this.highlightSettings.fill || this.highlightSettings.border.color);
            var borderWidth = (targetEle.parentElement.id.indexOf('LineString') === -1) ? (this.highlightSettings.border.width / (isMarkerSelect ? 1 : this.maps.scale)) : (this.highlightSettings.border.width / this.maps.scale);
            var borderOpacity = ej2_base_1.isNullOrUndefined(this.highlightSettings.border.opacity) ? this.highlightSettings.opacity :
                this.highlightSettings.border.opacity;
            var eventArgs = {
                opacity: this.highlightSettings.opacity,
                fill: (targetEle.parentElement.id.indexOf('LineString') === -1) ? (targetEle.id.indexOf('NavigationIndex') === -1 ? !ej2_base_1.isNullOrUndefined(this.highlightSettings.fill)
                    ? this.highlightSettings.fill : targetEle.getAttribute('fill') : 'none') : 'transparent',
                border: { color: borderColor, width: borderWidth, opacity: borderOpacity },
                cancel: false
            };
            var shapeEventArgs = {
                opacity: eventArgs.opacity,
                fill: eventArgs.fill,
                border: { color: borderColor, width: borderWidth, opacity: borderOpacity },
                name: index_1.shapeHighlight,
                target: targetEle.id,
                cancel: false,
                shapeData: shapeData,
                data: data,
                maps: this.maps
            };
            if (targetEle.id.indexOf('shapeIndex') > -1) {
                this.maps.trigger(index_1.shapeHighlight, shapeEventArgs, function () { });
            }
            var itemEventArgs = {
                opacity: eventArgs.opacity,
                fill: eventArgs.fill,
                border: { color: borderColor, width: borderWidth, opacity: borderOpacity },
                name: index_1.itemHighlight,
                target: targetEle.id,
                cancel: false,
                shapeData: shapeData,
                data: data,
                maps: this.maps
            };
            this.maps.trigger(index_1.itemHighlight, itemEventArgs, function () {
                itemEventArgs.cancel = eventArgs.cancel !== itemEventArgs.cancel ? itemEventArgs.cancel : targetEle.id.indexOf('shapeIndex') > -1 ? shapeEventArgs.cancel : eventArgs.cancel;
                itemEventArgs.fill = eventArgs.fill !== itemEventArgs.fill ? itemEventArgs.fill : targetEle.id.indexOf('shapeIndex') > -1 ? shapeEventArgs.fill : eventArgs.fill;
                itemEventArgs.opacity = eventArgs.opacity !== itemEventArgs.opacity ? itemEventArgs.opacity : targetEle.id.indexOf('shapeIndex') > -1 ? shapeEventArgs.opacity : eventArgs.opacity;
                itemEventArgs.border.color = eventArgs.border.color !== itemEventArgs.border.color ? itemEventArgs.border.color : targetEle.id.indexOf('shapeIndex') > -1 ? shapeEventArgs.border.color : eventArgs.border.color;
                itemEventArgs.border.width = eventArgs.border.width !== itemEventArgs.border.width ? itemEventArgs.border.width : targetEle.id.indexOf('shapeIndex') > -1 ? shapeEventArgs.border.width : eventArgs.border.width;
                itemEventArgs.border.opacity = eventArgs.border.opacity !== itemEventArgs.border.opacity ? itemEventArgs.border.opacity : targetEle.id.indexOf('shapeIndex') > -1 ? shapeEventArgs.border.opacity : eventArgs.border.opacity;
                _this.highlightMap(targetEle, itemEventArgs);
            });
        };
        Highlight.prototype.highlightMap = function (targetEle, eventArgs) {
            if (targetEle.getAttribute('class') === 'highlightMapStyle' || eventArgs.cancel) {
                return;
            }
            else {
                if (helper_1.getElementsByClassName('highlightMapStyle').length > 0) {
                    var elem = helper_1.getElementsByClassName('highlightMapStyle')[0];
                    helper_1.removeClass(elem);
                    if (elem.id.indexOf('NavigationIndex') > -1) {
                        var index = parseInt(elem.id.split('_NavigationIndex_')[1].split('_')[0], 10);
                        var layerIndex = parseInt(elem.parentElement.id.split('_LayerIndex_')[1].split('_')[0], 10);
                        elem.setAttribute('stroke-width', this.maps.layers[layerIndex].navigationLineSettings[index].width.toString());
                        elem.setAttribute('stroke', this.maps.layers[layerIndex].navigationLineSettings[index].color);
                    }
                }
                if (!helper_1.getElement('highlightMap')) {
                    document.body.appendChild(helper_1.createStyle('highlightMap', 'highlightMapStyle', eventArgs));
                }
                else {
                    helper_1.customizeStyle('highlightMap', 'highlightMapStyle', eventArgs);
                }
                targetEle.setAttribute('class', 'highlightMapStyle');
            }
        };
        Highlight.prototype.getModuleName = function () {
            return 'Highlight';
        };
        Highlight.prototype.destroy = function () {
            this.highlightSettings = null;
            this.removeEventListener();
            this.maps = null;
        };
        return Highlight;
    }());
    exports.Highlight = Highlight;
});