odoo中如何实现点击按钮下载文件报告、报表到页面左下角

models.py

# -*- coding: utf-8 -*-
from openerp import models, fields, api
import logging try:
import xlwt
except ImportError:
xlwt = None import json
import urllib2 _logger = logging.getLogger(__name__) class test_module_template(models.Model):
_name = 'test.module.template'
_description = u'测试模块' def request_pdf_from(self, data, response):
""" 从服务器请求pdf """ server_url = "https://zhaichangyuan.jsreportonline.net/api/report"
server_data = {
"template": {"name": "template-main"},
'Headers': 'Content-Type: application/json',
# 'subject': '测试jsreport接口',
# 'BODY': {
# # "name": "invoice-main",
# # "recipe": "html-to-xlsx",
# # "engine": "handlebars",
# # "content": "<h1>sample content</h1>",
# },
"data": {
"number": "FP201904120003",
"seller": {
"name": u"北京百星电子系统有限公司",
"road": u"北京·枢密院",
"country": u"中国.北京"
},
"buyer": {
"name": u"中国建筑研究设计院",
"road": u"北京市海淀区中关村创业大厦",
"country": u"中国.北京"
},
"items": [
{
"name": u"网页设计",
"price": 400.00,
"city": "Beijing"
},
{
"name": u"程序开发",
"price": 1500.00,
"city": "Shanghai"
},
{
"name": u"系统运维",
"price": 600.00,
"city": "Beijing"
},
{
"name": u"硬件维护",
"price": 700.00,
"city": "Shenzhen"
},
{
"name": u"AI智能",
"price": 300.00,
"city": "Shanghai"
},
{
"name": u"软件开发",
"price": 100.00,
"city": "Wuhan"
},
{
"name": u"程序测试",
"price": 800.00,
"city": "Shanghai"
}
]
},
"options": {"timeout": 60000}
} headers = {
# "Accept": "application/pdf",
"Content-Type": "application/json",
"Authorization": "Basic d29ybWVyQHdvcm1lLmNuOklPUGlvcCooKTg5MA==",
}
request = urllib2.Request(server_url, data=json.dumps(server_data), headers=headers)
res = urllib2.urlopen(request)
#print res.read()
# file_Handle = open('report_test111.xlsx', 'w')
# file_Handle.write(response.read())
# file_Handle.close()
response.set_data(res.read())
return response @api.multi
def action_print(self):
return {
'type': 'ir_actions_jsreport_xls_download',
'data': {
'model': '',
'options': '',
'report_name': ''
}
} controllers/mains.py
# -*- coding: utf-8 -*-

import logging
import simplejson
from openerp import http
from openerp.http import request, Response _logger = logging.getLogger(__name__) class JsreportPrint(http.Controller): @http.route('/jsreport/xls/download', type='http', auth='public', methods=['POST'], csrf=False)
def jsreport_xls_download(self, action, token, **kw):
_logger.info(action)
data = simplejson.loads(action)
options = data.get('data').get('options')
report_name = u"jsreport_report"
uid = request.session.uid response = request.make_response(None,
headers=[('Content-Type', 'application/vnd.ms-excel'),
('Content-Disposition', 'attachment; filename=' + report_name + '.xlsx;')],
cookies={'fileToken': token}) obj = request.env['test.module.template'].sudo(uid)
return obj.request_pdf_from(options, response) static/src/js/jsreport_xls_print.js
openerp.test_module_template = function (instance) {
instance.web.ActionManager = instance.web.ActionManager.extend({
ir_actions_jsreport_xls_download: function (action, options) {
var self = this;
instance.web.blockUI();
action = _.clone(action); var c = instance.webclient.crashmanager;
console.log(action);
return $.Deferred(function (d) {
self.session.get_file({
url: '/jsreport/xls/download',
data: {action: JSON.stringify(action)},
complete: instance.web.unblockUI,
success: function () {
if (!self.dialog) {
options.on_close();
}
self.dialog_stop();
d.resolve();
},
error: function () {
c.rpc_error.apply(c, arguments);
d.reject();
}
});
});
}
})
} views/template.xml
<?xml version="1.0" encoding="utf-8"?>
<!-- vim:fdn=3:
-->
<openerp>
<data>
<template id="jsreport_xls_print" name="jsreport_xls_print" inherit_id="web.assets_backend">
<xpath expr="." position="inside">
<script type="text/javascript" src="/test_module_template/static/src/js/jsreport_xls_print.js"></script>
</xpath>
</template>
</data>
</openerp> views/views.xml
<?xml version="1.0" encoding="utf-8"?>
<openerp>
<data>
<record id="test_module_template_form" model="ir.ui.view">
<field name="name">test.module.template.form</field>
<field name="model">test.module.template</field>
<field name="type">form</field>
<field name="arch" type="xml">
<form>
<header>
<button name="action_print" class="oe_highlight" string="打印" type="object"/>
</header>
</form>
</field>
</record> <record id="test_module_template_action" model="ir.actions.act_window">
<field name="name">测试</field>
<field name="type">ir.actions.act_window</field>
<field name="res_model">test.module.template</field>
<field name="view_type">form</field>
<field name="view_mode">form</field>
<field name="help" type="html">
<p class="oe_view_nocontent_create">测试单</p>
</field>
</record>
<menuitem name="主测试按钮" id="test_module_template_1" sequence="10"/>
<menuitem name="主测试按钮1" id="test_module_template_2" parent="test_module_template_1" sequence="10"/>
<menuitem name="测试按钮" id="test_module_template" sequence="10" parent="test_module_template_2"
action="test_module_template_action"/>
</data>
</openerp>

odoo 响应下载文件的更多相关文章

  1. CEfSharp下载文件 弹出保存框,实现 IDownloadHandler 接口

    上节讲了如何将CefSharp集成到C#中,但集成后将web界面链接进ChromiumWebBrowser后,但web界面上下载附件的功能不好使咯. 百度了半天还是没搞定,只能去看官网的Excampl ...

  2. Servlet下载文件和http响应

    下载文件等: 1.得到公共的内容ServletContext sc = this.getServletContext(); 2.在链接名字后面加个? 一个参数?参数1=值 两个参数?参数1=值& ...

  3. odoo按钮触发下载文件

    测试环境:Odoo8.0 1.在你的模块中创建一个方法,返回url 举个例子, @api.multi def get_stock_file(self): return{'type':'ir.actio ...

  4. [ASP.NET] 解决点击控件下载文件没有响应的问题

    下载文件的方法是使用http响应输出流来实现的,使用到了response.write() 导致下载文件时点击控件出错,没有响应,也获取不了文件 是因为在母版页使用了updatepanel,因此回传时发 ...

  5. 下载文件时HttpServletResponse设置响应头的Content-Disposition属性

    Content-Disposition属性有两种类型 inline :将文件内容直接显示在页面 attachment:弹出对话框让用户下载 弹出对话框下载文件 resp.setHeader(" ...

  6. Vue.js +pdf.js 处理响应pdf文件流数据,前端转图片预览不可下载

    使用场景及原因 实际业务中,一些说明书或协议仅支持用户在线预览,为避免用户自行下载,并进行修改,引发纠纷,特将文件已文件流的形式,传给前端并转为图片显示,此时可能会有人问,为什么不直接在后端转图片,前 ...

  7. .net 下载文件几种方式

    方式一:TransmitFile实现下载.将指定的文件直接写入 HTTP 响应输出流,而不在内存中缓冲该文件. protected void Button1_Click(object sender, ...

  8. LoadRunner上传及下载文件

    (1)LoadRunner上传文件 web_submit_data("importStudent.do", "Action=https://testserver/cons ...

  9. LoadRunner下载文件脚本

    LoadRunner下载文件脚本  在看普泽关于pezybase的测试报告的时候,发现里面有用到jmeter(http协议)并发测试下载文件,考虑到后面可能需要在公司pezybase的并发下载,把之前 ...

随机推荐

  1. 7系列FPGA的时钟资源——UG472

    时钟架构总览 7系的FPGA使用了专用的全局(Global)和区域(Regional)IO和时钟资源来管理设计中各种的时钟需求.Clock Management Tiles(CMT)提供了时钟合成(C ...

  2. Vue+SpringBoot+Mybatis的简单员工管理项目

    本文项目参考自:https://github.com/boylegu/SpringBoot-vue 为了完成此项目你需要会springBoot,mybatis的一些基本操作 运行界面 第一步:搭建前端 ...

  3. java中的stream的泛型方法的使用示例

    本文章使用jdk8测试 ,并结合使用lambda测试 测试前准备一些测试数据: class ObjectDemo { private Integer id; private String name; ...

  4. js通过高德地图获取当前位置的经度纬度

    效果图如下: 已经获取到了经度纬度了 代码如下: <!doctype html> <html> <head> <meta charset="utf- ...

  5. PyMysql的LIKE查询%问题

    今天写一个模糊匹配的接口的时候,发现PyMysql的防注入方式会将%给转义,就算是写两个%%也是无用,依旧查不出来结果 Google翻了,Baidu翻了,一样没有适用的解决方法. 后来灵机一动想到了方 ...

  6. EChart 文字大小调整 饼状图为例

    一.EChart图中的文字调整(以饼图为例) 二.源码: { "title": { "text": "", "subtext&qu ...

  7. 【EasyNetQ】- 发布/订阅模式

    EasyNetQ支持的最简单的消息传递模式是发布/ 订阅.这种模式是消除消费者信息提供者的绝佳方式.出版商简单地向全世界说,“这已经发生了”或“我现在有了这些信息”.它不关心是否有人正在倾听,他们可能 ...

  8. 一条很用的MSSQL语句

    select *,ActionName= stuff((select ',' + ActionName from Sys_Action_Table where ModuleId = Sys_Modul ...

  9. 微信小程序--家庭记账本开发--04

    界面的布局 在微信小程序开发过程中,界面的布局是十分重要的,无论是一个什么样的程序,界面的美观合理才能提供给客户一个较好的使用体验,就微信小程序布局自己看了许多小程序布局,自己将学习心得记录如下: 下 ...

  10. Centos6.5升级openssh、OpenSSL和wget

    1.OpenSSL 1.1.查看版本 使用如下命令查看版本: openssl version 1.2.安装gcc依赖 yum -y install gcc gcc-c++ 1.3.安装配置 ./con ...