UNPKG

kepler.gl

Version:

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

202 lines (173 loc) 25.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = ShareMapUrlModalFactory; exports.SharingUrl = exports.StyleSharingUrl = exports.StyledInputLabel = void 0; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireWildcard(require("styled-components")); var _reactCopyToClipboard = require("react-copy-to-clipboard"); var _base = require("../../styles/base"); var _imageModalContainer = _interopRequireDefault(require("./image-modal-container")); var _providerModalContainer = _interopRequireDefault(require("./provider-modal-container")); var _styledComponents2 = require("../common/styled-components"); var _cloudTile = _interopRequireDefault(require("./cloud-tile")); var _statusPanel = _interopRequireDefault(require("./status-panel")); var _localization = require("../../localization"); var _templateObject, _templateObject2, _templateObject3, _templateObject4; var StyledInputLabel = _styledComponents["default"].label(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n color: ", ";\n letter-spacing: 0.2px;\n"])), function (props) { return props.theme.textColorLT; }); exports.StyledInputLabel = StyledInputLabel; var StyleSharingUrl = _styledComponents["default"].div.attrs({ className: 'sharing-url' })(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n display: flex;\n margin-bottom: 14px;\n flex-direction: column;\n\n input {\n border-right: 0;\n }\n\n .button {\n border-top-left-radius: 0;\n border-bottom-left-radius: 0;\n }\n"]))); exports.StyleSharingUrl = StyleSharingUrl; var SharingUrl = function SharingUrl(_ref) { var url = _ref.url, _ref$message = _ref.message, message = _ref$message === void 0 ? '' : _ref$message; var _useState = (0, _react.useState)(false), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), copied = _useState2[0], setCopy = _useState2[1]; return /*#__PURE__*/_react["default"].createElement(StyleSharingUrl, null, /*#__PURE__*/_react["default"].createElement(StyledInputLabel, null, message), /*#__PURE__*/_react["default"].createElement("div", { style: { display: 'flex' } }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.InputLight, { type: "text", value: url, readOnly: true, selected: true }), /*#__PURE__*/_react["default"].createElement(_reactCopyToClipboard.CopyToClipboard, { text: url, onCopy: function onCopy() { return setCopy(true); } }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { width: "80px" }, copied ? 'Copied!' : 'Copy')))); }; exports.SharingUrl = SharingUrl; var nop = function nop() {}; var StyledShareMapModal = (0, _styledComponents["default"])(_styledComponents2.StyledModalContent)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 24px 72px 40px 72px;\n margin: 0 -72px -40px -72px;\n"]))); var StyledInnerDiv = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 500px;\n"]))); function ShareMapUrlModalFactory() { var ShareMapUrlModal = function ShareMapUrlModal(_ref2) { var isProviderLoading = _ref2.isProviderLoading, isReady = _ref2.isReady, onExport = _ref2.onExport, cloudProviders = _ref2.cloudProviders, currentProvider = _ref2.currentProvider, providerError = _ref2.providerError, successInfo = _ref2.successInfo, onSetCloudProvider = _ref2.onSetCloudProvider, onUpdateImageSetting = _ref2.onUpdateImageSetting, cleanupExportImage = _ref2.cleanupExportImage; var shareUrl = successInfo.shareUrl, folderLink = successInfo.folderLink; var provider = currentProvider ? cloudProviders.find(function (p) { return p.name === currentProvider; }) : null; return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, { theme: _base.themeLT }, /*#__PURE__*/_react["default"].createElement(_providerModalContainer["default"], { onSetCloudProvider: onSetCloudProvider, cloudProviders: cloudProviders, currentProvider: currentProvider }, /*#__PURE__*/_react["default"].createElement(_imageModalContainer["default"], { currentProvider: currentProvider, cloudProviders: cloudProviders, onUpdateImageSetting: onUpdateImageSetting, cleanupExportImage: cleanupExportImage }, /*#__PURE__*/_react["default"].createElement(StyledShareMapModal, { className: "export-cloud-modal" }, /*#__PURE__*/_react["default"].createElement(StyledInnerDiv, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledExportSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "description" }, /*#__PURE__*/_react["default"].createElement("div", { className: "title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.shareMap.shareUriTitle' })), /*#__PURE__*/_react["default"].createElement("div", { className: "subtitle" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.shareMap.shareUriSubtitle' }))), /*#__PURE__*/_react["default"].createElement("div", { className: "selection" }, /*#__PURE__*/_react["default"].createElement("div", { className: "title warning" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.shareMap.shareDisclaimer' })))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledExportSection, { disabled: isProviderLoading }, /*#__PURE__*/_react["default"].createElement("div", { className: "description" }, /*#__PURE__*/_react["default"].createElement("div", { className: "title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.shareMap.cloudTitle' })), /*#__PURE__*/_react["default"].createElement("div", { className: "subtitle" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.shareMap.cloudSubtitle' }))), /*#__PURE__*/_react["default"].createElement("div", { className: "selection" }, cloudProviders.map(function (cloudProvider) { return /*#__PURE__*/_react["default"].createElement(_cloudTile["default"], { key: cloudProvider.name, onSelect: function onSelect() { return onExport(cloudProvider); }, onSetCloudProvider: onSetCloudProvider, cloudProvider: cloudProvider, actionName: "Upload", isSelected: cloudProvider.name === currentProvider, isConnected: Boolean(cloudProvider.getAccessToken()), isReady: isReady }); }))), isProviderLoading || providerError ? /*#__PURE__*/_react["default"].createElement(_statusPanel["default"], { isLoading: isProviderLoading, error: providerError, providerIcon: provider && provider.icon }) : null, shareUrl && /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledExportSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "description" }, /*#__PURE__*/_react["default"].createElement("div", { className: "title" }, "Share Url")), /*#__PURE__*/_react["default"].createElement("div", { className: "selection" }, /*#__PURE__*/_react["default"].createElement(SharingUrl, { key: 0, url: shareUrl }), provider && folderLink && /*#__PURE__*/_react["default"].createElement("a", { key: 1, href: folderLink, target: "_blank", rel: "noopener noreferrer", style: { textDecoration: 'underline' } }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.shareMap.gotoPage', values: { currentProvider: currentProvider } }))))))))); }; ShareMapUrlModal.defaultProps = { isProviderLoading: false, onExport: nop, cloudProviders: [], currentProvider: null, providerError: null, successInfo: {}, onSetCloudProvider: nop, onUpdateImageSetting: nop }; return ShareMapUrlModal; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/share-map-modal.js"],"names":["StyledInputLabel","styled","label","props","theme","textColorLT","StyleSharingUrl","div","attrs","className","SharingUrl","url","message","copied","setCopy","display","nop","StyledShareMapModal","StyledModalContent","StyledInnerDiv","ShareMapUrlModalFactory","ShareMapUrlModal","isProviderLoading","isReady","onExport","cloudProviders","currentProvider","providerError","successInfo","onSetCloudProvider","onUpdateImageSetting","cleanupExportImage","shareUrl","folderLink","provider","find","p","name","themeLT","map","cloudProvider","Boolean","getAccessToken","icon","textDecoration","defaultProps"],"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, {useState} from 'react';\nimport styled, {ThemeProvider} from 'styled-components';\nimport {CopyToClipboard} from 'react-copy-to-clipboard';\nimport {themeLT} from 'styles/base';\nimport ImageModalContainer from './image-modal-container';\nimport ProviderModalContainer from './provider-modal-container';\n\nimport {\n  StyledModalContent,\n  StyledExportSection,\n  InputLight,\n  Button\n} from 'components/common/styled-components';\nimport CloudTile from './cloud-tile';\nimport StatusPanel from './status-panel';\nimport {FormattedMessage} from 'localization';\n\nexport const StyledInputLabel = styled.label`\n  font-size: 12px;\n  color: ${props => props.theme.textColorLT};\n  letter-spacing: 0.2px;\n`;\n\nexport const StyleSharingUrl = styled.div.attrs({\n  className: 'sharing-url'\n})`\n  width: 100%;\n  display: flex;\n  margin-bottom: 14px;\n  flex-direction: column;\n\n  input {\n    border-right: 0;\n  }\n\n  .button {\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n  }\n`;\n\nexport const SharingUrl = ({url, message = ''}) => {\n  const [copied, setCopy] = useState(false);\n  return (\n    <StyleSharingUrl>\n      <StyledInputLabel>{message}</StyledInputLabel>\n      <div style={{display: 'flex'}}>\n        <InputLight type=\"text\" value={url} readOnly selected />\n        <CopyToClipboard text={url} onCopy={() => setCopy(true)}>\n          <Button width=\"80px\">{copied ? 'Copied!' : 'Copy'}</Button>\n        </CopyToClipboard>\n      </div>\n    </StyleSharingUrl>\n  );\n};\nconst nop = () => {};\n\nconst StyledShareMapModal = styled(StyledModalContent)`\n  padding: 24px 72px 40px 72px;\n  margin: 0 -72px -40px -72px;\n`;\n\nconst StyledInnerDiv = styled.div`\n  min-height: 500px;\n`;\n\nexport default function ShareMapUrlModalFactory() {\n  const ShareMapUrlModal = ({\n    isProviderLoading,\n    isReady,\n    onExport,\n    cloudProviders,\n    currentProvider,\n    providerError,\n    successInfo,\n    onSetCloudProvider,\n    onUpdateImageSetting,\n    cleanupExportImage\n  }) => {\n    const {shareUrl, folderLink} = successInfo;\n    const provider = currentProvider ? cloudProviders.find(p => p.name === currentProvider) : null;\n\n    return (\n      <ThemeProvider theme={themeLT}>\n        <ProviderModalContainer\n          onSetCloudProvider={onSetCloudProvider}\n          cloudProviders={cloudProviders}\n          currentProvider={currentProvider}\n        >\n          <ImageModalContainer\n            currentProvider={currentProvider}\n            cloudProviders={cloudProviders}\n            onUpdateImageSetting={onUpdateImageSetting}\n            cleanupExportImage={cleanupExportImage}\n          >\n            <StyledShareMapModal className=\"export-cloud-modal\">\n              <StyledInnerDiv>\n                <StyledExportSection>\n                  <div className=\"description\">\n                    <div className=\"title\">\n                      <FormattedMessage id={'modal.shareMap.shareUriTitle'} />\n                    </div>\n                    <div className=\"subtitle\">\n                      <FormattedMessage id={'modal.shareMap.shareUriSubtitle'} />\n                    </div>\n                  </div>\n                  <div className=\"selection\">\n                    <div className=\"title warning\">\n                      <FormattedMessage id={'modal.shareMap.shareDisclaimer'} />\n                    </div>\n                  </div>\n                </StyledExportSection>\n                <StyledExportSection disabled={isProviderLoading}>\n                  <div className=\"description\">\n                    <div className=\"title\">\n                      <FormattedMessage id={'modal.shareMap.cloudTitle'} />\n                    </div>\n                    <div className=\"subtitle\">\n                      <FormattedMessage id={'modal.shareMap.cloudSubtitle'} />\n                    </div>\n                  </div>\n                  <div className=\"selection\">\n                    {cloudProviders.map(cloudProvider => (\n                      <CloudTile\n                        key={cloudProvider.name}\n                        onSelect={() => onExport(cloudProvider)}\n                        onSetCloudProvider={onSetCloudProvider}\n                        cloudProvider={cloudProvider}\n                        actionName=\"Upload\"\n                        isSelected={cloudProvider.name === currentProvider}\n                        isConnected={Boolean(cloudProvider.getAccessToken())}\n                        isReady={isReady}\n                      />\n                    ))}\n                  </div>\n                </StyledExportSection>\n                {isProviderLoading || providerError ? (\n                  <StatusPanel\n                    isLoading={isProviderLoading}\n                    error={providerError}\n                    providerIcon={provider && provider.icon}\n                  />\n                ) : null}\n                {shareUrl && (\n                  <StyledExportSection>\n                    <div className=\"description\">\n                      <div className=\"title\">Share Url</div>\n                    </div>\n                    <div className=\"selection\">\n                      <SharingUrl key={0} url={shareUrl} />\n                      {provider && folderLink && (\n                        <a\n                          key={1}\n                          href={folderLink}\n                          target=\"_blank\"\n                          rel=\"noopener noreferrer\"\n                          style={{textDecoration: 'underline'}}\n                        >\n                          <FormattedMessage\n                            id={'modal.shareMap.gotoPage'}\n                            values={{currentProvider}}\n                          />\n                        </a>\n                      )}\n                    </div>\n                  </StyledExportSection>\n                )}\n              </StyledInnerDiv>\n            </StyledShareMapModal>\n          </ImageModalContainer>\n        </ProviderModalContainer>\n      </ThemeProvider>\n    );\n  };\n\n  ShareMapUrlModal.defaultProps = {\n    isProviderLoading: false,\n    onExport: nop,\n    cloudProviders: [],\n    currentProvider: null,\n    providerError: null,\n    successInfo: {},\n    onSetCloudProvider: nop,\n    onUpdateImageSetting: nop\n  };\n\n  return ShareMapUrlModal;\n}\n"]}