BanglaDateTime is a Laravel package that allows you to easily format and convert DateTime to the Bangla calendar and Bangla number formats. It supports both current time and custom dates, as well as timezones.
- Convert DateTime to Bangla format.
- Convert to the Bangla calendar (Bengali Era).
- Supports custom dates and timezones.
- Easy to use with a fluent API.
- Helper functions for easy access to common operations.
You can install the package via Composer:
composer require bangladatetime/laravel
To integrate BanglaDateTime with Laravel, follow these steps:
-
Publish the Configuration File:
Run the following command to publish the package configuration file:
php artisan vendor:publish --provider="BanglaDateTime\Laravel\BanglaDateTimeServiceProvider"
This will create a configuration file at
config/bangladatetime.php
. -
Configuration:
Edit the
config/bangladatetime.php
file to set your desired date formats and timezone. -
Usage:
The package integrates with Laravel's
Carbon
class, allowing you to use custom methods to format dates in Bangla format and Bangla calendar directly.
If you have a model with a datetime
cast, you can easily format the datetime attributes using the BanglaDateTime methods. For example:
use App\Models\User;
// Retrieve a user and format the created_at attribute in Bangla format
$user = User::find(1);
echo $user->created_at->formatBangla('l jS F Y h:i:s');
// Format the created_at attribute in Bangla calendar format
echo $user->created_at->toBangla('l jS F Y h:i:s');
Output:
Created at with Bangla format: বৃহস্পতিবার ১২ই সেপ্টেম্বর ২০২৪ ০৩:৩৭:০৩
Created at converted to Bangla: বৃহস্পতিবার ২৮শে ভাদ্র ১৪৩১ ০৩:৩৭:০৩
use Illuminate\Support\Carbon;
// Get current date and time in Bangla format
echo Carbon::now()->formatBangla('l jS F Y h:i:s');
// Get current date and time in Bangla calendar format
echo Carbon::now()->toBangla('l jS F Y h:i:s');
Output:
Current time with Bangla format: বৃহস্পতিবার ১২ই সেপ্টেম্বর ২০২৪ ০৩:৩৭:০৩
Current time converted to Bangla: বৃহস্পতিবার ২৮শে ভাদ্র ১৪৩১ ০৩:৩৭:০৩
use Illuminate\Support\Carbon;
// Set a custom date ('2023-04-13') in Bangla format
echo Carbon::create('2023-04-13')->formatBangla('l jS F Y h:i:s');
// Set a custom date ('2023-04-13') in Bangla calendar format
echo Carbon::create('2023-04-13')->toBangla('l jS F Y h:i:s');
Output:
Set Time with Bangla format: বৃহস্পতিবার ১৩ই এপ্রিল ২০২৩ ১২:০০:০০
Set Time & converted to Bangla: বৃহস্পতিবার ৩০শে চৈত্র ১৪২৯ ১২:০০:০০
use Illuminate\Support\Carbon;
// Set current time with a specific timezone ('Asia/Dhaka') in Bangla format
echo Carbon::now('Asia/Dhaka')->formatBangla('l jS F Y h:i:s');
// Set current time with a specific timezone ('Asia/Dhaka') in Bangla calendar format
echo Carbon::now('Asia/Dhaka')->toBangla('l jS F Y h:i:s');
Output:
Set Time & Time Zone with Bangla format: বৃহস্পতিবার ১২ই সেপ্টেম্বর ২০২৪ ০৯:৩৭:০৩
Set Time & Time Zone & converted to Bangla: বৃহস্পতিবার ২৮শে ভাদ্র ১৪৩১ ০৯:৩৭:০৩
You can specify a custom format and timezone when calling formatBangla
and toBangla
methods:
use Illuminate\Support\Carbon;
// Get current date and time in Bangla format with a custom format and timezone
echo Carbon::now()->formatBangla('d/m/Y H:i:s', 'Asia/Dhaka');
// Get current date and time in Bangla calendar format with a custom format and timezone
echo Carbon::now()->toBangla('d/m/Y H:i:s', 'Asia/Dhaka');
Output:
Custom Time with Bangla format: ১২/০৯/২০২৪ ১৫:৩৭:০৩
Custom Time & converted to Bangla: ২৮/ভাদ্র/১৪৩১ ১৫:৩৭:০৩
Creates a new BanglaDateTime
instance.
$time
: The date and time to use (optional, defaults to'now'
).$timezone
: The timezone to use (optional, defaults to'UTC'
).
Formats the date and time using a specified format, with the output in the Bangla locale.
$format
: The format string (same as PHP'sDateTime::format
).
Converts and formats the date and time into the Bangla calendar and Bangla numbers.
$format
: The format string (same as PHP'sDateTime::format
).
BanglaDateTime provides the following global helper functions for easy access:
-
bangla_date_time($time = 'now', $timezone = 'UTC')
: Creates a newBanglaDateTime
instance.$date = bangla_date_time('2023-04-13', 'Asia/Dhaka');
-
format_bangla_date($format, $time = 'now', $timezone = 'UTC')
: Formats a date/time in Bangla format.echo format_bangla_date('l jS F Y h:i:s');
-
convert_to_bangla_calendar($format, $time = 'now', $timezone = 'UTC')
: Converts a date/time to Bangla calendar format.echo convert_to_bangla_calendar('l jS F Y h:i:s');
Feel free to contribute by submitting a pull request or opening an issue. Your contributions are highly appreciated!
This library is open-sourced software licensed under the MIT license.