Files
ncd-fe/packages/pl-fe/src/features/admin/moderation-log.tsx
marcin mikołajczak 076b16d751 pl-fe: Replace virtuoso with tanstack virtual for scrollable list
Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
2024-09-19 00:55:53 +02:00

72 lines
1.9 KiB
TypeScript

import React from 'react';
import { defineMessages, FormattedDate, useIntl } from 'react-intl';
import { useModerationLog } from 'pl-fe/api/hooks/admin';
import ScrollableList from 'pl-fe/components/scrollable-list';
import { Column, Stack, Text } from 'pl-fe/components/ui';
import type { AdminModerationLogEntry } from 'pl-api';
const messages = defineMessages({
heading: { id: 'column.admin.moderation_log', defaultMessage: 'Moderation log' },
emptyMessage: { id: 'admin.moderation_log.empty_message', defaultMessage: 'You have not performed any moderation actions yet. When you do, a history will be shown here.' },
});
const ModerationLog = () => {
const intl = useIntl();
const {
data,
hasNextPage,
isLoading,
fetchNextPage,
} = useModerationLog();
const showLoading = isLoading && data.length === 0;
const handleLoadMore = () => {
fetchNextPage();
};
return (
<Column label={intl.formatMessage(messages.heading)}>
<ScrollableList
isLoading={isLoading}
showLoading={showLoading}
emptyMessage={intl.formatMessage(messages.emptyMessage)}
hasMore={hasNextPage}
onLoadMore={handleLoadMore}
listClassName='divide-y divide-solid divide-gray-200 dark:divide-gray-800'
>
{data.map(item => item && (
<LogItem key={item.id} log={item} />
))}
</ScrollableList>
</Column>
);
};
interface ILogItem {
log: AdminModerationLogEntry;
}
const LogItem: React.FC<ILogItem> = ({ log }) => (
<Stack space={2} className='p-4'>
<Text>{log.message}</Text>
<Text theme='muted' size='xs'>
<FormattedDate
value={new Date(log.time * 1000)}
hour12
year='numeric'
month='short'
day='2-digit'
hour='numeric'
minute='2-digit'
/>
</Text>
</Stack>
);
export { ModerationLog as default };