mirror of
https://github.com/HolgerHatGarKeineNode/einundzwanzig-app.git
synced 2025-12-20 13:40:15 +00:00
✨ 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:
@@ -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)
|
||||
|
||||
36
app/Http/Middleware/SetTimezone.php
Normal file
36
app/Http/Middleware/SetTimezone.php
Normal 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);
|
||||
}
|
||||
}
|
||||
@@ -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(),
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
@@ -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'));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user