UNPKG

kepler.gl

Version:

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

181 lines (173 loc) 26.2 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.ContainerFactory = ContainerFactory; exports["default"] = exports.appInjector = exports.ERROR_MSG = void 0; exports.injectComponents = injectComponents; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _reactRedux = require("react-redux"); var _window = require("global/window"); var _injector = require("./injector"); var _keplerGl = _interopRequireDefault(require("./kepler-gl")); var _actions = require("@kepler.gl/actions"); var _utils = require("@kepler.gl/utils"); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } 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; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var ERROR_MSG = exports.ERROR_MSG = { noState: "kepler.gl state does not 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" }; var mapStateToProps = function mapStateToProps(state, props) { return _objectSpread({ state: state }, props); }; var dispatchToProps = function dispatchToProps(dispatch) { return { dispatch: dispatch }; }; var connector = (0, _reactRedux.connect)(mapStateToProps, dispatchToProps); 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_ * @param {object} props.initialUiState - _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 */ function usePreviousId(value) { var ref = (0, _react.useRef)(); (0, _react.useEffect)(function () { ref.current = value; }); return ref.current; } var Container = function Container(props) { var _props$id = props.id, id = _props$id === void 0 ? 'map' : _props$id, _props$getState = props.getState, getState = _props$getState === void 0 ? function (state) { return state.keplerGl; } : _props$getState, _props$mint = props.mint, mint = _props$mint === void 0 ? true : _props$mint, mapboxApiAccessToken = props.mapboxApiAccessToken, mapboxApiUrl = props.mapboxApiUrl, mapStylesReplaceDefault = props.mapStylesReplaceDefault, initialUiState = props.initialUiState, state = props.state; var prevId = usePreviousId(id); var dispatch = (0, _reactRedux.useDispatch)(); (0, _react.useEffect)(function () { // add a new entry to reducer dispatch((0, _actions.registerEntry)({ id: id, mint: mint, mapboxApiAccessToken: mapboxApiAccessToken, mapboxApiUrl: mapboxApiUrl, mapStylesReplaceDefault: mapStylesReplaceDefault, initialUiState: initialUiState })); // initialize plugins if ((0, _utils.getApplicationConfig)().plugins.length) { (0, _utils.getApplicationConfig)().plugins.forEach( /*#__PURE__*/function () { var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(plugin) { return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: _context.next = 2; return plugin.init(); case 2: case "end": return _context.stop(); } }, _callee); })); return function (_x) { return _ref.apply(this, arguments); }; }()); } // cleanup return function () { if (mint !== false) { // delete entry in reducer dispatch((0, _actions.deleteEntry)(id)); } }; }, [id, dispatch, initialUiState, mapStylesReplaceDefault, mapboxApiAccessToken, mapboxApiUrl, mint]); (0, _react.useEffect)(function () { // check if id has changed, if true, copy state over if (prevId && id && prevId !== id) { dispatch((0, _actions.renameEntry)(prevId, id)); } }, [dispatch, prevId, id]); var stateSelector = (0, _react.useMemo)(function () { return function (keplerState) { if (!getState(keplerState)) { // log error _window.console.error(ERROR_MSG.noState); return null; } return getState(keplerState)[id]; }; }, [id, getState]); var forwardDispatch = (0, _react.useMemo)(function () { return (0, _actions.forwardTo)(id, dispatch); }, [id, dispatch]); // const selector = getSelector(id, getState); if (!stateSelector || !stateSelector(state)) { // instance state hasn't been mounted yet return /*#__PURE__*/_react["default"].createElement("div", null); } return /*#__PURE__*/_react["default"].createElement(KeplerGl, (0, _extends2["default"])({}, props, { id: id, selector: stateSelector, dispatch: forwardDispatch })); }; return connector(Container); } var allDependencies = (0, _injector.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() { var recipes = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; return (0, _injector.provideRecipesToInjector)(recipes, appInjector).get(ContainerFactory); } var InjectedContainer = appInjector.get(ContainerFactory); var _default = exports["default"] = InjectedContainer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_window","_injector","_keplerGl","_interopRequireDefault","_actions","_utils","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","ERROR_MSG","exports","noState","mapStateToProps","state","props","dispatchToProps","dispatch","connector","connect","ContainerFactory","deps","KeplerGlFactory","KeplerGl","usePreviousId","value","ref","useRef","useEffect","current","Container","_props$id","id","_props$getState","getState","keplerGl","_props$mint","mint","mapboxApiAccessToken","mapboxApiUrl","mapStylesReplaceDefault","initialUiState","prevId","useDispatch","registerEntry","getApplicationConfig","plugins","_ref","_asyncToGenerator2","_regenerator","mark","_callee","plugin","wrap","_callee$","_context","prev","next","init","stop","_x","deleteEntry","renameEntry","stateSelector","useMemo","keplerState","Console","error","forwardDispatch","forwardTo","createElement","_extends2","selector","allDependencies","flattenDeps","appInjector","reduce","inj","factory","provide","injector","injectComponents","recipes","undefined","provideRecipesToInjector","InjectedContainer","_default"],"sources":["../src/container.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useRef, ComponentType, Dispatch, useEffect, useMemo} from 'react';\nimport {connect, ConnectedProps, useDispatch} from 'react-redux';\n\nimport {console as Console} from 'global/window';\nimport {injector, provideRecipesToInjector, flattenDeps} from './injector';\nimport KeplerGlFactory from './kepler-gl';\nimport {registerEntry, deleteEntry, renameEntry, forwardTo} from '@kepler.gl/actions';\nimport {KeplerGlState} from '@kepler.gl/reducers';\nimport {getApplicationConfig} from '@kepler.gl/utils';\n\nexport const ERROR_MSG = {\n  noState:\n    `kepler.gl state does not 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\nconst mapStateToProps = (state: any, props: ContainerProps) => ({state, ...props});\nconst dispatchToProps = (dispatch: Dispatch<any>) => ({dispatch});\nconst connector = connect(mapStateToProps, dispatchToProps);\n\ntype ContainerProps = {\n  id: string;\n  mapboxApiAccessToken: string;\n  mapboxApiUrl?: string;\n  mapStylesReplaceDefault?: boolean;\n  initialUiState?: object;\n  width: number;\n  mint?: boolean;\n  getState: (state: any) => KeplerGlState;\n};\n\ntype PropsFromRedux = ConnectedProps<typeof connector> & ContainerProps;\n\nContainerFactory.deps = [KeplerGlFactory];\n\nexport function ContainerFactory(\n  KeplerGl: ReturnType<typeof KeplerGlFactory>\n): ComponentType<PropsFromRedux> {\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    * @param {object} props.initialUiState - _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\n  function usePreviousId(value) {\n    const ref = useRef();\n    useEffect(() => {\n      ref.current = value;\n    });\n    return ref.current;\n  }\n\n  const Container: React.FC<PropsFromRedux> = props => {\n    const {\n      // default id and address if not provided\n      id = 'map',\n      getState = state => state.keplerGl,\n      mint = true,\n      mapboxApiAccessToken,\n      mapboxApiUrl,\n      mapStylesReplaceDefault,\n      initialUiState,\n      state\n    } = props;\n    const prevId = usePreviousId(id);\n    const dispatch = useDispatch();\n\n    useEffect(() => {\n      // add a new entry to reducer\n      dispatch(\n        registerEntry({\n          id,\n          mint,\n          mapboxApiAccessToken,\n          mapboxApiUrl,\n          mapStylesReplaceDefault,\n          initialUiState\n        })\n      );\n\n      // initialize plugins\n      if (getApplicationConfig().plugins.length) {\n        getApplicationConfig().plugins.forEach(async plugin => {\n          await plugin.init();\n        });\n      }\n\n      // cleanup\n      return () => {\n        if (mint !== false) {\n          // delete entry in reducer\n          dispatch(deleteEntry(id));\n        }\n      };\n    }, [\n      id,\n      dispatch,\n      initialUiState,\n      mapStylesReplaceDefault,\n      mapboxApiAccessToken,\n      mapboxApiUrl,\n      mint\n    ]);\n\n    useEffect(() => {\n      // check if id has changed, if true, copy state over\n      if (prevId && id && prevId !== id) {\n        dispatch(renameEntry(prevId, id));\n      }\n    }, [dispatch, prevId, id]);\n\n    const stateSelector = useMemo(\n      () => keplerState => {\n        if (!getState(keplerState)) {\n          // log error\n          Console.error(ERROR_MSG.noState);\n\n          return null;\n        }\n        return getState(keplerState)[id];\n      },\n      [id, getState]\n    );\n    const forwardDispatch = useMemo(() => forwardTo(id, dispatch), [id, dispatch]);\n\n    // const selector = getSelector(id, getState);\n\n    if (!stateSelector || !stateSelector(state)) {\n      // instance state hasn't been mounted yet\n      return <div />;\n    }\n\n    return <KeplerGl {...props} id={id} selector={stateSelector} dispatch={forwardDispatch} />;\n  };\n\n  return connector(Container);\n}\n\nconst allDependencies = flattenDeps([], ContainerFactory);\n\n// provide all dependencies to appInjector\nexport const appInjector = allDependencies.reduce(\n  (inj, factory) => inj.provide(factory, factory),\n  injector()\n);\n\n// Helper to inject custom components and return kepler.gl container\nexport function injectComponents(recipes = []) {\n  return provideRecipesToInjector(recipes, appInjector).get(ContainerFactory);\n}\n\nconst InjectedContainer = appInjector.get(ContainerFactory);\n\nexport default InjectedContainer;\n"],"mappings":"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","ignoreList":[]}