Saturday, April 16, 2011

Add LoV to new and existing taskflow

Introduction

Configuring a new portal site is easy, right?! However this statement is probably made by someone who knows his way around.
To ease this process the development team can assist there portal administrators by introducing LoV (List of Values) for the available taskflows. This applies to new and existing taskflow, yes you can add List of Values to existing taskflows.
There is following types of LoV:
  • Static LOV
    To display a list of predefined values.
  • Dynamic LOV
    To display a list of values generated by evaluating an EL value that is computed when the page is run.
  • Global LOV
    To display a global list of values that can be used in any task flow in the application.
  • Picker
    To display all values in a picker format, for example, a document picker.
This post will only go through a Static example, however the other options are straight forward.

Configuration

Assume following scenario to understand the context:
Step one create a new WebCenter Portal Project, add a desired navigation, add few pages, make sure they are customizable and support composer. All pages will be empty so the administrator has to add the taskflow  using the Runtime administration and edit the page.
It will look something like this:
image
The parameters now are open text boxes that is completely open, even though we declared them mandatory, one problem here is that we cannot guarantee the value the user will enter
There is an remedy for this, by using the new Oracle Composer extension file, pe_ext.xml
We are now going to introduce LoV for parameters  Colour and Language parameter, the process below can be repeated for any taskflow, new or existing.
Create new XML file called pe_ext.xml under Portal\adfmsrc\META-INF
Add following xml chunk:
<?xml version="1.0" encoding="UTF-8" ?> <pe-extension xmlns="http://xmlns.oracle.com/adf/pageeditor/extension">  
  <lov-config>
  </lov-config>
</pe-extension>

Now we are going to add the taskflow reference for the affected taskflow
Add following:
<task-flow-definition taskflow-id="/oracle/webcenter/siteresources/scopedMD/shared/taskflow/demo-taskflow.xml#demo-taskflow">

</task-flow-definition>
The best approach to find the id for the taskflow is to open the resource catalog in runtime and copying it
image
Now the final part, each parameter can now be configured with one of the four options of LoV, below is two static examples:
Parameter Colour
<name>Colour</name>  
     <enumeration inline="true">    
             <item>      
                      <name>Blue Colour</name>      
                           <value>Blue</value>
                           <description>Select ... Blue</description>    
              </item>    
              <item>      
                   <name>Green Colour</name>      
                   <value>Green</value>      
                   <description>Select ... Green</description>   
               </item>  
         </enumeration>
</input-parameter-definition>

Parameter Language
<input-parameter-definition>   
      <name>Language</name>  
      <enumeration inline="true">
             <item>      
                 <name>English</name>      
                 <value>en</value>      
                 <description>Select ... English</description>    
            </item>    
            <item>      
                  <name>Swedish</name>
                  <value>sv</value>      
                  <description>Select ... Swedish</description>    
             </item>  
         </enumeration> </input-parameter-definition>

The entire xml should look like this:
image
Deploy the Portal project to see following result:
image

References

For more information on how to configure LoV see documentation:
http://download.oracle.com/docs/cd/E17904_01/webcenter.1111/e10148/jpsdg_page_editor_adv.htm#CACGHHAI

No comments:

Post a Comment