odoo14 创建按钮旁边添加按钮

107 篇文章 4 订阅
57 篇文章 7 订阅
js文件: tree_button.js
odoo.define('my_test.my.action.tree.button',function(require){
    "use strict";

    let ListController = require('web.ListController');

    ListController.include({
        renderButtons: function($node){
            let $buttons = this._super.apply(this, arguments);
            let tree_model =this.modelName;
            // let context = this.initialState.context.my_action;
            // 出现模型
            if (tree_model === 'my.action'){
                let but2 = "<button type=\"button\" t-if=\"widget.modelName == 'my.action'\" class=\"oe_highlight\">测试按钮</button>";
                let button2 = $(but2).click(this.proxy('my_action_test'));
                // this.$button.append(button2);
                this.$buttons.prepend(button2);
            }
            return $buttons;
        },
        // 按钮功能:弹出窗form视图
        my_action_test :function(){
            // 第一种:利用rpc调用py方法, 写逻辑
            return this._rpc({
                model: this.modelName,
                method: 'my_action_test',
                // kwargs: {//参数直接传就可以
                //     domain: this.domain,
                //     // m2m_field: this.m2m_field
                //     }
            }).then(function (result) {
                self.data = result;
            });
            // 第二种:js里面直接写方法
            // let action = {
            //     name:'导入',
            //     type:'ir.actions.act_window',
            //     res_model:'my.action',
            //     view_mode:'form',
            //     target:'new',
            //     views:[[false,'form']],
            // };
            // let self = this;
            // this.do_action(action,{
            //     on_close:function(){
            //         self.trigger_up('reload');
            //     }
            // });
        },
    });
});
引用js文件: add_button.xml
<odoo>
   <template id="tree_button_test" inherit_id="web.assets_backend" name="bicon_wms_base_assets_1">
        <xpath expr="." position="inside">
        <!--src是你自己的路径 /当前项目/static....-->
            <script type="text/javascript" src="/my_test/static/src/tree_button.js"></script>
        </xpath>
    </template>
</odoo>
引用addbutton.xml文件: _manifest.py
'data': [
    ...
    'views/add_button.xml',
    ...
],
相应的模块里面写
class MyAction(models.Model):
    _name = 'my.action'
    _description = '测试'

    user_id = fields.Many2one('res.users', string='业务员')
    count = fields.Float(string='销售合计')
    order_line = fields.One2many('my.action.line', 'line_id')

    def my_action_test(self):
        self.env['my.action'].create({
            'user_id': self.env.uid,
            'count': 100
        })

在这里插入图片描述

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

隔壁小红馆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值