UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

350 lines (288 loc) 33.2 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.MapPopover = undefined; var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _class, _temp; var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n ', '\n font-size: 11px;\n font-weight: 500;\n background-color: ', ';\n color: ', ';\n z-index: 1001;\n position: absolute;\n overflow-x: auto;\n\n .gutter {\n height: 6px;\n }\n\n table {\n margin: 2px 12px 12px 12px;\n width: auto;\n\n tbody {\n border-top: transparent;\n border-bottom: transparent;\n }\n\n td {\n border-color: transparent;\n padding: 4px;\n color: ', ';\n }\n\n td.row__value {\n text-align: right;\n font-weight: 500;\n color: ', ';\n }\n }\n'], ['\n ', '\n font-size: 11px;\n font-weight: 500;\n background-color: ', ';\n color: ', ';\n z-index: 1001;\n position: absolute;\n overflow-x: auto;\n\n .gutter {\n height: 6px;\n }\n\n table {\n margin: 2px 12px 12px 12px;\n width: auto;\n\n tbody {\n border-top: transparent;\n border-bottom: transparent;\n }\n\n td {\n border-color: transparent;\n padding: 4px;\n color: ', ';\n }\n\n td.row__value {\n text-align: right;\n font-weight: 500;\n color: ', ';\n }\n }\n']), _templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n position: absolute;\n left: 50%;\n transform: rotate(30deg);\n top: 10px;\n color: ', ';\n\n :hover {\n cursor: pointer;\n color: ', ';\n }\n'], ['\n position: absolute;\n left: 50%;\n transform: rotate(30deg);\n top: 10px;\n color: ', ';\n\n :hover {\n cursor: pointer;\n color: ', ';\n }\n']), _templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n color: ', ';\n font-size: 12px;\n letter-spacing: 0.43px;\n text-transform: capitalize;\n padding-left: 14px;\n margin-top: 12px;\n\n svg {\n margin-right: 4px;\n }\n'], ['\n color: ', ';\n font-size: 12px;\n letter-spacing: 0.43px;\n text-transform: capitalize;\n padding-left: 14px;\n margin-top: 12px;\n\n svg {\n margin-right: 4px;\n }\n']); // Copyright (c) 2018 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _styledComponents3 = require('../common/styled-components'); var _icons = require('../common/icons'); var _defaultSettings = require('../../constants/default-settings'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var MAX_WIDTH = 400; var MAX_HEIGHT = 600; var StyledMapPopover = _styledComponents2.default.div(_templateObject, function (props) { return props.theme.scrollBar; }, function (props) { return props.theme.panelBackground; }, function (props) { return props.theme.textColor; }, function (props) { return props.theme.textColor; }, function (props) { return props.theme.textColorHl; }); var StyledPin = _styledComponents2.default.div(_templateObject2, function (props) { return props.theme.primaryBtnBgd; }, function (props) { return props.theme.linkBtnColor; }); var StyledLayerName = _styledComponents3.CenterFlexbox.extend(_templateObject3, function (props) { return props.theme.textColorHl; }); var MapPopover = exports.MapPopover = (_temp = _class = function (_Component) { (0, _inherits3.default)(MapPopover, _Component); function MapPopover(props) { (0, _classCallCheck3.default)(this, MapPopover); var _this = (0, _possibleConstructorReturn3.default)(this, (MapPopover.__proto__ || Object.getPrototypeOf(MapPopover)).call(this, props)); _this.state = { isMouseOver: false, width: 380, height: 160 }; return _this; } (0, _createClass3.default)(MapPopover, [{ key: 'componentDidMount', value: function componentDidMount() { this._setContainerSize(); } }, { key: 'componentDidUpdate', value: function componentDidUpdate() { this._setContainerSize(); } }, { key: '_setContainerSize', value: function _setContainerSize() { var node = this.popover; if (!node) { return; } var width = Math.min(node.scrollWidth, MAX_WIDTH); var height = Math.min(node.scrollHeight, MAX_HEIGHT); if (width !== this.state.width || height !== this.state.height) { this.setState({ width: width, height: height }); } } }, { key: '_getPosition', value: function _getPosition(x, y) { var topOffset = 30; var leftOffset = 30; var mapState = this.props.mapState; var _state = this.state, width = _state.width, height = _state.height; var pos = {}; if (x + leftOffset + width > mapState.width) { pos.right = mapState.width - x + leftOffset; } else { pos.left = x + leftOffset; } if (y + topOffset + height > mapState.height) { pos.bottom = 10; } else { pos.top = y + topOffset; } return pos; } }, { key: 'render', value: function render() { var _this2 = this; var _props = this.props, x = _props.x, y = _props.y, isVisible = _props.isVisible, data = _props.data, layer = _props.layer, freezed = _props.freezed, fields = _props.fields, _props$fieldsToShow = _props.fieldsToShow, fieldsToShow = _props$fieldsToShow === undefined ? [] : _props$fieldsToShow; var hidden = !isVisible && !this.state.isMouseOver; var width = this.state.width; if (!data || !layer || !fieldsToShow.length) { return null; } var infoProps = { data: data, layer: layer, fieldsToShow: fieldsToShow, fields: fields }; var style = Number.isFinite(x) && Number.isFinite(y) ? this._getPosition(x, y) : {}; return _react2.default.createElement( StyledMapPopover, { innerRef: function innerRef(comp) { _this2.popover = comp; }, className: (0, _classnames2.default)('map-popover', { hidden: hidden }), style: (0, _extends3.default)({}, style, { maxWidth: width }), onMouseEnter: function onMouseEnter() { _this2.setState({ isMouseOver: true }); }, onMouseLeave: function onMouseLeave() { _this2.setState({ isMouseOver: false }); } }, freezed ? _react2.default.createElement( 'div', { className: 'map-popover__top' }, _react2.default.createElement('div', { className: 'gutter' }), _react2.default.createElement( StyledPin, { className: 'popover-pin', onClick: this.props.onClose }, _react2.default.createElement(_icons.Pin, { height: '16px' }) ) ) : null, _react2.default.createElement( StyledLayerName, { className: 'map-popover__layer-name' }, _react2.default.createElement(_icons.Layers, { height: '12px' }), layer.config.label ), _react2.default.createElement( 'table', { className: 'map-popover__table' }, layer.isAggregated ? _react2.default.createElement(CellInfo, infoProps) : _react2.default.createElement(EntryInfo, infoProps) ) ); } }]); return MapPopover; }(_react.Component), _class.propTypes = { fields: _propTypes2.default.arrayOf(_propTypes2.default.any), fieldsToShow: _propTypes2.default.arrayOf(_propTypes2.default.any), isVisible: _propTypes2.default.bool, layer: _propTypes2.default.object, data: _propTypes2.default.oneOfType([_propTypes2.default.arrayOf(_propTypes2.default.any), _propTypes2.default.object]), freezed: _propTypes2.default.bool, x: _propTypes2.default.number, y: _propTypes2.default.number, onClose: _propTypes2.default.func, mapState: _propTypes2.default.object.isRequired }, _temp); var Row = function Row(_ref) { var name = _ref.name, value = _ref.value, url = _ref.url; // Set 'url' to 'value' if it looks like a url if (!url && value && typeof value === 'string' && value.match(/^http/)) { url = value; } var asImg = /<img>/.test(name); return _react2.default.createElement( 'tr', { className: 'row', key: name }, _react2.default.createElement( 'td', { className: 'row__name' }, name ), _react2.default.createElement( 'td', { className: 'row__value' }, asImg ? _react2.default.createElement('img', { src: value }) : url ? _react2.default.createElement( 'a', { target: '_blank', rel: 'noopener noreferrer', href: url }, value ) : value ) ); }; var EntryInfo = function EntryInfo(_ref2) { var fieldsToShow = _ref2.fieldsToShow, fields = _ref2.fields, data = _ref2.data; return _react2.default.createElement( 'tbody', null, fieldsToShow.map(function (name) { return _react2.default.createElement(EntryInfoRow, { key: name, name: name, fields: fields, data: data }); }) ); }; var EntryInfoRow = function EntryInfoRow(_ref3) { var name = _ref3.name, fields = _ref3.fields, data = _ref3.data; var field = fields.find(function (f) { return f.name === name; }); if (!field) { return null; } var valueIdx = field.tableFieldIndex - 1; var format = _getCellFormat(field.type); return _react2.default.createElement(Row, { name: name, value: format ? format(data[valueIdx]) : data[valueIdx] }); }; var CellInfo = function CellInfo(_ref4) { var data = _ref4.data, layer = _ref4.layer; var _layer$config = layer.config, colorField = _layer$config.colorField, sizeField = _layer$config.sizeField; return _react2.default.createElement( 'tbody', null, _react2.default.createElement(Row, { name: 'total points', key: 'count', value: data.points && data.points.length }), colorField && layer.visualChannels.color ? _react2.default.createElement(Row, { name: layer.getVisualChannelDescription('color').measure, key: 'color', value: data.colorValue || 'N/A' }) : null, sizeField && layer.visualChannels.size ? _react2.default.createElement(Row, { name: layer.getVisualChannelDescription('size').measure, key: 'size', value: data.elevationValue || 'N/A' }) : null ); }; function _getCellFormat(type) { return _defaultSettings.FIELD_DISPLAY_FORMAT[type]; } var MapPopoverFactory = function MapPopoverFactory() { return MapPopover; }; exports.default = MapPopoverFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/map-popover.js"],"names":["MAX_WIDTH","MAX_HEIGHT","StyledMapPopover","styled","div","props","theme","scrollBar","panelBackground","textColor","textColorHl","StyledPin","primaryBtnBgd","linkBtnColor","StyledLayerName","CenterFlexbox","extend","MapPopover","state","isMouseOver","width","height","_setContainerSize","node","popover","Math","min","scrollWidth","scrollHeight","setState","x","y","topOffset","leftOffset","mapState","pos","right","left","bottom","top","isVisible","data","layer","freezed","fields","fieldsToShow","hidden","length","infoProps","style","Number","isFinite","_getPosition","comp","maxWidth","onClose","config","label","isAggregated","Component","propTypes","PropTypes","arrayOf","any","bool","object","oneOfType","number","func","isRequired","Row","name","value","url","match","asImg","test","EntryInfo","map","EntryInfoRow","field","find","f","valueIdx","tableFieldIndex","format","_getCellFormat","type","CellInfo","colorField","sizeField","points","visualChannels","color","getVisualChannelDescription","measure","colorValue","size","elevationValue","FIELD_DISPLAY_FORMAT","MapPopoverFactory"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ibAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;AACA;;AACA;;;;AAEA,IAAMA,YAAY,GAAlB;AACA,IAAMC,aAAa,GAAnB;;AAEA,IAAMC,mBAAmBC,2BAAOC,GAA1B,kBACF;AAAA,SAASC,MAAMC,KAAN,CAAYC,SAArB;AAAA,CADE,EAIgB;AAAA,SAASF,MAAMC,KAAN,CAAYE,eAArB;AAAA,CAJhB,EAKK;AAAA,SAASH,MAAMC,KAAN,CAAYG,SAArB;AAAA,CALL,EA0BS;AAAA,SAASJ,MAAMC,KAAN,CAAYG,SAArB;AAAA,CA1BT,EAgCS;AAAA,SAASJ,MAAMC,KAAN,CAAYI,WAArB;AAAA,CAhCT,CAAN;;AAqCA,IAAMC,YAAYR,2BAAOC,GAAnB,mBAKK;AAAA,SAASC,MAAMC,KAAN,CAAYM,aAArB;AAAA,CALL,EASO;AAAA,SAASP,MAAMC,KAAN,CAAYO,YAArB;AAAA,CATP,CAAN;;AAaA,IAAMC,kBAAkBC,iCAAcC,MAAhC,mBACK;AAAA,SAASX,MAAMC,KAAN,CAAYI,WAArB;AAAA,CADL,CAAN;;IAaaO,U,WAAAA,U;;;AAcX,sBAAYZ,KAAZ,EAAmB;AAAA;;AAAA,sIACXA,KADW;;AAEjB,UAAKa,KAAL,GAAa;AACXC,mBAAa,KADF;AAEXC,aAAO,GAFI;AAGXC,cAAQ;AAHG,KAAb;AAFiB;AAOlB;;;;wCAEmB;AAClB,WAAKC,iBAAL;AACD;;;yCAEoB;AACnB,WAAKA,iBAAL;AACD;;;wCAEmB;AAClB,UAAMC,OAAO,KAAKC,OAAlB;AACA,UAAI,CAACD,IAAL,EAAW;AACT;AACD;;AAED,UAAMH,QAAQK,KAAKC,GAAL,CAASH,KAAKI,WAAd,EAA2B3B,SAA3B,CAAd;AACA,UAAMqB,SAASI,KAAKC,GAAL,CAASH,KAAKK,YAAd,EAA4B3B,UAA5B,CAAf;;AAEA,UAAImB,UAAU,KAAKF,KAAL,CAAWE,KAArB,IAA8BC,WAAW,KAAKH,KAAL,CAAWG,MAAxD,EAAgE;AAC9D,aAAKQ,QAAL,CAAc,EAACT,YAAD,EAAQC,cAAR,EAAd;AACD;AACF;;;iCAEYS,C,EAAGC,C,EAAG;AACjB,UAAMC,YAAY,EAAlB;AACA,UAAMC,aAAa,EAAnB;AAFiB,UAGVC,QAHU,GAGE,KAAK7B,KAHP,CAGV6B,QAHU;AAAA,mBAIO,KAAKhB,KAJZ;AAAA,UAIVE,KAJU,UAIVA,KAJU;AAAA,UAIHC,MAJG,UAIHA,MAJG;;AAKjB,UAAMc,MAAM,EAAZ;AACA,UAAIL,IAAIG,UAAJ,GAAiBb,KAAjB,GAAyBc,SAASd,KAAtC,EAA6C;AAC3Ce,YAAIC,KAAJ,GAAYF,SAASd,KAAT,GAAiBU,CAAjB,GAAqBG,UAAjC;AACD,OAFD,MAEO;AACLE,YAAIE,IAAJ,GAAWP,IAAIG,UAAf;AACD;;AAED,UAAIF,IAAIC,SAAJ,GAAgBX,MAAhB,GAAyBa,SAASb,MAAtC,EAA8C;AAC5Cc,YAAIG,MAAJ,GAAa,EAAb;AACD,OAFD,MAEO;AACLH,YAAII,GAAJ,GAAUR,IAAIC,SAAd;AACD;;AAED,aAAOG,GAAP;AACD;;;6BAEQ;AAAA;;AAAA,mBAUH,KAAK9B,KAVF;AAAA,UAELyB,CAFK,UAELA,CAFK;AAAA,UAGLC,CAHK,UAGLA,CAHK;AAAA,UAILS,SAJK,UAILA,SAJK;AAAA,UAKLC,IALK,UAKLA,IALK;AAAA,UAMLC,KANK,UAMLA,KANK;AAAA,UAOLC,OAPK,UAOLA,OAPK;AAAA,UAQLC,MARK,UAQLA,MARK;AAAA,uCASLC,YATK;AAAA,UASLA,YATK,uCASU,EATV;;AAWP,UAAMC,SAAS,CAACN,SAAD,IAAc,CAAC,KAAKtB,KAAL,CAAWC,WAAzC;AAXO,UAYAC,KAZA,GAYS,KAAKF,KAZd,CAYAE,KAZA;;;AAcP,UAAI,CAACqB,IAAD,IAAS,CAACC,KAAV,IAAmB,CAACG,aAAaE,MAArC,EAA6C;AAC3C,eAAO,IAAP;AACD;;AAED,UAAMC,YAAY,EAACP,UAAD,EAAOC,YAAP,EAAcG,0BAAd,EAA4BD,cAA5B,EAAlB;;AAEA,UAAMK,QACJC,OAAOC,QAAP,CAAgBrB,CAAhB,KAAsBoB,OAAOC,QAAP,CAAgBpB,CAAhB,CAAtB,GAA2C,KAAKqB,YAAL,CAAkBtB,CAAlB,EAAqBC,CAArB,CAA3C,GAAqE,EADvE;;AAGA,aACE;AAAC,wBAAD;AAAA;AACE,oBAAU,wBAAQ;AAChB,mBAAKP,OAAL,GAAe6B,IAAf;AACD,WAHH;AAIE,qBAAW,0BAAW,aAAX,EAA0B,EAACP,cAAD,EAA1B,CAJb;AAKE,4CACKG,KADL;AAEEK,sBAAUlC;AAFZ,YALF;AASE,wBAAc,wBAAM;AAClB,mBAAKS,QAAL,CAAc,EAACV,aAAa,IAAd,EAAd;AACD,WAXH;AAYE,wBAAc,wBAAM;AAClB,mBAAKU,QAAL,CAAc,EAACV,aAAa,KAAd,EAAd;AACD;AAdH;AAgBGwB,kBACC;AAAA;AAAA,YAAK,WAAU,kBAAf;AACE,iDAAK,WAAU,QAAf,GADF;AAEE;AAAC,qBAAD;AAAA,cAAW,WAAU,aAArB,EAAmC,SAAS,KAAKtC,KAAL,CAAWkD,OAAvD;AACE,0CAAC,UAAD,IAAK,QAAO,MAAZ;AADF;AAFF,SADD,GAOG,IAvBN;AAwBE;AAAC,yBAAD;AAAA,YAAiB,WAAU,yBAA3B;AACE,wCAAC,aAAD,IAAQ,QAAO,MAAf,GADF;AAC0Bb,gBAAMc,MAAN,CAAaC;AADvC,SAxBF;AA0BE;AAAA;AAAA,YAAO,WAAU,oBAAjB;AACGf,gBAAMgB,YAAN,GACC,8BAAC,QAAD,EAAcV,SAAd,CADD,GAGC,8BAAC,SAAD,EAAeA,SAAf;AAJJ;AA1BF,OADF;AAoCD;;;EA7H6BW,gB,UACvBC,S,GAAY;AACjBhB,UAAQiB,oBAAUC,OAAV,CAAkBD,oBAAUE,GAA5B,CADS;AAEjBlB,gBAAcgB,oBAAUC,OAAV,CAAkBD,oBAAUE,GAA5B,CAFG;AAGjBvB,aAAWqB,oBAAUG,IAHJ;AAIjBtB,SAAOmB,oBAAUI,MAJA;AAKjBxB,QAAMoB,oBAAUK,SAAV,CAAoB,CAACL,oBAAUC,OAAV,CAAkBD,oBAAUE,GAA5B,CAAD,EAAmCF,oBAAUI,MAA7C,CAApB,CALW;AAMjBtB,WAASkB,oBAAUG,IANF;AAOjBlC,KAAG+B,oBAAUM,MAPI;AAQjBpC,KAAG8B,oBAAUM,MARI;AASjBZ,WAASM,oBAAUO,IATF;AAUjBlC,YAAU2B,oBAAUI,MAAV,CAAiBI;AAVV,C;;;AA+HrB,IAAMC,MAAM,SAANA,GAAM,OAAwB;AAAA,MAAtBC,IAAsB,QAAtBA,IAAsB;AAAA,MAAhBC,KAAgB,QAAhBA,KAAgB;AAAA,MAATC,GAAS,QAATA,GAAS;;AAClC;AACA,MAAI,CAACA,GAAD,IAAQD,KAAR,IAAiB,OAAOA,KAAP,KAAiB,QAAlC,IAA8CA,MAAME,KAAN,CAAY,OAAZ,CAAlD,EAAwE;AACtED,UAAMD,KAAN;AACD;;AAED,MAAMG,QAAQ,QAAQC,IAAR,CAAaL,IAAb,CAAd;AACA,SACE;AAAA;AAAA,MAAI,WAAU,KAAd,EAAoB,KAAKA,IAAzB;AACE;AAAA;AAAA,QAAI,WAAU,WAAd;AAA2BA;AAA3B,KADF;AAEE;AAAA;AAAA,QAAI,WAAU,YAAd;AACGI,cACC,uCAAK,KAAKH,KAAV,GADD,GAEGC,MACF;AAAA;AAAA,UAAG,QAAO,QAAV,EAAmB,KAAI,qBAAvB,EAA6C,MAAMA,GAAnD;AACGD;AADH,OADE,GAKFA;AARJ;AAFF,GADF;AAgBD,CAvBD;;AAyBA,IAAMK,YAAY,SAAZA,SAAY;AAAA,MAAEhC,YAAF,SAAEA,YAAF;AAAA,MAAgBD,MAAhB,SAAgBA,MAAhB;AAAA,MAAwBH,IAAxB,SAAwBA,IAAxB;AAAA,SAChB;AAAA;AAAA;AACGI,iBAAaiC,GAAb,CAAiB;AAAA,aAChB,8BAAC,YAAD,IAAc,KAAKP,IAAnB,EAAyB,MAAMA,IAA/B,EAAqC,QAAQ3B,MAA7C,EAAqD,MAAMH,IAA3D,GADgB;AAAA,KAAjB;AADH,GADgB;AAAA,CAAlB;;AAQA,IAAMsC,eAAe,SAAfA,YAAe,QAA0B;AAAA,MAAxBR,IAAwB,SAAxBA,IAAwB;AAAA,MAAlB3B,MAAkB,SAAlBA,MAAkB;AAAA,MAAVH,IAAU,SAAVA,IAAU;;AAC7C,MAAMuC,QAAQpC,OAAOqC,IAAP,CAAY;AAAA,WAAKC,EAAEX,IAAF,KAAWA,IAAhB;AAAA,GAAZ,CAAd;AACA,MAAI,CAACS,KAAL,EAAY;AACV,WAAO,IAAP;AACD;;AAED,MAAMG,WAAWH,MAAMI,eAAN,GAAwB,CAAzC;AACA,MAAMC,SAASC,eAAeN,MAAMO,IAArB,CAAf;;AAEA,SACE,8BAAC,GAAD,IAAK,MAAMhB,IAAX,EAAiB,OAAOc,SAASA,OAAO5C,KAAK0C,QAAL,CAAP,CAAT,GAAkC1C,KAAK0C,QAAL,CAA1D,GADF;AAGD,CAZD;;AAcA,IAAMK,WAAW,SAAXA,QAAW,QAAmB;AAAA,MAAjB/C,IAAiB,SAAjBA,IAAiB;AAAA,MAAXC,KAAW,SAAXA,KAAW;AAAA,sBACFA,MAAMc,MADJ;AAAA,MAC3BiC,UAD2B,iBAC3BA,UAD2B;AAAA,MACfC,SADe,iBACfA,SADe;;;AAGlC,SACE;AAAA;AAAA;AACE,kCAAC,GAAD,IAAK,MAAM,cAAX,EAA2B,KAAI,OAA/B,EAAuC,OAAOjD,KAAKkD,MAAL,IAAelD,KAAKkD,MAAL,CAAY5C,MAAzE,GADF;AAEG0C,kBAAc/C,MAAMkD,cAAN,CAAqBC,KAAnC,GACC,8BAAC,GAAD;AACE,YAAMnD,MAAMoD,2BAAN,CAAkC,OAAlC,EAA2CC,OADnD;AAEE,WAAI,OAFN;AAGE,aAAOtD,KAAKuD,UAAL,IAAmB;AAH5B,MADD,GAMG,IARN;AASGN,iBAAahD,MAAMkD,cAAN,CAAqBK,IAAlC,GACC,8BAAC,GAAD;AACE,YAAMvD,MAAMoD,2BAAN,CAAkC,MAAlC,EAA0CC,OADlD;AAEE,WAAI,MAFN;AAGE,aAAOtD,KAAKyD,cAAL,IAAuB;AAHhC,MADD,GAMG;AAfN,GADF;AAmBD,CAtBD;;AAwBA,SAASZ,cAAT,CAAwBC,IAAxB,EAA8B;AAC5B,SAAOY,sCAAqBZ,IAArB,CAAP;AACD;;AAED,IAAMa,oBAAqB,SAArBA,iBAAqB;AAAA,SAAMnF,UAAN;AAAA,CAA3B;kBACemF,iB","file":"map-popover.js","sourcesContent":["// Copyright (c) 2018 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {Component} from 'react';\nimport styled from 'styled-components';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport {CenterFlexbox} from 'components/common/styled-components';\nimport {Pin, Layers} from 'components/common/icons';\nimport {FIELD_DISPLAY_FORMAT} from 'constants/default-settings';\n\nconst MAX_WIDTH = 400;\nconst MAX_HEIGHT = 600;\n\nconst StyledMapPopover = styled.div`\n  ${props => props.theme.scrollBar}\n  font-size: 11px;\n  font-weight: 500;\n  background-color: ${props => props.theme.panelBackground};\n  color: ${props => props.theme.textColor};\n  z-index: 1001;\n  position: absolute;\n  overflow-x: auto;\n\n  .gutter {\n    height: 6px;\n  }\n\n  table {\n    margin: 2px 12px 12px 12px;\n    width: auto;\n\n    tbody {\n      border-top: transparent;\n      border-bottom: transparent;\n    }\n\n    td {\n      border-color: transparent;\n      padding: 4px;\n      color: ${props => props.theme.textColor};\n    }\n\n    td.row__value {\n      text-align: right;\n      font-weight: 500;\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nconst StyledPin = styled.div`\n  position: absolute;\n  left: 50%;\n  transform: rotate(30deg);\n  top: 10px;\n  color: ${props => props.theme.primaryBtnBgd};\n\n  :hover {\n    cursor: pointer;\n    color: ${props => props.theme.linkBtnColor};\n  }\n`;\n\nconst StyledLayerName = CenterFlexbox.extend`\n  color: ${props => props.theme.textColorHl};\n  font-size: 12px;\n  letter-spacing: 0.43px;\n  text-transform: capitalize;\n  padding-left: 14px;\n  margin-top: 12px;\n\n  svg {\n    margin-right: 4px;\n  }\n`;\n\nexport class MapPopover extends Component {\n  static propTypes = {\n    fields: PropTypes.arrayOf(PropTypes.any),\n    fieldsToShow: PropTypes.arrayOf(PropTypes.any),\n    isVisible: PropTypes.bool,\n    layer: PropTypes.object,\n    data: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.any), PropTypes.object]),\n    freezed: PropTypes.bool,\n    x: PropTypes.number,\n    y: PropTypes.number,\n    onClose: PropTypes.func,\n    mapState: PropTypes.object.isRequired\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      isMouseOver: false,\n      width: 380,\n      height: 160\n    };\n  }\n\n  componentDidMount() {\n    this._setContainerSize();\n  }\n\n  componentDidUpdate() {\n    this._setContainerSize();\n  }\n\n  _setContainerSize() {\n    const node = this.popover;\n    if (!node) {\n      return;\n    }\n\n    const width = Math.min(node.scrollWidth, MAX_WIDTH);\n    const height = Math.min(node.scrollHeight, MAX_HEIGHT);\n\n    if (width !== this.state.width || height !== this.state.height) {\n      this.setState({width, height});\n    }\n  }\n\n  _getPosition(x, y) {\n    const topOffset = 30;\n    const leftOffset = 30;\n    const {mapState} = this.props;\n    const {width, height} = this.state;\n    const pos = {};\n    if (x + leftOffset + width > mapState.width) {\n      pos.right = mapState.width - x + leftOffset;\n    } else {\n      pos.left = x + leftOffset;\n    }\n\n    if (y + topOffset + height > mapState.height) {\n      pos.bottom = 10;\n    } else {\n      pos.top = y + topOffset;\n    }\n\n    return pos;\n  }\n\n  render() {\n    const {\n      x,\n      y,\n      isVisible,\n      data,\n      layer,\n      freezed,\n      fields,\n      fieldsToShow = []\n    } = this.props;\n    const hidden = !isVisible && !this.state.isMouseOver;\n    const {width} = this.state;\n\n    if (!data || !layer || !fieldsToShow.length) {\n      return null;\n    }\n\n    const infoProps = {data, layer, fieldsToShow, fields};\n\n    const style =\n      Number.isFinite(x) && Number.isFinite(y) ? this._getPosition(x, y) : {};\n\n    return (\n      <StyledMapPopover\n        innerRef={comp => {\n          this.popover = comp;\n        }}\n        className={classnames('map-popover', {hidden})}\n        style={{\n          ...style,\n          maxWidth: width\n        }}\n        onMouseEnter={() => {\n          this.setState({isMouseOver: true});\n        }}\n        onMouseLeave={() => {\n          this.setState({isMouseOver: false});\n        }}\n      >\n        {freezed ? (\n          <div className=\"map-popover__top\">\n            <div className=\"gutter\" />\n            <StyledPin className=\"popover-pin\" onClick={this.props.onClose}>\n              <Pin height=\"16px\" />\n            </StyledPin>\n          </div>\n        ) : null}\n        <StyledLayerName className=\"map-popover__layer-name\">\n          <Layers height=\"12px\"/>{layer.config.label}</StyledLayerName>\n        <table className=\"map-popover__table\">\n          {layer.isAggregated ? (\n            <CellInfo {...infoProps} />\n          ) : (\n            <EntryInfo {...infoProps} />\n          )}\n        </table>\n      </StyledMapPopover>\n    );\n  }\n}\n\nconst Row = ({name, value, url}) => {\n  // Set 'url' to 'value' if it looks like a url\n  if (!url && value && typeof value === 'string' && value.match(/^http/)) {\n    url = value;\n  }\n\n  const asImg = /<img>/.test(name);\n  return (\n    <tr className=\"row\" key={name}>\n      <td className=\"row__name\">{name}</td>\n      <td className=\"row__value\">\n        {asImg ? (\n          <img src={value} />\n        ) : url ? (\n          <a target=\"_blank\" rel=\"noopener noreferrer\" href={url}>\n            {value}\n          </a>\n        ) : (\n          value\n        )}\n      </td>\n    </tr>\n  );\n};\n\nconst EntryInfo = ({fieldsToShow, fields, data}) => (\n  <tbody>\n    {fieldsToShow.map(name => (\n      <EntryInfoRow key={name} name={name} fields={fields} data={data} />\n    ))}\n  </tbody>\n);\n\nconst EntryInfoRow = ({name, fields, data}) => {\n  const field = fields.find(f => f.name === name);\n  if (!field) {\n    return null;\n  }\n\n  const valueIdx = field.tableFieldIndex - 1;\n  const format = _getCellFormat(field.type);\n\n  return (\n    <Row name={name} value={format ? format(data[valueIdx]) : data[valueIdx]} />\n  );\n};\n\nconst CellInfo = ({data, layer}) => {\n  const {colorField, sizeField} = layer.config;\n\n  return (\n    <tbody>\n      <Row name={'total points'} key=\"count\" value={data.points && data.points.length} />\n      {colorField && layer.visualChannels.color ? (\n        <Row\n          name={layer.getVisualChannelDescription('color').measure}\n          key=\"color\"\n          value={data.colorValue || 'N/A'}\n        />\n      ) : null}\n      {sizeField && layer.visualChannels.size ? (\n        <Row\n          name={layer.getVisualChannelDescription('size').measure}\n          key=\"size\"\n          value={data.elevationValue || 'N/A'}\n        />\n      ) : null}\n    </tbody>\n  );\n};\n\nfunction _getCellFormat(type) {\n  return FIELD_DISPLAY_FORMAT[type];\n}\n\nconst MapPopoverFactory =  () => MapPopover;\nexport default MapPopoverFactory;\n"]}