Creating a Login Manager Application with GWT Designer
Before you can start with the tutorial, you must install a supported version of the following:
Eclipse, Java 1.5 or higher, GWT Designer (Full stand-alone version), and the GWT SDK or Google Plugin for Eclipse (includes GWT SDK)
Note: This tutorial was created in Windows XP using GWT Designer 2.3, GPE 2.3, Eclipse 3.7 & Java 1.6.
Basic steps:
- Set the GWT installation directory
- Create a GWT Java Project and the LoginManager module
- Create the Login Composite
- Create and apply CSS styles
- Add Event Handlers
- Add the Login composite to the LoginManager module
- Run Application in Hosted Mode
- Build and Deploy
1. Set the path to the GWT SDK installation directory.
If you installed the Google Plugin for Eclipse (GPE), this step is not needed (GWT Designer will just use the SDK included with the GPE). Do this only if you downloaded the stand-alone GWT SDK zip file. The path would be the directory you unzipped the GWT SDK to (the dir just above the /doc subdirectory).
data:image/s3,"s3://crabby-images/04731/04731778c1e0afe0fd8521543c2837361588b632" alt="Set GWT Path"
2. Create a GWT Java Project and the LoginManager module.
data:image/s3,"s3://crabby-images/e27a8/e27a81ffc71ef1c510ac8c64394fcbf45cb51db2" alt="Select GWT Java Project"
data:image/s3,"s3://crabby-images/8c10f/8c10f40bdf41f6fbc0a4e80424751f21b1c3b9fc" alt="Enter Project information"
data:image/s3,"s3://crabby-images/3aefb/3aefb7f580a0b4bbf33f44cb19eee7cbc4673ee4" alt="Create a Module"
A LoginManager GWT project is created and configured. The LoginManager file is opened and you should see Source and Design tabs at the bottom of the LoginManager view. If you don't see the tabs, right-click on the Java class and select Open With > WindowBuilder Editor.
data:image/s3,"s3://crabby-images/51e7a/51e7a1d514c5b5678e25fdf88e645b318e4e41e9" alt="Source View"
To start designing your UI using GWT Designer, click the Design tab. Below is GWT Designer's Design view. Top left corner of the LoginManager is the Components view. Below the Components view is the Properties view. In the middle is the Palette and to the right is your UI.
data:image/s3,"s3://crabby-images/ee491/ee491f92a9e948013572e0226696c4696a67ffa4" alt="Design View"
3. Create the Login Composite.
First, we need to create a Composite for the Login application.
data:image/s3,"s3://crabby-images/73b36/73b36b45dbcdc7334e22da982e0b4e3c50ed45c1" alt="Create GWT Composite"
data:image/s3,"s3://crabby-images/590e2/590e2d7ef7c7d2bad5c5bea7eb01f22887144ca6" alt="New Composite"
Composite created and opened in Source mode.
data:image/s3,"s3://crabby-images/faa51/faa51103fcb19bb76bd04dd8c1619ba7d681e45b" alt="Login Composite Source"
Switch to Design mode and Add a VerticalPanel to the Composite.
data:image/s3,"s3://crabby-images/f272e/f272e5a2dc301b2b0dabe779ec13cf0bc585cca3" alt="Empty Login Composite"
Add a Label widget to the VerticalPanel.
data:image/s3,"s3://crabby-images/821fa/821fa55cca8631d2f94ead6c218ebd4f6eec36ca" alt="Add New Label"
data:image/s3,"s3://crabby-images/9a02e/9a02e34785db1562f5f6bc842811e2cb7a66261e" alt="Sign in Label"
To easily structure the widgets, add a FlexTable panel.
Add the following widgets to the FlexTable and arrange it as follows:
data:image/s3,"s3://crabby-images/cbd95/cbd951f0883e76d1abf31b2f2fdcc54de5eec56e" alt="Complete Login Composite"
4. Create and apply CSS styles
Let's create a CSS style for the Label widgets.
data:image/s3,"s3://crabby-images/c540a/c540ade1f98fa996339d3855bb73ee9bbfaa1ce4" alt="Open CSS Editor"
The CSS Style Editor opens.
data:image/s3,"s3://crabby-images/6bbc1/6bbc115833fc86cc8f62dda6a3e88a6b7febeceb" alt="CSS Editor"
data:image/s3,"s3://crabby-images/1ef60/1ef60f0e8b492ff39a23723209e83f0697d6e1ae" alt="New CSS Rule"
data:image/s3,"s3://crabby-images/7b854/7b854c5ffa2e5c921dd0d87672c1b165c768f5b6" alt="CSS Editor"
When you're done, you should have something similar to this:
data:image/s3,"s3://crabby-images/97a4e/97a4e9223e307c4e936de5cfe853aed7730bc907" alt="CSS Editor"
data:image/s3,"s3://crabby-images/18365/183651e555a5cacb3b11e5665ab8043c43f9755c" alt="Assign styleName"
Following the same procedure, create a style for the checkbox and set the styleName property.
Open the Login class and this is how it looks like with some css styling. Make sure to Save your work.
data:image/s3,"s3://crabby-images/c11dc/c11dc3e0513948c1a98051fbe52225b9d8d2e220" alt="Login with styling"
5. Add Event Handlers
First, let's convert the text boxes from local to field variables.
data:image/s3,"s3://crabby-images/e6b6a/e6b6aba9b5ee97e3ccfd422f1349666d2498704e" alt=""
Now, let's add an onClick event for the "Sign In" button.
As you can see a ClickHandler has been added and all you have to do is implement the onClick event.
import com.google.gwt.user.client.Window;
if (textBoxUsername.getText().length() == 0
|| textBoxPassword.getText().length() == 0) {
Window.alert("Username or password is empty.");
}
6. Add the Login Composite to the LoginManager module.
data:image/s3,"s3://crabby-images/05a8d/05a8dd01b3c4ce279bec0d7643e5da23652b5c35" alt="Choose Component button"
data:image/s3,"s3://crabby-images/c6a6c/c6a6c60e6eb21e0e058beff23f5af3e0429c3ef6" alt="Choose Component dialog"
data:image/s3,"s3://crabby-images/8626d/8626d0cfeab50b2fe12d50a846bdb16d21b676cc" alt="LoginManager with Composite"
7. Run your Application in Hostedmode.
data:image/s3,"s3://crabby-images/d1117/d111707dc0494d394b656ed3c13acf3d44cafb58" alt="Launch Browser"
You should now see the LoginManager application similar to the screen below.
data:image/s3,"s3://crabby-images/c7bfa/c7bfad20b873af6adc26b5ed741b183e2400c308" alt="Run application"
data:image/s3,"s3://crabby-images/c7bfa/c7bfad20b873af6adc26b5ed741b183e2400c308" alt="Run application"
8. Build and Deploy.
data:image/s3,"s3://crabby-images/71409/7140935a54a66c16819cc81ba6b18726eb0bf787" alt="Deploy Module"
data:image/s3,"s3://crabby-images/920b6/920b60f51a9f0d26482d0127125791b6db2fe6ef" alt="Deployment configuration"
this article very use full for me....Thanks ! sagar...
ReplyDelete