You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

70 lines
2.5 KiB

  1. # -*- coding: utf-8 -*-
  2. ##############################################################################
  3. #
  4. # OpenERP, Open Source Management Solution
  5. # Copyright (C) 2015-TODAY Akretion (<http://www.akretion.com>).
  6. #
  7. # This program is free software: you can redistribute it and/or modify
  8. # it under the terms of the GNU Affero General Public License as
  9. # published by the Free Software Foundation, either version 3 of the
  10. # License, or (at your option) any later version.
  11. #
  12. # This program is distributed in the hope that it will be useful,
  13. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. # GNU Affero General Public License for more details.
  16. #
  17. # You should have received a copy of the GNU Affero General Public License
  18. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  19. #
  20. ##############################################################################
  21. from openerp import models, fields, api
  22. class ProductTemplate(models.Model):
  23. _inherit = 'product.template'
  24. pos_categ_id = fields.Many2one('product.category',
  25. store=True, related='categ_id')
  26. @api.model
  27. def create(self, vals):
  28. vals['pos_categ_id'] = vals['categ_id']
  29. return super(ProductTemplate, self).create(vals)
  30. @api.multi
  31. def write(self, vals):
  32. if 'pos_categ_id' in vals and not vals['pos_categ_id']:
  33. del vals['pos_categ_id']
  34. return super(ProductTemplate, self).write(vals)
  35. _auto_end_original = models.BaseModel._auto_end
  36. def _auto_end(self, cr, context=None):
  37. """ Create the foreign keys recorded by _auto_init.
  38. (pos_product_category monkey patching)
  39. """
  40. context = context or {}
  41. module = context['module']
  42. foreign_keys = []
  43. for t, k, r, d in self._foreign_keys:
  44. if (t, k) == ('product_template', 'pos_categ_id'):
  45. if module == 'pos_product_category':
  46. cr.execute('''
  47. ALTER TABLE product_template
  48. DROP CONSTRAINT IF EXISTS
  49. product_template_pos_categ_id_fkey
  50. ''')
  51. cr.execute('''
  52. UPDATE product_template
  53. SET pos_categ_id = categ_id;
  54. ''')
  55. continue
  56. foreign_keys.append((t, k, r, d))
  57. self._foreign_keys = foreign_keys
  58. return _auto_end_original(self, cr, context=context)
  59. models.BaseModel._auto_end = _auto_end