diff --git a/base_continent/README.rst b/base_continent/README.rst new file mode 100644 index 000000000..eda08ea1c --- /dev/null +++ b/base_continent/README.rst @@ -0,0 +1,61 @@ +.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg + :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 + +============== +Base Continent +============== + +This module adds a *Continent* object (res.continent) and a link between continents and countries. It also adds a continent field on partners (automatically set if a country has been selected on the partner). + +Configuration +============= + +Go to the menu *Sales > Configuration > Address Book > Localization > Continents* to see the list of continents and assign countries to continents. + +Usage +===== + +You can now group partners per continent. + +.. image:: https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas + :alt: Try me on Runbot + :target: https://runbot.odoo-community.org/runbot/134/8.0 + + +Bug Tracker +=========== + +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 smashing it by providing a detailed and welcomed feedback. + +Credits +======= + +Images +------ + +* Odoo Community Association: `Icon `_. + +Contributors +------------ + +* Romain Deheele +* Alexis de Lattre + +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 https://odoo-community.org. diff --git a/base_continent/__init__.py b/base_continent/__init__.py index 89a35d724..cde864bae 100644 --- a/base_continent/__init__.py +++ b/base_continent/__init__.py @@ -1,24 +1,3 @@ -# -*- encoding: utf-8 -*- -############################################################################## -# -# Author: Romain Deheele -# Copyright 2014 Camptocamp SA -# -# This program is free software: you can redistribute it and/or modify -# it under the terms of the GNU 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 General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program. If not, see . -# -############################################################################## +# -*- coding: utf-8 -*- -from . import base_continent -from . import country -from . import partner +from . import models diff --git a/base_continent/__openerp__.py b/base_continent/__openerp__.py index adbec72f2..d3e2c2b9a 100644 --- a/base_continent/__openerp__.py +++ b/base_continent/__openerp__.py @@ -1,41 +1,21 @@ # -*- coding: utf-8 -*- -############################################################################## -# -# Author: Romain Deheele -# Copyright 2014 Camptocamp SA -# -# 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 . -# -############################################################################## +# © 2014-2016 Camptocamp SA (Author: Romain Deheele) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). { 'name': 'Continent management', - 'version': '8.0.1.0.0', + 'version': '8.0.1.0.1', 'depends': ['base'], 'author': "Camptocamp,Odoo Community Association (OCA)", 'license': 'AGPL-3', - 'description': """ -This module introduces continent management. -============================================ -Links continents to countries, -adds continent field on partner form -""", 'category': 'Generic Modules/Base', 'data': [ - 'base_continent_view.xml', - 'base_continent_data.xml', + 'views/continent.xml', + 'views/country.xml', + 'views/partner.xml', + 'data/continent_data.xml', + 'data/country_data.xml', 'security/ir.model.access.csv', ], 'installable': True, diff --git a/base_continent/base_continent.py b/base_continent/base_continent.py deleted file mode 100644 index c48051841..000000000 --- a/base_continent/base_continent.py +++ /dev/null @@ -1,34 +0,0 @@ -# -*- coding: utf-8 -*- -############################################################################## -# -# Author: Romain Deheele -# Copyright 2014 Camptocamp SA -# -# 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 . -# -############################################################################## - -from openerp.osv.orm import Model -from openerp.osv import fields - - -class Continent(Model): - _name = 'res.continent' - _description = 'Continent' - _columns = { - 'name': fields.char('Continent Name', size=64, - help='The full name of the continent.', - required=True, translate=True), - } - _order = 'name' diff --git a/base_continent/base_continent_view.xml b/base_continent/base_continent_view.xml deleted file mode 100644 index 7522bbf01..000000000 --- a/base_continent/base_continent_view.xml +++ /dev/null @@ -1,73 +0,0 @@ - - - - - - res.country.tree.add_continent - res.country - - - - - - - - - - - res.country.form.add_continent - res.country - - - - - - - - - - res.continent.tree - res.continent - - - - - - - - - res.continent.form - res.continent - -
- - - -
-
-
- - - Continents - ir.actions.act_window - res.continent - form - Display and manage the list of all continents that can be assigned to your partner records. - - - - - - - res.partner.form.add_continent - res.partner - - - - - - - - -
-
diff --git a/base_continent/country.py b/base_continent/country.py deleted file mode 100644 index b4395763b..000000000 --- a/base_continent/country.py +++ /dev/null @@ -1,30 +0,0 @@ -# -*- coding: utf-8 -*- -############################################################################## -# -# Author: Romain Deheele -# Copyright 2014 Camptocamp SA -# -# 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 . -# -############################################################################## - -from openerp.osv.orm import Model -from openerp.osv import fields - - -class Country(Model): - _inherit = 'res.country' - _columns = { - 'continent_id': fields.many2one('res.continent', 'Continent'), - } diff --git a/base_continent/base_continent_data.xml b/base_continent/data/continent_data.xml similarity index 100% rename from base_continent/base_continent_data.xml rename to base_continent/data/continent_data.xml diff --git a/base_continent/data/country_data.xml b/base_continent/data/country_data.xml new file mode 100644 index 000000000..6d9fe09c5 --- /dev/null +++ b/base_continent/data/country_data.xml @@ -0,0 +1,1021 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/base_continent/models/__init__.py b/base_continent/models/__init__.py new file mode 100644 index 000000000..7403f56be --- /dev/null +++ b/base_continent/models/__init__.py @@ -0,0 +1,5 @@ +# -*- coding: utf-8 -*- + +from . import base_continent +from . import country +from . import partner diff --git a/base_continent/models/base_continent.py b/base_continent/models/base_continent.py new file mode 100644 index 000000000..011b4faec --- /dev/null +++ b/base_continent/models/base_continent.py @@ -0,0 +1,18 @@ +# -*- coding: utf-8 -*- +# © 2014-2016 Camptocamp SA (Author: Romain Deheele) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from openerp import models, fields + + +class Continent(models.Model): + _name = 'res.continent' + _description = 'Continent' + _order = 'name' + + name = fields.Char( + string='Continent Name', + help='The full name of the continent.', + required=True, translate=True) + country_ids = fields.One2many( + 'res.country', 'continent_id', string="Countries") diff --git a/base_continent/models/country.py b/base_continent/models/country.py new file mode 100644 index 000000000..6e2e3cb8f --- /dev/null +++ b/base_continent/models/country.py @@ -0,0 +1,12 @@ +# -*- coding: utf-8 -*- +# © 2014-2016 Camptocamp SA (Author: Romain Deheele) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from openerp import models, fields + + +class Country(models.Model): + _inherit = 'res.country' + + continent_id = fields.Many2one( + 'res.continent', string='Continent', ondelete='restrict') diff --git a/base_continent/models/partner.py b/base_continent/models/partner.py new file mode 100644 index 000000000..434770013 --- /dev/null +++ b/base_continent/models/partner.py @@ -0,0 +1,13 @@ +# -*- coding: utf-8 -*- +# © 2014-2016 Camptocamp SA (Author: Romain Deheele) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from openerp import models, fields + + +class Partner(models.Model): + _inherit = 'res.partner' + + continent_id = fields.Many2one( + 'res.continent', related='country_id.continent_id', + string='Continent', readonly=True, store=True) diff --git a/base_continent/partner.py b/base_continent/partner.py deleted file mode 100644 index a5656652c..000000000 --- a/base_continent/partner.py +++ /dev/null @@ -1,34 +0,0 @@ -# -*- coding: utf-8 -*- -############################################################################## -# -# Author: Romain Deheele -# Copyright 2014 Camptocamp SA -# -# 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 . -# -############################################################################## - -from openerp.osv.orm import Model -from openerp.osv import fields - - -class Partner(Model): - _inherit = 'res.partner' - _columns = { - 'continent_id': fields.related('country_id', 'continent_id', - type='many2one', - relation='res.continent', - string='Continent', - readonly=True, store=True), - } diff --git a/base_continent/views/continent.xml b/base_continent/views/continent.xml new file mode 100644 index 000000000..dc031771a --- /dev/null +++ b/base_continent/views/continent.xml @@ -0,0 +1,44 @@ + + + + + + res.continent.tree + res.continent + + + + + + + + + res.continent.form + res.continent + +
+ + + + + + +
+
+
+ + + Continents + res.continent + tree,form + Display and manage the list of all continents that can be assigned to your partner records. + + + + + +
+
diff --git a/base_continent/views/country.xml b/base_continent/views/country.xml new file mode 100644 index 000000000..1a8d87ac7 --- /dev/null +++ b/base_continent/views/country.xml @@ -0,0 +1,28 @@ + + + + + + res.country.tree.add_continent + res.country + + + + + + + + + + res.country.form.add_continent + res.country + + + + + + + + + + diff --git a/base_continent/views/partner.xml b/base_continent/views/partner.xml new file mode 100644 index 000000000..19267f675 --- /dev/null +++ b/base_continent/views/partner.xml @@ -0,0 +1,28 @@ + + + + + + res.partner.form.add_continent + res.partner + + + + + + + + + + res.partner.filter.add_continent + res.partner + + + + + + + + + + diff --git a/base_partner_sequence/__openerp__.py b/base_partner_sequence/__openerp__.py index be79f9951..f4799fefd 100644 --- a/base_partner_sequence/__openerp__.py +++ b/base_partner_sequence/__openerp__.py @@ -34,5 +34,5 @@ 'views/partner_view.xml', ], "active": False, - "installable": True + "installable": True, } diff --git a/base_partner_sequence/models/partner.py b/base_partner_sequence/models/partner.py index 8a6f84274..42ff65159 100644 --- a/base_partner_sequence/models/partner.py +++ b/base_partner_sequence/models/partner.py @@ -23,13 +23,15 @@ class ResPartner(models.Model): """ if not vals and not partner_id: raise Exception('Either field values or an id must be provided.') - vals = vals or {} + if vals is None: + vals = {} + values = vals.copy() # only assign a 'ref' to commercial partners if partner_id: partner = self.browse(partner_id) - vals.setdefault('is_company', partner.is_company) - vals.setdefault('parent_id', partner.parent_id.id) - return vals.get('is_company') or not vals.get('parent_id') + values.setdefault('is_company', partner.is_company) + values.setdefault('parent_id', partner.parent_id.id) + return values.get('is_company') or not values.get('parent_id') @api.model def _commercial_fields(self):