jQuery.datetextentry: Options

The following examples illustrate the use of various options

Description Example

Default behaviour - select a plain HTML text <input> element and transform it into a date text entry widget.

$('#date1').datetextentry();

Change field order and separator.

$('#date2').datetextentry({
    field_order : 'YMD',
    separator   : '-'
});

Disable tooltips - leaving only field hints.

$('#date3').datetextentry({
    show_tooltips : false,
    show_hints    : true
});

Disable field hints - leaving only tooltips.

$('#date4').datetextentry({
    show_tooltips : true,
    show_hints    : false
});

Disable tooltips and re-position error box for messages below the widget rather than to the right.

$('#date5').datetextentry({
    show_tooltips : false,
    errorbox_x    : -135,
    errorbox_y    : 28
});

Mark field as required, with optional custom message.

$('#date6').datetextentry({
    is_required      : true,
    E_REQUIRED_FIELD : 'Please enter a date'
});

Specify allowable date range using maximum and minimum dates.

$('#date7').datetextentry({
    min_date         : '1970-01-01',
    min_date_message : 'Please select a date in the 1970s',
    max_date         : '1979-31-12',
    max_date_message : 'Please select a date in the 1970s',
});

Specify allowable date range using a minimum year - with the default message; and using a function to calculate the maximum date.

$('#date8').datetextentry({
    min_year         : '2000',
    max_date         : function() { return this.get_today(); },
    max_date_message : 'Date must not be in the future'
});

Note: Your function should return an object like:
{ day: '02', month: '06', year: '2012' }
When the function is called, this will point to the datetextwidget object, which provides a get_today() method returning the current date in the required format.

Use a custom validation function to apply arbitrary rules.

$('#date9').datetextentry({
    custom_validation : function(valid) {
        if(valid.year === '1983'  &&  valid.date.getDay() === 2) {
            return;
        }
        throw "Please select a Tuesday in 1983";
    }
});

Your code can interact with the datetextentry widget after it has been initialised. You can set and clear the date value as well as moving focus to the widget's first field:

$('#date10').datetextentry();

$('#launch-dates li').click(function() {
    $('#date10').datetextentry('set_date', $(this).data('date'));
});

$('#btn-clear').click(function() {
    $('#date10').datetextentry('clear');
});

$('#btn-focus').click(function() {
    $('#date10').datetextentry('focus');
});

Select a launch date:

  • Apollo 1
  • Apollo 7
  • Apollo 8
  • Apollo 9
  • Apollo 10
  • Apollo 11
  • Apollo 12
  • Apollo 13
  • Apollo 14
  • Apollo 15
  • Apollo 16
  • Apollo 17

Dynamically add/remove datetextentry functionality.

$('#btn-init').click(function(e) {
    $('#date11').datetextentry();
});

$('#btn-destroy').click(function(e) {
    $('#date11').datetextentry('destroy');
});

Supply a callback function to be run when a valid date is entered.

$('#date12').datetextentry({
    on_change : function(date_str) {
        $('#valid-date12').text(date_str);
    }
});
Validated date:

Supply a callback function to be run when the error status changes - in this case used to put the field label in 'error' mode and override the default display of error messages.

$('#date13').datetextentry({
    show_errors: false,
    on_error : function(msg) {
        $('label[for=date13]')
          .toggleClass('error', msg !== '')
          .find('.error-text').text(msg);
    }

});

Switch date widget into read-only mode or back to read/write mode.

$('#date14').datetextentry({});

$('#btn-readonly').click(function(e) {
    $('#date14').datetextentry('set_readonly', true);
});

$('#btn-readwrite').click(function(e) {
    $('#date14').datetextentry('set_readonly', false);
});

Validate fields and set custom error message

$('#date15a').datetextentry({is_required: true});
$('#date15b').datetextentry({is_required: true});

$('#date15-form').submit(function(e) {
    var all_valid = true;
    var start_date =  $('#date15a').val();
    if(start_date === '') {
        $('#date15a').datetextentry('set_error', 'Start date is required');
        all_valid = false;
    }
    var end_date =  $('#date15b').val();
    if(end_date === '') {
        $('#date15b').datetextentry('set_error', 'End date is required');
        all_valid = false;
    }
    if(all_valid && start_date >= end_date) {
        $('#date15b').datetextentry('set_error', 'End date must be after start date');
        all_valid = false;
    }
    if(!all_valid) {
        e.preventDefault();
    }
});