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.

107 lines
3.8 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="_get_image",
  41. 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 _get_image(self):
  51. return dict(
  52. (rec.id, tools.image_get_resized_images(rec.image)) for rec in
  53. self)
  54. @api.one
  55. def _set_image(self):
  56. return self.write(
  57. {'image': tools.image_resize_image_big(self.image_medium)})
  58. _auto_end_original = models.BaseModel._auto_end
  59. def _auto_end(self, cr, context=None):
  60. """ Create the foreign keys recorded by _auto_init.
  61. (pos_remove_pos_category monkey patching)
  62. """
  63. context = context or {}
  64. module = context['module']
  65. foreign_keys = []
  66. patched = 'openerp.addons.pos_remove_pos_category' in sys.modules
  67. for t, k, r, d in self._foreign_keys:
  68. if patched and (t, k) == ('product_template', 'pos_categ_id'):
  69. if module == 'pos_remove_pos_category':
  70. cr.execute('''
  71. ALTER TABLE product_template
  72. DROP CONSTRAINT IF EXISTS
  73. product_template_pos_categ_id_fkey
  74. ''')
  75. cr.execute('''
  76. UPDATE product_template
  77. SET pos_categ_id = categ_id;
  78. ''')
  79. cr.execute('''
  80. ALTER TABLE product_template ADD CONSTRAINT
  81. "product_template_pos_categ_id_fkey"
  82. FOREIGN KEY (pos_categ_id)
  83. REFERENCES product_category(id) ON DELETE SET NULL;
  84. ''')
  85. continue
  86. foreign_keys.append((t, k, r, d))
  87. self._foreign_keys = foreign_keys
  88. return _auto_end_original(self, cr, context=context)
  89. models.BaseModel._auto_end = _auto_end