From 5055cc517b81f2215de64d4c02af8fc5de1d4c7d Mon Sep 17 00:00:00 2001 From: Vladyslav Palyvoda Date: Wed, 20 Nov 2024 15:04:27 +0200 Subject: [PATCH] fix: Component crash, tekton 404 pages (#494) --- .../providers/DynamicData/provider.tsx | 7 ++++--- .../pages/pipeline-details/view.tsx | 19 ++++++++++++++----- .../configuration/pages/task-details/view.tsx | 19 ++++++++++++++----- 3 files changed, 32 insertions(+), 13 deletions(-) diff --git a/src/pages/component-details/providers/DynamicData/provider.tsx b/src/pages/component-details/providers/DynamicData/provider.tsx index 4288b34c9..3906095b2 100644 --- a/src/pages/component-details/providers/DynamicData/provider.tsx +++ b/src/pages/component-details/providers/DynamicData/provider.tsx @@ -41,9 +41,10 @@ export const DynamicDataContextProvider: React.FC = ({ children }) => { labelSelector: `${CODEBASE_BRANCH_LABEL_SELECTOR_CODEBASE_NAME}=${name}`, }); - const sortedCodebaseBranches = codebaseBranches?.sort((a) => - isDefaultBranch(component, a) ? -1 : 1 - ); + const sortedCodebaseBranches = + component === null + ? null + : codebaseBranches?.sort((a) => (isDefaultBranch(component, a) ? -1 : 1)); const DataContextValue = React.useMemo( () => ({ diff --git a/src/pages/configuration/pages/pipeline-details/view.tsx b/src/pages/configuration/pages/pipeline-details/view.tsx index a33209061..e8eee9edb 100644 --- a/src/pages/configuration/pages/pipeline-details/view.tsx +++ b/src/pages/configuration/pages/pipeline-details/view.tsx @@ -1,5 +1,6 @@ import React from 'react'; import { useParams } from 'react-router-dom'; +import { ErrorContent } from '../../../../components/ErrorContent'; import { LoadingWrapper } from '../../../../components/LoadingWrapper'; import { PageWrapper } from '../../../../components/PageWrapper'; import { Section } from '../../../../components/Section'; @@ -18,6 +19,18 @@ export const PageView = () => { const { activeTab, handleChangeTab } = useTabsContext(); + const renderPageContent = React.useCallback(() => { + if (error) { + return ; + } + + return ( + + + + ); + }, [activeTab, error, handleChangeTab, item, tabs]); + return ( { }, ]} > -
- - - -
+
{renderPageContent()}
); }; diff --git a/src/pages/configuration/pages/task-details/view.tsx b/src/pages/configuration/pages/task-details/view.tsx index 6dca376e8..dcee6a2af 100644 --- a/src/pages/configuration/pages/task-details/view.tsx +++ b/src/pages/configuration/pages/task-details/view.tsx @@ -1,5 +1,6 @@ import React from 'react'; import { useParams } from 'react-router-dom'; +import { ErrorContent } from '../../../../components/ErrorContent'; import { LoadingWrapper } from '../../../../components/LoadingWrapper'; import { PageWrapper } from '../../../../components/PageWrapper'; import { Section } from '../../../../components/Section'; @@ -17,6 +18,18 @@ export const PageView = () => { const tabs = useTabs({ task: item }); const { activeTab, handleChangeTab } = useTabsContext(); + const renderPageContent = React.useCallback(() => { + if (error) { + return ; + } + + return ( + + + + ); + }, [activeTab, error, handleChangeTab, item, tabs]); + return ( { }, ]} > -
- - - -
+
{renderPageContent()}
); };