Merge pull request #192 from StefanRijnhart/8.0-language_path_mixin_therp
[ADD] Language path mixinpull/198/head
commit
506d535d37
|
@ -0,0 +1,83 @@
|
||||||
|
.. 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 RML
|
||||||
|
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
|
||||||
|
=============
|
||||||
|
|
||||||
|
With a dependency on this module, you can have any model inherit from the mixin
|
||||||
|
model 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)
|
Binary file not shown.
After Width: | Height: | Size: 4.0 KiB |
Loading…
Reference in New Issue