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.
		
		
		
		
		
			
		
			
				
					
					
						
							170 lines
						
					
					
						
							7.1 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							170 lines
						
					
					
						
							7.1 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ################################################################################### | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| #    Copyright (C) 2017-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |
| #    Author: Nilmar Shereef(<https://www.cybrosys.com>) | |
| # | |
| #    This program is free software: you can modify | |
| #    it under the terms of the GNU Affero General Public License (AGPL) as | |
| #    published by the Free Software Foundation, either version 3 of the | |
| #    License, or (at your option) any later version. | |
| # | |
| #    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 for more details. | |
| # | |
| #    You should have received a copy of the GNU Affero General Public License | |
| #    along with this program.  If not, see <https://www.gnu.org/licenses/>. | |
| # | |
| ################################################################################### | |
| 
 | |
| from odoo.http import request | |
| from odoo import models, api | |
| 
 | |
| 
 | |
| class ProjectReportParser(models.AbstractModel): | |
|     _name = 'report.project_report_pdf.project_report_template' | |
| 
 | |
|     def get_task_model(self, name): | |
|         wizard_record = request.env['wizard.project.report'].search([])[-1] | |
|         task_obj = request.env['project.task'] | |
|         users_selected = [] | |
|         stages_selected = [] | |
|         current_task_obj = [] | |
|         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 len(wizard_record.partner_select) == 0: | |
|             if len(wizard_record.stage_select) == 0: | |
|                 current_task = task_obj.search([('project_id', '=', name)]) | |
|                 for i in current_task: | |
|                     vals = { | |
|                         'name': i.name, | |
|                         'user_id': i.user_id.name, | |
|                         'stage_id': i.stage_id.name, | |
|                     } | |
|                     current_task_obj.append(vals) | |
|                 return current_task_obj | |
|             else: | |
|                 current_task = task_obj.search([('project_id', '=', name), ('stage_id', 'in', stages_selected)]) | |
|                 for i in current_task: | |
|                     vals = { | |
|                         'name': i.name, | |
|                         'user_id': i.user_id.name, | |
|                         'stage_id': i.stage_id.name, | |
|                     } | |
|                     current_task_obj.append(vals) | |
|                 return current_task_obj | |
|         else: | |
|             if len(wizard_record.stage_select) == 0: | |
|                 current_task = task_obj.search([('project_id', '=', name), ('user_id', 'in', users_selected)]) | |
|                 for i in current_task: | |
|                     vals = { | |
|                         'name': i.name, | |
|                         'user_id': i.user_id.name, | |
|                         'stage_id': i.stage_id.name, | |
|                     } | |
|                     current_task_obj.append(vals) | |
|                 return current_task_obj | |
|             else: | |
|                 current_task = task_obj.search( | |
|                     [('project_id', '=', name), ('user_id', 'in', users_selected), ('stage_id', 'in', stages_selected)]) | |
|                 for i in current_task: | |
|                     vals = { | |
|                         'name': i.name, | |
|                         'user_id':  i.user_id.name, | |
|                         'stage_id': i.stage_id.name, | |
|                     } | |
|                     current_task_obj.append(vals) | |
|                 return current_task_obj | |
| 
 | |
|     def get_issue_model(self, name): | |
|         wizard_record = request.env['wizard.project.report'].search([])[-1] | |
|         issue_obj = request.env['project.issue'] | |
|         task_obj = issue_obj | |
|         users_selected = [] | |
|         stages_selected = [] | |
|         current_task_obj = [] | |
|         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 len(wizard_record.partner_select) == 0: | |
|             if len(wizard_record.stage_select) == 0: | |
|                 current_task = task_obj.search([('project_id', '=', name)]) | |
|                 for i in current_task: | |
|                     vals = { | |
|                         'name': i.name, | |
|                         'user_id': i.user_id.name, | |
|                         'stage_id': i.stage_id.name, | |
|                     } | |
|                     current_task_obj.append(vals) | |
|                 return current_task_obj | |
|             else: | |
|                 current_task = task_obj.search([('project_id', '=', name), ('stage_id', 'in', stages_selected)]) | |
|                 for i in current_task: | |
|                     vals = { | |
|                         'name': i.name, | |
|                         'user_id': i.user_id.name, | |
|                         'stage_id': i.stage_id.name, | |
|                     } | |
|                     current_task_obj.append(vals) | |
|                 return current_task_obj | |
|         else: | |
|             if len(wizard_record.stage_select) == 0: | |
|                 current_task = task_obj.search([('project_id', '=', name), ('user_id', 'in', users_selected)]) | |
|                 for i in current_task: | |
|                     vals = { | |
|                         'name': i.name, | |
|                         'user_id': i.user_id.name, | |
|                         'stage_id': i.stage_id.name, | |
|                     } | |
|                     current_task_obj.append(vals) | |
|                 return current_task_obj | |
|             else: | |
|                 current_task = task_obj.search( | |
|                     [('project_id', '=', name), ('user_id', 'in', users_selected), ('stage_id', 'in', stages_selected)]) | |
|                 for i in current_task: | |
|                     vals = { | |
|                         'name': i.name, | |
|                         'user_id': i.user_id.name, | |
|                         'stage_id': i.stage_id.name, | |
|                     } | |
|                     current_task_obj.append(vals) | |
|                 return current_task_obj | |
| 
 | |
|     def get_list_model_task(self, name): | |
|         wizard_record = request.env['wizard.project.report'].search([])[-1] | |
|         if wizard_record.task_select: | |
|             return 2 | |
|         else: | |
|             return 3 | |
| 
 | |
|     def get_list_model_issue(self, name): | |
|         wizard_record = request.env['wizard.project.report'].search([])[-1] | |
|         if wizard_record.issue_select: | |
|             return 2 | |
|         else: | |
|             return 3 | |
| 
 | |
|     @api.model | |
|     def render_html(self, docids, data=None): | |
|         self.model = self.env.context.get('active_model') | |
|         model = self.env['project.project'].search([('id', '=', docids)]) | |
|         get_task_model = self.get_task_model(docids), | |
|         get_issue_model = self.get_issue_model(docids), | |
|         get_list_model_task = self.get_list_model_task(docids), | |
|         get_list_model_issue = self.get_list_model_issue(docids), | |
|         docargs = { | |
|             'doc': model, | |
|             'get_task_model': get_task_model, | |
|             'get_issue_model': get_issue_model, | |
|             'get_list_model_task': get_list_model_task[0], | |
|             'get_list_model_issue': get_list_model_issue[0], | |
|         } | |
| 
 | |
|         return self.env['report'].render('project_report_pdf.project_report_template', docargs) | |
| 
 | |
| 
 |