You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
57 lines
2.2 KiB
57 lines
2.2 KiB
# -*- coding: utf-8 -*-
|
|
###############################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
#
|
|
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
|
|
# Author: Cybrosys Technologies(odoo@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 base64
|
|
import io
|
|
import openpyxl
|
|
from odoo import http
|
|
|
|
|
|
class ImportLots(http.Controller):
|
|
"""Class to handle excel download"""
|
|
@http.route('/download/excel', type='http', auth="user")
|
|
def download_excel_file(self):
|
|
"""Download sample Excel sheet"""
|
|
# Create a new workbook
|
|
wb = openpyxl.Workbook()
|
|
ws = wb.active
|
|
# Add headers
|
|
ws.append(['Lots', 'Product', 'Quantity'])
|
|
# Add sample data
|
|
data = [
|
|
('0000021', '[FURN_8220] Four Person Desk', 2.00),
|
|
('0000022', '[FURN_8220] Four Person Desk', 3.00),
|
|
('0000023', '[FURN_8900] Drawer Black', 6.00),
|
|
]
|
|
for row in data:
|
|
ws.append(row)
|
|
# Save the workbook to a BytesIO buffer
|
|
buffer = io.BytesIO()
|
|
wb.save(buffer)
|
|
buffer.seek(0)
|
|
# Convert the buffer content to base64
|
|
file_content_base64 = base64.b64encode(buffer.getvalue())
|
|
return http.send_file(io.BytesIO(base64.b64decode(file_content_base64)),
|
|
filename='my_excel_file.xlsx',
|
|
as_attachment=True,
|
|
mimetype=
|
|
'application/vnd.openxmlformats-officedocument.'
|
|
'spreadsheetml.sheet')
|
|
|