UNPKG

kepler.gl

Version:

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

141 lines (123 loc) 19.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _styledComponents = require("../../common/styled-components"); var _components = require("./components"); var _defaultSettings = require("../../../constants/default-settings"); var _userGuides = require("../../../constants/user-guides"); var _styledComponents2 = _interopRequireDefault(require("styled-components")); var _reactIntl = require("react-intl"); var _localization = require("../../../localization"); var _templateObject, _templateObject2, _templateObject3; var ExportMapStyledExportSection = (0, _styledComponents2["default"])(_styledComponents.StyledExportSection)(_templateObject || (_templateObject = (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 StyledInput = _styledComponents2["default"].input(_templateObject2 || (_templateObject2 = (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 BigStyledTile = (0, _styledComponents2["default"])(_styledComponents.StyledType)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n height: unset;\n width: unset;\n img {\n width: 180px;\n height: 120px;\n }\n"]))); function ExportHtmlMapFactory() { /** @type {typeof import('./export-html-map').ExportHtmlMap} */ var ExportHtmlMap = function ExportHtmlMap(_ref) { var _ref$onChangeExportMa = _ref.onChangeExportMapHTMLMode, onChangeExportMapHTMLMode = _ref$onChangeExportMa === void 0 ? function (mode) {} : _ref$onChangeExportMa, _ref$onEditUserMapbox = _ref.onEditUserMapboxAccessToken, onEditUserMapboxAccessToken = _ref$onEditUserMapbox === void 0 ? function (token) {} : _ref$onEditUserMapbox, _ref$options = _ref.options, options = _ref$options === void 0 ? {} : _ref$options, intl = _ref.intl; return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_components.StyledExportMapSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "description" }), /*#__PURE__*/_react["default"].createElement("div", { className: "selection" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.selection' }))), /*#__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" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.tokenTitle' })), /*#__PURE__*/_react["default"].createElement("div", { className: "subtitle" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.tokenSubtitle' }))), /*#__PURE__*/_react["default"].createElement("div", { className: "selection" }, /*#__PURE__*/_react["default"].createElement(StyledInput, { onChange: function onChange(e) { return onEditUserMapboxAccessToken(e.target.value); }, type: "text", placeholder: intl.formatMessage({ id: 'modal.exportMap.html.tokenPlaceholder' }), value: options ? options.userMapboxToken : '' }), /*#__PURE__*/_react["default"].createElement("div", { className: "disclaimer" }, /*#__PURE__*/_react["default"].createElement(_components.StyledWarning, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.tokenMisuseWarning' })), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.tokenDisclaimer' }), /*#__PURE__*/_react["default"].createElement(_components.ExportMapLink, { href: _userGuides.EXPORT_HTML_MAP_DOC }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.tokenUpdate' }))))), /*#__PURE__*/_react["default"].createElement(ExportMapStyledExportSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "description" }, /*#__PURE__*/_react["default"].createElement("div", { className: "title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.modeTitle' })), /*#__PURE__*/_react["default"].createElement("div", { className: "subtitle" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.modeSubtitle1' }), /*#__PURE__*/_react["default"].createElement("a", { href: _userGuides.EXPORT_HTML_MAP_MODES_DOC }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.modeSubtitle2' })))), /*#__PURE__*/_react["default"].createElement("div", { className: "selection" }, _defaultSettings.EXPORT_HTML_MAP_MODE_OPTIONS.map(function (mode) { return /*#__PURE__*/_react["default"].createElement(BigStyledTile, { 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, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.modeDescription', values: { mode: intl.formatMessage({ id: mode.label }) } })), options.mode === mode.id && /*#__PURE__*/_react["default"].createElement(_styledComponents.CheckMark, null)); })))); }; ExportHtmlMap.displayName = 'ExportHtmlMap'; return (0, _reactIntl.injectIntl)(ExportHtmlMap); } var _default = ExportHtmlMapFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/modals/export-map-modal/export-html-map.js"],"names":["ExportMapStyledExportSection","StyledExportSection","props","theme","inputFontSize","inputColor","StyledInput","styled","input","inputPadding","error","titleColorLT","inputBoxHeight","BigStyledTile","StyledType","ExportHtmlMapFactory","ExportHtmlMap","onChangeExportMapHTMLMode","mode","onEditUserMapboxAccessToken","token","options","intl","e","target","value","formatMessage","id","userMapboxToken","EXPORT_HTML_MAP_DOC","EXPORT_HTML_MAP_MODES_DOC","EXPORT_HTML_MAP_MODE_OPTIONS","map","available","url","label","displayName"],"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 {StyledExportSection, StyledType, CheckMark} from 'components/common/styled-components';\nimport {StyledExportMapSection, StyledWarning, ExportMapLink} from './components';\nimport {EXPORT_HTML_MAP_MODE_OPTIONS} from 'constants/default-settings';\nimport {EXPORT_HTML_MAP_DOC, EXPORT_HTML_MAP_MODES_DOC} from 'constants/user-guides';\nimport styled from 'styled-components';\nimport {injectIntl} from 'react-intl';\nimport {FormattedMessage} from 'localization';\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 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 BigStyledTile = styled(StyledType)`\n  height: unset;\n  width: unset;\n  img {\n    width: 180px;\n    height: 120px;\n  }\n`;\n\nfunction ExportHtmlMapFactory() {\n  /** @type {typeof import('./export-html-map').ExportHtmlMap} */\n  const ExportHtmlMap = ({\n    onChangeExportMapHTMLMode = mode => {},\n    onEditUserMapboxAccessToken = token => {},\n    options = {},\n    intl\n  }) => (\n    <div>\n      <StyledExportMapSection>\n        <div className=\"description\" />\n        <div className=\"selection\">\n          <FormattedMessage id={'modal.exportMap.html.selection'} />\n        </div>\n      </StyledExportMapSection>\n      <ExportMapStyledExportSection className=\"export-map-modal__html-options\">\n        <div className=\"description\">\n          <div className=\"title\">\n            <FormattedMessage id={'modal.exportMap.html.tokenTitle'} />\n          </div>\n          <div className=\"subtitle\">\n            <FormattedMessage id={'modal.exportMap.html.tokenSubtitle'} />\n          </div>\n        </div>\n        <div className=\"selection\">\n          <StyledInput\n            onChange={e => onEditUserMapboxAccessToken(e.target.value)}\n            type=\"text\"\n            placeholder={intl.formatMessage({id: 'modal.exportMap.html.tokenPlaceholder'})}\n            value={options ? options.userMapboxToken : ''}\n          />\n          <div className=\"disclaimer\">\n            <StyledWarning>\n              <FormattedMessage id={'modal.exportMap.html.tokenMisuseWarning'} />\n            </StyledWarning>\n            <FormattedMessage id={'modal.exportMap.html.tokenDisclaimer'} />\n            <ExportMapLink href={EXPORT_HTML_MAP_DOC}>\n              <FormattedMessage id={'modal.exportMap.html.tokenUpdate'} />\n            </ExportMapLink>\n          </div>\n        </div>\n      </ExportMapStyledExportSection>\n      <ExportMapStyledExportSection>\n        <div className=\"description\">\n          <div className=\"title\">\n            <FormattedMessage id={'modal.exportMap.html.modeTitle'} />\n          </div>\n          <div className=\"subtitle\">\n            <FormattedMessage id={'modal.exportMap.html.modeSubtitle1'} />\n            <a href={EXPORT_HTML_MAP_MODES_DOC}>\n              <FormattedMessage id={'modal.exportMap.html.modeSubtitle2'} />\n            </a>\n          </div>\n        </div>\n        <div className=\"selection\">\n          {EXPORT_HTML_MAP_MODE_OPTIONS.map(mode => (\n            <BigStyledTile\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>\n                <FormattedMessage\n                  id={'modal.exportMap.html.modeDescription'}\n                  values={{mode: intl.formatMessage({id: mode.label})}}\n                />\n              </p>\n              {options.mode === mode.id && <CheckMark />}\n            </BigStyledTile>\n          ))}\n        </div>\n      </ExportMapStyledExportSection>\n    </div>\n  );\n\n  ExportHtmlMap.displayName = 'ExportHtmlMap';\n\n  return injectIntl(ExportHtmlMap);\n}\n\nexport default ExportHtmlMapFactory;\n"]}