79 lines
2.4 KiB
TypeScript
Vendored
79 lines
2.4 KiB
TypeScript
Vendored
/*
|
|
Copyright (C) 2023-2026 modelstoken
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as
|
|
published by the Free Software Foundation, either version 3 of the
|
|
License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
For commercial licensing, please contact admin@modelstoken.com
|
|
*/
|
|
import { type Row } from '@tanstack/react-table'
|
|
import { MoreHorizontal, Pencil, Power, PowerOff } from 'lucide-react'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { Button } from '@/components/ui/button'
|
|
import {
|
|
DropdownMenu,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuTrigger,
|
|
} from '@/components/ui/dropdown-menu'
|
|
import type { PlanRecord } from '../types'
|
|
import { useSubscriptions } from './subscriptions-provider'
|
|
|
|
interface DataTableRowActionsProps {
|
|
row: Row<PlanRecord>
|
|
}
|
|
|
|
export function DataTableRowActions({ row }: DataTableRowActionsProps) {
|
|
const { t } = useTranslation()
|
|
const { setOpen, setCurrentRow } = useSubscriptions()
|
|
|
|
return (
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger
|
|
render={<Button variant='ghost' className='h-8 w-8 p-0' />}
|
|
>
|
|
<MoreHorizontal className='h-4 w-4' />
|
|
</DropdownMenuTrigger>
|
|
<DropdownMenuContent align='end'>
|
|
<DropdownMenuItem
|
|
onClick={() => {
|
|
setCurrentRow(row.original)
|
|
setOpen('update')
|
|
}}
|
|
>
|
|
<Pencil className='mr-2 h-4 w-4' />
|
|
{t('Edit')}
|
|
</DropdownMenuItem>
|
|
<DropdownMenuItem
|
|
onClick={() => {
|
|
setCurrentRow(row.original)
|
|
setOpen('toggle-status')
|
|
}}
|
|
>
|
|
{row.original.plan.enabled ? (
|
|
<>
|
|
<PowerOff className='mr-2 h-4 w-4' />
|
|
{t('Disable')}
|
|
</>
|
|
) : (
|
|
<>
|
|
<Power className='mr-2 h-4 w-4' />
|
|
{t('Enable')}
|
|
</>
|
|
)}
|
|
</DropdownMenuItem>
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
)
|
|
}
|