import { Table } from 'antd'; import format from 'date-fns/format'; import { SortOrder } from 'antd/lib/table/interface'; import { User } from '../types/chat'; import UserPopover from './user-popover'; import BanUserButton from './other/ban-user-button/ban-user-button'; export function formatDisplayDate(date: string | Date) { return format(new Date(date), 'MMM d H:mma'); } export default function UserTable({ data }: UserTableProps) { const columns = [ { title: 'Last Known Display Name', dataIndex: 'displayName', key: 'displayName', // eslint-disable-next-line react/destructuring-assignment render: (displayName: string, user: User) => ( {displayName} ), }, { title: 'Created', dataIndex: 'createdAt', key: 'createdAt', render: (date: Date) => formatDisplayDate(date), sorter: (a: any, b: any) => new Date(a.createdAt).getTime() - new Date(b.createdAt).getTime(), sortDirections: ['descend', 'ascend'] as SortOrder[], }, { title: 'Disabled at', dataIndex: 'disabledAt', key: 'disabledAt', defaultSortOrder: 'descend' as SortOrder, render: (date: Date) => (date ? formatDisplayDate(date) : null), sorter: (a: any, b: any) => new Date(a.disabledAt).getTime() - new Date(b.disabledAt).getTime(), sortDirections: ['descend', 'ascend'] as SortOrder[], }, { title: '', key: 'block', className: 'actions-col', render: (_, user) => , }, ]; return ( ); } interface UserTableProps { data: User[]; }