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
JavaScript
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"]}
;