kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
277 lines (275 loc) • 42.4 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.testForCoordinates = exports["default"] = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _classnames = _interopRequireDefault(require("classnames"));
var _geocoding = _interopRequireDefault(require("@mapbox/mapbox-sdk/services/geocoding"));
var _reactIntl = require("react-intl");
var _viewportMercatorProject = require("viewport-mercator-project");
var _constants = require("@kepler.gl/constants");
var _styledComponents2 = require("../common/styled-components");
var _icons = require("../common/icons");
var _utils = require("@kepler.gl/utils");
var _templateObject; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
// matches only valid coordinates
var COORDINATE_REGEX_STRING = '(^[-+]?(?:[1-8]?\\d(?:\\.\\d+)?|90(?:\\.0+)?)),\\s*([-+]?(?:180(?:\\.0+)?|(?:(?:1[0-7]\\d)|(?:[1-9]?\\d))(?:\\.\\d+)?))$';
var COORDINATE_REGEX = RegExp(COORDINATE_REGEX_STRING);
var PLACEHOLDER = 'Enter an address or coordinates, ex 37.79,-122.40';
var debounceTimeout = null;
/**
* Tests if a given query string contains valid coordinates.
* @param query The input string to test for coordinates.
* @returns A tuple where:
* - If valid, returns `[true, longitude, latitude]`.
* - If invalid, returns `[false, query]`.
*/
var testForCoordinates = exports.testForCoordinates = function testForCoordinates(query) {
var isValid = COORDINATE_REGEX.test(query.trim());
if (!isValid) {
return [isValid, query];
}
var tokens = query.trim().split(',');
var latitude = Number(tokens[0]);
var longitude = Number(tokens[1]);
return [isValid, longitude, latitude];
};
var StyledContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n color: ", ";\n\n .geocoder-input {\n box-shadow: ", ";\n\n .geocoder-input__search {\n position: absolute;\n height: ", "px;\n width: 30px;\n padding-left: 6px;\n display: flex;\n align-items: center;\n justify-content: center;\n color: ", ";\n }\n\n input {\n padding: 4px 36px;\n height: ", "px;\n caret-color: unset;\n }\n }\n\n .geocoder-results {\n box-shadow: ", ";\n background-color: ", ";\n position: absolute;\n width: ", "px;\n margin-top: ", "px;\n }\n\n .geocoder-item {\n ", ";\n ", ";\n\n &.active {\n background-color: ", ";\n }\n }\n\n .remove-result {\n position: absolute;\n right: 16px;\n top: 0px;\n height: ", "px;\n display: flex;\n align-items: center;\n\n &:hover {\n cursor: pointer;\n color: ", ";\n }\n }\n"])), function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.boxShadow;
}, function (props) {
return props.theme.geocoderInputHeight;
}, function (props) {
return props.theme.subtextColor;
}, function (props) {
return props.theme.geocoderInputHeight;
}, function (props) {
return props.theme.boxShadow;
}, function (props) {
return props.theme.panelBackground;
}, function (props) {
return Number.isFinite(props.width) ? props.width : props.theme.geocoderWidth;
}, function (props) {
return props.theme.dropdownWapperMargin;
}, function (props) {
return props.theme.dropdownListItem;
}, function (props) {
return props.theme.textTruncate;
}, function (props) {
return props.theme.dropdownListHighlightBg;
}, function (props) {
return props.theme.geocoderInputHeight;
}, function (props) {
return props.theme.textColorHl;
});
var GeoCoder = function GeoCoder(_ref) {
var mapboxApiAccessToken = _ref.mapboxApiAccessToken,
_ref$className = _ref.className,
className = _ref$className === void 0 ? '' : _ref$className,
_ref$limit = _ref.limit,
limit = _ref$limit === void 0 ? 5 : _ref$limit,
_ref$timeout = _ref.timeout,
timeout = _ref$timeout === void 0 ? 300 : _ref$timeout,
_ref$formatItem = _ref.formatItem,
formatItem = _ref$formatItem === void 0 ? function (item) {
return item.place_name;
} : _ref$formatItem,
viewport = _ref.viewport,
onSelected = _ref.onSelected,
onDeleteMarker = _ref.onDeleteMarker,
transitionDuration = _ref.transitionDuration,
pointZoom = _ref.pointZoom,
width = _ref.width,
intl = _ref.intl;
var _useState = (0, _react.useState)(''),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
inputValue = _useState2[0],
setInputValue = _useState2[1];
var _useState3 = (0, _react.useState)(false),
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
showResults = _useState4[0],
setShowResults = _useState4[1];
var _useState5 = (0, _react.useState)(false),
_useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
showDelete = _useState6[0],
setShowDelete = _useState6[1];
var initialResults = [];
var _useState7 = (0, _react.useState)(initialResults),
_useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
results = _useState8[0],
setResults = _useState8[1];
var _useState9 = (0, _react.useState)(0),
_useState10 = (0, _slicedToArray2["default"])(_useState9, 2),
selectedIndex = _useState10[0],
setSelectedIndex = _useState10[1];
var client = (0, _react.useMemo)(function () {
return (0, _utils.isTest)() ? null : (0, _geocoding["default"])({
accessToken: mapboxApiAccessToken
});
}, [mapboxApiAccessToken]);
var onChange = (0, _react.useCallback)(function (event) {
var queryString = event.target.value;
setInputValue(queryString);
var resultCoordinates = testForCoordinates(queryString);
if (resultCoordinates[0]) {
var _resultCoordinates = (0, _slicedToArray2["default"])(resultCoordinates, 3),
_isValid = _resultCoordinates[0],
longitude = _resultCoordinates[1],
latitude = _resultCoordinates[2];
setResults([{
center: [longitude, latitude],
place_name: queryString
}]);
} else {
if (debounceTimeout) {
clearTimeout(debounceTimeout);
}
debounceTimeout = setTimeout( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
var response;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
if (!(limit > 0 && Boolean(queryString))) {
_context.next = 11;
break;
}
_context.prev = 1;
_context.next = 4;
return client.forwardGeocode({
query: queryString,
limit: limit
}).send();
case 4:
response = _context.sent;
if (response.body.features) {
setShowResults(true);
setResults(response.body.features);
}
_context.next = 11;
break;
case 8:
_context.prev = 8;
_context.t0 = _context["catch"](1);
// TODO: show geocode error
// eslint-disable-next-line no-console
console.log(_context.t0);
case 11:
case "end":
return _context.stop();
}
}, _callee, null, [[1, 8]]);
})), timeout);
}
}, [client, limit, timeout, setResults, setShowResults]);
var onBlur = (0, _react.useCallback)(function () {
setTimeout(function () {
setShowResults(false);
}, timeout);
}, [setShowResults, timeout]);
var onFocus = (0, _react.useCallback)(function () {
return setShowResults(true);
}, [setShowResults]);
var onItemSelected = (0, _react.useCallback)(function (item) {
var newViewport = new _viewportMercatorProject.WebMercatorViewport(viewport);
var bbox = item.bbox,
center = item.center;
var gotoViewport = bbox ? newViewport.fitBounds([[bbox[0], bbox[1]], [bbox[2], bbox[3]]]) : {
longitude: center[0],
latitude: center[1],
zoom: pointZoom
};
var longitude = gotoViewport.longitude,
latitude = gotoViewport.latitude,
zoom = gotoViewport.zoom;
onSelected(_objectSpread(_objectSpread({}, viewport), {
longitude: longitude,
latitude: latitude,
zoom: zoom,
transitionDuration: transitionDuration
}), item);
setShowResults(false);
setInputValue(formatItem(item));
setShowDelete(true);
}, [viewport, onSelected, transitionDuration, pointZoom, formatItem]);
var onMarkDeleted = (0, _react.useCallback)(function () {
setShowDelete(false);
setInputValue('');
onDeleteMarker === null || onDeleteMarker === void 0 || onDeleteMarker();
}, [onDeleteMarker]);
var onKeyDown = (0, _react.useCallback)(function (e) {
if (!results || results.length === 0) {
return;
}
switch (e.keyCode) {
case _constants.KeyEvent.DOM_VK_UP:
setSelectedIndex(selectedIndex > 0 ? selectedIndex - 1 : selectedIndex);
break;
case _constants.KeyEvent.DOM_VK_DOWN:
setSelectedIndex(selectedIndex < results.length - 1 ? selectedIndex + 1 : selectedIndex);
break;
case _constants.KeyEvent.DOM_VK_ENTER:
case _constants.KeyEvent.DOM_VK_RETURN:
if (results[selectedIndex]) {
onItemSelected(results[selectedIndex]);
}
break;
default:
break;
}
}, [results, selectedIndex, setSelectedIndex, onItemSelected]);
return /*#__PURE__*/_react["default"].createElement(StyledContainer, {
className: className,
width: width
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "geocoder-input"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "geocoder-input__search"
}, /*#__PURE__*/_react["default"].createElement(_icons.Search, {
height: "20px"
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Input, {
type: "text",
onChange: onChange,
onBlur: onBlur,
onFocus: onFocus,
onKeyDown: onKeyDown,
value: inputValue,
placeholder: intl ? intl.formatMessage({
id: 'geocoder.title',
defaultMessage: PLACEHOLDER
}) : PLACEHOLDER
}), showDelete ? /*#__PURE__*/_react["default"].createElement("div", {
className: "remove-result"
}, /*#__PURE__*/_react["default"].createElement(_icons.Delete, {
height: "12px",
onClick: onMarkDeleted
})) : null), showResults ? /*#__PURE__*/_react["default"].createElement("div", {
className: "geocoder-results"
}, results.map(function (item, index) {
return /*#__PURE__*/_react["default"].createElement("div", {
key: index,
className: (0, _classnames["default"])('geocoder-item', {
active: selectedIndex === index
}),
onClick: function onClick() {
return onItemSelected(item);
}
}, formatItem(item));
})) : null);
};
var _default = exports["default"] = (0, _reactIntl.injectIntl)(GeoCoder);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames","_geocoding","_reactIntl","_viewportMercatorProject","_constants","_styledComponents2","_icons","_utils","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","COORDINATE_REGEX_STRING","COORDINATE_REGEX","RegExp","PLACEHOLDER","debounceTimeout","testForCoordinates","exports","query","isValid","test","trim","tokens","split","latitude","Number","longitude","StyledContainer","styled","div","_taggedTemplateLiteral2","props","theme","textColor","boxShadow","geocoderInputHeight","subtextColor","panelBackground","isFinite","width","geocoderWidth","dropdownWapperMargin","dropdownListItem","textTruncate","dropdownListHighlightBg","textColorHl","GeoCoder","_ref","mapboxApiAccessToken","_ref$className","className","_ref$limit","limit","_ref$timeout","timeout","_ref$formatItem","formatItem","item","place_name","viewport","onSelected","onDeleteMarker","transitionDuration","pointZoom","intl","_useState","useState","_useState2","_slicedToArray2","inputValue","setInputValue","_useState3","_useState4","showResults","setShowResults","_useState5","_useState6","showDelete","setShowDelete","initialResults","_useState7","_useState8","results","setResults","_useState9","_useState10","selectedIndex","setSelectedIndex","client","useMemo","isTest","geocoderService","accessToken","onChange","useCallback","event","queryString","target","value","resultCoordinates","_resultCoordinates","_isValid","center","clearTimeout","setTimeout","_asyncToGenerator2","_regenerator","mark","_callee","response","wrap","_callee$","_context","prev","next","Boolean","forwardGeocode","send","sent","body","features","t0","console","log","stop","onBlur","onFocus","onItemSelected","newViewport","WebMercatorViewport","bbox","gotoViewport","fitBounds","zoom","onMarkDeleted","onKeyDown","keyCode","KeyEvent","DOM_VK_UP","DOM_VK_DOWN","DOM_VK_ENTER","DOM_VK_RETURN","createElement","Search","height","Input","type","placeholder","formatMessage","id","defaultMessage","Delete","onClick","map","index","key","classnames","active","_default","injectIntl"],"sources":["../../src/geocoder/geocoder.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo, useState} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport geocoderService from '@mapbox/mapbox-sdk/services/geocoding';\nimport {injectIntl, IntlShape} from 'react-intl';\nimport {WebMercatorViewport} from 'viewport-mercator-project';\nimport {KeyEvent} from '@kepler.gl/constants';\nimport {Input} from '../common/styled-components';\nimport {Search, Delete} from '../common/icons';\nimport {Viewport} from '@kepler.gl/types';\nimport {isTest} from '@kepler.gl/utils';\n\ntype StyledContainerProps = {\n  width?: number;\n};\n\n// matches only valid coordinates\nconst COORDINATE_REGEX_STRING =\n  '(^[-+]?(?:[1-8]?\\\\d(?:\\\\.\\\\d+)?|90(?:\\\\.0+)?)),\\\\s*([-+]?(?:180(?:\\\\.0+)?|(?:(?:1[0-7]\\\\d)|(?:[1-9]?\\\\d))(?:\\\\.\\\\d+)?))$';\n\nconst COORDINATE_REGEX = RegExp(COORDINATE_REGEX_STRING);\n\nconst PLACEHOLDER = 'Enter an address or coordinates, ex 37.79,-122.40';\n\nlet debounceTimeout: NodeJS.Timeout | null = null;\n\n/**\n * Tests if a given query string contains valid coordinates.\n * @param query The input string to test for coordinates.\n * @returns A tuple where:\n *   - If valid, returns `[true, longitude, latitude]`.\n *   - If invalid, returns `[false, query]`.\n */\nexport const testForCoordinates = (query: string): [true, number, number] | [false, string] => {\n  const isValid = COORDINATE_REGEX.test(query.trim());\n\n  if (!isValid) {\n    return [isValid, query];\n  }\n\n  const tokens = query.trim().split(',');\n  const latitude = Number(tokens[0]);\n  const longitude = Number(tokens[1]);\n\n  return [isValid, longitude, latitude];\n};\n\nconst StyledContainer = styled.div<StyledContainerProps>`\n  position: relative;\n  color: ${props => props.theme.textColor};\n\n  .geocoder-input {\n    box-shadow: ${props => props.theme.boxShadow};\n\n    .geocoder-input__search {\n      position: absolute;\n      height: ${props => props.theme.geocoderInputHeight}px;\n      width: 30px;\n      padding-left: 6px;\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      color: ${props => props.theme.subtextColor};\n    }\n\n    input {\n      padding: 4px 36px;\n      height: ${props => props.theme.geocoderInputHeight}px;\n      caret-color: unset;\n    }\n  }\n\n  .geocoder-results {\n    box-shadow: ${props => props.theme.boxShadow};\n    background-color: ${props => props.theme.panelBackground};\n    position: absolute;\n    width: ${props => (Number.isFinite(props.width) ? props.width : props.theme.geocoderWidth)}px;\n    margin-top: ${props => props.theme.dropdownWapperMargin}px;\n  }\n\n  .geocoder-item {\n    ${props => props.theme.dropdownListItem};\n    ${props => props.theme.textTruncate};\n\n    &.active {\n      background-color: ${props => props.theme.dropdownListHighlightBg};\n    }\n  }\n\n  .remove-result {\n    position: absolute;\n    right: 16px;\n    top: 0px;\n    height: ${props => props.theme.geocoderInputHeight}px;\n    display: flex;\n    align-items: center;\n\n    &:hover {\n      cursor: pointer;\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nexport interface Result {\n  center: [number, number];\n  place_name: string;\n  bbox?: [number, number, number, number];\n  text?: string;\n}\n\nexport type Results = ReadonlyArray<Result>;\n\ntype GeocoderProps = {\n  mapboxApiAccessToken: string;\n  className?: string;\n  limit?: number;\n  timeout?: number;\n  formatItem?: (item: Result) => string;\n  viewport?: Viewport;\n  onSelected: (viewport: Viewport | null, item: Result) => void;\n  onDeleteMarker?: () => void;\n  transitionDuration?: number;\n  pointZoom?: number;\n  width?: number;\n};\n\ntype IntlProps = {\n  intl: IntlShape;\n};\n\nconst GeoCoder: React.FC<GeocoderProps & IntlProps> = ({\n  mapboxApiAccessToken,\n  className = '',\n  limit = 5,\n  timeout = 300,\n  formatItem = item => item.place_name,\n  viewport,\n  onSelected,\n  onDeleteMarker,\n  transitionDuration,\n  pointZoom,\n  width,\n  intl\n}) => {\n  const [inputValue, setInputValue] = useState('');\n  const [showResults, setShowResults] = useState(false);\n  const [showDelete, setShowDelete] = useState(false);\n  const initialResults: Result[] = [];\n  const [results, setResults] = useState(initialResults);\n  const [selectedIndex, setSelectedIndex] = useState(0);\n\n  const client = useMemo(\n    () => (isTest() ? null : geocoderService({accessToken: mapboxApiAccessToken})),\n    [mapboxApiAccessToken]\n  );\n\n  const onChange = useCallback(\n    event => {\n      const queryString = event.target.value;\n      setInputValue(queryString);\n      const resultCoordinates = testForCoordinates(queryString);\n      if (resultCoordinates[0]) {\n        const [_isValid, longitude, latitude] = resultCoordinates;\n        setResults([{center: [longitude, latitude], place_name: queryString}]);\n      } else {\n        if (debounceTimeout) {\n          clearTimeout(debounceTimeout);\n        }\n        debounceTimeout = setTimeout(async () => {\n          if (limit > 0 && Boolean(queryString)) {\n            try {\n              const response = await client\n                .forwardGeocode({\n                  query: queryString,\n                  limit\n                })\n                .send();\n              if (response.body.features) {\n                setShowResults(true);\n                setResults(response.body.features);\n              }\n            } catch (e) {\n              // TODO: show geocode error\n              // eslint-disable-next-line no-console\n              console.log(e);\n            }\n          }\n        }, timeout);\n      }\n    },\n    [client, limit, timeout, setResults, setShowResults]\n  );\n\n  const onBlur = useCallback(() => {\n    setTimeout(() => {\n      setShowResults(false);\n    }, timeout);\n  }, [setShowResults, timeout]);\n\n  const onFocus = useCallback(() => setShowResults(true), [setShowResults]);\n\n  const onItemSelected = useCallback(\n    item => {\n      const newViewport = new WebMercatorViewport(viewport);\n      const {bbox, center} = item;\n\n      const gotoViewport = bbox\n        ? newViewport.fitBounds([\n            [bbox[0], bbox[1]],\n            [bbox[2], bbox[3]]\n          ])\n        : {\n            longitude: center[0],\n            latitude: center[1],\n            zoom: pointZoom\n          };\n\n      const {longitude, latitude, zoom} = gotoViewport;\n\n      onSelected({...viewport, ...{longitude, latitude, zoom, transitionDuration}}, item);\n\n      setShowResults(false);\n      setInputValue(formatItem(item));\n      setShowDelete(true);\n    },\n    [viewport, onSelected, transitionDuration, pointZoom, formatItem]\n  );\n\n  const onMarkDeleted = useCallback(() => {\n    setShowDelete(false);\n    setInputValue('');\n    onDeleteMarker?.();\n  }, [onDeleteMarker]);\n\n  const onKeyDown = useCallback(\n    e => {\n      if (!results || results.length === 0) {\n        return;\n      }\n      switch (e.keyCode) {\n        case KeyEvent.DOM_VK_UP:\n          setSelectedIndex(selectedIndex > 0 ? selectedIndex - 1 : selectedIndex);\n          break;\n        case KeyEvent.DOM_VK_DOWN:\n          setSelectedIndex(selectedIndex < results.length - 1 ? selectedIndex + 1 : selectedIndex);\n          break;\n        case KeyEvent.DOM_VK_ENTER:\n        case KeyEvent.DOM_VK_RETURN:\n          if (results[selectedIndex]) {\n            onItemSelected(results[selectedIndex]);\n          }\n          break;\n        default:\n          break;\n      }\n    },\n    [results, selectedIndex, setSelectedIndex, onItemSelected]\n  );\n\n  return (\n    <StyledContainer className={className} width={width}>\n      <div className=\"geocoder-input\">\n        <div className=\"geocoder-input__search\">\n          <Search height=\"20px\" />\n        </div>\n        <Input\n          type=\"text\"\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          onKeyDown={onKeyDown}\n          value={inputValue}\n          placeholder={\n            intl\n              ? intl.formatMessage({id: 'geocoder.title', defaultMessage: PLACEHOLDER})\n              : PLACEHOLDER\n          }\n        />\n        {showDelete ? (\n          <div className=\"remove-result\">\n            <Delete height=\"12px\" onClick={onMarkDeleted} />\n          </div>\n        ) : null}\n      </div>\n\n      {showResults ? (\n        <div className=\"geocoder-results\">\n          {results.map((item, index) => (\n            <div\n              key={index}\n              className={classnames('geocoder-item', {active: selectedIndex === index})}\n              onClick={() => onItemSelected(item)}\n            >\n              {formatItem(item)}\n            </div>\n          ))}\n        </div>\n      ) : null}\n    </StyledContainer>\n  );\n};\n\nexport default injectIntl(GeoCoder);\n"],"mappings":"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","ignoreList":[]}
;