npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@webilix/jalali-date-time

v2.0.5

Published

Lightweight library for parsing and formating Jalali date with timezone functionality

Downloads

272

Readme

@webilix/jalali-date-time

Lightweight library for parsing and formating Jalali date with timezone functionality

Table of contents


Installation

npm install --save @webilix/jalali-date-time

Usage JavaScript

// Default configuration
const config = {
    timezone: 'Asia/Tehran',
    locale: 'en',
    fullTextFormat: 'W, D N Y H:I:S',
    titleFormat: 'W, D N Y',
    dateFormat: 'Y-M-D',
    timeFormat: 'H:I:S',
};

// Load modules
const JalaliDateTime = require('@webilix/jalali-date-time');
const jalali = JalaliDateTime(config);

OR

// inline configurations
const jalali = require('@webilix/jalali-date-time')({
    timezone: 'Asia/Tehran',
    locale: 'en',
    fullTextFormat: 'W, D N Y H:I:S',
    titleFormat: 'W, D N Y',
    dateFormat: 'Y-M-D',
    timeFormat: 'H:I:S',
});

OR

// Without configurations / using default values
const jalali = require('@webilix/jalali-date-time')();

Usage TypeScript

// Default configuration
const config = {
    timezone: 'Asia/Tehran',
    locale: 'en',
    fullTextFormat: 'W, D N Y H:I:S',
    titleFormat: 'W, D N Y',
    dateFormat: 'Y-M-D',
    timeFormat: 'H:I:S',
};

// Load modules
import { JalaliDateTime } from '@webilix/jalali-date-time';
const jalali = JalaliDateTime(config);

OR

// Without configurations / using default values
import { JalaliDateTime } from '@webilix/jalali-date-time';
const jalali = JalaliDateTime();

Default Configuration

| Name | Type | Description | Default Value | | -------------- | ------------ | ------------------------------------ | -------------- | | timezone | String | Standard timezone identifier | Asia/Tehran | | locale | Enum en / fa | Numbers locale format (en: 3, fa: ۳) | en | | fullTextFormat | String | Full-Text date format | W, D N Y H:I:S | | titleFormat | String | Date title format | W, D N Y | | dateFormat | String | Date format | Y-M-D | | timeFormat | String | Time format | H:I:S |


Formatting Output

Following characters can be used to specify the format of the outputted date string

| Identifier | Description | Example | | ---------- | ------------------------------- | ------- | | W | Day of Week in persian | یک‌شنبه | | N | Month name in persian | خرداد | | Y | Year (4 digits) | 1398 | | y | Year (2 digits) | 98 | | M | Month number (zerofill) | 03 | | m | Month number | 3 | | D | Day of the month (zerofill) | 07 | | d | Day of the month | 7 | | H | Hour (24-hour format, zerofill) | 01 | | h | Hour (24-hour format) | 1 | | I | Minute (zerofill) | 00 | | i | Minute | 0 | | S | Second (zerofill) | 06 | | s | Second | 6 |


API Features

| Method | Description | | --------------------------- | ------------------------------------------------------- | | now | Current jalali date | | toDate | Jalali date value for an specific date | | toTime | Time value for an specific date/timezone | | toString | Jalali date/time value for an specific date. | | toTitle | Jalali date/time persian title for an specific date | | toFullText | Jalali date/time persian full text for an specific date | | toObject | Jalali date/time object for an specific date | | daysInMonth | Number of days in Jalali calendar for specific month | | calendar | Jalali monthly calendar | | gregorian | Gregorian date string for an specific Jalali date | | timezones | List of Standard timezone identifiers |


now

Current jalali date

Parameters:

| Name | Type | Required | Description | | ------ | --------------------------------------------- | -------- | --------------------- | | config | Configuration Object | No | Result Configurations |

Valid Operators in configration Format are: Y, M, D, H, I, S (in both uppercase and lowercase)

Return Value (String):

Current jalali date.

If format is not specified in configuration then a concatination of dateFormat and timeFormat in Default Configuration (with an space between) will be used.

Sample:

const result = jalali.now();
// 1398-01-23 01:23:45

const result = jalali.now({
    timezone: 'Asia/Tehran',
    locale: 'fa',
    format: 'Y-M-D H:I',
});
// ۱۳۹۸-۰۱-۲۳ ۰۱:۲۳

toDate

Jalali date value for an specific date

Parameters:

| Name | Type | Required | Description | | ------ | --------------------------------------------- | -------- | --------------------- | | date | Date | Yes | Date Value | | config | Configuration Object | No | Result Configurations |

Valid Operators in configration Format are: Y, M, D (in both uppercase and lowercase)

Return Value (String):

Jalali date value for an specific date.

If date parameter is not a valid Javascript Date then TypeError will thrown.

If format is not specified in configuration then the dateFormat in Default Configuration will be used.

Sample:

const result = jalali.toDate(new Date());
// 1398-01-23

const result = jalali.toDate(new Date(), {
    timezone: 'Asia/Tehran',
    locale: 'fa',
    format: 'Y/M/D',
});
// ۱۳۹۸/۰۱/۲۳

toTime

Time value for an specific date/timezone

Parameters:

| Name | Type | Required | Description | | ------ | --------------------------------------------- | -------- | --------------------- | | date | Date | Yes | Date Value | | config | Configuration Object | No | Result Configurations |

Valid Operators in configration Format are: H, I, S (in both uppercase and lowercase)

Return Value (String):

Date value for an specific date/timezone.

If date parameter is not a valid Javascript Date then TypeError will thrown.

If format is not specified in configuration then the timeFormat in Default Configuration will be used.

Sample:

const result = jalali.toTime(new Date());
// 01:23:45

const result = jalali.toTime(new Date(), {
    timezone: 'Asia/Tehran',
    locale: 'fa',
    format: 'H:I',
});
// ۰۱:۲۳

toString

Jalali date/time value for an specific date.

Parameters:

| Name | Type | Required | Description | | ------ | --------------------------------------------- | -------- | --------------------- | | date | Date | Yes | Date Value | | config | Configuration Object | No | Result Configurations |

Valid Operators in configration Format are: Y, M, D, H, I, S (in both uppercase and lowercase)

Return Value (String):

Jalali date/time value for an specific date.

If date parameter is not a valid Javascript Date then TypeError will thrown.

If format is not specified in configuration then a concatination of dateFormat and timeFormat in Default Configuration (with an space between) will be used.

Sample:

const result = jalali.toString(new Date());
// 1398-01-23 01:23:45

const result = jalali.toString(new Date(), {
    timezone: 'Asia/Tehran',
    locale: 'fa',
    format: 'Y-M-D H:I',
});
// ۱۳۹۸-۰۱-۲۳ ۰۱:۲۳

toTitle

Jalali date/time persian title for an specific date.

Parameters:

| Name | Type | Required | Description | | ------ | --------------------------------------------- | -------- | --------------------- | | date | Date | Yes | Date Value | | config | Configuration Object | No | Result Configurations |

Valid Operators in configration Format are: W, N, Y, M, D (in both uppercase and lowercase)

Default locale configuration for this method is fa. Use locale in config parameter to change it. Useing locle in Default Configuration will not effect this method's result

Return Value (String):

Jalali date/time persian title for an specific date.

If date parameter is not a valid Javascript Date then TypeError will thrown.

If format is not specified in configuration then the titleFormat in Default Configuration will be used.

Sample:

const result = jalali.toTitle(new Date());
// جمعه, ۲۳ فروردین ۱۳۹۸

const result = jalali.toTitle(new Date(), {
    timezone: 'Asia/Tehran',
    locale: 'en',
    format: 'W - D N y',
});
// جمعه - 23 فروردین 98

toFullText

Jalali date/time persian full text for an specific date

Parameters:

| Name | Type | Required | Description | | ------ | --------------------------------------------- | -------- | --------------------- | | date | Date | Yes | Date Value | | config | Configuration Object | No | Result Configurations |

Valid Operators in configration Format are: W, N, Y, M, D, H, I, S (in both uppercase and lowercase)

Default locale configuration for this method is fa. Use locale in config parameter to change it. Useing locle in Default Configuration will not effect this method's result

Return Value (String):

Jalali date/time persian full text for an specific date.

If date parameter is not a valid Javascript Date then TypeError will thrown.

If format is not specified in configuration then the fullTextFormat in Default Configuration will be used.

Sample:

const result = jalali.toFullText(new Date());
// ۰۱:۲۳:۴۵ جمعه, ۲۳ فروردین ۱۳۹۸

const result = jalali.toFullText(new Date(), {
    timezone: 'Asia/Tehran',
    locale: 'en',
    format: 'W - D N y ساعت h:I:S',
});
// جمعه - 23 فروردین 98 ساعت 1:23:45

toObject

Jalali date/time object for an specific date

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | -------------- | | date | Date | Yes | Date Value | | timezone | String | No | Timezone Value |

Return Value (Custom Date Object):

Jalali date/time object for an specific date.

If date parameter is not a valid Javascript Date then TypeError will thrown.

Sample:

const result = jalali.toObject(new Date());
/*   {
 *      week: 6,
 *      year: 1398,
 *      month: 1,
 *      day: 23,
 *      hour: 1,
 *      minute: 23,
 *      second: 45
 *   }
 */

dayOfWeek

Week day number in jalali calendar

Starts with Saturday as 0 and ends with Friday as 6

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | -------------- | | date | Date | No | Date Value | | timezone | String | No | Timezone Value |

Return Value (number, 0 - 6):

If date parameter is not a valid Javascript Date then TypeError will thrown.

Sample:

const result = jalali.dayOfWeek();

daysInMonth

Number of days in Jalali calendar for specific month

Parameters:

| Name | Type | Required | Description | | ----- | ------ | -------- | ------------ | | month | String | No | Jalali Month |

Return Value (number):

If month value is not a valid month string (format: Y-M, sample: 1398-01) then TypeError will thrown.

If month value is not specified then current Jalali month will be used instead.

Sample:

const result1 = jalali.daysInMonth('1390-01'); // 31
const result2 = jalali.daysInMonth('1390-07'); // 30
const result3 = jalali.daysInMonth('1390-12'); // 29
const result4 = jalali.daysInMonth('1391-12'); // 30

calendar

Jalali monthly calendar

Parameters:

| Name | Type | Required | Description | | ----- | ------ | -------- | ------------ | | month | String | No | Jalali Month |

Return Value (Jalali Calendar Object):

Jalali monthly calendar info.

If month value is not a valid month string (format: Y-M, sample: 1398-01) then TypeError will thrown.

If month value is not specified then current Jalali month will be used instead.

Sample:

const result = jalali.calendar('1398-01');
/*   {
 *       month: '1398-01',
 *       title: 'فروردین ۱۳۹۸',
 *       weeks:
 *          [
 *              [
 *                  { date: '1397-12-25', month: '1397-12', day: 25 },
 *                  { date: '1397-12-26', month: '1397-12', day: 26 },
 *                  { date: '1397-12-27', month: '1397-12', day: 27 },
 *                  { date: '1397-12-28', month: '1397-12', day: 28 },
 *                  { date: '1397-12-29', month: '1397-12', day: 29 },
 *                  { date: '1398-01-01', month: '1398-01', day: 1 },
 *                  { date: '1398-01-02', month: '1398-01', day: 2 }
 *              ],
 *              [
 *                  { date: '1398-01-03', month: '1398-01', day: 3 },
 *                  { date: '1398-01-04', month: '1398-01', day: 4 },
 *                  { date: '1398-01-05', month: '1398-01', day: 5 },
 *                  { date: '1398-01-06', month: '1398-01', day: 6 },
 *                  { date: '1398-01-07', month: '1398-01', day: 7 },
 *                  { date: '1398-01-08', month: '1398-01', day: 8 },
 *                  { date: '1398-01-09', month: '1398-01', day: 9 }
 *              ],
 *              [
 *                  { date: '1398-01-10', month: '1398-01', day: 10 },
 *                  { date: '1398-01-11', month: '1398-01', day: 11 },
 *                  { date: '1398-01-12', month: '1398-01', day: 12 },
 *                  { date: '1398-01-13', month: '1398-01', day: 13 },
 *                  { date: '1398-01-14', month: '1398-01', day: 14 },
 *                  { date: '1398-01-15', month: '1398-01', day: 15 },
 *                  { date: '1398-01-16', month: '1398-01', day: 16 }
 *              ],
 *              [
 *                  { date: '1398-01-17', month: '1398-01', day: 17 },
 *                  { date: '1398-01-18', month: '1398-01', day: 18 },
 *                  { date: '1398-01-19', month: '1398-01', day: 19 },
 *                  { date: '1398-01-20', month: '1398-01', day: 20 },
 *                  { date: '1398-01-21', month: '1398-01', day: 21 },
 *                  { date: '1398-01-22', month: '1398-01', day: 22 },
 *                  { date: '1398-01-23', month: '1398-01', day: 23 }
 *              ],
 *              [
 *                  { date: '1398-01-24', month: '1398-01', day: 24 },
 *                  { date: '1398-01-25', month: '1398-01', day: 25 },
 *                  { date: '1398-01-26', month: '1398-01', day: 26 },
 *                  { date: '1398-01-27', month: '1398-01', day: 27 },
 *                  { date: '1398-01-28', month: '1398-01', day: 28 },
 *                  { date: '1398-01-29', month: '1398-01', day: 29 },
 *                  { date: '1398-01-30', month: '1398-01', day: 30 }
 *              ],
 *              [
 *                  { date: '1398-01-31', month: '1398-01', day: 31 },
 *                  { date: '1398-02-01', month: '1398-02', day: 1 },
 *                  { date: '1398-02-02', month: '1398-02', day: 2 },
 *                  { date: '1398-02-03', month: '1398-02', day: 3 },
 *                  { date: '1398-02-04', month: '1398-02', day: 4 },
 *                  { date: '1398-02-05', month: '1398-02', day: 5 },
 *                  { date: '1398-02-06', month: '1398-02', day: 6 }
 *              ]
 *          ]
 *   }
 */

gregorian

Gregorian date string for an specific Jalali date

Parameters:

| Name | Type | Required | Description | | ------ | ------ | -------- | ----------- | | jalali | String | Yes | Jalali Date |

Return Value (Gregorian Date Object):

Gregorian date string for an specific Jalali date.

If date parameter is not a valid date string (format: Y-M-D, sample: 1398-01-23 or 1398-1-23) then TypeError will thrown.

Year in date string must be 4 digits otherwise RangeError will thrown.

Month in date string must be between 1 and 12 otherwise RangeError will thrown.

Day in date string must be between 1 and 31 otherwise RangeError will thrown.

Sample:

const result = jalali.gregorian('1398-01-23');
/*   {
 *      year: 2019,
 *      month: 4,
 *      day: 12,
 *      date: '2019-04-12'
 *   }
 */

timezones

List of Standard timezone identifiers

Return Value (Stringp[]):

List of Standard timezone identifiers.

All values in returned list can be use as timezone on all methods

Sample:

const result = jalali.timezones();
/*   [
 *      'Africa/Abidjan',
 *      'Africa/Accra',
 *      'Africa/Addis_Ababa',
 *      'Africa/Algiers',
 *      'Africa/Asmara',
 *      'Africa/Asmera',
 *      'Africa/Bamako',
 *      'Africa/Bangui',
 *      ...
 *   ]
 */

nextDayOfWeek

Next week day according to specific date

Parameters:

| Name | Type | Required | Description | | --------- | ------ | -------- | ----------------------------------------- | | dayOfWeek | Number | Yes | Week day number (Sunday: 0 - Saturday: 6) | | date | Date | No | Date Value | | timezone | String | No | Timezone Value |

Return Value (Date):

If dayOfWeek value is NaN or not between 0, 6 then TypeError will thrown.

If date parameter is not a valid Javascript Date then TypeError will thrown.

Sample:

const result = jalali.nextDayOfWeek(0);
/* 2025-03-22T19:30:00.000Z */

const result = jalali.nextDayOfWeek(2);
/* 2025-03-24T19:30:00.000Z */

nextDayOfMonth

Specific days in next month according to specific date in Jalali calendar

Parameters:

| Name | Type | Required | Description | | ---------- | -------------- | -------- | ------------------------------------------------- | | dayOfMonth | String, number | Yes | Month day value: 'FIRST', 'LAST', number (1 - 31) | | date | Date | No | Date Value | | timezone | String | No | Timezone Value |

Return Value (Date):

If dayOfMonth value is not one of specified values then TypeError will thrown.

If date parameter is not a valid Javascript Date then TypeError will thrown.

Results:

  • FIRST: First day of month
  • LAST: Last day of month
  • DAY: Specific day of month according to date (example: 1400-01-15 > 1400-02-15)

    If date is not valid for next month, first month with valid date will be returned (example: 1400-06-31 > 1401-01-31)

Sample:

const result = jalali.nextDayOfMonth('FIRST');
/* 2025-03-20T20:30:00.000Z */

const result = jalali.nextDayOfMonth('LAST');
/* 2025-04-19T19:30:00.000Z */

nextDayOfYear

Next years date according to specific date in Jalali calendar

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | -------------- | | date | Date | No | Date Value | | timezone | String | No | Timezone Value |

Return Value (Date):

If date parameter is not a valid Javascript Date then TypeError will thrown.

If date is not valid for next year, first year with valid date will be returned (example: 1403-12-30 > 1408-12-30)

Sample:

const result = jalali.nextDayOfYear();
/* 2030-03-19T20:30:00.000Z */

periodHour

Hourly date/time period values based of number of hours

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | --------------- | | hours | Number | Yes | Nomber of hours | | date | Date | No | End Date Value | | timezone | String | No | Timezone Value |

Return Value (Period Object):

If hours value is NaN or less than 1 then TypeError will thrown.

If date parameter is not a valid Javascript Date then TypeError will thrown.

Sample:

const result = jalali.periodHour(3);
/*   {
 *      from: 2021-10-05T01:30:00.000Z,
 *      to: 2021-10-05T04:29:59.999Z,
 *      periods: [
 *        { from: 2021-10-05T01:30:00.000Z, to: 2021-10-05T02:29:59.999Z },
 *        { from: 2021-10-05T02:30:00.000Z, to: 2021-10-05T03:29:59.999Z },
 *        { from: 2021-10-05T03:30:00.000Z, to: 2021-10-05T04:29:59.999Z }
 *      ]
 *    }
 */

periodDay

Daily date/time period values based of number of days

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | -------------- | | days | Number | Yes | Nomber of days | | date | Date | No | End Date Value | | timezone | String | No | Timezone Value |

Return Value (Period Object):

If days value is NaN or less than 1 then TypeError will thrown.

If date parameter is not a valid Javascript Date then TypeError will thrown.

Sample:

const result = jalali.periodDay(7);
/*   {
 *      from: 2021-09-28T20:30:00.000Z,
 *      to: 2021-10-05T20:29:59.999Z,
 *      periods: [
 *        { from: 2021-09-28T20:30:00.000Z, to: 2021-09-29T20:29:59.999Z },
 *        { from: 2021-09-29T20:30:00.000Z, to: 2021-09-30T20:29:59.999Z },
 *        { from: 2021-09-30T20:30:00.000Z, to: 2021-10-01T20:29:59.999Z },
 *        { from: 2021-10-01T20:30:00.000Z, to: 2021-10-02T20:29:59.999Z },
 *        { from: 2021-10-02T20:30:00.000Z, to: 2021-10-03T20:29:59.999Z },
 *        { from: 2021-10-03T20:30:00.000Z, to: 2021-10-04T20:29:59.999Z },
 *        { from: 2021-10-04T20:30:00.000Z, to: 2021-10-05T20:29:59.999Z }
 *      ]
 *   }
 */

periodWeek

Weekly date/time period values based of number of days

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | --------------- | | weeks | Number | Yes | Nomber of weekd | | date | Date | No | End Date Value | | timezone | String | No | Timezone Value |

Return Value (Period Object):

If weeks value is NaN or less than 1 then TypeError will thrown.

If date parameter is not a valid Javascript Date then TypeError will thrown.

Sample:

const result = jalali.periodWeeks(4);
/*   {
 *       from: 2021-09-24T20:30:00.000Z,
 *       to: 2021-10-22T20:29:59.999Z,
 *       periods: [
 *         { from: 2021-09-24T20:30:00.000Z, to: 2021-10-01T20:29:59.999Z },
 *         { from: 2021-10-01T20:30:00.000Z, to: 2021-10-08T20:29:59.999Z },
 *         { from: 2021-10-08T20:30:00.000Z, to: 2021-10-15T20:29:59.999Z },
 *         { from: 2021-10-15T20:30:00.000Z, to: 2021-10-22T20:29:59.999Z }
 *       ]
 *    }
 */

periodMonth

Monthly (jalali month) date/time period values based of number of months

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | ---------------- | | months | Number | Yes | Nomber of months | | date | Date | No | End Date Value | | timezone | String | No | Timezone Value |

Return Value (Period Object):

If months value is NaN or less than 1 then TypeError will thrown.

If date parameter is not a valid Javascript Date then TypeError will thrown.

Sample:

const result = jalali.periodMonth(4);
/*   {
 *      from: 2020-10-21T20:30:00.000Z,
 *      to: 2021-10-22T20:29:59.999Z,
 *      periods: [
 *        { from: 2021-06-21T20:30:00.000Z, to: 2021-07-22T20:29:59.999Z },
 *        { from: 2021-07-22T20:30:00.000Z, to: 2021-08-22T20:29:59.999Z },
 *        { from: 2021-08-22T20:30:00.000Z, to: 2021-09-22T20:29:59.999Z },
 *        { from: 2021-09-22T20:30:00.000Z, to: 2021-10-22T20:29:59.999Z }
 *      ]
 *    }
 */

periodYear

Yearly (jalali year) date/time period values based of number of years

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | --------------- | | years | Number | Yes | Nomber of years | | date | Date | No | End Date Value | | timezone | String | No | Timezone Value |

Return Value (Period Object):

If years value is NaN or less than 1 then TypeError will thrown.

If date parameter is not a valid Javascript Date then TypeError will thrown.

Sample:

const result = jalali.periodYear(4);
/*   {
 *      from: 2019-03-20T20:30:00.000Z,
 *      to: 2023-03-20T20:29:59.999Z,
 *      periods: [
 *        { from: 2019-03-20T20:30:00.000Z, to: 2020-03-19T20:29:59.999Z },
 *        { from: 2020-03-19T20:30:00.000Z, to: 2021-03-20T20:29:59.999Z },
 *        { from: 2021-03-20T20:30:00.000Z, to: 2022-03-20T20:29:59.999Z },
 *        { from: 2022-03-20T20:30:00.000Z, to: 2023-03-20T20:29:59.999Z }
 *      ]
 *   }
 */

Classes

Modify

Modifying date by adding or subtracting year / month / day according to jalali date-time

Create class instance

Parameters:

| Name | Type | Required | Description | | -------- | ------ | -------- | -------------------- | | date | Date | No | Date Value to modify | | timezone | String | No | Timezone Value |

Return Value:

New instance of modify class

Sample:

const modify = new jalali.modify(new Date(), 'Asia/Tehran');
// or
const modify = new jalali.modify();

Change year value

Parameters:

| Name | Type | Required | Description | | ------ | ------ | -------- | ----------------------------------------------------------------------- | | change | Number | Yes | Number of years to add (positive numbers) / subtract (negative numbers) |

Return Value:

Instance of modify class with changed values

Sample:

modify.year(10); // Add 10 years to current date
modify.year(-10); // Subtract 10 years from current date

Change month value

Parameters:

| Name | Type | Required | Description | | ------ | ------ | -------- | ------------------------------------------------------------------------ | | change | Number | Yes | Number of months to add (positive numbers) / subtract (negative numbers) |

Return Value:

Instance of modify class with changed values

Sample:

modify.month(50); // Add 50 months to current date
modify.month(-50); // Subtract 50 months from current date

Change day value

Parameters:

| Name | Type | Required | Description | | ------ | ------ | -------- | ---------------------------------------------------------------------- | | change | Number | Yes | Number of days to add (positive numbers) / subtract (negative numbers) |

Return Value:

Instance of modify class with changed values

Sample:

modify.day(150); // Add 150 days to current date
modify.day(-150); // Subtract 150 days from current date

Getting modified date value

| Name | Type | Required | Description | | ---- | -------------- | -------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | time | 'START', 'END' | No | Time of returned dateSTART: Date value will be at the start of day (00:00:00)END: Date value will be at the end of day (23:59:59)Default: Time of date value will not change |

Return Value:

JavaScript Date object

Sample:

const date: Date = modify.toDate('START');
// or
const date: Date = modify.toDate();

Chain methods

Sample:

const modify = new jalali.modify();
// 2025-07-08T22:38:35.000Z

// Adding 1 year and 5 months and subtracting 10 days from current date
// and returning new Date value at the start of modified date
const date: Date = modify.year(1).month(5).day(-10).toDate('START');
// 2025-07-08T20:30:00.000Z

Custom Types

| Type | Usage | | ----------------------------------------------- | ------------------------------------------ | | Configuration Object | Main methods configuration parameter | | Custom Date Object | Result value type for toObject method | | Gregorian Date Object | Result value type for gregorian method | | Period Object | Result value type for period methods |

Configuration Object

Main methods configuration parameter

| Property | Type | Description | | -------- | ------------ | ------------------------------------ | | timezone | String | Standard timezone identifier | | locale | Enum en / fa | Numbers locale format (en: 3, fa: ۳) | | format | String | Return Value Format |

Custom Date Object

Result value type for toObject method

| Property | Type | Description | | -------- | ------ | ------------------------------- | | week | Number | Week Day (saturday=0, friday=6) | | year | Number | Year Value | | month | Number | Month Value | | day | Number | Day Value | | hour | Number | Hour Value | | minute | Number | Minute Value | | second | Number | Second Value |

Jalali Calendar Object

Result value type for calendar method

| Property | Type | Description | | -------------------- | --------------- | ------------------------ | | month | String | Jalali Month Value | | title | String | Jalali Month Title | | weeks | Array of Arrays | Weeks Data | | weeks[*][1-7].date | String | Day values: Jalali Date | | weeks[*][1-7].month | String | Day values: Jalali Month | | weeks[*][1-7].day | Number | Day values: Day Number |

Gregorian Date Object

Result value type for gregorian method

| Property | Type | Description | | -------- | ------ | ------------------------------------- | | year | Number | Year Value | | month | Number | Month Value | | day | Number | Day Value | | date | String | Full Date String (sample: 2019-04-12) |

Period Object

Result value type for period methods

| Property | Type | Description | | -------- | ---------------------------------------- | --------------- | | from | Date | Start of period | | to | Date | End of period | | periods | Array of Object { from: Date, to: Date } | Periods list |


Errors

| Error | Method | Parameter | Message | | ---------- | --------------------------- | --------- | ---------------------------- | | TypeError | toDate | date | Invalid Date | | TypeError | toTime | date | Invalid Date | | TypeError | toString | date | Invalid Date | | TypeError | toTitle | date | Invalid Date | | TypeError | toFullText | date | Invalid Date | | TypeError | toObject | date | Invalid Date | | TypeError | gregorian | jalali | Date is not String | | RangeError | gregorian | jalali | Year must be 4 digits | | RangeError | gregorian | jalali | Month is not between 1, 12 | | RangeError | gregorian | jalali | Day is not between 1, 31 | | TypeError | periodHour | hours | Hours must be bigger than 0 | | TypeError | periodHour | date | Invalid Date | | TypeError | periodDay | days | Days must be bigger than 0 | | TypeError | periodDay | date | Invalid Date | | TypeError | periodMonth | months | Months must be bigger than 0 | | TypeError | periodMonth | date | Invalid Date |


Tests

git clone https://github.com/webilix/jalali-date-time.git
npm install
npm test