import React, { useEffect, useState } from 'react'; import getServerDatabases from '@/api/server/getServerDatabases'; import { ServerContext } from '@/state/server'; import { httpErrorToHuman } from '@/api/http'; import FlashMessageRender from '@/components/FlashMessageRender'; import DatabaseRow from '@/components/server/databases/DatabaseRow'; import Spinner from '@/components/elements/Spinner'; import { CSSTransition } from 'react-transition-group'; import CreateDatabaseButton from '@/components/server/databases/CreateDatabaseButton'; import Can from '@/components/elements/Can'; import useFlash from '@/plugins/useFlash'; import useServer from '@/plugins/useServer'; export default () => { const { uuid, featureLimits } = useServer(); const { addError, clearFlashes } = useFlash(); const [ loading, setLoading ] = useState(true); const databases = ServerContext.useStoreState(state => state.databases.data); const setDatabases = ServerContext.useStoreActions(state => state.databases.setDatabases); useEffect(() => { setLoading(!databases.length); clearFlashes('databases'); getServerDatabases(uuid) .then(databases => setDatabases(databases)) .catch(error => { console.error(error); addError({ key: 'databases', message: httpErrorToHuman(error) }); }) .then(() => setLoading(false)); }, []); return (
{(!databases.length && loading) ? : <> {databases.length > 0 ? databases.map((database, index) => ( 0 ? 'mt-1' : undefined} /> )) :

{featureLimits.databases > 0 ? `It looks like you have no databases.` : `Databases cannot be created for this server.` }

} {featureLimits.databases > 0 &&
}
}
); };