Create an input form with Oracle JET
data:image/s3,"s3://crabby-images/3fbef/3fbefd89329c8d07e24efda19075fd253722cda5" alt="Oracle website"
After creating my first JET-application I want to know more of Oracle JET.
I want to create a web form that saves the input in the database through a REST-service.
First let’s create the table for the input of the data.
data:image/s3,"s3://crabby-images/d12ed/d12eda4f751f4ab6a8767a974269915b7cbef81c" alt="Table input data"
The data for this table must be inserted through a REST-service. So I create an ADF web application with an entity-object for the table I just mentioned.
This entity-object will be then exposed as a REST-service.
data:image/s3,"s3://crabby-images/4b2d7/4b2d745dc9b01d08eb104906fa9d30d9c07a08f8" alt="REST-service"
So now it’s time for creating the input form. This form uses the default ALTA-CSS style.
data:image/s3,"s3://crabby-images/fbd19/fbd199d83cafca325da41a986f7197bbc6b7a498" alt="ALTA-CSS"
I chose some special inputfields which I will use in the input form.
These are the inputfields:
- Title and Nationality are “Single select”
- Birthdate is an “InputDate” field
- Zipcode is “Validation” field
- Gender is a “Radioset”
Let’s look a bit closer to these special inputfields:
Single select:
This is the code for the single select:
data:image/s3,"s3://crabby-images/13233/13233847af79466832a8f49ab11b142e7c947c85" alt="code for single select"
The first option in the option value list is the default value shown in the input form. Don’t forget to initialise the single select item:
self.SelectTitleValue("MR");
Birthdate:
This is the code for the inputdate:
data:image/s3,"s3://crabby-images/6834c/6834c256587cc76a8c84b37adc5f77a150ad141e" alt="Code for the inputdate"
In the object datePicker there is the possibility to specify a yearrange. Default this is plus 10 years and minus 10 years. This is not enough for a birthdate. So you can specify your own yearrange as you can see in the next image. See for more information the API documentation: datePicker.
data:image/s3,"s3://crabby-images/9b0f4/9b0f4fe0f9380edd8ecb3ad2bef4fdb6e94c5070" alt="datePicker"
To set a default date for the inputdate field, you can use the following code:
self.birthdatedateTimeValue = ko.observable(oj.IntlConverterUtils.dateToLocalIso(new Date(2015, 1, 1)));
Zipcode:
This is the code for the validation field. The zipcode what the user entered must be validated.
data:image/s3,"s3://crabby-images/7717d/7717db5dfa4cf8ea7ff161c8c1b8f11ee19f82d8" alt="Zipcode"
Placeholder is the hinttext for the user as you can see in the screenprint of the input form. For validating the zipcode I use a regular expression. When the input doesn’t match the regular expression the messageDetail is shown:
data:image/s3,"s3://crabby-images/8654c/8654cfe8b215b098e7ea616780e21f76a97cc3e3" alt="Zipcode error"
Gender:
This is the code for the radioset.
data:image/s3,"s3://crabby-images/25c94/25c9424f3efb97ba2bbbf39ee81510f2f9bfaa04" alt="Code for radioset"
The first input item is the default item of the radioset. Also don’t forget to initialise this item:
self.radiosetGenderValue("MALE");
At the end there are two buttons; Save and Clear. When the Save button is pressed the inputdata will be send to the database using the REST-service.
When the button Clear is pressed, all inputfields will be cleared and the default values are set.
So let’s enter a person:
data:image/s3,"s3://crabby-images/62bbf/62bbf5e13169b0d864ec5a30b8c5e154009c3261" alt="Enter a person"
Below the buttons there is a textfield. In this textfield I show the user if the data succesfull is saved. Otherwise the user see’s an error.
When the button Save is pressed the user see’s a message that the input is saved.
After that let’s check the database:
data:image/s3,"s3://crabby-images/98c3d/98c3d047167161a3134f99b3cd5b6614f4d2787f" alt="Check database"