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