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
|
|
|