Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@deck.gl/react

Package Overview
Dependencies
Maintainers
1
Versions
474
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@deck.gl/react - npm Package Compare versions

Comparing version 5.3.0-rc.1 to 5.3.0-rc.2

606

dist/deckgl.js

@@ -1,330 +0,396 @@

// Copyright (c) 2015 - 2017 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
import React, { createElement, cloneElement } from 'react';
import PropTypes from 'prop-types';
import autobind from './utils/autobind';
import { inheritsFrom } from './utils/inherits-from';
import { Deck, Layer, log } from '@deck.gl/core';
const propTypes = Object.assign({}, Deck.getPropTypes(PropTypes), {
viewports: PropTypes.array,
// Deprecated
viewport: PropTypes.object // Deprecated
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
const defaultProps = Deck.defaultProps;
export default class DeckGL extends React.Component {
constructor(props) {
super(props);
this.state = {};
this.children = [];
autobind(this);
}
exports.default = void 0;
componentDidMount() {
this.deck = new Deck(Object.assign({}, this.props, {
canvas: this.deckCanvas,
viewState: this._getViewState(this.props),
// Note: If Deck event handling change size or view state, it calls onResize to update
onViewStateChange: this._onViewStateChange,
onResize: this._onResize
}));
var _react = _interopRequireWildcard(require("react"));
this._updateFromProps(this.props);
}
var _propTypes = _interopRequireDefault(require("prop-types"));
componentWillReceiveProps(nextProps) {
this._updateFromProps(nextProps);
}
var _autobind = _interopRequireDefault(require("./utils/autobind"));
componentWillUnmount() {
this.deck.finalize();
} // Public API
var _inheritsFrom = require("./utils/inherits-from");
var _core = require("@deck.gl/core");
pickObject({
x,
y,
radius = 0,
layerIds = null
}) {
return this.deck.pickObject({
x,
y,
radius,
layerIds
});
}
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
pickMultipleObjects({
x,
y,
radius = 0,
layerIds = null,
depth = 10
}) {
return this.deck.pickMultipleObjects({
x,
y,
radius,
layerIds,
depth
});
}
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
pickObjects({
x,
y,
width = 1,
height = 1,
layerIds = null
}) {
return this.deck.pickObjects({
x,
y,
width,
height,
layerIds
});
}
function _instanceof(left, right) { if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) { return right[Symbol.hasInstance](left); } else { return left instanceof right; } }
queryObject(opts) {
log.deprecated('queryObject', 'pickObject')();
return this.deck.pickObject(opts);
}
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
queryVisibleObjects(opts) {
log.deprecated('queryVisibleObjects', 'pickObjects')();
return this.pickObjects(opts);
} // Callbacks
// Forward callback and then call forceUpdate to guarantee that sub components update
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); }
_onResize(...args) {
if (this.props.onResize) {
this.props.onResize(...args);
}
function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); }
this.forceUpdate();
} // Forward callback and then call forceUpdate to guarantee that sub components update
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }
function _classCallCheck(instance, Constructor) { if (!_instanceof(instance, Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
_onViewStateChange(...args) {
if (this.props.onViewStateChange) {
this.props.onViewStateChange(...args);
}
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
this.forceUpdate();
} // Private Helpers
// 1. Extract any JSX layers from the react children
// 2. Handle any backwards compatiblity props for React layer
// Needs to be called both from initial mount, and when new props arrive
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
_updateFromProps(nextProps) {
// extract any deck.gl layers masquerading as react elements from props.children
const {
layers,
children
} = this._extractJSXLayers(nextProps.children);
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } _setPrototypeOf(subClass.prototype, superClass && superClass.prototype); if (superClass) _setPrototypeOf(subClass, superClass); }
if (this.deck) {
this.deck.setProps(Object.assign({}, nextProps, {
views: this._getViews(nextProps),
viewState: this._getViewState(nextProps),
// Avoid modifying layers array if no JSX layers were found
layers: layers ? [...layers, ...nextProps.layers] : nextProps.layers
}));
}
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
this.children = children;
} // Support old `viewports` prop (React only!)
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
var propTypes = Object.assign({}, _core.Deck.getPropTypes(_propTypes.default), {
viewports: _propTypes.default.array,
// Deprecated
viewport: _propTypes.default.object // Deprecated
_getViews(props) {
if (props.viewports) {
log.deprecated('DeckGL.viewports', 'DeckGL.views')();
});
var defaultProps = _core.Deck.defaultProps;
var DeckGL =
/*#__PURE__*/
function (_React$Component) {
_inherits(DeckGL, _React$Component);
function DeckGL(props) {
var _this;
_classCallCheck(this, DeckGL);
_this = _possibleConstructorReturn(this, (DeckGL.__proto__ || Object.getPrototypeOf(DeckGL)).call(this, props));
_this.state = {};
_this.children = [];
(0, _autobind.default)(_assertThisInitialized(_this));
return _this;
}
_createClass(DeckGL, [{
key: "componentDidMount",
value: function componentDidMount() {
this.deck = new _core.Deck(Object.assign({}, this.props, {
canvas: this.deckCanvas,
viewState: this._getViewState(this.props),
// Note: If Deck event handling change size or view state, it calls onResize to update
onViewStateChange: this._onViewStateChange,
onResize: this._onResize
}));
this._updateFromProps(this.props);
}
}, {
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(nextProps) {
this._updateFromProps(nextProps);
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
this.deck.finalize();
} // Public API
if (props.viewport) {
log.deprecated('DeckGL.viewport', 'DeckGL.views')();
}, {
key: "pickObject",
value: function pickObject(_ref) {
var x = _ref.x,
y = _ref.y,
_ref$radius = _ref.radius,
radius = _ref$radius === void 0 ? 0 : _ref$radius,
_ref$layerIds = _ref.layerIds,
layerIds = _ref$layerIds === void 0 ? null : _ref$layerIds;
return this.deck.pickObject({
x: x,
y: y,
radius: radius,
layerIds: layerIds
});
}
}, {
key: "pickMultipleObjects",
value: function pickMultipleObjects(_ref2) {
var x = _ref2.x,
y = _ref2.y,
_ref2$radius = _ref2.radius,
radius = _ref2$radius === void 0 ? 0 : _ref2$radius,
_ref2$layerIds = _ref2.layerIds,
layerIds = _ref2$layerIds === void 0 ? null : _ref2$layerIds,
_ref2$depth = _ref2.depth,
depth = _ref2$depth === void 0 ? 10 : _ref2$depth;
return this.deck.pickMultipleObjects({
x: x,
y: y,
radius: radius,
layerIds: layerIds,
depth: depth
});
}
}, {
key: "pickObjects",
value: function pickObjects(_ref3) {
var x = _ref3.x,
y = _ref3.y,
_ref3$width = _ref3.width,
width = _ref3$width === void 0 ? 1 : _ref3$width,
_ref3$height = _ref3.height,
height = _ref3$height === void 0 ? 1 : _ref3$height,
_ref3$layerIds = _ref3.layerIds,
layerIds = _ref3$layerIds === void 0 ? null : _ref3$layerIds;
return this.deck.pickObjects({
x: x,
y: y,
width: width,
height: height,
layerIds: layerIds
});
}
}, {
key: "queryObject",
value: function queryObject(opts) {
_core.log.deprecated('queryObject', 'pickObject')();
return props.views || props.viewports || props.viewport && [props.viewport];
} // Supports old "geospatial view state as separate props" style (React only!)
return this.deck.pickObject(opts);
}
}, {
key: "queryVisibleObjects",
value: function queryVisibleObjects(opts) {
_core.log.deprecated('queryVisibleObjects', 'pickObjects')();
return this.pickObjects(opts);
} // Callbacks
// Forward callback and then call forceUpdate to guarantee that sub components update
_getViewState(props) {
let {
viewState
} = props;
}, {
key: "_onResize",
value: function _onResize() {
if (this.props.onResize) {
var _this$props;
if (!viewState && 'latitude' in props && 'longitude' in props && 'zoom' in props) {
const {
latitude,
longitude,
zoom,
pitch = 0,
bearing = 0
} = props;
viewState = props.viewState || {
latitude,
longitude,
zoom,
pitch,
bearing
};
}
(_this$props = this.props).onResize.apply(_this$props, arguments);
}
return viewState;
} // extracts any deck.gl layers masquerading as react elements from props.children
this.forceUpdate();
} // Forward callback and then call forceUpdate to guarantee that sub components update
}, {
key: "_onViewStateChange",
value: function _onViewStateChange() {
if (this.props.onViewStateChange) {
var _this$props2;
_extractJSXLayers(children) {
const reactChildren = []; // extract real react elements (i.e. not deck.gl layers)
(_this$props2 = this.props).onViewStateChange.apply(_this$props2, arguments);
}
let layers = null; // extracted layer from react children, will add to deck.gl layer array
this.forceUpdate();
} // Private Helpers
// 1. Extract any JSX layers from the react children
// 2. Handle any backwards compatiblity props for React layer
// Needs to be called both from initial mount, and when new props arrive
React.Children.forEach(children, reactElement => {
if (reactElement) {
// For some reason Children.forEach doesn't filter out `null`s
const LayerType = reactElement.type;
}, {
key: "_updateFromProps",
value: function _updateFromProps(nextProps) {
// extract any deck.gl layers masquerading as react elements from props.children
var _this$_extractJSXLaye = this._extractJSXLayers(nextProps.children),
layers = _this$_extractJSXLaye.layers,
children = _this$_extractJSXLaye.children;
if (inheritsFrom(LayerType, Layer)) {
const layer = new LayerType(reactElement.props);
layers = layers || [];
layers.push(layer);
} else {
reactChildren.push(reactElement);
}
if (this.deck) {
this.deck.setProps(Object.assign({}, nextProps, {
views: this._getViews(nextProps),
viewState: this._getViewState(nextProps),
// Avoid modifying layers array if no JSX layers were found
layers: layers ? _toConsumableArray(layers).concat(_toConsumableArray(nextProps.layers)) : nextProps.layers
}));
}
});
return {
layers,
children: reactChildren
};
} // Iterate over views and reposition children associated with views
// TODO - Can we supply a similar function for the non-React case?
this.children = children;
} // Support old `viewports` prop (React only!)
_renderChildrenUnderViews(children) {
// Flatten out nested views array
const views = this.deck ? this.deck.getViewports() : []; // Build a view id to view index
}, {
key: "_getViews",
value: function _getViews(props) {
if (props.viewports) {
_core.log.deprecated('DeckGL.viewports', 'DeckGL.views')();
}
const viewMap = {};
views.forEach(view => {
if (view.id) {
viewMap[view.id] = view;
if (props.viewport) {
_core.log.deprecated('DeckGL.viewport', 'DeckGL.views')();
}
});
return children.map( // If child specifies props.viewId, position under view, otherwise render as normal
(child, i) => child.props.viewId || child.props.viewId ? this._positionChild({
child,
viewMap,
i
}) : child);
}
_positionChild({
child,
viewMap,
i
}) {
const {
viewId,
viewportId
} = child.props;
return props.views || props.viewports || props.viewport && [props.viewport];
} // Supports old "geospatial view state as separate props" style (React only!)
if (viewportId) {
log.deprecated('viewportId', 'viewId')();
}, {
key: "_getViewState",
value: function _getViewState(props) {
var viewState = props.viewState;
if (!viewState && 'latitude' in props && 'longitude' in props && 'zoom' in props) {
var latitude = props.latitude,
longitude = props.longitude,
zoom = props.zoom,
_props$pitch = props.pitch,
pitch = _props$pitch === void 0 ? 0 : _props$pitch,
_props$bearing = props.bearing,
bearing = _props$bearing === void 0 ? 0 : _props$bearing;
viewState = props.viewState || {
latitude: latitude,
longitude: longitude,
zoom: zoom,
pitch: pitch,
bearing: bearing
};
}
return viewState;
} // extracts any deck.gl layers masquerading as react elements from props.children
}, {
key: "_extractJSXLayers",
value: function _extractJSXLayers(children) {
var reactChildren = []; // extract real react elements (i.e. not deck.gl layers)
var layers = null; // extracted layer from react children, will add to deck.gl layer array
_react.default.Children.forEach(children, function (reactElement) {
if (reactElement) {
// For some reason Children.forEach doesn't filter out `null`s
var LayerType = reactElement.type;
if ((0, _inheritsFrom.inheritsFrom)(LayerType, _core.Layer)) {
var layer = new LayerType(reactElement.props);
layers = layers || [];
layers.push(layer);
} else {
reactChildren.push(reactElement);
}
}
});
return {
layers: layers,
children: reactChildren
};
} // Iterate over views and reposition children associated with views
// TODO - Can we supply a similar function for the non-React case?
}, {
key: "_renderChildrenUnderViews",
value: function _renderChildrenUnderViews(children) {
var _this2 = this;
// Flatten out nested views array
var views = this.deck ? this.deck.getViewports() : []; // Build a view id to view index
var viewMap = {};
views.forEach(function (view) {
if (view.id) {
viewMap[view.id] = view;
}
});
return children.map( // If child specifies props.viewId, position under view, otherwise render as normal
function (child, i) {
return child.props.viewId || child.props.viewId ? _this2._positionChild({
child: child,
viewMap: viewMap,
i: i
}) : child;
});
}
}, {
key: "_positionChild",
value: function _positionChild(_ref4) {
var child = _ref4.child,
viewMap = _ref4.viewMap,
i = _ref4.i;
var _child$props = child.props,
viewId = _child$props.viewId,
viewportId = _child$props.viewportId;
const view = viewMap[viewId || viewportId]; // Drop (auto-hide) elements with viewId that are not matched by any current view
if (viewportId) {
_core.log.deprecated('viewportId', 'viewId')();
}
if (!view) {
return null;
} // Resolve potentially relative dimensions using the deck.gl container size
var view = viewMap[viewId || viewportId]; // Drop (auto-hide) elements with viewId that are not matched by any current view
if (!view) {
return null;
} // Resolve potentially relative dimensions using the deck.gl container size
const {
x,
y,
width,
height
} = view; // Clone the element with width and height set per view
const newProps = Object.assign({}, child.props, {
width,
height
}); // Inject map properties
// TODO - this is too react-map-gl specific
var x = view.x,
y = view.y,
width = view.width,
height = view.height; // Clone the element with width and height set per view
Object.assign(newProps, view.getMercatorParams(), {
visible: view.isMapSynched()
});
const clone = cloneElement(child, newProps); // Wrap it in an absolutely positioning div
var newProps = Object.assign({}, child.props, {
width: width,
height: height
}); // Inject map properties
// TODO - this is too react-map-gl specific
const style = {
position: 'absolute',
left: x,
top: y,
width,
height
};
const key = `view-child-${viewId}-${i}`;
return createElement('div', {
key,
id: key,
style
}, clone);
}
Object.assign(newProps, view.getMercatorParams(), {
visible: view.isMapSynched()
});
var clone = (0, _react.cloneElement)(child, newProps); // Wrap it in an absolutely positioning div
render() {
// Render the background elements (typically react-map-gl instances)
// using the view descriptors
const children = this._renderChildrenUnderViews(this.children); // Note that width and height are handled by deck.gl
var style = {
position: 'absolute',
left: x,
top: y,
width: width,
height: height
};
var key = "view-child-".concat(viewId, "-").concat(i);
return (0, _react.createElement)('div', {
key: key,
id: key,
style: style
}, clone);
}
}, {
key: "render",
value: function render() {
var _this3 = this;
// Render the background elements (typically react-map-gl instances)
// using the view descriptors
var children = this._renderChildrenUnderViews(this.children); // Note that width and height are handled by deck.gl
const {
id
} = this.props; // TODO - this styling is enforced for correct positioning with children
// It can override the styling set by `Deck`, this should be consolidated.
const style = Object.assign({}, {
position: 'absolute',
left: 0,
top: 0
}, this.props.style);
const canvas = createElement('canvas', {
ref: c => this.deckCanvas = c,
key: 'deck-canvas',
id,
style
}); // Render deck.gl as last child
var id = this.props.id; // TODO - this styling is enforced for correct positioning with children
// It can override the styling set by `Deck`, this should be consolidated.
children.push(canvas);
return createElement('div', {
id: 'deckgl-wrapper'
}, children);
}
var style = Object.assign({}, {
position: 'absolute',
left: 0,
top: 0
}, this.props.style);
var canvas = (0, _react.createElement)('canvas', {
ref: function ref(c) {
return _this3.deckCanvas = c;
},
key: 'deck-canvas',
id: id,
style: style
}); // Render deck.gl as last child
}
children.push(canvas);
return (0, _react.createElement)('div', {
id: 'deckgl-wrapper'
}, children);
}
}]);
return DeckGL;
}(_react.default.Component);
exports.default = DeckGL;
DeckGL.propTypes = propTypes;
DeckGL.defaultProps = defaultProps;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/deckgl.js"],"names":["React","createElement","cloneElement","PropTypes","autobind","inheritsFrom","Deck","Layer","log","propTypes","Object","assign","getPropTypes","viewports","array","viewport","object","defaultProps","DeckGL","Component","constructor","props","state","children","componentDidMount","deck","canvas","deckCanvas","viewState","_getViewState","onViewStateChange","_onViewStateChange","onResize","_onResize","_updateFromProps","componentWillReceiveProps","nextProps","componentWillUnmount","finalize","pickObject","x","y","radius","layerIds","pickMultipleObjects","depth","pickObjects","width","height","queryObject","opts","deprecated","queryVisibleObjects","args","forceUpdate","layers","_extractJSXLayers","setProps","views","_getViews","latitude","longitude","zoom","pitch","bearing","reactChildren","Children","forEach","reactElement","LayerType","type","layer","push","_renderChildrenUnderViews","getViewports","viewMap","view","id","map","child","i","viewId","_positionChild","viewportId","newProps","getMercatorParams","visible","isMapSynched","clone","style","position","left","top","key","render","ref","c"],"mappings":"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","sourcesContent":["// Copyright (c) 2015 - 2017 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, {createElement, cloneElement} from 'react';\nimport PropTypes from 'prop-types';\nimport autobind from './utils/autobind';\nimport {inheritsFrom} from './utils/inherits-from';\nimport {Deck, Layer, log} from '@deck.gl/core';\n\nconst propTypes = Object.assign({}, Deck.getPropTypes(PropTypes), {\n  viewports: PropTypes.array, // Deprecated\n  viewport: PropTypes.object // Deprecated\n});\n\nconst defaultProps = Deck.defaultProps;\n\nexport default class DeckGL extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {};\n    this.children = [];\n    autobind(this);\n  }\n\n  componentDidMount() {\n    this.deck = new Deck(\n      Object.assign({}, this.props, {\n        canvas: this.deckCanvas,\n        viewState: this._getViewState(this.props),\n        // Note: If Deck event handling change size or view state, it calls onResize to update\n        onViewStateChange: this._onViewStateChange,\n        onResize: this._onResize\n      })\n    );\n    this._updateFromProps(this.props);\n  }\n\n  componentWillReceiveProps(nextProps) {\n    this._updateFromProps(nextProps);\n  }\n\n  componentWillUnmount() {\n    this.deck.finalize();\n  }\n\n  // Public API\n\n  pickObject({x, y, radius = 0, layerIds = null}) {\n    return this.deck.pickObject({x, y, radius, layerIds});\n  }\n\n  pickMultipleObjects({x, y, radius = 0, layerIds = null, depth = 10}) {\n    return this.deck.pickMultipleObjects({x, y, radius, layerIds, depth});\n  }\n\n  pickObjects({x, y, width = 1, height = 1, layerIds = null}) {\n    return this.deck.pickObjects({x, y, width, height, layerIds});\n  }\n\n  queryObject(opts) {\n    log.deprecated('queryObject', 'pickObject')();\n    return this.deck.pickObject(opts);\n  }\n\n  queryVisibleObjects(opts) {\n    log.deprecated('queryVisibleObjects', 'pickObjects')();\n    return this.pickObjects(opts);\n  }\n\n  // Callbacks\n\n  // Forward callback and then call forceUpdate to guarantee that sub components update\n  _onResize(...args) {\n    if (this.props.onResize) {\n      this.props.onResize(...args);\n    }\n    this.forceUpdate();\n  }\n\n  // Forward callback and then call forceUpdate to guarantee that sub components update\n  _onViewStateChange(...args) {\n    if (this.props.onViewStateChange) {\n      this.props.onViewStateChange(...args);\n    }\n    this.forceUpdate();\n  }\n\n  // Private Helpers\n\n  // 1. Extract any JSX layers from the react children\n  // 2. Handle any backwards compatiblity props for React layer\n  // Needs to be called both from initial mount, and when new props arrive\n  _updateFromProps(nextProps) {\n    // extract any deck.gl layers masquerading as react elements from props.children\n    const {layers, children} = this._extractJSXLayers(nextProps.children);\n\n    if (this.deck) {\n      this.deck.setProps(\n        Object.assign({}, nextProps, {\n          views: this._getViews(nextProps),\n          viewState: this._getViewState(nextProps),\n          // Avoid modifying layers array if no JSX layers were found\n          layers: layers ? [...layers, ...nextProps.layers] : nextProps.layers\n        })\n      );\n    }\n\n    this.children = children;\n  }\n\n  // Support old `viewports` prop (React only!)\n  _getViews(props) {\n    if (props.viewports) {\n      log.deprecated('DeckGL.viewports', 'DeckGL.views')();\n    }\n    if (props.viewport) {\n      log.deprecated('DeckGL.viewport', 'DeckGL.views')();\n    }\n    return props.views || props.viewports || (props.viewport && [props.viewport]);\n  }\n\n  // Supports old \"geospatial view state as separate props\" style (React only!)\n  _getViewState(props) {\n    let {viewState} = props;\n\n    if (!viewState && 'latitude' in props && 'longitude' in props && 'zoom' in props) {\n      const {latitude, longitude, zoom, pitch = 0, bearing = 0} = props;\n      viewState = props.viewState || {latitude, longitude, zoom, pitch, bearing};\n    }\n\n    return viewState;\n  }\n\n  // extracts any deck.gl layers masquerading as react elements from props.children\n  _extractJSXLayers(children) {\n    const reactChildren = []; // extract real react elements (i.e. not deck.gl layers)\n    let layers = null; // extracted layer from react children, will add to deck.gl layer array\n\n    React.Children.forEach(children, reactElement => {\n      if (reactElement) {\n        // For some reason Children.forEach doesn't filter out `null`s\n        const LayerType = reactElement.type;\n        if (inheritsFrom(LayerType, Layer)) {\n          const layer = new LayerType(reactElement.props);\n          layers = layers || [];\n          layers.push(layer);\n        } else {\n          reactChildren.push(reactElement);\n        }\n      }\n    });\n\n    return {layers, children: reactChildren};\n  }\n\n  // Iterate over views and reposition children associated with views\n  // TODO - Can we supply a similar function for the non-React case?\n  _renderChildrenUnderViews(children) {\n    // Flatten out nested views array\n    const views = this.deck ? this.deck.getViewports() : [];\n\n    // Build a view id to view index\n    const viewMap = {};\n    views.forEach(view => {\n      if (view.id) {\n        viewMap[view.id] = view;\n      }\n    });\n\n    return children.map(\n      // If child specifies props.viewId, position under view, otherwise render as normal\n      (child, i) =>\n        child.props.viewId || child.props.viewId ? this._positionChild({child, viewMap, i}) : child\n    );\n  }\n\n  _positionChild({child, viewMap, i}) {\n    const {viewId, viewportId} = child.props;\n    if (viewportId) {\n      log.deprecated('viewportId', 'viewId')();\n    }\n    const view = viewMap[viewId || viewportId];\n\n    // Drop (auto-hide) elements with viewId that are not matched by any current view\n    if (!view) {\n      return null;\n    }\n\n    // Resolve potentially relative dimensions using the deck.gl container size\n    const {x, y, width, height} = view;\n\n    // Clone the element with width and height set per view\n    const newProps = Object.assign({}, child.props, {width, height});\n\n    // Inject map properties\n    // TODO - this is too react-map-gl specific\n    Object.assign(newProps, view.getMercatorParams(), {\n      visible: view.isMapSynched()\n    });\n\n    const clone = cloneElement(child, newProps);\n\n    // Wrap it in an absolutely positioning div\n    const style = {position: 'absolute', left: x, top: y, width, height};\n    const key = `view-child-${viewId}-${i}`;\n    return createElement('div', {key, id: key, style}, clone);\n  }\n\n  render() {\n    // Render the background elements (typically react-map-gl instances)\n    // using the view descriptors\n    const children = this._renderChildrenUnderViews(this.children);\n\n    // Note that width and height are handled by deck.gl\n    const {id} = this.props;\n    // TODO - this styling is enforced for correct positioning with children\n    // It can override the styling set by `Deck`, this should be consolidated.\n    const style = Object.assign({}, {position: 'absolute', left: 0, top: 0}, this.props.style);\n\n    const canvas = createElement('canvas', {\n      ref: c => (this.deckCanvas = c),\n      key: 'deck-canvas',\n      id,\n      style\n    });\n\n    // Render deck.gl as last child\n    children.push(canvas);\n\n    return createElement('div', {id: 'deckgl-wrapper'}, children);\n  }\n}\n\nDeckGL.propTypes = propTypes;\nDeckGL.defaultProps = defaultProps;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/deckgl.js"],"names":["propTypes","Object","assign","Deck","getPropTypes","PropTypes","viewports","array","viewport","object","defaultProps","DeckGL","props","state","children","deck","canvas","deckCanvas","viewState","_getViewState","onViewStateChange","_onViewStateChange","onResize","_onResize","_updateFromProps","nextProps","finalize","x","y","radius","layerIds","pickObject","depth","pickMultipleObjects","width","height","pickObjects","opts","log","deprecated","forceUpdate","_extractJSXLayers","layers","setProps","views","_getViews","latitude","longitude","zoom","pitch","bearing","reactChildren","React","Children","forEach","reactElement","LayerType","type","Layer","layer","push","getViewports","viewMap","view","id","map","child","i","viewId","_positionChild","viewportId","newProps","getMercatorParams","visible","isMapSynched","clone","style","position","left","top","key","_renderChildrenUnderViews","ref","c","Component"],"mappings":"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","sourcesContent":["// Copyright (c) 2015 - 2017 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, {createElement, cloneElement} from 'react';\nimport PropTypes from 'prop-types';\nimport autobind from './utils/autobind';\nimport {inheritsFrom} from './utils/inherits-from';\nimport {Deck, Layer, log} from '@deck.gl/core';\n\nconst propTypes = Object.assign({}, Deck.getPropTypes(PropTypes), {\n  viewports: PropTypes.array, // Deprecated\n  viewport: PropTypes.object // Deprecated\n});\n\nconst defaultProps = Deck.defaultProps;\n\nexport default class DeckGL extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {};\n    this.children = [];\n    autobind(this);\n  }\n\n  componentDidMount() {\n    this.deck = new Deck(\n      Object.assign({}, this.props, {\n        canvas: this.deckCanvas,\n        viewState: this._getViewState(this.props),\n        // Note: If Deck event handling change size or view state, it calls onResize to update\n        onViewStateChange: this._onViewStateChange,\n        onResize: this._onResize\n      })\n    );\n    this._updateFromProps(this.props);\n  }\n\n  componentWillReceiveProps(nextProps) {\n    this._updateFromProps(nextProps);\n  }\n\n  componentWillUnmount() {\n    this.deck.finalize();\n  }\n\n  // Public API\n\n  pickObject({x, y, radius = 0, layerIds = null}) {\n    return this.deck.pickObject({x, y, radius, layerIds});\n  }\n\n  pickMultipleObjects({x, y, radius = 0, layerIds = null, depth = 10}) {\n    return this.deck.pickMultipleObjects({x, y, radius, layerIds, depth});\n  }\n\n  pickObjects({x, y, width = 1, height = 1, layerIds = null}) {\n    return this.deck.pickObjects({x, y, width, height, layerIds});\n  }\n\n  queryObject(opts) {\n    log.deprecated('queryObject', 'pickObject')();\n    return this.deck.pickObject(opts);\n  }\n\n  queryVisibleObjects(opts) {\n    log.deprecated('queryVisibleObjects', 'pickObjects')();\n    return this.pickObjects(opts);\n  }\n\n  // Callbacks\n\n  // Forward callback and then call forceUpdate to guarantee that sub components update\n  _onResize(...args) {\n    if (this.props.onResize) {\n      this.props.onResize(...args);\n    }\n    this.forceUpdate();\n  }\n\n  // Forward callback and then call forceUpdate to guarantee that sub components update\n  _onViewStateChange(...args) {\n    if (this.props.onViewStateChange) {\n      this.props.onViewStateChange(...args);\n    }\n    this.forceUpdate();\n  }\n\n  // Private Helpers\n\n  // 1. Extract any JSX layers from the react children\n  // 2. Handle any backwards compatiblity props for React layer\n  // Needs to be called both from initial mount, and when new props arrive\n  _updateFromProps(nextProps) {\n    // extract any deck.gl layers masquerading as react elements from props.children\n    const {layers, children} = this._extractJSXLayers(nextProps.children);\n\n    if (this.deck) {\n      this.deck.setProps(\n        Object.assign({}, nextProps, {\n          views: this._getViews(nextProps),\n          viewState: this._getViewState(nextProps),\n          // Avoid modifying layers array if no JSX layers were found\n          layers: layers ? [...layers, ...nextProps.layers] : nextProps.layers\n        })\n      );\n    }\n\n    this.children = children;\n  }\n\n  // Support old `viewports` prop (React only!)\n  _getViews(props) {\n    if (props.viewports) {\n      log.deprecated('DeckGL.viewports', 'DeckGL.views')();\n    }\n    if (props.viewport) {\n      log.deprecated('DeckGL.viewport', 'DeckGL.views')();\n    }\n    return props.views || props.viewports || (props.viewport && [props.viewport]);\n  }\n\n  // Supports old \"geospatial view state as separate props\" style (React only!)\n  _getViewState(props) {\n    let {viewState} = props;\n\n    if (!viewState && 'latitude' in props && 'longitude' in props && 'zoom' in props) {\n      const {latitude, longitude, zoom, pitch = 0, bearing = 0} = props;\n      viewState = props.viewState || {latitude, longitude, zoom, pitch, bearing};\n    }\n\n    return viewState;\n  }\n\n  // extracts any deck.gl layers masquerading as react elements from props.children\n  _extractJSXLayers(children) {\n    const reactChildren = []; // extract real react elements (i.e. not deck.gl layers)\n    let layers = null; // extracted layer from react children, will add to deck.gl layer array\n\n    React.Children.forEach(children, reactElement => {\n      if (reactElement) {\n        // For some reason Children.forEach doesn't filter out `null`s\n        const LayerType = reactElement.type;\n        if (inheritsFrom(LayerType, Layer)) {\n          const layer = new LayerType(reactElement.props);\n          layers = layers || [];\n          layers.push(layer);\n        } else {\n          reactChildren.push(reactElement);\n        }\n      }\n    });\n\n    return {layers, children: reactChildren};\n  }\n\n  // Iterate over views and reposition children associated with views\n  // TODO - Can we supply a similar function for the non-React case?\n  _renderChildrenUnderViews(children) {\n    // Flatten out nested views array\n    const views = this.deck ? this.deck.getViewports() : [];\n\n    // Build a view id to view index\n    const viewMap = {};\n    views.forEach(view => {\n      if (view.id) {\n        viewMap[view.id] = view;\n      }\n    });\n\n    return children.map(\n      // If child specifies props.viewId, position under view, otherwise render as normal\n      (child, i) =>\n        child.props.viewId || child.props.viewId ? this._positionChild({child, viewMap, i}) : child\n    );\n  }\n\n  _positionChild({child, viewMap, i}) {\n    const {viewId, viewportId} = child.props;\n    if (viewportId) {\n      log.deprecated('viewportId', 'viewId')();\n    }\n    const view = viewMap[viewId || viewportId];\n\n    // Drop (auto-hide) elements with viewId that are not matched by any current view\n    if (!view) {\n      return null;\n    }\n\n    // Resolve potentially relative dimensions using the deck.gl container size\n    const {x, y, width, height} = view;\n\n    // Clone the element with width and height set per view\n    const newProps = Object.assign({}, child.props, {width, height});\n\n    // Inject map properties\n    // TODO - this is too react-map-gl specific\n    Object.assign(newProps, view.getMercatorParams(), {\n      visible: view.isMapSynched()\n    });\n\n    const clone = cloneElement(child, newProps);\n\n    // Wrap it in an absolutely positioning div\n    const style = {position: 'absolute', left: x, top: y, width, height};\n    const key = `view-child-${viewId}-${i}`;\n    return createElement('div', {key, id: key, style}, clone);\n  }\n\n  render() {\n    // Render the background elements (typically react-map-gl instances)\n    // using the view descriptors\n    const children = this._renderChildrenUnderViews(this.children);\n\n    // Note that width and height are handled by deck.gl\n    const {id} = this.props;\n    // TODO - this styling is enforced for correct positioning with children\n    // It can override the styling set by `Deck`, this should be consolidated.\n    const style = Object.assign({}, {position: 'absolute', left: 0, top: 0}, this.props.style);\n\n    const canvas = createElement('canvas', {\n      ref: c => (this.deckCanvas = c),\n      key: 'deck-canvas',\n      id,\n      style\n    });\n\n    // Render deck.gl as last child\n    children.push(canvas);\n\n    return createElement('div', {id: 'deckgl-wrapper'}, children);\n  }\n}\n\nDeckGL.propTypes = propTypes;\nDeckGL.defaultProps = defaultProps;\n"]}

@@ -1,25 +0,38 @@

// Copyright (c) 2015 - 2017 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
export { default as DeckGL } from './deckgl';
export { default } from './deckgl'; // TODO - should react controllers be exported or just integrated into deck.gl API?
"use strict";
export { default as ViewportController } from './viewport-controller';
export { default as autobind } from './utils/autobind';
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0IiwiRGVja0dMIiwiVmlld3BvcnRDb250cm9sbGVyIiwiYXV0b2JpbmQiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUEsU0FBUUEsV0FBV0MsTUFBbkIsUUFBZ0MsVUFBaEM7QUFDQSxTQUFRRCxPQUFSLFFBQXNCLFVBQXRCLEMsQ0FFQTs7QUFDQSxTQUFRQSxXQUFXRSxrQkFBbkIsUUFBNEMsdUJBQTVDO0FBRUEsU0FBUUYsV0FBV0csUUFBbkIsUUFBa0Msa0JBQWxDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IChjKSAyMDE1IC0gMjAxNyBVYmVyIFRlY2hub2xvZ2llcywgSW5jLlxuLy9cbi8vIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHlcbi8vIG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlIFwiU29mdHdhcmVcIiksIHRvIGRlYWxcbi8vIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSByaWdodHNcbi8vIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCwgZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGxcbi8vIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpc1xuLy8gZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczpcbi8vXG4vLyBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpblxuLy8gYWxsIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuXG4vL1xuLy8gVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUlxuLy8gSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksXG4vLyBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULiBJTiBOTyBFVkVOVCBTSEFMTCBUSEVcbi8vIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVJcbi8vIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sXG4vLyBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTIElOXG4vLyBUSEUgU09GVFdBUkUuXG5cbmV4cG9ydCB7ZGVmYXVsdCBhcyBEZWNrR0x9IGZyb20gJy4vZGVja2dsJztcbmV4cG9ydCB7ZGVmYXVsdH0gZnJvbSAnLi9kZWNrZ2wnO1xuXG4vLyBUT0RPIC0gc2hvdWxkIHJlYWN0IGNvbnRyb2xsZXJzIGJlIGV4cG9ydGVkIG9yIGp1c3QgaW50ZWdyYXRlZCBpbnRvIGRlY2suZ2wgQVBJP1xuZXhwb3J0IHtkZWZhdWx0IGFzIFZpZXdwb3J0Q29udHJvbGxlcn0gZnJvbSAnLi92aWV3cG9ydC1jb250cm9sbGVyJztcblxuZXhwb3J0IHtkZWZhdWx0IGFzIGF1dG9iaW5kfSBmcm9tICcuL3V0aWxzL2F1dG9iaW5kJztcbiJdfQ==
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "DeckGL", {
enumerable: true,
get: function get() {
return _deckgl.default;
}
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function get() {
return _deckgl.default;
}
});
Object.defineProperty(exports, "ViewportController", {
enumerable: true,
get: function get() {
return _viewportController.default;
}
});
Object.defineProperty(exports, "autobind", {
enumerable: true,
get: function get() {
return _autobind.default;
}
});
var _deckgl = _interopRequireDefault(require("./deckgl"));
var _viewportController = _interopRequireDefault(require("./viewport-controller"));
var _autobind = _interopRequireDefault(require("./utils/autobind"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFvQkE7O0FBSUE7O0FBRUEiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIDIwMTUgLSAyMDE3IFViZXIgVGVjaG5vbG9naWVzLCBJbmMuXG4vL1xuLy8gUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuLy8gb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuLy8gaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuLy8gdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuLy8gY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4vLyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuLy9cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluXG4vLyBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbi8vXG4vLyBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4vLyBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbi8vIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuLy8gQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuLy8gTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbi8vIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU5cbi8vIFRIRSBTT0ZUV0FSRS5cblxuZXhwb3J0IHtkZWZhdWx0IGFzIERlY2tHTH0gZnJvbSAnLi9kZWNrZ2wnO1xuZXhwb3J0IHtkZWZhdWx0fSBmcm9tICcuL2RlY2tnbCc7XG5cbi8vIFRPRE8gLSBzaG91bGQgcmVhY3QgY29udHJvbGxlcnMgYmUgZXhwb3J0ZWQgb3IganVzdCBpbnRlZ3JhdGVkIGludG8gZGVjay5nbCBBUEk/XG5leHBvcnQge2RlZmF1bHQgYXMgVmlld3BvcnRDb250cm9sbGVyfSBmcm9tICcuL3ZpZXdwb3J0LWNvbnRyb2xsZXInO1xuXG5leHBvcnQge2RlZmF1bHQgYXMgYXV0b2JpbmR9IGZyb20gJy4vdXRpbHMvYXV0b2JpbmQnO1xuIl19

@@ -0,1 +1,7 @@

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = autobind;
// Copyright (c) 2015 - 2017 Uber Technologies, Inc.

@@ -20,3 +26,3 @@ //

// THE SOFTWARE.
const PREDEFINED = ['constructor', 'render', 'componentWillMount', 'componentDidMount', 'componentWillReceiveProps', 'shouldComponentUpdate', 'componentWillUpdate', 'componentDidUpdate', 'componentWillUnmount'];
var PREDEFINED = ['constructor', 'render', 'componentWillMount', 'componentDidMount', 'componentWillReceiveProps', 'shouldComponentUpdate', 'componentWillUpdate', 'componentDidUpdate', 'componentWillUnmount'];
/**

@@ -27,14 +33,40 @@ * Binds the "this" argument of all functions on a class instance to the instance

export default function autobind(obj) {
const proto = Object.getPrototypeOf(obj);
const propNames = Object.getOwnPropertyNames(proto);
function autobind(obj) {
var proto = Object.getPrototypeOf(obj);
var propNames = Object.getOwnPropertyNames(proto);
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
for (const key of propNames) {
if (typeof obj[key] === 'function') {
if (!PREDEFINED.find(name => key === name)) {
obj[key] = obj[key].bind(obj);
try {
var _loop = function _loop() {
var key = _step.value;
if (typeof obj[key] === 'function') {
if (!PREDEFINED.find(function (name) {
return key === name;
})) {
obj[key] = obj[key].bind(obj);
}
}
};
for (var _iterator = propNames[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
_loop();
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator.return != null) {
_iterator.return();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9hdXRvYmluZC5qcyJdLCJuYW1lcyI6WyJQUkVERUZJTkVEIiwiYXV0b2JpbmQiLCJvYmoiLCJwcm90byIsIk9iamVjdCIsImdldFByb3RvdHlwZU9mIiwicHJvcE5hbWVzIiwiZ2V0T3duUHJvcGVydHlOYW1lcyIsImtleSIsImZpbmQiLCJuYW1lIiwiYmluZCJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQSxNQUFNQSxhQUFhLENBQ2pCLGFBRGlCLEVBRWpCLFFBRmlCLEVBR2pCLG9CQUhpQixFQUlqQixtQkFKaUIsRUFLakIsMkJBTGlCLEVBTWpCLHVCQU5pQixFQU9qQixxQkFQaUIsRUFRakIsb0JBUmlCLEVBU2pCLHNCQVRpQixDQUFuQjtBQVlBOzs7OztBQUlBLGVBQWUsU0FBU0MsUUFBVCxDQUFrQkMsR0FBbEIsRUFBdUI7QUFDcEMsUUFBTUMsUUFBUUMsT0FBT0MsY0FBUCxDQUFzQkgsR0FBdEIsQ0FBZDtBQUNBLFFBQU1JLFlBQVlGLE9BQU9HLG1CQUFQLENBQTJCSixLQUEzQixDQUFsQjs7QUFDQSxPQUFLLE1BQU1LLEdBQVgsSUFBa0JGLFNBQWxCLEVBQTZCO0FBQzNCLFFBQUksT0FBT0osSUFBSU0sR0FBSixDQUFQLEtBQW9CLFVBQXhCLEVBQW9DO0FBQ2xDLFVBQUksQ0FBQ1IsV0FBV1MsSUFBWCxDQUFnQkMsUUFBUUYsUUFBUUUsSUFBaEMsQ0FBTCxFQUE0QztBQUMxQ1IsWUFBSU0sR0FBSixJQUFXTixJQUFJTSxHQUFKLEVBQVNHLElBQVQsQ0FBY1QsR0FBZCxDQUFYO0FBQ0Q7QUFDRjtBQUNGO0FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIDIwMTUgLSAyMDE3IFViZXIgVGVjaG5vbG9naWVzLCBJbmMuXG4vL1xuLy8gUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuLy8gb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuLy8gaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuLy8gdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuLy8gY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4vLyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuLy9cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluXG4vLyBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbi8vXG4vLyBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4vLyBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbi8vIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuLy8gQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuLy8gTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbi8vIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU5cbi8vIFRIRSBTT0ZUV0FSRS5cblxuY29uc3QgUFJFREVGSU5FRCA9IFtcbiAgJ2NvbnN0cnVjdG9yJyxcbiAgJ3JlbmRlcicsXG4gICdjb21wb25lbnRXaWxsTW91bnQnLFxuICAnY29tcG9uZW50RGlkTW91bnQnLFxuICAnY29tcG9uZW50V2lsbFJlY2VpdmVQcm9wcycsXG4gICdzaG91bGRDb21wb25lbnRVcGRhdGUnLFxuICAnY29tcG9uZW50V2lsbFVwZGF0ZScsXG4gICdjb21wb25lbnREaWRVcGRhdGUnLFxuICAnY29tcG9uZW50V2lsbFVubW91bnQnXG5dO1xuXG4vKipcbiAqIEJpbmRzIHRoZSBcInRoaXNcIiBhcmd1bWVudCBvZiBhbGwgZnVuY3Rpb25zIG9uIGEgY2xhc3MgaW5zdGFuY2UgdG8gdGhlIGluc3RhbmNlXG4gKiBAcGFyYW0ge09iamVjdH0gb2JqIC0gY2xhc3MgaW5zdGFuY2UgKHR5cGljYWxseSBhIHJlYWN0IGNvbXBvbmVudClcbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gYXV0b2JpbmQob2JqKSB7XG4gIGNvbnN0IHByb3RvID0gT2JqZWN0LmdldFByb3RvdHlwZU9mKG9iaik7XG4gIGNvbnN0IHByb3BOYW1lcyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eU5hbWVzKHByb3RvKTtcbiAgZm9yIChjb25zdCBrZXkgb2YgcHJvcE5hbWVzKSB7XG4gICAgaWYgKHR5cGVvZiBvYmpba2V5XSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgaWYgKCFQUkVERUZJTkVELmZpbmQobmFtZSA9PiBrZXkgPT09IG5hbWUpKSB7XG4gICAgICAgIG9ialtrZXldID0gb2JqW2tleV0uYmluZChvYmopO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9hdXRvYmluZC5qcyJdLCJuYW1lcyI6WyJQUkVERUZJTkVEIiwiYXV0b2JpbmQiLCJvYmoiLCJwcm90byIsIk9iamVjdCIsImdldFByb3RvdHlwZU9mIiwicHJvcE5hbWVzIiwiZ2V0T3duUHJvcGVydHlOYW1lcyIsImtleSIsImZpbmQiLCJuYW1lIiwiYmluZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQSxJQUFNQSxhQUFhLENBQ2pCLGFBRGlCLEVBRWpCLFFBRmlCLEVBR2pCLG9CQUhpQixFQUlqQixtQkFKaUIsRUFLakIsMkJBTGlCLEVBTWpCLHVCQU5pQixFQU9qQixxQkFQaUIsRUFRakIsb0JBUmlCLEVBU2pCLHNCQVRpQixDQUFuQjtBQVlBOzs7OztBQUllLFNBQVNDLFFBQVQsQ0FBa0JDLEdBQWxCLEVBQXVCO0FBQ3BDLE1BQU1DLFFBQVFDLE9BQU9DLGNBQVAsQ0FBc0JILEdBQXRCLENBQWQ7QUFDQSxNQUFNSSxZQUFZRixPQUFPRyxtQkFBUCxDQUEyQkosS0FBM0IsQ0FBbEI7QUFGb0M7QUFBQTtBQUFBOztBQUFBO0FBQUE7QUFBQSxVQUd6QkssR0FIeUI7O0FBSWxDLFVBQUksT0FBT04sSUFBSU0sR0FBSixDQUFQLEtBQW9CLFVBQXhCLEVBQW9DO0FBQ2xDLFlBQUksQ0FBQ1IsV0FBV1MsSUFBWCxDQUFnQjtBQUFBLGlCQUFRRCxRQUFRRSxJQUFoQjtBQUFBLFNBQWhCLENBQUwsRUFBNEM7QUFDMUNSLGNBQUlNLEdBQUosSUFBV04sSUFBSU0sR0FBSixFQUFTRyxJQUFULENBQWNULEdBQWQsQ0FBWDtBQUNEO0FBQ0Y7QUFSaUM7O0FBR3BDLHlCQUFrQkksU0FBbEIsOEhBQTZCO0FBQUE7QUFNNUI7QUFUbUM7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQVVyQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAoYykgMjAxNSAtIDIwMTcgVWJlciBUZWNobm9sb2dpZXMsIEluYy5cbi8vXG4vLyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4vLyBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4vLyBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4vLyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4vLyBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbi8vIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4vL1xuLy8gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW5cbi8vIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuLy9cbi8vIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1Jcbi8vIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuLy8gRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4vLyBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4vLyBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuLy8gT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTlxuLy8gVEhFIFNPRlRXQVJFLlxuXG5jb25zdCBQUkVERUZJTkVEID0gW1xuICAnY29uc3RydWN0b3InLFxuICAncmVuZGVyJyxcbiAgJ2NvbXBvbmVudFdpbGxNb3VudCcsXG4gICdjb21wb25lbnREaWRNb3VudCcsXG4gICdjb21wb25lbnRXaWxsUmVjZWl2ZVByb3BzJyxcbiAgJ3Nob3VsZENvbXBvbmVudFVwZGF0ZScsXG4gICdjb21wb25lbnRXaWxsVXBkYXRlJyxcbiAgJ2NvbXBvbmVudERpZFVwZGF0ZScsXG4gICdjb21wb25lbnRXaWxsVW5tb3VudCdcbl07XG5cbi8qKlxuICogQmluZHMgdGhlIFwidGhpc1wiIGFyZ3VtZW50IG9mIGFsbCBmdW5jdGlvbnMgb24gYSBjbGFzcyBpbnN0YW5jZSB0byB0aGUgaW5zdGFuY2VcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmogLSBjbGFzcyBpbnN0YW5jZSAodHlwaWNhbGx5IGEgcmVhY3QgY29tcG9uZW50KVxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBhdXRvYmluZChvYmopIHtcbiAgY29uc3QgcHJvdG8gPSBPYmplY3QuZ2V0UHJvdG90eXBlT2Yob2JqKTtcbiAgY29uc3QgcHJvcE5hbWVzID0gT2JqZWN0LmdldE93blByb3BlcnR5TmFtZXMocHJvdG8pO1xuICBmb3IgKGNvbnN0IGtleSBvZiBwcm9wTmFtZXMpIHtcbiAgICBpZiAodHlwZW9mIG9ialtrZXldID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICBpZiAoIVBSRURFRklORUQuZmluZChuYW1lID0+IGtleSA9PT0gbmFtZSkpIHtcbiAgICAgICAgb2JqW2tleV0gPSBvYmpba2V5XS5iaW5kKG9iaik7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iXX0=

@@ -0,1 +1,7 @@

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
// Copyright (c) 2015 Uber Technologies, Inc.

@@ -18,11 +24,12 @@ // Permission is hereby granted, free of charge, to any person obtaining a copy

// import browser from 'bowser';
const PREFIX = '-webkit-'; // browser.webkit || browser.blink ? '-webkit-' :
var PREFIX = '-webkit-'; // browser.webkit || browser.blink ? '-webkit-' :
// browser.gecko ? '-moz-' :
// '';
export default {
GRABBING: `${PREFIX}grabbing`,
GRAB: `${PREFIX}grab`,
var _default = {
GRABBING: "".concat(PREFIX, "grabbing"),
GRAB: "".concat(PREFIX, "grab"),
POINTER: 'pointer'
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jdXJzb3JzLmpzIl0sIm5hbWVzIjpbIlBSRUZJWCIsIkdSQUJCSU5HIiwiR1JBQiIsIlBPSU5URVIiXSwibWFwcGluZ3MiOiJBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFFQSxNQUFNQSxTQUFTLFVBQWYsQyxDQUNBO0FBQ0E7QUFDQTs7QUFFQSxlQUFlO0FBQ2JDLFlBQVcsR0FBRUQsTUFBTyxVQURQO0FBRWJFLFFBQU8sR0FBRUYsTUFBTyxNQUZIO0FBR2JHLFdBQVM7QUFISSxDQUFmIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IChjKSAyMDE1IFViZXIgVGVjaG5vbG9naWVzLCBJbmMuXG5cbi8vIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHlcbi8vIG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlIFwiU29mdHdhcmVcIiksIHRvIGRlYWxcbi8vIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSByaWdodHNcbi8vIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCwgZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGxcbi8vIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpc1xuLy8gZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczpcblxuLy8gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW5cbi8vIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuXG4vLyBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4vLyBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbi8vIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuLy8gQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuLy8gTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbi8vIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU5cbi8vIFRIRSBTT0ZUV0FSRS5cblxuLy8gaW1wb3J0IGJyb3dzZXIgZnJvbSAnYm93c2VyJztcblxuY29uc3QgUFJFRklYID0gJy13ZWJraXQtJztcbi8vIGJyb3dzZXIud2Via2l0IHx8IGJyb3dzZXIuYmxpbmsgPyAnLXdlYmtpdC0nIDpcbi8vIGJyb3dzZXIuZ2Vja28gPyAnLW1vei0nIDpcbi8vICcnO1xuXG5leHBvcnQgZGVmYXVsdCB7XG4gIEdSQUJCSU5HOiBgJHtQUkVGSVh9Z3JhYmJpbmdgLFxuICBHUkFCOiBgJHtQUkVGSVh9Z3JhYmAsXG4gIFBPSU5URVI6ICdwb2ludGVyJ1xufTtcbiJdfQ==
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jdXJzb3JzLmpzIl0sIm5hbWVzIjpbIlBSRUZJWCIsIkdSQUJCSU5HIiwiR1JBQiIsIlBPSU5URVIiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFFQSxJQUFNQSxTQUFTLFVBQWYsQyxDQUNBO0FBQ0E7QUFDQTs7ZUFFZTtBQUNiQyxzQkFBYUQsTUFBYixhQURhO0FBRWJFLGtCQUFTRixNQUFULFNBRmE7QUFHYkcsV0FBUztBQUhJLEMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIDIwMTUgVWJlciBUZWNobm9sb2dpZXMsIEluYy5cblxuLy8gUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuLy8gb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuLy8gaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuLy8gdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuLy8gY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4vLyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuXG4vLyBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpblxuLy8gYWxsIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuXG5cbi8vIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1Jcbi8vIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuLy8gRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4vLyBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4vLyBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuLy8gT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTlxuLy8gVEhFIFNPRlRXQVJFLlxuXG4vLyBpbXBvcnQgYnJvd3NlciBmcm9tICdib3dzZXInO1xuXG5jb25zdCBQUkVGSVggPSAnLXdlYmtpdC0nO1xuLy8gYnJvd3Nlci53ZWJraXQgfHwgYnJvd3Nlci5ibGluayA/ICctd2Via2l0LScgOlxuLy8gYnJvd3Nlci5nZWNrbyA/ICctbW96LScgOlxuLy8gJyc7XG5cbmV4cG9ydCBkZWZhdWx0IHtcbiAgR1JBQkJJTkc6IGAke1BSRUZJWH1ncmFiYmluZ2AsXG4gIEdSQUI6IGAke1BSRUZJWH1ncmFiYCxcbiAgUE9JTlRFUjogJ3BvaW50ZXInXG59O1xuIl19

@@ -0,3 +1,10 @@

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.inheritsFrom = inheritsFrom;
// Check if one JavaScript class inherits from another
export function inheritsFrom(Type, ParentType) {
function inheritsFrom(Type, ParentType) {
while (Type) {

@@ -13,2 +20,2 @@ if (Type === ParentType) {

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9pbmhlcml0cy1mcm9tLmpzIl0sIm5hbWVzIjpbImluaGVyaXRzRnJvbSIsIlR5cGUiLCJQYXJlbnRUeXBlIiwiT2JqZWN0IiwiZ2V0UHJvdG90eXBlT2YiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0EsT0FBTyxTQUFTQSxZQUFULENBQXNCQyxJQUF0QixFQUE0QkMsVUFBNUIsRUFBd0M7QUFDN0MsU0FBT0QsSUFBUCxFQUFhO0FBQ1gsUUFBSUEsU0FBU0MsVUFBYixFQUF5QjtBQUN2QixhQUFPLElBQVA7QUFDRDs7QUFDREQsV0FBT0UsT0FBT0MsY0FBUCxDQUFzQkgsSUFBdEIsQ0FBUDtBQUNEOztBQUNELFNBQU8sS0FBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ2hlY2sgaWYgb25lIEphdmFTY3JpcHQgY2xhc3MgaW5oZXJpdHMgZnJvbSBhbm90aGVyXG5leHBvcnQgZnVuY3Rpb24gaW5oZXJpdHNGcm9tKFR5cGUsIFBhcmVudFR5cGUpIHtcbiAgd2hpbGUgKFR5cGUpIHtcbiAgICBpZiAoVHlwZSA9PT0gUGFyZW50VHlwZSkge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICAgIFR5cGUgPSBPYmplY3QuZ2V0UHJvdG90eXBlT2YoVHlwZSk7XG4gIH1cbiAgcmV0dXJuIGZhbHNlO1xufVxuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9pbmhlcml0cy1mcm9tLmpzIl0sIm5hbWVzIjpbImluaGVyaXRzRnJvbSIsIlR5cGUiLCJQYXJlbnRUeXBlIiwiT2JqZWN0IiwiZ2V0UHJvdG90eXBlT2YiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTtBQUNPLFNBQVNBLFlBQVQsQ0FBc0JDLElBQXRCLEVBQTRCQyxVQUE1QixFQUF3QztBQUM3QyxTQUFPRCxJQUFQLEVBQWE7QUFDWCxRQUFJQSxTQUFTQyxVQUFiLEVBQXlCO0FBQ3ZCLGFBQU8sSUFBUDtBQUNEOztBQUNERCxXQUFPRSxPQUFPQyxjQUFQLENBQXNCSCxJQUF0QixDQUFQO0FBQ0Q7O0FBQ0QsU0FBTyxLQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDaGVjayBpZiBvbmUgSmF2YVNjcmlwdCBjbGFzcyBpbmhlcml0cyBmcm9tIGFub3RoZXJcbmV4cG9ydCBmdW5jdGlvbiBpbmhlcml0c0Zyb20oVHlwZSwgUGFyZW50VHlwZSkge1xuICB3aGlsZSAoVHlwZSkge1xuICAgIGlmIChUeXBlID09PSBQYXJlbnRUeXBlKSB7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgVHlwZSA9IE9iamVjdC5nZXRQcm90b3R5cGVPZihUeXBlKTtcbiAgfVxuICByZXR1cm4gZmFsc2U7XG59XG4iXX0=

@@ -0,1 +1,10 @@

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = shallowCompare;
var _shallowEqual = require("./shallow-equal");
// Copyright (c) 2015 - 2017 Uber Technologies, Inc.

@@ -20,10 +29,9 @@ //

// THE SOFTWARE.
import { shallowEqual } from './shallow-equal';
/**
* Does a shallow comparison for React props and state.
*/
export default function shallowCompare(instance, nextProps, nextState) {
return !shallowEqual(instance.props, nextProps) || !shallowEqual(instance.state, nextState);
function shallowCompare(instance, nextProps, nextState) {
return !(0, _shallowEqual.shallowEqual)(instance.props, nextProps) || !(0, _shallowEqual.shallowEqual)(instance.state, nextState);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9zaGFsbG93LWNvbXBhcmUuanMiXSwibmFtZXMiOlsic2hhbGxvd0VxdWFsIiwic2hhbGxvd0NvbXBhcmUiLCJpbnN0YW5jZSIsIm5leHRQcm9wcyIsIm5leHRTdGF0ZSIsInByb3BzIiwic3RhdGUiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUEsU0FBUUEsWUFBUixRQUEyQixpQkFBM0I7QUFFQTs7OztBQUdBLGVBQWUsU0FBU0MsY0FBVCxDQUF3QkMsUUFBeEIsRUFBa0NDLFNBQWxDLEVBQTZDQyxTQUE3QyxFQUF3RDtBQUNyRSxTQUFPLENBQUNKLGFBQWFFLFNBQVNHLEtBQXRCLEVBQTZCRixTQUE3QixDQUFELElBQTRDLENBQUNILGFBQWFFLFNBQVNJLEtBQXRCLEVBQTZCRixTQUE3QixDQUFwRDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IChjKSAyMDE1IC0gMjAxNyBVYmVyIFRlY2hub2xvZ2llcywgSW5jLlxuLy9cbi8vIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHlcbi8vIG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlIFwiU29mdHdhcmVcIiksIHRvIGRlYWxcbi8vIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSByaWdodHNcbi8vIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCwgZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGxcbi8vIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpc1xuLy8gZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczpcbi8vXG4vLyBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpblxuLy8gYWxsIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuXG4vL1xuLy8gVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUlxuLy8gSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksXG4vLyBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULiBJTiBOTyBFVkVOVCBTSEFMTCBUSEVcbi8vIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVJcbi8vIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sXG4vLyBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTIElOXG4vLyBUSEUgU09GVFdBUkUuXG5cbmltcG9ydCB7c2hhbGxvd0VxdWFsfSBmcm9tICcuL3NoYWxsb3ctZXF1YWwnO1xuXG4vKipcbiAqIERvZXMgYSBzaGFsbG93IGNvbXBhcmlzb24gZm9yIFJlYWN0IHByb3BzIGFuZCBzdGF0ZS5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gc2hhbGxvd0NvbXBhcmUoaW5zdGFuY2UsIG5leHRQcm9wcywgbmV4dFN0YXRlKSB7XG4gIHJldHVybiAhc2hhbGxvd0VxdWFsKGluc3RhbmNlLnByb3BzLCBuZXh0UHJvcHMpIHx8ICFzaGFsbG93RXF1YWwoaW5zdGFuY2Uuc3RhdGUsIG5leHRTdGF0ZSk7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9zaGFsbG93LWNvbXBhcmUuanMiXSwibmFtZXMiOlsic2hhbGxvd0NvbXBhcmUiLCJpbnN0YW5jZSIsIm5leHRQcm9wcyIsIm5leHRTdGF0ZSIsInByb3BzIiwic3RhdGUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFvQkE7O0FBcEJBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUlBOzs7QUFHZSxTQUFTQSxjQUFULENBQXdCQyxRQUF4QixFQUFrQ0MsU0FBbEMsRUFBNkNDLFNBQTdDLEVBQXdEO0FBQ3JFLFNBQU8sQ0FBQyxnQ0FBYUYsU0FBU0csS0FBdEIsRUFBNkJGLFNBQTdCLENBQUQsSUFBNEMsQ0FBQyxnQ0FBYUQsU0FBU0ksS0FBdEIsRUFBNkJGLFNBQTdCLENBQXBEO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIDIwMTUgLSAyMDE3IFViZXIgVGVjaG5vbG9naWVzLCBJbmMuXG4vL1xuLy8gUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuLy8gb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuLy8gaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuLy8gdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuLy8gY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4vLyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuLy9cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluXG4vLyBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbi8vXG4vLyBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4vLyBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbi8vIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuLy8gQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuLy8gTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbi8vIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU5cbi8vIFRIRSBTT0ZUV0FSRS5cblxuaW1wb3J0IHtzaGFsbG93RXF1YWx9IGZyb20gJy4vc2hhbGxvdy1lcXVhbCc7XG5cbi8qKlxuICogRG9lcyBhIHNoYWxsb3cgY29tcGFyaXNvbiBmb3IgUmVhY3QgcHJvcHMgYW5kIHN0YXRlLlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBzaGFsbG93Q29tcGFyZShpbnN0YW5jZSwgbmV4dFByb3BzLCBuZXh0U3RhdGUpIHtcbiAgcmV0dXJuICFzaGFsbG93RXF1YWwoaW5zdGFuY2UucHJvcHMsIG5leHRQcm9wcykgfHwgIXNoYWxsb3dFcXVhbChpbnN0YW5jZS5zdGF0ZSwgbmV4dFN0YXRlKTtcbn1cbiJdfQ==

@@ -0,1 +1,10 @@

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.shallowEqual = shallowEqual;
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
// Copyright (c) 2015 - 2017 Uber Technologies, Inc.

@@ -23,5 +32,7 @@ //

/* eslint-disable complexity */
export function shallowEqual(a, b, {
ignore = {}
} = {}) {
function shallowEqual(a, b) {
var _ref = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {},
_ref$ignore = _ref.ignore,
ignore = _ref$ignore === void 0 ? {} : _ref$ignore;
if (a === b) {

@@ -31,3 +42,3 @@ return true;

if (typeof a !== 'object' || a === null || typeof b !== 'object' || b === null) {
if (_typeof(a) !== 'object' || a === null || _typeof(b) !== 'object' || b === null) {
return false;

@@ -40,3 +51,3 @@ }

for (const key in a) {
for (var key in a) {
if (!(key in ignore) && (!(key in b) || a[key] !== b[key])) {

@@ -47,4 +58,4 @@ return false;

for (const key in b) {
if (!(key in ignore) && !(key in a)) {
for (var _key in b) {
if (!(_key in ignore) && !(_key in a)) {
return false;

@@ -56,2 +67,2 @@ }

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9zaGFsbG93LWVxdWFsLmpzIl0sIm5hbWVzIjpbInNoYWxsb3dFcXVhbCIsImEiLCJiIiwiaWdub3JlIiwiT2JqZWN0Iiwia2V5cyIsImxlbmd0aCIsImtleSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTs7QUFDQTtBQUNBLE9BQU8sU0FBU0EsWUFBVCxDQUFzQkMsQ0FBdEIsRUFBeUJDLENBQXpCLEVBQTRCO0FBQUNDLFdBQVM7QUFBVixJQUFnQixFQUE1QyxFQUFnRDtBQUNyRCxNQUFJRixNQUFNQyxDQUFWLEVBQWE7QUFDWCxXQUFPLElBQVA7QUFDRDs7QUFFRCxNQUFJLE9BQU9ELENBQVAsS0FBYSxRQUFiLElBQXlCQSxNQUFNLElBQS9CLElBQXVDLE9BQU9DLENBQVAsS0FBYSxRQUFwRCxJQUFnRUEsTUFBTSxJQUExRSxFQUFnRjtBQUM5RSxXQUFPLEtBQVA7QUFDRDs7QUFFRCxNQUFJRSxPQUFPQyxJQUFQLENBQVlKLENBQVosRUFBZUssTUFBZixLQUEwQkYsT0FBT0MsSUFBUCxDQUFZSCxDQUFaLEVBQWVJLE1BQTdDLEVBQXFEO0FBQ25ELFdBQU8sS0FBUDtBQUNEOztBQUVELE9BQUssTUFBTUMsR0FBWCxJQUFrQk4sQ0FBbEIsRUFBcUI7QUFDbkIsUUFBSSxFQUFFTSxPQUFPSixNQUFULE1BQXFCLEVBQUVJLE9BQU9MLENBQVQsS0FBZUQsRUFBRU0sR0FBRixNQUFXTCxFQUFFSyxHQUFGLENBQS9DLENBQUosRUFBNEQ7QUFDMUQsYUFBTyxLQUFQO0FBQ0Q7QUFDRjs7QUFDRCxPQUFLLE1BQU1BLEdBQVgsSUFBa0JMLENBQWxCLEVBQXFCO0FBQ25CLFFBQUksRUFBRUssT0FBT0osTUFBVCxLQUFvQixFQUFFSSxPQUFPTixDQUFULENBQXhCLEVBQXFDO0FBQ25DLGFBQU8sS0FBUDtBQUNEO0FBQ0Y7O0FBQ0QsU0FBTyxJQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIDIwMTUgLSAyMDE3IFViZXIgVGVjaG5vbG9naWVzLCBJbmMuXG4vL1xuLy8gUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuLy8gb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuLy8gaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuLy8gdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuLy8gY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4vLyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuLy9cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluXG4vLyBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbi8vXG4vLyBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SXG4vLyBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSxcbi8vIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMIFRIRVxuLy8gQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUlxuLy8gTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSxcbi8vIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU5cbi8vIFRIRSBTT0ZUV0FSRS5cblxuLy8gU2hhbGxvdyBjb21wYXJlXG4vKiBlc2xpbnQtZGlzYWJsZSBjb21wbGV4aXR5ICovXG5leHBvcnQgZnVuY3Rpb24gc2hhbGxvd0VxdWFsKGEsIGIsIHtpZ25vcmUgPSB7fX0gPSB7fSkge1xuICBpZiAoYSA9PT0gYikge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKHR5cGVvZiBhICE9PSAnb2JqZWN0JyB8fCBhID09PSBudWxsIHx8IHR5cGVvZiBiICE9PSAnb2JqZWN0JyB8fCBiID09PSBudWxsKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKE9iamVjdC5rZXlzKGEpLmxlbmd0aCAhPT0gT2JqZWN0LmtleXMoYikubGVuZ3RoKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgZm9yIChjb25zdCBrZXkgaW4gYSkge1xuICAgIGlmICghKGtleSBpbiBpZ25vcmUpICYmICghKGtleSBpbiBiKSB8fCBhW2tleV0gIT09IGJba2V5XSkpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cbiAgZm9yIChjb25zdCBrZXkgaW4gYikge1xuICAgIGlmICghKGtleSBpbiBpZ25vcmUpICYmICEoa2V5IGluIGEpKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9XG4gIHJldHVybiB0cnVlO1xufVxuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9zaGFsbG93LWVxdWFsLmpzIl0sIm5hbWVzIjpbInNoYWxsb3dFcXVhbCIsImEiLCJiIiwiaWdub3JlIiwiT2JqZWN0Iiwia2V5cyIsImxlbmd0aCIsImtleSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTs7QUFDQTtBQUNPLFNBQVNBLFlBQVQsQ0FBc0JDLENBQXRCLEVBQXlCQyxDQUF6QixFQUFnRDtBQUFBLGlGQUFKLEVBQUk7QUFBQSx5QkFBbkJDLE1BQW1CO0FBQUEsTUFBbkJBLE1BQW1CLDRCQUFWLEVBQVU7O0FBQ3JELE1BQUlGLE1BQU1DLENBQVYsRUFBYTtBQUNYLFdBQU8sSUFBUDtBQUNEOztBQUVELE1BQUksUUFBT0QsQ0FBUCxNQUFhLFFBQWIsSUFBeUJBLE1BQU0sSUFBL0IsSUFBdUMsUUFBT0MsQ0FBUCxNQUFhLFFBQXBELElBQWdFQSxNQUFNLElBQTFFLEVBQWdGO0FBQzlFLFdBQU8sS0FBUDtBQUNEOztBQUVELE1BQUlFLE9BQU9DLElBQVAsQ0FBWUosQ0FBWixFQUFlSyxNQUFmLEtBQTBCRixPQUFPQyxJQUFQLENBQVlILENBQVosRUFBZUksTUFBN0MsRUFBcUQ7QUFDbkQsV0FBTyxLQUFQO0FBQ0Q7O0FBRUQsT0FBSyxJQUFNQyxHQUFYLElBQWtCTixDQUFsQixFQUFxQjtBQUNuQixRQUFJLEVBQUVNLE9BQU9KLE1BQVQsTUFBcUIsRUFBRUksT0FBT0wsQ0FBVCxLQUFlRCxFQUFFTSxHQUFGLE1BQVdMLEVBQUVLLEdBQUYsQ0FBL0MsQ0FBSixFQUE0RDtBQUMxRCxhQUFPLEtBQVA7QUFDRDtBQUNGOztBQUNELE9BQUssSUFBTUEsSUFBWCxJQUFrQkwsQ0FBbEIsRUFBcUI7QUFDbkIsUUFBSSxFQUFFSyxRQUFPSixNQUFULEtBQW9CLEVBQUVJLFFBQU9OLENBQVQsQ0FBeEIsRUFBcUM7QUFDbkMsYUFBTyxLQUFQO0FBQ0Q7QUFDRjs7QUFDRCxTQUFPLElBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAoYykgMjAxNSAtIDIwMTcgVWJlciBUZWNobm9sb2dpZXMsIEluYy5cbi8vXG4vLyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4vLyBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4vLyBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4vLyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4vLyBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbi8vIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4vL1xuLy8gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW5cbi8vIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuLy9cbi8vIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1Jcbi8vIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuLy8gRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4vLyBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4vLyBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuLy8gT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTlxuLy8gVEhFIFNPRlRXQVJFLlxuXG4vLyBTaGFsbG93IGNvbXBhcmVcbi8qIGVzbGludC1kaXNhYmxlIGNvbXBsZXhpdHkgKi9cbmV4cG9ydCBmdW5jdGlvbiBzaGFsbG93RXF1YWwoYSwgYiwge2lnbm9yZSA9IHt9fSA9IHt9KSB7XG4gIGlmIChhID09PSBiKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBpZiAodHlwZW9mIGEgIT09ICdvYmplY3QnIHx8IGEgPT09IG51bGwgfHwgdHlwZW9mIGIgIT09ICdvYmplY3QnIHx8IGIgPT09IG51bGwpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoT2JqZWN0LmtleXMoYSkubGVuZ3RoICE9PSBPYmplY3Qua2V5cyhiKS5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBmb3IgKGNvbnN0IGtleSBpbiBhKSB7XG4gICAgaWYgKCEoa2V5IGluIGlnbm9yZSkgJiYgKCEoa2V5IGluIGIpIHx8IGFba2V5XSAhPT0gYltrZXldKSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuICBmb3IgKGNvbnN0IGtleSBpbiBiKSB7XG4gICAgaWYgKCEoa2V5IGluIGlnbm9yZSkgJiYgIShrZXkgaW4gYSkpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHRydWU7XG59XG4iXX0=

@@ -1,48 +0,80 @@

import { Component, createElement } from 'react';
import PropTypes from 'prop-types';
import { EventManager } from 'mjolnir.js';
import { MapController as ViewportControls } from '@deck.gl/core';
import CURSOR from './utils/cursors';
const propTypes = {
viewportState: PropTypes.func,
state: PropTypes.object,
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = require("react");
var _propTypes = _interopRequireDefault(require("prop-types"));
var _mjolnir = require("mjolnir.js");
var _core = require("@deck.gl/core");
var _cursors = _interopRequireDefault(require("./utils/cursors"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _instanceof(left, right) { if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) { return right[Symbol.hasInstance](left); } else { return left instanceof right; } }
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
function _classCallCheck(instance, Constructor) { if (!_instanceof(instance, Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } _setPrototypeOf(subClass.prototype, superClass && superClass.prototype); if (superClass) _setPrototypeOf(subClass, superClass); }
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
var propTypes = {
viewportState: _propTypes.default.func,
state: _propTypes.default.object,
/** Viewport props */
/** The width of the map. */
width: PropTypes.number.isRequired,
width: _propTypes.default.number.isRequired,
/** The height of the map. */
height: PropTypes.number.isRequired,
height: _propTypes.default.number.isRequired,
/** The longitude of the center of the map. */
longitude: PropTypes.number.isRequired,
longitude: _propTypes.default.number.isRequired,
/** The latitude of the center of the map. */
latitude: PropTypes.number.isRequired,
latitude: _propTypes.default.number.isRequired,
/** The tile zoom level of the map. */
zoom: PropTypes.number.isRequired,
zoom: _propTypes.default.number.isRequired,
/** Specify the bearing of the viewport */
bearing: PropTypes.number,
bearing: _propTypes.default.number,
/** Specify the pitch of the viewport */
pitch: PropTypes.number,
pitch: _propTypes.default.number,
/** Altitude of the viewport camera. Default 1.5 "screen heights" */
// Note: Non-public API, see https://github.com/mapbox/mapbox-gl-js/issues/1137
altitude: PropTypes.number,
altitude: _propTypes.default.number,
// Camera position for FirstPersonViewport
position: PropTypes.array,
position: _propTypes.default.array,
/** Viewport constraints */
// Max zoom level
maxZoom: PropTypes.number,
maxZoom: _propTypes.default.number,
// Min zoom level
minZoom: PropTypes.number,
minZoom: _propTypes.default.number,
// Max pitch in degrees
maxPitch: PropTypes.number,
maxPitch: _propTypes.default.number,
// Min pitch in degrees
minPitch: PropTypes.number,
minPitch: _propTypes.default.number,

@@ -54,46 +86,47 @@ /**

*/
onViewportChange: PropTypes.func,
onViewportChange: _propTypes.default.func,
/** Viewport transition **/
// transition duration for viewport change
transitionDuration: PropTypes.number,
transitionDuration: _propTypes.default.number,
// an instance of ViewportTransitionInterpolator, can be used to perform custom transitions.
transitionInterpolator: PropTypes.object,
transitionInterpolator: _propTypes.default.object,
// type of interruption of current transition on update.
transitionInterruption: PropTypes.number,
transitionInterruption: _propTypes.default.number,
// easing function
transitionEasing: PropTypes.func,
transitionEasing: _propTypes.default.func,
// transition status update functions
onTransitionStart: PropTypes.func,
onTransitionInterrupt: PropTypes.func,
onTransitionEnd: PropTypes.func,
onTransitionStart: _propTypes.default.func,
onTransitionInterrupt: _propTypes.default.func,
onTransitionEnd: _propTypes.default.func,
/** Enables control event handling */
// Scroll to zoom
scrollZoom: PropTypes.bool,
scrollZoom: _propTypes.default.bool,
// Drag to pan
dragPan: PropTypes.bool,
dragPan: _propTypes.default.bool,
// Drag to rotate
dragRotate: PropTypes.bool,
dragRotate: _propTypes.default.bool,
// Double click to zoom
doubleClickZoom: PropTypes.bool,
doubleClickZoom: _propTypes.default.bool,
// Pinch to zoom / rotate
touchZoomRotate: PropTypes.bool,
touchZoomRotate: _propTypes.default.bool,
/** Accessor that returns a cursor style to show interactive state */
getCursor: PropTypes.func,
getCursor: _propTypes.default.func,
// A map control instance to replace the default map controls
// The object must expose one property: `events` as an array of subscribed
// event names; and two methods: `setState(state)` and `handle(event)`
controls: PropTypes.shape({
events: PropTypes.arrayOf(PropTypes.string),
handleEvent: PropTypes.func
controls: _propTypes.default.shape({
events: _propTypes.default.arrayOf(_propTypes.default.string),
handleEvent: _propTypes.default.func
})
};
const getDefaultCursor = ({
isDragging
}) => isDragging ? CURSOR.GRABBING : CURSOR.GRAB;
var getDefaultCursor = function getDefaultCursor(_ref) {
var isDragging = _ref.isDragging;
return isDragging ? _cursors.default.GRABBING : _cursors.default.GRAB;
};
const defaultProps = {
var defaultProps = {
onViewportChange: null,

@@ -107,66 +140,90 @@ scrollZoom: true,

};
export default class ViewportController extends Component {
constructor(props) {
super(props);
this.state = {
var ViewportController =
/*#__PURE__*/
function (_Component) {
_inherits(ViewportController, _Component);
function ViewportController(props) {
var _this;
_classCallCheck(this, ViewportController);
_this = _possibleConstructorReturn(this, (ViewportController.__proto__ || Object.getPrototypeOf(ViewportController)).call(this, props));
_this.state = {
isDragging: false // Whether the cursor is down
};
return _this;
}
componentDidMount() {
this._eventManager = new EventManager(this.eventCanvas); // If props.controls is not provided, fallback to default MapControls instance
// Cannot use defaultProps here because it needs to be per map instance
_createClass(ViewportController, [{
key: "componentDidMount",
value: function componentDidMount() {
this._eventManager = new _mjolnir.EventManager(this.eventCanvas); // If props.controls is not provided, fallback to default MapControls instance
// Cannot use defaultProps here because it needs to be per map instance
this._controls = this.props.controls || new ViewportControls(this.props.viewportState);
this._controls = this.props.controls || new _core.MapController(this.props.viewportState);
this._controls.setOptions(Object.assign({}, this.props, {
onStateChange: this._onInteractiveStateChange.bind(this),
eventManager: this._eventManager
}));
}
this._controls.setOptions(Object.assign({}, this.props, {
onStateChange: this._onInteractiveStateChange.bind(this),
eventManager: this._eventManager
}));
}
}, {
key: "componentWillUpdate",
value: function componentWillUpdate(nextProps) {
if (this._controls) {
this._controls.setOptions(nextProps);
}
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
this._eventManager.destroy();
}
}, {
key: "_onInteractiveStateChange",
value: function _onInteractiveStateChange(_ref2) {
var _ref2$isDragging = _ref2.isDragging,
isDragging = _ref2$isDragging === void 0 ? false : _ref2$isDragging;
componentWillUpdate(nextProps) {
if (this._controls) {
this._controls.setOptions(nextProps);
if (isDragging !== this.state.isDragging) {
this.setState({
isDragging: isDragging
});
}
}
}
}, {
key: "render",
value: function render() {
var _this2 = this;
componentWillUnmount() {
this._eventManager.destroy();
}
_onInteractiveStateChange({
isDragging = false
}) {
if (isDragging !== this.state.isDragging) {
this.setState({
isDragging
});
var _this$props = this.props,
width = _this$props.width,
height = _this$props.height,
getCursor = _this$props.getCursor;
var eventCanvasStyle = {
width: width,
height: height,
position: 'relative',
cursor: getCursor(this.state)
};
return (0, _react.createElement)('div', {
key: 'map-controls',
ref: function ref(c) {
return _this2.eventCanvas = c;
},
style: eventCanvasStyle
}, this.props.children);
}
}
}]);
render() {
const {
width,
height,
getCursor
} = this.props;
const eventCanvasStyle = {
width,
height,
position: 'relative',
cursor: getCursor(this.state)
};
return createElement('div', {
key: 'map-controls',
ref: c => this.eventCanvas = c,
style: eventCanvasStyle
}, this.props.children);
}
return ViewportController;
}(_react.Component);
}
exports.default = ViewportController;
ViewportController.displayName = 'ViewportController';
ViewportController.propTypes = propTypes;
ViewportController.defaultProps = defaultProps;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/viewport-controller.js"],"names":["Component","createElement","PropTypes","EventManager","MapController","ViewportControls","CURSOR","propTypes","viewportState","func","state","object","width","number","isRequired","height","longitude","latitude","zoom","bearing","pitch","altitude","position","array","maxZoom","minZoom","maxPitch","minPitch","onViewportChange","transitionDuration","transitionInterpolator","transitionInterruption","transitionEasing","onTransitionStart","onTransitionInterrupt","onTransitionEnd","scrollZoom","bool","dragPan","dragRotate","doubleClickZoom","touchZoomRotate","getCursor","controls","shape","events","arrayOf","string","handleEvent","getDefaultCursor","isDragging","GRABBING","GRAB","defaultProps","ViewportController","constructor","props","componentDidMount","_eventManager","eventCanvas","_controls","setOptions","Object","assign","onStateChange","_onInteractiveStateChange","bind","eventManager","componentWillUpdate","nextProps","componentWillUnmount","destroy","setState","render","eventCanvasStyle","cursor","key","ref","c","style","children","displayName"],"mappings":"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","sourcesContent":["import {Component, createElement} from 'react';\nimport PropTypes from 'prop-types';\n\nimport {EventManager} from 'mjolnir.js';\nimport {MapController as ViewportControls} from '@deck.gl/core';\n\nimport CURSOR from './utils/cursors';\n\nconst propTypes = {\n  viewportState: PropTypes.func,\n  state: PropTypes.object,\n\n  /** Viewport props */\n  /** The width of the map. */\n  width: PropTypes.number.isRequired,\n  /** The height of the map. */\n  height: PropTypes.number.isRequired,\n  /** The longitude of the center of the map. */\n  longitude: PropTypes.number.isRequired,\n  /** The latitude of the center of the map. */\n  latitude: PropTypes.number.isRequired,\n  /** The tile zoom level of the map. */\n  zoom: PropTypes.number.isRequired,\n  /** Specify the bearing of the viewport */\n  bearing: PropTypes.number,\n  /** Specify the pitch of the viewport */\n  pitch: PropTypes.number,\n  /** Altitude of the viewport camera. Default 1.5 \"screen heights\" */\n  // Note: Non-public API, see https://github.com/mapbox/mapbox-gl-js/issues/1137\n  altitude: PropTypes.number,\n  // Camera position for FirstPersonViewport\n  position: PropTypes.array,\n\n  /** Viewport constraints */\n  // Max zoom level\n  maxZoom: PropTypes.number,\n  // Min zoom level\n  minZoom: PropTypes.number,\n  // Max pitch in degrees\n  maxPitch: PropTypes.number,\n  // Min pitch in degrees\n  minPitch: PropTypes.number,\n\n  /**\n   * `onViewportChange` callback is fired when the user interacted with the\n   * map. The object passed to the callback contains viewport properties\n   * such as `longitude`, `latitude`, `zoom` etc.\n   */\n  onViewportChange: PropTypes.func,\n\n  /** Viewport transition **/\n  // transition duration for viewport change\n  transitionDuration: PropTypes.number,\n  // an instance of ViewportTransitionInterpolator, can be used to perform custom transitions.\n  transitionInterpolator: PropTypes.object,\n  // type of interruption of current transition on update.\n  transitionInterruption: PropTypes.number,\n  // easing function\n  transitionEasing: PropTypes.func,\n  // transition status update functions\n  onTransitionStart: PropTypes.func,\n  onTransitionInterrupt: PropTypes.func,\n  onTransitionEnd: PropTypes.func,\n\n  /** Enables control event handling */\n  // Scroll to zoom\n  scrollZoom: PropTypes.bool,\n  // Drag to pan\n  dragPan: PropTypes.bool,\n  // Drag to rotate\n  dragRotate: PropTypes.bool,\n  // Double click to zoom\n  doubleClickZoom: PropTypes.bool,\n  // Pinch to zoom / rotate\n  touchZoomRotate: PropTypes.bool,\n\n  /** Accessor that returns a cursor style to show interactive state */\n  getCursor: PropTypes.func,\n\n  // A map control instance to replace the default map controls\n  // The object must expose one property: `events` as an array of subscribed\n  // event names; and two methods: `setState(state)` and `handle(event)`\n  controls: PropTypes.shape({\n    events: PropTypes.arrayOf(PropTypes.string),\n    handleEvent: PropTypes.func\n  })\n};\n\nconst getDefaultCursor = ({isDragging}) => (isDragging ? CURSOR.GRABBING : CURSOR.GRAB);\n\nconst defaultProps = {\n  onViewportChange: null,\n\n  scrollZoom: true,\n  dragPan: true,\n  dragRotate: true,\n  doubleClickZoom: true,\n  touchZoomRotate: true,\n\n  getCursor: getDefaultCursor\n};\n\nexport default class ViewportController extends Component {\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      isDragging: false // Whether the cursor is down\n    };\n  }\n\n  componentDidMount() {\n    this._eventManager = new EventManager(this.eventCanvas);\n\n    // If props.controls is not provided, fallback to default MapControls instance\n    // Cannot use defaultProps here because it needs to be per map instance\n    this._controls = this.props.controls || new ViewportControls(this.props.viewportState);\n\n    this._controls.setOptions(\n      Object.assign({}, this.props, {\n        onStateChange: this._onInteractiveStateChange.bind(this),\n        eventManager: this._eventManager\n      })\n    );\n  }\n\n  componentWillUpdate(nextProps) {\n    if (this._controls) {\n      this._controls.setOptions(nextProps);\n    }\n  }\n\n  componentWillUnmount() {\n    this._eventManager.destroy();\n  }\n\n  _onInteractiveStateChange({isDragging = false}) {\n    if (isDragging !== this.state.isDragging) {\n      this.setState({isDragging});\n    }\n  }\n\n  render() {\n    const {width, height, getCursor} = this.props;\n\n    const eventCanvasStyle = {\n      width,\n      height,\n      position: 'relative',\n      cursor: getCursor(this.state)\n    };\n\n    return createElement(\n      'div',\n      {\n        key: 'map-controls',\n        ref: c => (this.eventCanvas = c),\n        style: eventCanvasStyle\n      },\n      this.props.children\n    );\n  }\n}\n\nViewportController.displayName = 'ViewportController';\nViewportController.propTypes = propTypes;\nViewportController.defaultProps = defaultProps;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/viewport-controller.js"],"names":["propTypes","viewportState","PropTypes","func","state","object","width","number","isRequired","height","longitude","latitude","zoom","bearing","pitch","altitude","position","array","maxZoom","minZoom","maxPitch","minPitch","onViewportChange","transitionDuration","transitionInterpolator","transitionInterruption","transitionEasing","onTransitionStart","onTransitionInterrupt","onTransitionEnd","scrollZoom","bool","dragPan","dragRotate","doubleClickZoom","touchZoomRotate","getCursor","controls","shape","events","arrayOf","string","handleEvent","getDefaultCursor","isDragging","CURSOR","GRABBING","GRAB","defaultProps","ViewportController","props","_eventManager","EventManager","eventCanvas","_controls","ViewportControls","setOptions","Object","assign","onStateChange","_onInteractiveStateChange","bind","eventManager","nextProps","destroy","setState","eventCanvasStyle","cursor","key","ref","c","style","children","Component","displayName"],"mappings":"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","sourcesContent":["import {Component, createElement} from 'react';\nimport PropTypes from 'prop-types';\n\nimport {EventManager} from 'mjolnir.js';\nimport {MapController as ViewportControls} from '@deck.gl/core';\n\nimport CURSOR from './utils/cursors';\n\nconst propTypes = {\n  viewportState: PropTypes.func,\n  state: PropTypes.object,\n\n  /** Viewport props */\n  /** The width of the map. */\n  width: PropTypes.number.isRequired,\n  /** The height of the map. */\n  height: PropTypes.number.isRequired,\n  /** The longitude of the center of the map. */\n  longitude: PropTypes.number.isRequired,\n  /** The latitude of the center of the map. */\n  latitude: PropTypes.number.isRequired,\n  /** The tile zoom level of the map. */\n  zoom: PropTypes.number.isRequired,\n  /** Specify the bearing of the viewport */\n  bearing: PropTypes.number,\n  /** Specify the pitch of the viewport */\n  pitch: PropTypes.number,\n  /** Altitude of the viewport camera. Default 1.5 \"screen heights\" */\n  // Note: Non-public API, see https://github.com/mapbox/mapbox-gl-js/issues/1137\n  altitude: PropTypes.number,\n  // Camera position for FirstPersonViewport\n  position: PropTypes.array,\n\n  /** Viewport constraints */\n  // Max zoom level\n  maxZoom: PropTypes.number,\n  // Min zoom level\n  minZoom: PropTypes.number,\n  // Max pitch in degrees\n  maxPitch: PropTypes.number,\n  // Min pitch in degrees\n  minPitch: PropTypes.number,\n\n  /**\n   * `onViewportChange` callback is fired when the user interacted with the\n   * map. The object passed to the callback contains viewport properties\n   * such as `longitude`, `latitude`, `zoom` etc.\n   */\n  onViewportChange: PropTypes.func,\n\n  /** Viewport transition **/\n  // transition duration for viewport change\n  transitionDuration: PropTypes.number,\n  // an instance of ViewportTransitionInterpolator, can be used to perform custom transitions.\n  transitionInterpolator: PropTypes.object,\n  // type of interruption of current transition on update.\n  transitionInterruption: PropTypes.number,\n  // easing function\n  transitionEasing: PropTypes.func,\n  // transition status update functions\n  onTransitionStart: PropTypes.func,\n  onTransitionInterrupt: PropTypes.func,\n  onTransitionEnd: PropTypes.func,\n\n  /** Enables control event handling */\n  // Scroll to zoom\n  scrollZoom: PropTypes.bool,\n  // Drag to pan\n  dragPan: PropTypes.bool,\n  // Drag to rotate\n  dragRotate: PropTypes.bool,\n  // Double click to zoom\n  doubleClickZoom: PropTypes.bool,\n  // Pinch to zoom / rotate\n  touchZoomRotate: PropTypes.bool,\n\n  /** Accessor that returns a cursor style to show interactive state */\n  getCursor: PropTypes.func,\n\n  // A map control instance to replace the default map controls\n  // The object must expose one property: `events` as an array of subscribed\n  // event names; and two methods: `setState(state)` and `handle(event)`\n  controls: PropTypes.shape({\n    events: PropTypes.arrayOf(PropTypes.string),\n    handleEvent: PropTypes.func\n  })\n};\n\nconst getDefaultCursor = ({isDragging}) => (isDragging ? CURSOR.GRABBING : CURSOR.GRAB);\n\nconst defaultProps = {\n  onViewportChange: null,\n\n  scrollZoom: true,\n  dragPan: true,\n  dragRotate: true,\n  doubleClickZoom: true,\n  touchZoomRotate: true,\n\n  getCursor: getDefaultCursor\n};\n\nexport default class ViewportController extends Component {\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      isDragging: false // Whether the cursor is down\n    };\n  }\n\n  componentDidMount() {\n    this._eventManager = new EventManager(this.eventCanvas);\n\n    // If props.controls is not provided, fallback to default MapControls instance\n    // Cannot use defaultProps here because it needs to be per map instance\n    this._controls = this.props.controls || new ViewportControls(this.props.viewportState);\n\n    this._controls.setOptions(\n      Object.assign({}, this.props, {\n        onStateChange: this._onInteractiveStateChange.bind(this),\n        eventManager: this._eventManager\n      })\n    );\n  }\n\n  componentWillUpdate(nextProps) {\n    if (this._controls) {\n      this._controls.setOptions(nextProps);\n    }\n  }\n\n  componentWillUnmount() {\n    this._eventManager.destroy();\n  }\n\n  _onInteractiveStateChange({isDragging = false}) {\n    if (isDragging !== this.state.isDragging) {\n      this.setState({isDragging});\n    }\n  }\n\n  render() {\n    const {width, height, getCursor} = this.props;\n\n    const eventCanvasStyle = {\n      width,\n      height,\n      position: 'relative',\n      cursor: getCursor(this.state)\n    };\n\n    return createElement(\n      'div',\n      {\n        key: 'map-controls',\n        ref: c => (this.eventCanvas = c),\n        style: eventCanvasStyle\n      },\n      this.props.children\n    );\n  }\n}\n\nViewportController.displayName = 'ViewportController';\nViewportController.propTypes = propTypes;\nViewportController.defaultProps = defaultProps;\n"]}

@@ -5,3 +5,3 @@ {

"license": "MIT",
"version": "5.3.0-rc.1",
"version": "5.3.0-rc.2",
"publishConfig": {

@@ -26,3 +26,3 @@ "access": "public"

"dependencies": {
"@deck.gl/core": "^5.3.0-rc.1",
"@deck.gl/core": "^5.3.0-rc.2",
"prop-types": "^15.6.0"

@@ -29,0 +29,0 @@ },

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc