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()
|
|
|