Browse Source

Jan 02 : [ADD] Initial Commit 'excel_report_designer'

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

41
excel_report_designer/README.rst

@ -0,0 +1,41 @@
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 15: Sreerag E @cybrosys
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/__init__.py

@ -0,0 +1,23 @@
# -*- coding: utf-8 -*-
######################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2022-December Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: odoo@cybrosys.com
#
# This program is under the terms of the Odoo Proprietary License v1.0 (OPL-1)
# It is forbidden to publish, distribute, sublicense, or sell copies of the Software
# or modified copies of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
#
########################################################################################
from . import models
from . import controllers

47
excel_report_designer/__manifest__.py

@ -0,0 +1,47 @@
# -*- coding: utf-8 -*-
######################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2022-December Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: odoo@cybrosys.com
#
# This program is under the terms of the Odoo Proprietary License v1.0 (OPL-1)
# It is forbidden to publish, distribute, sublicense, or sell copies of the Software
# or modified copies of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
#
########################################################################################
{
'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': 'Create Customised Excel Reports for Any Models',
'description': """Create Customised Excel Reports for Any Models""",
'depends': ['sale', 'purchase', 'account', 'base'],
'data': [
'security/ir.model.access.csv',
'views/select_report.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,
}

22
excel_report_designer/controllers/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
######################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2022-December Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: odoo@cybrosys.com
#
# This program is under the terms of the Odoo Proprietary License v1.0 (OPL-1)
# It is forbidden to publish, distribute, sublicense, or sell copies of the Software
# or modified copies of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
#
########################################################################################
from . import main

58
excel_report_designer/controllers/main.py

@ -0,0 +1,58 @@
# -*- coding: utf-8 -*-
######################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2022-December Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: odoo@cybrosys.com
#
# This program is under the terms of the Odoo Proprietary License v1.0 (OPL-1)
# It is forbidden to publish, distribute, sublicense, or sell copies of the Software
# or modified copies of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
#
########################################################################################
import json
from odoo import http
from odoo.http import content_disposition, request
from odoo.tools import html_escape
class XLSXReportController(http.Controller):
@http.route('/xlsx_reports', type='http', auth='user', methods=['POST'],
csrf=False)
def get_report_xlsx(self, model, options, output_format, report_name, **kw):
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/doc/RELEASE_NOTES.md

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

22
excel_report_designer/models/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
######################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2022-December Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: odoo@cybrosys.com
#
# This program is under the terms of the Odoo Proprietary License v1.0 (OPL-1)
# It is forbidden to publish, distribute, sublicense, or sell copies of the Software
# or modified copies of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
#
########################################################################################
from . import select_report

379
excel_report_designer/models/select_report.py

@ -0,0 +1,379 @@
# -*- coding: utf-8 -*-
######################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2022-December Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: odoo@cybrosys.com
#
# This program is under the terms of the Odoo Proprietary License v1.0 (OPL-1)
# It is forbidden to publish, distribute, sublicense, or sell copies of the Software
# or modified copies of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
#
########################################################################################
from odoo import models, fields, api, _
try:
from odoo.tools.misc import xlsxwriter
except ImportError:
import xlsxwriter
import io
import json
import datetime
from odoo.tools import date_utils
class SelectReportExcel(models.Model):
_name = 'report.excel'
_rec_name = 'name'
name = fields.Char(string='Name')
model_id = fields.Many2one('ir.model', string='Model', required=True, ondelete="cascade")
fields_ids = fields.Many2many('ir.model.fields', string='Fields',
required=True, ondelete="cascade")
date_field = fields.Many2one('ir.model.fields', string='Date Filter', ondelete="cascade")
start_date = fields.Date(string='Start Date')
end_date = fields.Date(string='End Date')
field_order = fields.Char(default='[]')
action_button = fields.Boolean(default=False)
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)
binding_model_id = fields.Many2one('ir.model', ondelete="cascade")
binding_type = fields.Selection([('action', 'Action'),
('report', 'Report')],
required=True, default='action')
ir_act_server_ref = fields.Many2one('ir.actions.act_window', readonly=True, copy=False)
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):
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})
format7 = 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
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([])
table_data = []
for record in records:
list = []
order = data['field_order'].strip('][').split(', ')
for field_id in order:
field_name = self.env['ir.model.fields'].browse(
int(field_id)).name
list.append(record[field_name])
table_data.append(list)
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()
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.wizard',
'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):
self.fields_ids = []
current_order = self.field_order.strip('][').split(', ')
if self.fields_ids:
self.field_order = str(self.fields_ids._origin.ids)
@api.onchange('model_id')
def onchange_model_id(self):
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):
_name = "excel.report.wizard"
def print_excel_report(self):
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
}
return {
'type': 'ir.actions.report',
'data': {'model': 'excel.report.wizard',
'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):
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})
format7 = 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
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([])
table_data = []
for record in records:
list = []
order = data['field_order'].strip('][').split(', ')
for field_id in order:
field_name = self.env['ir.model.fields'].browse(
int(field_id)).name
list.append(record[field_name])
table_data.append(list)
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()

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

@ -0,0 +1,4 @@
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_excel_report_wizard,excel.report.wizard,model_excel_report_wizard,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.wizard model_excel_report_wizard 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/static/description/assets/icons/check.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 59 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 59 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 59 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 140 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 70 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 135 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 72 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 75 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 20 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 72 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 138 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 165 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 113 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 283 KiB

BIN
excel_report_designer/static/description/banner.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

BIN
excel_report_designer/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.5 KiB

656
excel_report_designer/static/description/index.html

@ -0,0 +1,656 @@
<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>

24
excel_report_designer/static/src/js/action_manager.js

@ -0,0 +1,24 @@
/** @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';
registry.category("ir.actions.report handlers").add("xlsx", async (action) => {
if (action.report_type === 'stock_xlsx') {
framework.blockUI();
var self = this;
console.log(self, "self")
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;
}
});

95
excel_report_designer/views/select_report.xml

@ -0,0 +1,95 @@
<odoo>
<data>
<record id="action_select_reports_wizard_form" model="ir.ui.view">
<field name="name">SelectExcelReport</field>
<field name="model">excel.report.wizard</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>
<record id="action_select_reports_form" model="ir.ui.view">
<field name="name">SelectReport</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="action_select_excel_report" 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>
<menuitem id="menu_select_report"
name="Excel Report Designer"
action="action_select_excel_report"
parent="base.menu_administration"
sequence="50"
/>
</data>
</odoo>
Loading…
Cancel
Save