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.
		
		
		
		
		
			
		
			
				
					
					
						
							112 lines
						
					
					
						
							4.9 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							112 lines
						
					
					
						
							4.9 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ############################################################################# | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2019-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |
| #    Author: Fasluca @ cybrosys,(odoo@cybrosys.com) | |
| # | |
| #    You can modify it under the terms of the GNU AFFERO | |
| #    GENERAL PUBLIC LICENSE (AGPL v3), Version 3. | |
| # | |
| #    This program is distributed in the hope that it will be useful, | |
| #    but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |
| #    GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. | |
| # | |
| #    You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE | |
| #    (AGPL v3) along with this program. | |
| #    If not, see <http://www.gnu.org/licenses/>. | |
| # | |
| ############################################################################# | |
| # -*- coding: utf-8 -*- | |
| 
 | |
| import base64 | |
| from werkzeug.utils import redirect | |
| import io | |
| from odoo import http | |
| from odoo.http import request | |
| from odoo.addons.website.controllers.main import QueryURL | |
| from odoo.addons.website_sale.controllers.main import WebsiteSale | |
| 
 | |
| 
 | |
| class WebsiteSale(WebsiteSale): | |
| 
 | |
|     @http.route(['/shop/<model("product.template"):product>'], type='http', auth="public", website=True) | |
|     def product(self, product, category='', search='', **kwargs): | |
|         product_context = dict(request.env.context, active_id=product.id) | |
|         ProductCategory = request.env['product.public.category'] | |
|         Rating = request.env['rating.rating'].sudo() | |
|         if category: | |
|             category = ProductCategory.browse(int(category)).exists() | |
| 
 | |
|         attrib_list = request.httprequest.args.getlist('attrib') | |
|         attrib_values = [map(int, v.split("-")) for v in attrib_list if v] | |
|         attrib_set = set([v[1] for v in attrib_values]) | |
|         keep = QueryURL('/shop', category=category and category.id, search=search, attrib=attrib_list) | |
|         categs = ProductCategory.search([('parent_id', '=', False)]) | |
|         pricelist = request.website.get_current_pricelist() | |
|         from_currency = request.env.user.company_id.currency_id | |
|         to_currency = pricelist.currency_id | |
|         compute_currency = lambda price: from_currency.compute(price, to_currency) | |
|         # get the rating attached to a mail.message, and the rating stats of the product | |
|         ratings = Rating.search([('message_id', 'in', product.website_message_ids.ids)]) | |
|         rating_message_values = dict([(record.message_id.id, record.rating) for record in ratings]) | |
|         if not product_context.get('pricelist'): | |
|             product_context['pricelist'] = pricelist.id | |
|             product = product.with_context(product_context) | |
| 
 | |
|         attachments = request.env['ir.attachment'].sudo().search( | |
|             [('res_model', '=', 'product.template'), | |
|              ('res_id', '=', product.id)], order='id') | |
| 
 | |
|         values = { | |
|             'search': search, | |
|             'category': category, | |
|             'pricelist': pricelist, | |
|             'attrib_values': attrib_values, | |
|             'compute_currency': compute_currency, | |
|             'attrib_set': attrib_set, | |
|             'keep': keep, | |
|             'categories': categs, | |
|             'main_object': product, | |
|             'product': product, | |
|             '_get_attribute_exclusions': self._get_attribute_exclusion, | |
|             'rating_message_values': rating_message_values, | |
|             'attachments': attachments | |
|         } | |
|         return request.render("website_sale.product", values) | |
| 
 | |
|     def _get_attribute_exclusion(self, product, reference_product=None): | |
|         parent_combination = request.env['product.template.attribute.value'] | |
|         if reference_product: | |
|             parent_combination |= reference_product.product_template_attribute_value_ids | |
|             if reference_product.env.context.get('no_variant_attribute_values'): | |
|                 # Add "no_variant" attribute values' exclusions | |
|                 # They are kept in the context since they are not linked to this product variant | |
|                 parent_combination |= reference_product.env.context.get('no_variant_attribute_values') | |
|         return product._get_attribute_exclusions(parent_combination) | |
| 
 | |
|     @http.route(['/attachment/download',], type='http', auth='public') | |
|     def download_attachment(self, attachment_id): | |
|         # Check if this is a valid attachment id | |
|         attachment = request.env['ir.attachment'].sudo().search([('id', '=', int(attachment_id))]) | |
| 
 | |
|         if attachment: | |
|             attachment = attachment[0] | |
|         else: | |
|             return redirect('/shop') | |
| 
 | |
|         if attachment["type"] == "url": | |
|             if attachment["url"]: | |
|                 return redirect(attachment["url"]) | |
|             else: | |
|                 return request.not_found() | |
|         elif attachment["datas"]: | |
|             data = io.BytesIO(base64.standard_b64decode(attachment["datas"])) | |
|             return http.send_file(data, filename=attachment['name'], as_attachment=True) | |
|         else: | |
|             return request.not_found() | |
| 
 | |
| 
 | |
| 
 | |
| 
 |