erag/laravel-datetime-format
Composer 安装命令:
composer require erag/laravel-datetime-format
包简介
Format Eloquent date and datetime values consistently across models, Blade, and APIs.
README 文档
README
A powerful Laravel package for centralized and consistent date/time formatting across your application. Automatically format Eloquent model dates, API responses, Blade output, and Carbon instances without repeating manual ->format(...) calls everywhere.
Key Features 🔥
- 👤 Automatic Eloquent model datetime formatting
- 🧠 Centralized datetime formatter service
- 🧩 Custom cast support with
FormattedDateTimeCast - 🎨 Blade directive support via
@dateTimeFormat(...),@datetime(...),@dateFormat(...), and@timeFormat(...) - ⏱️ Carbon macro support using
toConfiguredFormat() - 📦 API resource helper macros
- 🌍 Timezone and locale support
- 🧱 Laravel
10,11,12, and13support - ✅ PHP
8.2+support
Install 🚀
composer require erag/laravel-datetime-format php artisan erag:install-datetime-format
Config ⚙️
Published file: config/datetime-format.php
return [ 'format' => 'd-m-Y H:i:s', 'timezone' => env('APP_TIMEZONE', 'UTC'), 'locale' => env('APP_LOCALE', 'en'), 'null_value' => null, 'auto_apply' => true, 'date_format' => 'd-m-Y', 'time_format' => 'H:i:s', ];
What timezone and locale do 🌍
timezone: defines the timezone used for formatted output.
Example: the input can be UTC, but output can be converted toAsia/Kolkata.locale: sets Carbon’s language/context before formatting.
This is useful when using month/day names, such as28 May 2026or localized month labels.
Quick Understanding (Before vs After) 👀
Without package (common output):
{
"created_at": "2026-05-27T15:39:13.000000Z"
}
With package + trait:
{
"created_at": "27-05-2026 21:09:13"
}
Usage
1) Model Auto Format (Recommended) 👤
use LaravelDateTimeFormat\Concerns\HasFormattedDateTimes; class User extends Model { use HasFormattedDateTimes; }
By default, every formatted date uses the global package config:
datetime-format.formatdatetime-format.timezonedatetime-format.locale
Controller:
return response()->json([ 'user' => User::first(), ]);
Response example:
{
"user": {
"id": 1,
"name": "Kaden Herring",
"email": "biwepa@mailinator.com",
"created_at": "27-05-2026 21:09:13",
"updated_at": "27-05-2026 21:09:13"
}
}
1.1) Different format per attribute 👤
Use formattedDateAttributes() when you want different output formats on the same model:
use LaravelDateTimeFormat\Concerns\HasFormattedDateTimes; class User extends Model { use HasFormattedDateTimes; protected function formattedDateAttributes(): array { return [ 'created_at' => 'd-m-Y', 'updated_at' => 'd/m/Y h:i A', 'email_verified_at' => 'M d, Y', ]; } }
Example output:
{
"created_at": "29-05-2026",
"updated_at": "29/05/2026 10:30 AM",
"email_verified_at": "May 29, 2026"
}
1.2) Different format and timezone per attribute 🌍
Use $formattedDate when a field needs additional options like timezone or locale:
use LaravelDateTimeFormat\Concerns\HasFormattedDateTimes; class User extends Model { use HasFormattedDateTimes; protected array $formattedDate = [ 'created_at' => ['format' => 'd-m-Y', 'timezone' => 'UTC'], 'updated_at' => ['format' => 'd/m/Y h:i A', 'timezone' => 'Asia/Kolkata'], 'email_verified_at' => ['format' => 'M d, Y', 'locale' => 'en'], ]; }
This is enough by itself. You do not need to repeat the same fields in formattedDateAttributes().
Example output:
{
"created_at": "29-05-2026",
"updated_at": "29/05/2026 10:30 AM",
"email_verified_at": "May 29, 2026"
}
1.3) Real User.php example ✅
<?php namespace App\Models; use Database\Factories\UserFactory; use Illuminate\Database\Eloquent\Attributes\Fillable; use Illuminate\Database\Eloquent\Attributes\Hidden; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Laravel\Fortify\Contracts\PasskeyUser; use Laravel\Fortify\PasskeyAuthenticatable; use Laravel\Fortify\TwoFactorAuthenticatable; use LaravelDateTimeFormat\Concerns\HasFormattedDateTimes; #[Fillable(['name', 'email', 'password'])] #[Hidden(['password', 'two_factor_secret', 'two_factor_recovery_codes', 'remember_token'])] class User extends Authenticatable implements PasskeyUser { /** @use HasFactory<UserFactory> */ use HasFactory, HasFormattedDateTimes, Notifiable, PasskeyAuthenticatable, TwoFactorAuthenticatable; protected function casts(): array { return [ 'email_verified_at' => 'datetime', 'password' => 'hashed', 'two_factor_confirmed_at' => 'datetime', ]; } protected array $formattedDate = [ 'updated_at' => ['format' => 'M d, Y'], ]; }
Rule of thumb:
- use default package config when all date fields should look the same
- use
formattedDateAttributes()for per-attribute formats - use
$formattedDatefor per-attributeformat,timezone, andlocale - prefer one approach per field to keep model code short and readable
If your custom format is date-only, time will not be included:
protected array $formattedDate = [ 'updated_at' => ['format' => 'M d, Y'], ];
Output:
{
"updated_at": "May 29, 2026"
}
2) Custom Cast (When you only want specific columns formatted) 🧩
use LaravelDateTimeFormat\Casts\FormattedDateTimeCast; protected function casts(): array { return [ 'email_verified_at' => FormattedDateTimeCast::class, ]; }
Example output:
{
"email_verified_at": "28-05-2026 15:45:30"
}
3) Blade Directive 🎨
@dateTimeFormat($user->created_at) @datetime($user->created_at) @dateFormat($user->created_at) @timeFormat($user->created_at)
Rendered output:
27-05-2026 21:09:13
27-05-2026 21:09:13
27-05-2026
21:09:13
4) Formatter Service 🧠
use LaravelDateTimeFormat\Formatters\DateTimeFormatter; public function show(DateTimeFormatter $formatter) { return [ 'datetime' => $formatter->format('2026-05-28 10:15:30'), 'date' => $formatter->formatDate('2026-05-28 10:15:30'), 'time' => $formatter->formatTime('2026-05-28 10:15:30'), ]; }
Response example:
{
"datetime": "28-05-2026 15:45:30",
"date": "28-05-2026",
"time": "15:45:30"
}
5) Facade Usage 🛠️
use DateFormat; DateFormat::format(now()); DateFormat::format(now(), 'd/m/Y H:i');
6) Carbon Macro ⏱️
Carbon::now()->toConfiguredFormat(); Carbon::now()->toConfiguredFormat('d M Y, h:i A');
7) API Resource Macro 📦
return [ 'created_at' => $this->formatDateTime($this->created_at), ];
Resource output example:
{
"created_at": "27-05-2026 21:09:13"
}
Real Demo Style Response ✅
If you want to see mixed output (service + blade + model):
{
"source_utc": "2026-05-28 10:15:30 UTC",
"formatter_service": "28-05-2026 15:45:30",
"date_only": "2026-05-28",
"time_only": "15:45:30",
"facade": "28/05/2026 15:45",
"carbon_macro": "28 May 2026, 03:45 PM",
"blade_directive": "28-05-2026 15:45:30",
"user_date": {
"data": [
{
"created_at": "27-05-2026 21:09:13",
"updated_at": "27-05-2026 21:09:13"
}
]
}
}
统计信息
- 总下载量: 3
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 7
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-05-27