import React, { useEffect, useState } from 'react'; import Spinner from '@/components/elements/Spinner'; import getServerBackups, { ServerBackup } from '@/api/server/backups/getServerBackups'; import useServer from '@/plugins/useServer'; import useFlash from '@/plugins/useFlash'; import { httpErrorToHuman } from '@/api/http'; import Can from '@/components/elements/Can'; import CreateBackupButton from '@/components/server/backups/CreateBackupButton'; import FlashMessageRender from '@/components/FlashMessageRender'; import BackupRow from '@/components/server/backups/BackupRow'; export default () => { const { uuid } = useServer(); const { addError, clearFlashes } = useFlash(); const [ loading, setLoading ] = useState(true); const [ backups, setBackups ] = useState([]); useEffect(() => { clearFlashes('backups'); getServerBackups(uuid) .then(data => { setBackups(data.items); }) .catch(error => { console.error(error); addError({ key: 'backups', message: httpErrorToHuman(error) }); }) .then(() => setLoading(false)); }, []); if (loading) { return ; } return (
{!backups.length ?

There are no backups stored for this server.

:
{backups.map((backup, index) => )}
}
setBackups(s => [...s, backup])} />
); };