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.
194 lines
9.3 KiB
194 lines
9.3 KiB
# -*- coding: utf-8 -*-
|
|
"""Wizard for pdf and xlsx reports"""
|
|
################################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
# Copyright (C) 2017-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
|
|
# Author: Avinash Nk(<avinash@cybrosys.in>)
|
|
#
|
|
# 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/>.
|
|
#
|
|
################################################################################
|
|
import json
|
|
import pytz
|
|
from odoo import fields, models
|
|
from odoo.exceptions import ValidationError
|
|
from odoo.tools import date_utils, io, xlsxwriter
|
|
|
|
|
|
class HotelManagementWizard(models.TransientModel):
|
|
"""Class for wizard"""
|
|
_name = 'event.management.wizard'
|
|
_description = 'Event Management Wizard'
|
|
|
|
date_from = fields.Date(string="From")
|
|
date_to = fields.Date(string="To")
|
|
partner_id = fields.Many2one('res.partner', string='Customer')
|
|
type_event_ids = fields.Many2many('event.management.type', 'event_type_rel',
|
|
'report_id', 'type_id', string="Type")
|
|
event_state = fields.Selection(
|
|
[('draft', 'Draft'), ('confirm', 'Confirmed'), ('invoice', 'Invoiced'),
|
|
('close', 'Close'), ('cancel', 'Canceled')], string="State")
|
|
|
|
def print_pdf_report(self):
|
|
"""Method for printing pdf report"""
|
|
type_select = self.type_event_ids.ids
|
|
data = {
|
|
'model': 'event.management.wizard',
|
|
'form': self.read()[0],
|
|
'event_types': type_select
|
|
}
|
|
return self.env.ref(
|
|
'event_management.action_event_management_report').report_action(
|
|
self, data=data)
|
|
|
|
def print_xls_report(self):
|
|
"""Method of button for printing xlsx report"""
|
|
rec = self.env.user.sudo().company_id
|
|
if self.date_from and self.date_to and self.date_from > self.date_to:
|
|
raise ValidationError('From Date must be less than To Date')
|
|
user_tz = self.env.user.tz
|
|
current = fields.datetime.now()
|
|
current = pytz.UTC.localize(current)
|
|
current = current.astimezone(pytz.timezone(user_tz))
|
|
data = {
|
|
'event_type': self.type_event_ids.ids,
|
|
'date_from': self.date_from,
|
|
'date_to': self.date_to,
|
|
'customer': self.partner_id.id,
|
|
'state': self.event_state,
|
|
'today_date': current,
|
|
'company': [rec.partner_id.name, rec.street, rec.favicon]
|
|
}
|
|
return {
|
|
'type': 'ir.actions.report',
|
|
'report_type': 'xlsx',
|
|
'data': {'model': 'event.management.wizard',
|
|
'output_format': 'xlsx',
|
|
'options': json.dumps(data,
|
|
default=date_utils.json_default),
|
|
'report_name': 'Event Management Report', },
|
|
}
|
|
|
|
def get_xlsx_report(self, data, response):
|
|
"""Method for fetching data and printing xlsx report from controller"""
|
|
output = io.BytesIO()
|
|
workbook = xlsxwriter.Workbook(output, {'in_memory': True})
|
|
sheet = workbook.add_worksheet()
|
|
head = workbook.add_format({'align': 'center',
|
|
'bold': True, 'font_size': '20px'})
|
|
cell_head_format = workbook.add_format({'font_size': '12px'})
|
|
cell_data_format = workbook.add_format({'font_size': '10px'})
|
|
txt_head = workbook.add_format({'font_size': '10px', 'border': 2})
|
|
txt = workbook.add_format({'font_size': '10px', 'border': 2})
|
|
sheet.merge_range('F2:M3', 'EVENT MANAGEMENT REPORT', head)
|
|
sheet.merge_range('B4:E4', data['company'][0], cell_head_format)
|
|
sheet.merge_range('B5:E5', data['company'][1], cell_head_format)
|
|
sheet.write('B6', 'Date:', cell_head_format)
|
|
sheet.merge_range('C6:E6', data['today_date'], cell_data_format)
|
|
if data['date_from'] and data['date_to'] and data['customer']:
|
|
customer_name = self.env['res.partner'].browse(int(
|
|
data['customer'])).name
|
|
sheet.write('B8', 'From:', cell_head_format)
|
|
sheet.merge_range('C8:D8', data['date_from'], cell_data_format)
|
|
sheet.write('F8', 'To:', cell_head_format)
|
|
sheet.merge_range('G8:H8', data['date_to'], cell_data_format)
|
|
sheet.merge_range('J8:K8', 'Customer:', cell_head_format)
|
|
sheet.merge_range('L8:N8', customer_name, cell_data_format)
|
|
elif data['date_from'] and data['date_to']:
|
|
sheet.write('B8', 'From:', cell_head_format)
|
|
sheet.merge_range('C8:D8', data['date_from'],
|
|
cell_data_format)
|
|
sheet.write('F8', 'To:', cell_head_format)
|
|
sheet.merge_range('G8:H8', data['date_to'], cell_data_format)
|
|
elif data['date_from'] and data['customer']:
|
|
customer_name = self.env['res.partner'].browse(int(
|
|
data['customer'])).name
|
|
sheet.write('B8', 'From:', cell_head_format)
|
|
sheet.merge_range('C8:D8', data['date_from'], cell_data_format)
|
|
sheet.merge_range('F8:G8', 'Customer:', cell_head_format)
|
|
sheet.merge_range('H8:J8', customer_name, cell_data_format)
|
|
elif data['customer'] and data['date_to']:
|
|
customer_name = self.env['res.partner'].browse(int(
|
|
data['customer'])).name
|
|
sheet.write('B8', 'To:', cell_head_format)
|
|
sheet.merge_range('C8:D8', data['date_to'], cell_data_format)
|
|
sheet.merge_range('F8:G8', 'Customer:', cell_head_format)
|
|
sheet.merge_range('H8:J8', customer_name, cell_data_format)
|
|
elif data['date_from']:
|
|
sheet.write('B8', 'From:', cell_head_format)
|
|
sheet.merge_range('C8:D8', data['date_from'], cell_data_format)
|
|
elif data['date_to']:
|
|
sheet.write('B8', 'To:', cell_head_format)
|
|
sheet.merge_range('C8:D8', data['date_to'], cell_data_format)
|
|
elif data['customer']:
|
|
customer_name = self.env['res.partner'].browse(int(
|
|
data['customer'])).name
|
|
sheet.merge_range('B8:C8', 'Customer:', cell_head_format)
|
|
sheet.merge_range('D8:E8', customer_name, cell_data_format)
|
|
sheet.write(10, 0, 'Sl.no', txt_head)
|
|
sheet.merge_range('B11:E11', 'Name', txt_head)
|
|
sheet.merge_range('F11:H11', 'Type', txt_head)
|
|
sheet.merge_range('I11:K11', 'Customer', txt_head)
|
|
sheet.merge_range('L11:M11', 'Date', txt_head)
|
|
sheet.merge_range('N11:O11', 'Start Date', txt_head)
|
|
sheet.merge_range('P11:Q11', 'End Date', txt_head)
|
|
sheet.write(10, 17, 'State', txt_head)
|
|
where = '1=1'
|
|
|
|
if data["customer"]:
|
|
where += """AND e.partner_id = %s""" % int(data['customer'])
|
|
if data['date_from']:
|
|
where += """AND e.date>='%s'""" % (data['date_from'])
|
|
if data['date_to']:
|
|
where += """AND e.date <= '%s'""" % (data['date_to'])
|
|
if data['event_type']:
|
|
event_list = data['event_type']
|
|
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 data['state']:
|
|
where += """AND e.state = '%s'""" % (data['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.fetchall()
|
|
j = 11
|
|
k = 1
|
|
for i in range(0, len(rec)):
|
|
sheet.write(j, 0, k, txt)
|
|
sheet.merge_range('B%d:E%d' % (j + 1, j + 1), rec[i][0], txt)
|
|
sheet.merge_range('F%d:H%d' % (j + 1, j + 1), rec[i][1], txt)
|
|
sheet.merge_range('I%d:K%d' % (j + 1, j + 1), rec[i][2], txt)
|
|
sheet.merge_range('L%d:M%d' % (j + 1, j + 1),
|
|
fields.Date.to_string(rec[i][4]), txt)
|
|
sheet.merge_range('N%d:O%d' % (j + 1, j + 1),
|
|
fields.Datetime.to_string(rec[i][5]), txt)
|
|
sheet.merge_range('P%d:Q%d' % (j + 1, j + 1),
|
|
fields.Datetime.to_string(rec[i][6]), txt)
|
|
sheet.write(j, 17,
|
|
dict(self.env['event.management']._fields[
|
|
'state'].selection).get(rec[i][3]), txt)
|
|
j += 1
|
|
k += 1
|
|
workbook.close()
|
|
output.seek(0)
|
|
response.stream.write(output.read())
|
|
output.close()
|
|
|