odoo10在顶部“创建”按钮附加增加自定义按钮

2023-11-21 17:38

本文主要是介绍odoo10在顶部“创建”按钮附加增加自定义按钮,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

HOW TO ADD BUTTON IN TREE VIEW HEADER NEAR “CREATE” AND “IMPORT” BUTTONS ODOO10


来自:https://supportuae.wordpress.com/2017/09/06/how-to-add-button-in-tree-view-header-near-create-and-import-buttons-odoo10/


1). I create some js script (tree_menu/static/src/js/tree_view_button.js) with click listener for my button :

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
odoo.define( 'tree_menu.tree_view_button' , function (require){
"use strict" ;
var core = require( 'web.core' );
var ListView = require( 'web.ListView' );
var QWeb = core.qweb;
ListView.include({      
     
         render_buttons: function ($node) {
                 var self = this ;
                 this ._super($node);
                     this .$buttons.find( '.o_list_tender_button_create' ).click( this .proxy( 'tree_view_action' ));
         },
         tree_view_action: function () {          
                 
         this .do_action({              
                 type: "ir.actions.act_window" ,              
                 name: "product" ,              
                 res_model: "product.template" ,              
                 views: [[ false , 'form' ]],              
                 target: 'current' ,              
                 view_type : 'form' ,              
                 view_mode : 'form' ,              
                 flags: { 'form' : { 'action_buttons' : true , 'options' : { 'mode' : 'edit' }}}
         });
         return { 'type' : 'ir.actions.client' , 'tag' : 'reload' , } }
});
});

2). After that, create tree_menu/static/src/xml/tree_view_button.xml with the template, which replaces “Create” button if I use project.project model

1
2
3
4
5
6
7
8
9
<? xml version = "1.0" encoding = "UTF-8" ?>
       < template id = "template" xml:space = "preserve" >      
           &l t ;t t-extend = "ListView.buttons" >                  
             &l t ;t t-jquery = "button.o_list_button_add" t-operation = "replace" >                          
                   < button t-if = "widget.model == 'purchase.order'" class = "btn btn-primary btn-sm o_list_tender_button_create" type = "button" >Create Tender</ button >
                   < button t-if = "widget.model != 'purchase.order'" class = "btn btn-primary btn-sm o_list_button_add" type = "button" >Create</ button >
             &l t ;/t>      
           &l t ;/t>  
       </ template >

3). After that, add js script in web.asset_backend (Create file tree_menu/views/tree_view_asset.xml)

1
2
3
4
5
6
7
8
9
10
<? xml version = "1.0" encoding = "utf-8" ?>  
< odoo >      
       < data >          
             < template id = "assets_backend" name = "tree view menu" inherit_id = "web.assets_backend" >              
                   < xpath expr = "." position = "inside" >                  
                         < script type = "text/javascript" src = "/tree_menu/static/src/js/tree_view_button.js" ></ script >              
                   </ xpath >          
             </ template >      
       </ data >  
</ odoo >

4). And finally, add in __manifest__.py section ‘qweb’ for ‘qweb’: [‘static/src/xml/tree_view_button.xml’], and place file views/project.xml in ‘data’ section.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
{
     'name': 'odoo10 Tree View JS Menu',
     'version': '1.0',
     'category': 'General',
     'summary': 'odoo10 Tree View JS Menu',
     'description': """ odoo10 Tree View JS Menu """,
     'author': 'Ananthu',
     'website': 'http://www.codersfort.com',
     'depends': ['base','purchase','web'],
     'data':[
             'views/tree_view_asset.xml',
             ],
     'qweb': ['static/src/xml/tree_view_button.xml'],      
     'demo': [],
     'installable': True,
     'application': True,
     'auto_install': False,
}


这篇关于odoo10在顶部“创建”按钮附加增加自定义按钮的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/403939

相关文章

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换

java创建xls文件放到指定文件夹中实现方式

《java创建xls文件放到指定文件夹中实现方式》本文介绍了如何在Java中使用ApachePOI库创建和操作Excel文件,重点是如何创建一个XLS文件并将其放置到指定文件夹中... 目录Java创建XLS文件并放到指定文件夹中步骤一:引入依赖步骤二:创建XLS文件总结Java创建XLS文件并放到指定文件

kafka自定义分区器使用详解

《kafka自定义分区器使用详解》本文介绍了如何根据企业需求自定义Kafka分区器,只需实现Partitioner接口并重写partition()方法,示例中,包含cuihaida的数据发送到0号分区... 目录kafka自定义分区器假设现在有一个需求使用分区器的方法总结kafka自定义分区器根据企业需求

linux ssh如何实现增加访问端口

《linuxssh如何实现增加访问端口》Linux中SSH默认使用22端口,为了增强安全性或满足特定需求,可以通过修改SSH配置来增加或更改SSH访问端口,具体步骤包括修改SSH配置文件、增加或修改... 目录1. 修改 SSH 配置文件2. 增加或修改端口3. 保存并退出编辑器4. 更新防火墙规则使用uf

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型