| Oracle® Fusion Middleware Java EE Developer's Guide for Oracle Application Development Framework 11g Release 1 (11.1.1.5.0) Part Number E16272-03 | 
 | 
| 
 | View PDF | 
ADF Model is a declarative data binding facility that implements the JSR-227 specification. This specification provides an API for accessing declarative data binding metadata. The ADF Model layer enables a unified approach to bind any user interface to any business service with no code.
This chapter provides a brief overview of ADF Model data binding. For more comprehensive information about using ADF Model data binding, refer to the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
This chapter includes the following sections:
ADF Model implements the two concepts in JSR-227 that enable decoupling the user interface technology from the business service implementation: data controls and declarative bindings. Data controls abstract the implementation technology of a business service by using standard metadata interfaces to describe the bean's operations and data collections, including information about the properties, methods, and types involved. Using JDeveloper, you can view that information as icons which you can drag and drop onto a page. Using those icons, you can create databound HTML elements (for JSP pages), databound UI components (for JSF pages), and databound Swing UI components (for ADF Swing panels) by dragging and dropping them from the panel onto the visual editor for a page. JDeveloper automatically creates the metadata that describes the bindings from the page to the services. At runtime, the ADF Model layer reads the metadata information from the appropriate XML files for both the data controls and the bindings, and then implements the two-way connection between your user interface and your business services.
Declarative bindings abstract the details of accessing data from data collections in a data control and of invoking its operations. There are three basic kinds of declarative binding objects:
Executable bindings: Include iterator bindings, which simplify the building of user interfaces that allow scrolling and paging through collections of data and drilling-down from summary to detail information. Executable bindings also include bindings that allow searching and nesting a series of pages within another page.
Value bindings: Used by UI components that display data. Value bindings range from the most basic variety that work with a simple text field to more sophisticated list and tree bindings that support the additional needs of list, table, and tree UI controls.
Action bindings: Used by UI command components like hyperlinks or buttons to invoke built-in or custom operations on data collections or a data control without writing code.
Figure 2-1 shows how bindings connect UI components to data control collections and methods.
The group of bindings supporting the UI components on a page are described in a page-specific XML file called the page definition file. The ADF Model layer uses this file at runtime to instantiate the page's bindings. These bindings are held in a request-scoped map called the binding container. In a JSF application, the binding container is accessible during each page request using the EL expression #{bindings}.
Tip:
For more information about ADF EL expressions, see the "Creating ADF Data Binding EL Expressions" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.To use the ADF Model layer to data-bind, you need to create a data control for your services. The data controls will then appear as icons in the Data Controls panel, which you can use to declaratively create pages whose components will be automatically bound to those services.
Once you have your application's services in place, you can use JDeveloper to create data controls that provide the information needed to declaratively bind UI components to those services. In a Java EE application, you normally create entity beans that represent tables in a database and then create a session facade over all the EJBs. This facade provides a unified interface to the underlying entities. In an ADF application, you can create a data control for the session bean, and that data control will contain representation of all the EJBs under the session bean. The data control consists of a number of XML metadata files that define the capabilities of the service that the bindings can work with at runtime.
For example, the Suppliers module uses the FOD database schema, which contains a number of relational database tables. The module has a number of entity beans that represent the tables in the schema used by the Suppliers module. There is an Addresses bean, a Product bean, a Persons bean, and so on. The module also contains two session beans: the SupplierFacade bean, which is used to access the beans created from tables, and the GenericServiceFacade bean, which contains generic service methods used by all beans in the application. A data control exists for each of those session beans, which allows developers to declaratively create UI pages using the data and logic contained in those beans.
You create data controls from within the Application Navigator of JDeveloper.
Before you begin:
Create JPA/EJB 3.0 entities. For more information, see the "Building a Persistence Tier" section of the JDeveloper online help.
Create one or more session beans for the entities. For more information see the "Implementing Business Processes in Session Facade Design Pattern" section of the JDeveloper online help.
When creating your entities and session bean(s), keep the following in mind:
For a class to be a valid data control source, it has to meet the JavaBeans specification. It needs to have a public default constructor.
Because the metadata files that represent the beans for the data control are named based on the class names for the beans, you must ensure that if beans have the same name, they are in different packages. If two beans with the same name are in the same package, one metadata file will overwrite the other.
If you rename the bean used to create a data control, you must re-create the data control.
To create a data control:
In the Application Navigator, right-click the session bean for which you want to create a data control.
From the context menu, select Create Data Control.
In the Choose EJB Interface dialog, choose Local.
When you create a data control based on an EJB session bean, the data control contains a representation of all the methods exposed on the bean, as well as underlying entity beans, and the methods and properties exposed on those.
For the data control to work directly with the service and the bindings, JDeveloper creates the following metadata XML files:
Data control definition file (DataControls.dcx). This file defines the factory class and ID for each data control. It also contains settings that determine how the data control behaves. For example, you can use the .dcx file to set global properties, such as whether the service supports transactions. To change the settings, you select the data control in the overview editor and change the value of the property in the Property Inspector. Figure 2-2 shows the DataControls.dcx file in the overview editor and Property Inspector of JDeveloper.
Example 2-1 shows the code from the corresponding XML file (available by clicking the source tab).
Example 2-1 DataControls.dcx File
<?xml version="1.0" encoding="UTF-8" ?>
<DataControlConfigs xmlns="http://xmlns.oracle.com/adfm/configuration"
                    version="11.1.1.54.7" id="DataControls"
                    Package="oracle.fodemo.supplier.model">
  <AdapterDataControl id="SupplierFacadeLocal"
                   FactoryClass="oracle.adf.model.adapter.DataControlFactoryImpl"
                   ImplDef="oracle.adfinternal.model.adapter.ejb.EjbDefinition"
                   SupportsTransactions="false" SupportsSortCollection="true"
                   SupportsResetState="false" SupportsRangesize="false"
                   SupportsFindMode="false" SupportsUpdates="true"
                   Definition="oracle.fodemo.supplier.service.SupplierFacadeLocal"
                   BeanClass="oracle.fodemo.supplier.service.SupplierFacadeLocal"
                   xmlns="http://xmlns.oracle.com/adfm/datacontrol">
    <CreatableTypes>
      <TypeInfo FullName="oracle.fodemo.supplier.model.CountryCode"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.ProductCategory"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.Addresses"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.AddressUsage"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.Person"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.Supplier"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.Product"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.ProductImage"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.ProductTranslation"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.WarehouseStockLevel"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.OrderItem"/>
      <TypeInfo FullName="oracle.fodemo.supplier.model.LookupCode"/>
    </CreatableTypes>
    <Source>
      <ejb-definition ejb-version="3.0" ejb-name="SupplierFacade"
                      ejb-type="Session"
       ejb-business-interface="oracle.fodemo.supplier.service.SupplierFacadeLocal"
                      ejb-interface-type="local"
                   initial-context-factory="weblogic.jndi.WLInitialContextFactory"
      DataControlHandler="oracle.adf.model.adapter.bean.jpa.JPQLDataFilterHandler"
                      xmlns="http://xmlns.oracle.com/adfm/adapter/ejb"/>
    </Source>
  </AdapterDataControl>
  <AdapterDataControl id="GenericServiceFacadeLocal"
. . .
  </AdapterDataControl>
</DataControlConfigs>
Structure definition files for every entity object and structured object that this service exposes. These files define how attributes, accessors, and operations will display and behave. For example, you can set how the label for an attribute will display in a client. A structure definition file contains the following information:
Attributes: Describes the attributes available on the service. You can set UI hints that define how these attributes will display in the UI. You can also set other properties, such as whether the attribute value is required, whether it must be unique, and whether it is visible. For information about setting UI hints, see the "Defining Attribute Control Hints for View Objects" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
Note:
View objects are ADF Business Components used to encapsulate SQL queries and to simplify working with the results. When reading this section, simply substitute "bean" for "view object."You can also set validation for an attribute and create custom properties. For more information, see the "Using the Built-in Declarative Validation Rules" and the "How to Implement Generic Functionality Driven by Custom Properties" sections of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
Accessors: Describes the different accessor methods.
Operations: Describes custom methods on the service, along with any parameters.
Figure 2-3 shows the structure definition file for the Addresses bean in the Suppliers module.
Example 2-2 shows the code from the corresponding XML file (available by clicking the source tab).
Example 2-2 Structure File
<?xml version="1.0" encoding="UTF-8" ?>
<JavaBean xmlns="http://xmlns.oracle.com/adfm/beanmodel" version="11.1.1.54.7"
          id="Addresses" Package="oracle.fodemo.supplier.model"
          BeanClass="oracle.fodemo.supplier.model.Addresses" isJavaBased="true">
  <Attribute Name="address1" Type="java.lang.String" Precision="40">
    <Properties>
      <SchemaBasedProperties>
        <LABEL ResId="oracle.fodemo.supplier.model.Addresses.address1_LABEL"/>
        <TOOLTIP ResId="oracle.fodemo.supplier.model.Addresses.address1_TOOLTIP"/>
        <DISPLAYWIDTH Value="40"/>
      </SchemaBasedProperties>
    </Properties>
  </Attribute>
  <Attribute Name="address2" Type="java.lang.String" Precision="40">
    <Properties>
      <SchemaBasedProperties>
        <LABEL ResId="oracle.fodemo.supplier.model.Addresses.address2_LABEL"/>
        <TOOLTIP ResId="oracle.fodemo.supplier.model.Addresses.address2_TOOLTIP"/>
        <DISPLAYWIDTH Value="40"/>
      </SchemaBasedProperties>
    </Properties>
  </Attribute>
. . .
  <AccessorAttribute id="addressUsageList" IsCollection="true"
                     RemoveMethod="removeAddressUsage"
                     AddMethod="addAddressUsage"
                     BeanClass="oracle.fodemo.supplier.model.AddressUsage"
                     CollectionBeanClass="UpdateableCollection">
    <Properties>
      <Property Name="RemoveMethod" Value="removeAddressUsage"/>
      <Property Name="AddMethod" Value="addAddressUsage"/>
    </Properties>
  </AccessorAttribute>
. . .
  <MethodAccessor IsCollection="false"
                  Type="oracle.fodemo.supplier.model.AddressUsage"
                  BeanClass="oracle.fodemo.supplier.model.AddressUsage"
                  id="addAddressUsage" ReturnNodeName="AddressUsage">
    <ParameterInfo id="addressUsage"
                   Type="oracle.fodemo.supplier.model.AddressUsage"
                   isStructured="true"/>
  </MethodAccessor>
  <MethodAccessor IsCollection="false"
                  Type="oracle.fodemo.supplier.model.AddressUsage"
                  BeanClass="oracle.fodemo.supplier.model.AddressUsage"
                  id="removeAddressUsage" ReturnNodeName="AddressUsage">
    <ParameterInfo id="addressUsage"
                   Type="oracle.fodemo.supplier.model.AddressUsage"
                   isStructured="true"/>
  </MethodAccessor>
. . .
  <ConstructorMethod IsCollection="true"
                     Type="oracle.fodemo.supplier.model.Addresses"
                     BeanClass="oracle.fodemo.supplier.model.Addresses"
                     id="Addresses">
    <ParameterInfo id="address1" Type="java.lang.String" isStructured="false"/>
    <ParameterInfo id="address2" Type="java.lang.String" isStructured="false"/>
    <ParameterInfo id="addressId" Type="java.lang.Long" isStructured="false"/>
    <ParameterInfo id="city" Type="java.lang.String" isStructured="false"/>
    <ParameterInfo id="countryId" Type="java.lang.String" isStructured="false"/>
    <ParameterInfo id="createdBy" Type="java.lang.String" isStructured="false"/>
    <ParameterInfo id="creationDate" Type="java.sql.Timestamp"
                   isStructured="false"/>
    <ParameterInfo id="lastUpdateDate" Type="java.sql.Timestamp"
                   isStructured="false"/>
    <ParameterInfo id="lastUpdatedBy" Type="java.lang.String"
                   isStructured="false"/>
    <ParameterInfo id="latitude" Type="java.lang.Long" isStructured="false"/>
    <ParameterInfo id="longitude" Type="java.lang.Long" isStructured="false"/>
    <ParameterInfo id="objectVersionId" Type="java.lang.Long"
                   isStructured="false"/>
    <ParameterInfo id="postalCode" Type="java.lang.String"
                   isStructured="false"/>
    <ParameterInfo id="stateProvince" Type="java.lang.String"
                   isStructured="false"/>
  </ConstructorMethod>
  <ConstructorMethod IsCollection="true"
                     Type="oracle.fodemo.supplier.model.Addresses"
                     BeanClass="oracle.fodemo.supplier.model.Addresses"
                     id="Addresses"/>
  <ResourceBundle>
    <PropertiesBundle xmlns="http://xmlns.oracle.com/adfm/resourcebundle"
                      PropertiesFile="oracle.fodemo.supplier.model.ModelBundle"/>
  </ResourceBundle>
</JavaBean>
JDeveloper also adds the icons to the Data Controls panel that you can use to create databound UI components. The Data Controls panel lists all the data controls that have been created for the application's business services and exposes all the collections, methods, and built-in operations that are available for binding to UI components.
Tip:
If the Data Controls panel is not visible, see the "How to Open the Data Controls Panel" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework for instructions on opening the panel.When a data control is created for a session bean, and that session bean was configured to contain an accessor method for the underlying beans, those beans appear as an accessor returned collection whose name matches the bean instance name. The Data Controls panel reflects the master-detail hierarchies in your data model by displaying detail data collections nested under their master data collection. For example, Figure 2-4 shows the Data Controls panel for the Suppliers module of the Fusion Order Demo application. Note that the Addresses, Person, and Product beans are all represented by accessor returned collections in the Data Controls panel.
The Data Controls panel also displays each service method on the session bean as a method icon whose name matches the method name. If a method accepts arguments, those arguments appear in a Parameters node as parameters nested inside the method's node. Objects that are returned by the methods appear as well, as shown in Figure 2-4.
Each returned collection or object displays any attributes and custom methods that were defined on the associated bean. Figure 2-5 shows the attributes and methods defined on the Supplier bean that is returned by the supplierFindAll accessor method.
By default, implicit view criteria are created for each attribute that is able to be queried on a bean. They appear as the All Queriable Attributes node under the Named Criteria node, as shown in Figure 2-5. This node is used to create quick search forms, as detailed in Chapter 7, "Creating Databound Search Forms."
As shown in Figure 2-5, the Operations node under a returned collection displays all its available built-in operations. If an operation accepts one or more parameters, then those parameters appear in a nested Parameters node. At runtime, when one of these data collection operations is invoked by name by the data binding layer, the data control delegates the call to an appropriate method on the bean interface to handle the built-in functionality. Most of the built-in operations affect the current row. Only the execute operation refreshes the data control itself. Following are the built-in operations:
Create: Creates a new row that becomes the current row, but does not insert it.
Delete: Deletes the current row.
Execute: Refreshes the data collection by executing or reexecuting the accessor method.
First: Sets the first row in the row set to be the current row.
Last: Sets the last row in the row set to be the current row.
Next: Sets the next row in the row set to be the current row.
Next Set: Navigates forward one full set of rows.
Previous: Sets the previous row in the row set to be the current row.
Previous Set: Navigates backward one full set of rows.
removeCurrentRowWithKey: Tries to find a row using the serialized string representation of the row key passed as a parameter. If found, the row is removed.
setCurrentRowWithKey: Tries to find a row using the serialized string representation of the row key passed as a parameter. If found, that row becomes the current row.
setCurrentRowWithKeyValue: Tries to find a row using the primary key attribute value passed as a parameter. If found, that row becomes the current row.
Note:
By default, JavaBeans assume therowIndex as the key. If you do not explicitly define a key, the index will be used.The Data Controls panel is a direct representation of the DataControls.dcx and structure definition files created when you created a data control. By editing the files, you can change the elements displayed in the panel.
Note:
Whenever changes are made to the underlying services, you need to manually refresh the data control in order to view the changes. To refresh the data control, click the Refresh icon in the header of the Data Controls panel.You can design a databound user interface by dragging an item from the Data Controls panel and dropping it on a page as a specific UI component. When you use data controls to create a UI component, JDeveloper automatically creates the various code and objects needed to bind the component to the data control you selected.
In the Data Controls panel, each object is represented by a specific icon. Table 2-1 describes what each icon represents, where it appears in the Data Controls panel hierarchy, and what components it can be used to create.
Table 2-1 The Data Controls Panel Icons and Object Hierarchy
| Icon | Name | Description | Used to Create... | 
|---|---|---|---|
| 
 | Data Control | Represents a data control. You cannot use the data control itself to create UI components, but you can use any of the child objects listed under it. Depending on how your business services were defined, there may be more than one data control. | Serves as a container for the other objects, and is not used to create anything. | 
| 
 | Accessor Returned Collection | Represents an object returned by a bean-style accessor method on the business service. For example, if when you created a session bean, you chose to also create accessor methods for each of the Java entities under the session bean, then an accessor returned collection is displayed for each of those entities. If an entity contains a relationship to another entity (for example, a foreign key), then a child accessor returned collection is shown for that entity In ADF, the relationship between parent and child entities is called a master-detail relationship. The children under a collection may be attributes of the elements that make up the collection, operations on the entire collection, or operations on the row for each element in the collection. | For collections: forms, tables, trees, range navigation components, and master-detail widgets. For single objects: forms, master-detail widgets, and selection lists. For more information about creating forms, and navigation components, see Chapter 3, "Creating a Basic Databound Page." For more information about creating tables, see Chapter 4, "Creating ADF Databound Tables." For information about creating trees and other master-detail UI components, see Chapter 5, "Displaying Master-Detail Data." For information about creating lists, see Chapter 6, "Creating Databound Selection Lists." | 
| 
 | Attribute | Represents a discrete data element in an object (for example, an attribute in a row). Attributes appear as children under the collections or method returns to which they belong. | Label, text field, date and selection list components. For information about creating text fields, see Section 3.2, "Using Attributes to Create Text Fields." | 
| 
 | Method | Represents an operation in the data control or one of its exposed structures that may accept parameters, perform some business logic, and optionally return a single value, a structure, or a collection of a single value and a structure. | Command components. For methods that accept parameters: command components and parameterized forms. For information about creating command components from methods, see Section 3.6, "Creating a Form to Edit an Existing Record." For information about creating parameterized forms, see Section 3.5, "Creating a Form Using a Method That Takes Parameters." | 
| 
 | Method Return | Represents an object that is returned by a custom method. The returned object can be a single value or a collection. A method return appears as a child under the method that returns it. The objects that appear as children under a method return can be attributes of the collection, other methods that perform actions related to the parent collection, or operations that can be performed on the parent collection. | For single values: text fields and selection lists. For collections: forms, tables, trees, and range navigation components. When a single-value method return is dropped, the method is not invoked automatically by the framework. A user either has to also create an invoke action as an executable, or drop the corresponding method as a button to invoke the method. | 
| 
 | Operation | Represents a built-in data control operation that performs actions on the parent object. Data control operations are located in an Operations node under collections or method returns. The operations that are children of a particular collection or method return operate on those objects only. If an operation requires one or more parameters, they are listed in a Parameters node under the operation. | Command components such as buttons or links. For information about creating command components from operations, see Section 3.4, "Incorporating Range Navigation into Forms." | 
| 
 | Parameter | Represents a parameter value that is declared by the method or operation under which it appears. Parameters appear in the Parameters node under a method or operation. | Label, text, and selection list components. | 
JDeveloper provides you with a predefined set of UI components from which to choose for each data control item you drop.
To use the Data Controls panel to create UI components:
Select an item in the Data Controls panel and drag it onto the visual editor for your page. For a definition of each item in the panel, see Table 2-1.
From the ensuing context menu, select a UI component.
When you drag an item from the Data Controls panel and drop it on a page, JDeveloper displays a context menu of all the default UI components available for the item you dropped.
Figure 2-6 shows the context menu displayed when an accessor returned collection from the Data Controls panel is dropped on a page.
Depending on the component you select from the context menu, JDeveloper may display a dialog that enables you to define how you want the component to look.
The resulting UI component appears in the JDeveloper visual editor, as shown in Figure 2-7.
Tip:
Instead of creating automatically bound UI components using the Data Controls panel, you can create your UI first and then bind the components to the ADF Model layer. For more information, see the "Using Simple UI First Development" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.When a web application is built using the Data Controls panel, JDeveloper does the following:
Creates a DataBindings.cpx file in the default package for the project (if one does not already exist), and adds an entry for the page.
DataBindings.cpx files define the binding context (a container object that holds a list of available data controls and data binding objects) for the application. Each DataBindings.cpx file maps individual pages to the binding definitions in the page definition file and registers the data controls used by those pages. Figure 2-8 shows a DataBindings.cpx file in the overview editor of JDeveloper.
Example 2-3 shows the code from the corresponding XML file.
Example 2-3 DataBindings.cpx File
<?xml version="1.0" encoding="UTF-8" ?>
<Application xmlns="http://xmlns.oracle.com/adfm/application"
             version="11.1.1.54.7" id="DataBindings" SeparateXMLFiles="false"
             Package="oracle.fodemo.supplier" ClientType="Generic"
             ErrorHandlerClass="oracle.fodemo.frmwkext.CustomErrorHandlerImpl">
  <definitionFactories>
    <factory nameSpace="http://xmlns.oracle.com/adf/controller/binding"
             className="oracle.adf.controller.internal.binding.
                                                  TaskFlowBindingDefFactoryImpl"/>
    <dtfactory className="oracle.adf.controller.internal.dtrt.binding.
                                                         BindingDTObjectFactory"/>
  </definitionFactories>
  <pageMap>
    <page path="/templates/StoreFrontTemplate.jspx"
          usageId="oracle_fodemo_supplier_StoreFrontTemplatePageDef"/>
    <page path="/browse.jspx" usageId="oracle_fodemo_supplier_browsePageDef"/>
    <page path="/supplier/supplierDetails.jspx"
          usageId="oracle_fodemo_supplier_supplierdetailPageDef"/>
    <page path="/login_error.jspx"
          usageId="oracle_fodemo_supplier_login_errorPageDef"/>
. . .
  </pageMap>
  <pageDefinitionUsages>
    <page id="oracle_fodemo_supplier_StoreFrontTemplatePageDef"
          path="templates.StoreFrontTemplatePageDef"/>
    <page id="oracle_fodemo_supplier_browsePageDef"
          path="oracle.fodemo.supplier.pageDefs.browsePageDef"/>
    <page id="oracle_fodemo_supplier_supplierdetailPageDef"
          path="oracle.fodemo.supplier.pageDefs.supplierdetailPageDef"/>
    <page id="oracle_fodemo_supplier_login_errorPageDef"
          path="oracle.fodemo.supplier.pageDefs.login_errorPageDef"/>
. . .
  </pageDefinitionUsages>
  <dataControlUsages>
    <dc id="GenericServiceFacadeLocal"
        path="oracle.fodemo.supplier.model.GenericServiceFacadeLocal"/>
    <dc id="SupplierFacadeLocal"
        path="oracle.fodemo.supplier.model.SupplierFacadeLocal"/>
  </dataControlUsages>
</Application>
For more information about the .cpx file, see the "Working with the DataBindings.cpx File" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
Creates the adfm.xml file in the META-INF directory. This file creates a registry for the DataBindings.cpx file, and is used by the applications metadata layer to allow customization and personalization of the application. Example 2-4 shows an example of an adfm.xml file.
For web applications, registers the ADF binding filter in the web.xml file.
The ADF binding filter preprocesses any HTTP requests that may require access to the binding context. For more information about the filter, see the "Configuring the ADF Binding Filter" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
Adds the following libraries to the project:
ADF Model Runtime
ADF Model Generic Runtime
Adds a page definition file (if one does not already exist for the page) to the page definition subpackage. The default subpackage is view.pageDefs in the adfmsrc directory.
The page definition file (pageNamePageDef.xml) defines the ADF binding container for each page in an application's view layer. The binding container provides runtime access to all the ADF binding objects. Figure 2-9 shows a page definition file in the overview editor of JDeveloper.
Configures the page definition file, which includes adding definitions of the binding objects referenced by the page. Example 2-5 shows the corresponding XML for a page definition.
Example 2-5 Page Definition File
<pageDefinition xmlns="http://xmlns.oracle.com/adfm/uimodel"
                version="11.1.1.54.43" id="browsePageDef"
                Package="oracle.fodemo.supplier.pageDefs">
  <parameters/>
  <executables>
    <variableIterator id="variables"/>
    <page path="templates.StoreFrontTemplatePageDef" id="pageTemplateBinding"
          Refresh="ifNeeded"/>
    <iterator Binds="root" RangeSize="25" DataControl="SupplierFacadeLocal"
              id="SupplierFacadeLocalIterator"/>
    <accessorIterator MasterBinding="SupplierFacadeLocalIterator"
                      Binds="productFindAll" RangeSize="25"
                      DataControl="SupplierFacadeLocal"
                      BeanClass="oracle.fodemo.supplier.model.Product"
                      id="productFindAllIterator" Refresh="ifNeeded"/>
    <searchRegion Criteria="__ImplicitViewCriteria__"
                  Customizer="oracle.jbo.uicli.binding.JUSearchBindingCustomizer"
                  Binds="productFindAllIterator"
                  id="ImplicitViewCriteriaQuery" />
  </executables>
  <bindings>
    <tree IterBinding="productFindAllIterator" id="productFindAll">
      <nodeDefinition DefName="oracle.fodemo.supplier.model.Product"
                      Name="productFindAll0">
        <AttrNames>
          <Item Value="productId"/>
          <Item Value="productName"/>
          <Item Value="costPrice"/>
          <Item Value="listPrice"/>
          <Item Value="minPrice"/>
          <Item Value="productStatus"/>
        </AttrNames>
      </nodeDefinition>
    </tree>
    <methodAction id="removeProduct" RequiresUpdateModel="true"
                  Action="invokeMethod" MethodName="removeProduct"
                  IsViewObjectMethod="false" DataControl="SupplierFacadeLocal"
                  InstanceName="SupplierFacadeLocal.dataProvider">
      <NamedData NDName="product"
              NDValue="${bindings.productFindAllIterator.currentRow.dataProvider}"
                 NDType="oracle.fodemo.supplier.model.Product"/>
    </methodAction>
    <action IterBinding="productFindAllIterator" id="Delete"
            RequiresUpdateModel="false" Action="removeCurrentRow"/>
  </bindings>
</pageDefinition>
For more information about the page definition file, see the "Working with Page Definition Files" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
Adds prebuilt components to the view page.
These prebuilt components include ADF data bindings that reference the binding objects in the page definition file. Example 2-6 shows a JSF page that contains components that have been bound using ADF Model data binding. Note that values of the output text components are bound to values of the productsFindAll binding object, as defined in the page definition file in Example 2-5.
Example 2-6 JSF Page with ADF Model Data Binding
.
.
.
<af:column sortProperty="costPrice" sortable="false"
           headerText="#{bindings.productFindAll.hints.costPrice.label}"
           id="c6" align="right">
  <af:outputText value="#{row.costPrice}" id="ot1">
    <af:convertNumber groupingUsed="false"
                     pattern="#{bindings.productFindAll.hints.costPrice.format}"/>
  </af:outputText>
</af:column>
<af:column sortProperty="listPrice" sortable="false"
           headerText="#{bindings.productFindAll.hints.listPrice.label}"
           id="c1" align="right">
  <af:outputText value="#{row.listPrice}" id="ot6">
    <af:convertNumber groupingUsed="false"
                     pattern="#{bindings.productFindAll.hints.listPrice.format}"/>
  </af:outputText>
</af:column>
<af:column sortProperty="minPrice" sortable="false"
           headerText="#{bindings.productFindAll.hints.minPrice.label}"
           id="c3" align="right">
  <af:outputText value="#{row.minPrice}" id="ot3">
    <af:convertNumber groupingUsed="false"
                      pattern="#{bindings.productFindAll.hints.minPrice.format}"/>
  </af:outputText>
</af:column>.
.
.
.
For applications that use ADF Faces, adds all the files, and configuration elements required by ADF Faces components. For more information, see the Oracle Fusion Middleware Web User Interface Developer's Guide for Oracle Application Development Framework.
When a page contains ADF bindings, at runtime the interaction with the business services initiated from the client or controller is managed by the application through the binding context. The binding context is a runtime map (named data and accessible through the EL expression #{data}) of all data controls and page definitions within the application.
The ADF lifecycle creates the ADF binding context from the DataControls.dcx, DataBindings.cpx, and page definition files, as shown in Figure 2-10. The DataControls.dcx file defines the data controls available to the application at design time, while the DataBindings.cpx files define what data controls are available to the application at runtime. A DataBindings.cpx file lists all the data controls that are being used by pages in the application and maps the binding containers, which contain the binding objects defined in the page definition files, to web page URLs, or in the case of a Java Swing application, the Java class. The page definition files define the binding objects used by the application pages. There is one page definition file for each page.
The binding context does not contain real live instances of these objects. Instead, the map first contains references that become data control or binding container objects on demand. When the object (such as the page definition) is released from the application (for example when a task flow ends or when the binding container or data control is released at the end of the request), data controls and binding containers turn back into reference objects. For more information, see the "Understanding the Fusion Page Lifecycle" chapter of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
When a data control modifies a collection, the data control must instantiate a new instance of the collection in order for the ADF Model layer to understand that it has been modified. In other words, although some action in the client may change the collection, that change will not be reflected in the UI unless a new instance of the collection is created. However, for performance reasons, accessor and method iterators cache their results set (by default, the cacheResults attribute on the iterator is set to true). This setting means that the iterator is refreshed and a new instance of the collection is created only when the page is first rendered. The iterator is not refreshed when the page is revisited, for example, if the page is refreshed using partial page rendering, or if the user navigates back to the page.
For example, say you want to allow sorting on a table on your page. Because you want the page to refresh after the sort, you add code to the listener for the sort event that will refresh the table using partial page rendering (for more information, see the "Rendering Partial Page Content" chapter of the Oracle Fusion Middleware Web User Interface Developer's Guide for Oracle Application Development Framework). Because the instance of the collection for the table has already been instantiated and is cached, the accessor iterator will not reexecute, which means that a new instance of the collection with the new sort order will not be created, so the sort order on the page will remain the same.
To work around this issue, you can either configure the iterator so that it does not cache the results, or you can place a button on the page that can be used to reexecute the iterator when the page is refreshed. If your page does not have a button whose action attribute can be bound to a method, then you can use an invokeAction executable that will be invoked whenever the page is refreshed.
Note:
If your page uses the navigation operations to navigate through the collection, do not setCacheResults to false, as that navigation will no longer work. You must use a button to reexecute the iterator. For more information about the navigation operations, see Section 3.4, "Incorporating Range Navigation into Forms."Performance Tip:
If you set an iterator to not cache its result set, and that result set is a collection that may return a large number of rows, performance will be negatively affected. For large result sets, you should use aninvokeAction.To set an iterator to not cache its result set:
Open the page definition file, and in the Structure window, select the iterator whose results should not be cached.
In the Property Inspector, expand the Advanced section and set CacheResults to false.
To use a button to reexecute the iterator:
From the ADF Faces page of the Component Palette, drag and drop a Button onto the page.
In the Structure window, right click the button and in the context menu, choose Bind to ADF Control.
In the Bind to ADF Control dialog, expand the accessor associated with the iterator to reexecute, expand that accessor's Operations node, and select Execute.
To use an invokeAction to reexecute the iterator:
Open the page definition file, and in the Structure window, right-click executables and choose Insert inside executables > invokeAction.
In the Insert invokeAction dialog, set id to a unique name. Use the Binds dropdown list to select the iterator to be reexecuted.
With the newly created invokeAction still selected, in the Property Inspector, set Refresh to prepareModel.
This setting will cause the accessor method to be invoked during the Prepare Model phase. This refreshes the binding container.
Set RefreshCondition to an EL expression that will cause the refresh to happen only if any value has actually changed. If this condition is not set, the invokeAction will be called twice.
For example, the expression #{(userState.refresh) and (!adfFacesContext.postback)} will cause the refresh to happen only if the page is refreshed.
For more information about the page lifecycle phases and using the refresh and refreshCondition attributes, see "The JSF and ADF Page Lifecycle" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
You can set validation on the attribute bindings in a page definition file. When a user edits or enters data in a field for an attribute for which validation has been defined, and submits the form, the bound data is validated against the configured rules and conditions. If validation fails, the application displays an error message. For information and procedures on setting model layer validation, see the "Adding ADF Model Layer Validation" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
When you set validation, you can define the error message that will be displayed. By default, these messages are displayed in a client dialog. You can configure these messages to display inline instead. For more information, see the "Displaying Error Messages" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.
You can also change the way messages are handled by creating your own error handling class. For more information, see the "Customizing Error Handling" section of the Oracle Fusion Middleware Fusion Developer's Guide for Oracle Application Development Framework.