前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Odoo 菜单定义和修改学习总结

Odoo 菜单定义和修改学习总结

作者头像
授客
发布2023-02-26 16:51:09
1.2K0
发布2023-02-26 16:51:09
举报
文章被收录于专栏:授客的专栏授客的专栏

odoo菜单定义和修改学习总结

环境

odoo-14.0.post20221212.tar

定义菜单

方式1:

代码语言:javascript
复制
<?xml version="1.0"?>
<odoo>
    <menuitem id="root_menu_id" name="TopMenu" web_icon="estate,static/img/icon.png">
        <menuitem id="second_level_menu" name="SecondLevelMenu">
            <menuitem id="third_level_menu1" action="third_level_menu1_action" sequence ="10"/>
            <menuitem id="third_level_menu2" action="third_level_menu2_action" sequence ="20"/>
        </menuitem>
    </menuitem>
</odoo>

说明:

id 菜单外部ID

name

如果不指定name,则:

  • 如果为菜单设置了action,则获取action record定义中name字段的值作为菜单name属性的值
  • 如果未设置菜单action,则获取菜单外部ID为值作为菜单name属性的值

action

打开菜单时需要执行的action的外部ID

web_icon

指定菜单图标,格式:模块名称,图标路径,形如estate,static/img/icon.png 意为estate模块下的static/img/icon.png图标。其中图标路径,一般是相对于模块根目录的相对路径

sequence

设置菜单展示顺序。该属性值越大,越靠右、靠下方展示。也就是说,菜单从左往右,从上到下,对应sequence属性值从小到大。

<menuitem>元素也可以放在<data>元素中,形如

代码语言:javascript
复制
<?xml version="1.0"?>
<odoo>
    <data>
        <menuitem id="root_menu_id" name="TopMenu" web_icon="estate,static/img/icon.png">
        ...
        </menuitem>
    </data>
</odoo>

groups

逗号分隔的res.groups模型的外部ID序列,形如groups="group_account_user,group_account_manager,group_account_invoice",表示菜单只能被group_account_user,group_account_manager,group_account_invoice 三个用户组访问。用于指定可以访问菜单的用户组。如果外部ID以-为前缀,则从菜单组中移除该ID代表的组,注意,如果指定用户组不是在当前模块中定义的,需要指定所在模块名称,形如estate.group_estate_property_root_menu

示例:

代码语言:javascript
复制
<?xml version="1.0"?>
<odoo>
    <data>
        <menuitem id="root_menu_id" name="TopMenu" web_icon="estate,static/img/icon.png" groups="group_estate_property_root_menu">
        ...
        </menuitem>
    </data>
</odoo>

方式2:通过parent来设置菜单层级

代码语言:javascript
复制
<?xml version="1.0"?>
<odoo>
    <menuitem id="root_menu_id" name="TopMenu" web_icon="estate,static/img/icon.png"/>
    <menuitem id="second_level_menu" name="SecondLevelMenu" parent="root_menu_id"/>
    <menuitem id="third_level_menu1" action="third_level_menu1_action" sequence ="10" parent="second_level_menu"/>
    <menuitem id="third_level_menu2" action="third_level_menu2_action" sequence ="20" parent="second_level_menu"/>
</odoo>

说明:

  • parent

指定父级菜单外部ID,如果上级菜单不在当前模块中,则需要指定上级菜单所在模块,形如parent="moduleName.parent_menu_id"

修改菜单

本节要介绍的是一种特殊的修改方式,并不是直接修改原有菜单定义。这种修改方式之所以特殊,是因为它不修改原有菜单的定义,而是通过重新定义菜单来修改,可以简单的类比为“继承”,具体做法如下:

定义一个新的菜单<menuitem>,将其id属性值设置为原有菜单所在模块名称及其id属性值的组合,形如:moduleName.source_menu_id(参见下述示例),如果新的菜单和原有菜单在同一个模块,可以省略moduleName.

修改相关菜单属性值为目标值(如果需要的话)

示例:重新定义purchase.menu_purchase_root菜单名称

代码语言:javascript
复制
<menuitem id="purchase.menu_purchase_root" name="omsPurchase"/>

以新定义的菜单为父级菜单,添加子菜单(如果需要的话),添加方式可以参考上文所述,需要注意的是,不管采用哪种方式,原有菜单的子菜单依然存在,并显示为新定义菜单的子菜单

隐藏原有菜单的子菜单(如果需要的话)

定义一个<record>,将其id设置为要隐藏的子菜单所在模块名称及id属性值的组合,形如:moduleName.source_menu_id,如果新的菜单和原有菜单在同一个模块,可以省略moduleName.

将其model设置为"ir.ui.menu"

添加子元素 <field name="active" eval="False"></field>,其中eval=False则表示隐藏,eval=True表示显示

代码语言:javascript
复制
<?xml version="1.0"?>
<odoo>
    ...
    <record id="purchase.sub_menu_purchase" model="ir.ui.menu">
        <field name="active" eval="False"></field>
    </record>
</odoo>

参考连接

https://www.odoo.com/documentation/14.0/zh_CN/developer/reference/addons/data.html#shortcuts

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-02-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • odoo菜单定义和修改学习总结
    • 环境
      • 定义菜单
        • 修改菜单
          • 参考连接
          相关产品与服务
          访问管理
          访问管理(Cloud Access Management,CAM)可以帮助您安全、便捷地管理对腾讯云服务和资源的访问。您可以使用CAM创建子用户、用户组和角色,并通过策略控制其访问范围。CAM支持用户和角色SSO能力,您可以根据具体管理场景针对性设置企业内用户和腾讯云的互通能力。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档