kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
136 lines (119 loc) • 17.4 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"] = 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 _defaultSettings = require("../../constants/default-settings");
var _styledComponents2 = require("../common/styled-components");
var _switch = _interopRequireDefault(require("../common/switch"));
var _reactIntl = require("react-intl");
var _localization = require("../../localization");
var _templateObject;
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() {
/** @type {typeof import('./export-image-modal').ExportImageModal} */
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"
}, _defaultSettings.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"
}, _defaultSettings.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 = 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","mapW","mapH","exportImage","onUpdateImageSetting","cleanupExportImage","intl","legend","ratio","resolution","exporting","EXPORT_IMG_RATIO_OPTIONS","filter","op","hidden","map","id","label","EXPORT_IMG_RESOLUTION_OPTIONS","available","formatMessage"],"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, {useEffect} from 'react';\nimport styled from 'styled-components';\nimport ImagePreview from 'components/common/image-preview';\n\nimport {EXPORT_IMG_RATIO_OPTIONS, EXPORT_IMG_RESOLUTION_OPTIONS} from 'constants/default-settings';\n\nimport {StyledModalContent, SelectionButton, CheckMark} from 'components/common/styled-components';\nimport Switch from 'components/common/switch';\nimport {injectIntl} from 'react-intl';\nimport {FormattedMessage} from '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\nconst ExportImageModalFactory = () => {\n  /** @type {typeof import('./export-image-modal').ExportImageModal} */\n  const ExportImageModal = ({\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"]}