2022-06-09 11:56:14 -07:00
|
|
|
import React, { useEffect, useState } from 'react';
|
|
|
|
import { defineMessages, useIntl } from 'react-intl';
|
|
|
|
|
2022-06-10 10:56:22 -07:00
|
|
|
import { fetchBackups, createBackup } from 'soapbox/actions/backups';
|
2022-11-15 08:00:49 -08:00
|
|
|
import ScrollableList from 'soapbox/components/scrollable-list';
|
2023-01-11 15:25:25 -08:00
|
|
|
import { Button, Column, FormActions, Text } from 'soapbox/components/ui';
|
2022-06-09 11:56:14 -07:00
|
|
|
import { useAppDispatch, useAppSelector } from 'soapbox/hooks';
|
|
|
|
|
|
|
|
const messages = defineMessages({
|
|
|
|
heading: { id: 'column.backups', defaultMessage: 'Backups' },
|
|
|
|
create: { id: 'backups.actions.create', defaultMessage: 'Create backup' },
|
|
|
|
emptyMessage: { id: 'backups.empty_message', defaultMessage: 'No backups found. {action}' },
|
|
|
|
emptyMessageAction: { id: 'backups.empty_message.action', defaultMessage: 'Create one now?' },
|
|
|
|
pending: { id: 'backups.pending', defaultMessage: 'Pending' },
|
|
|
|
});
|
|
|
|
|
|
|
|
const Backups = () => {
|
|
|
|
const intl = useIntl();
|
|
|
|
const dispatch = useAppDispatch();
|
|
|
|
|
2022-06-20 10:59:51 -07:00
|
|
|
const backups = useAppSelector((state) => state.backups.toList().sortBy((backup) => backup.inserted_at));
|
2022-06-09 11:56:14 -07:00
|
|
|
|
|
|
|
const [isLoading, setIsLoading] = useState(true);
|
|
|
|
|
2023-01-11 15:25:25 -08:00
|
|
|
const handleCreateBackup: React.MouseEventHandler = e => {
|
2022-06-09 11:56:14 -07:00
|
|
|
dispatch(createBackup());
|
|
|
|
e.preventDefault();
|
|
|
|
};
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
dispatch(fetchBackups()).then(() => {
|
2023-01-11 15:25:25 -08:00
|
|
|
setIsLoading(false);
|
2022-06-09 11:56:14 -07:00
|
|
|
}).catch(() => {});
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
const showLoading = isLoading && backups.count() === 0;
|
|
|
|
|
|
|
|
const emptyMessageAction = (
|
|
|
|
<a href='#' onClick={handleCreateBackup}>
|
2023-01-11 15:25:25 -08:00
|
|
|
<Text tag='span' theme='primary' size='sm' className='hover:underline'>
|
|
|
|
{intl.formatMessage(messages.emptyMessageAction)}
|
|
|
|
</Text>
|
2022-06-09 11:56:14 -07:00
|
|
|
</a>
|
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
2023-01-11 15:25:25 -08:00
|
|
|
<Column label={intl.formatMessage(messages.heading)}>
|
2022-06-09 11:56:14 -07:00
|
|
|
<ScrollableList
|
|
|
|
isLoading={isLoading}
|
|
|
|
showLoading={showLoading}
|
|
|
|
scrollKey='backups'
|
|
|
|
emptyMessage={intl.formatMessage(messages.emptyMessage, { action: emptyMessageAction })}
|
|
|
|
>
|
|
|
|
{backups.map((backup) => (
|
|
|
|
<div
|
2023-01-11 15:25:25 -08:00
|
|
|
className='p-4'
|
2022-06-20 10:59:51 -07:00
|
|
|
key={backup.id}
|
2022-06-09 11:56:14 -07:00
|
|
|
>
|
2022-06-20 10:59:51 -07:00
|
|
|
{backup.processed
|
|
|
|
? <a href={backup.url} target='_blank'>{backup.inserted_at}</a>
|
2023-01-11 15:25:25 -08:00
|
|
|
: <Text theme='subtle'>{intl.formatMessage(messages.pending)}: {backup.inserted_at}</Text>
|
2022-06-09 11:56:14 -07:00
|
|
|
}
|
|
|
|
</div>
|
|
|
|
))}
|
|
|
|
</ScrollableList>
|
2023-01-11 15:25:25 -08:00
|
|
|
|
|
|
|
<FormActions>
|
|
|
|
<Button theme='primary' disabled={isLoading} onClick={handleCreateBackup}>
|
|
|
|
{intl.formatMessage(messages.create)}
|
|
|
|
</Button>
|
|
|
|
</FormActions>
|
2022-06-09 11:56:14 -07:00
|
|
|
</Column>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Backups;
|