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.
		
		
		
		
		
			
		
			
				
					
					
						
							185 lines
						
					
					
						
							8.6 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							185 lines
						
					
					
						
							8.6 KiB
						
					
					
				
								# -*- coding: utf-8 -*-
							 | 
						|
								###############################################################################
							 | 
						|
								#
							 | 
						|
								#    Cybrosys Technologies Pvt. Ltd.
							 | 
						|
								#
							 | 
						|
								#    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
							 | 
						|
								#    Author: Raneesha M K (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/>.
							 | 
						|
								#
							 | 
						|
								###############################################################################
							 | 
						|
								import datetime
							 | 
						|
								from odoo import api, fields, models
							 | 
						|
								from odoo.fields import Command
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								class BookOrder(models.Model):
							 | 
						|
								    """
							 | 
						|
								       Model for managing booked orders in the POS system.
							 | 
						|
								    """
							 | 
						|
								    _name = 'book.order'
							 | 
						|
								    _description = "Point of Sale Booked Orders"
							 | 
						|
								
							 | 
						|
								    @api.model
							 | 
						|
								    def _amount_line_tax(self, line, fiscal_position_id):
							 | 
						|
								        """ Calculates the tax amount of the order line.
							 | 
						|
								            :param line: Order line record
							 | 
						|
								            :param fiscal_position_id: Fiscal position account for order
							 | 
						|
								            :return float: Total tax amount as float
							 | 
						|
								        """
							 | 
						|
								        taxes = line.tax_ids.filtered(
							 | 
						|
								            lambda t: t.company_id.id == line.order_id.company_id.id)
							 | 
						|
								        taxes = fiscal_position_id.map_tax(taxes)
							 | 
						|
								        price = line.price_unit * (1 - (line.discount or 0.0) / 100.0)
							 | 
						|
								        taxes = taxes.compute_all(price,
							 | 
						|
								                                  line.order_id.pricelist_id.currency_id,
							 | 
						|
								                                  line.qty, product=line.product_id,
							 | 
						|
								                                  partner=line.order_id.partner_id or False)[
							 | 
						|
								            'taxes']
							 | 
						|
								        return sum(tax.get('amount', 0.0) for tax in taxes)
							 | 
						|
								
							 | 
						|
								    name = fields.Char(string='Booking Ref', readonly=True,
							 | 
						|
								                       help="Name of the booked order",
							 | 
						|
								                       copy=False, default='/')
							 | 
						|
								    company_id = fields.Many2one('res.company', string='Company',
							 | 
						|
								                                 help="Company of the booked order",
							 | 
						|
								                                 default=lambda self: self.env.user.company_id)
							 | 
						|
								    date_quotation = fields.Datetime(string='Quotation Date',
							 | 
						|
								                                     help="Quotation created date",
							 | 
						|
								                                     readonly=True, index=True,
							 | 
						|
								                                     default=fields.Datetime.now)
							 | 
						|
								    date_order = fields.Date(string='Order Date', help="Order created date",
							 | 
						|
								                             readonly=True, index=True,
							 | 
						|
								                             default=fields.Date.today())
							 | 
						|
								    amount_tax = fields.Float(compute='_compute_amount_all', string='Taxes',
							 | 
						|
								                              help="Tax amount for the order",
							 | 
						|
								                              digits=0, default=1.2)
							 | 
						|
								    amount_total = fields.Float(compute='_compute_amount_all', string='Total',
							 | 
						|
								                                help="Total amount of the order",
							 | 
						|
								                                digits=0)
							 | 
						|
								    book_line_ids = fields.One2many('book.order.line', 'order_id',
							 | 
						|
								                                    help="Order Line of book orders",
							 | 
						|
								                                    string='Order Lines',
							 | 
						|
								                                    copy=True)
							 | 
						|
								    partner_id = fields.Many2one('res.partner', string='Customer',
							 | 
						|
								                                 help="Partner of the order",
							 | 
						|
								                                 change_default=True, index=True)
							 | 
						|
								    state = fields.Selection([('draft', 'New'), ('confirmed', 'Confirmed')],
							 | 
						|
								                             'Status', readonly=True, copy=False,
							 | 
						|
								                             help="Current status of the order",
							 | 
						|
								                             default='draft')
							 | 
						|
								    note = fields.Text(string='Internal Notes',
							 | 
						|
								                       help="Enter any notes regarding order")
							 | 
						|
								    fiscal_position_id = fields.Many2one('account.fiscal.position',
							 | 
						|
								                                         help="Fiscal position account "
							 | 
						|
								                                              "for order",
							 | 
						|
								                                         string='Fiscal Position')
							 | 
						|
								    pickup_date = fields.Datetime(string='Pickup Date', readonly=True,
							 | 
						|
								                                  help="Picking date of the order")
							 | 
						|
								    deliver_date = fields.Datetime(string='Deliver Date', readonly=True,
							 | 
						|
								                                   help="Delivering date of the order")
							 | 
						|
								    phone = fields.Char('Contact no', help='Phone of customer for delivery')
							 | 
						|
								    delivery_address = fields.Char('Delivery Address',
							 | 
						|
								                                   help='Address of customer for delivery')
							 | 
						|
								    pricelist_id = fields.Many2one('product.pricelist', string='Pricelist',
							 | 
						|
								                                   help="Pricelist of the order")
							 | 
						|
								
							 | 
						|
								    @api.depends('book_line_ids.price_subtotal_incl', 'book_line_ids.discount')
							 | 
						|
								    def _compute_amount_all(self):
							 | 
						|
								        """ To compute total amount with tax and without tax """
							 | 
						|
								        for order in self:
							 | 
						|
								            order.amount_tax = 0.0
							 | 
						|
								            currency = order.pricelist_id.currency_id
							 | 
						|
								            order.amount_tax = currency.round(
							 | 
						|
								                sum(self._amount_line_tax(line, order.fiscal_position_id) for
							 | 
						|
								                    line in order.book_line_ids))
							 | 
						|
								            amount_untaxed = currency.round(
							 | 
						|
								                sum(line.price_subtotal for line in order.book_line_ids))
							 | 
						|
								            order.amount_total = order.amount_tax + amount_untaxed
							 | 
						|
								
							 | 
						|
								    @api.model
							 | 
						|
								    def create(self, vals):
							 | 
						|
								        """ Inherited create function to generate sequence number
							 | 
						|
								            for booker orders
							 | 
						|
								            :return record: created record
							 | 
						|
								        """
							 | 
						|
								        if vals.get('name', '/') == '/':
							 | 
						|
								            vals['name'] = self.env['ir.sequence'].next_by_code(
							 | 
						|
								                'book.order') or '/'
							 | 
						|
								        return super(BookOrder, self).create(vals)
							 | 
						|
								
							 | 
						|
								    @api.model
							 | 
						|
								    def create_booked_order(self, partner, phone, address, date, price_list,
							 | 
						|
								                            product, note, pickup, delivery):
							 | 
						|
								        """ It creates a booked order based on the value in the booking popup
							 | 
						|
								             in PoS ui.
							 | 
						|
								             partner(int): id of partner
							 | 
						|
								             phone(string): contact number of customer
							 | 
						|
								             address(string): contact address of the customer
							 | 
						|
								             date(date): ordered date
							 | 
						|
								             price_list(int): price list id of order
							 | 
						|
								             product(dict): dictionary values with product ids and  quantity
							 | 
						|
								             note(string): Order note
							 | 
						|
								             pickup(date): pickup date of the booked order
							 | 
						|
								             delivery(date): delivery date of the booked order
							 | 
						|
								        """
							 | 
						|
								        book_date = (datetime.datetime.fromisoformat(date[:-1])).strftime(
							 | 
						|
								            '%Y-%m-%d %H:%M:%S')
							 | 
						|
								        order = self.create({
							 | 
						|
								            'partner_id': partner,
							 | 
						|
								            'phone': phone,
							 | 
						|
								            'delivery_address': address,
							 | 
						|
								            'pricelist_id': price_list,
							 | 
						|
								            'date_quotation': book_date,
							 | 
						|
								            'book_line_ids': [Command.create({
							 | 
						|
								                'product_id': product['product_id'][i],
							 | 
						|
								                'qty': product['qty'][i],
							 | 
						|
								                'price_unit':product['price'][i],
							 | 
						|
								            }) for i in range(len(product['product_id']))],
							 | 
						|
								            'note': note,
							 | 
						|
								        })
							 | 
						|
								        if pickup:
							 | 
						|
								            order.write({'pickup_date': pickup + ' 00:00:00'})
							 | 
						|
								        if delivery:
							 | 
						|
								            order.write({'deliver_date': delivery + ' 00:00:00'})
							 | 
						|
								
							 | 
						|
								    @api.model
							 | 
						|
								    def all_orders(self):
							 | 
						|
								        """ To fetch all draft stage orders to PoS Booked orders screen
							 | 
						|
								            :return dict: A list of dictionaries containing information
							 | 
						|
								                        about each order
							 | 
						|
								        """
							 | 
						|
								        values = []
							 | 
						|
								        for rec in self.search([('state', '=', 'draft')]):
							 | 
						|
								            products = []
							 | 
						|
								            for line in rec.book_line_ids:
							 | 
						|
								                products.append({
							 | 
						|
								                    'id': line.product_id.id,
							 | 
						|
								                    'qty': line.qty,
							 | 
						|
								                    'price':line.price_unit
							 | 
						|
								                })
							 | 
						|
								            values.append({'id': rec.id,
							 | 
						|
								                           'name': rec.name,
							 | 
						|
								                           'partner_id': rec.partner_id.id,
							 | 
						|
								                           'partner_name': rec.partner_id.name,
							 | 
						|
								                           'address': rec.delivery_address,
							 | 
						|
								                           'note': rec.note,
							 | 
						|
								                           'phone': rec.phone,
							 | 
						|
								                           'date': rec.date_quotation,
							 | 
						|
								                           'pickup': rec.pickup_date,
							 | 
						|
								                           'deliver': rec.deliver_date,
							 | 
						|
								                           'products': products,
							 | 
						|
								                           'total': rec.amount_total
							 | 
						|
								                           })
							 | 
						|
								        return values
							 | 
						|
								
							 |