ledgerrz/resources/js/components/ManagePasskeys.vue
2026-06-15 00:30:57 +02:00

66 lines
2.0 KiB
Vue

<script setup lang="ts">
import { router } from '@inertiajs/vue3';
import { KeyRound } from '@lucide/vue';
import { destroy } from '@/actions/Laravel/Passkeys/Http/Controllers/PasskeyRegistrationController';
import Heading from '@/components/Heading.vue';
import PasskeyItem from '@/components/PasskeyItem.vue';
import PasskeyRegister from '@/components/PasskeyRegister.vue';
import type { Passkey } from '@/types/auth';
export type Props = {
canManagePasskeys?: boolean;
passkeys?: Passkey[];
};
withDefaults(defineProps<Props>(), {
canManagePasskeys: false,
passkeys: () => [],
});
const handleDelete = (id: number, onError: () => void) => {
router.delete(destroy.url(id), {
preserveScroll: true,
onError,
});
};
const handleRegisterSuccess = () => {
router.reload();
};
</script>
<template>
<div v-if="canManagePasskeys" class="space-y-6">
<Heading
variant="small"
title="Passkeys"
description="Manage your passkeys for passwordless sign-in"
/>
<div class="overflow-hidden rounded-lg border border-border">
<template v-if="passkeys.length">
<PasskeyItem
v-for="passkey in passkeys"
:key="passkey.id"
:passkey="passkey"
@remove="handleDelete"
/>
</template>
<div v-else class="p-8 text-center">
<div
class="mx-auto mb-4 flex h-14 w-14 items-center justify-center rounded-2xl bg-muted"
>
<KeyRound class="h-7 w-7 text-muted-foreground" />
</div>
<p class="font-medium">No passkeys yet</p>
<p class="mt-1 text-sm text-muted-foreground">
Add a passkey to sign in without a password
</p>
</div>
</div>
<PasskeyRegister @success="handleRegisterSuccess" />
</div>
</template>