Skip to content

Commit

Permalink
Update
Browse files Browse the repository at this point in the history
  • Loading branch information
dpanshug committed Sep 7, 2023
1 parent 8323422 commit db8e51f
Show file tree
Hide file tree
Showing 5 changed files with 141 additions and 116 deletions.
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
import * as React from 'react';
import { Divider, PageSection, Stack, StackItem } from '@patternfly/react-core';
import { PageSection, Stack, StackItem } from '@patternfly/react-core';
import GenericSidebar from '~/components/GenericSidebar';
import { useAppContext } from '~/app/AppContext';
import ServingRuntimeList from '~/pages/modelServing/screens/projects/ServingRuntimeList';
import { ProjectDetailsContext } from '~/pages/projects/ProjectDetailsContext';
import { featureFlagEnabled } from '~/utilities/utils';
import PipelinesSection from '~/pages/projects/screens/detail/pipelines/PipelinesSection';
import usePipelines from '~/concepts/pipelines/apiHooks/usePipelines';
import NotebooksList from './notebooks/NotebookList';
import { ProjectSectionID } from './types';
import StorageList from './storage/StorageList';
Expand All @@ -17,21 +15,10 @@ import useCheckLogoutParams from './useCheckLogoutParams';
type SectionType = {
id: ProjectSectionID;
component: React.ReactNode;
isEmpty: boolean;
};

const ProjectDetailsComponents: React.FC = () => {
const { dashboardConfig } = useAppContext();
const {
notebooks: { data: notebookStates, loaded: notebookStatesLoaded },
pvcs: { data: pvcs, loaded: pvcsLoaded },
dataConnections: { data: connections, loaded: connectionsLoaded },
servingRuntimes: { data: modelServers, loaded: modelServersLoaded },
} = React.useContext(ProjectDetailsContext);

// Limit set to 1 for checking pipeline emptiness
const [pipelines, pipelinesLoaded] = usePipelines(1);

const modelServingEnabled = featureFlagEnabled(
dashboardConfig.spec.dashboardConfig.disableModelServing,
);
Expand All @@ -44,24 +31,20 @@ const ProjectDetailsComponents: React.FC = () => {
{
id: ProjectSectionID.WORKBENCHES,
component: <NotebooksList />,
isEmpty: notebookStatesLoaded && notebookStates.length === 0,
},
{
id: ProjectSectionID.CLUSTER_STORAGES,
component: <StorageList />,
isEmpty: pvcsLoaded && pvcs.length === 0,
},
{
id: ProjectSectionID.DATA_CONNECTIONS,
component: <DataConnectionsList />,
isEmpty: connectionsLoaded && connections.length === 0,
},
...(pipelinesEnabled
? [
{
id: ProjectSectionID.PIPELINES,
component: <PipelinesSection />,
isEmpty: pipelinesLoaded && pipelines.length === 0,
},
]
: []),
Expand All @@ -70,7 +53,6 @@ const ProjectDetailsComponents: React.FC = () => {
{
id: ProjectSectionID.MODEL_SERVER,
component: <ServingRuntimeList />,
isEmpty: modelServersLoaded && modelServers.length === 0,
},
]
: []),
Expand All @@ -84,7 +66,7 @@ const ProjectDetailsComponents: React.FC = () => {
maxWidth={175}
>
<Stack hasGutter>
{sections.map(({ id, component, isEmpty }, index) => (
{sections.map(({ id, component }) => (
<React.Fragment key={id}>
<StackItem
id={id}
Expand All @@ -93,9 +75,6 @@ const ProjectDetailsComponents: React.FC = () => {
>
{component}
</StackItem>
{index !== sections.length - 1 && isEmpty && (
<Divider data-id="details-page-section-divider" />
)}
</React.Fragment>
))}
</Stack>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as React from 'react';
import { Button } from '@patternfly/react-core';
import { Button, Divider, Stack, StackItem } from '@patternfly/react-core';
import EmptyDetailsList from '~/pages/projects/screens/detail/EmptyDetailsList';
import { ProjectSectionID } from '~/pages/projects/screens/detail/types';
import DetailsSection from '~/pages/projects/screens/detail/DetailsSection';
Expand All @@ -15,32 +15,43 @@ const DataConnectionsList: React.FC = () => {
} = React.useContext(ProjectDetailsContext);
const [open, setOpen] = React.useState(false);

const emptyDataConnections = connections.length === 0;

return (
<>
<DetailsSection
id={ProjectSectionID.DATA_CONNECTIONS}
title={ProjectSectionTitles[ProjectSectionID.DATA_CONNECTIONS] || ''}
actions={[
<Button
key={`action-${ProjectSectionID.DATA_CONNECTIONS}`}
variant="secondary"
onClick={() => setOpen(true)}
<Stack>
<StackItem>
<DetailsSection
id={ProjectSectionID.DATA_CONNECTIONS}
title={ProjectSectionTitles[ProjectSectionID.DATA_CONNECTIONS] || ''}
actions={[
<Button
key={`action-${ProjectSectionID.DATA_CONNECTIONS}`}
variant="secondary"
onClick={() => setOpen(true)}
>
Add data connection
</Button>,
]}
isLoading={!loaded}
isEmpty={emptyDataConnections}
loadError={error}
emptyState={
<EmptyDetailsList
title="No data connections"
description="To get started, add data to your project."
/>
}
>
Add data connection
</Button>,
]}
isLoading={!loaded}
isEmpty={connections.length === 0}
loadError={error}
emptyState={
<EmptyDetailsList
title="No data connections"
description="To get started, add data to your project."
/>
}
>
<DataConnectionsTable connections={connections} refreshData={refreshAllProjectData} />
</DetailsSection>
<DataConnectionsTable connections={connections} refreshData={refreshAllProjectData} />
</DetailsSection>
</StackItem>
</Stack>
{emptyDataConnections && (
<StackItem>
<Divider data-id="details-page-section-divider" />
</StackItem>
)}
<ManageDataConnectionModal
isOpen={open}
onClose={(submitted) => {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as React from 'react';
import { Button } from '@patternfly/react-core';
import { Button, Divider, Stack, StackItem } from '@patternfly/react-core';
import { useNavigate } from 'react-router-dom';
import EmptyDetailsList from '~/pages/projects/screens/detail/EmptyDetailsList';
import { ProjectSectionID } from '~/pages/projects/screens/detail/types';
Expand All @@ -17,6 +17,7 @@ const NotebookList: React.FC = () => {
} = React.useContext(ProjectDetailsContext);
const navigate = useNavigate();
const projectName = currentProject.metadata.name;
const emptyNotebooks = notebookStates.length === 0;

React.useEffect(() => {
let interval: ReturnType<typeof setInterval>;
Expand All @@ -27,30 +28,39 @@ const NotebookList: React.FC = () => {
}, [notebookStates, refreshNotebooks]);

return (
<DetailsSection
id={ProjectSectionID.WORKBENCHES}
title={ProjectSectionTitles[ProjectSectionID.WORKBENCHES] || ''}
actions={[
<Button
key={`action-${ProjectSectionID.WORKBENCHES}`}
onClick={() => navigate(`/projects/${projectName}/spawner`)}
variant="secondary"
<Stack>
<StackItem>
<DetailsSection
id={ProjectSectionID.WORKBENCHES}
title={ProjectSectionTitles[ProjectSectionID.WORKBENCHES] || ''}
actions={[
<Button
key={`action-${ProjectSectionID.WORKBENCHES}`}
onClick={() => navigate(`/projects/${projectName}/spawner`)}
variant="secondary"
>
Create workbench
</Button>,
]}
isLoading={!loaded}
loadError={loadError}
isEmpty={emptyNotebooks}
emptyState={
<EmptyDetailsList
title="No workbenches"
description="To get started, create a workbench."
/>
}
>
Create workbench
</Button>,
]}
isLoading={!loaded}
loadError={loadError}
isEmpty={notebookStates.length === 0}
emptyState={
<EmptyDetailsList
title="No workbenches"
description="To get started, create a workbench."
/>
}
>
<NotebookTable notebookStates={notebookStates} refresh={refresh} />
</DetailsSection>
<NotebookTable notebookStates={notebookStates} refresh={refresh} />
</DetailsSection>
</StackItem>
{emptyNotebooks && (
<StackItem>
<Divider data-id="details-page-section-divider" />
</StackItem>
)}
</Stack>
);
};

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import * as React from 'react';
import { Divider, Stack, StackItem } from '@patternfly/react-core';
import { ProjectSectionID } from '~/pages/projects/screens/detail/types';
import { ProjectSectionTitles } from '~/pages/projects/screens/detail/const';
import DetailsSection from '~/pages/projects/screens/detail/DetailsSection';
Expand All @@ -7,35 +8,48 @@ import NoPipelineServer from '~/concepts/pipelines/NoPipelineServer';
import ImportPipelineButton from '~/concepts/pipelines/content/import/ImportPipelineButton';
import PipelinesList from '~/pages/projects/screens/detail/pipelines/PipelinesList';
import EnsureAPIAvailability from '~/concepts/pipelines/EnsureAPIAvailability';
import usePipelines from '~/concepts/pipelines/apiHooks/usePipelines';

const PipelinesSection: React.FC = () => {
const {
pipelinesServer: { initializing, installed, timedOut },
} = usePipelinesAPI();

const [pipelines] = usePipelines(1);
const pipelinesEmpty = !installed || pipelines.length === 0;

return (
<DetailsSection
id={ProjectSectionID.PIPELINES}
title={ProjectSectionTitles[ProjectSectionID.PIPELINES]}
actions={[
<ImportPipelineButton
isDisabled={!installed}
key={`action-${ProjectSectionID.PIPELINES}`}
variant="secondary"
/>,
]}
isLoading={initializing}
isEmpty={!installed}
emptyState={<NoPipelineServer variant="secondary" />}
>
{timedOut ? (
<PipelineServerTimedOut />
) : (
<EnsureAPIAvailability>
<PipelinesList />
</EnsureAPIAvailability>
<Stack>
<StackItem>
<DetailsSection
id={ProjectSectionID.PIPELINES}
title={ProjectSectionTitles[ProjectSectionID.PIPELINES]}
actions={[
<ImportPipelineButton
isDisabled={!installed}
key={`action-${ProjectSectionID.PIPELINES}`}
variant="secondary"
/>,
]}
isLoading={initializing}
isEmpty={!installed}
emptyState={<NoPipelineServer variant="secondary" />}
>
{timedOut ? (
<PipelineServerTimedOut />
) : (
<EnsureAPIAvailability>
<PipelinesList />
</EnsureAPIAvailability>
)}
</DetailsSection>
</StackItem>
{pipelinesEmpty && (
<StackItem>
<Divider data-id="details-page-section-divider" />
</StackItem>
)}
</DetailsSection>
</Stack>
);
};

Expand Down
59 changes: 35 additions & 24 deletions frontend/src/pages/projects/screens/detail/storage/StorageList.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as React from 'react';
import { Button } from '@patternfly/react-core';
import { Button, Divider, Stack, StackItem } from '@patternfly/react-core';
import EmptyDetailsList from '~/pages/projects/screens/detail/EmptyDetailsList';
import DetailsSection from '~/pages/projects/screens/detail/DetailsSection';
import { ProjectSectionID } from '~/pages/projects/screens/detail/types';
Expand All @@ -15,32 +15,43 @@ const StorageList: React.FC = () => {
refreshAllProjectData: refresh,
} = React.useContext(ProjectDetailsContext);

const emptyPvsc = pvcs.length === 0;

return (
<>
<DetailsSection
id={ProjectSectionID.CLUSTER_STORAGES}
title={ProjectSectionTitles[ProjectSectionID.CLUSTER_STORAGES] || ''}
actions={[
<Button
onClick={() => setOpen(true)}
key={`action-${ProjectSectionID.CLUSTER_STORAGES}`}
variant="secondary"
<Stack>
<StackItem>
<DetailsSection
id={ProjectSectionID.CLUSTER_STORAGES}
title={ProjectSectionTitles[ProjectSectionID.CLUSTER_STORAGES] || ''}
actions={[
<Button
onClick={() => setOpen(true)}
key={`action-${ProjectSectionID.CLUSTER_STORAGES}`}
variant="secondary"
>
Add cluster storage
</Button>,
]}
isLoading={!loaded}
isEmpty={emptyPvsc}
loadError={loadError}
emptyState={
<EmptyDetailsList
title="No storage"
description="To get started, add existing or create new cluster storage."
/>
}
>
Add cluster storage
</Button>,
]}
isLoading={!loaded}
isEmpty={pvcs.length === 0}
loadError={loadError}
emptyState={
<EmptyDetailsList
title="No storage"
description="To get started, add existing or create new cluster storage."
/>
}
>
<StorageTable pvcs={pvcs} refresh={refresh} onAddPVC={() => setOpen(true)} />
</DetailsSection>
<StorageTable pvcs={pvcs} refresh={refresh} onAddPVC={() => setOpen(true)} />
</DetailsSection>
</StackItem>
{emptyPvsc && (
<StackItem>
<Divider data-id="details-page-section-divider" />
</StackItem>
)}
</Stack>
<ManageStorageModal
isOpen={isOpen}
onClose={(submit: boolean) => {
Expand Down

0 comments on commit db8e51f

Please sign in to comment.