aboutsummaryrefslogtreecommitdiffstats
path: root/documentation/components/components-datefield.asciidoc
diff options
context:
space:
mode:
Diffstat (limited to 'documentation/components/components-datefield.asciidoc')
-rw-r--r--documentation/components/components-datefield.asciidoc111
1 files changed, 12 insertions, 99 deletions
diff --git a/documentation/components/components-datefield.asciidoc b/documentation/components/components-datefield.asciidoc
index bf535c702c..a5aae85a1f 100644
--- a/documentation/components/components-datefield.asciidoc
+++ b/documentation/components/components-datefield.asciidoc
@@ -62,6 +62,9 @@ Java.
----
// Display only year, month, and day in ISO format
date.setDateFormat("yyyy-MM-dd");
+
+// Display the correct format as placeholder
+date.setPlaceholder("yyyy-mm-dd");
----
The result is shown in <<figure.components.datefield.popupdatefield.format>>.
@@ -73,8 +76,6 @@ image::img/datefield-formatting.png[width=35%, scaledwidth=60%]
The same format specification is also used for parsing user-input date,
as described later.
-
-ifdef::web[]
[[components.datefield.popupdatefield.malformed]]
=== Handling Malformed User Input
@@ -119,23 +120,14 @@ in the following example.
// custom error message for invalid format
DateField date = new DateField("My Date") {
@Override
- protected Result<Date> handleUnparsableDateString(String dateString) {
- // Try custom parsing
- String fields[] = dateString.split("/");
- if (fields.length >= 3) {
- try {
- int year = Integer.parseInt(fields[0]);
- int month = Integer.parseInt(fields[1])-1;
- int day = Integer.parseInt(fields[2]);
-
- return Result.ok(LocalDate.of(year, month, day));
- } catch (NumberFormatException e) {
- return Result.error("Not a number");
- }
+ protected Result<LocalDate> handleUnparsableDateString(
+ String dateString) {
+ try {
+ // try to parse with alternative format
+ return Result.ok(LocalDate.of(dateString, myFormat));
+ } catch (DateTimeParseException e) {
+ return Result.error("Bad date");
}
-
- // Bad date
- return Result.error("Your date needs two slashes");
}
};
@@ -147,68 +139,6 @@ date.setDateFormat("yyyy/MM/dd");
date.setLenient(true);
----
-The handler method must either return a parsed [classname]#Date# object or throw
-a [classname]#ConversionException#. Returning [parameter]#null# will set the
-field value to [parameter]#null# and clear the input box.
-
-endif::web[]
-
-ifdef::web[]
-[[components.datefield.popupdatefield.error-customization]]
-=== Customizing the Error Message
-
-In addition to customized parsing, overriding the handler method for unparseable
-input is useful for internationalization and other customization of the error
-message. You can also use it for another way for reporting the errors, as is
-done in the example below:
-
-
-[source, java]
-----
-// Create a date field with a custom error message for invalid format
-DateField date = new DateField("My Date") {
- @Override
- protected Result<LocalDate> handleUnparsableDateString(String dateString) {
- // Have a notification for the error
- Notification.show(
- "Your date needs two slashes",
- Notification.TYPE_WARNING_MESSAGE);
-
- // A failure must always also throw an exception
- return Result.error("Bad date");
- }
-};
-----
-
-If the input is invalid, you should always throw the exception; returning a
-[parameter]#null# value would make the input field empty, which is probably
-undesired.
-
-endif::web[]
-
-[[components.datefield.popupdatefield.prompt]]
-=== Placeholder
-
-Like other fields that have a text box, [classname]#DateField# allows an
-placeholder that is visible until the user has input a value. You can set that with [methodname]#setPlaceholder#.
-
-
-[source, java]
-----
-DateField date = new DateField();
-
-// Set the prompt
-date.setPlaceholder("Select a date");
-
-// Set width explicitly to accommodate the prompt
-date.setWidth("10em");
-----
-
-The date field doesn't automatically scale to accommodate the prompt, so you
-need to set it explicitly with [methodname]#setWidth()#.
-
-The input prompt is not available in the [classname]#DateField# superclass.
-
[[components.datefield.popupdatefield.css]]
=== CSS Style Rules
@@ -323,7 +253,7 @@ endings for the weekday bar.
In addition to display a calendar with dates, [classname]#DateField# can also
display just the month or year. The visibility of the input components is
-controlled by __date resolution__, which you can set with [methodname]#setResolution()#.
+controlled by [methodname]#setDateResolution()#, which you can set with [methodname]#setResolution()#.
The method takes as its parameter the highest resolution date element that should
be visible. Please see the API Reference for the complete list of resolution parameters.
@@ -338,25 +268,8 @@ method of [classname]#AbstractComponent#, as described in
Only Gregorian calendar is supported.
-ifdef::web[]
[[components.datefield.weeknumbers]]
== Week Numbers
You can enable week numbers in a date field with
-[methodname]#setShowISOWeekNumbers()#. The numbers are shown in a column on the
-left side of the field.
-
-
-[source, java]
-----
-df.setShowISOWeekNumbers(true);
-----
-
-The supported numbering is defined in the ISO 8601 standard. Note that the ISO
-standard applies only to calendar locales where the week starts on Monday. This
-is not the case in many countries, such as Americas (North and South), many
-East-Asian countries, and some African countries, where the week starts on
-Sunday, nor in some North African and Middle-Eastern countries, where the week
-begins on Saturday. In such locales, the week numbers are not displayed.
-
-endif::web[]
+[methodname]#setShowISOWeekNumbers()#. The numbers are shown according to the ISO 8601 standard in a column on the left side of the field.