@finos/legend-application-marketplace
Version:
Legend Marketplace application core
35 lines • 2.32 kB
JavaScript
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
/**
* Copyright (c) 2020-present, Goldman Sachs
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { observer } from 'mobx-react-lite';
import { useLegendMarketplaceProductViewerStore, withLegendMarketplaceProductViewerStore, } from '../../../application/providers/LegendMarketplaceProductViewerStoreProvider.js';
import { useEffect } from 'react';
import { CubesLoadingIndicator, CubesLoadingIndicatorIcon, } from '@finos/legend-art';
import { LEGEND_MARKETPLACE_ROUTE_PATTERN_TOKEN, } from '../../../__lib__/LegendMarketplaceNavigation.js';
import { useParams } from '@finos/legend-application/browser';
import { guaranteeNonNullable } from '@finos/legend-shared';
import { LegendMarketplacePage } from '../../LegendMarketplacePage.js';
import { ProductViewer } from '@finos/legend-extension-dsl-data-product';
export const TerminalProduct = withLegendMarketplaceProductViewerStore(observer(() => {
const productViewerStore = useLegendMarketplaceProductViewerStore();
const params = useParams();
const terminalId = guaranteeNonNullable(params[LEGEND_MARKETPLACE_ROUTE_PATTERN_TOKEN.TERMINAL_ID]);
useEffect(() => {
productViewerStore.initWithTerminal(terminalId);
}, [productViewerStore, terminalId]);
return (_jsxs(LegendMarketplacePage, { className: "legend-marketplace-terminal-data-product", children: [_jsx(CubesLoadingIndicator, { isLoading: productViewerStore.loadingProductState.isInProgress, children: _jsx(CubesLoadingIndicatorIcon, {}) }), productViewerStore.terminalProductViewer && (_jsx(ProductViewer, { productViewerState: productViewerStore.terminalProductViewer, productDataAccessState: productViewerStore.terminalProductDataAccess }))] }));
}));
//# sourceMappingURL=TerminalProduct.js.map