Skip to content

Commit

Permalink
[MIG] report_xlsx - Backport from the 9.0 branch
Browse files Browse the repository at this point in the history
  • Loading branch information
sebalix committed Apr 26, 2016
1 parent 076b9bb commit fe69f0f
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 11 deletions.
20 changes: 15 additions & 5 deletions report_xlsx/README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,13 @@ Base report xlsx

This module provides a basic report class to generate xlsx report.

Installation
============

Make sure you have ``xlsxwriter`` Python module installed::

$ pip install xlsxwriter

Usage
=====

Expand All @@ -18,7 +25,7 @@ A python class ::
from openerp.addons.report_xlsx.report.report_xlsx import ReportXlsx

class partner_xlsx(ReportXlsx):

def generate_xlsx_report(self, workbook, data, partners):
for obj in partners:
report_name = obj.name
Expand All @@ -31,9 +38,12 @@ A python class ::
partner_xlsx('report.res.partner.xlsx',
'res.partner')

To manipulate the ``workbook`` and ``sheet`` objects, refer to the
`documentation <http://xlsxwriter.readthedocs.org/>`_ of ``xlsxwriter``.

A report XML record ::

<report
<report
id="partner_xlsx"
model="res.partner"
string="Print to XLSX"
Expand All @@ -45,15 +55,15 @@ A report XML record ::

.. image:: https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas
:alt: Try me on Runbot
:target: https://runbot.odoo-community.org/runbot/143/9.0
:target: https://runbot.odoo-community.org/runbot/143/8.0

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/reporting-engine/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us smashing it by providing a detailed and welcomed feedback
`here <https://github.com/OCA/reporting-engine/issues/new?body=module:%20report_xlsx%0Aversion:%209.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.
`here <https://github.com/OCA/reporting-engine/issues/new?body=module:%20report_xlsx%0Aversion:%208.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Credits
=======
Expand All @@ -74,4 +84,4 @@ This module is maintained by the OCA.

OCA, or the Odoo Community Association, is a nonprofit organization whose mission is to support the collaborative development of Odoo features and promote its widespread use.

To contribute to this module, please visit https://odoo-community.org.
To contribute to this module, please visit https://odoo-community.org.
2 changes: 1 addition & 1 deletion report_xlsx/models/ir_report.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
# Copyright 2015 ACSONE SA/NV (<http://acsone.eu>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

from openerp import api, fields, models
from openerp import fields, models


class IrActionsReportXml(models.Model):
Expand Down
13 changes: 9 additions & 4 deletions report_xlsx/report/report_xlsx.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,10 @@
# Copyright 2015 ACSONE SA/NV (<http://acsone.eu>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

from cStringIO import StringIO

from openerp.report.report_sxw import report_sxw
from openerp.api import Environment
from cStringIO import StringIO

import logging
_logger = logging.getLogger(__name__)
Expand All @@ -24,11 +25,15 @@ def create(self, cr, uid, ids, data, context=None):
if report.ids:
self.title = report.name
if report.report_type == 'xlsx':
objs = self.env[self.table].browse(ids)
return self.create_xlsx_report(data, objs)
return self.create_xlsx_report(ids, data, report)
return super(ReportXlsx, self).create(cr, uid, ids, data, context)

def create_xlsx_report(self, data, objs):
def create_xlsx_report(self, ids, data, report):
self.parser_instance = self.parser(
self.env.cr, self.env.uid, self.name2, self.env.context)
objs = self.getObjects(
self.env.cr, self.env.uid, ids, self.env.context)
self.parser_instance.set_context(objs, data, ids, 'xlsx')
file_data = StringIO()
workbook = xlsxwriter.Workbook(file_data)
self.generate_xlsx_report(workbook, data, objs)
Expand Down
Binary file modified report_xlsx/static/description/icon.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion requirements.txt
Original file line number Diff line number Diff line change
@@ -1 +1 @@
xlwt
xlwtxlsxwriter
Expand Down

0 comments on commit fe69f0f

Please sign in to comment.