/**
* VolumesPage — lists Rook-Ceph PersistentVolumes.
*/
import {
Loader,
NameValueTable,
SectionBox,
SectionHeader,
SimpleTable,
StatusLabel,
} from '@kinvolk/headlamp-plugin/lib/CommonComponents';
import React, { useState } from 'react';
import { formatAccessModes, formatAge, phaseToStatus, RookCephPersistentVolume } from '../api/k8s';
import { useRookCephContext } from '../api/RookCephDataContext';
function PVDetail({ pv, onClose }: { pv: RookCephPersistentVolume; onClose: () => void }) {
const attrs = pv.spec.csi?.volumeAttributes ?? {};
return (
{pv.metadata.name}
{pv.status?.phase ?? 'Unknown'}
),
},
{
name: 'Claim',
value: pv.spec.claimRef
? `${pv.spec.claimRef.namespace}/${pv.spec.claimRef.name}`
: '—',
},
{ name: 'Age', value: formatAge(pv.metadata.creationTimestamp) },
]}
/>
({ name: k, value: v ?? '—' })),
]}
/>
);
}
export default function VolumesPage() {
const { persistentVolumes, loading, error } = useRookCephContext();
const [selected, setSelected] = useState(null);
if (loading) return ;
return (
<>
{error && (
{error} }]} />
)}
{persistentVolumes.length === 0 ? (
) : (
(
),
},
{ label: 'Capacity', getter: (pv: RookCephPersistentVolume) => pv.spec.capacity?.storage ?? '—' },
{ label: 'Access Modes', getter: (pv: RookCephPersistentVolume) => formatAccessModes(pv.spec.accessModes) },
{
label: 'Phase',
getter: (pv: RookCephPersistentVolume) => (
{pv.status?.phase ?? 'Unknown'}
),
},
{ label: 'Reclaim', getter: (pv: RookCephPersistentVolume) => pv.spec.persistentVolumeReclaimPolicy ?? '—' },
{ label: 'Pool', getter: (pv: RookCephPersistentVolume) => pv.spec.csi?.volumeAttributes?.['pool'] ?? '—' },
{ label: 'Claim', getter: (pv: RookCephPersistentVolume) => pv.spec.claimRef ? `${pv.spec.claimRef.namespace}/${pv.spec.claimRef.name}` : '—' },
{ label: 'Age', getter: (pv: RookCephPersistentVolume) => formatAge(pv.metadata.creationTimestamp) },
]}
data={persistentVolumes}
/>
)}
{selected && (
<>
setSelected(null)}
/>
setSelected(null)} />
>
)}
>
);
}