Here is an example of how to create a Bar Graph in OAF. Graphs are created with the graphTable region style.
1) Create a new OA page:
Step 1
Step 2
Step 3
Step 1
In PR method, we call a method of AM to intiate query:
regards
1) Create a new OA page:
=========================
Right click on project (xxcus) --> New --> Web Tier --> OA Components --> select 'Page' item. Click OK. (This will open a popup window)
Name: BarGraphPG
Package: xxcus.oracle.apps.fnd.bargraph.webui
2) Create a new view object (VO):
=========================
Right click --> New View Object (This will open a wizard having 7 steps).
Step 1
Package: xxcus.oracle.apps.fnd.bargraph.server
Name: GraphVO
Choose the radio button 'Read-only Access' (as we are not performing any DML operation). Click Next.
Step 2
Enter the below query in 'Query Statement':
select ename, sal from employee
Step 3
Generate Impl class for the view object.
Keep defaults for step 4, 5, 6 & 7 and click Finish. Save All.
3) Create a new Application Module (AM):
=========================
Step 1
Package: xxcus.oracle.apps.fnd.bargraph.server
Name: BarGraphAM. Click Next.
Step 2
Here we will add an instance of the VO created in (2). Select GraphVO from 'Available View Objects' and shuttle it to 'Data Model' using ">" button.
Keep defaults for all other steps (3, 4). Click Finish.
4) Create a new Controller (CO):
=========================
Right click on pageLayout region and create a new controller
Name: BarGraphCO
package: xxcus.oracle.apps.fnd.bargraph.webui
5) Creating the Page Layout & Setting its Properties
=========================
1) Create a new region under pageLayout of type graphTable. This will automatically create a default graphs container. Also, it will add a graph to the graphs container along with two default graphData columns.
Now change the properties for each field from property inspector as shown below:
pageLayout:
ID: pageLayoutRN
AM Definition: xxcus.oracle.apps.fnd.bargraph.server.BarGraphAM
Window Title: Employee Salary Graph Page
Title: Employee Salary Graph
graphTable:
ID: graphTableRN
Graph render style: graph
set these properties for the graph:
ID: empSalGraph
Graph Type: vertical clustered bar
Title: Employee Name vs Salary
Size: Medium
X-axis label: Employee Name
set properties for graphData1:
ID: xAxisData
View Instance: GraphVO1
View Attribute: Ename
Purpose in Graph: groupLabels (it represents data on X-axis)
set properties for graphData1:
ID: yAxisData
View Instance: GraphVO1
View Attribute: Sal
Purpose in Graph: data (it represents data on Y axis)
Prompt: Salary
public void processRequest(OAPageContext pageContext ,OAWebBean webBean){
super.processRequest(pageContext,webBean);
OAApplicationModule am = pageContext.getRootApplicationModule();
Code for initQuery method in BarGraphAMImpl.java file:
am.invokeMethod(
"
initQuery
"
);
}
public void initQuery()
{
try{
GraphVOImpl graphVO=getGraphVO1();
graphVO.setMaxFetchSize(-1);
graphVO.executeQuery();
} catch(Exception ex){
ex.printStackTrace();
}
}
regards
RekhaKasyap.
No comments:
Post a Comment