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.
		
		
		
		
		
			
		
			
				
					
					
						
							120 lines
						
					
					
						
							5.6 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							120 lines
						
					
					
						
							5.6 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ############################################################################### | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |
| #    Author: Vishnu K 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 api, fields, models, tools | |
| 
 | |
| 
 | |
| class FoodBookingLine(models.Model): | |
|     """Model that handles the food booking""" | |
|     _name = "food.booking.line" | |
|     _description = "Hotel Food Line" | |
|     _rec_name = 'food_id' | |
| 
 | |
|     @tools.ormcache() | |
|     def _get_default_uom_id(self): | |
|         """Method for getting the default uom id""" | |
|         return self.env.ref('uom.product_uom_unit') | |
| 
 | |
|     booking_id = fields.Many2one("room.booking", string="Booking", | |
|                                  help="Shows the room Booking", | |
|                                  ondelete="cascade") | |
|     food_id = fields.Many2one('lunch.product', string="Product", | |
|                               help="Indicates the Food Product") | |
|     description = fields.Char(string='Description', | |
|                               help="Description of Food Product", | |
|                               related='food_id.display_name') | |
|     uom_qty = fields.Float(string="Qty", default=1, | |
|                            help="The quantity converted into the UoM used by " | |
|                                 "the product") | |
|     uom_id = fields.Many2one('uom.uom', readonly=True, | |
|                              string="Unit of Measure", | |
|                              default=_get_default_uom_id, help="This will set " | |
|                                                                "the unit of" | |
|                                                                " measure used") | |
|     price_unit = fields.Float(related='food_id.price', string='Price', | |
|                               digits='Product Price', | |
|                               help="The price of the selected food item.") | |
|     tax_ids = fields.Many2many('account.tax', | |
|                                'hotel_food_order_line_taxes_rel', | |
|                                'food_id', 'tax_id', | |
|                                string='Taxes', | |
|                                help="Default taxes used when selling the food" | |
|                                     " products.", | |
|                                domain=[('type_tax_use', '=', 'sale')]) | |
|     currency_id = fields.Many2one(related='booking_id.pricelist_id.currency_id' | |
|                                   , string="Currency", | |
|                                   help='The currency used') | |
|     price_subtotal = fields.Float(string="Subtotal", | |
|                                   compute='_compute_price_subtotal', | |
|                                   help="Total Price Excluding Tax", | |
|                                   store=True) | |
|     price_tax = fields.Float(string="Total Tax", | |
|                              compute='_compute_price_subtotal', | |
|                              help="Tax Amount", | |
|                              store=True) | |
|     price_total = fields.Float(string="Total", | |
|                                compute='_compute_price_subtotal', | |
|                                help="Total Price Including Tax", | |
|                                store=True) | |
|     state = fields.Selection(related='booking_id.state', | |
|                              string="Order Status", | |
|                              help=" Status of the Order", | |
|                              copy=False) | |
| 
 | |
|     @api.depends('uom_qty', 'price_unit', 'tax_ids') | |
|     def _compute_price_subtotal(self): | |
|         """Compute the amounts of the room booking line.""" | |
|         for line in self: | |
|             tax_results = self.env['account.tax']._compute_taxes( | |
|                 [line._convert_to_tax_base_line_dict()]) | |
|             totals = list(tax_results['totals'].values())[0] | |
|             amount_untaxed = totals['amount_untaxed'] | |
|             amount_tax = totals['amount_tax'] | |
|             line.update({ | |
|                 'price_subtotal': amount_untaxed, | |
|                 'price_tax': amount_tax, | |
|                 'price_total': amount_untaxed + amount_tax, | |
|             }) | |
|             if self.env.context.get('import_file', | |
|                                     False) and not self.env.user. \ | |
|                     user_has_groups('account.group_account_manager'): | |
|                 line.tax_id.invalidate_recordset( | |
|                     ['invoice_repartition_line_ids']) | |
| 
 | |
|     def _convert_to_tax_base_line_dict(self): | |
|         """ Convert the current record to a dictionary in order to use the | |
|         generic taxes computation method | |
|         defined on account.tax. | |
|         :return: A python dictionary.""" | |
|         self.ensure_one() | |
|         return self.env['account.tax']._convert_to_tax_base_line_dict( | |
|             self, | |
|             partner=self.booking_id.partner_id, | |
|             currency=self.currency_id, | |
|             taxes=self.tax_ids, | |
|             price_unit=self.price_unit, | |
|             quantity=self.uom_qty, | |
|             price_subtotal=self.price_subtotal, ) | |
| 
 | |
|     def search_food_orders(self): | |
|         """Returns list of food orders""" | |
|         return (self.search([]).filtered(lambda r: r.booking_id.state not in [ | |
|             'check_out', 'cancel', 'done']).ids)
 | |
| 
 |