Class DateUtil
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final DateDisplayFormatterString will display with seconds in 24 hour time:[H]H:MM:SS.static final DateDisplayFormatterDate in the format <YYYYMMDD>T<HHMMSS>Z Example:20051104T111001Zstatic final DateDisplayFormatterShort date in format DD/MM/YYYY.
 Example:4/11/2005static final DateDisplayFormatterShort date with time in format DD/MM/YYYY HH:MM
 Example:4/11/2005 11:03static final DateDisplayFormatterShort date in format YYYY/MM/DD.
 Example:2005/11/4static final DateDisplayFormatterShort date with time in format YYYY/MM/DD HH:MM
 Example:2005/11/4 11:03static final DateDisplayFormatterDefault native browser 'toLocaleString()' implementation.static final DateDisplayFormatterNormal date format for the localestatic final DateDisplayFormatterNormal datetime format for the localestatic final DateDisplayFormatterString will display with seconds, with a 2 digit hour in 24 hour format:HH:MM:SS.static final DateDisplayFormatterString will display with seconds, with a 2 digit hour and am/pm indicator:HH:MM:SS am|pm.static final DateDisplayFormatterDate in the format YYYY-MM-DD HH:MM:SS
 Example:2005-11-04 11:09:15static final DateDisplayFormatterString will have no seconds and be in 24 hour format:[H]H:MM.
 Example:15:25static final DateDisplayFormatterString will have no seconds and will display with a 2 digit hour in 24 hour clock format:HH:MM.
 Examples:15:25,03:16static final DateDisplayFormatterString will have no seconds and will display a 2 digit hour, in 12 hour clock format:HH:MM am|pm.
 Example:03:25 pmstatic final DateDisplayFormatterString will have no seconds and be in 12 hour format:[H]H:MM am|pm.
 Example:3:25 pmstatic final DateDisplayFormatterDefault native browser 'toString()' implementation.static final DateDisplayFormatterString will display with seconds and am/pm indicator:[H]H:MM:SS am|pm.static final DateDisplayFormatterShort date in format MM/DD/YYYY.
 Example:11/4/2005static final DateDisplayFormatterShort date with time in format MM/DD/YYYY HH:MM
 Example:11/4/2005 11:03
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic DateadjustDate(Date baseDate, String relativeDateShortcut) Create a new Date instance representing the baseDate adjusted by the parameter relativeDateShortcut.static voidUse the GWT LocaleInfo class to auto-detect the various formats for dates and times.static voidIf a custom system wide date parser has been specified viasetDateParser(DateParser), clear this and revert to the standard date input format specified viasetDateInputFormat(String).static DatecombineLogicalDateAndTime(Date date, Date time) Combine a logical date (a value appropriate for a DataSourceField of type "date") with a logical time (a value appropriate for a DataSourceField of type "time") into a datetime value (a value appropriate for a DataSourceField of type "datetime")static intcompareDates(Date date1, Date date2) Compare two dates; returns 0 if equal, -1 if the first date is greater (later), or 1 if the second date is greater.static intcompareLogicalDates(Date date1, Date date2) Compare two dates, normalizing out the time elements so that only the date elements are considered; returns 0 if equal, -1 if the first date is greater (later), or 1 if the second date is greater.static Datecreate()Create a newDateobject - synonym fornew Date(arguments)static DatecreateDatetime(Integer year, Integer month, Integer date) Create a new Date instance in the current locale time.static DatecreateDatetime(Integer year, Integer month, Integer date, Integer hour, Integer minute, Integer second, Integer millisecond) Create a new Date instance in the current locale time.static DatecreateDatetime(Date baseDate) Create a new Date instance in the current locale time.static DatecreateDatetime(Date baseDate, Integer month, Integer date) Create a new Date instance in the current locale time.static DatecreateDatetime(Date baseDate, Integer month, Integer date, Integer hour, Integer minute, Integer second, Integer millisecond) Create a new Date instance in the current locale timestatic LogicalDateCreate a new Date representing a logical date value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,date type field}.static LogicalDatecreateLogicalDate(int year, int month, int date) Create a new Date to represent a logical date value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,date type field}.static LogicalDatecreateLogicalDate(Date baseDate) Create a new Date to represent a logical date value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,date type field}.static LogicalDatecreateLogicalDate(Date baseDate, Integer month, Integer date) static LogicalTimeCreate a new Date object to represent a logical time value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,time type field}.static LogicalTimecreateLogicalTime(int hour, int minute, int second, int millisecond) Create a new Date object to represent a logical time value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,time type field}.static LogicalTimecreateLogicalTime(Date baseDate) Create a new Date object to represent a logical time value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,time type field}.static LogicalTimecreateLogicalTime(Date baseDate, Integer minutes, Integer seconds) Create a new Date object to represent a logical time value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,time type field}.static StringFormat a date as a string according to the format specified bysetNormalDateDisplayFormatter(DateDisplayFormatter).static StringFormat the parameter date using the parameter format string.static StringformatAsNormalDate(Date date) Format a date as a string according to the format specified bysetNormalDateDisplayFormatter(DateDisplayFormatter).static StringformatAsShortDate(Date date) Format a date as a string according to the format specified bysetShortDateDisplayFormatter(DateDisplayFormatter).static StringformatAsShortDatetime(Date date) Format a date as a string according to the format specified bysetShortDatetimeDisplayFormatter(DateDisplayFormatter).static DategetAbsoluteDate(RelativeDate relativeDate) static DategetAbsoluteDate(RelativeDate relativeDate, Date baseDate) static DategetAbsoluteDate(String relativeDateShortcut, Date baseDate, RelativeDateRangePosition rangePosition) static StringgetDayName(Date date) Return the full day of week name for this date (Monday, Tuesday, etc).static String[]Return an array of the full names of each day, suitable for use in a selection list, etc.static Stringgets the default date separator stringstatic intgetDisplayDay(Date datetime) Returns the day of month from the passed datetime, as it will be displayed to the user.static intgetDisplayHours(Date datetime) Returns the hours value from the passed datetime, as it will be displayed to the user.static intgetDisplayMinutes(Date datetime) Returns the minutes value from the passed datetime, as it will be displayed to the user.static intgetDisplayMonth(Date datetime) Returns the month number from the passed datetime, as it will be displayed to the user.static intgetDisplayYear(Date datetime) Returns the full year from the passed datetime, as it will be displayed to the user.static DateReturns the end of some period, like day, week or month, relative to a passed Date instance.static Datestatic DateReturns the end of some period, like day, week or month, relative to a passed Date instance.static intReturns the global attribute that dictates which day should be treated as the first day of the week in calendars and date calculations.static FiscalCalendarReturns the globalFiscalCalendar objectrepresenting the start month and date of the fiscal year in the current locale.static DategetFiscalStartDate(Integer year, FiscalCalendar fiscalCalendar) Get the start date of the fiscal period for the passed year.static DategetFiscalStartDate(Date date) Returns the start date of the fiscal year for the passed date.static DategetFiscalStartDate(Date date, FiscalCalendar fiscalCalendar) Returns the start date of the fiscal year for the passed date.static intgetFiscalWeek(Date date) Returns a date's week-number, according to the fiscal calendarstatic intgetFiscalWeek(Date date, FiscalCalendar fiscalCalendar) Returns a date's week-number, according to the fiscal calendarstatic FiscalYeargetFiscalYear(Date date) Returns theFiscalYearobject for the fiscal year in which the passed date exists.static FiscalYeargetFiscalYear(Date date, FiscalCalendar fiscalCalendar) Returns theFiscalYearobject for the fiscal year in which the passed date exists.static StringRetrieves the default format for strings being parsed into dates viaDateUtil.parseInput()static LogicalDategetLogicalDateOnly(Date date) Get a logical date - a value appropriate for a DataSourceField of type "date" - from a datetime value (a value from a DataSourceField of type "datetime").static LogicalTimegetLogicalTimeOnly(Date date) Get a logical time - a value appropriate for a DataSourceField of type "time" - from a datetime value (a value from a DataSourceField of type "datetime").getMonthName(Date date) Return the full name of the month for this date (January, February, etc) To modify the value returned by this method, usecom.smartgwt.client.util.DateUtil#setMonthNames().getShortDayName(Date date) Return the abbreviated (up to 3 chars) day of week name for this date (Mon, Tue, etc).static String[]getShortDayNames(int length) Return an array of the short names of each day, suitable for use in a selection list, etc.getShortMonthName(Date date) Return the abbreviated name of the month for this date (Jan, Feb, etc) To modify the value returned by this method, usecom.smartgwt.client.util.DateUtil#setShortMonthNames().getShortYear(Date date) Return a 2 digit year for this date.static DategetStartOf(Date date, String period) Returns the start of some period, like day, week or month, relative to a passed Date instance.static DategetStartOf(Date date, String period, Boolean logicalDate) static DategetStartOf(Date date, String period, Boolean logicalDate, Integer firstDayOfWeek) Returns the start of some period, like day, week or month, relative to a passed Date instance.static Integer[]Return an array of days that are considered "weekend" days.static StringmapRelativeDateShortcut(String relativeDateShortcut) static StringmapRelativeDateShortcut(String relativeDateShortcut, RelativeDateRangePosition position) Converts a RelativeDate shortcut string such as"$today"to a RelativeDateString such as"+0D"static DateparseInput(String dateString) Parse a date passed in as a string, returning the appropriate date object.static DateparseInput(String dateString, String format) static DateparseInput(String dateString, String format, Integer centuryThreshold) static DateparseInput(String dateString, String format, Integer centuryThreshold, Boolean suppressConversion) Parse a date passed in as a string, returning the appropriate date object.static voidsetAdjustForDST(boolean adjustForDST) Determines whether, when formatting values of type datetime and time, the effect of Daylight Saving Time should be considered when computing offsets from UTC.static voidsetDateInputFormat(String inputFormat) Sets up the default system-wide input format for strings being parsed into dates via SmartGWT utilities and components (seeparseInput(String)).static voidsetDateInputFormatter(DateInputFormatter formatter) Deprecated.in favor of setDateParser()static voidsetDateParser(DateParser parser) Sets up a custom parsing function to use by default when converting dates or datetimes from formatted string values to Dates.static voidsetDayNames(String[] dayNames) Set the array of names of days.static voidsetDefaultDateSeparator(String separator) Sets a new default separator that will be used when formatting dates.static voidsetDefaultDisplayTimezone(String offset) Globally sets the offset from UTC to use when formatting values of type datetime and time with standard display formatters.static voidsetFirstDayOfWeek(int firstDayOfWeek) Sets the global attribute that dictates which day should be treated as the first day of the week in calendars and date calculations.static voidsetFiscalCalendar(FiscalCalendar fiscalCalendar) Sets the global fiscal calendar, which is used for all calls to getFiscalYear() / getFiscalWeek() if those methods aren't passed a fiscalCalander.static voidsetInputFormat(String format) Sets up the default system-wide input format for strings being parsed into dates viaDateUtil.parseInput().static voidsetMonthNames(String[] monthNames) Set the array of names of months.static voidSet the default formatter for date objects to the custom DateDisplayFormatter passed in.static voidSet the default datetime format for date objects to the DateDisplayFormat passed in.static voidSet up a system wide default normal time formatting function.static voidsetShortDateDisplayFormatter(DateDisplayFormatter formatter) Set up a system wide default short date formatting function.static voidSet up a system wide default short datetime formatting function.static voidsetShortDayNames(String[] shortDayNames) Set the array of shortened names of days.static voidsetShortDisplayFormat(String format) Set the default short format for dates.static voidsetShortMonthNames(String[] shortMonthNames) Set the array of names of months.static voidsetShortTimeDisplayFormatter(DateDisplayFormatter formatter) Set up a system wide default short time formatting function.static voidsetShowChooserFiscalYearPickers(boolean showChooserFiscalYearPickers) static voidsetShowChooserWeekPickers(boolean showChooserWeekPickers) static voidsetWeekendDays(Integer[] weekendDays) Sets the days that are consideredweekend days.toDateStamp(Date date) Return this date in the format (UTC timezone):YYYYMMDDTHHMMSS[Z]static voidtoday()Return alogicalDaterepresenting the current day in the String.
- 
Field Details- 
TOSTRINGDefault native browser 'toString()' implementation. May vary by browser.
 Example:Fri Nov 04 2005 11:03:00 GMT-0800 (Pacific Standard Time)
- 
TOLOCALESTRINGDefault native browser 'toLocaleString()' implementation. May vary by browser. Example:Friday, November 04, 2005 11:03:00 AM
- 
TONORMALDATENormal date format for the locale
- 
TONORMALDATETIMENormal datetime format for the locale
- 
TOUSSHORTDATEShort date in format MM/DD/YYYY.
 Example:11/4/2005
- 
TOUSSHORTDATETIMEShort date with time in format MM/DD/YYYY HH:MM
 Example:11/4/2005 11:03
- 
TOEUROPEANSHORTDATEShort date in format DD/MM/YYYY.
 Example:4/11/2005
- 
TOEUROPEANSHORTDATETIMEShort date with time in format DD/MM/YYYY HH:MM
 Example:4/11/2005 11:03
- 
TOJAPANSHORTDATEShort date in format YYYY/MM/DD.
 Example:2005/11/4
- 
TOJAPANSHORTDATETIMEShort date with time in format YYYY/MM/DD HH:MM
 Example:2005/11/4 11:03
- 
TOSERIALIZEABLEDATEDate in the format YYYY-MM-DD HH:MM:SS
 Example:2005-11-04 11:09:15
- 
TODATESTAMPDate in the format <YYYYMMDD>T<HHMMSS>Z Example:20051104T111001Z
- 
TOTIMEString will display with seconds and am/pm indicator:[H]H:MM:SS am|pm.
 Example:3:25:15 pm
- 
TO24HOURTIMEString will display with seconds in 24 hour time:[H]H:MM:SS.
 Example:15:25:15
- 
TOPADDEDTIMEString will display with seconds, with a 2 digit hour and am/pm indicator:HH:MM:SS am|pm.
 Example:03:25:15 pm
- 
TOPADDED24HOURTIMEString will display with seconds, with a 2 digit hour in 24 hour format:HH:MM:SS.
 Examples:15:25:15,03:16:45
- 
TOSHORTTIMEString will have no seconds and be in 12 hour format:[H]H:MM am|pm.
 Example:3:25 pm
- 
TOSHORT24HOURTIMEString will have no seconds and be in 24 hour format:[H]H:MM.
 Example:15:25
- 
TOSHORTPADDEDTIMEString will have no seconds and will display a 2 digit hour, in 12 hour clock format:HH:MM am|pm.
 Example:03:25 pm
- 
TOSHORTPADDED24HOURTIMEString will have no seconds and will display with a 2 digit hour in 24 hour clock format:HH:MM.
 Examples:15:25,03:16
 
- 
- 
Constructor Details- 
DateUtilpublic DateUtil()
 
- 
- 
Method Details- 
combineLogicalDateAndTimeCombine a logical date (a value appropriate for a DataSourceField of type "date") with a logical time (a value appropriate for a DataSourceField of type "time") into a datetime value (a value appropriate for a DataSourceField of type "datetime")This method correctly takes into account the current String, specifically, the returned datetime value will show the same date and time as the passed date and time objects when rendered by a Smart GWT component that has been configured with a field of type "datetime". For further background on date, time and datetime types, storage and transmission, see this overview.- Parameters:
- date- a Date instance representing logical date value
- time- a Date instance representing logical time value
- Returns:
- a Date instance representing a datetime value combining the logical date and time passed
 
- 
compareDatesCompare two dates; returns 0 if equal, -1 if the first date is greater (later), or 1 if the second date is greater. If either value is not a Date object, it is treated as the epoch (midnight on Jan 1 1970) for comparison purposes.- Parameters:
- date1- first date to compare
- date2- second date to compare
- Returns:
- 0 if equal, -1 if first date > second date, 1 if second date > first date
 
- 
compareLogicalDatesCompare two dates, normalizing out the time elements so that only the date elements are considered; returns 0 if equal, -1 if the first date is greater (later), or 1 if the second date is greater.- Parameters:
- date1- first date to compare
- date2- second date to compare
- Returns:
- 0 if equal, -1 if first date > second date, 1 if second date > first date. Returns false if either argument is not a date
 
- 
createCreate a newDateobject - synonym fornew Date(arguments)- Returns:
- Date object
 
- 
getAbsoluteDate- Parameters:
- relativeDate- the relative date to convert
- Returns:
- resulting absolute date value
 
- 
getAbsoluteDate- Parameters:
- relativeDate- the relative date to convert
- baseDate- base value for conversion. Defaults to the current date/time.
- Returns:
- resulting absolute date value
 
- 
getDayNamesReturn an array of the full names of each day, suitable for use in a selection list, etc. Day names are picked up fromdayNames, which defaults to an array of English-language strings and these are updated to localized values by loading a locale.If DateUtil.dayNamesis purposely cleared, this method will fall back to deriving day-names from the native browser date string. Note, if we have to use this native backup behavior, the day names may vary by browser as well as locale - for example, they may be in an abbreviated form, similar to the result of callinggetShortDayNames().- Returns:
- array of day names
 
- 
getDefaultDateSeparatorgets the default date separator string- Returns:
- the default date separator
 
- 
getDisplayDayReturns the day of month from the passed datetime, as it will be displayed to the user. This might not be the same value as that returned by getDate() if a String has been applied. Only necessary for datetimes - for logical dates and times, this method returns the same value as getDate().- Parameters:
- datetime- datetime instance to work with
- Returns:
- the day of month from the passed datetime
 
- 
getDisplayHoursReturns the hours value from the passed datetime, as it will be displayed to the user. This might not be the same value as that returned by getHours() if a String has been applied. Only necessary for datetimes - for logical dates and times, this method returns the same value as getHours().- Parameters:
- datetime- datetime instance to work with
- Returns:
- the hours value from the passed datetime
 
- 
getDisplayMinutesReturns the minutes value from the passed datetime, as it will be displayed to the user. This might not be the same value as that returned by getMinutes() if a String has been applied. Only necessary for datetimes - for logical dates and times, this method returns the same value as getMinutes().- Parameters:
- datetime- datetime instance to work with
- Returns:
- the minutes value from the passed datetime
 
- 
getDisplayMonthReturns the month number from the passed datetime, as it will be displayed to the user. This might not be the same value as that returned by getMonth() if a String has been applied. Only necessary for datetimes - for logical dates and times, this method returns the same value as getMonth().- Parameters:
- datetime- datetime instance to work with
- Returns:
- the month number from the passed datetime
 
- 
getDisplayYearReturns the full year from the passed datetime, as it will be displayed to the user. This might not be the same value as that returned by getFullYear() if a String has been applied. Only necessary for datetimes - for logical dates and times, this method returns the same value as getFullYear().- Parameters:
- datetime- datetime instance to work with
- Returns:
- the 4-digit display year from the passed datetime
 
- 
getEndOfReturns the end of some period, like day, week or month, relative to a passed Date instance.- Parameters:
- date- the base date to find the period end from
- period- the period to return the end of, one of mn/h/d/w/m/y
- Returns:
- a Date instance representing the end of the period relative to the passed date
 
- 
getEndOf
- 
getEndOfReturns the end of some period, like day, week or month, relative to a passed Date instance.- Parameters:
- date- the base date to find the period end from
- period- the period to return the end of, one of mn/h/d/w/m/y
- logicalDate- process and return a logicalDate with no time element
- firstDayOfWeek- which day should be considered the firstDayOfWeek - overrides the default provided by the locale
- Returns:
- a Date instance representing the end of the period relative to the passed date
 
- 
getFirstDayOfWeekpublic static int getFirstDayOfWeek()Returns the global attribute that dictates which day should be treated as the first day of the week in calendars and date calculations. The parameter is expected to be an integer value between 0 (Sunday) and 6 (Saturday).The default value is picked up from the current locale. - Returns:
- the number of the day being used as the first day of the week
 
- 
getFiscalCalendarReturns the globalFiscalCalendar objectrepresenting the start month and date of the fiscal year in the current locale.- Returns:
- the FiscalCalendar object
 
- 
getFiscalStartDateReturns the start date of the fiscal year for the passed date.- Parameters:
- date- the date, or the year-number, to get the fiscal year for
- Returns:
- the start of the fiscal year for the passed date and fiscalCalendar
 
- 
getFiscalStartDateReturns the start date of the fiscal year for the passed date.- Parameters:
- date- the date, or the year-number, to get the fiscal year for
- fiscalCalendar- the object representing the starts of one or more fiscal years
- Returns:
- the start of the fiscal year for the passed date and fiscalCalendar
 
- 
getFiscalWeekReturns a date's week-number, according to the fiscal calendar- Parameters:
- date- the date to get the fiscal year for
- Returns:
- the fiscal week for the passed date
 
- 
getFiscalWeekReturns a date's week-number, according to the fiscal calendar- Parameters:
- date- the date to get the fiscal year for
- fiscalCalendar- the object representing the starts of fiscal years
- Returns:
- the fiscal week for the passed date
 
- 
getFiscalYearReturns theFiscalYearobject for the fiscal year in which the passed date exists.- Parameters:
- date- the date to get the fiscal year for
- Returns:
- the FiscalYearobject for the passed date
 
- 
getFiscalYearReturns theFiscalYearobject for the fiscal year in which the passed date exists.- Parameters:
- date- the date to get the fiscal year for
- fiscalCalendar- the object representing the start of the fiscal period
- Returns:
- the FiscalYearobject for the passed date
 
- 
getInputFormatRetrieves the default format for strings being parsed into dates viaDateUtil.parseInput()- Returns:
- the current inputFormat for dates
- See Also:
 
- 
getShortDayNamesReturn an array of the short names of each day, suitable for use in a selection list, etc. Day names are picked up from ashortDayNameslist specified in each locale.- Parameters:
- length- maximum length of each day string - default is no maximum (full strings)
- Returns:
- array of short day names
 
- 
getStartOfReturns the start of some period, like day, week or month, relative to a passed Date instance.- Parameters:
- date- the base date to find the period start from
- period- the period to return the start of, one of mn/h/d/w/m/y
- Returns:
- a Date instance representing the start of the period relative to the passed date
 
- 
getStartOf
- 
getStartOfpublic static Date getStartOf(Date date, String period, Boolean logicalDate, Integer firstDayOfWeek) Returns the start of some period, like day, week or month, relative to a passed Date instance.- Parameters:
- date- the base date to find the period start from
- period- the period to return the start of, one of mn/h/d/w/m/y
- logicalDate- process and return a logicalDate with no time element
- firstDayOfWeek- which day should be considered the firstDayOfWeek - overrides the default provided by the locale
- Returns:
- a Date instance representing the start of the period relative to the passed date
 
- 
getWeekendDaysReturn an array of days that are considered "weekend" days. Values will be the integers returned by the JavaScript built-in Date.getDay(), eg, 0 is Sunday and 6 is Saturday. OverrideweekendDaysto accommodate different workweeks such as Saudi Arabia (Saturday -> Wednesday) or Israel (Sunday -> Thursday).- Returns:
- array of weekend days
 
- 
parseInputParse a date passed in as a string, returning the appropriate date object.- Parameters:
- dateString- date value as a string
- Returns:
- date value, or null if the string could not be parsed to a valid date.
 
- 
parseInput- See Also:
 
- 
parseInput- See Also:
 
- 
parseInputpublic static Date parseInput(String dateString, String format, Integer centuryThreshold, Boolean suppressConversion) Parse a date passed in as a string, returning the appropriate date object.- Parameters:
- dateString- date value as a string
- format- Format of the date string being passed. If not passed, the default date input format as set up via setInputFormat() will be used. See- DateInputFormat
- centuryThreshold- For date formats that support a 2 digit year, if parsed year is 2 digits and less than this number, assume year to be 20xx rather than 19xx
- suppressConversion- If the string passed in was not a valid date, in some cases we can convert to a valid date (for example incrementing the year if the month is greater than 12). This optional parameter will suppress such conversions - anything that doesn't parse directly to a valid date will simply return null.
- Returns:
- date value, or null if the string could not be parsed to a valid date.
 
- 
setDefaultDateSeparatorSets a new default separator that will be used when formatting dates. By default, this is a forward slash character: "/"- Parameters:
- separator- separator to use in dates
 
- 
setFirstDayOfWeekpublic static void setFirstDayOfWeek(int firstDayOfWeek) Sets the global attribute that dictates which day should be treated as the first day of the week in calendars and date calculations. The parameter is expected to be an integer value between 0 (Sunday) and 6 (Saturday).The default value is picked up from the current locale. - Parameters:
- firstDayOfWeek- the number of the day to use as the first day of the week
 
- 
setFiscalCalendarSets the global fiscal calendar, which is used for all calls to getFiscalYear() / getFiscalWeek() if those methods aren't passed a fiscalCalander.- Parameters:
- fiscalCalendar- the object representing the start month and date of the fiscal year in the current locale
 
- 
setInputFormatSets up the default system-wide input format for strings being parsed into dates viaDateUtil.parseInput(). This will effect how Smart GWT components showing editable date or datetime fields parse user-entered values into live Date objects.The input format can be specified as a DateInputFormat- a 3 character string like"MDY"indicating the order of the Month, Day and Year components of date strings.As an example - an input format of "MDY" would parse "01/02/1999" to Jan 2nd 1999 
 This standard parsing logic will also handle date-time strings such as "01/02/1999 08:45", or "01/02/1999 16:21:05".Notes: - If the
 inputFormat is not explicitly set,the system automatically determines     the standard input format will be based on the
 specified      DateUtil.shortDisplayFormatwherever possible. For example if the short display format has been set to "toEuropeanShortDate" the input format will default to "DMY".
- The default date parsing functionality built into Smart GWT will handle dates presented    
 with any separator string, and can handle 1 or 2 digit day and month values, months formatted     as getMonthNames()orgetShortMonthNames(), and 2 or 4 digit year values. This means that in many cases custom date display formats can be parsed back to Date values without the need for a custom parser function. However if more sophisticated parsing logic is required, a function may be passed into this method. In this case the parser function should be able to handle parsing date and datetime values formatted viaformatAsShortDate()andformatAsShorDatetime().
- Date parsing and formatting logic may be overridden at the component level by setting properties directly on the component or field in question.
 - Parameters:
- format- Default format for strings to be parsed into Dates. See- DateInputFormat
- See Also:
 
- If the
 inputFormat is not explicitly set,the system automatically determines     the standard input format will be based on the
 specified      
- 
setShortDisplayFormatSet the default short format for dates. After calling this method, subsequent calls toformatAsShortDatewill return a string formatted according to this format specification. Note that this will be the standard short date format used by Smart GWT components.The formatparameter may be aFormatString, aDateDisplayFormatstring, or a function. If passed a function, this function will be executed in the scope of the Date and should return the formatted string.
 Initial default shortDateFormat is "toUSShortDate". This property is commonly modified for localization of applications. See http://en.wikipedia.org/wiki/Date_format_by_country for a useful overview of standard date formats per country.- Parameters:
- format- new formatter. See- FormatString
 
- 
setShowChooserFiscalYearPickerspublic static void setShowChooserFiscalYearPickers(boolean showChooserFiscalYearPickers) Sets the global attribute that dictates whether thechoosersshelled fromDateItemsshow a UI for working with Fiscal Years.- Parameters:
- showChooserFiscalYearPickers- whether to show Fiscal Year pickers in DateChoosers by default
 
- 
setShowChooserWeekPickerspublic static void setShowChooserWeekPickers(boolean showChooserWeekPickers) Sets the global attribute that dictates whether thechoosersshelled fromDateItemsshow a UI for working with Weeks.- Parameters:
- showChooserWeekPickers- whether to show Fiscal Week pickers in DateChoosers by default
 
- 
setWeekendDaysSets the days that are consideredweekend days. The parameter should be array of the integers returned by the JavaScript built-in Date.getDay(), eg, 0 is Sunday and 6 is Saturday. Override to accommodate different workweeks such as Saudi Arabia (Saturday -> Wednesday) or Israel (Sunday -> Thursday).- Parameters:
- weekendDays- the array of day-numbers to assign as weekend days
 
- 
todaypublic static void today()Return alogicalDaterepresenting the current day in the String.
- 
getDayNameReturn the full day of week name for this date (Monday, Tuesday, etc). To modify the value returned by this method, usesetDayNames(java.lang.String[]).- Parameters:
- date-
- Returns:
- Day name
 
- 
getShortDayNameReturn the abbreviated (up to 3 chars) day of week name for this date (Mon, Tue, etc). To modify the value returned by this method, usesetShortDayNames(java.lang.String[]).- Parameters:
- date-
- Returns:
- Abbreviated day name
 
- 
getMonthNameReturn the full name of the month for this date (January, February, etc) To modify the value returned by this method, usecom.smartgwt.client.util.DateUtil#setMonthNames().- Parameters:
- date-
- Returns:
- Month name
 
- 
getShortMonthNameReturn the abbreviated name of the month for this date (Jan, Feb, etc) To modify the value returned by this method, usecom.smartgwt.client.util.DateUtil#setShortMonthNames().- Parameters:
- date-
- Returns:
- Abbreviated month name (3 character string)
 
- 
getShortYearReturn a 2 digit year for this date.- Parameters:
- date-
- Returns:
- year number, padded to 2 characters
 
- 
toDateStampReturn this date in the format (UTC timezone):YYYYMMDDTHHMMSS[Z]- Parameters:
- date-
- Returns:
- formatted date string
 
- 
setDefaultDisplayTimezoneGlobally sets the offset from UTC to use when formatting values of type datetime and time with standard display formatters. This property effects how dates are displayed and also the assumed timezone for user-input.If this method is never called, the default display timezone for times and datetimes will be derived from the native browser local timezone. Note that by default daylight savings time adjustments (based on browser locale) may also be applied when formatting datetimes. setAdjustForDST(boolean)may be used to disable this adjustment.- Parameters:
- offset- offset from UTC. This should be a string in the format- +/-HH:MMfor example- "-08:00"
 
- 
setAdjustForDSTpublic static void setAdjustForDST(boolean adjustForDST) Determines whether, when formatting values of type datetime and time, the effect of Daylight Saving Time should be considered when computing offsets from UTC. By default, this flag is set during framework initialization if SmartGWT detects that it is running in a locale that is observing DST this year. If you do not want DST adjustments to be applied, set this flag to false.Note that setting this flag to true will have no effect unless you are in a locale that is observing Daylight Saving Time this year; this is because we rely on the browser for offset information, and browsers are only capable of returning local date and time information for the computer's current locale. - Parameters:
- whether- time and datetimes should account for daylight savings time in this application
 
- 
setNormalDatetimeDisplayFormatterSet the default datetime format for date objects to the DateDisplayFormat passed in. After calling this method, subsequent calls to Date.toNormalDate will return a string formatted according to this format specification.
 Note: this will be the standard long datetime format used by SmartGWT components. Initial default normalDatetimeDisplayFormat is "toLocaleString"- Parameters:
- format- the DateDisplayFormatter
 
- 
setNormalDateDisplayFormatterSet the default formatter for date objects to the custom DateDisplayFormatter passed in. After calling this method, subsequent calls to Date.toNormalDate will return a string formatted according to this formatter specification.When writing custom date formatting and parsing logic, developers may find the DateTimeFormatclass helpful. SmartGWT includes several built-in DateDisplayFormatters for common formats - seeDateDisplayFormatterfor details. Sample code :DateUtil.setNormalDateDisplayFormatter(new DateDisplayFormatter() { public String format(Date date) { if(date == null) return null; final DateTimeFormat dateFormatter = DateTimeFormat.getFormat("yyyy.MM.dd HH:mm:ss"); String format = dateFormatter.format(date); return format; } });As of version 4.1, SmartGWT has built-in string-based formatting of date and time values via theDateFormatStringFormatterclass. The main advantage of using the built-in formatting feature is that it is harmonized with the formatting we export to Excel and other targets, leading to an exported document that more closely resembles the original application. Seecom.smartgwt.client.data.DataSOurceField#formatfor details. Sample code :DateUtil.setNormalDateDisplayFormatter(new DateFormatStringFormatter("yyyy.MM.dd HH:mm:ss"));- Parameters:
- formatter- the DateDisplayFormatter
 
- 
setShortDateDisplayFormatterSet up a system wide default short date formatting function. The formatter passed in will be used by default by SmartGwt components when formatting date values to short date format (and byformatAsShortDate(Date)).If a custom short date formatter is applied, bear in mind that it will be applied by default when editing date values, so the system will need to be able to parse an edited date string in this format back to a live date object. Developers calling this method will therefore also commonly want to apply custom parsing logic via setDateInputFormat(String)orsetDateParser(DateParser).When writing custom date formatting and parsing logic, developers may find the DateTimeFormatclass helpful. SmartGWT includes several built-in DateDisplayFormatters for common formats - seeDateDisplayFormatterfor details. Sample code :DateUtil.setShortDateDisplayFormatter(new DateDisplayFormatter() { public String format(Date date) { if(date == null) return null; final DateTimeFormat dateFormatter = DateTimeFormat.getFormat("MMM d, yyyy"); String format = dateFormatter.format(date); return format; } });- Parameters:
- formatter- the DateDisplayFormatter
 
- 
setShortDatetimeDisplayFormatterSet up a system wide default short datetime formatting function. The formatter passed in will be used by default by SmartGwt components when formatting date values to short datetime format (and byformatAsShortDatetime(Date)).If a custom short datetime formatter is applied, bear in mind that it will be applied by default when editing date values, so the system will need to be able to parse an edited date string in this format back to a live date object. Developers calling this method will therefore also commonly want to apply custom parsing logic via setDateInputFormat(String)orsetDateParser(DateParser).When writing custom date formatting and parsing logic, developers may find the DateTimeFormatclass helpful. SmartGWT includes several built-in DateDisplayFormatters for common formats - seeDateDisplayFormatterfor details.- Parameters:
- formatter- the DateDisplayFormatter
 
- 
adjustDateCreate a new Date instance representing the baseDate adjusted by the parameter relativeDateShortcut.- Parameters:
- baseDate- base Date value to adjust. Defaults to the current date/time.
- relativeDateShortcut- the- RelativeDateShortcutor- RelativeDateStringstring to convert
- Returns:
- resulting absolute date value
 
- 
createDatetimeCreate a new Date instance in the current locale time.See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- baseDate- any Date instance. Defaults to the current date/time.
- Returns:
- new Date instance in the current locale time
 
- 
createDatetimeCreate a new Date instance in the current locale time. Time elements default to those from the parameter baseDate.See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- baseDate- any Date instance. Defaults to the current date/time.
- month- Integer month-number (0-11) - defaults to baseDate month
- date- Integer day of the month - defaults to baseDate date
- Returns:
- new Date instance in the current locale time
 
- 
createDatetimepublic static Date createDatetime(Date baseDate, Integer month, Integer date, Integer hour, Integer minute, Integer second, Integer millisecond) Create a new Date instance in the current locale timeSee the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- baseDate- any Date instance. Defaults to the current date/time.
- month- Integer month-number (0-11) - defaults to the month from the parameter baseDate
- date- Integer day of the month - defaults to the date from the parameter baseDate
- hour- Integer hours (0-23) - defaults to the hours form the parameter baseDate
- minute- Integer minutes (0-59) - defaults to the minutes form the parameter baseDate
- second- Integer seconds (0-59) - defaults to the seconds form the parameter baseDate
- millisecond- Integer milliseconds (0999) - defaults to the milliseconds form the parameter baseDate
- Returns:
- new Date instance in the current locale time
 
- 
createDatetimeCreate a new Date instance in the current locale time. Time elements default to zero.See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- year- Integer full year
- month- Integer month-number (0-11)
- date- Integer day of the month
- Returns:
- resulting absolute date value
 
- 
createDatetimepublic static Date createDatetime(Integer year, Integer month, Integer date, Integer hour, Integer minute, Integer second, Integer millisecond) Create a new Date instance in the current locale time.See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- year- Integer full year
- month- Integer month-number (0-11)
- date- Integer day of the month
- hour- Integer hours (0-23) - defaults to zero
- minute- Integer minutes (0-59) - defaults to zero
- second- Integer seconds (0-59) - defaults to zero
- millisecond- Integer milliseconds (0-999) - defaults to zero
- Returns:
- resulting absolute date value
 
- 
createLogicalDateCreate a new Date representing a logical date value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,date type field}. The generated Date value will have year, month and date set to today (in browser native local time).See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Returns:
- LogicalDate representing a logical date.
 
- 
createLogicalDateCreate a new Date to represent a logical date value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,date type field}. The parameter baseDate defaults to null if unset, and the generated Date value will have year, month and date set from that baseDate (in browser native local time).See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- baseDate-
- Returns:
- LogicalDate representing a logical date.
 
- 
createLogicalDate
- 
createLogicalDateCreate a new Date to represent a logical date value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,date type field}. The generated Date value will have year, month and date set to the specified values (in browser native local time).See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- year-
- month-
- date-
- Returns:
- LogicalDate representing a logical date.
 
- 
createLogicalTimeCreate a new Date object to represent a logical time value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,time type field}. The generated Date value will have year, month and date set to the epoch date (Jan 1 1970), and time elements set to the current time (in browser native local time).See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Returns:
- new LogicalTime representing the time in question
 
- 
createLogicalTimeCreate a new Date object to represent a logical time value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,time type field}. The generated Date value will have year, month and date set to the epoch date (Jan 1 1970), and time elements set to those from the parameter baseDate (in browser native local time).See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- baseDate- any Date instance
- Returns:
- new LogicalTime representing the time in question
 
- 
createLogicalTimeCreate a new Date object to represent a logical time value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,time type field}. The generated Date value will have year, month and date set to the epoch date (Jan 1 1970), where the hour comes from the parameter baseDate and the minute and second values come from their respective parameters, defaulting to the values from the parameter baseDate (in browser native local time).See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- baseDate- any Date instance
- minute- Integer minutes (0-59)
- second- Integer seconds (0-59)
- Returns:
- new LogicalTime representing the time in question
 
- 
createLogicalTimeCreate a new Date object to represent a logical time value (rather than a specific datetime value), typically for display in a +link{DataSourceField.type,time type field}. The generated Date value will have year, month and date set to the epoch date (Jan 1 1970), and time elements set to the supplied hour, minute and second (in browser native local time).See the docsfor a discussion of the difference between datetime field values and logical date field values, logical time field values.- Parameters:
- hour- (0-23)
- minute- (0-59)
- second- (0-59)
- millisecond- (0-999)
- Returns:
- new LogicalTime representing the time in question
 
- 
getLogicalDateOnlyGet a logical date - a value appropriate for a DataSourceField of type "date" - from a datetime value (a value from a DataSourceField of type "datetime").This method correctly takes into account the current String, specifically, the returned Date will reflect the day, month and year that appears when the datetime is rendered by a Smart GWT component rather than the date values that would be returned by Date.getDay() et al (which can differ, since getDay() uses the browser's local timezone). For further background on date, time and datetime types, storage and transmission, see this overview.- Parameters:
- date- a Date instance representing a datetime value
- Returns:
- a Date instance representing just the date portion of the datetime value, as a logical date
 
- 
getLogicalTimeOnlyGet a logical time - a value appropriate for a DataSourceField of type "time" - from a datetime value (a value from a DataSourceField of type "datetime").This method correctly takes into account the current String, specifically, the returned Date will reflect the hour, minute and second that appears when the datetime is rendered by a Smart GWT component rather than the time values that would be returned by Date.getHours() et al (which can differ, since getHours() uses the browser's local timezone). For further background on date, time and datetime types, storage and transmission, see this overview.- Parameters:
- date- a Date instance representing a datetime value
- Returns:
- a Date instance representing just the time portion of the datetime value, as a logical time
 
- 
formatAsShortDateFormat a date as a string according to the format specified bysetShortDateDisplayFormatter(DateDisplayFormatter).This calls the standard date formatting function used by SmartGWT components to display short-formatted dates. - Parameters:
- date-
- Returns:
 
- 
formatAsShortDatetimeFormat a date as a string according to the format specified bysetShortDatetimeDisplayFormatter(DateDisplayFormatter).This calls the standard date formatting function used by SmartGWT components to display short-formatted date-times. - Parameters:
- date-
- Returns:
 
- 
formatFormat a date as a string according to the format specified bysetNormalDateDisplayFormatter(DateDisplayFormatter).This calls the standard date formatting function used by SmartGWT components to display short-formatted dates. - Parameters:
- date-
- Returns:
 
- 
formatAsNormalDateFormat a date as a string according to the format specified bysetNormalDateDisplayFormatter(DateDisplayFormatter).This calls the standard date formatting function used by SmartGWT components to display normal-formatted dates. - Parameters:
- date-
- Returns:
- Returns a String containing the formatted date
 
- 
setDateInputFormatterDeprecated.in favor of setDateParser()Sets up the default format for strings being parsed into dates via DateUtil.parseInput
 Sample code :DateUtil.setDateInputFormatter(new DateInputFormatter() { public Date format(String dateString) { final DateTimeFormat dateFormatter = DateTimeFormat.getFormat("MMM d, yyyy"); Date date = dateFormatter.parse(dateString); return date; } });- Parameters:
- formatter- the DateInputFormatter
 
- 
setDateParserSets up a custom parsing function to use by default when converting dates or datetimes from formatted string values to Dates. This custom parser will be used by SmartGwt components parsing editable date or datetime type values back to live dates by default. The string passed in will be formatted according to the standard "short date" or "short datetime" format (which may be customized via thesetShortDateDisplayFormatter(DateDisplayFormatter)andsetShortDatetimeDisplayFormatter(DateDisplayFormatter)methods.Note that the default date parsing logic already handles all standard short date formats, including those formatted with custom separators. In most cases rather than applying an entirely custom date parser method, desired behavior can be achieved via changing the standard input format.When writing custom date formatting and parsing logic, developers may find the DateTimeFormatclass helpful.Sample code : DateUtil.setDateParser(new DateParser() { public Date parse(String dateString) { final DateTimeFormat format = DateTimeFormat.getFormat("MMM d, yyyy"); Date date = format.parse(dateString); return date; } });Individual components may also override date formatting and parsing functions directly. - Parameters:
- parser-
 
- 
setDateInputFormatSets up the default system-wide input format for strings being parsed into dates via SmartGWT utilities and components (seeparseInput(String)). This input format is respected when parsing formatted strings to "date" or "datetime" type values.This method takes a 3 character string like "MDY"indicating the order of the Month, Day and Year components of date strings.As an example - an input format of "MDY" would parse "01/02/1999" to Jan 2nd 1999 
 This standard parsing logic will also handle date-time strings such as "01/02/1999 08:45", or "01/02/1999 16:21:05".Notes: - Parameters:
- inputFormat-
 
- 
clearDateParserpublic static void clearDateParser()If a custom system wide date parser has been specified viasetDateParser(DateParser), clear this and revert to the standard date input format specified viasetDateInputFormat(String).
- 
mapRelativeDateShortcutpublic static String mapRelativeDateShortcut(String relativeDateShortcut, RelativeDateRangePosition position) Converts a RelativeDate shortcut string such as"$today"to a RelativeDateString such as"+0D"- Parameters:
- relativeDateShortcut- shortcut string to convert
- position- Are we interested in the start or end of the specified relative date? This applies to shortcuts which do not specify a specific moment (such as- $today) - it does not apply to shortcuts which already specify a specific moment such as- $startOfToday. If unspecified rangePosition is always assumed to be "start"
- Returns:
- converted relative date string
 
- 
mapRelativeDateShortcut
- 
getAbsoluteDatepublic static Date getAbsoluteDate(String relativeDateShortcut, Date baseDate, RelativeDateRangePosition rangePosition) - Parameters:
- relativeDateShortcut- the- RelativeDateShortcutor- RelativeDateStringstring to convert
- baseDate- base value for conversion. Defaults to the current date/time.
- rangePosition- date-range position. Only has an effect if the date passed in is a- RelativeDateShortcutwhere the range position is not implicit, such as "$yesterday"
- Returns:
- resulting absolute date value
- See Also:
 
- 
setNormalTimeDisplayFormatterSet up a system wide default normal time formatting function. After calling this method, times displayed in SmartGWT components will use the specified format. The initial default normal time display formatter isDateUtil.TOTIME.SmartGWT includes several built-in DateDisplayFormatters for common formats - see DateDisplayFormatterfor details.As of version 4.1, SmartGWT has built-in string-based formatting of date and time values via the DateFormatStringFormatterclass. The main advantage of using the built-in formatting feature is that it is harmonized with the formatting we export to Excel and other targets, leading to an exported document that more closely resembles the original application. Seecom.smartgwt.client.data.DataSourceField#formatfor details. Sample code :DateUtil.setNormalTimeDisplayFormatter(new DateFormatStringFormatter("HH-mm-ss"));- Parameters:
- formatter- the DateDisplayFormatter
 
- 
setShortTimeDisplayFormatterSet up a system wide default short time formatting function. After calling this method, subsequent calls toisc.Time.toShortTime()will return a string formatted according to this formatter specification. Note: this will be the standard time format used by SmartGWT components. The initial default normal time display formatter isDateUtil.TOSHORTTIME.SmartGWT includes several built-in DateDisplayFormatters for common formats - see DateDisplayFormatterfor details.- Parameters:
- formatter- the DateDisplayFormatter
 
- 
formatFormat the parameter date using the parameter format string. This is a convenience method; it simply creates aDateFormatStringFormatterand calls itsformat()method- Parameters:
- date- the Date to format
- format- the format string to use
- Returns:
- the parameter date formatted according to the parameter format string
 
- 
setDayNamesSet the array of names of days. For example:new String[] { "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" }The appropriate day name will then be returned from#getDayName(), and may be used whenever SmartGWT components display day-names (for example in theDateItem class).Note : This is an advanced setting - Parameters:
- dayNames- a length 7 array of day names
 
- 
setShortDayNamesSet the array of shortened names of days. For example:new String[] { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" }The appropriate day name will then be returned from#getShortDayName(), and may be used whenever SmartGWT components display shortened day-names (for example in theDateItem class).Note : This is an advanced setting - Parameters:
- shortDayNames- a length 7 array of abbreviated day names
 
- 
setMonthNamesSet the array of names of months. For example:new String[] { "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" }The appropriate month name will then be returned from#getMonthName(), and may be used whenever SmartGWT components display month-names (for example in theDateItem class).Note : This is an advanced setting - Parameters:
- monthNames- a length 12 array of month names
 
- 
setShortMonthNamesSet the array of names of months. For example:new String[] { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" }The appropriate month name will then be returned from#getShortMonthName(), and may be used whenever SmartGWT components display month-names (for example in theDateItem class).Note : This is an advanced setting - Parameters:
- shortMonthNames- a length 12 array of abbreviated month names
 
- 
getFiscalStartDateGet the start date of the fiscal period for the passed year.- Returns:
 
- 
autoDetectFormatspublic static void autoDetectFormats()Use the GWT LocaleInfo class to auto-detect the various formats for dates and times.
 
-