UNPKG

kepler.gl

Version:

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

126 lines (125 loc) 21 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 _constants = require("@kepler.gl/constants"); var _styledComponents2 = _interopRequireDefault(require("styled-components")); var _reactIntl = require("react-intl"); var _localization = require("@kepler.gl/localization"); var _templateObject, _templateObject2, _templateObject3; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project 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 () { return; } : _ref$onChangeExportMa, _ref$onEditUserMapbox = _ref.onEditUserMapboxAccessToken, onEditUserMapboxAccessToken = _ref$onEditUserMapbox === void 0 ? function () { return; } : _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: _constants.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: _constants.EXPORT_HTML_MAP_MODES_DOC }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportMap.html.modeSubtitle2' })))), /*#__PURE__*/_react["default"].createElement("div", { className: "selection" }, _constants.EXPORT_HTML_MAP_MODE_OPTIONS.map(function (mode) { return /*#__PURE__*/_react["default"].createElement(BigStyledTile, { key: mode.id, selected: options.mode === mode.id, 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 = exports["default"] = ExportHtmlMapFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_styledComponents","_components","_constants","_styledComponents2","_reactIntl","_localization","_templateObject","_templateObject2","_templateObject3","ExportMapStyledExportSection","styled","StyledExportSection","_taggedTemplateLiteral2","props","theme","inputFontSize","inputColor","StyledInput","input","inputPadding","error","titleColorLT","inputBoxHeight","BigStyledTile","StyledType","ExportHtmlMapFactory","ExportHtmlMap","_ref","_ref$onChangeExportMa","onChangeExportMapHTMLMode","_ref$onEditUserMapbox","onEditUserMapboxAccessToken","_ref$options","options","intl","createElement","StyledExportMapSection","className","FormattedMessage","id","onChange","e","target","value","type","placeholder","formatMessage","userMapboxToken","StyledWarning","ExportMapLink","href","EXPORT_HTML_MAP_DOC","EXPORT_HTML_MAP_MODES_DOC","EXPORT_HTML_MAP_MODE_OPTIONS","map","mode","key","selected","onClick","available","src","url","alt","values","label","CheckMark","displayName","injectIntl","_default","exports"],"sources":["../../../src/modals/export-map-modal/export-html-map.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React from 'react';\nimport {StyledExportSection, StyledType, CheckMark} from '../../common/styled-components';\nimport {StyledExportMapSection, StyledWarning, ExportMapLink} from './components';\nimport {\n  EXPORT_HTML_MAP_MODE_OPTIONS,\n  EXPORT_HTML_MAP_DOC,\n  EXPORT_HTML_MAP_MODES_DOC\n} from '@kepler.gl/constants';\nimport styled from 'styled-components';\nimport {injectIntl} from 'react-intl';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {IntlShape} from 'react-intl';\n\nimport {setUserMapboxAccessToken, setExportHTMLMapMode, ActionHandler} from '@kepler.gl/actions';\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\ninterface StyledInputProps {\n  error?: boolean;\n}\n\nconst StyledInput = styled.input<StyledInputProps>`\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\ntype ExportHtmlMapProps = {\n  onChangeExportMapHTMLMode: ActionHandler<typeof setExportHTMLMapMode>;\n  onEditUserMapboxAccessToken: ActionHandler<typeof setUserMapboxAccessToken>;\n  options: {\n    userMapboxToken?: string;\n    mode?: string;\n  };\n};\n\ntype IntlProps = {\n  intl: IntlShape;\n};\n\nfunction ExportHtmlMapFactory(): React.ComponentType<ExportHtmlMapProps> {\n  /** @type {typeof import('./export-html-map').ExportHtmlMap} */\n  const ExportHtmlMap: React.FC<ExportHtmlMapProps & IntlProps> = ({\n    onChangeExportMapHTMLMode = () => {\n      return;\n    },\n    onEditUserMapboxAccessToken = () => {\n      return;\n    },\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              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"],"mappings":"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","ignoreList":[]}