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.
		
		
		
		
		
			
		
			
				
					
					
						
							201 lines
						
					
					
						
							8.4 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							201 lines
						
					
					
						
							8.4 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ############################################################################### | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |
| #    Author: Aysha Shalin (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 json | |
| import io | |
| from odoo import fields, models | |
| from odoo.http import request | |
| from odoo.tools import date_utils | |
| try: | |
|     from odoo.tools.misc import xlsxwriter | |
| except ImportError: | |
|     import xlsxwriter | |
| 
 | |
| 
 | |
| class ProjectReport(models.TransientModel): | |
|     """ This model represents a wizard for generating project reports in both | |
|     PDF and XLS formats.""" | |
|     _name = 'project.report' | |
|     _description = 'Project Report' | |
| 
 | |
|     partner_select = fields.Many2many( | |
|         'res.users', | |
|         string='Assigned to', | |
|         help="Select the partner for whom the tasks are assigned") | |
|     stage_select = fields.Many2many( | |
|         'project.task.type', | |
|         string="Stage", | |
|         help="Select stage of task") | |
| 
 | |
|     def print_project_report_pdf(self): | |
|         """ Action for printing pdf report.""" | |
|         active_record = self._context['active_id'] | |
|         record = self.env['project.project'].browse(active_record) | |
|         data = { | |
|             'ids': self.ids, | |
|             'model': self._name, | |
|             'record': record.id, | |
|             'partner_select': self.partner_select | |
|         } | |
|         report_reference = ( | |
|             self.env.ref('project_report_pdf.action_report_project_project') | |
|             .report_action(self, data=data)) | |
|         report_reference.update({'close_on_report_download': True}) | |
|         return report_reference | |
| 
 | |
|     def print_project_report_xls(self): | |
|         """ Action for printing xls report.""" | |
|         active_record = self._context['active_id'] | |
|         record = self.env['project.project'].browse(active_record) | |
|         data = { | |
|             'ids': self.ids, | |
|             'model': self._name, | |
|             'record': record.id, | |
|         } | |
|         return { | |
|             'type': 'ir.actions.report', | |
|             'data': {'model': 'project.report', | |
|                      'options': json.dumps(data, | |
|                                            default=date_utils.json_default), | |
|                      'output_format': 'xlsx', | |
|                      'report_name': 'Project Report', | |
|                      }, | |
|             'report_type': 'xlsx' | |
|         } | |
| 
 | |
|     def get_xlsx_report(self, data, response): | |
|         """ This function uses the XlsxWriter library for generating XLSX | |
|         reports. The report includes company information, project details, | |
|         and task data. | |
|         """ | |
|         output = io.BytesIO() | |
|         workbook = xlsxwriter.Workbook(output, {'in_memory': True}) | |
|         name = data['record'] | |
|         user_obj = self.env.user | |
|         wizard_record = request.env['project.report'].search([])[-1] | |
|         task_obj = request.env['project.task'] | |
|         users_selected = [] | |
|         stages_selected = [] | |
|         for elements in wizard_record.partner_select: | |
|             users_selected.append(elements.id) | |
|         for elements in wizard_record.stage_select: | |
|             stages_selected.append(elements.id) | |
|         if wizard_record.partner_select: | |
|             if wizard_record.stage_select: | |
|                 current_task = task_obj.search([ | |
|                     ('project_id', '=', name), | |
|                     ('user_ids', 'in', users_selected), | |
|                     ('stage_id', 'in', stages_selected)]) | |
|             else: | |
|                 current_task = task_obj.search([ | |
|                     ('project_id', '=', name), | |
|                     ('user_ids', 'in', users_selected)]) | |
|         else: | |
|             if wizard_record.stage_select: | |
|                 current_task = task_obj.search([ | |
|                     ('project_id', '=', name), | |
|                     ('stage_id', 'in', stages_selected)]) | |
|             else: | |
|                 current_task = task_obj.search([('project_id', '=', name)]) | |
|         vals = [] | |
|         for i in current_task: | |
|             new = [] | |
|             new.clear() | |
|             for o in i.user_ids: | |
|                 new.append(o.name) | |
|             assignees_name = ' , '.join([str(elem) for elem in new]) | |
|             vals.append({ | |
|                 'name': i.name, | |
|                 'user_id': assignees_name, | |
|                 'stage_id': i.stage_id.name, | |
|             }) | |
|         if current_task: | |
|             project_name = current_task[0].project_id.name | |
|             user = current_task[0].project_id.user_id.name | |
|         else: | |
|             project_name = current_task.project_id.name | |
|             user = current_task.project_id.user_id.name | |
|         sheet = workbook.add_worksheet("Project Report") | |
|         format1 = workbook.add_format({'font_size': 22, 'bg_color': '#D3D3D3'}) | |
|         format4 = workbook.add_format({'font_size': 22}) | |
|         format2 = workbook.add_format( | |
|             {'font_size': 12, 'bold': True, 'bg_color': '#D3D3D3'}) | |
|         format3 = workbook.add_format({'font_size': 10}) | |
|         format5 = workbook.add_format({'font_size': 10, 'bg_color': '#FFFFFF'}) | |
|         format7 = workbook.add_format({'font_size': 10, 'bg_color': '#FFFFFF'}) | |
|         format7.set_align('center') | |
|         sheet.merge_range('A1:B1', user_obj.company_id.name, format5) | |
|         sheet.merge_range('A2:B2', user_obj.company_id.street, format5) | |
|         sheet.write('A3', user_obj.company_id.city, format5) | |
|         sheet.write('B3', user_obj.company_id.zip, format5) | |
|         sheet.merge_range('A4:B4', user_obj.company_id.state_id.name, format5) | |
|         sheet.merge_range('A5:B5', user_obj.company_id.country_id.name, format5) | |
|         sheet.merge_range('C1:H5', "", format5) | |
|         sheet.merge_range(5, 0, 6, 1, "Project  :", format1) | |
|         if project_name: | |
|             sheet.merge_range(5, 2, 6, 7, project_name, format1) | |
|         sheet.merge_range('A8:B8', "Project Manager    :", format5) | |
|         if user: | |
|             sheet.merge_range('C8:D8', user, format5) | |
|         date_start = '' | |
|         date_end = '' | |
|         if current_task: | |
|             date_start = current_task[0].project_id.date_start | |
|         if current_task: | |
|             date_end = current_task[0].project_id.date | |
|         sheet.merge_range('A9:B9', "Start Date              :", format5) | |
|         if date_start: | |
|             sheet.merge_range('C9:D9', str(date_start), format5) | |
|         else: | |
|             sheet.merge_range('C9:D9', '', format5) | |
|         sheet.merge_range('A10:B10', "End Date                :", format5) | |
|         if date_end: | |
|             sheet.merge_range('C10:D10', str(date_end), format5) | |
|         else: | |
|             sheet.merge_range('C10:D10', '', format5) | |
|         sheet.merge_range(1, 6, 4, 7, "", format5) | |
|         sheet.merge_range(7, 4, 9, 7, "", format5) | |
|         sheet.merge_range(10, 4, 11, 7, "", format5) | |
|         sheet.merge_range('A11:H12', 'Open Tasks', format4) | |
|         sheet.merge_range('A13:D13', "Tasks", format2) | |
|         sheet.merge_range('E13:G13', "Assigned", format2) | |
|         sheet.merge_range('H13:I13', "Stage", format2) | |
|         row_number = 13 | |
|         column_number = 0 | |
|         for val in vals: | |
|             sheet.merge_range(row_number, column_number, row_number, | |
|                               column_number + 3, val['name'], format3) | |
|             sheet.merge_range(row_number, column_number + 4, row_number, | |
|                               column_number + 6, val['user_id'], format3) | |
|             sheet.merge_range(row_number, column_number + 7, row_number, | |
|                               column_number + 8, val['stage_id'], format3) | |
|             row_number += 1 | |
|         row_number += 1 | |
|         sheet.merge_range(row_number, 0, row_number, 1, | |
|                           user_obj.company_id.phone, format7) | |
|         sheet.merge_range(row_number, 2, row_number, 4, | |
|                           user_obj.company_id.email, format7) | |
|         sheet.merge_range(row_number, 5, row_number, 7, | |
|                           user_obj.company_id.website, format7) | |
|         workbook.close() | |
|         output.seek(0) | |
|         response.stream.write(output.read()) | |
|         output.close()
 | |
| 
 |