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

@ahmad-wali-sh/jalaali-react-date-picker

v1.0.18

Published

This package is a date picker component for React that supports the Jalaali (Afghan/Shamsi/Persian) calendar system. It provides an easy-to-use interface for selecting a date in the Jalaali calendar and is fully customizable with options for setting the s

Downloads

10

Readme

NPM

Jalaali React Datepicker

Welcome to our date picker for React applications! This package offers a customizable and localized solution for selecting dates in your projects. With support for the Jalaali calendar system, our date picker allows you to easily implement date selection in your React projects, whether you need to select a single date, or range of dates. Get started now by installing the package and integrating it into your React code.

Version NPM Downloads

Installation

To install jalaali-react-date-picker, you will need to have npm or yarn installed on your system. Once you have one of these package managers set up, you can install jalaali-react-date-picker by running the following command:

  npm install --save jalaali-react-date-picker

or

  yarn add jalaali-react-date-picker

This will install the latest version of jalaali-react-date-picker and add it as a dependency to your project.

Usage/Examples

First, import the necessary styles at top of your application:

import "jalaali-react-date-picker/lib/styles/index.css";

DatePicker

The DatePicker component is a standalone calendar picker that allows the user to select a single date.

import { DatePicker } from "jalaali-react-date-picker";

function App() {
  return <DatePicker />;
}

RangePicker

The RangePicker component is a calendar picker that allows the user to select a range of dates.

import { RangePicker } from "jalaali-react-date-picker";

function App() {
  return <RangePicker />;
}

InputDatePicker

The InputDatePicker component is a calendar picker that is displayed as an input field. The user can select a single date by clicking the input field and selecting a date from the calendar picker.

import { InputDatePicker } from "jalaali-react-date-picker";

function App() {
  return <InputDatePicker />;
}

InputRangePicker

The InputRangePicker component is a calendar picker that is displayed as two input fields. The user can select a range of dates by clicking on either of the input fields and selecting a date from the calendar picker.

import { InputRangePicker } from "jalaali-react-date-picker";

function App() {
  return <InputRangePicker />;
}

Live Demo Examples

To see demo examples, run the following command:

  npm run storybook or yarn storybook

Running Tests

To run tests, run the following command:

  npm run test or yarn test

Features

  • Full support for React and server-side frameworks like Next.js: The package is designed to work seamlessly with these technologies, allowing you to easily incorporate it into your project.

  • Custom date highlighting: With this feature, you can define specific dates and highlight them with any color you choose. This is useful for highlighting important dates, events, or deadlines.

  • Complete style customization: The package allows you to fully customize the styles, including colors and style overrides. This means you can match the calendar to the look and feel of your project.

  • Support for both Gregorian and Jalaali (Shamsi) date formats: The package provides support for both formats, giving you the flexibility to use the one that best fits your needs.

Props

The jalaali-react-date-picker package offers a wide range of customizable props for each of the components. Here is a list of the available props for each component:

DatePicker

| Property | Type | Description | | :----------------- | :---------------------------------------------------------------------: | :------------------------------------------------------------------------------------------------------------------------------------ | | value | Moment \| null | The currently selected date. | | defaultValue | Moment \| null | To set default value, if value is undefined or null, the date picker will show default value. | | onChange | (date: Moment \| null, dateString: string) => void | Callback function which will be executed when date changes. | | onDayChange | (day:number) => void | Callback function which will be executed when day changes. | | onMonthChange | (month:MonthValue) => void | Callback function which will be executed when month changes. | | onYearChange | (year:number) => void | Callback function which will be executed when year changes. | | format | string \| (value:Moment) => string | The format is which the selected date should be displayed. Uses moment.js format strings. | | locale | Locale | The locale to be used for localization, while default locale is fa. | | disabledDates | (current:Moment) => boolean | Callback function that can specify the date that cannot be selected | | onModeChange | (mode:Mode) => void | Callback function which will be executed when calendar mode changes. | | panelRender | (date:PanelDate,panelNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for calendar panel component. | | footerRender | (current:Date \| null, footerNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for footer component. | | headerRender | (current:Date \| null, headerNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for header component. | | dayLabelRender | (labels:string[],labelNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom for day labels component. | | highlightDays | Moment[] \| (date:Moment) => boolean | The highlightDays can be used to determines which dates should be highlighted. it accepts array of moment or a callback function. | | highlightWeekend | boolean | If highlightWeekend set to true, its turn weekend days to highlighted. Default is true. | | customColors | ColorSchema | The customColors can be used to overrides the default colors. | | nextIcon | React.ReactNode | custom icon for next month | | prevIcon | React.ReactNode | custom icon for previous month | | superNextIcon | React.ReactNode | custom icon for next year | | superPrevIcon | React.ReactNode | custom icon for previous year | | loading | boolean | If true, renders loading component in calendar instead of caledar panel | | loadingIndicator | React.ReactNode | Set custom loading indicator | | style | React.CSSProperties | styles for root element of calendar panel | | className | string | class for root element of calendar panel |

RangePicker

| Property | Type | Description | | :----------------- | :-----------------------------------------------------------------------------------------: | :------------------------------------------------------------------------------------------------------------------------------------ | | value | [Moment,Moment] \| null | The currently selected range date date. | | defaultValue | [Moment,Moment] | To set default value, if value is undefined or null, the range picker will show default value. | | onChange | (date: [Moment,Moment], dateString: [string,string]) => void | Callback function which will be executed when range dates changes. | | onDayChange | (days:[number,number]) => void | Callback function which will be executed when days changes. | | onMonthChange | (month:[MonthValue,MonthValue]) => void | Callback function which will be executed when months changes. | | onYearChange | (year:[number, number]) => void | Callback function which will be executed when years changes. | | format | string \| (value:[Moment, Moment]) => string | The format is which the selected range dates should be displayed. Uses moment.js format strings. Default is jYYYY-jMM-jDD | | locale | Locale | The locale to be used for localization, while default is fa. | | disabledDates | (current:Moment) => boolean | Callback function that can specify the dates that cannot be selected | | onModeChange | (mode:Mode) => void | Callback function which will be executed when calendar mode changes. | | panelRender | (date:[PanelRange, PanelRange],panelNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for calendar panel component. | | headerRender | (current:[Moment, Moment \| null] \| null, headerNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for header component. | | dayLabelRender | (labels:string[],labelNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom for day labels component. | | highlightDays | Moment[] \| (date:Moment) => boolean | The highlightDays can be used to determines which dates should be highlighted. it accepts array of moment or a callback function. | | highlightWeekend | boolean | If highlightWeekend set to true, its turn weekend days to highlighted. Default is true. | | customColors | ColorSchema | The customColors can be used to overrides the default colors. | | nextIcon | React.ReactNode | custom icon for next month | | prevIcon | React.ReactNode | custom icon for previous month | | superNextIcon | React.ReactNode | custom icon for next year | | superPrevIcon | React.ReactNode | custom icon for previous year | | loading | boolean | If true, renders loading component in calendar instead of caledar panel | | loadingIndicator | React.ReactNode | Set custom loading indicator | | style | React.CSSProperties | styles for root element of calendar panel | | className | string | class for root element of calendar panel |

InputDatePicker

| Property | Type | Description | | :------------------ | :--------------------------------------------------: | :------------------------------------------------------------------------------------------------------------------- | | value | Moment \| null | The currently selected date. | | defaultValue | Moment \| null | To set default value, if value is undefined or null, the date picker will show default value. | | open | boolean | To set open the popup calendar. | | disabled | boolean | To set disable the popup calendar | | error | boolean | If true, the input will indicate an error | | presets | boolean | The preset range dates for quick selection. Default is true. | | renderInput | (field: FieldProps) => ReactNode | Customize date picker input render. | | prefixIcon | React.ReactNode | Input custom prefix icon. | | suffixIcon | React.ReactNode | Input custom suffix icon | | placement | top \| bottom \| right \| left | The position where the popup calendar box pops up. | | format | string \| (value:Moment) => string | The format is which the selected date should be displayed. Uses moment.js format strings. Default is jYYYY-jMM-jDD | | locale | Locale | The locale to be used for localization, while default is fa. | | getPopupContainer | HTMLElement \| (() => HTMLElement) \| string | The mounted node for popup calendar. | | disabledDates | (current:Moment) => boolean | Callback function that can specify the date that cannot be selected | | customColors | ColorSchema | The customColors can be used to overrides the default colors. | | onChange | (date: Moment \| null, dateString: string) => void | Callback function which will be executed when date changes. | | onDayChange | (day:number) => void | Callback function which will be executed when day changes. | | onMonthChange | (month:MonthValue) => void | Callback function which will be executed when month changes. | | onYearChange | (year:number) => void | Callback function which will be executed when year changes. | | onOpenChange | (open: boolean) => void | Callback function, can be executed whether the popup calendar is popped up or closed. | | pickerProps | picker props | Object containing options for changing the picker itself. | | onClear | () => void | Callback function, can be executed when the clear icon is clicked. | | wrapperClassName | string | class for wrapper element of inputs. | | wrapperStyle | React.CSSProperties | styles for wrapper element of inputs. | | |

PickerProps

| Property | Type | Description | | :----------------- | :---------------------------------------------------------------------: | :------------------------------------------------------------------------------------------------------------------------------------ | | panelRender | (date:PanelDate,panelNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for calendar panel component. | | footerRender | (current:Date \| null, footerNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for footer component. | | headerRender | (current:Date \| null, headerNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for header component. | | dayLabelRender | (labels:string[],labelNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom for day labels component. | | highlightDays | Moment[] \| (date:Moment) => boolean | The highlightDays can be used to determines which dates should be highlighted. it accepts array of moment or a callback function. | | highlightWeekend | boolean | If highlightWeekend set to true, its turn weekend days to highlighted. Default is true. | | loading | boolean | If true, renders loading component in calendar instead of caledar panel | | loadingIndicator | React.ReactNode | Set custom loading indicator | | onModeChange | (mode:Mode) => void | Callback function which will be executed when calendar mode changes. | | style | React.CSSProperties | styles for root element of calendar panel | | className | string | class for root element of calendar panel |

InputRangePicker

| Property | Type | Description | | :------------------ | :------------------------------------------------------------: | :-------------------------------------------------------------------------------------------------------------------------- | | value | [Moment,Moment] | The currently selected range date date. | | defaultValue | [Moment,Moment] | To set default value, if value is undefined or null, the range picker will show default value. | | open | boolean | To set open the popup calendar. | | disabled | boolean | To set disable the popup calendar | | error | boolean | If true, the input will indicate an error | | presets | boolean | The preset range dates for quick selection. Default is true. | | placeholder | [string,string] | The placeholder of date inputs. | | prefixIcon | React.ReactNode | Input custom prefix icon. | | suffixIcon | React.ReactNode | Input custom suffix icon | | placement | top \| bottom \| right \| left | The position where the popup calendar box pops up. | | getPopupContainer | HTMLElement \| (() => HTMLElement) \| string | The mounted node for popup calendar. | | disabledDates | (current:Moment) => boolean | Callback function that can specify the date that cannot be selected | | format | string \| (value:[Moment, Moment]) => string | The format is which the selected range dates should be displayed. Uses moment.js format strings. Default is jYYYY-jMM-jDD | | locale | Locale | The locale to be used for localization, while default is fa. | | responsive | desktop \| mobile \| auto | To set responsive, the range picker component is responsed and optimized to device it runs on. Default set to auto. | | separator | React.ReactNode | Set separator between inputs. | | customColors | ColorSchema | The customColors can be used to overrides the default colors. | | rangeProps | range props | Object containing options for changing the range picker itself. | | onChange | (date: [Moment,Moment], dateString: [string,string]) => void | Callback function which will be executed when range dates changes. | | onDayChange | (days:[number,number]) => void | Callback function which will be executed when days changes. | | onMonthChange | (month:[MonthValue,MonthValue]) => void | Callback function which will be executed when months changes. | | onYearChange | (year:[number, number]) => void | Callback function which will be executed when years changes. | | onOpenChange | (open: boolean) => void | Callback function, can be executed whether the popup calendar is popped up or closed. | | onClear | () => void | Callback function, can be executed when the clear icon is clicked. | | wrapperStyle | React.CSSProperties | styles for wrapper element of inputs. | | wrapperClassName | string | class for wrapper element of inputs. |

RangeProps

| Property | Type | Description | | :----------------- | :---------------------------------------------------------------------: | :------------------------------------------------------------------------------------------------------------------------------------ | | panelRender | (date:PanelDate,panelNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for calendar panel component. | | headerRender | (current:Date \| null, headerNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom node for header component. | | dayLabelRender | (labels:string[],labelNode:React.ReactNode) => React.ReactNode | Callback render function used to render custom for day labels component. | | highlightDays | Moment[] \| (date:Moment) => boolean | The highlightDays can be used to determines which dates should be highlighted. it accepts array of moment or a callback function. | | highlightWeekend | boolean | If highlightWeekend set to true, its turn weekend days to highlighted. Default is true. | | loading | boolean | If true, renders loading component in calendar instead of caledar panel | | loadingIndicator | React.ReactNode | Set custom loading indicator | | onModeChange | (mode:Mode) => void | Callback function which will be executed when calendar mode changes. | | style | React.CSSProperties | styles for root element of calendar panel | | className | string | class for root element of calendar panel |

Author

This authors section lists the names and github profiles of the individuals who have contributed to the project. It is a good way to acknowledge the work and efforts of the people involved in the project, and can also make it easier for users to contact the authors if they have questions or want to contribute to the project.

Dependencies

moment.js - A powerful and flexible JavaScript library for manipulating dates and times. We use Moment.js to handle date formatting and manipulation in our project.

License

MIT