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.
		
		
		
		
		
			
		
			
				
					
					
						
							67 lines
						
					
					
						
							3.1 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							67 lines
						
					
					
						
							3.1 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ############################################################################# | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |
| #    Author: Manasa T P (odoo@cybrosys.com) | |
| # | |
| #    You can modify it under the terms of the GNU LESSER | |
| #    GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details. | |
| # | |
| #    You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE | |
| #    (LGPL v3) along with this program. | |
| #    If not, see <http://www.gnu.org/licenses/>. | |
| # | |
| ##############################################################################from odoo import http | |
| from odoo import http | |
| from odoo.http import Controller, request | |
| 
 | |
| 
 | |
| class WebsiteSaleController(Controller): | |
|     @http.route(['/shop/product_nutrition_details'], | |
|                 type='json', auth="public") | |
|     def product_nutrition_details(self, name): | |
|         """ Return product nutrition details to js""" | |
|         lang = request.env['res.users'].browse(request.env.uid).lang | |
|         product_name = name.split('#')[0].split('-') | |
|         product_info = product_name[len(product_name) - 1] | |
|         product_id = product_info.split('?')[0] | |
|         product = request.env['product.template'].browse(int(product_id)) | |
|         query = (""" select product_nutrition.name AS name, | |
|                     product_nutrition.nutrition_value,uom_uom.name->> '{}' as  | |
|                     uom_name from product_template join product_nutrition on  | |
|                     product_template.id = product_nutrition.product_template_id  | |
|                     join uom_uom on uom_uom.id = product_nutrition.uom_id """ | |
|                  .format(lang)) | |
|         if product.sudo().nutrition_ids: | |
|             request.env.cr.execute( | |
|                 """{} where product_template.id ='{}'""".format( | |
|                     query, product_id)) | |
|             conf = request.env.cr.dictfetchall() | |
|             return conf | |
| 
 | |
|     @http.route(['/shop/product_ingredients_details'], | |
|                 type='json', auth="public") | |
|     def product_ingredients_details(self, name): | |
|         """ Return product ingredient details to js""" | |
|         product_name = name.split('#')[0].split('-') | |
|         product_info = product_name[len(product_name) - 1] | |
|         product_id = product_info.split('?')[0] | |
|         product = request.env['product.template'].browse(int(product_id)) | |
|         return product.sudo().ingredients_information | |
| 
 | |
|     @http.route(['/shop/product_allergy_details'], | |
|                 type='json', auth="public") | |
|     def product_allergy_details(self, name): | |
|         """ Return product allergy details to js""" | |
|         product_name = name.split('#')[0].split('-') | |
|         product_info = product_name[len(product_name) - 1] | |
|         product_id = product_info.split('?')[0] | |
|         product = request.env['product.template'].browse(int(product_id)) | |
|         return product.sudo().allergy_information |