There are many great datepickers available on GitHub, however, I didn't find one that really suited my needs. The hardest thing to find is a datepicker that can do a specific combination of features.
Here's a few other reasons:
Of course, no one datepicker will serve all projects since your needs may be different. So I'll be adding more to this API in the near future. You may also suggest changes by forking this repo and creating a pull request or opening an issue.
I am the creator, and currently contribute and maintain this project almost entirely myself. I have reviewed and accepted some pull requests along the way however, and I am happy to review and merge any helpful PRs as soon as I find time. If you want to contribute checkout the "Contributing" section!
Since the goal of this project is to use only vanilla JavaScript and Moment.js, we have only one dependency:
git clone https://github.com/ctrachte/Datepicker.js
Datepicker.js
to implement with pure Vanilla JS, HTML and CSS.Datepicker.html
in your browser of choice to view and test behavior.npm i --save moment-datepicker-js
Import the Datepicker, and move/scope the DatepickerSmall.css and moment.js files in the appropriate places in your project. Below is a basic example component that should work in Next.js or React for simple implementations:
Adjust the options as necessary for your needs, be sure to supply the Datepicker options with the appropriate container HTML element node. See usage section below
1.) You will first need a recent version of Moment.js installed.
2.) Download and add the Datepicker.js and Datepicker.css files to their appropriate directories in your project.
3.) Below are all the options you can enable using Vanilla JS syntax. For implementation in React, see above NPM section
// there should only be this one variable here // to instantiate the class into the container element const testDatepicker = new Datepicker({ containerElement: document.querySelector('.DatepickerContainer'), presetMenu: true, singleDate: false, autoClose: false, timePicker: false, leadingTrailingDates: true, clearDates: true, defaults: false, // militaryTime: false, // max: moment("08/14/2022"), // min: new Date("08/14/2021"), // defaults: [new Date('08/14/2023'),new Date('08/14/2023')], menuOptions: [ { title: 'Today', values: [new Date(), new Date()] } ], startDateLabel: "Reservation Start: ", endDateLabel: "Reservation End: ", // onChange: function () { // console.log("onChange:", this.dates); // }, // onSubmit: function () { // console.log("onSubmit:", this.dates); // }, // onClose: function () { // console.log("onClose:", this.dates); // } });
4.) Adjust the options above to meet the needs of your project, or the project's component you are implementing the datepicker in.
Method Name | Method Description | First Param | Second Param | Example |
---|---|---|---|---|
.value() | Invoke at any time with no parameters to return an array of dates containing start and end date. Invoke with params to set a date range. | Array of Date or Moment objects [new Date(), Moment()] | (String) Moment format "MM/DD/YYYY hh:mm:ss" |
|
.startDate() | Invoke at any time with no parameters to return single start date. Invoke with a single Moment or js Date object to set start date. | JS Date object new Date() Moment object Moment() |
| |
.endDate() | Invoke at any time with no parameters to return single end date. Invoke with a single Moment or js Date object to set end date. | JS Date object new Date() Moment object Moment() |
| |
.closeCalendar() | Invoke at any time to close the calendar UI (pop-up element). | Datepicker.closeCalendar() | ||
.openCalendar() | Invoke at any time to open the calendar UI (pop-up element). | Datepicker.openCalendar() | ||
.resetCalendar() | Invoke at any time to reset the calendar to its default state (determined by initial options). | Datepicker.resetCalendar() | ||
.snapTo(Date(), isVisible) | Invoke at any time to snap the calendar pop-up UI to a specific date. | JS Date object new Date() Moment object Moment() | isVisble - set to - false - if calendar is not visible, or should not be visible currently. | Datepicker.resetCalendar() |
Contributions are greatly appreciated towards the final goal of a perfect datepicker!
git checkout -b feature/AmazingFeature
)git commit -m 'Add some AmazingFeature'
)git push origin feature/AmazingFeature
)Code will be reviewed before being merged. If your code does not quite work or needs revision it may not be merged to the master.
![]() | ![]() | ||||
---|---|---|---|---|---|
Latest ✔ | Latest ✔ | Not supported ❌ | Not tested | Latest ✔ | Latest ✔ |
Want to fund the development of this project? Donate crypto!
3593eFRSHSVEAiwvEvpQnrodFpXPpwwrzx
0x8c1EB41f646b4d7DCE0D3075F2A639E40bC894c3
tz1fji2C1o21Xa6qQxC2hjsHNv7h89RnEkhq
0xaAa1650a9f842F8A0EEa2FD8966BB2bc9144Ea35