Browse Source
[IMP] base_export_manager: Several things:
[IMP] base_export_manager: Several things:
* Improve UX for base_export_manager. - Improve user instructions in README. - Require some required fields. - Allow to select models from a list. - Allow to select up to 3 fields from dynamic lists. - Improve translations. - More tests. - Translate column labels. Some methods have been renamed, so version tag is raised to 8.0.2.0.0. * Make inverse method be called at view time. * Hardcode constraints in the `create` method instead of using normal ones. Depending on the context where the record is created, it gets `resource` or `model_id`. The problem is that Odoo checks constrains before inverses, so constrains would fail always. Test added to ensure future versions contemplate all use cases. * Allow to reorder fields.pull/67/head
Jairo Llopis
9 years ago
committed by
Olivier Jossen
14 changed files with 428 additions and 221 deletions
-
56base_export_manager/README.rst
-
24base_export_manager/__init__.py
-
33base_export_manager/__openerp__.py
-
8base_export_manager/data/ir_exports_data.xml
-
50base_export_manager/i18n/base_exports_manager.pot
-
43base_export_manager/i18n/es.po
-
26base_export_manager/models/__init__.py
-
67base_export_manager/models/ir_exports.py
-
211base_export_manager/models/ir_exports_line.py
-
26base_export_manager/static/src/js/main.js
-
7base_export_manager/tests/__init__.py
-
54base_export_manager/tests/test_ir_exports.py
-
6base_export_manager/tests/test_ir_exports_line.py
-
38base_export_manager/views/ir_exports_view.xml
@ -1,25 +1,5 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# Python source code encoding : https://www.python.org/dev/peps/pep-0263/ |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright : |
|||
# (c) 2015 Antiun Ingenieria, SL (Madrid, Spain, http://www.antiun.com) |
|||
# Antonio Espinosa <antonioea@antiun.com> |
|||
# |
|||
# 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/>. |
|||
# |
|||
############################################################################## |
|||
# © 2015 Antiun Ingeniería S.L. - Antonio Espinosa |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
|||
|
|||
from . import models |
@ -1,40 +1,25 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# Python source code encoding : https://www.python.org/dev/peps/pep-0263/ |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Odoo Source Management Solution |
|||
# Copyright (c) 2015 Antiun Ingeniería S.L. (http://www.antiun.com) |
|||
# Antonio Espinosa <antonioea@antiun.com> |
|||
# |
|||
# 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/>. |
|||
# |
|||
############################################################################## |
|||
# © 2015 Antiun Ingeniería S.L. - Antonio Espinosa |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
|||
|
|||
{ |
|||
'name': "Manages model export profiles", |
|||
'name': "Manage model export profiles", |
|||
'category': 'Personalization', |
|||
'version': '8.0.1.0.0', |
|||
'version': '8.0.2.0.0', |
|||
'depends': [ |
|||
'web', |
|||
], |
|||
'data': [ |
|||
'data/ir_exports_data.xml', |
|||
'views/assets.xml', |
|||
'views/ir_exports_view.xml', |
|||
], |
|||
'qweb': [ |
|||
"static/src/xml/base.xml", |
|||
], |
|||
'author': 'Antiun Ingeniería S.L.,Odoo Community Association (OCA)', |
|||
'author': 'Antiun Ingeniería S.L., ' |
|||
'Tecnativa, ' |
|||
'Odoo Community Association (OCA)', |
|||
'website': 'http://www.antiun.com', |
|||
'license': 'AGPL-3', |
|||
'installable': True, |
|||
|
@ -0,0 +1,8 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<openerp> |
|||
<data> |
|||
|
|||
<function model="ir.exports.line" name="_install_base_export_manager"/> |
|||
|
|||
</data> |
|||
</openerp> |
@ -1,50 +0,0 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_exports_manager |
|||
# |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2015-10-27 12:38+0000\n" |
|||
"PO-Revision-Date: 2015-10-27 12:38+0000\n" |
|||
"Last-Translator: <>\n" |
|||
"Language-Team: \n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Plural-Forms: \n" |
|||
|
|||
#. module: base_exports_manager |
|||
#: view:ir.exports:base_exports_manager.ir_exports_form_view |
|||
msgid "Export Profile" |
|||
msgstr "" |
|||
|
|||
#. module: base_exports_manager |
|||
#: model:ir.actions.act_window,name:base_exports_manager.ir_exports_action |
|||
#: view:ir.exports:base_exports_manager.ir_exports_tree_view |
|||
#: model:ir.ui.menu,name:base_exports_manager.ir_exports_menu |
|||
msgid "Export Profiles" |
|||
msgstr "" |
|||
|
|||
#. module: base_exports_manager |
|||
#: code:addons/base_exports_manager/models/ir_exports_line.py:62 |
|||
#, python-format |
|||
msgid "Field '%s' already exists" |
|||
msgstr "" |
|||
|
|||
#. module: base_exports_manager |
|||
#: code:addons/base_exports_manager/models/ir_exports_line.py:57 |
|||
#, python-format |
|||
msgid "Field '%s' does not exist" |
|||
msgstr "" |
|||
|
|||
#. module: base_exports_manager |
|||
#: field:ir.exports.line,sequence:0 |
|||
msgid "Sequence" |
|||
msgstr "" |
|||
|
|||
#. module: base_exports_manager |
|||
#: field:ir.exports.line,label:0 |
|||
msgid "Label" |
|||
msgstr "" |
@ -1,25 +1,5 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# Python source code encoding : https://www.python.org/dev/peps/pep-0263/ |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright : |
|||
# (c) 2015 Antiun Ingenieria, SL (Madrid, Spain, http://www.antiun.com) |
|||
# Antonio Espinosa <antonioea@antiun.com> |
|||
# |
|||
# 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/>. |
|||
# |
|||
############################################################################## |
|||
# © 2015 Antiun Ingeniería S.L. - Antonio Espinosa |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
|||
|
|||
from . import ir_exports_line |
|||
from . import ir_exports, ir_exports_line |
@ -0,0 +1,67 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# Copyright 2015-2016 Jairo Llopis <jairo.llopis@tecnativa.com> |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
|||
|
|||
from openerp import _, api, fields, models |
|||
from openerp.exceptions import ValidationError |
|||
|
|||
|
|||
class IrExports(models.Model): |
|||
_inherit = 'ir.exports' |
|||
|
|||
name = fields.Char(required=True) |
|||
resource = fields.Char( |
|||
required=False, |
|||
readonly=True, |
|||
help="Model's technical name.") |
|||
model_id = fields.Many2one( |
|||
"ir.model", |
|||
"Model", |
|||
store=True, |
|||
domain=[("osv_memory", "=", False)], |
|||
compute="_compute_model_id", |
|||
inverse="_inverse_model_id", |
|||
help="Database model to export.") |
|||
|
|||
@api.multi |
|||
@api.depends("resource") |
|||
def _compute_model_id(self): |
|||
"""Get the model from the resource.""" |
|||
for s in self: |
|||
s.model_id = self._get_model_id(s.resource) |
|||
|
|||
@api.multi |
|||
@api.onchange("model_id") |
|||
def _inverse_model_id(self): |
|||
"""Get the resource from the model.""" |
|||
for s in self: |
|||
s.resource = s.model_id.model |
|||
|
|||
@api.multi |
|||
@api.onchange("resource") |
|||
def _onchange_resource(self): |
|||
"""Void fields if model is changed in a view.""" |
|||
for s in self: |
|||
s.export_fields = False |
|||
|
|||
@api.model |
|||
def _get_model_id(self, resource): |
|||
"""Return a model object from its technical name. |
|||
|
|||
:param str resource: |
|||
Technical name of the model, like ``ir.model``. |
|||
""" |
|||
return self.env["ir.model"].search([("model", "=", resource)]) |
|||
|
|||
@api.model |
|||
def create(self, vals): |
|||
"""Check required values when creating the record. |
|||
|
|||
Odoo's export dialog populates ``resource``, while this module's new |
|||
form populates ``model_id``. At least one of them is required to |
|||
trigger the methods that fill up the other, so this should fail if |
|||
one is missing. |
|||
""" |
|||
if not any(f in vals for f in {"model_id", "resource"}): |
|||
raise ValidationError(_("You must supply a model or resource.")) |
|||
return super(IrExports, self).create(vals) |
@ -1,5 +1,6 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# License AGPL-3: Antiun Ingenieria S.L. - Javier Iniesta |
|||
# See README.rst file on addon root folder for more details |
|||
# © 2015 Antiun Ingeniería S.L. - Javier Iniesta |
|||
# © 2015 Antiun Ingeniería S.L. - Jairo Llopis |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
|||
|
|||
from . import test_ir_exports_line |
|||
from . import test_ir_exports, test_ir_exports_line |
@ -0,0 +1,54 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# © 2015 Antiun Ingeniería S.L. - Jairo Llopis |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
|||
|
|||
from openerp.exceptions import ValidationError |
|||
from openerp.tests.common import TransactionCase |
|||
|
|||
|
|||
class TestIrExportsCase(TransactionCase): |
|||
def test_create_with_basic_data(self): |
|||
"""Emulate creation from original form. |
|||
|
|||
This form is handled entirely client-side, and lacks some required |
|||
field values. |
|||
""" |
|||
# Emulate creation from JsonRpc, without model_id and field#_id |
|||
data = { |
|||
"name": u"Test éxport", |
|||
"resource": "ir.exports", |
|||
"export_fields": [ |
|||
[0, 0, {"name": "export_fields"}], |
|||
[0, 0, {"name": "export_fields/create_uid"}], |
|||
[0, 0, {"name": "export_fields/create_date"}], |
|||
[0, 0, {"name": "export_fields/field1_id"}], |
|||
], |
|||
} |
|||
record = self.env["ir.exports"].create(data) |
|||
|
|||
self.assertEqual(record.model_id.model, data["resource"]) |
|||
|
|||
def test_create_without_model(self): |
|||
"""Creating a record without ``model_id`` and ``resource`` fails.""" |
|||
IrExports = self.env["ir.exports"] |
|||
model = IrExports._get_model_id("res.partner") |
|||
|
|||
# Creating with resource |
|||
record = IrExports.create({ |
|||
"name": "some", |
|||
"resource": model.model, |
|||
}) |
|||
self.assertEqual(record.model_id, model) |
|||
|
|||
# Creating with model_id |
|||
record = IrExports.create({ |
|||
"name": "some", |
|||
"model_id": model.id, |
|||
}) |
|||
self.assertEqual(record.resource, model.model) |
|||
|
|||
# Creating without anyone |
|||
with self.assertRaises(ValidationError): |
|||
IrExports.create({ |
|||
"name": "some", |
|||
}) |
Write
Preview
Loading…
Cancel
Save
Reference in new issue