Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pmzi/lahze
:calendar: Lightweight package for formatting dates between jalali and gregorian
https://github.com/pmzi/lahze
date format-time format-time-date gregorian gregorian-converter jalali jalali-converter jalalidate persian persian-date time
Last synced: 2 months ago
JSON representation
:calendar: Lightweight package for formatting dates between jalali and gregorian
- Host: GitHub
- URL: https://github.com/pmzi/lahze
- Owner: pmzi
- License: mit
- Created: 2020-01-11T12:24:56.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-06-06T07:37:10.000Z (over 1 year ago)
- Last Synced: 2024-10-05T12:04:43.374Z (3 months ago)
- Topics: date, format-time, format-time-date, gregorian, gregorian-converter, jalali, jalali-converter, jalalidate, persian, persian-date, time
- Language: JavaScript
- Homepage:
- Size: 279 KB
- Stars: 5
- Watchers: 2
- Forks: 0
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Lahze
![npm bundle size](https://img.shields.io/bundlephobia/minzip/lahze)
[![install size](https://packagephobia.now.sh/badge?p=hod)](https://packagephobia.now.sh/result?p=lahze)Lightweight package for formatting dates between jalali and gregorian. Supports both `node` and `browser` environments.
## Usage
### Basic usage
`lahze` can be initialized using 3 arguments: date, format of the date and locale.
After that `lahze` can manipulate and display date between locales easily.
```js
import lahze from 'lahze';lahze('1398/10/10', 'YYYY/MM/DD', 'fa').format('YYYY/MM/DD', 'en'); // 2019/12/31
```* Date can be on of the following items:
1. Instance of `Date` object
2. String with a specific format
3. Timestamp**If date is not specified or null, it will be equal to today.**
* Format accepted types are as followed:
* `YYYY`: full year (4 digits).
* `YY`: short year (last 2 digits).
* `MM`: full month (2 digits).
* `M`: short month (1-2 digit).
* `DD`: full day (2 digits).
* `D`: short day (1-2 digits).
* `HH`: full hours (2 digits).
* `H`: short hours (1-2 digits).
* `mm`: full minutes (2 digits).
* `m`: short minutes (1-2 digits).
* `ss`: full seconds (2 digits).
* `s`: short seconds (1-2 digits).
* Supported delimiters are `\`, `/`, `-`, `:`.**If format is not specified or null, it will be equal to whatever `Date` object accepts.**
* Locale can be either fa or en (defaults en).
After initializing `lahze` with the desired arguments, you can easily manupulate date and display it with a specific format at the end.
### Manipulating
#### Setters
##### setFullYear
This method accepts 4-digits year as the first argument and locale as it's second argument which specifies the locale of the first argument (defaults to initial locale which was specified by creating `lahze` instance).
```js
lahze('1398/10/10', 'YYYY/MM/DD', 'fa').setFullYear(1399, 'fa'); // 1399/10/10
```##### setMonth
This method accepts month (value between 1 and 12) as the first argument and locale as it's second argument which specifies the locale of the first argument (defaults to initial locale which was specified by creating `lahze` instance).
```js
lahze('1398/10/10', 'YYYY/MM/DD', 'fa').setMonth(12, 'fa'); // 1398/12/10
```##### setDay
This method accepts day of the month (value between 1 and 31) as the first argument and locale as it's second argument which specifies the locale of the first argument (defaults to initial locale which was specified by creating `lahze` instance).
```js
lahze('1398/10/10', 'YYYY/MM/DD', 'fa').setDay(5, 'fa'); // 1398/10/5
```##### setHours
This method accepts hours (value between 0 and 23) as the first argument.
```js
lahze('1398/10/10 12:00:00', 'YYYY/MM/DD HH:mm:ss', 'fa').setHours(5); // 1398/10/10 5:00:00
```##### setMinutes
This method accepts minutes (value between 0 and 59) as the first argument.
```js
lahze('1398/10/10 12:00:00', 'YYYY/MM/DD HH:mm:ss', 'fa').setHours(50); // 1398/10/10 12:50:00
```##### setSeconds
This method accepts minutes (value between 0 and 59) as the first argument.
```js
lahze('1398/10/10 12:00:00', 'YYYY/MM/DD HH:mm:ss', 'fa').setHours(10); // 1398/10/10 12:00:10
```#### Getters
##### getFullYear
This method returns full year (4-digits) of the `lahze` instance.
This method accepts locale as the first argument which specifies the locale of the returning value (defaults to initial locale which was specified by creating `lahze` instance).
```js
lahze('1398/10/10', 'YYYY/MM/DD', 'fa').getFullYear('en'); // 2019lahze('1398/10/10', 'YYYY/MM/DD', 'fa').getFullYear('fa'); // 1398
```##### getMonth
This method returns month number (1-12) of the `lahze` instance.
This method accepts locale as the first argument which specifies the locale of the returning value (defaults to initial locale which was specified by creating `lahze` instance).
```js
lahze('1398/10/10', 'YYYY/MM/DD', 'fa').getMonth('fa'); // 10lahze('1398/10/10', 'YYYY/MM/DD', 'fa').getMonth('en'); // 12
```##### getDay
This method returns day of the month of the `lahze` instance.
This method accepts locale as the first argument which specifies the locale of the returning value (defaults to initial locale which was specified by creating `lahze` instance).
```js
lahze('1398/10/10', 'YYYY/MM/DD', 'fa').getDay('fa'); // 10lahze('1398/10/10', 'YYYY/MM/DD', 'fa').getDay('en'); // 31
```##### getHours
This method returns hours of the month of the `lahze` instance.
```js
lahze('1398/10/10 12:00:00', 'YYYY/MM/DD HH:mm:ss', 'fa').getHours(); // 12
```##### getMinutes
This method returns hours of the month of the `lahze` instance.
```js
lahze('1398/10/10 12:20:00', 'YYYY/MM/DD HH:mm:ss', 'fa').getMinutes(); // 20
```##### getSeconds
This method returns hours of the month of the `lahze` instance.
```js
lahze('1398/10/10 12:00:50', 'YYYY/MM/DD HH:mm:ss', 'fa').getSeconds(); // 50
```## Advanced manipulation
You can set the year, month or day in a locale and get it in the opposite locale:
```js
lahze('1398/10/10', 'YYYY/MM/DD', 'fa').setMonth(11, 'en').getMonth('fa'); // 8
```### Display
`lahze` can return date in the given format with the desired locale:
```js
lahze('1398/10/10', 'YYYY/MM/DD', 'fa').format('YYYY/MM/DD', 'en'); // 2019/12/31
```**Supported formats are listed above.**
## License
MIT