Skip to main content

Auto Focus in ADF : Revisit

Auto focus on the first or name field of a jsff is difficult if it is loaded dynamically.

Here is one solution:

1) In your page or template add the following non visible text fields near the end of your page(these will set the client id of your field and execute some javascript):

<af:inputText clientComponent="true" id="hit7" value="#{formBean.focusId}" visible="false"/>

<inputText clientComponent="true" id="hit8" value="#{formBean.focusScript}" visible="false"/>

2) Backing bean (MUST use view scope):
//member variables
 private boolean mustExecuteAutoFocus = false;
 private String clientFocusId = null;
 //Constructor - this will be called when the taskflow id changes in the region
 public FormBean(){
  mustExecuteAutoFocus = true;
 }
 public String getFocusId(){
  //here you can use a bound component or find a component in the view root by id etc to get your id or just hard code it
  UIComponent comp = findFirstInputTextComponent();
  if (comp == null){
   setClientFocusId(null);
   return null;
  }
  setClientFocusId(comp.getClientId(FacesContext.getCurrentInstance()));
  return getClientFocusId();
}

public String getClientFocusId(){
 return clientFocusId;
}

public void setClientFocusId(String clientFocusId){
 this.clientFocusId = clientFocusId;
}

public String getAutoFocusClientScript(){
 if (getClientFocusId() != null && mustExecuteAutoFocus){
  executeScript("autoFocus('" + getClientFocusId() + "');");
  mustExecuteAutoFocus = false;
 }
 return "";
}


3) js
function focus(focusId) {
 var f = document.getElementById(focusId + '::content'); 
 if(f == null) {
  f = document.getElementById(focusId);
 }
 if (f != null) {
  setTimeout("focusElement('" + f.id + "');", 100);
 }
}

function focusElement(elementId) {
    var c = document.getElementById(elementId);
    if (c != null) {
        c.focus();
        c.select();
    }
}

Comments

Popular posts from this blog

MANIFEST.MF merge JDeveloper for an executable jar

Goto your project > properties. Then click on deployment in the menu. Edit or add a jar deployment profile. Fill in the details under jar options (select Include manifest and give it a main class name) Also remember that the merge functionality only works with a BLANK line at the end of the merge file. REALLY this caught me. My merge file contents: Class-Path: commons-codec-1.3.jar [...empty line here CRLF...]

JBO-25013: TooManyObjectsException

oracle.jbo.TooManyObjectsException: JBO-25013: Too many objects match the primary key oracle.jbo.Key[Key null ]. Ok so for you it may be trying to insert a duplicate record this should explain your problem (also check trigger they could be the cause.) NOTE: You can also try to create a new duplicate EO if you have a page with two VO's using the same EO. This could sort your problems. For me I needed to add a launch listener on my LOV and clear the cache of my vo. LOV <af:inputListOfValues id="NameId" popupTitle="#{bindings.Name.hints.label}" value="#{bindings.RolName1.inputValue}" label="#{bindings.RolName1.hints.label}" model="#{bindings.RolName1.listOfValuesModel}" required="#{bindings.RolName1.hints.mandatory}" columns="#{bindings.RolName1.hints.displayWidth}" shortDesc="#{bindings.RolName1.hints.tooltip}" launchPopupListener="#{backingBeanScope.backingBean.launchPop...

ADF Encountered deferred syntax #{ in template text.

OracleJSP error: oracle.jsp.parse.JspParseException:  Error: Encountered deferred syntax #{ in template text.  If intended as a literal, escape it or set directive  deferredSyntaxAllowedAsLiteral This normally happens when you have some tag lib dependancy problems but this was  not the case for me... My problem: For some reason my model project had web stuff in it(public html etc)  so I had to remove the public html stuff from my project and manually edit the Model.jpr project file and remove the tag lib entries at the bottom o the file. Go figure.