diff --git a/app/Http/Controllers/Public/LegalMentionsController.php b/app/Http/Controllers/Public/LegalMentionsController.php new file mode 100644 index 0000000000000000000000000000000000000000..4098697920ba33c78d7742a818a9902af53125af --- /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/app/Http/Controllers/Public/TermsController.php b/app/Http/Controllers/Public/TermsController.php new file mode 100644 index 0000000000000000000000000000000000000000..a20736b21e40f1970a758be6b82ebd599c7956b0 --- /dev/null +++ b/app/Http/Controllers/Public/TermsController.php @@ -0,0 +1,22 @@ +<?php + +namespace App\Http\Controllers\Public; + +use App\Http\Controllers\Controller; +use App\Models\TermsSection; +use Illuminate\View\View; + +class TermsController extends Controller +{ + public function __invoke(): View + { + $activeTermsText = TermsSection::where('active', true)->first(); + + if (! $activeTermsText) { + abort(404); + } + $activeTermsText = $activeTermsText->contentTranslationKey->getTranslation(); + + return view('public.terms', compact('activeTermsText')); + } +} diff --git a/lang/en/footer.php b/lang/en/footer.php new file mode 100644 index 0000000000000000000000000000000000000000..8c46e83400e9f00b7abead2b34a3dd71c39d197e --- /dev/null +++ b/lang/en/footer.php @@ -0,0 +1,14 @@ +<?php + +return [ + 'contact' => [ + 'title' => 'Excited to work with you!', + 'desc' => 'Feel free to contact me if you need information, or if you just want to chat with me.', + ], + 'links' => [ + 'title' => 'Stay in touch', + ], + 'legals-infos' => [ + 'title' => 'Legal information', + ], +]; diff --git a/lang/en/generic.php b/lang/en/generic.php index 51de6fe9e666f20e6169dff894b319ce4b1416d9..a345a842c4e75dcc9747427837b12f5f10eb10f9 100644 --- a/lang/en/generic.php +++ b/lang/en/generic.php @@ -4,4 +4,6 @@ 'custom_needs' => 'A specific need?', 'custom_needs_desc' => 'I am open to any proposal. Don’t hesitate to contact me!', 'completed_in' => 'Completed in', + 'legal_mentions' => 'Legal notices', + 'terms' => 'Terms and conditions of sale', ]; diff --git a/lang/fr/footer.php b/lang/fr/footer.php new file mode 100644 index 0000000000000000000000000000000000000000..0e7acdedfc7c68d0ae44642d3a24acba707dda0b --- /dev/null +++ b/lang/fr/footer.php @@ -0,0 +1,14 @@ +<?php + +return [ + 'contact' => [ + 'title' => 'Hâte de travailler avec vous !', + 'desc' => 'N’hésitez pas à me contacter si vous avez besoin de renseignements, ou que vous souhaitez simplement discuter avec moi.', + ], + 'links' => [ + 'title' => 'Restons en contact', + ], + 'legals-infos' => [ + 'title' => 'Informations légales', + ], +]; diff --git a/lang/fr/generic.php b/lang/fr/generic.php index 4b27032c33a73fb3c47194d9a0b8197c2d786f5d..0c369358497101f7f0bfffd75983290fdc6b7610 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 05142fdf514118c6824e2c1982921cb4f779788b..b49d55e59e1fa0ba91335832a7247dca42e76f63 100644 --- a/resources/views/components/public/footer.blade.php +++ b/resources/views/components/public/footer.blade.php @@ -8,20 +8,20 @@ <x-public.rann-logo height="4rem" role="image"/> </div> <div class="self-stretch flex-col justify-start items-start gap-2 flex"> - <div class="self-stretch text-2xl font-bold">Hâte de travailler avec vous !</div> - <div class="self-stretch text-muted">N’hésitez pas à me contacter si vous avez besoin de - renseignements, ou que vous souhaitez simplement discuter avec moi. + <div class="self-stretch text-2xl font-bold">{{ __('footer.contact.title') }}</div> + <div class="self-stretch text-muted"> + {{ __('footer.contact.desc') }} </div> </div> <x-public.button size="medium" tag="a" href="#"> - <div class="text-xl font-bold">Me contacter</div> + <div class="text-xl font-bold">{{ __('navbar.contact_me') }}</div> </x-public.button> </div> </div> <div class="w-full lg:w-auto items-start flex flex-col lg:flex-row gap-8 lg:gap-24"> <div class="w-full lg:w-56 flex-col gap-8 flex"> - <div class="self-stretch text-2xl font-bold">Restons en contact</div> + <div class="self-stretch text-2xl font-bold">{{ __('footer.links.title') }}</div> <ul class="flex flex-col gap-2"> @foreach(\App\Models\SocialMediaLink::all() as $socialMediaLink) <li> @@ -33,16 +33,15 @@ </ul> </div> <div class="w-full lg:w-56 flex-col gap-8 flex"> - <div class="self-stretch text-2xl font-bold">Informations légales</div> + <div class="self-stretch text-2xl font-bold">{{ __('footer.legals-infos.title') }}</div> <ul class="flex flex-col gap-2"> <li> - <a href="#" 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> - </li> - <li> - <a href="#" class="text-muted hover:text-primary">Politique de confidentialité</a> + <a href="{{ route('terms') }}" + class="text-muted hover:text-primary">{{ __('generic.terms') }}</a> </li> </ul> </div> diff --git a/resources/views/components/public/generic-page-header.blade.php b/resources/views/components/public/generic-page-header.blade.php index 7883746c0253491d0b38ca139d379b74f96a19ac..defaac73b1c21652eacf74dd4be847ddcc368361 100644 --- a/resources/views/components/public/generic-page-header.blade.php +++ b/resources/views/components/public/generic-page-header.blade.php @@ -1,6 +1,6 @@ @props([ 'title' => 'Title', - 'description' => 'Description', + 'description' => '', ]) <div {{ $attributes->class(['relative flex flex-col max-w-2xl gap-3']) }}> diff --git a/resources/views/public/legal-mentions.blade.php b/resources/views/public/legal-mentions.blade.php new file mode 100644 index 0000000000000000000000000000000000000000..65d3c5cc42d7c0a94a6e7782337eb2535d96c795 --- /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 new file mode 100644 index 0000000000000000000000000000000000000000..c7d919ab651ef56b0fc097ccca6d36e41e0cdc9d --- /dev/null +++ b/resources/views/public/terms.blade.php @@ -0,0 +1,16 @@ +@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="{{ __('generic.terms') }}"/> + <div> + <x-markdown class="markdown"> + {{ $activeTermsText }} + </x-markdown> + </div> + </div> + + <x-public.footer/> +@endsection \ No newline at end of file diff --git a/routes/web.php b/routes/web.php index aa637dc52583b1a3b5e1c9d22841990f31785ee2..3f72ca537dad8768b14793c321871478b4695110 100644 --- a/routes/web.php +++ b/routes/web.php @@ -11,8 +11,10 @@ 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; use App\Http\Middleware\CheckPrivateModeMiddleware; use App\Http\Middleware\RedirectIfUserExistsMiddleware; use Illuminate\Support\Facades\Route; @@ -29,6 +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', LegalMentionsController::class)->name('legal-mentions'); + Route::get('/conditions-generales-de-vente', TermsController::class)->name('terms'); Route::view('/maintenance', 'public.maintenance')->name('maintenance'); });