UNPKG

kepler.gl

Version:

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

121 lines (120 loc) 20.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _imagePreview = _interopRequireDefault(require("../common/image-preview")); var _constants = require("@kepler.gl/constants"); var _styledComponents2 = require("../common/styled-components"); var _switch = _interopRequireDefault(require("../common/switch")); var _reactIntl = require("react-intl"); var _localization = require("@kepler.gl/localization"); var _templateObject; // 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 ImageOptionList = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n justify-content: space-around;\n width: 250px;\n\n .image-option-section {\n .image-option-section-title {\n font-weight: 500;\n font-size: 14px;\n }\n }\n\n .button-list {\n display: flex;\n flex-direction: row;\n padding: 8px 0px;\n }\n\n input {\n margin-right: 8px;\n }\n"]))); var ExportImageModalFactory = function ExportImageModalFactory() { var ExportImageModal = function ExportImageModal(_ref) { var mapW = _ref.mapW, mapH = _ref.mapH, exportImage = _ref.exportImage, onUpdateImageSetting = _ref.onUpdateImageSetting, cleanupExportImage = _ref.cleanupExportImage, intl = _ref.intl; var legend = exportImage.legend, ratio = exportImage.ratio, resolution = exportImage.resolution; (0, _react.useEffect)(function () { onUpdateImageSetting({ exporting: true }); return cleanupExportImage; }, [onUpdateImageSetting, cleanupExportImage]); (0, _react.useEffect)(function () { if (mapH !== exportImage.mapH || mapW !== exportImage.mapW) { onUpdateImageSetting({ mapH: mapH, mapW: mapW }); } }, [mapH, mapW, exportImage, onUpdateImageSetting]); return /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalContent, { className: "export-image-modal" }, /*#__PURE__*/_react["default"].createElement(ImageOptionList, null, /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section" }, /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.ratioTitle' })), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.ratioDescription' }), /*#__PURE__*/_react["default"].createElement("div", { className: "button-list", id: "export-image-modal__option_ratio" }, _constants.EXPORT_IMG_RATIO_OPTIONS.filter(function (op) { return !op.hidden; }).map(function (op) { return /*#__PURE__*/_react["default"].createElement(_styledComponents2.SelectionButton, { key: op.id, selected: ratio === op.id, onClick: function onClick() { return onUpdateImageSetting({ ratio: op.id }); } }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: op.label }), ratio === op.id && /*#__PURE__*/_react["default"].createElement(_styledComponents2.CheckMark, null)); }))), /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section" }, /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.resolutionTitle' })), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.resolutionDescription' }), /*#__PURE__*/_react["default"].createElement("div", { className: "button-list", id: "export-image-modal__option_resolution" }, _constants.EXPORT_IMG_RESOLUTION_OPTIONS.map(function (op) { return /*#__PURE__*/_react["default"].createElement(_styledComponents2.SelectionButton, { key: op.id, selected: resolution === op.id, onClick: function onClick() { return op.available && onUpdateImageSetting({ resolution: op.id }); } }, op.label, resolution === op.id && /*#__PURE__*/_react["default"].createElement(_styledComponents2.CheckMark, null)); }))), /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section" }, /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.mapLegendTitle' })), /*#__PURE__*/_react["default"].createElement(_switch["default"], { type: "checkbox", id: "add-map-legend", checked: legend, label: intl.formatMessage({ id: 'modal.exportImage.mapLegendAdd' }), onChange: function onChange() { return onUpdateImageSetting({ legend: !legend }); } }))), /*#__PURE__*/_react["default"].createElement(_imagePreview["default"], { exportImage: exportImage })); }; return (0, _reactIntl.injectIntl)(ExportImageModal); }; var _default = exports["default"] = ExportImageModalFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_imagePreview","_constants","_styledComponents2","_switch","_reactIntl","_localization","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ImageOptionList","styled","div","_taggedTemplateLiteral2","ExportImageModalFactory","ExportImageModal","_ref","mapW","mapH","exportImage","onUpdateImageSetting","cleanupExportImage","intl","legend","ratio","resolution","useEffect","exporting","createElement","StyledModalContent","className","FormattedMessage","id","EXPORT_IMG_RATIO_OPTIONS","filter","op","hidden","map","SelectionButton","key","selected","onClick","label","CheckMark","EXPORT_IMG_RESOLUTION_OPTIONS","available","type","checked","formatMessage","onChange","injectIntl","_default","exports"],"sources":["../../src/modals/export-image-modal.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useEffect} from 'react';\nimport styled from 'styled-components';\nimport ImagePreview from '../common/image-preview';\nimport {SetExportImageSettingUpdaterAction} from '@kepler.gl/actions';\n\nimport {EXPORT_IMG_RATIO_OPTIONS, EXPORT_IMG_RESOLUTION_OPTIONS} from '@kepler.gl/constants';\nimport {ExportImage} from '@kepler.gl/types';\nimport {StyledModalContent, SelectionButton, CheckMark} from '../common/styled-components';\nimport Switch from '../common/switch';\nimport {injectIntl, IntlShape} from 'react-intl';\nimport {FormattedMessage} from '@kepler.gl/localization';\n\nconst ImageOptionList = styled.div`\n  display: flex;\n  flex-direction: column;\n  justify-content: space-around;\n  width: 250px;\n\n  .image-option-section {\n    .image-option-section-title {\n      font-weight: 500;\n      font-size: 14px;\n    }\n  }\n\n  .button-list {\n    display: flex;\n    flex-direction: row;\n    padding: 8px 0px;\n  }\n\n  input {\n    margin-right: 8px;\n  }\n`;\n\nexport interface ExportImageModalProps {\n  exportImage: ExportImage;\n  mapW: number;\n  mapH: number;\n  onUpdateImageSetting: (payload: SetExportImageSettingUpdaterAction['payload']) => void;\n  cleanupExportImage: () => void;\n  intl: IntlShape;\n}\n\nconst ExportImageModalFactory = () => {\n  const ExportImageModal: React.FC<ExportImageModalProps> = ({\n    mapW,\n    mapH,\n    exportImage,\n    onUpdateImageSetting,\n    cleanupExportImage,\n    intl\n  }) => {\n    const {legend, ratio, resolution} = exportImage;\n\n    useEffect(() => {\n      onUpdateImageSetting({\n        exporting: true\n      });\n      return cleanupExportImage;\n    }, [onUpdateImageSetting, cleanupExportImage]);\n\n    useEffect(() => {\n      if (mapH !== exportImage.mapH || mapW !== exportImage.mapW) {\n        onUpdateImageSetting({\n          mapH,\n          mapW\n        });\n      }\n    }, [mapH, mapW, exportImage, onUpdateImageSetting]);\n\n    return (\n      <StyledModalContent className=\"export-image-modal\">\n        <ImageOptionList>\n          <div className=\"image-option-section\">\n            <div className=\"image-option-section-title\">\n              <FormattedMessage id={'modal.exportImage.ratioTitle'} />\n            </div>\n            <FormattedMessage id={'modal.exportImage.ratioDescription'} />\n            <div className=\"button-list\" id=\"export-image-modal__option_ratio\">\n              {EXPORT_IMG_RATIO_OPTIONS.filter(op => !op.hidden).map(op => (\n                <SelectionButton\n                  key={op.id}\n                  selected={ratio === op.id}\n                  onClick={() => onUpdateImageSetting({ratio: op.id})}\n                >\n                  <FormattedMessage id={op.label} />\n                  {ratio === op.id && <CheckMark />}\n                </SelectionButton>\n              ))}\n            </div>\n          </div>\n          <div className=\"image-option-section\">\n            <div className=\"image-option-section-title\">\n              <FormattedMessage id={'modal.exportImage.resolutionTitle'} />\n            </div>\n            <FormattedMessage id={'modal.exportImage.resolutionDescription'} />\n            <div className=\"button-list\" id=\"export-image-modal__option_resolution\">\n              {EXPORT_IMG_RESOLUTION_OPTIONS.map(op => (\n                <SelectionButton\n                  key={op.id}\n                  selected={resolution === op.id}\n                  onClick={() => op.available && onUpdateImageSetting({resolution: op.id})}\n                >\n                  {op.label}\n                  {resolution === op.id && <CheckMark />}\n                </SelectionButton>\n              ))}\n            </div>\n          </div>\n          <div className=\"image-option-section\">\n            <div className=\"image-option-section-title\">\n              <FormattedMessage id={'modal.exportImage.mapLegendTitle'} />\n            </div>\n            <Switch\n              type=\"checkbox\"\n              id=\"add-map-legend\"\n              checked={legend}\n              label={intl.formatMessage({id: 'modal.exportImage.mapLegendAdd'})}\n              onChange={() => onUpdateImageSetting({legend: !legend})}\n            />\n          </div>\n        </ImageOptionList>\n        <ImagePreview exportImage={exportImage} />\n      </StyledModalContent>\n    );\n  };\n\n  return injectIntl(ExportImageModal);\n};\n\nexport default ExportImageModalFactory;\n"],"mappings":"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","ignoreList":[]}