kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
252 lines (197 loc) • 26.6 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof3 = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ContainerFactory = ContainerFactory;
exports.errorMsg = exports["default"] = exports.appInjector = void 0;
exports.injectComponents = injectComponents;
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _reactRedux = require("react-redux");
var _lodash = _interopRequireDefault(require("lodash.memoize"));
var _window = require("global/window");
var _injector = require("./injector");
var _keplerGl = _interopRequireDefault(require("./kepler-gl"));
var _actionWrapper = require("../actions/action-wrapper");
var _identityActions = require("../actions/identity-actions");
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var errorMsg = exports.errorMsg = {
noState: "kepler.gl state doesnt exist. " + "You might forget to mount keplerGlReducer in your root reducer." + "If it is not mounted as state.keplerGl by default, you need to provide getState as a prop",
wrongType: function wrongType(type) {
return "injectComponents takes an array of factories replacement pairs as input, " + "".concat(type, " is provided");
},
wrongPairType: "injectComponents takes an array of factories replacement pairs as input, " + "each pair be a array as [originalFactory, replacement]"
};
ContainerFactory.deps = [_keplerGl["default"]];
function ContainerFactory(KeplerGl) {
/** @lends KeplerGl */
/**
* Main Kepler.gl Component
* @param {Object} props
*
* @param {string} props.id - _required_
*
* - Default: `map`
* The id of this KeplerGl instance. `id` is required if you have multiple
* KeplerGl instances in your app. It defines the prop name of the KeplerGl state that is
* stored in the KeplerGl reducer. For example, the state of the KeplerGl component with id `foo` is
* stored in `state.keplerGl.foo`.
*
* In case you create multiple kepler.gl instances using the same id, the kepler.gl state defined by the entry will be
* overridden by the latest instance and reset to a blank state.
* @param {string} props.mapboxApiAccessToken - _required_
* @param {string} props.mapboxApiUrl - _optional_
* @param {Boolean} props.mapStylesReplaceDefault - _optional_
* You can create a free account at [www.mapbox.com](www.mapbox.com) and create a token at
* [www.mapbox.com/account/access-tokens](www.mapbox.com/account/access-tokens)
*
*
* @param {Number} props.width - _required_ Width of the KeplerGl UI.
* @public
*/
var Container = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(Container, _Component);
var _super = _createSuper(Container);
function Container(props, ctx) {
var _this;
(0, _classCallCheck2["default"])(this, Container);
_this = _super.call(this, props, ctx);
_this.getSelector = (0, _lodash["default"])(function (id, getState) {
return function (state) {
if (!getState(state)) {
// log error
_window.console.error(errorMsg.noState);
return null;
}
return getState(state)[id];
};
});
_this.getDispatch = (0, _lodash["default"])(function (id, dispatch) {
return (0, _actionWrapper.forwardTo)(id, dispatch);
});
return _this;
}
(0, _createClass2["default"])(Container, [{
key: "componentWillMount",
value: function componentWillMount() {
var _this$props = this.props,
id = _this$props.id,
mint = _this$props.mint,
mapboxApiAccessToken = _this$props.mapboxApiAccessToken,
mapboxApiUrl = _this$props.mapboxApiUrl,
mapStylesReplaceDefault = _this$props.mapStylesReplaceDefault; // add a new entry to reducer
this.props.dispatch((0, _identityActions.registerEntry)({
id: id,
mint: mint,
mapboxApiAccessToken: mapboxApiAccessToken,
mapboxApiUrl: mapboxApiUrl,
mapStylesReplaceDefault: mapStylesReplaceDefault
}));
}
}, {
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(nextProps) {
// check if id has changed, if true, copy state over
if (nextProps.id && nextProps.id !== this.props.id) {
this.props.dispatch((0, _identityActions.renameEntry)(this.props.id, nextProps.id));
}
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
if (this.props.mint !== false) {
// delete entry in reducer
this.props.dispatch((0, _identityActions.deleteEntry)(this.props.id));
}
}
}, {
key: "render",
value: function render() {
var _this$props2 = this.props,
id = _this$props2.id,
getState = _this$props2.getState,
dispatch = _this$props2.dispatch,
state = _this$props2.state;
var selector = this.getSelector(id, getState);
if (!selector || !selector(state)) {
// instance state hasn't been mounted yet
return (/*#__PURE__*/_react["default"].createElement("div", null)
);
}
return (/*#__PURE__*/_react["default"].createElement(KeplerGl, (0, _extends2["default"])({}, this.props, {
id: id,
selector: selector,
dispatch: this.getDispatch(id, dispatch)
}))
);
}
}]);
return Container;
}(_react.Component);
// default id and address if not provided
(0, _defineProperty2["default"])(Container, "defaultProps", {
id: 'map',
getState: function getState(state) {
return state.keplerGl;
},
mint: true
});
var mapStateToProps = function mapStateToProps(state, props) {
return _objectSpread({
state: state
}, props);
};
var dispatchToProps = function dispatchToProps(dispatch) {
return {
dispatch: dispatch
};
};
return (0, _reactRedux.connect)(mapStateToProps, dispatchToProps)(Container);
} // entryPoint
function flattenDeps(allDeps, factory) {
var addToDeps = allDeps.concat([factory]);
return Array.isArray(factory.deps) && factory.deps.length ? factory.deps.reduce(function (accu, dep) {
return flattenDeps(accu, dep);
}, addToDeps) : addToDeps;
}
var allDependencies = flattenDeps([], ContainerFactory); // provide all dependencies to appInjector
var appInjector = exports.appInjector = allDependencies.reduce(function (inj, factory) {
return inj.provide(factory, factory);
}, (0, _injector.injector)()); // Helper to inject custom components and return kepler.gl container
function injectComponents(recipes) {
if (!Array.isArray(recipes)) {
_window.console.error(errorMsg.wrongType((0, _typeof2["default"])(recipes)));
return appInjector.get(ContainerFactory);
}
return recipes.reduce(function (inj, recipe) {
var _inj;
if (!Array.isArray(recipes)) {
_window.console.error(errorMsg.wrongPairType);
return inj;
} // collect dependencies of custom factories, if there is any.
// Add them to the injector
var customDependencies = flattenDeps([], recipe[1]);
inj = customDependencies.reduce(function (ij, factory) {
return ij.provide(factory, factory);
}, inj);
return (_inj = inj).provide.apply(_inj, (0, _toConsumableArray2["default"])(recipe));
}, appInjector).get(ContainerFactory);
}
var InjectedContainer = appInjector.get(ContainerFactory);
var _default = exports["default"] = InjectedContainer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/container.js"],"names":["errorMsg","noState","wrongType","type","wrongPairType","ContainerFactory","deps","KeplerGlFactory","KeplerGl","Container","props","ctx","getSelector","id","getState","state","Console","error","getDispatch","dispatch","mint","mapboxApiAccessToken","mapboxApiUrl","mapStylesReplaceDefault","nextProps","selector","Component","keplerGl","mapStateToProps","dispatchToProps","flattenDeps","allDeps","factory","addToDeps","concat","Array","isArray","length","reduce","accu","dep","allDependencies","appInjector","inj","provide","injectComponents","recipes","get","recipe","customDependencies","ij","InjectedContainer"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;;;;;;;;;AAMO,IAAMA,QAAQ,sBAAG;AACtBC,EAAAA,OAAO,EACL,kMAFoB;AAMtBC,EAAAA,SAAS,EAAE,mBAAAC,IAAI;AAAA,WAAI,wFACdA,IADc,iBAAJ;AAAA,GANO;AAStBC,EAAAA,aAAa,EAAE;AATO,CAAjB;AAaPC,gBAAgB,CAACC,IAAjB,GAAwB,CAACC,oBAAD,CAAxB;;AAEO,SAASF,gBAAT,CAA0BG,QAA1B,EAAoC;AACzC;;AACA;;;;;;;;;;;;;;;;;;;;;;;;AAFyC,MA2BnCC,SA3BmC;AAAA;;AAAA;;AAmCvC,uBAAYC,KAAZ,EAAmBC,GAAnB,EAAwB;AAAA;;AAAA;AACtB,gCAAMD,KAAN,EAAaC,GAAb;AAEA,YAAKC,WAAL,GAAmB,wBAAQ,UAACC,EAAD,EAAKC,QAAL;AAAA,eAAkB,UAAAC,KAAK,EAAI;AACpD,cAAI,CAACD,QAAQ,CAACC,KAAD,CAAb,EAAsB;AACpB;AACAC,4BAAQC,KAAR,CAAcjB,QAAQ,CAACC,OAAvB;;AAEA,mBAAO,IAAP;AACD;;AACD,iBAAOa,QAAQ,CAACC,KAAD,CAAR,CAAgBF,EAAhB,CAAP;AACD,SAR0B;AAAA,OAAR,CAAnB;AASA,YAAKK,WAAL,GAAmB,wBAAQ,UAACL,EAAD,EAAKM,QAAL;AAAA,eAAkB,8BAAUN,EAAV,EAAcM,QAAd,CAAlB;AAAA,OAAR,CAAnB;AAZsB;AAavB;;AAhDsC;AAAA;AAAA,aAkDvC,8BAAqB;AACnB,0BAAgF,KAAKT,KAArF;AAAA,YAAOG,EAAP,eAAOA,EAAP;AAAA,YAAWO,IAAX,eAAWA,IAAX;AAAA,YAAiBC,oBAAjB,eAAiBA,oBAAjB;AAAA,YAAuCC,YAAvC,eAAuCA,YAAvC;AAAA,YAAqDC,uBAArD,eAAqDA,uBAArD,CADmB,CAEnB;;AACA,aAAKb,KAAL,CAAWS,QAAX,CAAoB,oCAAc;AAACN,UAAAA,EAAE,EAAFA,EAAD;AAAKO,UAAAA,IAAI,EAAJA,IAAL;AAAWC,UAAAA,oBAAoB,EAApBA,oBAAX;AAAiCC,UAAAA,YAAY,EAAZA,YAAjC;AAA+CC,UAAAA,uBAAuB,EAAvBA;AAA/C,SAAd,CAApB;AACD;AAtDsC;AAAA;AAAA,aAwDvC,mCAA0BC,SAA1B,EAAqC;AACnC;AACA,YAAIA,SAAS,CAACX,EAAV,IAAgBW,SAAS,CAACX,EAAV,KAAiB,KAAKH,KAAL,CAAWG,EAAhD,EAAoD;AAClD,eAAKH,KAAL,CAAWS,QAAX,CAAoB,kCAAY,KAAKT,KAAL,CAAWG,EAAvB,EAA2BW,SAAS,CAACX,EAArC,CAApB;AACD;AACF;AA7DsC;AAAA;AAAA,aA+DvC,gCAAuB;AACrB,YAAI,KAAKH,KAAL,CAAWU,IAAX,KAAoB,KAAxB,EAA+B;AAC7B;AACA,eAAKV,KAAL,CAAWS,QAAX,CAAoB,kCAAY,KAAKT,KAAL,CAAWG,EAAvB,CAApB;AACD;AACF;AApEsC;AAAA;AAAA,aAsEvC,kBAAS;AACP,2BAAwC,KAAKH,KAA7C;AAAA,YAAOG,EAAP,gBAAOA,EAAP;AAAA,YAAWC,QAAX,gBAAWA,QAAX;AAAA,YAAqBK,QAArB,gBAAqBA,QAArB;AAAA,YAA+BJ,KAA/B,gBAA+BA,KAA/B;AACA,YAAMU,QAAQ,GAAG,KAAKb,WAAL,CAAiBC,EAAjB,EAAqBC,QAArB,CAAjB;;AAEA,YAAI,CAACW,QAAD,IAAa,CAACA,QAAQ,CAACV,KAAD,CAA1B,EAAmC;AACjC;AACA,+BAAO;AAAP;AACD;;AAED,6BACE,gCAAC,QAAD,gCACM,KAAKL,KADX;AAEE,YAAA,EAAE,EAAEG,EAFN;AAGE,YAAA,QAAQ,EAAEY,QAHZ;AAIE,YAAA,QAAQ,EAAE,KAAKP,WAAL,CAAiBL,EAAjB,EAAqBM,QAArB;AAJZ;AADF;AAQD;AAvFsC;AAAA;AAAA,IA2BjBO,gBA3BiB;;AA4BvC;AA5BuC,mCA2BnCjB,SA3BmC,kBA6BjB;AACpBI,IAAAA,EAAE,EAAE,KADgB;AAEpBC,IAAAA,QAAQ,EAAE,kBAAAC,KAAK;AAAA,aAAIA,KAAK,CAACY,QAAV;AAAA,KAFK;AAGpBP,IAAAA,IAAI,EAAE;AAHc,GA7BiB;;AA0FzC,MAAMQ,eAAe,GAAG,SAAlBA,eAAkB,CAACb,KAAD,EAAQL,KAAR;AAAA;AAAoBK,MAAAA,KAAK,EAALA;AAApB,OAA8BL,KAA9B;AAAA,GAAxB;;AACA,MAAMmB,eAAe,GAAG,SAAlBA,eAAkB,CAAAV,QAAQ;AAAA,WAAK;AAACA,MAAAA,QAAQ,EAARA;AAAD,KAAL;AAAA,GAAhC;;AACA,SAAO,yBAAQS,eAAR,EAAyBC,eAAzB,EAA0CpB,SAA1C,CAAP;AACD,C,CAED;;;AACA,SAASqB,WAAT,CAAqBC,OAArB,EAA8BC,OAA9B,EAAuC;AACrC,MAAMC,SAAS,GAAGF,OAAO,CAACG,MAAR,CAAe,CAACF,OAAD,CAAf,CAAlB;AACA,SAAOG,KAAK,CAACC,OAAN,CAAcJ,OAAO,CAAC1B,IAAtB,KAA+B0B,OAAO,CAAC1B,IAAR,CAAa+B,MAA5C,GACLL,OAAO,CAAC1B,IAAR,CAAagC,MAAb,CAAoB,UAACC,IAAD,EAAOC,GAAP;AAAA,WAAeV,WAAW,CAACS,IAAD,EAAOC,GAAP,CAA1B;AAAA,GAApB,EAA2DP,SAA3D,CADK,GAELA,SAFF;AAGD;;AAED,IAAMQ,eAAe,GAAGX,WAAW,CAAC,EAAD,EAAKzB,gBAAL,CAAnC,C,CAEA;;AACO,IAAMqC,WAAW,yBAAGD,eAAe,CACvCH,MADwB,CACjB,UAACK,GAAD,EAAMX,OAAN;AAAA,SAAkBW,GAAG,CAACC,OAAJ,CAAYZ,OAAZ,EAAqBA,OAArB,CAAlB;AAAA,CADiB,EACgC,yBADhC,CAApB,C,CAGP;;AACO,SAASa,gBAAT,CAA0BC,OAA1B,EAAmC;AACxC,MAAI,CAACX,KAAK,CAACC,OAAN,CAAcU,OAAd,CAAL,EAA6B;AAC3B9B,oBAAQC,KAAR,CAAcjB,QAAQ,CAACE,SAAT,0BAA0B4C,OAA1B,EAAd;;AACA,WAAOJ,WAAW,CAACK,GAAZ,CAAgB1C,gBAAhB,CAAP;AACD;;AAED,SAAOyC,OAAO,CACXR,MADI,CACG,UAACK,GAAD,EAAMK,MAAN,EAAiB;AAAA;;AACvB,QAAI,CAACb,KAAK,CAACC,OAAN,CAAcU,OAAd,CAAL,EAA6B;AAC3B9B,sBAAQC,KAAR,CAAcjB,QAAQ,CAACI,aAAvB;;AACA,aAAOuC,GAAP;AACD,KAJsB,CAMvB;AACA;;;AACA,QAAMM,kBAAkB,GAAGnB,WAAW,CAAC,EAAD,EAAKkB,MAAM,CAAC,CAAD,CAAX,CAAtC;AACAL,IAAAA,GAAG,GAAGM,kBAAkB,CACrBX,MADG,CACI,UAACY,EAAD,EAAKlB,OAAL;AAAA,aAAiBkB,EAAE,CAACN,OAAH,CAAWZ,OAAX,EAAoBA,OAApB,CAAjB;AAAA,KADJ,EACmDW,GADnD,CAAN;AAGA,WAAO,QAAAA,GAAG,EAACC,OAAJ,iDAAeI,MAAf,EAAP;AACD,GAdI,EAcFN,WAdE,EAeJK,GAfI,CAeA1C,gBAfA,CAAP;AAgBD;;AAED,IAAM8C,iBAAiB,GAAGT,WAAW,CAACK,GAAZ,CAAgB1C,gBAAhB,CAA1B;;oCAEe8C,iB","sourcesContent":["// Copyright (c) 2023 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {Component} from 'react';\nimport {connect} from 'react-redux';\nimport memoize from 'lodash.memoize';\nimport {console as Console} from 'global/window';\nimport {injector} from './injector';\nimport KeplerGlFactory from './kepler-gl';\nimport {forwardTo} from 'actions/action-wrapper';\n\nimport {\n  registerEntry,\n  deleteEntry,\n  renameEntry\n} from 'actions/identity-actions';\n\nexport const errorMsg = {\n  noState:\n    `kepler.gl state doesnt exist. ` +\n    `You might forget to mount keplerGlReducer in your root reducer.` +\n    `If it is not mounted as state.keplerGl by default, you need to provide getState as a prop`,\n\n  wrongType: type => `injectComponents takes an array of factories replacement pairs as input, ` +\n    `${type} is provided`,\n\n  wrongPairType: `injectComponents takes an array of factories replacement pairs as input, ` +\n  `each pair be a array as [originalFactory, replacement]`\n};\n\nContainerFactory.deps = [KeplerGlFactory];\n\nexport function ContainerFactory(KeplerGl) {\n  /** @lends KeplerGl */\n  /**\n    * Main Kepler.gl Component\n    * @param {Object} props\n    *\n    * @param {string} props.id - _required_\n    *\n    * - Default: `map`\n    * The id of this KeplerGl instance. `id` is required if you have multiple\n    * KeplerGl instances in your app. It defines the prop name of the KeplerGl state that is\n    * stored in the KeplerGl reducer. For example, the state of the KeplerGl component with id `foo` is\n    * stored in `state.keplerGl.foo`.\n    *\n    * In case you create multiple kepler.gl instances using the same id, the kepler.gl state defined by the entry will be\n    * overridden by the latest instance and reset to a blank state.\n    * @param {string} props.mapboxApiAccessToken - _required_\n    * @param {string} props.mapboxApiUrl - _optional_\n    * @param {Boolean} props.mapStylesReplaceDefault - _optional_\n\n    * You can create a free account at [www.mapbox.com](www.mapbox.com) and create a token at\n    * [www.mapbox.com/account/access-tokens](www.mapbox.com/account/access-tokens)\n    *\n    *\n    * @param {Number} props.width - _required_ Width of the KeplerGl UI.\n    * @public\n   */\n  class Container extends Component {\n    // default id and address if not provided\n    static defaultProps = {\n      id: 'map',\n      getState: state => state.keplerGl,\n      mint: true\n    };\n\n    constructor(props, ctx) {\n      super(props, ctx);\n\n      this.getSelector = memoize((id, getState) => state => {\n        if (!getState(state)) {\n          // log error\n          Console.error(errorMsg.noState);\n\n          return null;\n        }\n        return getState(state)[id];\n      });\n      this.getDispatch = memoize((id, dispatch) => forwardTo(id, dispatch));\n    }\n\n    componentWillMount() {\n      const {id, mint, mapboxApiAccessToken, mapboxApiUrl, mapStylesReplaceDefault} = this.props;\n      // add a new entry to reducer\n      this.props.dispatch(registerEntry({id, mint, mapboxApiAccessToken, mapboxApiUrl, mapStylesReplaceDefault}));\n    }\n\n    componentWillReceiveProps(nextProps) {\n      // check if id has changed, if true, copy state over\n      if (nextProps.id && nextProps.id !== this.props.id) {\n        this.props.dispatch(renameEntry(this.props.id, nextProps.id));\n      }\n    }\n\n    componentWillUnmount() {\n      if (this.props.mint !== false) {\n        // delete entry in reducer\n        this.props.dispatch(deleteEntry(this.props.id));\n      }\n    }\n\n    render() {\n      const {id, getState, dispatch, state} = this.props;\n      const selector = this.getSelector(id, getState);\n\n      if (!selector || !selector(state)) {\n        // instance state hasn't been mounted yet\n        return <div />;\n      }\n\n      return (\n        <KeplerGl\n          {...this.props}\n          id={id}\n          selector={selector}\n          dispatch={this.getDispatch(id, dispatch)}\n        />\n      );\n    }\n  }\n\n  const mapStateToProps = (state, props) => ({state, ...props});\n  const dispatchToProps = dispatch => ({dispatch});\n  return connect(mapStateToProps, dispatchToProps)(Container);\n}\n\n// entryPoint\nfunction flattenDeps(allDeps, factory) {\n  const addToDeps = allDeps.concat([factory]);\n  return Array.isArray(factory.deps) && factory.deps.length ?\n    factory.deps.reduce((accu, dep) => flattenDeps(accu, dep), addToDeps) :\n    addToDeps;\n}\n\nconst allDependencies = flattenDeps([], ContainerFactory);\n\n// provide all dependencies to appInjector\nexport const appInjector = allDependencies\n  .reduce((inj, factory) => inj.provide(factory, factory), injector());\n\n// Helper to inject custom components and return kepler.gl container\nexport function injectComponents(recipes) {\n  if (!Array.isArray(recipes)) {\n    Console.error(errorMsg.wrongType(typeof(recipes)));\n    return appInjector.get(ContainerFactory);\n  }\n\n  return recipes\n    .reduce((inj, recipe) => {\n      if (!Array.isArray(recipes)) {\n        Console.error(errorMsg.wrongPairType);\n        return inj;\n      }\n\n      // collect dependencies of custom factories, if there is any.\n      // Add them to the injector\n      const customDependencies = flattenDeps([], recipe[1]);\n      inj = customDependencies\n        .reduce((ij, factory) => ij.provide(factory, factory), inj);\n\n      return inj.provide(...recipe);\n    }, appInjector)\n    .get(ContainerFactory);\n}\n\nconst InjectedContainer = appInjector.get(ContainerFactory);\n\nexport default InjectedContainer;\n"]}