Step 1)
Add your custom filter to the column filter facet.
Step 2) Create the getters and setters in your backing bean
NOTE: Dates
Filtered Dates with timestamps in ADF dont work very nicely if you just want to filter by date. So your can modify the date filters as above and here is some code to help with the process. (Note you will need to override the queryListener)
just call this from your listener.
ArrayList fieldNames = new ArrayList();
fieldNames.add("DateAttr");
queryWithDateFilter(
queryEvent, vo, "#{bindings.CustomVOQuery.processQuery}", fieldNames);
Add your custom filter to the column filter facet.
<f:facet name="filter"> <af:selectBooleanCheckbox value="#{backingBean.customfilter}" id="id99"/> </f:facet>
Step 2) Create the getters and setters in your backing bean
public Boolean getCustomfilter(){ Boolean returnobj = null; Object filterValue = super.getFilterValue("AttributeName"); if (filterValue != null){ returnobj = ("Y".equalsIgnoreCase(filterValue.toString())) ? Boolean.TRUE : Boolean.FALSE; } return returnobj; } public void setCustomfilter(Boolean deletefilter){ String value = filter == null ? null : (deletefilter) ? "Y" : "N"; super.setFilterValue(value, "AttributeName"); }
NOTE: Dates
Filtered Dates with timestamps in ADF dont work very nicely if you just want to filter by date. So your can modify the date filters as above and here is some code to help with the process. (Note you will need to override the queryListener)
just call this from your listener.
ArrayList
fieldNames.add("DateAttr");
queryWithDateFilter(
queryEvent, vo, "#{bindings.CustomVOQuery.processQuery}", fieldNames);
public void queryWithDateFilter( QueryEvent queryEvent, ViewObject vo, String mappedQueryEL, ListfieldNames){ FilterableQueryDescriptor fqd = (FilterableQueryDescriptor)queryEvent.getDescriptor(); Map map = fqd.getFilterCriteria(); if (fieldNames != null){ Map selectedValues = getSelectedValues(fieldNames, map); StringBuilder whereClauseSql = new StringBuilder(); for (String fieldKey : fieldNames){ String filterKey = "dateFilter_" + fieldKey; Object selectedValue = selectedValues.get(fieldKey); if (selectedValue != null){ fqd.getFilterCriteria().put(fieldKey, null); AttributeDef def = getAttributeDefForKeyName(vo, fieldKey); whereClauseSql.append( "TRUNC(" + def.getColumnNameForQuery() + ", 'DDD') = :" + filterKey); vo.defineNamedWhereClauseParam(filterKey, convertDate(selectedValue), null); vo.ensureVariableManager().setVariableValue( filterKey, convertDate(selectedValue)); } else { if (hasParam(filterKey, vo.getNamedWhereClauseParams())){ vo.removeNamedWhereClauseParam(filterKey); } } } if (whereClauseSql.length() > 0){ vo.setWhereClause(whereClauseSql.toString()); } else { vo.setWhereClause(whereClause); } JSFUtils.invokeMethodExpression( mappedQueryEL, Object.class, QueryEvent.class, queryEvent); for (String fieldKey : fieldNames){ Object selectedValue = selectedValues.get(fieldKey); fqd.getFilterCriteria().put(fieldKey, selectedValue); } } else { JSFUtils.invokeMethodExpression( mappedQueryEL, Object.class, QueryEvent.class, queryEvent); } } protected Map getSelectedValues( List fieldNames, Map mapValues){ Map returnMap = new HashMap (); Set set = mapValues.keySet(); for (String key : set){ if (fieldNames.contains(key)){ returnMap.put(key, mapValues.get(key)); } } return returnMap; } private Object convertDate(Object selectedValue){ if (selectedValue != null && selectedValue instanceof java.util.Date){ java.util.Date dateValue = (java.util.Date)selectedValue; return new Date(new java.sql.Date(dateValue.getTime())); } else { return selectedValue; } } protected AttributeDef getAttributeDefForKeyName( ViewObject vo, String fieldKey){ AttributeDef def = null; AttributeDef[] defs = vo.getAttributeDefs(); if (defs != null){ for (AttributeDef currentDef : defs){ if (currentDef.getName().equalsIgnoreCase(fieldKey)){ return currentDef; } } } return def; }
Comments
Post a Comment