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.
 
 
 
 
 

72 lines
3.3 KiB

# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Cybrosys Techno Solutions(<https://www.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 fields, models, _
from odoo.exceptions import ValidationError
class PosSaleTopSelling(models.TransientModel):
"""Get top_selling product,category,customer from pos"""
_name = 'pos.sale.top.selling'
_description = 'Point of Sale Top Selling Product/Category/Customer Report'
start_date = fields.Datetime(string="Start Date",
required=True,
help="Starting date")
end_date = fields.Datetime(string="End Date",
required=True,
help="Ending date")
top_selling = fields.Selection(
[('products', 'Products'), ('category', 'Categories'),
('customers', 'Customers')],
string='Top Selling', default='products',
help="Select Top selling categories, products and customers")
no_of_products = fields.Integer(string="Number of Products",
help="Number of products")
no_of_categories = fields.Integer(string="No of Categories",
help="Number of categories")
no_of_customers = fields.Integer(string="Number of Customers",
help="Number of customers")
def action_generate_report(self):
"""Generate top_selling product,category,customer report from pos"""
if self.start_date > self.end_date:
raise ValidationError(_("The End Date must be greater than the "
"Start Date"))
data = {
'start_date': self.start_date, 'end_date': self.end_date,
'top_selling': self.top_selling
}
if self.top_selling == 'products':
data['no_of_products'] = self.no_of_products
return self.env.ref(
'advanced_pos_reports.pos_top_selling_products_report'
).report_action([], data=data)
elif self.top_selling == 'category':
data['no_of_categories'] = self.no_of_categories
return self.env.ref(
'advanced_pos_reports.pos_top_selling_category_report'
).report_action([], data=data)
elif self.top_selling == 'customers':
data['no_of_customers'] = self.no_of_customers
return self.env.ref(
'advanced_pos_reports.pos_top_selling_customer_report'
).report_action([], data=data)