Andrew Pollack's Blog

Technology, Family, Entertainment, Politics, and Random Noise

Enough theory! Here's how my first real foray into building something with XPages is going

By Andrew Pollack on 06/24/2008 at 01:24 PM EDT

After all the time at the workshop doing walk throughs, all the demos, and all the talking -- I decided to try building something useful with XPages today. Even with all the background information, I'm finding my knowledge to be a little too theoretical and when it comes to practical code I'm really having to work for it.

The idea is simple enough -- but revolutionary from a pure old-school Notes perspective. I have two forms. One has company data, the other has record data. The records have a many to one relationship with the company data. It's like an invoice, or maybe a directory. You want to store the company information which is the same for all people in one place, and use another place for the data on each record. What you don't want, is a lot of navigating from place to place, editing on one form, then redrawing and doing a bunch of look-ups.

In building the thing, its tricky to keep track of the scope and bindings for each object. I've found that John Mackey's posting has been a great walk through refresher. In particular the slide deck he provides. Since I'm changing things as I go, I still stumbled in places but once I'd started using John's example as somewhat of a road map the stumbling became much more manageable.

I've got a working prototype now. It's taken me several hours to really understand what was going on, but that's a first timer (newbie) learning curve. Its a steep one, but its manageable. Re-doing this would now take only an hour, and after I've done a few it will be the work of minutes.

In the prototype, you can select the company or select "New Company". The company data is editable, and a save button tied just for that allows you to update it in place. The individual records display in a panel below, and can also be selected and edited.

The big learning curve here, as in anything else, is going to be developing your design patterns. For example, some early "Ah-ha" moments and patterns that I see emerging are as follows:

"Panels" will allow you to bind elements together that work with common data very well. For example, if I've got two data elements on my XPage, I can use script on a button to save each separately, or save them both. If the button is on a panel, and the panel is bound to a data source, a simple action "Save Document" will save the elements for the document which is bound to the panel. There's no confusion because the panel itself is tied to a document and the button is on the panel. If I don't tie things together on panels -- because I want to mix them up for display or whatever -- I can still call a save, but I need to know the name of the data element I've bound and call it's save function.

Generally speaking, you're going to want to create "Custom Controls" - think of these as Sub-Xpages, but without any implied limitations - for each of your form and view elements. Make them work as units, then drop them on the main pages. This will make debugging and reuse much easier.

No screen shots today, since the data is confidential.

I'm sure there'll be much more as I go.

There are  - loading -  comments....

Other Recent Stories...

  1. 05/05/2016Is the growing social-sourced economy the modern back door into socialism?Is the growing social-sourced economy the modern back door into socialism? I read a really insightful post a couple of days ago that suggested the use of social network funding sites like “Go Fund Me” and “Kickstarter” have come about and gained popularity in part because the existing economy in no longer serving its purpose for anyone who isn’t already wealthy. Have the traditional ways to get new ventures funded become closed to all but a few who aren’t already connected to them and so onerous as to make ...... 
  2. 04/20/2016Want to be whitelisted? Here are some sensible rules for web site advertisingAn increasing number of websites are now detecting when users have ad-blocking enabled, and refuse to show content unless you "whitelist" their site (disable your ad-blocking for them). I think that is a fair decision on their part, it's how they pay for the site. However, if you want me (and many others) to white list your site, there are some rules you should follow. If you violate these rules, I won't whitelist your site, I'll just find content elsewhere. 1. The total space taken up by advertisements ...... 
  3. 12/30/2015Fantastic new series on Syfy called “The Expanse” – for people who love traditional science fiction[] “The Expanse” is a new science fiction series being broadcast onthe Syfy channelthis winter. It’s closely based on a series of books by author James S. A. Corey beginning with “Leviathan Wakes”. There are 5 books in the “Expanse” series so far. If you’re a fan of the novels you’ll appreciate how closely the books are followed.TIP: The first five episodes are already available on If you’re having trouble getting into the characters and plot, use those to get up to speed.The worlds created for ...... 
  4. 10/20/2015My suggestion is to stay away from PayAnywhere(dot)com  
  5. 08/07/2015Here is one for you VMWARE gurus - particularly if you run ESXi without fancy drive arrays 
  6. 08/06/2015The Killer of Orphans (Orphan Documents) 
  7. 06/02/2015Homeopathic Marketing: Traveler on my Android is now calling itself VERSE. Allow me to translate that for the IBM Notes community... 
  8. 03/17/2015A review of British Airways Premium Economy Service – How to destroy customer goodwill all at once 
  9. 02/26/2015There's a bug in how @TextToTime() and @ToTime() process date strings related to international standards and browser settings. 
  10. 01/21/2015Delivering two new presentations at Developer Camp (EntwicklerCamp) 2015 in Germany 
Click here for more articles.....

pen icon Comment Entry
Your Name
*Your Email
* Your email address is required, but not displayed.
Your thoughts....
Remember Me  

Please wait while your document is saved.