Before we can get down to the fun, we have to create an empty application. Tapestry uses a feature of Maven to do this: archetypes (a too-clever way of saying "project templates").
For the tutorial, we're using a fresh install of Eclipse and an empty workspace at
/users/joeuser/workspace. You may need to adjust a few things for other operating systems or local paths.
Using the Quickstart Archetype
From Eclipse, we'll use a Maven archetype to create a skeleton Tapestry project.
Okay, let's get started creating our new project.
In Eclipse, go to File > New > Project... > Maven > Maven Project
Then click Next, Next (again), and then on the Select an Archetype page click the Configure button on the Catalog line. The Archetype preferences dialog should appear. Click the Add Remote Catalog... button, as shown below:
As shown above, enterin the Catalog File field, and "Apache Tapestry" in the Description field.
Click OK, then OK again.
On the Select an Archetype dialog (shown below), select the newly-added Apache Tapestry catalog, then select the "quickstart" artifact from the list and click Next.
Fill in the Group Id, Artifact Id, Version and Package as follows:
then click Finish.
After Maven finishes, you'll see a new directory,
tutorial in your Package Explorer view in Eclipse.
Running the Application using Jetty
One of the first things you can do is use Maven to run Jetty directly.
Right-click on the tutorial project in your Package Explorer view and select Run As > Maven Build... >, enter a Goal of "jetty:run". This creates a "Run Configuration" named "tutorial1" that we'll use throughout this tutorial to start the app:
Tapestry runs best with a couple of additional options; click the "JRE" tab and enter the following VM Arguments:
(If you're using JDK 1.8 then you should omit the MaxPermSize argument.)
Here's how it looks:
Finally, click Run.
Again, the first time, there's a dizzying number of downloads, but before you know it, the Jetty servlet container is up and running.
Once Jetty is initialized (which only takes a few seconds after the first time), you'll see the following in your console:
Note the red square icon above. Later on you'll use that icon to stop Jetty before restarting the app.
You can now open a web browser to http://localhost:8080/tutorial1/ to see the running application:
The date and time in the middle of the page shows that this is a live application.
This is a complete little web app; it doesn't do much, but it demonstrate how to create a number of pages sharing a common layout, and demonstrates some simple navigation and link handling. You can see that it has several different pages that share a common layout. (Layout is a loose term meaning common look and feel and navigation across many or all of the pages of an application. Often an application will include a Layout component to provide that commonness.)