kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
218 lines (166 loc) • 19.3 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.appInjector = exports.errorMsg = undefined;
var _typeof2 = require('babel-runtime/helpers/typeof');
var _typeof3 = _interopRequireDefault(_typeof2);
var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray');
var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
exports.ContainerFactory = ContainerFactory;
exports.injectComponents = injectComponents;
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactRedux = require('react-redux');
var _lodash = require('lodash.memoize');
var _lodash2 = _interopRequireDefault(_lodash);
var _window = require('global/window');
var _injector = require('./injector');
var _keplerGl = require('./kepler-gl');
var _keplerGl2 = _interopRequireDefault(_keplerGl);
var _actionWrapper = require('../actions/action-wrapper');
var _identityActions = require('../actions/identity-actions');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
// Copyright (c) 2018 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.
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, ' + (type + ' is provided');
},
wrongPairType: 'injectComponents takes an array of factories replacement pairs as input, ' + 'each pair be a array as [originalFactory, replacement]'
};
ContainerFactory.deps = [_keplerGl2.default];
function ContainerFactory(KeplerGl) {
var _class, _temp;
var Container = (_temp = _class = function (_Component) {
(0, _inherits3.default)(Container, _Component);
function Container(props, ctx) {
(0, _classCallCheck3.default)(this, Container);
var _this = (0, _possibleConstructorReturn3.default)(this, (Container.__proto__ || Object.getPrototypeOf(Container)).call(this, props, ctx));
_this.getSelector = (0, _lodash2.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, _lodash2.default)(function (id, dispatch) {
return (0, _actionWrapper.forwardTo)(id, dispatch);
});
return _this;
}
// default id and address if not provided
(0, _createClass3.default)(Container, [{
key: 'componentWillMount',
value: function componentWillMount() {
var _props = this.props,
id = _props.id,
mint = _props.mint,
mapboxApiAccessToken = _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 !== this.props.id) {
this.props.dispatch((0, _identityActions.renameEntry)(this.props.id, nextProps));
}
}
}, {
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 _props2 = this.props,
id = _props2.id,
getState = _props2.getState,
dispatch = _props2.dispatch,
state = _props2.state;
var selector = this.getSelector(id, getState);
if (!selector || !selector(state)) {
// instance state hasn't been mounted yet
return _react2.default.createElement('div', null);
}
return _react2.default.createElement(KeplerGl, (0, _extends3.default)({}, this.props, {
id: id,
selector: selector,
dispatch: this.getDispatch(id, dispatch)
}));
}
}]);
return Container;
}(_react.Component), _class.defaultProps = {
id: 'map',
getState: function getState(state) {
return state.keplerGl;
},
mint: true
}, _temp);
var mapStateToProps = function mapStateToProps(state, props) {
return (0, _extends3.default)({ state: state }, props);
};
var dispatchToProps = function dispatchToProps(dispatch) {
return { dispatch: dispatch };
};
return (0, _reactRedux.connect)(mapStateToProps, dispatchToProps)(Container);
}
// provide all recipes to injector
var appInjector = exports.appInjector = [ContainerFactory].concat((0, _toConsumableArray3.default)(ContainerFactory.deps), (0, _toConsumableArray3.default)(_keplerGl2.default.deps), (0, _toConsumableArray3.default)(_keplerGl.keplerGlChildDeps)).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(typeof recipes === 'undefined' ? 'undefined' : (0, _typeof3.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, _toConsumableArray3.default)(recipe));
}, appInjector).get(ContainerFactory);
}
var InjectedContainer = appInjector.get(ContainerFactory);
exports.default = InjectedContainer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/container.js"],"names":["ContainerFactory","injectComponents","errorMsg","noState","wrongType","type","wrongPairType","deps","KeplerGlFactory","KeplerGl","Container","props","ctx","getSelector","id","getState","state","Console","error","getDispatch","dispatch","mint","mapboxApiAccessToken","nextProps","selector","Component","defaultProps","keplerGl","mapStateToProps","dispatchToProps","appInjector","keplerGlChildDeps","reduce","inj","factory","provide","recipes","Array","isArray","get","recipe","InjectedContainer"],"mappings":"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","file":"container.js","sourcesContent":["// Copyright (c) 2018 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, {keplerGlChildDeps} 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 !== this.props.id) {\n        this.props.dispatch(renameEntry(this.props.id, nextProps));\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// provide all recipes to injector\nexport const appInjector = [\n  ContainerFactory,\n  ...ContainerFactory.deps,\n  ...KeplerGlFactory.deps,\n  ...keplerGlChildDeps\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"]}
;