UNPKG

@joeldodge/extension-sdk-react

Version:
133 lines (106 loc) 6.59 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ExtensionConnector = void 0; var _isEqual = _interopRequireDefault(require("lodash/isEqual")); var _react = _interopRequireWildcard(require("react")); var _reactRouterDom = require("react-router-dom"); var _extensionSdk = require("@joeldodge/extension-sdk"); var _ErrorMessage = require("../ErrorMessage"); var _RouteChangeListener = require("../RouteChangeListener"); var _get_initial_route_entries = require("../utils/get_initial_route_entries"); var _setup_close_popovers = require("../utils/setup_close_popovers"); function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } 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) { _defineProperty(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; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } var ExtensionConnector = (_ref) => { var { contextData, updateContextData, connectedCallback, unloadedCallback, onPathnameChange, onRouteChange, hostTracksRoute = true, loadingComponent, requiredLookerVersion, chattyTimeout, children } = _ref; var [initialRouteData, setInitialRouteData] = (0, _react.useState)(); var [hostRouteData, setHostRouteData] = (0, _react.useState)({ route: '' }); var [initializing, setInitializing] = (0, _react.useState)(true); var [initializeError, setInitializeError] = (0, _react.useState)(); var setInitialRouteAndRouteState = (route, routeState) => { if (hostTracksRoute) { setInitialRouteData({ route, routeState }); } }; var hostChangedRoute = (_route, routeState) => { var route = _route.startsWith('/') ? _route : '/' + _route; if (route !== hostRouteData.route || !(0, _isEqual.default)(routeState, hostRouteData.routeState)) { setHostRouteData({ route, routeState }); updateContextData(_objectSpread(_objectSpread({}, contextData), {}, { route, routeState })); } }; _react.default.useEffect(() => { var initialize = function () { var _ref2 = _asyncToGenerator(function* () { try { var extensionHost = yield (0, _extensionSdk.connectExtensionHost)({ setInitialRoute: setInitialRouteAndRouteState, requiredLookerVersion, hostChangedRoute, chattyTimeout }); connectedCallback(extensionHost); setInitializing(false); } catch (error) { console.error(error); setInitializeError(error.message || 'Extension failed to initialize.'); setInitializing(false); } }); return function initialize() { return _ref2.apply(this, arguments); }; }(); initialize(); return () => { unloadedCallback(); }; }, []); _react.default.useEffect(() => { return initializing ? undefined : (0, _setup_close_popovers.setupClosePopoversListener)(contextData.extensionSDK); }, [initializing]); return _react.default.createElement(_react.default.Fragment, null, initializing ? loadingComponent : _react.default.createElement(_react.default.Fragment, null, initializeError ? _react.default.createElement(_ErrorMessage.ErrorMessage, { errorMessage: initializeError }) : _react.default.createElement(_react.default.Fragment, null, hostTracksRoute ? _react.default.createElement(_reactRouterDom.MemoryRouter, { initialEntries: (0, _get_initial_route_entries.getInitialRouteEntries)(initialRouteData) }, _react.default.createElement(_RouteChangeListener.RouteChangeListener, { onRouteChange: onRouteChange, onPathnameChange: onPathnameChange, extensionHost: contextData.extensionSDK, hostRoute: hostRouteData.route, hostRouteState: hostRouteData.routeState }), children) : _react.default.createElement(_react.default.Fragment, null, children)))); }; exports.ExtensionConnector = ExtensionConnector; //# sourceMappingURL=ExtensionConnector.js.map