Skip to main content

Date Range Picker

The Range Picker component enables users to select a range of dates. It can be used in booking platforms, report filtering, scheduling systems, etc.

Properties

PropertyDescriptionExpected Value
LabelText to display as the label for the field.String (e.g., Select Check-In and Check-Out Dates).
Default start dateSet the start date to be selected by default in the component.Date in correct format (e.g., 01/04/2024).
Default end dateSet the end date to be selected by default in the component.Date in correct format (e.g., 10/04/2024).
FormatDefines the date format. Default date format is DD/MM/YYYY.Date format in ISO 8601 defined formats (e.g., MM/DD/YYYY).

Events

EventDescription
On selectTriggers whenever a start date or end date is selected.
On focusTriggers whenever the user clicks inside the input field.
On blurTriggers whenever the user clicks outside the input field.
info

Check Action Reference docs to get the detailed information about all the Actions.

Component Specific Actions (CSA)

Following actions of component can be controlled using the Component Specific Actions (CSAs), which can be triggered using an event or by using the given RunJS query:

Action
Description
How To Access
setStartDate( )Sets the start date of the selected date range.components.daterangepicker1.setStartDate(date)
clearStartDate( )Clears the selected start date.components.daterangepicker1.clearStartDate()
setEndDate( )Sets the end date of the selected date range. await components.daterangepicker1.setEndDate(date)
clearEndDate( )Clears the selected end date.components.daterangepicker1.clearEndDate()
setDateRange( )Sets both the start and end dates of the selected date range.components.daterangepicker1.setDateRange(startDate, endDate)
clearDateRange( )Clears both the start and end dates.components.daterangepicker1.clearDateRange()
setDisabledDates( )Sets specific dates as disabled, preventing selection.components.daterangepicker1.setDisabledDates([date1, date2])
clearDisabledDates( )Clears all disabled date restrictions.components.daterangepicker1.clearDisabledDates()
setMinDate( )Sets the minimum selectable date.components.daterangepicker1.setMinDate(date)
setMaxDate( )Sets the maximum selectable date.components.daterangepicker1.setMaxDate(date)
setFocus( )Sets the focus of the cursor on the input field.components.daterangepicker1.setFocus()
setBlur( )Removes the focus of the cursor from the input field.components.daterangepicker1.setBlur()
setVisibility()Sets the visibility of the component.components.daterangepicker1.setVisibility()
setLoading()Sets the loading state of the component.components.daterangepicker1.setLoading()
setDisable()Disables the component.components.daterangepicker1.setDisable()

Exposed Variables

Following exposed variables can be dynamically accessed using the given JS query:

Variables
Description
How To Access
endDateHolds the date selected as the end date in the component.{{components.daterangepicker1.endDate}}
startDateHolds the date selected as the start date in the component.{{components.daterangepicker1.startDate}}
labelHolds the value of the component's label.{{components.daterangepicker1.label}}
minDateHolds the value of the minimum date allowed in the component.{{components.daterangepicker1.minDate}}
maxDateHolds the value of the maximum date allowed in the component.{{components.daterangepicker1.maxDate}}
selectedDateRangeHolds the value of the component's date range.{{components.daterangepicker1.selectedDateRange}}
startDateInUnixHolds the start date in Unix timestamp format.{{components.daterangepicker1.startDateInUnix}}
endDateInUnixHolds the end date in Unix timestamp format.{{components.daterangepicker1.endDateInUnix}}
dateFormatDefines the format in which the selected date range is displayed.{{components.daterangepicker1.dateFormat}}
isMandatoryIndicates if the field is required.{{components.daterangepicker1.isMandatory}}
isLoadingIndicates if the component is loading.{{components.daterangepicker1.isLoading}}
isVisibleIndicates if the component is visible.{{components.daterangepicker1.isVisible}}
isDisabledIndicates if the component is disabled.{{components.daterangepicker1.isDisabled}}

Validation

Validation Option
Description
Expected Value
Make this field mandatoryDisplays a 'Field cannot be empty' message if no value is entered.Enable/disable the toggle button or dynamically configure the value by clicking on fx and entering a logical expression.
Min DateSets the minimum date allowed.Date in correct format (e.g. 01/01/2020).
Max DateSets the maximum date allowed.Date in correct format (e.g. 31/12/2026).
Disabled datesSets the dates that are not acceptable.Date in correct format (e.g. 23/07/2024).
Custom validationSpecifies a validation error message for specific conditions.Logical Expression

To add regex inside Custom Validation, you can use the below format:

Format: {{(<regexPattern>.test(<value>)) ? '' : 'Error message';}}

Example:

{
{
/^\d{4}-\d{2}-\d{2}$/.test(components.daterangepicker1.startDate) &&
/^\d{4}-\d{2}-\d{2}$/.test(components.daterangepicker1.endDate)
? ""
: "Please enter a valid date in YYYY-MM-DD format";
}
}

Additional Actions

Action
Description
Configuration Options
Loading stateEnables a loading spinner, often used with isLoading to indicate progress.Enable/disable the toggle button or dynamically configure the value by clicking on fx and entering a logical expression.
VisibilityControls component visibility.Enable/disable the toggle button or dynamically configure the value by clicking on fx and entering a logical expression.
DisableEnables or disables the component.Enable/disable the toggle button or dynamically configure the value by clicking on fx and entering a logical expression.
TooltipProvides additional information on hover.String (e.g., Select your booking dates. ).

Devices

Property
Description
Expected Value
Show on desktopMakes the component visible in desktop view.You can set it with the toggle button or dynamically configure the value by clicking on fx and entering a logical expression.
Show on mobileMakes the component visible in mobile view.You can set it with the toggle button or dynamically configure the value by clicking on fx and entering a logical expression.

Styles

Label

PropertyDescription
Label ColorSets the color of the label text.
AlignmentDetermines the label's position, choose between top/side and left/right alignment.
WidthSpecifies the percentage of the component’s width that the label should occupy.

Color

PropertyDescription
BackgroundSets the background color of the component.
BorderDefines the color of the component’s border.
AccentSpecifies the accent color used for highlights or focus indicators.
TextSets the text color inside the component.
Error textColor applied to error messages.

Input Field

PropertyDescription
IconAdds an icon to the component, usually for visual cues or actions.
Icon ColorSets the color of the icon.
Icon PositionDefines the position of the icon (e.g., left, right).
Border radiusControls the roundness of the component's input field.
Box shadowApplies shadow styling to the input field.
PaddingSets the internal spacing between the content and the input field edges.
info

Any property having fx button next to its field can be programmatically configured.