all files / common/user-interaction/ selection.js

98.94% Statements 280/283
94.42% Branches 254/269
100% Functions 13/13
98.94% Lines 279/282
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 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526   1106× 1106×   1012× 1012× 1012× 1012× 1012× 1012× 1012× 1012× 991×   991× 991× 991× 1951× 1951×   1951×   757× 757×   117× 1068× 1068× 1068× 1068×   1068×       1068× 1068×     640× 640× 640×     640×     1951×   1951× 135×   1951× 1951×   991× 991× 42×   991× 991× 991× 991×       1942× 1942× 1942× 1942×     1942× 1942× 1942× 1942× 1942× 1942× 1942× 1942× 1942× 1942× 1942× 1942× 1942×   86× 86× 86×       86×               86×   79× 79× 79×       79×     79×   53× 53×       53× 53× 53×   66× 66×       66×           66×   66× 66×       66×           66×   66× 66×       66×           66×   66× 66×       66×           66×   66× 66×       66×       66×       66×       66×       66×       66×       66×       66×   97× 97×       97×             97×   66× 66×       66×             66×   113× 113×       113×               113×   65× 65×       65× 65× 65× 65× 65×   75× 75×       75×       75×   65× 65×       65×       65×   65× 65× 65× 65× 65×   82× 82× 82×       82×   347× 347× 347×       347×       347×   48× 48× 48×       48×       48×   48× 48×       48× 48× 48×       48×   1942× 1942× 1942× 1942× 1942×   1942× 1942× 4043× 4043×     523×   1245× 1245× 535×   710× 710× 710× 1184× 1184× 707×     710× 573× 573×   14× 14× 14×       559× 554× 554×       710×   37506× 37506× 37506× 37506× 26417× 26417× 26417× 1675× 119×   1556× 78×   1478× 937×   541× 541×     26417× 609× 2011× 15902× 15902× 15902× 15902× 2103× 104×   2103× 925× 925×   2103×             25808× 148245× 148245× 148245× 148245× 29648× 1866×   29648× 24170× 24170×   29648× 96×             54525× 54525× 10835× 10835× 10835× 359× 24×   335× 30×   305× 153×   152× 152×     10835× 250× 1014× 3548× 3548× 3548× 3548× 996× 12×   996× 306×   996×               10585× 73875× 73875× 73875× 73875× 18363× 624×   18363× 12926×   18363× 64×             1614× 1614× 3076× 2742×     1614×        
define(["require", "exports", "@syncfusion/ej2-base"], function (require, exports, ej2_base_1) {
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    var BaseSelection = (function () {
        function BaseSelection(control) {
            this.selectionStyle = [];
            this.control = control;
        }
        BaseSelection.prototype.seriesStyles = function () {
            var seriesclass;
            var style = document.getElementById(this.styleId);
            var pattern = '{}';
            var fill;
            var opacity;
            var selectionPattern = this.control.selectionPattern;
            var highlightPattern = this.control.highlightPattern;
            if ((this.styleId.indexOf('highlight') > 0 && this.control.highlightColor !== '') || ej2_base_1.isNullOrUndefined(style) || selectionPattern !== 'None' || highlightPattern !== 'None') {
                if (document.getElementById(this.styleId)) {
                    document.getElementById(this.styleId).remove();
                }
                style = this.control.createElement('div');
                style.setAttribute('id', this.styleId);
                for (var _i = 0, _a = this.control.visibleSeries; _i < _a.length; _i++) {
                    var series = _a[_i];
                    var visibleSeries = this.control.visibleSeries[series.index] ||
                        this.control.visibleSeries[series.index];
                    if ((this.styleId.indexOf('highlight') > 0 && this.control.highlightColor !== '') || (!ej2_base_1.isNullOrUndefined(selectionPattern) || !ej2_base_1.isNullOrUndefined(highlightPattern)) &&
                        (selectionPattern !== 'None' || highlightPattern !== 'None')) {
                        var patternName = this.styleId.indexOf('highlight') > 0 ? highlightPattern : selectionPattern;
                        if (((visibleSeries.type === 'Pie' || visibleSeries.type === 'Funnel' ||
                            visibleSeries.type === 'Pyramid') || this.control.getModuleName() === 'circularchart3d') && this.control.highlightColor !== 'transparent') {
                            for (var i = 0; i < visibleSeries.points.length; i++) {
                                opacity = visibleSeries.opacity;
                                fill = this.pattern(this.control, (this.styleId.indexOf('highlight') > 0 && this.control.highlightColor !== '') ? this.control.highlightColor : (visibleSeries.points[i]).color, series.points[i].index, patternName, opacity);
                                pattern = '{ fill:' + fill + '}';
                                seriesclass = series.selectionStyle || this.styleId + '_series_' + series.index + '_point_' + series.points[i].index + ',' + '.' +
                                    this.styleId + '_series_' + series.index + '_point_' + series.points[i].index + '> *';
                                Iif (this.control.highlightMode === 'None' && this.control.legendSettings.enableHighlight && !series.isRectSeries) {
                                    style.innerText += '.' + this.styleId + '_series_' + series.index + '> *' + ' { stroke-width:' + (3) + ';} ';
                                    this.selectionStyle.push([this.styleId + '_series_' + series.index, 'stroke-width', '3']);
                                }
                                pattern = (pattern.indexOf('None') > -1) ? '{fill:' + ((this.styleId.indexOf('highlight') > 0 && this.control.highlightColor !== '') ? this.control.highlightColor : (visibleSeries.points[i]).color) + '!important}' : pattern;
                                this.selectionStyle.push([this.styleId + '_series_' + series.index + '_point_' + series.points[i].index, 'fill', fill ? ((fill.indexOf('None') > -1) ? (this.styleId.indexOf('highlight') > -1 ? this.control.highlightColor : '') : fill) : '']);
                            }
                        }
                        else Eif (visibleSeries.type && this.control.highlightColor !== 'transparent') {
                            opacity = visibleSeries.opacity;
                            fill = this.pattern(this.control, (this.styleId.indexOf('highlight') > 0 && this.control.highlightColor !== '') ? this.control.highlightColor :
                                (visibleSeries.pointColorMapping !== '' || (this.control.rangeColorSettings && this.control.rangeColorSettings.length > 1)) ? (visibleSeries.points[0]).color
                                    : visibleSeries.interior, series.index, patternName, opacity);
                            pattern = '{ fill:' + fill + '}';
                        }
                    }
                    seriesclass = series.selectionStyle || this.styleId + '_series_' + series.index + ',' + '.' +
                        this.styleId + '_series_' + series.index + '> *';
                    if (this.control.highlightMode === 'None' && this.control.legendSettings.enableHighlight && !series.isRectSeries) {
                        this.selectionStyle.push([this.styleId + '_series_' + series.index, 'stroke-width', (parseFloat((series.width ? series.width.toString() : '0')) + 1).toString()]);
                    }
                    pattern = (pattern.indexOf('None') > -1) ? '{}' : pattern;
                    this.selectionStyle.push([this.styleId + '_series_' + series.index, 'fill', fill ? ((fill.indexOf('None') > -1) ? (this.styleId.indexOf('highlight') > -1 ? this.control.highlightColor : '') : fill) : '']);
                }
                var unSelectOpacity = (this.control).highlightColor !== 'transparent' ? (this.control.getModuleName() === 'circularchart3d' ? 0.2 : 0.3) : opacity;
                if (ej2_base_1.isNullOrUndefined(this.control.selectionModule) && this.control.selectionMode === 'None' && this.control.highlightColor !== '') {
                    unSelectOpacity = 1;
                }
                this.selectionStyle.push([this.unselected, 'opacity', unSelectOpacity.toString()]);
                var secondaryElement = document.getElementById(this.control.element.id + '_Secondary_Element');
                Eif (secondaryElement) {
                    secondaryElement.appendChild(style);
                }
            }
        };
        BaseSelection.prototype.pattern = function (chart, color, index, patternName, opacity) {
            var backgroundColor = '#ffffff';
            var svg = chart.svgObject;
            var pathOptions = [];
            var patternGroup = {
                'id': chart.element.id + '_' + patternName + '_Selection' + '_' + index, 'patternUnits': 'userSpaceOnUse'
            };
            var heightStr = 'height';
            var widthStr = 'width';
            var width = 10;
            var height = 12;
            var patternNum = 6;
            var turquoiseNum = 17;
            var turstrokewidth = 1;
            var starNum = 21;
            var circleNum = 9;
            var tileNum = 18;
            var strokeWidth = 1;
            var bubNum = 20;
            switch (patternName) {
                case 'Dots':
                    patternGroup[heightStr] = patternGroup[widthStr] = patternNum;
                    patternGroup[widthStr] = patternNum;
                    pathOptions[0] = {
                        'x': 0, 'y': 0, 'width': 7, 'height': 7, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity, 'name': 'rect'
                    };
                    pathOptions[1] = {
                        'cx': 3,
                        'cy': 3,
                        'r': 2,
                        'stroke-width': 1,
                        'fill': color,
                        'name': 'circle'
                    };
                    break;
                case 'Pacman':
                    patternGroup[heightStr] = '18.384';
                    patternGroup[widthStr] = '17.917';
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': 17.917, 'height': 18.384,
                        'transform': 'translate(0,0)', 'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path', 'd': 'M9.081,9.194l5.806-3.08c-0.812-1.496-2.403-3.052-4.291-3.052H8.835C6.138,3.063,3,6.151,3,8.723v1.679   c0,2.572,3.138,5.661,5.835,5.661h1.761c2.085,0,3.835-1.76,4.535-3.514L9.081,9.194z', 'stroke-width': 1, 'stroke': color, 'fill': color
                    };
                    break;
                case 'Chessboard':
                    patternGroup[heightStr] = patternGroup[widthStr] = width;
                    pathOptions[0] = {
                        'x': 0, 'y': 0, 'width': width, 'height': width, 'fill': backgroundColor, 'opacity': opacity,
                        'name': 'rect'
                    };
                    pathOptions[1] = { 'x': 0, 'y': 0, 'width': 5, 'height': 5, 'fill': color, 'opacity': opacity, 'name': 'rect' };
                    pathOptions[2] = { 'x': 5, 'y': 5, 'width': 5, 'height': 5, 'fill': color, 'opacity': opacity, 'name': 'rect' };
                    break;
                case 'Crosshatch':
                    patternGroup[heightStr] = patternGroup[widthStr] = '8';
                    pathOptions[0] = {
                        'x': 0, 'y': 0, 'width': 8, 'height': 8, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity, 'name': 'rect'
                    };
                    pathOptions[1] = {
                        'd': 'M0 0L8 8ZM8 0L0 8Z',
                        'stroke-width': 1,
                        'stroke': color,
                        'name': 'path'
                    };
                    break;
                case 'DiagonalForward':
                    patternGroup[heightStr] = patternGroup[widthStr] = patternNum;
                    pathOptions[0] = {
                        'x': 0, 'y': 0, 'width': patternNum, 'height': patternNum, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity, 'name': 'rect'
                    };
                    pathOptions[1] = {
                        'd': 'M 3 -3 L 9 3 M 6 6 L 0 0 M 3 9 L -3 3',
                        'stroke-width': 2,
                        'stroke': color,
                        'name': 'path'
                    };
                    break;
                case 'DiagonalBackward':
                    patternGroup[heightStr] = patternGroup[widthStr] = patternNum;
                    pathOptions[0] = {
                        'x': 0, 'y': 0, 'width': patternNum, 'height': patternNum, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity, 'name': 'rect'
                    };
                    pathOptions[1] = {
                        'd': 'M 3 -3 L -3 3 M 0 6 L 6 0 M 9 3 L 3 9',
                        'stroke-width': 2,
                        'stroke': color,
                        'name': 'path'
                    };
                    break;
                case 'Grid':
                    patternGroup[heightStr] = patternGroup[widthStr] = patternNum;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': patternNum, 'height': patternNum, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path',
                        'd': 'M1 3.5L11 3.5 M0 3.5L11 3.5 M0 7.5L11 7.5 M0 11.5L11 11.5 M5.5 0L5.5 12 M11.5 0L11.5 12Z',
                        'stroke-width': 1,
                        'stroke': color
                    };
                    break;
                case 'Turquoise':
                    patternGroup[heightStr] = patternGroup[widthStr] = turquoiseNum;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': turquoiseNum, 'height': turquoiseNum, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path', 'd': 'M0.5739999999999998,2.643a2.123,2.111 0 1,0 4.246,0a2.123,2.111 0 1,0 -4.246,0',
                        'stroke-width': turstrokewidth, 'stroke-miterlimit': width, 'stroke': color, 'fill': color
                    };
                    pathOptions[2] = {
                        'name': 'path', 'd': 'M11.805,2.643a2.123,2.111 0 1,0 4.246,0a2.123,2.111 0 1,0 -4.246,0',
                        'stroke-width': turstrokewidth, 'stroke-miterlimit': width, 'stroke': color, 'fill': color
                    };
                    pathOptions[3] = {
                        'name': 'path', 'd': 'M6.19,2.643a2.123,2.111 0 1,0 4.246,0a2.123,2.111 0 1,0 -4.246,0',
                        'stroke-width': turstrokewidth, 'stroke-miterlimit': width, 'stroke': color, 'fill': color
                    };
                    pathOptions[4] = {
                        'name': 'path', 'd': 'M11.805,8.217a2.123,2.111 0 1,0 4.246,0a2.123,2.111 0 1,0 -4.246,0',
                        'stroke-width': turstrokewidth, 'stroke-miterlimit': width, 'stroke': color, 'fill': color
                    };
                    pathOptions[5] = {
                        'name': 'path', 'd': 'M6.19,8.217a2.123,2.111 0 1,0 4.246,0a2.123,2.111 0 1,0 -4.246,0',
                        'stroke-width': turstrokewidth, 'stroke-miterlimit': width, 'stroke': color, 'fill': color
                    };
                    pathOptions[6] = {
                        'name': 'path', 'd': 'M11.805,13.899a2.123,2.111 0 1,0 4.246,0a2.123,2.111 0 1,0 -4.246,0',
                        'stroke-width': turstrokewidth, 'stroke-miterlimit': width, 'stroke': color, 'fill': color
                    };
                    pathOptions[7] = {
                        'name': 'path', 'd': 'M6.19,13.899a2.123,2.111 0 1,0 4.246,0a2.123,2.111 0 1,0 -4.246,0',
                        'stroke-width': turstrokewidth, 'stroke-miterlimit': width, 'stroke': color, 'fill': color
                    };
                    break;
                case 'Star':
                    patternGroup[heightStr] = patternGroup[widthStr] = starNum;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': starNum, 'height': starNum, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path',
                        'd': 'M15.913,18.59L10.762 12.842 5.613 18.75 8.291 11.422 0.325 9.91 8.154 8.33 5.337 0.91 10.488 6.658 15.637 0.75 12.959 8.078 20.925 9.59 13.096 11.17 z',
                        'stroke-width': 1,
                        'stroke': color,
                        'fill': color
                    };
                    break;
                case 'Triangle':
                    patternGroup[heightStr] = patternGroup[widthStr] = width;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': width, 'height': width, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path',
                        'd': 'M4.987,0L7.48 4.847 9.974 9.694 4.987 9.694 0 9.694 2.493 4.847 z',
                        'stroke-width': 1,
                        'stroke': color,
                        'fill': color
                    };
                    break;
                case 'Circle':
                    patternGroup[heightStr] = patternGroup[widthStr] = circleNum;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': circleNum, 'height': circleNum, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'circle',
                        'cx': 5.125,
                        'cy': 3.875,
                        'r': 3.625,
                        'stroke-width': 1,
                        'fill': color
                    };
                    break;
                case 'Tile':
                    patternGroup[heightStr] = patternGroup[widthStr] = tileNum;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': tileNum, 'height': tileNum, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = { 'name': 'path', 'd': 'M0,9L0 0 9 0 z', 'stroke-width': strokeWidth, 'stroke': color, 'fill': color };
                    pathOptions[2] = { 'name': 'path', 'd': 'M9,9L9 0 18 0 z', 'stroke-width': strokeWidth, 'stroke': color, 'fill': color };
                    pathOptions[3] = { 'name': 'path', 'd': 'M0,18L0 9 9 9 z', 'stroke-width': strokeWidth, 'stroke': color, 'fill': color };
                    pathOptions[4] = { 'name': 'path', 'd': 'M9,18L9 9 18 9 z', 'stroke-width': strokeWidth, 'stroke': color, 'fill': color };
                    break;
                case 'HorizontalDash':
                    patternGroup[heightStr] = patternGroup[widthStr] = height;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': height, 'height': height, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path', 'd': 'M0,1.5 L10 1.5 M0,5.5 L10 5.5 M0,9.5 L10 9.5 z', 'stroke-width': 1,
                        'stroke': color, 'fill': color
                    };
                    break;
                case 'VerticalDash':
                    patternGroup[heightStr] = patternGroup[widthStr] = height;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': height, 'height': height, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path', 'd': 'M1.5,0 L1.5 10 M5.5,0 L5.5 10 M9.5,0 L9.5 10 z', 'stroke-width': 1,
                        'stroke': color, 'fill': color
                    };
                    break;
                case 'Rectangle':
                    patternGroup[heightStr] = patternGroup[widthStr] = height;
                    pathOptions[0] = { 'name': 'rect', 'width': height, 'height': height, 'fill': backgroundColor, 'opacity': opacity };
                    pathOptions[1] = { 'name': 'rect', 'x': 1, 'y': 2, 'width': 4, 'height': 9, 'fill': color, 'opacity': opacity };
                    pathOptions[2] = { 'name': 'rect', 'x': 7, 'y': 2, 'width': 4, 'height': 9, 'fill': color, 'opacity': opacity };
                    break;
                case 'Box':
                    patternGroup[heightStr] = patternGroup[widthStr] = width;
                    pathOptions[0] = { 'name': 'rect', 'width': 13, 'height': 13, 'fill': backgroundColor, 'opacity': opacity };
                    pathOptions[1] = {
                        'name': 'rect', 'x': 1.5, 'y': 1.5, 'width': width, 'height': 9, 'fill': color,
                        'opacity': opacity
                    };
                    break;
                case 'HorizontalStripe':
                    patternGroup[heightStr] = height;
                    patternGroup[widthStr] = width;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': width, 'height': height,
                        'transform': 'translate(0,0)', 'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path', 'd': 'M0,0.5 L10 0.5 M0,4.5 L10 4.5 M0,8.5 L10 8.5 z', 'stroke-width': 1,
                        'stroke': color, 'fill': color
                    };
                    break;
                case 'VerticalStripe':
                    patternGroup[heightStr] = width;
                    patternGroup[widthStr] = height;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': height, 'height': width, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = {
                        'name': 'path', 'd': 'M0.5,0 L0.5 10 M4.5,0 L4.5 10 M8.5,0 L8.5 10 z', 'stroke-width': 1,
                        'stroke': color, 'fill': color
                    };
                    break;
                case 'Bubble':
                    patternGroup[heightStr] = patternGroup[widthStr] = bubNum;
                    pathOptions[0] = {
                        'name': 'rect', 'x': 0, 'y': 0, 'width': bubNum, 'height': bubNum, 'transform': 'translate(0,0)',
                        'fill': backgroundColor, 'opacity': opacity
                    };
                    pathOptions[1] = { 'name': 'circle', 'cx': 5.217, 'cy': 11.325, 'r': 3.429, 'stroke-width': 1, 'fill': '#D0A6D1' };
                    pathOptions[2] = { 'name': 'circle', 'cx': 13.328, 'cy': 6.24, 'r': 4.884, 'stroke-width': 1, 'fill': color };
                    pathOptions[3] = {
                        'name': 'circle', 'cx': 13.277, 'cy': 14.66, 'r': 3.018, 'stroke-width': 1,
                        'fill': '#D0A6D1'
                    };
                    break;
            }
            var svgRenderer = (chart.svgRenderer || chart.renderer);
            var pattern = svgRenderer.createPattern(patternGroup, 'pattern');
            this.loadPattern(chart, pathOptions, pattern, svgRenderer);
            svg.appendChild(pattern);
            return 'url(#' + chart.element.id + '_' + patternName + '_' + 'Selection' + '_' + index + ')';
        };
        BaseSelection.prototype.loadPattern = function (chart, options, pattern, svgRenderer) {
            var i;
            for (i = 0; i < options.length; i++) {
                var path = svgRenderer.createPattern(options[i], options[i].name);
                pattern.appendChild(path);
            }
        };
        BaseSelection.prototype.concatIndexes = function (userIndexes, localIndexes) {
            return userIndexes.concat(localIndexes);
        };
        BaseSelection.prototype.checkVisibility = function (selectedIndexes, chart) {
            if (chart === void 0) { chart = null; }
            if (!selectedIndexes) {
                return false;
            }
            var visible = false;
            var uniqueSeries = [];
            for (var _i = 0, selectedIndexes_1 = selectedIndexes; _i < selectedIndexes_1.length; _i++) {
                var index = selectedIndexes_1[_i];
                if (uniqueSeries.indexOf(index.series) === -1) {
                    uniqueSeries.push(index.series);
                }
            }
            for (var _a = 0, uniqueSeries_1 = uniqueSeries; _a < uniqueSeries_1.length; _a++) {
                var index = uniqueSeries_1[_a];
                if (chart != null && chart.rangeColorSettings && chart.rangeColorSettings.length > 0 &&
                    chart.rangeColorSettings[0].colors.length > 0) {
                    Eif (this.control.series[0].visible) {
                        visible = true;
                        break;
                    }
                }
                else {
                    if (this.control.visibleSeries[index].visible) {
                        visible = true;
                        break;
                    }
                }
            }
            return visible;
        };
        BaseSelection.prototype.addSvgClass = function (element, className) {
            var elementClassName = element.getAttribute('class') || '';
            elementClassName += ((elementClassName !== '') ? ' ' : '');
            var isDataLabel = element.id.indexOf('datalabel') > -1 || (element.id.indexOf('Text') > -1 || element.id.indexOf('TextShape') > -1);
            if (elementClassName.indexOf(className) === -1) {
                element.setAttribute('class', elementClassName + className);
                var selectionStyles_1 = this.selectionStyle;
                if (className && className.indexOf('highlight') !== -1) {
                    if (this.control.getModuleName() === 'chart' && this.control.highlightModule) {
                        selectionStyles_1 = this.control.highlightModule.selectionStyle;
                    }
                    else if (this.control.getModuleName() === 'accumulationchart' && this.control.accumulationHighlightModule) {
                        selectionStyles_1 = this.control.accumulationHighlightModule.selectionStyle;
                    }
                    else if (this.control.getModuleName() === 'chart3d' && this.control.highlight3DModule) {
                        selectionStyles_1 = this.control.highlight3DModule.selectionStyle;
                    }
                    else Eif (this.control.getModuleName() === 'circularchart3d' && this.control.circularChartHighlight3DModule) {
                        selectionStyles_1 = this.control.circularChartHighlight3DModule.selectionStyle;
                    }
                }
                if (element.tagName.toLowerCase() === 'g') {
                    element.querySelectorAll('*').forEach(function (child) {
                        for (var i = 0; i < selectionStyles_1.length; i++) {
                            var key = selectionStyles_1[i];
                            var classValue = key[0];
                            var childClass = child.getAttribute('class') ? child.getAttribute('class') : '';
                            if ((classValue === className || classValue.indexOf(className) !== -1) && childClass.indexOf('selection') === -1) {
                                if (key[1] === 'fill' && key[2] && !isDataLabel) {
                                    child.style.fill = key[2];
                                }
                                if (key[1] === 'opacity' && key[2]) {
                                    child.style.opacity = key[2];
                                    child.style.fill = '';
                                }
                                if (key[1] === 'stroke-width' && key[2]) {
                                    child.style.strokeWidth = key[2];
                                }
                            }
                        }
                    });
                }
                else {
                    for (var i = 0; i < selectionStyles_1.length; i++) {
                        var key = selectionStyles_1[i];
                        var classValue = key[0];
                        var childClass = element.getAttribute('class') ? element.getAttribute('class') : '';
                        if ((classValue === className || classValue.indexOf(className) !== -1) && (className.indexOf('highlight') === -1 || childClass.indexOf('selection') === -1)) {
                            if (key[1] === 'fill' && key[2] && !isDataLabel) {
                                element.style.fill = key[2];
                            }
                            if (key[1] === 'opacity' && key[2]) {
                                element.style.opacity = key[2];
                                element.style.fill = '';
                            }
                            if (key[1] === 'stroke-width' && key[2] && element.id.indexOf('legend_shape') === -1) {
                                element.style.strokeWidth = key[2];
                            }
                        }
                    }
                }
            }
        };
        BaseSelection.prototype.removeSvgClass = function (element, className) {
            var elementClassName = element.getAttribute('class') || '';
            if (elementClassName.indexOf(className) > -1) {
                element.setAttribute('class', elementClassName.replace(className, '').trim());
                var selectionStyles_2 = this.selectionStyle;
                if (className && className.indexOf('highlight') !== -1) {
                    if (this.control.getModuleName() === 'chart' && this.control.highlightModule) {
                        selectionStyles_2 = this.control.highlightModule.selectionStyle;
                    }
                    else if (this.control.getModuleName() === 'accumulationchart' && this.control.accumulationHighlightModule) {
                        selectionStyles_2 = this.control.accumulationHighlightModule.selectionStyle;
                    }
                    else if (this.control.getModuleName() === 'chart3d' && this.control.highlight3DModule) {
                        selectionStyles_2 = this.control.highlight3DModule.selectionStyle;
                    }
                    else Eif (this.control.getModuleName() === 'circularchart3d' && this.control.circularChartHighlight3DModule) {
                        selectionStyles_2 = this.control.circularChartHighlight3DModule.selectionStyle;
                    }
                }
                if (element.tagName.toLowerCase() === 'g') {
                    element.querySelectorAll('*').forEach(function (child) {
                        for (var i = 0; i < selectionStyles_2.length; i++) {
                            var key = selectionStyles_2[i];
                            var classValue = key[0];
                            var childClass = child.getAttribute('class') ? child.getAttribute('class') : '';
                            if ((classValue === className || classValue.indexOf(className) !== -1) && childClass.indexOf('selection') === -1) {
                                if (key[1] === 'fill' && key[2]) {
                                    child.style.fill = '';
                                }
                                if (key[1] === 'opacity' && key[2]) {
                                    child.style.opacity = '';
                                }
                                Iif (key[1] === 'stroke-width' && key[2]) {
                                    child.style.strokeWidth = '';
                                }
                            }
                        }
                    });
                }
                else {
                    for (var i = 0; i < selectionStyles_2.length; i++) {
                        var key = selectionStyles_2[i];
                        var classValue = key[0];
                        var childClass = element.getAttribute('class') ? element.getAttribute('class') : '';
                        if ((classValue === className || classValue.indexOf(className) !== -1) && (className.indexOf('highlight') === -1 || childClass.indexOf('selection') === -1)) {
                            if (key[1] === 'fill' && key[2]) {
                                element.style.fill = '';
                            }
                            if (key[1] === 'opacity' && key[2]) {
                                element.style.opacity = '';
                            }
                            if (key[1] === 'stroke-width' && key[2]) {
                                element.style.strokeWidth = '';
                            }
                        }
                    }
                }
            }
        };
        BaseSelection.prototype.getChildren = function (parent) {
            var children = [];
            for (var i = 0; i < parent.childNodes.length; i++) {
                if (parent.childNodes[i].tagName !== 'defs') {
                    children.push(parent.childNodes[i]);
                }
            }
            return children;
        };
        return BaseSelection;
    }());
    exports.BaseSelection = BaseSelection;
});