UNPKG

kepler.gl

Version:

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

139 lines (111 loc) 13.3 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.errorMsg = undefined; var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties'); var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2); var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); var _extends4 = require('babel-runtime/helpers/extends'); var _extends5 = _interopRequireDefault(_extends4); var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray'); var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2); exports.injector = injector; exports.withState = withState; var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _reactRedux = require('react-redux'); var _redux = require('redux'); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _window = require('global/window'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var MissingComp = function MissingComp() { return _react2.default.createElement('div', null); }; // 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 = { noDep: function noDep(fac, parent) { return fac.name + ' is required as a dependency of ' + parent.name + ', ' + 'but is not provided to injectComponents. It will not be rendered'; }, notFunc: '`factory and its replacment should be a function`' }; function injector() { var map = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var cache = {}; // map<factory, factory -> ?> var get = function get(fac, parent) { var factory = map[fac]; // factory is not injected if (!factory) { _window.console.error(errorMsg.noDep(fac, parent)); return MissingComp; } var instances = cache[factory] || factory.apply(undefined, (0, _toConsumableArray3.default)(factory.deps ? factory.deps.map(function (dep) { return get(dep, factory); }) : [])); cache[fac] = instances; return instances; }; // if you have two functions that happen to have the exactly same text // it will be override: 2018-02-05 return { provide: function provide(factory, replacement) { if (typeof factory !== 'function' || typeof replacement !== 'function') { _window.console.error(errorMsg.notFunc); return injector(map); } return injector((0, _extends5.default)({}, map, (0, _defineProperty3.default)({}, factory, replacement))); }, get: get }; } var identity = function identity(state) { return state; }; // Helper to add reducer state to custom component function withState(lenses) { var mapStateToProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : identity; var actions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; return function (Component) { var WrappedComponent = function WrappedComponent(_ref, _ref2) { var selector = _ref2.selector, id = _ref2.id; var state = _ref.state, props = (0, _objectWithoutProperties3.default)(_ref, ['state']); return _react2.default.createElement(Component, lenses.reduce(function (totalState, lens) { return (0, _extends5.default)({}, totalState, lens(selector(state))); }, props)); }; WrappedComponent.contextTypes = { selector: _propTypes2.default.func, id: _propTypes2.default.string }; return (0, _reactRedux.connect)(function (state) { return (0, _extends5.default)({}, mapStateToProps(state), { state: state }); }, function (dispatch) { return Object.keys(actions).reduce(function (accu, key) { return (0, _extends5.default)({}, accu, (0, _defineProperty3.default)({}, key, (0, _redux.bindActionCreators)(actions[key], dispatch))); }, {}); })(WrappedComponent); }; } // Helpter to add actionCreator to custom component //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/injector.js"],"names":["injector","withState","MissingComp","errorMsg","noDep","fac","parent","name","notFunc","map","cache","get","factory","Console","error","instances","deps","dep","provide","replacement","identity","state","lenses","mapStateToProps","actions","Component","WrappedComponent","selector","id","props","reduce","totalState","lens","contextTypes","PropTypes","func","string","Object","keys","accu","key","dispatch"],"mappings":"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","file":"injector.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 from 'react';\nimport {connect} from 'react-redux';\nimport {bindActionCreators} from 'redux';\nimport PropTypes from 'prop-types';\nimport {console as Console} from 'global/window';\n\nconst MissingComp = () => <div />;\nexport const errorMsg = {\n  noDep: (fac, parent) =>\n    `${fac.name} is required as a dependency of ${parent.name}, ` +\n    `but is not provided to injectComponents. It will not be rendered`,\n  notFunc: '`factory and its replacment should be a function`'\n};\n\nexport function injector(map = {}) {\n  const cache = {}; // map<factory, factory -> ?>\n  const get = (fac, parent) => {\n    const factory = map[fac];\n    // factory is not injected\n    if (!factory) {\n      Console.error(errorMsg.noDep(fac, parent));\n      return MissingComp;\n    }\n\n    const instances =\n      cache[factory] ||\n      factory(\n        ...(factory.deps ? factory.deps.map(dep => get(dep, factory)) : [])\n      );\n\n    cache[fac] = instances;\n    return instances;\n  };\n\n  // if you have two functions that happen to have the exactly same text\n  // it will be override: 2018-02-05\n  return {\n    provide: (factory, replacement) => {\n      if (typeof factory !== 'function' || typeof replacement !== 'function') {\n        Console.error(errorMsg.notFunc);\n        return injector(map);\n      }\n      return injector({...map, [factory]: replacement});\n    },\n    get\n  };\n}\n\nconst identity = state => (state);\n// Helper to add reducer state to custom component\nexport function withState(lenses, mapStateToProps = identity, actions = {}) {\n  return (Component) => {\n    const WrappedComponent = ({state, ...props}, {selector, id}) => (\n      <Component\n        {...lenses.reduce(\n          (totalState, lens) => ({\n            ...totalState,\n            ...lens(selector(state))\n          }),\n          props\n        )}\n      />\n    );\n    WrappedComponent.contextTypes = {\n      selector: PropTypes.func,\n      id: PropTypes.string\n    };\n    return connect(\n      state => ({...mapStateToProps(state), state}),\n      dispatch => Object.keys(actions).reduce((accu, key) => ({\n        ...accu,\n        [key]: bindActionCreators(actions[key], dispatch)\n      }), {})\n    )(WrappedComponent);\n  }\n}\n\n// Helpter to add actionCreator to custom component"]}