Initial commit of the L'Ami Fiduciaire SaaS platform built on Laravel 12, Vue 3, Inertia.js 2, and Tailwind CSS 4. Story 0.1 (rename folders to declarations in database) is implemented and code-reviewed: migration, rollback, and 6 Pest tests all passing. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
90 lines
3.0 KiB
Vue
90 lines
3.0 KiB
Vue
<script setup lang="ts">
|
|
import { Form, Head } from '@inertiajs/vue3';
|
|
import { ref } from 'vue';
|
|
import InputError from '@/components/InputError.vue';
|
|
import { Button } from '@/components/ui/button';
|
|
import { Input } from '@/components/ui/input';
|
|
import { Label } from '@/components/ui/label';
|
|
import { Spinner } from '@/components/ui/spinner';
|
|
import AuthLayout from '@/layouts/AuthLayout.vue';
|
|
import { update } from '@/routes/password';
|
|
|
|
const props = defineProps<{
|
|
token: string;
|
|
email: string;
|
|
}>();
|
|
|
|
const inputEmail = ref(props.email);
|
|
</script>
|
|
|
|
<template>
|
|
<AuthLayout
|
|
title="Reset password"
|
|
description="Please enter your new password below"
|
|
>
|
|
<Head title="Reset password" />
|
|
|
|
<Form
|
|
v-bind="update.form()"
|
|
:transform="(data) => ({ ...data, token, email })"
|
|
:reset-on-success="['password', 'password_confirmation']"
|
|
v-slot="{ errors, processing }"
|
|
>
|
|
<div class="grid gap-6">
|
|
<div class="grid gap-2">
|
|
<Label for="email">Email</Label>
|
|
<Input
|
|
id="email"
|
|
type="email"
|
|
name="email"
|
|
autocomplete="email"
|
|
v-model="inputEmail"
|
|
class="mt-1 block w-full"
|
|
readonly
|
|
/>
|
|
<InputError :message="errors.email" class="mt-2" />
|
|
</div>
|
|
|
|
<div class="grid gap-2">
|
|
<Label for="password">Password</Label>
|
|
<Input
|
|
id="password"
|
|
type="password"
|
|
name="password"
|
|
autocomplete="new-password"
|
|
class="mt-1 block w-full"
|
|
autofocus
|
|
placeholder="Password"
|
|
/>
|
|
<InputError :message="errors.password" />
|
|
</div>
|
|
|
|
<div class="grid gap-2">
|
|
<Label for="password_confirmation">
|
|
Confirm Password
|
|
</Label>
|
|
<Input
|
|
id="password_confirmation"
|
|
type="password"
|
|
name="password_confirmation"
|
|
autocomplete="new-password"
|
|
class="mt-1 block w-full"
|
|
placeholder="Confirm password"
|
|
/>
|
|
<InputError :message="errors.password_confirmation" />
|
|
</div>
|
|
|
|
<Button
|
|
type="submit"
|
|
class="mt-4 w-full"
|
|
:disabled="processing"
|
|
data-test="reset-password-button"
|
|
>
|
|
<Spinner v-if="processing" />
|
|
Reset password
|
|
</Button>
|
|
</div>
|
|
</Form>
|
|
</AuthLayout>
|
|
</template>
|