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.

79 lines
2.9 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. import sys
  22. from openerp import models, fields, api
  23. class ProductTemplate(models.Model):
  24. _inherit = 'product.template'
  25. pos_categ_id = fields.Many2one('product.category',
  26. store=True, related='categ_id')
  27. @api.model
  28. def create(self, vals):
  29. vals['pos_categ_id'] = vals['categ_id']
  30. return super(ProductTemplate, self).create(vals)
  31. @api.multi
  32. def write(self, vals):
  33. if 'pos_categ_id' in vals and not vals['pos_categ_id']:
  34. del vals['pos_categ_id']
  35. return super(ProductTemplate, self).write(vals)
  36. _auto_end_original = models.BaseModel._auto_end
  37. def _auto_end(self, cr, context=None):
  38. """ Create the foreign keys recorded by _auto_init.
  39. (pos_remove_pos_category monkey patching)
  40. """
  41. context = context or {}
  42. module = context['module']
  43. foreign_keys = []
  44. patched = 'openerp.addons.pos_remove_pos_category' in sys.modules
  45. for t, k, r, d in self._foreign_keys:
  46. if patched and (t, k) == ('product_template', 'pos_categ_id'):
  47. if module == 'pos_remove_pos_category':
  48. cr.execute('''
  49. ALTER TABLE product_template
  50. DROP CONSTRAINT IF EXISTS
  51. product_template_pos_categ_id_fkey
  52. ''')
  53. cr.execute('''
  54. UPDATE product_template
  55. SET pos_categ_id = categ_id;
  56. ''')
  57. cr.execute('''
  58. ALTER TABLE product_template ADD CONSTRAINT
  59. "product_template_pos_categ_id_fkey"
  60. FOREIGN KEY (pos_categ_id)
  61. REFERENCES product_category(id) ON DELETE SET NULL;
  62. ''')
  63. continue
  64. foreign_keys.append((t, k, r, d))
  65. self._foreign_keys = foreign_keys
  66. return _auto_end_original(self, cr, context=context)
  67. models.BaseModel._auto_end = _auto_end