UNPKG

kepler.gl.geoiq

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

207 lines (160 loc) 20.5 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.ContainerFactory = ContainerFactory; exports.injectComponents = injectComponents; exports["default"] = exports.appInjector = exports.errorMsg = void 0; 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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); 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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var 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]" }; exports.errorMsg = errorMsg; ContainerFactory.deps = [_keplerGl["default"]]; function ContainerFactory(KeplerGl) { var Container = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(Container, _Component); // default id and address if not provided function Container(props, ctx) { var _this; (0, _classCallCheck2["default"])(this, Container); _this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(Container).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; // add a new entry to reducer this.props.dispatch((0, _identityActions.registerEntry)({ id: id, mint: mint, mapboxApiAccessToken: mapboxApiAccessToken })); } }, { 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 _react["default"].createElement("div", null); } return _react["default"].createElement(KeplerGl, (0, _extends2["default"])({}, this.props, { id: id, selector: selector, dispatch: this.getDispatch(id, dispatch) })); } }]); return Container; }(_react.Component); (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 = allDependencies.reduce(function (inj, factory) { return inj.provide(factory, factory); }, (0, _injector.injector)()); // Helper to inject custom components and return kepler.gl container exports.appInjector = appInjector; 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) { if (!Array.isArray(recipes)) { _window.console.error(errorMsg.wrongPairType); return inj; } return inj.provide.apply(inj, (0, _toConsumableArray2["default"])(recipe)); }, appInjector).get(ContainerFactory); } var InjectedContainer = appInjector.get(ContainerFactory); var _default = InjectedContainer; exports["default"] = _default; //# 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","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","InjectedContainer"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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  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} = this.props;\n      // add a new entry to reducer\n      this.props.dispatch(registerEntry({id, mint, mapboxApiAccessToken}));\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      return inj.provide(...recipe);\n    }, appInjector)\n    .get(ContainerFactory);\n}\n\nconst InjectedContainer = appInjector.get(ContainerFactory);\n\nexport default InjectedContainer;\n"]}