summaryrefslogtreecommitdiff
path: root/addons/website_sale_stock/models/product_template.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/website_sale_stock/models/product_template.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/website_sale_stock/models/product_template.py')
-rw-r--r--addons/website_sale_stock/models/product_template.py54
1 files changed, 54 insertions, 0 deletions
diff --git a/addons/website_sale_stock/models/product_template.py b/addons/website_sale_stock/models/product_template.py
new file mode 100644
index 00000000..3a3e2067
--- /dev/null
+++ b/addons/website_sale_stock/models/product_template.py
@@ -0,0 +1,54 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import fields, models, api
+
+
+class ProductTemplate(models.Model):
+ _inherit = 'product.template'
+
+ inventory_availability = fields.Selection([
+ ('never', 'Sell regardless of inventory'),
+ ('always', 'Show inventory on website and prevent sales if not enough stock'),
+ ('threshold', 'Show inventory below a threshold and prevent sales if not enough stock'),
+ ('custom', 'Show product-specific notifications'),
+ ], string='Inventory Availability', help='Adds an inventory availability status on the web product page.', default='never')
+ available_threshold = fields.Float(string='Availability Threshold', default=5.0)
+ custom_message = fields.Text(string='Custom Message', default='', translate=True)
+
+ def _get_combination_info(self, combination=False, product_id=False, add_qty=1, pricelist=False, parent_combination=False, only_template=False):
+ combination_info = super(ProductTemplate, self)._get_combination_info(
+ combination=combination, product_id=product_id, add_qty=add_qty, pricelist=pricelist,
+ parent_combination=parent_combination, only_template=only_template)
+
+ if not self.env.context.get('website_sale_stock_get_quantity'):
+ return combination_info
+
+ if combination_info['product_id']:
+ product = self.env['product.product'].sudo().browse(combination_info['product_id'])
+ website = self.env['website'].get_current_website()
+ virtual_available = product.with_context(warehouse=website.warehouse_id.id).virtual_available
+ combination_info.update({
+ 'virtual_available': virtual_available,
+ 'virtual_available_formatted': self.env['ir.qweb.field.float'].value_to_html(virtual_available, {'precision': 0}),
+ 'product_type': product.type,
+ 'inventory_availability': product.inventory_availability,
+ 'available_threshold': product.available_threshold,
+ 'custom_message': product.custom_message,
+ 'product_template': product.product_tmpl_id.id,
+ 'cart_qty': product.cart_qty,
+ 'uom_name': product.uom_id.name,
+ })
+ else:
+ product_template = self.sudo()
+ combination_info.update({
+ 'virtual_available': 0,
+ 'product_type': product_template.type,
+ 'inventory_availability': product_template.inventory_availability,
+ 'available_threshold': product_template.available_threshold,
+ 'custom_message': product_template.custom_message,
+ 'product_template': product_template.id,
+ 'cart_qty': 0
+ })
+
+ return combination_info