summaryrefslogtreecommitdiff
path: root/lib/pq/pq-criteria/pq-table-toolbar-actions.tsx
blob: f168b83d80ba9c18a498976020afc0898ac39968 (plain)
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
"use client"

import * as React from "react"
import { type Table } from "@tanstack/react-table"
// import { Download, FileDown } from "lucide-react"
// import { toast } from "sonner"

// import { exportTableToExcel } from "@/lib/export"
// import { Button } from "@/components/ui/button"
// import {
//   DropdownMenu,
//   DropdownMenuContent,
//   DropdownMenuItem,
//   DropdownMenuTrigger,
// } from "@/components/ui/dropdown-menu"

import { DeletePqsDialog } from "./delete-pqs-dialog"
import { AddPqDialog } from "./add-pq-dialog"
import { PqCriterias } from "@/db/schema/pq"
// import { ImportPqButton } from "./import-pq-button"
// import { exportPqTemplate } from "./pq-excel-template"

interface PqTableToolbarActionsProps {
  table: Table<PqCriterias>
  pqListId: number
}

export function PqTableToolbarActions({ 
  table, 
  pqListId
}: PqTableToolbarActionsProps) {
  // const [refreshKey, setRefreshKey] = React.useState(0)
  
  // // Import 성공 후 테이블 갱신
  // const handleImportSuccess = () => {
  //   setRefreshKey(prev => prev + 1)
  // }
  
  return (
    <div className="flex items-center gap-2">
      {table.getFilteredSelectedRowModel().rows.length > 0 ? (
        <DeletePqsDialog
          pqs={table
            .getFilteredSelectedRowModel()
            .rows.map((row) => row.original)}
          onSuccess={() => table.toggleAllRowsSelected(false)}
        />
      ) : null}
      
      <AddPqDialog pqListId={pqListId} />
      
      {/* Import 버튼 */}
      {/* <ImportPqButton 
        pqListId={pqListId} 
        onSuccess={handleImportSuccess} 
      /> */}
      
      {/* Export 드롭다운 메뉴 */}
      {/* <DropdownMenu>
        <DropdownMenuTrigger asChild>
          <Button variant="outline" size="sm" className="gap-2">
            <Download className="size-4" aria-hidden="true" />
            <span className="hidden sm:inline">Export</span>
          </Button>
        </DropdownMenuTrigger>
        <DropdownMenuContent align="end">
          <DropdownMenuItem
            onClick={() =>
              exportTableToExcel(table, {
                filename: `pq-list-${pqListId}-criteria`,
                excludeColumns: ["select", "actions"],
              })
            }
          >
            <FileDown className="mr-2 h-4 w-4" />
            <span>현재 데이터 내보내기</span>
          </DropdownMenuItem>
          <DropdownMenuItem onClick={() => exportPqTemplate()}>
            <FileDown className="mr-2 h-4 w-4" />
            <span>템플릿 다운로드</span>
          </DropdownMenuItem>
        </DropdownMenuContent>
      </DropdownMenu> */}
    </div>
  )
}