kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
180 lines (179 loc) • 33.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.MapInfoPanel = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _imageModalContainer = _interopRequireDefault(require("./image-modal-container"));
var _flexContainer = require("../common/flex-container");
var _statusPanel = _interopRequireWildcard(require("./status-panel"));
var _providerSelect = require("./cloud-components/provider-select");
var _constants = require("@kepler.gl/constants");
var _styledComponents2 = require("../common/styled-components");
var _imagePreview = _interopRequireDefault(require("../common/image-preview"));
var _localization = require("@kepler.gl/localization");
var _modal = require("../common/modal");
var _useCloudListProvider2 = require("../hooks/use-cloud-list-provider");
var _templateObject, _templateObject2; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
var StyledSaveMapModal = _styledComponents["default"].div.attrs({
className: 'save-map-modal'
})(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .save-map-modal-content {\n min-height: 400px;\n flex-direction: column;\n }\n\n .description {\n width: 300px;\n }\n\n .image-preview-panel {\n width: 300px;\n\n .image-preview {\n padding: 0;\n }\n }\n\n .map-info-panel {\n flex-direction: column;\n }\n\n .save-map-modal-description {\n .modal-section-subtitle {\n margin-left: 6px;\n }\n }\n"])));
var StyledCompactExportSection = (0, _styledComponents["default"])(_styledComponents2.StyledExportSection)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 5px 0;\n"])));
var nop = function nop() {
return;
};
var TEXT_AREA_LIGHT_STYLE = {
resize: 'none'
};
var MapInfoPanel = exports.MapInfoPanel = function MapInfoPanel(_ref) {
var mapInfo = _ref.mapInfo,
characterLimits = _ref.characterLimits,
onChangeInput = _ref.onChangeInput;
var _mapInfo$description = mapInfo.description,
description = _mapInfo$description === void 0 ? '' : _mapInfo$description,
_mapInfo$title = mapInfo.title,
title = _mapInfo$title === void 0 ? '' : _mapInfo$title;
return /*#__PURE__*/_react["default"].createElement("div", {
className: "selection map-info-panel",
"data-testid": _constants.dataTestIds.providerMapInfoPanel
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalSection, {
className: "save-map-modal-name"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "modal-section-title"
}, "Name*"), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.InputLight, {
id: "map-title",
type: "text",
value: title,
onChange: function onChange(e) {
return onChangeInput('title', e);
},
placeholder: "Type map title"
}))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalSection, null, /*#__PURE__*/_react["default"].createElement(_flexContainer.FlexContainer, {
className: "save-map-modal-description"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "modal-section-title"
}, "Description"), /*#__PURE__*/_react["default"].createElement("div", {
className: "modal-section-subtitle"
}, "(optional)")), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.TextAreaLight, {
rows: 3,
id: "map-description",
style: TEXT_AREA_LIGHT_STYLE,
value: description,
onChange: function onChange(e) {
return onChangeInput('description', e);
},
placeholder: "Type map description"
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalInputFootnote, {
error: Boolean(characterLimits === null || characterLimits === void 0 ? void 0 : characterLimits.description) && description.length > Number(characterLimits === null || characterLimits === void 0 ? void 0 : characterLimits.description)
}, description.length, "/", (characterLimits === null || characterLimits === void 0 ? void 0 : characterLimits.description) || _constants.MAP_INFO_CHARACTER.description, ' ', "characters")));
};
var SaveMapHeader = function SaveMapHeader(_ref2) {
var cloudProviders = _ref2.cloudProviders;
return /*#__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.saveMap.title'
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "subtitle"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.saveMap.subtitle'
}))), /*#__PURE__*/_react["default"].createElement(_providerSelect.ProviderSelect, {
cloudProviders: cloudProviders
}));
};
var STYLED_EXPORT_SECTION_STYLE = {
margin: '2px 0'
};
var PROVIDER_MANAGER_URL_STYLE = {
textDecoration: 'underline'
};
function SaveMapModalFactory() {
var SaveMapModal = function SaveMapModal(_ref3) {
var mapInfo = _ref3.mapInfo,
exportImage = _ref3.exportImage,
_ref3$characterLimits = _ref3.characterLimits,
characterLimits = _ref3$characterLimits === void 0 ? _constants.MAP_INFO_CHARACTER : _ref3$characterLimits,
isProviderLoading = _ref3.isProviderLoading,
providerError = _ref3.providerError,
_ref3$onUpdateImageSe = _ref3.onUpdateImageSetting,
onUpdateImageSetting = _ref3$onUpdateImageSe === void 0 ? nop : _ref3$onUpdateImageSe,
cleanupExportImage = _ref3.cleanupExportImage,
onSetMapInfo = _ref3.onSetMapInfo,
onCancel = _ref3.onCancel,
onConfirm = _ref3.onConfirm;
var _useCloudListProvider = (0, _useCloudListProvider2.useCloudListProvider)(),
provider = _useCloudListProvider.provider,
cloudProviders = _useCloudListProvider.cloudProviders;
var onChangeInput = function onChangeInput(key, _ref4) {
var value = _ref4.target.value;
onSetMapInfo((0, _defineProperty2["default"])({}, key, value));
};
var confirmButton = (0, _react.useMemo)(function () {
return {
large: true,
disabled: Boolean(!(provider && mapInfo.title)),
children: 'modal.button.save'
};
}, [provider, mapInfo]);
var confirm = (0, _react.useCallback)(function () {
if (provider) {
onConfirm(provider);
}
}, [onConfirm, provider]);
return /*#__PURE__*/_react["default"].createElement(_imageModalContainer["default"], {
provider: provider,
onUpdateImageSetting: onUpdateImageSetting,
cleanupExportImage: cleanupExportImage
}, /*#__PURE__*/_react["default"].createElement(StyledSaveMapModal, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalContent, {
className: "save-map-modal-content"
}, /*#__PURE__*/_react["default"].createElement(SaveMapHeader, {
cloudProviders: cloudProviders
}), provider && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, provider.getManagementUrl ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledExportSection, {
style: STYLED_EXPORT_SECTION_STYLE
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "selection"
}, /*#__PURE__*/_react["default"].createElement("a", {
key: 1,
href: provider.getManagementUrl(),
target: "_blank",
rel: "noopener noreferrer",
style: PROVIDER_MANAGER_URL_STYLE
}, "Go to your Kepler.gl ", provider.displayName, " page"))) : null, /*#__PURE__*/_react["default"].createElement(StyledCompactExportSection, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "description image-preview-panel"
}, /*#__PURE__*/_react["default"].createElement(_imagePreview["default"], {
exportImage: exportImage,
width: _constants.MAP_THUMBNAIL_DIMENSION.width,
showDimension: false
})), isProviderLoading ? /*#__PURE__*/_react["default"].createElement("div", {
"data-testid": _constants.dataTestIds.providerLoading,
className: "selection map-saving-animation"
}, /*#__PURE__*/_react["default"].createElement(_statusPanel.UploadAnimation, {
icon: provider && provider.icon
})) : /*#__PURE__*/_react["default"].createElement(MapInfoPanel, {
mapInfo: mapInfo,
characterLimits: characterLimits,
onChangeInput: onChangeInput
}))), providerError ? /*#__PURE__*/_react["default"].createElement(_statusPanel["default"], {
isLoading: false,
error: providerError.message,
providerIcon: provider && provider.icon
}) : null)), /*#__PURE__*/_react["default"].createElement(_modal.ModalFooter, {
cancel: onCancel,
confirm: confirm,
confirmButton: confirmButton
}));
};
return SaveMapModal;
}
var _default = exports["default"] = SaveMapModalFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_imageModalContainer","_flexContainer","_statusPanel","_providerSelect","_constants","_styledComponents2","_imagePreview","_localization","_modal","_useCloudListProvider2","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledSaveMapModal","styled","div","attrs","className","_taggedTemplateLiteral2","StyledCompactExportSection","StyledExportSection","nop","TEXT_AREA_LIGHT_STYLE","resize","MapInfoPanel","exports","_ref","mapInfo","characterLimits","onChangeInput","_mapInfo$description","description","_mapInfo$title","title","createElement","dataTestIds","providerMapInfoPanel","StyledModalSection","InputLight","id","type","value","onChange","placeholder","FlexContainer","TextAreaLight","rows","style","StyledModalInputFootnote","error","Boolean","length","Number","MAP_INFO_CHARACTER","SaveMapHeader","_ref2","cloudProviders","FormattedMessage","ProviderSelect","STYLED_EXPORT_SECTION_STYLE","margin","PROVIDER_MANAGER_URL_STYLE","textDecoration","SaveMapModalFactory","SaveMapModal","_ref3","exportImage","_ref3$characterLimits","isProviderLoading","providerError","_ref3$onUpdateImageSe","onUpdateImageSetting","cleanupExportImage","onSetMapInfo","onCancel","onConfirm","_useCloudListProvider","useCloudListProvider","provider","key","_ref4","target","_defineProperty2","confirmButton","useMemo","large","disabled","children","confirm","useCallback","StyledModalContent","Fragment","getManagementUrl","href","rel","displayName","width","MAP_THUMBNAIL_DIMENSION","showDimension","providerLoading","UploadAnimation","icon","isLoading","message","providerIcon","ModalFooter","cancel","_default"],"sources":["../../src/modals/save-map-modal.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport styled from 'styled-components';\nimport ImageModalContainer, {ImageModalContainerProps} from './image-modal-container';\nimport {FlexContainer} from '../common/flex-container';\nimport StatusPanel, {UploadAnimation} from './status-panel';\nimport {ProviderSelect} from './cloud-components/provider-select';\nimport {\n  MAP_THUMBNAIL_DIMENSION,\n  MAP_INFO_CHARACTER,\n  ExportImage,\n  dataTestIds\n} from '@kepler.gl/constants';\n\nimport {\n  StyledModalContent,\n  InputLight,\n  TextAreaLight,\n  StyledExportSection,\n  StyledModalSection,\n  StyledModalInputFootnote\n} from '../common/styled-components';\nimport ImagePreview from '../common/image-preview';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {MapInfo} from '@kepler.gl/types';\nimport {Provider} from '@kepler.gl/cloud-providers';\nimport {setMapInfo, cleanupExportImage as cleanupExportImageAction} from '@kepler.gl/actions';\nimport {ModalFooter} from '../common/modal';\nimport {useCloudListProvider} from '../hooks/use-cloud-list-provider';\n\nconst StyledSaveMapModal = styled.div.attrs({\n  className: 'save-map-modal'\n})`\n  .save-map-modal-content {\n    min-height: 400px;\n    flex-direction: column;\n  }\n\n  .description {\n    width: 300px;\n  }\n\n  .image-preview-panel {\n    width: 300px;\n\n    .image-preview {\n      padding: 0;\n    }\n  }\n\n  .map-info-panel {\n    flex-direction: column;\n  }\n\n  .save-map-modal-description {\n    .modal-section-subtitle {\n      margin-left: 6px;\n    }\n  }\n`;\n\nconst StyledCompactExportSection = styled(StyledExportSection)`\n  margin: 5px 0;\n`;\n\nconst nop = () => {\n  return;\n};\nconst TEXT_AREA_LIGHT_STYLE = {resize: 'none'};\n\ntype CharacterLimits = {\n  title?: number;\n  description?: number;\n};\n\ntype SaveMapModalProps = {\n  mapInfo: MapInfo;\n  exportImage: ExportImage;\n  isProviderLoading: boolean;\n  providerError?: Error;\n  characterLimits?: CharacterLimits;\n\n  // callbacks\n  onUpdateImageSetting: ImageModalContainerProps['onUpdateImageSetting'];\n  cleanupExportImage: typeof cleanupExportImageAction;\n  onSetMapInfo: typeof setMapInfo;\n  onConfirm: (provider: Provider) => void;\n  onCancel: () => void;\n};\n\ntype MapInfoPanelProps = Pick<SaveMapModalProps, 'mapInfo' | 'characterLimits'> & {\n  onChangeInput: (\n    type: string,\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void;\n};\n\nexport const MapInfoPanel: React.FC<MapInfoPanelProps> = ({\n  mapInfo,\n  characterLimits,\n  onChangeInput\n}) => {\n  const {description = '', title = ''} = mapInfo;\n  return (\n    <div className=\"selection map-info-panel\" data-testid={dataTestIds.providerMapInfoPanel}>\n      <StyledModalSection className=\"save-map-modal-name\">\n        <div className=\"modal-section-title\">Name*</div>\n        <div>\n          <InputLight\n            id=\"map-title\"\n            type=\"text\"\n            value={title}\n            onChange={e => onChangeInput('title', e)}\n            placeholder=\"Type map title\"\n          />\n        </div>\n      </StyledModalSection>\n      <StyledModalSection>\n        <FlexContainer className=\"save-map-modal-description\">\n          <div className=\"modal-section-title\">Description</div>\n          <div className=\"modal-section-subtitle\">(optional)</div>\n        </FlexContainer>\n        <div>\n          <TextAreaLight\n            rows={3}\n            id=\"map-description\"\n            style={TEXT_AREA_LIGHT_STYLE as React.CSSProperties}\n            value={description}\n            onChange={e => onChangeInput('description', e)}\n            placeholder=\"Type map description\"\n          />\n        </div>\n        <StyledModalInputFootnote\n          error={\n            Boolean(characterLimits?.description) &&\n            description.length > Number(characterLimits?.description)\n          }\n        >\n          {description.length}/{characterLimits?.description || MAP_INFO_CHARACTER.description}{' '}\n          characters\n        </StyledModalInputFootnote>\n      </StyledModalSection>\n    </div>\n  );\n};\n\nconst SaveMapHeader = ({cloudProviders}) => {\n  return (\n    <StyledExportSection>\n      <div className=\"description\">\n        <div className=\"title\">\n          <FormattedMessage id={'modal.saveMap.title'} />\n        </div>\n        <div className=\"subtitle\">\n          <FormattedMessage id={'modal.saveMap.subtitle'} />\n        </div>\n      </div>\n      <ProviderSelect cloudProviders={cloudProviders} />\n    </StyledExportSection>\n  );\n};\n\nconst STYLED_EXPORT_SECTION_STYLE = {margin: '2px 0'};\nconst PROVIDER_MANAGER_URL_STYLE = {textDecoration: 'underline'};\n\nfunction SaveMapModalFactory() {\n  const SaveMapModal: React.FC<SaveMapModalProps> = ({\n    mapInfo,\n    exportImage,\n    characterLimits = MAP_INFO_CHARACTER,\n    isProviderLoading,\n    providerError,\n    onUpdateImageSetting = nop,\n    cleanupExportImage,\n    onSetMapInfo,\n    onCancel,\n    onConfirm\n  }) => {\n    const {provider, cloudProviders} = useCloudListProvider();\n\n    const onChangeInput = (\n      key: string,\n      {target: {value}}: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n    ) => {\n      onSetMapInfo({[key]: value});\n    };\n\n    const confirmButton = useMemo(\n      () => ({\n        large: true,\n        disabled: Boolean(!(provider && mapInfo.title)),\n        children: 'modal.button.save'\n      }),\n      [provider, mapInfo]\n    );\n\n    const confirm = useCallback(() => {\n      if (provider) {\n        onConfirm(provider);\n      }\n    }, [onConfirm, provider]);\n\n    return (\n      <ImageModalContainer\n        provider={provider}\n        onUpdateImageSetting={onUpdateImageSetting}\n        cleanupExportImage={cleanupExportImage}\n      >\n        <StyledSaveMapModal>\n          <StyledModalContent className=\"save-map-modal-content\">\n            <SaveMapHeader cloudProviders={cloudProviders} />\n            {provider && (\n              <>\n                {provider.getManagementUrl ? (\n                  <StyledExportSection style={STYLED_EXPORT_SECTION_STYLE}>\n                    <div className=\"selection\">\n                      <a\n                        key={1}\n                        href={provider.getManagementUrl()}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={PROVIDER_MANAGER_URL_STYLE}\n                      >\n                        Go to your Kepler.gl {provider.displayName} page\n                      </a>\n                    </div>\n                  </StyledExportSection>\n                ) : null}\n                <StyledCompactExportSection>\n                  <div className=\"description image-preview-panel\">\n                    <ImagePreview\n                      exportImage={exportImage}\n                      width={MAP_THUMBNAIL_DIMENSION.width}\n                      showDimension={false}\n                    />\n                  </div>\n                  {isProviderLoading ? (\n                    <div\n                      data-testid={dataTestIds.providerLoading}\n                      className=\"selection map-saving-animation\"\n                    >\n                      <UploadAnimation icon={provider && provider.icon} />\n                    </div>\n                  ) : (\n                    <MapInfoPanel\n                      mapInfo={mapInfo}\n                      characterLimits={characterLimits}\n                      onChangeInput={onChangeInput}\n                    />\n                  )}\n                </StyledCompactExportSection>\n              </>\n            )}\n            {providerError ? (\n              <StatusPanel\n                isLoading={false}\n                error={providerError.message}\n                providerIcon={provider && provider.icon}\n              />\n            ) : null}\n          </StyledModalContent>\n        </StyledSaveMapModal>\n        <ModalFooter cancel={onCancel} confirm={confirm} confirmButton={confirmButton} />\n      </ImageModalContainer>\n    );\n  };\n\n  return SaveMapModal;\n}\n\nexport default SaveMapModalFactory;\n"],"mappings":"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","ignoreList":[]}