Version 19.1 by Kieran Kelleher on 2007/10/01 22:11

Hide last authors
Kieran Kelleher 6.1 1 == Introduction ==
2
3 So you have decided to take the plunge and take advantage of the many useful features of Project Wonder. The most common usage of Project Wonder is to simply integrate the Wonder foundation frameworks of ERJars, ERExtensions and JavaWOExtensions into your project. Doing this fixes many problems with the standard WebObjects frameworks and provides easy access to many configurable features that most typical WebObjects applications need.
Kieran Kelleher 12.1 4 In this short article, we itemize the absolute minimum to add Wonder to your project and avoid initial integration stumbles.
Kieran Kelleher 6.1 5
6 == Minimum Wonder Integration ==
7
Kieran Kelleher 10.1 8 * Add ERJars, ERExtensions and Wonder's JavaWOExtensions frameworks to your project's framework references
Kieran Kelleher 6.1 9 * Remove existing log4j jar if your project had that.
10 * Make it so your Application class subclasses ERXApplication
11 * Make it so your Session class subclasses ERXSession
12 * Make it so your DirectAction classes extend ERXDirectAction
Kieran Kelleher 12.1 13 * Your Application class' main static method **{+}must{+}** call ERXApplication.main(...) instead of WOApplication.main(...). Your application will fail to initialize and launch otherwise.
Kieran Kelleher 6.1 14 * Use ERXEC.newEditingContext() to create new editing contexts in your application
15 * Add minimal content to Properties file. To get minimal content, create a temporary empty project using the WOnderApplication WOLips project template and copy/paste the contents from that template's Properties file.
16
17 {{warning title="Remember"}}
18 All of these steps are important. Failing to integrate properly may lead to errors during runtime or your application will fail to launch successfully
19
20 {{/warning}}
21
22 {{code title="Application main method"}}
23
Kieran Kelleher 12.1 24 public static void main(String argv[]) {
Kieran Kelleher 6.1 25 ERXApplication.main(argv, Application.class);
26 }
27
28 {{/code}}
29
Kieran Kelleher 14.1 30 == Easy Extras ==
Kieran Kelleher 6.1 31
Kieran Kelleher 14.1 32 If you got the minimum Wonder integration done and your app is working, then adding these extra fundamental useful frameworks are definitely worthwhile from the start:
Kieran Kelleher 6.1 33
34 * ERPrototypes - save yourself lots of manhours fiddling with EOModel attributes by using convenient prototypes. This is considered best practice.
Kieran Kelleher 14.1 35 * ERJavaMail - send all kinds of emails - plain text, html, multi-part, attachments, etc. HTML can be generated from a WOComponent or be set using a HTML String.
Kieran Kelleher 6.1 36 * ERSelenium - functional testing that simulates user interaction with your app's web pages.
37
38 {{tip value=" Link To Wonder Source in your Workspace"}}
39 Wonder source is in itself a very useful reference and gives insight into the inner workings of the WebObjects frameworks, so having the source directly linked to your project in your workspace has many advantages. See other tutorials on this wiki that show how to set that up.
40
41 {{/tip}}
Kieran Kelleher 16.1 42
43 {{info value="Start Your Next Project on the Right Foot"}}
44
45 For your next project, simply select the WOnderApplication project template instead of the WOApplication template and all the minimum integration tasks itemized above are already done for you. Besides, the WOnder Application project template is so neatly organized that some have commented on how it is a better overall project template for WebObjects projects even if you are not using Wonder.
46
Kieran Kelleher 18.1 47 !Picture 9.jpg!
Kieran Kelleher 16.1 48
49 {{/info}}