/** * 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 (
{ if (e.key === 'Escape') onClose(); }} style={{ position: 'fixed', top: 0, right: 0, bottom: 0, width: '520px', backgroundColor: 'var(--mui-palette-background-paper, #fff)', boxShadow: '-4px 0 16px rgba(0,0,0,0.15)', zIndex: 1300, overflowY: 'auto', padding: '24px', }} >
{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)} /> )} ); }