Search code examples
htmltemplatesprimefacesjsf-2xhtml

Getting Error: UIInstructions cannot be cast to org.primefaces.model.menu.MenuElement


I am trying to run the code of that is taken directly from primefaces website, but i am getting an error of UIInstructions cannot be cast to org.primefaces.model.menu.MenuElement

/This is my AddUser.xhtml code/

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:p="http://primefaces.org/ui"
      >

<h:head>
        <title>Getting User Information</title>

</h:head>
<h:body>
<h:form>
        <p:menubar>
        <p:submenu label="File" icon="ui-icon-document">
            <p:submenu label="New" icon="ui-icon-contact">
                <p:menuitem value="Project" url="#" />
                <p:menuitem value="Other" url="#" />
            </p:submenu>
            <p:menuitem value="Open" url="#" />
            <p:separator />
            <p:menuitem value="Quit" url="#" />
        </p:submenu>
 
        <p:submenu label="Edit" icon="ui-icon-pencil">
            <p:menuitem value="Undo" url="#" icon="ui-icon-arrowreturnthick-1-w" />
            <p:menuitem value="Redo" url="#" icon="ui-icon-arrowreturnthick-1-e" />
        </p:submenu>
 
        <p:submenu label="Help" icon="ui-icon-help">
            <p:menuitem value="Contents" url="#" />
            <p:submenu label="Search" icon="ui-icon-search">
                <p:submenu label="Text">
                    <p:menuitem value="Workspace" url="#" />
                </p:submenu>
                <p:menuitem value="File" url="#" />
            </p:submenu>
        </p:submenu>
 
        <p:submenu label="Actions" icon="ui-icon-gear">
            <p:submenu label="Ajax" icon="ui-icon-refresh">
                <p:menuitem value="Save" actionListener="#{menuView.save}" icon="ui-icon-disk" update="messages"/>
                <p:menuitem value="Update" actionListener="#{menuView.update}" icon="ui-icon-arrowrefresh-1-w" update="messages"/>
            </p:submenu>
            <p:submenu label="Non-Ajax" icon="ui-icon-newwin">
                <p:menuitem value="Delete" actionListener="#{menuView.delete}" icon="ui-icon-close" update="messages" ajax="false"/>
            </p:submenu>
        </p:submenu>
 
        <p:menuitem value="Quit" url="http://www.primefaces.org" icon="ui-icon-close" />
 
        <f:facet name="options">
            <p:inputText style="margin-right:10px" placeholder="Search"/>
            <p:commandButton type="button" value="Logout" icon="ui-icon-extlink" />
        </f:facet>
    </p:menubar>

</h:form>
</h:body>
</html>

/This is my web.xml file/

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
  <display-name>UserWebApp</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
  <servlet>
    <servlet-name>Faces Servlet</servlet-name>
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Faces Servlet</servlet-name>
    <url-pattern>/faces/*</url-pattern>
     <url-pattern>*.xhtml</url-pattern>
    <url-pattern>*.jsf</url-pattern>

  </servlet-mapping>

   <context-param>
    <param-name>primefaces.THEME</param-name>
    <param-value>afterdark</param-value>
    </context-param>

    <context-param>
    <param-name>facelets.SKIP_COMMENTS</param-name>
    <param-value>true</param-value>
    </context-param>


    <context-param>
    <param-name>javax.faces.FACELETS_LIBRARIES</param-name>
    <param-value>/WEB-INF/my.taglib.xml</param-value>
</context-param>

</web-app>

/And my jar file is also placed in webInf/lib/

enter image description here

I have tried everything available online but still unable o solve it Thanks in advance


Solution

  • I figured out the problem. I was copying the MenuBar code directly from primefaces website (https://www.primefaces.org/showcase/ui/menu/menubar.xhtml)

    And then i realized that there are invisible characters/stuff present between each line of code. (i figured this out when i copied/paste java class code), once these invisible stuff id deleted and my code works perfectly.

    /Following code is also the primefaces website code but free of invisible characters/

    <h:form>
    <p:growl id="messages"/>
    <p:menubar>
    <p:submenu label="File" icon="ui-icon-document">
    <p:submenu label="New" icon="ui-icon-contact">
    <p:menuitem value="Project" url="#" />
    <p:menuitem value="Other" url="#" />
    </p:submenu>
    <p:menuitem value="Open" url="#" />
    <p:separator />
    <p:menuitem value="Quit" url="#" />
    </p:submenu>
    <p:submenu label="Edit" icon="ui-icon-pencil">
    <p:menuitem value="Undo" url="#" icon="ui-icon-arrowreturnthick-1-w" />
    <p:menuitem value="Redo" url="#" icon="ui-icon-arrowreturnthick-1-e" />
    </p:submenu>
    <p:submenu label="Help" icon="ui-icon-help">
    <p:menuitem value="Contents" url="#" />
    <p:submenu label="Search" icon="ui-icon-search">
    <p:submenu label="Text">
    <p:menuitem value="Workspace" url="#" />
    </p:submenu>
    <p:menuitem value="File" url="#" />
    </p:submenu>
    </p:submenu>
    <p:submenu label="Actions" icon="ui-icon-gear">
    <p:submenu label="Ajax" icon="ui-icon-refresh">
    <p:menuitem value="Save" actionListener="#{menuView.save}" icon="ui-icon-disk" update="messages"/>
    <p:menuitem value="Update" actionListener="#{menuView.update}" icon="ui-icon-arrowrefresh-1-w" update="messages"/>
    </p:submenu>
    <p:submenu label="Non-Ajax" icon="ui-icon-newwin">
    <p:menuitem value="Delete" actionListener="#{menuView.delete}" icon="ui-icon-close" update="messages" ajax="false"/>
    </p:submenu>
    </p:submenu>
    <p:menuitem value="Quit" url="http://www.primefaces.org" icon="ui-icon-close" />
    <f:facet name="options">
    <p:inputText style="margin-right:10px" placeholder="Search"/>
    <p:commandButton type="button" value="Logout" icon="ui-icon-extlink" />
    </f:facet>
    </p:menubar>
    
    </h:form>