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.

109 lines
4.0 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, tools
  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. class ProductCategory(models.Model):
  37. _inherit = 'product.category'
  38. image = fields.Binary(help='Show Image Category in Form View')
  39. image_medium = fields.Binary(help='Show image category button in POS',
  40. compute="_compute_get_image",
  41. inverse="_inverse_set_image",
  42. store=True)
  43. available_in_pos = fields.Boolean(
  44. string="Available in the Point of Sale",
  45. default=True,
  46. help="Check if you want this category to appear in Point Of Sale.\n"
  47. "If you uncheck, children categories will becomes invisible too, "
  48. "whatever their checkbox state.")
  49. @api.multi
  50. def _compute_get_image(self):
  51. return dict(
  52. (rec.id, tools.image_get_resized_images(rec.image)) for rec in
  53. self)
  54. @api.multi
  55. def _inverse_set_image(self):
  56. self.ensure_one()
  57. return self.write(
  58. {'image': tools.image_resize_image_big(self.image_medium)})
  59. _auto_end_original = models.BaseModel._auto_end
  60. def _auto_end(self, cr, context=None):
  61. """ Create the foreign keys recorded by _auto_init.
  62. (pos_remove_pos_category monkey patching)
  63. """
  64. context = context or {}
  65. # If the field is created by the user, there is no module.
  66. module = context.get('module', False)
  67. foreign_keys = []
  68. patched = 'openerp.addons.pos_remove_pos_category' in sys.modules
  69. for t, k, r, d in self._foreign_keys:
  70. if patched and (t, k) == ('product_template', 'pos_categ_id'):
  71. if module == 'pos_remove_pos_category':
  72. cr.execute('''
  73. ALTER TABLE product_template
  74. DROP CONSTRAINT IF EXISTS
  75. product_template_pos_categ_id_fkey
  76. ''')
  77. cr.execute('''
  78. UPDATE product_template
  79. SET pos_categ_id = categ_id;
  80. ''')
  81. cr.execute('''
  82. ALTER TABLE product_template ADD CONSTRAINT
  83. "product_template_pos_categ_id_fkey"
  84. FOREIGN KEY (pos_categ_id)
  85. REFERENCES product_category(id) ON DELETE SET NULL;
  86. ''')
  87. continue
  88. foreign_keys.append((t, k, r, d))
  89. self._foreign_keys = foreign_keys
  90. return _auto_end_original(self, cr, context=context)
  91. models.BaseModel._auto_end = _auto_end