Use Case
- JSF Page with two tabs (Departments, Employees)
The DepartmentName is rendered as a command link. If the user clicks on a DepartmentName the view changes on to the Employees Tab and filters the data
- In each tab there is an static adf region (bound to fragment based BTF)
- DepartmentName as command link
- View switches to the Employees Tab
- Tab text should change to “Employees (<DepartmentName>)
- On the employees tab - of course – only the corresponding entries should be displayed
- The employees tab contains a button to remove the “global” filter.
How to do it?
Create DataExchange Bean as followspublic class DeptEmpExchange {
private Number deptId;
private String deptName;
public DeptEmpExchange() {
super();
System.out.println("DeptEmpExchange created " + this);
}
public void setDeptId(Number deptId) {
this.deptId = deptId;
}
public Number getDeptId() {
return deptId;
}
public void setDeptName(String deptName) {
this.deptName = deptName;
}
public String getDeptName() {
return deptName;
}
/**
* Exposed as DC Operation.
* Called from the dept btf
* @param deptId
* @param deptName
*/
public void onDepartmentChange(final Number deptId,
final String deptName) {
System.out.println("onDepartmentExchange called: " + deptId + "/" + deptName);
setDeptId(deptId);
setDeptName(deptName);
View1Bean view1 = (View1Bean)JSFUtils.resolveExpression("#{View1Bean}");
view1.getEmpTab().setDisclosed(true);
view1.getDeptTab().setDisclosed(false);
view1.setEmpTabText("Employees ("+deptName+")");
AdfFacesContext.getCurrentInstance().addPartialTarget(view1.getPanelTabbed());
}
And expose as JavaBean DataControl.
Now, on depts page fragment: drop the exposed operation onto the command link and provide the parameters from the current row.
data:image/s3,"s3://crabby-images/9f2f2/9f2f2ca3426a28ab12ffb50c7715cf3959f06ec7" alt="image image"
The refresh of the panel tabbed is done programmatically in the onDepartmentChange(..) method. In order to refresh the emp btf with the new dept id configure the following bindings / properties on the main page
data:image/s3,"s3://crabby-images/1fc30/1fc3086cbb2eb0c826fed47b73b79a8d9b664be0" alt="image image"
- create an attribute binding on the deptId from the DeptEmpExchange Bean.
- bind the tf input parameter to the attribute binding
- do not forget to set refresh=ifNeeded => this causes the btf to refresh in case the input params will change.
Implementing the “remove global filter” functionality is pretty simple. Just drag the onDepartmentChange-Operation from the data control palette on to the toolbar and adjust the text.
data:image/s3,"s3://crabby-images/634cc/634cca104517afe45f26237a80b062dd5f552612" alt="image image"
data:image/s3,"s3://crabby-images/33939/33939c311f39fe6df53b03ef9b50be21bdde2c35" alt="image image"
I hope I have not forgotten any important steps.
Download JDev11112Workspace
Update on Dec 19th 2011: Added Sample Application