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
JavaScript
"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"]}