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.
		
		
		
		
		
			
		
			
				
					
					
						
							73 lines
						
					
					
						
							3.2 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							73 lines
						
					
					
						
							3.2 KiB
						
					
					
				| """Module for pdf data fetching and carry off pdf report data""" | |
| # -*- coding: utf-8 -*- | |
| ################################################################################ | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |
| #    Author: Subina 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/>. | |
| # | |
| ################################################################################ | |
| import pytz | |
| from odoo import api, fields, models | |
| from odoo.exceptions import ValidationError | |
| 
 | |
| 
 | |
| class ReportHotelManagement(models.AbstractModel): | |
|     """Class for fetch and carry off pdf data to template""" | |
|     _name = "report.event_management.report_event_management" | |
|     _description = "Event Management Report" | |
| 
 | |
|     @api.model | |
|     def _get_report_values(self, docids, data=None): | |
|         """ Get values for the report""" | |
|         form_data = data['form'] | |
|         where = '1=1' | |
|         if form_data['date_from'] and form_data['date_to'] \ | |
|                 and form_data['date_from'] > form_data['date_to']: | |
|             raise ValidationError('From Date must be less than To Date') | |
|         if form_data["partner_id"]: | |
|             where += """AND e.partner_id = '%s'""" % \ | |
|                      (form_data['partner_id'][0]) | |
|         if form_data['date_from']: | |
|             where += """AND e.date>='%s'""" % (form_data['date_from']) | |
|         if form_data['date_to']: | |
|             where += """AND e.date <= '%s'""" % (form_data['date_to']) | |
|         if form_data['type_event_ids']: | |
|             event_list = data['event_types'] | |
|             event_ids = f"({event_list[0]})" if len(event_list) == 1 else tuple( | |
|                 event_list) | |
|             where += """AND e.type_of_event_id IN {}""".format(event_ids) | |
|         if form_data['event_state']: | |
|             where += """AND e.state = '%s'""" % (form_data['event_state']) | |
|         self.env.cr.execute(""" | |
|                 SELECT e.name as event, t.name as type, r.name as partner,  | |
|                 e.state, e.date, | |
|                 e.start_date, e.end_date | |
|                 from event_management e inner join  | |
|                 res_partner r on e.partner_id = r.id | |
|                 inner join event_management_type t on  | |
|                 e.type_of_event_id = t.id | |
|                 where %s order by e.date""" % where) | |
|         rec = self.env.cr.dictfetchall() | |
|         return { | |
|             'docs': rec, | |
|             'docs2': form_data, | |
|             'today_date': fields.datetime.strftime( | |
|                 pytz.UTC.localize(fields.datetime. | |
|                                   now()).astimezone(pytz.timezone(self.env. | |
|                                                                   user.tz)), | |
|                 "%d-%m-%Y %H:%M:%S") | |
|         }
 | |
| 
 |