Enhance timezone support across application

- Introduced a `SetTimezone` middleware to dynamically apply user-specific timezones.
- Added a `timezone chooser` component for users to select their timezone.
- Enhanced date and time display in views with `asDate`, `asTime`, and `asDateTime` methods.
- Updated `AppServiceProvider` to leverage `preventLazyLoading` in local environments and set custom `Carbon` instance for dates.
- Expanded configuration with `user-timezone`.
- Integrated timezone support into meetups and events for consistent scheduling.
This commit is contained in:
HolgerHatGarKeineNode
2025-11-23 19:21:19 +01:00
parent cdf8744883
commit ca9cd9b875
13 changed files with 134 additions and 20 deletions

View File

@@ -9,6 +9,7 @@ class SeoDataAttribute
{
public function __construct(
public ?string $key = null, // e.g., 'meetups_index', 'event_show', etc.
public ?string $image = null, // image url override
) {}
// Centralized SEO data definitions by key as SEOData instances (lazy initialized)

View File

@@ -0,0 +1,36 @@
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class SetTimezone
{
/**
* Handle an incoming request.
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next): Response
{
if (
$request->user()
&& $timezone = $request->user()->timezone
) {
config([
'app.timezone' => $timezone,
'app.user-timezone' => $timezone,
]);
return $next($request);
}
config([
'app.timezone' => 'Europe/Berlin',
'app.user-timezone' => 'Europe/Berlin',
]);
return $next($request);
}
}

View File

@@ -123,6 +123,7 @@ class Meetup extends Model implements HasMedia
return Attribute::make(
get: fn()
=> $nextEvent ? [
'id' => $nextEvent->id,
'start' => $nextEvent->start,
'portalLink' => url()->route('meetups.landingpage-event',
['country' => $this->city->country, 'meetup' => $this, 'event' => $nextEvent]),
@@ -139,7 +140,8 @@ class Meetup extends Model implements HasMedia
protected function belongsToMe(): Attribute
{
return Attribute::make(
get: fn() => DB::table('meetup_user')->where('meetup_id', $this->id)->where('user_id', auth()->id())->exists(),
get: fn() => DB::table('meetup_user')->where('meetup_id', $this->id)->where('user_id',
auth()->id())->exists(),
);
}

View File

@@ -2,6 +2,9 @@
namespace App\Providers;
use App\Support\Carbon;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\Date;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider
@@ -11,7 +14,9 @@ class AppServiceProvider extends ServiceProvider
*/
public function register(): void
{
//
Date::use(
Carbon::class
);
}
/**
@@ -19,6 +24,6 @@ class AppServiceProvider extends ServiceProvider
*/
public function boot(): void
{
//
Model::preventLazyLoading(app()->environment('local'));
}
}