jQuery UI DateRangePicker

A jQuery UI widget similar to the date range picker used in Google Analytics; supports multiple months, custom preset ranges and smart positioning; ThemeRoller-ready and mobile-friendly.

The Basics

DateRangePicker can take a regular input element like this:

and turn it into:

Example Code

  1. <head>
  2. <link href="jquery-ui.min.css" rel="stylesheet">
  3. <link href="jquery.comiseo.daterangepicker.css" rel="stylesheet">
  4. <script src="jquery.min.js"></script>
  5. <script src="jquery-ui.min.js"></script>
  6. <script src="moment.min.js"></script>
  7. <script src="jquery.comiseo.daterangepicker.js"></script>
  8. <script>
  9. $(function() { $("#e1").daterangepicker(); });
  10. </script>
  11. </head>
  12. <body>
  13. <input id="e1" name="e1">
  14. </body>

Multiple Months

You can specify the number of months shown (the default is 3):

Example Code

  1. $("#e2").daterangepicker({
  2. datepickerOptions : {
  3. numberOfMonths : 2
  4. }
  5. });

Placeholders

A placeholder value is defined and will be displayed until a selection is made:



Example Code

  1. $("#e3").daterangepicker({
  2. initialText : 'Select period...'
  3. });

Custom Preset Ranges

DateRangePicker supports custom preset ranges to serve your needs (eg date ranges in the future):

Example Code

  1. $("#e4").daterangepicker({
  2. presetRanges: [{
  3. text: 'Today',
  4. dateStart: function() { return moment() },
  5. dateEnd: function() { return moment() }
  6. }, {
  7. text: 'Tomorrow',
  8. dateStart: function() { return moment().add('days', 1) },
  9. dateEnd: function() { return moment().add('days', 1) }
  10. }, {
  11. text: 'Next 7 Days',
  12. dateStart: function() { return moment() },
  13. dateEnd: function() { return moment().add('days', 6) }
  14. }, {
  15. text: 'Next Week',
  16. dateStart: function() { return moment().add('weeks', 1).startOf('week') },
  17. dateEnd: function() { return moment().add('weeks', 1).endOf('week') }
  18. }],
  19. applyOnMenuSelect: false,
  20. datepickerOptions: {
  21. minDate: 0,
  22. maxDate: null
  23. }
  24. });

Programmatic Control

DateRangePicker supports methods that allow programmatic control of the component:

Example Code

  1. $("#e5").daterangepicker();
  2. $("#e5_get").click(function () {
  3. alert("Selected range is: " + JSON.stringify($("#e5").daterangepicker("getRange")));
  4. });
  5. $("#e5_gets").click(function () { alert("Input value is: " + $("#e5").val());});
  6. $("#e5_set").click(function () {
  7. var yesterday = moment().subtract('days', 1).startOf('day').toDate();
  8. $("#e5").daterangepicker("setRange", {start: yesterday});
  9. });
  10. $("#e5_cl").click(function() { $("#e5").daterangepicker("clearRange"); });
  11. $("#e5_open").click(function () { $("#e5").daterangepicker("open"); });
  12. $("#e5_close").click(function () { $("#e5").daterangepicker("close"); });

Lifecycle


Example Code

  1. $("#e6").daterangepicker();
  2. $("#e6_init").click(function() {
  3. $("#e6").daterangepicker();
  4. });
  5. $("#e6_destroy").click(function() {
  6. $("#e6").daterangepicker("destroy");
  7. });

Events

open is triggered when the dropdown opens.

close is triggered when the dropdown closes.

change is triggered when the date range changes.

clear is triggered when the clear button is used.

cancel is triggered when the cancel button is used.



Event Log

    Example Code

    1. function log(e) {
    2. $("#event_log").append($("<li>"+e+"</li>"));
    3. }
    4. // using callbacks
    5. $("#e7").daterangepicker({
    6. open: function(event, data) { log('open') },
    7. change: function(event, data) { log('change') },
    8. clear: function(event, data) { log('clear') },
    9. cancel: function(event, data) { log('cancel') }
    10. });
    11. // using events
    12. $("#e7").on('daterangepickerclose', function(event, data) { log('close') });
    13. // a change event is also triggered on the original element
    14. $("#e7").on('change', function(event) { log('input element changed') });

    Options

    Option Type Default Description
    presetRanges array see source

    Array of objects. Each object describes an item in the presets menu and must have the following properties:

    Property Type Description
    text string the label of the menu option.
    dateStart function returning a moment the start of the preset date range
    dateEnd function returning a moment the end of the preset date range
    initialText string 'Select date range...' Placeholder text - shown when no date range is selected.
    icon string 'ui-icon-triangle-1-s' CSS class of the icon shown inside the trigger button.
    applyButtonText string 'Apply' Label of the Apply button. If the label is empty string the button will not be rendered.
    clearButtonText string 'Clear' Label of the Clear button. If the label is empty string the button will not be rendered.
    cancelButtonText string 'Cancel' Label of the Cancel button. If the label is empty string the button will not be rendered.
    rangeSplitter string ' - ' String used between the start and end dates.
    dateFormat string 'M d, yy' Displayed date format. See available formats.
    altFormat string 'yy-mm-dd' Submitted date format - used inside JSON { "start": "...", "end": "..." }.
    verticalOffset int 0 Vertical offset of the dropdown (measured from just below/above the trigger button). Useful for custom borders.
    mirrorOnCollision boolean true Use a mirrored layout (calendar followed by presets menu) when there is not enough space on the right and the dropdown opens to the left.
    autoFitCalendars boolean true Override the numberOfMonths from datepickerOptions in order to fit widget width inside the viewport.
    applyOnMenuSelect boolean true Use auto-apply when a preset date range is selected from the menu.
    datepickerOptions object see source Object containing the options used to initialize the jQuery UI datepicker widget. See all available options.
    open function null Callback that executes when the dropdown opens.
    close function null Callback that executes when the dropdown closes.
    change function null Callback that executes when the date range changes.
    clear function null Callback that executes when the "Clear" button is used.
    cancel function null Callback that executes when the "Cancel" button is used.
    onOpen function null deprecated Callback that executes when the dropdown opens.
    onClose function null deprecated Callback that executes when the dropdown closes.
    onChange function null deprecated Callback that executes when the date range changes.
    onClear function null deprecated Callback that executes when the clear button is used.

    Methods

    Option Return Type Description
    open() jQuery (plugin only) Opens the dropdown.
    close() jQuery (plugin only) Closes the dropdown.
    setRange(range) jQuery (plugin only)

    Sets the selected date range.

    Parameter Type Description
    range Object

    the date range.

    Property Type Description
    start Date start of date range.
    end Date end of date range; optional - start is used by default.

    Always use start-of-day for any Date values.

    getRange() Object Gets the selected date range (the object has the same properties as above).
    clearRange() jQuery (plugin only) Clears the selected date range.
    destroy() jQuery (plugin only) Removes the date range picker functionality completely. This will return the element back to its pre-init state, preserving any selected date range.
    widget() jQuery Returns a jQuery object containing the dropdown.

    Events

    Event Description
    open Fired when the dropdown opens.
    close Fired when the dropdown closes.
    change Fired when the selected date range is changed.
    clear Fired when the "Clear" button is used.
    cancel Fired when the "Cancel" button is used.