diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/website_sale_digital/models/product.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/website_sale_digital/models/product.py')
| -rw-r--r-- | addons/website_sale_digital/models/product.py | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/addons/website_sale_digital/models/product.py b/addons/website_sale_digital/models/product.py new file mode 100644 index 00000000..a5512dc9 --- /dev/null +++ b/addons/website_sale_digital/models/product.py @@ -0,0 +1,61 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import api, fields, models, _ + + +class ProductTemplate(models.Model): + _inherit = ['product.template'] + + attachment_count = fields.Integer(compute='_compute_attachment_count', string="File") + + def _compute_attachment_count(self): + attachment_data = self.env['ir.attachment'].read_group([('res_model', '=', self._name), ('res_id', 'in', self.ids), ('product_downloadable', '=', True)], ['res_id'], ['res_id']) + mapped_data = dict([(data['res_id'], data['res_id_count']) for data in attachment_data]) + for product_template in self: + product_template.attachment_count = mapped_data.get(product_template.id, 0) + + def action_open_attachments(self): + self.ensure_one() + return { + 'name': _('Digital Attachments'), + 'domain': [('res_model', '=', self._name), ('res_id', '=', self.id), ('product_downloadable', '=', True)], + 'res_model': 'ir.attachment', + 'type': 'ir.actions.act_window', + 'view_mode': 'kanban,form', + 'context': "{'default_res_model': '%s','default_res_id': %d, 'default_product_downloadable': True}" % (self._name, self.id), + 'help': """ + <p class="o_view_nocontent_smiling_face">Add attachments for this digital product</p> + <p>The attached files are the ones that will be purchased and sent to the customer.</p> + """, + } + + +class Product(models.Model): + _inherit = 'product.product' + + attachment_count = fields.Integer(compute='_compute_attachment_count', string="File") + + def _compute_attachment_count(self): + for product in self: + product.attachment_count = self.env['ir.attachment'].search_count([ + '|', + '&', '&', ('res_model', '=', 'product.template'), ('res_id', '=', product.product_tmpl_id.id), ('product_downloadable', '=', True), + '&', '&', ('res_model', '=', 'product.product'), ('res_id', '=', product.id), ('product_downloadable', '=', True)]) + + def action_open_attachments(self): + self.ensure_one() + return { + 'name': _('Digital Attachments'), + 'domain': [('product_downloadable', '=', True), '|', + '&', ('res_model', '=', 'product.template'), ('res_id', '=', self.product_tmpl_id.id), + '&', ('res_model', '=', self._name), ('res_id', '=', self.id)], + 'res_model': 'ir.attachment', + 'type': 'ir.actions.act_window', + 'view_mode': 'kanban,form', + 'context': "{'default_res_model': '%s','default_res_id': %d, 'default_product_downloadable': True}" % (self._name, self.id), + 'help': """ + <p class="o_view_nocontent_smiling_face">Add attachments for this digital product</p> + <p>The attached files are the ones that will be purchased and sent to the customer.</p> + """, + } |
