import React, { useEffect } from 'react'; import Spinner from '@/components/elements/Spinner'; import useFlash from '@/plugins/useFlash'; 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'; import tw from 'twin.macro'; import getServerBackups from '@/api/swr/getServerBackups'; import { ServerContext } from '@/state/server'; import ServerContentBlock from '@/components/elements/ServerContentBlock'; export default () => { const { clearFlashes, clearAndAddHttpError } = useFlash(); const { data: backups, error, isValidating } = getServerBackups(); const backupLimit = ServerContext.useStoreState(state => state.server.data!.featureLimits.backups); useEffect(() => { if (!error) { clearFlashes('backups'); return; } clearAndAddHttpError({ error, key: 'backups' }); }, [ error ]); if (!backups || (error && isValidating)) { return ; } return ( {!backups.items.length ? There are no backups stored for this server. : {backups.items.map((backup, index) => 0 ? tw`mt-2` : undefined} />)} } {backupLimit === 0 && Backups cannot be created for this server. } {(backupLimit > 0 && backups.items.length > 0) && {backups.items.length} of {backupLimit} backups have been created for this server. } {backupLimit > 0 && backupLimit !== backups.items.length && } ); };
There are no backups stored for this server.
Backups cannot be created for this server.
{backups.items.length} of {backupLimit} backups have been created for this server.