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.
		
		
		
		
		
			
		
			
				
					
					
						
							116 lines
						
					
					
						
							4.6 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							116 lines
						
					
					
						
							4.6 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ############################################################################## | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |
| #    Author: Dhanya Babu (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 werkzeug.utils import redirect | |
| 
 | |
| from odoo import http | |
| from odoo.addons.portal.controllers import portal | |
| 
 | |
| from odoo.exceptions import AccessError | |
| from odoo.http import request | |
| 
 | |
| 
 | |
| class TicketPortal(portal.CustomerPortal): | |
| 
 | |
|     def _prepare_home_portal_values(self, counters): | |
|         """ | |
|         Prepare values for the home portal, including ticket count. Args: | |
|         counters (dict): A dictionary containing counters for various portal | |
|         information. Returns: dict: A dictionary of values for the home portal. | |
|         """ | |
|         values = super()._prepare_home_portal_values(counters) | |
|         if 'ticket_count' in counters: | |
|             ticket_count = request.env['ticket.helpdesk'].search_count( | |
|                 self._get_tickets_domain()) if request.env[ | |
|                 'ticket.helpdesk'].check_access_rights( | |
|                 'read', raise_exception=False) else 0 | |
|             values['ticket_count'] = ticket_count | |
|         return values | |
| 
 | |
|     def _get_tickets_domain(self): | |
|         """ | |
|         Define the domain for searching tickets related to the current customer. | |
|         Returns: | |
|             list: A list representing the domain for ticket search. | |
|         """ | |
|         return [('customer_id', '=', request.env.user.partner_id.id)] | |
| 
 | |
|     @http.route(['/my/tickets'], type='http', auth="user", website=True) | |
|     def portal_my_tickets(self): | |
|         """ | |
|         Route to display the tickets associated with the current customer. | |
|         Returns: | |
|             http.Response: The HTTP response rendering the tickets page. | |
|         """ | |
|         domain = self._get_tickets_domain() | |
|         tickets = request.env['ticket.helpdesk'].sudo().search(domain) | |
|         values = { | |
|             'default_url': "/my/tickets", | |
|             'tickets': tickets, | |
|             'page_name': 'ticket', | |
|         } | |
|         return request.render("odoo_website_helpdesk.portal_my_tickets", values) | |
| 
 | |
|     @http.route(['/my/tickets/<int:id>'], type='http', auth="public", | |
|                 website=True) | |
|     def portal_tickets_details(self, **kwargs): | |
|         """ | |
|         Route to display the details of a specific ticket. | |
|         Args: | |
|             ticket_id (int): The ID of the ticket to be displayed. | |
|         Returns: | |
|             http.Response: The HTTP response rendering the ticket details page. | |
|         """ | |
|         ticket_id = kwargs.get("id") | |
|         details = request.env['ticket.helpdesk'].sudo().browse(ticket_id) | |
|         if not details or details.customer_id != request.env.user.partner_id: | |
|             return redirect('/my/tickets') | |
|         data = { | |
|             'page_name': 'ticket', | |
|             'ticket': True, | |
|             'details': details, | |
|         } | |
|         return request.render("odoo_website_helpdesk.portal_ticket_details", | |
|                               data) | |
| 
 | |
|     @http.route('/my/tickets/download/<id>', auth='public', | |
|                 type='http', | |
|                 website=True) | |
|     def ticket_download_portal(self, **kwargs): | |
|         """ | |
|         Route to download a PDF version of a specific ticket. | |
|         Args: | |
|             ticket (str): The ID of the ticket to be downloaded. | |
|         Returns: | |
|             http.Response: The HTTP response with the PDF file for download. | |
|         """ | |
|         ticket_id = int(kwargs.get('id')) | |
|         data = { | |
|             'help': request.env['ticket.helpdesk'].sudo().browse(ticket_id)} | |
|         report = request.env.ref( | |
|             'odoo_website_helpdesk.report_ticket') | |
|         pdf, _ = report.sudo()._render_qweb_pdf( | |
|             report, res_ids=ticket_id, data=data) | |
|         pdf_http_headers = [('Content-Type', 'application/pdf'), | |
|                             ('Content-Length', len(pdf)), | |
|                             ('Content-Disposition', | |
|                              'attachment; filename="Helpdesk Ticket.pdf"')] | |
|         return request.make_response(pdf, headers=pdf_http_headers)
 | |
| 
 |