This module was written to extend the functionality of the reporting engine to support XML reports and allow modules to generate them by code or by QWeb templates.
Table of contents
To install this module, you need to:
- Install lxml in Odoo's
$PYTHONPATH
. - Install the repository reporting-engine.
But this module does nothing for the end user by itself, so if you have it installed it's probably because there is another module that depends on it.
This module is intended as a base engine for other modules to use it, so no direct result if you are a user.
To learn from an example, just check the demo
report
on GitHub for the model res.company
or check it in interface from
companies views.
To develop with this module, you need to:
- Create a module.
- Make it depend on this one.
- Follow instructions to create
reports
having in mind that the
report_type
field in yourir.actions.report
record must beqweb-xml
.
In case you want to create a custom
report,
the instructions remain the same as for HTML reports, and the method
that you must override is also called _get_report_values
, even when
this time you are creating a XML report.
You can make your custom report inherit report.report_xml.abstract
,
name it in such way report.<module.report_name>
. Also you can add a
XSD file for report validation into xsd_schema
field of your report
(check report
definition)
and have XSD automatic checking for free.
You can customize rendering process and validation way via changing
logic of generate_report
and validate_report
methods in your
report class.
You can visit
http://<server-address>/report/xml/<module.report_name>/<ids>
to see
your XML report online as a web page.
For further information, please visit:
Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. If you spotted it first, help us to smash it by providing a detailed and welcomed feedback.
Do not contact contributors directly about support or help with technical issues.
- Tecnativa
- Avoin.Systems
- Enric Tobella <etobella@creublanca.es>
- Tecnativa:
- Jairo Llopis
- Avoin.Systems:
- Tatiana Deribina
- Iván Antón <ozono@ozonomultimedia.com>
- Icon taken from http://commons.wikimedia.org/wiki/File:Text-xml.svg
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.
This module is part of the OCA/reporting-engine project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.