A jQueryplugin
that attaches a popup calendar to your input fields or shows an
inline calendar for selecting individual dates or date ranges.
For support of other world calendars, and a datepicker that works with them,
see the jQuery Calendars plugin.
For date entry via a spinner use the jQuery Date Entry plugin.
Complement this plugin with the jQuery Time Entry plugin, or
combine date and time entry with the jQuery Date/Time Entry plugin.
The current version is 5.1.0 and is available
under the MIT licence.
For more detail see the documentation reference page.
Or see a minimal page that you could
use as a basis for your own investigations.
This plugin formed the basis for the
jQuery UI Datepicker.
It is made available as a separate plugin because the jQuery UI version
desired simplified functionality. It was originally developed by
Marc Grabanski.
A datepicker can easily be added as a popup to a text field
or inline in a division or span with appropriate default settings.
The popup shows when the field gains focus and is closed by clicking
on the Close link or clicking anywhere else on the page.
You can also remove the datepicker widget if it is no longer required.
Processed fields are marked with a class of is-datepick
and are not re-processed if targeted a second time.
A note on Date - the JavaScript Date constructor expects
the year, month, and day as parameters. However, the month ranges from 0 to 11.
To make explicit what date is intended (does a month of 3 mean March or April?)
I specify the month from 1 to 12 and manually subtract the 1.
Thus the following denotes 25 December, 2014.
$(selector).datepick({minDate: new Date(2014, 12-1, 25)});
Invocation
By default a popup datepicker appears when its input field gains focus.
You can configure an external trigger in addition to or instead of the default.
Clicking on the trigger toggles the popup open and closed.
You can also control the animation used to display the datepicker and
its duration. There are three standard animations (show,
fadeIn, slideDown) as well as the ones from the
jQuery UI effects package.
Additional options for the latter may be specified with the
showOptions setting. Use '' for no animation.
You can specify the format in which the date is to appear.
Use a combination of the field formats below, which may vary depending
on the localisation used ('mm/dd/yyyy' by default).
You must quote (using ') any text that matches these formats
to avoid it being replaced.
You can retrieve or supply the date(s) for the datepicker by using
the 'getDate' or 'setDate' commands. The dates are returned
as an array (possibly empty) of Date objects.
When setting the dates you can provide one value, two values (for a range),
or mutliple values in an array. Each value may be a Date,
the date as a string in the current date format, a number of days relative to today (+5),
or a string to specify one or more units and periods relative to today ('+1m -1d').
For the last, use 'd' for days, 'w' for weeks, 'm' for months, or 'y' for years.
$('#getDates').click(function() {
var dates = $('#' + $('#getSetSelect').val()).datepick('getDate');
var value = '';
for (var i = 0; i < dates.length; i++) {
value += (i == 0 ? '' : ',') + $.datepick.formatDate(dates[i]);
}
$('#getSetValue').val(value || 'none');
});
$('#setDates').click(function() {
var dates = $('#getSetValue').val().split(',');
$('#' + $('#getSetSelect').val()).datepick('setDate', dates);
});
Default Date
You can set the default date to display when no other is set in the datepicker.
In addition, you can set this date to be automatically selected.
Without any modification, the default date is today.
The default date can be set as an absolute date as either a Date
or a string (in the current date format). Or it may be set as a relative value
by using a simple number to offset from today's date a given number of days (+5),
or a string to specify one or more units and periods ('+1m -1d').
Use 'd' for days, 'w' for weeks, 'm' for months, or 'y' for years.
Actual date - January 1, 2014:
$('#defaultActualPicker').datepick({
defaultDate: new Date(2014, 1 - 1, 1), showTrigger: '#calImg'});
You can set minimum and/or maximum dates within which a date may be chosen.
These dates can be set as an absolute date as either a Date
or a string (in the current date format). Or they may be set as relative values
by using a simple number to offset from today's date a given number of days,
or a string to specify one or more units and periods.
Use 'd' for days, 'w' for weeks, 'm' for months, or 'y' for years.
Jan 1, 2012 to Jan 1, 2014:
$('#minmaxPicker').datepick({
minDate: new Date(2012, 1 - 1, 26),
maxDate: new Date(2014, 1 - 1, 26), showTrigger: '#calImg'});
You have some control over the behaviour and style of individual days
shown in the datepicker by preventing days being selected,
by changing their style, by changing their description,
or by replacing the cell content.
The onDate function is called for each day shown
and returns an object with (optionally) a selectable flag (selectable),
any CSS styles (dateClass),
a description (title), and /or new content (content).
The datepicker can be configured to allow the selection of a date range within
the one picker. The first click selects the start of the range and the second
selects the end.
The datepicker can be configured to allow the selection of multiple individual dates.
Clicking on an already selected date de-selects it. The datepicker automatically
closes when the maximum number of allowed dates has been chosen.
Modify the controls and month/year navigation, as shown below.
Control inclusion and/or placement are defined in the renderer for the datepicker.
Thereafter, several settings affect their appearance.
You can override parts of the default renderer by creating a new empty renderer
and extending it with the default values and then the overridden ones.
Controls appearing on the datepicker are defined as commands -
encapsulating the displayed text, a triggering keystroke, whether or not
it is enabled, a representative date, and the actual action itself.
They are positioned in the renderer as substitution points of the form
'{link:name}' or '{button:name}',
depending on whether they are to show as links or buttons.
You can override parts of the default commands by creating a new
empty command object and extending it with the default values
($.datepick.commands) and then the overridden settings.
Determine whether or not the month and year may be directly selected.
Specify which years appear in the drop-down - by default it shows
10 years before and after the currently selected date.
Note that the yearRange setting only applies to the
year drop-down. It does not restrict date selection directly.
You must still provide minDate and/or
maxDate settings if restrictions apply.
The jquery.datepick.ext.js module provides additional
functionality to extend the datepicker. These include onShow
callbacks that enhance the datepicker. If you need multiple onShow
functions, use the $.datepick.multipleEvents function and
pass the relevant handlers to it.
Instead of configuring fields via parameters to the datepicker instantiation,
you can specify them inline. You must encode the settings in the data-datepick attribute.
You can localise the datepicker for other languages and regional differences (over 70
now available). The datepicker defaults to US English with a date format of mm/dd/yyyy.
:
$('#l10nPicker').datepick($.extend({
showTrigger: '#calImg',
altField: '#l10nAlternate', altFormat: 'DD, d MM, yyyy'},
$.datepick.regionalOptions['fr']));
$('#l10nLanguage').change(function() {
var language = $(this).val();
$.localise('js/jquery.datepick', language);
$('#l10nPicker').datepick('option', $.datepick.regionalOptions[language]);
$.datepick.setDefaults($.datepick.regionalOptions['']);
});
Some localisations read right-to-left.
:
$('#rtlPicker').datepick($.extend({
showTrigger: '#calImg',
altField: '#rtlAlternate', altFormat: 'DD, d MM, yyyy'},
$.datepick.regionalOptions['ar']));
$('#rtlLanguage').change(function() {
var language = $(this).val();
$.localise('js/jquery.datepick', language);
$('#rtlPicker').datepick('option', $.datepick.regionalOptions[language]);
$.datepick.setDefaults($.datepick.regionalOptions['']);
});
You need to load the appropriate language packages for the datepicker.
The latter adds a language set ($.datepick.regionalOptions[langCode]) and
automatically sets this language as the default for all datepicker fields.
The datepicker uses a templating mechanism to render its layout.
So it is easy to change the structure of the datepicker to suit your needs:
from minor changes such as
adding or removing
controls, to major adjustments that drastically alter its appearance.
Combine the layout with appropriate CSS to create your datepicker.
The jquery.datepick.ext.js module also
defines a renderer that produces the standard structure, but using the
ThemeRoller
classes to help blend your datepicker with other
jQuery UI components.
Don't forget to load the appropriate ThemeRoller CSS,
along with the corresponding local overrides:
Datepicker can be integrated with Jörn Zaefferer's
validation plugin by
adding the jquery.datepick.validation.js extension to your page.
One new validation is defined (dpDate) for basic date checking.
It automatically handles date ranges and multiple dates, checks against any
minDate and/or maxDate settings, and calls any
onDate callback to verify selectability. It may be added as a class
to your datepicker fields, or may be defined in the validate settings.
Another new validation (dpCompareDate) lets you compare one date field
against another date - either the value of another datepicker field,
a specific date, or today.
There is also a custom errorPlacement function defined so that
the error messages appear after any trigger button or image
(or before them if using a right-to-left localisation).
You can override the validation error messages through the messages
setting of the validation plugin, or globally via the datepicker
setDefaults function with any or all of the following settings:
validateDate, validateDateMin, validateDateMax,
validateDateMinMax, validateDateCompare,
validateDateToday, validateDateOther,
validateDateEQ, validateDateNE, validateDateLT,
validateDateGT, validateDateLE, validateDateGE.
Date Functions
Datepicker provides a number of functions to work with dates.
The constructor for a JavaScript Date expects the year, month, day,
and (optionally) the hour, minute, and second. The month must be in the
range 0 to 11 rather than the normal 1 to 12. So to avoid confusion in my code
(does a month of 3 mean March or April?) I always use the 1 to 12 value and
explicitly subtract the 1:
var d = new Date(2014, 1 - 1, 26);
Alternately, you can use the datepicker newDate function
without having to worry about the month:
var d = $.datepick.newDate(2014, 1, 26);
This function also zeroes out any time information and makes
adjustments for certain daylight saving cutovers.
For today's date use $.datepick.today().
Other functions include the following:
Format date:
=
$('#formatSpec').change(reformatDate);
$('#formatDate').datepick({onSelect: reformatDate}).
datepick('setDate', new Date());
function reformatDate() {
$('#formatOutput').val($.datepick.formatDate(
$('#formatSpec').val(), $('#formatDate').datepick('getDate')[0]));
}
$('#doyDate').datepick({onSelect: function(dates) {
$('#doyDays').val($.datepick.dayOfYear(dates[0]));
}}).
datepick('setDate', new Date());
Set year/month/day:
=
$('#setDay,#setMonth,#setYear').change(function() {
var date = $.datepick.day(
$.datepick.month(
$.datepick.year(
$.datepick.today(), $('#setYear').val()),
$('#setMonth').val()),
$('#setDay').val());
$('#setDate').val($.datepick.formatDate(date));
}).
change();
Add periods:
+
=
$('#addDate').datepick({onSelect: addPeriods}).
datepick('setDate', new Date());
$('#addAmount,#addPeriod').change(addPeriods);
function addPeriods() {
var date = new Date($('#addDate').datepick('getDate')[0].getTime());
$.datepick.add(date, parseInt($('#addAmount').val(), 10), $('#addPeriod').val());
$('#addedDate').val($.datepick.formatDate(date));
}
Compatibility
Version 4.0.0 was a major update to the datepicker.
As such, several compatibility issues arise when upgrading from version
3.7.x:
dateFormat years have changed: use 'yy' for two digit year
or 'yyyy' for four digit year.
showOn, buttonText, buttonImage, and
buttonImageOnly settings are replaced by
showOnFocus and showTrigger settings.
duration setting is replaced by the showSpeed setting.
numberOfMonths setting is replaced by the monthsToShow
setting and showCurrentAtPos setting is replaced by the
monthsOffset setting.
stepMonths setting is replaced by the monthsToStep
setting and stepBigMonths setting is replaced by the
monthsToJump setting.
changeYear setting is no longer available while the
changeMonth setting now controls both drop-downs.
showDefault setting is replaced by the
selectDefaultDate setting.
closeAtTop, gotoCurrent, mandatory,
showBigPrevNext, and showMonthAfterYear
settings are no longer available but the same
functionality can be achieved with the renderer setting.
hideIfNoPrevNext setting is no longer available
but the same functionality can be achieved with the pickerClass
setting and some CSS.
navigationAsDateFormat setting is replaced by the
commandsAsDateFormat setting.
onClose and onSelect functions only receive an
array of Date objects as a parameter.
appendText setting is no longer available but the same
functionality can be achieved using normal jQuery.
useThemeRoller setting is no longer available
but the same functionality can be achieved with the renderer
setting and the themeRollerRenderer object in the extension module.
beforeShow setting is no longer available but similar functionality
can be achieved by using the option command at an earlier time.
changeFirstDay setting is no longer available but the same
functionality can be achieved with the onShow setting
and the changeFirstDay function in the extension module.
showWeeks setting is no longer available but the same
functionality can be achieved with the renderer setting
and the weekOfYearRenderer object in the extension module.
highlightWeek setting is no longer available but the same
functionality can be achieved with the onShow setting
and the highlightWeek function in the extension module.
onHover setting is no longer available but the same
functionality can be achieved with the onShow setting
and the hoverCallback function in the extension module.
showStatus setting is no longer available but the same
functionality can be achieved with the onShow setting
and the showStatus function in the extension module.
Opening the datepicker in a dialog is no longer available but the same
functionality can be achieved by combining the datepicker with the
jQuery UI Dialog plugin.
In the Wild
This tab highlights examples of this plugin in use "in the wild".
WestJet Vacations is your first destination for planning your vacation experience.
WestJet Vacations has a variety of distinctive destinations and deals to choose from.
The datepicker is used in the selection of departing and returning dates.
Website of a travel agent from Bulgaria.
The plugin is used for enriching the search forms throughout the website
and for date picking in the administration area.
The calendar's display was customized using addon .css file.
Also it was localised using the file provided.
Some settings were modified to fit the current needs through an addon .js file.
Home page of Apartments Lozo in Brela, Croatia. Here you can
find accommodation in the beautiful town of Brela, Croatia.
The datepicker is used on the reservations part of the site,
so users can easily pick departure and arrival dates.
It uses CSS for additional styling, and makes use of the
localizations for other languages (there is even Croatian!).
Camping Split Croatia is situated on beautiful coast in middle
Dalmatia, within administrative borders of the east part of city of Split,
in city district Stobreč.
Camp is 6 km (about 3 miles) away from Diocletian's palace and the same
distance is to ancient remains of Salona. It is situated within beautiful
green forest,
sorrounded on two sides by sea and on the third by river mouth of Žrnovnica.
Even on the hottest day there is a mild and refreshing breeze in the camp
because of the camp's position on the penninsula and vicinity of the river with
dense vegetation that creates rich shades.
GiveJet seeks to make private aviation more accessible, more convenient,
and better targeted for your needs. This mission is achieved through priority attention
to our clients, going above and beyond to find the perfect aircraft or jet for your needs,
and by making our team fully available to you. The datepicker form gave us a simple solution
for allowing customers to quickly select dates in large ranges (sometimes months in advance)
with ease! The multiple language releases help us with our translated pages a ton!
To add another example, please contact me (wood.keith{at}optusnet.com.au)
and provide the plugin name, the URL of your site, its title,
and a short description of its purpose and where/how the plugin is used.
Quick Reference
A full list of all possible settings is shown below.
Note that not all would apply in all cases. For more detail see the
documentation reference page.
$(selector).datepick({
pickerClass: '', // CSS class to add to this instance of the datepicker
showOnFocus: true, // True for popup on focus, false for not
showTrigger: null, // Element to be cloned for a trigger, null for none
showAnim: 'show', // Name of jQuery animation for popup, '' for no animation
showOptions: {}, // Options for enhanced animations
showSpeed: '_default', // Duration of display/closure
popupContainer: null, // The element to which a popup calendar is added, null for body
alignment: 'bottom', // Alignment of popup - with nominated corner of input:
// 'top' or 'bottom' aligns depending on language direction,
// 'topLeft', 'topRight', 'bottomLeft', 'bottomRight'
fixedWeeks: false, // True to always show 6 weeks, false to only show as many as are needed
firstDay: null, // First day of the week, 0 = Sunday, 1 = Monday, ...
// defaults to calendar local setting if null
calculateWeek: null, // Calculate week of the year from a date, null for calendar default
monthsToShow: 1, // How many months to show, cols or [rows, cols]
monthsOffset: 0, // How many months to offset the primary month by
monthsToStep: 1, // How many months to move when prev/next clicked
monthsToJump: 12, // How many months to move when large prev/next clicked
changeMonth: true, // True to change month/year via drop-down, false for navigation only
yearRange: 'c-10:c+10', // Range of years to show in drop-down: 'any' for direct text entry
// or 'start:end', where start/end are '+-nn' for relative to today
// or 'c+-nn' for relative to the currently selected date
// or 'nnnn' for an absolute year
shortYearCutoff: '+10', // Cutoff for two-digit year in the current century
showOtherMonths: false, // True to show dates from other months, false to not show them
selectOtherMonths: false, // True to allow selection of dates from other months too
defaultDate: null, // Date to show if no other selected
selectDefaultDate: false, // True to pre-select the default date if no other is chosen
minDate: null, // The minimum selectable date
maxDate: null, // The maximum selectable date
dateFormat: null, // Format for dates, defaults to calendar setting if null
autoSize: false, // True to size the input field according to the date format
rangeSelect: false, // Allows for selecting a date range on one date picker
rangeSeparator: ' - ', // Text between two dates in a range
multiSelect: 0, // Maximum number of selectable dates, zero for single select
multiSeparator: ',', // Text between multiple dates
onDate: null, // Callback as a date is added to the datepicker
onShow: null, // Callback just before a datepicker is shown
onChangeMonthYear: null, // Callback when a new month/year is selected
onSelect: null, // Callback when a date is selected
onClose: null, // Callback when a datepicker is closed
altField: null, // Alternate field to update in synch with the datepicker
altFormat: null, // Date format for alternate field, defaults to dateFormat
constrainInput: true, // True to constrain typed input to dateFormat allowed characters
commandsAsDateFormat: false, // True to apply formatDate to the command texts
commands: this.commands, // Command actions that may be added to a layout by name
// Localisation settings
monthNames: ['January', 'February', 'March', 'April', 'May', 'June',
'July', 'August', 'September', 'October', 'November', 'December'],
monthNamesShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],
dayNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],
dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
dayNamesMin: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],
dateFormat: 'mm/dd/yyyy', // See format options on parseDate
firstDay: 0, // The first day of the week, Sun = 0, Mon = 1, ...
renderer: this.defaultRenderer, // The rendering templates
prevText: '<Prev', // Text for the previous month command
prevStatus: 'Show the previous month', // Status text for the previous month command
prevJumpText: '<<', // Text for the previous year command
prevJumpStatus: 'Show the previous year', // Status text for the previous year command
nextText: 'Next>', // Text for the next month command
nextStatus: 'Show the next month', // Status text for the next month command
nextJumpText: '>>', // Text for the next year command
nextJumpStatus: 'Show the next year', // Status text for the next year command
currentText: 'Current', // Text for the current month command
currentStatus: 'Show the current month', // Status text for the current month command
todayText: 'Today', // Text for the today's month command
todayStatus: 'Show today\'s month', // Status text for the today's month command
clearText: 'Clear', // Text for the clear command
clearStatus: 'Clear all the dates', // Status text for the clear command
closeText: 'Close', // Text for the close command
closeStatus: 'Close the datepicker', // Status text for the close command
yearStatus: 'Change the year', // Status text for year selection
earlierText: ' ▲', // Text for earlier years
laterText: ' ▼', // Text for later years
monthStatus: 'Change the month', // Status text for month selection
weekText: 'Wk', // Text for week of the year column header
weekStatus: 'Week of the year', // Status text for week of the year column header
dayStatus: 'Select DD, M d, yyyy', // Status text for selectable days
defaultStatus: 'Select a date', // Status text shown by default
isRTL: false // True if language is right-to-left
});
$.datepick.regionalOptions[] // Language/country-specific localisations
$.datepick.commands = { // Command actions that may be added to a layout by name
// name: { // The command name, use '{button:name}' or '{link:name}' in layouts
// text: '', // The field in the regional settings for the displayed text
// status: '', // The field in the regional settings for the status text
// // The keystroke to trigger the action
// keystroke: {keyCode: nn, ctrlKey: boolean, altKey: boolean},
// enabled: fn, // The function that indicates the command is enabled
// date: fn, // The function to get the date associated with this action
// action: fn} // The function that implements the action
prev: {...}, // Previous month
prevJump: {...}, // Previous year
next: {...}, // Next month
nextJump: {...}, // Next year
current: {...}, // Currently selected month
today: {...}, // Today's month
clear: {...}, // Clear the datepicker
close: {...}, // Close the datepicker
prevWeek: {...}, // Previous week
prevDay: {...}, // Previous day
nextDay: {...}, // Next day
nextWeek: {...} // Next week
}
$.datepick.defaultRenderer = { // The standard datepicker renderer
picker: '...', // Overall structure
monthRow: '...', // One row of months
month: '...', // A single month
weekHeader: '...', // A week header
dayHeader: '...', // Individual day header
week: '...', // One week of the month
day: '...', // An individual day
monthSelector: '...', // jQuery selector, relative to picker, for a single month
daySelector: '...', // jQuery selector, relative to picker, for individual days
rtlClass: '...', // Class for right-to-left (RTL) languages
multiClass: '...', // Class for multi-month datepickers
defaultClass: '...', // Class for selectable dates
selectedClass: '...', // Class for currently selected dates
highlightedClass: '...', // Class for highlighted dates
todayClass: '...', // Class for today
otherMonthClass: '...', // Class for days from other months
weekendClass: '...', // Class for days on weekends
commandClass: '...', // Class prefix for commands
commandButtonClass: '...', // Extra class(es) for commands that are buttons
commandLinkClass: '...', // Extra class(es) for commands that are links
disabledClass: '...' // Class for disabled commands
}
$.datepick.setDefaults(settings) // Set global defaults
$.datepick.multipleEvents(fns) // Apply multiple callbacks to an event
$.datepick.formatDate(format, date, settings) // Format a date
$.datepick.parseDate(format, value, settings) // Parse a date from a string
// Calculate a date
$.datepick.determineDate(dateSpec, defaultDate, currentDate, dateFormat, settings)
$.datepick.daysInMonth(year, month)
$.datepick.dayOfYear(year, month, day)
$.datepick.iso8601Week(year, month, day) // ISO 8601 week of year
$.datepick.today()
$.datepick.newDate(year, month, day)
$.datepick.year(date, year) // Set year for a date
$.datepick.month(date, month) // Set month for a date
$.datepick.day(date, day) // Set day for a date
$.datepick.add(date, amount, period) // Add periods to a date
$(selector).datepick('option', settings) // Update multiple settings
$(selector).datepick('option', name, value) // Update a single setting
$(selector).datepick('option', name) // Retrieve a current setting
$(selector).datepick('destroy') // Remove datepicker functionality
$(selector).datepick('enable') // Enable datepicker and field
$(selector).datepick('disable') // Disable datepicker and field
$(selector).datepick('isDisabled') // Determine if a datepicker is disabled
$(selector).datepick('show') // Display a popup datepicker
$(selector).datepick('hide') // Close a popup datepicker
$(selector).datepick('clear') // Close a popup datepicker and clear its field
$(selector).datepick('getDate') // Retrieve the selected dates
$(selector).datepick('setDate', dates, endDate) // Set the selected dates
$(selector).datepick('retrieveDate', elem) // Retrieve the date for a selected datepicker element
$(selector).datepick('performAction', action) // Execute a named command
$(selector).datepick('changeMonth', offset) // Move a number of months
$(selector).datepick('showMonth', year, month) // Show a specific month and year
$(selector).datepick('changeDay', offset) // Move a number of days
$(selector).datepick('selectDate', elem) // Select the date for a datepicker element
// And in the extension module
$.datepick.weekOfYearRenderer // Renderer showing week of the year
$.datepick.themeRollerRenderer // Renderer using ThemeRoller styling
$.datepick.themeRollerWeekOfYearRenderer // Renderer combining the above two
$.datepick.noWeekends // onDate callback to not allow weekend dates
$.datepick.changeFirstDay // onShow callback to allow changing the first day of the week
$.datepick.hoverCallback(onHover) // onShow callback to follow date hovers
$.datepick.highlightWeek // onShow callback to highlight a hovered week
$.datepick.showStatus // onShow callback to show a status bar
$.datepick.monthNavigation // onShow callback to navigate to other months/years
$.datepick.selectWeek // onShow callback to select an entire week
$.datepick.selectMonth // onShow callback to select an entire month
Usage
Include the jQuery library in the head section of your page.
Localisation packages are available for download
and should be loaded after the main datepicker code. These packages
automatically apply their settings as global default values.
All of the localisation files are also available in one module:
jquery.datepick.lang.js.