-
Notifications
You must be signed in to change notification settings - Fork 21
/
PersistentVolumeClaimSelect.tsx
56 lines (48 loc) · 1.54 KB
/
PersistentVolumeClaimSelect.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
import * as React from 'react';
import { PersistentVolumeClainSelectSkeleton } from './PersistentVolumeClainSelectSkeleton';
import { PersistentVolumeSelectName } from './PersistentVolumeSelectName';
import { PersistentVolumeSelectProject } from './PersistentVolumeSelectProject';
import { useProjectsAndPVCs } from './utils';
import './PersistentVolumeClaimSelect.scss';
type PersistentVolumeClaimSelectProps = {
pvcNameSelected: string;
projectSelected: string;
selectPVC: (pvcNamespace: string, pvcName?: string) => void;
};
export const PersistentVolumeClaimSelect: React.FC<PersistentVolumeClaimSelectProps> = ({
pvcNameSelected,
projectSelected,
selectPVC,
}) => {
const { projectsNames, filteredPVCNames, projectsLoaded, pvcsLoaded } =
useProjectsAndPVCs(projectSelected);
const onSelectProject = React.useCallback(
(newProject) => {
selectPVC(newProject);
},
[selectPVC],
);
const onPVCSelected = React.useCallback(
(selection) => {
selectPVC(projectSelected, selection);
},
[selectPVC, projectSelected],
);
if (!projectsLoaded) return <PersistentVolumeClainSelectSkeleton />;
return (
<div>
<PersistentVolumeSelectProject
projectsName={projectsNames}
selectedProject={projectSelected}
onChange={onSelectProject}
/>
<PersistentVolumeSelectName
onChange={onPVCSelected}
pvcNameSelected={pvcNameSelected}
pvcNames={filteredPVCNames}
isDisabled={!projectSelected}
isLoading={!pvcsLoaded}
/>
</div>
);
};