43 lines
1.2 KiB
Vue
43 lines
1.2 KiB
Vue
<script setup lang="ts">
|
|
import { DotsHorizontalIcon } from '@radix-icons/vue'
|
|
import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuLabel, DropdownMenuSeparator, DropdownMenuTrigger } from '@/lib/registry/new-york/ui/dropdown-menu'
|
|
import { Button } from '@/lib/registry/new-york/ui/button'
|
|
|
|
defineProps<{
|
|
payment: {
|
|
id: string
|
|
}
|
|
}>()
|
|
|
|
defineEmits<{
|
|
(e: 'expand'): void
|
|
}>()
|
|
|
|
function copy(id: string) {
|
|
navigator.clipboard.writeText(id)
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger as-child>
|
|
<Button variant="ghost" class="h-8 w-8 p-0">
|
|
<span class="sr-only">Open menu</span>
|
|
<DotsHorizontalIcon class="h-4 w-4" />
|
|
</Button>
|
|
</DropdownMenuTrigger>
|
|
<DropdownMenuContent align="end">
|
|
<DropdownMenuLabel>Actions</DropdownMenuLabel>
|
|
<DropdownMenuItem @click="copy(payment.id)">
|
|
Copy payment ID
|
|
</DropdownMenuItem>
|
|
<DropdownMenuItem @click="$emit('expand')">
|
|
Expand
|
|
</DropdownMenuItem>
|
|
<DropdownMenuSeparator />
|
|
<DropdownMenuItem>View customer</DropdownMenuItem>
|
|
<DropdownMenuItem>View payment details</DropdownMenuItem>
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
</template>
|