MooTools DatePicker is a nice modular and themable DatePicker. It has many features and options, such as year, month, day or timepicker only modes, min and max dates, Localization and a lot more.
This Plugin makes use of MooTools' Locale and Date plugins in MooTools More, to provide a localized datepicker, as well as easy formatting and parsing Dates.
This DatePicker is a fork of the original MonkeyPhysics DatePicker, and has improved a lot since then. Though it should be (almost) backward compatible.
As of version 1.60 the datepicker will only work with MooTools 1.3.
Below you will find a description and some docs how you can use the datepicker. If you find any weird things, please create a ticket at github or fork and fix it!
The DatePicker consists out of three layers, a Picker class, which can be used to create any form of Picker, a Picker.Attach class, which handles stuff like attaching the Picker to a input or anchor element. Finally there is the DatePicker class, which you'll probably use. Every option of the Picker or Picker.Attach classes can be used in the DatePicker class.
First you need to include the following html tags:
#HTML
<script src="../Source/Locale.en-US.DatePicker.js" type="text/javascript"></script>
<script src="../Source/Picker.js" type="text/javascript"></script>
<script src="../Source/Picker.Attach.js" type="text/javascript"></script>
<script src="../Source/Picker.Date.js" type="text/javascript"></script>
<link href="../Source/datepicker_dashboard/datepicker_dashboard.css" rel="stylesheet">
Then you can simply use, for example:
#JS
new Picker.Date($$('input'), {
timePicker: true,
positionOffset: {x: 5, y: 0},
pickerClass: 'datepicker_dashboard',
useFadeInOut: !Browser.ie
});
Theming is done with CSS files, there are four themes available, which you can find in the Source folder.
Just include the CSS file and set the pickerClass
option.
The DatePicker uses the MooTools More Date Class, which already includes many localized strings. For some specific strings DatePicker has its own localizations, which you can find in the Locale.-.DatePicker.js files. Just include the file in your page with a script tag to use the translations.
Currently the following languages are supported
- af-ZA
- cs-CZ
- de-DE
- en-US
- es-ES
- fr-FR
- he-IL
- it-IT
- nl-NL
- pl-PL
- pt-BR
- ru-RU
You can set the current language with:
#JS
Locale.use('nl-NL');
#JS
var dp = new DatePicker([element, options]);
- element: (element, string, array) The element(s) to attach the datepicker to
- options: (object, optional) The options object
All the options of the Picker and Picker.Attach classes, and:
- minDate: (Date instance, string, defaults to
null
) Minimum date allowed to pick. Blocks anything before. - maxDate: (Date instance, string, defaults to
null
) Maximum date allowed to pick. Blocks anything after. - availableDates: (object, defaults to
null
) When only a few dates should be selectable. An object like{2011: {1: [19, 29, 31], 3: [5, 19, 24]}}
with all the dates (year -> months -> days). - invertAvailable: (boolean, defaults to
false
) Invert theavailableDates
option. - format: (string, defaults to the default localized format) The format to output into the input field. Uses Date.format
- timePicker: (boolean, defaults to 1
false
) Enable/disable timepicker functionality. Hours/Minutes values can be changed using the scrollwheel. - timeWheelStep: (number, defaults to
1
) The number of minutes the minutes field will change in the timepicker when using the scrollwheel, for example 5, 10, 15. The value will always be k * timeWheelStep. - yearPicker: (boolean, defaults to
true
) Enable/disable yearpicker functionality. Makes it much easier to change years. - yearPerPage: (number, defaults to
20
) Amount of years to show in the year-picking view. Be aware that this may affect your layout. - startView: (string, defaults to
days
) The view that will be showed when the picker opens. The options aretime
,days
,months
andyears
- openLastView: (boolean, defaults to
false
) Opens the last opened view after the picker is opened again, instead of thestartView
- pickOnly: (string, defaults to
false
) If you just want to pick a year, month, day or time. The options aretime
,days
,months
andyears
- canAlwaysGoUp: (array, defaults to
['months', 'days']
) The views where you can click the title to go up. The options aretime
,days
,months
andyears
- updateAll (boolean, defaults to
false
) whether or not to update all inputs when selecting a date - weeknumbers (boolean, defaults to
false
) display weeknumbers for thedays
view - months_abbr: (array) An array with the month name abbreviations. If nothing is set, it will automatically use MooTools Locale to get the abbreviations
- days_abbr: (array) An array with the day name abbreviations. If nothing is set, it will automatically use MooTools Locale to get the abbreviations
- years_title: (function, defaults to a function which returns
year + '-' + (year + options.yearsPerPage - 1)
) A function that returns the title for the yearpicker with as arguments the date object and the options object. - months_title: (function, defaults to a function which returns
date.format('%b %Y')
) A function that returns the title for the monthpicker with as arguments the date object and the options object. - days_title: (function, defaults to a function which returns
date.format('%b %Y')
) A function that returns the title for the daypicker with as arguments the date object and the options object. - time_title: (function, defaults to a function which returns
(options.pickOnly == 'time') ? Locale.get('DatePicker.select_a_time') : date.format('%d %B, %Y')
) A function that returns the title for the timepicker with as arguments the date object and the options object.
- onSelect: Will fire when the user has selected a date
#JS
onSelect(date)
- date - A Date object. You could use Date.format to format it into a string. For example to set it into a hidden field which will be sent to the server.
#JS
new DatePicker('inputField', {
timePicker: true,
pickerClass: 'datepicker_jqui',
onSelect: function(date){
myHiddenField.set('value', date.format('%s');
}
});
Selects a date manually.
picker.select(date[, all]);
- date (Date instance) the date instance of the new date
- all (boolean, optional) Whether it should update all inputs (defaults to the updateAll option)
- Picker.Date instance.
The range picker can be used to select date ranges, with a start date and a end date.
#JS
var dp = new Picker.Date.Range([element, options]);
All Picker.Date
options plus:
- getStartEndDate: (function) Parses the two dates in the input field to
Date
instances. Signature:function(input)
- setStartEndDate: (function) Formats the dates and sets the input field value. Signature:
function(input, dates)
- columns: (number, defaults to
3
) Number of columns - footer: (boolean, defaults to
true
) Creates an extra footer element
Picker.Attach handles all the links from elements to the Picker. It handles the onfocus events of input elements etc. The Class itself is not very useful on its own, but it is useful to extend this Class. This class adds a outerclick as well to close the Picker if you click outside the picker.
#JS
new Picker.Attach(attachTo, options);
- toggle: (element, string, array) A collection of elements which will toggle the picker when such a link is clicked.
- togglesOnly: (*boolean, defaults to
true
) If thetoggle
option is set, this option determines if the focus/blur events on the input fields are still added as well. - blockKeydown: (boolean, defaults to
true
) Whether it should block keydown events, so the user can type into the input field or not.
This will attach links and input elements to the picker
#JS
myPicker.attach(attachTo);
- attachTo: (element, string, array) The elements or element to attach to the Picker. Can be a input element for onfocus events or other elements for click events.
This will detach links and input elements from the picker
#JS
myPicker.detach(detach);
- detach: (element, string, array) The elements or element to detach from the Picker. Can be a input element for onfocus events or other elements for click events.
This is a generic Picker Class, which is used for the basic things, like positioning, Fx, open, close, stuff like that.
#JS
new Picker(options);
- pickerClass: (string, defaults to
datepicker
) CSS class for the main datepicker container element. You can use multiple classes by separating them by a space, e.g.class1 class2 class3
- inject: (element, defaults to
document.body
) This is where the Picker element will be injected to. - anitmationDuration: (number, defaults to
400
) Duration of the slide/fade animations in milliseconds. - useFadeInOut: (boolean, defaults to
true
) Whether to fade-in/out the datepicker popup. You might want to set this tofalse
in IE. - positionOffset: (object, defaults to
{x: 0, y: 0}
) Allows you to tweak the position at which the datepicker appears, relative to the input element. Formatted as an object with x and y properties. Values can be negative. - pickerPosition: (string, defaults to
bottom
) If the picker is positioned relative to an element, you can choose to position it top, bottom, left or right. - draggable: (boolean, defaults to
true
) Will make the picker draggable, if Drag from MooTools More is included. - columns: (number, defaults to
1
) Number of columns - footer: (boolean, defaults to
false
) Creates an extra footer element
- open - triggered when the Picker will open (before the fx)
- close - triggered after the Picker is will get closed (before the fx)
- show - triggered when the Picker is shown
- hide - triggered when the Picker is hidden
A method to show the Picker manually, with a Fx.
#JS
dp.show()
Closes the Picker with a Fx.
#JS
dp.close();
Toggles the Picker with a Fx.
#JS
picker.toggle();
Opens the Picker directly.
#JS
dp.show();
Hides the Picker directly.
#JS
dp.hide();
Destroys the Picker
#JS
picker.destroy();
Positions the Picker.
#JS
picker.position(x, y);
// or
picker.position(myElement, where);
- x: (number) Number of pixels from the left
- y: (number) Number of pixels from the top
Or
- myElement - (element) A element the Picker should be positioned relative to.
- where - (string, optional) Position the Picker
left
orright
to the element.
Set the content of the Picker, either elements or text.
#JS
picker.setContent(element, fx);
- element: (element, string) Set the content of the Picker with this value
- fx: (string, optional) Set the content of the picker, and apply it with this Fx. Options: 'fade', 'right', 'left'
Sets the Picker title text.
#JS
picker.setTitle(text);
- text: (string) The text which will be set into the title.