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: Gayathri V(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')
							 | 
						|
								
							 |