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