Browse Source

Jun 23 : [UPDT] Updated 'excel_report_designer'

pull/257/head
AjmalCybro 2 years ago
parent
commit
b93a53cb3b
  1. 40
      excel_report_designer/excel_report_designer/README.rst
  2. 23
      excel_report_designer/excel_report_designer/__init__.py
  3. 48
      excel_report_designer/excel_report_designer/__manifest__.py
  4. 23
      excel_report_designer/excel_report_designer/controllers/__init__.py
  5. 60
      excel_report_designer/excel_report_designer/controllers/main.py
  6. 11
      excel_report_designer/excel_report_designer/doc/RELEASE_NOTES.md
  7. 23
      excel_report_designer/excel_report_designer/models/__init__.py
  8. 536
      excel_report_designer/excel_report_designer/models/select_report.py
  9. 3
      excel_report_designer/excel_report_designer/security/ir.model.access.csv
  10. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/check.png
  11. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/chevron.png
  12. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/cogs.png
  13. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/consultation.png
  14. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/ecom-black.png
  15. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/education-black.png
  16. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/hotel-black.png
  17. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/license.png
  18. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/lifebuoy.png
  19. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/logo.png
  20. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/manufacturing-black.png
  21. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/pos-black.png
  22. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/puzzle.png
  23. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/restaurant-black.png
  24. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/service-black.png
  25. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/trading-black.png
  26. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/training.png
  27. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/update.png
  28. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/user.png
  29. BIN
      excel_report_designer/excel_report_designer/static/description/assets/icons/wrench.png
  30. BIN
      excel_report_designer/excel_report_designer/static/description/assets/modules/1.png
  31. BIN
      excel_report_designer/excel_report_designer/static/description/assets/modules/2.png
  32. BIN
      excel_report_designer/excel_report_designer/static/description/assets/modules/3.png
  33. BIN
      excel_report_designer/excel_report_designer/static/description/assets/modules/4.png
  34. BIN
      excel_report_designer/excel_report_designer/static/description/assets/modules/5.png
  35. BIN
      excel_report_designer/excel_report_designer/static/description/assets/modules/6.png
  36. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/hero.gif
  37. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image1.png
  38. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image10.png
  39. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image11.png
  40. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image12.png
  41. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image13.png
  42. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image2.png
  43. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image3.png
  44. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image4.png
  45. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image5.png
  46. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image7.png
  47. BIN
      excel_report_designer/excel_report_designer/static/description/assets/screenshots/image8.png
  48. BIN
      excel_report_designer/excel_report_designer/static/description/banner.png
  49. BIN
      excel_report_designer/excel_report_designer/static/description/icon.png
  50. 656
      excel_report_designer/excel_report_designer/static/description/index.html
  51. 21
      excel_report_designer/excel_report_designer/static/src/js/action_manager.js
  52. 18
      excel_report_designer/excel_report_designer/views/excel_report_wizards.xml
  53. 81
      excel_report_designer/excel_report_designer/views/report_excel.xml

40
excel_report_designer/excel_report_designer/README.rst

@ -1,40 +0,0 @@
Excel Report Designer v16
=========================
This module helps to create reports from various modules
Configuration
=============
* No additional configurations needed
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
* Developers: Cybrosys Techno Solutions odoo@cybrosys.com
Version 16: Gayathri V @cybrosys
Contacts
--------
* Mail Contact : odoo@cybrosys.com
* Website : https://cybrosys.com
Bug Tracker
-----------
Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported.
Maintainer
==========
.. image:: https://cybrosys.com/images/logo.png
:target: https://cybrosys.com
This module is maintained by Cybrosys Technologies.
For support and more information, please visit `Our Website <https://cybrosys.com/>`__
Further information
===================
HTML Description: `<static/description/index.html>`__

23
excel_report_designer/excel_report_designer/__init__.py

@ -1,23 +0,0 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import models
from . import controllers

48
excel_report_designer/excel_report_designer/__manifest__.py

@ -1,48 +0,0 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
{
'name': 'Excel Report Designer',
'version': '16.0.1.0.0',
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': 'https://www.cybrosys.com',
'category': 'Technical',
'summary': 'This module is used to create reports for models and can be select the fields the user want to print.',
'description': """Create Excel Reports for Any Models""",
'depends': ['sale', 'purchase', 'account', 'base'],
'data': [
'security/ir.model.access.csv',
'views/excel_report_wizards.xml',
'views/report_excel.xml',
],
'assets': {
'web.assets_backend': [
'/excel_report_designer/static/src/js/action_manager.js'
],
},
'images': ['static/description/banner.png'],
'license': 'AGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

23
excel_report_designer/excel_report_designer/controllers/__init__.py

@ -1,23 +0,0 @@
"""excel report designer"""
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import main

60
excel_report_designer/excel_report_designer/controllers/main.py

@ -1,60 +0,0 @@
"""excel_report"""
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
import json
from odoo import http
from odoo.http import content_disposition, request
from odoo.tools import html_escape
class XLSXReportController(http.Controller):
"""This is used to call the xlsx report function"""
@http.route('/xlsx_reports', type='http', auth='user', methods=['POST'],
csrf=False)
def get_report_xlsx(self, model, options, output_format, report_name, **kw):
"""this is used to call the function"""
uid = request.session.uid
report_obj = request.env[model].with_user(uid)
options = json.loads(options)
token = 'dummy-because-api-expects-one'
try:
if output_format == 'xlsx':
response = request.make_response(
None,
headers=[
('Content-Type', 'application/vnd.ms-excel'),
('Content-Disposition',
content_disposition(report_name + '.xlsx'))
]
)
report_obj.get_xlsx_report(options, response)
response.set_cookie('fileToken', token)
return response
except Exception as e:
se = http.serialize_exception(e)
error = {
'code': 200,
'message': 'Odoo Server Error',
'data': se
}
return request.make_response(html_escape(json.dumps(error)))

11
excel_report_designer/excel_report_designer/doc/RELEASE_NOTES.md

@ -1,11 +0,0 @@
## Module <excel_report_designer>
#### 12.12.2022
#### Version 16.0.1.0.0
#### ADD
Initial Commit Excel Report Designer

23
excel_report_designer/excel_report_designer/models/__init__.py

@ -1,23 +0,0 @@
"""report excel"""
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import select_report

536
excel_report_designer/excel_report_designer/models/select_report.py

@ -1,536 +0,0 @@
"""report excel"""
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import api, fields, models, _
try:
from odoo.tools.misc import xlsxwriter
except ImportError:
import xlsxwriter
import io
import json
import datetime
from odoo.tools import date_utils
class ReportExcel(models.Model):
"""this is used to create the a binding action"""
_name = 'report.excel'
_description = "report excel"
_rec_name = 'name'
name = fields.Char(string='Name', help='Name')
model_id = fields.Many2one('ir.model', string='Model', required=True,
ondelete="cascade", help="The binding model")
fields_ids = fields.Many2many('ir.model.fields', string='Fields',
required=True, ondelete="cascade",
help="the fields to be printed in the report")
date_field = fields.Many2one('ir.model.fields', string='Date Filter',
ondelete="cascade",
help="filter on the basis of date")
start_date = fields.Date(string='Start Date', help="start date")
end_date = fields.Date(string='End Date', help="end date")
field_order = fields.Char(default='[]', help="the field order")
action_button = fields.Boolean(default=False, string="Action",
help="visibility of action")
state = fields.Selection([
('code', 'Execute Python Code'),
('object_create', 'Create a new Record'),
('object_write', 'Update the Record'),
('multi', 'Execute several actions')], string='Action To Do',
default='code', required=True, copy=True,
help="to execute the code on the basis")
binding_model_id = fields.Many2one('ir.model', ondelete="cascade",
string="Binding Model Id",
help="binding model id")
binding_type = fields.Selection([('action', 'Action'),
('report', 'Report')],
required=True, default='action',
string="Binding Type", help="binding type")
ir_act_server_ref = fields.Many2one('ir.actions.act_window', readonly=True,
copy=False, string="Action Reference",
help="action reference")
def print_report(self):
for rec in self:
data = {
'report_name': rec.name,
'model_name': rec.model_id.model,
'fields_name': rec.fields_ids.mapped('name'),
'field_label': rec.fields_ids.mapped('field_description'),
'date_field': rec.date_field.name,
'date_name': rec.date_field.field_description,
'start_date': rec.start_date,
'end_date': rec.end_date,
'field_order': rec.field_order
}
return {
'type': 'ir.actions.report',
'data': {'model': 'report.excel',
'options': json.dumps(data,
default=date_utils.json_default),
'output_format': 'xlsx',
'report_name': rec.name,
},
'report_type': 'stock_xlsx',
}
def get_xlsx_report(self, data, response):
"""this is used to print the report of all records"""
output = io.BytesIO()
workbook = xlsxwriter.Workbook(output, {'in_memory': True})
sheet = workbook.add_worksheet()
# Formats
format1 = workbook.add_format(
{'font_size': 15, 'align': 'center', 'bold': True})
format1.set_font_color('#000080')
format2 = workbook.add_format(
{'font_size': 11, 'bold': True, 'border': 1, 'bg_color': '#928E8E'})
format4 = workbook.add_format(
{'font_size': 10, 'num_format': 'yyyy-m-d', 'bold': True})
format5 = workbook.add_format({'font_size': 10, 'border': 1, 'text_wrap': True})
format6 = workbook.add_format({'font_size': 10, 'bold': True})
format8 = workbook.add_format({'font_size': 10, 'border': 1})
format9 = workbook.add_format(
{'font_size': 10, 'num_format': 'yyyy-m-d'})
format10 = workbook.add_format(
{'font_size': 10, 'num_format': 'yyyy-m-d', 'border': 1})
format2.set_align('center')
format4.set_align('right')
format6.set_align('right')
format8.set_align('left')
sheet.merge_range(1, 1, 1, len(data['field_label']) + 1,
data['report_name'], format1)
sheet.write(2, 0, "Date :", format4)
sheet.write(2, 1, fields.Datetime.today(), format4)
if data['date_field']:
sheet.write(3, 0, data['date_name'], format4)
if data['start_date']:
sheet.write(3, 1, "From:", format4)
sheet.write(3, 2, data['start_date'], format9)
else:
sheet.write(3, 2, "", format9)
if data['end_date']:
sheet.write(3, 3, "To:", format4)
sheet.write(3, 4, data['end_date'], format9)
else:
sheet.write(3, 4, "", format9)
sl_no = 1
sheet.write(5, 1, "SL No", format2)
row_num = 5
col_num = 2
order = data['field_order'].strip('][').split(', ')
for field_id in order:
field_name = self.env['ir.model.fields'].browse(
int(field_id)).field_description
sheet.write(row_num, col_num, field_name, format2)
col_num += 1
row_num += 1
records = []
if data['date_field']:
if data['start_date'] and data['end_date']:
records = self.env[data['model_name']].search([
(data['date_field'], '>=', data['start_date']),
(data['date_field'], '<=', data['end_date'])])
elif data['start_date'] and not data['end_date']:
records = self.env[data['model_name']].search([
(data['date_field'], '>=', data['start_date'])])
elif not data['start_date'] and data['end_date']:
records = self.env[data['model_name']].search([
(data['date_field'], '<=', data['end_date'])])
else:
records = self.env[data['model_name']].search([])
new_table = []
for record in records:
order = data['field_order'].strip('][').split(', ')
record_dict = {}
for field_id in order:
field = self.env['ir.model.fields'].browse(int(field_id))
field_name = field.name
field_type = self.env['ir.model.fields'].browse(
int(field_id)).ttype
if field_type in ['many2many']:
one2many_values = ', '.join(record[field_name].mapped('name'))
record_dict[field] = one2many_values
elif field_type in ['one2many']:
if record[field_name]:
o2m_list = []
for rec in record[field_name]:
o2m_list.append(rec)
record_dict[field] = o2m_list
else:
record_dict[field] = [record[field_name]]
new_table.append(record_dict)
print('new_table',new_table)
for record in new_table:
col_num = 1
sheet.write(row_num, col_num, sl_no, format5)
col_num += 1
count = 1
for field in record:
field_type = self.env['ir.model.fields'].browse(int(field.id)).ttype
if not field_type in ['one2many', 'many2many']:
try:
if isinstance(record[field][0], datetime.date):
sheet.write(row_num, col_num, record[field][0], format10)
elif isinstance(record[field][0], bool):
if not field:
sheet.write(row_num, col_num, " ", format5)
else:
sheet.write(row_num, col_num, "Yes", format5)
else:
print(record[field][0])
sheet.write(row_num, col_num, record[field][0], format5)
except Exception as e:
if record[field][0]:
sheet.write(row_num, col_num, record[field][0].name_get()[0][1],
format5)
else:
sheet.write(row_num, col_num, "",
format5)
elif field_type == 'one2many':
sub_row_num = row_num
for x in record[field]:
new_count = 1
try:
if isinstance(x.name, datetime.date):
sheet.write(sub_row_num, col_num, x.name, format10)
elif isinstance(x.name, bool):
if not field:
sheet.write(sub_row_num, col_num, " ", format5)
else:
sheet.write(sub_row_num, col_num, "Yes", format5)
else:
print(sub_row_num, col_num, x.name)
new_count+=1
if new_count > count:
count = new_count
sheet.write(sub_row_num, col_num, x.name, format5)
except Exception as e:
if x:
sheet.write(sub_row_num, col_num, x.name_get()[0][1], format5)
else:
sheet.write(sub_row_num, col_num, "", format5)
sub_row_num += 1
elif field_type == 'many2many':
if record[field]:
try:
if isinstance(record[field], datetime.date):
sheet.write(row_num, col_num, record[field][0], format10)
elif isinstance(record[field], bool):
if not field:
sheet.write(row_num, col_num, " ", format5)
else:
sheet.write(row_num, col_num, "Yes", format5)
else:
sheet.write(row_num, col_num, record[field], format5)
except Exception as e:
if record[field][0]:
sheet.write(row_num, col_num, record[field].name_get()[0][1], format5)
else:
sheet.write(row_num, col_num, "", format5)
col_num += 1
sl_no += 1
row_num+=1
for record in new_table:
col_num = 1
sheet.write(row_num, col_num, sl_no, format5)
col_num += 1
count = 1
for field in record:
field_type = self.env['ir.model.fields'].browse(int(field.id)).ttype
if not field_type in ['one2many', 'many2many']:
try:
if isinstance(record[field][0], datetime.date):
sheet.write(row_num, col_num, record[field][0], format10)
elif isinstance(record[field][0], bool):
if not field:
sheet.write(row_num, col_num, " ", format5)
else:
sheet.write(row_num, col_num, "Yes", format5)
else:
sheet.write(row_num, col_num, record[field][0], format5)
except Exception as e:
if record[field][0]:
sheet.write(row_num, col_num, record[field][0].name_get()[0][1], format5)
else:
sheet.write(row_num, col_num, "", format5)
elif field_type == 'one2many':
sub_row_num = row_num
for x in record[field]:
new_count = 1
try:
if isinstance(x.name, datetime.date):
sheet.write(sub_row_num, col_num, x.name, format10)
elif isinstance(x.name, bool):
if not field:
sheet.write(sub_row_num, col_num, " ", format5)
else:
sheet.write(sub_row_num, col_num, "Yes", format5)
else:
new_count += 1
if new_count > count:
count = new_count
sheet.write(sub_row_num, col_num, x.name, format5)
except Exception as e:
if x:
sheet.write(sub_row_num, col_num, x.name_get()[0][1], format5)
else:
sheet.write(sub_row_num, col_num, "", format5)
sub_row_num += 1
elif field_type == 'many2many':
if record[field]:
try:
if isinstance(record[field], datetime.date):
sheet.write(row_num, col_num, record[field][0], format10)
elif isinstance(record[field], bool):
if not field:
sheet.write(row_num, col_num, " ", format5)
else:
sheet.write(row_num, col_num, "Yes", format5)
else:
sheet.write(row_num, col_num, record[field], format5)
except Exception as e:
if record[field][0]:
sheet.write(row_num, col_num, record[field].name_get()[0][1], format5)
else:
sheet.write(row_num, col_num, "", format5)
col_num += 1
sl_no += 1
row_num += count
workbook.close()
output.seek(0)
response.stream.write(output.read())
output.close()
def create_model_action(self):
""" Create a contextual action for each server action."""
self.action_button = True
WindowAction = self.env['ir.actions.act_window']
data = self.env['ir.model.data']
for rec in self.browse(self._ids):
binding_model_id = rec.model_id.id
model_data_id = data._load_xmlid('excel_report_designer')
res_id = data.browse(model_data_id).res_id
button_name = _('Print Report (%s)') % rec.name
act_id = WindowAction.create({
'name': button_name,
'type': 'ir.actions.act_window',
'res_model': 'excel.report.wizards',
'binding_model_id': binding_model_id,
'context': "{'excel' : %d}" % (rec.id),
'view_mode': 'form,tree',
'view_id': res_id,
'target': 'new',
})
rec.write({
'ir_act_server_ref': act_id.id,
})
return True
def unlink_model_action(self):
""" Remove the contextual actions created for the server actions. """
self.action_button = False
self.check_access_rights('write', raise_exception=True)
self.filtered('binding_model_id').write({'binding_model_id': False})
return True
@api.onchange('fields_ids')
def onchange_fields(self):
"""this is used to find the fields of new models"""
self.fields_ids = []
if self.fields_ids:
self.field_order = str(self.fields_ids._origin.ids)
@api.onchange('model_id')
def onchange_model_id(self):
"""this is used to return the fields"""
if self.model_id:
self.name = self.model_id.name + ' Report'
self.fields_ids = False
self.date_field = False
return {
'domain': {
'fields_ids': [('model_id', '=', self.model_id.id)],
'date_field': [('model_id', '=', self.model_id.id),
('ttype', 'in', ['date', 'datetime'])],
}
}
class excel_report_wizard(models.TransientModel):
"""This is used to the wizard class"""
_name = "excel.report.wizards"
_description = "excel report wizard"
def print_excel_report(self):
"""this is used to do the report action"""
excel_report_id = self.env['report.excel'].browse(
self._context.get('excel'))
for rec in excel_report_id:
data = {
'report_name': rec.name,
'model_name': rec.model_id.model,
'fields_name': rec.fields_ids.mapped('name'),
'field_label': rec.fields_ids.mapped('field_description'),
'date_field': rec.date_field.name,
'date_name': rec.date_field.field_description,
'start_date': rec.start_date,
'end_date': rec.end_date,
'field_order': rec.field_order,
'active_model_id': self.env.context['active_ids']
}
return {
'type': 'ir.actions.report',
'data': {'model': 'excel.report.wizards',
'options': json.dumps(data,
default=date_utils.json_default),
'output_format': 'xlsx',
'report_name': rec.name,
},
'report_type': 'stock_xlsx',
}
def get_xlsx_report(self, data, response):
"""This is used to prin the report for selected records."""
output = io.BytesIO()
workbook = xlsxwriter.Workbook(output, {'in_memory': True})
sheet = workbook.add_worksheet()
# Formats
format1 = workbook.add_format(
{'font_size': 15, 'align': 'center', 'bold': True})
format1.set_font_color('#000080')
format2 = workbook.add_format(
{'font_size': 11, 'bold': True, 'border': 1, 'bg_color': '#928E8E'})
format4 = workbook.add_format(
{'font_size': 10, 'num_format': 'yyyy-m-d', 'bold': True})
format5 = workbook.add_format({'font_size': 10, 'border': 1})
format6 = workbook.add_format({'font_size': 10, 'bold': True})
format8 = workbook.add_format({'font_size': 10, 'border': 1})
format9 = workbook.add_format(
{'font_size': 10, 'num_format': 'yyyy-m-d'})
format10 = workbook.add_format(
{'font_size': 10, 'num_format': 'yyyy-m-d', 'border': 1})
format2.set_align('center')
format4.set_align('right')
format6.set_align('right')
format8.set_align('left')
sheet.merge_range(1, 1, 1, len(data['field_label']) + 1,
data['report_name'], format1)
sheet.write(2, 0, "Date :", format4)
sheet.write(2, 1, fields.Datetime.today(), format4)
if data['date_field']:
sheet.write(3, 0, data['date_name'], format4)
if data['start_date']:
sheet.write(3, 1, "From:", format4)
sheet.write(3, 2, data['start_date'], format9)
else:
sheet.write(3, 2, "", format9)
if data['end_date']:
sheet.write(3, 3, "To:", format4)
sheet.write(3, 4, data['end_date'], format9)
else:
sheet.write(3, 4, "", format9)
sl_no = 1
sheet.write(5, 1, "SL No", format2)
row_num = 5
col_num = 2
order = data['field_order'].strip('][').split(', ')
for field_id in order:
field_name = self.env['ir.model.fields'].browse(
int(field_id)).field_description
sheet.write(row_num, col_num, field_name, format2)
col_num += 1
row_num += 1
records = []
if data['date_field']:
if data['start_date'] and data['end_date']:
records = self.env[data['model_name']].search([
(data['date_field'], '>=', data['start_date']),
('id', 'in', data['active_model_id']),
(data['date_field'], '<=', data['end_date'])])
elif data['start_date'] and not data['end_date']:
records = self.env[data['model_name']].search([
(data['date_field'], '>=', data['start_date']),
('id', 'in', data['active_model_id'])])
elif not data['start_date'] and data['end_date']:
records = self.env[data['model_name']].search([
(data['date_field'], '<=', data['end_date']),
('id', 'in', data['active_model_id'])])
else:
records = self.env[data['model_name']].search(
[('id', 'in', data['active_model_id'])])
table_data = []
for record in records:
lst = []
order = data['field_order'].strip('][').split(', ')
for field_id in order:
field_name = self.env['ir.model.fields'].browse(
int(field_id)).name
field_type = self.env['ir.model.fields'].browse(
int(field_id)).ttype
if field_type in ['one2many', 'many2many']:
one2many_values = []
for rec in record[field_name]:
one2many_values.append(rec.name)
lst.append(', '.join(one2many_values))
else:
lst.append(record[field_name])
table_data.append(lst)
for record in table_data:
col_num = 1
sheet.write(row_num, col_num, sl_no, format5)
col_num += 1
for field in record:
try:
if isinstance(field, datetime.date):
sheet.write(row_num, col_num, field, format10)
elif isinstance(field, bool):
if not field:
sheet.write(row_num, col_num, " ", format5)
else:
sheet.write(row_num, col_num, "Yes", format5)
else:
sheet.write(row_num, col_num, field, format5)
except Exception as e:
if field:
sheet.write(row_num, col_num, field.name_get()[0][1],
format5)
else:
sheet.write(row_num, col_num, "",
format5)
col_num += 1
sl_no += 1
row_num += 1
workbook.close()
output.seek(0)
response.stream.write(output.read())
output.close()

3
excel_report_designer/excel_report_designer/security/ir.model.access.csv

@ -1,3 +0,0 @@
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_excel_report_wizard,excel.report.wizards,model_excel_report_wizards,base.group_user,1,1,1,1
access_report_excel,report.excel,model_report_excel,base.group_user,1,1,1,1
1 id name model_id:id group_id:id perm_read perm_write perm_create perm_unlink
2 access_excel_report_wizard excel.report.wizards model_excel_report_wizards base.group_user 1 1 1 1
3 access_report_excel report.excel model_report_excel base.group_user 1 1 1 1

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/check.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.6 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/chevron.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 310 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/cogs.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/consultation.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/ecom-black.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 576 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/education-black.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 733 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/hotel-black.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 911 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/license.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/lifebuoy.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/logo.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.4 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/manufacturing-black.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 673 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/pos-black.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 878 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/puzzle.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 653 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/restaurant-black.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 905 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/service-black.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 839 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/trading-black.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 427 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/training.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 627 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/update.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/user.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 988 B

BIN
excel_report_designer/excel_report_designer/static/description/assets/icons/wrench.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/modules/1.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 59 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/modules/2.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 59 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/modules/3.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 60 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/modules/4.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 59 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/modules/5.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 60 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/modules/6.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 60 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/hero.gif

Binary file not shown.

Before

Width:  |  Height:  |  Size: 140 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image1.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 70 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image10.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 135 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image11.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 72 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image12.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 75 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image13.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 20 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image2.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 72 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image3.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 138 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image4.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 165 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image5.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 42 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image7.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 113 KiB

BIN
excel_report_designer/excel_report_designer/static/description/assets/screenshots/image8.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 283 KiB

BIN
excel_report_designer/excel_report_designer/static/description/banner.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

BIN
excel_report_designer/excel_report_designer/static/description/icon.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 KiB

656
excel_report_designer/excel_report_designer/static/description/index.html

@ -1,656 +0,0 @@
<div class="container" style="padding: 1rem !important; margin-bottom: 1rem !important;">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between" style="border-bottom: 1px solid #d5d5d5;">
<div class="my-3">
<img src="./assets/icons/logo.png" style="width: auto !important; height: 40px !important;">
</div>
<div class="my-3 d-flex align-items-center">
<div
style="background-color: #7C7BAD !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Community
</div>
<div
style="background-color: #875A7B !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
</div>
</div>
</div>
</div>
<div class="container" style="padding: 0rem 1.5rem 4rem !important">
<div class="row" style="height: 900px !important;">
<div class="col-sm-12 col-md-12 col-lg-12"
style="padding: 4rem 1rem !important; background-color: #714B67 !important; height: 600px !important; border-radius: 20px !important;">
<h1
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #FFFFFF !important; font-size: 3.5rem !important; text-align: center !important;">
Excel Report Designer</h1>
<p
style="font-family: 'Montserrat', sans-serif !important; font-weight: 300 !important; color: #FFFFFF !important; font-size: 1.4rem !important; text-align: center !important;">
Create Customised Excel Reports for Any Models
</p>
<img src="./assets/screenshots/hero.gif" class="img-responsive" width="100%" height="auto" />
</div>
</div>
<div class="row">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin-bottom: 2rem !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-compass mr-2"></i>Explore this module
</h2>
<div class="row">
<div class="col-md-6">
<a href="#overview" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Overview</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
Learn more about this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#features" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Features</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
View features of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#screenshots" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Screenshots</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
See key screenshots of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
</div>
</div>
</div>
<div class="row" id="overview">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-pie-chart mr-2"></i>Overview
</h2>
</div>
<div class="col-mg-12 pl-3">
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important; line-height: 30px !important;">
In this Excel Report Designer module, we can create reports in XLSX format for any model with
any fields in the model. We can also filter the report based on the date, using any date field
in the model.
</p>
</div>
</div>
<div class="row" id="features">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-star mr-2"></i>Features
</h2>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Fully configurable XLSX reports</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Filter report data based on any date field</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Custom report name</h4>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Reports menu under the action menu.</h4>
</div>
</div>
</div>
<div class="row" id="screenshots">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-image mr-2"></i>Screenshots
</h2>
</div>
<div class="col-lg-12 my-2">
<h4 class="mt-2"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Report Configuration</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
The reports can be configured and printed using the 'Excel Report Designer' menu at Settings.
Select the desired model on which you want to create report, select the required fields
and filter using any of the date field in the model.</p>
<img src="assets/screenshots/image1.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Configure The Report Of Invoice.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
</p>
<img src="assets/screenshots/image7.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Configure The Report Of Project.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
</p>
<img src="assets/screenshots/image11.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Print report from the configuration form and also add as a action menu.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
</p>
<img src="assets/screenshots/image2.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Print report from the configuration form and also add as a action menu.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
</p>
<img src="assets/screenshots/image12.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Print Report.</h4>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important;">
</p>
<img src="assets/screenshots/image8.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Print the report in the corresponding model.</h4>
<img src="assets/screenshots/image4.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Confirmation wizard for printing the report.</h4>
<img src="assets/screenshots/image3.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
XLXS Report.</h4>
<img src="assets/screenshots/image5.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
XLXS Report.</h4>
<img src="assets/screenshots/image10.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
XLXS Report.</h4>
<img src="assets/screenshots/image13.png" class="img-responsive img-thumbnail border" width="100%"
height="auto" />
</div>
</div>
<!-- SUGGESTED PRODUCTS -->
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center"
style="text-align: center; padding: 2.5rem 1rem !important;">
<h2 style="color: #212529 !important;">Suggested Products</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner">
<div class="carousel-item active" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/report_stock_inventory/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/1.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/project_report_pdf/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/2.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/sale_report_advanced/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/3.png">
</div>
</a>
</div>
</div>
<div class="carousel-item" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/account_reports_xlsx/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/4.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/dynamic_accounts_report/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/5.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/export_stockinfo_xls/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/6.png">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev" style="left:-25px;width: 35px;color: #000;">
<span class="carousel-control-prev-icon"><i class="fa fa-chevron-left" style="font-size:24px"></i></span>
</a>
<a class="carousel-control-next" href="#demo1" data-slide="next" style="right:-25px;width: 35px;color: #000;">
<span class="carousel-control-next-icon"><i class="fa fa-chevron-right" style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
<!-- END OF SUGGESTED PRODUCTS -->
<!-- OUR SERVICES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Services</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire
Odoo
Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Licensing Consultancy</h6>
</div>
</div>
</section>
<!-- END OF END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Industries</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/trading-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure
and
sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/pos-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy
configuration
and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/education-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for
educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/manufacturing-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and
schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/ecom-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile
friendly,
awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/service-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of
services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/restaurant-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or
restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/hotel-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An
all-inclusive
hotel management application</p>
</div>
</div>
</div>
</section>
<!-- END OF END OF OUR INDUSTRIES -->
<!-- FOOTER -->
<!-- Footer Section -->
<section class="container" style="margin: 5rem auto 2rem;">
<div class="row" style="max-width:1540px;">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Need Help?</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</div>
</div>
<!-- Contact Cards -->
<div class="row d-flex justify-content-center align-items-center"
style="max-width:1540px; margin: 0 auto 2rem auto;">
<div class="col-lg-12" style="padding: 0rem 3rem 2rem; border-radius: 10px; margin-right: 3rem; ">
<div class="row mt-4">
<div class="col-lg-6">
<a href="mailto:odoo@cybrosys.com" target="_blank" class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #4d4d4d; color: #FFF; border-radius: 4px;"><i
class="fa fa-envelope mr-2"></i>odoo@cybrosys.com</a>
</div>
<div class="col-lg-6">
<a href="https://api.whatsapp.com/send?phone=918606827707" target="_blank"
class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #25D366; color: #FFF; border-radius: 4px;"><i
class="fa fa-whatsapp mr-2"></i>+91 86068 27707</a>
</div>
</div>
</div>
</div>
<!-- End of Contact Cards -->
</section>
<!-- Footer -->
<section class="oe_container" style="padding: 2rem 3rem 1rem;">
<div class="row" style="max-width:1540px; margin: 0 auto; margin-right: 3rem; ">
<!-- Logo -->
<div class="col-lg-12 d-flex justify-content-center align-items-center" style="margin-top: 3rem;">
<img src="https://www.cybrosys.com/images/logo.png" width="200px" height="auto" />
</div>
<!-- End of Logo -->
<div class="col-lg-12">
<hr
style="margin-top: 3rem;background: linear-gradient(90deg, rgba(2,0,36,0) 0%, rgba(229,229,229,1) 33%, rgba(229,229,229,1) 58%, rgba(0,212,255,0) 100%); height: 2px; border-style: none;">
<!-- End of Footer Section -->
</div>
</div>
</section>
<!-- END OF FOOTER -->
</div>

21
excel_report_designer/excel_report_designer/static/src/js/action_manager.js

@ -1,21 +0,0 @@
/** @odoo-module */
import { registry } from "@web/core/registry";
import { download } from "@web/core/network/download";
import framework from 'web.framework';
import session from 'web.session';
//this is used to call the controller and also passes the report data.
registry.category("ir.actions.report handlers").add("xlsx", async (action) => {
if (action.report_type === 'stock_xlsx') {
framework.blockUI();
var self = this;
var def = $.Deferred();
session.get_file({
url: '/xlsx_reports',
data: action.data,
success: def.resolve.bind(def),
error: (error) => self.call('crash_manager', 'rpc_error', error),
complete: framework.unblockUI,
});
return def;
}
});

18
excel_report_designer/excel_report_designer/views/excel_report_wizards.xml

@ -1,18 +0,0 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!--report wizard form view-->
<record id="excel_report_wizards_view_form" model="ir.ui.view">
<field name="name">excel.report.wizards.view.form</field>
<field name="model">excel.report.wizards</field>
<field name="arch" type="xml">
<form>
<h2>Do you want to print the report??</h2>
<footer>
<button name="print_excel_report" string="Print"
type="object" class="oe_highlight"/>
<button string="Cancel" special="cancel" class="oe_link"/>
</footer>
</form>
</field>
</record>
</odoo>

81
excel_report_designer/excel_report_designer/views/report_excel.xml

@ -1,81 +0,0 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!--report excel views-->
<record id="report_excel_view_form" model="ir.ui.view">
<field name="name">report.excel.view.form</field>
<field name="model">report.excel</field>
<field name="priority">20</field>
<field name="arch" type="xml">
<form>
<header>
<button name="print_report" type="object"
string="Print Excel Report" class="oe_highlight"/>
</header>
<field name="binding_model_id" invisible="1"/>
<field name="action_button" invisible="1"/>
<sheet>
<div class="oe_button_box" name="button_box">
<button name="create_model_action" type="object"
string="Add Action"
attrs="{'invisible':[('action_button','!=',False)]}"
icon="fa-plus-square"
class="oe_stat_button"/>
<button name="unlink_model_action" type="object"
string="Remove"
attrs="{'invisible':[('action_button','=',False)]}"
icon="fa-minus-square"
class="oe_stat_button"/>
</div>
<div class="oe_title">
<h1>
<group>
<field name="name"/>
</group>
</h1>
</div>
<group>
<field name="model_id"/>
<field name="state"/>
</group>
<span>The column order will be as selected in the below
table
</span>
<notebook>
<page string="Fields To View">
<group>
<field name="fields_ids">
<tree editable="bottom">
<field name="name"/>
<field name="field_description"/>
<field name="ttype"/>
</tree>
</field>
<field name="date_field"/>
<field name="field_order" invisible="1"/>
</group>
<group attrs="{'invisible': [('date_field', '=', False)]}">
<field name="start_date" class="oe_inline"
attrs="{'invisible': [('date_field', '=', False)]}"/>
<field name="end_date" class="oe_inline"
attrs="{'invisible': [('date_field', '=', False)]}"/>
</group>
</page>
</notebook>
</sheet>
</form>
</field>
</record>
<record id="select_report_action" model="ir.actions.act_window">
<field name="name">Select Report</field>
<field name="res_model">report.excel</field>
<field name="view_mode">tree,form</field>
</record>
<!--report excel menu-->
<menuitem id="menu_select_report"
name="Excel Report Designer"
action="select_report_action"
parent="base.menu_administration"
sequence="50"
/>
</odoo>
Loading…
Cancel
Save