UNPKG

kepler.gl

Version:

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

133 lines (112 loc) 16 kB
"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 _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _icons = require("../../common/icons"); var _styledComponents = require("../../common/styled-components"); var _defaultSettings = require("../../../constants/default-settings"); var _components = require("./components"); var _exportHtmlMap = _interopRequireDefault(require("./export-html-map")); var _exportJsonMap = _interopRequireDefault(require("./export-json-map")); var _localization = require("../../../localization"); // Copyright (c) 2021 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 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 NO_OP = function NO_OP() {}; ExportMapModalFactory.deps = [_exportHtmlMap["default"], _exportJsonMap["default"]]; function ExportMapModalFactory(ExportHtmlMap, ExportJsonMap) { var ExportMapModalUnmemoized = function ExportMapModalUnmemoized(_ref) { var _EXPORT_MAP_FORMATS$H; var _ref$config = _ref.config, config = _ref$config === void 0 ? {} : _ref$config, _ref$onChangeExportDa = _ref.onChangeExportData, onChangeExportData = _ref$onChangeExportDa === void 0 ? NO_OP : _ref$onChangeExportDa, _ref$onChangeExportMa = _ref.onChangeExportMapFormat, onChangeExportMapFormat = _ref$onChangeExportMa === void 0 ? function (format) {} : _ref$onChangeExportMa, _ref$onChangeExportMa2 = _ref.onChangeExportMapHTMLMode, onChangeExportMapHTMLMode = _ref$onChangeExportMa2 === void 0 ? NO_OP : _ref$onChangeExportMa2, _ref$onEditUserMapbox = _ref.onEditUserMapboxAccessToken, onEditUserMapboxAccessToken = _ref$onEditUserMapbox === void 0 ? NO_OP : _ref$onEditUserMapbox, _ref$options = _ref.options, options = _ref$options === void 0 ? { format: '' } : _ref$options; return /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledModalContent, { className: "export-map-modal" }, /*#__PURE__*/_react["default"].createElement("div", { style: style }, /*#__PURE__*/_react["default"].createElement(_components.StyledExportMapSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "description" }, /*#__PURE__*/_react["default"].createElement("div", { className: "title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.formatTitle' })), /*#__PURE__*/_react["default"].createElement("div", { className: "subtitle" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.formatSubtitle' }))), /*#__PURE__*/_react["default"].createElement("div", { className: "selection" }, _defaultSettings.EXPORT_MAP_FORMAT_OPTIONS.map(function (op) { return /*#__PURE__*/_react["default"].createElement(_styledComponents.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" }), options.format === op.id && /*#__PURE__*/_react["default"].createElement(_styledComponents.CheckMark, null)); }))), (_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)[// @ts-ignore options.format])); }; ExportMapModalUnmemoized.propTypes = propTypes; ExportMapModalUnmemoized.displayName = 'ExportMapModal'; var ExportMapModal = /*#__PURE__*/_react["default"].memo(ExportMapModalUnmemoized); return ExportMapModal; } var _default = ExportMapModalFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/modals/export-map-modal/export-map-modal.js"],"names":["propTypes","options","PropTypes","object","onEditUserMapboxAccessToken","func","isRequired","onChangeExportData","onChangeExportMapType","mapFormat","string","style","width","NO_OP","ExportMapModalFactory","deps","ExportHtmlMapFactory","ExportJsonMapFactory","ExportHtmlMap","ExportJsonMap","ExportMapModalUnmemoized","config","onChangeExportMapFormat","format","onChangeExportMapHTMLMode","EXPORT_MAP_FORMAT_OPTIONS","map","op","id","available","label","EXPORT_MAP_FORMATS","HTML","JSON","displayName","ExportMapModal","React","memo"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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';\n\nimport {FileType} from 'components/common/icons';\nimport {StyledModalContent, StyledType, CheckMark} from 'components/common/styled-components';\nimport {EXPORT_MAP_FORMATS, EXPORT_MAP_FORMAT_OPTIONS} from 'constants/default-settings';\nimport {StyledExportMapSection} from './components';\nimport ExportHtmlMapFactory from './export-html-map';\nimport ExportJsonMapFactory from './export-json-map';\nimport {FormattedMessage} from 'localization';\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 NO_OP = () => {};\n\nExportMapModalFactory.deps = [ExportHtmlMapFactory, ExportJsonMapFactory];\n\nfunction ExportMapModalFactory(ExportHtmlMap, ExportJsonMap) {\n  const ExportMapModalUnmemoized = ({\n    config = {},\n    onChangeExportData = NO_OP,\n    onChangeExportMapFormat = format => {},\n    onChangeExportMapHTMLMode = NO_OP,\n    onEditUserMapboxAccessToken = NO_OP,\n    options = {format: ''}\n  }) => (\n    <StyledModalContent className=\"export-map-modal\">\n      <div style={style}>\n        <StyledExportMapSection>\n          <div className=\"description\">\n            <div className=\"title\">\n              <FormattedMessage id={'modal.exportMap.formatTitle'} />\n            </div>\n            <div className=\"subtitle\">\n              <FormattedMessage id={'modal.exportMap.formatSubtitle'} />\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\n                {options.format === op.id && <CheckMark />}\n              </StyledType>\n            ))}\n          </div>\n        </StyledExportMapSection>\n        {\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          }[\n            // @ts-ignore\n            options.format\n          ]\n        }\n      </div>\n    </StyledModalContent>\n  );\n\n  ExportMapModalUnmemoized.propTypes = propTypes;\n  ExportMapModalUnmemoized.displayName = 'ExportMapModal';\n\n  const ExportMapModal = React.memo(ExportMapModalUnmemoized);\n\n  return ExportMapModal;\n}\n\nexport default ExportMapModalFactory;\n"]}