anuzpandey / laravel-nepali-date
A Laravel Package to convert English Date (A.D.) to Nepali Date (B.S.) and vice-versa.
Installs: 13 584
Dependents: 0
Suggesters: 0
Security: 0
Stars: 16
Watchers: 1
Forks: 11
Open Issues: 1
pkg:composer/anuzpandey/laravel-nepali-date
Requires
- php: ^8.2
- illuminate/contracts: ^11.0|^12.0
- spatie/laravel-package-tools: ^1.14.0
Requires (Dev)
- larastan/larastan: ^2.0 || ^3.0
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.8 || ^8.0
- orchestra/testbench: ^9.0 || ^10.0
- pestphp/pest: ^2.20 || ^3.8
- pestphp/pest-plugin-arch: ^2.0 || ^3.0
- pestphp/pest-plugin-laravel: ^2.0 || ^3.0
- phpstan/phpstan: ^1.12.17 || ^2.1
- dev-main
- 3.1.0
- 3.0.0
- 2.4.0
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.0
- 2.1.0
- 2.0.0
- 1.7.1
- 1.7.0
- 1.6.5
- 1.6.4
- 1.6.3
- 1.6.2
- 1.6.1
- 1.6.0
- 1.5.0
- 1.4.0
- 1.3.0
- 1.2.0
- 1.1.0
- 1.0.0
- dev-feat/flexible-inputs
- dev-feat/strict-validation
- dev-feat/artisan-commands
- dev-fix/17/days-in-month
- dev-fixes/year-month-count-mismatch
- dev-updates/remove-carbon
- dev-dev
This package is auto-updated.
Last update: 2026-02-06 10:04:43 UTC
README
LaravelNepaliDate is a Laravel package that simplifies the conversion of dates between the Gregorian (English) and Nepali (Bikram Sambat) calendars. This package is a handy tool for projects that require handling dates in both English and Nepali formats, such as websites and applications targeting users in Nepal.
Installation
You can install the package via composer:
composer require anuzpandey/laravel-nepali-date
Optionally, you can publish the config file with:
php artisan vendor:publish --tag="nepali-date-config"
Usage
$engDate = '1996-04-22'; LaravelNepaliDate::from($engDate)->toNepaliDate(); // Result: 2053-01-10 LaravelNepaliDate::from($engDate)->toNepaliDate(format: 'D, j F Y'); // Result: सोम, १० वैशाख २०५३ // Format Specifiers are supported and listed below LaravelNepaliDate::from($engDate)->toNepaliDate(format: 'D, j F Y', locale: 'en'); // Result: Mon, 10 Baisakh 2053 $nepDate = '2053-01-10'; LaravelNepaliDate::from($nepDate)->toEnglishDate(); // Result: 1996-04-22 LaravelNepaliDate::from($nepDate)->toEnglishDate(format: 'l, jS F Y'); // Result: Sunday, 22nd April 1996 // Format Specifiers are supported and listed below LaravelNepaliDate::from($nepDate)->toEnglishDate(format: 'l, j F Y', locale: 'np'); // Result: आइतबार, २२ बैशाख १९९६ // Get total days in a month of a year use Anuzpandey\LaravelNepaliDate\Enums\NepaliMonth; // month can be NepaliMonth::XXX or month number (1-12) LaravelNepaliDate::daysInMonth(NepaliMonth::BAISAKH, 2053); // Result: 31 // Get total days in a year LaravelNepaliDate::daysInYear(2053); // Result: 365
Format Specifiers
The following format specifiers are supported for formatting dates:
Y- Year in four digitsy- Year in two digitsm- Month in two digits with leading zero (01-12/०१-१२)n- Month in one or two digits without leading zero (1-12/१-१२)M- Month in three letters (Jan-Dec)F- Month in full name (January-December/बैशाख-चैत्र)d- Day in two digits with leading zero (01-31/०१-३२)j- Day in one or two digits without leading zero (1-31/१-३२)D- Day in three letters (Sun-Sat/आइत-शनि)l- Day in full name (Sunday-Saturday/आइतबार-शनिबार)S- Day in two letters (st, nd, rd, th)
Extending Carbon with NepaliDateMixin
Note: This feature has been deprecated as Carbon doesn't support the months having more than 31 days. This feature has been removed from version 2.0.0.
Helper function
// Convert English date to Nepali date (B.S.). toNepaliDate("1996-04-22") // Result: 2053-01-10 // Convert Nepali date to English date (A.D.). toEnglishDate("2053-01-10") // Result: 1996-04-22
Blade Directives
You can use the Blade directives directly in your views:
{{-- Convert English date to Nepali date --}} @nepaliDate('1996-04-22') {{-- Result: 2053-01-10 --}} {{-- With format --}} @nepaliDate('1996-04-22', 'l, d F Y') {{-- Result: सोमबार, १० वैशाख २०५३ --}} {{-- With format and locale --}} @nepaliDate('1996-04-22', 'l, d F Y', 'en') {{-- Result: Monday, 10 Baisakh 2053 --}} {{-- Convert Nepali date to English date --}} @englishDate('2053-01-10') {{-- Result: 1996-04-22 --}} {{-- With format --}} @englishDate('2053-01-10', 'l, d F Y') {{-- Result: सोमबार, २२ अप्रिल १९९६ --}} {{-- With format and locale --}} @englishDate('2053-01-10', 'l, d F Y', 'en') {{-- Result: Monday, 22 April 1996 --}}
Artisan Commands
Run quick conversions from the CLI:
php artisan nepali-date:convert --from=1996-04-22 --to=np php artisan nepali-date:today php artisan nepali-date:range --from=2080-01-01 --until=2080-01-05 --calendar=np --to=en
Common options:
--format=Output format (defaults toconfig('nepali-date.default_format'))--locale=Output localeenornp--strictEnable stricter date validation--jsonEmit JSON output--timezone=Timezone fortoday
Getting Date as Array
You can get the date components as an array for more flexibility:
$engDate = '1996-04-22'; $dateArray = LaravelNepaliDate::from($engDate)->toNepaliDateArray(); // Returns NepaliDateArrayData object with: // - year: '2053' // - month: '01' // - day: '10' // - npYear: '२०५३' // - npMonth: '०१' // - npDay: '१०' // - dayName: 'Monday' // - monthName: 'Baisakh' // - npDayName: 'सोमबार' // - npMonthName: 'वैशाख' $nepDate = '2053-01-10'; $dateArray = LaravelNepaliDate::from($nepDate)->toEnglishDateArray(); // Returns similar structure with English date data
Supported Date Ranges
| Calendar | From | To |
|---|---|---|
| English (A.D.) | 1944-01-01 | 2033-12-31 |
| Nepali (B.S.) | 2000-09-17 | 2099-12-30 |
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.