kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
177 lines (145 loc) • 24.2 kB
JavaScript
;
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 _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
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 _exportImageUtils = require("../../utils/export-image-utils");
var _defaultSettings = require("../../constants/default-settings");
var _styledComponents2 = require("../common/styled-components");
var _switch = _interopRequireDefault(require("../common/switch"));
var _loadingSpinner = _interopRequireDefault(require("../common/loading-spinner"));
var _templateObject, _templateObject2;
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
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 PreviewImageSection = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n align-items: center;\n display: flex;\n flex-direction: column;\n flex: 1;\n justify-content: center;\n padding: 30px;\n\n .dimension,\n .instruction {\n padding: 8px 0px;\n }\n\n .preview-image {\n background: #e2e2e2;\n border-radius: 4px;\n box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.18);\n width: 100%;\n padding-bottom: ", ";\n position: relative;\n }\n\n .preview-image-placeholder {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n }\n\n .preview-image-spinner {\n position: absolute;\n left: calc(50% - 25px);\n top: calc(50% - 25px);\n }\n\n .preview-image--error {\n font-size: 12px;\n padding: 12px;\n color: ", ";\n text-align: center;\n }\n"])), function (props) {
return props.ratio === _defaultSettings.RATIOS.SCREEN ? "".concat(100 * props.height / props.width, "%") : props.ratio === _defaultSettings.RATIOS.SIXTEEN_BY_NINE ? '56.25%' : '75%';
}, function (props) {
return props.theme.errorColor;
});
var ExportImageModal = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(ExportImageModal, _Component);
var _super = _createSuper(ExportImageModal);
function ExportImageModal() {
(0, _classCallCheck2["default"])(this, ExportImageModal);
return _super.apply(this, arguments);
}
(0, _createClass2["default"])(ExportImageModal, [{
key: "render",
value: function render() {
var _this$props = this.props,
height = _this$props.height,
legend = _this$props.legend,
ratio = _this$props.ratio,
error = _this$props.error,
resolution = _this$props.resolution,
width = _this$props.width,
exporting = _this$props.exporting,
imageDataUri = _this$props.imageDataUri,
onChangeRatio = _this$props.onChangeRatio,
onChangeResolution = _this$props.onChangeResolution,
onToggleLegend = _this$props.onToggleLegend;
var exportImageSize = (0, _exportImageUtils.calculateExportImageSize)({
width: width,
height: height,
ratio: ratio,
resolution: resolution
});
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"
}, "Ratio"), "Choose the ratio for various usages.", /*#__PURE__*/_react["default"].createElement("div", {
className: "button-list"
}, _defaultSettings.RATIO_OPTIONS.map(function (op) {
return (/*#__PURE__*/_react["default"].createElement(_styledComponents2.SelectionButton, {
key: op.id,
selected: ratio === op.id,
onClick: function onClick() {
return onChangeRatio({
ratio: op.id
});
}
}, op.label)
);
}))), /*#__PURE__*/_react["default"].createElement("div", {
className: "image-option-section"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "image-option-section-title"
}, "Resolution"), "High resolution is better for prints.", /*#__PURE__*/_react["default"].createElement("div", {
className: "button-list"
}, _defaultSettings.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 && onChangeResolution({
resolution: op.id
});
}
}, op.label)
);
}))), /*#__PURE__*/_react["default"].createElement("div", {
className: "image-option-section"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "image-option-section-title"
}, "Map Legend"), /*#__PURE__*/_react["default"].createElement(_switch["default"], {
type: "checkbox",
id: "add-map-legend",
checked: legend,
label: "Add legend on map",
onChange: onToggleLegend
}))), /*#__PURE__*/_react["default"].createElement(PreviewImageSection, {
ratio: ratio,
width: width,
height: height
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "dimension"
}, "".concat(exportImageSize.width, " x ").concat(exportImageSize.height)), /*#__PURE__*/_react["default"].createElement("div", {
className: "preview-image"
}, exporting ? /*#__PURE__*/_react["default"].createElement("div", {
className: "preview-image-spinner"
}, /*#__PURE__*/_react["default"].createElement(_loadingSpinner["default"], null)) : error ? /*#__PURE__*/_react["default"].createElement("div", {
className: "preview-image--error"
}, /*#__PURE__*/_react["default"].createElement("span", null, " ", error.message || 'Generate map image failed!')) : /*#__PURE__*/_react["default"].createElement("img", {
className: "preview-image-placeholder",
src: imageDataUri
}))))
);
}
}]);
return ExportImageModal;
}(_react.Component);
(0, _defineProperty2["default"])(ExportImageModal, "propTypes", {
height: _propTypes["default"].number.isRequired,
ratio: _propTypes["default"].string.isRequired,
resolution: _propTypes["default"].string.isRequired,
width: _propTypes["default"].number.isRequired,
exporting: _propTypes["default"].bool.isRequired,
imageDataUri: _propTypes["default"].string,
// callbacks
onChangeRatio: _propTypes["default"].func.isRequired,
onChangeResolution: _propTypes["default"].func.isRequired,
onToggleLegend: _propTypes["default"].func.isRequired
});
var ExportImageModalFactory = function ExportImageModalFactory() {
return ExportImageModal;
};
var _default = exports["default"] = ExportImageModalFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/export-image-modal.js"],"names":["ImageOptionList","styled","div","PreviewImageSection","props","ratio","RATIOS","SCREEN","height","width","SIXTEEN_BY_NINE","theme","errorColor","ExportImageModal","legend","error","resolution","exporting","imageDataUri","onChangeRatio","onChangeResolution","onToggleLegend","exportImageSize","RATIO_OPTIONS","map","op","id","label","RESOLUTION_OPTIONS","available","message","Component","PropTypes","number","isRequired","string","bool","func","ExportImageModalFactory"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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';\n\nimport {calculateExportImageSize} from 'utils/export-image-utils';\nimport {\n  RATIO_OPTIONS,\n  RATIOS,\n  RESOLUTION_OPTIONS\n} from 'constants/default-settings';\n\nimport {\n  StyledModalContent,\n  SelectionButton\n} from 'components/common/styled-components';\nimport Switch from 'components/common/switch';\nimport LoadingSpinner from 'components/common/loading-spinner';\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 PreviewImageSection = styled.div`\n  align-items: center;\n  display: flex;\n  flex-direction: column;\n  flex: 1;\n  justify-content: center;\n  padding: 30px;\n\n  .dimension,\n  .instruction {\n    padding: 8px 0px;\n  }\n\n  .preview-image {\n    background: #e2e2e2;\n    border-radius: 4px;\n    box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.18);\n    width: 100%;\n    padding-bottom: ${props =>\n      props.ratio === RATIOS.SCREEN\n        ? `${(100 * props.height) / props.width}%`\n        : props.ratio === RATIOS.SIXTEEN_BY_NINE\n        ? '56.25%'\n        : '75%'};\n    position: relative;\n  }\n\n  .preview-image-placeholder {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n  }\n\n  .preview-image-spinner {\n    position: absolute;\n    left: calc(50% - 25px);\n    top: calc(50% - 25px);\n  }\n\n  .preview-image--error {\n    font-size: 12px;\n    padding: 12px;\n    color: ${props => props.theme.errorColor};\n    text-align: center;\n  }\n`;\n\nclass ExportImageModal extends Component {\n  static propTypes = {\n    height: PropTypes.number.isRequired,\n    ratio: PropTypes.string.isRequired,\n    resolution: PropTypes.string.isRequired,\n    width: PropTypes.number.isRequired,\n    exporting: PropTypes.bool.isRequired,\n    imageDataUri: PropTypes.string,\n    // callbacks\n    onChangeRatio: PropTypes.func.isRequired,\n    onChangeResolution: PropTypes.func.isRequired,\n    onToggleLegend: PropTypes.func.isRequired\n  };\n\n  render() {\n    const {\n      height,\n      legend,\n      ratio,\n      error,\n      resolution,\n      width,\n      exporting,\n      imageDataUri,\n      // callbacks:\n      onChangeRatio,\n      onChangeResolution,\n      onToggleLegend\n    } = this.props;\n\n    const exportImageSize = calculateExportImageSize({\n      width,\n      height,\n      ratio,\n      resolution\n    });\n\n    return (\n      <StyledModalContent className=\"export-image-modal\">\n        <ImageOptionList>\n          <div className=\"image-option-section\">\n            <div className=\"image-option-section-title\">Ratio</div>\n            Choose the ratio for various usages.\n            <div className=\"button-list\">\n              {RATIO_OPTIONS.map(op => (\n                <SelectionButton\n                  key={op.id}\n                  selected={ratio === op.id}\n                  onClick={() => onChangeRatio({ratio: 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\">Resolution</div>\n            High resolution is better for prints.\n            <div className=\"button-list\">\n              {RESOLUTION_OPTIONS.map(op => (\n                <SelectionButton\n                  key={op.id}\n                  selected={resolution === op.id}\n                  onClick={() =>\n                    op.available && onChangeResolution({resolution: op.id})\n                  }\n                >\n                  {op.label}\n                </SelectionButton>\n              ))}\n            </div>\n          </div>\n          <div className=\"image-option-section\">\n            <div className=\"image-option-section-title\">Map Legend</div>\n            <Switch\n              type=\"checkbox\"\n              id=\"add-map-legend\"\n              checked={legend}\n              label=\"Add legend on map\"\n              onChange={onToggleLegend}\n            />\n          </div>\n        </ImageOptionList>\n        <PreviewImageSection ratio={ratio} width={width} height={height}>\n          <div className=\"dimension\">{`${exportImageSize.width} x ${\n            exportImageSize.height\n          }`}</div>\n          <div className=\"preview-image\">\n            {exporting ? (\n              <div className=\"preview-image-spinner\">\n                <LoadingSpinner />\n              </div>\n            ) : error ? (\n              <div className=\"preview-image--error\">\n                <span> {error.message || 'Generate map image failed!'}</span>\n              </div>\n            ) : (\n              <img className=\"preview-image-placeholder\" src={imageDataUri} />\n            )}\n          </div>\n        </PreviewImageSection>\n      </StyledModalContent>\n    );\n  }\n}\n\nconst ExportImageModalFactory = () => ExportImageModal;\nexport default ExportImageModalFactory;\n"]}