-
Notifications
You must be signed in to change notification settings - Fork 0
/
gisplayv2.bundle.js
227 lines (201 loc) · 305 KB
/
gisplayv2.bundle.js
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
var GisplayLibrary =
/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId])
/******/ return installedModules[moduleId].exports;
/******/
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // identity function for calling harmony imports with the correct context
/******/ __webpack_require__.i = function(value) { return value; };
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, {
/******/ configurable: false,
/******/ enumerable: true,
/******/ get: getter
/******/ });
/******/ }
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = 12);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/* unknown exports provided */
/* all exports used */
/*!*******************************!*\
!*** ./src/Gisplay/Legend.js ***!
\*******************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\r\n * This class represents the Map Legend. 15/03\r\n */\nvar Legend = exports.Legend = function () {\n /**\r\n * Creates an instance of Legend class.\r\n * @param {number} id - The id of the legend.\r\n * @param {string} title - The title for the legend.\r\n * \r\n * @memberOf Legend\r\n */\n function Legend(id, title) {\n _classCallCheck(this, Legend);\n\n /**\r\n * Title of the Gisplay map Legend.\r\n * @type {string}\r\n */\n this.title = title;\n this.init(id);\n return this; //@Rui Remove this\n }\n\n /**\r\n * Appends the legend div element to the map container.\r\n * @param {*} map \r\n */\n\n\n _createClass(Legend, [{\n key: 'insertLegend',\n value: function insertLegend(map) {\n this.legendDiv.appendChild(this.table);\n map.getContainer().appendChild(this.legendDiv);\n }\n\n /**\r\n * Inserts one row for the Aesthetic object.\r\n * @param {Aesthetic} currentaes - The Aesthetic object \r\n * @param {*} mapobj \r\n */\n\n }, {\n key: 'insertPointRow',\n value: function insertPointRow(currentaes, mapobj) {\n this.insertRow(currentaes, mapobj, 2);\n }\n }, {\n key: 'insertPolygonRow',\n value: function insertPolygonRow(currentaes, mapobj) {\n this.insertRow(currentaes, mapobj, 1);\n }\n }, {\n key: 'insertRow',\n value: function insertRow(currentaes, mapobj, type) {\n\n var row = document.createElement('tr');\n var value = document.createElement('td');\n var color = document.createElement('td');\n var text = void 0;\n if (typeof currentaes.range[0] === 'number') {\n var mininput = currentaes.range[0] != null ? currentaes.range[0] : mapobj.min;\n var maxinput = currentaes.range[1] != null ? currentaes.range[1] : mapobj.max;\n if (currentaes.outer == false) text = document.createTextNode('[' + mininput + ', ' + maxinput + '[');else text = document.createTextNode('[' + mininput + ', ' + maxinput + ']');\n } else text = document.createTextNode(currentaes.range[0]);\n value.appendChild(text);\n\n var colorDiv = document.createElement('div');\n colorDiv.style.position = 'relative';\n var rgbc = 'rgba(' + currentaes.fillColor[0] + ',' + currentaes.fillColor[1] + ',' + currentaes.fillColor[2] + ',' + currentaes.fillColor[3] + ')';\n colorDiv.style['backgroundColor'] = rgbc;\n if (type == 1) {\n //polygon\n colorDiv.style.height = 25; //(mapCanvas.height / 10);\n colorDiv.style.width = 80; //(mapCanvas.width / 10);\n if (currentaes.strokeColor != null && currentaes != undefined) colorDiv.style['borderColor'] = 'rgba(' + currentaes.strokeColor[0] + ',' + currentaes.strokeColor[1] + ',' + currentaes.strokeColor[2] + ',' + currentaes.strokeColor[3] + ')';\n colorDiv.className = '_gisplayrectangle';\n } else if (type == 2) {\n //point\n var size = void 0;\n if (currentaes.pointSize != null) {\n size = Math.max(currentaes.pointSize, 5);\n } else size = 25;\n colorDiv.style.height = size;\n colorDiv.style.width = size;\n colorDiv.className = '_gisplaycircle';\n }\n\n color.appendChild(colorDiv);\n\n row.appendChild(color);\n row.appendChild(value);\n\n row.onclick = function () {\n if (window.profiling == true) var start = Date.now();\n if (mapobj.legendToggle != false) {\n var toFade = !currentaes.enableDisable();\n if (toFade == true) {\n this.className += \" _gisplayfade\";\n } else {\n this.className = this.className.replace(/(?:^|\\s)_gisplayfade(?!\\S)/g, '');\n }\n }\n if (mapobj.legendOnClickCall != null && mapobj.legendOnClickCall != undefined) mapobj.legendOnClickCall(currentaes);\n mapobj.draw();\n if (window.profiling == true) {\n var end = Date.now();\n window.console.log('Tempo de processamento de filtragem pela legenda (segundos): ' + (end - start) / 1000);\n }\n };\n\n this.table.appendChild(row);\n }\n }, {\n key: 'insertGradient',\n value: function insertGradient(mapobj, left, middle, right) {\n var row = document.createElement('tr');\n var value = document.createElement('td');\n var valueDiv = document.createElement('div');\n value.colSpan = 2;\n value.style.textAlign = 'center';\n var numberof = 5;\n if (mapobj.aesthetics.length > 5) numberof = mapobj.aesthetics.length;\n var strcolor = '';\n for (var i = 0; i < numberof; i++) {\n var color = mapobj.fcolor(i / numberof).rgb();\n strcolor += ',rgba(' + Math.round(color[0]) + ',' + Math.round(color[1]) + ',' + Math.round(color[2]) + ',' + mapobj.alpha + ')';\n }\n strcolor += ') ';\n valueDiv.style.background = '-webkit-linear-gradient(left' + strcolor;\n\n valueDiv.style.height = 25; //(mapCanvas.height / 10);\n valueDiv.style.width = 130; //(mapCanvas.width / 10);\n\n var row2 = document.createElement('tr');\n var value2 = document.createElement('td');\n value2.colSpan = 2;\n\n var divleft = document.createElement('div');\n divleft.style.textAlign = 'left';\n divleft.style.width = '33%';\n divleft.style.display = \"inline-block\";\n var lefttext = document.createTextNode(left);\n var divmid = document.createElement('div');\n divmid.style.textAlign = 'center';\n divmid.style.width = '33%';\n divmid.style.display = \"inline-block\";\n var text = document.createTextNode(middle);\n var divright = document.createElement('div');\n divright.style.textAlign = 'right';\n divright.style.width = '33%';\n divright.style.display = \"inline-block\";\n var righttext = document.createTextNode(right);\n\n divleft.appendChild(lefttext);\n divmid.appendChild(text);\n divright.appendChild(righttext);\n value2.appendChild(divleft);\n value2.appendChild(divmid);\n value2.appendChild(divright);\n value.appendChild(valueDiv);\n row2.appendChild(value2);\n row.appendChild(value);\n this.table.appendChild(row);\n this.table.appendChild(row2);\n }\n }, {\n key: 'init',\n value: function init(id, classname) {\n //console.log(\"id == \" + id);\n var mapCanvas = document.getElementById('mapCanvas' + id);\n this.legendDiv = document.createElement('div');\n if (classname != undefined && classname != null) {\n this.legendDiv.className = classname;\n } else {\n this.legendDiv.className = '_gisplaylegendBR';\n }\n this.legendDiv.id = 'legendDiv' + id;\n\n this.table = document.createElement('table');\n this.table.style.zIndex = \"2000\";\n var thvalue = document.createElement('th');\n var thcolor = document.createElement('th');\n thcolor.style.align = \"center\";\n //thcolor.style.width = 100;\n this.table.appendChild(thcolor);\n this.table.appendChild(thvalue);\n var titlerow = document.createElement('tr');\n var titletd = document.createElement('td');\n titletd.colSpan = 2;\n titletd.style.textAlign = 'center';\n titletd.style.width = 100;\n var titletext = document.createTextNode(this.title);\n titletd.appendChild(titletext);\n titlerow.appendChild(titletd);\n this.table.appendChild(titlerow);\n }\n }, {\n key: 'insertProportionalSymbols',\n value: function insertProportionalSymbols(currentaes, mapobj, numberof) {\n if (this.lastdiv == undefined) {\n var row = document.createElement('tr');\n var value = document.createElement('td');\n value.colSpan = 2;\n value.style.textAlign = 'center';\n this.firstInsertion = true;\n } else {\n this.firstInsertion = false;\n }\n\n var rgbc = 'rgba(' + currentaes.fillColor[0] + ',' + currentaes.fillColor[1] + ',' + currentaes.fillColor[2] + ',' + 1 + ')';\n var strokecolor = void 0;\n\n if (currentaes.strokeColor != null && currentaes != undefined) strokecolor = 'rgba(' + currentaes.strokeColor[0] + ',' + currentaes.strokeColor[1] + ',' + currentaes.strokeColor[2] + ',' + currentaes.strokeColor[3] + ')';else strokecolor = 'rgba(' + 0 + ',' + 0 + ',' + 0 + ',' + 1 + ')';\n\n for (var i = numberof - 1; i >= 0; i--) {\n var current = document.createElement('div');\n var propvalue = void 0;\n if (this.firstInsertion == false && i == numberof - 1 || numberof == 1) propvalue = currentaes.range[1];else propvalue = mapobj.min + i / (numberof - 1) * (mapobj.max - mapobj.min);\n\n var text = document.createTextNode(this.round(propvalue));\n current.appendChild(text);\n var colorDiv = document.createElement('div');\n colorDiv.style.position = 'relative';\n colorDiv.style.backgroundColor = rgbc;\n colorDiv.className = '_gisplayproportionalcircle';\n colorDiv.style.borderColor = strokecolor;\n var temppointsize = (mapobj.maxpointsize - mapobj.minpointsize) / (mapobj.max - mapobj.min) * (propvalue - mapobj.min);\n var size = Math.max(temppointsize, 7.5);\n colorDiv.style.height = size;\n colorDiv.style.width = size;\n colorDiv.style.inherit = false;\n\n colorDiv.onclick = function (e) {\n if (window.profiling == true) var start = Date.now();\n if (mapobj.legendToggle != false) {\n var toFade = !currentaes.enableDisable();\n if (toFade == true) {\n this.className += \" _gisplayfade\";\n } else {\n this.className = this.className.replace(/(?:^|\\s)_gisplayfade(?!\\S)/g, '');\n }\n }\n if (mapobj.legendOnClickCall != null && mapobj.legendOnClickCall != undefined) mapobj.legendOnClickCall(currentaes);\n mapobj.draw();\n if (window.profiling == true) {\n var end = Date.now();\n window.console.log('Tempo de processamento de filtragem pela legenda (segundos): ' + (end - start) / 1000);\n }\n if (!e) var e = window.event;\n e.cancelBubble = true;\n if (e.stopPropagation) e.stopPropagation();\n };\n current.appendChild(colorDiv);\n if ( /*i!= (numberof-1) &&*/this.lastdiv != undefined) {\n this.lastdiv.appendChild(current);\n this.lastdiv = colorDiv;\n } else {\n value.appendChild(current);\n this.lastdiv = colorDiv;\n }\n }\n if (this.firstInsertion == true) {\n row.appendChild(value);\n this.table.appendChild(row);\n }\n }\n }, {\n key: 'round',\n value: function round(value, exp) {\n //@Rui Added cuz its used by insertProportionalSymbols\n if (typeof exp === 'undefined' || +exp === 0) return Math.round(value);\n\n value = +value;\n exp = +exp;\n\n if (isNaN(value) || !(typeof exp === 'number' && exp % 1 === 0)) return NaN;\n\n // Shift\n value = value.toString().split('e');\n value = Math.round(+(value[0] + 'e' + (value[1] ? +value[1] + exp : exp)));\n\n // Shift back\n value = value.toString().split('e');\n return +(value[0] + 'e' + (value[1] ? +value[1] - exp : -exp));\n }\n }]);\n\n return Legend;\n}();//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"0.js","sources":["webpack:///src/Gisplay/Legend.js?c842"],"sourcesContent":["/**\r\n * This class represents the Map Legend. 15/03\r\n */\r\nexport class Legend {\r\n    /**\r\n     * Creates an instance of Legend class.\r\n     * @param {number} id -  The id of the legend.\r\n     * @param {string} title - The title for the legend.\r\n     * \r\n     * @memberOf Legend\r\n     */\r\n    constructor(id, title) {\r\n        /**\r\n         * Title of the Gisplay map Legend.\r\n         * @type {string}\r\n         */\r\n        this.title = title;\r\n        this.init(id);\r\n        return this; //@Rui Remove this\r\n    }\r\n\r\n    /**\r\n     * Appends the legend div element to the map container.\r\n     * @param {*} map \r\n     */\r\n    insertLegend(map) {\r\n        this.legendDiv.appendChild(this.table);\r\n        map.getContainer().appendChild(this.legendDiv);\r\n    }\r\n\r\n    /**\r\n     * Inserts one row for the Aesthetic object.\r\n     * @param {Aesthetic} currentaes - The Aesthetic object \r\n     * @param {*} mapobj \r\n     */\r\n    insertPointRow(currentaes, mapobj) {\r\n        this.insertRow(currentaes, mapobj, 2);\r\n    }\r\n\r\n    insertPolygonRow(currentaes, mapobj) {\r\n        this.insertRow(currentaes, mapobj, 1);\r\n    }\r\n\r\n    insertRow(currentaes, mapobj, type) {\r\n\r\n        const row = document.createElement('tr');\r\n        const value = document.createElement('td');\r\n        const color = document.createElement('td');\r\n        let text;\r\n        if (typeof currentaes.range[0] === 'number') {\r\n            const mininput = currentaes.range[0] != null ? currentaes.range[0] : mapobj.min;\r\n            const maxinput = currentaes.range[1] != null ? currentaes.range[1] : mapobj.max;\r\n            if (currentaes.outer == false)\r\n                text = document.createTextNode(`[${mininput}, ${maxinput}[`);\r\n            else\r\n                text = document.createTextNode(`[${mininput}, ${maxinput}]`);\r\n        }\r\n        else\r\n            text = document.createTextNode(currentaes.range[0]);\r\n        value.appendChild(text);\r\n\r\n        const colorDiv = document.createElement('div');\r\n        colorDiv.style.position = 'relative';\r\n        const rgbc = `rgba(${currentaes.fillColor[0]},${currentaes.fillColor[1]},${currentaes.fillColor[2]},${currentaes.fillColor[3]})`;\r\n        colorDiv.style['backgroundColor'] = rgbc;\r\n        if (type == 1) {//polygon\r\n            colorDiv.style.height = 25;//(mapCanvas.height / 10);\r\n            colorDiv.style.width = 80;//(mapCanvas.width / 10);\r\n            if (currentaes.strokeColor != null && currentaes != undefined)\r\n                colorDiv.style['borderColor'] = `rgba(${currentaes.strokeColor[0]},${currentaes.strokeColor[1]},${currentaes.strokeColor[2]},${currentaes.strokeColor[3]})`;\r\n            colorDiv.className = '_gisplayrectangle';\r\n        }\r\n        else if (type == 2) {//point\r\n            let size;\r\n            if (currentaes.pointSize != null) {\r\n                size = Math.max(currentaes.pointSize, 5);\r\n            }\r\n            else\r\n                size = 25;\r\n            colorDiv.style.height = size;\r\n            colorDiv.style.width = size;\r\n            colorDiv.className = '_gisplaycircle';\r\n        }\r\n\r\n\r\n        color.appendChild(colorDiv);\r\n\r\n        row.appendChild(color);\r\n        row.appendChild(value);\r\n\r\n        row.onclick = function () {\r\n            if (window.profiling == true)\r\n                var start = Date.now();\r\n            if (mapobj.legendToggle != false) {\r\n                const toFade = !currentaes.enableDisable();\r\n                if (toFade == true) {\r\n                    this.className += \" _gisplayfade\";\r\n                }\r\n                else {\r\n                    this.className = this.className.replace(/(?:^|\\s)_gisplayfade(?!\\S)/g, '');\r\n                }\r\n            }\r\n            if (mapobj.legendOnClickCall != null && mapobj.legendOnClickCall != undefined)\r\n                mapobj.legendOnClickCall(currentaes);\r\n            mapobj.draw();\r\n            if (window.profiling == true) {\r\n                const end = Date.now();\r\n                window.console.log(`Tempo de processamento de filtragem pela legenda (segundos): ${(end - start) / 1000}`);\r\n            }\r\n\r\n        };\r\n\r\n        this.table.appendChild(row);\r\n\r\n    }\r\n\r\n    insertGradient(mapobj, left, middle, right) {\r\n        const row = document.createElement('tr');\r\n        const value = document.createElement('td');\r\n        const valueDiv = document.createElement('div');\r\n        value.colSpan = 2;\r\n        value.style.textAlign = 'center';\r\n        let numberof = 5;\r\n        if (mapobj.aesthetics.length > 5)\r\n            numberof = mapobj.aesthetics.length;\r\n        let strcolor = '';\r\n        for (let i = 0; i < numberof; i++) {\r\n            const color = mapobj.fcolor(i / numberof).rgb();\r\n            strcolor += `,rgba(${Math.round(color[0])},${Math.round(color[1])},${Math.round(color[2])},${mapobj.alpha})`;\r\n        }\r\n        strcolor += ') ';\r\n        valueDiv.style.background = `-webkit-linear-gradient(left${strcolor}`;\r\n\r\n        valueDiv.style.height = 25;//(mapCanvas.height / 10);\r\n        valueDiv.style.width = 130;//(mapCanvas.width / 10);\r\n\r\n        const row2 = document.createElement('tr');\r\n        const value2 = document.createElement('td');\r\n        value2.colSpan = 2;\r\n\r\n        const divleft = document.createElement('div');\r\n        divleft.style.textAlign = 'left';\r\n        divleft.style.width = '33%';\r\n        divleft.style.display = \"inline-block\";\r\n        const lefttext = document.createTextNode(left);\r\n        const divmid = document.createElement('div');\r\n        divmid.style.textAlign = 'center';\r\n        divmid.style.width = '33%';\r\n        divmid.style.display = \"inline-block\";\r\n        const text = document.createTextNode(middle);\r\n        const divright = document.createElement('div');\r\n        divright.style.textAlign = 'right';\r\n        divright.style.width = '33%';\r\n        divright.style.display = \"inline-block\";\r\n        const righttext = document.createTextNode(right);\r\n\r\n\r\n\r\n        divleft.appendChild(lefttext);\r\n        divmid.appendChild(text);\r\n        divright.appendChild(righttext);\r\n        value2.appendChild(divleft);\r\n        value2.appendChild(divmid);\r\n        value2.appendChild(divright);\r\n        value.appendChild(valueDiv);\r\n        row2.appendChild(value2);\r\n        row.appendChild(value);\r\n        this.table.appendChild(row);\r\n        this.table.appendChild(row2);\r\n    }\r\n\r\n    init(id, classname) {\r\n        //console.log(\"id == \" + id);\r\n        const mapCanvas = document.getElementById(`mapCanvas${id}`);\r\n        this.legendDiv = document.createElement('div');\r\n        if (classname != undefined && classname != null) {\r\n            this.legendDiv.className = classname;\r\n        }\r\n        else {\r\n            this.legendDiv.className = '_gisplaylegendBR';\r\n        }\r\n        this.legendDiv.id = `legendDiv${id}`;\r\n\r\n\r\n\r\n\r\n\r\n        this.table = document.createElement('table');\r\n        this.table.style.zIndex = \"2000\";\r\n        const thvalue = document.createElement('th');\r\n        const thcolor = document.createElement('th');\r\n        thcolor.style.align = \"center\";\r\n        //thcolor.style.width = 100;\r\n        this.table.appendChild(thcolor);\r\n        this.table.appendChild(thvalue);\r\n        const titlerow = document.createElement('tr');\r\n        const titletd = document.createElement('td');\r\n        titletd.colSpan = 2;\r\n        titletd.style.textAlign = 'center';\r\n        titletd.style.width = 100;\r\n        const titletext = document.createTextNode(this.title);\r\n        titletd.appendChild(titletext);\r\n        titlerow.appendChild(titletd);\r\n        this.table.appendChild(titlerow);\r\n\r\n    }\r\n\r\n    insertProportionalSymbols(currentaes, mapobj, numberof) {\r\n        if (this.lastdiv == undefined) {\r\n            var row = document.createElement('tr');\r\n            var value = document.createElement('td');\r\n            value.colSpan = 2;\r\n            value.style.textAlign = 'center';\r\n            this.firstInsertion = true;\r\n        } else { this.firstInsertion = false; }\r\n\r\n        const rgbc = `rgba(${currentaes.fillColor[0]},${currentaes.fillColor[1]},${currentaes.fillColor[2]},${1})`;\r\n        let strokecolor;\r\n\r\n        if (currentaes.strokeColor != null && currentaes != undefined)\r\n            strokecolor = `rgba(${currentaes.strokeColor[0]},${currentaes.strokeColor[1]},${currentaes.strokeColor[2]},${currentaes.strokeColor[3]})`;\r\n        else\r\n            strokecolor = `rgba(${0},${0},${0},${1})`;\r\n\r\n        for (let i = numberof - 1; i >= 0; i--) {\r\n            const current = document.createElement('div');\r\n            let propvalue;\r\n            if (this.firstInsertion == false && i == (numberof - 1) || numberof == 1)\r\n                propvalue = currentaes.range[1];\r\n            else\r\n                propvalue = mapobj.min + i / (numberof - 1) * (mapobj.max - mapobj.min);\r\n\r\n            const text = document.createTextNode(this.round(propvalue));\r\n            current.appendChild(text);\r\n            const colorDiv = document.createElement('div');\r\n            colorDiv.style.position = 'relative';\r\n            colorDiv.style.backgroundColor = rgbc;\r\n            colorDiv.className = '_gisplayproportionalcircle';\r\n            colorDiv.style.borderColor = strokecolor;\r\n            const temppointsize = ((mapobj.maxpointsize - mapobj.minpointsize) / (mapobj.max - mapobj.min)) * (propvalue - mapobj.min);\r\n            const size = Math.max(temppointsize, 7.5);\r\n            colorDiv.style.height = size;\r\n            colorDiv.style.width = size;\r\n            colorDiv.style.inherit = false;\r\n\r\n            colorDiv.onclick = function (e) {\r\n                if (window.profiling == true)\r\n                    var start = Date.now();\r\n                if (mapobj.legendToggle != false) {\r\n                    const toFade = !currentaes.enableDisable();\r\n                    if (toFade == true) {\r\n                        this.className += \" _gisplayfade\";\r\n                    }\r\n                    else {\r\n                        this.className = this.className.replace(/(?:^|\\s)_gisplayfade(?!\\S)/g, '');\r\n                    }\r\n                }\r\n                if (mapobj.legendOnClickCall != null && mapobj.legendOnClickCall != undefined)\r\n                    mapobj.legendOnClickCall(currentaes);\r\n                mapobj.draw();\r\n                if (window.profiling == true) {\r\n                    const end = Date.now();\r\n                    window.console.log(`Tempo de processamento de filtragem pela legenda (segundos): ${(end - start) / 1000}`);\r\n                }\r\n                if (!e) var e = window.event;\r\n                e.cancelBubble = true;\r\n                if (e.stopPropagation) e.stopPropagation();\r\n\r\n            };\r\n            current.appendChild(colorDiv);\r\n            if (/*i!= (numberof-1) &&*/ this.lastdiv != undefined) {\r\n                this.lastdiv.appendChild(current);\r\n                this.lastdiv = colorDiv;\r\n            }\r\n            else {\r\n                value.appendChild(current);\r\n                this.lastdiv = colorDiv;\r\n            }\r\n\r\n        }\r\n        if (this.firstInsertion == true) {\r\n            row.appendChild(value);\r\n            this.table.appendChild(row);\r\n        }\r\n\r\n\r\n    }\r\n\r\n    round(value, exp) {//@Rui Added cuz its used by insertProportionalSymbols\r\n        if (typeof exp === 'undefined' || +exp === 0)\r\n            return Math.round(value);\r\n\r\n        value = +value;\r\n        exp = +exp;\r\n\r\n        if (isNaN(value) || !(typeof exp === 'number' && exp % 1 === 0))\r\n            return NaN;\r\n\r\n        // Shift\r\n        value = value.toString().split('e');\r\n        value = Math.round(+(value[0] + 'e' + (value[1] ? (+value[1] + exp) : exp)));\r\n\r\n        // Shift back\r\n        value = value.toString().split('e');\r\n        return +(value[0] + 'e' + (value[1] ? (+value[1] - exp) : -exp));\r\n    }\r\n}\n\n\n// WEBPACK FOOTER //\n// src/Gisplay/Legend.js"],"mappings":";;;;;;;;;;AAAA;;;AAGA;AACA;;;;;;;AAOA;AAAA;AACA;AAAA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAIA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAKA;AACA;AACA;;;AAEA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAGA;;;AAEA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;","sourceRoot":""}");
/***/ }),
/* 1 */
/* unknown exports provided */
/* all exports used */
/*!*********************************!*\
!*** ./src/Gisplay/Maps/Map.js ***!
\*********************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Map = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _BGMapWrapper = __webpack_require__(/*! ./BGMapWrapper */ 7);\n\nvar _Aesthetic = __webpack_require__(/*! ../Aesthetic */ 2);\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\r\n * This class contains the Map class which represents the current map.\r\n * Each map has a group of functions available. There is only one map yet(maybe there will be two if we want to compare two).\r\n */\nvar Map = exports.Map = function () {\n function Map(type, geometry, options) {\n _classCallCheck(this, Map);\n\n console.log(\"Map constructor called -> super()\");\n }\n\n _createClass(Map, [{\n key: 'program',\n value: function program() {\n this._webgl.program = this._webgl.gl.createProgram();\n this._webgl.heatmapProgram = [];\n this._webgl.heatmapProgram[0] = this._webgl.gl.createProgram();\n this._webgl.heatmapProgram[1] = this._webgl.gl.createProgram();\n\n var source_code = this.generateShaders();\n\n var vertex_shader = this.shader(this._webgl.gl.VERTEX_SHADER, source_code.vertex, this._webgl);\n var fragment_shader = this.shader(this._webgl.gl.FRAGMENT_SHADER, source_code.fragment, this._webgl);\n\n this._webgl.gl.attachShader(this._webgl.program, vertex_shader);\n this._webgl.gl.attachShader(this._webgl.program, fragment_shader);\n\n this._webgl.gl.linkProgram(this._webgl.program);\n this._webgl.gl.useProgram(this._webgl.program);\n }\n }, {\n key: 'shader',\n value: function shader(type, source_code, _webgl) {\n //Added HERE by Rui\n var shader = _webgl.gl.createShader(type);\n\n _webgl.gl.shaderSource(shader, source_code);\n _webgl.gl.compileShader(shader);\n\n console.log(\"shader \" + (type.valueOf() == 35633 ? \"vertex\" : \"fragment\") + \": \" + _webgl.gl.getShaderInfoLog(shader));\n\n return shader;\n }\n }, {\n key: 'generateShaders',\n value: function generateShaders() {\n //Added HERE by Rui @TODO Refactor to use ES6 `` instead of +=\n //general\n\n var vertexSourceCode = \" attribute vec4 vertexCoord; \";\n vertexSourceCode += \"\\n\tattribute float aPointSize; \";\n vertexSourceCode += \"\\n\tuniform mat4 projection; \";\n vertexSourceCode += \"\\n\tattribute float a_opacity; \";\n vertexSourceCode += \"\\n\tvarying float v_opacity; \";\n //vertexSourceCode+= \"\\n\tvarying vec4 u_color; \" ; //delete\n vertexSourceCode += \"\\n\tvoid main() {\";\n vertexSourceCode += \"\\n\t\tgl_Position = (projection * vertexCoord); \";\n vertexSourceCode += \"\\n\t\tgl_PointSize = aPointSize; v_opacity = a_opacity; \";\n vertexSourceCode += \"\\n}\";\n\n var fragmentSourceCode = \"precision mediump float;\";\n fragmentSourceCode += \"\\n\t\tuniform vec4 u_color;\"; //uniform\n fragmentSourceCode += \"\\n\t\tvarying float v_opacity; \";\n fragmentSourceCode += \"\\n \t\tuniform float isPoint;\";\n fragmentSourceCode += \"\\n\t\tvoid main(){\";\n fragmentSourceCode += \"\\n\t\t\tfloat border = 0.5;\";\n fragmentSourceCode += \"\\n\t\t\tfloat radius = 0.5;\";\n fragmentSourceCode += \"\\n\t\t\tfloat centerDist = length(gl_PointCoord - 0.5);\";\n fragmentSourceCode += \"\\n\t\t\tfloat alpha;\";\n fragmentSourceCode += \"\\n\t\t\tif (u_color[3] == -1.0){\"; //unnecessary??\n fragmentSourceCode += \"\\n\t\t\t\talpha = v_opacity * step(centerDist, radius);\"; //unnecessary??\n fragmentSourceCode += \"\\n\t\t\t}\"; //unnecessary??\n fragmentSourceCode += \"\\n\t\t\telse{\"; //unnecessary??\n fragmentSourceCode += \"\\n\t\t\t\talpha = u_color[3] * step(centerDist, radius);\";\n fragmentSourceCode += \"\\n\t\t\t}\"; //unnecessary??\n fragmentSourceCode += \"\\n\t\t\tif(isPoint == 1.0 ){\";\n fragmentSourceCode += \"\\n\t\t\tif (alpha < 0.1) discard;\";\n fragmentSourceCode += \"\\n\t\t\t\tgl_FragColor = vec4(u_color[0], u_color[1], u_color[2], alpha);}\";\n fragmentSourceCode += \"\\n \t\t\telse\";\n fragmentSourceCode += \"\\n\t\t\t\tgl_FragColor = vec4(u_color[0], u_color[1], u_color[2], u_color[3]);\";\n fragmentSourceCode += \"\\n\t\t}\";\n\n return { vertex: vertexSourceCode, fragment: fragmentSourceCode };\n }\n }, {\n key: 'addAesthetic',\n value: function addAesthetic(aes) {\n this.aesthetics.push(aes);\n }\n }, {\n key: 'setAesthetic',\n value: function setAesthetic(id, aes) {\n for (var i = 0; i < aesthetics.length; i++) {\n if (id == aesthetics[i].id) {\n aesthetics[i] = aes;\n break;\n }\n }\n }\n }, {\n key: 'buildLegend',\n value: function buildLegend() {\n var mapCanvas = document.getElementById('mapCanvas' + this.id);\n var legendDiv = document.createElement('div');\n legendDiv.id = 'legendDiv' + this.id;\n legendDiv.style.position = 'absolute';\n legendDiv.style.backgroundColor = 'white';\n //legendDiv.style.height = 200;//(mapCanvas.height / 10);\n legendDiv.style.width = 250; //(mapCanvas.width / 10);\n legendDiv.style.bottom = 20;\n legendDiv.style.right = 0;\n legendDiv.style.borderColor = 'black';\n legendDiv.style.border = 'solid';\n\n var table = document.createElement('table');\n var thvalue = document.createElement('th');\n var thcolor = document.createElement('th');\n //thvalue.style.width = 125;\n table.style.zIndex = \"2000\";\n thcolor.style.width = 100;\n table.appendChild(thcolor);\n table.appendChild(thvalue);\n\n var _iteratorNormalCompletion = true;\n var _didIteratorError = false;\n var _iteratorError = undefined;\n\n try {\n for (var _iterator = this.aesthetics[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {\n var currentaes = _step.value;\n\n //if(currentaes._features.length > 0 || currentaes._allFeatures.length > 0){\n var row = document.createElement('tr');\n var value = document.createElement('td');\n var color = document.createElement('td');\n var ptext = document.createElement('p');\n var text = void 0;\n if (typeof currentaes.range[0] === 'number') text = document.createTextNode('[' + currentaes.range[0] + ', ' + currentaes.range[1] + '[');else text = document.createTextNode(currentaes.range[0]);\n ptext.appendChild(text);\n value.appendChild(ptext);\n\n var colorDiv = document.createElement('div');\n colorDiv.style.position = 'relative';\n var rgbc = 'rgba(' + currentaes.fillColor[0] + ',' + currentaes.fillColor[1] + ',' + currentaes.fillColor[2] + ',' + currentaes.fillColor[3] + ')';\n //console.log(rgbc);\n colorDiv.style['backgroundColor'] = rgbc;\n colorDiv.style.height = 25; //(mapCanvas.height / 10);\n colorDiv.style.width = 80; //(mapCanvas.width / 10);\n\n\n color.appendChild(colorDiv);\n\n row.appendChild(color);\n row.appendChild(value);\n\n table.appendChild(row);\n //}\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally {\n try {\n if (!_iteratorNormalCompletion && _iterator.return) {\n _iterator.return();\n }\n } finally {\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n\n legendDiv.appendChild(table);\n this.map.getContainer().appendChild(legendDiv);\n }\n }, {\n key: 'preProcessData',\n value: function preProcessData(geojson, numberOf, algorithm, colorscheme) {\n\n var aesarray = [];\n var values = [];\n var strings = [];\n var breaks = void 0;\n var fcolor = void 0;\n for (var g = 0; g < geojson.features.length && (this.maxfeatures == undefined || g < this.maxfeatures); g++) {\n if (geojson.features[g].properties[this.attr] != null && typeof geojson.features[g].properties[this.attr] == 'number') {\n values.push(geojson.features[g].properties[this.attr]);\n this.max = Math.max(this.max, geojson.features[g].properties[this.attr]);\n this.min = Math.min(this.min, geojson.features[g].properties[this.attr]);\n } else if (!strings.includes(geojson.features[g].properties[this.attr])) strings.push(geojson.features[g].properties[this.attr]);\n }\n if (values.length > 0) {\n //quantitative\n if (this.breaks == undefined) {\n if (numberOf > 1) breaks = this.calcClassBreaks(values, algorithm, numberOf);else breaks = [this.min, this.max];\n } else {\n breaks = this.breaks;\n }\n if (breaks.length > 2) {\n fcolor = chroma.scale(colorscheme).colors(breaks.length - 1);\n for (var i = 0; i < breaks.length - 1; i++) {\n var color = chroma(fcolor[i]).rgb();\n if (i != breaks.length - 2) {\n var aes = new _Aesthetic.Aesthetic(i, this.attr, [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), this.alpha], [0, 0, 0, 1], null, [breaks[i], breaks[i + 1]]);\n } else {\n var aes = new _Aesthetic.Aesthetic(i, this.attr, [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), this.alpha], [0, 0, 0, 1], null, [breaks[i], breaks[i + 1]]);\n aes.outer = true;\n }\n aesarray.push(aes);\n }\n } else {\n color = chroma(colorscheme[0]).rgb();\n var aes = new _Aesthetic.Aesthetic(i, this.attr, [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), this.alpha], [0, 0, 0, 1], null, [breaks[0], breaks[1]]);\n aes.outer = true;\n aesarray.push(aes);\n }\n } else {\n //qualitative\n if (strings.length > 0) {\n breaks = strings;\n if (typeof colorscheme === 'string') {\n //string\n fcolor = chroma.scale(colorscheme).colors(breaks.length);\n } else {\n //array\n fcolor = chroma.scale(colorscheme).colors(breaks.length);\n }\n for (var i = 0; i < breaks.length; i++) {\n var color = chroma(fcolor[i]).rgb();\n var aes = new _Aesthetic.Aesthetic(i, this.attr, [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), 1], [0, 0, 0, 1], null, [strings[i]]);\n aesarray.push(aes);\n }\n }\n }\n\n this.aesthetics = aesarray;\n //return aesarray;\n }\n }, {\n key: 'calcClassBreaks',\n value: function calcClassBreaks(values, algorithm, numberOf) {\n var breaks = void 0;\n switch (algorithm) {\n case 'equidistant':\n breaks = chroma.limits(values, 'e', numberOf);\n break;\n\n case 'quantile':\n breaks = chroma.limits(values, 'q', numberOf);\n break;\n\n case 'k-means':\n breaks = chroma.limits(values, 'k', numberOf);\n break;\n\n default:\n breaks = chroma.limits(values, 'q', numberOf);\n break;\n }\n return breaks;\n }\n\n /**\r\n * \r\n * @param {JSON} geojson \r\n */\n\n }, {\n key: 'processData',\n value: function processData(geojson) {\n this.loadGeoJSON(geojson);\n }\n }, {\n key: 'loadGeoJSON',\n value: function loadGeoJSON(geojson) {\n for (var g = 0; g < geojson.features.length && (this.maxfeatures == undefined || g < this.maxfeatures); g++) {\n geojson.features[g].properties['_gisplayid'] = g;\n var geometry = geojson.features[g].geometry;\n var properties = geojson.features[g].properties;\n this.createAndInsertFeature(g, geometry, properties);\n }\n this.buildTrees(geojson);\n }\n }, {\n key: 'createAndInsertFeature',\n value: function createAndInsertFeature(id, geometry, properties) {\n var gl = this._webgl.gl;\n if (this.minuend != undefined && this.subtrahend != undefined && typeof properties[this.minuend] == 'number' && properties[this.subtrahend] != undefined && typeof properties[this.subtrahend] == 'number' && properties[this.subtrahend] != undefined) {\n properties[this.attr] = properties[this.minuend] - properties[this.subtrahend];\n }\n\n if (geometry.type == \"Polygon\" || geometry.type == \"MultiPolygon\") {\n this.hasPolygons = true;\n var polygons = this.processPolygon({ geometry: geometry, properties: properties });\n\n var currentBorders = [];\n var currentTriangles = [];\n var bufferT = [];\n var bufferB = [];\n\n for (var j = 0; j < polygons.length; j++) {\n var trianglespolygon = polygons[j].triangles;\n var border = polygons[j].vertex;\n currentTriangles[j] = new Array();\n currentBorders[j] = new Array();\n for (var h = 0; h < trianglespolygon.length; h++) {\n var pixel = this.latLongToPixelXY(border[trianglespolygon[h] * 2], border[trianglespolygon[h] * 2 + 1]);\n currentTriangles[j].push(pixel.x, pixel.y);\n\n if (h == trianglespolygon.length - 1) {\n bufferT.push(gl.createBuffer());\n\n var vertArray = new Float32Array(currentTriangles[j]);\n\n gl.fsize = vertArray.BYTES_PER_ELEMENT;\n gl.bindBuffer(gl.ARRAY_BUFFER, bufferT[j]);\n gl.bufferData(gl.ARRAY_BUFFER, vertArray, gl.STATIC_DRAW);\n\n bufferT[j].itemSize = 2;\n bufferT[j].numItems = vertArray.length / 2;\n }\n }\n\n for (var y = 0; y < border.length; y += 2) {\n var pixel = this.latLongToPixelXY(border[y], border[y + 1]);\n currentBorders[j].push(pixel.x, pixel.y);\n\n if (y == border.length - 2) {\n bufferB.push(gl.createBuffer());\n\n var vertArray = new Float32Array(currentBorders[j]);\n\n gl.fsize = vertArray.BYTES_PER_ELEMENT;\n gl.bindBuffer(gl.ARRAY_BUFFER, bufferB[j]);\n gl.bufferData(gl.ARRAY_BUFFER, vertArray, gl.STATIC_DRAW);\n\n bufferB[j].itemSize = 2;\n bufferB[j].numItems = vertArray.length / 2;\n }\n }\n }\n //polygon\n this.insertFeature(id, properties, bufferT, bufferB, []);\n } else if (geometry.type == \"Point\" && this.dynamic == true) {\n //dum\n var currentPoints = [];\n currentPoints[0] = new Array();\n var pixel = this.latLongToPixelXY(geometry.coordinates[0], geometry.coordinates[1]);\n currentPoints[0].push(pixel.x, pixel.y);\n var bufferP = [];\n bufferP.push(gl.createBuffer());\n\n var vertArray = new Float32Array(currentPoints[0]);\n\n gl.fsize = vertArray.BYTES_PER_ELEMENT;\n gl.bindBuffer(gl.ARRAY_BUFFER, bufferP[0]);\n gl.bufferData(gl.ARRAY_BUFFER, vertArray, gl.STATIC_DRAW);\n\n bufferP[0].itemSize = 2;\n bufferP[0].numItems = vertArray.length / 2;\n\n this.insertFeature(id, properties, [], [], bufferP);\n\n if (this.treepoints == null || this.treepoints == undefined) this.treepoints = [];\n this.treepoints.push({ lon: geometry.coordinates[0], lat: geometry.coordinates[1], properties: properties });\n } else if (geometry.type == \"Point\" && this.dynamic == false) {\n //debugger;\n var pixel = this.latLongToPixelXY(geometry.coordinates[0], geometry.coordinates[1]);\n if (this.tempPoints == null || this.tempPoints == undefined) {\n this.tempPoints = new Array();\n for (var a = 0; a < this.aesthetics.length; a++) {\n this.tempPoints[a] = [];\n }\n }\n\n var aesarrays = this.fitFeature(properties);\n for (var y = 0; y < aesarrays.length; y++) {\n this.tempPoints[aesarrays[y]].push(pixel.x, pixel.y);\n }\n\n if (this.treepoints == null) this.treepoints = [];\n this.treepoints.push({ lon: geometry.coordinates[0], lat: geometry.coordinates[1], properties: properties });\n }\n }\n }, {\n key: 'processPolygon',\n value: function processPolygon(polygon) {\n if (polygon.geometry.type == \"Polygon\") {\n var outsidepolygon = polygon.geometry.coordinates[0];\n\n var insidepolygons = [];\n for (var k = 1; k < polygon.geometry.coordinates.length; k++) {\n //todo inside polygon\n //insidepolygons.push(polygon.geometry.coordinates[i][k]);\n }\n var tempVerts = new Array();\n for (var out = 0; out < outsidepolygon.length - 1; out++) {\n tempVerts.push(outsidepolygon[out][0], outsidepolygon[out][1]);\n _vertexcount += (outsidepolygon.length + 1) / 2;\n //console.log(\"lon: \" + outsidepolygon[out][0] + \" lat: \" + outsidepolygon[out][1]);\n }\n\n var triangles_vert = earcut(tempVerts);\n _tricount += triangles_vert.length / 3;\n polyarray.push({ triangles: triangles_vert, vertex: tempVerts });\n } else if (polygon.geometry.type == \"MultiPolygon\") {\n var polyarray = [];\n for (var i = 0; i < polygon.geometry.coordinates.length; i++) {\n\n var outsidepolygon = polygon.geometry.coordinates[i][0];\n\n var insidepolygons = [];\n for (var k = 1; k < polygon.geometry.coordinates[i].length; k++) {\n //todo inside polygon\n insidepolygons.push(polygon.geometry.coordinates[i][k]);\n }\n var tempVerts = new Array();\n _vertexcount += outsidepolygon.length;\n for (var out = 0; out < outsidepolygon.length - 1; out++) {\n tempVerts.push(outsidepolygon[out][0], outsidepolygon[out][1]);\n\n //console.log(\"lon: \" + outsidepolygon[out][0] + \" lat: \" + outsidepolygon[out][1]);\n }\n\n var triangles_vert = earcut(tempVerts);\n //var temp = earcut.flatten(polygon.geometry.coordinates[i]);\n //var triangles_vert = earcut(temp.vertices, temp.holes, temp.dimensions);\n _tricount += triangles_vert.length / 3;\n polyarray.push({ triangles: triangles_vert, vertex: tempVerts });\n //console.log(polyarray);\n }\n return polyarray;\n }\n }\n }, {\n key: 'insertFeature',\n value: function insertFeature(id, properties, triangles, borders, points) {\n var flag = false;\n for (var i = 0; i < this.aesthetics.length; i++) {\n if (this.aesthetics[i].checkProperty(properties[this.aesthetics[i].getAttr()]) == true) {\n this.aesthetics[i].addFeature(id, properties, triangles, borders, points);\n flag = true;\n }\n }\n if (!flag) {\n //TODO\n //console.log(\"TODO: feature does not fit into any of the aesthetics defined.\\n Value: \" + properties[this.attr]);\n }\n }\n }, {\n key: 'latLongToPixelXY',\n value: function latLongToPixelXY(longitude, latitude) {\n var pi_180 = Math.PI / 180.0;\n var pi_4 = Math.PI * 4;\n var sinLatitude = Math.sin(latitude * pi_180);\n var pixelY = (0.5 - Math.log((1 + sinLatitude) / (1 - sinLatitude)) / pi_4) * 256;\n var pixelX = (longitude + 180) / 360 * 256;\n\n var pixel = { x: pixelX, y: pixelY };\n return pixel;\n }\n }, {\n key: 'fitFeature',\n value: function fitFeature(properties) {\n var result = [];\n for (var a = 0; a < this.aesthetics.length; a++) {\n if (this.aesthetics[a].checkProperty(properties[this.aesthetics[a].getAttr()]) == true) result.push(a);\n }\n return result;\n }\n }, {\n key: 'buildTrees',\n value: function buildTrees(geojson) {\n var gl = this._webgl.gl;\n if (this.tempPoints != null) {\n for (var t = 0; t < this.tempPoints.length; t++) {\n if (this.tempPoints[t].length > 0) {\n var bufferP = [];\n bufferP.push(gl.createBuffer());\n\n var vertArray = new Float32Array(this.tempPoints[t]);\n\n gl.fsize = vertArray.BYTES_PER_ELEMENT;\n gl.bindBuffer(gl.ARRAY_BUFFER, bufferP[0]);\n gl.bufferData(gl.ARRAY_BUFFER, vertArray, gl.STATIC_DRAW);\n\n bufferP[0].itemSize = 2;\n bufferP[0].numItems = vertArray.length / 2;\n this.insertGroupedFeature(t, [], [], bufferP);\n }\n }\n }\n //console.log(geojson)\n if (this.treepoints != null) this.kdtree = new kdTree(this.treepoints, function (a, b) {\n return (a.lon - b.lon) ** 2 + (a.lat - b.lat) ** 2;\n }, [\"lon\", \"lat\", \"properties\"]);\n if (this.hasPolygons == true) this.rtree = new PolygonLookup(geojson);\n }\n }, {\n key: 'insertGroupedFeature',\n value: function insertGroupedFeature(idaes, triangles, borders, points) {\n this.aesthetics[idaes].addGroupedFeature(null, triangles, borders, points);\n }\n }, {\n key: 'createCanvas',\n value: function createCanvas() {\n var canvas = this.map.createCanvas(this.id);\n\n //init webgl properties\n this._webgl = {\n gl: null,\n program: null,\n projection: null\n };\n\n this._webgl.gl = canvas.getContext(\"webgl\");\n this._webgl.projection = new Float32Array(16);\n this._webgl.projection.set([2 / canvas.width, 0, 0, 0, 0, -2 / canvas.height, 0, 0, 0, 0, 0, 0, -1, 1, 0, 1]);\n\n this._webgl.gl.viewport(0, 0, this.map.getContainer().offsetWidth, this.map.getContainer().offsetHeight);\n this._webgl.gl.disable(this._webgl.gl.DEPTH_TEST);\n }\n }, {\n key: 'getNumberOfFeatures',\n value: function getNumberOfFeatures() {\n var count = 0;\n for (var i = 0; i < this.aesthetics.length; i++) {\n count += this.aesthetics[i]._features.length;\n }\n return count;\n }\n }, {\n key: 'scaleProjection',\n value: function scaleProjection(matrix, scaleX, scaleY) {\n // scaling x and y, which is just scaling first two rows of matrix\n matrix[0] *= scaleX;\n matrix[1] *= scaleX;\n matrix[2] *= scaleX;\n matrix[3] *= scaleX;\n\n matrix[4] *= scaleY;\n matrix[5] *= scaleY;\n matrix[6] *= scaleY;\n matrix[7] *= scaleY;\n }\n }, {\n key: 'translateProjection',\n value: function translateProjection(matrix, tx, ty) {\n // translation is in last row of matrix\n matrix[12] += matrix[0] * tx + matrix[4] * ty;\n matrix[13] += matrix[1] * tx + matrix[5] * ty;\n matrix[14] += matrix[2] * tx + matrix[6] * ty;\n matrix[15] += matrix[3] * tx + matrix[7] * ty;\n }\n }, {\n key: 'clear',\n value: function clear() {\n var gl = this._webgl.gl;\n gl.clear(gl.COLOR_BUFFER_BIT);\n gl.disable(gl.DEPTH_TEST);\n }\n }, {\n key: 'drawTriangles',\n value: function drawTriangles(aes) {\n var gl = this._webgl.gl;\n if (gl == null) return;\n var matrixProjection = new Float32Array(16);\n\n //gl.clear(gl.COLOR_BUFFER_BIT);\n //gl.disable(gl.DEPTH_TEST);\n\n //gl.enable(gl.BLEND);\n //gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\n\n\n var currentZoom = this.map.getZoom();\n var pointSize = Math.max(currentZoom - 5.0, 1.0);\n\n matrixProjection.set(this._webgl.projection);\n\n var scale = 2 ** currentZoom;\n this.scaleProjection(matrixProjection, scale, scale);\n\n var offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\n this.translateProjection(matrixProjection, -offset.x, -offset.y);\n\n var projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\n gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\n\n var vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\n gl.vertexAttrib1f(vertexSizeLocation, pointSize);\n\n var isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\n gl.uniform1f(isPointLocation, 0.0);\n\n var vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\n\n var vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\n\n /** \r\n * \r\n * Draw Polygons' Interior\r\n * **/\n var fsize = Float32Array.BYTES_PER_ELEMENT;\n //console.log(\"Numero de Buffers: \", buffers.length);\n\n gl.uniform4f(vertexColorLocation, aes.fillColor[0] / 255, aes.fillColor[1] / 255, aes.fillColor[2] / 255, aes.fillColor[3]);\n\n for (var i = 0; i < aes._features.length; i++) {\n for (var y = 0; y < aes._features[i]._triangles.length; y++) {\n\n gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._triangles[y]);\n\n gl.enableVertexAttribArray(vertexCoordLocation);\n gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\n //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\n //gl.enableVertexAttribArray(vertexColorLocation);\n\n\n gl.drawArrays(gl.TRIANGLES, 0, aes._features[i]._triangles[y].numItems);\n }\n }\n }\n }, {\n key: 'drawBorders',\n value: function drawBorders(aes) {\n var gl = this._webgl.gl;\n if (gl == null) return;\n var matrixProjection = new Float32Array(16);\n\n //gl.clear(gl.COLOR_BUFFER_BIT);\n //gl.disable(gl.DEPTH_TEST);\n\n gl.enable(gl.BLEND);\n gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\n\n var currentZoom = this.map.getZoom();\n var pointSize = Math.max(currentZoom - 5.0, 1.0);\n\n matrixProjection.set(this._webgl.projection);\n\n var scale = 2 ** currentZoom;\n this.scaleProjection(matrixProjection, scale, scale);\n\n var offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\n this.translateProjection(matrixProjection, -offset.x, -offset.y);\n\n var projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\n gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\n\n var vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\n gl.vertexAttrib1f(vertexSizeLocation, pointSize);\n\n var vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\n\n var vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\n\n var isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\n gl.uniform1f(isPointLocation, 0.0);\n\n /** \r\n * \r\n * Draw Polygons' Interior\r\n * **/\n var fsize = Float32Array.BYTES_PER_ELEMENT;\n //console.log(\"Numero de Buffers: \", buffers.length);\n\n gl.uniform4f(vertexColorLocation, aes.strokeColor[0] / 255, aes.strokeColor[1] / 255, aes.strokeColor[2] / 255, aes.strokeColor[3]);\n\n for (var i = 0; i < aes._features.length; i++) {\n for (var y = 0; y < aes._features[i]._borders.length; y++) {\n\n gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._borders[y]);\n\n gl.enableVertexAttribArray(vertexCoordLocation);\n gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\n //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\n //gl.enableVertexAttribArray(vertexColorLocation);\n\n\n gl.drawArrays(gl.LINE_LOOP, 0, aes._features[i]._borders[y].numItems);\n }\n }\n }\n }, {\n key: 'drawPoints',\n value: function drawPoints(aes) {\n\n var gl = this._webgl.gl;\n if (gl == null) return;\n var matrixProjection = new Float32Array(16);\n\n //gl.clear(gl.COLOR_BUFFER_BIT);\n //gl.disable(gl.DEPTH_TEST);\n\n gl.enable(gl.BLEND);\n gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\n\n var currentZoom = this.map.getZoom();\n var pointSize = Math.max(currentZoom - 4.0 + aes.pointSize, aes.pointSize);\n\n matrixProjection.set(this._webgl.projection);\n\n var scale = 2 ** currentZoom;\n this.scaleProjection(matrixProjection, scale, scale);\n\n var offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\n this.translateProjection(matrixProjection, -offset.x, -offset.y);\n\n var projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\n gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\n\n var vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\n gl.vertexAttrib1f(vertexSizeLocation, pointSize);\n\n var vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\n\n var vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\n\n var isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\n gl.uniform1f(isPointLocation, 1.0);\n\n /** \r\n * \r\n * Draw Polygons' Interior\r\n * **/\n var fsize = Float32Array.BYTES_PER_ELEMENT;\n //console.log(\"Numero de Buffers: \", buffers.length);\n\n gl.uniform4f(vertexColorLocation, aes.fillColor[0] / 255, aes.fillColor[1] / 255, aes.fillColor[2] / 255, aes.fillColor[3]);\n\n for (var i = 0; i < aes._features.length && this.dynamic == true; i++) {\n for (var y = 0; y < aes._features[i]._points.length; y++) {\n\n gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._points[y]);\n\n gl.enableVertexAttribArray(vertexCoordLocation);\n gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\n //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\n //gl.enableVertexAttribArray(vertexColorLocation);\n\n\n gl.drawArrays(gl.POINTS, 0, aes._features[i]._points[y].numItems);\n //1);\n }\n }\n\n for (var i = 0; this.dynamic == false && aes._allFeatures != null && i < aes._allFeatures.length; i++) {\n for (var y = 0; y < aes._allFeatures[i]._points.length; y++) {\n\n gl.bindBuffer(gl.ARRAY_BUFFER, aes._allFeatures[i]._points[y]);\n\n gl.enableVertexAttribArray(vertexCoordLocation);\n gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\n //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\n //gl.enableVertexAttribArray(vertexColorLocation);\n\n\n gl.drawArrays(gl.POINTS, 0, aes._allFeatures[i]._points[y].numItems);\n //gl.drawArrays(gl.TRIANGLE_STRIP, 0, aes._allFeatures[i]._points[y].numItems-2);\t\n //1);\n }\n }\n }\n }, {\n key: 'drawContinuousPolygons',\n value: function drawContinuousPolygons(aes) {\n\n var gl = this._webgl.gl;\n if (gl == null) return;\n var matrixProjection = new Float32Array(16);\n\n //gl.clear(gl.COLOR_BUFFER_BIT);\n //gl.disable(gl.DEPTH_TEST);\n\n //gl.enable(gl.BLEND);\n //gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\n\n\n var currentZoom = this.map.getZoom();\n var pointSize = Math.max(currentZoom - 5.0, 1.0);\n\n matrixProjection.set(this._webgl.projection);\n\n var scale = 2 ** currentZoom;\n this.scaleProjection(matrixProjection, scale, scale);\n\n var offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\n this.translateProjection(matrixProjection, -offset.x, -offset.y);\n\n var projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\n gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\n\n var vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\n gl.vertexAttrib1f(vertexSizeLocation, pointSize);\n\n var isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\n gl.uniform1f(isPointLocation, 0.0);\n\n var vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\n\n var vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\n\n /** \r\n * \r\n * Draw Polygons' Interior\r\n * **/\n var fsize = Float32Array.BYTES_PER_ELEMENT;\n //console.log(\"Numero de Buffers: \", buffers.length);\n\n\n for (var i = 0; i < aes._features.length; i++) {\n var ucolor = void 0;\n var color = void 0;\n var diff = aes._features[i]._properties[this.attr];\n if (diff == 0) color = aes.fillColor(0.5).rgb();else {\n if (diff > 0) {\n color = aes.fillColor(0.5 + diff / this.max / 2).rgb();\n } else {\n color = aes.fillColor(0.5 - diff / this.min / 2).rgb();\n }\n }\n ucolor = [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), this.alpha];\n\n gl.uniform4f(vertexColorLocation, ucolor[0] / 255, ucolor[1] / 255, ucolor[2] / 255, this.alpha);\n for (var y = 0; y < aes._features[i]._triangles.length; y++) {\n\n gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._triangles[y]);\n\n gl.enableVertexAttribArray(vertexCoordLocation);\n gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\n //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\n //gl.enableVertexAttribArray(vertexColorLocation);\n\n\n gl.drawArrays(gl.TRIANGLES, 0, aes._features[i]._triangles[y].numItems);\n }\n }\n }\n }, {\n key: 'drawProporcionalPoints',\n value: function drawProporcionalPoints(aes) {\n\n var gl = this._webgl.gl;\n if (gl == null) return;\n var matrixProjection = new Float32Array(16);\n\n gl.enable(gl.BLEND);\n gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\n\n var currentZoom = this.map.getZoom();\n\n matrixProjection.set(this._webgl.projection);\n\n var scale = 2 ** currentZoom;\n this.scaleProjection(matrixProjection, scale, scale);\n\n var offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\n this.translateProjection(matrixProjection, -offset.x, -offset.y);\n\n var projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\n gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\n\n var vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\n\n var vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\n\n var isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\n gl.uniform1f(isPointLocation, 1.0);\n\n /** \r\n * \r\n * Draw Polygons' Interior\r\n * **/\n var fsize = Float32Array.BYTES_PER_ELEMENT;\n //console.log(\"Numero de Buffers: \", buffers.length);\n\n gl.uniform4f(vertexColorLocation, aes.fillColor[0] / 255, aes.fillColor[1] / 255, aes.fillColor[2] / 255, this.alpha);\n\n if (this.dynamic == true) {\n for (var i in aes._features) {\n for (var y in aes._features[i]._points) {\n\n gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._points[y]);\n var propvalue = parseFloat(aes._features[i]._properties[this.attr]);\n var temppointsize = (this.maxpointsize - this.minpointsize) / (this.max - this.min) * (propvalue - this.min);\n var pointSize = Math.max(currentZoom - 4.0 + temppointsize * currentZoom / 4, 2);\n var vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\n gl.vertexAttrib1f(vertexSizeLocation, pointSize);\n\n gl.enableVertexAttribArray(vertexCoordLocation);\n gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\n //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\n //gl.enableVertexAttribArray(vertexColorLocation);\n\n\n gl.drawArrays(gl.POINTS, 0, aes._features[i]._points[y].numItems);\n //1);\n }\n }\n }\n }\n }, {\n key: 'initialize',\n value: function initialize() {\n this.max = null;\n this.min = null;\n this.createCanvas();\n this.program();\n var mappos = void 0;\n for (var i = 0; i < maps.length; i++) {\n if (maps[i].id == this.id) mappos = i;\n }this.map.onEvent('move', function () {\n console.log(\"@Rui: mudar o profiling do window para outra coisa?\");\n if (window.profiling == true) var start = Date.now();\n maps[mappos].draw();\n if (window.profiling == true) {\n var end = Date.now();\n window.console.log('Tempo de processamento de Zoom/Pan (segundos):' + (end - start) / 1000);\n }\n });\n\n this.setupOnclick(mappos);\n }\n }, {\n key: 'setupOnclick',\n value: function setupOnclick(mappos) {\n console.log(\"@Rui: profiling mudar de window para? | Rtree e KdTree\");\n maps[mappos].map.onEvent('click', function (e) {\n if (window.profiling == true) var start = Date.now();\n var lat = e.latlng.lat;\n var lon = e.latlng.lng;\n\n if (maps[mappos].rtree != undefined) {\n var bool = maps[0].rtree.search(lon, lat);\n if (bool == undefined) return;else {\n //console.log\n var s = \"\";\n var first = true;\n if (maps[mappos].showPropertiesOnClick != null) {\n for (var i = 0; i < maps[mappos].showPropertiesOnClick.length; i += 2) {\n if (first) {\n s += maps[mappos].showPropertiesOnClick[i + 1] + ': ' + bool.properties[maps[mappos].showPropertiesOnClick[i]];\n first = false;\n } else {\n s += '\\n' + maps[mappos].showPropertiesOnClick[i + 1] + ': ' + bool.properties[maps[mappos].showPropertiesOnClick[i]];\n }\n }\n } else {\n\n var keys = Object.keys(bool.properties);\n\n for (var i = 0; i < keys.length; i++) {\n if (keys[i] != \"_gisplayid\") {\n if (first) {\n s += keys[i] + ': ' + bool.properties[keys[i]];\n first = false;\n } else {\n s += '\\n' + keys[i] + ': ' + bool.properties[keys[i]];\n }\n }\n }\n }\n if (maps[mappos].interactive == true) alert(s); //todo\n if (maps[mappos].mapOnClickCall != undefined && maps[mappos].mapOnClickCall != null) maps[mappos].mapOnClickCall(bool);\n }\n }\n if (maps[mappos].kdtree != undefined) {\n\n var nearest = maps[mappos].kdtree.nearest({ lat: lat, lon: lon }, 1, 128 / 2 ** (map.getZoom() * 2));\n if (nearest.length <= 0) return;else {\n var bool = nearest[0][0];\n //console.log\n var s = \"\";\n var first = true;\n if (maps[mappos].showPropertiesOnClick != null) {\n for (var i = 0; i < maps[mappos].showPropertiesOnClick.length; i += 2) {\n if (first) {\n s += maps[mappos].showPropertiesOnClick[i + 1] + ': ' + bool.properties[maps[mappos].showPropertiesOnClick[i]];\n first = false;\n } else {\n s += '\\n' + maps[mappos].showPropertiesOnClick[i + 1] + ': ' + bool.properties[maps[mappos].showPropertiesOnClick[i]];\n }\n }\n } else {\n\n var keys = Object.keys(bool.properties);\n\n for (var i = 0; i < keys.length; i++) {\n if (keys[i] != \"_gisplayid\") {\n if (first) {\n s += keys[i] + ': ' + bool.properties[keys[i]];\n first = false;\n } else {\n s += '\\n' + keys[i] + ': ' + bool.properties[keys[i]];\n }\n }\n }\n }\n if (maps[mappos].interactive == true) alert(s);\n if (maps[mappos].mapOnClickCall != undefined && maps[mappos].mapOnClickCall != null) maps[mappos].mapOnClickCall(bool);\n }\n }\n\n if (window.profiling == true) {\n var end = Date.now();\n window.console.log('Tempo de processamento de um click (segundos): ' + (end - start) / 1000);\n }\n });\n }\n }, {\n key: 'loadOptions',\n value: function loadOptions(options, bgmap) {\n if (options.customMapService == true) this.map = bgmap;else this.map = new _BGMapWrapper.BGMapWrapper(bgmap);\n if (options.loader != false) this.loader();\n\n if (options.showPropertiesOnClick == true) {\n this.showPropertiesOnClick = null;\n //append on bgmap object\n } else if (options.showPropertiesOnClick == false) {\n //nada\n } else if (options.showPropertiesOnClick != undefined) {\n this.showPropertiesOnClick = options.showPropertiesOnClick;\n }\n this.alpha = options.alpha != undefined ? options.alpha : 0.8;\n this.interactive = options.interactive == undefined ? true : !options.interactive;\n this.attr = options.attr;\n this.dynamic = options.memorySaver == undefined ? false : !options.memorySaver;\n this.maxfeatures = options.maxFeatures;\n this.breaks = options.classBreaks;\n this.colorscheme = options.colorScheme;\n this.numberofclasses = options.numberOfClasses;\n this.algorithm = options.classBreaksMethod;\n this.legendOnClickCall = options.legendOnClickFunction;\n this.mapOnClickCall = options.mapOnClickFunction;\n this.minuend = options.minuend;\n this.subtrahend = options.subtrahend;\n this.legendTitle = options.legendTitle != undefined ? options.legendTitle : this.attr != undefined ? this.attr : this.minuend + ' - ' + this.subtrahend;\n this.numberOfLegendItems = options.numberOfLegendItems != undefined ? options.numberOfLegendItems : 2;\n }\n }, {\n key: 'loader',\n value: function loader() {\n this.map.loader();\n }\n }, {\n key: 'getNumberOfPolygons',\n value: function getNumberOfPolygons() {\n var count = 0;\n for (var i = 0; i < this.aesthetics.length; i++) {\n for (var z = 0; z < this.aesthetics[i]._features.length; z++) {\n count += this.aesthetics[i]._features[z]._triangles.length;\n }\n }\n return count;\n }\n\n //STATIC METHODS(should be implemented by sub-classes)\n\n }, {\n key: 'draw',\n value: function draw() {\n alert(\"draw() not implemented\"); //throw new NotImplementedError();\n }\n\n /**\r\n * @deprecated This was created for Heat Maps. Another idea will probably be used.\r\n * @param {Aesthetic} aes \r\n */\n\n }, {\n key: 'drawHeatPoints',\n value: function drawHeatPoints(aes) {\n var gl = this._webgl.gl;\n\n if (gl == null) return;\n gl.useProgram(this._webgl.heatmapProgram[0]);\n var matrixProjection = new Float32Array(16);\n\n gl.clear(gl.COLOR_BUFFER_BIT);\n gl.enable(gl.BLEND);\n\n gl.blendFunc(gl.ONE, gl.ONE);\n\n var currentZoom = map.getZoom();\n var pointSize = Math.max(currentZoom - 5.0, 1.0);\n\n matrixProjection.set(this._webgl.projection);\n\n var scale = 2 ** currentZoom;\n this.scaleProjection(matrixProjection, scale, scale);\n\n var offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\n this.translateProjection(matrixProjection, -offset.x, -offset.y);\n\n var projectionLocation = gl.getUniformLocation(this._webgl.heatmapProgram[0], 'projection');\n gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\n\n var vertexCoordLocation = gl.getAttribLocation(this._webgl.heatmapProgram[0], 'position');\n var deltaLocation = gl.getAttribLocation(this._webgl.heatmapProgram[0], 'delta');\n var intensityLoc = gl.getAttribLocation(this._webgl.heatmapProgram[0], 'intensity');\n var vertexSizeLocation = gl.getAttribLocation(this._webgl.heatmapProgram[0], 'aPointSize');\n\n gl.vertexAttrib1f(vertexSizeLocation, pointSize);\n\n gl.enableVertexAttribArray(vertexCoordLocation);\n gl.enableVertexAttribArray(deltaLocation);\n gl.enableVertexAttribArray(intensityLoc);\n\n var fsize = Float32Array.BYTES_PER_ELEMENT;\n\n gl.bindBuffer(gl.ARRAY_BUFFER, aes._allFeatures[0]._points[0]);\n gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 8, 0 * 2);\n gl.vertexAttribPointer(deltaLocation, 2, gl.FLOAT, false, fsize * 8, 2 * 4);\n gl.vertexAttribPointer(intensityLoc, 4, gl.FLOAT, false, fsize * 8, 4 * 4);\n\n console.log(aes._allFeatures[0]._points[0].numItems);\n gl.drawArrays(gl.TRIANGLES, 0, aes._allFeatures[0]._points[0].numItems);\n\n gl.useProgram(this._webgl.heatmapProgram[1]);\n\n gl.disable(gl.BLEND);\n\n //console.log(\"fase 1 concluida\");\n\n var canvas = document.getElementById('mapCanvas' + this.id);\n\n var source = gl.createTexture();\n\n gl.activeTexture(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, source);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, canvas);\n\n function isPowerOf2(value) {\n return (value & value - 1) == 0;\n };\n\n function steupTextureFilteringAndMips(width, height, gl) {\n if (isPowerOf2(width) && isPowerOf2(height)) {\n // the dimensions are power of 2 so generate mips and turn on \n // tri-linear filtering.\n gl.generateMipmap(gl.TEXTURE_2D);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR_MIPMAP_LINEAR);\n } else {\n // at least one of the dimensions is not a power of 2 so set the filtering\n // so WebGL will render it.\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n }\n };\n\n steupTextureFilteringAndMips(canvas.width, canvas.height, gl);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n\n var vertices = new Float32Array([1, 1, -1, 1, -1, -1, 1, 1, -1, -1, 1, -1]);\n var buffer = gl.createBuffer();\n gl.bindBuffer(gl.ARRAY_BUFFER, buffer);\n gl.bufferData(gl.ARRAY_BUFFER, vertices, gl.STATIC_DRAW);\n var positionLoc = gl.getAttribLocation(this._webgl.heatmapProgram[1], 'position');\n var sourceLoc = gl.getUniformLocation(this._webgl.heatmapProgram[1], 'source');\n gl.enableVertexAttribArray(positionLoc);\n gl.vertexAttribPointer(positionLoc, 2, gl.FLOAT, false, 0, 0);\n gl.uniform1i(sourceLoc, 0);\n gl.drawArrays(gl.TRIANGLES, 0, 6);\n\n gl.disableVertexAttribArray(positionLoc);\n //defaults to general program\n //console.log(\"fase 2 concluida\");\n gl.bindBuffer(gl.ARRAY_BUFFER, null);\n this._webgl.gl.useProgram(this._webgl.program);\n }\n }]);\n\n return Map;\n}();//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"1.js","sources":["webpack:///src/Gisplay/Maps/Map.js?1d60"],"sourcesContent":["import { BGMapWrapper } from './BGMapWrapper';\r\nimport { Aesthetic } from '../Aesthetic';\r\n\r\n/**\r\n * This class contains the Map class which represents the current map.\r\n * Each map has a group of functions available. There is only one map yet(maybe there will be two if we want to compare two).\r\n */\r\nexport class Map {\r\n\r\n    constructor(type, geometry, options) {\r\n        console.log(\"Map constructor called -> super()\")\r\n    }\r\n\r\n    program() {\r\n        this._webgl.program = this._webgl.gl.createProgram();\r\n        this._webgl.heatmapProgram = [];\r\n        this._webgl.heatmapProgram[0] = this._webgl.gl.createProgram();\r\n        this._webgl.heatmapProgram[1] = this._webgl.gl.createProgram();\r\n\r\n        const source_code = this.generateShaders();\r\n\r\n        const vertex_shader = this.shader(this._webgl.gl.VERTEX_SHADER, source_code.vertex, this._webgl);\r\n        const fragment_shader = this.shader(this._webgl.gl.FRAGMENT_SHADER, source_code.fragment, this._webgl);\r\n\r\n        this._webgl.gl.attachShader(this._webgl.program, vertex_shader);\r\n        this._webgl.gl.attachShader(this._webgl.program, fragment_shader);\r\n\r\n        this._webgl.gl.linkProgram(this._webgl.program);\r\n        this._webgl.gl.useProgram(this._webgl.program);\r\n    }\r\n\r\n\r\n    shader(type, source_code, _webgl) { //Added HERE by Rui\r\n        var shader = _webgl.gl.createShader(type);\r\n\r\n        _webgl.gl.shaderSource(shader, source_code);\r\n        _webgl.gl.compileShader(shader);\r\n\r\n        console.log(\"shader \" + (type.valueOf() == 35633 ? \"vertex\" : \"fragment\") + \": \" + _webgl.gl.getShaderInfoLog(shader));\r\n\r\n        return shader;\r\n    }\r\n\r\n    generateShaders() { //Added HERE by Rui @TODO Refactor to use ES6 `` instead of +=\r\n        //general\r\n\r\n        let vertexSourceCode = \" attribute vec4 vertexCoord; \";\r\n        vertexSourceCode += \"\\n\tattribute float aPointSize; \";\r\n        vertexSourceCode += \"\\n\tuniform mat4 projection; \";\r\n        vertexSourceCode += \"\\n\tattribute float a_opacity; \";\r\n        vertexSourceCode += \"\\n\tvarying float v_opacity; \";\r\n        //vertexSourceCode+= \"\\n\tvarying vec4 u_color; \" ; //delete\r\n        vertexSourceCode += \"\\n\tvoid main() {\";\r\n        vertexSourceCode += \"\\n\t\tgl_Position = (projection * vertexCoord); \";\r\n        vertexSourceCode += \"\\n\t\tgl_PointSize = aPointSize; v_opacity = a_opacity; \";\r\n        vertexSourceCode += \"\\n}\";\r\n\r\n        let fragmentSourceCode = \"precision mediump float;\";\r\n        fragmentSourceCode += \"\\n\t\tuniform vec4 u_color;\";//uniform\r\n        fragmentSourceCode += \"\\n\t\tvarying float v_opacity; \";\r\n        fragmentSourceCode += \"\\n \t\tuniform float isPoint;\";\r\n        fragmentSourceCode += \"\\n\t\tvoid main(){\";\r\n        fragmentSourceCode += \"\\n\t\t\tfloat border = 0.5;\";\r\n        fragmentSourceCode += \"\\n\t\t\tfloat radius = 0.5;\";\r\n        fragmentSourceCode += \"\\n\t\t\tfloat centerDist = length(gl_PointCoord - 0.5);\";\r\n        fragmentSourceCode += \"\\n\t\t\tfloat alpha;\";\r\n        fragmentSourceCode += \"\\n\t\t\tif (u_color[3] == -1.0){\";   //unnecessary??\r\n        fragmentSourceCode += \"\\n\t\t\t\talpha =  v_opacity * step(centerDist, radius);\";//unnecessary??\r\n        fragmentSourceCode += \"\\n\t\t\t}\";//unnecessary??\r\n        fragmentSourceCode += \"\\n\t\t\telse{\";//unnecessary??\r\n        fragmentSourceCode += \"\\n\t\t\t\talpha =  u_color[3] * step(centerDist, radius);\";\r\n        fragmentSourceCode += \"\\n\t\t\t}\";//unnecessary??\r\n        fragmentSourceCode += \"\\n\t\t\tif(isPoint == 1.0 ){\";\r\n        fragmentSourceCode += \"\\n\t\t\tif (alpha < 0.1) discard;\";\r\n        fragmentSourceCode += \"\\n\t\t\t\tgl_FragColor = vec4(u_color[0], u_color[1], u_color[2], alpha);}\";\r\n        fragmentSourceCode += \"\\n \t\t\telse\";\r\n        fragmentSourceCode += \"\\n\t\t\t\tgl_FragColor = vec4(u_color[0], u_color[1], u_color[2], u_color[3]);\";\r\n        fragmentSourceCode += \"\\n\t\t}\";\r\n\r\n        return { vertex: vertexSourceCode, fragment: fragmentSourceCode };\r\n    }\r\n\r\n    addAesthetic(aes) {\r\n        this.aesthetics.push(aes);\r\n    }\r\n\r\n    setAesthetic(id, aes) {\r\n        for (let i = 0; i < aesthetics.length; i++) {\r\n            if (id == aesthetics[i].id) {\r\n                aesthetics[i] = aes;\r\n                break;\r\n            }\r\n        }\r\n    }\r\n\r\n    buildLegend() {\r\n        const mapCanvas = document.getElementById(`mapCanvas${this.id}`);\r\n        const legendDiv = document.createElement('div');\r\n        legendDiv.id = `legendDiv${this.id}`;\r\n        legendDiv.style.position = 'absolute';\r\n        legendDiv.style.backgroundColor = 'white';\r\n        //legendDiv.style.height = 200;//(mapCanvas.height / 10);\r\n        legendDiv.style.width = 250;//(mapCanvas.width / 10);\r\n        legendDiv.style.bottom = 20;\r\n        legendDiv.style.right = 0;\r\n        legendDiv.style.borderColor = 'black';\r\n        legendDiv.style.border = 'solid';\r\n\r\n        const table = document.createElement('table');\r\n        const thvalue = document.createElement('th');\r\n        const thcolor = document.createElement('th');\r\n        //thvalue.style.width = 125;\r\n        table.style.zIndex = \"2000\";\r\n        thcolor.style.width = 100;\r\n        table.appendChild(thcolor);\r\n        table.appendChild(thvalue);\r\n\r\n\r\n        for (const currentaes of this.aesthetics) {\r\n            //if(currentaes._features.length > 0 || currentaes._allFeatures.length > 0){\r\n            const row = document.createElement('tr');\r\n            const value = document.createElement('td');\r\n            const color = document.createElement('td');\r\n            const ptext = document.createElement('p');\r\n            let text;\r\n            if (typeof currentaes.range[0] === 'number')\r\n                text = document.createTextNode(`[${currentaes.range[0]}, ${currentaes.range[1]}[`);\r\n            else\r\n                text = document.createTextNode(currentaes.range[0]);\r\n            ptext.appendChild(text);\r\n            value.appendChild(ptext);\r\n\r\n            const colorDiv = document.createElement('div');\r\n            colorDiv.style.position = 'relative';\r\n            const rgbc = `rgba(${currentaes.fillColor[0]},${currentaes.fillColor[1]},${currentaes.fillColor[2]},${currentaes.fillColor[3]})`;\r\n            //console.log(rgbc);\r\n            colorDiv.style['backgroundColor'] = rgbc;\r\n            colorDiv.style.height = 25;//(mapCanvas.height / 10);\r\n            colorDiv.style.width = 80;//(mapCanvas.width / 10);\r\n\r\n\r\n\r\n            color.appendChild(colorDiv);\r\n\r\n            row.appendChild(color);\r\n            row.appendChild(value);\r\n\r\n            table.appendChild(row);\r\n            //}\r\n        }\r\n\r\n        legendDiv.appendChild(table);\r\n        this.map.getContainer().appendChild(legendDiv);\r\n    }\r\n\r\n    preProcessData(geojson, numberOf, algorithm, colorscheme) {\r\n\r\n        const aesarray = [];\r\n        const values = [];\r\n        const strings = [];\r\n        let breaks;\r\n        let fcolor;\r\n        for (let g = 0; g < geojson.features.length && (this.maxfeatures == undefined || g < this.maxfeatures); g++) {\r\n            if (geojson.features[g].properties[this.attr] != null && typeof geojson.features[g].properties[this.attr] == 'number') {\r\n                values.push(geojson.features[g].properties[this.attr]);\r\n                this.max = Math.max(this.max, geojson.features[g].properties[this.attr]);\r\n                this.min = Math.min(this.min, geojson.features[g].properties[this.attr]);\r\n            }\r\n            else\r\n                if (!strings.includes(geojson.features[g].properties[this.attr]))\r\n                    strings.push(geojson.features[g].properties[this.attr]);\r\n        }\r\n        if (values.length > 0) {//quantitative\r\n            if (this.breaks == undefined) {\r\n                if (numberOf > 1)\r\n                    breaks = this.calcClassBreaks(values, algorithm, numberOf);\r\n                else\r\n                    breaks = [this.min, this.max];\r\n            }\r\n            else {\r\n                breaks = this.breaks;\r\n            }\r\n            if (breaks.length > 2) {\r\n                fcolor = chroma.scale(colorscheme).colors(breaks.length - 1);\r\n                for (var i = 0; i < breaks.length - 1; i++) {\r\n                    var color = chroma(fcolor[i]).rgb();\r\n                    if (i != breaks.length - 2) {\r\n                        var aes = new Aesthetic(i, this.attr, [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), this.alpha], [0, 0, 0, 1], null, [breaks[i], breaks[i + 1]]);\r\n                    }\r\n                    else {\r\n                        var aes = new Aesthetic(i, this.attr, [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), this.alpha], [0, 0, 0, 1], null, [breaks[i], breaks[i + 1]]);\r\n                        aes.outer = true;\r\n                    }\r\n                    aesarray.push(aes);\r\n                }\r\n            }\r\n            else {\r\n                color = chroma(colorscheme[0]).rgb();\r\n                var aes = new Aesthetic(i, this.attr, [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), this.alpha], [0, 0, 0, 1], null, [breaks[0], breaks[1]]);\r\n                aes.outer = true;\r\n                aesarray.push(aes);\r\n            }\r\n        }\r\n\r\n        else {//qualitative\r\n            if (strings.length > 0) {\r\n                breaks = strings;\r\n                if (typeof colorscheme === 'string') {//string\r\n                    fcolor = chroma.scale(colorscheme).colors(breaks.length);\r\n                }\r\n                else { //array\r\n                    fcolor = chroma.scale(colorscheme).colors(breaks.length);\r\n                }\r\n                for (var i = 0; i < breaks.length; i++) {\r\n                    var color = chroma(fcolor[i]).rgb();\r\n                    var aes = new Aesthetic(i, this.attr, [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), 1], [0, 0, 0, 1], null, [strings[i]]);\r\n                    aesarray.push(aes);\r\n                }\r\n            }\r\n        }\r\n\r\n        this.aesthetics = aesarray;\r\n        //return aesarray;\r\n    }\r\n\r\n    calcClassBreaks(values, algorithm, numberOf) {\r\n        let breaks;\r\n        switch (algorithm) {\r\n            case 'equidistant':\r\n                breaks = chroma.limits(values, 'e', numberOf);\r\n                break;\r\n\r\n            case 'quantile':\r\n                breaks = chroma.limits(values, 'q', numberOf);\r\n                break;\r\n\r\n            case 'k-means':\r\n                breaks = chroma.limits(values, 'k', numberOf);\r\n                break;\r\n\r\n            default:\r\n                breaks = chroma.limits(values, 'q', numberOf);\r\n                break;\r\n        }\r\n        return breaks;\r\n    }\r\n\r\n    /**\r\n     * \r\n     * @param {JSON} geojson \r\n     */\r\n    processData(geojson) {\r\n        this.loadGeoJSON(geojson);\r\n    }\r\n\r\n    loadGeoJSON(geojson) {\r\n        for (let g = 0; g < geojson.features.length && (this.maxfeatures == undefined || g < this.maxfeatures); g++) {\r\n            geojson.features[g].properties['_gisplayid'] = g;\r\n            const geometry = geojson.features[g].geometry;\r\n            const properties = geojson.features[g].properties;\r\n            this.createAndInsertFeature(g, geometry, properties);\r\n        }\r\n        this.buildTrees(geojson);\r\n    }\r\n\r\n    createAndInsertFeature(id, geometry, properties) {\r\n        const gl = this._webgl.gl;\r\n        if (this.minuend != undefined && this.subtrahend != undefined && typeof properties[this.minuend] == 'number'\r\n            && properties[this.subtrahend] != undefined && typeof properties[this.subtrahend] == 'number'\r\n            && properties[this.subtrahend] != undefined) {\r\n            properties[this.attr] = properties[this.minuend] - properties[this.subtrahend];\r\n        }\r\n\r\n        if (geometry.type == \"Polygon\" || geometry.type == \"MultiPolygon\") {\r\n            this.hasPolygons = true;\r\n            const polygons = this.processPolygon({ geometry, properties });\r\n\r\n            const currentBorders = [];\r\n            const currentTriangles = [];\r\n            const bufferT = [];\r\n            const bufferB = [];\r\n\r\n            for (let j = 0; j < polygons.length; j++) {\r\n                const trianglespolygon = polygons[j].triangles;\r\n                const border = polygons[j].vertex;\r\n                currentTriangles[j] = new Array();\r\n                currentBorders[j] = new Array();\r\n                for (let h = 0; h < trianglespolygon.length; h++) {\r\n                    var pixel = this.latLongToPixelXY(border[trianglespolygon[h] * 2], border[trianglespolygon[h] * 2 + 1]);\r\n                    currentTriangles[j].push(pixel.x, pixel.y);\r\n\r\n                    if (h == trianglespolygon.length - 1) {\r\n                        bufferT.push(gl.createBuffer());\r\n\r\n                        var vertArray = new Float32Array(currentTriangles[j]);\r\n\r\n                        gl.fsize = vertArray.BYTES_PER_ELEMENT;\r\n                        gl.bindBuffer(gl.ARRAY_BUFFER, bufferT[j]);\r\n                        gl.bufferData(gl.ARRAY_BUFFER, vertArray, gl.STATIC_DRAW);\r\n\r\n                        bufferT[j].itemSize = 2;\r\n                        bufferT[j].numItems = vertArray.length / 2;\r\n                    }\r\n                }\r\n\r\n\r\n                for (var y = 0; y < border.length; y += 2) {\r\n                    var pixel = this.latLongToPixelXY(border[y], border[y + 1]);\r\n                    currentBorders[j].push(pixel.x, pixel.y);\r\n\r\n                    if (y == border.length - 2) {\r\n                        bufferB.push(gl.createBuffer());\r\n\r\n                        var vertArray = new Float32Array(currentBorders[j]);\r\n\r\n                        gl.fsize = vertArray.BYTES_PER_ELEMENT;\r\n                        gl.bindBuffer(gl.ARRAY_BUFFER, bufferB[j]);\r\n                        gl.bufferData(gl.ARRAY_BUFFER, vertArray, gl.STATIC_DRAW);\r\n\r\n                        bufferB[j].itemSize = 2;\r\n                        bufferB[j].numItems = vertArray.length / 2;\r\n                    }\r\n                }\r\n            }\r\n            //polygon\r\n            this.insertFeature(id, properties, bufferT, bufferB, []);\r\n        }\r\n\r\n        else if (geometry.type == \"Point\" && this.dynamic == true) {\r\n            //dum\r\n            const currentPoints = [];\r\n            currentPoints[0] = new Array();\r\n            var pixel = this.latLongToPixelXY(geometry.coordinates[0], geometry.coordinates[1]);\r\n            currentPoints[0].push(pixel.x, pixel.y);\r\n            const bufferP = [];\r\n            bufferP.push(gl.createBuffer());\r\n\r\n            var vertArray = new Float32Array(currentPoints[0]);\r\n\r\n            gl.fsize = vertArray.BYTES_PER_ELEMENT;\r\n            gl.bindBuffer(gl.ARRAY_BUFFER, bufferP[0]);\r\n            gl.bufferData(gl.ARRAY_BUFFER, vertArray, gl.STATIC_DRAW);\r\n\r\n            bufferP[0].itemSize = 2;\r\n            bufferP[0].numItems = vertArray.length / 2;\r\n\r\n            this.insertFeature(id, properties, [], [], bufferP);\r\n\r\n            if (this.treepoints == null || this.treepoints == undefined)\r\n                this.treepoints = [];\r\n            this.treepoints.push({ lon: geometry.coordinates[0], lat: geometry.coordinates[1], properties });\r\n        }\r\n\r\n        else if (geometry.type == \"Point\" && this.dynamic == false) {\r\n            //debugger;\r\n            var pixel = this.latLongToPixelXY(geometry.coordinates[0], geometry.coordinates[1]);\r\n            if (this.tempPoints == null || this.tempPoints == undefined) {\r\n                this.tempPoints = new Array();\r\n                for (let a = 0; a < this.aesthetics.length; a++) {\r\n                    this.tempPoints[a] = [];\r\n                }\r\n            }\r\n\r\n            const aesarrays = this.fitFeature(properties);\r\n            for (var y = 0; y < aesarrays.length; y++) {\r\n                this.tempPoints[aesarrays[y]].push(pixel.x, pixel.y);\r\n            }\r\n\r\n            if (this.treepoints == null)\r\n                this.treepoints = [];\r\n            this.treepoints.push({ lon: geometry.coordinates[0], lat: geometry.coordinates[1], properties });\r\n        }\r\n    }\r\n\r\n    processPolygon(polygon) {\r\n        if (polygon.geometry.type == \"Polygon\") {\r\n            var outsidepolygon = polygon.geometry.coordinates[0];\r\n\r\n            var insidepolygons = [];\r\n            for (var k = 1; k < polygon.geometry.coordinates.length; k++) {\r\n                //todo inside polygon\r\n                //insidepolygons.push(polygon.geometry.coordinates[i][k]);\r\n            }\r\n            var tempVerts = new Array();\r\n            for (var out = 0; out < outsidepolygon.length - 1; out++) {\r\n                tempVerts.push(outsidepolygon[out][0], outsidepolygon[out][1]);\r\n                _vertexcount += (outsidepolygon.length + 1) / 2;\r\n                //console.log(\"lon: \" + outsidepolygon[out][0] + \" lat: \" + outsidepolygon[out][1]);\r\n            }\r\n\r\n            var triangles_vert = earcut(tempVerts);\r\n            _tricount += (triangles_vert.length / 3);\r\n            polyarray.push({ triangles: triangles_vert, vertex: tempVerts });\r\n        }\r\n\r\n        else if (polygon.geometry.type == \"MultiPolygon\") {\r\n            var polyarray = [];\r\n            for (let i = 0; i < polygon.geometry.coordinates.length; i++) {\r\n\r\n                var outsidepolygon = polygon.geometry.coordinates[i][0];\r\n\r\n                var insidepolygons = [];\r\n                for (var k = 1; k < polygon.geometry.coordinates[i].length; k++) {\r\n                    //todo inside polygon\r\n                    insidepolygons.push(polygon.geometry.coordinates[i][k]);\r\n                }\r\n                var tempVerts = new Array();\r\n                _vertexcount += outsidepolygon.length;\r\n                for (var out = 0; out < outsidepolygon.length - 1; out++) {\r\n                    tempVerts.push(outsidepolygon[out][0], outsidepolygon[out][1]);\r\n\r\n                    //console.log(\"lon: \" + outsidepolygon[out][0] + \" lat: \" + outsidepolygon[out][1]);\r\n                }\r\n\r\n                var triangles_vert = earcut(tempVerts);\r\n                //var temp = earcut.flatten(polygon.geometry.coordinates[i]);\r\n                //var triangles_vert = earcut(temp.vertices, temp.holes, temp.dimensions);\r\n                _tricount += (triangles_vert.length / 3);\r\n                polyarray.push({ triangles: triangles_vert, vertex: tempVerts });\r\n                //console.log(polyarray);\r\n            }\r\n            return polyarray;\r\n        }\r\n    }\r\n\r\n    insertFeature(id, properties, triangles, borders, points) {\r\n        let flag = false;\r\n        for (let i = 0; i < this.aesthetics.length; i++) {\r\n            if (this.aesthetics[i].checkProperty(properties[this.aesthetics[i].getAttr()]) == true) {\r\n                this.aesthetics[i].addFeature(id, properties, triangles, borders, points);\r\n                flag = true;\r\n            }\r\n        }\r\n        if (!flag) {\r\n            //TODO\r\n            //console.log(\"TODO: feature does not fit into any of the aesthetics defined.\\n Value: \" + properties[this.attr]);\r\n        }\r\n    }\r\n\r\n    latLongToPixelXY(longitude, latitude) {\r\n        const pi_180 = Math.PI / 180.0;\r\n        const pi_4 = Math.PI * 4;\r\n        const sinLatitude = Math.sin(latitude * pi_180);\r\n        const pixelY = (0.5 - Math.log((1 + sinLatitude) / (1 - sinLatitude)) / (pi_4)) * 256;\r\n        const pixelX = ((longitude + 180) / 360) * 256;\r\n\r\n        const pixel = { x: pixelX, y: pixelY };\r\n        return pixel;\r\n    }\r\n\r\n    fitFeature(properties) {\r\n        const result = [];\r\n        for (let a = 0; a < this.aesthetics.length; a++) {\r\n            if (this.aesthetics[a].checkProperty(properties[this.aesthetics[a].getAttr()]) == true)\r\n                result.push(a);\r\n        }\r\n        return result;\r\n    }\r\n\r\n    buildTrees(geojson) {\r\n        const gl = this._webgl.gl;\r\n        if (this.tempPoints != null) {\r\n            for (let t = 0; t < this.tempPoints.length; t++) {\r\n                if (this.tempPoints[t].length > 0) {\r\n                    const bufferP = [];\r\n                    bufferP.push(gl.createBuffer());\r\n\r\n                    const vertArray = new Float32Array(this.tempPoints[t]);\r\n\r\n                    gl.fsize = vertArray.BYTES_PER_ELEMENT;\r\n                    gl.bindBuffer(gl.ARRAY_BUFFER, bufferP[0]);\r\n                    gl.bufferData(gl.ARRAY_BUFFER, vertArray, gl.STATIC_DRAW);\r\n\r\n                    bufferP[0].itemSize = 2;\r\n                    bufferP[0].numItems = vertArray.length / 2;\r\n                    this.insertGroupedFeature(t, [], [], bufferP);\r\n                }\r\n            }\r\n        }\r\n        //console.log(geojson)\r\n        if (this.treepoints != null)\r\n            this.kdtree = new kdTree(this.treepoints, (a, b) => (a.lon - b.lon) ** 2 + (a.lat - b.lat) ** 2, [\"lon\", \"lat\", \"properties\"]);\r\n        if (this.hasPolygons == true)\r\n            this.rtree = new PolygonLookup(geojson);\r\n    }\r\n\r\n    insertGroupedFeature(idaes, triangles, borders, points) {\r\n        this.aesthetics[idaes].addGroupedFeature(null, triangles, borders, points);\r\n    }\r\n\r\n    createCanvas() {\r\n        const canvas = this.map.createCanvas(this.id);\r\n\r\n        //init webgl properties\r\n        this._webgl = {\r\n            gl: null,\r\n            program: null,\r\n            projection: null\r\n        };\r\n\r\n        this._webgl.gl = canvas.getContext(\"webgl\");\r\n        this._webgl.projection = new Float32Array(16);\r\n        this._webgl.projection.set([2 / canvas.width, 0, 0, 0, 0, -2 / canvas.height, 0, 0, 0, 0, 0, 0, -1, 1, 0, 1]);\r\n\r\n        this._webgl.gl.viewport(0, 0, this.map.getContainer().offsetWidth, this.map.getContainer().offsetHeight);\r\n        this._webgl.gl.disable(this._webgl.gl.DEPTH_TEST);\r\n    }\r\n\r\n    getNumberOfFeatures() {\r\n        let count = 0;\r\n        for (let i = 0; i < this.aesthetics.length; i++) {\r\n            count += this.aesthetics[i]._features.length;\r\n        }\r\n        return count;\r\n    }\r\n\r\n    scaleProjection(matrix, scaleX, scaleY) {\r\n        // scaling x and y, which is just scaling first two rows of matrix\r\n        matrix[0] *= scaleX;\r\n        matrix[1] *= scaleX;\r\n        matrix[2] *= scaleX;\r\n        matrix[3] *= scaleX;\r\n\r\n        matrix[4] *= scaleY;\r\n        matrix[5] *= scaleY;\r\n        matrix[6] *= scaleY;\r\n        matrix[7] *= scaleY;\r\n    }\r\n\r\n    translateProjection(matrix, tx, ty) {\r\n        // translation is in last row of matrix\r\n        matrix[12] += matrix[0] * tx + matrix[4] * ty;\r\n        matrix[13] += matrix[1] * tx + matrix[5] * ty;\r\n        matrix[14] += matrix[2] * tx + matrix[6] * ty;\r\n        matrix[15] += matrix[3] * tx + matrix[7] * ty;\r\n    }\r\n\r\n    clear() {\r\n        const gl = this._webgl.gl;\r\n        gl.clear(gl.COLOR_BUFFER_BIT);\r\n        gl.disable(gl.DEPTH_TEST);\r\n    }\r\n\r\n    drawTriangles(aes) {\r\n        const gl = this._webgl.gl;\r\n        if (gl == null) return;\r\n        const matrixProjection = new Float32Array(16);\r\n\r\n        //gl.clear(gl.COLOR_BUFFER_BIT);\r\n        //gl.disable(gl.DEPTH_TEST);\r\n\r\n        //gl.enable(gl.BLEND);\r\n        //gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\r\n\r\n\r\n        const currentZoom = this.map.getZoom();\r\n        const pointSize = Math.max(currentZoom - 5.0, 1.0);\r\n\r\n        matrixProjection.set(this._webgl.projection);\r\n\r\n        const scale = 2 ** currentZoom;\r\n        this.scaleProjection(matrixProjection, scale, scale);\r\n\r\n        const offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\r\n        this.translateProjection(matrixProjection, -offset.x, -offset.y);\r\n\r\n        const projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\r\n        gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\r\n\r\n        const vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\r\n        gl.vertexAttrib1f(vertexSizeLocation, pointSize);\r\n\r\n        const isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\r\n        gl.uniform1f(isPointLocation, 0.0);\r\n\r\n\r\n\r\n        const vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\r\n\r\n\r\n        const vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\r\n\r\n\r\n\r\n        /** \r\n         * \r\n         *  Draw Polygons' Interior\r\n         *  **/\r\n        const fsize = Float32Array.BYTES_PER_ELEMENT;\r\n        //console.log(\"Numero de Buffers: \", buffers.length);\r\n\r\n        gl.uniform4f(vertexColorLocation, aes.fillColor[0] / 255, aes.fillColor[1] / 255, aes.fillColor[2] / 255, aes.fillColor[3]);\r\n\r\n\r\n\r\n\r\n        for (let i = 0; i < aes._features.length; i++) {\r\n            for (let y = 0; y < aes._features[i]._triangles.length; y++) {\r\n\r\n                gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._triangles[y]);\r\n\r\n                gl.enableVertexAttribArray(vertexCoordLocation);\r\n                gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\r\n                //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\r\n                //gl.enableVertexAttribArray(vertexColorLocation);\r\n\r\n\r\n\r\n                gl.drawArrays(gl.TRIANGLES, 0, aes._features[i]._triangles[y].numItems);\r\n            }\r\n        }\r\n    }\r\n\r\n    drawBorders(aes) {\r\n        const gl = this._webgl.gl;\r\n        if (gl == null) return;\r\n        const matrixProjection = new Float32Array(16);\r\n\r\n        //gl.clear(gl.COLOR_BUFFER_BIT);\r\n        //gl.disable(gl.DEPTH_TEST);\r\n\r\n        gl.enable(gl.BLEND);\r\n        gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\r\n\r\n        const currentZoom = this.map.getZoom();\r\n        const pointSize = Math.max(currentZoom - 5.0, 1.0);\r\n\r\n        matrixProjection.set(this._webgl.projection);\r\n\r\n        const scale = 2 ** currentZoom;\r\n        this.scaleProjection(matrixProjection, scale, scale);\r\n\r\n        const offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\r\n        this.translateProjection(matrixProjection, -offset.x, -offset.y);\r\n\r\n        const projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\r\n        gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\r\n\r\n        const vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\r\n        gl.vertexAttrib1f(vertexSizeLocation, pointSize);\r\n\r\n        const vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\r\n\r\n\r\n        const vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\r\n\r\n        const isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\r\n        gl.uniform1f(isPointLocation, 0.0);\r\n\r\n\r\n        /** \r\n         * \r\n         *  Draw Polygons' Interior\r\n         *  **/\r\n        const fsize = Float32Array.BYTES_PER_ELEMENT;\r\n        //console.log(\"Numero de Buffers: \", buffers.length);\r\n\r\n        gl.uniform4f(vertexColorLocation, aes.strokeColor[0] / 255, aes.strokeColor[1] / 255, aes.strokeColor[2] / 255, aes.strokeColor[3]);\r\n\r\n        for (let i = 0; i < aes._features.length; i++) {\r\n            for (let y = 0; y < aes._features[i]._borders.length; y++) {\r\n\r\n                gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._borders[y]);\r\n\r\n                gl.enableVertexAttribArray(vertexCoordLocation);\r\n                gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\r\n                //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\r\n                //gl.enableVertexAttribArray(vertexColorLocation);\r\n\r\n\r\n\r\n                gl.drawArrays(gl.LINE_LOOP, 0, aes._features[i]._borders[y].numItems);\r\n            }\r\n        }\r\n\r\n\r\n    }\r\n\r\n    drawPoints(aes) {\r\n\r\n\r\n        const gl = this._webgl.gl;\r\n        if (gl == null) return;\r\n        const matrixProjection = new Float32Array(16);\r\n\r\n\r\n        //gl.clear(gl.COLOR_BUFFER_BIT);\r\n        //gl.disable(gl.DEPTH_TEST);\r\n\r\n        gl.enable(gl.BLEND);\r\n        gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\r\n\r\n        const currentZoom = this.map.getZoom();\r\n        const pointSize = Math.max(currentZoom - 4.0 + aes.pointSize, aes.pointSize);\r\n\r\n        matrixProjection.set(this._webgl.projection);\r\n\r\n        const scale = 2 ** currentZoom;\r\n        this.scaleProjection(matrixProjection, scale, scale);\r\n\r\n        const offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\r\n        this.translateProjection(matrixProjection, -offset.x, -offset.y);\r\n\r\n        const projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\r\n        gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\r\n\r\n        const vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\r\n        gl.vertexAttrib1f(vertexSizeLocation, pointSize);\r\n\r\n        const vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\r\n\r\n\r\n        const vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\r\n\r\n        const isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\r\n        gl.uniform1f(isPointLocation, 1.0);\r\n\r\n        /** \r\n         * \r\n         *  Draw Polygons' Interior\r\n         *  **/\r\n        const fsize = Float32Array.BYTES_PER_ELEMENT;\r\n        //console.log(\"Numero de Buffers: \", buffers.length);\r\n\r\n        gl.uniform4f(vertexColorLocation, aes.fillColor[0] / 255, aes.fillColor[1] / 255, aes.fillColor[2] / 255, aes.fillColor[3]);\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n        for (var i = 0; i < aes._features.length && this.dynamic == true; i++) {\r\n            for (var y = 0; y < aes._features[i]._points.length; y++) {\r\n\r\n                gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._points[y]);\r\n\r\n                gl.enableVertexAttribArray(vertexCoordLocation);\r\n                gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\r\n                //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\r\n                //gl.enableVertexAttribArray(vertexColorLocation);\r\n\r\n\r\n\r\n                gl.drawArrays(gl.POINTS, 0, aes._features[i]._points[y].numItems);\r\n                //1);\r\n            }\r\n        }\r\n\r\n\r\n        for (var i = 0; this.dynamic == false && aes._allFeatures != null && i < aes._allFeatures.length; i++) {\r\n            for (var y = 0; y < aes._allFeatures[i]._points.length; y++) {\r\n\r\n                gl.bindBuffer(gl.ARRAY_BUFFER, aes._allFeatures[i]._points[y]);\r\n\r\n                gl.enableVertexAttribArray(vertexCoordLocation);\r\n                gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\r\n                //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\r\n                //gl.enableVertexAttribArray(vertexColorLocation);\r\n\r\n\r\n\r\n                gl.drawArrays(gl.POINTS, 0, aes._allFeatures[i]._points[y].numItems);\r\n                //gl.drawArrays(gl.TRIANGLE_STRIP, 0, aes._allFeatures[i]._points[y].numItems-2);\t\r\n                //1);\r\n            }\r\n        }\r\n\r\n\r\n\r\n\r\n    }\r\n\r\n    drawContinuousPolygons(aes) {\r\n\r\n        const gl = this._webgl.gl;\r\n        if (gl == null) return;\r\n        const matrixProjection = new Float32Array(16);\r\n\r\n        //gl.clear(gl.COLOR_BUFFER_BIT);\r\n        //gl.disable(gl.DEPTH_TEST);\r\n\r\n        //gl.enable(gl.BLEND);\r\n        //gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\r\n\r\n\r\n        const currentZoom = this.map.getZoom();\r\n        const pointSize = Math.max(currentZoom - 5.0, 1.0);\r\n\r\n        matrixProjection.set(this._webgl.projection);\r\n\r\n        const scale = 2 ** currentZoom;\r\n        this.scaleProjection(matrixProjection, scale, scale);\r\n\r\n        const offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\r\n        this.translateProjection(matrixProjection, -offset.x, -offset.y);\r\n\r\n        const projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\r\n        gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\r\n\r\n        const vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\r\n        gl.vertexAttrib1f(vertexSizeLocation, pointSize);\r\n\r\n        const isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\r\n        gl.uniform1f(isPointLocation, 0.0);\r\n\r\n\r\n\r\n        const vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\r\n\r\n\r\n        const vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\r\n\r\n\r\n\r\n        /** \r\n         * \r\n         *  Draw Polygons' Interior\r\n         *  **/\r\n        const fsize = Float32Array.BYTES_PER_ELEMENT;\r\n        //console.log(\"Numero de Buffers: \", buffers.length);\r\n\r\n\r\n\r\n\r\n\r\n\r\n        for (let i = 0; i < aes._features.length; i++) {\r\n            let ucolor;\r\n            let color;\r\n            const diff = aes._features[i]._properties[this.attr];\r\n            if (diff == 0)\r\n                color = aes.fillColor(0.5).rgb();\r\n            else {\r\n                if (diff > 0) {\r\n                    color = aes.fillColor(0.5 + diff / this.max / 2).rgb();\r\n\r\n\r\n                } else {\r\n                    color = aes.fillColor(0.5 - diff / this.min / 2).rgb();\r\n                }\r\n\r\n            }\r\n            ucolor = [Math.round(color[0]), Math.round(color[1]), Math.round(color[2]), this.alpha];\r\n\r\n            gl.uniform4f(vertexColorLocation, ucolor[0] / 255, ucolor[1] / 255, ucolor[2] / 255, this.alpha);\r\n            for (let y = 0; y < aes._features[i]._triangles.length; y++) {\r\n\r\n                gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._triangles[y]);\r\n\r\n                gl.enableVertexAttribArray(vertexCoordLocation);\r\n                gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\r\n                //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\r\n                //gl.enableVertexAttribArray(vertexColorLocation);\r\n\r\n\r\n\r\n                gl.drawArrays(gl.TRIANGLES, 0, aes._features[i]._triangles[y].numItems);\r\n            }\r\n        }\r\n\r\n\r\n    }\r\n\r\n    drawProporcionalPoints(aes) {\r\n\r\n        const gl = this._webgl.gl;\r\n        if (gl == null) return;\r\n        const matrixProjection = new Float32Array(16);\r\n\r\n\r\n\r\n        gl.enable(gl.BLEND);\r\n        gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\r\n\r\n        const currentZoom = this.map.getZoom();\r\n\r\n\r\n        matrixProjection.set(this._webgl.projection);\r\n\r\n        const scale = 2 ** currentZoom;\r\n        this.scaleProjection(matrixProjection, scale, scale);\r\n\r\n        const offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\r\n        this.translateProjection(matrixProjection, -offset.x, -offset.y);\r\n\r\n        const projectionLocation = gl.getUniformLocation(this._webgl.program, 'projection');\r\n        gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\r\n\r\n\r\n\r\n        const vertexCoordLocation = gl.getAttribLocation(this._webgl.program, 'vertexCoord');\r\n\r\n\r\n        const vertexColorLocation = gl.getUniformLocation(this._webgl.program, \"u_color\");\r\n\r\n        const isPointLocation = gl.getUniformLocation(this._webgl.program, 'isPoint');\r\n        gl.uniform1f(isPointLocation, 1.0);\r\n\r\n        /** \r\n         * \r\n         *  Draw Polygons' Interior\r\n         *  **/\r\n        const fsize = Float32Array.BYTES_PER_ELEMENT;\r\n        //console.log(\"Numero de Buffers: \", buffers.length);\r\n\r\n        gl.uniform4f(vertexColorLocation, aes.fillColor[0] / 255, aes.fillColor[1] / 255, aes.fillColor[2] / 255, this.alpha);\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n        if (this.dynamic == true) {\r\n            for (const i in aes._features) {\r\n                for (const y in aes._features[i]._points) {\r\n\r\n                    gl.bindBuffer(gl.ARRAY_BUFFER, aes._features[i]._points[y]);\r\n                    const propvalue = parseFloat(aes._features[i]._properties[this.attr]);\r\n                    const temppointsize = ((this.maxpointsize - this.minpointsize) / (this.max - this.min)) * (propvalue - this.min);\r\n                    const pointSize = Math.max(currentZoom - 4.0 + temppointsize * currentZoom / 4, 2);\r\n                    const vertexSizeLocation = gl.getAttribLocation(this._webgl.program, 'aPointSize');\r\n                    gl.vertexAttrib1f(vertexSizeLocation, pointSize);\r\n\r\n                    gl.enableVertexAttribArray(vertexCoordLocation);\r\n                    gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 2, 0);\r\n                    //gl.vertexAttribPointer(vertexColorLocation, 4, gl.FLOAT, false, fsize * 6, fsize * 2);\r\n                    //gl.enableVertexAttribArray(vertexColorLocation);\r\n\r\n\r\n\r\n                    gl.drawArrays(gl.POINTS, 0, aes._features[i]._points[y].numItems);\r\n                    //1);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    initialize() {\r\n        this.max = null;\r\n        this.min = null;\r\n        this.createCanvas();\r\n        this.program();\r\n        let mappos;\r\n        for (let i = 0; i < maps.length; i++)\r\n            if (maps[i].id == this.id)\r\n                mappos = i;\r\n        this.map.onEvent('move', () => {\r\n            console.log(\"@Rui: mudar o profiling do window para outra coisa?\")\r\n            if (window.profiling == true)\r\n                var start = Date.now();\r\n            maps[mappos].draw();\r\n            if (window.profiling == true) {\r\n                const end = Date.now();\r\n                window.console.log(`Tempo de processamento de Zoom/Pan (segundos):${(end - start) / 1000}`);\r\n            }\r\n        }\r\n        );\r\n\r\n        this.setupOnclick(mappos);\r\n    }\r\n\r\n    setupOnclick(mappos) {\r\n        console.log(\"@Rui: profiling mudar de window para? | Rtree e KdTree\")\r\n        maps[mappos].map.onEvent('click', e => {\r\n            if (window.profiling == true)\r\n                var start = Date.now();\r\n            const lat = e.latlng.lat;\r\n            const lon = e.latlng.lng;\r\n\r\n            if (maps[mappos].rtree != undefined) {\r\n                var bool = maps[0].rtree.search(lon, lat);\r\n                if (bool == undefined)\r\n                    return;\r\n                else {\r\n                    //console.log\r\n                    var s = \"\";\r\n                    var first = true;\r\n                    if (maps[mappos].showPropertiesOnClick != null) {\r\n                        for (var i = 0; i < maps[mappos].showPropertiesOnClick.length; i += 2) {\r\n                            if (first) {\r\n                                s += `${maps[mappos].showPropertiesOnClick[i + 1]}: ${bool.properties[maps[mappos].showPropertiesOnClick[i]]}`;\r\n                                first = false;\r\n                            }\r\n                            else {\r\n                                s += `\\n${maps[mappos].showPropertiesOnClick[i + 1]}: ${bool.properties[maps[mappos].showPropertiesOnClick[i]]}`;\r\n                            }\r\n\r\n                        }\r\n                    }\r\n                    else {\r\n\r\n                        var keys = Object.keys(bool.properties);\r\n\r\n                        for (var i = 0; i < keys.length; i++) {\r\n                            if (keys[i] != \"_gisplayid\") {\r\n                                if (first) {\r\n                                    s += `${keys[i]}: ${bool.properties[keys[i]]}`;\r\n                                    first = false;\r\n                                }\r\n                                else {\r\n                                    s += `\\n${keys[i]}: ${bool.properties[keys[i]]}`;\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                    if (maps[mappos].interactive == true)\r\n                        alert(s);//todo\r\n                    if (maps[mappos].mapOnClickCall != undefined && maps[mappos].mapOnClickCall != null)\r\n                        maps[mappos].mapOnClickCall(bool);\r\n                }\r\n            }\r\n            if (maps[mappos].kdtree != undefined) {\r\n\r\n                const nearest = maps[mappos].kdtree.nearest({ lat, lon }, 1, 128 / ((2 ** (map.getZoom() * 2))));\r\n                if (nearest.length <= 0)\r\n                    return;\r\n                else {\r\n                    var bool = nearest[0][0];\r\n                    //console.log\r\n                    var s = \"\";\r\n                    var first = true;\r\n                    if (maps[mappos].showPropertiesOnClick != null) {\r\n                        for (var i = 0; i < maps[mappos].showPropertiesOnClick.length; i += 2) {\r\n                            if (first) {\r\n                                s += `${maps[mappos].showPropertiesOnClick[i + 1]}: ${bool.properties[maps[mappos].showPropertiesOnClick[i]]}`;\r\n                                first = false;\r\n                            }\r\n                            else {\r\n                                s += `\\n${maps[mappos].showPropertiesOnClick[i + 1]}: ${bool.properties[maps[mappos].showPropertiesOnClick[i]]}`;\r\n                            }\r\n\r\n                        }\r\n                    }\r\n                    else {\r\n\r\n                        var keys = Object.keys(bool.properties);\r\n\r\n                        for (var i = 0; i < keys.length; i++) {\r\n                            if (keys[i] != \"_gisplayid\") {\r\n                                if (first) {\r\n                                    s += `${keys[i]}: ${bool.properties[keys[i]]}`;\r\n                                    first = false;\r\n                                }\r\n                                else {\r\n                                    s += `\\n${keys[i]}: ${bool.properties[keys[i]]}`;\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                    if (maps[mappos].interactive == true)\r\n                        alert(s);\r\n                    if (maps[mappos].mapOnClickCall != undefined && maps[mappos].mapOnClickCall != null)\r\n                        maps[mappos].mapOnClickCall(bool);\r\n                }\r\n            }\r\n\r\n            if (window.profiling == true) {\r\n                const end = Date.now();\r\n                window.console.log(`Tempo de processamento de um click (segundos): ${(end - start) / 1000}`);\r\n            }\r\n        });\r\n\r\n    }\r\n\r\n    loadOptions(options, bgmap) {\r\n        if (options.customMapService == true)\r\n            this.map = bgmap;\r\n        else\r\n            this.map = new BGMapWrapper(bgmap);\r\n        if (options.loader != false)\r\n            this.loader();\r\n\r\n        if (options.showPropertiesOnClick == true) {\r\n            this.showPropertiesOnClick = null;\r\n            //append on bgmap object\r\n        }\r\n        else if (options.showPropertiesOnClick == false) {\r\n            //nada\r\n        }\r\n        else if (options.showPropertiesOnClick != undefined) {\r\n            this.showPropertiesOnClick = options.showPropertiesOnClick;\r\n        }\r\n        this.alpha = options.alpha != undefined ? options.alpha : 0.8;\r\n        this.interactive = options.interactive == undefined ? true : !options.interactive;\r\n        this.attr = options.attr;\r\n        this.dynamic = options.memorySaver == undefined ? false : !options.memorySaver;\r\n        this.maxfeatures = options.maxFeatures;\r\n        this.breaks = options.classBreaks;\r\n        this.colorscheme = options.colorScheme;\r\n        this.numberofclasses = options.numberOfClasses;\r\n        this.algorithm = options.classBreaksMethod;\r\n        this.legendOnClickCall = options.legendOnClickFunction;\r\n        this.mapOnClickCall = options.mapOnClickFunction;\r\n        this.minuend = options.minuend;\r\n        this.subtrahend = options.subtrahend;\r\n        this.legendTitle = options.legendTitle != undefined ? options.legendTitle : (this.attr != undefined ? this.attr : `${this.minuend} - ${this.subtrahend}`);\r\n        this.numberOfLegendItems = options.numberOfLegendItems != undefined ? options.numberOfLegendItems : 2;\r\n    }\r\n\r\n    loader() {\r\n        this.map.loader();\r\n    }\r\n\r\n    getNumberOfPolygons() {\r\n        let count = 0;\r\n        for (let i = 0; i < this.aesthetics.length; i++) {\r\n            for (let z = 0; z < this.aesthetics[i]._features.length; z++) {\r\n                count += this.aesthetics[i]._features[z]._triangles.length;\r\n            }\r\n        }\r\n        return count;\r\n    }\r\n\r\n    //STATIC METHODS(should be implemented by sub-classes)\r\n    draw() {\r\n        alert(\"draw() not implemented\");//throw new NotImplementedError();\r\n    }\r\n\r\n    /**\r\n     * @deprecated This was created for Heat Maps. Another idea will probably be used.\r\n     * @param {Aesthetic} aes \r\n     */\r\n    drawHeatPoints(aes) {\r\n        const gl = this._webgl.gl;\r\n\r\n        if (gl == null) return;\r\n        gl.useProgram(this._webgl.heatmapProgram[0]);\r\n        const matrixProjection = new Float32Array(16);\r\n\r\n        gl.clear(gl.COLOR_BUFFER_BIT);\r\n        gl.enable(gl.BLEND);\r\n\r\n        gl.blendFunc(gl.ONE, gl.ONE);\r\n\r\n        const currentZoom = map.getZoom();\r\n        const pointSize = Math.max(currentZoom - 5.0, 1.0);\r\n\r\n        matrixProjection.set(this._webgl.projection);\r\n\r\n        const scale = 2 ** currentZoom;\r\n        this.scaleProjection(matrixProjection, scale, scale);\r\n\r\n        const offset = this.latLongToPixelXY(this.map.getLngBound(), this.map.getLatBound());\r\n        this.translateProjection(matrixProjection, -offset.x, -offset.y);\r\n\r\n\r\n        const projectionLocation = gl.getUniformLocation(this._webgl.heatmapProgram[0], 'projection');\r\n        gl.uniformMatrix4fv(projectionLocation, false, matrixProjection);\r\n\r\n\r\n        const vertexCoordLocation = gl.getAttribLocation(this._webgl.heatmapProgram[0], 'position');\r\n        const deltaLocation = gl.getAttribLocation(this._webgl.heatmapProgram[0], 'delta');\r\n        const intensityLoc = gl.getAttribLocation(this._webgl.heatmapProgram[0], 'intensity');\r\n        const vertexSizeLocation = gl.getAttribLocation(this._webgl.heatmapProgram[0], 'aPointSize');\r\n\r\n        gl.vertexAttrib1f(vertexSizeLocation, pointSize);\r\n\r\n        gl.enableVertexAttribArray(vertexCoordLocation);\r\n        gl.enableVertexAttribArray(deltaLocation);\r\n        gl.enableVertexAttribArray(intensityLoc);\r\n\r\n\r\n\r\n        const fsize = Float32Array.BYTES_PER_ELEMENT;\r\n\r\n        gl.bindBuffer(gl.ARRAY_BUFFER, aes._allFeatures[0]._points[0]);\r\n        gl.vertexAttribPointer(vertexCoordLocation, 2, gl.FLOAT, false, fsize * 8, 0 * 2);\r\n        gl.vertexAttribPointer(deltaLocation, 2, gl.FLOAT, false, fsize * 8, 2 * 4);\r\n        gl.vertexAttribPointer(intensityLoc, 4, gl.FLOAT, false, fsize * 8, 4 * 4);\r\n\r\n\r\n\r\n        console.log(aes._allFeatures[0]._points[0].numItems);\r\n        gl.drawArrays(gl.TRIANGLES, 0, aes._allFeatures[0]._points[0].numItems);\r\n\r\n\r\n        gl.useProgram(this._webgl.heatmapProgram[1]);\r\n\r\n        gl.disable(gl.BLEND);\r\n\r\n        //console.log(\"fase 1 concluida\");\r\n\r\n        const canvas = document.getElementById(`mapCanvas${this.id}`);\r\n\r\n\r\n\r\n        const source = gl.createTexture();\r\n\r\n        gl.activeTexture(gl.TEXTURE0);\r\n        gl.bindTexture(gl.TEXTURE_2D, source);\r\n        gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, canvas);\r\n\r\n        function isPowerOf2(value) {\r\n            return (value & (value - 1)) == 0;\r\n        };\r\n\r\n        function steupTextureFilteringAndMips(width, height, gl) {\r\n            if (isPowerOf2(width) && isPowerOf2(height)) {\r\n                // the dimensions are power of 2 so generate mips and turn on \r\n                // tri-linear filtering.\r\n                gl.generateMipmap(gl.TEXTURE_2D);\r\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR_MIPMAP_LINEAR);\r\n            } else {\r\n                // at least one of the dimensions is not a power of 2 so set the filtering\r\n                // so WebGL will render it.\r\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\r\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\r\n                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\r\n            }\r\n        };\r\n\r\n        steupTextureFilteringAndMips(canvas.width, canvas.height, gl);\r\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\r\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\r\n\r\n        const vertices = new Float32Array([1, 1, -1, 1, -1, -1, 1, 1, -1, -1, 1, -1]);\r\n        const buffer = gl.createBuffer();\r\n        gl.bindBuffer(gl.ARRAY_BUFFER, buffer);\r\n        gl.bufferData(gl.ARRAY_BUFFER, vertices, gl.STATIC_DRAW);\r\n        const positionLoc = gl.getAttribLocation(this._webgl.heatmapProgram[1], 'position');\r\n        const sourceLoc = gl.getUniformLocation(this._webgl.heatmapProgram[1], 'source');\r\n        gl.enableVertexAttribArray(positionLoc);\r\n        gl.vertexAttribPointer(positionLoc, 2, gl.FLOAT, false, 0, 0);\r\n        gl.uniform1i(sourceLoc, 0);\r\n        gl.drawArrays(gl.TRIANGLES, 0, 6);\r\n\r\n\r\n        gl.disableVertexAttribArray(positionLoc);\r\n        //defaults to general program\r\n        //console.log(\"fase 2 concluida\");\r\n        gl.bindBuffer(gl.ARRAY_BUFFER, null);\r\n        this._webgl.gl.useProgram(this._webgl.program);\r\n    }\r\n}\n\n\n// WEBPACK FOOTER //\n// src/Gisplay/Maps/Map.js"],"mappings":";;;;;;;;;AAAA;AACA;AAAA;AACA;;;AACA;;;;AAIA;AAEA;AAAA;AACA;AAAA;AACA;AACA;;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AArBA;AAAA;AAAA;AACA;AADA;AAuBA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAtDA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAuDA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AAAA;AACA;AACA;AAIA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAfA;AAiBA;AACA;AACA;AACA;;;;;;;AAIA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;;;AAEA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AAEA;AACA;AAGA;;;;AAIA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAGA;;;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;;;AAIA;AACA;AACA;AACA;AACA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAKA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AAEA;AACA;AAGA;;;;AAIA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AAGA;AACA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAGA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;;;AAIA;AACA;AACA;AACA;AACA;AAUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAEA;AACA;AAIA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAEA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;;;;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;;;","sourceRoot":""}");
/***/ }),
/* 2 */
/* unknown exports provided */
/* all exports used */
/*!**********************************!*\
!*** ./src/Gisplay/Aesthetic.js ***!
\**********************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Aesthetic = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Feature = __webpack_require__(/*! ./Feature */ 6);\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\r\n * Class that represents an aesthetic element. There will be one Aesthetic class for each class on the Legend.\r\n * \r\n * @export\r\n * @class Aesthetic\r\n */\nvar Aesthetic = exports.Aesthetic = function () {\n\n /**\r\n * Creates an instance of Aesthetic. \r\n * There will be as many Aesthetic objects as the number of classes on the Legend. \r\n * @example 1-> {\"id\":0,\"attr\":\"f3\",\"fcolor\":[255,255,255,0.8],\r\n * \"stroke\":[0,0,0,1],\"pointsize\":null,\"range\":[1,37]}\r\n * @example 2-> {\"id\":1,\"attr\":\"f3\",\"fcolor\":[255,255,0,0.8],\r\n * \"stroke\":[0,0,0,1],\"pointsize\":null,\"range\":[37,78]}\r\n * @param {number} id - The unique id of the Aesthetic object.\r\n * @param {string} attr - The attribute being mapped on this Aesthetic.\r\n * @param {number[]} fcolor - The color to fill the Aesthetic element(RGBA).\r\n * @param {number[]} stroke - Stroke color values(RGBA).\r\n * @param {number|null} pointsize - Size of the Aesthetic point to be drawn (Used only in maps that require dots to be drawn).\r\n * @param {number[]} range - The range for this particular Aesthetic element.\r\n * \r\n * @memberOf Aesthetic\r\n */\n function Aesthetic(id, attr, fcolor, stroke, pointsize, range) {\n _classCallCheck(this, Aesthetic);\n\n /**\r\n * The unique id of the Aesthetic object. \r\n * @type {number}\r\n */\n this.id = id;\n /**\r\n * The attribute being mapped on the Aesthetic.\r\n * @type {string}\r\n */\n this._attr = attr;\n /**\r\n * The color to fill the Aesthetic element(RGBA).\r\n * @type {number[4]}\r\n */\n this.fillColor = fcolor;\n /**\r\n * Stroke color values(RGBA).\r\n * @type {number[4]}\r\n */\n this.strokeColor = stroke;\n /**\r\n * The size of the Aesthetic point to be drawn (Used only in maps that require dots to be drawn).\r\n * @type {number|null}\r\n */\n this.pointSize = pointsize == null ? 1.0 : parseFloat(pointsize);\n /**\r\n * The range for this particular Aesthetic element.\r\n * @type {number[2]}\r\n */\n this.range = range;\n /**\r\n * This Array will keep track of all Features associated with this Aesthetic object.\r\n * @type {Array<Feature>}\r\n */\n this._features = new Array();\n /**\r\n * This Array is used for? \r\n * @todo\r\n * @type {Array<Feature>}\r\n */\n this._allFeatures = null;\n /**\r\n * This particular element will be active or not in the Legend.\r\n * @type {boolean}\r\n */\n this.enabled = true; //Elemento da legenda ativado ou desativado\n /**\r\n * Outer of? This is used for what?\r\n * @type {boolean}\r\n */\n this.outer = false;\n return this; //@TODO remove this\n }\n\n /**\r\n * Adds a new feature to this Aesthetic object.\r\n * @param {number} id - The Feature id. Each feature will have a different id inside this Aesthetic object.\r\n * @param {{fx: string, _gisplayid:number}} properties - Properties associated with the Feature.\r\n * @param {{itemSize: number, numItems: number}} triangles - Number of triangles associated with the Feature.\r\n * @param {{itemSize: number, numItems: number}} borders - Number of borders associated with the Feature.\r\n * @param {number[]} points - The points that belong to the Feature.\r\n * \r\n * @memberOf Aesthetic\r\n */\n\n\n _createClass(Aesthetic, [{\n key: 'addFeature',\n value: function addFeature(id, properties, triangles, borders, points) {\n this._features.push(new _Feature.Feature(id, properties, triangles, borders, points));\n }\n\n /**\r\n * Gets this Aesthetic attribute.\r\n * @returns {Aesthetic._attr} - The string representing the attr of this Aesthetic.\r\n * \r\n * @memberOf Aesthetic\r\n */\n\n }, {\n key: 'getAttr',\n value: function getAttr() {\n return this._attr;\n }\n\n /**\r\n * Verifies the existence or not of the property Aesthethic._attr and if it fits inside this Aesthetic range.\r\n * @param {string} value - The attribute ?.\r\n * @returns {boolean} - True if there's no range or it is inside the range or ?, otherwise, false.\r\n * \r\n * @memberOf Aesthetic\r\n */\n\n }, {\n key: 'checkProperty',\n value: function checkProperty(value) {\n if (this.range == null) return true;else {\n if (typeof value === 'number') return (this.range[0] == null || value >= this.range[0]) && (this.range[1] == null || value < this.range[1] || value <= this.range[1] && this.outer == true);else return value == this.range[0];\n }\n }\n\n /**\r\n * Add new grouped feature ? \r\n * @todo Finish document of this method.\r\n * @param {number} id \r\n * @param {null} triangles - Always empty? See line:479 Map.js\r\n * @param {null} borders - Always empty? See line:479 Map.js \r\n * @param {{buffer: WebGLBuffer, itemSize: number, numItems: number}} points \r\n */\n\n }, {\n key: 'addGroupedFeature',\n value: function addGroupedFeature(id, triangles, borders, points) {\n if (this._allFeatures == null) {\n this._allFeatures = new Array();\n this._allFeatures.push(new _Feature.Feature(id, null, triangles, borders, points));\n } else {\n var cursor = 0; //TODO\n //this._allFeatures[0]._properties.push(properties);\n this._allFeatures[cursor].push(new _Feature.Feature(id, null, triangles, borders, points));\n //this._allFeatures[cursor]._triangles.concat(triangles);\n //this._allFeatures[cursor]._borders.concat(borders);\n }\n }\n\n /**\r\n * Inverts this Aesthetic element state in the Legend object.\r\n * If it was enabled it will be disabled or vice-versa.\r\n * @returns {boolean} Inverse of current enabled value.\r\n */\n\n }, {\n key: 'enableDisable',\n value: function enableDisable() {\n this.enabled = !this.enabled;\n return this.enabled;\n }\n }]);\n\n return Aesthetic;\n}();\n\n/*var obj = {\r\n i: id,\r\n a: attr,\r\n f: fcolor,\r\n s: stroke,\r\n p: pointsize,\r\n r: range\r\n }\r\n console.warn(\"Aest called constructor!!! == \" + JSON.stringify(obj));*///# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"2.js","sources":["webpack:///src/Gisplay/Aesthetic.js?59e8"],"sourcesContent":["import { Feature } from './Feature';\r\n\r\n/**\r\n * Class that represents an aesthetic element. There will be one Aesthetic class for each class on the Legend.\r\n * \r\n * @export\r\n * @class Aesthetic\r\n */\r\nexport class Aesthetic {\r\n\r\n    /**\r\n     * Creates an instance of Aesthetic. \r\n     * There will be as many Aesthetic objects as the number of classes on the Legend. \r\n     * @example 1-> {\"id\":0,\"attr\":\"f3\",\"fcolor\":[255,255,255,0.8],\r\n     *         \"stroke\":[0,0,0,1],\"pointsize\":null,\"range\":[1,37]}\r\n     * @example 2-> {\"id\":1,\"attr\":\"f3\",\"fcolor\":[255,255,0,0.8],\r\n     *         \"stroke\":[0,0,0,1],\"pointsize\":null,\"range\":[37,78]}\r\n     * @param {number} id - The unique id of the Aesthetic object.\r\n     * @param {string} attr - The attribute being mapped on this Aesthetic.\r\n     * @param {number[]} fcolor - The color to fill the Aesthetic element(RGBA).\r\n     * @param {number[]} stroke - Stroke color values(RGBA).\r\n     * @param {number|null} pointsize - Size of the Aesthetic point to be drawn (Used only in maps that require dots to be drawn).\r\n     * @param {number[]} range - The range for this particular Aesthetic element.\r\n     * \r\n     * @memberOf Aesthetic\r\n     */\r\n    constructor(id, attr, fcolor, stroke, pointsize, range) {\r\n        /**\r\n         * The unique id of the Aesthetic object. \r\n         * @type {number}\r\n         */\r\n        this.id = id;\r\n        /**\r\n         * The attribute being mapped on the Aesthetic.\r\n         * @type {string}\r\n         */\r\n        this._attr = attr;\r\n        /**\r\n         * The color to fill the Aesthetic element(RGBA).\r\n         * @type {number[4]}\r\n         */\r\n        this.fillColor = fcolor;\r\n        /**\r\n         * Stroke color values(RGBA).\r\n         * @type {number[4]}\r\n         */\r\n        this.strokeColor = stroke;\r\n        /**\r\n         * The size of the Aesthetic point to be drawn (Used only in maps that require dots to be drawn).\r\n         * @type {number|null}\r\n         */\r\n        this.pointSize = pointsize == null ? 1.0 : parseFloat(pointsize);\r\n        /**\r\n         * The range for this particular Aesthetic element.\r\n         * @type {number[2]}\r\n         */\r\n        this.range = range;\r\n        /**\r\n         * This Array will keep track of all Features associated with this Aesthetic object.\r\n         * @type {Array<Feature>}\r\n         */\r\n        this._features = new Array();\r\n        /**\r\n         * This Array is used for? \r\n         * @todo\r\n         * @type {Array<Feature>}\r\n         */\r\n        this._allFeatures = null;\r\n        /**\r\n         * This particular element will be active or not in the Legend.\r\n         * @type {boolean}\r\n         */\r\n        this.enabled = true;//Elemento da legenda ativado ou desativado\r\n        /**\r\n         * Outer of? This is used for what?\r\n         * @type {boolean}\r\n         */\r\n        this.outer = false;\r\n        return this; //@TODO remove this\r\n    }\r\n\r\n    /**\r\n     * Adds a new feature to this Aesthetic object.\r\n     * @param {number} id - The Feature id. Each feature will have a different id inside this Aesthetic object.\r\n     * @param {{fx: string, _gisplayid:number}} properties - Properties associated with the Feature.\r\n     * @param {{itemSize: number, numItems: number}} triangles - Number of triangles associated with the Feature.\r\n     * @param {{itemSize: number, numItems: number}} borders - Number of borders associated with the Feature.\r\n     * @param {number[]} points - The points that belong to the Feature.\r\n     * \r\n     * @memberOf Aesthetic\r\n     */\r\n    addFeature(id, properties, triangles, borders, points) {\r\n        this._features.push(new Feature(id, properties, triangles, borders, points));\r\n    }\r\n\r\n    /**\r\n     * Gets this Aesthetic attribute.\r\n     * @returns {Aesthetic._attr} - The string representing the attr of this Aesthetic.\r\n     * \r\n     * @memberOf Aesthetic\r\n     */\r\n    getAttr() {\r\n        return this._attr;\r\n    }\r\n\r\n    /**\r\n     * Verifies the existence or not of the property Aesthethic._attr and if it fits inside this Aesthetic range.\r\n     * @param {string} value - The attribute ?.\r\n     * @returns {boolean} - True if there's no range or it is inside the range or ?, otherwise, false.\r\n     * \r\n     * @memberOf Aesthetic\r\n     */\r\n    checkProperty(value) {\r\n        if (this.range == null)\r\n            return true;\r\n        else {\r\n            if (typeof value === 'number') \r\n                return ((this.range[0] == null || value >= this.range[0]) &&\r\n                    (this.range[1] == null || (value < this.range[1] || (value <= this.range[1] && this.outer == true))));\r\n            else\r\n                return (value == this.range[0]);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Add new grouped feature ? \r\n     * @todo Finish document of this method.\r\n     * @param {number} id \r\n     * @param {null} triangles - Always empty? See line:479 Map.js\r\n     * @param {null} borders - Always empty? See line:479 Map.js \r\n     * @param {{buffer: WebGLBuffer, itemSize: number, numItems: number}} points \r\n     */\r\n    addGroupedFeature(id, triangles, borders, points) {\r\n        if (this._allFeatures == null) {\r\n            this._allFeatures = new Array();\r\n            this._allFeatures.push(new Feature(id, null, triangles, borders, points));\r\n        }\r\n        else {\r\n            const cursor = 0; //TODO\r\n            //this._allFeatures[0]._properties.push(properties);\r\n            this._allFeatures[cursor].push(new Feature(id, null, triangles, borders, points));\r\n            //this._allFeatures[cursor]._triangles.concat(triangles);\r\n            //this._allFeatures[cursor]._borders.concat(borders);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Inverts this Aesthetic element state in the Legend object.\r\n     * If it was enabled it will be disabled or vice-versa.\r\n     * @returns {boolean} Inverse of current enabled value.\r\n     */\r\n    enableDisable() {\r\n        this.enabled = !this.enabled;\r\n        return this.enabled;\r\n    }\r\n}\r\n\r\n /*var obj = {\r\n            i: id,\r\n            a: attr,\r\n            f: fcolor,\r\n            s: stroke,\r\n            p: pointsize,\r\n            r: range\r\n        }\r\n        console.warn(\"Aest called constructor!!! == \" + JSON.stringify(obj));*/\n\n\n// WEBPACK FOOTER //\n// src/Gisplay/Aesthetic.js"],"mappings":";;;;;;;;;AAAA;AACA;;;AACA;;;;;;AAMA;AACA;AACA;;;;;;;;;;;;;;;;AAgBA;AAAA;AACA;AAAA;;;;AAIA;AACA;;;;AAIA;AACA;;;;AAIA;AACA;;;;AAIA;AACA;;;;AAIA;AACA;;;;AAIA;AACA;;;;AAIA;AACA;;;;;AAKA;AACA;;;;AAIA;AACA;;;;AAIA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;AAUA;AACA;AACA;AACA;AACA;;;;;;;;;AAMA;AACA;AACA;AACA;AACA;;;;;;;;;;AAOA;AACA;AAGA;AAKA;AACA;AACA;AACA;;;;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAKA;AACA;AACA;AACA;;;;;;AAGA;;;;;;;;","sourceRoot":""}");
/***/ }),
/* 3 */
/* unknown exports provided */
/* all exports used */
/*!****************************************!*\
!*** ./src/Gisplay/Maps/Choropleth.js ***!
\****************************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Choropleth = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Map2 = __webpack_require__(/*! ./Map */ 1);\n\nvar _Legend = __webpack_require__(/*! ../Legend */ 0);\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\r\n * Choropleth implementation 06/03\r\n */\nvar Choropleth = exports.Choropleth = function (_Map) {\n _inherits(Choropleth, _Map);\n\n function Choropleth(bgmap, geometry, options) {\n _classCallCheck(this, Choropleth);\n\n var _this = _possibleConstructorReturn(this, (Choropleth.__proto__ || Object.getPrototypeOf(Choropleth)).call(this, bgmap, geometry, options));\n\n _this.aesthetics = new Array();\n _this.geometry = geometry;\n _this.loadOptions(options, bgmap);\n _this.id = mapcount++;\n _this.type = 'CP';\n maps.push(_this);\n _this.initialize();\n /*return this;*/\n return _this;\n }\n\n //@override\n\n\n _createClass(Choropleth, [{\n key: 'draw',\n value: function draw() {\n //console.log(\"Choropleth drawaaa() called\");\n this.clear();\n for (var i = 0; i < this.aesthetics.length; i++) {\n if (this.aesthetics[i].enabled == true) {\n this.drawTriangles(this.aesthetics[i]);\n }\n this.drawBorders(this.aesthetics[i]);\n }\n }\n }, {\n key: 'buildLegend',\n value: function buildLegend() {\n //console.log(\"Choropleth buildLegend() called\");\n this.legend = new _Legend.Legend(this.id, this.legendTitle);\n for (var a in this.aesthetics) {\n this.legend.insertPolygonRow(this.aesthetics[a], this);\n }\n this.legend.insertLegend(this.map);\n }\n }, {\n key: 'defaults',\n value: function defaults(defaultid) {\n //console.log(\"Choropleth defaults() called\");\n var options = {};\n switch (defaultid) {\n case 1:\n options.colorScheme = ['white', 'yellow', 'orange', 'red'];\n options.numberOfClasses = 4;\n break;\n default:\n break;\n }\n return options;\n }\n }]);\n\n return Choropleth;\n}(_Map2.Map);//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvR2lzcGxheS9NYXBzL0Nob3JvcGxldGguanM/ZjhjYiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNYXAgfSBmcm9tICcuL01hcCc7XHJcbmltcG9ydCB7IExlZ2VuZCB9IGZyb20gJy4uL0xlZ2VuZCc7XHJcblxyXG4vKipcclxuICogQ2hvcm9wbGV0aCBpbXBsZW1lbnRhdGlvbiAwNi8wM1xyXG4gKi9cclxuZXhwb3J0IGNsYXNzIENob3JvcGxldGggZXh0ZW5kcyBNYXAge1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKGJnbWFwLCBnZW9tZXRyeSwgb3B0aW9ucykge1xyXG4gICAgICAgIHN1cGVyKGJnbWFwLCBnZW9tZXRyeSwgb3B0aW9ucyk7XHJcbiAgICAgICAgdGhpcy5hZXN0aGV0aWNzID0gbmV3IEFycmF5KCk7XHJcbiAgICAgICAgdGhpcy5nZW9tZXRyeSA9IGdlb21ldHJ5O1xyXG4gICAgICAgIHRoaXMubG9hZE9wdGlvbnMob3B0aW9ucywgYmdtYXApO1xyXG4gICAgICAgIHRoaXMuaWQgPSBtYXBjb3VudCsrO1xyXG4gICAgICAgIHRoaXMudHlwZSA9ICdDUCc7XHJcbiAgICAgICAgbWFwcy5wdXNoKHRoaXMpO1xyXG4gICAgICAgIHRoaXMuaW5pdGlhbGl6ZSgpO1xyXG4gICAgICAgIC8qcmV0dXJuIHRoaXM7Ki9cclxuICAgIH1cclxuXHJcbiAgICAvL0BvdmVycmlkZVxyXG4gICAgZHJhdygpIHtcclxuICAgICAgICAvL2NvbnNvbGUubG9nKFwiQ2hvcm9wbGV0aCBkcmF3YWFhKCkgY2FsbGVkXCIpO1xyXG4gICAgICAgIHRoaXMuY2xlYXIoKTtcclxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuYWVzdGhldGljcy5sZW5ndGg7IGkrKykge1xyXG4gICAgICAgICAgICBpZiAodGhpcy5hZXN0aGV0aWNzW2ldLmVuYWJsZWQgPT0gdHJ1ZSkge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5kcmF3VHJpYW5nbGVzKHRoaXMuYWVzdGhldGljc1tpXSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgdGhpcy5kcmF3Qm9yZGVycyh0aGlzLmFlc3RoZXRpY3NbaV0pO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBidWlsZExlZ2VuZCgpIHtcclxuICAgICAgICAvL2NvbnNvbGUubG9nKFwiQ2hvcm9wbGV0aCBidWlsZExlZ2VuZCgpIGNhbGxlZFwiKTtcclxuICAgICAgICB0aGlzLmxlZ2VuZCA9IG5ldyBMZWdlbmQodGhpcy5pZCwgdGhpcy5sZWdlbmRUaXRsZSk7XHJcbiAgICAgICAgZm9yIChjb25zdCBhIGluIHRoaXMuYWVzdGhldGljcykge1xyXG4gICAgICAgICAgICB0aGlzLmxlZ2VuZC5pbnNlcnRQb2x5Z29uUm93KHRoaXMuYWVzdGhldGljc1thXSwgdGhpcyk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHRoaXMubGVnZW5kLmluc2VydExlZ2VuZCh0aGlzLm1hcCk7XHJcbiAgICB9XHJcblxyXG4gICAgZGVmYXVsdHMoZGVmYXVsdGlkKSB7XHJcbiAgICAgICAgLy9jb25zb2xlLmxvZyhcIkNob3JvcGxldGggZGVmYXVsdHMoKSBjYWxsZWRcIik7XHJcbiAgICAgICAgY29uc3Qgb3B0aW9ucyA9IHt9O1xyXG4gICAgICAgIHN3aXRjaCAoZGVmYXVsdGlkKSB7XHJcbiAgICAgICAgICAgIGNhc2UgMTpcclxuICAgICAgICAgICAgICAgIG9wdGlvbnMuY29sb3JTY2hlbWUgPSBbJ3doaXRlJywgJ3llbGxvdycsICdvcmFuZ2UnLCAncmVkJ107XHJcbiAgICAgICAgICAgICAgICBvcHRpb25zLm51bWJlck9mQ2xhc3NlcyA9IDQ7XHJcbiAgICAgICAgICAgICAgICBicmVhaztcclxuICAgICAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgICAgIGJyZWFrO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gb3B0aW9ucztcclxuICAgIH1cclxufVxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvR2lzcGxheS9NYXBzL0Nob3JvcGxldGguanMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFBQTtBQUNBOzs7Ozs7O0FBQ0E7OztBQUdBOzs7QUFFQTtBQUFBO0FBQ0E7QUFEQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQVRBO0FBVUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBREE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTkE7QUFRQTtBQUNBOzs7OyIsInNvdXJjZVJvb3QiOiIifQ==");
/***/ }),
/* 4 */
/* unknown exports provided */
/* all exports used */
/*!********************************!*\
!*** ./src/Gisplay/Gisplay.js ***!
\********************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Gisplay = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Choropleth = __webpack_require__(/*! ./Maps/Choropleth */ 3);\n\nvar _DotMap = __webpack_require__(/*! ./Maps/DotMap */ 10);\n\nvar _ChangeMap = __webpack_require__(/*! ./Maps/ChangeMap */ 8);\n\nvar _ProportionalSymbolsMap = __webpack_require__(/*! ./Maps/ProportionalSymbolsMap */ 11);\n\nvar _ChorochromaticMap = __webpack_require__(/*! ./Maps/ChorochromaticMap */ 9);\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\r\n * Gisplay API entry point with one method for each map available.\r\n */\nvar Gisplay = exports.Gisplay = function () {\n\n /**\r\n * Creates an instance of the Gisplay API.\r\n * \r\n * @memberOf Gisplay\r\n */\n function Gisplay() {\n _classCallCheck(this, Gisplay);\n\n console.log(\"Gisplay Class constructor\");\n /**\r\n * TimeStamp at the beginning.\r\n * @type {number} \r\n */\n this.startTimeStamp = 0;\n\n /**\r\n * Whether or not it should profile the API.\r\n * @type {string} - Whether or not it should profile the API.\r\n */\n window.profiling = true;\n /**\r\n * @type {Array} - Array of maps. @WHY?\r\n */\n window.maps = new Array();\n /**\r\n * @type {number} - The number of maps. @WHY?\r\n */\n window.mapcount = 0;\n\n //WebGL API\n /**\r\n * @type {number} - The number of vertices produced. @WHY?\r\n */\n window._vertexcount = 0;\n /**\r\n * @type {number} - The number of ???. @WHY?\r\n */\n window._tricount = 0;\n }\n\n /**\r\n * Creates a map of type Choropleth.\r\n * @param {Object} bgmap - Background map object be used(atm only MapBox being used).- Background map object be used(atm only MapBox being used).\r\n * @param {JSON} geometry - The object that contains the data.\r\n * @param {Object} options - Object that contains user personalization options.\r\n * \r\n * @memberOf Gisplay\r\n */\n\n\n _createClass(Gisplay, [{\n key: 'makeChoropleth',\n value: function makeChoropleth(bgmap, geometry, options) {\n console.log(bgmap);\n if (window.profiling == true) this.startTimeStamp = Date.now();\n var gismap = new _Choropleth.Choropleth(bgmap, geometry, options);\n this.makeMap(gismap, options);\n }\n\n /**\r\n * Creates a Dot Map.\r\n * @param {Object} bgmap - Background map object be used(atm only MapBox being used).\r\n * @param {JSON} geometry - The object that contains the data.\r\n * @param {Object} options - Object that contains user personalization options.\r\n * \r\n * @memberOf Gisplay\r\n */\n\n }, {\n key: 'makeDotMap',\n value: function makeDotMap(bgmap, geometry, options) {\n if (window.profiling == true) this.startTimeStamp = Date.now();\n var gismap = new _DotMap.DotMap(bgmap, geometry, options);\n this.makeMap(gismap, options);\n }\n\n /**\r\n * Creates a Change Map.\r\n * @param {Object} bgmap - Background map object be used(atm only MapBox being used).\r\n * @param {JSON} geometry - The object that contains the data.\r\n * @param {Object} options - Object that contains user personalization options.\r\n * \r\n * @memberOf Gisplay\r\n */\n\n }, {\n key: 'makeChangeMap',\n value: function makeChangeMap(bgmap, geometry, options) {\n if (window.profiling == true) this.startTimeStamp = Date.now();\n var gismap = new _ChangeMap.ChangeMap(bgmap, geometry, options);\n this.makeMap(gismap, options);\n }\n\n /**\r\n * Creates a Proportional Symbols Map.\r\n * @param {Object} bgmap - Background map object be used(atm only MapBox being used).\r\n * @param {JSON} geometry - The object that contains the data.\r\n * @param {Object} options - Object that contains user personalization options.\r\n * \r\n * @memberOf Gisplay\r\n */\n\n }, {\n key: 'makeProportionalSymbolsMap',\n value: function makeProportionalSymbolsMap(bgmap, geometry, options) {\n if (window.profiling == true) this.startTimeStamp = Date.now();\n var gismap = new _ProportionalSymbolsMap.ProportionalSymbolsMap(bgmap, geometry, options);\n this.makeMap(gismap, options); //@Rui add options (n tinha WUT)\n }\n\n /**\r\n * Creates a Chorocromatic Map.\r\n * @param {Object} bgmap - Background map object be used(atm only MapBox being used).\r\n * @param {JSON} geometry - The object that contains the data.\r\n * @param {Object} options - Object that contains user personalization options.\r\n * \r\n * @memberOf Gisplay\r\n */\n\n }, {\n key: 'makeChorochromaticMap',\n value: function makeChorochromaticMap(bgmap, geometry, options) {\n if (window.profiling == true) this.startTimeStamp = Date.now();\n var gismap = new _ChorochromaticMap.ChorochromaticMap(bgmap, geometry, options);\n this.makeMap(gismap, options); //@Rui .defaultid);\n }\n\n /**\r\n * Function that executes all the process associated with the creation of thematic maps.\r\n * @todo Should clean up this removing profiling code?\r\n * @param {Map} gismap - The Gisplay Map to use (Choropleth, DotMap,etc).\r\n * @param {Object} options - Object that contains user personalization options.\r\n * \r\n * @memberOf Gisplay\r\n */\n\n }, {\n key: 'makeMap',\n value: function makeMap(gismap, options) {\n var _this = this;\n\n var defaultid = options.defaultid != null ? defaultid : 1;\n setTimeout(function (console) {\n var start = 0;\n if (window.profiling == true) start = Date.now();\n if (gismap.colorscheme == undefined) gismap.colorscheme = gismap.defaults(defaultid).colorScheme;\n if (gismap.classbreaks == undefined) {\n if (gismap.numberofclasses == undefined) {\n gismap.numberofclasses = gismap.defaults(defaultid).numberOfClasses;\n }\n gismap.preProcessData(gismap.geometry, gismap.numberofclasses, gismap.algorithm, gismap.colorscheme);\n }\n\n //gismap.processData(gismap.geometry);\n gismap.loadGeoJSON(gismap.geometry);\n var start2 = 0;\n if (window.profiling == true) {\n start2 = Date.now();\n window.console.log('Tempo de processamento do dados (segundos): ' + (start2 - start) / 1000);\n }\n gismap.draw();\n\n var end = 0;\n if (window.profiling == true) {\n end = Date.now();\n window.console.log('Tempo de desenho do mapa (segundos): ' + (end - start2) / 1000);\n }\n if (options.legend != false) gismap.buildLegend();\n if (options.loader != false) {\n gismap.loader();\n }\n if (window.profiling == true) {\n end = Date.now();\n window.console.log('Tempo total (segundos): ' + (end - _this.startTimeStamp) / 1000);\n }\n }, 1);\n }\n }]);\n\n return Gisplay;\n}();//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"4.js","sources":["webpack:///src/Gisplay/Gisplay.js?05a5"],"sourcesContent":["import { Choropleth } from './Maps/Choropleth';\r\nimport { DotMap } from './Maps/DotMap';\r\nimport { ChangeMap } from './Maps/ChangeMap';\r\nimport { ProportionalSymbolsMap } from './Maps/ProportionalSymbolsMap'\r\nimport { ChorochromaticMap } from './Maps/ChorochromaticMap';\r\n\r\n/**\r\n * Gisplay API entry point with one method for each map available.\r\n */\r\nexport class Gisplay {\r\n\r\n    /**\r\n     * Creates an instance of the Gisplay API.\r\n     * \r\n     * @memberOf Gisplay\r\n     */\r\n    constructor() {\r\n        console.log(\"Gisplay Class constructor\");\r\n        /**\r\n         * TimeStamp at the beginning.\r\n         * @type {number} \r\n         */\r\n        this.startTimeStamp = 0;\r\n\r\n        /**\r\n         * Whether or not it  should profile the API.\r\n         * @type {string} - Whether or not it  should profile the API.\r\n         */\r\n        window.profiling = true;\r\n        /**\r\n         * @type {Array} - Array of maps. @WHY?\r\n         */\r\n        window.maps = new Array();\r\n        /**\r\n         * @type {number} - The number of maps. @WHY?\r\n         */\r\n        window.mapcount = 0;\r\n\r\n        //WebGL API\r\n        /**\r\n        * @type {number} - The number of vertices produced. @WHY?\r\n        */\r\n        window._vertexcount = 0;\r\n        /**\r\n        * @type {number} - The number of ???. @WHY?\r\n        */\r\n        window._tricount = 0;\r\n    }\r\n\r\n    /**\r\n     * Creates a map of type Choropleth.\r\n     * @param {Object} bgmap - Background map object be used(atm only MapBox being used).- Background map object be used(atm only MapBox being used).\r\n     * @param {JSON} geometry - The object that contains the data.\r\n     * @param {Object} options - Object that contains user personalization options.\r\n     * \r\n     * @memberOf Gisplay\r\n     */\r\n    makeChoropleth(bgmap, geometry, options) {\r\n        console.log(bgmap);\r\n        if (window.profiling == true)\r\n            this.startTimeStamp = Date.now();\r\n        const gismap = new Choropleth(bgmap, geometry, options);\r\n        this.makeMap(gismap, options);\r\n    }\r\n\r\n    /**\r\n     * Creates a Dot Map.\r\n     * @param {Object} bgmap - Background map object be used(atm only MapBox being used).\r\n     * @param {JSON} geometry - The object that contains the data.\r\n     * @param {Object} options - Object that contains user personalization options.\r\n     * \r\n     * @memberOf Gisplay\r\n     */\r\n    makeDotMap(bgmap, geometry, options) {\r\n        if (window.profiling == true)\r\n            this.startTimeStamp = Date.now();\r\n        const gismap = new DotMap(bgmap, geometry, options);\r\n        this.makeMap(gismap, options);\r\n    }\r\n\r\n    /**\r\n     * Creates a Change Map.\r\n     * @param {Object} bgmap - Background map object be used(atm only MapBox being used).\r\n     * @param {JSON} geometry - The object that contains the data.\r\n     * @param {Object} options - Object that contains user personalization options.\r\n     * \r\n     * @memberOf Gisplay\r\n     */\r\n    makeChangeMap(bgmap, geometry, options) {\r\n        if (window.profiling == true)\r\n            this.startTimeStamp = Date.now();\r\n        const gismap = new ChangeMap(bgmap, geometry, options);\r\n        this.makeMap(gismap, options);\r\n    }\r\n\r\n    /**\r\n     * Creates a Proportional Symbols Map.\r\n     * @param {Object} bgmap - Background map object be used(atm only MapBox being used).\r\n     * @param {JSON} geometry - The object that contains the data.\r\n     * @param {Object} options - Object that contains user personalization options.\r\n     * \r\n     * @memberOf Gisplay\r\n     */\r\n    makeProportionalSymbolsMap(bgmap, geometry, options) {\r\n        if (window.profiling == true)\r\n            this.startTimeStamp = Date.now();\r\n        const gismap = new ProportionalSymbolsMap(bgmap, geometry, options);\r\n        this.makeMap(gismap, options); //@Rui add options (n tinha WUT)\r\n    }\r\n\r\n    /**\r\n     * Creates a Chorocromatic Map.\r\n     * @param {Object} bgmap - Background map object be used(atm only MapBox being used).\r\n     * @param {JSON} geometry - The object that contains the data.\r\n     * @param {Object} options - Object that contains user personalization options.\r\n     * \r\n     * @memberOf Gisplay\r\n     */\r\n    makeChorochromaticMap(bgmap, geometry, options) {\r\n        if (window.profiling == true)\r\n            this.startTimeStamp = Date.now();\r\n        const gismap = new ChorochromaticMap(bgmap, geometry, options);\r\n        this.makeMap(gismap, options);//@Rui .defaultid);\r\n    }\r\n\r\n    /**\r\n     * Function that executes all the process associated with the creation of thematic maps.\r\n     * @todo Should clean up this removing profiling code?\r\n     * @param {Map} gismap - The Gisplay Map to use (Choropleth, DotMap,etc).\r\n     * @param {Object} options - Object that contains user personalization options.\r\n     * \r\n     * @memberOf Gisplay\r\n     */\r\n    makeMap(gismap, options) {\r\n        let defaultid = options.defaultid != null ? defaultid : 1;\r\n        setTimeout(console => {\r\n            let start = 0;\r\n            if (window.profiling == true)\r\n                start = Date.now();\r\n            if (gismap.colorscheme == undefined)\r\n                gismap.colorscheme = gismap.defaults(defaultid).colorScheme;\r\n            if (gismap.classbreaks == undefined) {\r\n                if (gismap.numberofclasses == undefined) {\r\n                    gismap.numberofclasses = gismap.defaults(defaultid).numberOfClasses;\r\n                }\r\n                gismap.preProcessData(gismap.geometry, gismap.numberofclasses, gismap.algorithm, gismap.colorscheme);\r\n            }\r\n\r\n            //gismap.processData(gismap.geometry);\r\n            gismap.loadGeoJSON(gismap.geometry);\r\n            let start2 = 0;\r\n            if (window.profiling == true) {\r\n                start2 = Date.now();\r\n                window.console.log(`Tempo de processamento do dados (segundos): ${(start2 - start) / 1000}`);\r\n            }\r\n            gismap.draw();\r\n\r\n            let end = 0;\r\n            if (window.profiling == true) {\r\n                end = Date.now();\r\n                window.console.log(`Tempo de desenho do mapa (segundos): ${(end - start2) / 1000}`);\r\n            }\r\n            if (options.legend != false)\r\n                gismap.buildLegend();\r\n            if (options.loader != false) {\r\n                gismap.loader();\r\n            }\r\n            if (window.profiling == true) {\r\n                end = Date.now();\r\n                window.console.log(`Tempo total (segundos): ${(end - this.startTimeStamp) / 1000}`);\r\n            }\r\n        }, 1);\r\n    }\r\n}\n\n\n// WEBPACK FOOTER //\n// src/Gisplay/Gisplay.js"],"mappings":";;;;;;;;;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;;;AACA;;;AAGA;AACA;AACA;;;;;AAKA;AAAA;AACA;AAAA;AACA;;;;AAIA;AACA;AACA;;;;AAIA;AACA;;;AAGA;AACA;;;AAGA;AACA;AACA;AACA;;;AAGA;AACA;;;AAGA;AACA;AACA;AACA;;;;;;;;;;;;AAQA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;;;;;;;;;;AAQA;AACA;AAEA;AACA;AACA;AACA;AACA;;;;;;;;;;;AAQA;AACA;AAEA;AACA;AACA;AACA;AACA;;;;;;;;;;;AAQA;AACA;AAEA;AACA;AACA;AACA;AACA;;;;;;;;;;;AAQA;AACA;AAEA;AACA;AACA;AACA;AACA;;;;;;;;;;;AAQA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;","sourceRoot":""}");
/***/ }),
/* 5 */
/* unknown exports provided */
/* all exports used */
/*!********************************************!*\
!*** ./src/Gisplay/Maps/GisplayOptions.js ***!
\********************************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\r\n * This class will contain all the options available on the Gisplay API.\r\n */\nvar GisplayOptions =\n\n/**\r\n * Creates a new Options object. User options take precedence over default options.\r\n * @param {Object} userOptions - The user defined options\r\n * @param {string} userOptions.attr - The attribute to be mapped.\r\n * @param {string[]} [userOptions.colorScheme] - The color scheme to be used.\r\n * @param {number} [userOptions.numberofclasses] - Number of classes to be used on the map Legend.\r\n * @param {string} [userOptions.algorithm=quantile] - Algorithm to be used by the API to calculate classes intervals. \r\n * @param {number[]} [userOptions.classBreaks=undefined] - Class intervals.\r\n * @param {boolean} [userOptions.interactive=true] - Show pop-up when the user clicks on a Feature.\r\n * @param {boolean} [userOptions.showPropertiesOnClick=null] - Show pop-up when the user clicks on a Feature.\r\n */\nexports.GisplayOptions = function GisplayOptions(userOptions) {\n _classCallCheck(this, GisplayOptions);\n\n /**\r\n * The attribute to be mapped.\r\n * @type {string} \r\n */\n this.attr = userOptions.attr;\n /**\r\n * Array of colors to be used by the API. \r\n * @type {string[]}\r\n */\n this.colorscheme = userOptions.colorScheme;\n /**\r\n * Number of classes to be used on the map Legend. This option should be used when the user wants the API\r\n * to calculate the classes (aka ranges) using the given number.\r\n * @type{number}\r\n */\n this.numberofclasses = userOptions.numberOfClasses;\n /**\r\n * Algorithm to be used by the API to calculate classes intervals. \r\n * Available options are 'quantile', 'equidistant', 'k-means'.\r\n * @type {string}\r\n */\n this.algorithm = userOptions.algorithm || 'quantile';\n /**\r\n * Class intervals. If this is defined then numberOfClasses and classBreakMethod are ignored.\r\n * @type {number[]}\r\n */\n this.classBreaks = userOptions.classBreaks || undefined; //undefined n era preciso\n /**\r\n * When we click on a feature that is on the map, show properties of said Feature or not.\r\n * @type {boolean}\r\n */\n this.interactive = userOptions.interactive || true;\n /**\r\n * Properties and description to be shown when the user clicks on a Feature.\r\n * @todo NOT USED? \r\n * @type {string[]}\r\n */\n this.showPropertiesOnClick = options.showPropertiesOnClick || null;\n\n /**\r\n * Alpha to be used in WebGL.\r\n * 0 means fully transparent <-> 1 fully opaque.\r\n * @type {number}\r\n */\n this.alpha = userOptions.alpha != undefined ? userOptions.alpha : 0.8;\n /**\r\n * \r\n */\n this.dynamic = userOptions.memorySaver == undefined ? false : !userOptions.memorySaver;\n this.maxfeatures = userOptions.maxFeatures;\n\n this.algorithm = userOptions.classBreaksMethod;\n this.legendOnClickCall = userOptions.legendOnClickFunction;\n this.mapOnClickCall = userOptions.mapOnClickFunction;\n this.minuend = userOptions.minuend;\n this.subtrahend = userOptions.subtrahend;\n this.legendTitle = userOptions.legendTitle != undefined ? userOptions.legendTitle : this.attr != undefined ? this.attr : this.minuend + ' - ' + this.subtrahend;\n this.numberOfLegendItems = userOptions.numberOfLegendItems != undefined ? userOptions.numberOfLegendItems : 2;\n};//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvR2lzcGxheS9NYXBzL0dpc3BsYXlPcHRpb25zLmpzPzdkOGEiXSwic291cmNlc0NvbnRlbnQiOlsiXHJcbi8qKlxyXG4gKiBUaGlzIGNsYXNzIHdpbGwgY29udGFpbiBhbGwgdGhlIG9wdGlvbnMgYXZhaWxhYmxlIG9uIHRoZSBHaXNwbGF5IEFQSS5cclxuICovXHJcbmV4cG9ydCBjbGFzcyBHaXNwbGF5T3B0aW9ucyB7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBDcmVhdGVzIGEgbmV3IE9wdGlvbnMgb2JqZWN0LiBVc2VyIG9wdGlvbnMgdGFrZSBwcmVjZWRlbmNlIG92ZXIgZGVmYXVsdCBvcHRpb25zLlxyXG4gICAgICogQHBhcmFtIHtPYmplY3R9IHVzZXJPcHRpb25zIC0gVGhlIHVzZXIgZGVmaW5lZCBvcHRpb25zXHJcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gdXNlck9wdGlvbnMuYXR0ciAtICBUaGUgYXR0cmlidXRlIHRvIGJlIG1hcHBlZC5cclxuICAgICAqIEBwYXJhbSB7c3RyaW5nW119IFt1c2VyT3B0aW9ucy5jb2xvclNjaGVtZV0gLSAgVGhlIGNvbG9yIHNjaGVtZSB0byBiZSB1c2VkLlxyXG4gICAgICogQHBhcmFtIHtudW1iZXJ9IFt1c2VyT3B0aW9ucy5udW1iZXJvZmNsYXNzZXNdIC0gIE51bWJlciBvZiBjbGFzc2VzIHRvIGJlIHVzZWQgb24gdGhlIG1hcCBMZWdlbmQuXHJcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gW3VzZXJPcHRpb25zLmFsZ29yaXRobT1xdWFudGlsZV0gLSAgQWxnb3JpdGhtIHRvIGJlIHVzZWQgYnkgdGhlIEFQSSB0byBjYWxjdWxhdGUgY2xhc3NlcyBpbnRlcnZhbHMuIFxyXG4gICAgICogQHBhcmFtIHtudW1iZXJbXX0gW3VzZXJPcHRpb25zLmNsYXNzQnJlYWtzPXVuZGVmaW5lZF0gLSBDbGFzcyBpbnRlcnZhbHMuXHJcbiAgICAgKiBAcGFyYW0ge2Jvb2xlYW59IFt1c2VyT3B0aW9ucy5pbnRlcmFjdGl2ZT10cnVlXSAtIFNob3cgcG9wLXVwIHdoZW4gdGhlIHVzZXIgY2xpY2tzIG9uIGEgRmVhdHVyZS5cclxuICAgICAqIEBwYXJhbSB7Ym9vbGVhbn0gW3VzZXJPcHRpb25zLnNob3dQcm9wZXJ0aWVzT25DbGljaz1udWxsXSAtIFNob3cgcG9wLXVwIHdoZW4gdGhlIHVzZXIgY2xpY2tzIG9uIGEgRmVhdHVyZS5cclxuICAgICAqL1xyXG4gICAgY29uc3RydWN0b3IodXNlck9wdGlvbnMpIHtcclxuICAgICAgICAvKipcclxuICAgICAgICAgKiBUaGUgYXR0cmlidXRlIHRvIGJlIG1hcHBlZC5cclxuICAgICAgICAgKiBAdHlwZSB7c3RyaW5nfSBcclxuICAgICAgICAgKi9cclxuICAgICAgICB0aGlzLmF0dHIgPSB1c2VyT3B0aW9ucy5hdHRyO1xyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICAqIEFycmF5IG9mIGNvbG9ycyB0byBiZSB1c2VkIGJ5IHRoZSBBUEkuIFxyXG4gICAgICAgICAqIEB0eXBlIHtzdHJpbmdbXX1cclxuICAgICAgICAgKi9cclxuICAgICAgICB0aGlzLmNvbG9yc2NoZW1lID0gdXNlck9wdGlvbnMuY29sb3JTY2hlbWU7XHJcbiAgICAgICAgLyoqXHJcbiAgICAgICAgICogTnVtYmVyIG9mIGNsYXNzZXMgdG8gYmUgdXNlZCBvbiB0aGUgbWFwIExlZ2VuZC4gVGhpcyBvcHRpb24gc2hvdWxkIGJlIHVzZWQgd2hlbiB0aGUgdXNlciB3YW50cyB0aGUgQVBJXHJcbiAgICAgICAgICogdG8gY2FsY3VsYXRlIHRoZSBjbGFzc2VzIChha2EgcmFuZ2VzKSB1c2luZyB0aGUgZ2l2ZW4gbnVtYmVyLlxyXG4gICAgICAgICAqIEB0eXBle251bWJlcn1cclxuICAgICAgICAgKi9cclxuICAgICAgICB0aGlzLm51bWJlcm9mY2xhc3NlcyA9IHVzZXJPcHRpb25zLm51bWJlck9mQ2xhc3NlcztcclxuICAgICAgICAvKipcclxuICAgICAgICAgKiBBbGdvcml0aG0gdG8gYmUgdXNlZCBieSB0aGUgQVBJIHRvIGNhbGN1bGF0ZSBjbGFzc2VzIGludGVydmFscy4gXHJcbiAgICAgICAgICogQXZhaWxhYmxlIG9wdGlvbnMgYXJlICdxdWFudGlsZScsICdlcXVpZGlzdGFudCcsICdrLW1lYW5zJy5cclxuICAgICAgICAgKiBAdHlwZSB7c3RyaW5nfVxyXG4gICAgICAgICAqL1xyXG4gICAgICAgIHRoaXMuYWxnb3JpdGhtID0gdXNlck9wdGlvbnMuYWxnb3JpdGhtIHx8ICdxdWFudGlsZSc7XHJcbiAgICAgICAgLyoqXHJcbiAgICAgICAgICogQ2xhc3MgaW50ZXJ2YWxzLiBJZiB0aGlzIGlzIGRlZmluZWQgdGhlbiBudW1iZXJPZkNsYXNzZXMgYW5kIGNsYXNzQnJlYWtNZXRob2QgYXJlIGlnbm9yZWQuXHJcbiAgICAgICAgICogQHR5cGUge251bWJlcltdfVxyXG4gICAgICAgICAqL1xyXG4gICAgICAgIHRoaXMuY2xhc3NCcmVha3MgPSB1c2VyT3B0aW9ucy5jbGFzc0JyZWFrcyB8fCB1bmRlZmluZWQ7IC8vdW5kZWZpbmVkIG4gZXJhIHByZWNpc29cclxuICAgICAgICAvKipcclxuICAgICAgICAgKiBXaGVuIHdlIGNsaWNrIG9uIGEgZmVhdHVyZSB0aGF0IGlzIG9uIHRoZSBtYXAsIHNob3cgcHJvcGVydGllcyBvZiBzYWlkIEZlYXR1cmUgb3Igbm90LlxyXG4gICAgICAgICAqIEB0eXBlIHtib29sZWFufVxyXG4gICAgICAgICAqL1xyXG4gICAgICAgIHRoaXMuaW50ZXJhY3RpdmUgPSB1c2VyT3B0aW9ucy5pbnRlcmFjdGl2ZSB8fCB0cnVlO1xyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICAqIFByb3BlcnRpZXMgYW5kIGRlc2NyaXB0aW9uIHRvIGJlIHNob3duIHdoZW4gdGhlIHVzZXIgY2xpY2tzIG9uIGEgRmVhdHVyZS5cclxuICAgICAgICAgKiBAdG9kbyBOT1QgVVNFRD8gXHJcbiAgICAgICAgICogQHR5cGUge3N0cmluZ1tdfVxyXG4gICAgICAgICAqL1xyXG4gICAgICAgIHRoaXMuc2hvd1Byb3BlcnRpZXNPbkNsaWNrID0gb3B0aW9ucy5zaG93UHJvcGVydGllc09uQ2xpY2sgfHwgbnVsbDtcclxuXHJcblxyXG5cclxuXHJcblxyXG5cclxuICAgICAgICAvKipcclxuICAgICAgICAgKiBBbHBoYSB0byBiZSB1c2VkIGluIFdlYkdMLlxyXG4gICAgICAgICAqIDAgbWVhbnMgZnVsbHkgdHJhbnNwYXJlbnQgPC0+IDEgZnVsbHkgb3BhcXVlLlxyXG4gICAgICAgICAqIEB0eXBlIHtudW1iZXJ9XHJcbiAgICAgICAgICovXHJcbiAgICAgICAgdGhpcy5hbHBoYSA9IHVzZXJPcHRpb25zLmFscGhhICE9IHVuZGVmaW5lZCA/IHVzZXJPcHRpb25zLmFscGhhIDogMC44O1xyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICAqIFxyXG4gICAgICAgICAqL1xyXG4gICAgICAgIHRoaXMuZHluYW1pYyA9IHVzZXJPcHRpb25zLm1lbW9yeVNhdmVyID09IHVuZGVmaW5lZCA/IGZhbHNlIDogIXVzZXJPcHRpb25zLm1lbW9yeVNhdmVyO1xyXG4gICAgICAgIHRoaXMubWF4ZmVhdHVyZXMgPSB1c2VyT3B0aW9ucy5tYXhGZWF0dXJlcztcclxuXHJcbiAgICAgICAgdGhpcy5hbGdvcml0aG0gPSB1c2VyT3B0aW9ucy5jbGFzc0JyZWFrc01ldGhvZDtcclxuICAgICAgICB0aGlzLmxlZ2VuZE9uQ2xpY2tDYWxsID0gdXNlck9wdGlvbnMubGVnZW5kT25DbGlja0Z1bmN0aW9uO1xyXG4gICAgICAgIHRoaXMubWFwT25DbGlja0NhbGwgPSB1c2VyT3B0aW9ucy5tYXBPbkNsaWNrRnVuY3Rpb247XHJcbiAgICAgICAgdGhpcy5taW51ZW5kID0gdXNlck9wdGlvbnMubWludWVuZDtcclxuICAgICAgICB0aGlzLnN1YnRyYWhlbmQgPSB1c2VyT3B0aW9ucy5zdWJ0cmFoZW5kO1xyXG4gICAgICAgIHRoaXMubGVnZW5kVGl0bGUgPSB1c2VyT3B0aW9ucy5sZWdlbmRUaXRsZSAhPSB1bmRlZmluZWQgPyB1c2VyT3B0aW9ucy5sZWdlbmRUaXRsZSA6ICh0aGlzLmF0dHIgIT0gdW5kZWZpbmVkID8gdGhpcy5hdHRyIDogYCR7dGhpcy5taW51ZW5kfSAtICR7dGhpcy5zdWJ0cmFoZW5kfWApO1xyXG4gICAgICAgIHRoaXMubnVtYmVyT2ZMZWdlbmRJdGVtcyA9IHVzZXJPcHRpb25zLm51bWJlck9mTGVnZW5kSXRlbXMgIT0gdW5kZWZpbmVkID8gdXNlck9wdGlvbnMubnVtYmVyT2ZMZWdlbmRJdGVtcyA6IDI7XHJcbiAgICB9XHJcbn1cblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gc3JjL0dpc3BsYXkvTWFwcy9HaXNwbGF5T3B0aW9ucy5qcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFDQTs7O0FBR0E7QUFDQTtBQUNBOzs7Ozs7Ozs7OztBQUZBO0FBYUE7QUFDQTtBQUFBOzs7O0FBSUE7QUFDQTs7OztBQUlBO0FBQ0E7Ozs7O0FBS0E7QUFDQTs7Ozs7QUFLQTtBQUNBOzs7O0FBSUE7QUFDQTs7OztBQUlBO0FBQ0E7Ozs7O0FBS0E7QUFDQTtBQU1BOzs7OztBQUtBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOyIsInNvdXJjZVJvb3QiOiIifQ==");
/***/ }),
/* 6 */
/* unknown exports provided */
/* all exports used */
/*!********************************!*\
!*** ./src/Gisplay/Feature.js ***!
\********************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n//Intermediate API\n\n/**\r\n * This class represents a Feature. Each feature belongs to one Aesthetic element.\r\n * \r\n * @exports Feature\r\n * @class Feature\r\n */\nvar Feature =\n/**\r\n * Creates an instance of Feature.\r\n * @example 1-> {\"id\":0,\"properties\":{\"f1\":\"Alabama\",\"f2\":\"Autauga\",\"f3\":150,\"_gisplayid\":0},\r\n \"triangles\":[{\"itemSize\":2,\"numItems\":417}],\"borders\":[{\"itemSize\":2,\"numItems\":141}],\"points\":[]}\r\n * @param {number} id - This Feature id.\r\n * @param {{fx: string, _gisplayid:number}} properties - Properties associated with this Feature. \r\n * @param {{itemSize: number, numItems: number}} triangles - Number of triangles associated with this Feature. \r\n * @param {{itemSize: number, numItems: number}} borders - Number of borders associated with this Feature.\r\n * @param {number[]} points - The points that belong to this Feature.\r\n * \r\n * @memberOf Feature\r\n */\nexports.Feature = function Feature(id, properties, triangles, borders, points) {\n _classCallCheck(this, Feature);\n\n /**\r\n * This Feature id.\r\n * @type {number} \r\n */\n this._id = id;\n /**\r\n * Properties associated with this Feature. \r\n * @type {{fx: string, _gisplayid:number}} \r\n */\n this._properties = properties;\n /**\r\n * Number of triangles associated with this Feature.\r\n * @type {{itemSize: number, numItems: number}}\r\n */\n this._triangles = triangles;\n /**\r\n * Number of borders associated with this Feature.\r\n * @type {{itemSize: number, numItems: number}}\r\n */\n this._borders = borders;\n /**\r\n * The points that belong to this Feature.\r\n * @type {number[]}\r\n */\n this._points = points;\n return this; // @Rui Remover this\n};\n/* if (window.count == 0) {\r\n var obj = {\r\n i: id,\r\n prs: properties,\r\n ts: triangles,\r\n bs: borders,\r\n pts: points,\r\n }\r\n window.count++;\r\n console.log(JSON.stringify(obj))\r\n }*///# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvR2lzcGxheS9GZWF0dXJlLmpzP2ZiNWMiXSwic291cmNlc0NvbnRlbnQiOlsiLy9JbnRlcm1lZGlhdGUgQVBJXHJcblxyXG4vKipcclxuICogVGhpcyBjbGFzcyByZXByZXNlbnRzIGEgRmVhdHVyZS4gRWFjaCBmZWF0dXJlIGJlbG9uZ3MgdG8gb25lIEFlc3RoZXRpYyBlbGVtZW50LlxyXG4gKiBcclxuICogQGV4cG9ydHMgRmVhdHVyZVxyXG4gKiBAY2xhc3MgRmVhdHVyZVxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEZlYXR1cmUge1xyXG4gICAgLyoqXHJcbiAgICAgKiBDcmVhdGVzIGFuIGluc3RhbmNlIG9mIEZlYXR1cmUuXHJcbiAgICAgKiBAZXhhbXBsZSAxLT4ge1wiaWRcIjowLFwicHJvcGVydGllc1wiOntcImYxXCI6XCJBbGFiYW1hXCIsXCJmMlwiOlwiQXV0YXVnYVwiLFwiZjNcIjoxNTAsXCJfZ2lzcGxheWlkXCI6MH0sXHJcbiAgICAgICAgICAgICAgICAgICAgIFwidHJpYW5nbGVzXCI6W3tcIml0ZW1TaXplXCI6MixcIm51bUl0ZW1zXCI6NDE3fV0sXCJib3JkZXJzXCI6W3tcIml0ZW1TaXplXCI6MixcIm51bUl0ZW1zXCI6MTQxfV0sXCJwb2ludHNcIjpbXX1cclxuICAgICAqIEBwYXJhbSB7bnVtYmVyfSBpZCAtIFRoaXMgRmVhdHVyZSBpZC5cclxuICAgICAqIEBwYXJhbSB7e2Z4OiBzdHJpbmcsIF9naXNwbGF5aWQ6bnVtYmVyfX0gcHJvcGVydGllcyAtIFByb3BlcnRpZXMgYXNzb2NpYXRlZCB3aXRoIHRoaXMgRmVhdHVyZS4gIFxyXG4gICAgICogQHBhcmFtIHt7aXRlbVNpemU6IG51bWJlciwgbnVtSXRlbXM6IG51bWJlcn19IHRyaWFuZ2xlcyAtIE51bWJlciBvZiB0cmlhbmdsZXMgYXNzb2NpYXRlZCB3aXRoIHRoaXMgRmVhdHVyZS4gXHJcbiAgICAgKiBAcGFyYW0ge3tpdGVtU2l6ZTogbnVtYmVyLCBudW1JdGVtczogbnVtYmVyfX0gYm9yZGVycyAtIE51bWJlciBvZiBib3JkZXJzIGFzc29jaWF0ZWQgd2l0aCB0aGlzIEZlYXR1cmUuXHJcbiAgICAgKiBAcGFyYW0ge251bWJlcltdfSBwb2ludHMgLSBUaGUgcG9pbnRzIHRoYXQgYmVsb25nIHRvIHRoaXMgRmVhdHVyZS5cclxuICAgICAqIFxyXG4gICAgICogQG1lbWJlck9mIEZlYXR1cmVcclxuICAgICAqL1xyXG4gICAgY29uc3RydWN0b3IoaWQsIHByb3BlcnRpZXMsIHRyaWFuZ2xlcywgYm9yZGVycywgcG9pbnRzKSB7XHJcbiAgICAgICAgLyoqXHJcbiAgICAgICAgICogVGhpcyBGZWF0dXJlIGlkLlxyXG4gICAgICAgICAqIEB0eXBlIHtudW1iZXJ9IFxyXG4gICAgICAgICAqL1xyXG4gICAgICAgIHRoaXMuX2lkID0gaWQ7XHJcbiAgICAgICAgLyoqXHJcbiAgICAgICAgICogUHJvcGVydGllcyBhc3NvY2lhdGVkIHdpdGggdGhpcyBGZWF0dXJlLiAgXHJcbiAgICAgICAgICogQHR5cGUge3tmeDogc3RyaW5nLCBfZ2lzcGxheWlkOm51bWJlcn19ICBcclxuICAgICAgICAgKi9cclxuICAgICAgICB0aGlzLl9wcm9wZXJ0aWVzID0gcHJvcGVydGllcztcclxuICAgICAgICAvKipcclxuICAgICAgICAgKiBOdW1iZXIgb2YgdHJpYW5nbGVzIGFzc29jaWF0ZWQgd2l0aCB0aGlzIEZlYXR1cmUuXHJcbiAgICAgICAgICogQHR5cGUge3tpdGVtU2l6ZTogbnVtYmVyLCBudW1JdGVtczogbnVtYmVyfX1cclxuICAgICAgICAgKi9cclxuICAgICAgICB0aGlzLl90cmlhbmdsZXMgPSB0cmlhbmdsZXM7XHJcbiAgICAgICAgLyoqXHJcbiAgICAgICAgICogTnVtYmVyIG9mIGJvcmRlcnMgYXNzb2NpYXRlZCB3aXRoIHRoaXMgRmVhdHVyZS5cclxuICAgICAgICAgKiBAdHlwZSB7e2l0ZW1TaXplOiBudW1iZXIsIG51bUl0ZW1zOiBudW1iZXJ9fVxyXG4gICAgICAgICAqL1xyXG4gICAgICAgIHRoaXMuX2JvcmRlcnMgPSBib3JkZXJzO1xyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICAqIFRoZSBwb2ludHMgdGhhdCBiZWxvbmcgdG8gdGhpcyBGZWF0dXJlLlxyXG4gICAgICAgICAqIEB0eXBlIHtudW1iZXJbXX1cclxuICAgICAgICAgKi9cclxuICAgICAgICB0aGlzLl9wb2ludHMgPSBwb2ludHM7XHJcbiAgICAgICAgcmV0dXJuIHRoaXM7Ly8gQFJ1aSBSZW1vdmVyIHRoaXNcclxuICAgIH1cclxufVxyXG4gLyogaWYgKHdpbmRvdy5jb3VudCA9PSAwKSB7XHJcbiAgICAgICAgICAgIHZhciBvYmogPSB7XHJcbiAgICAgICAgICAgICAgICBpOiBpZCxcclxuICAgICAgICAgICAgICAgIHByczogcHJvcGVydGllcyxcclxuICAgICAgICAgICAgICAgIHRzOiB0cmlhbmdsZXMsXHJcbiAgICAgICAgICAgICAgICBiczogYm9yZGVycyxcclxuICAgICAgICAgICAgICAgIHB0czogcG9pbnRzLFxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIHdpbmRvdy5jb3VudCsrO1xyXG4gICAgICAgICAgICBjb25zb2xlLmxvZyhKU09OLnN0cmluZ2lmeShvYmopKVxyXG4gICAgICAgIH0qL1xuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvR2lzcGxheS9GZWF0dXJlLmpzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBO0FBQ0E7QUFDQTs7Ozs7O0FBTUE7QUFDQTs7Ozs7Ozs7Ozs7O0FBREE7QUFhQTtBQUNBO0FBQUE7Ozs7QUFJQTtBQUNBOzs7O0FBSUE7QUFDQTs7OztBQUlBO0FBQ0E7Ozs7QUFJQTtBQUNBOzs7O0FBSUE7QUFDQTtBQUNBO0FBRUE7Ozs7Ozs7Ozs7Iiwic291cmNlUm9vdCI6IiJ9");
/***/ }),
/* 7 */
/* unknown exports provided */
/* all exports used */
/*!******************************************!*\
!*** ./src/Gisplay/Maps/BGMapWrapper.js ***!
\******************************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\r\n * This class represents a background map wrapper. Used to be a \"middle-man\" between the \r\n * background map provider and the API.\r\n */\nvar BGMapWrapper = exports.BGMapWrapper = function () {\n\n /**\r\n * This is the map that comes from the background map provider(e.g., MapBox).\r\n * @param {Object} map \r\n */\n function BGMapWrapper(map) {\n _classCallCheck(this, BGMapWrapper);\n\n console.log(\"BGMapWrapper constructor?\");\n /**\r\n * This is the map that comes from the background map provider(e.g., MapBox). \r\n * @type {Object}\r\n */\n this.map = map;\n }\n\n /**\r\n * Returns the map's containing HTML element.\r\n */\n\n\n _createClass(BGMapWrapper, [{\n key: 'getContainer',\n value: function getContainer() {\n return this.map.getContainer();\n }\n\n /**\r\n * Given one id it creates a canvas object.\r\n * @todo Understand case mapbox comment bellow.\r\n * @param {number} id - The id of the canvas to be created.\r\n * @returns {HTMLCanvasElement} Canvas object where everything will be drawn.\r\n */\n\n }, {\n key: 'createCanvas',\n value: function createCanvas(id) {\n var mapCanvas = document.createElement('canvas');\n mapCanvas.id = 'mapCanvas' + id;\n mapCanvas.style.position = 'absolute';\n\n var mapDiv = this.map.getContainer();\n mapCanvas.height = mapDiv.offsetHeight;\n mapCanvas.width = mapDiv.offsetWidth;\n //mapCanvas.style.zIndex = \"2\";\n\n //case mapbox\n mapDiv.insertBefore(mapCanvas, mapDiv.firstChild.nextSibling);\n\n var canvas = document.getElementById('mapCanvas' + id);\n return canvas;\n }\n\n /**\r\n * Returns the map's current zoom level.\r\n */\n\n }, {\n key: 'getZoom',\n value: function getZoom() {\n return this.map.getZoom();\n }\n\n /**\r\n * Returns the longitude of the bounding box northwest corner.\r\n */\n\n }, {\n key: 'getLngBound',\n value: function getLngBound() {\n return this.map.getBounds().getNorthWest().lng;\n }\n\n /**\r\n * Returns the latitude of the bounding box northwest corner.\r\n */\n\n }, {\n key: 'getLatBound',\n value: function getLatBound() {\n return this.map.getBounds().getNorthWest().lat;\n }\n\n /**\r\n * Adds a listener to a specified event type.\r\n * @param {string} eventstr - The event type to add a listen for.\r\n * @param {Function} eventfunction - The function to be called when the event is fired. The listener function is called with the data object passed to fire , extended with target and type properties. \r\n */\n\n }, {\n key: 'onEvent',\n value: function onEvent(eventstr, eventfunction) {\n this.map.on(eventstr, eventfunction);\n }\n\n /**\r\n * Creates loader to be shown at the beginning when the API is loading all data.\r\n * @todo This method is calling another with parameters in the 1st if. This is incorrect.\r\n */\n\n }, {\n key: 'loader',\n value: function loader() {\n if (this.loaderDiv === undefined) this.createLoader(this.map);else {\n if (this.loaderDiv.style.display == 'none') this.loaderDiv.style.display = 'flex';else {\n this.loaderDiv.style.display = 'none';\n }\n\n if (this.loaderDiv.className.includes('_gisplayhidden')) {\n this.loaderDiv.className = this.loaderDiv.className.replace(/(?:^|\\s)_gisplayhidden(?!\\S)/g, '_gisplayLoaderOuterDiv');\n } else {\n this.loaderDiv.className = this.loaderDiv.className.replace(/(?:^|\\s)_gisplayLoaderOuterDiv(?!\\S)/g, '_gisplayhidden');\n }\n }\n }\n\n /**\r\n * Auxiliar method to be called when the we want to create the loader.\r\n * @todo Probably it is not being used because nobody calls it(see L:82).\r\n * It inserts two divs on the map\r\n */\n\n }, {\n key: 'createLoader',\n value: function createLoader() {\n var outerDiv = document.createElement('div');\n var innerDiv = document.createElement('div');\n innerDiv.className = '_gisplayloader';\n\n var mapDiv = this.getContainer();\n\n /*outerDiv.style = ' opacity: 0.5; background-color: grey; justify-content: center; display: flex;';\r\n outerDiv.style.position = 'absolute';\r\n outerDiv.style.zIndex = '999999999';*/\n outerDiv.className = '_gisplayLoaderOuterDiv';\n outerDiv.style.height = mapDiv.offsetHeight;\n outerDiv.style.width = mapDiv.offsetWidth;\n outerDiv.appendChild(innerDiv);\n this.loaderDiv = outerDiv;\n\n mapDiv.parentElement.insertBefore(outerDiv, mapDiv);\n }\n }]);\n\n return BGMapWrapper;\n}();//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvR2lzcGxheS9NYXBzL0JHTWFwV3JhcHBlci5qcz9lMjZkIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBUaGlzIGNsYXNzIHJlcHJlc2VudHMgYSBiYWNrZ3JvdW5kIG1hcCB3cmFwcGVyLiBVc2VkIHRvIGJlIGEgXCJtaWRkbGUtbWFuXCIgYmV0d2VlbiB0aGUgXHJcbiAqIGJhY2tncm91bmQgbWFwIHByb3ZpZGVyIGFuZCB0aGUgQVBJLlxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEJHTWFwV3JhcHBlciB7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBUaGlzIGlzIHRoZSBtYXAgdGhhdCBjb21lcyBmcm9tIHRoZSBiYWNrZ3JvdW5kIG1hcCBwcm92aWRlcihlLmcuLCBNYXBCb3gpLlxyXG4gICAgICogQHBhcmFtIHtPYmplY3R9IG1hcCBcclxuICAgICAqL1xyXG4gICAgY29uc3RydWN0b3IobWFwKSB7XHJcbiAgICAgICAgY29uc29sZS5sb2coXCJCR01hcFdyYXBwZXIgY29uc3RydWN0b3I/XCIpO1xyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICAqIFRoaXMgaXMgdGhlIG1hcCB0aGF0IGNvbWVzIGZyb20gdGhlIGJhY2tncm91bmQgbWFwIHByb3ZpZGVyKGUuZy4sIE1hcEJveCkuIFxyXG4gICAgICAgICAqIEB0eXBlIHtPYmplY3R9XHJcbiAgICAgICAgICovXHJcbiAgICAgICAgdGhpcy5tYXAgPSBtYXA7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBSZXR1cm5zIHRoZSBtYXAncyBjb250YWluaW5nIEhUTUwgZWxlbWVudC5cclxuICAgICAqL1xyXG4gICAgZ2V0Q29udGFpbmVyKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLm1hcC5nZXRDb250YWluZXIoKTtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIEdpdmVuIG9uZSBpZCBpdCBjcmVhdGVzIGEgY2FudmFzIG9iamVjdC5cclxuICAgICAqIEB0b2RvIFVuZGVyc3RhbmQgY2FzZSBtYXBib3ggY29tbWVudCBiZWxsb3cuXHJcbiAgICAgKiBAcGFyYW0ge251bWJlcn0gaWQgLSBUaGUgaWQgb2YgdGhlIGNhbnZhcyB0byBiZSBjcmVhdGVkLlxyXG4gICAgICogQHJldHVybnMge0hUTUxDYW52YXNFbGVtZW50fSBDYW52YXMgb2JqZWN0IHdoZXJlIGV2ZXJ5dGhpbmcgd2lsbCBiZSBkcmF3bi5cclxuICAgICAqL1xyXG4gICAgY3JlYXRlQ2FudmFzKGlkKSB7XHJcbiAgICAgICAgY29uc3QgbWFwQ2FudmFzID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnY2FudmFzJyk7XHJcbiAgICAgICAgbWFwQ2FudmFzLmlkID0gYG1hcENhbnZhcyR7aWR9YDtcclxuICAgICAgICBtYXBDYW52YXMuc3R5bGUucG9zaXRpb24gPSAnYWJzb2x1dGUnO1xyXG5cclxuICAgICAgICBjb25zdCBtYXBEaXYgPSB0aGlzLm1hcC5nZXRDb250YWluZXIoKTtcclxuICAgICAgICBtYXBDYW52YXMuaGVpZ2h0ID0gbWFwRGl2Lm9mZnNldEhlaWdodDtcclxuICAgICAgICBtYXBDYW52YXMud2lkdGggPSBtYXBEaXYub2Zmc2V0V2lkdGg7XHJcbiAgICAgICAgLy9tYXBDYW52YXMuc3R5bGUuekluZGV4ID0gXCIyXCI7XHJcblxyXG4gICAgICAgIC8vY2FzZSBtYXBib3hcclxuICAgICAgICBtYXBEaXYuaW5zZXJ0QmVmb3JlKG1hcENhbnZhcywgbWFwRGl2LmZpcnN0Q2hpbGQubmV4dFNpYmxpbmcpO1xyXG5cclxuICAgICAgICBjb25zdCBjYW52YXMgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChgbWFwQ2FudmFzJHtpZH1gKTtcclxuICAgICAgICByZXR1cm4gY2FudmFzO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogUmV0dXJucyB0aGUgbWFwJ3MgY3VycmVudCB6b29tIGxldmVsLlxyXG4gICAgICovXHJcbiAgICBnZXRab29tKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLm1hcC5nZXRab29tKCk7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBSZXR1cm5zIHRoZSBsb25naXR1ZGUgb2YgdGhlIGJvdW5kaW5nIGJveCBub3J0aHdlc3QgY29ybmVyLlxyXG4gICAgICovXHJcbiAgICBnZXRMbmdCb3VuZCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5tYXAuZ2V0Qm91bmRzKCkuZ2V0Tm9ydGhXZXN0KCkubG5nO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogUmV0dXJucyB0aGUgbGF0aXR1ZGUgb2YgdGhlIGJvdW5kaW5nIGJveCBub3J0aHdlc3QgY29ybmVyLlxyXG4gICAgICovXHJcbiAgICBnZXRMYXRCb3VuZCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5tYXAuZ2V0Qm91bmRzKCkuZ2V0Tm9ydGhXZXN0KCkubGF0O1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogQWRkcyBhIGxpc3RlbmVyIHRvIGEgc3BlY2lmaWVkIGV2ZW50IHR5cGUuXHJcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gZXZlbnRzdHIgLSBUaGUgZXZlbnQgdHlwZSB0byBhZGQgYSBsaXN0ZW4gZm9yLlxyXG4gICAgICogQHBhcmFtIHtGdW5jdGlvbn0gZXZlbnRmdW5jdGlvbiAtIFRoZSBmdW5jdGlvbiB0byBiZSBjYWxsZWQgd2hlbiB0aGUgZXZlbnQgaXMgZmlyZWQuIFRoZSBsaXN0ZW5lciBmdW5jdGlvbiBpcyBjYWxsZWQgd2l0aCB0aGUgZGF0YSBvYmplY3QgcGFzc2VkIHRvICBmaXJlICwgZXh0ZW5kZWQgd2l0aCAgdGFyZ2V0IGFuZCAgdHlwZSBwcm9wZXJ0aWVzLiBcclxuICAgICAqL1xyXG4gICAgb25FdmVudChldmVudHN0ciwgZXZlbnRmdW5jdGlvbikge1xyXG4gICAgICAgIHRoaXMubWFwLm9uKGV2ZW50c3RyLCBldmVudGZ1bmN0aW9uKTtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIENyZWF0ZXMgbG9hZGVyIHRvIGJlIHNob3duIGF0IHRoZSBiZWdpbm5pbmcgd2hlbiB0aGUgQVBJIGlzIGxvYWRpbmcgYWxsIGRhdGEuXHJcbiAgICAgKiBAdG9kbyBUaGlzIG1ldGhvZCBpcyBjYWxsaW5nIGFub3RoZXIgd2l0aCBwYXJhbWV0ZXJzIGluIHRoZSAxc3QgaWYuIFRoaXMgaXMgaW5jb3JyZWN0LlxyXG4gICAgICovXHJcbiAgICBsb2FkZXIoKSB7XHJcbiAgICAgICAgaWYgKHRoaXMubG9hZGVyRGl2ID09PSB1bmRlZmluZWQpXHJcbiAgICAgICAgICAgIHRoaXMuY3JlYXRlTG9hZGVyKHRoaXMubWFwKTtcclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgaWYgKHRoaXMubG9hZGVyRGl2LnN0eWxlLmRpc3BsYXkgPT0gJ25vbmUnKVxyXG4gICAgICAgICAgICAgICAgdGhpcy5sb2FkZXJEaXYuc3R5bGUuZGlzcGxheSA9ICdmbGV4JztcclxuICAgICAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmxvYWRlckRpdi5zdHlsZS5kaXNwbGF5ID0gJ25vbmUnO1xyXG4gICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICBpZiAodGhpcy5sb2FkZXJEaXYuY2xhc3NOYW1lLmluY2x1ZGVzKCdfZ2lzcGxheWhpZGRlbicpKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmxvYWRlckRpdi5jbGFzc05hbWUgPSB0aGlzLmxvYWRlckRpdi5jbGFzc05hbWUucmVwbGFjZSgvKD86XnxcXHMpX2dpc3BsYXloaWRkZW4oPyFcXFMpL2csICdfZ2lzcGxheUxvYWRlck91dGVyRGl2Jyk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmxvYWRlckRpdi5jbGFzc05hbWUgPSB0aGlzLmxvYWRlckRpdi5jbGFzc05hbWUucmVwbGFjZSgvKD86XnxcXHMpX2dpc3BsYXlMb2FkZXJPdXRlckRpdig/IVxcUykvZywgJ19naXNwbGF5aGlkZGVuJyk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBBdXhpbGlhciBtZXRob2QgdG8gYmUgY2FsbGVkIHdoZW4gdGhlIHdlIHdhbnQgdG8gY3JlYXRlIHRoZSBsb2FkZXIuXHJcbiAgICAgKiBAdG9kbyBQcm9iYWJseSBpdCBpcyBub3QgYmVpbmcgdXNlZCBiZWNhdXNlIG5vYm9keSBjYWxscyBpdChzZWUgTDo4MikuXHJcbiAgICAgKiBJdCBpbnNlcnRzIHR3byBkaXZzIG9uIHRoZSBtYXBcclxuICAgICAqL1xyXG4gICAgY3JlYXRlTG9hZGVyKCkge1xyXG4gICAgICAgIGNvbnN0IG91dGVyRGl2ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2Jyk7XHJcbiAgICAgICAgY29uc3QgaW5uZXJEaXYgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdkaXYnKTtcclxuICAgICAgICBpbm5lckRpdi5jbGFzc05hbWUgPSAnX2dpc3BsYXlsb2FkZXInO1xyXG5cclxuICAgICAgICBjb25zdCBtYXBEaXYgPSB0aGlzLmdldENvbnRhaW5lcigpO1xyXG5cclxuICAgICAgICAvKm91dGVyRGl2LnN0eWxlID0gJyBvcGFjaXR5OiAwLjU7IGJhY2tncm91bmQtY29sb3I6IGdyZXk7IGp1c3RpZnktY29udGVudDogY2VudGVyOyBkaXNwbGF5OiBmbGV4Oyc7XHJcbiAgICAgICAgb3V0ZXJEaXYuc3R5bGUucG9zaXRpb24gPSAnYWJzb2x1dGUnO1xyXG4gICAgICAgIG91dGVyRGl2LnN0eWxlLnpJbmRleCA9ICc5OTk5OTk5OTknOyovXHJcbiAgICAgICAgb3V0ZXJEaXYuY2xhc3NOYW1lID0gJ19naXNwbGF5TG9hZGVyT3V0ZXJEaXYnO1xyXG4gICAgICAgIG91dGVyRGl2LnN0eWxlLmhlaWdodCA9IG1hcERpdi5vZmZzZXRIZWlnaHQ7XHJcbiAgICAgICAgb3V0ZXJEaXYuc3R5bGUud2lkdGggPSBtYXBEaXYub2Zmc2V0V2lkdGg7XHJcbiAgICAgICAgb3V0ZXJEaXYuYXBwZW5kQ2hpbGQoaW5uZXJEaXYpO1xyXG4gICAgICAgIHRoaXMubG9hZGVyRGl2ID0gb3V0ZXJEaXY7XHJcblxyXG4gICAgICAgIG1hcERpdi5wYXJlbnRFbGVtZW50Lmluc2VydEJlZm9yZShvdXRlckRpdiwgbWFwRGl2KTtcclxuICAgIH1cclxufVxyXG5cblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gc3JjL0dpc3BsYXkvTWFwcy9CR01hcFdyYXBwZXIuanMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFBQTs7OztBQUlBO0FBQ0E7QUFDQTs7OztBQUlBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7Ozs7QUFJQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7OztBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7O0FBSUE7QUFDQTtBQUdBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Iiwic291cmNlUm9vdCI6IiJ9");
/***/ }),
/* 8 */
/* unknown exports provided */
/* all exports used */
/*!***************************************!*\
!*** ./src/Gisplay/Maps/ChangeMap.js ***!
\***************************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ChangeMap = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Map2 = __webpack_require__(/*! ./Map */ 1);\n\nvar _Legend = __webpack_require__(/*! ../Legend */ 0);\n\nvar _Aesthetic = __webpack_require__(/*! ../Aesthetic */ 2);\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\r\n * ChangeMap implementation 07/03\r\n */\nvar ChangeMap = exports.ChangeMap = function (_Map) {\n _inherits(ChangeMap, _Map);\n\n function ChangeMap(bgmap, geometry, options) {\n _classCallCheck(this, ChangeMap);\n\n var _this = _possibleConstructorReturn(this, (ChangeMap.__proto__ || Object.getPrototypeOf(ChangeMap)).call(this, bgmap, geometry, options));\n\n _this.geometry = geometry;\n _this.aesthetics = new Array();\n _this.attr = \"change\";\n _this.loadOptions(options, bgmap);\n _this.id = mapcount++;\n _this.attr = \"change\"; //@Rui Duplicate?\n _this.type = 'CM';\n maps.push(_this);\n _this.initialize();\n\n /* return this;*/\n return _this;\n }\n\n _createClass(ChangeMap, [{\n key: 'draw',\n value: function draw() {\n this.clear();\n for (var i = 0; i < this.aesthetics.length; i++) {\n if (this.aesthetics[i].enabled == true) {\n this.drawContinuousPolygons(this.aesthetics[i]);\n }\n this.drawBorders(this.aesthetics[i]);\n }\n }\n }, {\n key: 'preProcessData',\n value: function preProcessData(geojson, numberOf, algorithm, colorscheme) {\n var aesarray = [];\n var values = [];\n var breaks = void 0;\n //var fcolor;\n for (var g = 0; g < geojson.features.length && (this.maxfeatures == undefined || g < this.maxfeatures); g++) {\n if (typeof geojson.features[g].properties[this.minuend] == 'number' && geojson.features[g].properties[this.minuend] != null && typeof geojson.features[g].properties[this.subtrahend] == 'number' && geojson.features[g].properties[this.subtrahend] != null) {\n this.max = Math.max(this.max, geojson.features[g].properties[this.minuend] - geojson.features[g].properties[this.subtrahend]);\n this.min = Math.min(this.min, geojson.features[g].properties[this.minuend] - geojson.features[g].properties[this.subtrahend]);\n }\n }\n breaks = [this.min, this.max];\n this.fcolor = chroma.scale(colorscheme);\n var aes = new _Aesthetic.Aesthetic(0, this.attr, this.fcolor, [0, 0, 0, 1], null, [breaks[0], breaks[1]]);\n aes.outer = true;\n aesarray.push(aes);\n\n this.aesthetics = aesarray;\n }\n }, {\n key: 'buildLegend',\n value: function buildLegend() {\n this.legend = new _Legend.Legend(this.id, this.legendTitle);\n this.legend.insertGradient(this, this.min, 0, this.max);\n this.legend.insertLegend(this.map);\n }\n }, {\n key: 'defaults',\n value: function defaults() {\n var options = {};\n return options;\n }\n }]);\n\n return ChangeMap;\n}(_Map2.Map);//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvR2lzcGxheS9NYXBzL0NoYW5nZU1hcC5qcz9lMTQxIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hcCB9IGZyb20gJy4vTWFwJztcclxuaW1wb3J0IHsgTGVnZW5kIH0gZnJvbSAnLi4vTGVnZW5kJztcclxuaW1wb3J0IHsgQWVzdGhldGljIH0gZnJvbSAnLi4vQWVzdGhldGljJztcclxuXHJcbi8qKlxyXG4gKiBDaGFuZ2VNYXAgaW1wbGVtZW50YXRpb24gMDcvMDNcclxuICovXHJcbmV4cG9ydCBjbGFzcyBDaGFuZ2VNYXAgZXh0ZW5kcyBNYXAge1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKGJnbWFwLCBnZW9tZXRyeSwgb3B0aW9ucykge1xyXG4gICAgICAgIHN1cGVyKGJnbWFwLCBnZW9tZXRyeSwgb3B0aW9ucyk7XHJcbiAgICAgICAgdGhpcy5nZW9tZXRyeSA9IGdlb21ldHJ5O1xyXG4gICAgICAgIHRoaXMuYWVzdGhldGljcyA9IG5ldyBBcnJheSgpO1xyXG4gICAgICAgIHRoaXMuYXR0ciA9IFwiY2hhbmdlXCI7XHJcbiAgICAgICAgdGhpcy5sb2FkT3B0aW9ucyhvcHRpb25zLCBiZ21hcCk7XHJcbiAgICAgICAgdGhpcy5pZCA9IG1hcGNvdW50Kys7XHJcbiAgICAgICAgdGhpcy5hdHRyID0gXCJjaGFuZ2VcIjsvL0BSdWkgRHVwbGljYXRlP1xyXG4gICAgICAgIHRoaXMudHlwZSA9ICdDTSc7XHJcbiAgICAgICAgbWFwcy5wdXNoKHRoaXMpO1xyXG4gICAgICAgIHRoaXMuaW5pdGlhbGl6ZSgpO1xyXG5cclxuICAgICAgICAvKiAgcmV0dXJuIHRoaXM7Ki9cclxuICAgIH1cclxuXHJcbiAgICBkcmF3KCkge1xyXG4gICAgICAgIHRoaXMuY2xlYXIoKTtcclxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuYWVzdGhldGljcy5sZW5ndGg7IGkrKykge1xyXG4gICAgICAgICAgICBpZiAodGhpcy5hZXN0aGV0aWNzW2ldLmVuYWJsZWQgPT0gdHJ1ZSkge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5kcmF3Q29udGludW91c1BvbHlnb25zKHRoaXMuYWVzdGhldGljc1tpXSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgdGhpcy5kcmF3Qm9yZGVycyh0aGlzLmFlc3RoZXRpY3NbaV0pO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBwcmVQcm9jZXNzRGF0YShnZW9qc29uLCBudW1iZXJPZiwgYWxnb3JpdGhtLCBjb2xvcnNjaGVtZSkge1xyXG4gICAgICAgIGNvbnN0IGFlc2FycmF5ID0gW107XHJcbiAgICAgICAgY29uc3QgdmFsdWVzID0gW107XHJcbiAgICAgICAgbGV0IGJyZWFrcztcclxuICAgICAgICAvL3ZhciBmY29sb3I7XHJcbiAgICAgICAgZm9yIChsZXQgZyA9IDA7IGcgPCBnZW9qc29uLmZlYXR1cmVzLmxlbmd0aCAmJiAodGhpcy5tYXhmZWF0dXJlcyA9PSB1bmRlZmluZWQgfHwgZyA8IHRoaXMubWF4ZmVhdHVyZXMpOyBnKyspIHtcclxuICAgICAgICAgICAgaWYgKHR5cGVvZiBnZW9qc29uLmZlYXR1cmVzW2ddLnByb3BlcnRpZXNbdGhpcy5taW51ZW5kXSA9PSAnbnVtYmVyJyAmJiBnZW9qc29uLmZlYXR1cmVzW2ddLnByb3BlcnRpZXNbdGhpcy5taW51ZW5kXSAhPSBudWxsICYmIHR5cGVvZiBnZW9qc29uLmZlYXR1cmVzW2ddLnByb3BlcnRpZXNbdGhpcy5zdWJ0cmFoZW5kXSA9PSAnbnVtYmVyJyAmJiBnZW9qc29uLmZlYXR1cmVzW2ddLnByb3BlcnRpZXNbdGhpcy5zdWJ0cmFoZW5kXSAhPSBudWxsKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLm1heCA9IE1hdGgubWF4KHRoaXMubWF4LCBnZW9qc29uLmZlYXR1cmVzW2ddLnByb3BlcnRpZXNbdGhpcy5taW51ZW5kXSAtIGdlb2pzb24uZmVhdHVyZXNbZ10ucHJvcGVydGllc1t0aGlzLnN1YnRyYWhlbmRdKTtcclxuICAgICAgICAgICAgICAgIHRoaXMubWluID0gTWF0aC5taW4odGhpcy5taW4sIGdlb2pzb24uZmVhdHVyZXNbZ10ucHJvcGVydGllc1t0aGlzLm1pbnVlbmRdIC0gZ2VvanNvbi5mZWF0dXJlc1tnXS5wcm9wZXJ0aWVzW3RoaXMuc3VidHJhaGVuZF0pO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGJyZWFrcyA9IFt0aGlzLm1pbiwgdGhpcy5tYXhdO1xyXG4gICAgICAgIHRoaXMuZmNvbG9yID0gY2hyb21hLnNjYWxlKGNvbG9yc2NoZW1lKTtcclxuICAgICAgICBjb25zdCBhZXMgPSBuZXcgQWVzdGhldGljKDAsIHRoaXMuYXR0ciwgdGhpcy5mY29sb3IsIFswLCAwLCAwLCAxXSwgbnVsbCwgW2JyZWFrc1swXSwgYnJlYWtzWzFdXSk7XHJcbiAgICAgICAgYWVzLm91dGVyID0gdHJ1ZTtcclxuICAgICAgICBhZXNhcnJheS5wdXNoKGFlcyk7XHJcblxyXG4gICAgICAgIHRoaXMuYWVzdGhldGljcyA9IGFlc2FycmF5O1xyXG4gICAgfVxyXG5cclxuICAgIGJ1aWxkTGVnZW5kKCkge1xyXG4gICAgICAgIHRoaXMubGVnZW5kID0gbmV3IExlZ2VuZCh0aGlzLmlkLCB0aGlzLmxlZ2VuZFRpdGxlKTtcclxuICAgICAgICB0aGlzLmxlZ2VuZC5pbnNlcnRHcmFkaWVudCh0aGlzLCB0aGlzLm1pbiwgMCwgdGhpcy5tYXgpO1xyXG4gICAgICAgIHRoaXMubGVnZW5kLmluc2VydExlZ2VuZCh0aGlzLm1hcCk7XHJcbiAgICB9XHJcblxyXG4gICAgZGVmYXVsdHMoKSB7XHJcbiAgICAgICAgY29uc3Qgb3B0aW9ucyA9IHt9O1xyXG4gICAgICAgIHJldHVybiBvcHRpb25zO1xyXG4gICAgfVxyXG59XG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIHNyYy9HaXNwbGF5L01hcHMvQ2hhbmdlTWFwLmpzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7Ozs7Ozs7QUFDQTs7O0FBR0E7OztBQUVBO0FBQUE7QUFDQTtBQURBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBWkE7QUFhQTtBQUNBOzs7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7OzsiLCJzb3VyY2VSb290IjoiIn0=");
/***/ }),
/* 9 */
/* unknown exports provided */
/* all exports used */
/*!***********************************************!*\
!*** ./src/Gisplay/Maps/ChorochromaticMap.js ***!
\***********************************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ChorochromaticMap = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Legend = __webpack_require__(/*! ../Legend */ 0);\n\nvar _Choropleth2 = __webpack_require__(/*! ./Choropleth */ 3);\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /*import { Map } from './Map';*/\n\n\n/**\r\n * Chorochormatic Map implemenetation.\r\n */\nvar ChorochromaticMap = exports.ChorochromaticMap = function (_Choropleth) {\n _inherits(ChorochromaticMap, _Choropleth);\n\n function ChorochromaticMap(bgmap, geometry, options) {\n _classCallCheck(this, ChorochromaticMap);\n\n return _possibleConstructorReturn(this, (ChorochromaticMap.__proto__ || Object.getPrototypeOf(ChorochromaticMap)).call(this, bgmap, geometry, options));\n }\n\n _createClass(ChorochromaticMap, [{\n key: 'defaults',\n value: function defaults(defaultid) {\n var options = {};\n switch (defaultid) {\n case 1:\n options.colorScheme = [\"#440154\", \"#440256\", \"#450457\", \"#450559\", \"#46075a\", \"#46085c\", \"#460a5d\", \"#460b5e\", \"#470d60\", \"#470e61\", \"#471063\", \"#471164\", \"#471365\", \"#481467\", \"#481668\", \"#481769\", \"#48186a\", \"#481a6c\", \"#481b6d\", \"#481c6e\", \"#481d6f\", \"#481f70\", \"#482071\", \"#482173\", \"#482374\", \"#482475\", \"#482576\", \"#482677\", \"#482878\", \"#482979\", \"#472a7a\", \"#472c7a\", \"#472d7b\", \"#472e7c\", \"#472f7d\", \"#46307e\", \"#46327e\", \"#46337f\", \"#463480\", \"#453581\", \"#453781\", \"#453882\", \"#443983\", \"#443a83\", \"#443b84\", \"#433d84\", \"#433e85\", \"#423f85\", \"#424086\", \"#424186\", \"#414287\", \"#414487\", \"#404588\", \"#404688\", \"#3f4788\", \"#3f4889\", \"#3e4989\", \"#3e4a89\", \"#3e4c8a\", \"#3d4d8a\", \"#3d4e8a\", \"#3c4f8a\", \"#3c508b\", \"#3b518b\", \"#3b528b\", \"#3a538b\", \"#3a548c\", \"#39558c\", \"#39568c\", \"#38588c\", \"#38598c\", \"#375a8c\", \"#375b8d\", \"#365c8d\", \"#365d8d\", \"#355e8d\", \"#355f8d\", \"#34608d\", \"#34618d\", \"#33628d\", \"#33638d\", \"#32648e\", \"#32658e\", \"#31668e\", \"#31678e\", \"#31688e\", \"#30698e\", \"#306a8e\", \"#2f6b8e\", \"#2f6c8e\", \"#2e6d8e\", \"#2e6e8e\", \"#2e6f8e\", \"#2d708e\", \"#2d718e\", \"#2c718e\", \"#2c728e\", \"#2c738e\", \"#2b748e\", \"#2b758e\", \"#2a768e\", \"#2a778e\", \"#2a788e\", \"#29798e\", \"#297a8e\", \"#297b8e\", \"#287c8e\", \"#287d8e\", \"#277e8e\", \"#277f8e\", \"#27808e\", \"#26818e\", \"#26828e\", \"#26828e\", \"#25838e\", \"#25848e\", \"#25858e\", \"#24868e\", \"#24878e\", \"#23888e\", \"#23898e\", \"#238a8d\", \"#228b8d\", \"#228c8d\", \"#228d8d\", \"#218e8d\", \"#218f8d\", \"#21908d\", \"#21918c\", \"#20928c\", \"#20928c\", \"#20938c\", \"#1f948c\", \"#1f958b\", \"#1f968b\", \"#1f978b\", \"#1f988b\", \"#1f998a\", \"#1f9a8a\", \"#1e9b8a\", \"#1e9c89\", \"#1e9d89\", \"#1f9e89\", \"#1f9f88\", \"#1fa088\", \"#1fa188\", \"#1fa187\", \"#1fa287\", \"#20a386\", \"#20a486\", \"#21a585\", \"#21a685\", \"#22a785\", \"#22a884\", \"#23a983\", \"#24aa83\", \"#25ab82\", \"#25ac82\", \"#26ad81\", \"#27ad81\", \"#28ae80\", \"#29af7f\", \"#2ab07f\", \"#2cb17e\", \"#2db27d\", \"#2eb37c\", \"#2fb47c\", \"#31b57b\", \"#32b67a\", \"#34b679\", \"#35b779\", \"#37b878\", \"#38b977\", \"#3aba76\", \"#3bbb75\", \"#3dbc74\", \"#3fbc73\", \"#40bd72\", \"#42be71\", \"#44bf70\", \"#46c06f\", \"#48c16e\", \"#4ac16d\", \"#4cc26c\", \"#4ec36b\", \"#50c46a\", \"#52c569\", \"#54c568\", \"#56c667\", \"#58c765\", \"#5ac864\", \"#5cc863\", \"#5ec962\", \"#60ca60\", \"#63cb5f\", \"#65cb5e\", \"#67cc5c\", \"#69cd5b\", \"#6ccd5a\", \"#6ece58\", \"#70cf57\", \"#73d056\", \"#75d054\", \"#77d153\", \"#7ad151\", \"#7cd250\", \"#7fd34e\", \"#81d34d\", \"#84d44b\", \"#86d549\", \"#89d548\", \"#8bd646\", \"#8ed645\", \"#90d743\", \"#93d741\", \"#95d840\", \"#98d83e\", \"#9bd93c\", \"#9dd93b\", \"#a0da39\", \"#a2da37\", \"#a5db36\", \"#a8db34\", \"#aadc32\", \"#addc30\", \"#b0dd2f\", \"#b2dd2d\", \"#b5de2b\", \"#b8de29\", \"#bade28\", \"#bddf26\", \"#c0df25\", \"#c2df23\", \"#c5e021\", \"#c8e020\", \"#cae11f\", \"#cde11d\", \"#d0e11c\", \"#d2e21b\", \"#d5e21a\", \"#d8e219\", \"#dae319\", \"#dde318\", \"#dfe318\", \"#e2e418\", \"#e5e419\", \"#e7e419\", \"#eae51a\", \"#ece51b\", \"#efe51c\", \"#f1e51d\", \"#f4e61e\", \"#f6e620\", \"#f8e621\", \"#fbe723\", \"#fde725\"];\n break;\n case 2:\n options.colorScheme = ['purple', 'orange', 'blue', 'yellow', 'pink', 'green', 'red', 'navy'];\n break;\n default:\n options.colorScheme = [\"#440154\", \"#440256\", \"#450457\", \"#450559\", \"#46075a\", \"#46085c\", \"#460a5d\", \"#460b5e\", \"#470d60\", \"#470e61\", \"#471063\", \"#471164\", \"#471365\", \"#481467\", \"#481668\", \"#481769\", \"#48186a\", \"#481a6c\", \"#481b6d\", \"#481c6e\", \"#481d6f\", \"#481f70\", \"#482071\", \"#482173\", \"#482374\", \"#482475\", \"#482576\", \"#482677\", \"#482878\", \"#482979\", \"#472a7a\", \"#472c7a\", \"#472d7b\", \"#472e7c\", \"#472f7d\", \"#46307e\", \"#46327e\", \"#46337f\", \"#463480\", \"#453581\", \"#453781\", \"#453882\", \"#443983\", \"#443a83\", \"#443b84\", \"#433d84\", \"#433e85\", \"#423f85\", \"#424086\", \"#424186\", \"#414287\", \"#414487\", \"#404588\", \"#404688\", \"#3f4788\", \"#3f4889\", \"#3e4989\", \"#3e4a89\", \"#3e4c8a\", \"#3d4d8a\", \"#3d4e8a\", \"#3c4f8a\", \"#3c508b\", \"#3b518b\", \"#3b528b\", \"#3a538b\", \"#3a548c\", \"#39558c\", \"#39568c\", \"#38588c\", \"#38598c\", \"#375a8c\", \"#375b8d\", \"#365c8d\", \"#365d8d\", \"#355e8d\", \"#355f8d\", \"#34608d\", \"#34618d\", \"#33628d\", \"#33638d\", \"#32648e\", \"#32658e\", \"#31668e\", \"#31678e\", \"#31688e\", \"#30698e\", \"#306a8e\", \"#2f6b8e\", \"#2f6c8e\", \"#2e6d8e\", \"#2e6e8e\", \"#2e6f8e\", \"#2d708e\", \"#2d718e\", \"#2c718e\", \"#2c728e\", \"#2c738e\", \"#2b748e\", \"#2b758e\", \"#2a768e\", \"#2a778e\", \"#2a788e\", \"#29798e\", \"#297a8e\", \"#297b8e\", \"#287c8e\", \"#287d8e\", \"#277e8e\", \"#277f8e\", \"#27808e\", \"#26818e\", \"#26828e\", \"#26828e\", \"#25838e\", \"#25848e\", \"#25858e\", \"#24868e\", \"#24878e\", \"#23888e\", \"#23898e\", \"#238a8d\", \"#228b8d\", \"#228c8d\", \"#228d8d\", \"#218e8d\", \"#218f8d\", \"#21908d\", \"#21918c\", \"#20928c\", \"#20928c\", \"#20938c\", \"#1f948c\", \"#1f958b\", \"#1f968b\", \"#1f978b\", \"#1f988b\", \"#1f998a\", \"#1f9a8a\", \"#1e9b8a\", \"#1e9c89\", \"#1e9d89\", \"#1f9e89\", \"#1f9f88\", \"#1fa088\", \"#1fa188\", \"#1fa187\", \"#1fa287\", \"#20a386\", \"#20a486\", \"#21a585\", \"#21a685\", \"#22a785\", \"#22a884\", \"#23a983\", \"#24aa83\", \"#25ab82\", \"#25ac82\", \"#26ad81\", \"#27ad81\", \"#28ae80\", \"#29af7f\", \"#2ab07f\", \"#2cb17e\", \"#2db27d\", \"#2eb37c\", \"#2fb47c\", \"#31b57b\", \"#32b67a\", \"#34b679\", \"#35b779\", \"#37b878\", \"#38b977\", \"#3aba76\", \"#3bbb75\", \"#3dbc74\", \"#3fbc73\", \"#40bd72\", \"#42be71\", \"#44bf70\", \"#46c06f\", \"#48c16e\", \"#4ac16d\", \"#4cc26c\", \"#4ec36b\", \"#50c46a\", \"#52c569\", \"#54c568\", \"#56c667\", \"#58c765\", \"#5ac864\", \"#5cc863\", \"#5ec962\", \"#60ca60\", \"#63cb5f\", \"#65cb5e\", \"#67cc5c\", \"#69cd5b\", \"#6ccd5a\", \"#6ece58\", \"#70cf57\", \"#73d056\", \"#75d054\", \"#77d153\", \"#7ad151\", \"#7cd250\", \"#7fd34e\", \"#81d34d\", \"#84d44b\", \"#86d549\", \"#89d548\", \"#8bd646\", \"#8ed645\", \"#90d743\", \"#93d741\", \"#95d840\", \"#98d83e\", \"#9bd93c\", \"#9dd93b\", \"#a0da39\", \"#a2da37\", \"#a5db36\", \"#a8db34\", \"#aadc32\", \"#addc30\", \"#b0dd2f\", \"#b2dd2d\", \"#b5de2b\", \"#b8de29\", \"#bade28\", \"#bddf26\", \"#c0df25\", \"#c2df23\", \"#c5e021\", \"#c8e020\", \"#cae11f\", \"#cde11d\", \"#d0e11c\", \"#d2e21b\", \"#d5e21a\", \"#d8e219\", \"#dae319\", \"#dde318\", \"#dfe318\", \"#e2e418\", \"#e5e419\", \"#e7e419\", \"#eae51a\", \"#ece51b\", \"#efe51c\", \"#f1e51d\", \"#f4e61e\", \"#f6e620\", \"#f8e621\", \"#fbe723\", \"#fde725\"];\n break;\n }\n return options;\n }\n }]);\n\n return ChorochromaticMap;\n}(_Choropleth2.Choropleth);//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"9.js","sources":["webpack:///src/Gisplay/Maps/ChorochromaticMap.js?44d9"],"sourcesContent":["/*import { Map } from './Map';*/\r\nimport { Legend } from '../Legend';\r\nimport { Choropleth } from './Choropleth';\r\n\r\n/**\r\n * Chorochormatic Map implemenetation.\r\n */\r\nexport class ChorochromaticMap extends Choropleth {\r\n\r\n    constructor(bgmap, geometry, options) {\r\n        super(bgmap, geometry, options);\r\n    }\r\n\r\n    defaults(defaultid) {\r\n        const options = {};\r\n        switch (defaultid) {\r\n            case 1:\r\n                options.colorScheme = [\"#440154\", \"#440256\", \"#450457\", \"#450559\", \"#46075a\", \"#46085c\", \"#460a5d\", \"#460b5e\", \"#470d60\", \"#470e61\", \"#471063\", \"#471164\", \"#471365\", \"#481467\", \"#481668\", \"#481769\", \"#48186a\", \"#481a6c\", \"#481b6d\", \"#481c6e\", \"#481d6f\", \"#481f70\", \"#482071\", \"#482173\", \"#482374\", \"#482475\", \"#482576\", \"#482677\", \"#482878\", \"#482979\", \"#472a7a\", \"#472c7a\", \"#472d7b\", \"#472e7c\", \"#472f7d\", \"#46307e\", \"#46327e\", \"#46337f\", \"#463480\", \"#453581\", \"#453781\", \"#453882\", \"#443983\", \"#443a83\", \"#443b84\", \"#433d84\", \"#433e85\", \"#423f85\", \"#424086\", \"#424186\", \"#414287\", \"#414487\", \"#404588\", \"#404688\", \"#3f4788\", \"#3f4889\", \"#3e4989\", \"#3e4a89\", \"#3e4c8a\", \"#3d4d8a\", \"#3d4e8a\", \"#3c4f8a\", \"#3c508b\", \"#3b518b\", \"#3b528b\", \"#3a538b\", \"#3a548c\", \"#39558c\", \"#39568c\", \"#38588c\", \"#38598c\", \"#375a8c\", \"#375b8d\", \"#365c8d\", \"#365d8d\", \"#355e8d\", \"#355f8d\", \"#34608d\", \"#34618d\", \"#33628d\", \"#33638d\", \"#32648e\", \"#32658e\", \"#31668e\", \"#31678e\", \"#31688e\", \"#30698e\", \"#306a8e\", \"#2f6b8e\", \"#2f6c8e\", \"#2e6d8e\", \"#2e6e8e\", \"#2e6f8e\", \"#2d708e\", \"#2d718e\", \"#2c718e\", \"#2c728e\", \"#2c738e\", \"#2b748e\", \"#2b758e\", \"#2a768e\", \"#2a778e\", \"#2a788e\", \"#29798e\", \"#297a8e\", \"#297b8e\", \"#287c8e\", \"#287d8e\", \"#277e8e\", \"#277f8e\", \"#27808e\", \"#26818e\", \"#26828e\", \"#26828e\", \"#25838e\", \"#25848e\", \"#25858e\", \"#24868e\", \"#24878e\", \"#23888e\", \"#23898e\", \"#238a8d\", \"#228b8d\", \"#228c8d\", \"#228d8d\", \"#218e8d\", \"#218f8d\", \"#21908d\", \"#21918c\", \"#20928c\", \"#20928c\", \"#20938c\", \"#1f948c\", \"#1f958b\", \"#1f968b\", \"#1f978b\", \"#1f988b\", \"#1f998a\", \"#1f9a8a\", \"#1e9b8a\", \"#1e9c89\", \"#1e9d89\", \"#1f9e89\", \"#1f9f88\", \"#1fa088\", \"#1fa188\", \"#1fa187\", \"#1fa287\", \"#20a386\", \"#20a486\", \"#21a585\", \"#21a685\", \"#22a785\", \"#22a884\", \"#23a983\", \"#24aa83\", \"#25ab82\", \"#25ac82\", \"#26ad81\", \"#27ad81\", \"#28ae80\", \"#29af7f\", \"#2ab07f\", \"#2cb17e\", \"#2db27d\", \"#2eb37c\", \"#2fb47c\", \"#31b57b\", \"#32b67a\", \"#34b679\", \"#35b779\", \"#37b878\", \"#38b977\", \"#3aba76\", \"#3bbb75\", \"#3dbc74\", \"#3fbc73\", \"#40bd72\", \"#42be71\", \"#44bf70\", \"#46c06f\", \"#48c16e\", \"#4ac16d\", \"#4cc26c\", \"#4ec36b\", \"#50c46a\", \"#52c569\", \"#54c568\", \"#56c667\", \"#58c765\", \"#5ac864\", \"#5cc863\", \"#5ec962\", \"#60ca60\", \"#63cb5f\", \"#65cb5e\", \"#67cc5c\", \"#69cd5b\", \"#6ccd5a\", \"#6ece58\", \"#70cf57\", \"#73d056\", \"#75d054\", \"#77d153\", \"#7ad151\", \"#7cd250\", \"#7fd34e\", \"#81d34d\", \"#84d44b\", \"#86d549\", \"#89d548\", \"#8bd646\", \"#8ed645\", \"#90d743\", \"#93d741\", \"#95d840\", \"#98d83e\", \"#9bd93c\", \"#9dd93b\", \"#a0da39\", \"#a2da37\", \"#a5db36\", \"#a8db34\", \"#aadc32\", \"#addc30\", \"#b0dd2f\", \"#b2dd2d\", \"#b5de2b\", \"#b8de29\", \"#bade28\", \"#bddf26\", \"#c0df25\", \"#c2df23\", \"#c5e021\", \"#c8e020\", \"#cae11f\", \"#cde11d\", \"#d0e11c\", \"#d2e21b\", \"#d5e21a\", \"#d8e219\", \"#dae319\", \"#dde318\", \"#dfe318\", \"#e2e418\", \"#e5e419\", \"#e7e419\", \"#eae51a\", \"#ece51b\", \"#efe51c\", \"#f1e51d\", \"#f4e61e\", \"#f6e620\", \"#f8e621\", \"#fbe723\", \"#fde725\"];\r\n                break;\r\n            case 2:\r\n                options.colorScheme = ['purple', 'orange', 'blue', 'yellow', 'pink', 'green', 'red', 'navy'];\r\n                break;\r\n            default:\r\n                options.colorScheme = [\"#440154\", \"#440256\", \"#450457\", \"#450559\", \"#46075a\", \"#46085c\", \"#460a5d\", \"#460b5e\", \"#470d60\", \"#470e61\", \"#471063\", \"#471164\", \"#471365\", \"#481467\", \"#481668\", \"#481769\", \"#48186a\", \"#481a6c\", \"#481b6d\", \"#481c6e\", \"#481d6f\", \"#481f70\", \"#482071\", \"#482173\", \"#482374\", \"#482475\", \"#482576\", \"#482677\", \"#482878\", \"#482979\", \"#472a7a\", \"#472c7a\", \"#472d7b\", \"#472e7c\", \"#472f7d\", \"#46307e\", \"#46327e\", \"#46337f\", \"#463480\", \"#453581\", \"#453781\", \"#453882\", \"#443983\", \"#443a83\", \"#443b84\", \"#433d84\", \"#433e85\", \"#423f85\", \"#424086\", \"#424186\", \"#414287\", \"#414487\", \"#404588\", \"#404688\", \"#3f4788\", \"#3f4889\", \"#3e4989\", \"#3e4a89\", \"#3e4c8a\", \"#3d4d8a\", \"#3d4e8a\", \"#3c4f8a\", \"#3c508b\", \"#3b518b\", \"#3b528b\", \"#3a538b\", \"#3a548c\", \"#39558c\", \"#39568c\", \"#38588c\", \"#38598c\", \"#375a8c\", \"#375b8d\", \"#365c8d\", \"#365d8d\", \"#355e8d\", \"#355f8d\", \"#34608d\", \"#34618d\", \"#33628d\", \"#33638d\", \"#32648e\", \"#32658e\", \"#31668e\", \"#31678e\", \"#31688e\", \"#30698e\", \"#306a8e\", \"#2f6b8e\", \"#2f6c8e\", \"#2e6d8e\", \"#2e6e8e\", \"#2e6f8e\", \"#2d708e\", \"#2d718e\", \"#2c718e\", \"#2c728e\", \"#2c738e\", \"#2b748e\", \"#2b758e\", \"#2a768e\", \"#2a778e\", \"#2a788e\", \"#29798e\", \"#297a8e\", \"#297b8e\", \"#287c8e\", \"#287d8e\", \"#277e8e\", \"#277f8e\", \"#27808e\", \"#26818e\", \"#26828e\", \"#26828e\", \"#25838e\", \"#25848e\", \"#25858e\", \"#24868e\", \"#24878e\", \"#23888e\", \"#23898e\", \"#238a8d\", \"#228b8d\", \"#228c8d\", \"#228d8d\", \"#218e8d\", \"#218f8d\", \"#21908d\", \"#21918c\", \"#20928c\", \"#20928c\", \"#20938c\", \"#1f948c\", \"#1f958b\", \"#1f968b\", \"#1f978b\", \"#1f988b\", \"#1f998a\", \"#1f9a8a\", \"#1e9b8a\", \"#1e9c89\", \"#1e9d89\", \"#1f9e89\", \"#1f9f88\", \"#1fa088\", \"#1fa188\", \"#1fa187\", \"#1fa287\", \"#20a386\", \"#20a486\", \"#21a585\", \"#21a685\", \"#22a785\", \"#22a884\", \"#23a983\", \"#24aa83\", \"#25ab82\", \"#25ac82\", \"#26ad81\", \"#27ad81\", \"#28ae80\", \"#29af7f\", \"#2ab07f\", \"#2cb17e\", \"#2db27d\", \"#2eb37c\", \"#2fb47c\", \"#31b57b\", \"#32b67a\", \"#34b679\", \"#35b779\", \"#37b878\", \"#38b977\", \"#3aba76\", \"#3bbb75\", \"#3dbc74\", \"#3fbc73\", \"#40bd72\", \"#42be71\", \"#44bf70\", \"#46c06f\", \"#48c16e\", \"#4ac16d\", \"#4cc26c\", \"#4ec36b\", \"#50c46a\", \"#52c569\", \"#54c568\", \"#56c667\", \"#58c765\", \"#5ac864\", \"#5cc863\", \"#5ec962\", \"#60ca60\", \"#63cb5f\", \"#65cb5e\", \"#67cc5c\", \"#69cd5b\", \"#6ccd5a\", \"#6ece58\", \"#70cf57\", \"#73d056\", \"#75d054\", \"#77d153\", \"#7ad151\", \"#7cd250\", \"#7fd34e\", \"#81d34d\", \"#84d44b\", \"#86d549\", \"#89d548\", \"#8bd646\", \"#8ed645\", \"#90d743\", \"#93d741\", \"#95d840\", \"#98d83e\", \"#9bd93c\", \"#9dd93b\", \"#a0da39\", \"#a2da37\", \"#a5db36\", \"#a8db34\", \"#aadc32\", \"#addc30\", \"#b0dd2f\", \"#b2dd2d\", \"#b5de2b\", \"#b8de29\", \"#bade28\", \"#bddf26\", \"#c0df25\", \"#c2df23\", \"#c5e021\", \"#c8e020\", \"#cae11f\", \"#cde11d\", \"#d0e11c\", \"#d2e21b\", \"#d5e21a\", \"#d8e219\", \"#dae319\", \"#dde318\", \"#dfe318\", \"#e2e418\", \"#e5e419\", \"#e7e419\", \"#eae51a\", \"#ece51b\", \"#efe51c\", \"#f1e51d\", \"#f4e61e\", \"#f6e620\", \"#f8e621\", \"#fbe723\", \"#fde725\"];\r\n                break;\r\n        }\r\n        return options;\r\n    }\r\n}\r\n\n\n\n// WEBPACK FOOTER //\n// src/Gisplay/Maps/ChorochromaticMap.js"],"mappings":";;;;;;;;;AACA;AACA;AAAA;AACA;;;;;AAHA;AACA;AACA;AAEA;;;AAGA;;;AAEA;AAAA;AACA;AADA;AAEA;AACA;;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AATA;AAWA;AACA;;;;","sourceRoot":""}");
/***/ }),
/* 10 */
/* unknown exports provided */
/* all exports used */
/*!************************************!*\
!*** ./src/Gisplay/Maps/DotMap.js ***!
\************************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.DotMap = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Map2 = __webpack_require__(/*! ./Map */ 1);\n\nvar _Legend = __webpack_require__(/*! ../Legend */ 0);\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\r\n * DotMap implemenetation\r\n */\nvar DotMap = exports.DotMap = function (_Map) {\n _inherits(DotMap, _Map);\n\n function DotMap(bgmap, geometry, options) {\n _classCallCheck(this, DotMap);\n\n var _this = _possibleConstructorReturn(this, (DotMap.__proto__ || Object.getPrototypeOf(DotMap)).call(this, bgmap, geometry, options));\n\n _this.geometry = geometry;\n _this.aesthetics = new Array();\n _this.type = 'DM';\n _this.loadOptions(options, bgmap);\n _this.id = mapcount++;\n maps.push(_this);\n _this.initialize();\n /* return this;*/\n return _this;\n }\n\n _createClass(DotMap, [{\n key: 'draw',\n value: function draw() {\n this.clear();\n for (var i = 0; i < this.aesthetics.length; i++) {\n if (this.aesthetics[i].enabled == true) this.drawPoints(this.aesthetics[i]);\n }\n }\n }, {\n key: 'buildLegend',\n value: function buildLegend() {\n this.legend = new _Legend.Legend(this.id, this.legendTitle);\n for (var a in this.aesthetics) {\n this.legend.insertPointRow(this.aesthetics[a], this);\n }this.legend.insertLegend(this.map);\n }\n }, {\n key: 'defaults',\n value: function defaults(defaultid, useroptions) {\n //@TODO useroptions not used\n var options = {};\n switch (defaultid) {\n case 1:\n options.colorScheme = [\"#440154\", \"#440256\", \"#450457\", \"#450559\", \"#46075a\", \"#46085c\", \"#460a5d\", \"#460b5e\", \"#470d60\", \"#470e61\", \"#471063\", \"#471164\", \"#471365\", \"#481467\", \"#481668\", \"#481769\", \"#48186a\", \"#481a6c\", \"#481b6d\", \"#481c6e\", \"#481d6f\", \"#481f70\", \"#482071\", \"#482173\", \"#482374\", \"#482475\", \"#482576\", \"#482677\", \"#482878\", \"#482979\", \"#472a7a\", \"#472c7a\", \"#472d7b\", \"#472e7c\", \"#472f7d\", \"#46307e\", \"#46327e\", \"#46337f\", \"#463480\", \"#453581\", \"#453781\", \"#453882\", \"#443983\", \"#443a83\", \"#443b84\", \"#433d84\", \"#433e85\", \"#423f85\", \"#424086\", \"#424186\", \"#414287\", \"#414487\", \"#404588\", \"#404688\", \"#3f4788\", \"#3f4889\", \"#3e4989\", \"#3e4a89\", \"#3e4c8a\", \"#3d4d8a\", \"#3d4e8a\", \"#3c4f8a\", \"#3c508b\", \"#3b518b\", \"#3b528b\", \"#3a538b\", \"#3a548c\", \"#39558c\", \"#39568c\", \"#38588c\", \"#38598c\", \"#375a8c\", \"#375b8d\", \"#365c8d\", \"#365d8d\", \"#355e8d\", \"#355f8d\", \"#34608d\", \"#34618d\", \"#33628d\", \"#33638d\", \"#32648e\", \"#32658e\", \"#31668e\", \"#31678e\", \"#31688e\", \"#30698e\", \"#306a8e\", \"#2f6b8e\", \"#2f6c8e\", \"#2e6d8e\", \"#2e6e8e\", \"#2e6f8e\", \"#2d708e\", \"#2d718e\", \"#2c718e\", \"#2c728e\", \"#2c738e\", \"#2b748e\", \"#2b758e\", \"#2a768e\", \"#2a778e\", \"#2a788e\", \"#29798e\", \"#297a8e\", \"#297b8e\", \"#287c8e\", \"#287d8e\", \"#277e8e\", \"#277f8e\", \"#27808e\", \"#26818e\", \"#26828e\", \"#26828e\", \"#25838e\", \"#25848e\", \"#25858e\", \"#24868e\", \"#24878e\", \"#23888e\", \"#23898e\", \"#238a8d\", \"#228b8d\", \"#228c8d\", \"#228d8d\", \"#218e8d\", \"#218f8d\", \"#21908d\", \"#21918c\", \"#20928c\", \"#20928c\", \"#20938c\", \"#1f948c\", \"#1f958b\", \"#1f968b\", \"#1f978b\", \"#1f988b\", \"#1f998a\", \"#1f9a8a\", \"#1e9b8a\", \"#1e9c89\", \"#1e9d89\", \"#1f9e89\", \"#1f9f88\", \"#1fa088\", \"#1fa188\", \"#1fa187\", \"#1fa287\", \"#20a386\", \"#20a486\", \"#21a585\", \"#21a685\", \"#22a785\", \"#22a884\", \"#23a983\", \"#24aa83\", \"#25ab82\", \"#25ac82\", \"#26ad81\", \"#27ad81\", \"#28ae80\", \"#29af7f\", \"#2ab07f\", \"#2cb17e\", \"#2db27d\", \"#2eb37c\", \"#2fb47c\", \"#31b57b\", \"#32b67a\", \"#34b679\", \"#35b779\", \"#37b878\", \"#38b977\", \"#3aba76\", \"#3bbb75\", \"#3dbc74\", \"#3fbc73\", \"#40bd72\", \"#42be71\", \"#44bf70\", \"#46c06f\", \"#48c16e\", \"#4ac16d\", \"#4cc26c\", \"#4ec36b\", \"#50c46a\", \"#52c569\", \"#54c568\", \"#56c667\", \"#58c765\", \"#5ac864\", \"#5cc863\", \"#5ec962\", \"#60ca60\", \"#63cb5f\", \"#65cb5e\", \"#67cc5c\", \"#69cd5b\", \"#6ccd5a\", \"#6ece58\", \"#70cf57\", \"#73d056\", \"#75d054\", \"#77d153\", \"#7ad151\", \"#7cd250\", \"#7fd34e\", \"#81d34d\", \"#84d44b\", \"#86d549\", \"#89d548\", \"#8bd646\", \"#8ed645\", \"#90d743\", \"#93d741\", \"#95d840\", \"#98d83e\", \"#9bd93c\", \"#9dd93b\", \"#a0da39\", \"#a2da37\", \"#a5db36\", \"#a8db34\", \"#aadc32\", \"#addc30\", \"#b0dd2f\", \"#b2dd2d\", \"#b5de2b\", \"#b8de29\", \"#bade28\", \"#bddf26\", \"#c0df25\", \"#c2df23\", \"#c5e021\", \"#c8e020\", \"#cae11f\", \"#cde11d\", \"#d0e11c\", \"#d2e21b\", \"#d5e21a\", \"#d8e219\", \"#dae319\", \"#dde318\", \"#dfe318\", \"#e2e418\", \"#e5e419\", \"#e7e419\", \"#eae51a\", \"#ece51b\", \"#efe51c\", \"#f1e51d\", \"#f4e61e\", \"#f6e620\", \"#f8e621\", \"#fbe723\", \"#fde725\"];\n break;\n case 2:\n options.colorScheme = ['purple', 'orange', 'blue', 'yellow', 'pink', 'green', 'red', 'navy'];\n break;\n default:\n break;\n }\n options.numberOfClasses = 1;\n return options;\n }\n }]);\n\n return DotMap;\n}(_Map2.Map);//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTAuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL0dpc3BsYXkvTWFwcy9Eb3RNYXAuanM/ODkzMSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge01hcH0gZnJvbSAnLi9NYXAnO1xyXG5pbXBvcnQge0xlZ2VuZH0gZnJvbSAnLi4vTGVnZW5kJztcclxuXHJcbi8qKlxyXG4gKiBEb3RNYXAgaW1wbGVtZW5ldGF0aW9uXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgRG90TWFwIGV4dGVuZHMgTWFwIHtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihiZ21hcCwgZ2VvbWV0cnksIG9wdGlvbnMpIHtcclxuICAgICAgICBzdXBlcihiZ21hcCwgZ2VvbWV0cnksIG9wdGlvbnMpO1xyXG4gICAgICAgIHRoaXMuZ2VvbWV0cnkgPSBnZW9tZXRyeTtcclxuICAgICAgICB0aGlzLmFlc3RoZXRpY3MgPSBuZXcgQXJyYXkoKTtcclxuICAgICAgICB0aGlzLnR5cGUgPSAnRE0nO1xyXG4gICAgICAgIHRoaXMubG9hZE9wdGlvbnMob3B0aW9ucywgYmdtYXApO1xyXG4gICAgICAgIHRoaXMuaWQgPSBtYXBjb3VudCsrO1xyXG4gICAgICAgIG1hcHMucHVzaCh0aGlzKTtcclxuICAgICAgICB0aGlzLmluaXRpYWxpemUoKTtcclxuICAgICAgICAvKiAgcmV0dXJuIHRoaXM7Ki9cclxuICAgIH1cclxuXHJcbiAgICBkcmF3KCkge1xyXG4gICAgICAgIHRoaXMuY2xlYXIoKTtcclxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuYWVzdGhldGljcy5sZW5ndGg7IGkrKylcclxuICAgICAgICAgICAgaWYgKHRoaXMuYWVzdGhldGljc1tpXS5lbmFibGVkID09IHRydWUpXHJcbiAgICAgICAgICAgICAgICB0aGlzLmRyYXdQb2ludHModGhpcy5hZXN0aGV0aWNzW2ldKTtcclxuICAgIH1cclxuXHJcbiAgICBidWlsZExlZ2VuZCgpIHtcclxuICAgICAgICB0aGlzLmxlZ2VuZCA9IG5ldyBMZWdlbmQodGhpcy5pZCwgdGhpcy5sZWdlbmRUaXRsZSk7XHJcbiAgICAgICAgZm9yIChjb25zdCBhIGluIHRoaXMuYWVzdGhldGljcylcclxuICAgICAgICAgICAgdGhpcy5sZWdlbmQuaW5zZXJ0UG9pbnRSb3codGhpcy5hZXN0aGV0aWNzW2FdLCB0aGlzKTtcclxuICAgICAgICB0aGlzLmxlZ2VuZC5pbnNlcnRMZWdlbmQodGhpcy5tYXApO1xyXG4gICAgfVxyXG5cclxuICAgIGRlZmF1bHRzKGRlZmF1bHRpZCwgdXNlcm9wdGlvbnMpIHsgLy9AVE9ETyB1c2Vyb3B0aW9ucyBub3QgdXNlZFxyXG4gICAgICAgIGNvbnN0IG9wdGlvbnMgPSB7fTtcclxuICAgICAgICBzd2l0Y2ggKGRlZmF1bHRpZCkge1xyXG4gICAgICAgICAgICBjYXNlIDE6XHJcbiAgICAgICAgICAgICAgICBvcHRpb25zLmNvbG9yU2NoZW1lID0gW1wiIzQ0MDE1NFwiLCBcIiM0NDAyNTZcIiwgXCIjNDUwNDU3XCIsIFwiIzQ1MDU1OVwiLCBcIiM0NjA3NWFcIiwgXCIjNDYwODVjXCIsIFwiIzQ2MGE1ZFwiLCBcIiM0NjBiNWVcIiwgXCIjNDcwZDYwXCIsIFwiIzQ3MGU2MVwiLCBcIiM0NzEwNjNcIiwgXCIjNDcxMTY0XCIsIFwiIzQ3MTM2NVwiLCBcIiM0ODE0NjdcIiwgXCIjNDgxNjY4XCIsIFwiIzQ4MTc2OVwiLCBcIiM0ODE4NmFcIiwgXCIjNDgxYTZjXCIsIFwiIzQ4MWI2ZFwiLCBcIiM0ODFjNmVcIiwgXCIjNDgxZDZmXCIsIFwiIzQ4MWY3MFwiLCBcIiM0ODIwNzFcIiwgXCIjNDgyMTczXCIsIFwiIzQ4MjM3NFwiLCBcIiM0ODI0NzVcIiwgXCIjNDgyNTc2XCIsIFwiIzQ4MjY3N1wiLCBcIiM0ODI4NzhcIiwgXCIjNDgyOTc5XCIsIFwiIzQ3MmE3YVwiLCBcIiM0NzJjN2FcIiwgXCIjNDcyZDdiXCIsIFwiIzQ3MmU3Y1wiLCBcIiM0NzJmN2RcIiwgXCIjNDYzMDdlXCIsIFwiIzQ2MzI3ZVwiLCBcIiM0NjMzN2ZcIiwgXCIjNDYzNDgwXCIsIFwiIzQ1MzU4MVwiLCBcIiM0NTM3ODFcIiwgXCIjNDUzODgyXCIsIFwiIzQ0Mzk4M1wiLCBcIiM0NDNhODNcIiwgXCIjNDQzYjg0XCIsIFwiIzQzM2Q4NFwiLCBcIiM0MzNlODVcIiwgXCIjNDIzZjg1XCIsIFwiIzQyNDA4NlwiLCBcIiM0MjQxODZcIiwgXCIjNDE0Mjg3XCIsIFwiIzQxNDQ4N1wiLCBcIiM0MDQ1ODhcIiwgXCIjNDA0Njg4XCIsIFwiIzNmNDc4OFwiLCBcIiMzZjQ4ODlcIiwgXCIjM2U0OTg5XCIsIFwiIzNlNGE4OVwiLCBcIiMzZTRjOGFcIiwgXCIjM2Q0ZDhhXCIsIFwiIzNkNGU4YVwiLCBcIiMzYzRmOGFcIiwgXCIjM2M1MDhiXCIsIFwiIzNiNTE4YlwiLCBcIiMzYjUyOGJcIiwgXCIjM2E1MzhiXCIsIFwiIzNhNTQ4Y1wiLCBcIiMzOTU1OGNcIiwgXCIjMzk1NjhjXCIsIFwiIzM4NTg4Y1wiLCBcIiMzODU5OGNcIiwgXCIjMzc1YThjXCIsIFwiIzM3NWI4ZFwiLCBcIiMzNjVjOGRcIiwgXCIjMzY1ZDhkXCIsIFwiIzM1NWU4ZFwiLCBcIiMzNTVmOGRcIiwgXCIjMzQ2MDhkXCIsIFwiIzM0NjE4ZFwiLCBcIiMzMzYyOGRcIiwgXCIjMzM2MzhkXCIsIFwiIzMyNjQ4ZVwiLCBcIiMzMjY1OGVcIiwgXCIjMzE2NjhlXCIsIFwiIzMxNjc4ZVwiLCBcIiMzMTY4OGVcIiwgXCIjMzA2OThlXCIsIFwiIzMwNmE4ZVwiLCBcIiMyZjZiOGVcIiwgXCIjMmY2YzhlXCIsIFwiIzJlNmQ4ZVwiLCBcIiMyZTZlOGVcIiwgXCIjMmU2ZjhlXCIsIFwiIzJkNzA4ZVwiLCBcIiMyZDcxOGVcIiwgXCIjMmM3MThlXCIsIFwiIzJjNzI4ZVwiLCBcIiMyYzczOGVcIiwgXCIjMmI3NDhlXCIsIFwiIzJiNzU4ZVwiLCBcIiMyYTc2OGVcIiwgXCIjMmE3NzhlXCIsIFwiIzJhNzg4ZVwiLCBcIiMyOTc5OGVcIiwgXCIjMjk3YThlXCIsIFwiIzI5N2I4ZVwiLCBcIiMyODdjOGVcIiwgXCIjMjg3ZDhlXCIsIFwiIzI3N2U4ZVwiLCBcIiMyNzdmOGVcIiwgXCIjMjc4MDhlXCIsIFwiIzI2ODE4ZVwiLCBcIiMyNjgyOGVcIiwgXCIjMjY4MjhlXCIsIFwiIzI1ODM4ZVwiLCBcIiMyNTg0OGVcIiwgXCIjMjU4NThlXCIsIFwiIzI0ODY4ZVwiLCBcIiMyNDg3OGVcIiwgXCIjMjM4ODhlXCIsIFwiIzIzODk4ZVwiLCBcIiMyMzhhOGRcIiwgXCIjMjI4YjhkXCIsIFwiIzIyOGM4ZFwiLCBcIiMyMjhkOGRcIiwgXCIjMjE4ZThkXCIsIFwiIzIxOGY4ZFwiLCBcIiMyMTkwOGRcIiwgXCIjMjE5MThjXCIsIFwiIzIwOTI4Y1wiLCBcIiMyMDkyOGNcIiwgXCIjMjA5MzhjXCIsIFwiIzFmOTQ4Y1wiLCBcIiMxZjk1OGJcIiwgXCIjMWY5NjhiXCIsIFwiIzFmOTc4YlwiLCBcIiMxZjk4OGJcIiwgXCIjMWY5OThhXCIsIFwiIzFmOWE4YVwiLCBcIiMxZTliOGFcIiwgXCIjMWU5Yzg5XCIsIFwiIzFlOWQ4OVwiLCBcIiMxZjllODlcIiwgXCIjMWY5Zjg4XCIsIFwiIzFmYTA4OFwiLCBcIiMxZmExODhcIiwgXCIjMWZhMTg3XCIsIFwiIzFmYTI4N1wiLCBcIiMyMGEzODZcIiwgXCIjMjBhNDg2XCIsIFwiIzIxYTU4NVwiLCBcIiMyMWE2ODVcIiwgXCIjMjJhNzg1XCIsIFwiIzIyYTg4NFwiLCBcIiMyM2E5ODNcIiwgXCIjMjRhYTgzXCIsIFwiIzI1YWI4MlwiLCBcIiMyNWFjODJcIiwgXCIjMjZhZDgxXCIsIFwiIzI3YWQ4MVwiLCBcIiMyOGFlODBcIiwgXCIjMjlhZjdmXCIsIFwiIzJhYjA3ZlwiLCBcIiMyY2IxN2VcIiwgXCIjMmRiMjdkXCIsIFwiIzJlYjM3Y1wiLCBcIiMyZmI0N2NcIiwgXCIjMzFiNTdiXCIsIFwiIzMyYjY3YVwiLCBcIiMzNGI2NzlcIiwgXCIjMzViNzc5XCIsIFwiIzM3Yjg3OFwiLCBcIiMzOGI5NzdcIiwgXCIjM2FiYTc2XCIsIFwiIzNiYmI3NVwiLCBcIiMzZGJjNzRcIiwgXCIjM2ZiYzczXCIsIFwiIzQwYmQ3MlwiLCBcIiM0MmJlNzFcIiwgXCIjNDRiZjcwXCIsIFwiIzQ2YzA2ZlwiLCBcIiM0OGMxNmVcIiwgXCIjNGFjMTZkXCIsIFwiIzRjYzI2Y1wiLCBcIiM0ZWMzNmJcIiwgXCIjNTBjNDZhXCIsIFwiIzUyYzU2OVwiLCBcIiM1NGM1NjhcIiwgXCIjNTZjNjY3XCIsIFwiIzU4Yzc2NVwiLCBcIiM1YWM4NjRcIiwgXCIjNWNjODYzXCIsIFwiIzVlYzk2MlwiLCBcIiM2MGNhNjBcIiwgXCIjNjNjYjVmXCIsIFwiIzY1Y2I1ZVwiLCBcIiM2N2NjNWNcIiwgXCIjNjljZDViXCIsIFwiIzZjY2Q1YVwiLCBcIiM2ZWNlNThcIiwgXCIjNzBjZjU3XCIsIFwiIzczZDA1NlwiLCBcIiM3NWQwNTRcIiwgXCIjNzdkMTUzXCIsIFwiIzdhZDE1MVwiLCBcIiM3Y2QyNTBcIiwgXCIjN2ZkMzRlXCIsIFwiIzgxZDM0ZFwiLCBcIiM4NGQ0NGJcIiwgXCIjODZkNTQ5XCIsIFwiIzg5ZDU0OFwiLCBcIiM4YmQ2NDZcIiwgXCIjOGVkNjQ1XCIsIFwiIzkwZDc0M1wiLCBcIiM5M2Q3NDFcIiwgXCIjOTVkODQwXCIsIFwiIzk4ZDgzZVwiLCBcIiM5YmQ5M2NcIiwgXCIjOWRkOTNiXCIsIFwiI2EwZGEzOVwiLCBcIiNhMmRhMzdcIiwgXCIjYTVkYjM2XCIsIFwiI2E4ZGIzNFwiLCBcIiNhYWRjMzJcIiwgXCIjYWRkYzMwXCIsIFwiI2IwZGQyZlwiLCBcIiNiMmRkMmRcIiwgXCIjYjVkZTJiXCIsIFwiI2I4ZGUyOVwiLCBcIiNiYWRlMjhcIiwgXCIjYmRkZjI2XCIsIFwiI2MwZGYyNVwiLCBcIiNjMmRmMjNcIiwgXCIjYzVlMDIxXCIsIFwiI2M4ZTAyMFwiLCBcIiNjYWUxMWZcIiwgXCIjY2RlMTFkXCIsIFwiI2QwZTExY1wiLCBcIiNkMmUyMWJcIiwgXCIjZDVlMjFhXCIsIFwiI2Q4ZTIxOVwiLCBcIiNkYWUzMTlcIiwgXCIjZGRlMzE4XCIsIFwiI2RmZTMxOFwiLCBcIiNlMmU0MThcIiwgXCIjZTVlNDE5XCIsIFwiI2U3ZTQxOVwiLCBcIiNlYWU1MWFcIiwgXCIjZWNlNTFiXCIsIFwiI2VmZTUxY1wiLCBcIiNmMWU1MWRcIiwgXCIjZjRlNjFlXCIsIFwiI2Y2ZTYyMFwiLCBcIiNmOGU2MjFcIiwgXCIjZmJlNzIzXCIsIFwiI2ZkZTcyNVwiXTtcclxuICAgICAgICAgICAgICAgIGJyZWFrO1xyXG4gICAgICAgICAgICBjYXNlIDI6XHJcbiAgICAgICAgICAgICAgICBvcHRpb25zLmNvbG9yU2NoZW1lID0gWydwdXJwbGUnLCAnb3JhbmdlJywgJ2JsdWUnLCAneWVsbG93JywgJ3BpbmsnLCAnZ3JlZW4nLCAncmVkJywgJ25hdnknXTtcclxuICAgICAgICAgICAgICAgIGJyZWFrO1xyXG4gICAgICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICAgICAgYnJlYWs7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG9wdGlvbnMubnVtYmVyT2ZDbGFzc2VzID0gMTtcclxuICAgICAgICByZXR1cm4gb3B0aW9ucztcclxuICAgIH1cclxufVxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvR2lzcGxheS9NYXBzL0RvdE1hcC5qcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7QUFDQTtBQUFBO0FBQ0E7Ozs7Ozs7QUFDQTs7O0FBR0E7OztBQUVBO0FBQUE7QUFDQTtBQURBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBVEE7QUFVQTtBQUNBOzs7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBR0E7OztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBREE7QUFHQTs7O0FBRUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBUkE7QUFVQTtBQUNBO0FBQ0E7Ozs7Iiwic291cmNlUm9vdCI6IiJ9");
/***/ }),
/* 11 */
/* unknown exports provided */
/* all exports used */
/*!****************************************************!*\
!*** ./src/Gisplay/Maps/ProportionalSymbolsMap.js ***!
\****************************************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ProportionalSymbolsMap = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Map2 = __webpack_require__(/*! ./Map */ 1);\n\nvar _Legend = __webpack_require__(/*! ../Legend */ 0);\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\r\n * Proportional Symbols Map implementation.\r\n */\nvar ProportionalSymbolsMap = exports.ProportionalSymbolsMap = function (_Map) {\n _inherits(ProportionalSymbolsMap, _Map);\n\n function ProportionalSymbolsMap(bgmap, geometry, options) {\n _classCallCheck(this, ProportionalSymbolsMap);\n\n var _this = _possibleConstructorReturn(this, (ProportionalSymbolsMap.__proto__ || Object.getPrototypeOf(ProportionalSymbolsMap)).call(this, bgmap, geometry, options));\n\n _this.geometry = geometry;\n _this.aesthetics = new Array();\n _this.legend; //@Rui TODO WUT\n _this.annotations = new Array();\n _this.map = bgmap;\n _this.id = mapcount++;\n _this.type = 'PS';\n _this.loadOptions(options, bgmap);\n _this.dynamic = options.sizeByClass == undefined ? true : !options.sizeByClass;\n if (_this.dynamic == true) {\n _this.maxpointsize = options.maxPointSize == undefined ? 10.0 : parseFloat(options.maxPointSize);\n _this.minpointsize = options.minPointSize == undefined ? 1.0 : parseFloat(options.minPointSize);\n }\n maps.push(_this);\n _this.initialize();\n return _this;\n }\n\n _createClass(ProportionalSymbolsMap, [{\n key: 'draw',\n value: function draw() {\n this.clear();\n if (this.dynamic == false) for (var i = this.aesthetics.length - 1; i >= 0; i--) {\n if (this.aesthetics[i].enabled == true) this.drawPoints(this.aesthetics[i]);\n } else {\n for (var i = this.aesthetics.length - 1; i >= 0; i--) {\n if (this.aesthetics[i].enabled == true) this.drawProporcionalPoints(this.aesthetics[i]);\n }\n }\n }\n }, {\n key: 'buildLegend',\n value: function buildLegend() {\n this.legend = new _Legend.Legend(this.id, this.legendTitle);\n if (this.aesthetics.length == 1) this.legend.insertProportionalSymbols(this.aesthetics[0], this, this.numberOfLegendItems);else for (var i = this.aesthetics.length - 1; i >= 0; i--) {\n if (i == 0) this.legend.insertProportionalSymbols(this.aesthetics[i], this, 2);else this.legend.insertProportionalSymbols(this.aesthetics[i], this, 1);\n }this.legend.insertLegend(this.map);\n }\n }, {\n key: 'defaults',\n value: function defaults(defaultid) {\n var options = {};\n switch (defaultid) {\n case 1:\n options.maxPointSize = 60;\n options.minPointSize = 5;\n options.colorScheme = ['green', 'red', 'blue'];\n options.numberOfClasses = 1;\n break;\n default:\n break;\n }\n return options;\n }\n }]);\n\n return ProportionalSymbolsMap;\n}(_Map2.Map);//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTEuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL0dpc3BsYXkvTWFwcy9Qcm9wb3J0aW9uYWxTeW1ib2xzTWFwLmpzPzgyNjMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWFwIH0gZnJvbSAnLi9NYXAnO1xyXG5pbXBvcnQgeyBMZWdlbmQgfSBmcm9tICcuLi9MZWdlbmQnO1xyXG5cclxuLyoqXHJcbiAqIFByb3BvcnRpb25hbCBTeW1ib2xzIE1hcCBpbXBsZW1lbnRhdGlvbi5cclxuICovXHJcbmV4cG9ydCBjbGFzcyBQcm9wb3J0aW9uYWxTeW1ib2xzTWFwIGV4dGVuZHMgTWFwIHtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihiZ21hcCwgZ2VvbWV0cnksIG9wdGlvbnMpIHtcclxuICAgICAgICBzdXBlcihiZ21hcCwgZ2VvbWV0cnksIG9wdGlvbnMpO1xyXG4gICAgICAgIHRoaXMuZ2VvbWV0cnkgPSBnZW9tZXRyeTtcclxuICAgICAgICB0aGlzLmFlc3RoZXRpY3MgPSBuZXcgQXJyYXkoKTtcclxuICAgICAgICB0aGlzLmxlZ2VuZDsgLy9AUnVpIFRPRE8gV1VUXHJcbiAgICAgICAgdGhpcy5hbm5vdGF0aW9ucyA9IG5ldyBBcnJheSgpO1xyXG4gICAgICAgIHRoaXMubWFwID0gYmdtYXA7XHJcbiAgICAgICAgdGhpcy5pZCA9IG1hcGNvdW50Kys7XHJcbiAgICAgICAgdGhpcy50eXBlID0gJ1BTJztcclxuICAgICAgICB0aGlzLmxvYWRPcHRpb25zKG9wdGlvbnMsIGJnbWFwKTtcclxuICAgICAgICB0aGlzLmR5bmFtaWMgPSBvcHRpb25zLnNpemVCeUNsYXNzID09IHVuZGVmaW5lZCA/IHRydWUgOiAhb3B0aW9ucy5zaXplQnlDbGFzcztcclxuICAgICAgICBpZiAodGhpcy5keW5hbWljID09IHRydWUpIHtcclxuICAgICAgICAgICAgdGhpcy5tYXhwb2ludHNpemUgPSBvcHRpb25zLm1heFBvaW50U2l6ZSA9PSB1bmRlZmluZWQgPyAxMC4wIDogcGFyc2VGbG9hdChvcHRpb25zLm1heFBvaW50U2l6ZSk7XHJcbiAgICAgICAgICAgIHRoaXMubWlucG9pbnRzaXplID0gb3B0aW9ucy5taW5Qb2ludFNpemUgPT0gdW5kZWZpbmVkID8gMS4wIDogcGFyc2VGbG9hdChvcHRpb25zLm1pblBvaW50U2l6ZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG1hcHMucHVzaCh0aGlzKTtcclxuICAgICAgICB0aGlzLmluaXRpYWxpemUoKTtcclxuICAgIH1cclxuXHJcbiAgICBkcmF3KCkge1xyXG4gICAgICAgIHRoaXMuY2xlYXIoKTtcclxuICAgICAgICBpZiAodGhpcy5keW5hbWljID09IGZhbHNlKVxyXG4gICAgICAgICAgICBmb3IgKHZhciBpID0gdGhpcy5hZXN0aGV0aWNzLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKSB7XHJcbiAgICAgICAgICAgICAgICBpZiAodGhpcy5hZXN0aGV0aWNzW2ldLmVuYWJsZWQgPT0gdHJ1ZSlcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmRyYXdQb2ludHModGhpcy5hZXN0aGV0aWNzW2ldKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICBmb3IgKHZhciBpID0gdGhpcy5hZXN0aGV0aWNzLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKSB7XHJcbiAgICAgICAgICAgICAgICBpZiAodGhpcy5hZXN0aGV0aWNzW2ldLmVuYWJsZWQgPT0gdHJ1ZSlcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmRyYXdQcm9wb3JjaW9uYWxQb2ludHModGhpcy5hZXN0aGV0aWNzW2ldKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBidWlsZExlZ2VuZCgpIHtcclxuICAgICAgICB0aGlzLmxlZ2VuZCA9IG5ldyBMZWdlbmQodGhpcy5pZCwgdGhpcy5sZWdlbmRUaXRsZSk7XHJcbiAgICAgICAgaWYgKHRoaXMuYWVzdGhldGljcy5sZW5ndGggPT0gMSlcclxuICAgICAgICAgICAgdGhpcy5sZWdlbmQuaW5zZXJ0UHJvcG9ydGlvbmFsU3ltYm9scyh0aGlzLmFlc3RoZXRpY3NbMF0sIHRoaXMsIHRoaXMubnVtYmVyT2ZMZWdlbmRJdGVtcyk7XHJcbiAgICAgICAgZWxzZVxyXG4gICAgICAgICAgICBmb3IgKGxldCBpID0gdGhpcy5hZXN0aGV0aWNzLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKVxyXG4gICAgICAgICAgICAgICAgaWYgKGkgPT0gMClcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmxlZ2VuZC5pbnNlcnRQcm9wb3J0aW9uYWxTeW1ib2xzKHRoaXMuYWVzdGhldGljc1tpXSwgdGhpcywgMik7XHJcbiAgICAgICAgICAgICAgICBlbHNlXHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5sZWdlbmQuaW5zZXJ0UHJvcG9ydGlvbmFsU3ltYm9scyh0aGlzLmFlc3RoZXRpY3NbaV0sIHRoaXMsIDEpO1xyXG4gICAgICAgIHRoaXMubGVnZW5kLmluc2VydExlZ2VuZCh0aGlzLm1hcCk7XHJcbiAgICB9XHJcblxyXG4gICAgZGVmYXVsdHMoZGVmYXVsdGlkKSB7XHJcbiAgICAgICAgY29uc3Qgb3B0aW9ucyA9IHt9O1xyXG4gICAgICAgIHN3aXRjaCAoZGVmYXVsdGlkKSB7XHJcbiAgICAgICAgICAgIGNhc2UgMTpcclxuICAgICAgICAgICAgICAgIG9wdGlvbnMubWF4UG9pbnRTaXplID0gNjA7XHJcbiAgICAgICAgICAgICAgICBvcHRpb25zLm1pblBvaW50U2l6ZSA9IDU7XHJcbiAgICAgICAgICAgICAgICBvcHRpb25zLmNvbG9yU2NoZW1lID0gWydncmVlbicsICdyZWQnLCAnYmx1ZSddO1xyXG4gICAgICAgICAgICAgICAgb3B0aW9ucy5udW1iZXJPZkNsYXNzZXMgPSAxO1xyXG4gICAgICAgICAgICAgICAgYnJlYWs7XHJcbiAgICAgICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgICAgICBicmVhaztcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIG9wdGlvbnM7XHJcbiAgICB9XHJcblxyXG59XG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIHNyYy9HaXNwbGF5L01hcHMvUHJvcG9ydGlvbmFsU3ltYm9sc01hcC5qcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7QUFDQTtBQUFBO0FBQ0E7Ozs7Ozs7QUFDQTs7O0FBR0E7OztBQUVBO0FBQUE7QUFDQTtBQURBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFoQkE7QUFpQkE7QUFDQTs7O0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFFQTtBQUVBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7OztBQUVBO0FBQ0E7QUFDQTtBQUlBO0FBREE7QUFNQTs7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQVJBO0FBVUE7QUFDQTs7OzsiLCJzb3VyY2VSb290IjoiIn0=");
/***/ }),
/* 12 */
/* unknown exports provided */
/* all exports used */
/*!**************************!*\
!*** ./src/gisplayv2.js ***!
\**************************/
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\n\nvar _Gisplay = __webpack_require__(/*! ./Gisplay/Gisplay */ 4);\n\nvar _GisplayOptions = __webpack_require__(/*! ./Gisplay/Maps/GisplayOptions */ 5);\n\n/**\r\n * This file is the entry point for the Gisplay API\r\n */\nmodule.exports = {\n\n /** #########################CHOROPLETH MAPS################################# */\n //Choropleth\n createBGMap: function createBGMap() {\n console.log(\"Start gisplayv2. TESTE workflow18/02.\");\n L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\n window.map = L.mapbox.map('map', 'mapbox.streets').setView([49.36855556, -81.66371667], 4);\n },\n\n startChoropleth: function startChoropleth() {\n /*window.count = 0;*/\n var gisplay = new _Gisplay.Gisplay();\n var options = {\n colorScheme: [\"white\", \"yellow\", \"orange\", \"red\"],\n numberOfClasses: 4,\n attr: 'f3',\n legendTitle: 'Fatals'\n };\n var time = Date.now();\n\n var reader = new FileReader();\n reader.onloadend = function () {\n var data = JSON.parse(reader.result);\n var datareadtimestamp = Date.now();\n console.log(\"tempo de leitura do ficheiro: \" + (datareadtimestamp - time) / 1000 + \" segundos\");\n\n /* console.log(window.map)\r\n console.log(map)*/\n gisplay.makeChoropleth(window.map, data, options);\n console.log(\"tempo gisplay: \" + (Date.now() - datareadtimestamp) / 1000 + \" segundos\");\n console.log(\"tempo total: \" + (Date.now() - time) / 1000 + \" segundos\");\n };\n reader.readAsText(document.getElementById(\"file\").files[0]);\n },\n\n createBGMapChorocromatic: function createBGMapChorocromatic() {\n L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\n window.map = L.mapbox.map('map', 'mapbox.streets').setView([49.36855556, -81.66371667], 4);\n },\n\n startChorocromatic: function startChorocromatic() {\n var gisplay = new _Gisplay.Gisplay();\n var options = {\n attr: 'f2',\n legendTitle: \"Most Frequent Crime\"\n };\n\n var time = Date.now();\n console.log(\"starting Chorocromatic Map...\");\n\n var reader = new FileReader();\n reader.onloadend = function () {\n var data = JSON.parse(reader.result);\n var datareadtimestamp = Date.now();\n console.log(\"tempo de leitura do ficheiro: \" + (datareadtimestamp - time) / 1000 + \" segundos\");\n gisplay.makeChorochromaticMap(map, data, options);\n };\n reader.readAsText(document.getElementById(\"file\").files[0]);\n },\n\n /** #########################DOT MAPS################################# */\n //DOT MAP Example 1\n createBGMapDotMap: function createBGMapDotMap() {\n L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\n window.map = L.mapbox.map('map', 'mapbox.dark').setView([49.36855556, -81.66371667], 4);\n },\n\n startDotMap1: function startDotMap1() {\n var gisplay = new _Gisplay.Gisplay();\n console.log(\"starting Dot Map 1...\");\n\n var options = {\n colorScheme: [\"red\", \"green\"],\n attr: 'f1',\n legendTitle: \"Alcohol\"\n };\n\n var reader = new FileReader();\n reader.onloadend = function () {\n var data = JSON.parse(reader.result);\n gisplay.makeDotMap(map, data, options);\n };\n reader.readAsText(document.getElementById(\"file\").files[0]);\n },\n\n //DOT MAP Example 2\n startDotMap2: function startDotMap2() {\n var gisplay = new _Gisplay.Gisplay();\n console.log(\"starting Dot Map 2...\");\n\n var options = {\n colorScheme: [\"blue\", \"red\"],\n maxPointSize: 100,\n numberOfClasses: 2,\n classBreaksMethod: \"k-means\",\n minPointSize: 1,\n attr: 'f2',\n legendTitle: \"Fatals\"\n };\n\n var reader = new FileReader();\n reader.onloadend = function () {\n var data = JSON.parse(reader.result);\n gisplay.makeDotMap(map, data, options);\n };\n reader.readAsText(document.getElementById(\"file\").files[0]);\n },\n\n /** #########################CHANGE MAPS################################# */\n //Change map Example\n createBGMapChangeMap: function createBGMapChangeMap() {\n L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\n window.map = L.mapbox.map('map', 'mapbox.dark').setView([49.36855556, -81.66371667], 4);\n },\n\n startChangeMap: function startChangeMap() {\n var gisplay = new _Gisplay.Gisplay();\n console.log(\"starting Change Map 1...\");\n\n var options = {\n colorScheme: [\"green\", \"red\"],\n minuend: 'f6',\n subtrahend: 'f2',\n alpha: 1,\n legendTitle: \"Evolução entre 2009 e 2013\"\n };\n\n var reader = new FileReader();\n reader.onloadend = function () {\n var data = JSON.parse(reader.result);\n gisplay.makeChangeMap(map, data, options);\n };\n reader.readAsText(document.getElementById(\"file\").files[0]);\n },\n\n /** ########################PROP. SYMBOLS MAPS########################### */\n createBGPSymbols: function createBGPSymbols() {\n L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\n window.map = L.mapbox.map('map', 'mapbox.dark').setView([49.36855556, -81.66371667], 4);\n },\n\n startPSymbols: function startPSymbols() {\n var gisplay = new _Gisplay.Gisplay();\n console.log(\"starting Proportional Symbols...\");\n var options = {\n maxPointSize: 100,\n minPointSize: 5,\n attr: 'f1',\n alpha: 1.0,\n numberOfLegendItems: 3,\n legendTitle: \"Accidents\"\n };\n\n var time = Date.now();\n\n var reader = new FileReader();\n reader.onloadend = function () {\n var data = JSON.parse(reader.result);\n gisplay.makeProportionalSymbolsMap(map, data, options);\n };\n reader.readAsText(document.getElementById(\"file\").files[0]);\n }\n\n};//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"12.js","sources":["webpack:///src/gisplayv2.js?5e37"],"sourcesContent":["/**\r\n * This file is the entry point for the Gisplay API\r\n */\r\nimport { Gisplay } from './Gisplay/Gisplay'\r\nimport { GisplayOptions } from './Gisplay/Maps/GisplayOptions';\r\n\r\nmodule.exports = {\r\n\r\n    /** #########################CHOROPLETH MAPS################################# */\r\n    //Choropleth\r\n    createBGMap: function () {\r\n        console.log(\"Start gisplayv2. TESTE workflow18/02.\");\r\n        L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\r\n        window.map = L.mapbox.map('map', 'mapbox.streets').setView([49.36855556, -81.66371667], 4);\r\n    },\r\n\r\n    startChoropleth: function () {\r\n        /*window.count = 0;*/\r\n        var gisplay = new Gisplay();\r\n        var options = {\r\n            colorScheme: [\"white\", \"yellow\", \"orange\", \"red\"],\r\n            numberOfClasses: 4,\r\n            attr: 'f3',\r\n            legendTitle: 'Fatals'\r\n        };\r\n        var time = Date.now();\r\n\r\n        var reader = new FileReader();\r\n        reader.onloadend = function () {\r\n            var data = JSON.parse(reader.result);\r\n            var datareadtimestamp = Date.now();\r\n            console.log(\"tempo de leitura do ficheiro: \" + (datareadtimestamp - time) / 1000 + \" segundos\");\r\n\r\n            /* console.log(window.map)\r\n             console.log(map)*/\r\n            gisplay.makeChoropleth(window.map, data, options);\r\n            console.log(\"tempo gisplay: \" + (Date.now() - datareadtimestamp) / 1000 + \" segundos\");\r\n            console.log(\"tempo total: \" + (Date.now() - time) / 1000 + \" segundos\");\r\n        }\r\n        reader.readAsText(document.getElementById(\"file\").files[0]);\r\n    },\r\n\r\n    createBGMapChorocromatic: function () {\r\n        L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\r\n        window.map = L.mapbox.map('map', 'mapbox.streets').setView([49.36855556, -81.66371667], 4);\r\n    },\r\n\r\n    startChorocromatic: function () {\r\n        var gisplay = new Gisplay();\r\n        var options = {\r\n            attr: 'f2',\r\n            legendTitle: \"Most Frequent Crime\"\r\n        };\r\n\r\n        var time = Date.now();\r\n        console.log(\"starting Chorocromatic Map...\");\r\n\r\n        var reader = new FileReader();\r\n        reader.onloadend = function () {\r\n            var data = JSON.parse(reader.result);\r\n            var datareadtimestamp = Date.now();\r\n            console.log(\"tempo de leitura do ficheiro: \" + (datareadtimestamp - time) / 1000 + \" segundos\");\r\n            gisplay.makeChorochromaticMap(map, data, options);\r\n        }\r\n        reader.readAsText(document.getElementById(\"file\").files[0]);\r\n    },\r\n\r\n    /** #########################DOT MAPS################################# */\r\n    //DOT MAP Example 1\r\n    createBGMapDotMap: function () {\r\n        L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\r\n        window.map = L.mapbox.map('map', 'mapbox.dark').setView([49.36855556, -81.66371667], 4);\r\n    },\r\n\r\n    startDotMap1: function () {\r\n        var gisplay = new Gisplay();\r\n        console.log(\"starting Dot Map 1...\");\r\n\r\n        var options = {\r\n            colorScheme: [\"red\", \"green\"],\r\n            attr: 'f1',\r\n            legendTitle: \"Alcohol\"\r\n        };\r\n\r\n        var reader = new FileReader();\r\n        reader.onloadend = function () {\r\n            var data = JSON.parse(reader.result);\r\n            gisplay.makeDotMap(map, data, options);\r\n        }\r\n        reader.readAsText(document.getElementById(\"file\").files[0]);\r\n    },\r\n\r\n    //DOT MAP Example 2\r\n    startDotMap2: function () {\r\n        var gisplay = new Gisplay();\r\n        console.log(\"starting Dot Map 2...\");\r\n\r\n        var options = {\r\n            colorScheme: [\"blue\", \"red\"],\r\n            maxPointSize: 100,\r\n            numberOfClasses: 2,\r\n            classBreaksMethod: \"k-means\",\r\n            minPointSize: 1,\r\n            attr: 'f2',\r\n            legendTitle: \"Fatals\"\r\n        };\r\n\r\n        var reader = new FileReader();\r\n        reader.onloadend = function () {\r\n            var data = JSON.parse(reader.result);\r\n            gisplay.makeDotMap(map, data, options);\r\n        }\r\n        reader.readAsText(document.getElementById(\"file\").files[0]);\r\n    },\r\n\r\n    /** #########################CHANGE MAPS################################# */\r\n    //Change map Example\r\n    createBGMapChangeMap: function () {\r\n        L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\r\n        window.map = L.mapbox.map('map', 'mapbox.dark').setView([49.36855556, -81.66371667], 4);\r\n    },\r\n\r\n    startChangeMap: function () {\r\n        var gisplay = new Gisplay();\r\n        console.log(\"starting Change Map 1...\");\r\n\r\n        var options = {\r\n            colorScheme: [\"green\", \"red\"],\r\n            minuend: 'f6',\r\n            subtrahend: 'f2',\r\n            alpha: 1,\r\n            legendTitle: \"Evolução entre 2009 e 2013\"\r\n        };\r\n\r\n        var reader = new FileReader();\r\n        reader.onloadend = function () {\r\n            var data = JSON.parse(reader.result);\r\n            gisplay.makeChangeMap(map, data, options);\r\n        }\r\n        reader.readAsText(document.getElementById(\"file\").files[0]);\r\n    },\r\n\r\n    /** ########################PROP. SYMBOLS MAPS########################### */\r\n    createBGPSymbols: function () {\r\n        L.mapbox.accessToken = 'pk.eyJ1IjoibG9sYXNkIiwiYSI6ImNpbmxsZDJkejAwOHR2Zm0yZHVwOWV1ejEifQ.SJ6CupBlW0gPic0n-HgY6w';\r\n        window.map = L.mapbox.map('map', 'mapbox.dark').setView([49.36855556, -81.66371667], 4);\r\n    },\r\n\r\n    startPSymbols: function () {\r\n        var gisplay = new Gisplay();\r\n        console.log(\"starting Proportional Symbols...\");\r\n        var options = {\r\n            maxPointSize: 100,\r\n            minPointSize: 5,\r\n            attr: 'f1',\r\n            alpha: 1.0,\r\n            numberOfLegendItems: 3,\r\n            legendTitle: \"Accidents\"\r\n        };\r\n\r\n        var time = Date.now();\r\n\r\n        var reader = new FileReader();\r\n        reader.onloadend = function () {\r\n            var data = JSON.parse(reader.result);\r\n            gisplay.makeProportionalSymbolsMap(map, data, options);\r\n        }\r\n        reader.readAsText(document.getElementById(\"file\").files[0]);\r\n    },\r\n\r\n    /** #########################HEAT MAPS################################# */\r\n};\r\n\n\n\n// WEBPACK FOOTER //\n// src/gisplayv2.js"],"mappings":";;AAGA;AACA;AAAA;AACA;AALA;;;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAPA;AACA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AALA;AACA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AANA;AACA;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAnKA","sourceRoot":""}");
/***/ })
/******/ ]);