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.

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