[IMP] report_xlsx - Pass the report instance as well as ids of records to print to the 'create_xlsx_report' method + Instanciate the parser and make it available for the 'generate_xlsx_report' method
parent
9e6dd0d9dd
commit
8d054ceaf7
|
@ -8,6 +8,13 @@ Base report xlsx
|
||||||
|
|
||||||
This module provides a basic report class to generate xlsx report.
|
This module provides a basic report class to generate xlsx report.
|
||||||
|
|
||||||
|
Installation
|
||||||
|
============
|
||||||
|
|
||||||
|
Make sure you have ``xlsxwriter`` Python module installed::
|
||||||
|
|
||||||
|
$ pip install xlsxwriter
|
||||||
|
|
||||||
Usage
|
Usage
|
||||||
=====
|
=====
|
||||||
|
|
||||||
|
@ -17,7 +24,7 @@ A python class ::
|
||||||
|
|
||||||
from openerp.addons.report_xlsx.report.report_xlsx import ReportXlsx
|
from openerp.addons.report_xlsx.report.report_xlsx import ReportXlsx
|
||||||
|
|
||||||
class partner_xlsx(ReportXlsx):
|
class PartnerXlsx(ReportXlsx):
|
||||||
|
|
||||||
def generate_xlsx_report(self, workbook, data, partners):
|
def generate_xlsx_report(self, workbook, data, partners):
|
||||||
for obj in partners:
|
for obj in partners:
|
||||||
|
@ -28,8 +35,11 @@ A python class ::
|
||||||
sheet.write(0, 0, obj.name, bold)
|
sheet.write(0, 0, obj.name, bold)
|
||||||
|
|
||||||
|
|
||||||
partner_xlsx('report.res.partner.xlsx',
|
PartnerXlsx('report.res.partner.xlsx',
|
||||||
'res.partner')
|
'res.partner')
|
||||||
|
|
||||||
|
To manipulate the ``workbook`` and ``sheet`` objects, refer to the
|
||||||
|
`documentation <http://xlsxwriter.readthedocs.org/>`_ of ``xlsxwriter``.
|
||||||
|
|
||||||
A report XML record ::
|
A report XML record ::
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
'Odoo Community Association (OCA)',
|
'Odoo Community Association (OCA)',
|
||||||
'website': "http://acsone.eu",
|
'website': "http://acsone.eu",
|
||||||
'category': 'Reporting',
|
'category': 'Reporting',
|
||||||
'version': '8.0.1.0.0',
|
'version': '9.0.1.0.0',
|
||||||
'license': 'AGPL-3',
|
'license': 'AGPL-3',
|
||||||
'external_dependencies': {'python': ['xlsxwriter']},
|
'external_dependencies': {'python': ['xlsxwriter']},
|
||||||
'depends': [
|
'depends': [
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# Copyright 2015 ACSONE SA/NV (<http://acsone.eu>)
|
# Copyright 2015 ACSONE SA/NV (<http://acsone.eu>)
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
# 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):
|
class IrActionsReportXml(models.Model):
|
||||||
|
|
|
@ -2,9 +2,10 @@
|
||||||
# Copyright 2015 ACSONE SA/NV (<http://acsone.eu>)
|
# Copyright 2015 ACSONE SA/NV (<http://acsone.eu>)
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
# 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.report.report_sxw import report_sxw
|
||||||
from openerp.api import Environment
|
from openerp.api import Environment
|
||||||
from cStringIO import StringIO
|
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
_logger = logging.getLogger(__name__)
|
_logger = logging.getLogger(__name__)
|
||||||
|
@ -24,11 +25,15 @@ class ReportXlsx(report_sxw):
|
||||||
if report.ids:
|
if report.ids:
|
||||||
self.title = report.name
|
self.title = report.name
|
||||||
if report.report_type == 'xlsx':
|
if report.report_type == 'xlsx':
|
||||||
objs = self.env[self.table].browse(ids)
|
return self.create_xlsx_report(ids, data, report)
|
||||||
return self.create_xlsx_report(data, objs)
|
|
||||||
return super(ReportXlsx, self).create(cr, uid, ids, data, context)
|
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()
|
file_data = StringIO()
|
||||||
workbook = xlsxwriter.Workbook(file_data)
|
workbook = xlsxwriter.Workbook(file_data)
|
||||||
self.generate_xlsx_report(workbook, data, objs)
|
self.generate_xlsx_report(workbook, data, objs)
|
||||||
|
|
Loading…
Reference in New Issue