kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
217 lines (172 loc) • 24.7 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = PlotContainerFactory;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
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 _reselect = require("reselect");
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactMapGl = require("react-map-gl");
var _lodash = _interopRequireDefault(require("lodash.debounce"));
var _notificationsUtils = require("../utils/notifications-utils");
var _mapContainer = _interopRequireDefault(require("./map-container"));
var _exportImageUtils = require("../utils/export-image-utils");
var _mapboxGlStyleEditor = require("../utils/map-style-utils/mapbox-gl-style-editor");
var _templateObject;
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 ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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 propTypes = {
width: _propTypes["default"].number.isRequired,
height: _propTypes["default"].number.isRequired,
exportImageSetting: _propTypes["default"].object.isRequired,
addNotification: _propTypes["default"].func.isRequired,
mapFields: _propTypes["default"].object.isRequired
};
PlotContainerFactory.deps = [_mapContainer["default"]]; // Remove mapbox logo in exported map, because it contains non-ascii characters
var StyledPlotContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .mapboxgl-ctrl-bottom-left,\n .mapboxgl-ctrl-bottom-right {\n display: none;\n }\n"])));
var deckGlProps = {
glOptions: {
preserveDrawingBuffer: true,
useDevicePixels: false
}
};
function PlotContainerFactory(MapContainer) {
var PlotContainer = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(PlotContainer, _Component);
var _super = _createSuper(PlotContainer);
function PlotContainer(_props) {
var _this;
(0, _classCallCheck2["default"])(this, PlotContainer);
_this = _super.call(this, _props);
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "plottingAreaRef", (0, _react.createRef)());
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "mapStyleSelector", function (props) {
return props.mapFields.mapStyle;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "resolutionSelector", function (props) {
return props.exportImageSetting.resolution;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "scaledMapStyleSelector", (0, _reselect.createSelector)(_this.mapStyleSelector, _this.resolutionSelector, function (mapStyle, resolution) {
return _objectSpread(_objectSpread({}, mapStyle), {}, {
bottomMapStyle: (0, _mapboxGlStyleEditor.scaleMapStyleByResolution)(mapStyle.bottomMapStyle, resolution),
topMapStyle: (0, _mapboxGlStyleEditor.scaleMapStyleByResolution)(mapStyle.topMapStyle, resolution)
});
}));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onMapRender", function (map) {
if (map.isStyleLoaded()) {
_this._retrieveNewScreenshot();
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_retrieveNewScreenshot", function () {
if (_this.plottingAreaRef.current) {
_this.props.startExportingImage();
var filter = function filter(node) {
return node.className !== 'mapboxgl-control-container';
};
(0, _exportImageUtils.convertToPng)(_this.plottingAreaRef.current, {
filter: filter
}).then(function (dataUri) {
_this.props.setExportImageDataUri(dataUri);
})["catch"](function (err) {
_this.props.setExportImageError(err);
_this.props.addNotification((0, _notificationsUtils.exportImageError)({
err: err
}));
});
}
});
_this._onMapRender = (0, _lodash["default"])(_this._onMapRender, 500);
return _this;
}
(0, _createClass2["default"])(PlotContainer, [{
key: "componentWillMount",
value: function componentWillMount() {
this.props.startExportingImage();
}
}, {
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(newProps) {
var _this2 = this;
// re-fetch the new screenshot only when ratio legend or resolution changes
var checks = ['ratio', 'resolution', 'legend'];
var shouldRetrieveScreenshot = checks.some(function (item) {
return _this2.props.exportImageSetting[item] !== newProps.exportImageSetting[item];
});
if (shouldRetrieveScreenshot) {
this._retrieveNewScreenshot();
}
}
}, {
key: "render",
value: function render() {
var _this$props = this.props,
width = _this$props.width,
height = _this$props.height,
exportImageSetting = _this$props.exportImageSetting,
mapFields = _this$props.mapFields;
var ratio = exportImageSetting.ratio,
resolution = exportImageSetting.resolution,
legend = exportImageSetting.legend;
var exportImageSize = (0, _exportImageUtils.calculateExportImageSize)({
width: width,
height: height,
ratio: ratio,
resolution: resolution
});
var mapProps = _objectSpread(_objectSpread({}, mapFields), {}, {
mapStyle: this.scaledMapStyleSelector(this.props),
// override viewport based on export settings
mapState: _objectSpread(_objectSpread(_objectSpread({}, mapFields.mapState), exportImageSize), {}, {
zoom: mapFields.mapState.zoom + exportImageSize.zoomOffset
}),
mapControls: {
// override map legend visibility
mapLegend: {
show: legend,
active: true
}
},
MapComponent: _reactMapGl.StaticMap
});
return (/*#__PURE__*/_react["default"].createElement(StyledPlotContainer, {
style: {
position: 'absolute',
top: -9999,
left: -9999
}
}, /*#__PURE__*/_react["default"].createElement("div", {
ref: this.plottingAreaRef,
style: {
width: exportImageSize.width,
height: exportImageSize.height
}
}, /*#__PURE__*/_react["default"].createElement(MapContainer, (0, _extends2["default"])({
index: 0,
onMapRender: this._onMapRender,
isExport: true,
deckGlProps: deckGlProps
}, mapProps))))
);
}
}]);
return PlotContainer;
}(_react.Component);
PlotContainer.propsTypes = propTypes;
return PlotContainer;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/plot-container.js"],"names":["propTypes","width","PropTypes","number","isRequired","height","exportImageSetting","object","addNotification","func","mapFields","PlotContainerFactory","deps","MapContainerFactory","StyledPlotContainer","styled","div","deckGlProps","glOptions","preserveDrawingBuffer","useDevicePixels","MapContainer","PlotContainer","props","mapStyle","resolution","mapStyleSelector","resolutionSelector","bottomMapStyle","topMapStyle","map","isStyleLoaded","_retrieveNewScreenshot","plottingAreaRef","current","startExportingImage","filter","node","className","then","dataUri","setExportImageDataUri","err","setExportImageError","_onMapRender","newProps","checks","shouldRetrieveScreenshot","some","item","ratio","legend","exportImageSize","mapProps","scaledMapStyleSelector","mapState","zoom","zoomOffset","mapControls","mapLegend","show","active","MapComponent","StaticMap","position","top","left","Component","propsTypes"],"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\n// libraries\nimport React, {Component, createRef} from 'react';\nimport PropTypes from 'prop-types';\nimport {createSelector} from 'reselect';\nimport styled from 'styled-components';\nimport {StaticMap} from 'react-map-gl';\nimport debounce from 'lodash.debounce';\nimport {exportImageError} from 'utils/notifications-utils';\nimport MapContainerFactory from './map-container';\nimport {calculateExportImageSize, convertToPng} from 'utils/export-image-utils';\nimport {scaleMapStyleByResolution} from 'utils/map-style-utils/mapbox-gl-style-editor';\n\nconst propTypes = {\n  width: PropTypes.number.isRequired,\n  height: PropTypes.number.isRequired,\n  exportImageSetting: PropTypes.object.isRequired,\n  addNotification: PropTypes.func.isRequired,\n  mapFields: PropTypes.object.isRequired\n};\n\nPlotContainerFactory.deps = [MapContainerFactory];\n\n// Remove mapbox logo in exported map, because it contains non-ascii characters\nconst StyledPlotContainer = styled.div`\n  .mapboxgl-ctrl-bottom-left,\n  .mapboxgl-ctrl-bottom-right {\n    display: none;\n  }\n`;\n\nconst deckGlProps = {\n  glOptions: {\n    preserveDrawingBuffer: true,\n    useDevicePixels: false\n  }\n};\n\nexport default function PlotContainerFactory(MapContainer) {\n  class PlotContainer extends Component {\n    constructor(props) {\n      super(props);\n      this._onMapRender = debounce(this._onMapRender, 500);\n    }\n\n    componentWillMount() {\n      this.props.startExportingImage();\n    }\n\n    componentWillReceiveProps(newProps) {\n      // re-fetch the new screenshot only when ratio legend or resolution changes\n      const checks = ['ratio', 'resolution', 'legend'];\n      const shouldRetrieveScreenshot = checks.some(\n        item =>\n          this.props.exportImageSetting[item] !==\n          newProps.exportImageSetting[item]\n      );\n      if (shouldRetrieveScreenshot) {\n        this._retrieveNewScreenshot();\n      }\n    }\n\n    plottingAreaRef = createRef();\n\n    mapStyleSelector = props => props.mapFields.mapStyle;\n    resolutionSelector = props => props.exportImageSetting.resolution;\n    scaledMapStyleSelector = createSelector(\n      this.mapStyleSelector,\n      this.resolutionSelector,\n      (mapStyle, resolution) => ({\n        ...mapStyle,\n        bottomMapStyle: scaleMapStyleByResolution(\n          mapStyle.bottomMapStyle,\n          resolution\n        ),\n        topMapStyle: scaleMapStyleByResolution(mapStyle.topMapStyle, resolution)\n      })\n    );\n\n    _onMapRender = map => {\n      if (map.isStyleLoaded()) {\n        this._retrieveNewScreenshot();\n      }\n    };\n\n    _retrieveNewScreenshot = () => {\n      if (this.plottingAreaRef.current) {\n        this.props.startExportingImage();\n        const filter = node => node.className !== 'mapboxgl-control-container';\n\n        convertToPng(this.plottingAreaRef.current, {filter})\n          .then(dataUri => {\n            this.props.setExportImageDataUri(dataUri);\n          })\n          .catch(err => {\n            this.props.setExportImageError(err);\n            this.props.addNotification(exportImageError({err}));\n          });\n      }\n    };\n\n    render() {\n      const {width, height, exportImageSetting, mapFields} = this.props;\n      const {ratio, resolution, legend} = exportImageSetting;\n      const exportImageSize = calculateExportImageSize({\n        width,\n        height,\n        ratio,\n        resolution\n      });\n\n      const mapProps = {\n        ...mapFields,\n        mapStyle: this.scaledMapStyleSelector(this.props),\n\n        // override viewport based on export settings\n        mapState: {\n          ...mapFields.mapState,\n          ...exportImageSize,\n          zoom: mapFields.mapState.zoom + exportImageSize.zoomOffset\n        },\n        mapControls: {\n          // override map legend visibility\n          mapLegend: {\n            show: legend,\n            active: true\n          }\n        },\n        MapComponent: StaticMap\n      };\n\n      return (\n        <StyledPlotContainer\n          style={{position: 'absolute', top: -9999, left: -9999}}\n        >\n          <div\n            ref={this.plottingAreaRef}\n            style={{\n              width: exportImageSize.width,\n              height: exportImageSize.height\n            }}\n          >\n            <MapContainer\n              index={0}\n              onMapRender={this._onMapRender}\n              isExport\n              deckGlProps={deckGlProps}\n              {...mapProps}\n            />\n          </div>\n        </StyledPlotContainer>\n      );\n    }\n  }\n\n  PlotContainer.propsTypes = propTypes;\n  return PlotContainer;\n}\n"]}