Stefan Rijnhart
10 years ago
6 changed files with 169 additions and 0 deletions
-
85language_path_mixin/README.rst
-
1language_path_mixin/__init__.py
-
33language_path_mixin/__openerp__.py
-
1language_path_mixin/models/__init__.py
-
49language_path_mixin/models/language_path_mixin.py
-
BINlanguage_path_mixin/static/description/icon.png
@ -0,0 +1,85 @@ |
|||||
|
.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg |
||||
|
:alt: License: AGPL-3 |
||||
|
|
||||
|
Language path mixin |
||||
|
=================== |
||||
|
This is a technical module to restore the possibility of Odoo to print reports |
||||
|
in other languages than the user's language (for instance, the customer's |
||||
|
language in the case of a sale order). |
||||
|
|
||||
|
Odoo 8.0 has lost that capability due to an unlucky combination of technical |
||||
|
aspects of the deprecated RML report functionality and the new API. While the |
||||
|
static content of the report is translated fine, any translatable fields will |
||||
|
still be rendered in the language of the user. |
||||
|
|
||||
|
See https://github.com/odoo/odoo/issues/7301 for the original bug report. |
||||
|
|
||||
|
This module provides a tool for developers to work around this bug in their |
||||
|
Python code. |
||||
|
|
||||
|
Configuration |
||||
|
============= |
||||
|
|
||||
|
After installation of the module, you can import the mixin class that it |
||||
|
provides and have any model inherit from it in your python class definition. |
||||
|
|
||||
|
You can then assign your class a *_language_path* member to indicate where |
||||
|
to find the language into which its reports are to be translated. See the |
||||
|
following code example: |
||||
|
|
||||
|
.. code:: |
||||
|
|
||||
|
class SaleOrder(models.Model): |
||||
|
_name = 'sale.order' |
||||
|
_inherit = ['sale.order', 'language.path.mixin'] |
||||
|
_language_path = 'partner_id.lang' |
||||
|
|
||||
|
In RML reports for such a model, you can then iterate over the records in the |
||||
|
correct language using |
||||
|
|
||||
|
[[ repeatIn(objects.with_language_path(), 'o') ]] |
||||
|
|
||||
|
Usage |
||||
|
===== |
||||
|
|
||||
|
For further information, please visit: |
||||
|
|
||||
|
* https://www.odoo.com/forum/help-1 |
||||
|
|
||||
|
Known issues / Roadmap |
||||
|
====================== |
||||
|
|
||||
|
* Kudos if you find a way to do this more elegantly, preferably with a simple |
||||
|
bugfix in the Odoo core |
||||
|
|
||||
|
Bug Tracker |
||||
|
=========== |
||||
|
|
||||
|
Bugs are tracked on `GitHub Issues <https://github.com/OCA/server-tools/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/server-tools/issues/new?body=module:%20language_path_mixin%0Aversion:%201.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_. |
||||
|
|
||||
|
Credits |
||||
|
======= |
||||
|
|
||||
|
Contributors |
||||
|
------------ |
||||
|
|
||||
|
* Stefan Rijnhart <stefan@therp.nl> |
||||
|
* Holger Brunn <hbrunn@therp.nl> |
||||
|
|
||||
|
Maintainer |
||||
|
---------- |
||||
|
|
||||
|
.. image:: https://odoo-community.org/logo.png |
||||
|
:alt: Odoo Community Association |
||||
|
:target: https://odoo-community.org |
||||
|
|
||||
|
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 http://odoo-community.org. |
@ -0,0 +1 @@ |
|||||
|
from . import models |
@ -0,0 +1,33 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################## |
||||
|
# |
||||
|
# Odoo, an open source suite of business apps |
||||
|
# This module copyright (C) 2015 Therp BV (<http://therp.nl>). |
||||
|
# |
||||
|
# This program is free software: you can redistribute it and/or modify |
||||
|
# it under the terms of the GNU Affero General Public License as |
||||
|
# published by the Free Software Foundation, either version 3 of the |
||||
|
# License, or (at your option) any later version. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU Affero General Public License for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU Affero General Public License |
||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################## |
||||
|
{ |
||||
|
'name': 'Language path mixin', |
||||
|
'summary': "Setting the partner's language in RML reports", |
||||
|
'version': '1.0', |
||||
|
'author': 'Therp BV,Odoo Community Association (OCA)', |
||||
|
'maintainer': 'Odoo Community Association (OCA)', |
||||
|
'website': 'https://github.com/OCA/server-tools', |
||||
|
'license': 'AGPL-3', |
||||
|
'category': 'Tools', |
||||
|
'depends': [ |
||||
|
'base', |
||||
|
], |
||||
|
} |
@ -0,0 +1 @@ |
|||||
|
from . import language_path_mixin |
@ -0,0 +1,49 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
############################################################################## |
||||
|
# |
||||
|
# Odoo, an open source suite of business apps |
||||
|
# This module copyright (C) 2015 Therp BV (<http://therp.nl>). |
||||
|
# |
||||
|
# This program is free software: you can redistribute it and/or modify |
||||
|
# it under the terms of the GNU Affero General Public License as |
||||
|
# published by the Free Software Foundation, either version 3 of the |
||||
|
# License, or (at your option) any later version. |
||||
|
# |
||||
|
# This program is distributed in the hope that it will be useful, |
||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
|
# GNU Affero General Public License for more details. |
||||
|
# |
||||
|
# You should have received a copy of the GNU Affero General Public License |
||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
||||
|
# |
||||
|
############################################################################## |
||||
|
from openerp import models |
||||
|
|
||||
|
|
||||
|
class LanguagePathMixin(models.AbstractModel): |
||||
|
""" Mixin class to print reports in a language taken from a field in the |
||||
|
record. """ |
||||
|
_name = 'language.path.mixin' |
||||
|
_language_path = False |
||||
|
|
||||
|
def with_language_path(self, path=None): |
||||
|
""" This method allows the system to iterate over a RecordSet with each |
||||
|
of the records being browsed in the language specified by the model's |
||||
|
_language_path attribute. Of course, this is a cache killer. It was |
||||
|
conceived to make translations in rml reports work again as using |
||||
|
setLang() in the report does not work as expected anymore in 8.0 due |
||||
|
to the way that caching works in the new API """ |
||||
|
path = path or self._language_path |
||||
|
for record in self: |
||||
|
if not path: |
||||
|
yield record |
||||
|
continue |
||||
|
lang = record |
||||
|
for part in path.split('.'): |
||||
|
lang = lang[part] |
||||
|
if not lang: |
||||
|
yield record |
||||
|
break |
||||
|
else: |
||||
|
yield record.with_context(lang=lang) |
After Width: 48 | Height: 48 | Size: 4.0 KiB |
Write
Preview
Loading…
Cancel
Save
Reference in new issue