UNPKG

kepler.gl.geoiq

Version:

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

125 lines (94 loc) 13.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.errorMsg = void 0; exports.injector = injector; exports.withState = withState; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _react = _interopRequireDefault(require("react")); var _reactRedux = require("react-redux"); var _redux = require("redux"); var _propTypes = _interopRequireDefault(require("prop-types")); var _window = require("global/window"); var _excluded = ["state"]; 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; } var MissingComp = function MissingComp() { return (/*#__PURE__*/_react["default"].createElement("div", null) ); }; var errorMsg = exports.errorMsg = { noDep: function noDep(fac, parent) { return "".concat(fac.name, " is required as a dependency of ").concat(parent.name, ", ") + "but is not provided to injectComponents. It will not be rendered"; }, notFunc: '`factory and its replacement should be a function`' }; function injector() { var map = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Map(); var cache = new Map(); // map<factory, factory -> ?> var get = function get(fac, parent) { var factory = map.get(fac); // factory is not injected if (!factory) { _window.console.error(errorMsg.noDep(fac, parent)); return MissingComp; } var instances = cache.get(factory) || factory.apply(void 0, (0, _toConsumableArray2["default"])(factory.deps ? factory.deps.map(function (dep) { return get(dep, factory); }) : [])); cache.set(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') { _window.console.error('Error injecting factory: ', factory); _window.console.error(errorMsg.notFunc); return injector(map); } else if (typeof replacement !== 'function') { _window.console.error('Error injecting replacement for: ', factory); _window.console.error(errorMsg.notFunc); return injector(map); } return injector(new Map(map).set(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 state = _ref.state, props = (0, _objectWithoutProperties2["default"])(_ref, _excluded); var selector = _ref2.selector, id = _ref2.id; return (/*#__PURE__*/_react["default"].createElement(Component, lenses.reduce(function (totalState, lens) { return _objectSpread(_objectSpread({}, totalState), lens(selector(state))); }, props)) ); }; WrappedComponent.contextTypes = { selector: _propTypes["default"].func, id: _propTypes["default"].string }; return (0, _reactRedux.connect)(function (state) { return _objectSpread(_objectSpread({}, mapStateToProps(state)), {}, { state: state }); }, function (dispatch) { return Object.keys(actions).reduce(function (accu, key) { return _objectSpread(_objectSpread({}, accu), {}, (0, _defineProperty2["default"])({}, key, (0, _redux.bindActionCreators)(actions[key], dispatch))); }, {}); })(WrappedComponent); }; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/injector.js"],"names":["MissingComp","errorMsg","noDep","fac","parent","name","notFunc","injector","map","Map","cache","get","factory","Console","error","instances","deps","dep","set","provide","replacement","identity","state","withState","lenses","mapStateToProps","actions","Component","WrappedComponent","props","selector","id","reduce","totalState","lens","contextTypes","PropTypes","func","string","dispatch","Object","keys","accu","key"],"mappings":"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","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 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 replacement should be a function`'\n};\n\nexport function injector(map = new Map()) {\n  const cache = new Map(); // map<factory, factory -> ?>\n  const get = (fac, parent) => {\n    const factory = map.get(fac);\n\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.get(factory) ||\n      factory(\n        ...(factory.deps ? factory.deps.map(dep => get(dep, factory)) : [])\n      );\n\n    cache.set(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') {\n        Console.error('Error injecting factory: ', factory);\n        Console.error(errorMsg.notFunc);\n        return injector(map);\n      } else if (typeof replacement !== 'function') {\n        Console.error('Error injecting replacement for: ', factory);\n        Console.error(errorMsg.notFunc);\n        return injector(map);\n      }\n\n      return injector((new Map(map)).set(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"]}