File size: 2,471 Bytes
9853396
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import { ArrowDownIcon, ArrowUpIcon, CaretSortIcon, EyeNoneIcon } from '@radix-ui/react-icons';
import { Column } from '@tanstack/react-table';
import { useTranslation } from 'react-i18next';
import { cn } from '@/lib/utils';
import { Button } from '@/components/ui/button';
import {
  DropdownMenu,
  DropdownMenuContent,
  DropdownMenuItem,
  DropdownMenuSeparator,
  DropdownMenuTrigger,
} from '@/components/ui/dropdown-menu';

interface DataTableColumnHeaderProps<TData, TValue> extends React.HTMLAttributes<HTMLDivElement> {
  column: Column<TData, TValue>;
  title: string;
}

export function DataTableColumnHeader<TData, TValue>({ column, title, className }: DataTableColumnHeaderProps<TData, TValue>) {
  const { t } = useTranslation();

  if (!column.getCanSort()) {
    return <div className={cn(className)}>{title}</div>;
  }

  return (
    <div className={cn('flex items-center space-x-2', className)}>

      <DropdownMenu>

        <DropdownMenuTrigger asChild>

          <Button variant='ghost' size='sm' className='data-[state=open]:bg-accent -ml-3 h-8'>

            <span className='uppercase'>{title}</span>

            {column.getIsSorted() === 'desc' ? (

              <ArrowDownIcon className='ml-2 h-4 w-4' />

            ) : column.getIsSorted() === 'asc' ? (

              <ArrowUpIcon className='ml-2 h-4 w-4' />

            ) : (

              <CaretSortIcon className='ml-2 h-4 w-4' />

            )}

          </Button>

        </DropdownMenuTrigger>

        <DropdownMenuContent align='start'>

          <DropdownMenuItem onClick={() => column.toggleSorting(false)}>

            <ArrowUpIcon className='text-muted-foreground/70 mr-2 h-3.5 w-3.5' />

            {t('common.sort.ascending')}

          </DropdownMenuItem>

          <DropdownMenuItem onClick={() => column.toggleSorting(true)}>

            <ArrowDownIcon className='text-muted-foreground/70 mr-2 h-3.5 w-3.5' />

            {t('common.sort.descending')}

          </DropdownMenuItem>

          {column.getCanHide() && (

            <>

              <DropdownMenuSeparator />

              <DropdownMenuItem onClick={() => column.toggleVisibility(false)}>

                <EyeNoneIcon className='text-muted-foreground/70 mr-2 h-3.5 w-3.5' />

                {t('common.sort.hide')}

              </DropdownMenuItem>

            </>

          )}

        </DropdownMenuContent>

      </DropdownMenu>
    </div>
  );
}