UNPKG

kepler.gl

Version:

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

186 lines (158 loc) 19.2 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _imagePreview = _interopRequireDefault(require("../common/image-preview")); var _defaultSettings = require("../../constants/default-settings"); var _styledComponents2 = require("../common/styled-components"); var _switch = _interopRequireDefault(require("../common/switch")); var _reactIntl = require("react-intl"); function _templateObject() { var data = (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"]); _templateObject = function _templateObject() { return data; }; return data; } var ImageOptionList = _styledComponents["default"].div(_templateObject()); var ExportImageModalFactory = function ExportImageModalFactory() { var ExportImageModal = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(ExportImageModal, _Component); function ExportImageModal() { (0, _classCallCheck2["default"])(this, ExportImageModal); return (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(ExportImageModal).apply(this, arguments)); } (0, _createClass2["default"])(ExportImageModal, [{ key: "componentDidMount", value: function componentDidMount() { this._updateMapDim(); } }, { key: "componentDidUpdate", value: function componentDidUpdate() { this._updateMapDim(); } }, { key: "_updateMapDim", value: function _updateMapDim() { var _this$props = this.props, exportImage = _this$props.exportImage, mapH = _this$props.mapH, mapW = _this$props.mapW; if (mapH !== exportImage.mapH || mapW !== exportImage.mapW) { this.props.onUpdateSetting({ mapH: mapH, mapW: mapW, ratio: _defaultSettings.EXPORT_IMG_RATIOS.CUSTOM, legend: false }); } } }, { key: "render", value: function render() { var _this$props2 = this.props, exportImage = _this$props2.exportImage, onUpdateSetting = _this$props2.onUpdateSetting, intl = _this$props2.intl; var legend = exportImage.legend, ratio = exportImage.ratio, resolution = exportImage.resolution; return _react["default"].createElement(_styledComponents2.StyledModalContent, { className: "export-image-modal" }, _react["default"].createElement(ImageOptionList, null, _react["default"].createElement("div", { className: "image-option-section" }, _react["default"].createElement("div", { className: "image-option-section-title" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportImage.ratioTitle' })), _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportImage.ratioDescription' }), _react["default"].createElement("div", { className: "button-list" }, _defaultSettings.EXPORT_IMG_RATIO_OPTIONS.filter(function (op) { return !op.hidden; }).map(function (op) { return _react["default"].createElement(_styledComponents2.SelectionButton, { key: op.id, selected: ratio === op.id, onClick: function onClick() { return onUpdateSetting({ ratio: op.id }); } }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: op.label })); }))), _react["default"].createElement("div", { className: "image-option-section" }, _react["default"].createElement("div", { className: "image-option-section-title" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportImage.resolutionTitle' })), _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportImage.resolutionDescription' }), _react["default"].createElement("div", { className: "button-list" }, _defaultSettings.EXPORT_IMG_RESOLUTION_OPTIONS.map(function (op) { return _react["default"].createElement(_styledComponents2.SelectionButton, { key: op.id, selected: resolution === op.id, onClick: function onClick() { return op.available && onUpdateSetting({ resolution: op.id }); } }, op.label); }))), _react["default"].createElement("div", { className: "image-option-section" }, _react["default"].createElement("div", { className: "image-option-section-title" }, _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'modal.exportImage.mapLegendTitle' })), _react["default"].createElement(_switch["default"], { type: "checkbox", id: "add-map-legend", checked: legend, label: intl.formatMessage({ id: 'modal.exportImage.mapLegendAdd' }), onChange: function onChange() { return onUpdateSetting({ legend: !legend }); } }))), _react["default"].createElement(_imagePreview["default"], { exportImage: exportImage })); } }]); return ExportImageModal; }(_react.Component); (0, _defineProperty2["default"])(ExportImageModal, "propTypes", { mapW: _propTypes["default"].number.isRequired, mapH: _propTypes["default"].number.isRequired, exportImage: _propTypes["default"].object.isRequired, // callbacks onUpdateSetting: _propTypes["default"].func.isRequired }); return (0, _reactIntl.injectIntl)(ExportImageModal); }; var _default = ExportImageModalFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/export-image-modal.js"],"names":["ImageOptionList","styled","div","ExportImageModalFactory","ExportImageModal","_updateMapDim","props","exportImage","mapH","mapW","onUpdateSetting","ratio","EXPORT_IMG_RATIOS","CUSTOM","legend","intl","resolution","EXPORT_IMG_RATIO_OPTIONS","filter","op","hidden","map","id","label","EXPORT_IMG_RESOLUTION_OPTIONS","available","formatMessage","Component","PropTypes","number","isRequired","object","func"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport ImagePreview from 'components/common/image-preview';\n\nimport {\n  EXPORT_IMG_RATIO_OPTIONS,\n  EXPORT_IMG_RESOLUTION_OPTIONS,\n  EXPORT_IMG_RATIOS\n} from 'constants/default-settings';\n\nimport {StyledModalContent, SelectionButton} from 'components/common/styled-components';\nimport Switch from 'components/common/switch';\nimport {FormattedMessage, injectIntl} from 'react-intl';\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\nconst ExportImageModalFactory = () => {\n  class ExportImageModal extends Component {\n    static propTypes = {\n      mapW: PropTypes.number.isRequired,\n      mapH: PropTypes.number.isRequired,\n      exportImage: PropTypes.object.isRequired,\n      // callbacks\n      onUpdateSetting: PropTypes.func.isRequired\n    };\n\n    componentDidMount() {\n      this._updateMapDim();\n    }\n\n    componentDidUpdate() {\n      this._updateMapDim();\n    }\n\n    _updateMapDim() {\n      const {exportImage, mapH, mapW} = this.props;\n      if (mapH !== exportImage.mapH || mapW !== exportImage.mapW) {\n        this.props.onUpdateSetting({\n          mapH,\n          mapW,\n          ratio: EXPORT_IMG_RATIOS.CUSTOM,\n          legend: false\n        });\n      }\n    }\n\n    render() {\n      const {exportImage, onUpdateSetting, intl} = this.props;\n      const {legend, ratio, resolution} = exportImage;\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\">\n                {EXPORT_IMG_RATIO_OPTIONS.filter(op => !op.hidden).map(op => (\n                  <SelectionButton\n                    key={op.id}\n                    selected={ratio === op.id}\n                    onClick={() => onUpdateSetting({ratio: op.id})}\n                  >\n                    <FormattedMessage id={op.label} />\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\">\n                {EXPORT_IMG_RESOLUTION_OPTIONS.map(op => (\n                  <SelectionButton\n                    key={op.id}\n                    selected={resolution === op.id}\n                    onClick={() => op.available && onUpdateSetting({resolution: op.id})}\n                  >\n                    {op.label}\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={() => onUpdateSetting({legend: !legend})}\n              />\n            </div>\n          </ImageOptionList>\n          <ImagePreview exportImage={exportImage} />\n        </StyledModalContent>\n      );\n    }\n  }\n\n  return injectIntl(ExportImageModal);\n};\n\nexport default ExportImageModalFactory;\n"]}