From f25cb186b76a6deed16b01cda624bff57ee48450 Mon Sep 17 00:00:00 2001 From: SofianeLasri <alasri250@gmail.com> Date: Thu, 20 Feb 2025 13:45:53 +0100 Subject: [PATCH] feat: add legal mentions page and update terms page with localization MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Created a new LegalMentionsController to handle the display of legal mentions. - Added a new Blade view for legal mentions with localization support. - Updated the terms page to use localized titles. - Updated footer links to use localized text for legal mentions and terms. - Added French localization entries for "Mentions légales" and "Conditions générales de vente". --- .../Public/LegalMentionsController.php | 21 +++++++++++++++++++ lang/fr/generic.php | 2 ++ .../views/components/public/footer.blade.php | 7 ++++--- .../views/public/legal-mentions.blade.php | 16 ++++++++++++++ resources/views/public/terms.blade.php | 6 +++--- routes/web.php | 4 +++- 6 files changed, 49 insertions(+), 7 deletions(-) create mode 100644 app/Http/Controllers/Public/LegalMentionsController.php create mode 100644 resources/views/public/legal-mentions.blade.php diff --git a/app/Http/Controllers/Public/LegalMentionsController.php b/app/Http/Controllers/Public/LegalMentionsController.php new file mode 100644 index 0000000..4098697 --- /dev/null +++ b/app/Http/Controllers/Public/LegalMentionsController.php @@ -0,0 +1,21 @@ +<?php + +namespace App\Http\Controllers\Public; + +use App\Http\Controllers\Controller; +use App\Models\LegalMention; + +class LegalMentionsController extends Controller +{ + public function __invoke() + { + $activeLegalMentionsText = LegalMention::where('active', true)->first(); + + if (! $activeLegalMentionsText) { + abort(404); + } + $activeLegalMentionsText = $activeLegalMentionsText->contentTransKey->getTranslation(); + + return view('public.legal-mentions', compact('activeLegalMentionsText')); + } +} diff --git a/lang/fr/generic.php b/lang/fr/generic.php index 4b27032..0c36935 100644 --- a/lang/fr/generic.php +++ b/lang/fr/generic.php @@ -4,4 +4,6 @@ 'custom_needs' => 'Un besoin particulier ?', 'custom_needs_desc' => 'Je suis ouverte à toute proposition. N’hésitez pas à me contacter !', 'completed_in' => 'Réalisé en', + 'legal_mentions' => 'Mentions légales', + 'terms' => 'Conditions générales de vente', ]; diff --git a/resources/views/components/public/footer.blade.php b/resources/views/components/public/footer.blade.php index 82765bb..720ebc3 100644 --- a/resources/views/components/public/footer.blade.php +++ b/resources/views/components/public/footer.blade.php @@ -36,11 +36,12 @@ <div class="self-stretch text-2xl font-bold">Informations légales</div> <ul class="flex flex-col gap-2"> <li> - <a href="{{ route('legal-mentions') }}" class="text-muted hover:text-primary">Mentions - légales</a> + <a href="{{ route('legal-mentions') }}" + class="text-muted hover:text-primary">{{ __('generic.legal_mentions') }}</a> </li> <li> - <a href="#" class="text-muted hover:text-primary">Conditions générales de vente</a> + <a href="{{ route('terms') }}" + class="text-muted hover:text-primary">{{ __('generic.terms') }}</a> </li> </ul> </div> diff --git a/resources/views/public/legal-mentions.blade.php b/resources/views/public/legal-mentions.blade.php new file mode 100644 index 0000000..65d3c5c --- /dev/null +++ b/resources/views/public/legal-mentions.blade.php @@ -0,0 +1,16 @@ +@extends('layouts.public', ['title' => __('generic.legal_mentions')]) + +@section('content') + <x-public.navbar class="container mx-auto px-4"/> + + <div class="container mx-auto px-4 py-24 flex flex-col gap-16"> + <x-public.generic-page-header title="{{ __('generic.legal_mentions') }}"/> + <div> + <x-markdown class="markdown"> + {{ $activeLegalMentionsText }} + </x-markdown> + </div> + </div> + + <x-public.footer/> +@endsection \ No newline at end of file diff --git a/resources/views/public/terms.blade.php b/resources/views/public/terms.blade.php index 65b7b67..c7d919a 100644 --- a/resources/views/public/terms.blade.php +++ b/resources/views/public/terms.blade.php @@ -1,11 +1,11 @@ -@extends('layouts.public', ['title' => "Mentions légales"]) +@extends('layouts.public', ['title' => __('generic.terms')]) @section('content') <x-public.navbar class="container mx-auto px-4"/> <div class="container mx-auto px-4 py-24 flex flex-col gap-16"> - <x-public.generic-page-header title="Mentions légales"/> - <div class=""> + <x-public.generic-page-header title="{{ __('generic.terms') }}"/> + <div> <x-markdown class="markdown"> {{ $activeTermsText }} </x-markdown> diff --git a/routes/web.php b/routes/web.php index d92fdd4..3f72ca5 100644 --- a/routes/web.php +++ b/routes/web.php @@ -11,6 +11,7 @@ use App\Http\Controllers\Admin\SocialMediaLinksController; use App\Http\Controllers\Admin\TermsSectionController; use App\Http\Controllers\Public\IndexController; +use App\Http\Controllers\Public\LegalMentionsController; use App\Http\Controllers\Public\PortfolioController; use App\Http\Controllers\Public\PrestationController as PublicPrestationController; use App\Http\Controllers\Public\TermsController; @@ -30,7 +31,8 @@ Route::get('/portfolio/api', [PortfolioController::class, 'api'])->name('portfolio.api'); Route::get('/portfolio/{slug}', [PortfolioController::class, 'show'])->name('portfolio.show'); Route::get('/prestations/{slug}', [PublicPrestationController::class, 'index'])->name('prestations.show'); - Route::get('/mentions-legales', TermsController::class)->name('legal-mentions'); + Route::get('/mentions-legales', LegalMentionsController::class)->name('legal-mentions'); + Route::get('/conditions-generales-de-vente', TermsController::class)->name('terms'); Route::view('/maintenance', 'public.maintenance')->name('maintenance'); }); -- GitLab