fix&feat(Logout & Contact service)

This commit is contained in:
2025-10-24 14:38:11 +02:00
parent ec1e45d1ec
commit 868b9a837b
9 changed files with 55 additions and 30 deletions

View File

@@ -4,13 +4,13 @@ namespace App\Http\Controllers\Forms;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use App\Http\Requests\Forms\ContactRequest; use App\Http\Requests\Forms\ContactRequest;
use App\Models\Contact; use App\Services\ContactService;
use Illuminate\Http\RedirectResponse; use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Inertia\Inertia; use Inertia\Inertia;
class ContactFormController extends Controller class ContactFormController extends Controller
{ {
public function __construct(protected ContactService $contactService) {}
/** /**
* Show the contact form page. * Show the contact form page.
*/ */
@@ -26,9 +26,17 @@ class ContactFormController extends Controller
public function store(ContactRequest $request): RedirectResponse public function store(ContactRequest $request): RedirectResponse
{ {
$validated = $request->validated(); $validated = $request->validated();
$contact = new Contact(); try {
$contact->fill($validated); $contact = $this->contactService->registerNewContactRequest($validated);
$contact->save(); } catch (\Throwable $e) {
\Log::error('Erreur lors de la création d\'un contact', [
'error' => $e->getMessage(),
'trace' => $e->getTraceAsString(),
'data' => $validated,
]);
return to_route('contact')->with('error', __('contacts.responses.error'));
}
return to_route('contact')->with('success', __('contacts.responses.success')); return to_route('contact')->with('success', __('contacts.responses.success'));
} }

View File

@@ -49,7 +49,7 @@ class MembershipFormController extends Controller
return redirect() return redirect()
->route('membership') ->route('membership')
->with('error', __('memberships.subscription.failed')); ->with('error', __('memberships.subscription.error'));
} }
return redirect() return redirect()

View File

@@ -0,0 +1,21 @@
<?php
namespace App\Services;
use App\Models\Contact;
class ContactService
{
public function __construct()
{
//
}
public function registerNewContactRequest(array $data): Contact
{
$contact = new Contact();
$contact->fill($data);
$contact->save();
}
}

View File

@@ -22,6 +22,6 @@ return [
'updated_at' => 'Updated at', 'updated_at' => 'Updated at',
'subscription' => [ 'subscription' => [
'success' => 'Your subscription has been successfully sent. We will contact you as soon as possible.', 'success' => 'Your subscription has been successfully sent. We will contact you as soon as possible.',
'failed' => 'An error occurred while sending your subscription.', 'error' => 'An error occurred while sending your subscription.',
] ]
]; ];

View File

@@ -27,7 +27,7 @@ return [
'updated_at' => 'Mise à jour le', 'updated_at' => 'Mise à jour le',
'subscription' => [ 'subscription' => [
'success' => 'Votre inscription a bien été envoyée. Nous vous recontacterons dans les plus brefs délais.', 'success' => 'Votre inscription a bien été envoyée. Nous vous recontacterons dans les plus brefs délais.',
'failed' => 'Une erreur est survenue lors de l\'envoi de votre inscription.', 'error' => 'Une erreur est survenue lors de l\'envoi de votre inscription.',
] ]
], ],

View File

@@ -67,12 +67,12 @@ export default function NavGuestLayout() {
</Link> </Link>
<Link <Link
className="bg-transparent border-0 shadow-none" className="border-3 bg-secondary text-secondary-foreground hover:bg-secondary/80 h-10 px-4 py-2 shadow-[4px_4px_0px_rgba(0,0,0,1)] hover:shadow-none hover:translate-2 transition delay-50 duration-200 ease-in-out font-bold"
href={logout()} href={logout()}
onClick={handleLogout} onClick={handleLogout}
data-test="logout-button" data-test="logout-button"
> >
<Button variant="secondary">Se déconnecter</Button> Se déconnecter
</Link> </Link>
</> </>
) : ( ) : (

View File

@@ -137,7 +137,7 @@ logoutForm.post = (options?: RouteQueryOptions): RouteFormDefinition<'post'> =>
logout.form = logoutForm logout.form = logoutForm
/** /**
* @see routes/web.php:7 * @see routes/web.php:6
* @route '/' * @route '/'
*/ */
export const home = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({ export const home = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
@@ -151,7 +151,7 @@ home.definition = {
} satisfies RouteDefinition<["get","head"]> } satisfies RouteDefinition<["get","head"]>
/** /**
* @see routes/web.php:7 * @see routes/web.php:6
* @route '/' * @route '/'
*/ */
home.url = (options?: RouteQueryOptions) => { home.url = (options?: RouteQueryOptions) => {
@@ -159,7 +159,7 @@ home.url = (options?: RouteQueryOptions) => {
} }
/** /**
* @see routes/web.php:7 * @see routes/web.php:6
* @route '/' * @route '/'
*/ */
home.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({ home.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
@@ -168,7 +168,7 @@ home.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
}) })
/** /**
* @see routes/web.php:7 * @see routes/web.php:6
* @route '/' * @route '/'
*/ */
home.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({ home.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({
@@ -177,7 +177,7 @@ home.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({
}) })
/** /**
* @see routes/web.php:7 * @see routes/web.php:6
* @route '/' * @route '/'
*/ */
const homeForm = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({ const homeForm = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
@@ -186,7 +186,7 @@ const homeForm = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
}) })
/** /**
* @see routes/web.php:7 * @see routes/web.php:6
* @route '/' * @route '/'
*/ */
homeForm.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({ homeForm.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
@@ -195,7 +195,7 @@ homeForm.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
}) })
/** /**
* @see routes/web.php:7 * @see routes/web.php:6
* @route '/' * @route '/'
*/ */
homeForm.head = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({ homeForm.head = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
@@ -211,7 +211,7 @@ homeForm.head = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
home.form = homeForm home.form = homeForm
/** /**
* @see routes/web.php:12 * @see routes/web.php:11
* @route '/dashboard' * @route '/dashboard'
*/ */
export const dashboard = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({ export const dashboard = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
@@ -225,7 +225,7 @@ dashboard.definition = {
} satisfies RouteDefinition<["get","head"]> } satisfies RouteDefinition<["get","head"]>
/** /**
* @see routes/web.php:12 * @see routes/web.php:11
* @route '/dashboard' * @route '/dashboard'
*/ */
dashboard.url = (options?: RouteQueryOptions) => { dashboard.url = (options?: RouteQueryOptions) => {
@@ -233,7 +233,7 @@ dashboard.url = (options?: RouteQueryOptions) => {
} }
/** /**
* @see routes/web.php:12 * @see routes/web.php:11
* @route '/dashboard' * @route '/dashboard'
*/ */
dashboard.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({ dashboard.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
@@ -242,7 +242,7 @@ dashboard.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
}) })
/** /**
* @see routes/web.php:12 * @see routes/web.php:11
* @route '/dashboard' * @route '/dashboard'
*/ */
dashboard.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({ dashboard.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({
@@ -251,7 +251,7 @@ dashboard.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({
}) })
/** /**
* @see routes/web.php:12 * @see routes/web.php:11
* @route '/dashboard' * @route '/dashboard'
*/ */
const dashboardForm = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({ const dashboardForm = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
@@ -260,7 +260,7 @@ const dashboardForm = (options?: RouteQueryOptions): RouteFormDefinition<'get'>
}) })
/** /**
* @see routes/web.php:12 * @see routes/web.php:11
* @route '/dashboard' * @route '/dashboard'
*/ */
dashboardForm.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({ dashboardForm.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
@@ -269,7 +269,7 @@ dashboardForm.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> =>
}) })
/** /**
* @see routes/web.php:12 * @see routes/web.php:11
* @route '/dashboard' * @route '/dashboard'
*/ */
dashboardForm.head = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({ dashboardForm.head = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({

View File

@@ -4,11 +4,8 @@ use App\Http\Controllers\Forms\ContactFormController;
use App\Http\Controllers\Forms\MembershipFormController; use App\Http\Controllers\Forms\MembershipFormController;
use Illuminate\Support\Facades\Route; use Illuminate\Support\Facades\Route;
Route::get('contact', [ContactFormController::class, 'create']) Route::get('contact', [ContactFormController::class, 'create'])->name('contact');
->name('contact'); Route::post('contact', [ContactFormController::class, 'store'])->name('contact.store');
Route::post('contact', [ContactFormController::class, 'store'])
->name('contact.store');
Route::get('membership', [MembershipFormController::class, 'create'])->name('membership'); Route::get('membership', [MembershipFormController::class, 'create'])->name('membership');
Route::post('membership', [MembershipFormController::class, 'store'])->name('membership.store'); Route::post('membership', [MembershipFormController::class, 'store'])->name('membership.store');

View File

@@ -1,6 +1,5 @@
<?php <?php
use App\Http\Controllers\Forms\ContactFormController;
use Illuminate\Support\Facades\Route; use Illuminate\Support\Facades\Route;
use Inertia\Inertia; use Inertia\Inertia;