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.


  • car icon

    On Site Training

    We can bring the same kind of top quality training you get at conferences right to your offices. If your team needs training in a single topic, or you want to do a whole series on site, we can put a mini-conference together just for your team. For more information, Contact Me.
  • There are  - loading -  comments....



    Other Recent Stories...

    1. 06/23/2009OpenNTF Licensing ChoiceOpenNTF should settle on the Apache Licensing. It allows IBM to consume OpenNTF released software for inclusion into the core product base -- which means really good stuff could get added in as default templates or parts of the mail file, etc. It also means developers can use Google code and other Apache Licensed software without worrying about being excluded from OpenNTF. As far as I'm concerned, if you don't agree, you're wrong -- and you should fork off (your own source tree) -- maybe call it ...... 
    2. 06/23/2009Web Developers and Artists -- What does a color really look like?The two images in the sample to the right - which LOOK like different colors, are not. they are the same web page and being displayed on the same computer with nearly the same settings. In both cases, the color is defined as "#15433D". [] The only difference, is that the one on top is shown in Firefox using the relatively little known feature introduced in version 3.x which uses the color profile configuration you have set up for your monitor when it renders images. These settings are ...... 
    3. 06/04/2009Product Review: Verizon's MiFiā„¢2200 Intelligent Mobile HotspotYou're not as connected as I am. If that's not true, you're a pretty unusually connected person. When I'm not in the office, I've used cellular tower based connections for several years. Originally it was just a cellular modem, then Verizon upgraded the network to "1xRTT" which gave speeds comparable to a dial-up line at home. EVDO came out and we boosted to the speed of a cheap DSL connection, and now with EVDO Rev A we can be connected almost anywhere with speeds nearly as good as any hotel or coffee ...... 
    4. 05/27/2009Second Signal - Starting to see the kind of growth I've been looking forward to 
    5. 05/26/2009Memorial Day 2009 - Slideshow of the parade, the marching band, the kids' bike parade, etc... 
    6. 05/21/2009Speaking at events that are not specific to our industry - Interesting Reaction 
    7. 05/19/2009Corporate Protectionism is as bad as the nationalistic kind 
    8. 05/17/2009Skippy, the Omega Dog! Freedom - thanks to the new "Dogwatch" fence 
    9. 05/17/2009This blog interrupted by the Lotus Design Partner Program 
    10. 04/24/2009Even more cool integration with the XLight FTP & SFTP Server to Domino - Upload/Download notificiations to the the Domino server 
    Click here for more articles.....


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

    Please wait while your document is saved.