树的每个节点上的不同上下文菜单

DHR*_*SAL 2 treeview jsf primefaces

在我的JSF项目中,我想根据某些条件在树的每个节点上显示不同的上下文菜单(准确地说是一些权限)

根据我的xhtml呈现,我已经与树绑定了上下文菜单,所以我在树的每个节点上获得相同的菜单.这是代码:

<p:contextMenu for="TreeID">
    <p:menuitem value="Create" update=":centerPanel" actionListener="#{someBean.createPrivilege}" onstart="statusDialog.show();"
        oncomplete="statusDialog.hide();" />
    <p:menuitem value="Edit" update=":commonDialog :centerPanel" actionListener="#{someBean.editPrivilege}"
        onstart="statusDialog.show();" oncomplete="statusDialog.hide();" />
    <p:menuitem value="Delete" onstart="delPrivilegeConfirmDialog.show();" />
</p:contextMenu>
<p:scrollPanel mode="native" styleClass="scroll-panel">
    <p:tree id="TreeID" value="root" var="node" selectionMode="single"
        selection="#{someBean.selectedNode}" dynamic="true">
        <p:ajax listener="#{someBean.onNodeSelect}" update=":centerPanel" event="select" onstart="statusDialog.show();"
            oncomplete="statusDialog.hide();" />
        <p:treeNode id="someID">
            <h:outputText value="#{node}" id="lblNode" />
        </p:treeNode>
    </p:tree>
</p:scrollPanel>
Run Code Online (Sandbox Code Playgroud)

但根据我的要求,我想在每个节点上使用不同的上下文菜单,基本上我在上下文菜单中有3个选项,如Create,Edit,Delete ..然后我需要根据特定条件在每个节点上隐藏1或2个选项.

我该怎么办?

提前致谢.

Pas*_*eli 8

假设您使用的是PrimeFaces,最近的版本提供了使用"nodeType"属性为不同节点类型设置不同上下文菜单的选项:

<p:contextMenu for="TreeID" nodeType="type1">
    <p:menuitem value="Create" update=":centerPanel" actionListener="#{someBean.createPrivilege}" onstart="statusDialog.show();"
        oncomplete="statusDialog.hide();" />
    <p:menuitem value="Edit" update=":commonDialog :centerPanel" actionListener="#{someBean.editPrivilege}"
        onstart="statusDialog.show();" oncomplete="statusDialog.hide();" />
    <p:menuitem value="Delete" onstart="delPrivilegeConfirmDialog.show();" />
</p:contextMenu>
<p:contextMenu for="TreeID" nodeType="type2">
    <!-- Other menu items -->
</p:contextMenu>
<p:scrollPanel mode="native" styleClass="scroll-panel">
    <p:tree id="TreeID" value="root" var="node" selectionMode="single"
        selection="#{someBean.selectedNode}" dynamic="true">
        <p:ajax listener="#{someBean.onNodeSelect}" update=":centerPanel" event="select" onstart="statusDialog.show();"
            oncomplete="statusDialog.hide();" />
        <p:treeNode id="someID" type="type1">
            <h:outputText value="#{node}" id="lblNode" />
        </p:treeNode>
        <p:treeNode id="someID" type="type2">
            <h:outputText value="#{node}" id="lblNode" />
        </p:treeNode>
    </p:tree>
</p:scrollPanel>
Run Code Online (Sandbox Code Playgroud)

请记住,您需要为模型生成的所有节点设置节点类型:

TreeNode x = new DefaultTreeNode("type1", data, parent);
Run Code Online (Sandbox Code Playgroud)