kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
264 lines (232 loc) • 35.3 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactJsonPretty = _interopRequireDefault(require("react-json-pretty"));
var _userGuides = require("../../constants/user-guides");
var _icons = require("../common/icons");
var _styledComponents2 = require("../common/styled-components");
var _defaultSettings = require("../../constants/default-settings");
var _excluded = ["children"];
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
var NO_OP = function NO_OP() {};
var StyledInput = _styledComponents["default"].input(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n padding: ", ";\n color: ", ";\n height: ", ";\n outline: 0;\n font-size: ", ";\n\n :active,\n :focus,\n &.focus,\n &.active {\n outline: 0;\n }\n"])), function (props) {
return props.theme.inputPadding;
}, function (props) {
return props.error ? 'red' : props.theme.titleColorLT;
}, function (props) {
return props.theme.inputBoxHeight;
}, function (props) {
return props.theme.inputFontSize;
});
var StyledWarning = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-weight: ", ";\n"])), function (props) {
return props.theme.errorColor;
}, function (props) {
return props.theme.selectFontWeightBold;
});
var StyledLink = _styledComponents["default"].a(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration-line: underline !important;\n"])));
var INTRA_SECTION_MARGING = '8px';
var ExportMapStyledExportSection = (0, _styledComponents["default"])(_styledComponents2.StyledExportSection)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n .disclaimer {\n font-size: ", ";\n color: ", ";\n margin-top: 12px;\n }\n"])), function (props) {
return props.theme.inputFontSize;
}, function (props) {
return props.theme.inputColor;
});
var Link = function Link(_ref) {
var children = _ref.children,
props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
return (/*#__PURE__*/_react["default"].createElement(StyledLink, (0, _extends2["default"])({
target: "_blank",
rel: "noopener noreferrer"
}, props), children)
);
};
var BigStyledType = (0, _styledComponents["default"])(_styledComponents2.StyledType)(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n height: unset;\n width: unset;\n img {\n width: 180px;\n height: 120px;\n }\n"])));
var exportHtmlPropTypes = {
options: _propTypes["default"].object,
onEditUserMapboxAccessToken: _propTypes["default"].func.isRequired
};
var ExportHtmlMap = function ExportHtmlMap(_ref2) {
var _ref2$onChangeExportM = _ref2.onChangeExportMapHTMLMode,
onChangeExportMapHTMLMode = _ref2$onChangeExportM === void 0 ? NO_OP : _ref2$onChangeExportM,
_ref2$onEditUserMapbo = _ref2.onEditUserMapboxAccessToken,
onEditUserMapboxAccessToken = _ref2$onEditUserMapbo === void 0 ? NO_OP : _ref2$onEditUserMapbo,
_ref2$options = _ref2.options,
options = _ref2$options === void 0 ? {} : _ref2$options;
return (/*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledExportSection, {
style: {
marginTop: INTRA_SECTION_MARGING
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, "Export your map into an interactive html file.")), /*#__PURE__*/_react["default"].createElement(ExportMapStyledExportSection, {
className: "export-map-modal__html-options"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "title"
}, "Mapbox access token"), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, "Use your own Mapbox access token in the html (optional)")), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, /*#__PURE__*/_react["default"].createElement(StyledInput, {
onChange: function onChange(e) {
return onEditUserMapboxAccessToken(e.target.value);
},
type: "text",
placeholder: "Paste your Mapbox access token",
value: options ? options.userMapboxToken : ''
}), /*#__PURE__*/_react["default"].createElement("div", {
className: "disclaimer"
}, /*#__PURE__*/_react["default"].createElement(StyledWarning, null, _defaultSettings.TOKEN_MISUSE_WARNING), /*#__PURE__*/_react["default"].createElement("span", null, _defaultSettings.DISCLAIMER), /*#__PURE__*/_react["default"].createElement(Link, {
href: _userGuides.GITHUB_EXPORT_HTML_MAP
}, "How to update an existing map token.")))), /*#__PURE__*/_react["default"].createElement(ExportMapStyledExportSection, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "title"
}, "Map Mode"), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, "Select the app mode. More ", /*#__PURE__*/_react["default"].createElement("a", {
href: _userGuides.GITHUB_EXPORT_HTML_MAP_MODES
}, "info"))), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, _defaultSettings.EXPORT_HTML_MAP_MODE_OPTIONS.map(function (mode) {
return (/*#__PURE__*/_react["default"].createElement(BigStyledType, {
key: mode.id,
selected: options.mode === mode.id,
available: mode.available,
onClick: function onClick() {
return mode.available && onChangeExportMapHTMLMode(mode.id);
}
}, /*#__PURE__*/_react["default"].createElement("img", {
src: mode.url,
alt: ""
}), /*#__PURE__*/_react["default"].createElement("p", null, "Allow users to ", mode.label, " the map"))
);
}))))
);
};
ExportHtmlMap.propTypes = exportHtmlPropTypes;
var StyledJsonExportSection = (0, _styledComponents["default"])(ExportMapStyledExportSection)(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n .note {\n color: ", ";\n font-size: 11px;\n }\n\n .viewer {\n border: 1px solid ", ";\n background-color: white;\n border-radius: 2px;\n display: inline-block;\n font: inherit;\n line-height: 1.5em;\n padding: 0.5em 3.5em 0.5em 1em;\n margin: 0;\n box-sizing: border-box;\n height: 180px;\n width: 100%;\n overflow-y: scroll;\n overflow-x: auto;\n white-space: pre-wrap;\n word-wrap: break-word;\n max-width: 600px;\n }\n"])), function (props) {
return props.theme.errorColor;
}, function (props) {
return props.theme.selectBorderColorLT;
});
var exportJsonPropTypes = {
options: _propTypes["default"].object
};
var ExportJsonMap = function ExportJsonMap(_ref3) {
var _ref3$config = _ref3.config,
config = _ref3$config === void 0 ? {} : _ref3$config;
return (/*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledExportSection, {
style: {
marginTop: INTRA_SECTION_MARGING
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, "Export current map data and config into a single Json file. You can later open the same map by uploading this file to kepler.gl.")), /*#__PURE__*/_react["default"].createElement(StyledJsonExportSection, {
className: "export-map-modal__json-options"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "title"
}, "Map Config"), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, _defaultSettings.MAP_CONFIG_DESCRIPTION, /*#__PURE__*/_react["default"].createElement(Link, {
href: _userGuides.GITHUB_ADD_DATA_TO_MAP
}, "addDataToMap"), ".")), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "viewer"
}, /*#__PURE__*/_react["default"].createElement(_reactJsonPretty["default"], {
id: "json-pretty",
json: config
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "disclaimer"
}, /*#__PURE__*/_react["default"].createElement(StyledWarning, null, "* Map config is coupled with loaded datasets. \u2018dataId\u2019 is used to bind layers, filters, and tooltips to a specific dataset. When passing this config to addDataToMap, make sure the dataset id matches the dataId/s in this config.")))))
);
};
ExportJsonMap.propTypes = exportJsonPropTypes;
var propTypes = {
options: _propTypes["default"].object,
onEditUserMapboxAccessToken: _propTypes["default"].func.isRequired,
onChangeExportData: _propTypes["default"].func,
onChangeExportMapType: _propTypes["default"].func,
mapFormat: _propTypes["default"].string
};
var style = {
width: '100%'
};
var ExportMapModal = function ExportMapModal(_ref4) {
var _EXPORT_MAP_FORMATS$H;
var _ref4$config = _ref4.config,
config = _ref4$config === void 0 ? {} : _ref4$config,
_ref4$onChangeExportD = _ref4.onChangeExportData,
onChangeExportData = _ref4$onChangeExportD === void 0 ? NO_OP : _ref4$onChangeExportD,
_ref4$onChangeExportM = _ref4.onChangeExportMapFormat,
onChangeExportMapFormat = _ref4$onChangeExportM === void 0 ? NO_OP : _ref4$onChangeExportM,
_ref4$onChangeExportM2 = _ref4.onChangeExportMapHTMLMode,
onChangeExportMapHTMLMode = _ref4$onChangeExportM2 === void 0 ? NO_OP : _ref4$onChangeExportM2,
_ref4$onEditUserMapbo = _ref4.onEditUserMapboxAccessToken,
onEditUserMapboxAccessToken = _ref4$onEditUserMapbo === void 0 ? NO_OP : _ref4$onEditUserMapbo,
_ref4$options = _ref4.options,
options = _ref4$options === void 0 ? {} : _ref4$options;
return (/*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalContent, {
className: "export-map-modal"
}, /*#__PURE__*/_react["default"].createElement("div", {
style: style
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledExportSection, {
style: {
marginBottom: INTRA_SECTION_MARGING
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "title"
}, "Map format"), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, "Choose the format to export your map to")), /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, _defaultSettings.EXPORT_MAP_FORMAT_OPTIONS.map(function (op) {
return (/*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledType, {
key: op.id,
selected: options.format === op.id,
available: op.available,
onClick: function onClick() {
return op.available && onChangeExportMapFormat(op.id);
}
}, /*#__PURE__*/_react["default"].createElement(_icons.FileType, {
ext: op.label,
height: "80px",
fontSize: "11px"
}))
);
}))), (_EXPORT_MAP_FORMATS$H = {}, (0, _defineProperty2["default"])(_EXPORT_MAP_FORMATS$H, _defaultSettings.EXPORT_MAP_FORMATS.HTML, /*#__PURE__*/_react["default"].createElement(ExportHtmlMap, {
onChangeExportMapHTMLMode: onChangeExportMapHTMLMode,
onEditUserMapboxAccessToken: onEditUserMapboxAccessToken,
options: options[options.format]
})), (0, _defineProperty2["default"])(_EXPORT_MAP_FORMATS$H, _defaultSettings.EXPORT_MAP_FORMATS.JSON, /*#__PURE__*/_react["default"].createElement(ExportJsonMap, {
config: config,
onChangeExportData: onChangeExportData,
options: options[options.format]
})), _EXPORT_MAP_FORMATS$H)[options.format]))
);
};
ExportMapModal.propTypes = propTypes;
var ExportMapModalFactory = function ExportMapModalFactory() {
return ExportMapModal;
};
var _default = exports["default"] = ExportMapModalFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/export-map-modal.js"],"names":["NO_OP","StyledInput","styled","input","props","theme","inputPadding","error","titleColorLT","inputBoxHeight","inputFontSize","StyledWarning","span","errorColor","selectFontWeightBold","StyledLink","a","INTRA_SECTION_MARGING","ExportMapStyledExportSection","StyledExportSection","inputColor","Link","children","BigStyledType","StyledType","exportHtmlPropTypes","options","PropTypes","object","onEditUserMapboxAccessToken","func","isRequired","ExportHtmlMap","onChangeExportMapHTMLMode","marginTop","e","target","value","userMapboxToken","TOKEN_MISUSE_WARNING","DISCLAIMER","GITHUB_EXPORT_HTML_MAP","GITHUB_EXPORT_HTML_MAP_MODES","EXPORT_HTML_MAP_MODE_OPTIONS","map","mode","id","available","url","label","propTypes","StyledJsonExportSection","selectBorderColorLT","exportJsonPropTypes","ExportJsonMap","config","MAP_CONFIG_DESCRIPTION","GITHUB_ADD_DATA_TO_MAP","onChangeExportData","onChangeExportMapType","mapFormat","string","style","width","ExportMapModal","onChangeExportMapFormat","marginBottom","EXPORT_MAP_FORMAT_OPTIONS","op","format","EXPORT_MAP_FORMATS","HTML","JSON","ExportMapModalFactory"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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 from 'react';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport JSONPretty from 'react-json-pretty';\nimport {GITHUB_EXPORT_HTML_MAP, GITHUB_ADD_DATA_TO_MAP, GITHUB_EXPORT_HTML_MAP_MODES} from 'constants/user-guides';\nimport {FileType} from 'components/common/icons';\nimport {\n  StyledModalContent,\n  StyledExportSection,\n  StyledType\n} from 'components/common/styled-components';\nimport {\n  DISCLAIMER,\n  EXPORT_MAP_FORMATS,\n  EXPORT_MAP_FORMAT_OPTIONS,\n  EXPORT_HTML_MAP_MODE_OPTIONS,\n  MAP_CONFIG_DESCRIPTION,\n  TOKEN_MISUSE_WARNING\n} from 'constants/default-settings';\n\nconst NO_OP = () => {};\n\nconst StyledInput = styled.input`\n  width: 100%;\n  padding: ${props => props.theme.inputPadding};\n  color: ${props => props.error ? 'red' : props.theme.titleColorLT};\n  height: ${props => props.theme.inputBoxHeight};\n  outline: 0;\n  font-size: ${props => props.theme.inputFontSize};\n\n  :active,\n  :focus,\n  &.focus,\n  &.active {\n    outline: 0;\n  }\n`;\n\nconst StyledWarning = styled.span`\n  color: ${props => props.theme.errorColor};\n  font-weight: ${props => props.theme.selectFontWeightBold};\n`;\n\nconst StyledLink = styled.a`\n  text-decoration-line: underline !important;\n`;\n\nconst INTRA_SECTION_MARGING = '8px';\n\nconst ExportMapStyledExportSection = styled(StyledExportSection)`\n  .disclaimer {\n    font-size: ${props => props.theme.inputFontSize};\n    color: ${props => props.theme.inputColor};\n    margin-top: 12px;\n  }\n`;\n\nconst Link = ({children, ...props}) => (\n  <StyledLink target=\"_blank\"\n              rel=\"noopener noreferrer\" {...props}>\n    {children}\n  </StyledLink>\n);\n\nconst BigStyledType = styled(StyledType)`\n  height: unset;\n  width: unset;\n  img {\n    width: 180px;\n    height: 120px;\n  }\n`;\n\nconst exportHtmlPropTypes = {\n  options: PropTypes.object,\n  onEditUserMapboxAccessToken: PropTypes.func.isRequired\n};\n\nconst ExportHtmlMap = ({\n  onChangeExportMapHTMLMode = NO_OP,\n  onEditUserMapboxAccessToken = NO_OP,\n  options = {}\n}) => (\n  <div>\n    <StyledExportSection style={{marginTop: INTRA_SECTION_MARGING}}>\n      <div className=\"description\" />\n      <div className=\"selection\">\n        Export your map into an interactive html file.\n      </div>\n    </StyledExportSection>\n    <ExportMapStyledExportSection className=\"export-map-modal__html-options\">\n      <div className=\"description\">\n        <div className=\"title\">\n          Mapbox access token\n        </div>\n        <div className=\"subtitle\">\n          Use your own Mapbox access token in the html (optional)\n        </div>\n      </div>\n      <div className=\"selection\">\n        <StyledInput\n          onChange={e => onEditUserMapboxAccessToken(e.target.value)}\n          type=\"text\"\n          placeholder=\"Paste your Mapbox access token\"\n          value={options ? options.userMapboxToken : ''}\n        />\n        <div className=\"disclaimer\">\n          <StyledWarning>{TOKEN_MISUSE_WARNING}</StyledWarning>\n          <span>{DISCLAIMER}</span>\n          <Link href={GITHUB_EXPORT_HTML_MAP}>\n            How to update an existing map token.\n          </Link>\n        </div>\n      </div>\n    </ExportMapStyledExportSection>\n    <ExportMapStyledExportSection>\n      <div className=\"description\">\n        <div className=\"title\">\n          Map Mode\n        </div>\n        <div className=\"subtitle\">\n          Select the app mode. More <a href={GITHUB_EXPORT_HTML_MAP_MODES}>info</a>\n        </div>\n      </div>\n      <div className=\"selection\">\n        {EXPORT_HTML_MAP_MODE_OPTIONS.map(mode =>\n          <BigStyledType\n            key={mode.id}\n            selected={options.mode === mode.id}\n            available={mode.available}\n            onClick={() => mode.available && onChangeExportMapHTMLMode(mode.id)}\n          >\n            <img src={mode.url} alt=\"\"/>\n            <p>Allow users to {mode.label} the map</p>\n          </BigStyledType>\n        )}\n      </div>\n    </ExportMapStyledExportSection>\n  </div>\n);\n\nExportHtmlMap.propTypes = exportHtmlPropTypes;\n\nconst StyledJsonExportSection = styled(ExportMapStyledExportSection)`\n  .note {\n    color: ${props => props.theme.errorColor};\n    font-size: 11px;\n  }\n\n  .viewer {\n    border: 1px solid ${props => props.theme.selectBorderColorLT};\n    background-color: white;\n    border-radius: 2px;\n    display: inline-block;\n    font: inherit;\n    line-height: 1.5em;\n    padding: 0.5em 3.5em 0.5em 1em;\n    margin: 0;\n    box-sizing: border-box;\n    height: 180px;\n    width: 100%;\n    overflow-y: scroll;\n    overflow-x: auto;\n    white-space: pre-wrap;\n    word-wrap: break-word;\n    max-width: 600px;\n  }\n`;\n\nconst exportJsonPropTypes = {\n  options: PropTypes.object\n};\n\nconst ExportJsonMap = ({\n  config = {}\n}) => (\n  <div>\n    <StyledExportSection style={{marginTop: INTRA_SECTION_MARGING}}>\n      <div className=\"description\" />\n      <div className=\"selection\">\n        Export current map data and config into a single Json file. You can later open the same map by uploading this file to kepler.gl.\n      </div>\n    </StyledExportSection>\n    <StyledJsonExportSection className=\"export-map-modal__json-options\">\n      <div className=\"description\">\n        <div className=\"title\">\n          Map Config\n        </div>\n        <div className=\"subtitle\">\n          {MAP_CONFIG_DESCRIPTION}\n          <Link href={GITHUB_ADD_DATA_TO_MAP}>\n            addDataToMap\n          </Link>.\n        </div>\n      </div>\n      <div className=\"selection\">\n        <div className=\"viewer\">\n          <JSONPretty id=\"json-pretty\" json={config}/>\n        </div>\n        <div className=\"disclaimer\">\n          <StyledWarning>\n            * Map config is coupled with loaded datasets. ‘dataId’ is used to bind layers, filters, and tooltips to a specific dataset. When passing this config to addDataToMap, make sure the dataset id matches the dataId/s in this config.\n          </StyledWarning>\n        </div>\n      </div>\n    </StyledJsonExportSection>\n  </div>\n);\n\nExportJsonMap.propTypes = exportJsonPropTypes;\n\nconst propTypes = {\n  options: PropTypes.object,\n  onEditUserMapboxAccessToken: PropTypes.func.isRequired,\n  onChangeExportData: PropTypes.func,\n  onChangeExportMapType: PropTypes.func,\n  mapFormat: PropTypes.string\n};\n\nconst style = {width: '100%'};\n\nconst ExportMapModal = ({\n  config = {},\n  onChangeExportData = NO_OP,\n  onChangeExportMapFormat = NO_OP,\n  onChangeExportMapHTMLMode = NO_OP,\n  onEditUserMapboxAccessToken = NO_OP,\n  options = {}\n}) => (\n  <StyledModalContent className=\"export-map-modal\">\n    <div style={style}>\n      <StyledExportSection style={{marginBottom: INTRA_SECTION_MARGING}}>\n        <div className=\"description\">\n          <div className=\"title\">\n            Map format\n          </div>\n          <div className=\"subtitle\">\n            Choose the format to export your map to\n          </div>\n        </div>\n        <div className=\"selection\">\n          {EXPORT_MAP_FORMAT_OPTIONS.map(op =>\n            <StyledType\n              key={op.id}\n              selected={options.format === op.id}\n              available={op.available}\n              onClick={() => op.available && onChangeExportMapFormat(op.id)}\n            >\n              <FileType ext={op.label} height=\"80px\" fontSize=\"11px\" />\n            </StyledType>\n          )}\n        </div>\n      </StyledExportSection>\n      {{\n        [EXPORT_MAP_FORMATS.HTML]:  (\n          <ExportHtmlMap\n            onChangeExportMapHTMLMode={onChangeExportMapHTMLMode}\n            onEditUserMapboxAccessToken={onEditUserMapboxAccessToken}\n            options={options[options.format]}\n          />\n        ),\n        [EXPORT_MAP_FORMATS.JSON]: (\n          <ExportJsonMap\n            config={config}\n            onChangeExportData={onChangeExportData}\n            options={options[options.format]}\n          />\n        )\n      }[options.format]}\n    </div>\n  </StyledModalContent>\n);\n\nExportMapModal.propTypes = propTypes;\n\nconst ExportMapModalFactory = () => ExportMapModal;\n\nexport default ExportMapModalFactory;\n"]}