From 86fe2f4fca214d8c0f79c6d63bc2979a36439251 Mon Sep 17 00:00:00 2001 From: Anjal Date: Fri, 14 Jun 2024 13:11:13 +0545 Subject: [PATCH 1/2] stringify everything before .toLowerCase --- dist/maptable.css | 2 +- dist/maptable.js | 153 +++++++++++++++++++++++++++++++++------- dist/maptable.js.map | 2 +- dist/maptable.min.js | 8 +-- docs/maptable.js | 3 +- docs/maptable.min.js | 8 +-- src/components/Table.js | 3 +- src/maptable.css | 2 +- 8 files changed, 143 insertions(+), 38 deletions(-) diff --git a/dist/maptable.css b/dist/maptable.css index 83d6821..5016bf8 100755 --- a/dist/maptable.css +++ b/dist/maptable.css @@ -1 +1 @@ -.form-control-inline{min-width:0;width:auto;display:inline}.panel{margin-top:15px}.mt-map-container{width:100%;height:0;position:relative;padding-bottom:52%}.mt-map-container #mt-map{width:100%;height:100%;display:block;position:absolute}.mt-map-country:hover{opacity:.9}.mt-map-tooltip{color:#222;background-color:hsla(0,0%,100%,.9);min-width:200px;max-width:300px;position:absolute}.mt-map-tooltip .badge{margin:5px 10px}.mt-map-marker{opacity:.9}.mt-map-marker:hover{opacity:1}.mt-table-sortable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.mt-table-sortable.sort_asc:after{content:"▲";font-size:7px;padding-left:5px}.mt-table-sortable.sort_desc:after{content:"▼";font-size:7px;padding-left:5px}.mt-table-sortable{cursor:pointer}#mt-filters-new{margin:10px}.mt-filter-row{margin:10px;padding-bottom:10px;border-bottom:1px solid #ddd;color:#aaa}.mt-filter-row span{font-size:14px;font-weight:500;color:#333;letter-spacing:1px;line-height:34px;padding-left:4px;padding-right:4px}#mt-map:hover #mt-map-export{opacity:1;transition:opacity .5s linear}#mt-map-export{position:absolute;top:10px;right:10px;opacity:0;transition:opacity .5s linear}.mt-loading{position:absolute;top:50%;color:#999;width:100%;text-align:center;font-size:24px;margin-top:-18px;display:none}#mt-map path{will-change:fill}.mt-blur{filter:blur(18px);transform:translateZ(0)}.mt-sun-gradient{background-image:radial-gradient(circle,rgba(255,192,0,.5) 0,rgba(255,192,0,.15) 45%,rgba(255,192,0,0) 100%)}.mt-header-fixed{position:sticky} \ No newline at end of file +.form-control-inline{min-width:0;width:auto;display:inline}.panel{margin-top:15px}.mt-map-container{width:100%;height:0;position:relative;padding-bottom:52%}.mt-map-container #mt-map{width:100%;height:100%;display:block;position:absolute}.mt-map-country:hover{opacity:.9}.mt-map-tooltip{color:#222;background-color:hsla(0,0%,100%,.9);min-width:200px;max-width:300px;position:absolute}.mt-map-tooltip .badge{margin:5px 10px}.mt-map-marker{opacity:.9}.mt-map-marker:hover{opacity:1}.mt-table-sortable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.mt-table-sortable.sort_asc:after{content:"▲";font-size:7px;padding-left:5px}.mt-table-sortable.sort_desc:after{content:"▼";font-size:7px;padding-left:5px}.mt-table-sortable{cursor:pointer}#mt-filters-new{margin:10px}.mt-filter-row{margin:10px;padding-bottom:10px;border-bottom:1px solid #ddd;color:#aaa}.mt-filter-row span{font-size:14px;font-weight:500;color:#333;letter-spacing:1px;line-height:34px;padding-left:4px;padding-right:4px}#mt-map:hover #mt-map-export{opacity:1;transition:opacity .5s linear}#mt-map-export{position:absolute;top:10px;right:10px;opacity:0;transition:opacity .5s linear}.mt-loading{position:absolute;top:50%;color:#999;width:100%;text-align:center;font-size:24px;margin-top:-18px;display:none}#mt-map path{will-change:fill}.mt-blur{filter:blur(18px);transform:translateZ(0)}.mt-sun-gradient{background-image:radial-gradient(circle,rgba(255,192,0,.5) 0,rgba(255,192,0,.15) 45%,rgba(255,192,0,0) 100%)}.mt-header-fixed{position:sticky}.bold{border-bottom:1.5px solid #999898}.table-sort-sn{position:absolute;left:0;width:38px;height:38px;display:flex;align-items:center;justify-content:flex-end;padding-right:7px;margin-left:-38px;opacity:.2;color:#000}.display-none{display:none} \ No newline at end of file diff --git a/dist/maptable.js b/dist/maptable.js index 5412939..ed1c2fb 100644 --- a/dist/maptable.js +++ b/dist/maptable.js @@ -111,7 +111,7 @@ this.d3.maptable = (function () { function toNumber(str) { if (!str || str === '') return null; - var resStr = str.toString().replace(/[^0-9.]+|\s+/gmi, ''); + var resStr = str.toString().replace(/[^0-9.]+|\s+/gim, ''); if (resStr !== '') return Number(resStr); return null; } @@ -152,6 +152,25 @@ this.d3.maptable = (function () { return str === null || str === '' || str === undefined; }; + var customSortOrders = { + days: ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday'], + months: ['january', 'february', 'march', 'april', 'may', 'june', 'july', 'august', 'september', 'october', 'november', 'december'] + }; + + var customSortAsc = function customSortAsc(type, d1, d2, sortOrder) { + var elem1 = d1.toLowerCase(); + var elem2 = d2.toLowerCase(); + var customSortOrder = sortOrder.length === 0 ? customSortOrders[type] || [] : sortOrder; + return customSortOrder.indexOf(elem1) - customSortOrder.indexOf(elem2); + }; + + var customSortDesc = function customSortDesc(type, d1, d2, sortOrder) { + var elem1 = d1.toLowerCase(); + var elem2 = d2.toLowerCase(); + var customSortOrder = sortOrder.length === 0 ? customSortOrders[type] || [] : sortOrder; + return customSortOrder.indexOf(elem2) - customSortOrder.indexOf(elem1); + }; + var utils = { rangeToBool: rangeToBool, appendOptions: appendOptions, @@ -162,7 +181,9 @@ this.d3.maptable = (function () { quantile: quantile, uniqueValues: uniqueValues, formatDate: formatDate, - isBlank: isBlank + isBlank: isBlank, + customSortAsc: customSortAsc, + customSortDesc: customSortDesc }; var defaultOptions = { @@ -2328,18 +2349,21 @@ this.d3.maptable = (function () { var filterOutput = [columnDetails.filterMethod]; if (columnDetails.filterMethod === 'compare') { var filterRangeSelect = element.querySelector('.mt-filter-range'); - filterOutput[1] = filterRangeSelect.value; - if (filterRangeSelect.value !== 'any') { - if (filterRangeSelect.value === 'BETWEEN') { - var filterValueMin = element.querySelector('.mt-filter-value-min').value; - var filterValueMax = element.querySelector('.mt-filter-value-max').value; - if (filterValueMin !== '' && filterValueMax === '') { - filterOutput[2] = filterValueMin; - filterOutput[3] = filterValueMax; + if (filterRangeSelect) { + filterOutput[1] = filterRangeSelect.value; + + if (filterRangeSelect.value !== 'any') { + if (filterRangeSelect.value === 'BETWEEN') { + var filterValueMin = element.querySelector('.mt-filter-value-min').value; + var filterValueMax = element.querySelector('.mt-filter-value-max').value; + if (filterValueMin !== '' && filterValueMax === '') { + filterOutput[2] = filterValueMin; + filterOutput[3] = filterValueMax; + } + } else { + var filterValue = element.querySelector('.mt-filter-value-min').value; + filterOutput[2] = filterValue; } - } else { - var filterValue = element.querySelector('.mt-filter-value-min').value; - filterOutput[2] = filterValue; } } } else if (columnDetails.filterMethod === 'field' || columnDetails.filterMethod === 'dropdown') { @@ -2713,10 +2737,17 @@ this.d3.maptable = (function () { this.maptable = maptable; this.options = options; + this.sorting = []; // initialize sort array + if (this.options.defaultSorting) { - if (Array.isArray(this.options.defaultSorting) && this.options.defaultSorting.length === 2) { + if (Array.isArray(this.options.defaultSorting) && (this.options.defaultSorting.length === 2 || this.options.defaultSorting.length === 3)) { + // handle case for second-order and third-order sort options this.sorting = this.options.defaultSorting; + } else if (Array.isArray(this.options.defaultSorting) && this.options.defaultSorting.length >= 4) { + // handle case for more than three default sort options + this.sorting = this.options.defaultSorting.slice(0, 3); } else { + // handle case for single default sort option this.sorting = [this.options.defaultSorting]; } this.sorting.forEach(function (s) { @@ -2846,7 +2877,6 @@ this.d3.maptable = (function () { // Apply Sort this.applySort(); - var tableData = this.maptable.data; if (this.options.distinctBy) { tableData = d3.nest().key(function (d) { @@ -2864,11 +2894,13 @@ this.d3.maptable = (function () { // Update var uniqueCollapsedRows = []; - this.body.selectAll('tr').data(tableData).attr('class', function (row) { + this.sortIndex = 0; + this.body.selectAll('tr').data(tableData).attr('class', function (row, index) { + var enableSeparator = _this2.isEndOfPrimarySort(tableData, index); if (_this2.options.rowClassName) { - return 'line ' + _this2.options.rowClassName(row); + return 'line ' + _this2.options.rowClassName(row) + ' ' + (enableSeparator ? 'bold' : ''); } - return 'line'; + return 'line ' + (enableSeparator ? 'bold' : ''); }).html(function (row) { var tds = ''; _this2.activeColumns.forEach(function (columnKey) { @@ -2892,6 +2924,14 @@ this.d3.maptable = (function () { tds += ''; }); return tds; + }).append('span').attr('class', 'table-sort-sn ' + (!this.options.dataCountIndicator || this.options.dataCountIndicator && !this.options.dataCountIndicator.enabled || this.sorting && this.sorting.length <= 1 ? 'display-none' : '') + ' ').html(function (row, index) { + var isSortGroupEnd = _this2.isEndOfPrimarySort(tableData, index - 1); + if (isSortGroupEnd) { + _this2.sortIndex = 1; + } else { + _this2.sortIndex += 1; + } + return '' + _this2.sortIndex; }); // On render @@ -2908,13 +2948,14 @@ this.d3.maptable = (function () { for (var i = 0; i < sortableColums.length; i += 1) { sortableColums[i].setAttribute('class', 'mt-table-sortable'); } - this.sorting.forEach(function (column) { - _this3.container.querySelector('#column_header_' + utils.sanitizeKey(column.key)).setAttribute('class', 'mt-table-sortable sort_' + column.mode); + this.sorting.forEach(function (column, index) { + _this3.container.querySelector('#column_header_' + utils.sanitizeKey(column.key)).setAttribute('class', 'mt-table-sortable sort_' + column.mode + ' sort_order_' + (index + 1)); }); this.maptable.data = this.maptable.data.sort(function (a, b) { var compareBool = false; _this3.sorting.forEach(function (column) { var d3SortMode = column.mode === 'asc' ? d3.ascending : d3.descending; + var d3CustomSortMode = column.mode === 'asc' ? utils.customSortAsc : utils.customSortDesc; var columnDetails = _this3.maptable.columnDetails[column.key]; var el1 = a[column.key]; var el2 = b[column.key]; @@ -2933,7 +2974,16 @@ this.d3.maptable = (function () { el1 = el1.toLowerCase(); el2 = el2.toLowerCase(); } - compareBool = compareBool || d3SortMode(el1, el2); + + if (columnDetails.filterInputType === 'months' || columnDetails.filterInputType === 'days') { + var currentCustomSortValues = _this3.options.customSortOrder && _this3.options.customSortOrder.filter(function (cs) { + return cs.key === column.key; + }); + var currentCustomSortOrder = currentCustomSortValues && currentCustomSortValues.length !== 0 ? currentCustomSortValues[0].order || [] : []; + compareBool = compareBool || d3CustomSortMode(columnDetails.filterInputType, el1, el2, currentCustomSortOrder); + } else { + compareBool = compareBool || d3SortMode(el1, el2); + } }); return compareBool; }); @@ -2954,7 +3004,12 @@ this.d3.maptable = (function () { if (sortIndex === -1) { sortValue.mode = 'desc'; if (d3.event && d3.event.shiftKey) { - this.sorting[1] = sortValue; + // FIFO - pop last sort element from array after third-order-sorting + if (this.sorting.length === 3) { + this.sorting.pop(); + } + // FIFO - push new sort element to array + this.sorting.unshift(sortValue); } else { this.sorting = [sortValue]; } @@ -2967,12 +3022,58 @@ this.d3.maptable = (function () { } if (!d3.event.shiftKey) { this.sorting = [this.sorting[sortIndex]]; + } else { + // FIFO - set latest clicked column key as first-order-sorting + this.reOrderSorting(sortIndex, 0); } } - this.saveState(); this.render(); } + + /** + * Util for changing position of sorting array elements + * @param from: from position index + * @param to: to position index + */ + + }, { + key: 'reOrderSorting', + value: function reOrderSorting(from, to) { + if (to === from) return; + + var target = this.sorting[from]; + var increment = to < from ? -1 : 1; + + for (var k = from; k != to; k += increment) { + this.sorting[k] = this.sorting[k + increment]; + } + this.sorting[to] = target; + } + + /** + * Util for finding end of primary sort data + * @param data: table data + * @param index: current row index + */ + + }, { + key: 'isEndOfPrimarySort', + value: function isEndOfPrimarySort(data, index) { + // check if data group separator is enabled from passed options + if (!this.options.dataGroupSeparator || this.options.dataGroupSeparator && !this.options.dataGroupSeparator.enabled) return false; + // check if multi-order-sort + if (this.sorting && this.sorting.length <= 1) return false; + + var primarySort = this.sorting[0].key || ''; + if (data[index] && data[index + 1]) { + if (data[index][primarySort] && data[index + 1][primarySort]) { + // stringify everything before .toLowerCase() + return ('' + data[index][primarySort]).toLowerCase() !== ('' + data[index + 1][primarySort]).toLowerCase(); + } + } + return false; + } }]); return Table; }(); @@ -3253,6 +3354,8 @@ this.d3.maptable = (function () { }, { key: 'setColumnDetails', value: function setColumnDetails() { + var _this5 = this; + var that = this; if (that.rawData.length === 0) { return; @@ -3265,9 +3368,10 @@ this.d3.maptable = (function () { defaultColumns[k] = { title: utils.keyToTile(k), filterMethod: isNumber ? 'compare' : 'field', - filterInputType: isNumber ? 'number' : 'text', + filterInputType: isNumber ? 'number' : _this5.options.columns[k] && _this5.options.columns[k].filterInputType ? _this5.options.columns[k].filterInputType : 'text', sorting: true }; + if (isNumber) { defaultColumns[k].dataParse = function (val) { return parseFloat(val); @@ -3275,7 +3379,6 @@ this.d3.maptable = (function () { } }); that.columnDetails = utils.extendRecursive(defaultColumns, this.options.columns); - // add isVirtual to columns details Object.keys(that.columnDetails).forEach(function (k) { that.columnDetails[k].isVirtual = typeof that.columnDetails[k].virtual === 'function'; diff --git a/dist/maptable.js.map b/dist/maptable.js.map index 0b9848f..40ea2b6 100644 --- a/dist/maptable.js.map +++ b/dist/maptable.js.map @@ -1 +1 @@ -{"version":3,"file":"maptable.js","sources":["../src/utils.js","../src/defaultOptions.js","../src/components/Legend.js","../src/components/Watermark.js","../src/components/StackBlur.js","../src/components/solarPosition.js","../src/components/GeoMap.js","../src/components/Filters.js","../src/components/Table.js","../src/maptable.js","../src/index.js"],"sourcesContent":["function appendOptions(select, options, defaultValue) {\n options.forEach((f) => {\n // Filter select\n const option = document.createElement('option');\n option.setAttribute('value', f.value);\n option.innerText = f.text;\n select.appendChild(option);\n });\n select.value = defaultValue;\n}\n\nfunction rangeToBool(el1, range, el2) {\n if (range === '=') {\n return parseInt(el1, 10) === parseInt(el2, 10);\n }\n if (range === '≠') {\n return parseInt(el1, 10) !== parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n if (range === '>') {\n return parseInt(el1, 10) > parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n if (range === '<') {\n return parseInt(el1, 10) < parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n if (range === '≥') {\n return parseInt(el1, 10) >= parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n if (range === '≤') {\n return parseInt(el1, 10) <= parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n return true;\n}\n\n/* eslint no-loop-func: 0 */\nfunction extendRecursive() {\n const dst = {};\n let src;\n const args = [].splice.call(arguments, 0);\n const toString = ({}).toString;\n\n while (args.length > 0) {\n src = args.splice(0, 1)[0];\n if (toString.call(src) === '[object Object]') {\n Object.keys(src).forEach((p) => {\n if (toString.call(src[p]) === '[object Object]') {\n dst[p] = extendRecursive(dst[p] || {}, src[p]);\n } else {\n dst[p] = src[p];\n }\n });\n }\n }\n return dst;\n}\n\nfunction keyToTile(k) {\n const upperK = k.charAt(0).toUpperCase() + k.slice(1);\n return upperK.replace(/_/g, ' ');\n}\n\nfunction sanitizeKey(k) {\n return k.toLowerCase()\n .replace(/ /g, '_')\n .replace(/\"/g, '')\n .replace(/'/g, '');\n}\n\nfunction toNumber(str) {\n if (!str || str === '') return null;\n const resStr = str.toString().replace(/[^0-9.]+|\\s+/gmi, '');\n if (resStr !== '') return Number(resStr);\n return null;\n}\n\nfunction quantile(array, percentile) {\n array.sort((a, b) => a - b);\n const index = (percentile / 100.0) * (array.length - 1);\n let result;\n if (Math.floor(index) === index) {\n result = array[index];\n } else {\n const i = Math.floor(index);\n const fraction = index - i;\n result = array[i] + (array[i + 1] - array[i]) * fraction;\n }\n return result;\n}\n\nfunction uniqueValues(arr) {\n if (!arr) return arr;\n const a = [];\n for (let i = 0, l = arr.length; i < l; i += 1) {\n if (a.indexOf(arr[i]) === -1 && arr[i] !== '') {\n a.push(arr[i]);\n }\n }\n return a;\n}\n\nconst formatDate = (d, zone) => {\n const newDate = new Date(d.getTime() + zone * 3600 * 1000);\n return newDate.toISOString().split('T')[1].substr(0, 5);\n};\n\nconst isBlank = (str) => (str === null || str === '' || str === undefined);\n\nexport default {\n rangeToBool,\n appendOptions,\n extendRecursive,\n sanitizeKey,\n toNumber,\n keyToTile,\n quantile,\n uniqueValues,\n formatDate,\n isBlank,\n};\n","export default {\n map: {\n longitudeKey: 'longitude',\n latitudeKey: 'latitude',\n countryIdentifierKey: 'country_code',\n countryIdentifierType: 'iso_a2',\n zoom: true,\n saveState: true,\n exportSvg: null,\n exportSvgClient: false,\n ratioFromWidth: 0.5,\n scaleHeight: 1.0,\n scaleZoom: [1, 10],\n fitContentMargin: 10,\n autoFitContent: false,\n tooltipClassName: 'popover bottom',\n countries: {\n legend: false,\n attr: {\n fill: '#FCFCFC',\n stroke: '#CCC',\n 'stroke-width': 0.5,\n },\n tooltipClassName: 'mt-map-tooltip popover bottom',\n },\n heatmap: {\n mask: true,\n weightByAttribute: null,\n weightByAttributeScale: 'linear',\n circles: {\n min: 1,\n max: 90,\n step: 4,\n color: '#FF0000',\n colorStrength: 1,\n blur: 4.0,\n },\n borders: {\n stroke: 1,\n opacity: 0.1,\n color: '#000',\n },\n },\n markers: {\n attr: {\n r: 4,\n fill: 'blue',\n stroke: '#CCC',\n 'stroke-width': 0.5,\n },\n tooltipClassName: 'mt-map-tooltip popover bottom',\n },\n title: {\n fontSize: 12,\n fontFamily: 'Helevetica, Arial, Sans-Serif',\n },\n },\n filters: {\n saveState: true,\n },\n table: {\n className: 'table table-striped table-bordered',\n collapseRowsBy: [],\n },\n};\n","export default class Legend {\n constructor(map) {\n this.legendWidth = 220;\n this.map = map;\n // Create Legend\n this.node = this.map.svg\n .append('g')\n .attr('id', 'mt-map-legend')\n .attr(\n 'transform',\n `translate(${(this.map.getWidth() - 350)}, ${(this.map.getHeight() - 60)})`,\n );\n\n this.buildIndice();\n }\n\n buildScale(domain) {\n const legendGradient = this.node\n .append('defs')\n .append('linearGradient')\n .attr('id', 'mt-map-legend-gradient')\n .attr('x1', '0%')\n .attr('y1', '0%')\n .attr('x2', '100%')\n .attr('y2', '0%');\n\n if (this.map.options.countries.attr.fill.minNegative\n && this.map.options.countries.attr.fill.maxNegative) {\n // todo - maybe watch for domain[0] < 0 && domain[1] < 0? fall back to normal min & max?\n const midPercentNegative = Math.round(((0 - domain[0]) / (domain[1] - domain[0])) * 100);\n const midPercentPositive = midPercentNegative + 1;\n\n legendGradient.append('stop')\n .attr('offset', '0%')\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.maxNegative};stop-opacity:1`);\n\n legendGradient.append('stop')\n .attr('offset', `${midPercentNegative}%`)\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.minNegative};stop-opacity:1`);\n legendGradient.append('stop')\n .attr('offset', `${midPercentPositive}%`)\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.min};stop-opacity:1`);\n } else {\n legendGradient.append('stop')\n .attr('offset', '0%')\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.min};stop-opacity:1`);\n }\n\n legendGradient.append('stop')\n .attr('offset', '100%')\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.max};stop-opacity:1`);\n\n this.node.append('rect')\n .attr('x', 30)\n .attr('y', 0)\n .attr('width', this.legendWidth)\n .attr('height', 15)\n .attr('fill', 'url(#mt-map-legend-gradient)');\n }\n\n buildIndice() {\n const indice = this.node.append('g')\n .attr('id', 'mt-map-legend-indice')\n .attr('style', 'display:none')\n .attr('transform', 'translate(36,15)');\n\n indice.append('polygon')\n .attr('points', '4.5 0 9 5 0 5')\n .attr('fill', '#222222');\n\n indice.append('text')\n .attr('x', 4)\n .attr('y', 13)\n .attr('width', 10)\n .attr('height', 10)\n .attr('text-anchor', 'middle')\n .attr('font-family', 'Arial')\n .attr('font-size', '9')\n .attr('stroke', '#FFFFF')\n .attr('stroke-width', '1')\n .attr('fill', '#222222')\n .text('0');\n\n this.node.append('text')\n .attr('id', 'mt-map-legend-min')\n .attr('x', 25)\n .attr('y', 13)\n .attr('width', 35)\n .attr('height', 15)\n .attr('text-anchor', 'end')\n .attr('font-family', 'Arial')\n .attr('font-size', '14')\n .attr('stroke', '#FFFFF')\n .attr('stroke-width', '3')\n .attr('fill', '#222222')\n .text('0');\n\n this.node.append('text')\n .attr('id', 'mt-map-legend-max')\n .attr('y', 13)\n .attr('x', 255)\n .attr('width', 50)\n .attr('height', 15)\n .attr('text-anchor', 'start')\n .attr('font-family', 'Arial')\n .attr('font-size', '14')\n .attr('stroke', '#FFFFF')\n .attr('stroke-width', '3')\n .attr('fill', '#222222')\n .text('1');\n }\n\n updateExtents(domain) {\n this.node.select('#mt-map-legend').style('opacity', (domain[0] === domain[1]) ? 0 : 1);\n if (this.node.selectAll('mt-map-legend-min').length) {\n this.node.select('#mt-map-legend-min').text(Math.round(domain[0]).toLocaleString());\n this.node.select('#mt-map-legend-max').text(Math.round(domain[1]).toLocaleString());\n\n // pass in the min and max (domain) to the legend\n this.buildScale(domain);\n }\n }\n\n indiceChange(val) {\n if (Number.isNaN(val)) {\n this.node.select('#mt-map-legend-indice')\n .attr('style', 'display:none');\n } else {\n const maxValue = parseInt(this.node.select('#mt-map-legend-max').text(), 10);\n const minValue = parseInt(this.node.select('#mt-map-legend-min').text(), 10);\n const positionDelta = Math.round((0 - (minValue - val) / (maxValue - minValue))\n * this.legendWidth);\n this.node.select('#mt-map-legend-indice text').text(Math.round(val).toLocaleString());\n this.node.select('#mt-map-legend-indice')\n .attr('style', 'display:block')\n .attr('transform', `translate(${(36 + positionDelta)},15)`);\n }\n }\n}\n","export default class Legend {\n constructor(map, options) {\n this.map = map;\n this.src = options.src;\n this.position = options.position;\n this.width = parseInt(options.width, 10);\n this.height = parseInt(options.height, 10);\n this.padding = options.padding || 10;\n this.style = options.style;\n\n if (!options.src) {\n console.warn('Watermak src not found');\n return;\n }\n if (Number.isNaN(this.width)) {\n console.warn('Watermak width not found');\n return;\n }\n if (Number.isNaN(this.height)) {\n console.warn('Watermak height not found');\n return;\n }\n\n if (window.btoa) {\n this.buildWatermark();\n } else {\n console.warn('Watermark not rendered: btoa error');\n }\n }\n\n buildWatermark() {\n d3.xhr(this.src, (res) => {\n let mapWatermarkDelta = 0;\n if (this.map.options.title) mapWatermarkDelta = 30;\n let mime;\n let x;\n let y;\n if (this.src.indexOf('.svg') !== -1) {\n mime = 'image/svg+xml';\n } else if (this.src.indexOf('.jpg') !== -1 || this.src.indexOf('.jpeg') !== -1) {\n mime = 'image/jpeg';\n } else if (this.src.indexOf('.png') !== -1) {\n mime = 'image/png';\n } else {\n console.warn('invalid watermark mime type');\n return;\n }\n const dataUri = `data:${mime};base64,${window.btoa(res.responseText)}`;\n\n if (this.position) {\n const pos = this.position.split(' ');\n if (pos[0] === 'top') {\n y = this.padding;\n } else if (pos[0] === 'middle') {\n y = (this.map.getHeight() - this.height) / 2;\n } else if (pos[0] === 'bottom') {\n y = this.map.getHeight() - this.height - this.padding - mapWatermarkDelta;\n } else {\n console.warn('position should be (top|middle|bottom) (left|middle|right)');\n }\n\n if (pos[1] === 'left') {\n x = this.padding;\n } else if (pos[1] === 'middle') {\n x = (this.map.getWidth() - this.width) / 2;\n } else if (pos[1] === 'right') {\n x = this.map.getWidth() - this.width - this.padding;\n } else {\n console.warn('position should be (top|middle|bottom) (left|middle|right)');\n }\n }\n\n this.node = this.map.svg\n .append('image')\n .attr('xlink:href', dataUri)\n .attr('width', this.width)\n .attr('height', this.height);\n\n if (x && y) {\n this.node.attr('x', x).attr('y', y);\n }\n\n if (this.style) {\n this.node.attr('style', this.style);\n }\n });\n }\n}\n","/* eslint-disable */\n\n/*\n StackBlur - a fast almost Gaussian Blur For Canvas\n Version: 0.5\n Author: Mario Klingemann\n Contact: mario@quasimondo.com\n Website: http://www.quasimondo.com/StackBlurForCanvas\n Twitter: @quasimondo\n In case you find this class useful - especially in commercial projects -\n I am not totally unhappy for a small donation to my PayPal account\n mario@quasimondo.de\n Or support me on flattr:\n https://flattr.com/thing/72791/StackBlur-a-fast-almost-Gaussian-Blur-Effect-for-CanvasJavascript\n Copyright (c) 2010 Mario Klingemann\n Permission is hereby granted, free of charge, to any person\n obtaining a copy of this software and associated documentation\n files (the \"Software\"), to deal in the Software without\n restriction, including without limitation the rights to use,\n copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the\n Software is furnished to do so, subject to the following\n conditions:\n The above copyright notice and this permission notice shall be\n included in all copies or substantial portions of the Software.\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\n EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES\n OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\n NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\n HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,\n WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR\n OTHER DEALINGS IN THE SOFTWARE.\n */\n\n\nvar mul_table = [\n 512,512,456,512,328,456,335,512,405,328,271,456,388,335,292,512,\n 454,405,364,328,298,271,496,456,420,388,360,335,312,292,273,512,\n 482,454,428,405,383,364,345,328,312,298,284,271,259,496,475,456,\n 437,420,404,388,374,360,347,335,323,312,302,292,282,273,265,512,\n 497,482,468,454,441,428,417,405,394,383,373,364,354,345,337,328,\n 320,312,305,298,291,284,278,271,265,259,507,496,485,475,465,456,\n 446,437,428,420,412,404,396,388,381,374,367,360,354,347,341,335,\n 329,323,318,312,307,302,297,292,287,282,278,273,269,265,261,512,\n 505,497,489,482,475,468,461,454,447,441,435,428,422,417,411,405,\n 399,394,389,383,378,373,368,364,359,354,350,345,341,337,332,328,\n 324,320,316,312,309,305,301,298,294,291,287,284,281,278,274,271,\n 268,265,262,259,257,507,501,496,491,485,480,475,470,465,460,456,\n 451,446,442,437,433,428,424,420,416,412,408,404,400,396,392,388,\n 385,381,377,374,370,367,363,360,357,354,350,347,344,341,338,335,\n 332,329,326,323,320,318,315,312,310,307,304,302,299,297,294,292,\n 289,287,285,282,280,278,275,273,271,269,267,265,263,261,259];\n\n\nvar shg_table = [\n 9, 11, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 16, 17,\n 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18, 19,\n 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 20, 20, 20,\n 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 21,\n 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,\n 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 22, 22, 22, 22, 22, 22,\n 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,\n 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 23,\n 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,\n 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,\n 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,\n 23, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,\n 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,\n 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,\n 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,\n 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24 ];\n\n\nfunction processImage(img, canvas, radius, blurAlphaChannel)\n{\n if (typeof(img) == 'string') {\n var img = document.getElementById(img);\n }\n else if (typeof HTMLImageElement !== 'undefined' && !img instanceof HTMLImageElement) {\n return;\n }\n var w = img.naturalWidth;\n var h = img.naturalHeight;\n\n if (typeof(canvas) == 'string') {\n var canvas = document.getElementById(canvas);\n }\n else if (typeof HTMLCanvasElement !== 'undefined' && !canvas instanceof HTMLCanvasElement) {\n return;\n }\n\n canvas.style.width = w + 'px';\n canvas.style.height = h + 'px';\n canvas.width = w;\n canvas.height = h;\n\n var context = canvas.getContext('2d');\n context.clearRect(0, 0, w, h);\n context.drawImage(img, 0, 0);\n\n if (Number.isNaN(radius) || radius < 1) return;\n\n if (blurAlphaChannel)\n processCanvasRGBA(canvas, 0, 0, w, h, radius);\n else\n processCanvasRGB(canvas, 0, 0, w, h, radius);\n}\n\nfunction getImageDataFromCanvas(canvas, top_x, top_y, width, height)\n{\n if (typeof(canvas) == 'string')\n var canvas = document.getElementById(canvas);\n else if (typeof HTMLCanvasElement !== 'undefined' && !canvas instanceof HTMLCanvasElement)\n return;\n\n var context = canvas.getContext('2d');\n var imageData;\n\n try {\n try {\n imageData = context.getImageData(top_x, top_y, width, height);\n } catch(e) {\n throw new Error(\"unable to access local image data: \" + e);\n return;\n }\n } catch(e) {\n throw new Error(\"unable to access image data: \" + e);\n }\n\n return imageData;\n}\n\nfunction processCanvasRGBA(canvas, top_x, top_y, width, height, radius)\n{\n if (Number.isNaN(radius) || radius < 1) return;\n radius |= 0;\n\n var imageData = getImageDataFromCanvas(canvas, top_x, top_y, width, height);\n\n imageData = processImageDataRGBA(imageData, top_x, top_y, width, height, radius);\n\n canvas.getContext('2d').putImageData(imageData, top_x, top_y);\n}\n\nfunction processImageDataRGBA(imageData, top_x, top_y, width, height, radius)\n{\n var pixels = imageData.data;\n\n var x, y, i, p, yp, yi, yw, r_sum, g_sum, b_sum, a_sum,\n r_out_sum, g_out_sum, b_out_sum, a_out_sum,\n r_in_sum, g_in_sum, b_in_sum, a_in_sum,\n pr, pg, pb, pa, rbs;\n\n var div = radius + radius + 1;\n var w4 = width << 2;\n var widthMinus1 = width - 1;\n var heightMinus1 = height - 1;\n var radiusPlus1 = radius + 1;\n var sumFactor = radiusPlus1 * (radiusPlus1 + 1) / 2;\n\n var stackStart = new BlurStack();\n var stack = stackStart;\n for (i = 1; i < div; i++)\n {\n stack = stack.next = new BlurStack();\n if (i == radiusPlus1) var stackEnd = stack;\n }\n stack.next = stackStart;\n var stackIn = null;\n var stackOut = null;\n\n yw = yi = 0;\n\n var mul_sum = mul_table[radius];\n var shg_sum = shg_table[radius];\n\n for (y = 0; y < height; y++)\n {\n r_in_sum = g_in_sum = b_in_sum = a_in_sum = r_sum = g_sum = b_sum = a_sum = 0;\n\n r_out_sum = radiusPlus1 * (pr = pixels[yi]);\n g_out_sum = radiusPlus1 * (pg = pixels[yi+1]);\n b_out_sum = radiusPlus1 * (pb = pixels[yi+2]);\n a_out_sum = radiusPlus1 * (pa = pixels[yi+3]);\n\n r_sum += sumFactor * pr;\n g_sum += sumFactor * pg;\n b_sum += sumFactor * pb;\n a_sum += sumFactor * pa;\n\n stack = stackStart;\n\n for (i = 0; i < radiusPlus1; i++)\n {\n stack.r = pr;\n stack.g = pg;\n stack.b = pb;\n stack.a = pa;\n stack = stack.next;\n }\n\n for (i = 1; i < radiusPlus1; i++)\n {\n p = yi + ((widthMinus1 < i ? widthMinus1 : i) << 2);\n r_sum += (stack.r = (pr = pixels[p])) * (rbs = radiusPlus1 - i);\n g_sum += (stack.g = (pg = pixels[p+1])) * rbs;\n b_sum += (stack.b = (pb = pixels[p+2])) * rbs;\n a_sum += (stack.a = (pa = pixels[p+3])) * rbs;\n\n r_in_sum += pr;\n g_in_sum += pg;\n b_in_sum += pb;\n a_in_sum += pa;\n\n stack = stack.next;\n }\n\n\n stackIn = stackStart;\n stackOut = stackEnd;\n for (x = 0; x < width; x++)\n {\n pixels[yi+3] = pa = (a_sum * mul_sum) >> shg_sum;\n if (pa != 0)\n {\n pa = 255 / pa;\n pixels[yi] = ((r_sum * mul_sum) >> shg_sum) * pa;\n pixels[yi+1] = ((g_sum * mul_sum) >> shg_sum) * pa;\n pixels[yi+2] = ((b_sum * mul_sum) >> shg_sum) * pa;\n } else {\n pixels[yi] = pixels[yi+1] = pixels[yi+2] = 0;\n }\n\n r_sum -= r_out_sum;\n g_sum -= g_out_sum;\n b_sum -= b_out_sum;\n a_sum -= a_out_sum;\n\n r_out_sum -= stackIn.r;\n g_out_sum -= stackIn.g;\n b_out_sum -= stackIn.b;\n a_out_sum -= stackIn.a;\n\n p = (yw + ((p = x + radius + 1) < widthMinus1 ? p : widthMinus1)) << 2;\n\n r_in_sum += (stackIn.r = pixels[p]);\n g_in_sum += (stackIn.g = pixels[p+1]);\n b_in_sum += (stackIn.b = pixels[p+2]);\n a_in_sum += (stackIn.a = pixels[p+3]);\n\n r_sum += r_in_sum;\n g_sum += g_in_sum;\n b_sum += b_in_sum;\n a_sum += a_in_sum;\n\n stackIn = stackIn.next;\n\n r_out_sum += (pr = stackOut.r);\n g_out_sum += (pg = stackOut.g);\n b_out_sum += (pb = stackOut.b);\n a_out_sum += (pa = stackOut.a);\n\n r_in_sum -= pr;\n g_in_sum -= pg;\n b_in_sum -= pb;\n a_in_sum -= pa;\n\n stackOut = stackOut.next;\n\n yi += 4;\n }\n yw += width;\n }\n\n\n for (x = 0; x < width; x++)\n {\n g_in_sum = b_in_sum = a_in_sum = r_in_sum = g_sum = b_sum = a_sum = r_sum = 0;\n\n yi = x << 2;\n r_out_sum = radiusPlus1 * (pr = pixels[yi]);\n g_out_sum = radiusPlus1 * (pg = pixels[yi+1]);\n b_out_sum = radiusPlus1 * (pb = pixels[yi+2]);\n a_out_sum = radiusPlus1 * (pa = pixels[yi+3]);\n\n r_sum += sumFactor * pr;\n g_sum += sumFactor * pg;\n b_sum += sumFactor * pb;\n a_sum += sumFactor * pa;\n\n stack = stackStart;\n\n for (i = 0; i < radiusPlus1; i++)\n {\n stack.r = pr;\n stack.g = pg;\n stack.b = pb;\n stack.a = pa;\n stack = stack.next;\n }\n\n yp = width;\n\n for (i = 1; i <= radius; i++)\n {\n yi = (yp + x) << 2;\n\n r_sum += (stack.r = (pr = pixels[yi])) * (rbs = radiusPlus1 - i);\n g_sum += (stack.g = (pg = pixels[yi+1])) * rbs;\n b_sum += (stack.b = (pb = pixels[yi+2])) * rbs;\n a_sum += (stack.a = (pa = pixels[yi+3])) * rbs;\n\n r_in_sum += pr;\n g_in_sum += pg;\n b_in_sum += pb;\n a_in_sum += pa;\n\n stack = stack.next;\n\n if(i < heightMinus1)\n {\n yp += width;\n }\n }\n\n yi = x;\n stackIn = stackStart;\n stackOut = stackEnd;\n for (y = 0; y < height; y++)\n {\n p = yi << 2;\n pixels[p+3] = pa = (a_sum * mul_sum) >> shg_sum;\n if (pa > 0)\n {\n pa = 255 / pa;\n pixels[p] = ((r_sum * mul_sum) >> shg_sum) * pa;\n pixels[p+1] = ((g_sum * mul_sum) >> shg_sum) * pa;\n pixels[p+2] = ((b_sum * mul_sum) >> shg_sum) * pa;\n } else {\n pixels[p] = pixels[p+1] = pixels[p+2] = 0;\n }\n\n r_sum -= r_out_sum;\n g_sum -= g_out_sum;\n b_sum -= b_out_sum;\n a_sum -= a_out_sum;\n\n r_out_sum -= stackIn.r;\n g_out_sum -= stackIn.g;\n b_out_sum -= stackIn.b;\n a_out_sum -= stackIn.a;\n\n p = (x + (((p = y + radiusPlus1) < heightMinus1 ? p : heightMinus1) * width)) << 2;\n\n r_sum += (r_in_sum += (stackIn.r = pixels[p]));\n g_sum += (g_in_sum += (stackIn.g = pixels[p+1]));\n b_sum += (b_in_sum += (stackIn.b = pixels[p+2]));\n a_sum += (a_in_sum += (stackIn.a = pixels[p+3]));\n\n stackIn = stackIn.next;\n\n r_out_sum += (pr = stackOut.r);\n g_out_sum += (pg = stackOut.g);\n b_out_sum += (pb = stackOut.b);\n a_out_sum += (pa = stackOut.a);\n\n r_in_sum -= pr;\n g_in_sum -= pg;\n b_in_sum -= pb;\n a_in_sum -= pa;\n\n stackOut = stackOut.next;\n\n yi += width;\n }\n }\n return imageData;\n}\n\nfunction processCanvasRGB(canvas, top_x, top_y, width, height, radius)\n{\n if (Number.isNaN(radius) || radius < 1) return;\n radius |= 0;\n\n var imageData = getImageDataFromCanvas(canvas, top_x, top_y, width, height);\n imageData = processImageDataRGB(imageData, top_x, top_y, width, height, radius);\n\n canvas.getContext('2d').putImageData(imageData, top_x, top_y);\n}\n\nfunction processImageDataRGB(imageData, top_x, top_y, width, height, radius)\n{\n var pixels = imageData.data;\n\n var x, y, i, p, yp, yi, yw, r_sum, g_sum, b_sum,\n r_out_sum, g_out_sum, b_out_sum,\n r_in_sum, g_in_sum, b_in_sum,\n pr, pg, pb, rbs;\n\n var div = radius + radius + 1;\n var w4 = width << 2;\n var widthMinus1 = width - 1;\n var heightMinus1 = height - 1;\n var radiusPlus1 = radius + 1;\n var sumFactor = radiusPlus1 * (radiusPlus1 + 1) / 2;\n\n var stackStart = new BlurStack();\n var stack = stackStart;\n for (i = 1; i < div; i++)\n {\n stack = stack.next = new BlurStack();\n if (i == radiusPlus1) var stackEnd = stack;\n }\n stack.next = stackStart;\n var stackIn = null;\n var stackOut = null;\n\n yw = yi = 0;\n\n var mul_sum = mul_table[radius];\n var shg_sum = shg_table[radius];\n\n for (y = 0; y < height; y++)\n {\n r_in_sum = g_in_sum = b_in_sum = r_sum = g_sum = b_sum = 0;\n\n r_out_sum = radiusPlus1 * (pr = pixels[yi]);\n g_out_sum = radiusPlus1 * (pg = pixels[yi+1]);\n b_out_sum = radiusPlus1 * (pb = pixels[yi+2]);\n\n r_sum += sumFactor * pr;\n g_sum += sumFactor * pg;\n b_sum += sumFactor * pb;\n\n stack = stackStart;\n\n for (i = 0; i < radiusPlus1; i++)\n {\n stack.r = pr;\n stack.g = pg;\n stack.b = pb;\n stack = stack.next;\n }\n\n for (i = 1; i < radiusPlus1; i++)\n {\n p = yi + ((widthMinus1 < i ? widthMinus1 : i) << 2);\n r_sum += (stack.r = (pr = pixels[p])) * (rbs = radiusPlus1 - i);\n g_sum += (stack.g = (pg = pixels[p+1])) * rbs;\n b_sum += (stack.b = (pb = pixels[p+2])) * rbs;\n\n r_in_sum += pr;\n g_in_sum += pg;\n b_in_sum += pb;\n\n stack = stack.next;\n }\n\n\n stackIn = stackStart;\n stackOut = stackEnd;\n for (x = 0; x < width; x++)\n {\n pixels[yi] = (r_sum * mul_sum) >> shg_sum;\n pixels[yi+1] = (g_sum * mul_sum) >> shg_sum;\n pixels[yi+2] = (b_sum * mul_sum) >> shg_sum;\n\n r_sum -= r_out_sum;\n g_sum -= g_out_sum;\n b_sum -= b_out_sum;\n\n r_out_sum -= stackIn.r;\n g_out_sum -= stackIn.g;\n b_out_sum -= stackIn.b;\n\n p = (yw + ((p = x + radius + 1) < widthMinus1 ? p : widthMinus1)) << 2;\n\n r_in_sum += (stackIn.r = pixels[p]);\n g_in_sum += (stackIn.g = pixels[p+1]);\n b_in_sum += (stackIn.b = pixels[p+2]);\n\n r_sum += r_in_sum;\n g_sum += g_in_sum;\n b_sum += b_in_sum;\n\n stackIn = stackIn.next;\n\n r_out_sum += (pr = stackOut.r);\n g_out_sum += (pg = stackOut.g);\n b_out_sum += (pb = stackOut.b);\n\n r_in_sum -= pr;\n g_in_sum -= pg;\n b_in_sum -= pb;\n\n stackOut = stackOut.next;\n\n yi += 4;\n }\n yw += width;\n }\n\n\n for (x = 0; x < width; x++)\n {\n g_in_sum = b_in_sum = r_in_sum = g_sum = b_sum = r_sum = 0;\n\n yi = x << 2;\n r_out_sum = radiusPlus1 * (pr = pixels[yi]);\n g_out_sum = radiusPlus1 * (pg = pixels[yi+1]);\n b_out_sum = radiusPlus1 * (pb = pixels[yi+2]);\n\n r_sum += sumFactor * pr;\n g_sum += sumFactor * pg;\n b_sum += sumFactor * pb;\n\n stack = stackStart;\n\n for (i = 0; i < radiusPlus1; i++)\n {\n stack.r = pr;\n stack.g = pg;\n stack.b = pb;\n stack = stack.next;\n }\n\n yp = width;\n\n for (i = 1; i <= radius; i++)\n {\n yi = (yp + x) << 2;\n\n r_sum += (stack.r = (pr = pixels[yi])) * (rbs = radiusPlus1 - i);\n g_sum += (stack.g = (pg = pixels[yi+1])) * rbs;\n b_sum += (stack.b = (pb = pixels[yi+2])) * rbs;\n\n r_in_sum += pr;\n g_in_sum += pg;\n b_in_sum += pb;\n\n stack = stack.next;\n\n if(i < heightMinus1)\n {\n yp += width;\n }\n }\n\n yi = x;\n stackIn = stackStart;\n stackOut = stackEnd;\n for (y = 0; y < height; y++)\n {\n p = yi << 2;\n pixels[p] = (r_sum * mul_sum) >> shg_sum;\n pixels[p+1] = (g_sum * mul_sum) >> shg_sum;\n pixels[p+2] = (b_sum * mul_sum) >> shg_sum;\n\n r_sum -= r_out_sum;\n g_sum -= g_out_sum;\n b_sum -= b_out_sum;\n\n r_out_sum -= stackIn.r;\n g_out_sum -= stackIn.g;\n b_out_sum -= stackIn.b;\n\n p = (x + (((p = y + radiusPlus1) < heightMinus1 ? p : heightMinus1) * width)) << 2;\n\n r_sum += (r_in_sum += (stackIn.r = pixels[p]));\n g_sum += (g_in_sum += (stackIn.g = pixels[p+1]));\n b_sum += (b_in_sum += (stackIn.b = pixels[p+2]));\n\n stackIn = stackIn.next;\n\n r_out_sum += (pr = stackOut.r);\n g_out_sum += (pg = stackOut.g);\n b_out_sum += (pb = stackOut.b);\n\n r_in_sum -= pr;\n g_in_sum -= pg;\n b_in_sum -= pb;\n\n stackOut = stackOut.next;\n\n yi += width;\n }\n }\n\n return imageData;\n}\n\nfunction BlurStack()\n{\n this.r = 0;\n this.g = 0;\n this.b = 0;\n this.a = 0;\n this.next = null;\n}\n\nexport default {\n image: processImage,\n canvasRGBA: processCanvasRGBA,\n canvasRGB: processCanvasRGB,\n imageDataRGBA: processImageDataRGBA,\n imageDataRGB: processImageDataRGB\n};\n","/* eslint-disable max-len */\n// Equations based on NOAA’s Solar Calculator; all angles in radians.\n// http://www.esrl.noaa.gov/gmd/grad/solcalc/\n\nconst π = Math.PI;\nconst radians = π / 180;\nconst degrees = 180 / π;\n\nfunction solarGeometricMeanAnomaly(centuries) {\n return (357.52911 + centuries * (35999.05029 - 0.0001537 * centuries)) * radians;\n}\n\nfunction solarGeometricMeanLongitude(centuries) {\n const l = (280.46646 + centuries * (36000.76983 + centuries * 0.0003032)) % 360;\n return ((l < 0 ? l + 360 : l) / 180) * π;\n}\n\nfunction solarEquationOfCenter(centuries) {\n const m = solarGeometricMeanAnomaly(centuries);\n return (Math.sin(m) * (1.914602 - centuries * (0.004817 + 0.000014 * centuries))\n + Math.sin(m + m) * (0.019993 - 0.000101 * centuries)\n + Math.sin(m + m + m) * 0.000289) * radians;\n}\n\nfunction solarTrueLongitude(centuries) {\n return solarGeometricMeanLongitude(centuries) + solarEquationOfCenter(centuries);\n}\n\nfunction solarApparentLongitude(centuries) {\n return solarTrueLongitude(centuries) - (0.00569 + 0.00478 * Math.sin((125.04 - 1934.136 * centuries) * radians)) * radians;\n}\n\nfunction meanObliquityOfEcliptic(centuries) {\n return (23 + (26 + (21.448 - centuries * (46.8150 + centuries * (0.00059 - centuries * 0.001813))) / 60) / 60) * radians;\n}\n\nfunction obliquityCorrection(centuries) {\n return meanObliquityOfEcliptic(centuries) + 0.00256 * Math.cos((125.04 - 1934.136 * centuries) * radians) * radians;\n}\n\nfunction solarDeclination(centuries) {\n return Math.asin(\n Math.sin(obliquityCorrection(centuries)) * Math.sin(solarApparentLongitude(centuries)),\n );\n}\n\nfunction eccentricityEarthOrbit(centuries) {\n return 0.016708634 - centuries * (0.000042037 + 0.0000001267 * centuries);\n}\n\nfunction equationOfTime(centuries) {\n const e = eccentricityEarthOrbit(centuries);\n const m = solarGeometricMeanAnomaly(centuries);\n const l = solarGeometricMeanLongitude(centuries);\n let y = Math.tan(obliquityCorrection(centuries) / 2);\n y *= y;\n return y * Math.sin(2 * l)\n - 2 * e * Math.sin(m)\n + 4 * e * y * Math.sin(m) * Math.cos(2 * l)\n - 0.5 * y * y * Math.sin(4 * l)\n - 1.25 * e * e * Math.sin(2 * m);\n}\n\nexport function antipode(position) {\n return [position[0] + 180, -position[1]];\n}\n\nexport function solarPosition(time) {\n const centuries = (time - Date.UTC(2000, 0, 1, 12)) / 864e5 / 36525; // since J2000\n const longitude = ((d3.time.day.utc.floor(time) - time) / 864e5) * 360 - 180;\n return [\n longitude - equationOfTime(centuries) * degrees,\n solarDeclination(centuries) * degrees,\n ];\n}\n","import Legend from './Legend';\nimport Watermark from './Watermark';\nimport StackBlur from './StackBlur';\nimport utils from '../utils';\nimport { solarPosition, antipode } from './solarPosition';\n\n/**\n * Used the name GeoMap instead of Map to avoid collision with the native Map class of JS\n */\nexport default class GeoMap {\n /**\n * Geo Mapping class constructor that will initiate the map drawing\n * @param maptable: Maptable main Object\n * @param options: options communicated to map\n * @param jsonWorld: Object that contain TopoJSON dataset\n */\n constructor(maptable, options, jsonWorld) {\n this.maptable = maptable;\n this.scale = 1;\n this.transX = 0;\n this.transY = 0;\n\n this.options = options;\n\n this.jsonWorld = jsonWorld;\n\n this.containerSelector = maptable.options.target;\n this.container = document.querySelector(maptable.options.target);\n\n // Map wrapper\n const mapWrapper = this.container.querySelector('.mt-map-container');\n\n const existingMap = this.container.querySelector('#mt-map');\n if (existingMap) {\n // transform #mt-map to .mt-map-container'\n mapWrapper.parentNode.insertBefore(mapWrapper, existingMap);\n existingMap.parentNode.removeChild(existingMap);\n }\n\n // Map\n this.node = document.createElement('div');\n this.node.setAttribute('id', 'mt-map');\n mapWrapper.appendChild(this.node);\n\n this.svg = d3.select(this.node)\n .append('svg')\n .attr('id', 'mt-map-svg')\n .attr('xmlns', 'http://www.w3.org/2000/svg')\n .attr('xmlns:xlink', 'http://www.w3.org/1999/xlink')\n .attr('viewBox', `0 0 ${this.getWidth()} ${this.getHeight()}`)\n .attr('width', this.getWidth())\n .attr('height', this.getHeight());\n\n this.projection = d3.geo.equirectangular()\n .translate([this.getWidth() / 2, this.getHeight() / (2 * this.options.scaleHeight)])\n .scale((this.getWidth() / 640) * 100)\n .rotate([-12, 0])\n .precision(0.1);\n\n this.path = d3.geo.path().projection(this.projection);\n\n this.enrichData();\n\n this.zoomListener = d3.behavior\n .zoom()\n .scaleExtent(this.options.scaleZoom)\n .on('zoom', this.rescale.bind(this));\n\n // Attach Zoom event to map\n if (this.options.zoom) {\n this.svg = this.svg.call(this.zoomListener.bind(this));\n }\n\n // Add tooltip\n if (this.options.markers) {\n this.tooltipMarkersNode = d3.select(this.node)\n .append('div')\n .attr('id', 'mt-map-markers-tooltip')\n .attr('class', `mt-map-tooltip ${this.options.markers.tooltipClassName}`)\n .style('display', 'none');\n }\n\n if (this.options.countries) {\n this.tooltipCountriesNode = d3.select(this.node)\n .append('div')\n .attr('id', 'mt-map-countries-tooltip')\n .attr('class', `mt-map-tooltip ${this.options.countries.tooltipClassName}`)\n .style('display', 'none');\n }\n\n this.layerGlobal = this.svg.append('g').attr('class', 'mt-map-global');\n this.layerDefs = this.svg.append('defs');\n this.layerDefs.html(`\n \n \n \n \n \n \n `);\n if (this.options.timezones) this.layerTimezones = this.layerGlobal.append('g').attr('class', 'mt-map-timezones');\n this.layerCountries = this.layerGlobal.append('g').attr('class', 'mt-map-countries');\n if (this.options.night) this.layerNight = this.layerGlobal.append('g').attr('class', 'mt-map-night');\n\n if (this.options.heatmap) this.layerHeatmap = this.layerGlobal.append('g').attr('class', 'mt-map-heatmap');\n this.layerMarkers = this.layerGlobal.append('g').attr('class', 'mt-map-markers');\n\n // Add Watermark\n if (this.options.watermark) {\n this.watermark = new Watermark(this, this.options.watermark);\n }\n\n // Add Title\n if (this.options.title) {\n this.buildTitle();\n }\n\n // Add Export SVG Capability\n if (this.options.exportSvgClient || this.options.exportSvg) {\n this.addExportSvgCapability();\n }\n\n // AutoResize\n if (!this.options.width) {\n window.addEventListener('resize', () => {\n this.svg.attr('width', this.getWidth());\n this.svg.attr('height', this.getHeight());\n this.rescale();\n });\n }\n\n // Let's build things\n this.loadGeometries();\n\n // render is triggered by MapTable\n // this.render();\n }\n\n enrichData() {\n // Add coordinates to rawData\n this.maptable.rawData.forEach((d) => {\n d.longitude = parseFloat(d[this.options.longitudeKey]);\n d.latitude = parseFloat(d[this.options.latitudeKey]);\n let coord = [0, 0];\n if (!Number.isNaN(d.longitude) && !Number.isNaN(d.latitude)) {\n coord = this.projection([d.longitude, d.latitude]);\n }\n d.x = coord[0];\n d.y = coord[1];\n });\n }\n\n scaleAttributes() {\n return Math.pow(this.scale, 2 / 3); // eslint-disable-line\n }\n\n getWidth() {\n if (this.options.width) {\n return this.options.width;\n }\n this.options.width = this.node.offsetWidth;\n return this.node.offsetWidth;\n }\n\n getHeight() {\n const deltaHeight = (this.options.title) ? 30 : 0;\n if (!this.options.height && this.options.ratioFromWidth) {\n return this.getWidth() * this.options.ratioFromWidth * this.options.scaleHeight + deltaHeight;\n }\n return this.options.height * this.options.scaleHeight + deltaHeight;\n }\n\n /**\n * Load geometries and built the map components\n */\n loadGeometries() {\n // We filter world data\n if (this.options.filterCountries) {\n this.jsonWorld.objects.countries.geometries = this.jsonWorld.objects.countries\n .geometries.filter(this.options.filterCountries);\n }\n\n // Build countries\n if (this.options.countries) this.buildCountries();\n\n // Build heatmap\n if (this.options.heatmap) this.buildHeatmap();\n\n if (this.options.night) this.buildNight();\n if (\n this.options.timezones\n && (this.options.timezones.path || this.options.timezones.pathData)\n ) this.buildTimezone();\n }\n\n /**\n * Logic to build the heatmap elements (without the filling the heatmap image)\n */\n buildHeatmap() {\n // Build vectors\n const lands = topojson.merge(this.jsonWorld, this.jsonWorld.objects.countries.geometries);\n if (!this.options.heatmap.disableMask) {\n this.maskHeatmap = this.layerHeatmap.append('defs')\n .append('clipPath')\n .attr('id', 'mt-map-heatmap-mask');\n\n this.maskHeatmap\n .datum(lands)\n .append('path')\n .attr('class', 'mt-map-heatmap-mask-paths')\n .attr('d', this.path);\n }\n\n this.imgHeatmap = this.layerHeatmap\n .append('image')\n .attr('width', this.getWidth())\n .attr('height', this.getHeight())\n .attr('x', 0)\n .attr('y', 0)\n .attr('class', 'mt-map-heatmap-img');\n\n if (this.options.heatmap.mask) {\n this.imgHeatmap = this.imgHeatmap.attr('clip-path', 'url(#mt-map-heatmap-mask)');\n }\n\n if (this.options.heatmap.borders) {\n const borders = topojson.mesh(\n this.jsonWorld,\n this.jsonWorld.objects.countries,\n (a, b) => a !== b,\n );\n\n this.bordersHeatmap = this.layerHeatmap\n .append('g')\n .attr('class', 'mt-map-heatmap-borders');\n\n this.bordersHeatmap.selectAll('path.mt-map-heatmap-borders-paths')\n .data([lands, borders])\n .enter()\n .append('path')\n .attr('class', 'mt-map-heatmap-borders-paths')\n .attr('fill', 'none')\n .attr('stroke-width', this.options.heatmap.borders.stroke)\n .attr('stroke', this.options.heatmap.borders.color)\n .attr('style', `opacity: ${this.options.heatmap.borders.opacity}`)\n .attr('d', this.path);\n }\n }\n\n /**\n * Logic to build the night position\n */\n buildNight() {\n this.layerNight = this.layerGlobal.append('g')\n .attr('class', 'mt-map-night');\n\n const circle = d3.geo.circle()\n .angle(90);\n\n // Mask night\n this.maskNight = this.layerNight.append('defs')\n .append('clipPath')\n .attr('id', 'mt-map-night-mask');\n\n this.maskNight.append('rect')\n .attr('x', 0)\n .attr('y', 30)\n .attr('width', this.getWidth())\n .attr('height', this.getHeight() * 0.82 - 30);\n\n // Build vectors\n this.nightPath = this.layerNight.append('path')\n .attr('class', `mt-map-night-layer${this.options.night.cssBlur ? ' mt-blur' : ''}`)\n .attr('filter', this.options.night.cssBlur ? undefined : 'url(#blur)')\n .attr('clip-path', 'url(#mt-map-night-mask)')\n .attr('d', this.path)\n .style('opacity', 0.1);\n\n const userDate = this.options.night.date || Date.UTC();\n const startOfDay = Date.UTC(\n userDate.getUTCFullYear(),\n userDate.getUTCMonth(),\n userDate.getUTCDate(),\n 0,\n 0,\n 0,\n );\n const solarPositionDated = solarPosition(new Date(startOfDay));\n this.nightPath.datum(circle.origin(antipode(solarPositionDated))).attr('d', this.path);\n\n this.nightPathRight = this.layerNight.append('path')\n .attr('class', `mt-map-night-layer${this.options.night.cssBlur ? ' mt-blur' : ''}`)\n .attr('filter', this.options.night.cssBlur ? undefined : 'url(#blur)')\n .attr('clip-path', 'url(#mt-map-night-mask)')\n .attr('d', this.nightPath.attr('d'))\n .style('opacity', 0.1)\n .style('transform', `translate3d(${this.getWidth()}px,0,0)`);\n\n this.nightPathLeft = this.layerNight.append('path')\n .attr('class', `mt-map-night-layer${this.options.night.cssBlur ? ' mt-blur' : ''}`)\n .attr('filter', this.options.night.cssBlur ? undefined : 'url(#blur)')\n .attr('clip-path', 'url(#mt-map-night-mask)')\n .attr('d', this.nightPath.attr('d'))\n .style('opacity', 0.1)\n .style('transform', `translate3d(${-this.getWidth()}px,0,0)`);\n\n if (!this.options.night.disableSun) {\n const sunCoords = this.projection(solarPositionDated);\n\n this.sunCircleRight = this.layerNight.append('svg:circle')\n .attr('class', 'mt-map-sun-right')\n .attr('cx', sunCoords[0])\n .attr('cy', sunCoords[1])\n .attr('fill', 'url(#sunGradient)')\n .attr('r', this.getHeight() * 0.35);\n\n this.sunCircleXRight = this.layerNight.append('svg:circle')\n .attr('class', 'mt-map-sun-xright')\n .attr('cx', sunCoords[0] + this.getWidth())\n .attr('cy', sunCoords[1])\n .attr('fill', 'url(#sunGradient)')\n .attr('r', this.getHeight() * 0.35);\n\n this.sunCircleLeft = this.layerNight.append('svg:circle')\n .attr('class', 'mt-map-sun-right')\n .attr('cx', sunCoords[0] - this.getWidth())\n .attr('cy', sunCoords[1])\n .attr('fill', 'url(#sunGradient)')\n .attr('r', this.getHeight() * 0.35);\n\n this.sunCircleXLeft = this.layerNight.append('svg:circle')\n .attr('class', 'mt-map-sun-xright')\n .attr('cx', sunCoords[0] - 2 * this.getWidth())\n .attr('cy', sunCoords[1])\n .attr('fill', 'url(#sunGradient)')\n .attr('r', this.getHeight() * 0.35);\n }\n }\n\n /**\n * Logic to build the timezone strips\n */\n buildTimezone() {\n if (this.options.timezones.pathData) {\n this.loadTimezone(null, JSON.parse(this.options.timezones.pathData));\n } else if (this.options.timezones.path) {\n d3.json(this.options.timezones.path, (errGeoMap, jsonTimezones) => {\n this.loadTimezone(errGeoMap, jsonTimezones);\n });\n }\n }\n\n scaleFontSize(fontSize) {\n return this.getWidth() < 700 ? fontSize * (this.getWidth() / 700) : fontSize;\n }\n\n loadTimezone(err, jsonTimezones) {\n this.dataTimezones = topojson.feature(\n jsonTimezones,\n jsonTimezones.objects.timezones,\n ).features;\n\n // Mask timezone\n this.maskTimezone = this.layerTimezones.append('defs')\n .append('clipPath')\n .attr('id', 'mt-map-timezone-mask');\n\n this.maskTimezone.append('rect')\n .attr('x', 0)\n .attr('y', 30)\n .attr('width', this.getWidth())\n .attr('height', this.getHeight() * 0.82 - 30);\n\n // Build timezone paths\n this.layerTimezones\n .selectAll('.mt-map-timezone')\n .data(this.dataTimezones.filter((d) => d.properties.places !== 'Antarctica'))\n .enter()\n .insert('path')\n .attr('class', 'mt-map-timezone')\n .attr('d', this.path)\n .attr('fill', (d) => (d.properties.zone % 2 === 0 ? '#F4F5F5' : 'transparent'))\n .attr('title', (d) => JSON.stringify(d.properties))\n .attr('clip-path', 'url(#mt-map-timezone-mask)')\n .style('opacity', 0.6);\n\n // Add times\n const timezoneTexts = this.dataTimezones.filter((d) => d.properties.places !== 'Antarctica' && d.properties.zone % 1 === 0 && d.properties.zone !== 14);\n const timezoneTextsUnique = [...new Map(timezoneTexts.map((item) => (\n [item.properties.zone, item]\n ))).values()];\n\n this.layerTimezonesText = this.layerTimezones.append('g').attr('class', 'mt-map-timezones-texts');\n this.layerTimezonesText.selectAll('.mt-map-timezone-text')\n .data(timezoneTextsUnique)\n .enter()\n .insert('text')\n .attr('class', 'mt-map-timezone-text')\n .attr('y', this.getHeight() * 0.82 - 5)\n .attr('x', (d) => (d.properties.zone + 10) * (this.getWidth() / 24.5) - 1)\n .attr('dx', (this.getWidth() / 24.5) / 2)\n .attr('font-size', this.scaleFontSize(9))\n .attr('font-family', 'Helevetica, Arial, Sans-Serif')\n .attr('fill', '#999')\n .attr('text-anchor', 'middle')\n .html((d) => (\n utils.formatDate((this.options.timezones.date || new Date()), d.properties.zone)));\n }\n\n /**\n * Get Scale for every circle magnitude\n * @param heatmapDataset: heatmap dataset that we use\n * @returns scale: function - Scale function that output a value [0 - 1]\n */\n getMagnitudeScale(heatmapDataset) {\n const opts = this.options.heatmap;\n const lengthDataset = heatmapDataset.length;\n if (!lengthDataset) return () => 0;\n // const layersPerLocation = (opts.circles.max - opts.circles.min) / opts.circles.step;\n const maxOpacityScale = d3.scale.linear()\n .domain([1, lengthDataset])\n .range([1, 0.25]);\n const centralCircleOpacity = maxOpacityScale(lengthDataset);\n\n const scale = d3.scale.linear()\n .domain([opts.circles.min, 20])\n .range([centralCircleOpacity, 0]);\n return (m) => scale(m);\n }\n\n /**\n * Get Scale for every data point (used for weighting)\n * @returns scale: function - Scale function that output a value [0 - 1]\n */\n getDatumScale() {\n if (!this.options.heatmap.weightByAttribute) return () => 1;\n const dataExtents = d3.extent(this.maptable.data, this.options.heatmap.weightByAttribute);\n const userScale = (this.options.heatmap.weightByAttributeScale === 'log')\n ? d3.scale.log : d3.scale.linear;\n const scale = userScale().domain(dataExtents).range([0.5, 1]);\n return (d) => {\n const val = this.options.heatmap.weightByAttribute(d);\n if (!val) return 0;\n return scale(val);\n };\n }\n\n /**\n * Get the Data URL of the heatmap image\n * @returns {string} base64 image\n */\n getHeatmapData() {\n const canvasHeatmap = d3.select(this.node)\n .append('canvas')\n .attr('id', 'mt-map-heatmap-canvas')\n .attr('width', this.getWidth())\n .attr('height', this.getHeight())\n .attr('style', 'display: none;');\n\n const ctx = canvasHeatmap.node().getContext('2d');\n ctx.globalCompositeOperation = 'multiply';\n const circles = d3.range(\n this.options.heatmap.circles.min,\n this.options.heatmap.circles.max,\n this.options.heatmap.circles.step,\n );\n const datumScale = this.getDatumScale();\n const heatmapDataset = this.maptable.data.filter((d) => datumScale(d) > 0.1);\n const path = this.path.context(ctx);\n const magnitudeScale = this.getMagnitudeScale(heatmapDataset);\n const colorScale = d3.scale.linear()\n .domain([1, 0])\n .range(['#000000', '#FFFFFF']);\n\n // Make a flat white background first\n ctx.beginPath();\n ctx.rect(0, 0, this.getWidth(), this.getHeight());\n ctx.fillStyle = '#ffffff';\n ctx.fill();\n ctx.closePath();\n\n // color strenght factor\n const colorMultiplier = (x) => {\n const a = this.options.heatmap.circles.colorStrength;\n const aa = 1 + ((a - 1) / 100);\n if (a > 1) return (2 - aa) * x + aa - 1;\n return a * x;\n };\n\n // add condensed clouds\n heatmapDataset.forEach((point) => {\n const scaleOpacityDatum = datumScale(point);\n circles.forEach((m) => {\n const opacity = colorMultiplier(magnitudeScale(m) * scaleOpacityDatum);\n if (opacity > 0) {\n ctx.beginPath();\n path(d3.geo.circle().origin([point.longitude, point.latitude]).angle(m - 0.0001)());\n ctx.fillStyle = colorScale(opacity);\n ctx.fill();\n ctx.closePath();\n }\n });\n });\n\n StackBlur.canvasRGBA(\n canvasHeatmap.node(),\n 0,\n 0,\n this.getWidth(),\n this.getHeight(),\n this.options.heatmap.circles.blur,\n );\n\n // Add color layer\n ctx.beginPath();\n ctx.globalCompositeOperation = 'screen';\n ctx.rect(0, 0, this.getWidth(), this.getHeight());\n ctx.fillStyle = this.options.heatmap.circles.color;\n ctx.fill();\n ctx.closePath();\n\n const dataUrl = canvasHeatmap.node().toDataURL();\n canvasHeatmap.remove();\n return dataUrl;\n }\n\n /**\n * Set the data URL to the heatmap image\n */\n updateHeatmap() {\n const dataUrl = this.getHeatmapData();\n this.imgHeatmap.attr('xlink:href', dataUrl);\n }\n\n /**\n * build the paths for the countries\n */\n buildCountries() {\n this.dataCountries = topojson.feature(\n this.jsonWorld,\n this.jsonWorld.objects.countries,\n ).features;\n\n // Build country paths\n this.layerCountries\n .selectAll('.mt-map-country')\n .data(this.dataCountries)\n .enter()\n .insert('path')\n .attr('class', 'mt-map-country')\n .attr('d', this.path);\n\n // Build Country Legend\n this.legendCountry = {};\n\n if (this.shouldRenderLegend()) {\n this.legendCountry.fill = new Legend(this);\n }\n }\n\n shouldRenderLegend() {\n const f = this.options.countries.attr.fill;\n if (!f) return false;\n if (!f.legend || !f.min || !f.max) return false;\n if (f.aggregate && f.aggregate.scale) {\n const scale = (typeof (f.aggregate.scale) === 'function')\n ? f.aggregate.scale.bind(this.maptable)()\n : f.aggregate.scale;\n if (scale !== 'linear') return false;\n }\n return true;\n }\n\n /**\n * Get all mt-map-country elements\n */\n getAllMtMapCountry() {\n if (this.allMtMapCountry) return this.allMtMapCountry;\n this.allMtMapCountry = d3.selectAll(`${this.containerSelector} .mt-map-country`);\n return this.allMtMapCountry;\n }\n\n /**\n * Get all mt-map-marjker elements\n */\n getAllMtMapMarker() {\n if (this.allMtMapMarker) return this.allMtMapMarker;\n this.allMtMapMarker = d3.selectAll(`${this.containerSelector} .mt-map-marker`);\n return this.allMtMapMarker;\n }\n\n /**\n * Set the right color for every country\n */\n updateCountries() {\n // Data from user input\n const dataByCountry = new Map();\n this.maptable.data.forEach((d) => {\n const key = d[this.options.countryIdentifierKey];\n if (!dataByCountry.has(key)) {\n dataByCountry.set(key, []);\n }\n dataByCountry.get(key).push(d);\n });\n\n // We merge both data\n this.dataCountries.forEach((geoDatum) => {\n geoDatum.key = geoDatum.properties[this.options.countryIdentifierType];\n const matchedCountry = dataByCountry.get(geoDatum.key);\n geoDatum.values = matchedCountry || [];\n geoDatum.attr = {};\n geoDatum.rollupValue = {};\n });\n\n // We calculate attributes values\n Object.keys(this.options.countries.attr).forEach((k) => {\n this.setAttrValues(k, this.options.countries.attr[k], this.dataCountries);\n });\n\n // Update SVG\n const countryItem = this.getAllMtMapCountry().each(function (d) {\n const selection = d3.select(this);\n Object.keys(d.attr).forEach((key) => {\n selection.attr(key, d.attr[key]);\n });\n });\n\n // Update Legend\n Object.keys(this.options.countries.attr).forEach((attrKey) => {\n const attrValue = this.options.countries.attr[attrKey];\n if (typeof (attrValue) === 'object' && attrValue.legend && this.legendCountry[attrKey] !== undefined) {\n const scaleDomain = d3.extent(\n this.dataCountries,\n (d) => Number(d.attrProperties[attrKey].value),\n );\n this.legendCountry[attrKey].updateExtents(scaleDomain);\n\n // When we mouseover the legend, it should highlight the indice selected\n countryItem.on('mouseover', (d) => {\n this.legendCountry[attrKey].indiceChange(d.attrProperties[attrKey].value);\n })\n .on('mouseout', () => {\n this.legendCountry[attrKey].indiceChange(NaN);\n });\n }\n });\n\n // Update Tooltip\n if (this.options.countries && this.options.countries.tooltip) {\n this.activateTooltip(\n countryItem,\n this.tooltipCountriesNode,\n this.options.countries.tooltip,\n true,\n );\n }\n }\n\n /**\n * Update night drawings\n */\n updateNight() {\n const userDate = this.options.night.date || Date.UTC();\n const startOfDay = Date.UTC(\n userDate.getUTCFullYear(),\n userDate.getUTCMonth(),\n userDate.getUTCDate(),\n 0,\n 0,\n 0,\n );\n const endOfDay = Date.UTC(\n userDate.getUTCFullYear(),\n userDate.getUTCMonth(),\n userDate.getUTCDate(),\n 23,\n 59,\n 59,\n );\n\n const totalMilliseconds = endOfDay - startOfDay;\n const currentTime = userDate - startOfDay;\n const relativeTranslateX = (currentTime / totalMilliseconds);\n\n this.layerNight.node().style.transform = `translateX(${-this.getWidth() * relativeTranslateX}px)`;\n }\n\n /**\n * Update night drawings\n */\n updateTimezones() {\n const timezoneTexts = document.querySelectorAll('.mt-map-timezone-text');\n const currentDate = this.options.timezones.date || new Date();\n\n Array.from(timezoneTexts).forEach((timezoneText) => {\n timezoneText.textContent = utils.formatDate(\n currentDate,\n timezoneText.__data__.properties.zone,\n );\n });\n }\n\n updateMarkers() {\n const defaultGroupBy = (a) => `${a.longitude},${a.latitude}`;\n\n this.dataMarkers = d3.nest()\n .key(defaultGroupBy)\n .entries(this.maptable.data)\n .filter((d) => d.values[0].x !== 0);\n\n // We merge both data\n this.dataMarkers.forEach((d) => {\n d.attr = {};\n d.attrProperties = {};\n });\n\n // We calculate attributes values\n Object.keys(this.options.markers.attr).forEach((k) => {\n this.setAttrValues(k, this.options.markers.attr[k], this.dataMarkers);\n });\n\n // Enter\n const markerItem = this.layerMarkers\n .selectAll('.mt-map-marker')\n .data(this.dataMarkers);\n let markerObject = markerItem.enter();\n if (this.options.markers.customTag) {\n markerObject = this.options.markers.customTag(markerObject);\n } else {\n markerObject = markerObject.append('svg:circle');\n }\n const markerClassName = (this.options.markers.className)\n ? this.options.markers.className : '';\n\n markerObject.attr('class', `mt-map-marker ${markerClassName}`);\n\n // Exit\n markerItem.exit().transition()\n .attr('r', 0)\n .attr('fill', '#eee')\n .style('opacity', 0)\n .remove();\n\n // Update\n const attrX = (this.options.markers.attrX) ? this.options.markers.attrX : 'cx';\n const attrY = (this.options.markers.attrY) ? this.options.markers.attrY : 'cy';\n\n const attrXDelta = (this.options.markers.attrXDelta) ? this.options.markers.attrXDelta : 0;\n const attrYDelta = (this.options.markers.attrYDelta) ? this.options.markers.attrYDelta : 0;\n\n const markerUpdate = markerItem\n .attr(attrX, (d) => d.values[0].x + attrXDelta)\n .attr(attrY, (d) => d.values[0].y + attrYDelta);\n\n this.getAllMtMapMarker().each(function (d) {\n Object.keys(d.attr).forEach((key) => {\n d3.select(this).attr(key, d.attr[key]);\n });\n });\n\n if (this.options.markers.tooltip) {\n this.activateTooltip(\n markerUpdate,\n this.tooltipMarkersNode,\n this.options.markers.tooltip,\n false,\n );\n }\n\n this.rescale();\n }\n\n fitContent() {\n if (this.maptable.data.length === 0) {\n this.transX = 0;\n this.transY = 0;\n this.scale = 1;\n this.zoomListener.translate([this.transX, this.transY])\n .scale(this.scale);\n return;\n }\n const hor = d3.extent(this.maptable.data, (d) => d.x);\n const ver = d3.extent(this.maptable.data, (d) => d.y);\n\n // center dots with the good ratio\n const ratio = this.getWidth() / this.getHeight();\n const deltaMarker = 20 + ((this.options.title) ? 30 : 0);\n\n const currentWidth = (hor[1] - hor[0]) + deltaMarker;\n const currentHeight = (ver[1] - ver[0]) + deltaMarker;\n\n const realHeight = currentWidth / ratio;\n const realWidth = currentHeight * ratio;\n\n let diffMarginWidth = 0;\n let diffMarginHeight = 0;\n if (realWidth >= currentWidth) {\n diffMarginWidth = (realWidth - currentWidth) / 2;\n } else {\n diffMarginHeight = (realHeight - currentHeight) / 2;\n }\n\n // add layout margin\n hor[0] -= (this.options.fitContentMargin + diffMarginWidth);\n hor[1] += (this.options.fitContentMargin + diffMarginWidth);\n ver[0] -= (this.options.fitContentMargin + diffMarginHeight);\n ver[1] += (this.options.fitContentMargin + diffMarginHeight);\n\n this.scale = this.getWidth() / (hor[1] - hor[0]);\n this.transX = -1 * hor[0] * this.scale;\n this.transY = -1 * ver[0] * this.scale;\n\n this.zoomListener.translate([this.transX, this.transY]).scale(this.scale);\n }\n\n buildTitle() {\n const titleContainer = this.svg\n .append('svg')\n .attr('width', this.getWidth())\n .attr('x', 0)\n .attr('y', (this.getHeight() - 30))\n .attr('height', 30);\n\n if (this.options.title.bgColor) {\n titleContainer.append('rect')\n .attr('x', 0)\n .attr('y', 0)\n .attr('width', this.getWidth())\n .attr('height', 30)\n .attr('fill', this.options.title.bgColor);\n }\n\n titleContainer.append('text')\n .attr('id', 'mt-map-title')\n .attr('x', 20)\n .attr('font-size', this.scaleFontSize(this.options.title.fontSize))\n .attr('font-family', this.options.title.fontFamily)\n .attr('y', 20);\n\n if (this.options.title.source) {\n titleContainer.append('text')\n .attr('y', 20)\n .attr('x', (this.getWidth() - 20))\n .attr('text-anchor', 'end')\n .attr('font-size', this.scaleFontSize(this.options.title.fontSize))\n .attr('font-family', this.options.title.fontFamily)\n .html(this.options.title.source());\n }\n }\n\n /**\n * We encode a transaltion to be independent from the dimensions of the visualization\n * @param originalTranslation: Array - original translation value (from screen)\n * @returns encodedTranslation: Array - encoded translation\n */\n encodeTranslation(originalTranslation) {\n const newTx = originalTranslation[0] / (this.scale * this.getWidth());\n\n const newTy = originalTranslation[1] / (this.scale * this.getHeight());\n\n return [newTx, newTy];\n }\n\n /**\n * We decode a translation to adapt it to the dimensions of the visualization\n * @param encodedTranslation: Array - encoded translation\n * @returns originalTranslation: Array - original translation value (from screen)\n */\n decodeTranslation(encodedTranslation) {\n const newTx = encodedTranslation[0] * this.getWidth() * this.scale;\n\n const newTy = encodedTranslation[1] * this.getHeight() * this.scale;\n\n return [newTx, newTy];\n }\n\n /**\n * Restore state from the url hash\n */\n restoreState(defaultZoom) {\n if (!defaultZoom || defaultZoom.length !== 3) return;\n this.scale = defaultZoom[0];\n const originalTranslation = this.decodeTranslation([defaultZoom[1], defaultZoom[2]]);\n this.transX = originalTranslation[0];\n this.transY = originalTranslation[1];\n this.zoomListener.scale(defaultZoom[0])\n .translate(originalTranslation)\n .event(this.svg);\n }\n\n /**\n * Save state into the url hash\n */\n saveState() {\n const encodedTranslation = this.encodeTranslation([this.transX, this.transY]);\n const exportedData = [this.scale, encodedTranslation[0],\n encodedTranslation[1]];\n if (exportedData[0] !== 1 && exportedData[1] !== 0 && exportedData[2] !== 0) {\n this.maptable.saveState('zoom', exportedData);\n } else {\n this.maptable.removeState('zoom');\n }\n }\n\n rescale() {\n const self = this;\n if (d3.event && d3.event.translate) {\n this.scale = d3.event.scale;\n this.transX = (this.scale === 1) ? 0 : d3.event.translate[0];\n this.transY = (this.scale === 1) ? 0 : d3.event.translate[1];\n }\n\n const maxTransX = 0;\n const maxTransY = 0;\n const minTransX = this.getWidth() * (1 - this.scale);\n const minTransY = this.getHeight() * (1 - this.scale);\n\n if (this.transY > maxTransY) {\n this.transY = maxTransY;\n } else if (this.transY < minTransY) {\n this.transY = minTransY;\n }\n\n if (this.transX > maxTransX) {\n this.transX = maxTransX;\n } else if (this.transX < minTransX) {\n this.transX = minTransX;\n }\n\n if (d3.event && d3.event.translate) {\n d3.event.translate[0] = this.transX;\n d3.event.translate[1] = this.transY;\n }\n\n this.layerGlobal.style(\n 'transform',\n `translate(${this.transX}px,${this.transY}px)scale(${this.scale})`,\n );\n\n // Hide tooltip\n if (self.tooltipCountriesNode) self.tooltipCountriesNode.attr('style', 'display:none;');\n if (self.tooltipMarkersNode) self.tooltipMarkersNode.attr('style', 'display:none;');\n\n // Rescale markers size\n if (this.options.markers) {\n // markers\n this.getAllMtMapMarker().each(function (d) {\n // stroke\n if (d.attr['stroke-width']) {\n d3.select(this).attr('stroke-width', d.attr['stroke-width'] / self.scaleAttributes());\n }\n // radius\n if (d.attr.r) {\n d3.select(this).attr('r', d.attr.r / self.scaleAttributes());\n }\n });\n }\n\n // Rescale Sun\n if (this.options.night && !this.options.disableSun) {\n d3.selectAll(`${this.containerSelector} .mt-map-sun`).style(\n 'r',\n (this.getHeight() * 0.35) / this.scale,\n );\n }\n\n // Rescale Country stroke-width\n if (this.options.countries) {\n this.getAllMtMapCountry().style(\n 'stroke-width',\n this.options.countries.attr['stroke-width'] / this.scale,\n );\n }\n\n // Rescale heatmap borders\n if (this.options.heatmap && this.options.heatmap.borders) {\n d3.selectAll(`${this.containerSelector} .mt-map-heatmap-borders-paths`)\n .style('stroke-width', this.options.heatmap.borders.stroke / this.scale);\n }\n\n // save state\n if (this.maptable.firstExecution && this.options.saveState) this.saveState();\n }\n\n setAttrValues(attrKey, attrValue, dataset) {\n if (typeof (attrValue) === 'number' || typeof (attrValue) === 'string') {\n // Static value\n dataset.forEach((d) => {\n d.attr[attrKey] = attrValue;\n });\n } else if (typeof (attrValue) === 'function') {\n // Dynamic value based on the dataset\n dataset.forEach((d) => {\n d.attr[attrKey] = attrValue(d);\n });\n } else if (typeof (attrValue) === 'object') {\n let scale = 'linear';\n let key = null;\n let mode = 'count';\n let scaleToUse = d3.scale.linear();\n if (attrValue.aggregate) {\n key = (typeof (attrValue.aggregate.key) === 'function')\n ? attrValue.aggregate.key.bind(this.maptable)()\n : attrValue.aggregate.key;\n\n mode = (typeof (attrValue.aggregate.mode) === 'function')\n ? attrValue.aggregate.mode.bind(this.maptable)()\n : attrValue.aggregate.mode;\n\n if (typeof (attrValue.aggregate.scale) === 'function') {\n scale = attrValue.aggregate.scale.bind(this.maptable)();\n } else if (attrValue.aggregate.scale) {\n scale = attrValue.aggregate.scale;\n }\n\n if (!key || !mode) {\n throw new Error(`MapTable: You should provide values 'key' & 'mode' for attr.${attrKey}.aggregate`);\n }\n\n // Custom aggregate mode\n if (mode === 'sum') {\n attrValue.rollup = (groupedData) => (\n groupedData.map((d) => Number(d[key])).reduce((a, c) => a + c, 0)\n );\n } else if (mode === 'avg') {\n attrValue.rollup = (groupedData) => {\n if (!groupedData.length) return 0;\n const validData = groupedData.filter((d) => !Number.isNaN(Number(d[key])));\n return validData\n .map((d) => Number(d[key]))\n .reduce((a, c) => a + c, 0) / validData.length;\n };\n } else if (mode === 'count') {\n attrValue.rollup = (groupedData) => groupedData.length;\n } else if (mode === 'min') {\n attrValue.rollup = (groupedData) => {\n if (!groupedData.length) return 0;\n const groupedValues = groupedData.map((d) => Number(d[key]));\n return groupedValues.reduce((min, p) => (p < min ? p : min), groupedValues[0]);\n };\n } else if (mode === 'max') {\n attrValue.rollup = (groupedData) => {\n if (!groupedData.length) return 0;\n const groupedValues = groupedData.map((d) => Number(d[key]));\n return groupedValues.reduce((max, p) => (p > max ? p : max), groupedValues[0]);\n };\n } else if (mode.indexOf('percentile') !== -1) {\n const percentile = utils.toNumber(mode);\n attrValue.rollup = (groupedData) => {\n if (!groupedData.length) return 0;\n const groupedValues = groupedData.map((d) => Number(d[key]));\n return utils.quantile(groupedValues, percentile);\n };\n } else if (typeof (attrValue.rollup) === 'function') {\n attrValue.rollup = attrValue.rollup.bind(this.maptable);\n }\n\n // Custom scale\n if (scale) {\n if (scale.indexOf('log') !== -1) {\n scaleToUse = d3.scale.log();\n } else if (scale.indexOf('pow') !== -1) {\n scaleToUse = d3.scale.pow().exponent(utils.toNumber(scale) || 1);\n } else if (scale === 'sqrt') {\n scaleToUse = d3.scale.sqrt();\n }\n // Rank scale neeed additional transformations\n }\n }\n\n // Dynamic value based on a scale\n if (!attrValue.rollup) {\n attrValue.rollup = (d) => d.length;\n }\n if (!attrValue.min || !attrValue.max) {\n throw new Error(`MapTable: You should provide values 'min' & 'max' for attr.${attrKey}`);\n }\n\n dataset.forEach((d) => {\n const aggregatedValue = attrValue.rollup(d.values);\n if (!d.attrProperties) d.attrProperties = {};\n if (!d.attrProperties[attrKey]) d.attrProperties[attrKey] = {};\n d.attrProperties[attrKey].value = aggregatedValue;\n if (key) {\n d.attrProperties[attrKey].key = key;\n d.attrProperties[attrKey].mode = mode;\n d.attrProperties[attrKey].scale = scale;\n const c = this.maptable.columnDetails[key];\n d.attrProperties[attrKey].columnDetails = c;\n const datum = {};\n datum[key] = aggregatedValue;\n d.attrProperties[attrKey].formatted = (c && c.cellContent)\n ? c.cellContent.bind(this.maptable)(datum)\n : aggregatedValue;\n }\n });\n if (scale === 'rank') {\n const positiveRanks = utils.uniqueValues([0].concat(dataset\n .map((d) => Math.floor(d.attrProperties[attrKey].value * 100) / 100)\n .filter((v) => v > 0)));\n const negativeRanks = utils.uniqueValues(dataset\n .map((d) => Math.floor(d.attrProperties[attrKey].value * 100) / 100)\n .filter((v) => v < 0));\n\n positiveRanks.sort((a, b) => a - b);\n negativeRanks.sort((a, b) => b - a);\n\n dataset.forEach((d) => {\n if (d.attrProperties[attrKey].value !== 0) {\n const ranks = d.attrProperties[attrKey].value >= 0 ? positiveRanks : negativeRanks;\n const pos = ranks.indexOf(Math.floor(d.attrProperties[attrKey].value * 100) / 100);\n const percentile = Math.round((pos / ranks.length) * 100);\n const newValue = d.attrProperties[attrKey].value < 0\n ? percentile - (percentile * 2)\n : percentile;\n d.attrProperties[attrKey].value = newValue;\n }\n });\n }\n\n let scaleDomain = d3.extent(dataset, (d) => Number(d.attrProperties[attrKey].value));\n if (scaleDomain[0] === 0 && scale && scale.indexOf('log') !== '-1') {\n scaleDomain = d3.extent(\n dataset.filter((v) => Number(v.attrProperties[attrKey].value) !== 0),\n (d) => Number(d.attrProperties[attrKey].value),\n );\n }\n if (attrValue.transform) {\n scaleDomain[0] = attrValue.transform\n .bind(this.maptable)(scaleDomain[0], this.maptable.data);\n scaleDomain[1] = attrValue.transform\n .bind(this.maptable)(scaleDomain[1], this.maptable.data);\n }\n\n let minValue = attrValue.min;\n let maxValue = attrValue.max;\n\n if (attrValue.min === 'minValue') {\n minValue = scaleDomain[0];\n }\n if (attrValue.max === 'maxValue') {\n maxValue = scaleDomain[1];\n }\n\n // check for negative color declarations\n if ((attrValue.maxNegative && !attrValue.minNegative)\n || (!attrValue.maxNegative && attrValue.minNegative)) {\n throw new Error('MapTable: maxNegative or minNegative undefined. Please declare both.');\n }\n const useNegative = (attrValue.maxNegative && attrValue.minNegative);\n let scaleFunction;\n let scaleNegativeFunction;\n\n if (useNegative) {\n scaleFunction = scaleToUse.copy()\n .domain([0, scaleDomain[1]])\n .range([minValue, maxValue]);\n scaleNegativeFunction = scaleToUse.copy()\n .domain([scaleDomain[0], 0])\n .range([attrValue.maxNegative, attrValue.minNegative]);\n } else {\n scaleFunction = scaleToUse\n .domain(scaleDomain)\n .range([minValue, maxValue]);\n }\n\n dataset.forEach((d) => {\n let scaledValue;\n if (!d.values.length || Number.isNaN(d.attrProperties[attrKey].value)) {\n if (typeof (attrValue.empty) === 'undefined') {\n throw new Error(`MapTable: no empty property found for attr.${attrKey}`);\n }\n scaledValue = attrValue.empty;\n } else {\n const originalValueRaw = d.attrProperties[attrKey].value;\n const originalValue = (attrValue.transform)\n ? attrValue.transform.bind(this.maptable)(originalValueRaw, this.maptable.data)\n : originalValueRaw;\n\n if (useNegative && originalValue < 0) {\n scaledValue = scaleNegativeFunction(originalValue);\n } else {\n scaledValue = scaleFunction(originalValue);\n }\n }\n d.attr[attrKey] = scaledValue;\n });\n } else {\n throw new Error(`Maptable: Invalid value for ${attrKey}`);\n }\n }\n\n render() {\n if (this.options.markers) this.updateMarkers();\n if (this.options.countries) this.updateCountries();\n if (this.options.night) this.updateNight();\n if (this.options.timezones) this.updateTimezones();\n if (this.options.title) this.updateTitle();\n if (this.options.heatmap) this.updateHeatmap();\n if (this.options.autoFitContent) {\n this.fitContent();\n this.rescale();\n }\n // On render\n if (this.options.onRender && this.options.onRender.constructor === Function) {\n this.options.onRender.bind(this.maptable)();\n }\n }\n\n updateTitle() {\n if (this.options.title.content) {\n const showing = this.maptable.data.filter((d) => d[this.options.latitudeKey] !== 0).length;\n const total = this.maptable.rawData.filter((d) => d[this.options.latitudeKey] !== 0).length;\n\n let inlineFilters = '';\n if (this.maptable.filters) {\n inlineFilters = this.maptable.filters.getDescription();\n }\n\n this.container.querySelector('#mt-map-title').innerHTML = this.options.title\n .content.bind(this.maptable)(\n showing,\n total,\n inlineFilters,\n this.maptable.data,\n this.maptable.rawData,\n this.dataCountries,\n );\n }\n }\n\n activateTooltip(target, tooltipNode, tooltipContent, isCountry) {\n const self = this;\n target.on(isCountry ? 'mousemove' : 'mouseover', function (d) {\n const content = tooltipContent.bind(this.maptable)(d);\n if (!content) return;\n tooltipNode.html(content).attr('style', 'display:block;position:fixed;');\n\n let mouseLeft;\n let mouseTop;\n const tooltipDelta = tooltipNode.node().offsetWidth / 2;\n if (isCountry) {\n const mapRect = self.node.getBoundingClientRect();\n const mousePosition = d3.mouse(self.svg.node()).map((v) => parseInt(v, 10));\n\n mouseLeft = mapRect.left + mousePosition[0] - tooltipDelta;\n mouseTop = mapRect.top + mousePosition[1] + 10;\n } else {\n const targetRect = this.getBoundingClientRect();\n mouseLeft = (targetRect.left + (targetRect.width / 2) - tooltipDelta);\n mouseTop = (targetRect.top + targetRect.height + 2); // +2 is for the border\n }\n\n tooltipNode.attr(\n 'style',\n `top:${mouseTop}px;left:${mouseLeft}px;display:block;position:fixed;`,\n )\n .on('mouseout', () => {\n tooltipNode.style('display', 'none');\n });\n })\n .on('mouseout', () => {\n tooltipNode.style('display', 'none');\n });\n }\n\n exportSvg() {\n // Get the d3js SVG element\n const svg = this.container.querySelector('#mt-map-svg');\n // Extract the data as SVG text string\n const svgXml = `\n${(new XMLSerializer()).serializeToString(svg)}`;\n\n if (this.options.exportSvgClient) {\n if (!window.saveAs) {\n throw new Error('MapTable: Missing FileSaver.js library');\n }\n const blob = new Blob([svgXml], { type: 'image/svg+xml' });\n window.saveAs(blob, 'visualization.svg');\n } else if (this.options.exportSvg) {\n const form = this.node.querySelector('#mt-map-svg-form');\n form.querySelector('[name=\"data\"]').value = svgXml;\n form.submit();\n }\n }\n\n addExportSvgCapability() {\n const exportNode = document.createElement('div');\n exportNode.setAttribute('id', 'mt-map-export');\n this.container.querySelector('#mt-map').appendChild(exportNode);\n\n const exportButton = document.createElement('button');\n exportButton.setAttribute('class', 'btn btn-xs btn-default');\n exportButton.innerHTML = 'Download';\n exportButton.addEventListener('click', this.exportSvg.bind(this));\n exportNode.appendChild(exportButton);\n\n if (this.options.exportSvg) {\n const exportForm = document.createElement('div');\n exportForm.innerHTML = `
`;\n exportNode.appendChild(exportForm);\n }\n }\n}\n","import utils from '../utils';\n\nexport default class Filters {\n constructor(maptable, options) {\n this.maptable = maptable;\n this.options = options;\n this.criteria = [];\n\n if (this.options.show) {\n const arrayDiff = this.options.show\n .filter((i) => Object.keys(this.maptable.columnDetails).indexOf(i) < 0);\n if (arrayDiff.length > 0) {\n throw new Error(`MapTable: invalid columns \"${arrayDiff.join(', ')}\"`);\n }\n this.activeColumns = this.options.show;\n } else {\n this.activeColumns = Object.keys(this.maptable.columnDetails);\n }\n\n this.container = document.createElement('div');\n this.maptable.node.appendChild(this.container);\n\n this.containerSelector = maptable.options.target;\n this.container = document.querySelector(maptable.options.target);\n this.node = this.container.querySelector('#mt-filters');\n\n if (!this.node) {\n this.node = document.createElement('div');\n this.node.setAttribute('id', 'mt-filters');\n this.node.setAttribute('class', 'panel panel-default');\n this.maptable.node.appendChild(this.node);\n }\n\n // -- Filters Header\n\n const filtersHeaderNode = document.createElement('div');\n filtersHeaderNode.setAttribute('class', 'panel-heading');\n\n const filtersResetNode = document.createElement('button');\n filtersResetNode.setAttribute('id', 'mt-filters-reset');\n filtersResetNode.setAttribute('class', 'btn btn-default btn-xs pull-right');\n filtersResetNode.style.display = 'none';\n filtersResetNode.style.marginLeft = 5;\n filtersResetNode.innerText = '↺ Reset';\n filtersResetNode.addEventListener('click', this.reset);\n filtersHeaderNode.appendChild(filtersResetNode);\n\n const filtersTitleNode = document.createElement('h3');\n filtersTitleNode.setAttribute('class', 'panel-title');\n filtersTitleNode.appendChild(document.createTextNode('Filters'));\n filtersHeaderNode.appendChild(filtersTitleNode);\n\n this.node.appendChild(filtersHeaderNode);\n\n // -- Filters Content\n const filtersBodyNode = document.createElement('div');\n filtersBodyNode.setAttribute('id', 'mt-filters-content');\n filtersBodyNode.setAttribute('class', 'panel-body');\n\n const filtersElementsNode = document.createElement('div');\n filtersElementsNode.setAttribute('id', 'mt-filters-elements');\n filtersBodyNode.appendChild(filtersElementsNode);\n\n const filtersNewNode = document.createElement('a');\n filtersNewNode.setAttribute('id', 'mt-filters-new');\n filtersNewNode.setAttribute('href', '#');\n filtersNewNode.innerText = '+ New filter';\n filtersNewNode.addEventListener('click', this.add.bind(this));\n filtersBodyNode.appendChild(filtersNewNode);\n\n this.node.appendChild(filtersBodyNode);\n }\n\n /**\n * Add a filter\n * @param evt: Window Event Object\n */\n add(evt) {\n if (evt) evt.preventDefault();\n const possibleFilters = this.getPossibleFilters();\n\n if (possibleFilters.length === 0) {\n return;\n }\n const filterName = possibleFilters[0].key;\n this.create(filterName);\n }\n\n create(filterName, replaceNode) {\n const rowNode = this.buildRow(filterName);\n if (replaceNode) {\n replaceNode.parentNode.replaceChild(rowNode, replaceNode);\n } else {\n this.node.querySelector('#mt-filters-elements').appendChild(rowNode);\n }\n this.criteria.push(filterName);\n this.maptable.render();\n if (this.container.style.display === 'none') {\n this.toggle();\n }\n }\n\n remove(filterName) {\n const rowNode = this.node.querySelector(`[data-mt-filter-name=\"${filterName}\"]`);\n if (rowNode) rowNode.parentNode.removeChild(rowNode);\n const filterIndex = this.criteria.indexOf(filterName);\n this.criteria.splice(filterIndex, 1);\n this.maptable.render();\n }\n\n /**\n * Reset filters\n */\n reset() {\n const rowNodes = this.node.querySelectorAll('[data-mt-filter-name]');\n for (let i = 0; i < rowNodes.length; i += 1) {\n rowNodes[i].parentNode.removeChild(rowNodes[i]);\n }\n this.criteria = [];\n this.maptable.render();\n }\n\n /**\n * Export the current filters to an object\n * @returns exportedFilters: Object - key => value that contain data about the current filters\n */\n exportFilters() {\n const output = {};\n const filtersChildren = this.node.querySelector('#mt-filters-elements').childNodes;\n\n for (let i = 0; i < filtersChildren.length; i += 1) {\n const element = filtersChildren[i];\n const filterName = element.querySelector('.mt-filter-name').value;\n const columnDetails = this.maptable.columnDetails[filterName];\n const filterOutput = [columnDetails.filterMethod];\n if (columnDetails.filterMethod === 'compare') {\n const filterRangeSelect = element.querySelector('.mt-filter-range');\n filterOutput[1] = filterRangeSelect.value;\n if (filterRangeSelect.value !== 'any') {\n if (filterRangeSelect.value === 'BETWEEN') {\n const filterValueMin = element.querySelector('.mt-filter-value-min').value;\n const filterValueMax = element.querySelector('.mt-filter-value-max').value;\n if (filterValueMin !== '' && filterValueMax === '') {\n filterOutput[2] = filterValueMin;\n filterOutput[3] = filterValueMax;\n }\n } else {\n const filterValue = element.querySelector('.mt-filter-value-min').value;\n filterOutput[2] = filterValue;\n }\n }\n } else if (columnDetails.filterMethod === 'field'\n || columnDetails.filterMethod === 'dropdown') {\n filterOutput[1] = '';\n const filterValue = element.querySelector('.mt-filter-value').value;\n filterOutput[2] = filterValue;\n }\n if (filterOutput[1] !== 'any' && filterOutput[2] && filterOutput[2] !== '') {\n output[filterName] = filterOutput;\n }\n }\n return output;\n }\n\n /**\n * Set the value for the current filters\n * @param criteria - Object - same format as the exportedFilters\n */\n setFilters(criteria) {\n this.reset();\n Object.keys(criteria).forEach((filterName) => {\n this.create(filterName);\n const criterion = criteria[filterName];\n const row = document\n .querySelector(`#mt-filters-elements [data-mt-filter-name=\"${filterName}\"]`);\n if (row) {\n if (criterion[0] === 'compare') {\n row.querySelector('.mt-filter-range').value = criterion[1];\n if (criterion[1] !== 'any') {\n if (criterion[1] === 'BETWEEN') {\n row.querySelector('.mt-filter-value-min').value = criterion[2];\n row.querySelector('.mt-filter-value-max').value = criterion[3];\n } else {\n row.querySelector('.mt-filter-value-min').value = criterion[2];\n }\n }\n } else if (criterion[0] === 'field' || criterion[0] === 'dropdown') {\n row.querySelector('.mt-filter-value').value = decodeURIComponent(criterion[2]);\n }\n }\n });\n this.maptable.render();\n }\n\n /**\n * Restore state from the URL hash\n */\n restoreState(defaultCriteria) {\n if (!defaultCriteria) return;\n this.setFilters(defaultCriteria);\n }\n\n /**\n * Get a human readable description of the filters (used for the title)\n * @returns {string} Human readable description\n */\n getDescription() {\n const outputArray = [];\n\n const filtersChildren = this.node.querySelector('#mt-filters-elements').childNodes;\n\n for (let i = 0; i < filtersChildren.length; i += 1) {\n const element = filtersChildren[i];\n const filterName = element.querySelector('.mt-filter-name').value;\n\n const columnDetails = this.maptable.columnDetails[filterName];\n\n let line = '';\n\n if (columnDetails.filterMethod === 'compare') {\n const filterRangeSelect = element.querySelector('.mt-filter-range');\n if (filterRangeSelect.value !== 'any') {\n if (filterRangeSelect.value === 'BETWEEN') {\n const filterValueMin = element.querySelector('.mt-filter-value-min').value;\n const filterValueMax = element.querySelector('.mt-filter-value-max').value;\n if (filterValueMin === '' || filterValueMax === '') continue;\n line += `${columnDetails.title} is between `;\n line += `${filterValueMin} and\n ${filterValueMax}`;\n } else {\n const filterValue = element.querySelector('.mt-filter-value-min').value;\n if (filterValue === '') continue;\n line += `${columnDetails.title} is `;\n line += filterRangeSelect.options[filterRangeSelect.selectedIndex].text;\n line += `${filterValue}`;\n }\n }\n } else if (columnDetails.filterMethod === 'field'\n || columnDetails.filterMethod === 'dropdown') {\n const filterValue = element.querySelector('.mt-filter-value').value;\n if (filterValue === '') continue;\n const separatorWord = (columnDetails.filterMethod === 'field') ? 'contains' : 'is';\n line += `${columnDetails.title} ${separatorWord}\n ${filterValue}`;\n }\n outputArray.push(line);\n }\n return outputArray.join(', ');\n }\n\n buildRow(filterName) {\n const that = this;\n\n const possibleFilters = this.getPossibleFilters();\n\n const columnDetails = this.maptable.columnDetails[filterName];\n\n const rowNode = document.createElement('div');\n rowNode.setAttribute('class', 'mt-filter-row');\n rowNode.setAttribute('data-mt-filter-name', filterName);\n\n // Button to remove filter\n const minusButton = document.createElement('button');\n minusButton.setAttribute('class', 'btn btn-default pull-right');\n minusButton.setAttribute('data-mt-filter-btn-minus', 1);\n minusButton.innerText = '– Remove this filter';\n minusButton.addEventListener('click', () => {\n filterName = rowNode.querySelector('.mt-filter-name').value;\n this.remove(filterName);\n });\n rowNode.appendChild(minusButton);\n\n // Filters separator \"AND\"\n const filterSeparator = document.createElement('span');\n filterSeparator.setAttribute('class', 'mt-filters-and');\n filterSeparator.innerText = 'And ';\n rowNode.appendChild(filterSeparator);\n\n // Filter name select\n const filterNameSelect = document.createElement('select');\n filterNameSelect.setAttribute('class', 'mt-filter-name form-control form-control-inline');\n utils.appendOptions(\n filterNameSelect,\n possibleFilters.map((f) => ({ text: f.title, value: f.key })),\n );\n filterNameSelect.value = filterName;\n\n filterNameSelect.addEventListener('change', function () {\n const oldFilterName = this.parentNode.getAttribute('data-mt-filter-name');\n const newFilterName = this.value;\n that.create(newFilterName, this.parentNode);\n that.remove(oldFilterName);\n that.refresh();\n });\n rowNode.appendChild(filterNameSelect);\n\n // Filter verb\n const filterVerb = document.createElement('span');\n filterVerb.innerText = (columnDetails.filterMethod === 'field') ? ' contains ' : ' is ';\n rowNode.appendChild(filterVerb);\n\n // Filter range\n let filterRange = null;\n if (columnDetails.filterMethod !== 'field' && columnDetails.filterMethod !== 'dropdown') {\n filterRange = document.createElement('select');\n filterRange.setAttribute('class', 'mt-filter-range form-control form-control-inline');\n utils.appendOptions(filterRange, ['any', '=', '≠', '<', '>', '≤', '≥', 'BETWEEN'].map((v) => ({ text: v, value: v })));\n filterRange.addEventListener('change', function () {\n that.handleRangeChange(this);\n });\n rowNode.appendChild(filterRange);\n\n // Little space:\n rowNode.appendChild(document.createTextNode(' '));\n }\n\n // Filter value\n const filterValue = document.createElement('div');\n filterValue.style.display = 'inline-block';\n filterValue.setAttribute('class', 'mt-filter-value-container');\n\n if (columnDetails.filterMethod === 'compare') {\n ['min', 'max'].forEach((val, i) => {\n const filterInput = document.createElement('input');\n filterInput.setAttribute(\n 'class',\n `form-control form-control-inline mt-filter-value-${val}`,\n );\n filterInput.setAttribute('type', columnDetails.filterInputType);\n filterInput.addEventListener('keyup', this.maptable.render.bind(this.maptable));\n filterInput.addEventListener('change', this.maptable.render.bind(this.maptable));\n filterValue.appendChild(filterInput);\n if (i === 0) {\n // AND\n const filterValueAnd = document.createElement('span');\n filterValueAnd.setAttribute('class', 'mt-filter-value-and');\n filterValueAnd.innerText = ' and ';\n filterValue.appendChild(filterValueAnd);\n }\n });\n } else if (columnDetails.filterMethod === 'field') {\n const filterInput = document.createElement('input');\n filterInput.setAttribute('class', 'form-control form-control-inline mt-filter-value');\n filterInput.setAttribute('type', 'text');\n filterInput.addEventListener('keyup', this.maptable.render.bind(this.maptable));\n filterInput.addEventListener('change', this.maptable.render.bind(this.maptable));\n filterValue.appendChild(filterInput);\n } else if (columnDetails.filterMethod === 'dropdown') {\n const filterSelect = document.createElement('select');\n filterSelect.setAttribute('class', 'form-control form-control-inline mt-filter-value');\n\n const uniqueValues = d3.nest().key((d) => d[filterName])\n .sortKeys(d3.ascending)\n .entries(this.maptable.rawData);\n\n utils.appendOptions(filterSelect, [{ text: 'Any', value: '' }].concat(uniqueValues.map((k) => ({ text: k.key, value: k.key }))));\n\n filterSelect.addEventListener('change', this.maptable.render.bind(this.maptable));\n filterValue.appendChild(filterSelect);\n }\n\n rowNode.appendChild(filterValue);\n\n // We trigger it here to handle the value of the filter range\n if (filterRange) {\n this.handleRangeChange(filterRange);\n }\n\n return rowNode;\n }\n\n handleRangeChange(filterRange) {\n const rowNode = filterRange.parentNode;\n if (filterRange.value === 'any') {\n rowNode.querySelector('.mt-filter-value-container').style.display = 'none';\n } else {\n rowNode.querySelector('.mt-filter-value-container').style.display = 'inline-block';\n if (filterRange.value === 'BETWEEN') {\n rowNode.querySelector('.mt-filter-value-min').style.display = 'inline-block';\n rowNode.querySelector('.mt-filter-value-and').style.display = 'inline-block';\n rowNode.querySelector('.mt-filter-value-max').style.display = 'inline-block';\n } else {\n rowNode.querySelector('.mt-filter-value-min').style.display = 'inline-block';\n rowNode.querySelector('.mt-filter-value-and').style.display = 'none';\n rowNode.querySelector('.mt-filter-value-max').style.display = 'none';\n }\n }\n this.maptable.render.bind(this.maptable)();\n }\n\n getPossibleFilters(except) {\n return Object.keys(this.maptable.columnDetails)\n .map((k) => utils.extendRecursive({ key: k }, this.maptable.columnDetails[k]))\n .filter((v) => (this.activeColumns.indexOf(v.key) !== -1)\n && (\n (except && except === v.key)\n || (this.criteria.indexOf(v.key) === -1 && v.filterMethod && !v.isVirtual)\n ));\n }\n\n filterData() {\n const that = this;\n this.maptable.data = this.maptable.rawData.filter((d) => {\n const rowNodes = this.node.querySelectorAll('.mt-filter-row');\n let matched = true;\n for (let i = 0; i < rowNodes.length && matched; i += 1) {\n const rowNode = rowNodes[i];\n const filterName = rowNode.getAttribute('data-mt-filter-name');\n const columnDetails = that.maptable.columnDetails[filterName];\n const fmt = columnDetails.dataParse; // shortcut\n\n if (columnDetails.filterMethod === 'dropdown') {\n const filterValue = rowNode.querySelector('.mt-filter-value').value;\n if (filterValue === '') continue;\n if (d[filterName] !== filterValue) matched = false;\n } else if (columnDetails.filterMethod === 'field') {\n const filterValue = rowNode.querySelector('.mt-filter-value').value;\n if (filterValue === '') continue;\n if (d[filterName].toLowerCase().indexOf(filterValue.toLowerCase()) === -1) {\n matched = false;\n }\n } else if (columnDetails.filterMethod === 'compare') {\n const filterRange = rowNode.querySelector('.mt-filter-range').value;\n if (filterRange === 'BETWEEN') {\n const filterValueMin = rowNode.querySelector('.mt-filter-value-min').value;\n const filterValueMax = rowNode.querySelector('.mt-filter-value-max').value;\n if (filterValueMin === '' || filterValueMax === '') continue;\n if (fmt\n && (fmt(d[filterName]) < fmt(filterValueMin)\n || fmt(d[filterName]) > fmt(filterValueMax))\n ) {\n matched = false;\n } else if (\n parseInt(d[filterName], 10) < parseInt(filterValueMin, 10)\n || parseInt(d[filterName], 10) > parseInt(filterValueMax, 10)\n ) {\n matched = false;\n }\n } else {\n const filterValue = rowNode.querySelector('.mt-filter-value-min').value;\n if (filterValue === '') continue;\n if (fmt && !utils.rangeToBool(fmt(d[filterName]), filterRange, fmt(filterValue))) {\n matched = false;\n } else if (!fmt && !utils.rangeToBool(d[filterName], filterRange, filterValue)) {\n matched = false;\n }\n }\n }\n\n if ((fmt && utils.isBlank(fmt(d[filterName]))) || utils.isBlank(d[filterName])) {\n matched = false;\n continue;\n }\n }\n return matched;\n });\n // save state\n if (this.options.saveState) this.maptable.saveState('filters', this.exportFilters());\n }\n\n refresh() {\n // update dropdown\n const filterNameSelects = this.node.querySelectorAll('.mt-filter-name');\n for (let i = 0; i < filterNameSelects.length; i += 1) {\n const filterNameSelect = filterNameSelects[i];\n const filterName = filterNameSelect.value;\n const possibleFilters = this.getPossibleFilters(filterName);\n filterNameSelect.innerHTML = '';\n utils.appendOptions(\n filterNameSelect,\n possibleFilters.map((f) => ({ text: f.title, value: f.key })),\n );\n filterNameSelect.value = filterName;\n }\n\n // Hide the first \"And\"\n if (this.node.querySelectorAll('.mt-filters-and').length > 0) {\n this.node.querySelectorAll('.mt-filters-and')[0].style.visibility = 'hidden';\n }\n\n // Check if we reached the maximum of allowed filters\n const disableNewFilter = (!this.getPossibleFilters().length);\n this.node.querySelector('#mt-filters-new').style.visibility = disableNewFilter\n ? 'hidden' : 'visible';\n }\n\n toggle() {\n if (this.container.style.display === 'none') {\n this.container.style.display = 'block';\n if (this.criteria.length === 0) {\n this.add();\n }\n } else {\n this.container.style.display = 'none';\n }\n }\n}\n","import utils from '../utils';\n\nexport default class Table {\n /**\n * Table componenet constructor\n * @param maptable: Maptable main Object\n * @param options: options communicated to the table\n * @returns {string|*}\n */\n constructor(maptable, options) {\n this.maptable = maptable;\n this.options = options;\n if (this.options.defaultSorting) {\n if (Array.isArray(this.options.defaultSorting) && this.options.defaultSorting.length === 2) {\n this.sorting = this.options.defaultSorting;\n } else {\n this.sorting = [this.options.defaultSorting];\n }\n this.sorting.forEach((s) => {\n if (!s.mode) s.mode = 'asc';\n });\n } else {\n this.sorting = [\n {\n key: Object.keys(this.maptable.data[0])[0],\n mode: 'asc',\n },\n ];\n }\n\n this.initialSorting = this.sorting.map((s) => `${s.key},${s.mode}`).join(';');\n this.isSorting = false;\n\n this.containerSelector = maptable.options.target;\n this.container = document.querySelector(maptable.options.target);\n\n this.node = this.container.querySelector('#mt-table');\n\n if (!this.node) {\n this.node = document.createElement('div');\n this.node.setAttribute('id', 'mt-table');\n this.maptable.node.appendChild(this.node);\n }\n\n this.node = d3.select(this.node).append('table').attr('class', this.options.className);\n\n this.header = this.node.append('thead');\n\n this.body = this.node.append('tbody');\n\n if (this.options.show) {\n const arrayDiff = this.options.show.filter((i) => Object.keys(this.maptable.columnDetails).indexOf(i) < 0);\n if (arrayDiff.length > 0) {\n throw new Error(`MapTable: invalid columns \"${arrayDiff.join(', ')}\"`);\n }\n this.activeColumns = this.options.show;\n } else {\n this.activeColumns = Object.keys(this.maptable.columnDetails);\n }\n\n // make table header fixed\n if (this.options.header) {\n if (this.options.header.className) {\n this.header.attr('class', `${this.options.header.className}`);\n }\n\n // set custom top header space\n if (this.options.header.top) {\n this.header.attr('style', `top:${this.options.header.top || '0'}px;`);\n } else {\n this.header.attr('style', 'top:0px;');\n }\n }\n\n this.header\n .selectAll('tr')\n .data([1])\n .enter()\n .append('tr')\n .selectAll('th')\n .data(this.activeColumns.map((k) => utils.extendRecursive({ key: k }, this.maptable.columnDetails[k])))\n .enter()\n .append('th')\n .attr('class', (d) => {\n let output = d.sorting ? 'mt-table-sortable' : '';\n output += d.nowrap ? ' nowrap' : '';\n return output;\n })\n .attr('data-key', (d) => utils.sanitizeKey(d.key))\n .attr('onselectstart', 'return false;')\n .attr('unselectable', 'on')\n .attr('style', (d) => (d.nowrap ? 'white-space:nowrap;' : ''))\n .on('click', (d) => {\n if (this.isSorting) return;\n this.isSorting = true;\n if (d.sorting) {\n this.sortColumn(d.key);\n }\n this.isSorting = false;\n })\n .text((d) => d.title)\n .attr('id', (d) => `column_header_${utils.sanitizeKey(d.key)}`);\n\n // render is triggered by MapTable\n // this.render();\n }\n\n /**\n * Restore state from the url hash\n */\n restoreState(sortingRaw) {\n if (!sortingRaw) return;\n const sortingList = sortingRaw.split(';');\n const defaultSorting = [];\n sortingList.forEach((s) => {\n const sortingData = s.split(',');\n defaultSorting.push({\n key: sortingData[0],\n mode: sortingData[1] || 'asc',\n });\n });\n this.sorting = defaultSorting;\n }\n\n /**\n * Save state into the url hash\n */\n saveState() {\n const encodedSorting = this.sorting.map((s) => `${s.key},${s.mode}`).join(';');\n if (encodedSorting !== this.initialSorting) {\n this.maptable.saveState('sort', encodedSorting);\n }\n }\n\n render() {\n // Apply Sort\n this.applySort();\n\n let tableData = this.maptable.data;\n if (this.options.distinctBy) {\n tableData = d3\n .nest()\n .key((d) => d[this.options.distinctBy])\n .entries(this.maptable.data)\n .map((g) => g.values[0]);\n }\n\n // Enter\n this.body.selectAll('tr').data(tableData).enter().append('tr');\n\n // Exit\n this.body.selectAll('tr').data(tableData).exit().remove();\n\n // Update\n const uniqueCollapsedRows = [];\n this.body\n .selectAll('tr')\n .data(tableData)\n .attr('class', (row) => {\n if (this.options.rowClassName) {\n return `line ${this.options.rowClassName(row)}`;\n }\n return 'line';\n })\n .html((row) => {\n let tds = '';\n this.activeColumns.forEach((columnKey) => {\n const column = this.maptable.columnDetails[columnKey];\n tds += ' {\n this.container.querySelector(`#column_header_${utils.sanitizeKey(column.key)}`).setAttribute('class', `mt-table-sortable sort_${column.mode}`);\n });\n this.maptable.data = this.maptable.data.sort((a, b) => {\n let compareBool = false;\n this.sorting.forEach((column) => {\n const d3SortMode = column.mode === 'asc' ? d3.ascending : d3.descending;\n const columnDetails = this.maptable.columnDetails[column.key];\n let el1 = a[column.key];\n let el2 = b[column.key];\n if (columnDetails.dataParse) {\n el1 = columnDetails.dataParse.bind(this.maptable)(el1);\n el2 = columnDetails.dataParse.bind(this.maptable)(el2);\n } else if (columnDetails.virtual) {\n el2 = columnDetails.virtual.bind(this.maptable)(a);\n el2 = columnDetails.virtual.bind(this.maptable)(b);\n } else if (columnDetails.filterType === 'compare') {\n el1 = Number(el1);\n el2 = Number(el2);\n }\n\n if (typeof el1 === 'string' && typeof el2 === 'string') {\n el1 = el1.toLowerCase();\n el2 = el2.toLowerCase();\n }\n compareBool = compareBool || d3SortMode(el1, el2);\n });\n return compareBool;\n });\n }\n\n /**\n * Sort Table by a column key\n * @param columnKey: String - column key\n */\n sortColumn(key) {\n const sortIndex = this.sorting.map((d) => d.key).indexOf(key);\n const sortValue = { key };\n if (sortIndex === -1) {\n sortValue.mode = 'desc';\n if (d3.event && d3.event.shiftKey) {\n this.sorting[1] = sortValue;\n } else {\n this.sorting = [sortValue];\n }\n } else {\n if (this.sorting[sortIndex].mode === 'asc') {\n this.sorting[sortIndex].mode = 'desc';\n } else {\n this.sorting[sortIndex].mode = 'asc';\n // this.sorting.splice(sortIndex, 1); // to disable sorting\n }\n if (!d3.event.shiftKey) {\n this.sorting = [this.sorting[sortIndex]];\n }\n }\n\n this.saveState();\n this.render();\n }\n}\n","import utils from './utils';\n\nimport GeoMap from './components/GeoMap';\nimport Filters from './components/Filters';\nimport Table from './components/Table';\n\nexport default class MapTable {\n constructor(target, options) {\n this.options = options;\n\n this.state = {};\n this.saveStateTimeout = {};\n this.removeStateTimeout = null;\n\n this.node = document.querySelector(target);\n this.node.setAttribute('style', 'position:relative;');\n\n if (this.options.data.type === 'json') {\n d3.json(this.options.data.path, this.loadData.bind(this));\n } else if (this.options.data.type === 'csv') {\n d3.csv(this.options.data.path, this.loadData.bind(this));\n } else if (this.options.data.type === 'tsv') {\n d3.tsv(this.options.data.path, this.loadData.bind(this));\n } else if (this.options.data.type === 'jsonData') {\n this.loadData(null, JSON.parse(this.options.data.value));\n } else if (this.options.data.type === 'csvData') {\n this.loadData(null, d3.csv.parse(this.options.data.value));\n } else if (this.options.data.type === 'tsvData') {\n this.loadData(null, d3.tsv.parse(this.options.data.value));\n } else if (this.options.data.type === 'data') {\n this.loadData(null, this.options.data.value);\n }\n\n if (this.options.map && this.options.map.heatmap) {\n delete this.options.map.countries;\n }\n }\n\n /**\n * Callback used when we pull the dataset\n * @param err: Error - error data if it happened\n * @param data: Object - dataset object\n */\n loadData(err, data) {\n if (err) {\n throw err;\n }\n this.rawData = data;\n\n if (this.options.data.preFilter) {\n this.rawData = this.rawData.filter(this.options.data.preFilter);\n }\n\n this.setColumnDetails();\n this.data = this.rawData.slice(); // we clone data, so that we can filter it\n // Map\n if (this.options.map) {\n // Map wrapper\n const mapWrapper = document.createElement('div');\n mapWrapper.setAttribute('class', 'mt-map-container');\n const isIE = (navigator.userAgent.indexOf('MSIE') !== -1 || navigator.appVersion.indexOf('Trident/') > 0);\n if (this.options.map.heatmap && isIE) {\n mapWrapper.innerHTML = '
The heatmap feature is not supported with Internet Explorer.
Please use another modern browser to see this map.
';\n this.node.insertBefore(mapWrapper, this.node.firstChild);\n mapWrapper.querySelector('.mt-loading').style.display = 'block';\n this.options.map = false;\n this.buildComponenents();\n return;\n }\n mapWrapper.innerHTML = '
Loading...
';\n this.node.insertBefore(mapWrapper, this.node.firstChild);\n mapWrapper.querySelector('.mt-loading').style.display = 'block';\n if (this.options.map.pathData) {\n this.loadMapData(null, JSON.parse(this.options.map.pathData), mapWrapper);\n } else if (this.options.map.path) {\n d3.json(this.options.map.path, (errGeoMap, jsonWorld) => {\n this.loadMapData(errGeoMap, jsonWorld, mapWrapper);\n });\n } else {\n throw new Error('missing map path|pathData');\n }\n } else {\n this.buildComponenents();\n }\n }\n\n loadMapData(errGeoMap, jsonWorld, mapWrapper) {\n if (errGeoMap) {\n throw errGeoMap;\n }\n this.map = new GeoMap(this, this.options.map, jsonWorld);\n\n mapWrapper.querySelector('.mt-loading').style.display = 'none';\n\n this.buildComponenents();\n }\n\n buildComponenents() {\n // Filters\n if (this.options.filters) {\n this.filters = new Filters(this, this.options.filters);\n }\n\n // Table\n if (this.options.table) {\n this.table = new Table(this, this.options.table);\n }\n\n // Restore state\n this.restoreState();\n window.addEventListener('hashchange', () => {\n this.restoreState();\n });\n\n // Render\n this.render();\n }\n\n /**\n * Load state from url\n * @param stateName: name of the state (either filters or zoom)\n * @param isJson: do we need to decode a json from the state?\n * @return loaded state\n */\n loadState(stateName, isJson) {\n // JSON state\n if (isJson) {\n const v = this.parseState(stateName);\n if (!v) return null;\n try {\n const parsedState = JSON.parse(v);\n this.state[stateName] = parsedState;\n } catch (e) {\n console.log(`Maptable: Invalid URL State for mt-${stateName} ${e.message}`);\n return null;\n }\n } else {\n const v = this.parseState(stateName);\n if (v) this.state[stateName] = v;\n }\n return this.state[stateName];\n }\n\n /**\n * Restore state for filters or/and map zooming and/or sorting\n */\n restoreState() {\n if (this.map) {\n this.loadState('zoom', true);\n this.map.restoreState(this.state.zoom);\n }\n\n if (this.filters) {\n this.loadState('filters', true);\n this.filters.restoreState(this.state.filters);\n }\n\n if (this.table) {\n this.loadState('sort', false);\n this.table.restoreState(this.state.sort);\n }\n }\n\n /**\n * Extract state from the url\n * @param stateName: name of the state (either filters or zoom)\n */\n parseState(stateName) {\n const params = document.location.href.replace(/%21mt/g, '!mt').split(`!mt-${stateName}=`);\n return (params[1]) ? decodeURIComponent(params[1].split('!mt')[0]) : null;\n }\n\n /**\n * Remove state\n * @param stateName: name of the state (either filters or zoom)\n */\n removeState(stateName) {\n window.clearTimeout(this.saveStateTimeout[stateName]);\n delete this.state[stateName];\n this.updateState();\n }\n\n /**\n * Save the state in this.state\n * @param stateName: name of the state (either filters or zoom)\n * @param stateData: object, contain state information\n */\n saveState(stateName, stateData) {\n window.clearTimeout(this.saveStateTimeout[stateName]);\n this.saveStateTimeout[stateName] = window.setTimeout(() => {\n this.state[stateName] = stateData;\n this.updateState();\n }, 200);\n }\n\n /**\n * Update state into the URL hash\n */\n updateState() {\n const newUrl = document.location.href.split('#')[0];\n let stateHash = '';\n Object.keys(this.state).forEach((k) => {\n if (!this.state[k]) return;\n let stateValue = this.state[k];\n if (typeof (this.state[k]) === 'object') {\n if (!Object.keys(this.state[k]).length) return;\n stateValue = JSON.stringify(this.state[k]);\n }\n stateHash += `!mt-${k}=${encodeURIComponent(stateValue)}`;\n });\n if (stateHash !== '') stateHash = `#${stateHash}`;\n if (document.location.href !== `${newUrl}${stateHash}`) {\n window.history.pushState(null, null, `${newUrl}${stateHash}`);\n }\n }\n\n render() {\n if (this.filters) {\n this.filters.filterData();\n this.filters.refresh();\n }\n\n if (this.map) {\n this.map.render();\n // On complete\n if (!this.firstExecution\n && this.options.map.onComplete\n && this.options.map.onComplete.constructor === Function\n ) {\n this.options.map.onComplete.bind(this)();\n }\n }\n\n if (this.table) {\n this.table.render();\n // On complete\n if (!this.firstExecution\n && this.options.table.onComplete\n && this.options.table.onComplete.constructor === Function\n ) {\n this.options.table.onComplete.bind(this)();\n }\n }\n\n // On complete\n if (!this.firstExecution\n && this.options.onComplete\n && this.options.onComplete.constructor === Function\n ) {\n this.options.onComplete.bind(this)();\n }\n this.firstExecution = true;\n }\n\n setColumnDetails() {\n const that = this;\n if (that.rawData.length === 0) {\n return;\n }\n const defaultColumns = {};\n\n Object.keys(that.rawData[0]).forEach((k) => {\n const patternNumber = /^[-+]?[0-9]*\\.?[0-9]+([eE][-+]?[0-9]+)?$/;\n const isNumber = (patternNumber.test(that.rawData[0][k]));\n defaultColumns[k] = {\n title: utils.keyToTile(k),\n filterMethod: (isNumber) ? 'compare' : 'field',\n filterInputType: (isNumber) ? 'number' : 'text',\n sorting: true,\n };\n if (isNumber) {\n defaultColumns[k].dataParse = (val) => parseFloat(val);\n }\n });\n that.columnDetails = utils.extendRecursive(defaultColumns, this.options.columns);\n\n // add isVirtual to columns details\n Object.keys(that.columnDetails).forEach((k) => {\n that.columnDetails[k].isVirtual = (typeof (that.columnDetails[k].virtual) === 'function');\n });\n }\n}\n","/* eslint no-unused-vars: 0 */\nimport utils from './utils';\nimport defaultOptions from './defaultOptions';\nimport MapTable from './maptable';\n\nd3.maptable = function (target) {\n let maptableObject;\n const maptable = {};\n const options = {\n target,\n columns: {},\n data: {},\n map: null,\n filters: null,\n table: null,\n };\n\n maptable.map = function (mapOptions = {}) {\n if (!topojson) {\n throw new Error('Maptable requires topojson.js');\n }\n if (typeof mapOptions.path !== 'string' && typeof mapOptions.pathData !== 'string') {\n throw new Error('MapTable: map not provided');\n }\n options.map = mapOptions;\n return maptable;\n };\n\n maptable.data = function (data) {\n options.data.type = 'data';\n options.data.value = data;\n return maptable;\n };\n\n maptable.json = function (jsonPath, preFilter) {\n options.data.type = 'json';\n options.data.path = jsonPath;\n options.data.preFilter = preFilter;\n return maptable;\n };\n\n maptable.jsonData = function (jsonData) {\n options.data.type = 'jsonData';\n options.data.value = jsonData;\n return maptable;\n };\n\n maptable.csv = function (csvPath, preFilter) {\n options.data.type = 'csv';\n options.data.path = csvPath;\n options.data.preFilter = preFilter;\n return maptable;\n };\n\n maptable.csvData = function (csvData) {\n options.data.type = 'csvData';\n options.data.value = csvData;\n return maptable;\n };\n\n maptable.tsv = function (tsvPath, preFilter) {\n options.data.type = 'tsv';\n options.data.path = tsvPath;\n options.data.preFilter = preFilter;\n return maptable;\n };\n\n maptable.tsvData = function (tsvData) {\n options.data.type = 'tsvData';\n options.data.value = tsvData;\n return maptable;\n };\n\n maptable.filters = function (filtersOptions = {}) {\n options.filters = filtersOptions;\n return maptable;\n };\n\n maptable.table = function (tableOptions = {}) {\n options.table = tableOptions;\n return maptable;\n };\n\n maptable.columns = function (columns = {}) {\n options.columns = columns;\n return maptable;\n };\n\n maptable.render = function (onComplete) {\n if (typeof target !== 'string' || !document.querySelector(target)) {\n throw new Error('MapTable: target not found');\n }\n\n if (!options.data || !options.data.type) {\n throw new Error('MapTable: Please provide the path for your dataset data|json|jsonData|csv|csvData|tsv|tsvData');\n }\n\n if (options.map && !options.map.heatmap) options.map.heatmap = null;\n\n if (options.map && options.map.markers === false) options.map.markers = null;\n\n if (options.map && options.map.countries === false) options.map.countries = null;\n\n if (!options.filters) options.filters = null;\n options.onComplete = onComplete;\n\n const customOptions = utils.extendRecursive(defaultOptions, options);\n\n if (options.map && !options.map.markers) delete customOptions.map.markers;\n if (options.map && !options.map.heatmap) delete customOptions.map.heatmap;\n if (options.map && !options.map.title) delete customOptions.map.title;\n if (options.map && !options.map.timezones) delete customOptions.map.timezones;\n if (options.map && !options.map.night) delete customOptions.map.night;\n if (!options.filters) delete customOptions.filters;\n if (!options.table) delete customOptions.table;\n\n maptableObject = new MapTable(target, customOptions);\n\n // public functions\n return {\n render: () => maptableObject.render(),\n loadState: (stateName, isJson) => maptableObject.loadState(stateName, isJson),\n removeState: (stateName) => maptableObject.removeState(stateName),\n saveState: (stateName, stateData) => maptableObject.saveState(stateName, stateData),\n setTitleContent: (title) => {\n maptableObject.options.map.title.content = () => title;\n },\n setData: (data) => {\n maptableObject.options.data.type = 'data';\n maptableObject.options.data.value = data;\n maptableObject.options.rawData = data;\n maptableObject.rawData = data;\n maptableObject.data = data;\n if (maptableObject.map) {\n maptableObject.map.enrichData();\n }\n },\n setNightDate: (date) => {\n maptableObject.options.map.night.date = date;\n },\n setTimezonesDate: (date) => {\n maptableObject.options.map.timezones.date = date;\n },\n getMapWidth: () => maptableObject.map.getWidth(),\n getMapHeight: () => maptableObject.map.getHeight(),\n };\n };\n return maptable;\n};\n\nif (!d3) {\n throw new Error('Maptable requires d3.js');\n}\n\nexport default d3.maptable;\n"],"names":["appendOptions","select","options","defaultValue","forEach","f","option","document","createElement","setAttribute","value","innerText","text","appendChild","rangeToBool","el1","range","el2","parseInt","extendRecursive","dst","src","args","splice","call","arguments","toString","length","Object","keys","p","keyToTile","k","upperK","charAt","toUpperCase","slice","replace","sanitizeKey","toLowerCase","toNumber","str","resStr","Number","quantile","array","percentile","sort","a","b","index","result","Math","floor","i","fraction","uniqueValues","arr","l","indexOf","push","formatDate","d","zone","newDate","Date","getTime","toISOString","split","substr","isBlank","undefined","map","longitudeKey","latitudeKey","countryIdentifierKey","countryIdentifierType","zoom","saveState","exportSvg","exportSvgClient","ratioFromWidth","scaleHeight","scaleZoom","fitContentMargin","autoFitContent","tooltipClassName","countries","legend","attr","fill","stroke","heatmap","mask","weightByAttribute","weightByAttributeScale","circles","min","max","step","color","colorStrength","blur","borders","opacity","markers","r","title","fontSize","fontFamily","filters","table","className","collapseRowsBy","Legend","legendWidth","node","svg","append","getWidth","getHeight","buildIndice","domain","legendGradient","minNegative","maxNegative","midPercentNegative","round","midPercentPositive","indice","style","selectAll","toLocaleString","buildScale","val","isNaN","maxValue","minValue","positionDelta","position","width","height","padding","console","warn","window","btoa","buildWatermark","d3","xhr","res","mapWatermarkDelta","mime","x","y","dataUri","responseText","pos","mul_table","shg_table","processImage","img","canvas","radius","blurAlphaChannel","getElementById","HTMLImageElement","w","naturalWidth","h","naturalHeight","HTMLCanvasElement","context","getContext","clearRect","drawImage","processCanvasRGBA","processCanvasRGB","getImageDataFromCanvas","top_x","top_y","imageData","getImageData","e","Error","processImageDataRGBA","putImageData","pixels","data","yp","yi","yw","r_sum","g_sum","b_sum","a_sum","r_out_sum","g_out_sum","b_out_sum","a_out_sum","r_in_sum","g_in_sum","b_in_sum","a_in_sum","pr","pg","pb","pa","rbs","div","w4","widthMinus1","heightMinus1","radiusPlus1","sumFactor","stackStart","BlurStack","stack","next","stackEnd","stackIn","stackOut","mul_sum","shg_sum","g","processImageDataRGB","image","canvasRGBA","canvasRGB","imageDataRGBA","imageDataRGB","π","PI","radians","degrees","solarGeometricMeanAnomaly","centuries","solarGeometricMeanLongitude","solarEquationOfCenter","m","sin","solarTrueLongitude","solarApparentLongitude","meanObliquityOfEcliptic","obliquityCorrection","cos","solarDeclination","asin","eccentricityEarthOrbit","equationOfTime","tan","antipode","solarPosition","time","UTC","longitude","day","utc","GeoMap","maptable","jsonWorld","scale","transX","transY","containerSelector","target","container","querySelector","mapWrapper","existingMap","parentNode","insertBefore","removeChild","projection","geo","equirectangular","translate","rotate","precision","path","enrichData","zoomListener","behavior","scaleExtent","on","rescale","bind","tooltipMarkersNode","tooltipCountriesNode","layerGlobal","layerDefs","html","timezones","layerTimezones","layerCountries","night","layerNight","layerHeatmap","layerMarkers","watermark","Watermark","buildTitle","addExportSvgCapability","addEventListener","loadGeometries","rawData","parseFloat","latitude","coord","pow","offsetWidth","deltaHeight","filterCountries","objects","geometries","filter","buildCountries","buildHeatmap","buildNight","pathData","buildTimezone","lands","topojson","merge","disableMask","maskHeatmap","datum","imgHeatmap","mesh","bordersHeatmap","enter","circle","angle","maskNight","nightPath","cssBlur","userDate","date","startOfDay","getUTCFullYear","getUTCMonth","getUTCDate","solarPositionDated","origin","nightPathRight","nightPathLeft","disableSun","sunCoords","sunCircleRight","sunCircleXRight","sunCircleLeft","sunCircleXLeft","loadTimezone","JSON","parse","json","errGeoMap","jsonTimezones","err","dataTimezones","feature","features","maskTimezone","properties","places","insert","stringify","timezoneTexts","timezoneTextsUnique","Map","item","values","layerTimezonesText","scaleFontSize","utils","heatmapDataset","opts","lengthDataset","maxOpacityScale","linear","centralCircleOpacity","dataExtents","extent","userScale","log","canvasHeatmap","ctx","globalCompositeOperation","datumScale","getDatumScale","magnitudeScale","getMagnitudeScale","colorScale","beginPath","rect","fillStyle","closePath","colorMultiplier","aa","point","scaleOpacityDatum","StackBlur","dataUrl","toDataURL","remove","getHeatmapData","dataCountries","legendCountry","shouldRenderLegend","aggregate","allMtMapCountry","allMtMapMarker","dataByCountry","key","has","set","get","geoDatum","matchedCountry","rollupValue","setAttrValues","countryItem","getAllMtMapCountry","each","selection","attrKey","attrValue","scaleDomain","attrProperties","updateExtents","indiceChange","NaN","tooltip","activateTooltip","endOfDay","totalMilliseconds","currentTime","relativeTranslateX","transform","querySelectorAll","currentDate","Array","from","timezoneText","textContent","__data__","defaultGroupBy","dataMarkers","nest","entries","markerItem","markerObject","customTag","markerClassName","exit","transition","attrX","attrY","attrXDelta","attrYDelta","markerUpdate","getAllMtMapMarker","hor","ver","ratio","deltaMarker","currentWidth","currentHeight","realHeight","realWidth","diffMarginWidth","diffMarginHeight","titleContainer","bgColor","source","originalTranslation","newTx","newTy","encodedTranslation","defaultZoom","decodeTranslation","event","encodeTranslation","exportedData","removeState","self","maxTransX","maxTransY","minTransX","minTransY","scaleAttributes","firstExecution","dataset","mode","scaleToUse","rollup","groupedData","reduce","c","validData","groupedValues","exponent","sqrt","aggregatedValue","columnDetails","formatted","cellContent","positiveRanks","concat","v","negativeRanks","ranks","newValue","useNegative","scaleFunction","scaleNegativeFunction","copy","scaledValue","empty","originalValueRaw","originalValue","updateMarkers","updateCountries","updateNight","updateTimezones","updateTitle","updateHeatmap","fitContent","onRender","constructor","Function","content","showing","total","inlineFilters","getDescription","innerHTML","tooltipNode","tooltipContent","isCountry","mouseLeft","mouseTop","tooltipDelta","mapRect","getBoundingClientRect","mousePosition","mouse","left","top","targetRect","svgXml","XMLSerializer","serializeToString","saveAs","blob","Blob","type","form","submit","exportNode","exportButton","exportForm","Filters","criteria","show","arrayDiff","join","activeColumns","filtersHeaderNode","filtersResetNode","display","marginLeft","reset","filtersTitleNode","createTextNode","filtersBodyNode","filtersElementsNode","filtersNewNode","add","evt","preventDefault","possibleFilters","getPossibleFilters","filterName","create","replaceNode","rowNode","buildRow","replaceChild","render","toggle","filterIndex","rowNodes","output","filtersChildren","childNodes","element","filterOutput","filterMethod","filterRangeSelect","filterValueMin","filterValueMax","filterValue","criterion","row","decodeURIComponent","defaultCriteria","setFilters","outputArray","line","selectedIndex","separatorWord","that","minusButton","filterSeparator","filterNameSelect","oldFilterName","getAttribute","newFilterName","refresh","filterVerb","filterRange","handleRangeChange","filterInput","filterInputType","filterValueAnd","filterSelect","sortKeys","ascending","except","isVirtual","matched","fmt","dataParse","exportFilters","filterNameSelects","visibility","disableNewFilter","Table","defaultSorting","isArray","sorting","s","initialSorting","isSorting","header","body","nowrap","sortColumn","sortingRaw","sortingList","sortingData","encodedSorting","applySort","tableData","distinctBy","uniqueCollapsedRows","rowClassName","tds","columnKey","column","virtual","sortableColums","compareBool","d3SortMode","descending","filterType","sortIndex","sortValue","shiftKey","MapTable","state","saveStateTimeout","removeStateTimeout","loadData","csv","tsv","preFilter","setColumnDetails","isIE","navigator","userAgent","appVersion","firstChild","buildComponenents","loadMapData","restoreState","stateName","isJson","parseState","parsedState","message","loadState","params","location","href","clearTimeout","updateState","stateData","setTimeout","newUrl","stateHash","stateValue","encodeURIComponent","history","pushState","filterData","onComplete","defaultColumns","patternNumber","isNumber","test","columns","maptableObject","mapOptions","jsonPath","jsonData","csvPath","csvData","tsvPath","tsvData","filtersOptions","tableOptions","customOptions","defaultOptions","setTitleContent","setData","setNightDate","setTimezonesDate","getMapWidth","getMapHeight"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"maptable.js","sources":["../src/utils.js","../src/defaultOptions.js","../src/components/Legend.js","../src/components/Watermark.js","../src/components/StackBlur.js","../src/components/solarPosition.js","../src/components/GeoMap.js","../src/components/Filters.js","../src/components/Table.js","../src/maptable.js","../src/index.js"],"sourcesContent":["function appendOptions(select, options, defaultValue) {\n options.forEach((f) => {\n // Filter select\n const option = document.createElement('option');\n option.setAttribute('value', f.value);\n option.innerText = f.text;\n select.appendChild(option);\n });\n select.value = defaultValue;\n}\n\nfunction rangeToBool(el1, range, el2) {\n if (range === '=') {\n return parseInt(el1, 10) === parseInt(el2, 10);\n }\n if (range === '≠') {\n return parseInt(el1, 10) !== parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n if (range === '>') {\n return parseInt(el1, 10) > parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n if (range === '<') {\n return parseInt(el1, 10) < parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n if (range === '≥') {\n return parseInt(el1, 10) >= parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n if (range === '≤') {\n return parseInt(el1, 10) <= parseInt(el2, 10) && el1 !== '' && el2 !== '';\n }\n return true;\n}\n\n/* eslint no-loop-func: 0 */\nfunction extendRecursive() {\n const dst = {};\n let src;\n const args = [].splice.call(arguments, 0);\n const toString = {}.toString;\n\n while (args.length > 0) {\n src = args.splice(0, 1)[0];\n if (toString.call(src) === '[object Object]') {\n Object.keys(src).forEach((p) => {\n if (toString.call(src[p]) === '[object Object]') {\n dst[p] = extendRecursive(dst[p] || {}, src[p]);\n } else {\n dst[p] = src[p];\n }\n });\n }\n }\n return dst;\n}\n\nfunction keyToTile(k) {\n const upperK = k.charAt(0).toUpperCase() + k.slice(1);\n return upperK.replace(/_/g, ' ');\n}\n\nfunction sanitizeKey(k) {\n return k.toLowerCase().replace(/ /g, '_').replace(/\"/g, '').replace(/'/g, '');\n}\n\nfunction toNumber(str) {\n if (!str || str === '') return null;\n const resStr = str.toString().replace(/[^0-9.]+|\\s+/gim, '');\n if (resStr !== '') return Number(resStr);\n return null;\n}\n\nfunction quantile(array, percentile) {\n array.sort((a, b) => a - b);\n const index = (percentile / 100.0) * (array.length - 1);\n let result;\n if (Math.floor(index) === index) {\n result = array[index];\n } else {\n const i = Math.floor(index);\n const fraction = index - i;\n result = array[i] + (array[i + 1] - array[i]) * fraction;\n }\n return result;\n}\n\nfunction uniqueValues(arr) {\n if (!arr) return arr;\n const a = [];\n for (let i = 0, l = arr.length; i < l; i += 1) {\n if (a.indexOf(arr[i]) === -1 && arr[i] !== '') {\n a.push(arr[i]);\n }\n }\n return a;\n}\n\nconst formatDate = (d, zone) => {\n const newDate = new Date(d.getTime() + zone * 3600 * 1000);\n return newDate.toISOString().split('T')[1].substr(0, 5);\n};\n\nconst isBlank = (str) => str === null || str === '' || str === undefined;\n\nconst customSortOrders = {\n days: ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday'],\n months: ['january', 'february', 'march', 'april', 'may', 'june', 'july', 'august', 'september', 'october', 'november', 'december'],\n};\n\nconst customSortAsc = (type, d1, d2, sortOrder) => {\n const elem1 = d1.toLowerCase();\n const elem2 = d2.toLowerCase();\n const customSortOrder = sortOrder.length === 0 ? customSortOrders[type] || [] : sortOrder;\n return customSortOrder.indexOf(elem1) - customSortOrder.indexOf(elem2);\n};\n\nconst customSortDesc = (type, d1, d2, sortOrder) => {\n const elem1 = d1.toLowerCase();\n const elem2 = d2.toLowerCase();\n const customSortOrder = sortOrder.length === 0 ? customSortOrders[type] || [] : sortOrder;\n return customSortOrder.indexOf(elem2) - customSortOrder.indexOf(elem1);\n};\n\nexport default {\n rangeToBool,\n appendOptions,\n extendRecursive,\n sanitizeKey,\n toNumber,\n keyToTile,\n quantile,\n uniqueValues,\n formatDate,\n isBlank,\n customSortAsc,\n customSortDesc,\n};\n","export default {\n map: {\n longitudeKey: 'longitude',\n latitudeKey: 'latitude',\n countryIdentifierKey: 'country_code',\n countryIdentifierType: 'iso_a2',\n zoom: true,\n saveState: true,\n exportSvg: null,\n exportSvgClient: false,\n ratioFromWidth: 0.5,\n scaleHeight: 1.0,\n scaleZoom: [1, 10],\n fitContentMargin: 10,\n autoFitContent: false,\n tooltipClassName: 'popover bottom',\n countries: {\n legend: false,\n attr: {\n fill: '#FCFCFC',\n stroke: '#CCC',\n 'stroke-width': 0.5,\n },\n tooltipClassName: 'mt-map-tooltip popover bottom',\n },\n heatmap: {\n mask: true,\n weightByAttribute: null,\n weightByAttributeScale: 'linear',\n circles: {\n min: 1,\n max: 90,\n step: 4,\n color: '#FF0000',\n colorStrength: 1,\n blur: 4.0,\n },\n borders: {\n stroke: 1,\n opacity: 0.1,\n color: '#000',\n },\n },\n markers: {\n attr: {\n r: 4,\n fill: 'blue',\n stroke: '#CCC',\n 'stroke-width': 0.5,\n },\n tooltipClassName: 'mt-map-tooltip popover bottom',\n },\n title: {\n fontSize: 12,\n fontFamily: 'Helevetica, Arial, Sans-Serif',\n },\n },\n filters: {\n saveState: true,\n },\n table: {\n className: 'table table-striped table-bordered',\n collapseRowsBy: [],\n },\n};\n","export default class Legend {\n constructor(map) {\n this.legendWidth = 220;\n this.map = map;\n // Create Legend\n this.node = this.map.svg\n .append('g')\n .attr('id', 'mt-map-legend')\n .attr(\n 'transform',\n `translate(${(this.map.getWidth() - 350)}, ${(this.map.getHeight() - 60)})`,\n );\n\n this.buildIndice();\n }\n\n buildScale(domain) {\n const legendGradient = this.node\n .append('defs')\n .append('linearGradient')\n .attr('id', 'mt-map-legend-gradient')\n .attr('x1', '0%')\n .attr('y1', '0%')\n .attr('x2', '100%')\n .attr('y2', '0%');\n\n if (this.map.options.countries.attr.fill.minNegative\n && this.map.options.countries.attr.fill.maxNegative) {\n // todo - maybe watch for domain[0] < 0 && domain[1] < 0? fall back to normal min & max?\n const midPercentNegative = Math.round(((0 - domain[0]) / (domain[1] - domain[0])) * 100);\n const midPercentPositive = midPercentNegative + 1;\n\n legendGradient.append('stop')\n .attr('offset', '0%')\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.maxNegative};stop-opacity:1`);\n\n legendGradient.append('stop')\n .attr('offset', `${midPercentNegative}%`)\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.minNegative};stop-opacity:1`);\n legendGradient.append('stop')\n .attr('offset', `${midPercentPositive}%`)\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.min};stop-opacity:1`);\n } else {\n legendGradient.append('stop')\n .attr('offset', '0%')\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.min};stop-opacity:1`);\n }\n\n legendGradient.append('stop')\n .attr('offset', '100%')\n .attr('style', `stop-color:${this.map.options.countries.attr.fill.max};stop-opacity:1`);\n\n this.node.append('rect')\n .attr('x', 30)\n .attr('y', 0)\n .attr('width', this.legendWidth)\n .attr('height', 15)\n .attr('fill', 'url(#mt-map-legend-gradient)');\n }\n\n buildIndice() {\n const indice = this.node.append('g')\n .attr('id', 'mt-map-legend-indice')\n .attr('style', 'display:none')\n .attr('transform', 'translate(36,15)');\n\n indice.append('polygon')\n .attr('points', '4.5 0 9 5 0 5')\n .attr('fill', '#222222');\n\n indice.append('text')\n .attr('x', 4)\n .attr('y', 13)\n .attr('width', 10)\n .attr('height', 10)\n .attr('text-anchor', 'middle')\n .attr('font-family', 'Arial')\n .attr('font-size', '9')\n .attr('stroke', '#FFFFF')\n .attr('stroke-width', '1')\n .attr('fill', '#222222')\n .text('0');\n\n this.node.append('text')\n .attr('id', 'mt-map-legend-min')\n .attr('x', 25)\n .attr('y', 13)\n .attr('width', 35)\n .attr('height', 15)\n .attr('text-anchor', 'end')\n .attr('font-family', 'Arial')\n .attr('font-size', '14')\n .attr('stroke', '#FFFFF')\n .attr('stroke-width', '3')\n .attr('fill', '#222222')\n .text('0');\n\n this.node.append('text')\n .attr('id', 'mt-map-legend-max')\n .attr('y', 13)\n .attr('x', 255)\n .attr('width', 50)\n .attr('height', 15)\n .attr('text-anchor', 'start')\n .attr('font-family', 'Arial')\n .attr('font-size', '14')\n .attr('stroke', '#FFFFF')\n .attr('stroke-width', '3')\n .attr('fill', '#222222')\n .text('1');\n }\n\n updateExtents(domain) {\n this.node.select('#mt-map-legend').style('opacity', (domain[0] === domain[1]) ? 0 : 1);\n if (this.node.selectAll('mt-map-legend-min').length) {\n this.node.select('#mt-map-legend-min').text(Math.round(domain[0]).toLocaleString());\n this.node.select('#mt-map-legend-max').text(Math.round(domain[1]).toLocaleString());\n\n // pass in the min and max (domain) to the legend\n this.buildScale(domain);\n }\n }\n\n indiceChange(val) {\n if (Number.isNaN(val)) {\n this.node.select('#mt-map-legend-indice')\n .attr('style', 'display:none');\n } else {\n const maxValue = parseInt(this.node.select('#mt-map-legend-max').text(), 10);\n const minValue = parseInt(this.node.select('#mt-map-legend-min').text(), 10);\n const positionDelta = Math.round((0 - (minValue - val) / (maxValue - minValue))\n * this.legendWidth);\n this.node.select('#mt-map-legend-indice text').text(Math.round(val).toLocaleString());\n this.node.select('#mt-map-legend-indice')\n .attr('style', 'display:block')\n .attr('transform', `translate(${(36 + positionDelta)},15)`);\n }\n }\n}\n","export default class Legend {\n constructor(map, options) {\n this.map = map;\n this.src = options.src;\n this.position = options.position;\n this.width = parseInt(options.width, 10);\n this.height = parseInt(options.height, 10);\n this.padding = options.padding || 10;\n this.style = options.style;\n\n if (!options.src) {\n console.warn('Watermak src not found');\n return;\n }\n if (Number.isNaN(this.width)) {\n console.warn('Watermak width not found');\n return;\n }\n if (Number.isNaN(this.height)) {\n console.warn('Watermak height not found');\n return;\n }\n\n if (window.btoa) {\n this.buildWatermark();\n } else {\n console.warn('Watermark not rendered: btoa error');\n }\n }\n\n buildWatermark() {\n d3.xhr(this.src, (res) => {\n let mapWatermarkDelta = 0;\n if (this.map.options.title) mapWatermarkDelta = 30;\n let mime;\n let x;\n let y;\n if (this.src.indexOf('.svg') !== -1) {\n mime = 'image/svg+xml';\n } else if (this.src.indexOf('.jpg') !== -1 || this.src.indexOf('.jpeg') !== -1) {\n mime = 'image/jpeg';\n } else if (this.src.indexOf('.png') !== -1) {\n mime = 'image/png';\n } else {\n console.warn('invalid watermark mime type');\n return;\n }\n const dataUri = `data:${mime};base64,${window.btoa(res.responseText)}`;\n\n if (this.position) {\n const pos = this.position.split(' ');\n if (pos[0] === 'top') {\n y = this.padding;\n } else if (pos[0] === 'middle') {\n y = (this.map.getHeight() - this.height) / 2;\n } else if (pos[0] === 'bottom') {\n y = this.map.getHeight() - this.height - this.padding - mapWatermarkDelta;\n } else {\n console.warn('position should be (top|middle|bottom) (left|middle|right)');\n }\n\n if (pos[1] === 'left') {\n x = this.padding;\n } else if (pos[1] === 'middle') {\n x = (this.map.getWidth() - this.width) / 2;\n } else if (pos[1] === 'right') {\n x = this.map.getWidth() - this.width - this.padding;\n } else {\n console.warn('position should be (top|middle|bottom) (left|middle|right)');\n }\n }\n\n this.node = this.map.svg\n .append('image')\n .attr('xlink:href', dataUri)\n .attr('width', this.width)\n .attr('height', this.height);\n\n if (x && y) {\n this.node.attr('x', x).attr('y', y);\n }\n\n if (this.style) {\n this.node.attr('style', this.style);\n }\n });\n }\n}\n","/* eslint-disable */\n\n/*\n StackBlur - a fast almost Gaussian Blur For Canvas\n Version: 0.5\n Author: Mario Klingemann\n Contact: mario@quasimondo.com\n Website: http://www.quasimondo.com/StackBlurForCanvas\n Twitter: @quasimondo\n In case you find this class useful - especially in commercial projects -\n I am not totally unhappy for a small donation to my PayPal account\n mario@quasimondo.de\n Or support me on flattr:\n https://flattr.com/thing/72791/StackBlur-a-fast-almost-Gaussian-Blur-Effect-for-CanvasJavascript\n Copyright (c) 2010 Mario Klingemann\n Permission is hereby granted, free of charge, to any person\n obtaining a copy of this software and associated documentation\n files (the \"Software\"), to deal in the Software without\n restriction, including without limitation the rights to use,\n copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the\n Software is furnished to do so, subject to the following\n conditions:\n The above copyright notice and this permission notice shall be\n included in all copies or substantial portions of the Software.\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\n EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES\n OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\n NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\n HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,\n WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR\n OTHER DEALINGS IN THE SOFTWARE.\n */\n\n\nvar mul_table = [\n 512,512,456,512,328,456,335,512,405,328,271,456,388,335,292,512,\n 454,405,364,328,298,271,496,456,420,388,360,335,312,292,273,512,\n 482,454,428,405,383,364,345,328,312,298,284,271,259,496,475,456,\n 437,420,404,388,374,360,347,335,323,312,302,292,282,273,265,512,\n 497,482,468,454,441,428,417,405,394,383,373,364,354,345,337,328,\n 320,312,305,298,291,284,278,271,265,259,507,496,485,475,465,456,\n 446,437,428,420,412,404,396,388,381,374,367,360,354,347,341,335,\n 329,323,318,312,307,302,297,292,287,282,278,273,269,265,261,512,\n 505,497,489,482,475,468,461,454,447,441,435,428,422,417,411,405,\n 399,394,389,383,378,373,368,364,359,354,350,345,341,337,332,328,\n 324,320,316,312,309,305,301,298,294,291,287,284,281,278,274,271,\n 268,265,262,259,257,507,501,496,491,485,480,475,470,465,460,456,\n 451,446,442,437,433,428,424,420,416,412,408,404,400,396,392,388,\n 385,381,377,374,370,367,363,360,357,354,350,347,344,341,338,335,\n 332,329,326,323,320,318,315,312,310,307,304,302,299,297,294,292,\n 289,287,285,282,280,278,275,273,271,269,267,265,263,261,259];\n\n\nvar shg_table = [\n 9, 11, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 16, 17,\n 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18, 19,\n 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 20, 20, 20,\n 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 21,\n 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,\n 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 22, 22, 22, 22, 22, 22,\n 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,\n 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 23,\n 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,\n 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,\n 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,\n 23, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,\n 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,\n 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,\n 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,\n 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24 ];\n\n\nfunction processImage(img, canvas, radius, blurAlphaChannel)\n{\n if (typeof(img) == 'string') {\n var img = document.getElementById(img);\n }\n else if (typeof HTMLImageElement !== 'undefined' && !img instanceof HTMLImageElement) {\n return;\n }\n var w = img.naturalWidth;\n var h = img.naturalHeight;\n\n if (typeof(canvas) == 'string') {\n var canvas = document.getElementById(canvas);\n }\n else if (typeof HTMLCanvasElement !== 'undefined' && !canvas instanceof HTMLCanvasElement) {\n return;\n }\n\n canvas.style.width = w + 'px';\n canvas.style.height = h + 'px';\n canvas.width = w;\n canvas.height = h;\n\n var context = canvas.getContext('2d');\n context.clearRect(0, 0, w, h);\n context.drawImage(img, 0, 0);\n\n if (Number.isNaN(radius) || radius < 1) return;\n\n if (blurAlphaChannel)\n processCanvasRGBA(canvas, 0, 0, w, h, radius);\n else\n processCanvasRGB(canvas, 0, 0, w, h, radius);\n}\n\nfunction getImageDataFromCanvas(canvas, top_x, top_y, width, height)\n{\n if (typeof(canvas) == 'string')\n var canvas = document.getElementById(canvas);\n else if (typeof HTMLCanvasElement !== 'undefined' && !canvas instanceof HTMLCanvasElement)\n return;\n\n var context = canvas.getContext('2d');\n var imageData;\n\n try {\n try {\n imageData = context.getImageData(top_x, top_y, width, height);\n } catch(e) {\n throw new Error(\"unable to access local image data: \" + e);\n return;\n }\n } catch(e) {\n throw new Error(\"unable to access image data: \" + e);\n }\n\n return imageData;\n}\n\nfunction processCanvasRGBA(canvas, top_x, top_y, width, height, radius)\n{\n if (Number.isNaN(radius) || radius < 1) return;\n radius |= 0;\n\n var imageData = getImageDataFromCanvas(canvas, top_x, top_y, width, height);\n\n imageData = processImageDataRGBA(imageData, top_x, top_y, width, height, radius);\n\n canvas.getContext('2d').putImageData(imageData, top_x, top_y);\n}\n\nfunction processImageDataRGBA(imageData, top_x, top_y, width, height, radius)\n{\n var pixels = imageData.data;\n\n var x, y, i, p, yp, yi, yw, r_sum, g_sum, b_sum, a_sum,\n r_out_sum, g_out_sum, b_out_sum, a_out_sum,\n r_in_sum, g_in_sum, b_in_sum, a_in_sum,\n pr, pg, pb, pa, rbs;\n\n var div = radius + radius + 1;\n var w4 = width << 2;\n var widthMinus1 = width - 1;\n var heightMinus1 = height - 1;\n var radiusPlus1 = radius + 1;\n var sumFactor = radiusPlus1 * (radiusPlus1 + 1) / 2;\n\n var stackStart = new BlurStack();\n var stack = stackStart;\n for (i = 1; i < div; i++)\n {\n stack = stack.next = new BlurStack();\n if (i == radiusPlus1) var stackEnd = stack;\n }\n stack.next = stackStart;\n var stackIn = null;\n var stackOut = null;\n\n yw = yi = 0;\n\n var mul_sum = mul_table[radius];\n var shg_sum = shg_table[radius];\n\n for (y = 0; y < height; y++)\n {\n r_in_sum = g_in_sum = b_in_sum = a_in_sum = r_sum = g_sum = b_sum = a_sum = 0;\n\n r_out_sum = radiusPlus1 * (pr = pixels[yi]);\n g_out_sum = radiusPlus1 * (pg = pixels[yi+1]);\n b_out_sum = radiusPlus1 * (pb = pixels[yi+2]);\n a_out_sum = radiusPlus1 * (pa = pixels[yi+3]);\n\n r_sum += sumFactor * pr;\n g_sum += sumFactor * pg;\n b_sum += sumFactor * pb;\n a_sum += sumFactor * pa;\n\n stack = stackStart;\n\n for (i = 0; i < radiusPlus1; i++)\n {\n stack.r = pr;\n stack.g = pg;\n stack.b = pb;\n stack.a = pa;\n stack = stack.next;\n }\n\n for (i = 1; i < radiusPlus1; i++)\n {\n p = yi + ((widthMinus1 < i ? widthMinus1 : i) << 2);\n r_sum += (stack.r = (pr = pixels[p])) * (rbs = radiusPlus1 - i);\n g_sum += (stack.g = (pg = pixels[p+1])) * rbs;\n b_sum += (stack.b = (pb = pixels[p+2])) * rbs;\n a_sum += (stack.a = (pa = pixels[p+3])) * rbs;\n\n r_in_sum += pr;\n g_in_sum += pg;\n b_in_sum += pb;\n a_in_sum += pa;\n\n stack = stack.next;\n }\n\n\n stackIn = stackStart;\n stackOut = stackEnd;\n for (x = 0; x < width; x++)\n {\n pixels[yi+3] = pa = (a_sum * mul_sum) >> shg_sum;\n if (pa != 0)\n {\n pa = 255 / pa;\n pixels[yi] = ((r_sum * mul_sum) >> shg_sum) * pa;\n pixels[yi+1] = ((g_sum * mul_sum) >> shg_sum) * pa;\n pixels[yi+2] = ((b_sum * mul_sum) >> shg_sum) * pa;\n } else {\n pixels[yi] = pixels[yi+1] = pixels[yi+2] = 0;\n }\n\n r_sum -= r_out_sum;\n g_sum -= g_out_sum;\n b_sum -= b_out_sum;\n a_sum -= a_out_sum;\n\n r_out_sum -= stackIn.r;\n g_out_sum -= stackIn.g;\n b_out_sum -= stackIn.b;\n a_out_sum -= stackIn.a;\n\n p = (yw + ((p = x + radius + 1) < widthMinus1 ? p : widthMinus1)) << 2;\n\n r_in_sum += (stackIn.r = pixels[p]);\n g_in_sum += (stackIn.g = pixels[p+1]);\n b_in_sum += (stackIn.b = pixels[p+2]);\n a_in_sum += (stackIn.a = pixels[p+3]);\n\n r_sum += r_in_sum;\n g_sum += g_in_sum;\n b_sum += b_in_sum;\n a_sum += a_in_sum;\n\n stackIn = stackIn.next;\n\n r_out_sum += (pr = stackOut.r);\n g_out_sum += (pg = stackOut.g);\n b_out_sum += (pb = stackOut.b);\n a_out_sum += (pa = stackOut.a);\n\n r_in_sum -= pr;\n g_in_sum -= pg;\n b_in_sum -= pb;\n a_in_sum -= pa;\n\n stackOut = stackOut.next;\n\n yi += 4;\n }\n yw += width;\n }\n\n\n for (x = 0; x < width; x++)\n {\n g_in_sum = b_in_sum = a_in_sum = r_in_sum = g_sum = b_sum = a_sum = r_sum = 0;\n\n yi = x << 2;\n r_out_sum = radiusPlus1 * (pr = pixels[yi]);\n g_out_sum = radiusPlus1 * (pg = pixels[yi+1]);\n b_out_sum = radiusPlus1 * (pb = pixels[yi+2]);\n a_out_sum = radiusPlus1 * (pa = pixels[yi+3]);\n\n r_sum += sumFactor * pr;\n g_sum += sumFactor * pg;\n b_sum += sumFactor * pb;\n a_sum += sumFactor * pa;\n\n stack = stackStart;\n\n for (i = 0; i < radiusPlus1; i++)\n {\n stack.r = pr;\n stack.g = pg;\n stack.b = pb;\n stack.a = pa;\n stack = stack.next;\n }\n\n yp = width;\n\n for (i = 1; i <= radius; i++)\n {\n yi = (yp + x) << 2;\n\n r_sum += (stack.r = (pr = pixels[yi])) * (rbs = radiusPlus1 - i);\n g_sum += (stack.g = (pg = pixels[yi+1])) * rbs;\n b_sum += (stack.b = (pb = pixels[yi+2])) * rbs;\n a_sum += (stack.a = (pa = pixels[yi+3])) * rbs;\n\n r_in_sum += pr;\n g_in_sum += pg;\n b_in_sum += pb;\n a_in_sum += pa;\n\n stack = stack.next;\n\n if(i < heightMinus1)\n {\n yp += width;\n }\n }\n\n yi = x;\n stackIn = stackStart;\n stackOut = stackEnd;\n for (y = 0; y < height; y++)\n {\n p = yi << 2;\n pixels[p+3] = pa = (a_sum * mul_sum) >> shg_sum;\n if (pa > 0)\n {\n pa = 255 / pa;\n pixels[p] = ((r_sum * mul_sum) >> shg_sum) * pa;\n pixels[p+1] = ((g_sum * mul_sum) >> shg_sum) * pa;\n pixels[p+2] = ((b_sum * mul_sum) >> shg_sum) * pa;\n } else {\n pixels[p] = pixels[p+1] = pixels[p+2] = 0;\n }\n\n r_sum -= r_out_sum;\n g_sum -= g_out_sum;\n b_sum -= b_out_sum;\n a_sum -= a_out_sum;\n\n r_out_sum -= stackIn.r;\n g_out_sum -= stackIn.g;\n b_out_sum -= stackIn.b;\n a_out_sum -= stackIn.a;\n\n p = (x + (((p = y + radiusPlus1) < heightMinus1 ? p : heightMinus1) * width)) << 2;\n\n r_sum += (r_in_sum += (stackIn.r = pixels[p]));\n g_sum += (g_in_sum += (stackIn.g = pixels[p+1]));\n b_sum += (b_in_sum += (stackIn.b = pixels[p+2]));\n a_sum += (a_in_sum += (stackIn.a = pixels[p+3]));\n\n stackIn = stackIn.next;\n\n r_out_sum += (pr = stackOut.r);\n g_out_sum += (pg = stackOut.g);\n b_out_sum += (pb = stackOut.b);\n a_out_sum += (pa = stackOut.a);\n\n r_in_sum -= pr;\n g_in_sum -= pg;\n b_in_sum -= pb;\n a_in_sum -= pa;\n\n stackOut = stackOut.next;\n\n yi += width;\n }\n }\n return imageData;\n}\n\nfunction processCanvasRGB(canvas, top_x, top_y, width, height, radius)\n{\n if (Number.isNaN(radius) || radius < 1) return;\n radius |= 0;\n\n var imageData = getImageDataFromCanvas(canvas, top_x, top_y, width, height);\n imageData = processImageDataRGB(imageData, top_x, top_y, width, height, radius);\n\n canvas.getContext('2d').putImageData(imageData, top_x, top_y);\n}\n\nfunction processImageDataRGB(imageData, top_x, top_y, width, height, radius)\n{\n var pixels = imageData.data;\n\n var x, y, i, p, yp, yi, yw, r_sum, g_sum, b_sum,\n r_out_sum, g_out_sum, b_out_sum,\n r_in_sum, g_in_sum, b_in_sum,\n pr, pg, pb, rbs;\n\n var div = radius + radius + 1;\n var w4 = width << 2;\n var widthMinus1 = width - 1;\n var heightMinus1 = height - 1;\n var radiusPlus1 = radius + 1;\n var sumFactor = radiusPlus1 * (radiusPlus1 + 1) / 2;\n\n var stackStart = new BlurStack();\n var stack = stackStart;\n for (i = 1; i < div; i++)\n {\n stack = stack.next = new BlurStack();\n if (i == radiusPlus1) var stackEnd = stack;\n }\n stack.next = stackStart;\n var stackIn = null;\n var stackOut = null;\n\n yw = yi = 0;\n\n var mul_sum = mul_table[radius];\n var shg_sum = shg_table[radius];\n\n for (y = 0; y < height; y++)\n {\n r_in_sum = g_in_sum = b_in_sum = r_sum = g_sum = b_sum = 0;\n\n r_out_sum = radiusPlus1 * (pr = pixels[yi]);\n g_out_sum = radiusPlus1 * (pg = pixels[yi+1]);\n b_out_sum = radiusPlus1 * (pb = pixels[yi+2]);\n\n r_sum += sumFactor * pr;\n g_sum += sumFactor * pg;\n b_sum += sumFactor * pb;\n\n stack = stackStart;\n\n for (i = 0; i < radiusPlus1; i++)\n {\n stack.r = pr;\n stack.g = pg;\n stack.b = pb;\n stack = stack.next;\n }\n\n for (i = 1; i < radiusPlus1; i++)\n {\n p = yi + ((widthMinus1 < i ? widthMinus1 : i) << 2);\n r_sum += (stack.r = (pr = pixels[p])) * (rbs = radiusPlus1 - i);\n g_sum += (stack.g = (pg = pixels[p+1])) * rbs;\n b_sum += (stack.b = (pb = pixels[p+2])) * rbs;\n\n r_in_sum += pr;\n g_in_sum += pg;\n b_in_sum += pb;\n\n stack = stack.next;\n }\n\n\n stackIn = stackStart;\n stackOut = stackEnd;\n for (x = 0; x < width; x++)\n {\n pixels[yi] = (r_sum * mul_sum) >> shg_sum;\n pixels[yi+1] = (g_sum * mul_sum) >> shg_sum;\n pixels[yi+2] = (b_sum * mul_sum) >> shg_sum;\n\n r_sum -= r_out_sum;\n g_sum -= g_out_sum;\n b_sum -= b_out_sum;\n\n r_out_sum -= stackIn.r;\n g_out_sum -= stackIn.g;\n b_out_sum -= stackIn.b;\n\n p = (yw + ((p = x + radius + 1) < widthMinus1 ? p : widthMinus1)) << 2;\n\n r_in_sum += (stackIn.r = pixels[p]);\n g_in_sum += (stackIn.g = pixels[p+1]);\n b_in_sum += (stackIn.b = pixels[p+2]);\n\n r_sum += r_in_sum;\n g_sum += g_in_sum;\n b_sum += b_in_sum;\n\n stackIn = stackIn.next;\n\n r_out_sum += (pr = stackOut.r);\n g_out_sum += (pg = stackOut.g);\n b_out_sum += (pb = stackOut.b);\n\n r_in_sum -= pr;\n g_in_sum -= pg;\n b_in_sum -= pb;\n\n stackOut = stackOut.next;\n\n yi += 4;\n }\n yw += width;\n }\n\n\n for (x = 0; x < width; x++)\n {\n g_in_sum = b_in_sum = r_in_sum = g_sum = b_sum = r_sum = 0;\n\n yi = x << 2;\n r_out_sum = radiusPlus1 * (pr = pixels[yi]);\n g_out_sum = radiusPlus1 * (pg = pixels[yi+1]);\n b_out_sum = radiusPlus1 * (pb = pixels[yi+2]);\n\n r_sum += sumFactor * pr;\n g_sum += sumFactor * pg;\n b_sum += sumFactor * pb;\n\n stack = stackStart;\n\n for (i = 0; i < radiusPlus1; i++)\n {\n stack.r = pr;\n stack.g = pg;\n stack.b = pb;\n stack = stack.next;\n }\n\n yp = width;\n\n for (i = 1; i <= radius; i++)\n {\n yi = (yp + x) << 2;\n\n r_sum += (stack.r = (pr = pixels[yi])) * (rbs = radiusPlus1 - i);\n g_sum += (stack.g = (pg = pixels[yi+1])) * rbs;\n b_sum += (stack.b = (pb = pixels[yi+2])) * rbs;\n\n r_in_sum += pr;\n g_in_sum += pg;\n b_in_sum += pb;\n\n stack = stack.next;\n\n if(i < heightMinus1)\n {\n yp += width;\n }\n }\n\n yi = x;\n stackIn = stackStart;\n stackOut = stackEnd;\n for (y = 0; y < height; y++)\n {\n p = yi << 2;\n pixels[p] = (r_sum * mul_sum) >> shg_sum;\n pixels[p+1] = (g_sum * mul_sum) >> shg_sum;\n pixels[p+2] = (b_sum * mul_sum) >> shg_sum;\n\n r_sum -= r_out_sum;\n g_sum -= g_out_sum;\n b_sum -= b_out_sum;\n\n r_out_sum -= stackIn.r;\n g_out_sum -= stackIn.g;\n b_out_sum -= stackIn.b;\n\n p = (x + (((p = y + radiusPlus1) < heightMinus1 ? p : heightMinus1) * width)) << 2;\n\n r_sum += (r_in_sum += (stackIn.r = pixels[p]));\n g_sum += (g_in_sum += (stackIn.g = pixels[p+1]));\n b_sum += (b_in_sum += (stackIn.b = pixels[p+2]));\n\n stackIn = stackIn.next;\n\n r_out_sum += (pr = stackOut.r);\n g_out_sum += (pg = stackOut.g);\n b_out_sum += (pb = stackOut.b);\n\n r_in_sum -= pr;\n g_in_sum -= pg;\n b_in_sum -= pb;\n\n stackOut = stackOut.next;\n\n yi += width;\n }\n }\n\n return imageData;\n}\n\nfunction BlurStack()\n{\n this.r = 0;\n this.g = 0;\n this.b = 0;\n this.a = 0;\n this.next = null;\n}\n\nexport default {\n image: processImage,\n canvasRGBA: processCanvasRGBA,\n canvasRGB: processCanvasRGB,\n imageDataRGBA: processImageDataRGBA,\n imageDataRGB: processImageDataRGB\n};\n","/* eslint-disable max-len */\n// Equations based on NOAA’s Solar Calculator; all angles in radians.\n// http://www.esrl.noaa.gov/gmd/grad/solcalc/\n\nconst π = Math.PI;\nconst radians = π / 180;\nconst degrees = 180 / π;\n\nfunction solarGeometricMeanAnomaly(centuries) {\n return (357.52911 + centuries * (35999.05029 - 0.0001537 * centuries)) * radians;\n}\n\nfunction solarGeometricMeanLongitude(centuries) {\n const l = (280.46646 + centuries * (36000.76983 + centuries * 0.0003032)) % 360;\n return ((l < 0 ? l + 360 : l) / 180) * π;\n}\n\nfunction solarEquationOfCenter(centuries) {\n const m = solarGeometricMeanAnomaly(centuries);\n return (Math.sin(m) * (1.914602 - centuries * (0.004817 + 0.000014 * centuries))\n + Math.sin(m + m) * (0.019993 - 0.000101 * centuries)\n + Math.sin(m + m + m) * 0.000289) * radians;\n}\n\nfunction solarTrueLongitude(centuries) {\n return solarGeometricMeanLongitude(centuries) + solarEquationOfCenter(centuries);\n}\n\nfunction solarApparentLongitude(centuries) {\n return solarTrueLongitude(centuries) - (0.00569 + 0.00478 * Math.sin((125.04 - 1934.136 * centuries) * radians)) * radians;\n}\n\nfunction meanObliquityOfEcliptic(centuries) {\n return (23 + (26 + (21.448 - centuries * (46.8150 + centuries * (0.00059 - centuries * 0.001813))) / 60) / 60) * radians;\n}\n\nfunction obliquityCorrection(centuries) {\n return meanObliquityOfEcliptic(centuries) + 0.00256 * Math.cos((125.04 - 1934.136 * centuries) * radians) * radians;\n}\n\nfunction solarDeclination(centuries) {\n return Math.asin(\n Math.sin(obliquityCorrection(centuries)) * Math.sin(solarApparentLongitude(centuries)),\n );\n}\n\nfunction eccentricityEarthOrbit(centuries) {\n return 0.016708634 - centuries * (0.000042037 + 0.0000001267 * centuries);\n}\n\nfunction equationOfTime(centuries) {\n const e = eccentricityEarthOrbit(centuries);\n const m = solarGeometricMeanAnomaly(centuries);\n const l = solarGeometricMeanLongitude(centuries);\n let y = Math.tan(obliquityCorrection(centuries) / 2);\n y *= y;\n return y * Math.sin(2 * l)\n - 2 * e * Math.sin(m)\n + 4 * e * y * Math.sin(m) * Math.cos(2 * l)\n - 0.5 * y * y * Math.sin(4 * l)\n - 1.25 * e * e * Math.sin(2 * m);\n}\n\nexport function antipode(position) {\n return [position[0] + 180, -position[1]];\n}\n\nexport function solarPosition(time) {\n const centuries = (time - Date.UTC(2000, 0, 1, 12)) / 864e5 / 36525; // since J2000\n const longitude = ((d3.time.day.utc.floor(time) - time) / 864e5) * 360 - 180;\n return [\n longitude - equationOfTime(centuries) * degrees,\n solarDeclination(centuries) * degrees,\n ];\n}\n","import Legend from './Legend';\nimport Watermark from './Watermark';\nimport StackBlur from './StackBlur';\nimport utils from '../utils';\nimport { solarPosition, antipode } from './solarPosition';\n\n/**\n * Used the name GeoMap instead of Map to avoid collision with the native Map class of JS\n */\nexport default class GeoMap {\n /**\n * Geo Mapping class constructor that will initiate the map drawing\n * @param maptable: Maptable main Object\n * @param options: options communicated to map\n * @param jsonWorld: Object that contain TopoJSON dataset\n */\n constructor(maptable, options, jsonWorld) {\n this.maptable = maptable;\n this.scale = 1;\n this.transX = 0;\n this.transY = 0;\n\n this.options = options;\n\n this.jsonWorld = jsonWorld;\n\n this.containerSelector = maptable.options.target;\n this.container = document.querySelector(maptable.options.target);\n\n // Map wrapper\n const mapWrapper = this.container.querySelector('.mt-map-container');\n\n const existingMap = this.container.querySelector('#mt-map');\n if (existingMap) {\n // transform #mt-map to .mt-map-container'\n mapWrapper.parentNode.insertBefore(mapWrapper, existingMap);\n existingMap.parentNode.removeChild(existingMap);\n }\n\n // Map\n this.node = document.createElement('div');\n this.node.setAttribute('id', 'mt-map');\n mapWrapper.appendChild(this.node);\n\n this.svg = d3.select(this.node)\n .append('svg')\n .attr('id', 'mt-map-svg')\n .attr('xmlns', 'http://www.w3.org/2000/svg')\n .attr('xmlns:xlink', 'http://www.w3.org/1999/xlink')\n .attr('viewBox', `0 0 ${this.getWidth()} ${this.getHeight()}`)\n .attr('width', this.getWidth())\n .attr('height', this.getHeight());\n\n this.projection = d3.geo.equirectangular()\n .translate([this.getWidth() / 2, this.getHeight() / (2 * this.options.scaleHeight)])\n .scale((this.getWidth() / 640) * 100)\n .rotate([-12, 0])\n .precision(0.1);\n\n this.path = d3.geo.path().projection(this.projection);\n\n this.enrichData();\n\n this.zoomListener = d3.behavior\n .zoom()\n .scaleExtent(this.options.scaleZoom)\n .on('zoom', this.rescale.bind(this));\n\n // Attach Zoom event to map\n if (this.options.zoom) {\n this.svg = this.svg.call(this.zoomListener.bind(this));\n }\n\n // Add tooltip\n if (this.options.markers) {\n this.tooltipMarkersNode = d3.select(this.node)\n .append('div')\n .attr('id', 'mt-map-markers-tooltip')\n .attr('class', `mt-map-tooltip ${this.options.markers.tooltipClassName}`)\n .style('display', 'none');\n }\n\n if (this.options.countries) {\n this.tooltipCountriesNode = d3.select(this.node)\n .append('div')\n .attr('id', 'mt-map-countries-tooltip')\n .attr('class', `mt-map-tooltip ${this.options.countries.tooltipClassName}`)\n .style('display', 'none');\n }\n\n this.layerGlobal = this.svg.append('g').attr('class', 'mt-map-global');\n this.layerDefs = this.svg.append('defs');\n this.layerDefs.html(`\n \n \n \n \n \n \n `);\n if (this.options.timezones) this.layerTimezones = this.layerGlobal.append('g').attr('class', 'mt-map-timezones');\n this.layerCountries = this.layerGlobal.append('g').attr('class', 'mt-map-countries');\n if (this.options.night) this.layerNight = this.layerGlobal.append('g').attr('class', 'mt-map-night');\n\n if (this.options.heatmap) this.layerHeatmap = this.layerGlobal.append('g').attr('class', 'mt-map-heatmap');\n this.layerMarkers = this.layerGlobal.append('g').attr('class', 'mt-map-markers');\n\n // Add Watermark\n if (this.options.watermark) {\n this.watermark = new Watermark(this, this.options.watermark);\n }\n\n // Add Title\n if (this.options.title) {\n this.buildTitle();\n }\n\n // Add Export SVG Capability\n if (this.options.exportSvgClient || this.options.exportSvg) {\n this.addExportSvgCapability();\n }\n\n // AutoResize\n if (!this.options.width) {\n window.addEventListener('resize', () => {\n this.svg.attr('width', this.getWidth());\n this.svg.attr('height', this.getHeight());\n this.rescale();\n });\n }\n\n // Let's build things\n this.loadGeometries();\n\n // render is triggered by MapTable\n // this.render();\n }\n\n enrichData() {\n // Add coordinates to rawData\n this.maptable.rawData.forEach((d) => {\n d.longitude = parseFloat(d[this.options.longitudeKey]);\n d.latitude = parseFloat(d[this.options.latitudeKey]);\n let coord = [0, 0];\n if (!Number.isNaN(d.longitude) && !Number.isNaN(d.latitude)) {\n coord = this.projection([d.longitude, d.latitude]);\n }\n d.x = coord[0];\n d.y = coord[1];\n });\n }\n\n scaleAttributes() {\n return Math.pow(this.scale, 2 / 3); // eslint-disable-line\n }\n\n getWidth() {\n if (this.options.width) {\n return this.options.width;\n }\n this.options.width = this.node.offsetWidth;\n return this.node.offsetWidth;\n }\n\n getHeight() {\n const deltaHeight = (this.options.title) ? 30 : 0;\n if (!this.options.height && this.options.ratioFromWidth) {\n return this.getWidth() * this.options.ratioFromWidth * this.options.scaleHeight + deltaHeight;\n }\n return this.options.height * this.options.scaleHeight + deltaHeight;\n }\n\n /**\n * Load geometries and built the map components\n */\n loadGeometries() {\n // We filter world data\n if (this.options.filterCountries) {\n this.jsonWorld.objects.countries.geometries = this.jsonWorld.objects.countries\n .geometries.filter(this.options.filterCountries);\n }\n\n // Build countries\n if (this.options.countries) this.buildCountries();\n\n // Build heatmap\n if (this.options.heatmap) this.buildHeatmap();\n\n if (this.options.night) this.buildNight();\n if (\n this.options.timezones\n && (this.options.timezones.path || this.options.timezones.pathData)\n ) this.buildTimezone();\n }\n\n /**\n * Logic to build the heatmap elements (without the filling the heatmap image)\n */\n buildHeatmap() {\n // Build vectors\n const lands = topojson.merge(this.jsonWorld, this.jsonWorld.objects.countries.geometries);\n if (!this.options.heatmap.disableMask) {\n this.maskHeatmap = this.layerHeatmap.append('defs')\n .append('clipPath')\n .attr('id', 'mt-map-heatmap-mask');\n\n this.maskHeatmap\n .datum(lands)\n .append('path')\n .attr('class', 'mt-map-heatmap-mask-paths')\n .attr('d', this.path);\n }\n\n this.imgHeatmap = this.layerHeatmap\n .append('image')\n .attr('width', this.getWidth())\n .attr('height', this.getHeight())\n .attr('x', 0)\n .attr('y', 0)\n .attr('class', 'mt-map-heatmap-img');\n\n if (this.options.heatmap.mask) {\n this.imgHeatmap = this.imgHeatmap.attr('clip-path', 'url(#mt-map-heatmap-mask)');\n }\n\n if (this.options.heatmap.borders) {\n const borders = topojson.mesh(\n this.jsonWorld,\n this.jsonWorld.objects.countries,\n (a, b) => a !== b,\n );\n\n this.bordersHeatmap = this.layerHeatmap\n .append('g')\n .attr('class', 'mt-map-heatmap-borders');\n\n this.bordersHeatmap.selectAll('path.mt-map-heatmap-borders-paths')\n .data([lands, borders])\n .enter()\n .append('path')\n .attr('class', 'mt-map-heatmap-borders-paths')\n .attr('fill', 'none')\n .attr('stroke-width', this.options.heatmap.borders.stroke)\n .attr('stroke', this.options.heatmap.borders.color)\n .attr('style', `opacity: ${this.options.heatmap.borders.opacity}`)\n .attr('d', this.path);\n }\n }\n\n /**\n * Logic to build the night position\n */\n buildNight() {\n this.layerNight = this.layerGlobal.append('g')\n .attr('class', 'mt-map-night');\n\n const circle = d3.geo.circle()\n .angle(90);\n\n // Mask night\n this.maskNight = this.layerNight.append('defs')\n .append('clipPath')\n .attr('id', 'mt-map-night-mask');\n\n this.maskNight.append('rect')\n .attr('x', 0)\n .attr('y', 30)\n .attr('width', this.getWidth())\n .attr('height', this.getHeight() * 0.82 - 30);\n\n // Build vectors\n this.nightPath = this.layerNight.append('path')\n .attr('class', `mt-map-night-layer${this.options.night.cssBlur ? ' mt-blur' : ''}`)\n .attr('filter', this.options.night.cssBlur ? undefined : 'url(#blur)')\n .attr('clip-path', 'url(#mt-map-night-mask)')\n .attr('d', this.path)\n .style('opacity', 0.1);\n\n const userDate = this.options.night.date || Date.UTC();\n const startOfDay = Date.UTC(\n userDate.getUTCFullYear(),\n userDate.getUTCMonth(),\n userDate.getUTCDate(),\n 0,\n 0,\n 0,\n );\n const solarPositionDated = solarPosition(new Date(startOfDay));\n this.nightPath.datum(circle.origin(antipode(solarPositionDated))).attr('d', this.path);\n\n this.nightPathRight = this.layerNight.append('path')\n .attr('class', `mt-map-night-layer${this.options.night.cssBlur ? ' mt-blur' : ''}`)\n .attr('filter', this.options.night.cssBlur ? undefined : 'url(#blur)')\n .attr('clip-path', 'url(#mt-map-night-mask)')\n .attr('d', this.nightPath.attr('d'))\n .style('opacity', 0.1)\n .style('transform', `translate3d(${this.getWidth()}px,0,0)`);\n\n this.nightPathLeft = this.layerNight.append('path')\n .attr('class', `mt-map-night-layer${this.options.night.cssBlur ? ' mt-blur' : ''}`)\n .attr('filter', this.options.night.cssBlur ? undefined : 'url(#blur)')\n .attr('clip-path', 'url(#mt-map-night-mask)')\n .attr('d', this.nightPath.attr('d'))\n .style('opacity', 0.1)\n .style('transform', `translate3d(${-this.getWidth()}px,0,0)`);\n\n if (!this.options.night.disableSun) {\n const sunCoords = this.projection(solarPositionDated);\n\n this.sunCircleRight = this.layerNight.append('svg:circle')\n .attr('class', 'mt-map-sun-right')\n .attr('cx', sunCoords[0])\n .attr('cy', sunCoords[1])\n .attr('fill', 'url(#sunGradient)')\n .attr('r', this.getHeight() * 0.35);\n\n this.sunCircleXRight = this.layerNight.append('svg:circle')\n .attr('class', 'mt-map-sun-xright')\n .attr('cx', sunCoords[0] + this.getWidth())\n .attr('cy', sunCoords[1])\n .attr('fill', 'url(#sunGradient)')\n .attr('r', this.getHeight() * 0.35);\n\n this.sunCircleLeft = this.layerNight.append('svg:circle')\n .attr('class', 'mt-map-sun-right')\n .attr('cx', sunCoords[0] - this.getWidth())\n .attr('cy', sunCoords[1])\n .attr('fill', 'url(#sunGradient)')\n .attr('r', this.getHeight() * 0.35);\n\n this.sunCircleXLeft = this.layerNight.append('svg:circle')\n .attr('class', 'mt-map-sun-xright')\n .attr('cx', sunCoords[0] - 2 * this.getWidth())\n .attr('cy', sunCoords[1])\n .attr('fill', 'url(#sunGradient)')\n .attr('r', this.getHeight() * 0.35);\n }\n }\n\n /**\n * Logic to build the timezone strips\n */\n buildTimezone() {\n if (this.options.timezones.pathData) {\n this.loadTimezone(null, JSON.parse(this.options.timezones.pathData));\n } else if (this.options.timezones.path) {\n d3.json(this.options.timezones.path, (errGeoMap, jsonTimezones) => {\n this.loadTimezone(errGeoMap, jsonTimezones);\n });\n }\n }\n\n scaleFontSize(fontSize) {\n return this.getWidth() < 700 ? fontSize * (this.getWidth() / 700) : fontSize;\n }\n\n loadTimezone(err, jsonTimezones) {\n this.dataTimezones = topojson.feature(\n jsonTimezones,\n jsonTimezones.objects.timezones,\n ).features;\n\n // Mask timezone\n this.maskTimezone = this.layerTimezones.append('defs')\n .append('clipPath')\n .attr('id', 'mt-map-timezone-mask');\n\n this.maskTimezone.append('rect')\n .attr('x', 0)\n .attr('y', 30)\n .attr('width', this.getWidth())\n .attr('height', this.getHeight() * 0.82 - 30);\n\n // Build timezone paths\n this.layerTimezones\n .selectAll('.mt-map-timezone')\n .data(this.dataTimezones.filter((d) => d.properties.places !== 'Antarctica'))\n .enter()\n .insert('path')\n .attr('class', 'mt-map-timezone')\n .attr('d', this.path)\n .attr('fill', (d) => (d.properties.zone % 2 === 0 ? '#F4F5F5' : 'transparent'))\n .attr('title', (d) => JSON.stringify(d.properties))\n .attr('clip-path', 'url(#mt-map-timezone-mask)')\n .style('opacity', 0.6);\n\n // Add times\n const timezoneTexts = this.dataTimezones.filter((d) => d.properties.places !== 'Antarctica' && d.properties.zone % 1 === 0 && d.properties.zone !== 14);\n const timezoneTextsUnique = [...new Map(timezoneTexts.map((item) => (\n [item.properties.zone, item]\n ))).values()];\n\n this.layerTimezonesText = this.layerTimezones.append('g').attr('class', 'mt-map-timezones-texts');\n this.layerTimezonesText.selectAll('.mt-map-timezone-text')\n .data(timezoneTextsUnique)\n .enter()\n .insert('text')\n .attr('class', 'mt-map-timezone-text')\n .attr('y', this.getHeight() * 0.82 - 5)\n .attr('x', (d) => (d.properties.zone + 10) * (this.getWidth() / 24.5) - 1)\n .attr('dx', (this.getWidth() / 24.5) / 2)\n .attr('font-size', this.scaleFontSize(9))\n .attr('font-family', 'Helevetica, Arial, Sans-Serif')\n .attr('fill', '#999')\n .attr('text-anchor', 'middle')\n .html((d) => (\n utils.formatDate((this.options.timezones.date || new Date()), d.properties.zone)));\n }\n\n /**\n * Get Scale for every circle magnitude\n * @param heatmapDataset: heatmap dataset that we use\n * @returns scale: function - Scale function that output a value [0 - 1]\n */\n getMagnitudeScale(heatmapDataset) {\n const opts = this.options.heatmap;\n const lengthDataset = heatmapDataset.length;\n if (!lengthDataset) return () => 0;\n // const layersPerLocation = (opts.circles.max - opts.circles.min) / opts.circles.step;\n const maxOpacityScale = d3.scale.linear()\n .domain([1, lengthDataset])\n .range([1, 0.25]);\n const centralCircleOpacity = maxOpacityScale(lengthDataset);\n\n const scale = d3.scale.linear()\n .domain([opts.circles.min, 20])\n .range([centralCircleOpacity, 0]);\n return (m) => scale(m);\n }\n\n /**\n * Get Scale for every data point (used for weighting)\n * @returns scale: function - Scale function that output a value [0 - 1]\n */\n getDatumScale() {\n if (!this.options.heatmap.weightByAttribute) return () => 1;\n const dataExtents = d3.extent(this.maptable.data, this.options.heatmap.weightByAttribute);\n const userScale = (this.options.heatmap.weightByAttributeScale === 'log')\n ? d3.scale.log : d3.scale.linear;\n const scale = userScale().domain(dataExtents).range([0.5, 1]);\n return (d) => {\n const val = this.options.heatmap.weightByAttribute(d);\n if (!val) return 0;\n return scale(val);\n };\n }\n\n /**\n * Get the Data URL of the heatmap image\n * @returns {string} base64 image\n */\n getHeatmapData() {\n const canvasHeatmap = d3.select(this.node)\n .append('canvas')\n .attr('id', 'mt-map-heatmap-canvas')\n .attr('width', this.getWidth())\n .attr('height', this.getHeight())\n .attr('style', 'display: none;');\n\n const ctx = canvasHeatmap.node().getContext('2d');\n ctx.globalCompositeOperation = 'multiply';\n const circles = d3.range(\n this.options.heatmap.circles.min,\n this.options.heatmap.circles.max,\n this.options.heatmap.circles.step,\n );\n const datumScale = this.getDatumScale();\n const heatmapDataset = this.maptable.data.filter((d) => datumScale(d) > 0.1);\n const path = this.path.context(ctx);\n const magnitudeScale = this.getMagnitudeScale(heatmapDataset);\n const colorScale = d3.scale.linear()\n .domain([1, 0])\n .range(['#000000', '#FFFFFF']);\n\n // Make a flat white background first\n ctx.beginPath();\n ctx.rect(0, 0, this.getWidth(), this.getHeight());\n ctx.fillStyle = '#ffffff';\n ctx.fill();\n ctx.closePath();\n\n // color strenght factor\n const colorMultiplier = (x) => {\n const a = this.options.heatmap.circles.colorStrength;\n const aa = 1 + ((a - 1) / 100);\n if (a > 1) return (2 - aa) * x + aa - 1;\n return a * x;\n };\n\n // add condensed clouds\n heatmapDataset.forEach((point) => {\n const scaleOpacityDatum = datumScale(point);\n circles.forEach((m) => {\n const opacity = colorMultiplier(magnitudeScale(m) * scaleOpacityDatum);\n if (opacity > 0) {\n ctx.beginPath();\n path(d3.geo.circle().origin([point.longitude, point.latitude]).angle(m - 0.0001)());\n ctx.fillStyle = colorScale(opacity);\n ctx.fill();\n ctx.closePath();\n }\n });\n });\n\n StackBlur.canvasRGBA(\n canvasHeatmap.node(),\n 0,\n 0,\n this.getWidth(),\n this.getHeight(),\n this.options.heatmap.circles.blur,\n );\n\n // Add color layer\n ctx.beginPath();\n ctx.globalCompositeOperation = 'screen';\n ctx.rect(0, 0, this.getWidth(), this.getHeight());\n ctx.fillStyle = this.options.heatmap.circles.color;\n ctx.fill();\n ctx.closePath();\n\n const dataUrl = canvasHeatmap.node().toDataURL();\n canvasHeatmap.remove();\n return dataUrl;\n }\n\n /**\n * Set the data URL to the heatmap image\n */\n updateHeatmap() {\n const dataUrl = this.getHeatmapData();\n this.imgHeatmap.attr('xlink:href', dataUrl);\n }\n\n /**\n * build the paths for the countries\n */\n buildCountries() {\n this.dataCountries = topojson.feature(\n this.jsonWorld,\n this.jsonWorld.objects.countries,\n ).features;\n\n // Build country paths\n this.layerCountries\n .selectAll('.mt-map-country')\n .data(this.dataCountries)\n .enter()\n .insert('path')\n .attr('class', 'mt-map-country')\n .attr('d', this.path);\n\n // Build Country Legend\n this.legendCountry = {};\n\n if (this.shouldRenderLegend()) {\n this.legendCountry.fill = new Legend(this);\n }\n }\n\n shouldRenderLegend() {\n const f = this.options.countries.attr.fill;\n if (!f) return false;\n if (!f.legend || !f.min || !f.max) return false;\n if (f.aggregate && f.aggregate.scale) {\n const scale = (typeof (f.aggregate.scale) === 'function')\n ? f.aggregate.scale.bind(this.maptable)()\n : f.aggregate.scale;\n if (scale !== 'linear') return false;\n }\n return true;\n }\n\n /**\n * Get all mt-map-country elements\n */\n getAllMtMapCountry() {\n if (this.allMtMapCountry) return this.allMtMapCountry;\n this.allMtMapCountry = d3.selectAll(`${this.containerSelector} .mt-map-country`);\n return this.allMtMapCountry;\n }\n\n /**\n * Get all mt-map-marjker elements\n */\n getAllMtMapMarker() {\n if (this.allMtMapMarker) return this.allMtMapMarker;\n this.allMtMapMarker = d3.selectAll(`${this.containerSelector} .mt-map-marker`);\n return this.allMtMapMarker;\n }\n\n /**\n * Set the right color for every country\n */\n updateCountries() {\n // Data from user input\n const dataByCountry = new Map();\n this.maptable.data.forEach((d) => {\n const key = d[this.options.countryIdentifierKey];\n if (!dataByCountry.has(key)) {\n dataByCountry.set(key, []);\n }\n dataByCountry.get(key).push(d);\n });\n\n // We merge both data\n this.dataCountries.forEach((geoDatum) => {\n geoDatum.key = geoDatum.properties[this.options.countryIdentifierType];\n const matchedCountry = dataByCountry.get(geoDatum.key);\n geoDatum.values = matchedCountry || [];\n geoDatum.attr = {};\n geoDatum.rollupValue = {};\n });\n\n // We calculate attributes values\n Object.keys(this.options.countries.attr).forEach((k) => {\n this.setAttrValues(k, this.options.countries.attr[k], this.dataCountries);\n });\n\n // Update SVG\n const countryItem = this.getAllMtMapCountry().each(function (d) {\n const selection = d3.select(this);\n Object.keys(d.attr).forEach((key) => {\n selection.attr(key, d.attr[key]);\n });\n });\n\n // Update Legend\n Object.keys(this.options.countries.attr).forEach((attrKey) => {\n const attrValue = this.options.countries.attr[attrKey];\n if (typeof (attrValue) === 'object' && attrValue.legend && this.legendCountry[attrKey] !== undefined) {\n const scaleDomain = d3.extent(\n this.dataCountries,\n (d) => Number(d.attrProperties[attrKey].value),\n );\n this.legendCountry[attrKey].updateExtents(scaleDomain);\n\n // When we mouseover the legend, it should highlight the indice selected\n countryItem.on('mouseover', (d) => {\n this.legendCountry[attrKey].indiceChange(d.attrProperties[attrKey].value);\n })\n .on('mouseout', () => {\n this.legendCountry[attrKey].indiceChange(NaN);\n });\n }\n });\n\n // Update Tooltip\n if (this.options.countries && this.options.countries.tooltip) {\n this.activateTooltip(\n countryItem,\n this.tooltipCountriesNode,\n this.options.countries.tooltip,\n true,\n );\n }\n }\n\n /**\n * Update night drawings\n */\n updateNight() {\n const userDate = this.options.night.date || Date.UTC();\n const startOfDay = Date.UTC(\n userDate.getUTCFullYear(),\n userDate.getUTCMonth(),\n userDate.getUTCDate(),\n 0,\n 0,\n 0,\n );\n const endOfDay = Date.UTC(\n userDate.getUTCFullYear(),\n userDate.getUTCMonth(),\n userDate.getUTCDate(),\n 23,\n 59,\n 59,\n );\n\n const totalMilliseconds = endOfDay - startOfDay;\n const currentTime = userDate - startOfDay;\n const relativeTranslateX = (currentTime / totalMilliseconds);\n\n this.layerNight.node().style.transform = `translateX(${-this.getWidth() * relativeTranslateX}px)`;\n }\n\n /**\n * Update night drawings\n */\n updateTimezones() {\n const timezoneTexts = document.querySelectorAll('.mt-map-timezone-text');\n const currentDate = this.options.timezones.date || new Date();\n\n Array.from(timezoneTexts).forEach((timezoneText) => {\n timezoneText.textContent = utils.formatDate(\n currentDate,\n timezoneText.__data__.properties.zone,\n );\n });\n }\n\n updateMarkers() {\n const defaultGroupBy = (a) => `${a.longitude},${a.latitude}`;\n\n this.dataMarkers = d3.nest()\n .key(defaultGroupBy)\n .entries(this.maptable.data)\n .filter((d) => d.values[0].x !== 0);\n\n // We merge both data\n this.dataMarkers.forEach((d) => {\n d.attr = {};\n d.attrProperties = {};\n });\n\n // We calculate attributes values\n Object.keys(this.options.markers.attr).forEach((k) => {\n this.setAttrValues(k, this.options.markers.attr[k], this.dataMarkers);\n });\n\n // Enter\n const markerItem = this.layerMarkers\n .selectAll('.mt-map-marker')\n .data(this.dataMarkers);\n let markerObject = markerItem.enter();\n if (this.options.markers.customTag) {\n markerObject = this.options.markers.customTag(markerObject);\n } else {\n markerObject = markerObject.append('svg:circle');\n }\n const markerClassName = (this.options.markers.className)\n ? this.options.markers.className : '';\n\n markerObject.attr('class', `mt-map-marker ${markerClassName}`);\n\n // Exit\n markerItem.exit().transition()\n .attr('r', 0)\n .attr('fill', '#eee')\n .style('opacity', 0)\n .remove();\n\n // Update\n const attrX = (this.options.markers.attrX) ? this.options.markers.attrX : 'cx';\n const attrY = (this.options.markers.attrY) ? this.options.markers.attrY : 'cy';\n\n const attrXDelta = (this.options.markers.attrXDelta) ? this.options.markers.attrXDelta : 0;\n const attrYDelta = (this.options.markers.attrYDelta) ? this.options.markers.attrYDelta : 0;\n\n const markerUpdate = markerItem\n .attr(attrX, (d) => d.values[0].x + attrXDelta)\n .attr(attrY, (d) => d.values[0].y + attrYDelta);\n\n this.getAllMtMapMarker().each(function (d) {\n Object.keys(d.attr).forEach((key) => {\n d3.select(this).attr(key, d.attr[key]);\n });\n });\n\n if (this.options.markers.tooltip) {\n this.activateTooltip(\n markerUpdate,\n this.tooltipMarkersNode,\n this.options.markers.tooltip,\n false,\n );\n }\n\n this.rescale();\n }\n\n fitContent() {\n if (this.maptable.data.length === 0) {\n this.transX = 0;\n this.transY = 0;\n this.scale = 1;\n this.zoomListener.translate([this.transX, this.transY])\n .scale(this.scale);\n return;\n }\n const hor = d3.extent(this.maptable.data, (d) => d.x);\n const ver = d3.extent(this.maptable.data, (d) => d.y);\n\n // center dots with the good ratio\n const ratio = this.getWidth() / this.getHeight();\n const deltaMarker = 20 + ((this.options.title) ? 30 : 0);\n\n const currentWidth = (hor[1] - hor[0]) + deltaMarker;\n const currentHeight = (ver[1] - ver[0]) + deltaMarker;\n\n const realHeight = currentWidth / ratio;\n const realWidth = currentHeight * ratio;\n\n let diffMarginWidth = 0;\n let diffMarginHeight = 0;\n if (realWidth >= currentWidth) {\n diffMarginWidth = (realWidth - currentWidth) / 2;\n } else {\n diffMarginHeight = (realHeight - currentHeight) / 2;\n }\n\n // add layout margin\n hor[0] -= (this.options.fitContentMargin + diffMarginWidth);\n hor[1] += (this.options.fitContentMargin + diffMarginWidth);\n ver[0] -= (this.options.fitContentMargin + diffMarginHeight);\n ver[1] += (this.options.fitContentMargin + diffMarginHeight);\n\n this.scale = this.getWidth() / (hor[1] - hor[0]);\n this.transX = -1 * hor[0] * this.scale;\n this.transY = -1 * ver[0] * this.scale;\n\n this.zoomListener.translate([this.transX, this.transY]).scale(this.scale);\n }\n\n buildTitle() {\n const titleContainer = this.svg\n .append('svg')\n .attr('width', this.getWidth())\n .attr('x', 0)\n .attr('y', (this.getHeight() - 30))\n .attr('height', 30);\n\n if (this.options.title.bgColor) {\n titleContainer.append('rect')\n .attr('x', 0)\n .attr('y', 0)\n .attr('width', this.getWidth())\n .attr('height', 30)\n .attr('fill', this.options.title.bgColor);\n }\n\n titleContainer.append('text')\n .attr('id', 'mt-map-title')\n .attr('x', 20)\n .attr('font-size', this.scaleFontSize(this.options.title.fontSize))\n .attr('font-family', this.options.title.fontFamily)\n .attr('y', 20);\n\n if (this.options.title.source) {\n titleContainer.append('text')\n .attr('y', 20)\n .attr('x', (this.getWidth() - 20))\n .attr('text-anchor', 'end')\n .attr('font-size', this.scaleFontSize(this.options.title.fontSize))\n .attr('font-family', this.options.title.fontFamily)\n .html(this.options.title.source());\n }\n }\n\n /**\n * We encode a transaltion to be independent from the dimensions of the visualization\n * @param originalTranslation: Array - original translation value (from screen)\n * @returns encodedTranslation: Array - encoded translation\n */\n encodeTranslation(originalTranslation) {\n const newTx = originalTranslation[0] / (this.scale * this.getWidth());\n\n const newTy = originalTranslation[1] / (this.scale * this.getHeight());\n\n return [newTx, newTy];\n }\n\n /**\n * We decode a translation to adapt it to the dimensions of the visualization\n * @param encodedTranslation: Array - encoded translation\n * @returns originalTranslation: Array - original translation value (from screen)\n */\n decodeTranslation(encodedTranslation) {\n const newTx = encodedTranslation[0] * this.getWidth() * this.scale;\n\n const newTy = encodedTranslation[1] * this.getHeight() * this.scale;\n\n return [newTx, newTy];\n }\n\n /**\n * Restore state from the url hash\n */\n restoreState(defaultZoom) {\n if (!defaultZoom || defaultZoom.length !== 3) return;\n this.scale = defaultZoom[0];\n const originalTranslation = this.decodeTranslation([defaultZoom[1], defaultZoom[2]]);\n this.transX = originalTranslation[0];\n this.transY = originalTranslation[1];\n this.zoomListener.scale(defaultZoom[0])\n .translate(originalTranslation)\n .event(this.svg);\n }\n\n /**\n * Save state into the url hash\n */\n saveState() {\n const encodedTranslation = this.encodeTranslation([this.transX, this.transY]);\n const exportedData = [this.scale, encodedTranslation[0],\n encodedTranslation[1]];\n if (exportedData[0] !== 1 && exportedData[1] !== 0 && exportedData[2] !== 0) {\n this.maptable.saveState('zoom', exportedData);\n } else {\n this.maptable.removeState('zoom');\n }\n }\n\n rescale() {\n const self = this;\n if (d3.event && d3.event.translate) {\n this.scale = d3.event.scale;\n this.transX = (this.scale === 1) ? 0 : d3.event.translate[0];\n this.transY = (this.scale === 1) ? 0 : d3.event.translate[1];\n }\n\n const maxTransX = 0;\n const maxTransY = 0;\n const minTransX = this.getWidth() * (1 - this.scale);\n const minTransY = this.getHeight() * (1 - this.scale);\n\n if (this.transY > maxTransY) {\n this.transY = maxTransY;\n } else if (this.transY < minTransY) {\n this.transY = minTransY;\n }\n\n if (this.transX > maxTransX) {\n this.transX = maxTransX;\n } else if (this.transX < minTransX) {\n this.transX = minTransX;\n }\n\n if (d3.event && d3.event.translate) {\n d3.event.translate[0] = this.transX;\n d3.event.translate[1] = this.transY;\n }\n\n this.layerGlobal.style(\n 'transform',\n `translate(${this.transX}px,${this.transY}px)scale(${this.scale})`,\n );\n\n // Hide tooltip\n if (self.tooltipCountriesNode) self.tooltipCountriesNode.attr('style', 'display:none;');\n if (self.tooltipMarkersNode) self.tooltipMarkersNode.attr('style', 'display:none;');\n\n // Rescale markers size\n if (this.options.markers) {\n // markers\n this.getAllMtMapMarker().each(function (d) {\n // stroke\n if (d.attr['stroke-width']) {\n d3.select(this).attr('stroke-width', d.attr['stroke-width'] / self.scaleAttributes());\n }\n // radius\n if (d.attr.r) {\n d3.select(this).attr('r', d.attr.r / self.scaleAttributes());\n }\n });\n }\n\n // Rescale Sun\n if (this.options.night && !this.options.disableSun) {\n d3.selectAll(`${this.containerSelector} .mt-map-sun`).style(\n 'r',\n (this.getHeight() * 0.35) / this.scale,\n );\n }\n\n // Rescale Country stroke-width\n if (this.options.countries) {\n this.getAllMtMapCountry().style(\n 'stroke-width',\n this.options.countries.attr['stroke-width'] / this.scale,\n );\n }\n\n // Rescale heatmap borders\n if (this.options.heatmap && this.options.heatmap.borders) {\n d3.selectAll(`${this.containerSelector} .mt-map-heatmap-borders-paths`)\n .style('stroke-width', this.options.heatmap.borders.stroke / this.scale);\n }\n\n // save state\n if (this.maptable.firstExecution && this.options.saveState) this.saveState();\n }\n\n setAttrValues(attrKey, attrValue, dataset) {\n if (typeof (attrValue) === 'number' || typeof (attrValue) === 'string') {\n // Static value\n dataset.forEach((d) => {\n d.attr[attrKey] = attrValue;\n });\n } else if (typeof (attrValue) === 'function') {\n // Dynamic value based on the dataset\n dataset.forEach((d) => {\n d.attr[attrKey] = attrValue(d);\n });\n } else if (typeof (attrValue) === 'object') {\n let scale = 'linear';\n let key = null;\n let mode = 'count';\n let scaleToUse = d3.scale.linear();\n if (attrValue.aggregate) {\n key = (typeof (attrValue.aggregate.key) === 'function')\n ? attrValue.aggregate.key.bind(this.maptable)()\n : attrValue.aggregate.key;\n\n mode = (typeof (attrValue.aggregate.mode) === 'function')\n ? attrValue.aggregate.mode.bind(this.maptable)()\n : attrValue.aggregate.mode;\n\n if (typeof (attrValue.aggregate.scale) === 'function') {\n scale = attrValue.aggregate.scale.bind(this.maptable)();\n } else if (attrValue.aggregate.scale) {\n scale = attrValue.aggregate.scale;\n }\n\n if (!key || !mode) {\n throw new Error(`MapTable: You should provide values 'key' & 'mode' for attr.${attrKey}.aggregate`);\n }\n\n // Custom aggregate mode\n if (mode === 'sum') {\n attrValue.rollup = (groupedData) => (\n groupedData.map((d) => Number(d[key])).reduce((a, c) => a + c, 0)\n );\n } else if (mode === 'avg') {\n attrValue.rollup = (groupedData) => {\n if (!groupedData.length) return 0;\n const validData = groupedData.filter((d) => !Number.isNaN(Number(d[key])));\n return validData\n .map((d) => Number(d[key]))\n .reduce((a, c) => a + c, 0) / validData.length;\n };\n } else if (mode === 'count') {\n attrValue.rollup = (groupedData) => groupedData.length;\n } else if (mode === 'min') {\n attrValue.rollup = (groupedData) => {\n if (!groupedData.length) return 0;\n const groupedValues = groupedData.map((d) => Number(d[key]));\n return groupedValues.reduce((min, p) => (p < min ? p : min), groupedValues[0]);\n };\n } else if (mode === 'max') {\n attrValue.rollup = (groupedData) => {\n if (!groupedData.length) return 0;\n const groupedValues = groupedData.map((d) => Number(d[key]));\n return groupedValues.reduce((max, p) => (p > max ? p : max), groupedValues[0]);\n };\n } else if (mode.indexOf('percentile') !== -1) {\n const percentile = utils.toNumber(mode);\n attrValue.rollup = (groupedData) => {\n if (!groupedData.length) return 0;\n const groupedValues = groupedData.map((d) => Number(d[key]));\n return utils.quantile(groupedValues, percentile);\n };\n } else if (typeof (attrValue.rollup) === 'function') {\n attrValue.rollup = attrValue.rollup.bind(this.maptable);\n }\n\n // Custom scale\n if (scale) {\n if (scale.indexOf('log') !== -1) {\n scaleToUse = d3.scale.log();\n } else if (scale.indexOf('pow') !== -1) {\n scaleToUse = d3.scale.pow().exponent(utils.toNumber(scale) || 1);\n } else if (scale === 'sqrt') {\n scaleToUse = d3.scale.sqrt();\n }\n // Rank scale neeed additional transformations\n }\n }\n\n // Dynamic value based on a scale\n if (!attrValue.rollup) {\n attrValue.rollup = (d) => d.length;\n }\n if (!attrValue.min || !attrValue.max) {\n throw new Error(`MapTable: You should provide values 'min' & 'max' for attr.${attrKey}`);\n }\n\n dataset.forEach((d) => {\n const aggregatedValue = attrValue.rollup(d.values);\n if (!d.attrProperties) d.attrProperties = {};\n if (!d.attrProperties[attrKey]) d.attrProperties[attrKey] = {};\n d.attrProperties[attrKey].value = aggregatedValue;\n if (key) {\n d.attrProperties[attrKey].key = key;\n d.attrProperties[attrKey].mode = mode;\n d.attrProperties[attrKey].scale = scale;\n const c = this.maptable.columnDetails[key];\n d.attrProperties[attrKey].columnDetails = c;\n const datum = {};\n datum[key] = aggregatedValue;\n d.attrProperties[attrKey].formatted = (c && c.cellContent)\n ? c.cellContent.bind(this.maptable)(datum)\n : aggregatedValue;\n }\n });\n if (scale === 'rank') {\n const positiveRanks = utils.uniqueValues([0].concat(dataset\n .map((d) => Math.floor(d.attrProperties[attrKey].value * 100) / 100)\n .filter((v) => v > 0)));\n const negativeRanks = utils.uniqueValues(dataset\n .map((d) => Math.floor(d.attrProperties[attrKey].value * 100) / 100)\n .filter((v) => v < 0));\n\n positiveRanks.sort((a, b) => a - b);\n negativeRanks.sort((a, b) => b - a);\n\n dataset.forEach((d) => {\n if (d.attrProperties[attrKey].value !== 0) {\n const ranks = d.attrProperties[attrKey].value >= 0 ? positiveRanks : negativeRanks;\n const pos = ranks.indexOf(Math.floor(d.attrProperties[attrKey].value * 100) / 100);\n const percentile = Math.round((pos / ranks.length) * 100);\n const newValue = d.attrProperties[attrKey].value < 0\n ? percentile - (percentile * 2)\n : percentile;\n d.attrProperties[attrKey].value = newValue;\n }\n });\n }\n\n let scaleDomain = d3.extent(dataset, (d) => Number(d.attrProperties[attrKey].value));\n if (scaleDomain[0] === 0 && scale && scale.indexOf('log') !== '-1') {\n scaleDomain = d3.extent(\n dataset.filter((v) => Number(v.attrProperties[attrKey].value) !== 0),\n (d) => Number(d.attrProperties[attrKey].value),\n );\n }\n if (attrValue.transform) {\n scaleDomain[0] = attrValue.transform\n .bind(this.maptable)(scaleDomain[0], this.maptable.data);\n scaleDomain[1] = attrValue.transform\n .bind(this.maptable)(scaleDomain[1], this.maptable.data);\n }\n\n let minValue = attrValue.min;\n let maxValue = attrValue.max;\n\n if (attrValue.min === 'minValue') {\n minValue = scaleDomain[0];\n }\n if (attrValue.max === 'maxValue') {\n maxValue = scaleDomain[1];\n }\n\n // check for negative color declarations\n if ((attrValue.maxNegative && !attrValue.minNegative)\n || (!attrValue.maxNegative && attrValue.minNegative)) {\n throw new Error('MapTable: maxNegative or minNegative undefined. Please declare both.');\n }\n const useNegative = (attrValue.maxNegative && attrValue.minNegative);\n let scaleFunction;\n let scaleNegativeFunction;\n\n if (useNegative) {\n scaleFunction = scaleToUse.copy()\n .domain([0, scaleDomain[1]])\n .range([minValue, maxValue]);\n scaleNegativeFunction = scaleToUse.copy()\n .domain([scaleDomain[0], 0])\n .range([attrValue.maxNegative, attrValue.minNegative]);\n } else {\n scaleFunction = scaleToUse\n .domain(scaleDomain)\n .range([minValue, maxValue]);\n }\n\n dataset.forEach((d) => {\n let scaledValue;\n if (!d.values.length || Number.isNaN(d.attrProperties[attrKey].value)) {\n if (typeof (attrValue.empty) === 'undefined') {\n throw new Error(`MapTable: no empty property found for attr.${attrKey}`);\n }\n scaledValue = attrValue.empty;\n } else {\n const originalValueRaw = d.attrProperties[attrKey].value;\n const originalValue = (attrValue.transform)\n ? attrValue.transform.bind(this.maptable)(originalValueRaw, this.maptable.data)\n : originalValueRaw;\n\n if (useNegative && originalValue < 0) {\n scaledValue = scaleNegativeFunction(originalValue);\n } else {\n scaledValue = scaleFunction(originalValue);\n }\n }\n d.attr[attrKey] = scaledValue;\n });\n } else {\n throw new Error(`Maptable: Invalid value for ${attrKey}`);\n }\n }\n\n render() {\n if (this.options.markers) this.updateMarkers();\n if (this.options.countries) this.updateCountries();\n if (this.options.night) this.updateNight();\n if (this.options.timezones) this.updateTimezones();\n if (this.options.title) this.updateTitle();\n if (this.options.heatmap) this.updateHeatmap();\n if (this.options.autoFitContent) {\n this.fitContent();\n this.rescale();\n }\n // On render\n if (this.options.onRender && this.options.onRender.constructor === Function) {\n this.options.onRender.bind(this.maptable)();\n }\n }\n\n updateTitle() {\n if (this.options.title.content) {\n const showing = this.maptable.data.filter((d) => d[this.options.latitudeKey] !== 0).length;\n const total = this.maptable.rawData.filter((d) => d[this.options.latitudeKey] !== 0).length;\n\n let inlineFilters = '';\n if (this.maptable.filters) {\n inlineFilters = this.maptable.filters.getDescription();\n }\n\n this.container.querySelector('#mt-map-title').innerHTML = this.options.title\n .content.bind(this.maptable)(\n showing,\n total,\n inlineFilters,\n this.maptable.data,\n this.maptable.rawData,\n this.dataCountries,\n );\n }\n }\n\n activateTooltip(target, tooltipNode, tooltipContent, isCountry) {\n const self = this;\n target.on(isCountry ? 'mousemove' : 'mouseover', function (d) {\n const content = tooltipContent.bind(this.maptable)(d);\n if (!content) return;\n tooltipNode.html(content).attr('style', 'display:block;position:fixed;');\n\n let mouseLeft;\n let mouseTop;\n const tooltipDelta = tooltipNode.node().offsetWidth / 2;\n if (isCountry) {\n const mapRect = self.node.getBoundingClientRect();\n const mousePosition = d3.mouse(self.svg.node()).map((v) => parseInt(v, 10));\n\n mouseLeft = mapRect.left + mousePosition[0] - tooltipDelta;\n mouseTop = mapRect.top + mousePosition[1] + 10;\n } else {\n const targetRect = this.getBoundingClientRect();\n mouseLeft = (targetRect.left + (targetRect.width / 2) - tooltipDelta);\n mouseTop = (targetRect.top + targetRect.height + 2); // +2 is for the border\n }\n\n tooltipNode.attr(\n 'style',\n `top:${mouseTop}px;left:${mouseLeft}px;display:block;position:fixed;`,\n )\n .on('mouseout', () => {\n tooltipNode.style('display', 'none');\n });\n })\n .on('mouseout', () => {\n tooltipNode.style('display', 'none');\n });\n }\n\n exportSvg() {\n // Get the d3js SVG element\n const svg = this.container.querySelector('#mt-map-svg');\n // Extract the data as SVG text string\n const svgXml = `\n${(new XMLSerializer()).serializeToString(svg)}`;\n\n if (this.options.exportSvgClient) {\n if (!window.saveAs) {\n throw new Error('MapTable: Missing FileSaver.js library');\n }\n const blob = new Blob([svgXml], { type: 'image/svg+xml' });\n window.saveAs(blob, 'visualization.svg');\n } else if (this.options.exportSvg) {\n const form = this.node.querySelector('#mt-map-svg-form');\n form.querySelector('[name=\"data\"]').value = svgXml;\n form.submit();\n }\n }\n\n addExportSvgCapability() {\n const exportNode = document.createElement('div');\n exportNode.setAttribute('id', 'mt-map-export');\n this.container.querySelector('#mt-map').appendChild(exportNode);\n\n const exportButton = document.createElement('button');\n exportButton.setAttribute('class', 'btn btn-xs btn-default');\n exportButton.innerHTML = 'Download';\n exportButton.addEventListener('click', this.exportSvg.bind(this));\n exportNode.appendChild(exportButton);\n\n if (this.options.exportSvg) {\n const exportForm = document.createElement('div');\n exportForm.innerHTML = `
`;\n exportNode.appendChild(exportForm);\n }\n }\n}\n","import utils from '../utils';\n\nexport default class Filters {\n constructor(maptable, options) {\n this.maptable = maptable;\n this.options = options;\n this.criteria = [];\n\n if (this.options.show) {\n const arrayDiff = this.options.show.filter((i) => Object.keys(this.maptable.columnDetails).indexOf(i) < 0);\n if (arrayDiff.length > 0) {\n throw new Error(`MapTable: invalid columns \"${arrayDiff.join(', ')}\"`);\n }\n this.activeColumns = this.options.show;\n } else {\n this.activeColumns = Object.keys(this.maptable.columnDetails);\n }\n\n this.container = document.createElement('div');\n this.maptable.node.appendChild(this.container);\n\n this.containerSelector = maptable.options.target;\n this.container = document.querySelector(maptable.options.target);\n this.node = this.container.querySelector('#mt-filters');\n\n if (!this.node) {\n this.node = document.createElement('div');\n this.node.setAttribute('id', 'mt-filters');\n this.node.setAttribute('class', 'panel panel-default');\n this.maptable.node.appendChild(this.node);\n }\n\n // -- Filters Header\n\n const filtersHeaderNode = document.createElement('div');\n filtersHeaderNode.setAttribute('class', 'panel-heading');\n\n const filtersResetNode = document.createElement('button');\n filtersResetNode.setAttribute('id', 'mt-filters-reset');\n filtersResetNode.setAttribute('class', 'btn btn-default btn-xs pull-right');\n filtersResetNode.style.display = 'none';\n filtersResetNode.style.marginLeft = 5;\n filtersResetNode.innerText = '↺ Reset';\n filtersResetNode.addEventListener('click', this.reset);\n filtersHeaderNode.appendChild(filtersResetNode);\n\n const filtersTitleNode = document.createElement('h3');\n filtersTitleNode.setAttribute('class', 'panel-title');\n filtersTitleNode.appendChild(document.createTextNode('Filters'));\n filtersHeaderNode.appendChild(filtersTitleNode);\n\n this.node.appendChild(filtersHeaderNode);\n\n // -- Filters Content\n const filtersBodyNode = document.createElement('div');\n filtersBodyNode.setAttribute('id', 'mt-filters-content');\n filtersBodyNode.setAttribute('class', 'panel-body');\n\n const filtersElementsNode = document.createElement('div');\n filtersElementsNode.setAttribute('id', 'mt-filters-elements');\n filtersBodyNode.appendChild(filtersElementsNode);\n\n const filtersNewNode = document.createElement('a');\n filtersNewNode.setAttribute('id', 'mt-filters-new');\n filtersNewNode.setAttribute('href', '#');\n filtersNewNode.innerText = '+ New filter';\n filtersNewNode.addEventListener('click', this.add.bind(this));\n filtersBodyNode.appendChild(filtersNewNode);\n\n this.node.appendChild(filtersBodyNode);\n }\n\n /**\n * Add a filter\n * @param evt: Window Event Object\n */\n add(evt) {\n if (evt) evt.preventDefault();\n const possibleFilters = this.getPossibleFilters();\n\n if (possibleFilters.length === 0) {\n return;\n }\n const filterName = possibleFilters[0].key;\n this.create(filterName);\n }\n\n create(filterName, replaceNode) {\n const rowNode = this.buildRow(filterName);\n if (replaceNode) {\n replaceNode.parentNode.replaceChild(rowNode, replaceNode);\n } else {\n this.node.querySelector('#mt-filters-elements').appendChild(rowNode);\n }\n this.criteria.push(filterName);\n this.maptable.render();\n if (this.container.style.display === 'none') {\n this.toggle();\n }\n }\n\n remove(filterName) {\n const rowNode = this.node.querySelector(`[data-mt-filter-name=\"${filterName}\"]`);\n if (rowNode) rowNode.parentNode.removeChild(rowNode);\n const filterIndex = this.criteria.indexOf(filterName);\n this.criteria.splice(filterIndex, 1);\n this.maptable.render();\n }\n\n /**\n * Reset filters\n */\n reset() {\n const rowNodes = this.node.querySelectorAll('[data-mt-filter-name]');\n for (let i = 0; i < rowNodes.length; i += 1) {\n rowNodes[i].parentNode.removeChild(rowNodes[i]);\n }\n this.criteria = [];\n this.maptable.render();\n }\n\n /**\n * Export the current filters to an object\n * @returns exportedFilters: Object - key => value that contain data about the current filters\n */\n exportFilters() {\n const output = {};\n const filtersChildren = this.node.querySelector('#mt-filters-elements').childNodes;\n\n for (let i = 0; i < filtersChildren.length; i += 1) {\n const element = filtersChildren[i];\n const filterName = element.querySelector('.mt-filter-name').value;\n const columnDetails = this.maptable.columnDetails[filterName];\n const filterOutput = [columnDetails.filterMethod];\n if (columnDetails.filterMethod === 'compare') {\n const filterRangeSelect = element.querySelector('.mt-filter-range');\n if (filterRangeSelect) {\n filterOutput[1] = filterRangeSelect.value;\n\n if (filterRangeSelect.value !== 'any') {\n if (filterRangeSelect.value === 'BETWEEN') {\n const filterValueMin = element.querySelector('.mt-filter-value-min').value;\n const filterValueMax = element.querySelector('.mt-filter-value-max').value;\n if (filterValueMin !== '' && filterValueMax === '') {\n filterOutput[2] = filterValueMin;\n filterOutput[3] = filterValueMax;\n }\n } else {\n const filterValue = element.querySelector('.mt-filter-value-min').value;\n filterOutput[2] = filterValue;\n }\n }\n }\n } else if (columnDetails.filterMethod === 'field' || columnDetails.filterMethod === 'dropdown') {\n filterOutput[1] = '';\n const filterValue = element.querySelector('.mt-filter-value').value;\n filterOutput[2] = filterValue;\n }\n if (filterOutput[1] !== 'any' && filterOutput[2] && filterOutput[2] !== '') {\n output[filterName] = filterOutput;\n }\n }\n return output;\n }\n\n /**\n * Set the value for the current filters\n * @param criteria - Object - same format as the exportedFilters\n */\n setFilters(criteria) {\n this.reset();\n Object.keys(criteria).forEach((filterName) => {\n this.create(filterName);\n const criterion = criteria[filterName];\n const row = document.querySelector(`#mt-filters-elements [data-mt-filter-name=\"${filterName}\"]`);\n if (row) {\n if (criterion[0] === 'compare') {\n row.querySelector('.mt-filter-range').value = criterion[1];\n if (criterion[1] !== 'any') {\n if (criterion[1] === 'BETWEEN') {\n row.querySelector('.mt-filter-value-min').value = criterion[2];\n row.querySelector('.mt-filter-value-max').value = criterion[3];\n } else {\n row.querySelector('.mt-filter-value-min').value = criterion[2];\n }\n }\n } else if (criterion[0] === 'field' || criterion[0] === 'dropdown') {\n row.querySelector('.mt-filter-value').value = decodeURIComponent(criterion[2]);\n }\n }\n });\n this.maptable.render();\n }\n\n /**\n * Restore state from the URL hash\n */\n restoreState(defaultCriteria) {\n if (!defaultCriteria) return;\n this.setFilters(defaultCriteria);\n }\n\n /**\n * Get a human readable description of the filters (used for the title)\n * @returns {string} Human readable description\n */\n getDescription() {\n const outputArray = [];\n\n const filtersChildren = this.node.querySelector('#mt-filters-elements').childNodes;\n\n for (let i = 0; i < filtersChildren.length; i += 1) {\n const element = filtersChildren[i];\n const filterName = element.querySelector('.mt-filter-name').value;\n\n const columnDetails = this.maptable.columnDetails[filterName];\n\n let line = '';\n\n if (columnDetails.filterMethod === 'compare') {\n const filterRangeSelect = element.querySelector('.mt-filter-range');\n if (filterRangeSelect.value !== 'any') {\n if (filterRangeSelect.value === 'BETWEEN') {\n const filterValueMin = element.querySelector('.mt-filter-value-min').value;\n const filterValueMax = element.querySelector('.mt-filter-value-max').value;\n if (filterValueMin === '' || filterValueMax === '') continue;\n line += `${columnDetails.title} is between `;\n line += `${filterValueMin} and\n ${filterValueMax}`;\n } else {\n const filterValue = element.querySelector('.mt-filter-value-min').value;\n if (filterValue === '') continue;\n line += `${columnDetails.title} is `;\n line += filterRangeSelect.options[filterRangeSelect.selectedIndex].text;\n line += `${filterValue}`;\n }\n }\n } else if (columnDetails.filterMethod === 'field' || columnDetails.filterMethod === 'dropdown') {\n const filterValue = element.querySelector('.mt-filter-value').value;\n if (filterValue === '') continue;\n const separatorWord = columnDetails.filterMethod === 'field' ? 'contains' : 'is';\n line += `${columnDetails.title} ${separatorWord}\n ${filterValue}`;\n }\n outputArray.push(line);\n }\n return outputArray.join(', ');\n }\n\n buildRow(filterName) {\n const that = this;\n\n const possibleFilters = this.getPossibleFilters();\n\n const columnDetails = this.maptable.columnDetails[filterName];\n\n const rowNode = document.createElement('div');\n rowNode.setAttribute('class', 'mt-filter-row');\n rowNode.setAttribute('data-mt-filter-name', filterName);\n\n // Button to remove filter\n const minusButton = document.createElement('button');\n minusButton.setAttribute('class', 'btn btn-default pull-right');\n minusButton.setAttribute('data-mt-filter-btn-minus', 1);\n minusButton.innerText = '– Remove this filter';\n minusButton.addEventListener('click', () => {\n filterName = rowNode.querySelector('.mt-filter-name').value;\n this.remove(filterName);\n });\n rowNode.appendChild(minusButton);\n\n // Filters separator \"AND\"\n const filterSeparator = document.createElement('span');\n filterSeparator.setAttribute('class', 'mt-filters-and');\n filterSeparator.innerText = 'And ';\n rowNode.appendChild(filterSeparator);\n\n // Filter name select\n const filterNameSelect = document.createElement('select');\n filterNameSelect.setAttribute('class', 'mt-filter-name form-control form-control-inline');\n utils.appendOptions(\n filterNameSelect,\n possibleFilters.map((f) => ({ text: f.title, value: f.key }))\n );\n filterNameSelect.value = filterName;\n\n filterNameSelect.addEventListener('change', function () {\n const oldFilterName = this.parentNode.getAttribute('data-mt-filter-name');\n const newFilterName = this.value;\n that.create(newFilterName, this.parentNode);\n that.remove(oldFilterName);\n that.refresh();\n });\n rowNode.appendChild(filterNameSelect);\n\n // Filter verb\n const filterVerb = document.createElement('span');\n filterVerb.innerText = columnDetails.filterMethod === 'field' ? ' contains ' : ' is ';\n rowNode.appendChild(filterVerb);\n\n // Filter range\n let filterRange = null;\n if (columnDetails.filterMethod !== 'field' && columnDetails.filterMethod !== 'dropdown') {\n filterRange = document.createElement('select');\n filterRange.setAttribute('class', 'mt-filter-range form-control form-control-inline');\n utils.appendOptions(\n filterRange,\n ['any', '=', '≠', '<', '>', '≤', '≥', 'BETWEEN'].map((v) => ({ text: v, value: v }))\n );\n filterRange.addEventListener('change', function () {\n that.handleRangeChange(this);\n });\n rowNode.appendChild(filterRange);\n\n // Little space:\n rowNode.appendChild(document.createTextNode(' '));\n }\n\n // Filter value\n const filterValue = document.createElement('div');\n filterValue.style.display = 'inline-block';\n filterValue.setAttribute('class', 'mt-filter-value-container');\n\n if (columnDetails.filterMethod === 'compare') {\n ['min', 'max'].forEach((val, i) => {\n const filterInput = document.createElement('input');\n filterInput.setAttribute('class', `form-control form-control-inline mt-filter-value-${val}`);\n filterInput.setAttribute('type', columnDetails.filterInputType);\n filterInput.addEventListener('keyup', this.maptable.render.bind(this.maptable));\n filterInput.addEventListener('change', this.maptable.render.bind(this.maptable));\n filterValue.appendChild(filterInput);\n if (i === 0) {\n // AND\n const filterValueAnd = document.createElement('span');\n filterValueAnd.setAttribute('class', 'mt-filter-value-and');\n filterValueAnd.innerText = ' and ';\n filterValue.appendChild(filterValueAnd);\n }\n });\n } else if (columnDetails.filterMethod === 'field') {\n const filterInput = document.createElement('input');\n filterInput.setAttribute('class', 'form-control form-control-inline mt-filter-value');\n filterInput.setAttribute('type', 'text');\n filterInput.addEventListener('keyup', this.maptable.render.bind(this.maptable));\n filterInput.addEventListener('change', this.maptable.render.bind(this.maptable));\n filterValue.appendChild(filterInput);\n } else if (columnDetails.filterMethod === 'dropdown') {\n const filterSelect = document.createElement('select');\n filterSelect.setAttribute('class', 'form-control form-control-inline mt-filter-value');\n\n const uniqueValues = d3\n .nest()\n .key((d) => d[filterName])\n .sortKeys(d3.ascending)\n .entries(this.maptable.rawData);\n\n utils.appendOptions(filterSelect, [{ text: 'Any', value: '' }].concat(uniqueValues.map((k) => ({ text: k.key, value: k.key }))));\n\n filterSelect.addEventListener('change', this.maptable.render.bind(this.maptable));\n filterValue.appendChild(filterSelect);\n }\n\n rowNode.appendChild(filterValue);\n\n // We trigger it here to handle the value of the filter range\n if (filterRange) {\n this.handleRangeChange(filterRange);\n }\n\n return rowNode;\n }\n\n handleRangeChange(filterRange) {\n const rowNode = filterRange.parentNode;\n if (filterRange.value === 'any') {\n rowNode.querySelector('.mt-filter-value-container').style.display = 'none';\n } else {\n rowNode.querySelector('.mt-filter-value-container').style.display = 'inline-block';\n if (filterRange.value === 'BETWEEN') {\n rowNode.querySelector('.mt-filter-value-min').style.display = 'inline-block';\n rowNode.querySelector('.mt-filter-value-and').style.display = 'inline-block';\n rowNode.querySelector('.mt-filter-value-max').style.display = 'inline-block';\n } else {\n rowNode.querySelector('.mt-filter-value-min').style.display = 'inline-block';\n rowNode.querySelector('.mt-filter-value-and').style.display = 'none';\n rowNode.querySelector('.mt-filter-value-max').style.display = 'none';\n }\n }\n this.maptable.render.bind(this.maptable)();\n }\n\n getPossibleFilters(except) {\n return Object.keys(this.maptable.columnDetails)\n .map((k) => utils.extendRecursive({ key: k }, this.maptable.columnDetails[k]))\n .filter((v) => this.activeColumns.indexOf(v.key) !== -1 && ((except && except === v.key) || (this.criteria.indexOf(v.key) === -1 && v.filterMethod && !v.isVirtual)));\n }\n\n filterData() {\n const that = this;\n this.maptable.data = this.maptable.rawData.filter((d) => {\n const rowNodes = this.node.querySelectorAll('.mt-filter-row');\n let matched = true;\n for (let i = 0; i < rowNodes.length && matched; i += 1) {\n const rowNode = rowNodes[i];\n const filterName = rowNode.getAttribute('data-mt-filter-name');\n const columnDetails = that.maptable.columnDetails[filterName];\n const fmt = columnDetails.dataParse; // shortcut\n\n if (columnDetails.filterMethod === 'dropdown') {\n const filterValue = rowNode.querySelector('.mt-filter-value').value;\n if (filterValue === '') continue;\n if (d[filterName] !== filterValue) matched = false;\n } else if (columnDetails.filterMethod === 'field') {\n const filterValue = rowNode.querySelector('.mt-filter-value').value;\n if (filterValue === '') continue;\n if (d[filterName].toLowerCase().indexOf(filterValue.toLowerCase()) === -1) {\n matched = false;\n }\n } else if (columnDetails.filterMethod === 'compare') {\n const filterRange = rowNode.querySelector('.mt-filter-range').value;\n if (filterRange === 'BETWEEN') {\n const filterValueMin = rowNode.querySelector('.mt-filter-value-min').value;\n const filterValueMax = rowNode.querySelector('.mt-filter-value-max').value;\n if (filterValueMin === '' || filterValueMax === '') continue;\n if (fmt && (fmt(d[filterName]) < fmt(filterValueMin) || fmt(d[filterName]) > fmt(filterValueMax))) {\n matched = false;\n } else if (parseInt(d[filterName], 10) < parseInt(filterValueMin, 10) || parseInt(d[filterName], 10) > parseInt(filterValueMax, 10)) {\n matched = false;\n }\n } else {\n const filterValue = rowNode.querySelector('.mt-filter-value-min').value;\n if (filterValue === '') continue;\n if (fmt && !utils.rangeToBool(fmt(d[filterName]), filterRange, fmt(filterValue))) {\n matched = false;\n } else if (!fmt && !utils.rangeToBool(d[filterName], filterRange, filterValue)) {\n matched = false;\n }\n }\n }\n\n if ((fmt && utils.isBlank(fmt(d[filterName]))) || utils.isBlank(d[filterName])) {\n matched = false;\n continue;\n }\n }\n return matched;\n });\n // save state\n if (this.options.saveState) this.maptable.saveState('filters', this.exportFilters());\n }\n\n refresh() {\n // update dropdown\n const filterNameSelects = this.node.querySelectorAll('.mt-filter-name');\n for (let i = 0; i < filterNameSelects.length; i += 1) {\n const filterNameSelect = filterNameSelects[i];\n const filterName = filterNameSelect.value;\n const possibleFilters = this.getPossibleFilters(filterName);\n filterNameSelect.innerHTML = '';\n utils.appendOptions(\n filterNameSelect,\n possibleFilters.map((f) => ({ text: f.title, value: f.key }))\n );\n filterNameSelect.value = filterName;\n }\n\n // Hide the first \"And\"\n if (this.node.querySelectorAll('.mt-filters-and').length > 0) {\n this.node.querySelectorAll('.mt-filters-and')[0].style.visibility = 'hidden';\n }\n\n // Check if we reached the maximum of allowed filters\n const disableNewFilter = !this.getPossibleFilters().length;\n this.node.querySelector('#mt-filters-new').style.visibility = disableNewFilter ? 'hidden' : 'visible';\n }\n\n toggle() {\n if (this.container.style.display === 'none') {\n this.container.style.display = 'block';\n if (this.criteria.length === 0) {\n this.add();\n }\n } else {\n this.container.style.display = 'none';\n }\n }\n}\n","import utils from '../utils';\n\nexport default class Table {\n /**\n * Table componenet constructor\n * @param maptable: Maptable main Object\n * @param options: options communicated to the table\n * @returns {string|*}\n */\n constructor(maptable, options) {\n this.maptable = maptable;\n this.options = options;\n this.sorting = []; // initialize sort array\n\n if (this.options.defaultSorting) {\n if (Array.isArray(this.options.defaultSorting) && (this.options.defaultSorting.length === 2 || this.options.defaultSorting.length === 3)) {\n // handle case for second-order and third-order sort options\n this.sorting = this.options.defaultSorting;\n } else if (Array.isArray(this.options.defaultSorting) && this.options.defaultSorting.length >= 4) {\n // handle case for more than three default sort options\n this.sorting = this.options.defaultSorting.slice(0, 3);\n } else {\n // handle case for single default sort option\n this.sorting = [this.options.defaultSorting];\n }\n this.sorting.forEach((s) => {\n if (!s.mode) s.mode = 'asc';\n });\n } else {\n this.sorting = [\n {\n key: Object.keys(this.maptable.data[0])[0],\n mode: 'asc',\n },\n ];\n }\n\n this.initialSorting = this.sorting.map((s) => `${s.key},${s.mode}`).join(';');\n this.isSorting = false;\n\n this.containerSelector = maptable.options.target;\n this.container = document.querySelector(maptable.options.target);\n\n this.node = this.container.querySelector('#mt-table');\n\n if (!this.node) {\n this.node = document.createElement('div');\n this.node.setAttribute('id', 'mt-table');\n this.maptable.node.appendChild(this.node);\n }\n\n this.node = d3.select(this.node).append('table').attr('class', this.options.className);\n\n this.header = this.node.append('thead');\n\n this.body = this.node.append('tbody');\n\n if (this.options.show) {\n const arrayDiff = this.options.show.filter((i) => Object.keys(this.maptable.columnDetails).indexOf(i) < 0);\n if (arrayDiff.length > 0) {\n throw new Error(`MapTable: invalid columns \"${arrayDiff.join(', ')}\"`);\n }\n this.activeColumns = this.options.show;\n } else {\n this.activeColumns = Object.keys(this.maptable.columnDetails);\n }\n\n // make table header fixed\n if (this.options.header) {\n if (this.options.header.className) {\n this.header.attr('class', `${this.options.header.className}`);\n }\n\n // set custom top header space\n if (this.options.header.top) {\n this.header.attr('style', `top:${this.options.header.top || '0'}px;`);\n } else {\n this.header.attr('style', 'top:0px;');\n }\n }\n\n this.header\n .selectAll('tr')\n .data([1])\n .enter()\n .append('tr')\n .selectAll('th')\n .data(this.activeColumns.map((k) => utils.extendRecursive({ key: k }, this.maptable.columnDetails[k])))\n .enter()\n .append('th')\n .attr('class', (d) => {\n let output = d.sorting ? 'mt-table-sortable' : '';\n output += d.nowrap ? ' nowrap' : '';\n return output;\n })\n .attr('data-key', (d) => utils.sanitizeKey(d.key))\n .attr('onselectstart', 'return false;')\n .attr('unselectable', 'on')\n .attr('style', (d) => (d.nowrap ? 'white-space:nowrap;' : ''))\n .on('click', (d) => {\n if (this.isSorting) return;\n this.isSorting = true;\n if (d.sorting) {\n this.sortColumn(d.key);\n }\n this.isSorting = false;\n })\n .text((d) => d.title)\n .attr('id', (d) => `column_header_${utils.sanitizeKey(d.key)}`);\n\n // render is triggered by MapTable\n // this.render();\n }\n\n /**\n * Restore state from the url hash\n */\n restoreState(sortingRaw) {\n if (!sortingRaw) return;\n const sortingList = sortingRaw.split(';');\n const defaultSorting = [];\n sortingList.forEach((s) => {\n const sortingData = s.split(',');\n defaultSorting.push({\n key: sortingData[0],\n mode: sortingData[1] || 'asc',\n });\n });\n this.sorting = defaultSorting;\n }\n\n /**\n * Save state into the url hash\n */\n saveState() {\n const encodedSorting = this.sorting.map((s) => `${s.key},${s.mode}`).join(';');\n if (encodedSorting !== this.initialSorting) {\n this.maptable.saveState('sort', encodedSorting);\n }\n }\n\n render() {\n // Apply Sort\n this.applySort();\n let tableData = this.maptable.data;\n if (this.options.distinctBy) {\n tableData = d3\n .nest()\n .key((d) => d[this.options.distinctBy])\n .entries(this.maptable.data)\n .map((g) => g.values[0]);\n }\n\n // Enter\n this.body.selectAll('tr').data(tableData).enter().append('tr');\n\n // Exit\n this.body.selectAll('tr').data(tableData).exit().remove();\n\n // Update\n const uniqueCollapsedRows = [];\n this.sortIndex = 0;\n this.body\n .selectAll('tr')\n .data(tableData)\n .attr('class', (row, index) => {\n const enableSeparator = this.isEndOfPrimarySort(tableData, index);\n if (this.options.rowClassName) {\n return `line ${this.options.rowClassName(row)} ${enableSeparator ? 'bold' : ''}`;\n }\n return `line ${enableSeparator ? 'bold' : ''}`;\n })\n .html((row) => {\n let tds = '';\n this.activeColumns.forEach((columnKey) => {\n const column = this.maptable.columnDetails[columnKey];\n tds += ' {\n const isSortGroupEnd = this.isEndOfPrimarySort(tableData, index - 1);\n if (isSortGroupEnd) {\n this.sortIndex = 1;\n } else {\n this.sortIndex += 1;\n }\n return `${this.sortIndex}`;\n });\n\n // On render\n if (this.options.onRender && this.options.onRender.constructor === Function) {\n this.options.onRender.bind(this.maptable)();\n }\n }\n\n applySort() {\n const sortableColums = this.container.querySelectorAll('.mt-table-sortable');\n for (let i = 0; i < sortableColums.length; i += 1) {\n sortableColums[i].setAttribute('class', 'mt-table-sortable');\n }\n this.sorting.forEach((column, index) => {\n this.container.querySelector(`#column_header_${utils.sanitizeKey(column.key)}`).setAttribute('class', `mt-table-sortable sort_${column.mode} sort_order_${index + 1}`);\n });\n this.maptable.data = this.maptable.data.sort((a, b) => {\n let compareBool = false;\n this.sorting.forEach((column) => {\n const d3SortMode = column.mode === 'asc' ? d3.ascending : d3.descending;\n const d3CustomSortMode = column.mode === 'asc' ? utils.customSortAsc : utils.customSortDesc;\n const columnDetails = this.maptable.columnDetails[column.key];\n let el1 = a[column.key];\n let el2 = b[column.key];\n if (columnDetails.dataParse) {\n el1 = columnDetails.dataParse.bind(this.maptable)(el1);\n el2 = columnDetails.dataParse.bind(this.maptable)(el2);\n } else if (columnDetails.virtual) {\n el2 = columnDetails.virtual.bind(this.maptable)(a);\n el2 = columnDetails.virtual.bind(this.maptable)(b);\n } else if (columnDetails.filterType === 'compare') {\n el1 = Number(el1);\n el2 = Number(el2);\n }\n\n if (typeof el1 === 'string' && typeof el2 === 'string') {\n el1 = el1.toLowerCase();\n el2 = el2.toLowerCase();\n }\n\n if (columnDetails.filterInputType === 'months' || columnDetails.filterInputType === 'days') {\n const currentCustomSortValues = this.options.customSortOrder && this.options.customSortOrder.filter((cs) => cs.key === column.key);\n const currentCustomSortOrder = currentCustomSortValues && currentCustomSortValues.length !== 0 ? currentCustomSortValues[0].order || [] : [];\n compareBool = compareBool || d3CustomSortMode(columnDetails.filterInputType, el1, el2, currentCustomSortOrder);\n } else {\n compareBool = compareBool || d3SortMode(el1, el2);\n }\n });\n return compareBool;\n });\n }\n\n /**\n * Sort Table by a column key\n * @param columnKey: String - column key\n */\n sortColumn(key) {\n const sortIndex = this.sorting.map((d) => d.key).indexOf(key);\n const sortValue = { key };\n if (sortIndex === -1) {\n sortValue.mode = 'desc';\n if (d3.event && d3.event.shiftKey) {\n // FIFO - pop last sort element from array after third-order-sorting\n if (this.sorting.length === 3) {\n this.sorting.pop();\n }\n // FIFO - push new sort element to array\n this.sorting.unshift(sortValue);\n } else {\n this.sorting = [sortValue];\n }\n } else {\n if (this.sorting[sortIndex].mode === 'asc') {\n this.sorting[sortIndex].mode = 'desc';\n } else {\n this.sorting[sortIndex].mode = 'asc';\n // this.sorting.splice(sortIndex, 1); // to disable sorting\n }\n if (!d3.event.shiftKey) {\n this.sorting = [this.sorting[sortIndex]];\n } else {\n // FIFO - set latest clicked column key as first-order-sorting\n this.reOrderSorting(sortIndex, 0);\n }\n }\n this.saveState();\n this.render();\n }\n\n /**\n * Util for changing position of sorting array elements\n * @param from: from position index\n * @param to: to position index\n */\n reOrderSorting(from, to) {\n if (to === from) return;\n\n var target = this.sorting[from];\n var increment = to < from ? -1 : 1;\n\n for (var k = from; k != to; k += increment) {\n this.sorting[k] = this.sorting[k + increment];\n }\n this.sorting[to] = target;\n }\n\n /**\n * Util for finding end of primary sort data\n * @param data: table data\n * @param index: current row index\n */\n isEndOfPrimarySort(data, index) {\n // check if data group separator is enabled from passed options\n if (!this.options.dataGroupSeparator || (this.options.dataGroupSeparator && !this.options.dataGroupSeparator.enabled)) return false;\n // check if multi-order-sort\n if (this.sorting && this.sorting.length <= 1) return false;\n\n const primarySort = this.sorting[0].key || '';\n if (data[index] && data[index + 1]) {\n if (data[index][primarySort] && data[index + 1][primarySort]) {\n // stringify everything before .toLowerCase()\n return `${data[index][primarySort]}`.toLowerCase() !== `${data[index + 1][primarySort]}`.toLowerCase();\n }\n }\n return false;\n }\n}\n","import utils from './utils';\n\nimport GeoMap from './components/GeoMap';\nimport Filters from './components/Filters';\nimport Table from './components/Table';\n\nexport default class MapTable {\n constructor(target, options) {\n this.options = options;\n\n this.state = {};\n this.saveStateTimeout = {};\n this.removeStateTimeout = null;\n\n this.node = document.querySelector(target);\n this.node.setAttribute('style', 'position:relative;');\n\n if (this.options.data.type === 'json') {\n d3.json(this.options.data.path, this.loadData.bind(this));\n } else if (this.options.data.type === 'csv') {\n d3.csv(this.options.data.path, this.loadData.bind(this));\n } else if (this.options.data.type === 'tsv') {\n d3.tsv(this.options.data.path, this.loadData.bind(this));\n } else if (this.options.data.type === 'jsonData') {\n this.loadData(null, JSON.parse(this.options.data.value));\n } else if (this.options.data.type === 'csvData') {\n this.loadData(null, d3.csv.parse(this.options.data.value));\n } else if (this.options.data.type === 'tsvData') {\n this.loadData(null, d3.tsv.parse(this.options.data.value));\n } else if (this.options.data.type === 'data') {\n this.loadData(null, this.options.data.value);\n }\n\n if (this.options.map && this.options.map.heatmap) {\n delete this.options.map.countries;\n }\n }\n\n /**\n * Callback used when we pull the dataset\n * @param err: Error - error data if it happened\n * @param data: Object - dataset object\n */\n loadData(err, data) {\n if (err) {\n throw err;\n }\n this.rawData = data;\n\n if (this.options.data.preFilter) {\n this.rawData = this.rawData.filter(this.options.data.preFilter);\n }\n\n this.setColumnDetails();\n this.data = this.rawData.slice(); // we clone data, so that we can filter it\n // Map\n if (this.options.map) {\n // Map wrapper\n const mapWrapper = document.createElement('div');\n mapWrapper.setAttribute('class', 'mt-map-container');\n const isIE = navigator.userAgent.indexOf('MSIE') !== -1 || navigator.appVersion.indexOf('Trident/') > 0;\n if (this.options.map.heatmap && isIE) {\n mapWrapper.innerHTML = '
The heatmap feature is not supported with Internet Explorer.
Please use another modern browser to see this map.
';\n this.node.insertBefore(mapWrapper, this.node.firstChild);\n mapWrapper.querySelector('.mt-loading').style.display = 'block';\n this.options.map = false;\n this.buildComponenents();\n return;\n }\n mapWrapper.innerHTML = '
Loading...
';\n this.node.insertBefore(mapWrapper, this.node.firstChild);\n mapWrapper.querySelector('.mt-loading').style.display = 'block';\n if (this.options.map.pathData) {\n this.loadMapData(null, JSON.parse(this.options.map.pathData), mapWrapper);\n } else if (this.options.map.path) {\n d3.json(this.options.map.path, (errGeoMap, jsonWorld) => {\n this.loadMapData(errGeoMap, jsonWorld, mapWrapper);\n });\n } else {\n throw new Error('missing map path|pathData');\n }\n } else {\n this.buildComponenents();\n }\n }\n\n loadMapData(errGeoMap, jsonWorld, mapWrapper) {\n if (errGeoMap) {\n throw errGeoMap;\n }\n this.map = new GeoMap(this, this.options.map, jsonWorld);\n\n mapWrapper.querySelector('.mt-loading').style.display = 'none';\n\n this.buildComponenents();\n }\n\n buildComponenents() {\n // Filters\n if (this.options.filters) {\n this.filters = new Filters(this, this.options.filters);\n }\n\n // Table\n if (this.options.table) {\n this.table = new Table(this, this.options.table);\n }\n\n // Restore state\n this.restoreState();\n window.addEventListener('hashchange', () => {\n this.restoreState();\n });\n\n // Render\n this.render();\n }\n\n /**\n * Load state from url\n * @param stateName: name of the state (either filters or zoom)\n * @param isJson: do we need to decode a json from the state?\n * @return loaded state\n */\n loadState(stateName, isJson) {\n // JSON state\n if (isJson) {\n const v = this.parseState(stateName);\n if (!v) return null;\n try {\n const parsedState = JSON.parse(v);\n this.state[stateName] = parsedState;\n } catch (e) {\n console.log(`Maptable: Invalid URL State for mt-${stateName} ${e.message}`);\n return null;\n }\n } else {\n const v = this.parseState(stateName);\n if (v) this.state[stateName] = v;\n }\n return this.state[stateName];\n }\n\n /**\n * Restore state for filters or/and map zooming and/or sorting\n */\n restoreState() {\n if (this.map) {\n this.loadState('zoom', true);\n this.map.restoreState(this.state.zoom);\n }\n\n if (this.filters) {\n this.loadState('filters', true);\n this.filters.restoreState(this.state.filters);\n }\n\n if (this.table) {\n this.loadState('sort', false);\n this.table.restoreState(this.state.sort);\n }\n }\n\n /**\n * Extract state from the url\n * @param stateName: name of the state (either filters or zoom)\n */\n parseState(stateName) {\n const params = document.location.href.replace(/%21mt/g, '!mt').split(`!mt-${stateName}=`);\n return params[1] ? decodeURIComponent(params[1].split('!mt')[0]) : null;\n }\n\n /**\n * Remove state\n * @param stateName: name of the state (either filters or zoom)\n */\n removeState(stateName) {\n window.clearTimeout(this.saveStateTimeout[stateName]);\n delete this.state[stateName];\n this.updateState();\n }\n\n /**\n * Save the state in this.state\n * @param stateName: name of the state (either filters or zoom)\n * @param stateData: object, contain state information\n */\n saveState(stateName, stateData) {\n window.clearTimeout(this.saveStateTimeout[stateName]);\n this.saveStateTimeout[stateName] = window.setTimeout(() => {\n this.state[stateName] = stateData;\n this.updateState();\n }, 200);\n }\n\n /**\n * Update state into the URL hash\n */\n updateState() {\n const newUrl = document.location.href.split('#')[0];\n let stateHash = '';\n Object.keys(this.state).forEach((k) => {\n if (!this.state[k]) return;\n let stateValue = this.state[k];\n if (typeof this.state[k] === 'object') {\n if (!Object.keys(this.state[k]).length) return;\n stateValue = JSON.stringify(this.state[k]);\n }\n stateHash += `!mt-${k}=${encodeURIComponent(stateValue)}`;\n });\n if (stateHash !== '') stateHash = `#${stateHash}`;\n if (document.location.href !== `${newUrl}${stateHash}`) {\n window.history.pushState(null, null, `${newUrl}${stateHash}`);\n }\n }\n\n render() {\n if (this.filters) {\n this.filters.filterData();\n this.filters.refresh();\n }\n\n if (this.map) {\n this.map.render();\n // On complete\n if (!this.firstExecution && this.options.map.onComplete && this.options.map.onComplete.constructor === Function) {\n this.options.map.onComplete.bind(this)();\n }\n }\n\n if (this.table) {\n this.table.render();\n // On complete\n if (!this.firstExecution && this.options.table.onComplete && this.options.table.onComplete.constructor === Function) {\n this.options.table.onComplete.bind(this)();\n }\n }\n\n // On complete\n if (!this.firstExecution && this.options.onComplete && this.options.onComplete.constructor === Function) {\n this.options.onComplete.bind(this)();\n }\n this.firstExecution = true;\n }\n\n setColumnDetails() {\n const that = this;\n if (that.rawData.length === 0) {\n return;\n }\n const defaultColumns = {};\n\n Object.keys(that.rawData[0]).forEach((k) => {\n const patternNumber = /^[-+]?[0-9]*\\.?[0-9]+([eE][-+]?[0-9]+)?$/;\n const isNumber = patternNumber.test(that.rawData[0][k]);\n defaultColumns[k] = {\n title: utils.keyToTile(k),\n filterMethod: isNumber ? 'compare' : 'field',\n filterInputType: isNumber ? 'number' : this.options.columns[k] && this.options.columns[k].filterInputType ? this.options.columns[k].filterInputType : 'text',\n sorting: true,\n };\n\n if (isNumber) {\n defaultColumns[k].dataParse = (val) => parseFloat(val);\n }\n });\n that.columnDetails = utils.extendRecursive(defaultColumns, this.options.columns);\n // add isVirtual to columns details\n Object.keys(that.columnDetails).forEach((k) => {\n that.columnDetails[k].isVirtual = typeof that.columnDetails[k].virtual === 'function';\n });\n }\n}\n","/* eslint no-unused-vars: 0 */\nimport utils from './utils';\nimport defaultOptions from './defaultOptions';\nimport MapTable from './maptable';\n\nd3.maptable = function (target) {\n let maptableObject;\n const maptable = {};\n const options = {\n target,\n columns: {},\n data: {},\n map: null,\n filters: null,\n table: null,\n };\n\n maptable.map = function (mapOptions = {}) {\n if (!topojson) {\n throw new Error('Maptable requires topojson.js');\n }\n if (typeof mapOptions.path !== 'string' && typeof mapOptions.pathData !== 'string') {\n throw new Error('MapTable: map not provided');\n }\n options.map = mapOptions;\n return maptable;\n };\n\n maptable.data = function (data) {\n options.data.type = 'data';\n options.data.value = data;\n return maptable;\n };\n\n maptable.json = function (jsonPath, preFilter) {\n options.data.type = 'json';\n options.data.path = jsonPath;\n options.data.preFilter = preFilter;\n return maptable;\n };\n\n maptable.jsonData = function (jsonData) {\n options.data.type = 'jsonData';\n options.data.value = jsonData;\n return maptable;\n };\n\n maptable.csv = function (csvPath, preFilter) {\n options.data.type = 'csv';\n options.data.path = csvPath;\n options.data.preFilter = preFilter;\n return maptable;\n };\n\n maptable.csvData = function (csvData) {\n options.data.type = 'csvData';\n options.data.value = csvData;\n return maptable;\n };\n\n maptable.tsv = function (tsvPath, preFilter) {\n options.data.type = 'tsv';\n options.data.path = tsvPath;\n options.data.preFilter = preFilter;\n return maptable;\n };\n\n maptable.tsvData = function (tsvData) {\n options.data.type = 'tsvData';\n options.data.value = tsvData;\n return maptable;\n };\n\n maptable.filters = function (filtersOptions = {}) {\n options.filters = filtersOptions;\n return maptable;\n };\n\n maptable.table = function (tableOptions = {}) {\n options.table = tableOptions;\n return maptable;\n };\n\n maptable.columns = function (columns = {}) {\n options.columns = columns;\n return maptable;\n };\n\n maptable.render = function (onComplete) {\n if (typeof target !== 'string' || !document.querySelector(target)) {\n throw new Error('MapTable: target not found');\n }\n\n if (!options.data || !options.data.type) {\n throw new Error('MapTable: Please provide the path for your dataset data|json|jsonData|csv|csvData|tsv|tsvData');\n }\n\n if (options.map && !options.map.heatmap) options.map.heatmap = null;\n\n if (options.map && options.map.markers === false) options.map.markers = null;\n\n if (options.map && options.map.countries === false) options.map.countries = null;\n\n if (!options.filters) options.filters = null;\n options.onComplete = onComplete;\n\n const customOptions = utils.extendRecursive(defaultOptions, options);\n\n if (options.map && !options.map.markers) delete customOptions.map.markers;\n if (options.map && !options.map.heatmap) delete customOptions.map.heatmap;\n if (options.map && !options.map.title) delete customOptions.map.title;\n if (options.map && !options.map.timezones) delete customOptions.map.timezones;\n if (options.map && !options.map.night) delete customOptions.map.night;\n if (!options.filters) delete customOptions.filters;\n if (!options.table) delete customOptions.table;\n\n maptableObject = new MapTable(target, customOptions);\n\n // public functions\n return {\n render: () => maptableObject.render(),\n loadState: (stateName, isJson) => maptableObject.loadState(stateName, isJson),\n removeState: (stateName) => maptableObject.removeState(stateName),\n saveState: (stateName, stateData) => maptableObject.saveState(stateName, stateData),\n setTitleContent: (title) => {\n maptableObject.options.map.title.content = () => title;\n },\n setData: (data) => {\n maptableObject.options.data.type = 'data';\n maptableObject.options.data.value = data;\n maptableObject.options.rawData = data;\n maptableObject.rawData = data;\n maptableObject.data = data;\n if (maptableObject.map) {\n maptableObject.map.enrichData();\n }\n },\n setNightDate: (date) => {\n maptableObject.options.map.night.date = date;\n },\n setTimezonesDate: (date) => {\n maptableObject.options.map.timezones.date = date;\n },\n getMapWidth: () => maptableObject.map.getWidth(),\n getMapHeight: () => maptableObject.map.getHeight(),\n };\n };\n return maptable;\n};\n\nif (!d3) {\n throw new Error('Maptable requires d3.js');\n}\n\nexport default d3.maptable;\n"],"names":["appendOptions","select","options","defaultValue","forEach","f","option","document","createElement","setAttribute","value","innerText","text","appendChild","rangeToBool","el1","range","el2","parseInt","extendRecursive","dst","src","args","splice","call","arguments","toString","length","Object","keys","p","keyToTile","k","upperK","charAt","toUpperCase","slice","replace","sanitizeKey","toLowerCase","toNumber","str","resStr","Number","quantile","array","percentile","sort","a","b","index","result","Math","floor","i","fraction","uniqueValues","arr","l","indexOf","push","formatDate","d","zone","newDate","Date","getTime","toISOString","split","substr","isBlank","undefined","customSortOrders","days","months","customSortAsc","type","d1","d2","sortOrder","elem1","elem2","customSortOrder","customSortDesc","map","longitudeKey","latitudeKey","countryIdentifierKey","countryIdentifierType","zoom","saveState","exportSvg","exportSvgClient","ratioFromWidth","scaleHeight","scaleZoom","fitContentMargin","autoFitContent","tooltipClassName","countries","legend","attr","fill","stroke","heatmap","mask","weightByAttribute","weightByAttributeScale","circles","min","max","step","color","colorStrength","blur","borders","opacity","markers","r","title","fontSize","fontFamily","filters","table","className","collapseRowsBy","Legend","legendWidth","node","svg","append","getWidth","getHeight","buildIndice","domain","legendGradient","minNegative","maxNegative","midPercentNegative","round","midPercentPositive","indice","style","selectAll","toLocaleString","buildScale","val","isNaN","maxValue","minValue","positionDelta","position","width","height","padding","console","warn","window","btoa","buildWatermark","d3","xhr","res","mapWatermarkDelta","mime","x","y","dataUri","responseText","pos","mul_table","shg_table","processImage","img","canvas","radius","blurAlphaChannel","getElementById","HTMLImageElement","w","naturalWidth","h","naturalHeight","HTMLCanvasElement","context","getContext","clearRect","drawImage","processCanvasRGBA","processCanvasRGB","getImageDataFromCanvas","top_x","top_y","imageData","getImageData","e","Error","processImageDataRGBA","putImageData","pixels","data","yp","yi","yw","r_sum","g_sum","b_sum","a_sum","r_out_sum","g_out_sum","b_out_sum","a_out_sum","r_in_sum","g_in_sum","b_in_sum","a_in_sum","pr","pg","pb","pa","rbs","div","w4","widthMinus1","heightMinus1","radiusPlus1","sumFactor","stackStart","BlurStack","stack","next","stackEnd","stackIn","stackOut","mul_sum","shg_sum","g","processImageDataRGB","image","canvasRGBA","canvasRGB","imageDataRGBA","imageDataRGB","π","PI","radians","degrees","solarGeometricMeanAnomaly","centuries","solarGeometricMeanLongitude","solarEquationOfCenter","m","sin","solarTrueLongitude","solarApparentLongitude","meanObliquityOfEcliptic","obliquityCorrection","cos","solarDeclination","asin","eccentricityEarthOrbit","equationOfTime","tan","antipode","solarPosition","time","UTC","longitude","day","utc","GeoMap","maptable","jsonWorld","scale","transX","transY","containerSelector","target","container","querySelector","mapWrapper","existingMap","parentNode","insertBefore","removeChild","projection","geo","equirectangular","translate","rotate","precision","path","enrichData","zoomListener","behavior","scaleExtent","on","rescale","bind","tooltipMarkersNode","tooltipCountriesNode","layerGlobal","layerDefs","html","timezones","layerTimezones","layerCountries","night","layerNight","layerHeatmap","layerMarkers","watermark","Watermark","buildTitle","addExportSvgCapability","addEventListener","loadGeometries","rawData","parseFloat","latitude","coord","pow","offsetWidth","deltaHeight","filterCountries","objects","geometries","filter","buildCountries","buildHeatmap","buildNight","pathData","buildTimezone","lands","topojson","merge","disableMask","maskHeatmap","datum","imgHeatmap","mesh","bordersHeatmap","enter","circle","angle","maskNight","nightPath","cssBlur","userDate","date","startOfDay","getUTCFullYear","getUTCMonth","getUTCDate","solarPositionDated","origin","nightPathRight","nightPathLeft","disableSun","sunCoords","sunCircleRight","sunCircleXRight","sunCircleLeft","sunCircleXLeft","loadTimezone","JSON","parse","json","errGeoMap","jsonTimezones","err","dataTimezones","feature","features","maskTimezone","properties","places","insert","stringify","timezoneTexts","timezoneTextsUnique","Map","item","values","layerTimezonesText","scaleFontSize","utils","heatmapDataset","opts","lengthDataset","maxOpacityScale","linear","centralCircleOpacity","dataExtents","extent","userScale","log","canvasHeatmap","ctx","globalCompositeOperation","datumScale","getDatumScale","magnitudeScale","getMagnitudeScale","colorScale","beginPath","rect","fillStyle","closePath","colorMultiplier","aa","point","scaleOpacityDatum","StackBlur","dataUrl","toDataURL","remove","getHeatmapData","dataCountries","legendCountry","shouldRenderLegend","aggregate","allMtMapCountry","allMtMapMarker","dataByCountry","key","has","set","get","geoDatum","matchedCountry","rollupValue","setAttrValues","countryItem","getAllMtMapCountry","each","selection","attrKey","attrValue","scaleDomain","attrProperties","updateExtents","indiceChange","NaN","tooltip","activateTooltip","endOfDay","totalMilliseconds","currentTime","relativeTranslateX","transform","querySelectorAll","currentDate","Array","from","timezoneText","textContent","__data__","defaultGroupBy","dataMarkers","nest","entries","markerItem","markerObject","customTag","markerClassName","exit","transition","attrX","attrY","attrXDelta","attrYDelta","markerUpdate","getAllMtMapMarker","hor","ver","ratio","deltaMarker","currentWidth","currentHeight","realHeight","realWidth","diffMarginWidth","diffMarginHeight","titleContainer","bgColor","source","originalTranslation","newTx","newTy","encodedTranslation","defaultZoom","decodeTranslation","event","encodeTranslation","exportedData","removeState","self","maxTransX","maxTransY","minTransX","minTransY","scaleAttributes","firstExecution","dataset","mode","scaleToUse","rollup","groupedData","reduce","c","validData","groupedValues","exponent","sqrt","aggregatedValue","columnDetails","formatted","cellContent","positiveRanks","concat","v","negativeRanks","ranks","newValue","useNegative","scaleFunction","scaleNegativeFunction","copy","scaledValue","empty","originalValueRaw","originalValue","updateMarkers","updateCountries","updateNight","updateTimezones","updateTitle","updateHeatmap","fitContent","onRender","constructor","Function","content","showing","total","inlineFilters","getDescription","innerHTML","tooltipNode","tooltipContent","isCountry","mouseLeft","mouseTop","tooltipDelta","mapRect","getBoundingClientRect","mousePosition","mouse","left","top","targetRect","svgXml","XMLSerializer","serializeToString","saveAs","blob","Blob","form","submit","exportNode","exportButton","exportForm","Filters","criteria","show","arrayDiff","join","activeColumns","filtersHeaderNode","filtersResetNode","display","marginLeft","reset","filtersTitleNode","createTextNode","filtersBodyNode","filtersElementsNode","filtersNewNode","add","evt","preventDefault","possibleFilters","getPossibleFilters","filterName","create","replaceNode","rowNode","buildRow","replaceChild","render","toggle","filterIndex","rowNodes","output","filtersChildren","childNodes","element","filterOutput","filterMethod","filterRangeSelect","filterValueMin","filterValueMax","filterValue","criterion","row","decodeURIComponent","defaultCriteria","setFilters","outputArray","line","selectedIndex","separatorWord","that","minusButton","filterSeparator","filterNameSelect","oldFilterName","getAttribute","newFilterName","refresh","filterVerb","filterRange","handleRangeChange","filterInput","filterInputType","filterValueAnd","filterSelect","sortKeys","ascending","except","isVirtual","matched","fmt","dataParse","exportFilters","filterNameSelects","visibility","disableNewFilter","Table","sorting","defaultSorting","isArray","s","initialSorting","isSorting","header","body","nowrap","sortColumn","sortingRaw","sortingList","sortingData","encodedSorting","applySort","tableData","distinctBy","uniqueCollapsedRows","sortIndex","enableSeparator","isEndOfPrimarySort","rowClassName","tds","columnKey","column","virtual","dataCountIndicator","enabled","isSortGroupEnd","sortableColums","compareBool","d3SortMode","descending","d3CustomSortMode","filterType","currentCustomSortValues","cs","currentCustomSortOrder","order","sortValue","shiftKey","pop","unshift","reOrderSorting","to","increment","dataGroupSeparator","primarySort","MapTable","state","saveStateTimeout","removeStateTimeout","loadData","csv","tsv","preFilter","setColumnDetails","isIE","navigator","userAgent","appVersion","firstChild","buildComponenents","loadMapData","restoreState","stateName","isJson","parseState","parsedState","message","loadState","params","location","href","clearTimeout","updateState","stateData","setTimeout","newUrl","stateHash","stateValue","encodeURIComponent","history","pushState","filterData","onComplete","defaultColumns","patternNumber","isNumber","test","columns","maptableObject","mapOptions","jsonPath","jsonData","csvPath","csvData","tsvPath","tsvData","filtersOptions","tableOptions","customOptions","defaultOptions","setTitleContent","setData","setNightDate","setTimezonesDate","getMapWidth","getMapHeight"],"mappings":"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"} \ No newline at end of file diff --git a/dist/maptable.min.js b/dist/maptable.min.js index 8737653..1234261 100644 --- a/dist/maptable.min.js +++ b/dist/maptable.min.js @@ -1,7 +1,7 @@ /** - * MapTable 2.5.0 - License MIT - Build: Fri May 17 2024 12:52:37 GMT+0200 (Central European Summer Time) + * MapTable 2.5.0 - License MIT - Build: Fri Jun 14 2024 12:48:26 GMT+0545 (Nepal Time) */ -this.d3=this.d3||{},this.d3.maptable=function(){"use strict";function t(t,e,a){e.forEach(function(e){var a=document.createElement("option");a.setAttribute("value",e.value),a.innerText=e.text,t.appendChild(a)}),t.value=a}function e(t,e,a){return"="===e?parseInt(t,10)===parseInt(a,10):"≠"===e?parseInt(t,10)!==parseInt(a,10)&&""!==t&&""!==a:">"===e?parseInt(t,10)>parseInt(a,10)&&""!==t&&""!==a:"<"===e?parseInt(t,10)=parseInt(a,10)&&""!==t&&""!==a:"≤"===e?parseInt(t,10)<=parseInt(a,10)&&""!==t&&""!==a:!0}function a(){for(var t={},e=void 0,i=[].splice.call(arguments,0),n={}.toString;i.length>0;)e=i.splice(0,1)[0],"[object Object]"===n.call(e)&&Object.keys(e).forEach(function(i){"[object Object]"===n.call(e[i])?t[i]=a(t[i]||{},e[i]):t[i]=e[i]});return t}function i(t){var e=t.charAt(0).toUpperCase()+t.slice(1);return e.replace(/_/g," ")}function n(t){return t.toLowerCase().replace(/ /g,"_").replace(/"/g,"").replace(/'/g,"")}function r(t){if(!t||""===t)return null;var e=t.toString().replace(/[^0-9.]+|\s+/gim,"");return""!==e?Number(e):null}function s(t,e){t.sort(function(t,e){return t-e});var a=e/100*(t.length-1),i=void 0;if(Math.floor(a)===a)i=t[a];else{var n=Math.floor(a),r=a-n;i=t[n]+(t[n+1]-t[n])*r}return i}function o(t){if(!t)return t;for(var e=[],a=0,i=t.length;i>a;a+=1)-1===e.indexOf(t[a])&&""!==t[a]&&e.push(t[a]);return e}function l(t,e,a,i){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLImageElement&&!t instanceof HTMLImageElement)return;var n=t.naturalWidth,r=t.naturalHeight;if("string"==typeof e)var e=document.getElementById(e);else if("undefined"!=typeof HTMLCanvasElement&&!e instanceof HTMLCanvasElement)return;e.style.width=n+"px",e.style.height=r+"px",e.width=n,e.height=r;var s=e.getContext("2d");s.clearRect(0,0,n,r),s.drawImage(t,0,0),Number.isNaN(a)||1>a||(i?p(e,0,0,n,r,a):d(e,0,0,n,r,a))}function h(t,e,a,i,n){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLCanvasElement&&!t instanceof HTMLCanvasElement)return;var r,s=t.getContext("2d");try{try{r=s.getImageData(e,a,i,n)}catch(o){throw new Error("unable to access local image data: "+o)}}catch(o){throw new Error("unable to access image data: "+o)}return r}function p(t,e,a,i,n,r){if(!(Number.isNaN(r)||1>r)){r|=0;var s=h(t,e,a,i,n);s=u(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function u(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,N,E,T,D,A,z=t.data,F=r+r+1,j=i-1,H=n-1,O=r+1,P=O*(O+1)/2,I=new m,L=I;for(l=1;F>l;l++)if(L=L.next=new m,l==O)var B=L;L.next=I;var R=null,G=null;d=u=0;var Y=q[r],U=W[r];for(o=0;n>o;o++){for(w=C=S=M=c=f=g=v=0,y=O*(N=z[u]),b=O*(E=z[u+1]),k=O*(T=z[u+2]),x=O*(D=z[u+3]),c+=P*N,f+=P*E,g+=P*T,v+=P*D,L=I,l=0;O>l;l++)L.r=N,L.g=E,L.b=T,L.a=D,L=L.next;for(l=1;O>l;l++)h=u+((l>j?j:l)<<2),c+=(L.r=N=z[h])*(A=O-l),f+=(L.g=E=z[h+1])*A,g+=(L.b=T=z[h+2])*A,v+=(L.a=D=z[h+3])*A,w+=N,C+=E,S+=T,M+=D,L=L.next;for(R=I,G=B,s=0;i>s;s++)z[u+3]=D=v*Y>>U,0!=D?(D=255/D,z[u]=(c*Y>>U)*D,z[u+1]=(f*Y>>U)*D,z[u+2]=(g*Y>>U)*D):z[u]=z[u+1]=z[u+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=d+((h=s+r+1)s;s++){for(C=S=M=w=f=g=v=c=0,u=s<<2,y=O*(N=z[u]),b=O*(E=z[u+1]),k=O*(T=z[u+2]),x=O*(D=z[u+3]),c+=P*N,f+=P*E,g+=P*T,v+=P*D,L=I,l=0;O>l;l++)L.r=N,L.g=E,L.b=T,L.a=D,L=L.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(L.r=N=z[u])*(A=O-l),f+=(L.g=E=z[u+1])*A,g+=(L.b=T=z[u+2])*A,v+=(L.a=D=z[u+3])*A,w+=N,C+=E,S+=T,M+=D,L=L.next,H>l&&(p+=i);for(u=s,R=I,G=B,o=0;n>o;o++)h=u<<2,z[h+3]=D=v*Y>>U,D>0?(D=255/D,z[h]=(c*Y>>U)*D,z[h+1]=(f*Y>>U)*D,z[h+2]=(g*Y>>U)*D):z[h]=z[h+1]=z[h+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=s+((h=o+O)r)){r|=0;var s=h(t,e,a,i,n);s=c(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function c(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,N,E=t.data,T=r+r+1,D=i-1,A=n-1,z=r+1,F=z*(z+1)/2,j=new m,H=j;for(l=1;T>l;l++)if(H=H.next=new m,l==z)var O=H;H.next=j;var P=null,I=null;d=u=0;var L=q[r],B=W[r];for(o=0;n>o;o++){for(k=x=w=c=f=g=0,v=z*(C=E[u]),y=z*(S=E[u+1]),b=z*(M=E[u+2]),c+=F*C,f+=F*S,g+=F*M,H=j,l=0;z>l;l++)H.r=C,H.g=S,H.b=M,H=H.next;for(l=1;z>l;l++)h=u+((l>D?D:l)<<2),c+=(H.r=C=E[h])*(N=z-l),f+=(H.g=S=E[h+1])*N,g+=(H.b=M=E[h+2])*N,k+=C,x+=S,w+=M,H=H.next;for(P=j,I=O,s=0;i>s;s++)E[u]=c*L>>B,E[u+1]=f*L>>B,E[u+2]=g*L>>B,c-=v,f-=y,g-=b,v-=P.r,y-=P.g,b-=P.b,h=d+((h=s+r+1)s;s++){for(x=w=k=f=g=c=0,u=s<<2,v=z*(C=E[u]),y=z*(S=E[u+1]),b=z*(M=E[u+2]),c+=F*C,f+=F*S,g+=F*M,H=j,l=0;z>l;l++)H.r=C,H.g=S,H.b=M,H=H.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(H.r=C=E[u])*(N=z-l),f+=(H.g=S=E[u+1])*N,g+=(H.b=M=E[u+2])*N,k+=C,x+=S,w+=M,H=H.next,A>l&&(p+=i);for(u=s,P=j,I=O,o=0;n>o;o++)h=u<<2,E[h]=c*L>>B,E[h+1]=f*L>>B,E[h+2]=g*L>>B,c-=v,f-=y,g-=b,v-=P.r,y-=P.g,b-=P.b,h=s+((h=o+z)e?e+360:e)/180*O}function v(t){var e=f(t);return(Math.sin(e)*(1.914602-t*(.004817+14e-6*t))+Math.sin(e+e)*(.019993-101e-6*t)+289e-6*Math.sin(e+e+e))*P}function y(t){return g(t)+v(t)}function b(t){return y(t)-(.00569+.00478*Math.sin((125.04-1934.136*t)*P))*P}function k(t){return(23+(26+(21.448-t*(46.815+t*(59e-5-.001813*t)))/60)/60)*P}function x(t){return k(t)+.00256*Math.cos((125.04-1934.136*t)*P)*P}function w(t){return Math.asin(Math.sin(x(t))*Math.sin(b(t)))}function C(t){return.016708634-t*(42037e-9+1.267e-7*t)}function S(t){var e=C(t),a=f(t),i=g(t),n=Math.tan(x(t)/2);return n*=n,n*Math.sin(2*i)-2*e*Math.sin(a)+4*e*n*Math.sin(a)*Math.cos(2*i)-.5*n*n*Math.sin(4*i)-1.25*e*e*Math.sin(2*a)}function M(t){return[t[0]+180,-t[1]]}function N(t){var e=(t-Date.UTC(2e3,0,1,12))/864e5/36525,a=(d3.time.day.utc.floor(t)-t)/864e5*360-180;return[a-S(e)*I,w(e)*I]}var E={};E["typeof"]="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},E.classCallCheck=function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")},E.createClass=function(){function t(t,e){for(var a=0;a\n \n \n \n \n \n '),this.options.timezones&&(this.layerTimezones=this.layerGlobal.append("g").attr("class","mt-map-timezones")),this.layerCountries=this.layerGlobal.append("g").attr("class","mt-map-countries"),this.options.night&&(this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night")),this.options.heatmap&&(this.layerHeatmap=this.layerGlobal.append("g").attr("class","mt-map-heatmap")),this.layerMarkers=this.layerGlobal.append("g").attr("class","mt-map-markers"),this.options.watermark&&(this.watermark=new j(this,this.options.watermark)),this.options.title&&this.buildTitle(),(this.options.exportSvgClient||this.options.exportSvg)&&this.addExportSvgCapability(),this.options.width||window.addEventListener("resize",function(){n.svg.attr("width",n.getWidth()),n.svg.attr("height",n.getHeight()),n.rescale()}),this.loadGeometries()}return E.createClass(t,[{key:"enrichData",value:function(){var t=this;this.maptable.rawData.forEach(function(e){e.longitude=parseFloat(e[t.options.longitudeKey]),e.latitude=parseFloat(e[t.options.latitudeKey]);var a=[0,0];Number.isNaN(e.longitude)||Number.isNaN(e.latitude)||(a=t.projection([e.longitude,e.latitude])),e.x=a[0],e.y=a[1]})}},{key:"scaleAttributes",value:function(){return Math.pow(this.scale,2/3)}},{key:"getWidth",value:function(){return this.options.width?this.options.width:(this.options.width=this.node.offsetWidth,this.node.offsetWidth)}},{key:"getHeight",value:function(){var t=this.options.title?30:0;return!this.options.height&&this.options.ratioFromWidth?this.getWidth()*this.options.ratioFromWidth*this.options.scaleHeight+t:this.options.height*this.options.scaleHeight+t}},{key:"loadGeometries",value:function(){this.options.filterCountries&&(this.jsonWorld.objects.countries.geometries=this.jsonWorld.objects.countries.geometries.filter(this.options.filterCountries)),this.options.countries&&this.buildCountries(),this.options.heatmap&&this.buildHeatmap(),this.options.night&&this.buildNight(),this.options.timezones&&(this.options.timezones.path||this.options.timezones.pathData)&&this.buildTimezone()}},{key:"buildHeatmap",value:function(){var t=topojson.merge(this.jsonWorld,this.jsonWorld.objects.countries.geometries);if(this.options.heatmap.disableMask||(this.maskHeatmap=this.layerHeatmap.append("defs").append("clipPath").attr("id","mt-map-heatmap-mask"),this.maskHeatmap.datum(t).append("path").attr("class","mt-map-heatmap-mask-paths").attr("d",this.path)),this.imgHeatmap=this.layerHeatmap.append("image").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("x",0).attr("y",0).attr("class","mt-map-heatmap-img"),this.options.heatmap.mask&&(this.imgHeatmap=this.imgHeatmap.attr("clip-path","url(#mt-map-heatmap-mask)")),this.options.heatmap.borders){var e=topojson.mesh(this.jsonWorld,this.jsonWorld.objects.countries,function(t,e){return t!==e});this.bordersHeatmap=this.layerHeatmap.append("g").attr("class","mt-map-heatmap-borders"),this.bordersHeatmap.selectAll("path.mt-map-heatmap-borders-paths").data([t,e]).enter().append("path").attr("class","mt-map-heatmap-borders-paths").attr("fill","none").attr("stroke-width",this.options.heatmap.borders.stroke).attr("stroke",this.options.heatmap.borders.color).attr("style","opacity: "+this.options.heatmap.borders.opacity).attr("d",this.path)}}},{key:"buildNight",value:function(){this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night");var t=d3.geo.circle().angle(90);this.maskNight=this.layerNight.append("defs").append("clipPath").attr("id","mt-map-night-mask"),this.maskNight.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.nightPath=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.path).style("opacity",.1);var e=this.options.night.date||Date.UTC(),a=Date.UTC(e.getUTCFullYear(),e.getUTCMonth(),e.getUTCDate(),0,0,0),i=N(new Date(a));if(this.nightPath.datum(t.origin(M(i))).attr("d",this.path),this.nightPathRight=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+this.getWidth()+"px,0,0)"),this.nightPathLeft=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+-this.getWidth()+"px,0,0)"),!this.options.night.disableSun){var n=this.projection(i);this.sunCircleRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]+this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]-this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]-2*this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight())}}},{key:"buildTimezone",value:function(){var t=this;this.options.timezones.pathData?this.loadTimezone(null,JSON.parse(this.options.timezones.pathData)):this.options.timezones.path&&d3.json(this.options.timezones.path,function(e,a){t.loadTimezone(e,a)})}},{key:"scaleFontSize",value:function(t){return this.getWidth()<700?t*(this.getWidth()/700):t}},{key:"loadTimezone",value:function(t,e){var a=this;this.dataTimezones=topojson.feature(e,e.objects.timezones).features,this.maskTimezone=this.layerTimezones.append("defs").append("clipPath").attr("id","mt-map-timezone-mask"),this.maskTimezone.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.layerTimezones.selectAll(".mt-map-timezone").data(this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places})).enter().insert("path").attr("class","mt-map-timezone").attr("d",this.path).attr("fill",function(t){return t.properties.zone%2===0?"#F4F5F5":"transparent"}).attr("title",function(t){return JSON.stringify(t.properties)}).attr("clip-path","url(#mt-map-timezone-mask)").style("opacity",.6);var i=this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places&&t.properties.zone%1===0&&14!==t.properties.zone}),n=[].concat(E.toConsumableArray(new Map(i.map(function(t){return[t.properties.zone,t]})).values()));this.layerTimezonesText=this.layerTimezones.append("g").attr("class","mt-map-timezones-texts"),this.layerTimezonesText.selectAll(".mt-map-timezone-text").data(n).enter().insert("text").attr("class","mt-map-timezone-text").attr("y",.82*this.getHeight()-5).attr("x",function(t){return(t.properties.zone+10)*(a.getWidth()/24.5)-1}).attr("dx",this.getWidth()/24.5/2).attr("font-size",this.scaleFontSize(9)).attr("font-family","Helevetica, Arial, Sans-Serif").attr("fill","#999").attr("text-anchor","middle").html(function(t){return A.formatDate(a.options.timezones.date||new Date,t.properties.zone)})}},{key:"getMagnitudeScale",value:function(t){var e=this.options.heatmap,a=t.length;if(!a)return function(){return 0};var i=d3.scale.linear().domain([1,a]).range([1,.25]),n=i(a),r=d3.scale.linear().domain([e.circles.min,20]).range([n,0]);return function(t){return r(t)}}},{key:"getDatumScale",value:function(){var t=this;if(!this.options.heatmap.weightByAttribute)return function(){return 1};var e=d3.extent(this.maptable.data,this.options.heatmap.weightByAttribute),a="log"===this.options.heatmap.weightByAttributeScale?d3.scale.log:d3.scale.linear,i=a().domain(e).range([.5,1]);return function(e){var a=t.options.heatmap.weightByAttribute(e);return a?i(a):0}}},{key:"getHeatmapData",value:function(){var t=this,e=d3.select(this.node).append("canvas").attr("id","mt-map-heatmap-canvas").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("style","display: none;"),a=e.node().getContext("2d");a.globalCompositeOperation="multiply";var i=d3.range(this.options.heatmap.circles.min,this.options.heatmap.circles.max,this.options.heatmap.circles.step),n=this.getDatumScale(),r=this.maptable.data.filter(function(t){return n(t)>.1}),s=this.path.context(a),o=this.getMagnitudeScale(r),l=d3.scale.linear().domain([1,0]).range(["#000000","#FFFFFF"]);a.beginPath(),a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle="#ffffff",a.fill(),a.closePath();var h=function(e){var a=t.options.heatmap.circles.colorStrength,i=1+(a-1)/100;return a>1?(2-i)*e+i-1:a*e};r.forEach(function(t){var e=n(t);i.forEach(function(i){var n=h(o(i)*e);n>0&&(a.beginPath(),s(d3.geo.circle().origin([t.longitude,t.latitude]).angle(i-1e-4)()),a.fillStyle=l(n),a.fill(),a.closePath())})}),H.canvasRGBA(e.node(),0,0,this.getWidth(),this.getHeight(),this.options.heatmap.circles.blur),a.beginPath(),a.globalCompositeOperation="screen",a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle=this.options.heatmap.circles.color,a.fill(),a.closePath();var p=e.node().toDataURL();return e.remove(),p}},{key:"updateHeatmap",value:function(){var t=this.getHeatmapData();this.imgHeatmap.attr("xlink:href",t)}},{key:"buildCountries",value:function(){this.dataCountries=topojson.feature(this.jsonWorld,this.jsonWorld.objects.countries).features,this.layerCountries.selectAll(".mt-map-country").data(this.dataCountries).enter().insert("path").attr("class","mt-map-country").attr("d",this.path),this.legendCountry={},this.shouldRenderLegend()&&(this.legendCountry.fill=new F(this))}},{key:"shouldRenderLegend",value:function(){var t=this.options.countries.attr.fill;if(!t)return!1;if(!t.legend||!t.min||!t.max)return!1;if(t.aggregate&&t.aggregate.scale){var e="function"==typeof t.aggregate.scale?t.aggregate.scale.bind(this.maptable)():t.aggregate.scale;if("linear"!==e)return!1}return!0}},{key:"getAllMtMapCountry",value:function(){return this.allMtMapCountry?this.allMtMapCountry:(this.allMtMapCountry=d3.selectAll(this.containerSelector+" .mt-map-country"),this.allMtMapCountry)}},{key:"getAllMtMapMarker",value:function(){return this.allMtMapMarker?this.allMtMapMarker:(this.allMtMapMarker=d3.selectAll(this.containerSelector+" .mt-map-marker"),this.allMtMapMarker)}},{key:"updateCountries",value:function(){var t=this,e=new Map;this.maptable.data.forEach(function(a){var i=a[t.options.countryIdentifierKey];e.has(i)||e.set(i,[]),e.get(i).push(a)}),this.dataCountries.forEach(function(a){a.key=a.properties[t.options.countryIdentifierType];var i=e.get(a.key);a.values=i||[],a.attr={},a.rollupValue={}}),Object.keys(this.options.countries.attr).forEach(function(e){t.setAttrValues(e,t.options.countries.attr[e],t.dataCountries)});var a=this.getAllMtMapCountry().each(function(t){var e=d3.select(this);Object.keys(t.attr).forEach(function(a){e.attr(a,t.attr[a])})});Object.keys(this.options.countries.attr).forEach(function(e){var i=t.options.countries.attr[e];if("object"===("undefined"==typeof i?"undefined":E["typeof"](i))&&i.legend&&void 0!==t.legendCountry[e]){var n=d3.extent(t.dataCountries,function(t){return Number(t.attrProperties[e].value)});t.legendCountry[e].updateExtents(n),a.on("mouseover",function(a){t.legendCountry[e].indiceChange(a.attrProperties[e].value)}).on("mouseout",function(){t.legendCountry[e].indiceChange(NaN)})}}),this.options.countries&&this.options.countries.tooltip&&this.activateTooltip(a,this.tooltipCountriesNode,this.options.countries.tooltip,!0)}},{key:"updateNight",value:function(){var t=this.options.night.date||Date.UTC(),e=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),0,0,0),a=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),23,59,59),i=a-e,n=t-e,r=n/i;this.layerNight.node().style.transform="translateX("+-this.getWidth()*r+"px)"}},{key:"updateTimezones",value:function(){var t=document.querySelectorAll(".mt-map-timezone-text"),e=this.options.timezones.date||new Date;Array.from(t).forEach(function(t){t.textContent=A.formatDate(e,t.__data__.properties.zone)})}},{key:"updateMarkers",value:function(){var t=this,e=function(t){return t.longitude+","+t.latitude};this.dataMarkers=d3.nest().key(e).entries(this.maptable.data).filter(function(t){return 0!==t.values[0].x}),this.dataMarkers.forEach(function(t){t.attr={},t.attrProperties={}}),Object.keys(this.options.markers.attr).forEach(function(e){t.setAttrValues(e,t.options.markers.attr[e],t.dataMarkers)});var a=this.layerMarkers.selectAll(".mt-map-marker").data(this.dataMarkers),i=a.enter();i=this.options.markers.customTag?this.options.markers.customTag(i):i.append("svg:circle");var n=this.options.markers.className?this.options.markers.className:"";i.attr("class","mt-map-marker "+n),a.exit().transition().attr("r",0).attr("fill","#eee").style("opacity",0).remove();var r=this.options.markers.attrX?this.options.markers.attrX:"cx",s=this.options.markers.attrY?this.options.markers.attrY:"cy",o=this.options.markers.attrXDelta?this.options.markers.attrXDelta:0,l=this.options.markers.attrYDelta?this.options.markers.attrYDelta:0,h=a.attr(r,function(t){return t.values[0].x+o}).attr(s,function(t){return t.values[0].y+l});this.getAllMtMapMarker().each(function(t){var e=this;Object.keys(t.attr).forEach(function(a){d3.select(e).attr(a,t.attr[a])})}),this.options.markers.tooltip&&this.activateTooltip(h,this.tooltipMarkersNode,this.options.markers.tooltip,!1),this.rescale()}},{key:"fitContent",value:function(){if(0===this.maptable.data.length)return this.transX=0,this.transY=0,this.scale=1,void this.zoomListener.translate([this.transX,this.transY]).scale(this.scale);var t=d3.extent(this.maptable.data,function(t){return t.x}),e=d3.extent(this.maptable.data,function(t){return t.y}),a=this.getWidth()/this.getHeight(),i=20+(this.options.title?30:0),n=t[1]-t[0]+i,r=e[1]-e[0]+i,s=n/a,o=r*a,l=0,h=0;o>=n?l=(o-n)/2:h=(s-r)/2,t[0]-=this.options.fitContentMargin+l,t[1]+=this.options.fitContentMargin+l,e[0]-=this.options.fitContentMargin+h,e[1]+=this.options.fitContentMargin+h,this.scale=this.getWidth()/(t[1]-t[0]),this.transX=-1*t[0]*this.scale,this.transY=-1*e[0]*this.scale,this.zoomListener.translate([this.transX,this.transY]).scale(this.scale); -}},{key:"buildTitle",value:function(){var t=this.svg.append("svg").attr("width",this.getWidth()).attr("x",0).attr("y",this.getHeight()-30).attr("height",30);this.options.title.bgColor&&t.append("rect").attr("x",0).attr("y",0).attr("width",this.getWidth()).attr("height",30).attr("fill",this.options.title.bgColor),t.append("text").attr("id","mt-map-title").attr("x",20).attr("font-size",this.scaleFontSize(this.options.title.fontSize)).attr("font-family",this.options.title.fontFamily).attr("y",20),this.options.title.source&&t.append("text").attr("y",20).attr("x",this.getWidth()-20).attr("text-anchor","end").attr("font-size",this.scaleFontSize(this.options.title.fontSize)).attr("font-family",this.options.title.fontFamily).html(this.options.title.source())}},{key:"encodeTranslation",value:function(t){var e=t[0]/(this.scale*this.getWidth()),a=t[1]/(this.scale*this.getHeight());return[e,a]}},{key:"decodeTranslation",value:function(t){var e=t[0]*this.getWidth()*this.scale,a=t[1]*this.getHeight()*this.scale;return[e,a]}},{key:"restoreState",value:function(t){if(t&&3===t.length){this.scale=t[0];var e=this.decodeTranslation([t[1],t[2]]);this.transX=e[0],this.transY=e[1],this.zoomListener.scale(t[0]).translate(e).event(this.svg)}}},{key:"saveState",value:function(){var t=this.encodeTranslation([this.transX,this.transY]),e=[this.scale,t[0],t[1]];1!==e[0]&&0!==e[1]&&0!==e[2]?this.maptable.saveState("zoom",e):this.maptable.removeState("zoom")}},{key:"rescale",value:function(){var t=this;d3.event&&d3.event.translate&&(this.scale=d3.event.scale,this.transX=1===this.scale?0:d3.event.translate[0],this.transY=1===this.scale?0:d3.event.translate[1]);var e=0,a=0,i=this.getWidth()*(1-this.scale),n=this.getHeight()*(1-this.scale);this.transY>a?this.transY=a:this.transYe?this.transX=e:this.transXe?e:t},e[0])};else if("max"===s)e.rollup=function(t){if(!t.length)return 0;var e=t.map(function(t){return Number(t[r])});return e.reduce(function(t,e){return e>t?e:t},e[0])};else if(-1!==s.indexOf("percentile")){var l=A.toNumber(s);e.rollup=function(t){if(!t.length)return 0;var e=t.map(function(t){return Number(t[r])});return A.quantile(e,l)}}else"function"==typeof e.rollup&&(e.rollup=e.rollup.bind(this.maptable));n&&(-1!==n.indexOf("log")?o=d3.scale.log():-1!==n.indexOf("pow")?o=d3.scale.pow().exponent(A.toNumber(n)||1):"sqrt"===n&&(o=d3.scale.sqrt()))}if(e.rollup||(e.rollup=function(t){return t.length}),!e.min||!e.max)throw new Error("MapTable: You should provide values 'min' & 'max' for attr."+t);if(a.forEach(function(a){var o=e.rollup(a.values);if(a.attrProperties||(a.attrProperties={}),a.attrProperties[t]||(a.attrProperties[t]={}),a.attrProperties[t].value=o,r){a.attrProperties[t].key=r,a.attrProperties[t].mode=s,a.attrProperties[t].scale=n;var l=i.maptable.columnDetails[r];a.attrProperties[t].columnDetails=l;var h={};h[r]=o,a.attrProperties[t].formatted=l&&l.cellContent?l.cellContent.bind(i.maptable)(h):o}}),"rank"===n){var h=A.uniqueValues([0].concat(a.map(function(e){return Math.floor(100*e.attrProperties[t].value)/100}).filter(function(t){return t>0}))),p=A.uniqueValues(a.map(function(e){return Math.floor(100*e.attrProperties[t].value)/100}).filter(function(t){return 0>t}));h.sort(function(t,e){return t-e}),p.sort(function(t,e){return e-t}),a.forEach(function(e){if(0!==e.attrProperties[t].value){var a=e.attrProperties[t].value>=0?h:p,i=a.indexOf(Math.floor(100*e.attrProperties[t].value)/100),n=Math.round(i/a.length*100),r=e.attrProperties[t].value<0?n-2*n:n;e.attrProperties[t].value=r}})}var u=d3.extent(a,function(e){return Number(e.attrProperties[t].value)});0===u[0]&&n&&"-1"!==n.indexOf("log")&&(u=d3.extent(a.filter(function(e){return 0!==Number(e.attrProperties[t].value)}),function(e){return Number(e.attrProperties[t].value)})),e.transform&&(u[0]=e.transform.bind(this.maptable)(u[0],this.maptable.data),u[1]=e.transform.bind(this.maptable)(u[1],this.maptable.data));var d=e.min,c=e.max;if("minValue"===e.min&&(d=u[0]),"maxValue"===e.max&&(c=u[1]),e.maxNegative&&!e.minNegative||!e.maxNegative&&e.minNegative)throw new Error("MapTable: maxNegative or minNegative undefined. Please declare both.");var m=e.maxNegative&&e.minNegative,f=void 0,g=void 0;m?(f=o.copy().domain([0,u[1]]).range([d,c]),g=o.copy().domain([u[0],0]).range([e.maxNegative,e.minNegative])):f=o.domain(u).range([d,c]),a.forEach(function(a){var n=void 0;if(!a.values.length||Number.isNaN(a.attrProperties[t].value)){if("undefined"==typeof e.empty)throw new Error("MapTable: no empty property found for attr."+t);n=e.empty}else{var r=a.attrProperties[t].value,s=e.transform?e.transform.bind(i.maptable)(r,i.maptable.data):r;n=m&&0>s?g(s):f(s)}a.attr[t]=n})}}},{key:"render",value:function(){this.options.markers&&this.updateMarkers(),this.options.countries&&this.updateCountries(),this.options.night&&this.updateNight(),this.options.timezones&&this.updateTimezones(),this.options.title&&this.updateTitle(),this.options.heatmap&&this.updateHeatmap(),this.options.autoFitContent&&(this.fitContent(),this.rescale()),this.options.onRender&&this.options.onRender.constructor===Function&&this.options.onRender.bind(this.maptable)()}},{key:"updateTitle",value:function(){var t=this;if(this.options.title.content){var e=this.maptable.data.filter(function(e){return 0!==e[t.options.latitudeKey]}).length,a=this.maptable.rawData.filter(function(e){return 0!==e[t.options.latitudeKey]}).length,i="";this.maptable.filters&&(i=this.maptable.filters.getDescription()),this.container.querySelector("#mt-map-title").innerHTML=this.options.title.content.bind(this.maptable)(e,a,i,this.maptable.data,this.maptable.rawData,this.dataCountries)}}},{key:"activateTooltip",value:function(t,e,a,i){var n=this;t.on(i?"mousemove":"mouseover",function(t){var r=a.bind(this.maptable)(t);if(r){e.html(r).attr("style","display:block;position:fixed;");var s=void 0,o=void 0,l=e.node().offsetWidth/2;if(i){var h=n.node.getBoundingClientRect(),p=d3.mouse(n.svg.node()).map(function(t){return parseInt(t,10)});s=h.left+p[0]-l,o=h.top+p[1]+10}else{var u=this.getBoundingClientRect();s=u.left+u.width/2-l,o=u.top+u.height+2}e.attr("style","top:"+o+"px;left:"+s+"px;display:block;position:fixed;").on("mouseout",function(){e.style("display","none")})}}).on("mouseout",function(){e.style("display","none")})}},{key:"exportSvg",value:function(){var t=this.container.querySelector("#mt-map-svg"),e='\n'+(new XMLSerializer).serializeToString(t);if(this.options.exportSvgClient){if(!window.saveAs)throw new Error("MapTable: Missing FileSaver.js library");var a=new Blob([e],{type:"image/svg+xml"});window.saveAs(a,"visualization.svg")}else if(this.options.exportSvg){var i=this.node.querySelector("#mt-map-svg-form");i.querySelector('[name="data"]').value=e,i.submit()}}},{key:"addExportSvgCapability",value:function(){var t=document.createElement("div");t.setAttribute("id","mt-map-export"),this.container.querySelector("#mt-map").appendChild(t);var e=document.createElement("button");if(e.setAttribute("class","btn btn-xs btn-default"),e.innerHTML="Download",e.addEventListener("click",this.exportSvg.bind(this)),t.appendChild(e),this.options.exportSvg){var a=document.createElement("div");a.innerHTML='
',t.appendChild(a)}}}]),t}(),B=function(){function t(e,a){var i=this;if(E.classCallCheck(this,t),this.maptable=e,this.options=a,this.criteria=[],this.options.show){var n=this.options.show.filter(function(t){return Object.keys(i.maptable.columnDetails).indexOf(t)<0});if(n.length>0)throw new Error('MapTable: invalid columns "'+n.join(", ")+'"');this.activeColumns=this.options.show}else this.activeColumns=Object.keys(this.maptable.columnDetails);this.container=document.createElement("div"),this.maptable.node.appendChild(this.container),this.containerSelector=e.options.target,this.container=document.querySelector(e.options.target),this.node=this.container.querySelector("#mt-filters"),this.node||(this.node=document.createElement("div"),this.node.setAttribute("id","mt-filters"),this.node.setAttribute("class","panel panel-default"),this.maptable.node.appendChild(this.node));var r=document.createElement("div");r.setAttribute("class","panel-heading");var s=document.createElement("button");s.setAttribute("id","mt-filters-reset"),s.setAttribute("class","btn btn-default btn-xs pull-right"),s.style.display="none",s.style.marginLeft=5,s.innerText="↺ Reset",s.addEventListener("click",this.reset),r.appendChild(s);var o=document.createElement("h3");o.setAttribute("class","panel-title"),o.appendChild(document.createTextNode("Filters")),r.appendChild(o),this.node.appendChild(r);var l=document.createElement("div");l.setAttribute("id","mt-filters-content"),l.setAttribute("class","panel-body");var h=document.createElement("div");h.setAttribute("id","mt-filters-elements"),l.appendChild(h);var p=document.createElement("a");p.setAttribute("id","mt-filters-new"),p.setAttribute("href","#"),p.innerText="+ New filter",p.addEventListener("click",this.add.bind(this)),l.appendChild(p),this.node.appendChild(l)}return E.createClass(t,[{key:"add",value:function(t){t&&t.preventDefault();var e=this.getPossibleFilters();if(0!==e.length){var a=e[0].key;this.create(a)}}},{key:"create",value:function(t,e){var a=this.buildRow(t);e?e.parentNode.replaceChild(a,e):this.node.querySelector("#mt-filters-elements").appendChild(a),this.criteria.push(t),this.maptable.render(),"none"===this.container.style.display&&this.toggle()}},{key:"remove",value:function(t){var e=this.node.querySelector('[data-mt-filter-name="'+t+'"]');e&&e.parentNode.removeChild(e);var a=this.criteria.indexOf(t);this.criteria.splice(a,1),this.maptable.render()}},{key:"reset",value:function(){for(var t=this.node.querySelectorAll("[data-mt-filter-name]"),e=0;e and\n '+h+""}else{var p=i.querySelector(".mt-filter-value-min").value;if(""===p)continue;s+=r.title+" is ",s+=o.options[o.selectedIndex].text,s+=''+p+""}}else if("field"===r.filterMethod||"dropdown"===r.filterMethod){var u=i.querySelector(".mt-filter-value").value;if(""===u)continue;var d="field"===r.filterMethod?"contains":"is";s+=r.title+" "+d+'\n '+u+""}t.push(s)}return t.join(", ")}},{key:"buildRow",value:function(t){var e=this,a=this,i=this.getPossibleFilters(),n=this.maptable.columnDetails[t],r=document.createElement("div");r.setAttribute("class","mt-filter-row"),r.setAttribute("data-mt-filter-name",t);var s=document.createElement("button");s.setAttribute("class","btn btn-default pull-right"),s.setAttribute("data-mt-filter-btn-minus",1),s.innerText="– Remove this filter",s.addEventListener("click",function(){t=r.querySelector(".mt-filter-name").value,e.remove(t)}),r.appendChild(s);var o=document.createElement("span");o.setAttribute("class","mt-filters-and"),o.innerText="And ",r.appendChild(o);var l=document.createElement("select");l.setAttribute("class","mt-filter-name form-control form-control-inline"),A.appendOptions(l,i.map(function(t){return{text:t.title,value:t.key}})),l.value=t,l.addEventListener("change",function(){var t=this.parentNode.getAttribute("data-mt-filter-name"),e=this.value;a.create(e,this.parentNode),a.remove(t),a.refresh()}),r.appendChild(l);var h=document.createElement("span");h.innerText="field"===n.filterMethod?" contains ":" is ",r.appendChild(h);var p=null;"field"!==n.filterMethod&&"dropdown"!==n.filterMethod&&(p=document.createElement("select"),p.setAttribute("class","mt-filter-range form-control form-control-inline"),A.appendOptions(p,["any","=","≠","<",">","≤","≥","BETWEEN"].map(function(t){return{text:t,value:t}})),p.addEventListener("change",function(){a.handleRangeChange(this)}),r.appendChild(p),r.appendChild(document.createTextNode(" ")));var u=document.createElement("div");if(u.style.display="inline-block",u.setAttribute("class","mt-filter-value-container"),"compare"===n.filterMethod)["min","max"].forEach(function(t,a){var i=document.createElement("input");if(i.setAttribute("class","form-control form-control-inline mt-filter-value-"+t),i.setAttribute("type",n.filterInputType),i.addEventListener("keyup",e.maptable.render.bind(e.maptable)),i.addEventListener("change",e.maptable.render.bind(e.maptable)),u.appendChild(i),0===a){var r=document.createElement("span");r.setAttribute("class","mt-filter-value-and"),r.innerText=" and ",u.appendChild(r)}});else if("field"===n.filterMethod){var d=document.createElement("input");d.setAttribute("class","form-control form-control-inline mt-filter-value"),d.setAttribute("type","text"),d.addEventListener("keyup",this.maptable.render.bind(this.maptable)),d.addEventListener("change",this.maptable.render.bind(this.maptable)),u.appendChild(d)}else if("dropdown"===n.filterMethod){var c=document.createElement("select");c.setAttribute("class","form-control form-control-inline mt-filter-value");var m=d3.nest().key(function(e){return e[t]}).sortKeys(d3.ascending).entries(this.maptable.rawData);A.appendOptions(c,[{text:"Any",value:""}].concat(m.map(function(t){return{text:t.key,value:t.key}}))),c.addEventListener("change",this.maptable.render.bind(this.maptable)),u.appendChild(c)}return r.appendChild(u),p&&this.handleRangeChange(p),r}},{key:"handleRangeChange",value:function(t){var e=t.parentNode;"any"===t.value?e.querySelector(".mt-filter-value-container").style.display="none":(e.querySelector(".mt-filter-value-container").style.display="inline-block","BETWEEN"===t.value?(e.querySelector(".mt-filter-value-min").style.display="inline-block",e.querySelector(".mt-filter-value-and").style.display="inline-block",e.querySelector(".mt-filter-value-max").style.display="inline-block"):(e.querySelector(".mt-filter-value-min").style.display="inline-block",e.querySelector(".mt-filter-value-and").style.display="none",e.querySelector(".mt-filter-value-max").style.display="none")),this.maptable.render.bind(this.maptable)()}},{key:"getPossibleFilters",value:function(t){var e=this;return Object.keys(this.maptable.columnDetails).map(function(t){return A.extendRecursive({key:t},e.maptable.columnDetails[t])}).filter(function(a){return-1!==e.activeColumns.indexOf(a.key)&&(t&&t===a.key||-1===e.criteria.indexOf(a.key)&&a.filterMethod&&!a.isVirtual)})}},{key:"filterData",value:function(){var t=this,e=this;this.maptable.data=this.maptable.rawData.filter(function(a){for(var i=t.node.querySelectorAll(".mt-filter-row"),n=!0,r=0;rh(m))?n=!1:(parseInt(a[o],10)parseInt(m,10))&&(n=!1)}else{var f=s.querySelector(".mt-filter-value-min").value;if(""===f)continue;h&&!A.rangeToBool(h(a[o]),d,h(f))?n=!1:h||A.rangeToBool(a[o],d,f)||(n=!1)}}(h&&A.isBlank(h(a[o]))||A.isBlank(a[o]))&&(n=!1)}return n}),this.options.saveState&&this.maptable.saveState("filters",this.exportFilters())}},{key:"refresh",value:function(){for(var t=this.node.querySelectorAll(".mt-filter-name"),e=0;e0&&(this.node.querySelectorAll(".mt-filters-and")[0].style.visibility="hidden");var r=!this.getPossibleFilters().length;this.node.querySelector("#mt-filters-new").style.visibility=r?"hidden":"visible"}},{key:"toggle",value:function(){"none"===this.container.style.display?(this.container.style.display="block",0===this.criteria.length&&this.add()):this.container.style.display="none"}}]),t}(),R=function(){function t(e,a){var i=this;if(E.classCallCheck(this,t),this.maptable=e,this.options=a,this.options.defaultSorting?(Array.isArray(this.options.defaultSorting)&&2===this.options.defaultSorting.length?this.sorting=this.options.defaultSorting:this.sorting=[this.options.defaultSorting],this.sorting.forEach(function(t){t.mode||(t.mode="asc")})):this.sorting=[{key:Object.keys(this.maptable.data[0])[0],mode:"asc"}],this.initialSorting=this.sorting.map(function(t){return t.key+","+t.mode}).join(";"),this.isSorting=!1,this.containerSelector=e.options.target,this.container=document.querySelector(e.options.target),this.node=this.container.querySelector("#mt-table"),this.node||(this.node=document.createElement("div"),this.node.setAttribute("id","mt-table"),this.maptable.node.appendChild(this.node)),this.node=d3.select(this.node).append("table").attr("class",this.options.className),this.header=this.node.append("thead"),this.body=this.node.append("tbody"),this.options.show){var n=this.options.show.filter(function(t){return Object.keys(i.maptable.columnDetails).indexOf(t)<0});if(n.length>0)throw new Error('MapTable: invalid columns "'+n.join(", ")+'"');this.activeColumns=this.options.show}else this.activeColumns=Object.keys(this.maptable.columnDetails);this.options.header&&(this.options.header.className&&this.header.attr("class",""+this.options.header.className),this.options.header.top?this.header.attr("style","top:"+(this.options.header.top||"0")+"px;"):this.header.attr("style","top:0px;")),this.header.selectAll("tr").data([1]).enter().append("tr").selectAll("th").data(this.activeColumns.map(function(t){return A.extendRecursive({key:t},i.maptable.columnDetails[t])})).enter().append("th").attr("class",function(t){var e=t.sorting?"mt-table-sortable":"";return e+=t.nowrap?" nowrap":""}).attr("data-key",function(t){return A.sanitizeKey(t.key)}).attr("onselectstart","return false;").attr("unselectable","on").attr("style",function(t){return t.nowrap?"white-space:nowrap;":""}).on("click",function(t){i.isSorting||(i.isSorting=!0,t.sorting&&i.sortColumn(t.key),i.isSorting=!1)}).text(function(t){return t.title}).attr("id",function(t){return"column_header_"+A.sanitizeKey(t.key)})}return E.createClass(t,[{key:"restoreState",value:function(t){if(t){var e=t.split(";"),a=[];e.forEach(function(t){var e=t.split(",");a.push({key:e[0],mode:e[1]||"asc"})}),this.sorting=a}}},{key:"saveState",value:function(){var t=this.sorting.map(function(t){return t.key+","+t.mode}).join(";");t!==this.initialSorting&&this.maptable.saveState("sort",t)}},{key:"render",value:function(){var t=this;this.applySort();var e=this.maptable.data;this.options.distinctBy&&(e=d3.nest().key(function(e){return e[t.options.distinctBy]}).entries(this.maptable.data).map(function(t){return t.values[0]})),this.body.selectAll("tr").data(e).enter().append("tr"),this.body.selectAll("tr").data(e).exit().remove();var a=[];this.body.selectAll("tr").data(e).attr("class",function(e){return t.options.rowClassName?"line "+t.options.rowClassName(e):"line"}).html(function(e){var i="";return t.activeColumns.forEach(function(n){var r=t.maptable.columnDetails[n];i+=""}),i}),this.options.onRender&&this.options.onRender.constructor===Function&&this.options.onRender.bind(this.maptable)()}},{key:"applySort",value:function(){for(var t=this,e=this.container.querySelectorAll(".mt-table-sortable"),a=0;a0;if(this.options.map.heatmap&&n)return i.innerHTML='
The heatmap feature is not supported with Internet Explorer.
Please use another modern browser to see this map.
',this.node.insertBefore(i,this.node.firstChild),i.querySelector(".mt-loading").style.display="block",this.options.map=!1,void this.buildComponenents();if(i.innerHTML='
Loading...
',this.node.insertBefore(i,this.node.firstChild),i.querySelector(".mt-loading").style.display="block",this.options.map.pathData)this.loadMapData(null,JSON.parse(this.options.map.pathData),i);else{if(!this.options.map.path)throw new Error("missing map path|pathData");d3.json(this.options.map.path,function(t,e){a.loadMapData(t,e,i)})}}else this.buildComponenents()}},{key:"loadMapData",value:function(t,e,a){if(t)throw t;this.map=new L(this,this.options.map,e),a.querySelector(".mt-loading").style.display="none",this.buildComponenents()}},{key:"buildComponenents",value:function(){var t=this;this.options.filters&&(this.filters=new B(this,this.options.filters)),this.options.table&&(this.table=new R(this,this.options.table)),this.restoreState(),window.addEventListener("hashchange",function(){t.restoreState()}),this.render()}},{key:"loadState",value:function(t,e){if(e){var a=this.parseState(t);if(!a)return null;try{var i=JSON.parse(a);this.state[t]=i}catch(n){return console.log("Maptable: Invalid URL State for mt-"+t+" "+n.message),null}}else{var r=this.parseState(t);r&&(this.state[t]=r)}return this.state[t]}},{key:"restoreState",value:function(){this.map&&(this.loadState("zoom",!0),this.map.restoreState(this.state.zoom)),this.filters&&(this.loadState("filters",!0),this.filters.restoreState(this.state.filters)),this.table&&(this.loadState("sort",!1),this.table.restoreState(this.state.sort))}},{key:"parseState",value:function(t){var e=document.location.href.replace(/%21mt/g,"!mt").split("!mt-"+t+"=");return e[1]?decodeURIComponent(e[1].split("!mt")[0]):null}},{key:"removeState",value:function(t){window.clearTimeout(this.saveStateTimeout[t]),delete this.state[t],this.updateState()}},{key:"saveState",value:function(t,e){var a=this;window.clearTimeout(this.saveStateTimeout[t]),this.saveStateTimeout[t]=window.setTimeout(function(){a.state[t]=e,a.updateState()},200)}},{key:"updateState",value:function(){var t=this,e=document.location.href.split("#")[0],a="";Object.keys(this.state).forEach(function(e){if(t.state[e]){var i=t.state[e];if("object"===E["typeof"](t.state[e])){if(!Object.keys(t.state[e]).length)return;i=JSON.stringify(t.state[e])}a+="!mt-"+e+"="+encodeURIComponent(i)}}),""!==a&&(a="#"+a),document.location.href!==""+e+a&&window.history.pushState(null,null,""+e+a)}},{key:"render",value:function(){this.filters&&(this.filters.filterData(),this.filters.refresh()),this.map&&(this.map.render(),!this.firstExecution&&this.options.map.onComplete&&this.options.map.onComplete.constructor===Function&&this.options.map.onComplete.bind(this)()),this.table&&(this.table.render(),!this.firstExecution&&this.options.table.onComplete&&this.options.table.onComplete.constructor===Function&&this.options.table.onComplete.bind(this)()),!this.firstExecution&&this.options.onComplete&&this.options.onComplete.constructor===Function&&this.options.onComplete.bind(this)(),this.firstExecution=!0}},{key:"setColumnDetails",value:function(){var t=this;if(0!==t.rawData.length){var e={};Object.keys(t.rawData[0]).forEach(function(a){var i=/^[-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?$/,n=i.test(t.rawData[0][a]);e[a]={title:A.keyToTile(a),filterMethod:n?"compare":"field",filterInputType:n?"number":"text",sorting:!0},n&&(e[a].dataParse=function(t){return parseFloat(t)})}),t.columnDetails=A.extendRecursive(e,this.options.columns),Object.keys(t.columnDetails).forEach(function(e){t.columnDetails[e].isVirtual="function"==typeof t.columnDetails[e].virtual})}}}]),t}();if(d3.maptable=function(t){var e=void 0,a={},i={target:t,columns:{},data:{},map:null,filters:null,table:null};return a.map=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(!topojson)throw new Error("Maptable requires topojson.js");if("string"!=typeof t.path&&"string"!=typeof t.pathData)throw new Error("MapTable: map not provided");return i.map=t,a},a.data=function(t){return i.data.type="data",i.data.value=t,a},a.json=function(t,e){return i.data.type="json",i.data.path=t,i.data.preFilter=e,a},a.jsonData=function(t){return i.data.type="jsonData",i.data.value=t,a},a.csv=function(t,e){return i.data.type="csv",i.data.path=t,i.data.preFilter=e,a},a.csvData=function(t){return i.data.type="csvData",i.data.value=t,a},a.tsv=function(t,e){return i.data.type="tsv",i.data.path=t,i.data.preFilter=e,a},a.tsvData=function(t){return i.data.type="tsvData",i.data.value=t,a},a.filters=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.filters=t,a},a.table=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.table=t,a},a.columns=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.columns=t, -a},a.render=function(a){if("string"!=typeof t||!document.querySelector(t))throw new Error("MapTable: target not found");if(!i.data||!i.data.type)throw new Error("MapTable: Please provide the path for your dataset data|json|jsonData|csv|csvData|tsv|tsvData");i.map&&!i.map.heatmap&&(i.map.heatmap=null),i.map&&i.map.markers===!1&&(i.map.markers=null),i.map&&i.map.countries===!1&&(i.map.countries=null),i.filters||(i.filters=null),i.onComplete=a;var n=A.extendRecursive(z,i);return i.map&&!i.map.markers&&delete n.map.markers,i.map&&!i.map.heatmap&&delete n.map.heatmap,i.map&&!i.map.title&&delete n.map.title,i.map&&!i.map.timezones&&delete n.map.timezones,i.map&&!i.map.night&&delete n.map.night,i.filters||delete n.filters,i.table||delete n.table,e=new G(t,n),{render:function(){return e.render()},loadState:function(t,a){return e.loadState(t,a)},removeState:function(t){return e.removeState(t)},saveState:function(t,a){return e.saveState(t,a)},setTitleContent:function(t){e.options.map.title.content=function(){return t}},setData:function(t){e.options.data.type="data",e.options.data.value=t,e.options.rawData=t,e.rawData=t,e.data=t,e.map&&e.map.enrichData()},setNightDate:function(t){e.options.map.night.date=t},setTimezonesDate:function(t){e.options.map.timezones.date=t},getMapWidth:function(){return e.map.getWidth()},getMapHeight:function(){return e.map.getHeight()}}},a},!d3)throw new Error("Maptable requires d3.js");var Y=d3.maptable;return Y}(); \ No newline at end of file +this.d3=this.d3||{},this.d3.maptable=function(){"use strict";function t(t,e,a){e.forEach(function(e){var a=document.createElement("option");a.setAttribute("value",e.value),a.innerText=e.text,t.appendChild(a)}),t.value=a}function e(t,e,a){return"="===e?parseInt(t,10)===parseInt(a,10):"≠"===e?parseInt(t,10)!==parseInt(a,10)&&""!==t&&""!==a:">"===e?parseInt(t,10)>parseInt(a,10)&&""!==t&&""!==a:"<"===e?parseInt(t,10)=parseInt(a,10)&&""!==t&&""!==a:"≤"===e?parseInt(t,10)<=parseInt(a,10)&&""!==t&&""!==a:!0}function a(){for(var t={},e=void 0,i=[].splice.call(arguments,0),n={}.toString;i.length>0;)e=i.splice(0,1)[0],"[object Object]"===n.call(e)&&Object.keys(e).forEach(function(i){"[object Object]"===n.call(e[i])?t[i]=a(t[i]||{},e[i]):t[i]=e[i]});return t}function i(t){var e=t.charAt(0).toUpperCase()+t.slice(1);return e.replace(/_/g," ")}function n(t){return t.toLowerCase().replace(/ /g,"_").replace(/"/g,"").replace(/'/g,"")}function r(t){if(!t||""===t)return null;var e=t.toString().replace(/[^0-9.]+|\s+/gim,"");return""!==e?Number(e):null}function s(t,e){t.sort(function(t,e){return t-e});var a=e/100*(t.length-1),i=void 0;if(Math.floor(a)===a)i=t[a];else{var n=Math.floor(a),r=a-n;i=t[n]+(t[n+1]-t[n])*r}return i}function o(t){if(!t)return t;for(var e=[],a=0,i=t.length;i>a;a+=1)-1===e.indexOf(t[a])&&""!==t[a]&&e.push(t[a]);return e}function l(t,e,a,i){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLImageElement&&!t instanceof HTMLImageElement)return;var n=t.naturalWidth,r=t.naturalHeight;if("string"==typeof e)var e=document.getElementById(e);else if("undefined"!=typeof HTMLCanvasElement&&!e instanceof HTMLCanvasElement)return;e.style.width=n+"px",e.style.height=r+"px",e.width=n,e.height=r;var s=e.getContext("2d");s.clearRect(0,0,n,r),s.drawImage(t,0,0),Number.isNaN(a)||1>a||(i?p(e,0,0,n,r,a):d(e,0,0,n,r,a))}function h(t,e,a,i,n){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLCanvasElement&&!t instanceof HTMLCanvasElement)return;var r,s=t.getContext("2d");try{try{r=s.getImageData(e,a,i,n)}catch(o){throw new Error("unable to access local image data: "+o)}}catch(o){throw new Error("unable to access image data: "+o)}return r}function p(t,e,a,i,n,r){if(!(Number.isNaN(r)||1>r)){r|=0;var s=h(t,e,a,i,n);s=u(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function u(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,E,N,T,D,A,z=t.data,j=r+r+1,F=i-1,q=n-1,W=r+1,O=W*(W+1)/2,P=new m,L=P;for(l=1;j>l;l++)if(L=L.next=new m,l==W)var B=L;L.next=P;var R=null,G=null;d=u=0;var Y=H[r],U=I[r];for(o=0;n>o;o++){for(w=C=S=M=c=f=g=v=0,y=W*(E=z[u]),b=W*(N=z[u+1]),k=W*(T=z[u+2]),x=W*(D=z[u+3]),c+=O*E,f+=O*N,g+=O*T,v+=O*D,L=P,l=0;W>l;l++)L.r=E,L.g=N,L.b=T,L.a=D,L=L.next;for(l=1;W>l;l++)h=u+((l>F?F:l)<<2),c+=(L.r=E=z[h])*(A=W-l),f+=(L.g=N=z[h+1])*A,g+=(L.b=T=z[h+2])*A,v+=(L.a=D=z[h+3])*A,w+=E,C+=N,S+=T,M+=D,L=L.next;for(R=P,G=B,s=0;i>s;s++)z[u+3]=D=v*Y>>U,0!=D?(D=255/D,z[u]=(c*Y>>U)*D,z[u+1]=(f*Y>>U)*D,z[u+2]=(g*Y>>U)*D):z[u]=z[u+1]=z[u+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=d+((h=s+r+1)s;s++){for(C=S=M=w=f=g=v=c=0,u=s<<2,y=W*(E=z[u]),b=W*(N=z[u+1]),k=W*(T=z[u+2]),x=W*(D=z[u+3]),c+=O*E,f+=O*N,g+=O*T,v+=O*D,L=P,l=0;W>l;l++)L.r=E,L.g=N,L.b=T,L.a=D,L=L.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(L.r=E=z[u])*(A=W-l),f+=(L.g=N=z[u+1])*A,g+=(L.b=T=z[u+2])*A,v+=(L.a=D=z[u+3])*A,w+=E,C+=N,S+=T,M+=D,L=L.next,q>l&&(p+=i);for(u=s,R=P,G=B,o=0;n>o;o++)h=u<<2,z[h+3]=D=v*Y>>U,D>0?(D=255/D,z[h]=(c*Y>>U)*D,z[h+1]=(f*Y>>U)*D,z[h+2]=(g*Y>>U)*D):z[h]=z[h+1]=z[h+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=s+((h=o+W)r)){r|=0;var s=h(t,e,a,i,n);s=c(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function c(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,E,N=t.data,T=r+r+1,D=i-1,A=n-1,z=r+1,j=z*(z+1)/2,F=new m,q=F;for(l=1;T>l;l++)if(q=q.next=new m,l==z)var W=q;q.next=F;var O=null,P=null;d=u=0;var L=H[r],B=I[r];for(o=0;n>o;o++){for(k=x=w=c=f=g=0,v=z*(C=N[u]),y=z*(S=N[u+1]),b=z*(M=N[u+2]),c+=j*C,f+=j*S,g+=j*M,q=F,l=0;z>l;l++)q.r=C,q.g=S,q.b=M,q=q.next;for(l=1;z>l;l++)h=u+((l>D?D:l)<<2),c+=(q.r=C=N[h])*(E=z-l),f+=(q.g=S=N[h+1])*E,g+=(q.b=M=N[h+2])*E,k+=C,x+=S,w+=M,q=q.next;for(O=F,P=W,s=0;i>s;s++)N[u]=c*L>>B,N[u+1]=f*L>>B,N[u+2]=g*L>>B,c-=v,f-=y,g-=b,v-=O.r,y-=O.g,b-=O.b,h=d+((h=s+r+1)s;s++){for(x=w=k=f=g=c=0,u=s<<2,v=z*(C=N[u]),y=z*(S=N[u+1]),b=z*(M=N[u+2]),c+=j*C,f+=j*S,g+=j*M,q=F,l=0;z>l;l++)q.r=C,q.g=S,q.b=M,q=q.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(q.r=C=N[u])*(E=z-l),f+=(q.g=S=N[u+1])*E,g+=(q.b=M=N[u+2])*E,k+=C,x+=S,w+=M,q=q.next,A>l&&(p+=i);for(u=s,O=F,P=W,o=0;n>o;o++)h=u<<2,N[h]=c*L>>B,N[h+1]=f*L>>B,N[h+2]=g*L>>B,c-=v,f-=y,g-=b,v-=O.r,y-=O.g,b-=O.b,h=s+((h=o+z)e?e+360:e)/180*L}function v(t){var e=f(t);return(Math.sin(e)*(1.914602-t*(.004817+14e-6*t))+Math.sin(e+e)*(.019993-101e-6*t)+289e-6*Math.sin(e+e+e))*B}function y(t){return g(t)+v(t)}function b(t){return y(t)-(.00569+.00478*Math.sin((125.04-1934.136*t)*B))*B}function k(t){return(23+(26+(21.448-t*(46.815+t*(59e-5-.001813*t)))/60)/60)*B}function x(t){return k(t)+.00256*Math.cos((125.04-1934.136*t)*B)*B}function w(t){return Math.asin(Math.sin(x(t))*Math.sin(b(t)))}function C(t){return.016708634-t*(42037e-9+1.267e-7*t)}function S(t){var e=C(t),a=f(t),i=g(t),n=Math.tan(x(t)/2);return n*=n,n*Math.sin(2*i)-2*e*Math.sin(a)+4*e*n*Math.sin(a)*Math.cos(2*i)-.5*n*n*Math.sin(4*i)-1.25*e*e*Math.sin(2*a)}function M(t){return[t[0]+180,-t[1]]}function E(t){var e=(t-Date.UTC(2e3,0,1,12))/864e5/36525,a=(d3.time.day.utc.floor(t)-t)/864e5*360-180;return[a-S(e)*R,w(e)*R]}var N={};N["typeof"]="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},N.classCallCheck=function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")},N.createClass=function(){function t(t,e){for(var a=0;a\n \n \n \n \n \n '),this.options.timezones&&(this.layerTimezones=this.layerGlobal.append("g").attr("class","mt-map-timezones")),this.layerCountries=this.layerGlobal.append("g").attr("class","mt-map-countries"),this.options.night&&(this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night")),this.options.heatmap&&(this.layerHeatmap=this.layerGlobal.append("g").attr("class","mt-map-heatmap")),this.layerMarkers=this.layerGlobal.append("g").attr("class","mt-map-markers"),this.options.watermark&&(this.watermark=new O(this,this.options.watermark)),this.options.title&&this.buildTitle(),(this.options.exportSvgClient||this.options.exportSvg)&&this.addExportSvgCapability(),this.options.width||window.addEventListener("resize",function(){n.svg.attr("width",n.getWidth()),n.svg.attr("height",n.getHeight()),n.rescale()}),this.loadGeometries()}return N.createClass(t,[{key:"enrichData",value:function(){var t=this;this.maptable.rawData.forEach(function(e){e.longitude=parseFloat(e[t.options.longitudeKey]),e.latitude=parseFloat(e[t.options.latitudeKey]);var a=[0,0];Number.isNaN(e.longitude)||Number.isNaN(e.latitude)||(a=t.projection([e.longitude,e.latitude])),e.x=a[0],e.y=a[1]})}},{key:"scaleAttributes",value:function(){return Math.pow(this.scale,2/3)}},{key:"getWidth",value:function(){return this.options.width?this.options.width:(this.options.width=this.node.offsetWidth,this.node.offsetWidth)}},{key:"getHeight",value:function(){var t=this.options.title?30:0;return!this.options.height&&this.options.ratioFromWidth?this.getWidth()*this.options.ratioFromWidth*this.options.scaleHeight+t:this.options.height*this.options.scaleHeight+t}},{key:"loadGeometries",value:function(){this.options.filterCountries&&(this.jsonWorld.objects.countries.geometries=this.jsonWorld.objects.countries.geometries.filter(this.options.filterCountries)),this.options.countries&&this.buildCountries(),this.options.heatmap&&this.buildHeatmap(),this.options.night&&this.buildNight(),this.options.timezones&&(this.options.timezones.path||this.options.timezones.pathData)&&this.buildTimezone()}},{key:"buildHeatmap",value:function(){var t=topojson.merge(this.jsonWorld,this.jsonWorld.objects.countries.geometries);if(this.options.heatmap.disableMask||(this.maskHeatmap=this.layerHeatmap.append("defs").append("clipPath").attr("id","mt-map-heatmap-mask"),this.maskHeatmap.datum(t).append("path").attr("class","mt-map-heatmap-mask-paths").attr("d",this.path)),this.imgHeatmap=this.layerHeatmap.append("image").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("x",0).attr("y",0).attr("class","mt-map-heatmap-img"),this.options.heatmap.mask&&(this.imgHeatmap=this.imgHeatmap.attr("clip-path","url(#mt-map-heatmap-mask)")),this.options.heatmap.borders){var e=topojson.mesh(this.jsonWorld,this.jsonWorld.objects.countries,function(t,e){return t!==e});this.bordersHeatmap=this.layerHeatmap.append("g").attr("class","mt-map-heatmap-borders"),this.bordersHeatmap.selectAll("path.mt-map-heatmap-borders-paths").data([t,e]).enter().append("path").attr("class","mt-map-heatmap-borders-paths").attr("fill","none").attr("stroke-width",this.options.heatmap.borders.stroke).attr("stroke",this.options.heatmap.borders.color).attr("style","opacity: "+this.options.heatmap.borders.opacity).attr("d",this.path)}}},{key:"buildNight",value:function(){this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night");var t=d3.geo.circle().angle(90);this.maskNight=this.layerNight.append("defs").append("clipPath").attr("id","mt-map-night-mask"),this.maskNight.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.nightPath=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.path).style("opacity",.1);var e=this.options.night.date||Date.UTC(),a=Date.UTC(e.getUTCFullYear(),e.getUTCMonth(),e.getUTCDate(),0,0,0),i=E(new Date(a));if(this.nightPath.datum(t.origin(M(i))).attr("d",this.path),this.nightPathRight=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+this.getWidth()+"px,0,0)"),this.nightPathLeft=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+-this.getWidth()+"px,0,0)"),!this.options.night.disableSun){var n=this.projection(i);this.sunCircleRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]+this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]-this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]-2*this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight())}}},{key:"buildTimezone",value:function(){var t=this;this.options.timezones.pathData?this.loadTimezone(null,JSON.parse(this.options.timezones.pathData)):this.options.timezones.path&&d3.json(this.options.timezones.path,function(e,a){t.loadTimezone(e,a)})}},{key:"scaleFontSize",value:function(t){return this.getWidth()<700?t*(this.getWidth()/700):t}},{key:"loadTimezone",value:function(t,e){var a=this;this.dataTimezones=topojson.feature(e,e.objects.timezones).features,this.maskTimezone=this.layerTimezones.append("defs").append("clipPath").attr("id","mt-map-timezone-mask"),this.maskTimezone.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.layerTimezones.selectAll(".mt-map-timezone").data(this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places})).enter().insert("path").attr("class","mt-map-timezone").attr("d",this.path).attr("fill",function(t){return t.properties.zone%2===0?"#F4F5F5":"transparent"}).attr("title",function(t){return JSON.stringify(t.properties)}).attr("clip-path","url(#mt-map-timezone-mask)").style("opacity",.6);var i=this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places&&t.properties.zone%1===0&&14!==t.properties.zone}),n=[].concat(N.toConsumableArray(new Map(i.map(function(t){return[t.properties.zone,t]})).values()));this.layerTimezonesText=this.layerTimezones.append("g").attr("class","mt-map-timezones-texts"),this.layerTimezonesText.selectAll(".mt-map-timezone-text").data(n).enter().insert("text").attr("class","mt-map-timezone-text").attr("y",.82*this.getHeight()-5).attr("x",function(t){return(t.properties.zone+10)*(a.getWidth()/24.5)-1}).attr("dx",this.getWidth()/24.5/2).attr("font-size",this.scaleFontSize(9)).attr("font-family","Helevetica, Arial, Sans-Serif").attr("fill","#999").attr("text-anchor","middle").html(function(t){return F.formatDate(a.options.timezones.date||new Date,t.properties.zone)})}},{key:"getMagnitudeScale",value:function(t){var e=this.options.heatmap,a=t.length;if(!a)return function(){return 0};var i=d3.scale.linear().domain([1,a]).range([1,.25]),n=i(a),r=d3.scale.linear().domain([e.circles.min,20]).range([n,0]);return function(t){return r(t)}}},{key:"getDatumScale",value:function(){var t=this;if(!this.options.heatmap.weightByAttribute)return function(){return 1};var e=d3.extent(this.maptable.data,this.options.heatmap.weightByAttribute),a="log"===this.options.heatmap.weightByAttributeScale?d3.scale.log:d3.scale.linear,i=a().domain(e).range([.5,1]);return function(e){var a=t.options.heatmap.weightByAttribute(e);return a?i(a):0}}},{key:"getHeatmapData",value:function(){var t=this,e=d3.select(this.node).append("canvas").attr("id","mt-map-heatmap-canvas").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("style","display: none;"),a=e.node().getContext("2d");a.globalCompositeOperation="multiply";var i=d3.range(this.options.heatmap.circles.min,this.options.heatmap.circles.max,this.options.heatmap.circles.step),n=this.getDatumScale(),r=this.maptable.data.filter(function(t){return n(t)>.1}),s=this.path.context(a),o=this.getMagnitudeScale(r),l=d3.scale.linear().domain([1,0]).range(["#000000","#FFFFFF"]);a.beginPath(),a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle="#ffffff",a.fill(),a.closePath();var h=function(e){var a=t.options.heatmap.circles.colorStrength,i=1+(a-1)/100;return a>1?(2-i)*e+i-1:a*e};r.forEach(function(t){var e=n(t);i.forEach(function(i){var n=h(o(i)*e);n>0&&(a.beginPath(),s(d3.geo.circle().origin([t.longitude,t.latitude]).angle(i-1e-4)()),a.fillStyle=l(n),a.fill(),a.closePath())})}),P.canvasRGBA(e.node(),0,0,this.getWidth(),this.getHeight(),this.options.heatmap.circles.blur),a.beginPath(),a.globalCompositeOperation="screen",a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle=this.options.heatmap.circles.color,a.fill(),a.closePath();var p=e.node().toDataURL();return e.remove(),p}},{key:"updateHeatmap",value:function(){var t=this.getHeatmapData();this.imgHeatmap.attr("xlink:href",t)}},{key:"buildCountries",value:function(){this.dataCountries=topojson.feature(this.jsonWorld,this.jsonWorld.objects.countries).features,this.layerCountries.selectAll(".mt-map-country").data(this.dataCountries).enter().insert("path").attr("class","mt-map-country").attr("d",this.path),this.legendCountry={},this.shouldRenderLegend()&&(this.legendCountry.fill=new W(this))}},{key:"shouldRenderLegend",value:function(){var t=this.options.countries.attr.fill;if(!t)return!1;if(!t.legend||!t.min||!t.max)return!1;if(t.aggregate&&t.aggregate.scale){var e="function"==typeof t.aggregate.scale?t.aggregate.scale.bind(this.maptable)():t.aggregate.scale;if("linear"!==e)return!1}return!0}},{key:"getAllMtMapCountry",value:function(){return this.allMtMapCountry?this.allMtMapCountry:(this.allMtMapCountry=d3.selectAll(this.containerSelector+" .mt-map-country"),this.allMtMapCountry)}},{key:"getAllMtMapMarker",value:function(){return this.allMtMapMarker?this.allMtMapMarker:(this.allMtMapMarker=d3.selectAll(this.containerSelector+" .mt-map-marker"),this.allMtMapMarker)}},{key:"updateCountries",value:function(){var t=this,e=new Map;this.maptable.data.forEach(function(a){var i=a[t.options.countryIdentifierKey];e.has(i)||e.set(i,[]),e.get(i).push(a)}),this.dataCountries.forEach(function(a){a.key=a.properties[t.options.countryIdentifierType];var i=e.get(a.key);a.values=i||[],a.attr={},a.rollupValue={}}),Object.keys(this.options.countries.attr).forEach(function(e){t.setAttrValues(e,t.options.countries.attr[e],t.dataCountries)});var a=this.getAllMtMapCountry().each(function(t){var e=d3.select(this);Object.keys(t.attr).forEach(function(a){e.attr(a,t.attr[a])})});Object.keys(this.options.countries.attr).forEach(function(e){var i=t.options.countries.attr[e];if("object"===("undefined"==typeof i?"undefined":N["typeof"](i))&&i.legend&&void 0!==t.legendCountry[e]){var n=d3.extent(t.dataCountries,function(t){return Number(t.attrProperties[e].value)});t.legendCountry[e].updateExtents(n),a.on("mouseover",function(a){t.legendCountry[e].indiceChange(a.attrProperties[e].value)}).on("mouseout",function(){t.legendCountry[e].indiceChange(NaN)})}}),this.options.countries&&this.options.countries.tooltip&&this.activateTooltip(a,this.tooltipCountriesNode,this.options.countries.tooltip,!0)}},{key:"updateNight",value:function(){var t=this.options.night.date||Date.UTC(),e=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),0,0,0),a=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),23,59,59),i=a-e,n=t-e,r=n/i;this.layerNight.node().style.transform="translateX("+-this.getWidth()*r+"px)"}},{key:"updateTimezones",value:function(){var t=document.querySelectorAll(".mt-map-timezone-text"),e=this.options.timezones.date||new Date;Array.from(t).forEach(function(t){t.textContent=F.formatDate(e,t.__data__.properties.zone)})}},{key:"updateMarkers",value:function(){var t=this,e=function(t){return t.longitude+","+t.latitude};this.dataMarkers=d3.nest().key(e).entries(this.maptable.data).filter(function(t){return 0!==t.values[0].x}),this.dataMarkers.forEach(function(t){t.attr={},t.attrProperties={}}),Object.keys(this.options.markers.attr).forEach(function(e){t.setAttrValues(e,t.options.markers.attr[e],t.dataMarkers)});var a=this.layerMarkers.selectAll(".mt-map-marker").data(this.dataMarkers),i=a.enter();i=this.options.markers.customTag?this.options.markers.customTag(i):i.append("svg:circle");var n=this.options.markers.className?this.options.markers.className:"";i.attr("class","mt-map-marker "+n),a.exit().transition().attr("r",0).attr("fill","#eee").style("opacity",0).remove();var r=this.options.markers.attrX?this.options.markers.attrX:"cx",s=this.options.markers.attrY?this.options.markers.attrY:"cy",o=this.options.markers.attrXDelta?this.options.markers.attrXDelta:0,l=this.options.markers.attrYDelta?this.options.markers.attrYDelta:0,h=a.attr(r,function(t){return t.values[0].x+o}).attr(s,function(t){return t.values[0].y+l});this.getAllMtMapMarker().each(function(t){var e=this;Object.keys(t.attr).forEach(function(a){d3.select(e).attr(a,t.attr[a])})}),this.options.markers.tooltip&&this.activateTooltip(h,this.tooltipMarkersNode,this.options.markers.tooltip,!1),this.rescale()}},{key:"fitContent",value:function(){if(0===this.maptable.data.length)return this.transX=0,this.transY=0,this.scale=1,void this.zoomListener.translate([this.transX,this.transY]).scale(this.scale);var t=d3.extent(this.maptable.data,function(t){return t.x}),e=d3.extent(this.maptable.data,function(t){ +return t.y}),a=this.getWidth()/this.getHeight(),i=20+(this.options.title?30:0),n=t[1]-t[0]+i,r=e[1]-e[0]+i,s=n/a,o=r*a,l=0,h=0;o>=n?l=(o-n)/2:h=(s-r)/2,t[0]-=this.options.fitContentMargin+l,t[1]+=this.options.fitContentMargin+l,e[0]-=this.options.fitContentMargin+h,e[1]+=this.options.fitContentMargin+h,this.scale=this.getWidth()/(t[1]-t[0]),this.transX=-1*t[0]*this.scale,this.transY=-1*e[0]*this.scale,this.zoomListener.translate([this.transX,this.transY]).scale(this.scale)}},{key:"buildTitle",value:function(){var t=this.svg.append("svg").attr("width",this.getWidth()).attr("x",0).attr("y",this.getHeight()-30).attr("height",30);this.options.title.bgColor&&t.append("rect").attr("x",0).attr("y",0).attr("width",this.getWidth()).attr("height",30).attr("fill",this.options.title.bgColor),t.append("text").attr("id","mt-map-title").attr("x",20).attr("font-size",this.scaleFontSize(this.options.title.fontSize)).attr("font-family",this.options.title.fontFamily).attr("y",20),this.options.title.source&&t.append("text").attr("y",20).attr("x",this.getWidth()-20).attr("text-anchor","end").attr("font-size",this.scaleFontSize(this.options.title.fontSize)).attr("font-family",this.options.title.fontFamily).html(this.options.title.source())}},{key:"encodeTranslation",value:function(t){var e=t[0]/(this.scale*this.getWidth()),a=t[1]/(this.scale*this.getHeight());return[e,a]}},{key:"decodeTranslation",value:function(t){var e=t[0]*this.getWidth()*this.scale,a=t[1]*this.getHeight()*this.scale;return[e,a]}},{key:"restoreState",value:function(t){if(t&&3===t.length){this.scale=t[0];var e=this.decodeTranslation([t[1],t[2]]);this.transX=e[0],this.transY=e[1],this.zoomListener.scale(t[0]).translate(e).event(this.svg)}}},{key:"saveState",value:function(){var t=this.encodeTranslation([this.transX,this.transY]),e=[this.scale,t[0],t[1]];1!==e[0]&&0!==e[1]&&0!==e[2]?this.maptable.saveState("zoom",e):this.maptable.removeState("zoom")}},{key:"rescale",value:function(){var t=this;d3.event&&d3.event.translate&&(this.scale=d3.event.scale,this.transX=1===this.scale?0:d3.event.translate[0],this.transY=1===this.scale?0:d3.event.translate[1]);var e=0,a=0,i=this.getWidth()*(1-this.scale),n=this.getHeight()*(1-this.scale);this.transY>a?this.transY=a:this.transYe?this.transX=e:this.transXe?e:t},e[0])};else if("max"===s)e.rollup=function(t){if(!t.length)return 0;var e=t.map(function(t){return Number(t[r])});return e.reduce(function(t,e){return e>t?e:t},e[0])};else if(-1!==s.indexOf("percentile")){var l=F.toNumber(s);e.rollup=function(t){if(!t.length)return 0;var e=t.map(function(t){return Number(t[r])});return F.quantile(e,l)}}else"function"==typeof e.rollup&&(e.rollup=e.rollup.bind(this.maptable));n&&(-1!==n.indexOf("log")?o=d3.scale.log():-1!==n.indexOf("pow")?o=d3.scale.pow().exponent(F.toNumber(n)||1):"sqrt"===n&&(o=d3.scale.sqrt()))}if(e.rollup||(e.rollup=function(t){return t.length}),!e.min||!e.max)throw new Error("MapTable: You should provide values 'min' & 'max' for attr."+t);if(a.forEach(function(a){var o=e.rollup(a.values);if(a.attrProperties||(a.attrProperties={}),a.attrProperties[t]||(a.attrProperties[t]={}),a.attrProperties[t].value=o,r){a.attrProperties[t].key=r,a.attrProperties[t].mode=s,a.attrProperties[t].scale=n;var l=i.maptable.columnDetails[r];a.attrProperties[t].columnDetails=l;var h={};h[r]=o,a.attrProperties[t].formatted=l&&l.cellContent?l.cellContent.bind(i.maptable)(h):o}}),"rank"===n){var h=F.uniqueValues([0].concat(a.map(function(e){return Math.floor(100*e.attrProperties[t].value)/100}).filter(function(t){return t>0}))),p=F.uniqueValues(a.map(function(e){return Math.floor(100*e.attrProperties[t].value)/100}).filter(function(t){return 0>t}));h.sort(function(t,e){return t-e}),p.sort(function(t,e){return e-t}),a.forEach(function(e){if(0!==e.attrProperties[t].value){var a=e.attrProperties[t].value>=0?h:p,i=a.indexOf(Math.floor(100*e.attrProperties[t].value)/100),n=Math.round(i/a.length*100),r=e.attrProperties[t].value<0?n-2*n:n;e.attrProperties[t].value=r}})}var u=d3.extent(a,function(e){return Number(e.attrProperties[t].value)});0===u[0]&&n&&"-1"!==n.indexOf("log")&&(u=d3.extent(a.filter(function(e){return 0!==Number(e.attrProperties[t].value)}),function(e){return Number(e.attrProperties[t].value)})),e.transform&&(u[0]=e.transform.bind(this.maptable)(u[0],this.maptable.data),u[1]=e.transform.bind(this.maptable)(u[1],this.maptable.data));var d=e.min,c=e.max;if("minValue"===e.min&&(d=u[0]),"maxValue"===e.max&&(c=u[1]),e.maxNegative&&!e.minNegative||!e.maxNegative&&e.minNegative)throw new Error("MapTable: maxNegative or minNegative undefined. Please declare both.");var m=e.maxNegative&&e.minNegative,f=void 0,g=void 0;m?(f=o.copy().domain([0,u[1]]).range([d,c]),g=o.copy().domain([u[0],0]).range([e.maxNegative,e.minNegative])):f=o.domain(u).range([d,c]),a.forEach(function(a){var n=void 0;if(!a.values.length||Number.isNaN(a.attrProperties[t].value)){if("undefined"==typeof e.empty)throw new Error("MapTable: no empty property found for attr."+t);n=e.empty}else{var r=a.attrProperties[t].value,s=e.transform?e.transform.bind(i.maptable)(r,i.maptable.data):r;n=m&&0>s?g(s):f(s)}a.attr[t]=n})}}},{key:"render",value:function(){this.options.markers&&this.updateMarkers(),this.options.countries&&this.updateCountries(),this.options.night&&this.updateNight(),this.options.timezones&&this.updateTimezones(),this.options.title&&this.updateTitle(),this.options.heatmap&&this.updateHeatmap(),this.options.autoFitContent&&(this.fitContent(),this.rescale()),this.options.onRender&&this.options.onRender.constructor===Function&&this.options.onRender.bind(this.maptable)()}},{key:"updateTitle",value:function(){var t=this;if(this.options.title.content){var e=this.maptable.data.filter(function(e){return 0!==e[t.options.latitudeKey]}).length,a=this.maptable.rawData.filter(function(e){return 0!==e[t.options.latitudeKey]}).length,i="";this.maptable.filters&&(i=this.maptable.filters.getDescription()),this.container.querySelector("#mt-map-title").innerHTML=this.options.title.content.bind(this.maptable)(e,a,i,this.maptable.data,this.maptable.rawData,this.dataCountries)}}},{key:"activateTooltip",value:function(t,e,a,i){var n=this;t.on(i?"mousemove":"mouseover",function(t){var r=a.bind(this.maptable)(t);if(r){e.html(r).attr("style","display:block;position:fixed;");var s=void 0,o=void 0,l=e.node().offsetWidth/2;if(i){var h=n.node.getBoundingClientRect(),p=d3.mouse(n.svg.node()).map(function(t){return parseInt(t,10)});s=h.left+p[0]-l,o=h.top+p[1]+10}else{var u=this.getBoundingClientRect();s=u.left+u.width/2-l,o=u.top+u.height+2}e.attr("style","top:"+o+"px;left:"+s+"px;display:block;position:fixed;").on("mouseout",function(){e.style("display","none")})}}).on("mouseout",function(){e.style("display","none")})}},{key:"exportSvg",value:function(){var t=this.container.querySelector("#mt-map-svg"),e='\n'+(new XMLSerializer).serializeToString(t);if(this.options.exportSvgClient){if(!window.saveAs)throw new Error("MapTable: Missing FileSaver.js library");var a=new Blob([e],{type:"image/svg+xml"});window.saveAs(a,"visualization.svg")}else if(this.options.exportSvg){var i=this.node.querySelector("#mt-map-svg-form");i.querySelector('[name="data"]').value=e,i.submit()}}},{key:"addExportSvgCapability",value:function(){var t=document.createElement("div");t.setAttribute("id","mt-map-export"),this.container.querySelector("#mt-map").appendChild(t);var e=document.createElement("button");if(e.setAttribute("class","btn btn-xs btn-default"),e.innerHTML="Download",e.addEventListener("click",this.exportSvg.bind(this)),t.appendChild(e),this.options.exportSvg){var a=document.createElement("div");a.innerHTML='
',t.appendChild(a)}}}]),t}(),Y=function(){function t(e,a){var i=this;if(N.classCallCheck(this,t),this.maptable=e,this.options=a,this.criteria=[],this.options.show){var n=this.options.show.filter(function(t){return Object.keys(i.maptable.columnDetails).indexOf(t)<0});if(n.length>0)throw new Error('MapTable: invalid columns "'+n.join(", ")+'"');this.activeColumns=this.options.show}else this.activeColumns=Object.keys(this.maptable.columnDetails);this.container=document.createElement("div"),this.maptable.node.appendChild(this.container),this.containerSelector=e.options.target,this.container=document.querySelector(e.options.target),this.node=this.container.querySelector("#mt-filters"),this.node||(this.node=document.createElement("div"),this.node.setAttribute("id","mt-filters"),this.node.setAttribute("class","panel panel-default"),this.maptable.node.appendChild(this.node));var r=document.createElement("div");r.setAttribute("class","panel-heading");var s=document.createElement("button");s.setAttribute("id","mt-filters-reset"),s.setAttribute("class","btn btn-default btn-xs pull-right"),s.style.display="none",s.style.marginLeft=5,s.innerText="↺ Reset",s.addEventListener("click",this.reset),r.appendChild(s);var o=document.createElement("h3");o.setAttribute("class","panel-title"),o.appendChild(document.createTextNode("Filters")),r.appendChild(o),this.node.appendChild(r);var l=document.createElement("div");l.setAttribute("id","mt-filters-content"),l.setAttribute("class","panel-body");var h=document.createElement("div");h.setAttribute("id","mt-filters-elements"),l.appendChild(h);var p=document.createElement("a");p.setAttribute("id","mt-filters-new"),p.setAttribute("href","#"),p.innerText="+ New filter",p.addEventListener("click",this.add.bind(this)),l.appendChild(p),this.node.appendChild(l)}return N.createClass(t,[{key:"add",value:function(t){t&&t.preventDefault();var e=this.getPossibleFilters();if(0!==e.length){var a=e[0].key;this.create(a)}}},{key:"create",value:function(t,e){var a=this.buildRow(t);e?e.parentNode.replaceChild(a,e):this.node.querySelector("#mt-filters-elements").appendChild(a),this.criteria.push(t),this.maptable.render(),"none"===this.container.style.display&&this.toggle()}},{key:"remove",value:function(t){var e=this.node.querySelector('[data-mt-filter-name="'+t+'"]');e&&e.parentNode.removeChild(e);var a=this.criteria.indexOf(t);this.criteria.splice(a,1),this.maptable.render()}},{key:"reset",value:function(){for(var t=this.node.querySelectorAll("[data-mt-filter-name]"),e=0;e and\n '+h+""}else{var p=i.querySelector(".mt-filter-value-min").value;if(""===p)continue;s+=r.title+" is ",s+=o.options[o.selectedIndex].text,s+=''+p+""}}else if("field"===r.filterMethod||"dropdown"===r.filterMethod){var u=i.querySelector(".mt-filter-value").value;if(""===u)continue;var d="field"===r.filterMethod?"contains":"is";s+=r.title+" "+d+'\n '+u+""}t.push(s)}return t.join(", ")}},{key:"buildRow",value:function(t){var e=this,a=this,i=this.getPossibleFilters(),n=this.maptable.columnDetails[t],r=document.createElement("div");r.setAttribute("class","mt-filter-row"),r.setAttribute("data-mt-filter-name",t);var s=document.createElement("button");s.setAttribute("class","btn btn-default pull-right"),s.setAttribute("data-mt-filter-btn-minus",1),s.innerText="– Remove this filter",s.addEventListener("click",function(){t=r.querySelector(".mt-filter-name").value,e.remove(t)}),r.appendChild(s);var o=document.createElement("span");o.setAttribute("class","mt-filters-and"),o.innerText="And ",r.appendChild(o);var l=document.createElement("select");l.setAttribute("class","mt-filter-name form-control form-control-inline"),F.appendOptions(l,i.map(function(t){return{text:t.title,value:t.key}})),l.value=t,l.addEventListener("change",function(){var t=this.parentNode.getAttribute("data-mt-filter-name"),e=this.value;a.create(e,this.parentNode),a.remove(t),a.refresh()}),r.appendChild(l);var h=document.createElement("span");h.innerText="field"===n.filterMethod?" contains ":" is ",r.appendChild(h);var p=null;"field"!==n.filterMethod&&"dropdown"!==n.filterMethod&&(p=document.createElement("select"),p.setAttribute("class","mt-filter-range form-control form-control-inline"),F.appendOptions(p,["any","=","≠","<",">","≤","≥","BETWEEN"].map(function(t){return{text:t,value:t}})),p.addEventListener("change",function(){a.handleRangeChange(this)}),r.appendChild(p),r.appendChild(document.createTextNode(" ")));var u=document.createElement("div");if(u.style.display="inline-block",u.setAttribute("class","mt-filter-value-container"),"compare"===n.filterMethod)["min","max"].forEach(function(t,a){var i=document.createElement("input");if(i.setAttribute("class","form-control form-control-inline mt-filter-value-"+t),i.setAttribute("type",n.filterInputType),i.addEventListener("keyup",e.maptable.render.bind(e.maptable)),i.addEventListener("change",e.maptable.render.bind(e.maptable)),u.appendChild(i),0===a){var r=document.createElement("span");r.setAttribute("class","mt-filter-value-and"),r.innerText=" and ",u.appendChild(r)}});else if("field"===n.filterMethod){var d=document.createElement("input");d.setAttribute("class","form-control form-control-inline mt-filter-value"),d.setAttribute("type","text"),d.addEventListener("keyup",this.maptable.render.bind(this.maptable)),d.addEventListener("change",this.maptable.render.bind(this.maptable)),u.appendChild(d)}else if("dropdown"===n.filterMethod){var c=document.createElement("select");c.setAttribute("class","form-control form-control-inline mt-filter-value");var m=d3.nest().key(function(e){return e[t]}).sortKeys(d3.ascending).entries(this.maptable.rawData);F.appendOptions(c,[{text:"Any",value:""}].concat(m.map(function(t){return{text:t.key,value:t.key}}))),c.addEventListener("change",this.maptable.render.bind(this.maptable)),u.appendChild(c)}return r.appendChild(u),p&&this.handleRangeChange(p),r}},{key:"handleRangeChange",value:function(t){var e=t.parentNode;"any"===t.value?e.querySelector(".mt-filter-value-container").style.display="none":(e.querySelector(".mt-filter-value-container").style.display="inline-block","BETWEEN"===t.value?(e.querySelector(".mt-filter-value-min").style.display="inline-block",e.querySelector(".mt-filter-value-and").style.display="inline-block",e.querySelector(".mt-filter-value-max").style.display="inline-block"):(e.querySelector(".mt-filter-value-min").style.display="inline-block",e.querySelector(".mt-filter-value-and").style.display="none",e.querySelector(".mt-filter-value-max").style.display="none")),this.maptable.render.bind(this.maptable)()}},{key:"getPossibleFilters",value:function(t){var e=this;return Object.keys(this.maptable.columnDetails).map(function(t){return F.extendRecursive({key:t},e.maptable.columnDetails[t])}).filter(function(a){return-1!==e.activeColumns.indexOf(a.key)&&(t&&t===a.key||-1===e.criteria.indexOf(a.key)&&a.filterMethod&&!a.isVirtual)})}},{key:"filterData",value:function(){var t=this,e=this;this.maptable.data=this.maptable.rawData.filter(function(a){for(var i=t.node.querySelectorAll(".mt-filter-row"),n=!0,r=0;rh(m))?n=!1:(parseInt(a[o],10)parseInt(m,10))&&(n=!1)}else{var f=s.querySelector(".mt-filter-value-min").value;if(""===f)continue;h&&!F.rangeToBool(h(a[o]),d,h(f))?n=!1:h||F.rangeToBool(a[o],d,f)||(n=!1)}}(h&&F.isBlank(h(a[o]))||F.isBlank(a[o]))&&(n=!1)}return n}),this.options.saveState&&this.maptable.saveState("filters",this.exportFilters())}},{key:"refresh",value:function(){for(var t=this.node.querySelectorAll(".mt-filter-name"),e=0;e0&&(this.node.querySelectorAll(".mt-filters-and")[0].style.visibility="hidden");var r=!this.getPossibleFilters().length;this.node.querySelector("#mt-filters-new").style.visibility=r?"hidden":"visible"}},{key:"toggle",value:function(){"none"===this.container.style.display?(this.container.style.display="block",0===this.criteria.length&&this.add()):this.container.style.display="none"}}]),t}(),U=function(){function t(e,a){var i=this;if(N.classCallCheck(this,t),this.maptable=e,this.options=a,this.sorting=[],this.options.defaultSorting?(!Array.isArray(this.options.defaultSorting)||2!==this.options.defaultSorting.length&&3!==this.options.defaultSorting.length?Array.isArray(this.options.defaultSorting)&&this.options.defaultSorting.length>=4?this.sorting=this.options.defaultSorting.slice(0,3):this.sorting=[this.options.defaultSorting]:this.sorting=this.options.defaultSorting,this.sorting.forEach(function(t){t.mode||(t.mode="asc")})):this.sorting=[{key:Object.keys(this.maptable.data[0])[0],mode:"asc"}],this.initialSorting=this.sorting.map(function(t){return t.key+","+t.mode}).join(";"),this.isSorting=!1,this.containerSelector=e.options.target,this.container=document.querySelector(e.options.target),this.node=this.container.querySelector("#mt-table"),this.node||(this.node=document.createElement("div"),this.node.setAttribute("id","mt-table"),this.maptable.node.appendChild(this.node)),this.node=d3.select(this.node).append("table").attr("class",this.options.className),this.header=this.node.append("thead"),this.body=this.node.append("tbody"),this.options.show){var n=this.options.show.filter(function(t){return Object.keys(i.maptable.columnDetails).indexOf(t)<0});if(n.length>0)throw new Error('MapTable: invalid columns "'+n.join(", ")+'"');this.activeColumns=this.options.show}else this.activeColumns=Object.keys(this.maptable.columnDetails);this.options.header&&(this.options.header.className&&this.header.attr("class",""+this.options.header.className),this.options.header.top?this.header.attr("style","top:"+(this.options.header.top||"0")+"px;"):this.header.attr("style","top:0px;")),this.header.selectAll("tr").data([1]).enter().append("tr").selectAll("th").data(this.activeColumns.map(function(t){return F.extendRecursive({key:t},i.maptable.columnDetails[t])})).enter().append("th").attr("class",function(t){var e=t.sorting?"mt-table-sortable":"";return e+=t.nowrap?" nowrap":""}).attr("data-key",function(t){return F.sanitizeKey(t.key)}).attr("onselectstart","return false;").attr("unselectable","on").attr("style",function(t){return t.nowrap?"white-space:nowrap;":""}).on("click",function(t){i.isSorting||(i.isSorting=!0,t.sorting&&i.sortColumn(t.key),i.isSorting=!1)}).text(function(t){return t.title}).attr("id",function(t){return"column_header_"+F.sanitizeKey(t.key)})}return N.createClass(t,[{key:"restoreState",value:function(t){if(t){var e=t.split(";"),a=[];e.forEach(function(t){var e=t.split(",");a.push({key:e[0],mode:e[1]||"asc"})}),this.sorting=a}}},{key:"saveState",value:function(){var t=this.sorting.map(function(t){return t.key+","+t.mode}).join(";");t!==this.initialSorting&&this.maptable.saveState("sort",t)}},{key:"render",value:function(){var t=this;this.applySort();var e=this.maptable.data;this.options.distinctBy&&(e=d3.nest().key(function(e){return e[t.options.distinctBy]}).entries(this.maptable.data).map(function(t){return t.values[0]})),this.body.selectAll("tr").data(e).enter().append("tr"),this.body.selectAll("tr").data(e).exit().remove();var a=[];this.sortIndex=0,this.body.selectAll("tr").data(e).attr("class",function(a,i){var n=t.isEndOfPrimarySort(e,i);return t.options.rowClassName?"line "+t.options.rowClassName(a)+" "+(n?"bold":""):"line "+(n?"bold":"")}).html(function(e){var i="";return t.activeColumns.forEach(function(n){var r=t.maptable.columnDetails[n];i+=""}),i}).append("span").attr("class","table-sort-sn "+(!this.options.dataCountIndicator||this.options.dataCountIndicator&&!this.options.dataCountIndicator.enabled||this.sorting&&this.sorting.length<=1?"display-none":"")+" ").html(function(a,i){var n=t.isEndOfPrimarySort(e,i-1);return n?t.sortIndex=1:t.sortIndex+=1,""+t.sortIndex}),this.options.onRender&&this.options.onRender.constructor===Function&&this.options.onRender.bind(this.maptable)()}},{key:"applySort",value:function(){for(var t=this,e=this.container.querySelectorAll(".mt-table-sortable"),a=0;ae?-1:1,n=t;n!=e;n+=i)this.sorting[n]=this.sorting[n+i];this.sorting[e]=a}}},{key:"isEndOfPrimarySort",value:function(t,e){if(!this.options.dataGroupSeparator||this.options.dataGroupSeparator&&!this.options.dataGroupSeparator.enabled)return!1;if(this.sorting&&this.sorting.length<=1)return!1;var a=this.sorting[0].key||"";return t[e]&&t[e+1]&&t[e][a]&&t[e+1][a]?(""+t[e][a]).toLowerCase()!==(""+t[e+1][a]).toLowerCase():!1}}]),t}(),X=function(){function t(e,a){N.classCallCheck(this,t),this.options=a,this.state={},this.saveStateTimeout={},this.removeStateTimeout=null,this.node=document.querySelector(e),this.node.setAttribute("style","position:relative;"),"json"===this.options.data.type?d3.json(this.options.data.path,this.loadData.bind(this)):"csv"===this.options.data.type?d3.csv(this.options.data.path,this.loadData.bind(this)):"tsv"===this.options.data.type?d3.tsv(this.options.data.path,this.loadData.bind(this)):"jsonData"===this.options.data.type?this.loadData(null,JSON.parse(this.options.data.value)):"csvData"===this.options.data.type?this.loadData(null,d3.csv.parse(this.options.data.value)):"tsvData"===this.options.data.type?this.loadData(null,d3.tsv.parse(this.options.data.value)):"data"===this.options.data.type&&this.loadData(null,this.options.data.value),this.options.map&&this.options.map.heatmap&&delete this.options.map.countries}return N.createClass(t,[{key:"loadData",value:function(t,e){var a=this;if(t)throw t;if(this.rawData=e,this.options.data.preFilter&&(this.rawData=this.rawData.filter(this.options.data.preFilter)),this.setColumnDetails(),this.data=this.rawData.slice(),this.options.map){var i=document.createElement("div");i.setAttribute("class","mt-map-container");var n=-1!==navigator.userAgent.indexOf("MSIE")||navigator.appVersion.indexOf("Trident/")>0;if(this.options.map.heatmap&&n)return i.innerHTML='
The heatmap feature is not supported with Internet Explorer.
Please use another modern browser to see this map.
',this.node.insertBefore(i,this.node.firstChild),i.querySelector(".mt-loading").style.display="block",this.options.map=!1,void this.buildComponenents();if(i.innerHTML='
Loading...
',this.node.insertBefore(i,this.node.firstChild),i.querySelector(".mt-loading").style.display="block",this.options.map.pathData)this.loadMapData(null,JSON.parse(this.options.map.pathData),i);else{if(!this.options.map.path)throw new Error("missing map path|pathData");d3.json(this.options.map.path,function(t,e){a.loadMapData(t,e,i)})}}else this.buildComponenents()}},{key:"loadMapData",value:function(t,e,a){if(t)throw t;this.map=new G(this,this.options.map,e),a.querySelector(".mt-loading").style.display="none",this.buildComponenents()}},{key:"buildComponenents",value:function(){var t=this;this.options.filters&&(this.filters=new Y(this,this.options.filters)),this.options.table&&(this.table=new U(this,this.options.table)),this.restoreState(),window.addEventListener("hashchange",function(){t.restoreState()}),this.render()}},{key:"loadState",value:function(t,e){if(e){var a=this.parseState(t);if(!a)return null;try{var i=JSON.parse(a);this.state[t]=i}catch(n){return console.log("Maptable: Invalid URL State for mt-"+t+" "+n.message),null}}else{var r=this.parseState(t);r&&(this.state[t]=r)}return this.state[t]}},{key:"restoreState",value:function(){this.map&&(this.loadState("zoom",!0),this.map.restoreState(this.state.zoom)),this.filters&&(this.loadState("filters",!0),this.filters.restoreState(this.state.filters)),this.table&&(this.loadState("sort",!1),this.table.restoreState(this.state.sort))}},{key:"parseState",value:function(t){var e=document.location.href.replace(/%21mt/g,"!mt").split("!mt-"+t+"=");return e[1]?decodeURIComponent(e[1].split("!mt")[0]):null}},{key:"removeState",value:function(t){window.clearTimeout(this.saveStateTimeout[t]),delete this.state[t],this.updateState()}},{key:"saveState",value:function(t,e){var a=this;window.clearTimeout(this.saveStateTimeout[t]),this.saveStateTimeout[t]=window.setTimeout(function(){a.state[t]=e,a.updateState()},200)}},{key:"updateState",value:function(){var t=this,e=document.location.href.split("#")[0],a="";Object.keys(this.state).forEach(function(e){if(t.state[e]){var i=t.state[e];if("object"===N["typeof"](t.state[e])){if(!Object.keys(t.state[e]).length)return;i=JSON.stringify(t.state[e])}a+="!mt-"+e+"="+encodeURIComponent(i)}}),""!==a&&(a="#"+a),document.location.href!==""+e+a&&window.history.pushState(null,null,""+e+a)}},{key:"render",value:function(){this.filters&&(this.filters.filterData(),this.filters.refresh()),this.map&&(this.map.render(),!this.firstExecution&&this.options.map.onComplete&&this.options.map.onComplete.constructor===Function&&this.options.map.onComplete.bind(this)()),this.table&&(this.table.render(),!this.firstExecution&&this.options.table.onComplete&&this.options.table.onComplete.constructor===Function&&this.options.table.onComplete.bind(this)()), +!this.firstExecution&&this.options.onComplete&&this.options.onComplete.constructor===Function&&this.options.onComplete.bind(this)(),this.firstExecution=!0}},{key:"setColumnDetails",value:function(){var t=this,e=this;if(0!==e.rawData.length){var a={};Object.keys(e.rawData[0]).forEach(function(i){var n=/^[-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?$/,r=n.test(e.rawData[0][i]);a[i]={title:F.keyToTile(i),filterMethod:r?"compare":"field",filterInputType:r?"number":t.options.columns[i]&&t.options.columns[i].filterInputType?t.options.columns[i].filterInputType:"text",sorting:!0},r&&(a[i].dataParse=function(t){return parseFloat(t)})}),e.columnDetails=F.extendRecursive(a,this.options.columns),Object.keys(e.columnDetails).forEach(function(t){e.columnDetails[t].isVirtual="function"==typeof e.columnDetails[t].virtual})}}}]),t}();if(d3.maptable=function(t){var e=void 0,a={},i={target:t,columns:{},data:{},map:null,filters:null,table:null};return a.map=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(!topojson)throw new Error("Maptable requires topojson.js");if("string"!=typeof t.path&&"string"!=typeof t.pathData)throw new Error("MapTable: map not provided");return i.map=t,a},a.data=function(t){return i.data.type="data",i.data.value=t,a},a.json=function(t,e){return i.data.type="json",i.data.path=t,i.data.preFilter=e,a},a.jsonData=function(t){return i.data.type="jsonData",i.data.value=t,a},a.csv=function(t,e){return i.data.type="csv",i.data.path=t,i.data.preFilter=e,a},a.csvData=function(t){return i.data.type="csvData",i.data.value=t,a},a.tsv=function(t,e){return i.data.type="tsv",i.data.path=t,i.data.preFilter=e,a},a.tsvData=function(t){return i.data.type="tsvData",i.data.value=t,a},a.filters=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.filters=t,a},a.table=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.table=t,a},a.columns=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.columns=t,a},a.render=function(a){if("string"!=typeof t||!document.querySelector(t))throw new Error("MapTable: target not found");if(!i.data||!i.data.type)throw new Error("MapTable: Please provide the path for your dataset data|json|jsonData|csv|csvData|tsv|tsvData");i.map&&!i.map.heatmap&&(i.map.heatmap=null),i.map&&i.map.markers===!1&&(i.map.markers=null),i.map&&i.map.countries===!1&&(i.map.countries=null),i.filters||(i.filters=null),i.onComplete=a;var n=F.extendRecursive(q,i);return i.map&&!i.map.markers&&delete n.map.markers,i.map&&!i.map.heatmap&&delete n.map.heatmap,i.map&&!i.map.title&&delete n.map.title,i.map&&!i.map.timezones&&delete n.map.timezones,i.map&&!i.map.night&&delete n.map.night,i.filters||delete n.filters,i.table||delete n.table,e=new X(t,n),{render:function(){return e.render()},loadState:function(t,a){return e.loadState(t,a)},removeState:function(t){return e.removeState(t)},saveState:function(t,a){return e.saveState(t,a)},setTitleContent:function(t){e.options.map.title.content=function(){return t}},setData:function(t){e.options.data.type="data",e.options.data.value=t,e.options.rawData=t,e.rawData=t,e.data=t,e.map&&e.map.enrichData()},setNightDate:function(t){e.options.map.night.date=t},setTimezonesDate:function(t){e.options.map.timezones.date=t},getMapWidth:function(){return e.map.getWidth()},getMapHeight:function(){return e.map.getHeight()}}},a},!d3)throw new Error("Maptable requires d3.js");var K=d3.maptable;return K}(); \ No newline at end of file diff --git a/docs/maptable.js b/docs/maptable.js index d1039ef..ed1c2fb 100644 --- a/docs/maptable.js +++ b/docs/maptable.js @@ -3068,7 +3068,8 @@ this.d3.maptable = (function () { var primarySort = this.sorting[0].key || ''; if (data[index] && data[index + 1]) { if (data[index][primarySort] && data[index + 1][primarySort]) { - return data[index][primarySort].toLowerCase() !== data[index + 1][primarySort].toLowerCase(); + // stringify everything before .toLowerCase() + return ('' + data[index][primarySort]).toLowerCase() !== ('' + data[index + 1][primarySort]).toLowerCase(); } } return false; diff --git a/docs/maptable.min.js b/docs/maptable.min.js index 8737653..1234261 100644 --- a/docs/maptable.min.js +++ b/docs/maptable.min.js @@ -1,7 +1,7 @@ /** - * MapTable 2.5.0 - License MIT - Build: Fri May 17 2024 12:52:37 GMT+0200 (Central European Summer Time) + * MapTable 2.5.0 - License MIT - Build: Fri Jun 14 2024 12:48:26 GMT+0545 (Nepal Time) */ -this.d3=this.d3||{},this.d3.maptable=function(){"use strict";function t(t,e,a){e.forEach(function(e){var a=document.createElement("option");a.setAttribute("value",e.value),a.innerText=e.text,t.appendChild(a)}),t.value=a}function e(t,e,a){return"="===e?parseInt(t,10)===parseInt(a,10):"≠"===e?parseInt(t,10)!==parseInt(a,10)&&""!==t&&""!==a:">"===e?parseInt(t,10)>parseInt(a,10)&&""!==t&&""!==a:"<"===e?parseInt(t,10)=parseInt(a,10)&&""!==t&&""!==a:"≤"===e?parseInt(t,10)<=parseInt(a,10)&&""!==t&&""!==a:!0}function a(){for(var t={},e=void 0,i=[].splice.call(arguments,0),n={}.toString;i.length>0;)e=i.splice(0,1)[0],"[object Object]"===n.call(e)&&Object.keys(e).forEach(function(i){"[object Object]"===n.call(e[i])?t[i]=a(t[i]||{},e[i]):t[i]=e[i]});return t}function i(t){var e=t.charAt(0).toUpperCase()+t.slice(1);return e.replace(/_/g," ")}function n(t){return t.toLowerCase().replace(/ /g,"_").replace(/"/g,"").replace(/'/g,"")}function r(t){if(!t||""===t)return null;var e=t.toString().replace(/[^0-9.]+|\s+/gim,"");return""!==e?Number(e):null}function s(t,e){t.sort(function(t,e){return t-e});var a=e/100*(t.length-1),i=void 0;if(Math.floor(a)===a)i=t[a];else{var n=Math.floor(a),r=a-n;i=t[n]+(t[n+1]-t[n])*r}return i}function o(t){if(!t)return t;for(var e=[],a=0,i=t.length;i>a;a+=1)-1===e.indexOf(t[a])&&""!==t[a]&&e.push(t[a]);return e}function l(t,e,a,i){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLImageElement&&!t instanceof HTMLImageElement)return;var n=t.naturalWidth,r=t.naturalHeight;if("string"==typeof e)var e=document.getElementById(e);else if("undefined"!=typeof HTMLCanvasElement&&!e instanceof HTMLCanvasElement)return;e.style.width=n+"px",e.style.height=r+"px",e.width=n,e.height=r;var s=e.getContext("2d");s.clearRect(0,0,n,r),s.drawImage(t,0,0),Number.isNaN(a)||1>a||(i?p(e,0,0,n,r,a):d(e,0,0,n,r,a))}function h(t,e,a,i,n){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLCanvasElement&&!t instanceof HTMLCanvasElement)return;var r,s=t.getContext("2d");try{try{r=s.getImageData(e,a,i,n)}catch(o){throw new Error("unable to access local image data: "+o)}}catch(o){throw new Error("unable to access image data: "+o)}return r}function p(t,e,a,i,n,r){if(!(Number.isNaN(r)||1>r)){r|=0;var s=h(t,e,a,i,n);s=u(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function u(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,N,E,T,D,A,z=t.data,F=r+r+1,j=i-1,H=n-1,O=r+1,P=O*(O+1)/2,I=new m,L=I;for(l=1;F>l;l++)if(L=L.next=new m,l==O)var B=L;L.next=I;var R=null,G=null;d=u=0;var Y=q[r],U=W[r];for(o=0;n>o;o++){for(w=C=S=M=c=f=g=v=0,y=O*(N=z[u]),b=O*(E=z[u+1]),k=O*(T=z[u+2]),x=O*(D=z[u+3]),c+=P*N,f+=P*E,g+=P*T,v+=P*D,L=I,l=0;O>l;l++)L.r=N,L.g=E,L.b=T,L.a=D,L=L.next;for(l=1;O>l;l++)h=u+((l>j?j:l)<<2),c+=(L.r=N=z[h])*(A=O-l),f+=(L.g=E=z[h+1])*A,g+=(L.b=T=z[h+2])*A,v+=(L.a=D=z[h+3])*A,w+=N,C+=E,S+=T,M+=D,L=L.next;for(R=I,G=B,s=0;i>s;s++)z[u+3]=D=v*Y>>U,0!=D?(D=255/D,z[u]=(c*Y>>U)*D,z[u+1]=(f*Y>>U)*D,z[u+2]=(g*Y>>U)*D):z[u]=z[u+1]=z[u+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=d+((h=s+r+1)s;s++){for(C=S=M=w=f=g=v=c=0,u=s<<2,y=O*(N=z[u]),b=O*(E=z[u+1]),k=O*(T=z[u+2]),x=O*(D=z[u+3]),c+=P*N,f+=P*E,g+=P*T,v+=P*D,L=I,l=0;O>l;l++)L.r=N,L.g=E,L.b=T,L.a=D,L=L.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(L.r=N=z[u])*(A=O-l),f+=(L.g=E=z[u+1])*A,g+=(L.b=T=z[u+2])*A,v+=(L.a=D=z[u+3])*A,w+=N,C+=E,S+=T,M+=D,L=L.next,H>l&&(p+=i);for(u=s,R=I,G=B,o=0;n>o;o++)h=u<<2,z[h+3]=D=v*Y>>U,D>0?(D=255/D,z[h]=(c*Y>>U)*D,z[h+1]=(f*Y>>U)*D,z[h+2]=(g*Y>>U)*D):z[h]=z[h+1]=z[h+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=s+((h=o+O)r)){r|=0;var s=h(t,e,a,i,n);s=c(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function c(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,N,E=t.data,T=r+r+1,D=i-1,A=n-1,z=r+1,F=z*(z+1)/2,j=new m,H=j;for(l=1;T>l;l++)if(H=H.next=new m,l==z)var O=H;H.next=j;var P=null,I=null;d=u=0;var L=q[r],B=W[r];for(o=0;n>o;o++){for(k=x=w=c=f=g=0,v=z*(C=E[u]),y=z*(S=E[u+1]),b=z*(M=E[u+2]),c+=F*C,f+=F*S,g+=F*M,H=j,l=0;z>l;l++)H.r=C,H.g=S,H.b=M,H=H.next;for(l=1;z>l;l++)h=u+((l>D?D:l)<<2),c+=(H.r=C=E[h])*(N=z-l),f+=(H.g=S=E[h+1])*N,g+=(H.b=M=E[h+2])*N,k+=C,x+=S,w+=M,H=H.next;for(P=j,I=O,s=0;i>s;s++)E[u]=c*L>>B,E[u+1]=f*L>>B,E[u+2]=g*L>>B,c-=v,f-=y,g-=b,v-=P.r,y-=P.g,b-=P.b,h=d+((h=s+r+1)s;s++){for(x=w=k=f=g=c=0,u=s<<2,v=z*(C=E[u]),y=z*(S=E[u+1]),b=z*(M=E[u+2]),c+=F*C,f+=F*S,g+=F*M,H=j,l=0;z>l;l++)H.r=C,H.g=S,H.b=M,H=H.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(H.r=C=E[u])*(N=z-l),f+=(H.g=S=E[u+1])*N,g+=(H.b=M=E[u+2])*N,k+=C,x+=S,w+=M,H=H.next,A>l&&(p+=i);for(u=s,P=j,I=O,o=0;n>o;o++)h=u<<2,E[h]=c*L>>B,E[h+1]=f*L>>B,E[h+2]=g*L>>B,c-=v,f-=y,g-=b,v-=P.r,y-=P.g,b-=P.b,h=s+((h=o+z)e?e+360:e)/180*O}function v(t){var e=f(t);return(Math.sin(e)*(1.914602-t*(.004817+14e-6*t))+Math.sin(e+e)*(.019993-101e-6*t)+289e-6*Math.sin(e+e+e))*P}function y(t){return g(t)+v(t)}function b(t){return y(t)-(.00569+.00478*Math.sin((125.04-1934.136*t)*P))*P}function k(t){return(23+(26+(21.448-t*(46.815+t*(59e-5-.001813*t)))/60)/60)*P}function x(t){return k(t)+.00256*Math.cos((125.04-1934.136*t)*P)*P}function w(t){return Math.asin(Math.sin(x(t))*Math.sin(b(t)))}function C(t){return.016708634-t*(42037e-9+1.267e-7*t)}function S(t){var e=C(t),a=f(t),i=g(t),n=Math.tan(x(t)/2);return n*=n,n*Math.sin(2*i)-2*e*Math.sin(a)+4*e*n*Math.sin(a)*Math.cos(2*i)-.5*n*n*Math.sin(4*i)-1.25*e*e*Math.sin(2*a)}function M(t){return[t[0]+180,-t[1]]}function N(t){var e=(t-Date.UTC(2e3,0,1,12))/864e5/36525,a=(d3.time.day.utc.floor(t)-t)/864e5*360-180;return[a-S(e)*I,w(e)*I]}var E={};E["typeof"]="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},E.classCallCheck=function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")},E.createClass=function(){function t(t,e){for(var a=0;a\n \n \n \n \n \n '),this.options.timezones&&(this.layerTimezones=this.layerGlobal.append("g").attr("class","mt-map-timezones")),this.layerCountries=this.layerGlobal.append("g").attr("class","mt-map-countries"),this.options.night&&(this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night")),this.options.heatmap&&(this.layerHeatmap=this.layerGlobal.append("g").attr("class","mt-map-heatmap")),this.layerMarkers=this.layerGlobal.append("g").attr("class","mt-map-markers"),this.options.watermark&&(this.watermark=new j(this,this.options.watermark)),this.options.title&&this.buildTitle(),(this.options.exportSvgClient||this.options.exportSvg)&&this.addExportSvgCapability(),this.options.width||window.addEventListener("resize",function(){n.svg.attr("width",n.getWidth()),n.svg.attr("height",n.getHeight()),n.rescale()}),this.loadGeometries()}return E.createClass(t,[{key:"enrichData",value:function(){var t=this;this.maptable.rawData.forEach(function(e){e.longitude=parseFloat(e[t.options.longitudeKey]),e.latitude=parseFloat(e[t.options.latitudeKey]);var a=[0,0];Number.isNaN(e.longitude)||Number.isNaN(e.latitude)||(a=t.projection([e.longitude,e.latitude])),e.x=a[0],e.y=a[1]})}},{key:"scaleAttributes",value:function(){return Math.pow(this.scale,2/3)}},{key:"getWidth",value:function(){return this.options.width?this.options.width:(this.options.width=this.node.offsetWidth,this.node.offsetWidth)}},{key:"getHeight",value:function(){var t=this.options.title?30:0;return!this.options.height&&this.options.ratioFromWidth?this.getWidth()*this.options.ratioFromWidth*this.options.scaleHeight+t:this.options.height*this.options.scaleHeight+t}},{key:"loadGeometries",value:function(){this.options.filterCountries&&(this.jsonWorld.objects.countries.geometries=this.jsonWorld.objects.countries.geometries.filter(this.options.filterCountries)),this.options.countries&&this.buildCountries(),this.options.heatmap&&this.buildHeatmap(),this.options.night&&this.buildNight(),this.options.timezones&&(this.options.timezones.path||this.options.timezones.pathData)&&this.buildTimezone()}},{key:"buildHeatmap",value:function(){var t=topojson.merge(this.jsonWorld,this.jsonWorld.objects.countries.geometries);if(this.options.heatmap.disableMask||(this.maskHeatmap=this.layerHeatmap.append("defs").append("clipPath").attr("id","mt-map-heatmap-mask"),this.maskHeatmap.datum(t).append("path").attr("class","mt-map-heatmap-mask-paths").attr("d",this.path)),this.imgHeatmap=this.layerHeatmap.append("image").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("x",0).attr("y",0).attr("class","mt-map-heatmap-img"),this.options.heatmap.mask&&(this.imgHeatmap=this.imgHeatmap.attr("clip-path","url(#mt-map-heatmap-mask)")),this.options.heatmap.borders){var e=topojson.mesh(this.jsonWorld,this.jsonWorld.objects.countries,function(t,e){return t!==e});this.bordersHeatmap=this.layerHeatmap.append("g").attr("class","mt-map-heatmap-borders"),this.bordersHeatmap.selectAll("path.mt-map-heatmap-borders-paths").data([t,e]).enter().append("path").attr("class","mt-map-heatmap-borders-paths").attr("fill","none").attr("stroke-width",this.options.heatmap.borders.stroke).attr("stroke",this.options.heatmap.borders.color).attr("style","opacity: "+this.options.heatmap.borders.opacity).attr("d",this.path)}}},{key:"buildNight",value:function(){this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night");var t=d3.geo.circle().angle(90);this.maskNight=this.layerNight.append("defs").append("clipPath").attr("id","mt-map-night-mask"),this.maskNight.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.nightPath=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.path).style("opacity",.1);var e=this.options.night.date||Date.UTC(),a=Date.UTC(e.getUTCFullYear(),e.getUTCMonth(),e.getUTCDate(),0,0,0),i=N(new Date(a));if(this.nightPath.datum(t.origin(M(i))).attr("d",this.path),this.nightPathRight=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+this.getWidth()+"px,0,0)"),this.nightPathLeft=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+-this.getWidth()+"px,0,0)"),!this.options.night.disableSun){var n=this.projection(i);this.sunCircleRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]+this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]-this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]-2*this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight())}}},{key:"buildTimezone",value:function(){var t=this;this.options.timezones.pathData?this.loadTimezone(null,JSON.parse(this.options.timezones.pathData)):this.options.timezones.path&&d3.json(this.options.timezones.path,function(e,a){t.loadTimezone(e,a)})}},{key:"scaleFontSize",value:function(t){return this.getWidth()<700?t*(this.getWidth()/700):t}},{key:"loadTimezone",value:function(t,e){var a=this;this.dataTimezones=topojson.feature(e,e.objects.timezones).features,this.maskTimezone=this.layerTimezones.append("defs").append("clipPath").attr("id","mt-map-timezone-mask"),this.maskTimezone.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.layerTimezones.selectAll(".mt-map-timezone").data(this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places})).enter().insert("path").attr("class","mt-map-timezone").attr("d",this.path).attr("fill",function(t){return t.properties.zone%2===0?"#F4F5F5":"transparent"}).attr("title",function(t){return JSON.stringify(t.properties)}).attr("clip-path","url(#mt-map-timezone-mask)").style("opacity",.6);var i=this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places&&t.properties.zone%1===0&&14!==t.properties.zone}),n=[].concat(E.toConsumableArray(new Map(i.map(function(t){return[t.properties.zone,t]})).values()));this.layerTimezonesText=this.layerTimezones.append("g").attr("class","mt-map-timezones-texts"),this.layerTimezonesText.selectAll(".mt-map-timezone-text").data(n).enter().insert("text").attr("class","mt-map-timezone-text").attr("y",.82*this.getHeight()-5).attr("x",function(t){return(t.properties.zone+10)*(a.getWidth()/24.5)-1}).attr("dx",this.getWidth()/24.5/2).attr("font-size",this.scaleFontSize(9)).attr("font-family","Helevetica, Arial, Sans-Serif").attr("fill","#999").attr("text-anchor","middle").html(function(t){return A.formatDate(a.options.timezones.date||new Date,t.properties.zone)})}},{key:"getMagnitudeScale",value:function(t){var e=this.options.heatmap,a=t.length;if(!a)return function(){return 0};var i=d3.scale.linear().domain([1,a]).range([1,.25]),n=i(a),r=d3.scale.linear().domain([e.circles.min,20]).range([n,0]);return function(t){return r(t)}}},{key:"getDatumScale",value:function(){var t=this;if(!this.options.heatmap.weightByAttribute)return function(){return 1};var e=d3.extent(this.maptable.data,this.options.heatmap.weightByAttribute),a="log"===this.options.heatmap.weightByAttributeScale?d3.scale.log:d3.scale.linear,i=a().domain(e).range([.5,1]);return function(e){var a=t.options.heatmap.weightByAttribute(e);return a?i(a):0}}},{key:"getHeatmapData",value:function(){var t=this,e=d3.select(this.node).append("canvas").attr("id","mt-map-heatmap-canvas").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("style","display: none;"),a=e.node().getContext("2d");a.globalCompositeOperation="multiply";var i=d3.range(this.options.heatmap.circles.min,this.options.heatmap.circles.max,this.options.heatmap.circles.step),n=this.getDatumScale(),r=this.maptable.data.filter(function(t){return n(t)>.1}),s=this.path.context(a),o=this.getMagnitudeScale(r),l=d3.scale.linear().domain([1,0]).range(["#000000","#FFFFFF"]);a.beginPath(),a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle="#ffffff",a.fill(),a.closePath();var h=function(e){var a=t.options.heatmap.circles.colorStrength,i=1+(a-1)/100;return a>1?(2-i)*e+i-1:a*e};r.forEach(function(t){var e=n(t);i.forEach(function(i){var n=h(o(i)*e);n>0&&(a.beginPath(),s(d3.geo.circle().origin([t.longitude,t.latitude]).angle(i-1e-4)()),a.fillStyle=l(n),a.fill(),a.closePath())})}),H.canvasRGBA(e.node(),0,0,this.getWidth(),this.getHeight(),this.options.heatmap.circles.blur),a.beginPath(),a.globalCompositeOperation="screen",a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle=this.options.heatmap.circles.color,a.fill(),a.closePath();var p=e.node().toDataURL();return e.remove(),p}},{key:"updateHeatmap",value:function(){var t=this.getHeatmapData();this.imgHeatmap.attr("xlink:href",t)}},{key:"buildCountries",value:function(){this.dataCountries=topojson.feature(this.jsonWorld,this.jsonWorld.objects.countries).features,this.layerCountries.selectAll(".mt-map-country").data(this.dataCountries).enter().insert("path").attr("class","mt-map-country").attr("d",this.path),this.legendCountry={},this.shouldRenderLegend()&&(this.legendCountry.fill=new F(this))}},{key:"shouldRenderLegend",value:function(){var t=this.options.countries.attr.fill;if(!t)return!1;if(!t.legend||!t.min||!t.max)return!1;if(t.aggregate&&t.aggregate.scale){var e="function"==typeof t.aggregate.scale?t.aggregate.scale.bind(this.maptable)():t.aggregate.scale;if("linear"!==e)return!1}return!0}},{key:"getAllMtMapCountry",value:function(){return this.allMtMapCountry?this.allMtMapCountry:(this.allMtMapCountry=d3.selectAll(this.containerSelector+" .mt-map-country"),this.allMtMapCountry)}},{key:"getAllMtMapMarker",value:function(){return this.allMtMapMarker?this.allMtMapMarker:(this.allMtMapMarker=d3.selectAll(this.containerSelector+" .mt-map-marker"),this.allMtMapMarker)}},{key:"updateCountries",value:function(){var t=this,e=new Map;this.maptable.data.forEach(function(a){var i=a[t.options.countryIdentifierKey];e.has(i)||e.set(i,[]),e.get(i).push(a)}),this.dataCountries.forEach(function(a){a.key=a.properties[t.options.countryIdentifierType];var i=e.get(a.key);a.values=i||[],a.attr={},a.rollupValue={}}),Object.keys(this.options.countries.attr).forEach(function(e){t.setAttrValues(e,t.options.countries.attr[e],t.dataCountries)});var a=this.getAllMtMapCountry().each(function(t){var e=d3.select(this);Object.keys(t.attr).forEach(function(a){e.attr(a,t.attr[a])})});Object.keys(this.options.countries.attr).forEach(function(e){var i=t.options.countries.attr[e];if("object"===("undefined"==typeof i?"undefined":E["typeof"](i))&&i.legend&&void 0!==t.legendCountry[e]){var n=d3.extent(t.dataCountries,function(t){return Number(t.attrProperties[e].value)});t.legendCountry[e].updateExtents(n),a.on("mouseover",function(a){t.legendCountry[e].indiceChange(a.attrProperties[e].value)}).on("mouseout",function(){t.legendCountry[e].indiceChange(NaN)})}}),this.options.countries&&this.options.countries.tooltip&&this.activateTooltip(a,this.tooltipCountriesNode,this.options.countries.tooltip,!0)}},{key:"updateNight",value:function(){var t=this.options.night.date||Date.UTC(),e=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),0,0,0),a=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),23,59,59),i=a-e,n=t-e,r=n/i;this.layerNight.node().style.transform="translateX("+-this.getWidth()*r+"px)"}},{key:"updateTimezones",value:function(){var t=document.querySelectorAll(".mt-map-timezone-text"),e=this.options.timezones.date||new Date;Array.from(t).forEach(function(t){t.textContent=A.formatDate(e,t.__data__.properties.zone)})}},{key:"updateMarkers",value:function(){var t=this,e=function(t){return t.longitude+","+t.latitude};this.dataMarkers=d3.nest().key(e).entries(this.maptable.data).filter(function(t){return 0!==t.values[0].x}),this.dataMarkers.forEach(function(t){t.attr={},t.attrProperties={}}),Object.keys(this.options.markers.attr).forEach(function(e){t.setAttrValues(e,t.options.markers.attr[e],t.dataMarkers)});var a=this.layerMarkers.selectAll(".mt-map-marker").data(this.dataMarkers),i=a.enter();i=this.options.markers.customTag?this.options.markers.customTag(i):i.append("svg:circle");var n=this.options.markers.className?this.options.markers.className:"";i.attr("class","mt-map-marker "+n),a.exit().transition().attr("r",0).attr("fill","#eee").style("opacity",0).remove();var r=this.options.markers.attrX?this.options.markers.attrX:"cx",s=this.options.markers.attrY?this.options.markers.attrY:"cy",o=this.options.markers.attrXDelta?this.options.markers.attrXDelta:0,l=this.options.markers.attrYDelta?this.options.markers.attrYDelta:0,h=a.attr(r,function(t){return t.values[0].x+o}).attr(s,function(t){return t.values[0].y+l});this.getAllMtMapMarker().each(function(t){var e=this;Object.keys(t.attr).forEach(function(a){d3.select(e).attr(a,t.attr[a])})}),this.options.markers.tooltip&&this.activateTooltip(h,this.tooltipMarkersNode,this.options.markers.tooltip,!1),this.rescale()}},{key:"fitContent",value:function(){if(0===this.maptable.data.length)return this.transX=0,this.transY=0,this.scale=1,void this.zoomListener.translate([this.transX,this.transY]).scale(this.scale);var t=d3.extent(this.maptable.data,function(t){return t.x}),e=d3.extent(this.maptable.data,function(t){return t.y}),a=this.getWidth()/this.getHeight(),i=20+(this.options.title?30:0),n=t[1]-t[0]+i,r=e[1]-e[0]+i,s=n/a,o=r*a,l=0,h=0;o>=n?l=(o-n)/2:h=(s-r)/2,t[0]-=this.options.fitContentMargin+l,t[1]+=this.options.fitContentMargin+l,e[0]-=this.options.fitContentMargin+h,e[1]+=this.options.fitContentMargin+h,this.scale=this.getWidth()/(t[1]-t[0]),this.transX=-1*t[0]*this.scale,this.transY=-1*e[0]*this.scale,this.zoomListener.translate([this.transX,this.transY]).scale(this.scale); -}},{key:"buildTitle",value:function(){var t=this.svg.append("svg").attr("width",this.getWidth()).attr("x",0).attr("y",this.getHeight()-30).attr("height",30);this.options.title.bgColor&&t.append("rect").attr("x",0).attr("y",0).attr("width",this.getWidth()).attr("height",30).attr("fill",this.options.title.bgColor),t.append("text").attr("id","mt-map-title").attr("x",20).attr("font-size",this.scaleFontSize(this.options.title.fontSize)).attr("font-family",this.options.title.fontFamily).attr("y",20),this.options.title.source&&t.append("text").attr("y",20).attr("x",this.getWidth()-20).attr("text-anchor","end").attr("font-size",this.scaleFontSize(this.options.title.fontSize)).attr("font-family",this.options.title.fontFamily).html(this.options.title.source())}},{key:"encodeTranslation",value:function(t){var e=t[0]/(this.scale*this.getWidth()),a=t[1]/(this.scale*this.getHeight());return[e,a]}},{key:"decodeTranslation",value:function(t){var e=t[0]*this.getWidth()*this.scale,a=t[1]*this.getHeight()*this.scale;return[e,a]}},{key:"restoreState",value:function(t){if(t&&3===t.length){this.scale=t[0];var e=this.decodeTranslation([t[1],t[2]]);this.transX=e[0],this.transY=e[1],this.zoomListener.scale(t[0]).translate(e).event(this.svg)}}},{key:"saveState",value:function(){var t=this.encodeTranslation([this.transX,this.transY]),e=[this.scale,t[0],t[1]];1!==e[0]&&0!==e[1]&&0!==e[2]?this.maptable.saveState("zoom",e):this.maptable.removeState("zoom")}},{key:"rescale",value:function(){var t=this;d3.event&&d3.event.translate&&(this.scale=d3.event.scale,this.transX=1===this.scale?0:d3.event.translate[0],this.transY=1===this.scale?0:d3.event.translate[1]);var e=0,a=0,i=this.getWidth()*(1-this.scale),n=this.getHeight()*(1-this.scale);this.transY>a?this.transY=a:this.transYe?this.transX=e:this.transXe?e:t},e[0])};else if("max"===s)e.rollup=function(t){if(!t.length)return 0;var e=t.map(function(t){return Number(t[r])});return e.reduce(function(t,e){return e>t?e:t},e[0])};else if(-1!==s.indexOf("percentile")){var l=A.toNumber(s);e.rollup=function(t){if(!t.length)return 0;var e=t.map(function(t){return Number(t[r])});return A.quantile(e,l)}}else"function"==typeof e.rollup&&(e.rollup=e.rollup.bind(this.maptable));n&&(-1!==n.indexOf("log")?o=d3.scale.log():-1!==n.indexOf("pow")?o=d3.scale.pow().exponent(A.toNumber(n)||1):"sqrt"===n&&(o=d3.scale.sqrt()))}if(e.rollup||(e.rollup=function(t){return t.length}),!e.min||!e.max)throw new Error("MapTable: You should provide values 'min' & 'max' for attr."+t);if(a.forEach(function(a){var o=e.rollup(a.values);if(a.attrProperties||(a.attrProperties={}),a.attrProperties[t]||(a.attrProperties[t]={}),a.attrProperties[t].value=o,r){a.attrProperties[t].key=r,a.attrProperties[t].mode=s,a.attrProperties[t].scale=n;var l=i.maptable.columnDetails[r];a.attrProperties[t].columnDetails=l;var h={};h[r]=o,a.attrProperties[t].formatted=l&&l.cellContent?l.cellContent.bind(i.maptable)(h):o}}),"rank"===n){var h=A.uniqueValues([0].concat(a.map(function(e){return Math.floor(100*e.attrProperties[t].value)/100}).filter(function(t){return t>0}))),p=A.uniqueValues(a.map(function(e){return Math.floor(100*e.attrProperties[t].value)/100}).filter(function(t){return 0>t}));h.sort(function(t,e){return t-e}),p.sort(function(t,e){return e-t}),a.forEach(function(e){if(0!==e.attrProperties[t].value){var a=e.attrProperties[t].value>=0?h:p,i=a.indexOf(Math.floor(100*e.attrProperties[t].value)/100),n=Math.round(i/a.length*100),r=e.attrProperties[t].value<0?n-2*n:n;e.attrProperties[t].value=r}})}var u=d3.extent(a,function(e){return Number(e.attrProperties[t].value)});0===u[0]&&n&&"-1"!==n.indexOf("log")&&(u=d3.extent(a.filter(function(e){return 0!==Number(e.attrProperties[t].value)}),function(e){return Number(e.attrProperties[t].value)})),e.transform&&(u[0]=e.transform.bind(this.maptable)(u[0],this.maptable.data),u[1]=e.transform.bind(this.maptable)(u[1],this.maptable.data));var d=e.min,c=e.max;if("minValue"===e.min&&(d=u[0]),"maxValue"===e.max&&(c=u[1]),e.maxNegative&&!e.minNegative||!e.maxNegative&&e.minNegative)throw new Error("MapTable: maxNegative or minNegative undefined. Please declare both.");var m=e.maxNegative&&e.minNegative,f=void 0,g=void 0;m?(f=o.copy().domain([0,u[1]]).range([d,c]),g=o.copy().domain([u[0],0]).range([e.maxNegative,e.minNegative])):f=o.domain(u).range([d,c]),a.forEach(function(a){var n=void 0;if(!a.values.length||Number.isNaN(a.attrProperties[t].value)){if("undefined"==typeof e.empty)throw new Error("MapTable: no empty property found for attr."+t);n=e.empty}else{var r=a.attrProperties[t].value,s=e.transform?e.transform.bind(i.maptable)(r,i.maptable.data):r;n=m&&0>s?g(s):f(s)}a.attr[t]=n})}}},{key:"render",value:function(){this.options.markers&&this.updateMarkers(),this.options.countries&&this.updateCountries(),this.options.night&&this.updateNight(),this.options.timezones&&this.updateTimezones(),this.options.title&&this.updateTitle(),this.options.heatmap&&this.updateHeatmap(),this.options.autoFitContent&&(this.fitContent(),this.rescale()),this.options.onRender&&this.options.onRender.constructor===Function&&this.options.onRender.bind(this.maptable)()}},{key:"updateTitle",value:function(){var t=this;if(this.options.title.content){var e=this.maptable.data.filter(function(e){return 0!==e[t.options.latitudeKey]}).length,a=this.maptable.rawData.filter(function(e){return 0!==e[t.options.latitudeKey]}).length,i="";this.maptable.filters&&(i=this.maptable.filters.getDescription()),this.container.querySelector("#mt-map-title").innerHTML=this.options.title.content.bind(this.maptable)(e,a,i,this.maptable.data,this.maptable.rawData,this.dataCountries)}}},{key:"activateTooltip",value:function(t,e,a,i){var n=this;t.on(i?"mousemove":"mouseover",function(t){var r=a.bind(this.maptable)(t);if(r){e.html(r).attr("style","display:block;position:fixed;");var s=void 0,o=void 0,l=e.node().offsetWidth/2;if(i){var h=n.node.getBoundingClientRect(),p=d3.mouse(n.svg.node()).map(function(t){return parseInt(t,10)});s=h.left+p[0]-l,o=h.top+p[1]+10}else{var u=this.getBoundingClientRect();s=u.left+u.width/2-l,o=u.top+u.height+2}e.attr("style","top:"+o+"px;left:"+s+"px;display:block;position:fixed;").on("mouseout",function(){e.style("display","none")})}}).on("mouseout",function(){e.style("display","none")})}},{key:"exportSvg",value:function(){var t=this.container.querySelector("#mt-map-svg"),e='\n'+(new XMLSerializer).serializeToString(t);if(this.options.exportSvgClient){if(!window.saveAs)throw new Error("MapTable: Missing FileSaver.js library");var a=new Blob([e],{type:"image/svg+xml"});window.saveAs(a,"visualization.svg")}else if(this.options.exportSvg){var i=this.node.querySelector("#mt-map-svg-form");i.querySelector('[name="data"]').value=e,i.submit()}}},{key:"addExportSvgCapability",value:function(){var t=document.createElement("div");t.setAttribute("id","mt-map-export"),this.container.querySelector("#mt-map").appendChild(t);var e=document.createElement("button");if(e.setAttribute("class","btn btn-xs btn-default"),e.innerHTML="Download",e.addEventListener("click",this.exportSvg.bind(this)),t.appendChild(e),this.options.exportSvg){var a=document.createElement("div");a.innerHTML='
',t.appendChild(a)}}}]),t}(),B=function(){function t(e,a){var i=this;if(E.classCallCheck(this,t),this.maptable=e,this.options=a,this.criteria=[],this.options.show){var n=this.options.show.filter(function(t){return Object.keys(i.maptable.columnDetails).indexOf(t)<0});if(n.length>0)throw new Error('MapTable: invalid columns "'+n.join(", ")+'"');this.activeColumns=this.options.show}else this.activeColumns=Object.keys(this.maptable.columnDetails);this.container=document.createElement("div"),this.maptable.node.appendChild(this.container),this.containerSelector=e.options.target,this.container=document.querySelector(e.options.target),this.node=this.container.querySelector("#mt-filters"),this.node||(this.node=document.createElement("div"),this.node.setAttribute("id","mt-filters"),this.node.setAttribute("class","panel panel-default"),this.maptable.node.appendChild(this.node));var r=document.createElement("div");r.setAttribute("class","panel-heading");var s=document.createElement("button");s.setAttribute("id","mt-filters-reset"),s.setAttribute("class","btn btn-default btn-xs pull-right"),s.style.display="none",s.style.marginLeft=5,s.innerText="↺ Reset",s.addEventListener("click",this.reset),r.appendChild(s);var o=document.createElement("h3");o.setAttribute("class","panel-title"),o.appendChild(document.createTextNode("Filters")),r.appendChild(o),this.node.appendChild(r);var l=document.createElement("div");l.setAttribute("id","mt-filters-content"),l.setAttribute("class","panel-body");var h=document.createElement("div");h.setAttribute("id","mt-filters-elements"),l.appendChild(h);var p=document.createElement("a");p.setAttribute("id","mt-filters-new"),p.setAttribute("href","#"),p.innerText="+ New filter",p.addEventListener("click",this.add.bind(this)),l.appendChild(p),this.node.appendChild(l)}return E.createClass(t,[{key:"add",value:function(t){t&&t.preventDefault();var e=this.getPossibleFilters();if(0!==e.length){var a=e[0].key;this.create(a)}}},{key:"create",value:function(t,e){var a=this.buildRow(t);e?e.parentNode.replaceChild(a,e):this.node.querySelector("#mt-filters-elements").appendChild(a),this.criteria.push(t),this.maptable.render(),"none"===this.container.style.display&&this.toggle()}},{key:"remove",value:function(t){var e=this.node.querySelector('[data-mt-filter-name="'+t+'"]');e&&e.parentNode.removeChild(e);var a=this.criteria.indexOf(t);this.criteria.splice(a,1),this.maptable.render()}},{key:"reset",value:function(){for(var t=this.node.querySelectorAll("[data-mt-filter-name]"),e=0;e and\n '+h+""}else{var p=i.querySelector(".mt-filter-value-min").value;if(""===p)continue;s+=r.title+" is ",s+=o.options[o.selectedIndex].text,s+=''+p+""}}else if("field"===r.filterMethod||"dropdown"===r.filterMethod){var u=i.querySelector(".mt-filter-value").value;if(""===u)continue;var d="field"===r.filterMethod?"contains":"is";s+=r.title+" "+d+'\n '+u+""}t.push(s)}return t.join(", ")}},{key:"buildRow",value:function(t){var e=this,a=this,i=this.getPossibleFilters(),n=this.maptable.columnDetails[t],r=document.createElement("div");r.setAttribute("class","mt-filter-row"),r.setAttribute("data-mt-filter-name",t);var s=document.createElement("button");s.setAttribute("class","btn btn-default pull-right"),s.setAttribute("data-mt-filter-btn-minus",1),s.innerText="– Remove this filter",s.addEventListener("click",function(){t=r.querySelector(".mt-filter-name").value,e.remove(t)}),r.appendChild(s);var o=document.createElement("span");o.setAttribute("class","mt-filters-and"),o.innerText="And ",r.appendChild(o);var l=document.createElement("select");l.setAttribute("class","mt-filter-name form-control form-control-inline"),A.appendOptions(l,i.map(function(t){return{text:t.title,value:t.key}})),l.value=t,l.addEventListener("change",function(){var t=this.parentNode.getAttribute("data-mt-filter-name"),e=this.value;a.create(e,this.parentNode),a.remove(t),a.refresh()}),r.appendChild(l);var h=document.createElement("span");h.innerText="field"===n.filterMethod?" contains ":" is ",r.appendChild(h);var p=null;"field"!==n.filterMethod&&"dropdown"!==n.filterMethod&&(p=document.createElement("select"),p.setAttribute("class","mt-filter-range form-control form-control-inline"),A.appendOptions(p,["any","=","≠","<",">","≤","≥","BETWEEN"].map(function(t){return{text:t,value:t}})),p.addEventListener("change",function(){a.handleRangeChange(this)}),r.appendChild(p),r.appendChild(document.createTextNode(" ")));var u=document.createElement("div");if(u.style.display="inline-block",u.setAttribute("class","mt-filter-value-container"),"compare"===n.filterMethod)["min","max"].forEach(function(t,a){var i=document.createElement("input");if(i.setAttribute("class","form-control form-control-inline mt-filter-value-"+t),i.setAttribute("type",n.filterInputType),i.addEventListener("keyup",e.maptable.render.bind(e.maptable)),i.addEventListener("change",e.maptable.render.bind(e.maptable)),u.appendChild(i),0===a){var r=document.createElement("span");r.setAttribute("class","mt-filter-value-and"),r.innerText=" and ",u.appendChild(r)}});else if("field"===n.filterMethod){var d=document.createElement("input");d.setAttribute("class","form-control form-control-inline mt-filter-value"),d.setAttribute("type","text"),d.addEventListener("keyup",this.maptable.render.bind(this.maptable)),d.addEventListener("change",this.maptable.render.bind(this.maptable)),u.appendChild(d)}else if("dropdown"===n.filterMethod){var c=document.createElement("select");c.setAttribute("class","form-control form-control-inline mt-filter-value");var m=d3.nest().key(function(e){return e[t]}).sortKeys(d3.ascending).entries(this.maptable.rawData);A.appendOptions(c,[{text:"Any",value:""}].concat(m.map(function(t){return{text:t.key,value:t.key}}))),c.addEventListener("change",this.maptable.render.bind(this.maptable)),u.appendChild(c)}return r.appendChild(u),p&&this.handleRangeChange(p),r}},{key:"handleRangeChange",value:function(t){var e=t.parentNode;"any"===t.value?e.querySelector(".mt-filter-value-container").style.display="none":(e.querySelector(".mt-filter-value-container").style.display="inline-block","BETWEEN"===t.value?(e.querySelector(".mt-filter-value-min").style.display="inline-block",e.querySelector(".mt-filter-value-and").style.display="inline-block",e.querySelector(".mt-filter-value-max").style.display="inline-block"):(e.querySelector(".mt-filter-value-min").style.display="inline-block",e.querySelector(".mt-filter-value-and").style.display="none",e.querySelector(".mt-filter-value-max").style.display="none")),this.maptable.render.bind(this.maptable)()}},{key:"getPossibleFilters",value:function(t){var e=this;return Object.keys(this.maptable.columnDetails).map(function(t){return A.extendRecursive({key:t},e.maptable.columnDetails[t])}).filter(function(a){return-1!==e.activeColumns.indexOf(a.key)&&(t&&t===a.key||-1===e.criteria.indexOf(a.key)&&a.filterMethod&&!a.isVirtual)})}},{key:"filterData",value:function(){var t=this,e=this;this.maptable.data=this.maptable.rawData.filter(function(a){for(var i=t.node.querySelectorAll(".mt-filter-row"),n=!0,r=0;rh(m))?n=!1:(parseInt(a[o],10)parseInt(m,10))&&(n=!1)}else{var f=s.querySelector(".mt-filter-value-min").value;if(""===f)continue;h&&!A.rangeToBool(h(a[o]),d,h(f))?n=!1:h||A.rangeToBool(a[o],d,f)||(n=!1)}}(h&&A.isBlank(h(a[o]))||A.isBlank(a[o]))&&(n=!1)}return n}),this.options.saveState&&this.maptable.saveState("filters",this.exportFilters())}},{key:"refresh",value:function(){for(var t=this.node.querySelectorAll(".mt-filter-name"),e=0;e0&&(this.node.querySelectorAll(".mt-filters-and")[0].style.visibility="hidden");var r=!this.getPossibleFilters().length;this.node.querySelector("#mt-filters-new").style.visibility=r?"hidden":"visible"}},{key:"toggle",value:function(){"none"===this.container.style.display?(this.container.style.display="block",0===this.criteria.length&&this.add()):this.container.style.display="none"}}]),t}(),R=function(){function t(e,a){var i=this;if(E.classCallCheck(this,t),this.maptable=e,this.options=a,this.options.defaultSorting?(Array.isArray(this.options.defaultSorting)&&2===this.options.defaultSorting.length?this.sorting=this.options.defaultSorting:this.sorting=[this.options.defaultSorting],this.sorting.forEach(function(t){t.mode||(t.mode="asc")})):this.sorting=[{key:Object.keys(this.maptable.data[0])[0],mode:"asc"}],this.initialSorting=this.sorting.map(function(t){return t.key+","+t.mode}).join(";"),this.isSorting=!1,this.containerSelector=e.options.target,this.container=document.querySelector(e.options.target),this.node=this.container.querySelector("#mt-table"),this.node||(this.node=document.createElement("div"),this.node.setAttribute("id","mt-table"),this.maptable.node.appendChild(this.node)),this.node=d3.select(this.node).append("table").attr("class",this.options.className),this.header=this.node.append("thead"),this.body=this.node.append("tbody"),this.options.show){var n=this.options.show.filter(function(t){return Object.keys(i.maptable.columnDetails).indexOf(t)<0});if(n.length>0)throw new Error('MapTable: invalid columns "'+n.join(", ")+'"');this.activeColumns=this.options.show}else this.activeColumns=Object.keys(this.maptable.columnDetails);this.options.header&&(this.options.header.className&&this.header.attr("class",""+this.options.header.className),this.options.header.top?this.header.attr("style","top:"+(this.options.header.top||"0")+"px;"):this.header.attr("style","top:0px;")),this.header.selectAll("tr").data([1]).enter().append("tr").selectAll("th").data(this.activeColumns.map(function(t){return A.extendRecursive({key:t},i.maptable.columnDetails[t])})).enter().append("th").attr("class",function(t){var e=t.sorting?"mt-table-sortable":"";return e+=t.nowrap?" nowrap":""}).attr("data-key",function(t){return A.sanitizeKey(t.key)}).attr("onselectstart","return false;").attr("unselectable","on").attr("style",function(t){return t.nowrap?"white-space:nowrap;":""}).on("click",function(t){i.isSorting||(i.isSorting=!0,t.sorting&&i.sortColumn(t.key),i.isSorting=!1)}).text(function(t){return t.title}).attr("id",function(t){return"column_header_"+A.sanitizeKey(t.key)})}return E.createClass(t,[{key:"restoreState",value:function(t){if(t){var e=t.split(";"),a=[];e.forEach(function(t){var e=t.split(",");a.push({key:e[0],mode:e[1]||"asc"})}),this.sorting=a}}},{key:"saveState",value:function(){var t=this.sorting.map(function(t){return t.key+","+t.mode}).join(";");t!==this.initialSorting&&this.maptable.saveState("sort",t)}},{key:"render",value:function(){var t=this;this.applySort();var e=this.maptable.data;this.options.distinctBy&&(e=d3.nest().key(function(e){return e[t.options.distinctBy]}).entries(this.maptable.data).map(function(t){return t.values[0]})),this.body.selectAll("tr").data(e).enter().append("tr"),this.body.selectAll("tr").data(e).exit().remove();var a=[];this.body.selectAll("tr").data(e).attr("class",function(e){return t.options.rowClassName?"line "+t.options.rowClassName(e):"line"}).html(function(e){var i="";return t.activeColumns.forEach(function(n){var r=t.maptable.columnDetails[n];i+=""}),i}),this.options.onRender&&this.options.onRender.constructor===Function&&this.options.onRender.bind(this.maptable)()}},{key:"applySort",value:function(){for(var t=this,e=this.container.querySelectorAll(".mt-table-sortable"),a=0;a0;if(this.options.map.heatmap&&n)return i.innerHTML='
The heatmap feature is not supported with Internet Explorer.
Please use another modern browser to see this map.
',this.node.insertBefore(i,this.node.firstChild),i.querySelector(".mt-loading").style.display="block",this.options.map=!1,void this.buildComponenents();if(i.innerHTML='
Loading...
',this.node.insertBefore(i,this.node.firstChild),i.querySelector(".mt-loading").style.display="block",this.options.map.pathData)this.loadMapData(null,JSON.parse(this.options.map.pathData),i);else{if(!this.options.map.path)throw new Error("missing map path|pathData");d3.json(this.options.map.path,function(t,e){a.loadMapData(t,e,i)})}}else this.buildComponenents()}},{key:"loadMapData",value:function(t,e,a){if(t)throw t;this.map=new L(this,this.options.map,e),a.querySelector(".mt-loading").style.display="none",this.buildComponenents()}},{key:"buildComponenents",value:function(){var t=this;this.options.filters&&(this.filters=new B(this,this.options.filters)),this.options.table&&(this.table=new R(this,this.options.table)),this.restoreState(),window.addEventListener("hashchange",function(){t.restoreState()}),this.render()}},{key:"loadState",value:function(t,e){if(e){var a=this.parseState(t);if(!a)return null;try{var i=JSON.parse(a);this.state[t]=i}catch(n){return console.log("Maptable: Invalid URL State for mt-"+t+" "+n.message),null}}else{var r=this.parseState(t);r&&(this.state[t]=r)}return this.state[t]}},{key:"restoreState",value:function(){this.map&&(this.loadState("zoom",!0),this.map.restoreState(this.state.zoom)),this.filters&&(this.loadState("filters",!0),this.filters.restoreState(this.state.filters)),this.table&&(this.loadState("sort",!1),this.table.restoreState(this.state.sort))}},{key:"parseState",value:function(t){var e=document.location.href.replace(/%21mt/g,"!mt").split("!mt-"+t+"=");return e[1]?decodeURIComponent(e[1].split("!mt")[0]):null}},{key:"removeState",value:function(t){window.clearTimeout(this.saveStateTimeout[t]),delete this.state[t],this.updateState()}},{key:"saveState",value:function(t,e){var a=this;window.clearTimeout(this.saveStateTimeout[t]),this.saveStateTimeout[t]=window.setTimeout(function(){a.state[t]=e,a.updateState()},200)}},{key:"updateState",value:function(){var t=this,e=document.location.href.split("#")[0],a="";Object.keys(this.state).forEach(function(e){if(t.state[e]){var i=t.state[e];if("object"===E["typeof"](t.state[e])){if(!Object.keys(t.state[e]).length)return;i=JSON.stringify(t.state[e])}a+="!mt-"+e+"="+encodeURIComponent(i)}}),""!==a&&(a="#"+a),document.location.href!==""+e+a&&window.history.pushState(null,null,""+e+a)}},{key:"render",value:function(){this.filters&&(this.filters.filterData(),this.filters.refresh()),this.map&&(this.map.render(),!this.firstExecution&&this.options.map.onComplete&&this.options.map.onComplete.constructor===Function&&this.options.map.onComplete.bind(this)()),this.table&&(this.table.render(),!this.firstExecution&&this.options.table.onComplete&&this.options.table.onComplete.constructor===Function&&this.options.table.onComplete.bind(this)()),!this.firstExecution&&this.options.onComplete&&this.options.onComplete.constructor===Function&&this.options.onComplete.bind(this)(),this.firstExecution=!0}},{key:"setColumnDetails",value:function(){var t=this;if(0!==t.rawData.length){var e={};Object.keys(t.rawData[0]).forEach(function(a){var i=/^[-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?$/,n=i.test(t.rawData[0][a]);e[a]={title:A.keyToTile(a),filterMethod:n?"compare":"field",filterInputType:n?"number":"text",sorting:!0},n&&(e[a].dataParse=function(t){return parseFloat(t)})}),t.columnDetails=A.extendRecursive(e,this.options.columns),Object.keys(t.columnDetails).forEach(function(e){t.columnDetails[e].isVirtual="function"==typeof t.columnDetails[e].virtual})}}}]),t}();if(d3.maptable=function(t){var e=void 0,a={},i={target:t,columns:{},data:{},map:null,filters:null,table:null};return a.map=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(!topojson)throw new Error("Maptable requires topojson.js");if("string"!=typeof t.path&&"string"!=typeof t.pathData)throw new Error("MapTable: map not provided");return i.map=t,a},a.data=function(t){return i.data.type="data",i.data.value=t,a},a.json=function(t,e){return i.data.type="json",i.data.path=t,i.data.preFilter=e,a},a.jsonData=function(t){return i.data.type="jsonData",i.data.value=t,a},a.csv=function(t,e){return i.data.type="csv",i.data.path=t,i.data.preFilter=e,a},a.csvData=function(t){return i.data.type="csvData",i.data.value=t,a},a.tsv=function(t,e){return i.data.type="tsv",i.data.path=t,i.data.preFilter=e,a},a.tsvData=function(t){return i.data.type="tsvData",i.data.value=t,a},a.filters=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.filters=t,a},a.table=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.table=t,a},a.columns=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.columns=t, -a},a.render=function(a){if("string"!=typeof t||!document.querySelector(t))throw new Error("MapTable: target not found");if(!i.data||!i.data.type)throw new Error("MapTable: Please provide the path for your dataset data|json|jsonData|csv|csvData|tsv|tsvData");i.map&&!i.map.heatmap&&(i.map.heatmap=null),i.map&&i.map.markers===!1&&(i.map.markers=null),i.map&&i.map.countries===!1&&(i.map.countries=null),i.filters||(i.filters=null),i.onComplete=a;var n=A.extendRecursive(z,i);return i.map&&!i.map.markers&&delete n.map.markers,i.map&&!i.map.heatmap&&delete n.map.heatmap,i.map&&!i.map.title&&delete n.map.title,i.map&&!i.map.timezones&&delete n.map.timezones,i.map&&!i.map.night&&delete n.map.night,i.filters||delete n.filters,i.table||delete n.table,e=new G(t,n),{render:function(){return e.render()},loadState:function(t,a){return e.loadState(t,a)},removeState:function(t){return e.removeState(t)},saveState:function(t,a){return e.saveState(t,a)},setTitleContent:function(t){e.options.map.title.content=function(){return t}},setData:function(t){e.options.data.type="data",e.options.data.value=t,e.options.rawData=t,e.rawData=t,e.data=t,e.map&&e.map.enrichData()},setNightDate:function(t){e.options.map.night.date=t},setTimezonesDate:function(t){e.options.map.timezones.date=t},getMapWidth:function(){return e.map.getWidth()},getMapHeight:function(){return e.map.getHeight()}}},a},!d3)throw new Error("Maptable requires d3.js");var Y=d3.maptable;return Y}(); \ No newline at end of file +this.d3=this.d3||{},this.d3.maptable=function(){"use strict";function t(t,e,a){e.forEach(function(e){var a=document.createElement("option");a.setAttribute("value",e.value),a.innerText=e.text,t.appendChild(a)}),t.value=a}function e(t,e,a){return"="===e?parseInt(t,10)===parseInt(a,10):"≠"===e?parseInt(t,10)!==parseInt(a,10)&&""!==t&&""!==a:">"===e?parseInt(t,10)>parseInt(a,10)&&""!==t&&""!==a:"<"===e?parseInt(t,10)=parseInt(a,10)&&""!==t&&""!==a:"≤"===e?parseInt(t,10)<=parseInt(a,10)&&""!==t&&""!==a:!0}function a(){for(var t={},e=void 0,i=[].splice.call(arguments,0),n={}.toString;i.length>0;)e=i.splice(0,1)[0],"[object Object]"===n.call(e)&&Object.keys(e).forEach(function(i){"[object Object]"===n.call(e[i])?t[i]=a(t[i]||{},e[i]):t[i]=e[i]});return t}function i(t){var e=t.charAt(0).toUpperCase()+t.slice(1);return e.replace(/_/g," ")}function n(t){return t.toLowerCase().replace(/ /g,"_").replace(/"/g,"").replace(/'/g,"")}function r(t){if(!t||""===t)return null;var e=t.toString().replace(/[^0-9.]+|\s+/gim,"");return""!==e?Number(e):null}function s(t,e){t.sort(function(t,e){return t-e});var a=e/100*(t.length-1),i=void 0;if(Math.floor(a)===a)i=t[a];else{var n=Math.floor(a),r=a-n;i=t[n]+(t[n+1]-t[n])*r}return i}function o(t){if(!t)return t;for(var e=[],a=0,i=t.length;i>a;a+=1)-1===e.indexOf(t[a])&&""!==t[a]&&e.push(t[a]);return e}function l(t,e,a,i){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLImageElement&&!t instanceof HTMLImageElement)return;var n=t.naturalWidth,r=t.naturalHeight;if("string"==typeof e)var e=document.getElementById(e);else if("undefined"!=typeof HTMLCanvasElement&&!e instanceof HTMLCanvasElement)return;e.style.width=n+"px",e.style.height=r+"px",e.width=n,e.height=r;var s=e.getContext("2d");s.clearRect(0,0,n,r),s.drawImage(t,0,0),Number.isNaN(a)||1>a||(i?p(e,0,0,n,r,a):d(e,0,0,n,r,a))}function h(t,e,a,i,n){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLCanvasElement&&!t instanceof HTMLCanvasElement)return;var r,s=t.getContext("2d");try{try{r=s.getImageData(e,a,i,n)}catch(o){throw new Error("unable to access local image data: "+o)}}catch(o){throw new Error("unable to access image data: "+o)}return r}function p(t,e,a,i,n,r){if(!(Number.isNaN(r)||1>r)){r|=0;var s=h(t,e,a,i,n);s=u(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function u(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,E,N,T,D,A,z=t.data,j=r+r+1,F=i-1,q=n-1,W=r+1,O=W*(W+1)/2,P=new m,L=P;for(l=1;j>l;l++)if(L=L.next=new m,l==W)var B=L;L.next=P;var R=null,G=null;d=u=0;var Y=H[r],U=I[r];for(o=0;n>o;o++){for(w=C=S=M=c=f=g=v=0,y=W*(E=z[u]),b=W*(N=z[u+1]),k=W*(T=z[u+2]),x=W*(D=z[u+3]),c+=O*E,f+=O*N,g+=O*T,v+=O*D,L=P,l=0;W>l;l++)L.r=E,L.g=N,L.b=T,L.a=D,L=L.next;for(l=1;W>l;l++)h=u+((l>F?F:l)<<2),c+=(L.r=E=z[h])*(A=W-l),f+=(L.g=N=z[h+1])*A,g+=(L.b=T=z[h+2])*A,v+=(L.a=D=z[h+3])*A,w+=E,C+=N,S+=T,M+=D,L=L.next;for(R=P,G=B,s=0;i>s;s++)z[u+3]=D=v*Y>>U,0!=D?(D=255/D,z[u]=(c*Y>>U)*D,z[u+1]=(f*Y>>U)*D,z[u+2]=(g*Y>>U)*D):z[u]=z[u+1]=z[u+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=d+((h=s+r+1)s;s++){for(C=S=M=w=f=g=v=c=0,u=s<<2,y=W*(E=z[u]),b=W*(N=z[u+1]),k=W*(T=z[u+2]),x=W*(D=z[u+3]),c+=O*E,f+=O*N,g+=O*T,v+=O*D,L=P,l=0;W>l;l++)L.r=E,L.g=N,L.b=T,L.a=D,L=L.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(L.r=E=z[u])*(A=W-l),f+=(L.g=N=z[u+1])*A,g+=(L.b=T=z[u+2])*A,v+=(L.a=D=z[u+3])*A,w+=E,C+=N,S+=T,M+=D,L=L.next,q>l&&(p+=i);for(u=s,R=P,G=B,o=0;n>o;o++)h=u<<2,z[h+3]=D=v*Y>>U,D>0?(D=255/D,z[h]=(c*Y>>U)*D,z[h+1]=(f*Y>>U)*D,z[h+2]=(g*Y>>U)*D):z[h]=z[h+1]=z[h+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=s+((h=o+W)r)){r|=0;var s=h(t,e,a,i,n);s=c(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function c(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,E,N=t.data,T=r+r+1,D=i-1,A=n-1,z=r+1,j=z*(z+1)/2,F=new m,q=F;for(l=1;T>l;l++)if(q=q.next=new m,l==z)var W=q;q.next=F;var O=null,P=null;d=u=0;var L=H[r],B=I[r];for(o=0;n>o;o++){for(k=x=w=c=f=g=0,v=z*(C=N[u]),y=z*(S=N[u+1]),b=z*(M=N[u+2]),c+=j*C,f+=j*S,g+=j*M,q=F,l=0;z>l;l++)q.r=C,q.g=S,q.b=M,q=q.next;for(l=1;z>l;l++)h=u+((l>D?D:l)<<2),c+=(q.r=C=N[h])*(E=z-l),f+=(q.g=S=N[h+1])*E,g+=(q.b=M=N[h+2])*E,k+=C,x+=S,w+=M,q=q.next;for(O=F,P=W,s=0;i>s;s++)N[u]=c*L>>B,N[u+1]=f*L>>B,N[u+2]=g*L>>B,c-=v,f-=y,g-=b,v-=O.r,y-=O.g,b-=O.b,h=d+((h=s+r+1)s;s++){for(x=w=k=f=g=c=0,u=s<<2,v=z*(C=N[u]),y=z*(S=N[u+1]),b=z*(M=N[u+2]),c+=j*C,f+=j*S,g+=j*M,q=F,l=0;z>l;l++)q.r=C,q.g=S,q.b=M,q=q.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(q.r=C=N[u])*(E=z-l),f+=(q.g=S=N[u+1])*E,g+=(q.b=M=N[u+2])*E,k+=C,x+=S,w+=M,q=q.next,A>l&&(p+=i);for(u=s,O=F,P=W,o=0;n>o;o++)h=u<<2,N[h]=c*L>>B,N[h+1]=f*L>>B,N[h+2]=g*L>>B,c-=v,f-=y,g-=b,v-=O.r,y-=O.g,b-=O.b,h=s+((h=o+z)e?e+360:e)/180*L}function v(t){var e=f(t);return(Math.sin(e)*(1.914602-t*(.004817+14e-6*t))+Math.sin(e+e)*(.019993-101e-6*t)+289e-6*Math.sin(e+e+e))*B}function y(t){return g(t)+v(t)}function b(t){return y(t)-(.00569+.00478*Math.sin((125.04-1934.136*t)*B))*B}function k(t){return(23+(26+(21.448-t*(46.815+t*(59e-5-.001813*t)))/60)/60)*B}function x(t){return k(t)+.00256*Math.cos((125.04-1934.136*t)*B)*B}function w(t){return Math.asin(Math.sin(x(t))*Math.sin(b(t)))}function C(t){return.016708634-t*(42037e-9+1.267e-7*t)}function S(t){var e=C(t),a=f(t),i=g(t),n=Math.tan(x(t)/2);return n*=n,n*Math.sin(2*i)-2*e*Math.sin(a)+4*e*n*Math.sin(a)*Math.cos(2*i)-.5*n*n*Math.sin(4*i)-1.25*e*e*Math.sin(2*a)}function M(t){return[t[0]+180,-t[1]]}function E(t){var e=(t-Date.UTC(2e3,0,1,12))/864e5/36525,a=(d3.time.day.utc.floor(t)-t)/864e5*360-180;return[a-S(e)*R,w(e)*R]}var N={};N["typeof"]="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},N.classCallCheck=function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")},N.createClass=function(){function t(t,e){for(var a=0;a\n \n \n \n \n \n '),this.options.timezones&&(this.layerTimezones=this.layerGlobal.append("g").attr("class","mt-map-timezones")),this.layerCountries=this.layerGlobal.append("g").attr("class","mt-map-countries"),this.options.night&&(this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night")),this.options.heatmap&&(this.layerHeatmap=this.layerGlobal.append("g").attr("class","mt-map-heatmap")),this.layerMarkers=this.layerGlobal.append("g").attr("class","mt-map-markers"),this.options.watermark&&(this.watermark=new O(this,this.options.watermark)),this.options.title&&this.buildTitle(),(this.options.exportSvgClient||this.options.exportSvg)&&this.addExportSvgCapability(),this.options.width||window.addEventListener("resize",function(){n.svg.attr("width",n.getWidth()),n.svg.attr("height",n.getHeight()),n.rescale()}),this.loadGeometries()}return N.createClass(t,[{key:"enrichData",value:function(){var t=this;this.maptable.rawData.forEach(function(e){e.longitude=parseFloat(e[t.options.longitudeKey]),e.latitude=parseFloat(e[t.options.latitudeKey]);var a=[0,0];Number.isNaN(e.longitude)||Number.isNaN(e.latitude)||(a=t.projection([e.longitude,e.latitude])),e.x=a[0],e.y=a[1]})}},{key:"scaleAttributes",value:function(){return Math.pow(this.scale,2/3)}},{key:"getWidth",value:function(){return this.options.width?this.options.width:(this.options.width=this.node.offsetWidth,this.node.offsetWidth)}},{key:"getHeight",value:function(){var t=this.options.title?30:0;return!this.options.height&&this.options.ratioFromWidth?this.getWidth()*this.options.ratioFromWidth*this.options.scaleHeight+t:this.options.height*this.options.scaleHeight+t}},{key:"loadGeometries",value:function(){this.options.filterCountries&&(this.jsonWorld.objects.countries.geometries=this.jsonWorld.objects.countries.geometries.filter(this.options.filterCountries)),this.options.countries&&this.buildCountries(),this.options.heatmap&&this.buildHeatmap(),this.options.night&&this.buildNight(),this.options.timezones&&(this.options.timezones.path||this.options.timezones.pathData)&&this.buildTimezone()}},{key:"buildHeatmap",value:function(){var t=topojson.merge(this.jsonWorld,this.jsonWorld.objects.countries.geometries);if(this.options.heatmap.disableMask||(this.maskHeatmap=this.layerHeatmap.append("defs").append("clipPath").attr("id","mt-map-heatmap-mask"),this.maskHeatmap.datum(t).append("path").attr("class","mt-map-heatmap-mask-paths").attr("d",this.path)),this.imgHeatmap=this.layerHeatmap.append("image").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("x",0).attr("y",0).attr("class","mt-map-heatmap-img"),this.options.heatmap.mask&&(this.imgHeatmap=this.imgHeatmap.attr("clip-path","url(#mt-map-heatmap-mask)")),this.options.heatmap.borders){var e=topojson.mesh(this.jsonWorld,this.jsonWorld.objects.countries,function(t,e){return t!==e});this.bordersHeatmap=this.layerHeatmap.append("g").attr("class","mt-map-heatmap-borders"),this.bordersHeatmap.selectAll("path.mt-map-heatmap-borders-paths").data([t,e]).enter().append("path").attr("class","mt-map-heatmap-borders-paths").attr("fill","none").attr("stroke-width",this.options.heatmap.borders.stroke).attr("stroke",this.options.heatmap.borders.color).attr("style","opacity: "+this.options.heatmap.borders.opacity).attr("d",this.path)}}},{key:"buildNight",value:function(){this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night");var t=d3.geo.circle().angle(90);this.maskNight=this.layerNight.append("defs").append("clipPath").attr("id","mt-map-night-mask"),this.maskNight.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.nightPath=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.path).style("opacity",.1);var e=this.options.night.date||Date.UTC(),a=Date.UTC(e.getUTCFullYear(),e.getUTCMonth(),e.getUTCDate(),0,0,0),i=E(new Date(a));if(this.nightPath.datum(t.origin(M(i))).attr("d",this.path),this.nightPathRight=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+this.getWidth()+"px,0,0)"),this.nightPathLeft=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+-this.getWidth()+"px,0,0)"),!this.options.night.disableSun){var n=this.projection(i);this.sunCircleRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]+this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]-this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]-2*this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight())}}},{key:"buildTimezone",value:function(){var t=this;this.options.timezones.pathData?this.loadTimezone(null,JSON.parse(this.options.timezones.pathData)):this.options.timezones.path&&d3.json(this.options.timezones.path,function(e,a){t.loadTimezone(e,a)})}},{key:"scaleFontSize",value:function(t){return this.getWidth()<700?t*(this.getWidth()/700):t}},{key:"loadTimezone",value:function(t,e){var a=this;this.dataTimezones=topojson.feature(e,e.objects.timezones).features,this.maskTimezone=this.layerTimezones.append("defs").append("clipPath").attr("id","mt-map-timezone-mask"),this.maskTimezone.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.layerTimezones.selectAll(".mt-map-timezone").data(this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places})).enter().insert("path").attr("class","mt-map-timezone").attr("d",this.path).attr("fill",function(t){return t.properties.zone%2===0?"#F4F5F5":"transparent"}).attr("title",function(t){return JSON.stringify(t.properties)}).attr("clip-path","url(#mt-map-timezone-mask)").style("opacity",.6);var i=this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places&&t.properties.zone%1===0&&14!==t.properties.zone}),n=[].concat(N.toConsumableArray(new Map(i.map(function(t){return[t.properties.zone,t]})).values()));this.layerTimezonesText=this.layerTimezones.append("g").attr("class","mt-map-timezones-texts"),this.layerTimezonesText.selectAll(".mt-map-timezone-text").data(n).enter().insert("text").attr("class","mt-map-timezone-text").attr("y",.82*this.getHeight()-5).attr("x",function(t){return(t.properties.zone+10)*(a.getWidth()/24.5)-1}).attr("dx",this.getWidth()/24.5/2).attr("font-size",this.scaleFontSize(9)).attr("font-family","Helevetica, Arial, Sans-Serif").attr("fill","#999").attr("text-anchor","middle").html(function(t){return F.formatDate(a.options.timezones.date||new Date,t.properties.zone)})}},{key:"getMagnitudeScale",value:function(t){var e=this.options.heatmap,a=t.length;if(!a)return function(){return 0};var i=d3.scale.linear().domain([1,a]).range([1,.25]),n=i(a),r=d3.scale.linear().domain([e.circles.min,20]).range([n,0]);return function(t){return r(t)}}},{key:"getDatumScale",value:function(){var t=this;if(!this.options.heatmap.weightByAttribute)return function(){return 1};var e=d3.extent(this.maptable.data,this.options.heatmap.weightByAttribute),a="log"===this.options.heatmap.weightByAttributeScale?d3.scale.log:d3.scale.linear,i=a().domain(e).range([.5,1]);return function(e){var a=t.options.heatmap.weightByAttribute(e);return a?i(a):0}}},{key:"getHeatmapData",value:function(){var t=this,e=d3.select(this.node).append("canvas").attr("id","mt-map-heatmap-canvas").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("style","display: none;"),a=e.node().getContext("2d");a.globalCompositeOperation="multiply";var i=d3.range(this.options.heatmap.circles.min,this.options.heatmap.circles.max,this.options.heatmap.circles.step),n=this.getDatumScale(),r=this.maptable.data.filter(function(t){return n(t)>.1}),s=this.path.context(a),o=this.getMagnitudeScale(r),l=d3.scale.linear().domain([1,0]).range(["#000000","#FFFFFF"]);a.beginPath(),a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle="#ffffff",a.fill(),a.closePath();var h=function(e){var a=t.options.heatmap.circles.colorStrength,i=1+(a-1)/100;return a>1?(2-i)*e+i-1:a*e};r.forEach(function(t){var e=n(t);i.forEach(function(i){var n=h(o(i)*e);n>0&&(a.beginPath(),s(d3.geo.circle().origin([t.longitude,t.latitude]).angle(i-1e-4)()),a.fillStyle=l(n),a.fill(),a.closePath())})}),P.canvasRGBA(e.node(),0,0,this.getWidth(),this.getHeight(),this.options.heatmap.circles.blur),a.beginPath(),a.globalCompositeOperation="screen",a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle=this.options.heatmap.circles.color,a.fill(),a.closePath();var p=e.node().toDataURL();return e.remove(),p}},{key:"updateHeatmap",value:function(){var t=this.getHeatmapData();this.imgHeatmap.attr("xlink:href",t)}},{key:"buildCountries",value:function(){this.dataCountries=topojson.feature(this.jsonWorld,this.jsonWorld.objects.countries).features,this.layerCountries.selectAll(".mt-map-country").data(this.dataCountries).enter().insert("path").attr("class","mt-map-country").attr("d",this.path),this.legendCountry={},this.shouldRenderLegend()&&(this.legendCountry.fill=new W(this))}},{key:"shouldRenderLegend",value:function(){var t=this.options.countries.attr.fill;if(!t)return!1;if(!t.legend||!t.min||!t.max)return!1;if(t.aggregate&&t.aggregate.scale){var e="function"==typeof t.aggregate.scale?t.aggregate.scale.bind(this.maptable)():t.aggregate.scale;if("linear"!==e)return!1}return!0}},{key:"getAllMtMapCountry",value:function(){return this.allMtMapCountry?this.allMtMapCountry:(this.allMtMapCountry=d3.selectAll(this.containerSelector+" .mt-map-country"),this.allMtMapCountry)}},{key:"getAllMtMapMarker",value:function(){return this.allMtMapMarker?this.allMtMapMarker:(this.allMtMapMarker=d3.selectAll(this.containerSelector+" .mt-map-marker"),this.allMtMapMarker)}},{key:"updateCountries",value:function(){var t=this,e=new Map;this.maptable.data.forEach(function(a){var i=a[t.options.countryIdentifierKey];e.has(i)||e.set(i,[]),e.get(i).push(a)}),this.dataCountries.forEach(function(a){a.key=a.properties[t.options.countryIdentifierType];var i=e.get(a.key);a.values=i||[],a.attr={},a.rollupValue={}}),Object.keys(this.options.countries.attr).forEach(function(e){t.setAttrValues(e,t.options.countries.attr[e],t.dataCountries)});var a=this.getAllMtMapCountry().each(function(t){var e=d3.select(this);Object.keys(t.attr).forEach(function(a){e.attr(a,t.attr[a])})});Object.keys(this.options.countries.attr).forEach(function(e){var i=t.options.countries.attr[e];if("object"===("undefined"==typeof i?"undefined":N["typeof"](i))&&i.legend&&void 0!==t.legendCountry[e]){var n=d3.extent(t.dataCountries,function(t){return Number(t.attrProperties[e].value)});t.legendCountry[e].updateExtents(n),a.on("mouseover",function(a){t.legendCountry[e].indiceChange(a.attrProperties[e].value)}).on("mouseout",function(){t.legendCountry[e].indiceChange(NaN)})}}),this.options.countries&&this.options.countries.tooltip&&this.activateTooltip(a,this.tooltipCountriesNode,this.options.countries.tooltip,!0)}},{key:"updateNight",value:function(){var t=this.options.night.date||Date.UTC(),e=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),0,0,0),a=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),23,59,59),i=a-e,n=t-e,r=n/i;this.layerNight.node().style.transform="translateX("+-this.getWidth()*r+"px)"}},{key:"updateTimezones",value:function(){var t=document.querySelectorAll(".mt-map-timezone-text"),e=this.options.timezones.date||new Date;Array.from(t).forEach(function(t){t.textContent=F.formatDate(e,t.__data__.properties.zone)})}},{key:"updateMarkers",value:function(){var t=this,e=function(t){return t.longitude+","+t.latitude};this.dataMarkers=d3.nest().key(e).entries(this.maptable.data).filter(function(t){return 0!==t.values[0].x}),this.dataMarkers.forEach(function(t){t.attr={},t.attrProperties={}}),Object.keys(this.options.markers.attr).forEach(function(e){t.setAttrValues(e,t.options.markers.attr[e],t.dataMarkers)});var a=this.layerMarkers.selectAll(".mt-map-marker").data(this.dataMarkers),i=a.enter();i=this.options.markers.customTag?this.options.markers.customTag(i):i.append("svg:circle");var n=this.options.markers.className?this.options.markers.className:"";i.attr("class","mt-map-marker "+n),a.exit().transition().attr("r",0).attr("fill","#eee").style("opacity",0).remove();var r=this.options.markers.attrX?this.options.markers.attrX:"cx",s=this.options.markers.attrY?this.options.markers.attrY:"cy",o=this.options.markers.attrXDelta?this.options.markers.attrXDelta:0,l=this.options.markers.attrYDelta?this.options.markers.attrYDelta:0,h=a.attr(r,function(t){return t.values[0].x+o}).attr(s,function(t){return t.values[0].y+l});this.getAllMtMapMarker().each(function(t){var e=this;Object.keys(t.attr).forEach(function(a){d3.select(e).attr(a,t.attr[a])})}),this.options.markers.tooltip&&this.activateTooltip(h,this.tooltipMarkersNode,this.options.markers.tooltip,!1),this.rescale()}},{key:"fitContent",value:function(){if(0===this.maptable.data.length)return this.transX=0,this.transY=0,this.scale=1,void this.zoomListener.translate([this.transX,this.transY]).scale(this.scale);var t=d3.extent(this.maptable.data,function(t){return t.x}),e=d3.extent(this.maptable.data,function(t){ +return t.y}),a=this.getWidth()/this.getHeight(),i=20+(this.options.title?30:0),n=t[1]-t[0]+i,r=e[1]-e[0]+i,s=n/a,o=r*a,l=0,h=0;o>=n?l=(o-n)/2:h=(s-r)/2,t[0]-=this.options.fitContentMargin+l,t[1]+=this.options.fitContentMargin+l,e[0]-=this.options.fitContentMargin+h,e[1]+=this.options.fitContentMargin+h,this.scale=this.getWidth()/(t[1]-t[0]),this.transX=-1*t[0]*this.scale,this.transY=-1*e[0]*this.scale,this.zoomListener.translate([this.transX,this.transY]).scale(this.scale)}},{key:"buildTitle",value:function(){var t=this.svg.append("svg").attr("width",this.getWidth()).attr("x",0).attr("y",this.getHeight()-30).attr("height",30);this.options.title.bgColor&&t.append("rect").attr("x",0).attr("y",0).attr("width",this.getWidth()).attr("height",30).attr("fill",this.options.title.bgColor),t.append("text").attr("id","mt-map-title").attr("x",20).attr("font-size",this.scaleFontSize(this.options.title.fontSize)).attr("font-family",this.options.title.fontFamily).attr("y",20),this.options.title.source&&t.append("text").attr("y",20).attr("x",this.getWidth()-20).attr("text-anchor","end").attr("font-size",this.scaleFontSize(this.options.title.fontSize)).attr("font-family",this.options.title.fontFamily).html(this.options.title.source())}},{key:"encodeTranslation",value:function(t){var e=t[0]/(this.scale*this.getWidth()),a=t[1]/(this.scale*this.getHeight());return[e,a]}},{key:"decodeTranslation",value:function(t){var e=t[0]*this.getWidth()*this.scale,a=t[1]*this.getHeight()*this.scale;return[e,a]}},{key:"restoreState",value:function(t){if(t&&3===t.length){this.scale=t[0];var e=this.decodeTranslation([t[1],t[2]]);this.transX=e[0],this.transY=e[1],this.zoomListener.scale(t[0]).translate(e).event(this.svg)}}},{key:"saveState",value:function(){var t=this.encodeTranslation([this.transX,this.transY]),e=[this.scale,t[0],t[1]];1!==e[0]&&0!==e[1]&&0!==e[2]?this.maptable.saveState("zoom",e):this.maptable.removeState("zoom")}},{key:"rescale",value:function(){var t=this;d3.event&&d3.event.translate&&(this.scale=d3.event.scale,this.transX=1===this.scale?0:d3.event.translate[0],this.transY=1===this.scale?0:d3.event.translate[1]);var e=0,a=0,i=this.getWidth()*(1-this.scale),n=this.getHeight()*(1-this.scale);this.transY>a?this.transY=a:this.transYe?this.transX=e:this.transXe?e:t},e[0])};else if("max"===s)e.rollup=function(t){if(!t.length)return 0;var e=t.map(function(t){return Number(t[r])});return e.reduce(function(t,e){return e>t?e:t},e[0])};else if(-1!==s.indexOf("percentile")){var l=F.toNumber(s);e.rollup=function(t){if(!t.length)return 0;var e=t.map(function(t){return Number(t[r])});return F.quantile(e,l)}}else"function"==typeof e.rollup&&(e.rollup=e.rollup.bind(this.maptable));n&&(-1!==n.indexOf("log")?o=d3.scale.log():-1!==n.indexOf("pow")?o=d3.scale.pow().exponent(F.toNumber(n)||1):"sqrt"===n&&(o=d3.scale.sqrt()))}if(e.rollup||(e.rollup=function(t){return t.length}),!e.min||!e.max)throw new Error("MapTable: You should provide values 'min' & 'max' for attr."+t);if(a.forEach(function(a){var o=e.rollup(a.values);if(a.attrProperties||(a.attrProperties={}),a.attrProperties[t]||(a.attrProperties[t]={}),a.attrProperties[t].value=o,r){a.attrProperties[t].key=r,a.attrProperties[t].mode=s,a.attrProperties[t].scale=n;var l=i.maptable.columnDetails[r];a.attrProperties[t].columnDetails=l;var h={};h[r]=o,a.attrProperties[t].formatted=l&&l.cellContent?l.cellContent.bind(i.maptable)(h):o}}),"rank"===n){var h=F.uniqueValues([0].concat(a.map(function(e){return Math.floor(100*e.attrProperties[t].value)/100}).filter(function(t){return t>0}))),p=F.uniqueValues(a.map(function(e){return Math.floor(100*e.attrProperties[t].value)/100}).filter(function(t){return 0>t}));h.sort(function(t,e){return t-e}),p.sort(function(t,e){return e-t}),a.forEach(function(e){if(0!==e.attrProperties[t].value){var a=e.attrProperties[t].value>=0?h:p,i=a.indexOf(Math.floor(100*e.attrProperties[t].value)/100),n=Math.round(i/a.length*100),r=e.attrProperties[t].value<0?n-2*n:n;e.attrProperties[t].value=r}})}var u=d3.extent(a,function(e){return Number(e.attrProperties[t].value)});0===u[0]&&n&&"-1"!==n.indexOf("log")&&(u=d3.extent(a.filter(function(e){return 0!==Number(e.attrProperties[t].value)}),function(e){return Number(e.attrProperties[t].value)})),e.transform&&(u[0]=e.transform.bind(this.maptable)(u[0],this.maptable.data),u[1]=e.transform.bind(this.maptable)(u[1],this.maptable.data));var d=e.min,c=e.max;if("minValue"===e.min&&(d=u[0]),"maxValue"===e.max&&(c=u[1]),e.maxNegative&&!e.minNegative||!e.maxNegative&&e.minNegative)throw new Error("MapTable: maxNegative or minNegative undefined. Please declare both.");var m=e.maxNegative&&e.minNegative,f=void 0,g=void 0;m?(f=o.copy().domain([0,u[1]]).range([d,c]),g=o.copy().domain([u[0],0]).range([e.maxNegative,e.minNegative])):f=o.domain(u).range([d,c]),a.forEach(function(a){var n=void 0;if(!a.values.length||Number.isNaN(a.attrProperties[t].value)){if("undefined"==typeof e.empty)throw new Error("MapTable: no empty property found for attr."+t);n=e.empty}else{var r=a.attrProperties[t].value,s=e.transform?e.transform.bind(i.maptable)(r,i.maptable.data):r;n=m&&0>s?g(s):f(s)}a.attr[t]=n})}}},{key:"render",value:function(){this.options.markers&&this.updateMarkers(),this.options.countries&&this.updateCountries(),this.options.night&&this.updateNight(),this.options.timezones&&this.updateTimezones(),this.options.title&&this.updateTitle(),this.options.heatmap&&this.updateHeatmap(),this.options.autoFitContent&&(this.fitContent(),this.rescale()),this.options.onRender&&this.options.onRender.constructor===Function&&this.options.onRender.bind(this.maptable)()}},{key:"updateTitle",value:function(){var t=this;if(this.options.title.content){var e=this.maptable.data.filter(function(e){return 0!==e[t.options.latitudeKey]}).length,a=this.maptable.rawData.filter(function(e){return 0!==e[t.options.latitudeKey]}).length,i="";this.maptable.filters&&(i=this.maptable.filters.getDescription()),this.container.querySelector("#mt-map-title").innerHTML=this.options.title.content.bind(this.maptable)(e,a,i,this.maptable.data,this.maptable.rawData,this.dataCountries)}}},{key:"activateTooltip",value:function(t,e,a,i){var n=this;t.on(i?"mousemove":"mouseover",function(t){var r=a.bind(this.maptable)(t);if(r){e.html(r).attr("style","display:block;position:fixed;");var s=void 0,o=void 0,l=e.node().offsetWidth/2;if(i){var h=n.node.getBoundingClientRect(),p=d3.mouse(n.svg.node()).map(function(t){return parseInt(t,10)});s=h.left+p[0]-l,o=h.top+p[1]+10}else{var u=this.getBoundingClientRect();s=u.left+u.width/2-l,o=u.top+u.height+2}e.attr("style","top:"+o+"px;left:"+s+"px;display:block;position:fixed;").on("mouseout",function(){e.style("display","none")})}}).on("mouseout",function(){e.style("display","none")})}},{key:"exportSvg",value:function(){var t=this.container.querySelector("#mt-map-svg"),e='\n'+(new XMLSerializer).serializeToString(t);if(this.options.exportSvgClient){if(!window.saveAs)throw new Error("MapTable: Missing FileSaver.js library");var a=new Blob([e],{type:"image/svg+xml"});window.saveAs(a,"visualization.svg")}else if(this.options.exportSvg){var i=this.node.querySelector("#mt-map-svg-form");i.querySelector('[name="data"]').value=e,i.submit()}}},{key:"addExportSvgCapability",value:function(){var t=document.createElement("div");t.setAttribute("id","mt-map-export"),this.container.querySelector("#mt-map").appendChild(t);var e=document.createElement("button");if(e.setAttribute("class","btn btn-xs btn-default"),e.innerHTML="Download",e.addEventListener("click",this.exportSvg.bind(this)),t.appendChild(e),this.options.exportSvg){var a=document.createElement("div");a.innerHTML='
',t.appendChild(a)}}}]),t}(),Y=function(){function t(e,a){var i=this;if(N.classCallCheck(this,t),this.maptable=e,this.options=a,this.criteria=[],this.options.show){var n=this.options.show.filter(function(t){return Object.keys(i.maptable.columnDetails).indexOf(t)<0});if(n.length>0)throw new Error('MapTable: invalid columns "'+n.join(", ")+'"');this.activeColumns=this.options.show}else this.activeColumns=Object.keys(this.maptable.columnDetails);this.container=document.createElement("div"),this.maptable.node.appendChild(this.container),this.containerSelector=e.options.target,this.container=document.querySelector(e.options.target),this.node=this.container.querySelector("#mt-filters"),this.node||(this.node=document.createElement("div"),this.node.setAttribute("id","mt-filters"),this.node.setAttribute("class","panel panel-default"),this.maptable.node.appendChild(this.node));var r=document.createElement("div");r.setAttribute("class","panel-heading");var s=document.createElement("button");s.setAttribute("id","mt-filters-reset"),s.setAttribute("class","btn btn-default btn-xs pull-right"),s.style.display="none",s.style.marginLeft=5,s.innerText="↺ Reset",s.addEventListener("click",this.reset),r.appendChild(s);var o=document.createElement("h3");o.setAttribute("class","panel-title"),o.appendChild(document.createTextNode("Filters")),r.appendChild(o),this.node.appendChild(r);var l=document.createElement("div");l.setAttribute("id","mt-filters-content"),l.setAttribute("class","panel-body");var h=document.createElement("div");h.setAttribute("id","mt-filters-elements"),l.appendChild(h);var p=document.createElement("a");p.setAttribute("id","mt-filters-new"),p.setAttribute("href","#"),p.innerText="+ New filter",p.addEventListener("click",this.add.bind(this)),l.appendChild(p),this.node.appendChild(l)}return N.createClass(t,[{key:"add",value:function(t){t&&t.preventDefault();var e=this.getPossibleFilters();if(0!==e.length){var a=e[0].key;this.create(a)}}},{key:"create",value:function(t,e){var a=this.buildRow(t);e?e.parentNode.replaceChild(a,e):this.node.querySelector("#mt-filters-elements").appendChild(a),this.criteria.push(t),this.maptable.render(),"none"===this.container.style.display&&this.toggle()}},{key:"remove",value:function(t){var e=this.node.querySelector('[data-mt-filter-name="'+t+'"]');e&&e.parentNode.removeChild(e);var a=this.criteria.indexOf(t);this.criteria.splice(a,1),this.maptable.render()}},{key:"reset",value:function(){for(var t=this.node.querySelectorAll("[data-mt-filter-name]"),e=0;e and\n '+h+""}else{var p=i.querySelector(".mt-filter-value-min").value;if(""===p)continue;s+=r.title+" is ",s+=o.options[o.selectedIndex].text,s+=''+p+""}}else if("field"===r.filterMethod||"dropdown"===r.filterMethod){var u=i.querySelector(".mt-filter-value").value;if(""===u)continue;var d="field"===r.filterMethod?"contains":"is";s+=r.title+" "+d+'\n '+u+""}t.push(s)}return t.join(", ")}},{key:"buildRow",value:function(t){var e=this,a=this,i=this.getPossibleFilters(),n=this.maptable.columnDetails[t],r=document.createElement("div");r.setAttribute("class","mt-filter-row"),r.setAttribute("data-mt-filter-name",t);var s=document.createElement("button");s.setAttribute("class","btn btn-default pull-right"),s.setAttribute("data-mt-filter-btn-minus",1),s.innerText="– Remove this filter",s.addEventListener("click",function(){t=r.querySelector(".mt-filter-name").value,e.remove(t)}),r.appendChild(s);var o=document.createElement("span");o.setAttribute("class","mt-filters-and"),o.innerText="And ",r.appendChild(o);var l=document.createElement("select");l.setAttribute("class","mt-filter-name form-control form-control-inline"),F.appendOptions(l,i.map(function(t){return{text:t.title,value:t.key}})),l.value=t,l.addEventListener("change",function(){var t=this.parentNode.getAttribute("data-mt-filter-name"),e=this.value;a.create(e,this.parentNode),a.remove(t),a.refresh()}),r.appendChild(l);var h=document.createElement("span");h.innerText="field"===n.filterMethod?" contains ":" is ",r.appendChild(h);var p=null;"field"!==n.filterMethod&&"dropdown"!==n.filterMethod&&(p=document.createElement("select"),p.setAttribute("class","mt-filter-range form-control form-control-inline"),F.appendOptions(p,["any","=","≠","<",">","≤","≥","BETWEEN"].map(function(t){return{text:t,value:t}})),p.addEventListener("change",function(){a.handleRangeChange(this)}),r.appendChild(p),r.appendChild(document.createTextNode(" ")));var u=document.createElement("div");if(u.style.display="inline-block",u.setAttribute("class","mt-filter-value-container"),"compare"===n.filterMethod)["min","max"].forEach(function(t,a){var i=document.createElement("input");if(i.setAttribute("class","form-control form-control-inline mt-filter-value-"+t),i.setAttribute("type",n.filterInputType),i.addEventListener("keyup",e.maptable.render.bind(e.maptable)),i.addEventListener("change",e.maptable.render.bind(e.maptable)),u.appendChild(i),0===a){var r=document.createElement("span");r.setAttribute("class","mt-filter-value-and"),r.innerText=" and ",u.appendChild(r)}});else if("field"===n.filterMethod){var d=document.createElement("input");d.setAttribute("class","form-control form-control-inline mt-filter-value"),d.setAttribute("type","text"),d.addEventListener("keyup",this.maptable.render.bind(this.maptable)),d.addEventListener("change",this.maptable.render.bind(this.maptable)),u.appendChild(d)}else if("dropdown"===n.filterMethod){var c=document.createElement("select");c.setAttribute("class","form-control form-control-inline mt-filter-value");var m=d3.nest().key(function(e){return e[t]}).sortKeys(d3.ascending).entries(this.maptable.rawData);F.appendOptions(c,[{text:"Any",value:""}].concat(m.map(function(t){return{text:t.key,value:t.key}}))),c.addEventListener("change",this.maptable.render.bind(this.maptable)),u.appendChild(c)}return r.appendChild(u),p&&this.handleRangeChange(p),r}},{key:"handleRangeChange",value:function(t){var e=t.parentNode;"any"===t.value?e.querySelector(".mt-filter-value-container").style.display="none":(e.querySelector(".mt-filter-value-container").style.display="inline-block","BETWEEN"===t.value?(e.querySelector(".mt-filter-value-min").style.display="inline-block",e.querySelector(".mt-filter-value-and").style.display="inline-block",e.querySelector(".mt-filter-value-max").style.display="inline-block"):(e.querySelector(".mt-filter-value-min").style.display="inline-block",e.querySelector(".mt-filter-value-and").style.display="none",e.querySelector(".mt-filter-value-max").style.display="none")),this.maptable.render.bind(this.maptable)()}},{key:"getPossibleFilters",value:function(t){var e=this;return Object.keys(this.maptable.columnDetails).map(function(t){return F.extendRecursive({key:t},e.maptable.columnDetails[t])}).filter(function(a){return-1!==e.activeColumns.indexOf(a.key)&&(t&&t===a.key||-1===e.criteria.indexOf(a.key)&&a.filterMethod&&!a.isVirtual)})}},{key:"filterData",value:function(){var t=this,e=this;this.maptable.data=this.maptable.rawData.filter(function(a){for(var i=t.node.querySelectorAll(".mt-filter-row"),n=!0,r=0;rh(m))?n=!1:(parseInt(a[o],10)parseInt(m,10))&&(n=!1)}else{var f=s.querySelector(".mt-filter-value-min").value;if(""===f)continue;h&&!F.rangeToBool(h(a[o]),d,h(f))?n=!1:h||F.rangeToBool(a[o],d,f)||(n=!1)}}(h&&F.isBlank(h(a[o]))||F.isBlank(a[o]))&&(n=!1)}return n}),this.options.saveState&&this.maptable.saveState("filters",this.exportFilters())}},{key:"refresh",value:function(){for(var t=this.node.querySelectorAll(".mt-filter-name"),e=0;e0&&(this.node.querySelectorAll(".mt-filters-and")[0].style.visibility="hidden");var r=!this.getPossibleFilters().length;this.node.querySelector("#mt-filters-new").style.visibility=r?"hidden":"visible"}},{key:"toggle",value:function(){"none"===this.container.style.display?(this.container.style.display="block",0===this.criteria.length&&this.add()):this.container.style.display="none"}}]),t}(),U=function(){function t(e,a){var i=this;if(N.classCallCheck(this,t),this.maptable=e,this.options=a,this.sorting=[],this.options.defaultSorting?(!Array.isArray(this.options.defaultSorting)||2!==this.options.defaultSorting.length&&3!==this.options.defaultSorting.length?Array.isArray(this.options.defaultSorting)&&this.options.defaultSorting.length>=4?this.sorting=this.options.defaultSorting.slice(0,3):this.sorting=[this.options.defaultSorting]:this.sorting=this.options.defaultSorting,this.sorting.forEach(function(t){t.mode||(t.mode="asc")})):this.sorting=[{key:Object.keys(this.maptable.data[0])[0],mode:"asc"}],this.initialSorting=this.sorting.map(function(t){return t.key+","+t.mode}).join(";"),this.isSorting=!1,this.containerSelector=e.options.target,this.container=document.querySelector(e.options.target),this.node=this.container.querySelector("#mt-table"),this.node||(this.node=document.createElement("div"),this.node.setAttribute("id","mt-table"),this.maptable.node.appendChild(this.node)),this.node=d3.select(this.node).append("table").attr("class",this.options.className),this.header=this.node.append("thead"),this.body=this.node.append("tbody"),this.options.show){var n=this.options.show.filter(function(t){return Object.keys(i.maptable.columnDetails).indexOf(t)<0});if(n.length>0)throw new Error('MapTable: invalid columns "'+n.join(", ")+'"');this.activeColumns=this.options.show}else this.activeColumns=Object.keys(this.maptable.columnDetails);this.options.header&&(this.options.header.className&&this.header.attr("class",""+this.options.header.className),this.options.header.top?this.header.attr("style","top:"+(this.options.header.top||"0")+"px;"):this.header.attr("style","top:0px;")),this.header.selectAll("tr").data([1]).enter().append("tr").selectAll("th").data(this.activeColumns.map(function(t){return F.extendRecursive({key:t},i.maptable.columnDetails[t])})).enter().append("th").attr("class",function(t){var e=t.sorting?"mt-table-sortable":"";return e+=t.nowrap?" nowrap":""}).attr("data-key",function(t){return F.sanitizeKey(t.key)}).attr("onselectstart","return false;").attr("unselectable","on").attr("style",function(t){return t.nowrap?"white-space:nowrap;":""}).on("click",function(t){i.isSorting||(i.isSorting=!0,t.sorting&&i.sortColumn(t.key),i.isSorting=!1)}).text(function(t){return t.title}).attr("id",function(t){return"column_header_"+F.sanitizeKey(t.key)})}return N.createClass(t,[{key:"restoreState",value:function(t){if(t){var e=t.split(";"),a=[];e.forEach(function(t){var e=t.split(",");a.push({key:e[0],mode:e[1]||"asc"})}),this.sorting=a}}},{key:"saveState",value:function(){var t=this.sorting.map(function(t){return t.key+","+t.mode}).join(";");t!==this.initialSorting&&this.maptable.saveState("sort",t)}},{key:"render",value:function(){var t=this;this.applySort();var e=this.maptable.data;this.options.distinctBy&&(e=d3.nest().key(function(e){return e[t.options.distinctBy]}).entries(this.maptable.data).map(function(t){return t.values[0]})),this.body.selectAll("tr").data(e).enter().append("tr"),this.body.selectAll("tr").data(e).exit().remove();var a=[];this.sortIndex=0,this.body.selectAll("tr").data(e).attr("class",function(a,i){var n=t.isEndOfPrimarySort(e,i);return t.options.rowClassName?"line "+t.options.rowClassName(a)+" "+(n?"bold":""):"line "+(n?"bold":"")}).html(function(e){var i="";return t.activeColumns.forEach(function(n){var r=t.maptable.columnDetails[n];i+=""}),i}).append("span").attr("class","table-sort-sn "+(!this.options.dataCountIndicator||this.options.dataCountIndicator&&!this.options.dataCountIndicator.enabled||this.sorting&&this.sorting.length<=1?"display-none":"")+" ").html(function(a,i){var n=t.isEndOfPrimarySort(e,i-1);return n?t.sortIndex=1:t.sortIndex+=1,""+t.sortIndex}),this.options.onRender&&this.options.onRender.constructor===Function&&this.options.onRender.bind(this.maptable)()}},{key:"applySort",value:function(){for(var t=this,e=this.container.querySelectorAll(".mt-table-sortable"),a=0;ae?-1:1,n=t;n!=e;n+=i)this.sorting[n]=this.sorting[n+i];this.sorting[e]=a}}},{key:"isEndOfPrimarySort",value:function(t,e){if(!this.options.dataGroupSeparator||this.options.dataGroupSeparator&&!this.options.dataGroupSeparator.enabled)return!1;if(this.sorting&&this.sorting.length<=1)return!1;var a=this.sorting[0].key||"";return t[e]&&t[e+1]&&t[e][a]&&t[e+1][a]?(""+t[e][a]).toLowerCase()!==(""+t[e+1][a]).toLowerCase():!1}}]),t}(),X=function(){function t(e,a){N.classCallCheck(this,t),this.options=a,this.state={},this.saveStateTimeout={},this.removeStateTimeout=null,this.node=document.querySelector(e),this.node.setAttribute("style","position:relative;"),"json"===this.options.data.type?d3.json(this.options.data.path,this.loadData.bind(this)):"csv"===this.options.data.type?d3.csv(this.options.data.path,this.loadData.bind(this)):"tsv"===this.options.data.type?d3.tsv(this.options.data.path,this.loadData.bind(this)):"jsonData"===this.options.data.type?this.loadData(null,JSON.parse(this.options.data.value)):"csvData"===this.options.data.type?this.loadData(null,d3.csv.parse(this.options.data.value)):"tsvData"===this.options.data.type?this.loadData(null,d3.tsv.parse(this.options.data.value)):"data"===this.options.data.type&&this.loadData(null,this.options.data.value),this.options.map&&this.options.map.heatmap&&delete this.options.map.countries}return N.createClass(t,[{key:"loadData",value:function(t,e){var a=this;if(t)throw t;if(this.rawData=e,this.options.data.preFilter&&(this.rawData=this.rawData.filter(this.options.data.preFilter)),this.setColumnDetails(),this.data=this.rawData.slice(),this.options.map){var i=document.createElement("div");i.setAttribute("class","mt-map-container");var n=-1!==navigator.userAgent.indexOf("MSIE")||navigator.appVersion.indexOf("Trident/")>0;if(this.options.map.heatmap&&n)return i.innerHTML='
The heatmap feature is not supported with Internet Explorer.
Please use another modern browser to see this map.
',this.node.insertBefore(i,this.node.firstChild),i.querySelector(".mt-loading").style.display="block",this.options.map=!1,void this.buildComponenents();if(i.innerHTML='
Loading...
',this.node.insertBefore(i,this.node.firstChild),i.querySelector(".mt-loading").style.display="block",this.options.map.pathData)this.loadMapData(null,JSON.parse(this.options.map.pathData),i);else{if(!this.options.map.path)throw new Error("missing map path|pathData");d3.json(this.options.map.path,function(t,e){a.loadMapData(t,e,i)})}}else this.buildComponenents()}},{key:"loadMapData",value:function(t,e,a){if(t)throw t;this.map=new G(this,this.options.map,e),a.querySelector(".mt-loading").style.display="none",this.buildComponenents()}},{key:"buildComponenents",value:function(){var t=this;this.options.filters&&(this.filters=new Y(this,this.options.filters)),this.options.table&&(this.table=new U(this,this.options.table)),this.restoreState(),window.addEventListener("hashchange",function(){t.restoreState()}),this.render()}},{key:"loadState",value:function(t,e){if(e){var a=this.parseState(t);if(!a)return null;try{var i=JSON.parse(a);this.state[t]=i}catch(n){return console.log("Maptable: Invalid URL State for mt-"+t+" "+n.message),null}}else{var r=this.parseState(t);r&&(this.state[t]=r)}return this.state[t]}},{key:"restoreState",value:function(){this.map&&(this.loadState("zoom",!0),this.map.restoreState(this.state.zoom)),this.filters&&(this.loadState("filters",!0),this.filters.restoreState(this.state.filters)),this.table&&(this.loadState("sort",!1),this.table.restoreState(this.state.sort))}},{key:"parseState",value:function(t){var e=document.location.href.replace(/%21mt/g,"!mt").split("!mt-"+t+"=");return e[1]?decodeURIComponent(e[1].split("!mt")[0]):null}},{key:"removeState",value:function(t){window.clearTimeout(this.saveStateTimeout[t]),delete this.state[t],this.updateState()}},{key:"saveState",value:function(t,e){var a=this;window.clearTimeout(this.saveStateTimeout[t]),this.saveStateTimeout[t]=window.setTimeout(function(){a.state[t]=e,a.updateState()},200)}},{key:"updateState",value:function(){var t=this,e=document.location.href.split("#")[0],a="";Object.keys(this.state).forEach(function(e){if(t.state[e]){var i=t.state[e];if("object"===N["typeof"](t.state[e])){if(!Object.keys(t.state[e]).length)return;i=JSON.stringify(t.state[e])}a+="!mt-"+e+"="+encodeURIComponent(i)}}),""!==a&&(a="#"+a),document.location.href!==""+e+a&&window.history.pushState(null,null,""+e+a)}},{key:"render",value:function(){this.filters&&(this.filters.filterData(),this.filters.refresh()),this.map&&(this.map.render(),!this.firstExecution&&this.options.map.onComplete&&this.options.map.onComplete.constructor===Function&&this.options.map.onComplete.bind(this)()),this.table&&(this.table.render(),!this.firstExecution&&this.options.table.onComplete&&this.options.table.onComplete.constructor===Function&&this.options.table.onComplete.bind(this)()), +!this.firstExecution&&this.options.onComplete&&this.options.onComplete.constructor===Function&&this.options.onComplete.bind(this)(),this.firstExecution=!0}},{key:"setColumnDetails",value:function(){var t=this,e=this;if(0!==e.rawData.length){var a={};Object.keys(e.rawData[0]).forEach(function(i){var n=/^[-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?$/,r=n.test(e.rawData[0][i]);a[i]={title:F.keyToTile(i),filterMethod:r?"compare":"field",filterInputType:r?"number":t.options.columns[i]&&t.options.columns[i].filterInputType?t.options.columns[i].filterInputType:"text",sorting:!0},r&&(a[i].dataParse=function(t){return parseFloat(t)})}),e.columnDetails=F.extendRecursive(a,this.options.columns),Object.keys(e.columnDetails).forEach(function(t){e.columnDetails[t].isVirtual="function"==typeof e.columnDetails[t].virtual})}}}]),t}();if(d3.maptable=function(t){var e=void 0,a={},i={target:t,columns:{},data:{},map:null,filters:null,table:null};return a.map=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(!topojson)throw new Error("Maptable requires topojson.js");if("string"!=typeof t.path&&"string"!=typeof t.pathData)throw new Error("MapTable: map not provided");return i.map=t,a},a.data=function(t){return i.data.type="data",i.data.value=t,a},a.json=function(t,e){return i.data.type="json",i.data.path=t,i.data.preFilter=e,a},a.jsonData=function(t){return i.data.type="jsonData",i.data.value=t,a},a.csv=function(t,e){return i.data.type="csv",i.data.path=t,i.data.preFilter=e,a},a.csvData=function(t){return i.data.type="csvData",i.data.value=t,a},a.tsv=function(t,e){return i.data.type="tsv",i.data.path=t,i.data.preFilter=e,a},a.tsvData=function(t){return i.data.type="tsvData",i.data.value=t,a},a.filters=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.filters=t,a},a.table=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.table=t,a},a.columns=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return i.columns=t,a},a.render=function(a){if("string"!=typeof t||!document.querySelector(t))throw new Error("MapTable: target not found");if(!i.data||!i.data.type)throw new Error("MapTable: Please provide the path for your dataset data|json|jsonData|csv|csvData|tsv|tsvData");i.map&&!i.map.heatmap&&(i.map.heatmap=null),i.map&&i.map.markers===!1&&(i.map.markers=null),i.map&&i.map.countries===!1&&(i.map.countries=null),i.filters||(i.filters=null),i.onComplete=a;var n=F.extendRecursive(q,i);return i.map&&!i.map.markers&&delete n.map.markers,i.map&&!i.map.heatmap&&delete n.map.heatmap,i.map&&!i.map.title&&delete n.map.title,i.map&&!i.map.timezones&&delete n.map.timezones,i.map&&!i.map.night&&delete n.map.night,i.filters||delete n.filters,i.table||delete n.table,e=new X(t,n),{render:function(){return e.render()},loadState:function(t,a){return e.loadState(t,a)},removeState:function(t){return e.removeState(t)},saveState:function(t,a){return e.saveState(t,a)},setTitleContent:function(t){e.options.map.title.content=function(){return t}},setData:function(t){e.options.data.type="data",e.options.data.value=t,e.options.rawData=t,e.rawData=t,e.data=t,e.map&&e.map.enrichData()},setNightDate:function(t){e.options.map.night.date=t},setTimezonesDate:function(t){e.options.map.timezones.date=t},getMapWidth:function(){return e.map.getWidth()},getMapHeight:function(){return e.map.getHeight()}}},a},!d3)throw new Error("Maptable requires d3.js");var K=d3.maptable;return K}(); \ No newline at end of file diff --git a/src/components/Table.js b/src/components/Table.js index 067f99a..13681c8 100644 --- a/src/components/Table.js +++ b/src/components/Table.js @@ -324,7 +324,8 @@ export default class Table { const primarySort = this.sorting[0].key || ''; if (data[index] && data[index + 1]) { if (data[index][primarySort] && data[index + 1][primarySort]) { - return data[index][primarySort].toLowerCase() !== data[index + 1][primarySort].toLowerCase(); + // stringify everything before .toLowerCase() + return `${data[index][primarySort]}`.toLowerCase() !== `${data[index + 1][primarySort]}`.toLowerCase(); } } return false; diff --git a/src/maptable.css b/src/maptable.css index c068658..9ef1046 100755 --- a/src/maptable.css +++ b/src/maptable.css @@ -152,5 +152,5 @@ } .display-none { - display: none; + display: none !important; } \ No newline at end of file From f40ace28ea4df9d0fe6d379a2262be21ec9ed09d Mon Sep 17 00:00:00 2001 From: Anjal Date: Fri, 14 Jun 2024 13:36:37 +0545 Subject: [PATCH 2/2] build success --- dist/maptable.min.js | 2 +- docs/maptable.min.js | 2 +- src/maptable.css | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/dist/maptable.min.js b/dist/maptable.min.js index 1234261..7577103 100644 --- a/dist/maptable.min.js +++ b/dist/maptable.min.js @@ -1,5 +1,5 @@ /** - * MapTable 2.5.0 - License MIT - Build: Fri Jun 14 2024 12:48:26 GMT+0545 (Nepal Time) + * MapTable 2.5.0 - License MIT - Build: Fri Jun 14 2024 13:23:16 GMT+0545 (Nepal Time) */ this.d3=this.d3||{},this.d3.maptable=function(){"use strict";function t(t,e,a){e.forEach(function(e){var a=document.createElement("option");a.setAttribute("value",e.value),a.innerText=e.text,t.appendChild(a)}),t.value=a}function e(t,e,a){return"="===e?parseInt(t,10)===parseInt(a,10):"≠"===e?parseInt(t,10)!==parseInt(a,10)&&""!==t&&""!==a:">"===e?parseInt(t,10)>parseInt(a,10)&&""!==t&&""!==a:"<"===e?parseInt(t,10)=parseInt(a,10)&&""!==t&&""!==a:"≤"===e?parseInt(t,10)<=parseInt(a,10)&&""!==t&&""!==a:!0}function a(){for(var t={},e=void 0,i=[].splice.call(arguments,0),n={}.toString;i.length>0;)e=i.splice(0,1)[0],"[object Object]"===n.call(e)&&Object.keys(e).forEach(function(i){"[object Object]"===n.call(e[i])?t[i]=a(t[i]||{},e[i]):t[i]=e[i]});return t}function i(t){var e=t.charAt(0).toUpperCase()+t.slice(1);return e.replace(/_/g," ")}function n(t){return t.toLowerCase().replace(/ /g,"_").replace(/"/g,"").replace(/'/g,"")}function r(t){if(!t||""===t)return null;var e=t.toString().replace(/[^0-9.]+|\s+/gim,"");return""!==e?Number(e):null}function s(t,e){t.sort(function(t,e){return t-e});var a=e/100*(t.length-1),i=void 0;if(Math.floor(a)===a)i=t[a];else{var n=Math.floor(a),r=a-n;i=t[n]+(t[n+1]-t[n])*r}return i}function o(t){if(!t)return t;for(var e=[],a=0,i=t.length;i>a;a+=1)-1===e.indexOf(t[a])&&""!==t[a]&&e.push(t[a]);return e}function l(t,e,a,i){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLImageElement&&!t instanceof HTMLImageElement)return;var n=t.naturalWidth,r=t.naturalHeight;if("string"==typeof e)var e=document.getElementById(e);else if("undefined"!=typeof HTMLCanvasElement&&!e instanceof HTMLCanvasElement)return;e.style.width=n+"px",e.style.height=r+"px",e.width=n,e.height=r;var s=e.getContext("2d");s.clearRect(0,0,n,r),s.drawImage(t,0,0),Number.isNaN(a)||1>a||(i?p(e,0,0,n,r,a):d(e,0,0,n,r,a))}function h(t,e,a,i,n){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLCanvasElement&&!t instanceof HTMLCanvasElement)return;var r,s=t.getContext("2d");try{try{r=s.getImageData(e,a,i,n)}catch(o){throw new Error("unable to access local image data: "+o)}}catch(o){throw new Error("unable to access image data: "+o)}return r}function p(t,e,a,i,n,r){if(!(Number.isNaN(r)||1>r)){r|=0;var s=h(t,e,a,i,n);s=u(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function u(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,E,N,T,D,A,z=t.data,j=r+r+1,F=i-1,q=n-1,W=r+1,O=W*(W+1)/2,P=new m,L=P;for(l=1;j>l;l++)if(L=L.next=new m,l==W)var B=L;L.next=P;var R=null,G=null;d=u=0;var Y=H[r],U=I[r];for(o=0;n>o;o++){for(w=C=S=M=c=f=g=v=0,y=W*(E=z[u]),b=W*(N=z[u+1]),k=W*(T=z[u+2]),x=W*(D=z[u+3]),c+=O*E,f+=O*N,g+=O*T,v+=O*D,L=P,l=0;W>l;l++)L.r=E,L.g=N,L.b=T,L.a=D,L=L.next;for(l=1;W>l;l++)h=u+((l>F?F:l)<<2),c+=(L.r=E=z[h])*(A=W-l),f+=(L.g=N=z[h+1])*A,g+=(L.b=T=z[h+2])*A,v+=(L.a=D=z[h+3])*A,w+=E,C+=N,S+=T,M+=D,L=L.next;for(R=P,G=B,s=0;i>s;s++)z[u+3]=D=v*Y>>U,0!=D?(D=255/D,z[u]=(c*Y>>U)*D,z[u+1]=(f*Y>>U)*D,z[u+2]=(g*Y>>U)*D):z[u]=z[u+1]=z[u+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=d+((h=s+r+1)s;s++){for(C=S=M=w=f=g=v=c=0,u=s<<2,y=W*(E=z[u]),b=W*(N=z[u+1]),k=W*(T=z[u+2]),x=W*(D=z[u+3]),c+=O*E,f+=O*N,g+=O*T,v+=O*D,L=P,l=0;W>l;l++)L.r=E,L.g=N,L.b=T,L.a=D,L=L.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(L.r=E=z[u])*(A=W-l),f+=(L.g=N=z[u+1])*A,g+=(L.b=T=z[u+2])*A,v+=(L.a=D=z[u+3])*A,w+=E,C+=N,S+=T,M+=D,L=L.next,q>l&&(p+=i);for(u=s,R=P,G=B,o=0;n>o;o++)h=u<<2,z[h+3]=D=v*Y>>U,D>0?(D=255/D,z[h]=(c*Y>>U)*D,z[h+1]=(f*Y>>U)*D,z[h+2]=(g*Y>>U)*D):z[h]=z[h+1]=z[h+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=s+((h=o+W)r)){r|=0;var s=h(t,e,a,i,n);s=c(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function c(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,E,N=t.data,T=r+r+1,D=i-1,A=n-1,z=r+1,j=z*(z+1)/2,F=new m,q=F;for(l=1;T>l;l++)if(q=q.next=new m,l==z)var W=q;q.next=F;var O=null,P=null;d=u=0;var L=H[r],B=I[r];for(o=0;n>o;o++){for(k=x=w=c=f=g=0,v=z*(C=N[u]),y=z*(S=N[u+1]),b=z*(M=N[u+2]),c+=j*C,f+=j*S,g+=j*M,q=F,l=0;z>l;l++)q.r=C,q.g=S,q.b=M,q=q.next;for(l=1;z>l;l++)h=u+((l>D?D:l)<<2),c+=(q.r=C=N[h])*(E=z-l),f+=(q.g=S=N[h+1])*E,g+=(q.b=M=N[h+2])*E,k+=C,x+=S,w+=M,q=q.next;for(O=F,P=W,s=0;i>s;s++)N[u]=c*L>>B,N[u+1]=f*L>>B,N[u+2]=g*L>>B,c-=v,f-=y,g-=b,v-=O.r,y-=O.g,b-=O.b,h=d+((h=s+r+1)s;s++){for(x=w=k=f=g=c=0,u=s<<2,v=z*(C=N[u]),y=z*(S=N[u+1]),b=z*(M=N[u+2]),c+=j*C,f+=j*S,g+=j*M,q=F,l=0;z>l;l++)q.r=C,q.g=S,q.b=M,q=q.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(q.r=C=N[u])*(E=z-l),f+=(q.g=S=N[u+1])*E,g+=(q.b=M=N[u+2])*E,k+=C,x+=S,w+=M,q=q.next,A>l&&(p+=i);for(u=s,O=F,P=W,o=0;n>o;o++)h=u<<2,N[h]=c*L>>B,N[h+1]=f*L>>B,N[h+2]=g*L>>B,c-=v,f-=y,g-=b,v-=O.r,y-=O.g,b-=O.b,h=s+((h=o+z)e?e+360:e)/180*L}function v(t){var e=f(t);return(Math.sin(e)*(1.914602-t*(.004817+14e-6*t))+Math.sin(e+e)*(.019993-101e-6*t)+289e-6*Math.sin(e+e+e))*B}function y(t){return g(t)+v(t)}function b(t){return y(t)-(.00569+.00478*Math.sin((125.04-1934.136*t)*B))*B}function k(t){return(23+(26+(21.448-t*(46.815+t*(59e-5-.001813*t)))/60)/60)*B}function x(t){return k(t)+.00256*Math.cos((125.04-1934.136*t)*B)*B}function w(t){return Math.asin(Math.sin(x(t))*Math.sin(b(t)))}function C(t){return.016708634-t*(42037e-9+1.267e-7*t)}function S(t){var e=C(t),a=f(t),i=g(t),n=Math.tan(x(t)/2);return n*=n,n*Math.sin(2*i)-2*e*Math.sin(a)+4*e*n*Math.sin(a)*Math.cos(2*i)-.5*n*n*Math.sin(4*i)-1.25*e*e*Math.sin(2*a)}function M(t){return[t[0]+180,-t[1]]}function E(t){var e=(t-Date.UTC(2e3,0,1,12))/864e5/36525,a=(d3.time.day.utc.floor(t)-t)/864e5*360-180;return[a-S(e)*R,w(e)*R]}var N={};N["typeof"]="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},N.classCallCheck=function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")},N.createClass=function(){function t(t,e){for(var a=0;a\n \n \n \n \n \n '),this.options.timezones&&(this.layerTimezones=this.layerGlobal.append("g").attr("class","mt-map-timezones")),this.layerCountries=this.layerGlobal.append("g").attr("class","mt-map-countries"),this.options.night&&(this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night")),this.options.heatmap&&(this.layerHeatmap=this.layerGlobal.append("g").attr("class","mt-map-heatmap")),this.layerMarkers=this.layerGlobal.append("g").attr("class","mt-map-markers"),this.options.watermark&&(this.watermark=new O(this,this.options.watermark)),this.options.title&&this.buildTitle(),(this.options.exportSvgClient||this.options.exportSvg)&&this.addExportSvgCapability(),this.options.width||window.addEventListener("resize",function(){n.svg.attr("width",n.getWidth()),n.svg.attr("height",n.getHeight()),n.rescale()}),this.loadGeometries()}return N.createClass(t,[{key:"enrichData",value:function(){var t=this;this.maptable.rawData.forEach(function(e){e.longitude=parseFloat(e[t.options.longitudeKey]),e.latitude=parseFloat(e[t.options.latitudeKey]);var a=[0,0];Number.isNaN(e.longitude)||Number.isNaN(e.latitude)||(a=t.projection([e.longitude,e.latitude])),e.x=a[0],e.y=a[1]})}},{key:"scaleAttributes",value:function(){return Math.pow(this.scale,2/3)}},{key:"getWidth",value:function(){return this.options.width?this.options.width:(this.options.width=this.node.offsetWidth,this.node.offsetWidth)}},{key:"getHeight",value:function(){var t=this.options.title?30:0;return!this.options.height&&this.options.ratioFromWidth?this.getWidth()*this.options.ratioFromWidth*this.options.scaleHeight+t:this.options.height*this.options.scaleHeight+t}},{key:"loadGeometries",value:function(){this.options.filterCountries&&(this.jsonWorld.objects.countries.geometries=this.jsonWorld.objects.countries.geometries.filter(this.options.filterCountries)),this.options.countries&&this.buildCountries(),this.options.heatmap&&this.buildHeatmap(),this.options.night&&this.buildNight(),this.options.timezones&&(this.options.timezones.path||this.options.timezones.pathData)&&this.buildTimezone()}},{key:"buildHeatmap",value:function(){var t=topojson.merge(this.jsonWorld,this.jsonWorld.objects.countries.geometries);if(this.options.heatmap.disableMask||(this.maskHeatmap=this.layerHeatmap.append("defs").append("clipPath").attr("id","mt-map-heatmap-mask"),this.maskHeatmap.datum(t).append("path").attr("class","mt-map-heatmap-mask-paths").attr("d",this.path)),this.imgHeatmap=this.layerHeatmap.append("image").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("x",0).attr("y",0).attr("class","mt-map-heatmap-img"),this.options.heatmap.mask&&(this.imgHeatmap=this.imgHeatmap.attr("clip-path","url(#mt-map-heatmap-mask)")),this.options.heatmap.borders){var e=topojson.mesh(this.jsonWorld,this.jsonWorld.objects.countries,function(t,e){return t!==e});this.bordersHeatmap=this.layerHeatmap.append("g").attr("class","mt-map-heatmap-borders"),this.bordersHeatmap.selectAll("path.mt-map-heatmap-borders-paths").data([t,e]).enter().append("path").attr("class","mt-map-heatmap-borders-paths").attr("fill","none").attr("stroke-width",this.options.heatmap.borders.stroke).attr("stroke",this.options.heatmap.borders.color).attr("style","opacity: "+this.options.heatmap.borders.opacity).attr("d",this.path)}}},{key:"buildNight",value:function(){this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night");var t=d3.geo.circle().angle(90);this.maskNight=this.layerNight.append("defs").append("clipPath").attr("id","mt-map-night-mask"),this.maskNight.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.nightPath=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.path).style("opacity",.1);var e=this.options.night.date||Date.UTC(),a=Date.UTC(e.getUTCFullYear(),e.getUTCMonth(),e.getUTCDate(),0,0,0),i=E(new Date(a));if(this.nightPath.datum(t.origin(M(i))).attr("d",this.path),this.nightPathRight=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+this.getWidth()+"px,0,0)"),this.nightPathLeft=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+-this.getWidth()+"px,0,0)"),!this.options.night.disableSun){var n=this.projection(i);this.sunCircleRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]+this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]-this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]-2*this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight())}}},{key:"buildTimezone",value:function(){var t=this;this.options.timezones.pathData?this.loadTimezone(null,JSON.parse(this.options.timezones.pathData)):this.options.timezones.path&&d3.json(this.options.timezones.path,function(e,a){t.loadTimezone(e,a)})}},{key:"scaleFontSize",value:function(t){return this.getWidth()<700?t*(this.getWidth()/700):t}},{key:"loadTimezone",value:function(t,e){var a=this;this.dataTimezones=topojson.feature(e,e.objects.timezones).features,this.maskTimezone=this.layerTimezones.append("defs").append("clipPath").attr("id","mt-map-timezone-mask"),this.maskTimezone.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.layerTimezones.selectAll(".mt-map-timezone").data(this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places})).enter().insert("path").attr("class","mt-map-timezone").attr("d",this.path).attr("fill",function(t){return t.properties.zone%2===0?"#F4F5F5":"transparent"}).attr("title",function(t){return JSON.stringify(t.properties)}).attr("clip-path","url(#mt-map-timezone-mask)").style("opacity",.6);var i=this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places&&t.properties.zone%1===0&&14!==t.properties.zone}),n=[].concat(N.toConsumableArray(new Map(i.map(function(t){return[t.properties.zone,t]})).values()));this.layerTimezonesText=this.layerTimezones.append("g").attr("class","mt-map-timezones-texts"),this.layerTimezonesText.selectAll(".mt-map-timezone-text").data(n).enter().insert("text").attr("class","mt-map-timezone-text").attr("y",.82*this.getHeight()-5).attr("x",function(t){return(t.properties.zone+10)*(a.getWidth()/24.5)-1}).attr("dx",this.getWidth()/24.5/2).attr("font-size",this.scaleFontSize(9)).attr("font-family","Helevetica, Arial, Sans-Serif").attr("fill","#999").attr("text-anchor","middle").html(function(t){return F.formatDate(a.options.timezones.date||new Date,t.properties.zone)})}},{key:"getMagnitudeScale",value:function(t){var e=this.options.heatmap,a=t.length;if(!a)return function(){return 0};var i=d3.scale.linear().domain([1,a]).range([1,.25]),n=i(a),r=d3.scale.linear().domain([e.circles.min,20]).range([n,0]);return function(t){return r(t)}}},{key:"getDatumScale",value:function(){var t=this;if(!this.options.heatmap.weightByAttribute)return function(){return 1};var e=d3.extent(this.maptable.data,this.options.heatmap.weightByAttribute),a="log"===this.options.heatmap.weightByAttributeScale?d3.scale.log:d3.scale.linear,i=a().domain(e).range([.5,1]);return function(e){var a=t.options.heatmap.weightByAttribute(e);return a?i(a):0}}},{key:"getHeatmapData",value:function(){var t=this,e=d3.select(this.node).append("canvas").attr("id","mt-map-heatmap-canvas").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("style","display: none;"),a=e.node().getContext("2d");a.globalCompositeOperation="multiply";var i=d3.range(this.options.heatmap.circles.min,this.options.heatmap.circles.max,this.options.heatmap.circles.step),n=this.getDatumScale(),r=this.maptable.data.filter(function(t){return n(t)>.1}),s=this.path.context(a),o=this.getMagnitudeScale(r),l=d3.scale.linear().domain([1,0]).range(["#000000","#FFFFFF"]);a.beginPath(),a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle="#ffffff",a.fill(),a.closePath();var h=function(e){var a=t.options.heatmap.circles.colorStrength,i=1+(a-1)/100;return a>1?(2-i)*e+i-1:a*e};r.forEach(function(t){var e=n(t);i.forEach(function(i){var n=h(o(i)*e);n>0&&(a.beginPath(),s(d3.geo.circle().origin([t.longitude,t.latitude]).angle(i-1e-4)()),a.fillStyle=l(n),a.fill(),a.closePath())})}),P.canvasRGBA(e.node(),0,0,this.getWidth(),this.getHeight(),this.options.heatmap.circles.blur),a.beginPath(),a.globalCompositeOperation="screen",a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle=this.options.heatmap.circles.color,a.fill(),a.closePath();var p=e.node().toDataURL();return e.remove(),p}},{key:"updateHeatmap",value:function(){var t=this.getHeatmapData();this.imgHeatmap.attr("xlink:href",t)}},{key:"buildCountries",value:function(){this.dataCountries=topojson.feature(this.jsonWorld,this.jsonWorld.objects.countries).features,this.layerCountries.selectAll(".mt-map-country").data(this.dataCountries).enter().insert("path").attr("class","mt-map-country").attr("d",this.path),this.legendCountry={},this.shouldRenderLegend()&&(this.legendCountry.fill=new W(this))}},{key:"shouldRenderLegend",value:function(){var t=this.options.countries.attr.fill;if(!t)return!1;if(!t.legend||!t.min||!t.max)return!1;if(t.aggregate&&t.aggregate.scale){var e="function"==typeof t.aggregate.scale?t.aggregate.scale.bind(this.maptable)():t.aggregate.scale;if("linear"!==e)return!1}return!0}},{key:"getAllMtMapCountry",value:function(){return this.allMtMapCountry?this.allMtMapCountry:(this.allMtMapCountry=d3.selectAll(this.containerSelector+" .mt-map-country"),this.allMtMapCountry)}},{key:"getAllMtMapMarker",value:function(){return this.allMtMapMarker?this.allMtMapMarker:(this.allMtMapMarker=d3.selectAll(this.containerSelector+" .mt-map-marker"),this.allMtMapMarker)}},{key:"updateCountries",value:function(){var t=this,e=new Map;this.maptable.data.forEach(function(a){var i=a[t.options.countryIdentifierKey];e.has(i)||e.set(i,[]),e.get(i).push(a)}),this.dataCountries.forEach(function(a){a.key=a.properties[t.options.countryIdentifierType];var i=e.get(a.key);a.values=i||[],a.attr={},a.rollupValue={}}),Object.keys(this.options.countries.attr).forEach(function(e){t.setAttrValues(e,t.options.countries.attr[e],t.dataCountries)});var a=this.getAllMtMapCountry().each(function(t){var e=d3.select(this);Object.keys(t.attr).forEach(function(a){e.attr(a,t.attr[a])})});Object.keys(this.options.countries.attr).forEach(function(e){var i=t.options.countries.attr[e];if("object"===("undefined"==typeof i?"undefined":N["typeof"](i))&&i.legend&&void 0!==t.legendCountry[e]){var n=d3.extent(t.dataCountries,function(t){return Number(t.attrProperties[e].value)});t.legendCountry[e].updateExtents(n),a.on("mouseover",function(a){t.legendCountry[e].indiceChange(a.attrProperties[e].value)}).on("mouseout",function(){t.legendCountry[e].indiceChange(NaN)})}}),this.options.countries&&this.options.countries.tooltip&&this.activateTooltip(a,this.tooltipCountriesNode,this.options.countries.tooltip,!0)}},{key:"updateNight",value:function(){var t=this.options.night.date||Date.UTC(),e=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),0,0,0),a=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),23,59,59),i=a-e,n=t-e,r=n/i;this.layerNight.node().style.transform="translateX("+-this.getWidth()*r+"px)"}},{key:"updateTimezones",value:function(){var t=document.querySelectorAll(".mt-map-timezone-text"),e=this.options.timezones.date||new Date;Array.from(t).forEach(function(t){t.textContent=F.formatDate(e,t.__data__.properties.zone)})}},{key:"updateMarkers",value:function(){var t=this,e=function(t){return t.longitude+","+t.latitude};this.dataMarkers=d3.nest().key(e).entries(this.maptable.data).filter(function(t){return 0!==t.values[0].x}),this.dataMarkers.forEach(function(t){t.attr={},t.attrProperties={}}),Object.keys(this.options.markers.attr).forEach(function(e){t.setAttrValues(e,t.options.markers.attr[e],t.dataMarkers)});var a=this.layerMarkers.selectAll(".mt-map-marker").data(this.dataMarkers),i=a.enter();i=this.options.markers.customTag?this.options.markers.customTag(i):i.append("svg:circle");var n=this.options.markers.className?this.options.markers.className:"";i.attr("class","mt-map-marker "+n),a.exit().transition().attr("r",0).attr("fill","#eee").style("opacity",0).remove();var r=this.options.markers.attrX?this.options.markers.attrX:"cx",s=this.options.markers.attrY?this.options.markers.attrY:"cy",o=this.options.markers.attrXDelta?this.options.markers.attrXDelta:0,l=this.options.markers.attrYDelta?this.options.markers.attrYDelta:0,h=a.attr(r,function(t){return t.values[0].x+o}).attr(s,function(t){return t.values[0].y+l});this.getAllMtMapMarker().each(function(t){var e=this;Object.keys(t.attr).forEach(function(a){d3.select(e).attr(a,t.attr[a])})}),this.options.markers.tooltip&&this.activateTooltip(h,this.tooltipMarkersNode,this.options.markers.tooltip,!1),this.rescale()}},{key:"fitContent",value:function(){if(0===this.maptable.data.length)return this.transX=0,this.transY=0,this.scale=1,void this.zoomListener.translate([this.transX,this.transY]).scale(this.scale);var t=d3.extent(this.maptable.data,function(t){return t.x}),e=d3.extent(this.maptable.data,function(t){ diff --git a/docs/maptable.min.js b/docs/maptable.min.js index 1234261..7577103 100644 --- a/docs/maptable.min.js +++ b/docs/maptable.min.js @@ -1,5 +1,5 @@ /** - * MapTable 2.5.0 - License MIT - Build: Fri Jun 14 2024 12:48:26 GMT+0545 (Nepal Time) + * MapTable 2.5.0 - License MIT - Build: Fri Jun 14 2024 13:23:16 GMT+0545 (Nepal Time) */ this.d3=this.d3||{},this.d3.maptable=function(){"use strict";function t(t,e,a){e.forEach(function(e){var a=document.createElement("option");a.setAttribute("value",e.value),a.innerText=e.text,t.appendChild(a)}),t.value=a}function e(t,e,a){return"="===e?parseInt(t,10)===parseInt(a,10):"≠"===e?parseInt(t,10)!==parseInt(a,10)&&""!==t&&""!==a:">"===e?parseInt(t,10)>parseInt(a,10)&&""!==t&&""!==a:"<"===e?parseInt(t,10)=parseInt(a,10)&&""!==t&&""!==a:"≤"===e?parseInt(t,10)<=parseInt(a,10)&&""!==t&&""!==a:!0}function a(){for(var t={},e=void 0,i=[].splice.call(arguments,0),n={}.toString;i.length>0;)e=i.splice(0,1)[0],"[object Object]"===n.call(e)&&Object.keys(e).forEach(function(i){"[object Object]"===n.call(e[i])?t[i]=a(t[i]||{},e[i]):t[i]=e[i]});return t}function i(t){var e=t.charAt(0).toUpperCase()+t.slice(1);return e.replace(/_/g," ")}function n(t){return t.toLowerCase().replace(/ /g,"_").replace(/"/g,"").replace(/'/g,"")}function r(t){if(!t||""===t)return null;var e=t.toString().replace(/[^0-9.]+|\s+/gim,"");return""!==e?Number(e):null}function s(t,e){t.sort(function(t,e){return t-e});var a=e/100*(t.length-1),i=void 0;if(Math.floor(a)===a)i=t[a];else{var n=Math.floor(a),r=a-n;i=t[n]+(t[n+1]-t[n])*r}return i}function o(t){if(!t)return t;for(var e=[],a=0,i=t.length;i>a;a+=1)-1===e.indexOf(t[a])&&""!==t[a]&&e.push(t[a]);return e}function l(t,e,a,i){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLImageElement&&!t instanceof HTMLImageElement)return;var n=t.naturalWidth,r=t.naturalHeight;if("string"==typeof e)var e=document.getElementById(e);else if("undefined"!=typeof HTMLCanvasElement&&!e instanceof HTMLCanvasElement)return;e.style.width=n+"px",e.style.height=r+"px",e.width=n,e.height=r;var s=e.getContext("2d");s.clearRect(0,0,n,r),s.drawImage(t,0,0),Number.isNaN(a)||1>a||(i?p(e,0,0,n,r,a):d(e,0,0,n,r,a))}function h(t,e,a,i,n){if("string"==typeof t)var t=document.getElementById(t);else if("undefined"!=typeof HTMLCanvasElement&&!t instanceof HTMLCanvasElement)return;var r,s=t.getContext("2d");try{try{r=s.getImageData(e,a,i,n)}catch(o){throw new Error("unable to access local image data: "+o)}}catch(o){throw new Error("unable to access image data: "+o)}return r}function p(t,e,a,i,n,r){if(!(Number.isNaN(r)||1>r)){r|=0;var s=h(t,e,a,i,n);s=u(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function u(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,E,N,T,D,A,z=t.data,j=r+r+1,F=i-1,q=n-1,W=r+1,O=W*(W+1)/2,P=new m,L=P;for(l=1;j>l;l++)if(L=L.next=new m,l==W)var B=L;L.next=P;var R=null,G=null;d=u=0;var Y=H[r],U=I[r];for(o=0;n>o;o++){for(w=C=S=M=c=f=g=v=0,y=W*(E=z[u]),b=W*(N=z[u+1]),k=W*(T=z[u+2]),x=W*(D=z[u+3]),c+=O*E,f+=O*N,g+=O*T,v+=O*D,L=P,l=0;W>l;l++)L.r=E,L.g=N,L.b=T,L.a=D,L=L.next;for(l=1;W>l;l++)h=u+((l>F?F:l)<<2),c+=(L.r=E=z[h])*(A=W-l),f+=(L.g=N=z[h+1])*A,g+=(L.b=T=z[h+2])*A,v+=(L.a=D=z[h+3])*A,w+=E,C+=N,S+=T,M+=D,L=L.next;for(R=P,G=B,s=0;i>s;s++)z[u+3]=D=v*Y>>U,0!=D?(D=255/D,z[u]=(c*Y>>U)*D,z[u+1]=(f*Y>>U)*D,z[u+2]=(g*Y>>U)*D):z[u]=z[u+1]=z[u+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=d+((h=s+r+1)s;s++){for(C=S=M=w=f=g=v=c=0,u=s<<2,y=W*(E=z[u]),b=W*(N=z[u+1]),k=W*(T=z[u+2]),x=W*(D=z[u+3]),c+=O*E,f+=O*N,g+=O*T,v+=O*D,L=P,l=0;W>l;l++)L.r=E,L.g=N,L.b=T,L.a=D,L=L.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(L.r=E=z[u])*(A=W-l),f+=(L.g=N=z[u+1])*A,g+=(L.b=T=z[u+2])*A,v+=(L.a=D=z[u+3])*A,w+=E,C+=N,S+=T,M+=D,L=L.next,q>l&&(p+=i);for(u=s,R=P,G=B,o=0;n>o;o++)h=u<<2,z[h+3]=D=v*Y>>U,D>0?(D=255/D,z[h]=(c*Y>>U)*D,z[h+1]=(f*Y>>U)*D,z[h+2]=(g*Y>>U)*D):z[h]=z[h+1]=z[h+2]=0,c-=y,f-=b,g-=k,v-=x,y-=R.r,b-=R.g,k-=R.b,x-=R.a,h=s+((h=o+W)r)){r|=0;var s=h(t,e,a,i,n);s=c(s,e,a,i,n,r),t.getContext("2d").putImageData(s,e,a)}}function c(t,e,a,i,n,r){var s,o,l,h,p,u,d,c,f,g,v,y,b,k,x,w,C,S,M,E,N=t.data,T=r+r+1,D=i-1,A=n-1,z=r+1,j=z*(z+1)/2,F=new m,q=F;for(l=1;T>l;l++)if(q=q.next=new m,l==z)var W=q;q.next=F;var O=null,P=null;d=u=0;var L=H[r],B=I[r];for(o=0;n>o;o++){for(k=x=w=c=f=g=0,v=z*(C=N[u]),y=z*(S=N[u+1]),b=z*(M=N[u+2]),c+=j*C,f+=j*S,g+=j*M,q=F,l=0;z>l;l++)q.r=C,q.g=S,q.b=M,q=q.next;for(l=1;z>l;l++)h=u+((l>D?D:l)<<2),c+=(q.r=C=N[h])*(E=z-l),f+=(q.g=S=N[h+1])*E,g+=(q.b=M=N[h+2])*E,k+=C,x+=S,w+=M,q=q.next;for(O=F,P=W,s=0;i>s;s++)N[u]=c*L>>B,N[u+1]=f*L>>B,N[u+2]=g*L>>B,c-=v,f-=y,g-=b,v-=O.r,y-=O.g,b-=O.b,h=d+((h=s+r+1)s;s++){for(x=w=k=f=g=c=0,u=s<<2,v=z*(C=N[u]),y=z*(S=N[u+1]),b=z*(M=N[u+2]),c+=j*C,f+=j*S,g+=j*M,q=F,l=0;z>l;l++)q.r=C,q.g=S,q.b=M,q=q.next;for(p=i,l=1;r>=l;l++)u=p+s<<2,c+=(q.r=C=N[u])*(E=z-l),f+=(q.g=S=N[u+1])*E,g+=(q.b=M=N[u+2])*E,k+=C,x+=S,w+=M,q=q.next,A>l&&(p+=i);for(u=s,O=F,P=W,o=0;n>o;o++)h=u<<2,N[h]=c*L>>B,N[h+1]=f*L>>B,N[h+2]=g*L>>B,c-=v,f-=y,g-=b,v-=O.r,y-=O.g,b-=O.b,h=s+((h=o+z)e?e+360:e)/180*L}function v(t){var e=f(t);return(Math.sin(e)*(1.914602-t*(.004817+14e-6*t))+Math.sin(e+e)*(.019993-101e-6*t)+289e-6*Math.sin(e+e+e))*B}function y(t){return g(t)+v(t)}function b(t){return y(t)-(.00569+.00478*Math.sin((125.04-1934.136*t)*B))*B}function k(t){return(23+(26+(21.448-t*(46.815+t*(59e-5-.001813*t)))/60)/60)*B}function x(t){return k(t)+.00256*Math.cos((125.04-1934.136*t)*B)*B}function w(t){return Math.asin(Math.sin(x(t))*Math.sin(b(t)))}function C(t){return.016708634-t*(42037e-9+1.267e-7*t)}function S(t){var e=C(t),a=f(t),i=g(t),n=Math.tan(x(t)/2);return n*=n,n*Math.sin(2*i)-2*e*Math.sin(a)+4*e*n*Math.sin(a)*Math.cos(2*i)-.5*n*n*Math.sin(4*i)-1.25*e*e*Math.sin(2*a)}function M(t){return[t[0]+180,-t[1]]}function E(t){var e=(t-Date.UTC(2e3,0,1,12))/864e5/36525,a=(d3.time.day.utc.floor(t)-t)/864e5*360-180;return[a-S(e)*R,w(e)*R]}var N={};N["typeof"]="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},N.classCallCheck=function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")},N.createClass=function(){function t(t,e){for(var a=0;a\n \n \n \n \n \n '),this.options.timezones&&(this.layerTimezones=this.layerGlobal.append("g").attr("class","mt-map-timezones")),this.layerCountries=this.layerGlobal.append("g").attr("class","mt-map-countries"),this.options.night&&(this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night")),this.options.heatmap&&(this.layerHeatmap=this.layerGlobal.append("g").attr("class","mt-map-heatmap")),this.layerMarkers=this.layerGlobal.append("g").attr("class","mt-map-markers"),this.options.watermark&&(this.watermark=new O(this,this.options.watermark)),this.options.title&&this.buildTitle(),(this.options.exportSvgClient||this.options.exportSvg)&&this.addExportSvgCapability(),this.options.width||window.addEventListener("resize",function(){n.svg.attr("width",n.getWidth()),n.svg.attr("height",n.getHeight()),n.rescale()}),this.loadGeometries()}return N.createClass(t,[{key:"enrichData",value:function(){var t=this;this.maptable.rawData.forEach(function(e){e.longitude=parseFloat(e[t.options.longitudeKey]),e.latitude=parseFloat(e[t.options.latitudeKey]);var a=[0,0];Number.isNaN(e.longitude)||Number.isNaN(e.latitude)||(a=t.projection([e.longitude,e.latitude])),e.x=a[0],e.y=a[1]})}},{key:"scaleAttributes",value:function(){return Math.pow(this.scale,2/3)}},{key:"getWidth",value:function(){return this.options.width?this.options.width:(this.options.width=this.node.offsetWidth,this.node.offsetWidth)}},{key:"getHeight",value:function(){var t=this.options.title?30:0;return!this.options.height&&this.options.ratioFromWidth?this.getWidth()*this.options.ratioFromWidth*this.options.scaleHeight+t:this.options.height*this.options.scaleHeight+t}},{key:"loadGeometries",value:function(){this.options.filterCountries&&(this.jsonWorld.objects.countries.geometries=this.jsonWorld.objects.countries.geometries.filter(this.options.filterCountries)),this.options.countries&&this.buildCountries(),this.options.heatmap&&this.buildHeatmap(),this.options.night&&this.buildNight(),this.options.timezones&&(this.options.timezones.path||this.options.timezones.pathData)&&this.buildTimezone()}},{key:"buildHeatmap",value:function(){var t=topojson.merge(this.jsonWorld,this.jsonWorld.objects.countries.geometries);if(this.options.heatmap.disableMask||(this.maskHeatmap=this.layerHeatmap.append("defs").append("clipPath").attr("id","mt-map-heatmap-mask"),this.maskHeatmap.datum(t).append("path").attr("class","mt-map-heatmap-mask-paths").attr("d",this.path)),this.imgHeatmap=this.layerHeatmap.append("image").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("x",0).attr("y",0).attr("class","mt-map-heatmap-img"),this.options.heatmap.mask&&(this.imgHeatmap=this.imgHeatmap.attr("clip-path","url(#mt-map-heatmap-mask)")),this.options.heatmap.borders){var e=topojson.mesh(this.jsonWorld,this.jsonWorld.objects.countries,function(t,e){return t!==e});this.bordersHeatmap=this.layerHeatmap.append("g").attr("class","mt-map-heatmap-borders"),this.bordersHeatmap.selectAll("path.mt-map-heatmap-borders-paths").data([t,e]).enter().append("path").attr("class","mt-map-heatmap-borders-paths").attr("fill","none").attr("stroke-width",this.options.heatmap.borders.stroke).attr("stroke",this.options.heatmap.borders.color).attr("style","opacity: "+this.options.heatmap.borders.opacity).attr("d",this.path)}}},{key:"buildNight",value:function(){this.layerNight=this.layerGlobal.append("g").attr("class","mt-map-night");var t=d3.geo.circle().angle(90);this.maskNight=this.layerNight.append("defs").append("clipPath").attr("id","mt-map-night-mask"),this.maskNight.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.nightPath=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.path).style("opacity",.1);var e=this.options.night.date||Date.UTC(),a=Date.UTC(e.getUTCFullYear(),e.getUTCMonth(),e.getUTCDate(),0,0,0),i=E(new Date(a));if(this.nightPath.datum(t.origin(M(i))).attr("d",this.path),this.nightPathRight=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+this.getWidth()+"px,0,0)"),this.nightPathLeft=this.layerNight.append("path").attr("class","mt-map-night-layer"+(this.options.night.cssBlur?" mt-blur":"")).attr("filter",this.options.night.cssBlur?void 0:"url(#blur)").attr("clip-path","url(#mt-map-night-mask)").attr("d",this.nightPath.attr("d")).style("opacity",.1).style("transform","translate3d("+-this.getWidth()+"px,0,0)"),!this.options.night.disableSun){var n=this.projection(i);this.sunCircleRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXRight=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]+this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-right").attr("cx",n[0]-this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight()),this.sunCircleXLeft=this.layerNight.append("svg:circle").attr("class","mt-map-sun-xright").attr("cx",n[0]-2*this.getWidth()).attr("cy",n[1]).attr("fill","url(#sunGradient)").attr("r",.35*this.getHeight())}}},{key:"buildTimezone",value:function(){var t=this;this.options.timezones.pathData?this.loadTimezone(null,JSON.parse(this.options.timezones.pathData)):this.options.timezones.path&&d3.json(this.options.timezones.path,function(e,a){t.loadTimezone(e,a)})}},{key:"scaleFontSize",value:function(t){return this.getWidth()<700?t*(this.getWidth()/700):t}},{key:"loadTimezone",value:function(t,e){var a=this;this.dataTimezones=topojson.feature(e,e.objects.timezones).features,this.maskTimezone=this.layerTimezones.append("defs").append("clipPath").attr("id","mt-map-timezone-mask"),this.maskTimezone.append("rect").attr("x",0).attr("y",30).attr("width",this.getWidth()).attr("height",.82*this.getHeight()-30),this.layerTimezones.selectAll(".mt-map-timezone").data(this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places})).enter().insert("path").attr("class","mt-map-timezone").attr("d",this.path).attr("fill",function(t){return t.properties.zone%2===0?"#F4F5F5":"transparent"}).attr("title",function(t){return JSON.stringify(t.properties)}).attr("clip-path","url(#mt-map-timezone-mask)").style("opacity",.6);var i=this.dataTimezones.filter(function(t){return"Antarctica"!==t.properties.places&&t.properties.zone%1===0&&14!==t.properties.zone}),n=[].concat(N.toConsumableArray(new Map(i.map(function(t){return[t.properties.zone,t]})).values()));this.layerTimezonesText=this.layerTimezones.append("g").attr("class","mt-map-timezones-texts"),this.layerTimezonesText.selectAll(".mt-map-timezone-text").data(n).enter().insert("text").attr("class","mt-map-timezone-text").attr("y",.82*this.getHeight()-5).attr("x",function(t){return(t.properties.zone+10)*(a.getWidth()/24.5)-1}).attr("dx",this.getWidth()/24.5/2).attr("font-size",this.scaleFontSize(9)).attr("font-family","Helevetica, Arial, Sans-Serif").attr("fill","#999").attr("text-anchor","middle").html(function(t){return F.formatDate(a.options.timezones.date||new Date,t.properties.zone)})}},{key:"getMagnitudeScale",value:function(t){var e=this.options.heatmap,a=t.length;if(!a)return function(){return 0};var i=d3.scale.linear().domain([1,a]).range([1,.25]),n=i(a),r=d3.scale.linear().domain([e.circles.min,20]).range([n,0]);return function(t){return r(t)}}},{key:"getDatumScale",value:function(){var t=this;if(!this.options.heatmap.weightByAttribute)return function(){return 1};var e=d3.extent(this.maptable.data,this.options.heatmap.weightByAttribute),a="log"===this.options.heatmap.weightByAttributeScale?d3.scale.log:d3.scale.linear,i=a().domain(e).range([.5,1]);return function(e){var a=t.options.heatmap.weightByAttribute(e);return a?i(a):0}}},{key:"getHeatmapData",value:function(){var t=this,e=d3.select(this.node).append("canvas").attr("id","mt-map-heatmap-canvas").attr("width",this.getWidth()).attr("height",this.getHeight()).attr("style","display: none;"),a=e.node().getContext("2d");a.globalCompositeOperation="multiply";var i=d3.range(this.options.heatmap.circles.min,this.options.heatmap.circles.max,this.options.heatmap.circles.step),n=this.getDatumScale(),r=this.maptable.data.filter(function(t){return n(t)>.1}),s=this.path.context(a),o=this.getMagnitudeScale(r),l=d3.scale.linear().domain([1,0]).range(["#000000","#FFFFFF"]);a.beginPath(),a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle="#ffffff",a.fill(),a.closePath();var h=function(e){var a=t.options.heatmap.circles.colorStrength,i=1+(a-1)/100;return a>1?(2-i)*e+i-1:a*e};r.forEach(function(t){var e=n(t);i.forEach(function(i){var n=h(o(i)*e);n>0&&(a.beginPath(),s(d3.geo.circle().origin([t.longitude,t.latitude]).angle(i-1e-4)()),a.fillStyle=l(n),a.fill(),a.closePath())})}),P.canvasRGBA(e.node(),0,0,this.getWidth(),this.getHeight(),this.options.heatmap.circles.blur),a.beginPath(),a.globalCompositeOperation="screen",a.rect(0,0,this.getWidth(),this.getHeight()),a.fillStyle=this.options.heatmap.circles.color,a.fill(),a.closePath();var p=e.node().toDataURL();return e.remove(),p}},{key:"updateHeatmap",value:function(){var t=this.getHeatmapData();this.imgHeatmap.attr("xlink:href",t)}},{key:"buildCountries",value:function(){this.dataCountries=topojson.feature(this.jsonWorld,this.jsonWorld.objects.countries).features,this.layerCountries.selectAll(".mt-map-country").data(this.dataCountries).enter().insert("path").attr("class","mt-map-country").attr("d",this.path),this.legendCountry={},this.shouldRenderLegend()&&(this.legendCountry.fill=new W(this))}},{key:"shouldRenderLegend",value:function(){var t=this.options.countries.attr.fill;if(!t)return!1;if(!t.legend||!t.min||!t.max)return!1;if(t.aggregate&&t.aggregate.scale){var e="function"==typeof t.aggregate.scale?t.aggregate.scale.bind(this.maptable)():t.aggregate.scale;if("linear"!==e)return!1}return!0}},{key:"getAllMtMapCountry",value:function(){return this.allMtMapCountry?this.allMtMapCountry:(this.allMtMapCountry=d3.selectAll(this.containerSelector+" .mt-map-country"),this.allMtMapCountry)}},{key:"getAllMtMapMarker",value:function(){return this.allMtMapMarker?this.allMtMapMarker:(this.allMtMapMarker=d3.selectAll(this.containerSelector+" .mt-map-marker"),this.allMtMapMarker)}},{key:"updateCountries",value:function(){var t=this,e=new Map;this.maptable.data.forEach(function(a){var i=a[t.options.countryIdentifierKey];e.has(i)||e.set(i,[]),e.get(i).push(a)}),this.dataCountries.forEach(function(a){a.key=a.properties[t.options.countryIdentifierType];var i=e.get(a.key);a.values=i||[],a.attr={},a.rollupValue={}}),Object.keys(this.options.countries.attr).forEach(function(e){t.setAttrValues(e,t.options.countries.attr[e],t.dataCountries)});var a=this.getAllMtMapCountry().each(function(t){var e=d3.select(this);Object.keys(t.attr).forEach(function(a){e.attr(a,t.attr[a])})});Object.keys(this.options.countries.attr).forEach(function(e){var i=t.options.countries.attr[e];if("object"===("undefined"==typeof i?"undefined":N["typeof"](i))&&i.legend&&void 0!==t.legendCountry[e]){var n=d3.extent(t.dataCountries,function(t){return Number(t.attrProperties[e].value)});t.legendCountry[e].updateExtents(n),a.on("mouseover",function(a){t.legendCountry[e].indiceChange(a.attrProperties[e].value)}).on("mouseout",function(){t.legendCountry[e].indiceChange(NaN)})}}),this.options.countries&&this.options.countries.tooltip&&this.activateTooltip(a,this.tooltipCountriesNode,this.options.countries.tooltip,!0)}},{key:"updateNight",value:function(){var t=this.options.night.date||Date.UTC(),e=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),0,0,0),a=Date.UTC(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),23,59,59),i=a-e,n=t-e,r=n/i;this.layerNight.node().style.transform="translateX("+-this.getWidth()*r+"px)"}},{key:"updateTimezones",value:function(){var t=document.querySelectorAll(".mt-map-timezone-text"),e=this.options.timezones.date||new Date;Array.from(t).forEach(function(t){t.textContent=F.formatDate(e,t.__data__.properties.zone)})}},{key:"updateMarkers",value:function(){var t=this,e=function(t){return t.longitude+","+t.latitude};this.dataMarkers=d3.nest().key(e).entries(this.maptable.data).filter(function(t){return 0!==t.values[0].x}),this.dataMarkers.forEach(function(t){t.attr={},t.attrProperties={}}),Object.keys(this.options.markers.attr).forEach(function(e){t.setAttrValues(e,t.options.markers.attr[e],t.dataMarkers)});var a=this.layerMarkers.selectAll(".mt-map-marker").data(this.dataMarkers),i=a.enter();i=this.options.markers.customTag?this.options.markers.customTag(i):i.append("svg:circle");var n=this.options.markers.className?this.options.markers.className:"";i.attr("class","mt-map-marker "+n),a.exit().transition().attr("r",0).attr("fill","#eee").style("opacity",0).remove();var r=this.options.markers.attrX?this.options.markers.attrX:"cx",s=this.options.markers.attrY?this.options.markers.attrY:"cy",o=this.options.markers.attrXDelta?this.options.markers.attrXDelta:0,l=this.options.markers.attrYDelta?this.options.markers.attrYDelta:0,h=a.attr(r,function(t){return t.values[0].x+o}).attr(s,function(t){return t.values[0].y+l});this.getAllMtMapMarker().each(function(t){var e=this;Object.keys(t.attr).forEach(function(a){d3.select(e).attr(a,t.attr[a])})}),this.options.markers.tooltip&&this.activateTooltip(h,this.tooltipMarkersNode,this.options.markers.tooltip,!1),this.rescale()}},{key:"fitContent",value:function(){if(0===this.maptable.data.length)return this.transX=0,this.transY=0,this.scale=1,void this.zoomListener.translate([this.transX,this.transY]).scale(this.scale);var t=d3.extent(this.maptable.data,function(t){return t.x}),e=d3.extent(this.maptable.data,function(t){ diff --git a/src/maptable.css b/src/maptable.css index 9ef1046..c068658 100755 --- a/src/maptable.css +++ b/src/maptable.css @@ -152,5 +152,5 @@ } .display-none { - display: none !important; + display: none; } \ No newline at end of file