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.
		
		
		
		
		
			
		
			
				
					
					
						
							233 lines
						
					
					
						
							9.6 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							233 lines
						
					
					
						
							9.6 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ################################################################################ | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #   Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |
| #    Author: Megha A P (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/>. | |
| # | |
| ################################################################################ | |
| from odoo.http import request, route | |
| from odoo.addons.portal.controllers.portal import CustomerPortal | |
| 
 | |
| 
 | |
| class DashboardPortal(CustomerPortal): | |
|     """ This class is used to super already existing dashboard portal to | |
|     change the template""" | |
|     @route(['/my', '/my/home'], type='http', auth="user", website=True) | |
|     def home(self, **kw): | |
|         """Replaces already existing work flow of portal view to redirect to | |
|         new template with record values and count""" | |
| 
 | |
|         user = request.env.user.id | |
|         partners = request.env.user | |
|         group_id = request.env.ref('base.group_user') | |
| 
 | |
|         sale_order = request.env['sale.order'].sudo() | |
|         purchase_order = request.env['purchase.order'].sudo() | |
|         account_move = request.env['account.move'] | |
|         project = request.env['project.project'].sudo() | |
|         task = request.env['project.task'].sudo() | |
|         config_parameters = request.env['ir.config_parameter'].sudo() | |
| 
 | |
|         number_project = "" | |
|         projects_limited = "" | |
|         tasks_limited = "" | |
|         number_account = "" | |
|         invoices_limited = "" | |
| 
 | |
|         show_project = request.env[ | |
|             'ir.config_parameter' | |
|         ].sudo().get_param('portal_dashboard.is_show_project') | |
|         show_account = request.env['ir.config_parameter'].sudo().get_param( | |
|             'portal_dashboard.is_show_recent_invoice_bill') | |
|         show_so_q = request.env[ | |
|             'ir.config_parameter' | |
|         ].sudo().get_param('portal_dashboard.is_show_recent_so_q') | |
|         show_po_rfq = request.env[ | |
|             'ir.config_parameter' | |
|         ].sudo().get_param('portal_dashboard.is_show_recent_po_rfq') | |
| 
 | |
|         number_so = "" | |
|         sale_orders_limited = "" | |
|         quotations_limited = "" | |
| 
 | |
|         number_po = "" | |
|         purchase_orders_limited = "" | |
|         rfq_limited = "" | |
| 
 | |
|         if group_id in partners.groups_id: | |
|             if show_so_q: | |
|                 number_so = request.env[ | |
|                     'ir.config_parameter' | |
|                 ].sudo().get_param('portal_dashboard.sale_count', 0) | |
| 
 | |
|                 sale_orders_limited = sale_order.search([ | |
|                     ('user_id', '=', user), | |
|                     ('state', 'not in', ['draft', 'sent']) | |
|                 ], limit=int(number_so)) | |
| 
 | |
|                 quotations_limited = sale_order.search([ | |
|                     ('user_id', '=', user), | |
|                     ('state', 'in', ['sent']) | |
|                 ], limit=int(number_so)) | |
| 
 | |
|             if show_po_rfq: | |
|                 number_po = config_parameters.get_param( | |
|                     'portal_dashboard.purchase_count', 0) | |
|                 purchase_orders_limited = purchase_order.search([ | |
|                         ('user_id', '=', user), | |
|                         ('state', 'not in', ['draft', 'sent', 'to approve']) | |
|                     ], limit=int(number_po)) | |
|                 rfq_limited = purchase_order.search([ | |
|                     ('user_id', '=', user), | |
|                     ('state', 'in', ['draft', 'sent', 'to approve']) | |
|                 ], limit=int(number_po)) | |
| 
 | |
|             if show_project: | |
|                 number_project = config_parameters.get_param( | |
|                     'portal_dashboard.project_count', 0) | |
|                 projects_limited = project.search([], | |
|                                                   limit=int(number_project)) | |
|                 tasks_limited = task.search([], limit=int(number_project)) | |
| 
 | |
|             if show_account: | |
|                 number_account = config_parameters.get_param( | |
|                     'portal_dashboard.account_count', 0) | |
|                 invoices_limited = account_move.search([ | |
|                     ('invoice_user_id', '=', user), | |
|                     ('state', 'not in', ['draft', 'cancel']) | |
|                 ], limit=int(number_account)) | |
| 
 | |
|             sale_orders = sale_order.search([ | |
|                 ('user_id', '=', user), | |
|                 ('state', 'not in', ['draft', 'sent']) | |
|             ]) | |
| 
 | |
|             quotations = sale_order.search([ | |
|                 ('user_id', '=', user), | |
|                 ('state', 'in', ['sent']) | |
|             ]) | |
|             purchase_orders = purchase_order.search([ | |
|                 ('user_id', '=', user), | |
|                 ('state', 'not in', ['draft', 'sent', 'to approve']) | |
|             ]) | |
|             rfq = purchase_order.search([ | |
|                 ('user_id', '=', user), | |
|                 ('state', 'in', ['sent', 'to approve']) | |
|             ]) | |
| 
 | |
|             projects = project.search([]) | |
|             tasks = task.search([]) | |
|             invoices = account_move.search([ | |
|                 ('invoice_user_id', '=', user), | |
|                 ('state', 'not in', ['draft', 'cancel']) | |
|             ]) | |
|         else: | |
|             if show_so_q: | |
|                 number_so = config_parameters.get_param( | |
|                     'portal_dashboard.sale_count', 0) | |
| 
 | |
|                 sale_orders_limited = sale_order.search([ | |
|                     ('partner_id', '=', partners.partner_id.id), | |
|                     ('state', 'not in', ['draft', 'sent']) | |
|                 ], limit=int(number_so)) | |
| 
 | |
|                 quotations_limited = sale_order.search([ | |
|                     ('partner_id', '=', partners.partner_id.id), | |
|                     ('state', 'in', ['sent']) | |
|                 ], limit=int(number_so)) | |
| 
 | |
|             if show_po_rfq: | |
|                 number_po = config_parameters.get_param( | |
|                     'portal_dashboard.purchase_count', 0) | |
|                 purchase_orders_limited = purchase_order.search([ | |
|                     ('partner_id', '=', partners.partner_id.id), | |
|                     ('state', 'not in', ['draft', 'sent', 'to approve']) | |
|                 ], limit=int(number_po)) | |
|                 rfq_limited = purchase_order.search([ | |
|                     ('partner_id', '=', partners.partner_id.id), | |
|                     ('state', 'in', ['draft', 'sent', 'to approve']) | |
|                 ], limit=int(number_po)) | |
| 
 | |
|             if show_project: | |
|                 number_project = config_parameters.get_param( | |
|                     'portal_dashboard.project_count', 0) | |
|                 projects_limited = project.search([('user_id', '=', user)], | |
|                                                   limit=int(number_project)) | |
|                 tasks_limited = task.search([('user_id', '=', user)], | |
|                                             limit=int(number_project)) | |
| 
 | |
|             if show_account: | |
|                 number_account = config_parameters.get_param( | |
|                     'portal_dashboard.account_count', 0) | |
|                 invoices_limited = account_move.search([ | |
|                     ('partner_id', '=', partners.partner_id.id), | |
|                     ('state', 'not in', ['draft', 'cancel']) | |
|                 ], limit=int(number_account)) | |
| 
 | |
|             sale_orders = sale_order.search([ | |
|                 ('partner_id', '=', partners.partner_id.id), | |
|                 ('state', 'not in', ['draft', 'sent']) | |
|             ]) | |
| 
 | |
|             quotations = sale_order.search([ | |
|                 ('partner_id', '=', partners.partner_id.id), | |
|                 ('state', 'in', ['sent']) | |
|             ]) | |
|             purchase_orders = purchase_order.search([ | |
|                 ('partner_id', '=', partners.partner_id.id), | |
|                 ('state', 'not in', ['draft', 'sent', 'to approve']) | |
|             ]) | |
|             rfq = purchase_order.search([ | |
|                 ('partner_id', '=', partners.partner_id.id), | |
|                 ('state', 'in', ['sent', 'to approve']) | |
|             ]) | |
| 
 | |
|             projects = project.search([ | |
|                 ('user_id', '=', user) | |
|             ]) | |
|             tasks = task.search([('user_id', '=', user)]) | |
|             invoices = account_move.search([ | |
|                 ('partner_id', '=', partners.partner_id.id), | |
|                 ('state', 'not in', ['draft', 'cancel']) | |
|             ]) | |
| 
 | |
|         values = self._prepare_portal_layout_values() | |
|         values['sale_order_portal'] = sale_orders | |
|         values['quotation_portal'] = quotations | |
|         values['purchase_orders_portal'] = purchase_orders | |
|         values['rfq_portal'] = rfq | |
|         values['projects_portal'] = projects | |
|         values['tasks_portal'] = tasks | |
|         values['invoices_portal'] = invoices | |
|         values['number_so_portal'] = number_so | |
|         values['number_po_portal'] = number_po | |
|         values['number_account_portal'] = number_account | |
|         values['number_project_portal'] = number_project | |
|         values['sale_orders_limited'] = sale_orders_limited | |
|         values['quotations_limited'] = quotations_limited | |
|         values['purchase_orders_limited'] = purchase_orders_limited | |
|         values['rfq_limited'] = rfq_limited | |
|         values['invoices_limited'] = invoices_limited | |
|         values['projects_limited'] = projects_limited | |
|         values['tasks_limited'] = tasks_limited | |
|         values['show_so_q'] = show_so_q | |
|         values['show_po_rfq'] = show_po_rfq | |
|         values['show_project'] = show_project | |
|         values['show_account'] = show_account | |
| 
 | |
|         return request.render("portal_dashboard.replace_dashboard_portal_view", | |
|                               values)
 | |
| 
 |