fix&feat(Logout & Contact service)
This commit is contained in:
@@ -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'));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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()
|
||||||
|
|||||||
21
app/Services/ContactService.php
Normal file
21
app/Services/ContactService.php
Normal 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();
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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.',
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
|
|||||||
@@ -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.',
|
||||||
]
|
]
|
||||||
],
|
],
|
||||||
|
|
||||||
|
|||||||
@@ -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>
|
||||||
</>
|
</>
|
||||||
) : (
|
) : (
|
||||||
|
|||||||
@@ -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'> => ({
|
||||||
|
|||||||
@@ -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');
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user