@joeldodge/extension-sdk-react
Version:
Looker Extension SDK for React
133 lines (106 loc) • 6.59 kB
JavaScript
;
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