summaryrefslogtreecommitdiff
path: root/lib/docu-list-rule/combo-box-settings/table/combo-box-options-table-toolbar.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'lib/docu-list-rule/combo-box-settings/table/combo-box-options-table-toolbar.tsx')
-rw-r--r--lib/docu-list-rule/combo-box-settings/table/combo-box-options-table-toolbar.tsx53
1 files changed, 53 insertions, 0 deletions
diff --git a/lib/docu-list-rule/combo-box-settings/table/combo-box-options-table-toolbar.tsx b/lib/docu-list-rule/combo-box-settings/table/combo-box-options-table-toolbar.tsx
new file mode 100644
index 00000000..7318efb8
--- /dev/null
+++ b/lib/docu-list-rule/combo-box-settings/table/combo-box-options-table-toolbar.tsx
@@ -0,0 +1,53 @@
+"use client"
+
+import * as React from "react"
+import { type Table } from "@tanstack/react-table"
+
+import { ComboBoxOptionsAddDialog } from "./combo-box-options-add-dialog"
+import { DeleteComboBoxOptionsDialog } from "./delete-combo-box-options-dialog"
+
+interface ComboBoxOption {
+ id: number
+ codeGroupId: number
+ code: string
+ description: string
+ remark: string | null
+ isActive: boolean
+ createdAt: Date
+ updatedAt: Date
+}
+
+interface ComboBoxOptionsTableToolbarActionsProps {
+ table: Table<ComboBoxOption>
+ codeGroupId: number
+ onSuccess?: () => void
+}
+
+export function ComboBoxOptionsTableToolbarActions({
+ table,
+ codeGroupId,
+ onSuccess,
+}: ComboBoxOptionsTableToolbarActionsProps) {
+ const selectedRows = table.getFilteredSelectedRowModel().rows
+ const selectedOptions = selectedRows.map((row) => row.original)
+
+ return (
+ <div className="flex items-center gap-2">
+ {/** 선택된 로우가 있으면 삭제 다이얼로그 */}
+ {selectedOptions.length > 0 ? (
+ <DeleteComboBoxOptionsDialog
+ options={selectedOptions}
+ onSuccess={() => {
+ table.toggleAllRowsSelected(false)
+ onSuccess?.()
+ }}
+ />
+ ) : null}
+
+ <ComboBoxOptionsAddDialog
+ codeGroupId={codeGroupId}
+ onSuccess={onSuccess}
+ />
+ </div>
+ )
+} \ No newline at end of file