diff --git a/import_lots/README.rst b/import_lots/README.rst new file mode 100755 index 000000000..1bb8c2c94 --- /dev/null +++ b/import_lots/README.rst @@ -0,0 +1,38 @@ +.. image:: https://img.shields.io/badge/license-LGPL--3-green.svg + :target: https://www.gnu.org/licenses/lgpl.html + :alt: License: LGPL-3 + +Import Lot from Excel +===================== +Module Helps to Import Lots From Excel Sheet to Stock Move Line. + +Company +------- +* `Cybrosys Techno Solutions `__ + +Credits +------- +Developer:(V17) Remya R, Sabeel B +Contact: odoo@cybrosys.com + +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 `__ + +Further information +=================== +HTML Description: ``__ diff --git a/import_lots/__init__.py b/import_lots/__init__.py new file mode 100644 index 000000000..0513ee3f9 --- /dev/null +++ b/import_lots/__init__.py @@ -0,0 +1,24 @@ +# -*- coding: utf-8 -*- +############################################################################### +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2024-TODAY Cybrosys Technologies() +# 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 . +# +############################################################################### +from . import controllers +from . import models +from . import wizard diff --git a/import_lots/__manifest__.py b/import_lots/__manifest__.py new file mode 100644 index 000000000..77a88411d --- /dev/null +++ b/import_lots/__manifest__.py @@ -0,0 +1,50 @@ +# -*- coding: utf-8 -*- +############################################################################### +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2024-TODAY Cybrosys Technologies() +# 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 . +# +############################################################################### +{ + 'name': 'Import Lot from Excel', + 'version': '17.0.1.0.0', + 'category': 'Warehouse', + 'summary': 'Import lots and add while validating a purchase ' + 'order picking', + 'description': 'Module helps to import lots and add to products in' + 'purchase order line while validating a stock_picking ', + 'author': 'Cybrosys Techno Solution', + 'company': 'Cybrosys Techno Solutions', + 'maintainer': 'Cybrosys Techno Solution', + 'website': 'https://www.cybrosys.com', + 'depends': ['stock', 'purchase'], + 'data': [ + 'security/ir.model.access.csv', + 'views/stock_move_views.xml', + 'wizard/lots_attachment_view_form.xml' + ], + 'assets': { + 'web.assets_backend': [ + 'import_lots/static/src/*.js', + ], + }, + 'images': ['static/description/banner.jpg'], + 'license': 'LGPL-3', + 'installable': True, + 'auto-install': False, + 'application': False, +} diff --git a/import_lots/controllers/__init__.py b/import_lots/controllers/__init__.py new file mode 100644 index 000000000..d347e7229 --- /dev/null +++ b/import_lots/controllers/__init__.py @@ -0,0 +1,22 @@ +# -*- coding: utf-8 -*- +############################################################################### +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2024-TODAY Cybrosys Technologies() +# 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 . +# +############################################################################### +from . import import_lots diff --git a/import_lots/controllers/import_lots.py b/import_lots/controllers/import_lots.py new file mode 100644 index 000000000..2a7a04a7d --- /dev/null +++ b/import_lots/controllers/import_lots.py @@ -0,0 +1,57 @@ +# -*- coding: utf-8 -*- +############################################################################### +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2024-TODAY Cybrosys Technologies() +# 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 . +# +############################################################################### +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') diff --git a/import_lots/doc/RELEASE_NOTES.md b/import_lots/doc/RELEASE_NOTES.md new file mode 100644 index 000000000..c91a1ac88 --- /dev/null +++ b/import_lots/doc/RELEASE_NOTES.md @@ -0,0 +1,6 @@ +## Module + +#### 31.05.2024 +#### Version 17.0.1.0.0 +#### ADD +- Initial commit for Import Lot from Excel diff --git a/import_lots/models/__init__.py b/import_lots/models/__init__.py new file mode 100644 index 000000000..c70288c91 --- /dev/null +++ b/import_lots/models/__init__.py @@ -0,0 +1,22 @@ +# -*- coding: utf-8 -*- +############################################################################### +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2024-TODAY Cybrosys Technologies() +# 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 . +# +############################################################################### +from . import stock_move diff --git a/import_lots/models/stock_move.py b/import_lots/models/stock_move.py new file mode 100644 index 000000000..c9373a1f8 --- /dev/null +++ b/import_lots/models/stock_move.py @@ -0,0 +1,54 @@ +# -*- coding: utf-8 -*- +############################################################################### +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2024-TODAY Cybrosys Technologies() +# 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 . +# +############################################################################### +from odoo import fields, models +import openpyxl +import base64 +from io import BytesIO + + +class StockMove(models.Model): + """Inheriting stock_move to add additional new field and function""" + _inherit = 'stock.move' + + attachment = fields.Binary(string="Upload") + + def action_import_lot(self): + """Import and write lots to stock_move_line""" + vals_list = [] + wb = openpyxl.load_workbook( + filename=BytesIO(base64.b64decode(self.attachment)), + read_only=True) + ws = wb.active + for record in ws.iter_rows(min_row=2, max_row=None, + min_col=None, + max_col=None, values_only=True): + if record[1] == self.product_id.display_name: + vals_list.append((0, 0, { + 'lot_name': record[0], + 'quantity': record[2], + 'product_id': self.product_id.id + })) + continue + self.move_line_ids.unlink() + self.write({ + 'move_line_ids': vals_list + }) diff --git a/import_lots/security/ir.model.access.csv b/import_lots/security/ir.model.access.csv new file mode 100644 index 000000000..4fe2259d8 --- /dev/null +++ b/import_lots/security/ir.model.access.csv @@ -0,0 +1,2 @@ +id,name,model_id/id,group_id/id,perm_read,perm_write,perm_create,perm_unlink +access_lot_attachment,access.lot.attachment,model_lot_attachment,base.group_user,1,1,1,1 diff --git a/import_lots/static/description/assets/icons/capture (1).png b/import_lots/static/description/assets/icons/capture (1).png new file mode 100644 index 000000000..8824deafc Binary files /dev/null and b/import_lots/static/description/assets/icons/capture (1).png differ diff --git a/import_lots/static/description/assets/icons/check.png b/import_lots/static/description/assets/icons/check.png new file mode 100644 index 000000000..c8e85f51d Binary files /dev/null and b/import_lots/static/description/assets/icons/check.png differ diff --git a/import_lots/static/description/assets/icons/chevron.png b/import_lots/static/description/assets/icons/chevron.png new file mode 100644 index 000000000..2089293d6 Binary files /dev/null and b/import_lots/static/description/assets/icons/chevron.png differ diff --git a/import_lots/static/description/assets/icons/cogs.png b/import_lots/static/description/assets/icons/cogs.png new file mode 100644 index 000000000..95d0bad62 Binary files /dev/null and b/import_lots/static/description/assets/icons/cogs.png differ diff --git a/import_lots/static/description/assets/icons/consultation.png b/import_lots/static/description/assets/icons/consultation.png new file mode 100644 index 000000000..8319d4baa Binary files /dev/null and b/import_lots/static/description/assets/icons/consultation.png differ diff --git a/import_lots/static/description/assets/icons/ecom-black.png b/import_lots/static/description/assets/icons/ecom-black.png new file mode 100644 index 000000000..a9385ff13 Binary files /dev/null and b/import_lots/static/description/assets/icons/ecom-black.png differ diff --git a/import_lots/static/description/assets/icons/education-black.png b/import_lots/static/description/assets/icons/education-black.png new file mode 100644 index 000000000..3eb09b27b Binary files /dev/null and b/import_lots/static/description/assets/icons/education-black.png differ diff --git a/import_lots/static/description/assets/icons/hotel-black.png b/import_lots/static/description/assets/icons/hotel-black.png new file mode 100644 index 000000000..130f613be Binary files /dev/null and b/import_lots/static/description/assets/icons/hotel-black.png differ diff --git a/import_lots/static/description/assets/icons/img.png b/import_lots/static/description/assets/icons/img.png new file mode 100644 index 000000000..70197f477 Binary files /dev/null and b/import_lots/static/description/assets/icons/img.png differ diff --git a/import_lots/static/description/assets/icons/license.png b/import_lots/static/description/assets/icons/license.png new file mode 100644 index 000000000..a5869797e Binary files /dev/null and b/import_lots/static/description/assets/icons/license.png differ diff --git a/import_lots/static/description/assets/icons/lifebuoy.png b/import_lots/static/description/assets/icons/lifebuoy.png new file mode 100644 index 000000000..658d56ccc Binary files /dev/null and b/import_lots/static/description/assets/icons/lifebuoy.png differ diff --git a/import_lots/static/description/assets/icons/manufacturing-black.png b/import_lots/static/description/assets/icons/manufacturing-black.png new file mode 100644 index 000000000..697eb0e9f Binary files /dev/null and b/import_lots/static/description/assets/icons/manufacturing-black.png differ diff --git a/import_lots/static/description/assets/icons/photo-capture.png b/import_lots/static/description/assets/icons/photo-capture.png new file mode 100644 index 000000000..06c111758 Binary files /dev/null and b/import_lots/static/description/assets/icons/photo-capture.png differ diff --git a/import_lots/static/description/assets/icons/pos-black.png b/import_lots/static/description/assets/icons/pos-black.png new file mode 100644 index 000000000..97c0f90c1 Binary files /dev/null and b/import_lots/static/description/assets/icons/pos-black.png differ diff --git a/import_lots/static/description/assets/icons/puzzle.png b/import_lots/static/description/assets/icons/puzzle.png new file mode 100644 index 000000000..65cf854e7 Binary files /dev/null and b/import_lots/static/description/assets/icons/puzzle.png differ diff --git a/import_lots/static/description/assets/icons/restaurant-black.png b/import_lots/static/description/assets/icons/restaurant-black.png new file mode 100644 index 000000000..4a35eb939 Binary files /dev/null and b/import_lots/static/description/assets/icons/restaurant-black.png differ diff --git a/import_lots/static/description/assets/icons/service-black.png b/import_lots/static/description/assets/icons/service-black.png new file mode 100644 index 000000000..301ab51cb Binary files /dev/null and b/import_lots/static/description/assets/icons/service-black.png differ diff --git a/import_lots/static/description/assets/icons/trading-black.png b/import_lots/static/description/assets/icons/trading-black.png new file mode 100644 index 000000000..9398ba2f1 Binary files /dev/null and b/import_lots/static/description/assets/icons/trading-black.png differ diff --git a/import_lots/static/description/assets/icons/training.png b/import_lots/static/description/assets/icons/training.png new file mode 100644 index 000000000..884ca024d Binary files /dev/null and b/import_lots/static/description/assets/icons/training.png differ diff --git a/import_lots/static/description/assets/icons/update.png b/import_lots/static/description/assets/icons/update.png new file mode 100644 index 000000000..ecbc5a01a Binary files /dev/null and b/import_lots/static/description/assets/icons/update.png differ diff --git a/import_lots/static/description/assets/icons/user.png b/import_lots/static/description/assets/icons/user.png new file mode 100644 index 000000000..6ffb23d9f Binary files /dev/null and b/import_lots/static/description/assets/icons/user.png differ diff --git a/import_lots/static/description/assets/icons/wrench.png b/import_lots/static/description/assets/icons/wrench.png new file mode 100644 index 000000000..6c04dea0f Binary files /dev/null and b/import_lots/static/description/assets/icons/wrench.png differ diff --git a/import_lots/static/description/assets/misc/Cybrosys R.png b/import_lots/static/description/assets/misc/Cybrosys R.png new file mode 100644 index 000000000..da4058087 Binary files /dev/null and b/import_lots/static/description/assets/misc/Cybrosys R.png differ diff --git a/import_lots/static/description/assets/misc/categories.png b/import_lots/static/description/assets/misc/categories.png new file mode 100644 index 000000000..bedf1e0b1 Binary files /dev/null and b/import_lots/static/description/assets/misc/categories.png differ diff --git a/import_lots/static/description/assets/misc/check-box.png b/import_lots/static/description/assets/misc/check-box.png new file mode 100644 index 000000000..42caf24b9 Binary files /dev/null and b/import_lots/static/description/assets/misc/check-box.png differ diff --git a/import_lots/static/description/assets/misc/compass.png b/import_lots/static/description/assets/misc/compass.png new file mode 100644 index 000000000..d5fed8faa Binary files /dev/null and b/import_lots/static/description/assets/misc/compass.png differ diff --git a/import_lots/static/description/assets/misc/corporate.png b/import_lots/static/description/assets/misc/corporate.png new file mode 100644 index 000000000..2eb13edbf Binary files /dev/null and b/import_lots/static/description/assets/misc/corporate.png differ diff --git a/import_lots/static/description/assets/misc/customer-support.png b/import_lots/static/description/assets/misc/customer-support.png new file mode 100644 index 000000000..79efc72ed Binary files /dev/null and b/import_lots/static/description/assets/misc/customer-support.png differ diff --git a/import_lots/static/description/assets/misc/cybrosys-logo.png b/import_lots/static/description/assets/misc/cybrosys-logo.png new file mode 100644 index 000000000..cc3cc0ccf Binary files /dev/null and b/import_lots/static/description/assets/misc/cybrosys-logo.png differ diff --git a/import_lots/static/description/assets/misc/email.svg b/import_lots/static/description/assets/misc/email.svg new file mode 100644 index 000000000..15291cdc3 --- /dev/null +++ b/import_lots/static/description/assets/misc/email.svg @@ -0,0 +1,33 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/import_lots/static/description/assets/misc/features.png b/import_lots/static/description/assets/misc/features.png new file mode 100644 index 000000000..b41769f77 Binary files /dev/null and b/import_lots/static/description/assets/misc/features.png differ diff --git a/import_lots/static/description/assets/misc/logo.png b/import_lots/static/description/assets/misc/logo.png new file mode 100644 index 000000000..478462d3e Binary files /dev/null and b/import_lots/static/description/assets/misc/logo.png differ diff --git a/import_lots/static/description/assets/misc/phone.svg b/import_lots/static/description/assets/misc/phone.svg new file mode 100644 index 000000000..b7bd7f251 --- /dev/null +++ b/import_lots/static/description/assets/misc/phone.svg @@ -0,0 +1,3 @@ + + + diff --git a/import_lots/static/description/assets/misc/pictures.png b/import_lots/static/description/assets/misc/pictures.png new file mode 100644 index 000000000..56d255fe9 Binary files /dev/null and b/import_lots/static/description/assets/misc/pictures.png differ diff --git a/import_lots/static/description/assets/misc/pie-chart.png b/import_lots/static/description/assets/misc/pie-chart.png new file mode 100644 index 000000000..426e05244 Binary files /dev/null and b/import_lots/static/description/assets/misc/pie-chart.png differ diff --git a/import_lots/static/description/assets/misc/right-arrow.png b/import_lots/static/description/assets/misc/right-arrow.png new file mode 100644 index 000000000..730984a06 Binary files /dev/null and b/import_lots/static/description/assets/misc/right-arrow.png differ diff --git a/import_lots/static/description/assets/misc/star (1) 2.svg b/import_lots/static/description/assets/misc/star (1) 2.svg new file mode 100644 index 000000000..5ae9f507a --- /dev/null +++ b/import_lots/static/description/assets/misc/star (1) 2.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/import_lots/static/description/assets/misc/star.png b/import_lots/static/description/assets/misc/star.png new file mode 100644 index 000000000..2eb9ab29f Binary files /dev/null and b/import_lots/static/description/assets/misc/star.png differ diff --git a/import_lots/static/description/assets/misc/support (1) 1.svg b/import_lots/static/description/assets/misc/support (1) 1.svg new file mode 100644 index 000000000..7d37a8f30 --- /dev/null +++ b/import_lots/static/description/assets/misc/support (1) 1.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/import_lots/static/description/assets/misc/support-email.svg b/import_lots/static/description/assets/misc/support-email.svg new file mode 100644 index 000000000..eb70370d6 --- /dev/null +++ b/import_lots/static/description/assets/misc/support-email.svg @@ -0,0 +1,6 @@ + + + + + + diff --git a/import_lots/static/description/assets/misc/support.png b/import_lots/static/description/assets/misc/support.png new file mode 100644 index 000000000..4f18b8b82 Binary files /dev/null and b/import_lots/static/description/assets/misc/support.png differ diff --git a/import_lots/static/description/assets/misc/tick-mark.svg b/import_lots/static/description/assets/misc/tick-mark.svg new file mode 100644 index 000000000..2dbb40187 --- /dev/null +++ b/import_lots/static/description/assets/misc/tick-mark.svg @@ -0,0 +1,17 @@ + + + + + + + + + + + + + + + + + diff --git a/import_lots/static/description/assets/misc/whatsapp 1.svg b/import_lots/static/description/assets/misc/whatsapp 1.svg new file mode 100644 index 000000000..0bfaf8fc6 --- /dev/null +++ b/import_lots/static/description/assets/misc/whatsapp 1.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/import_lots/static/description/assets/misc/whatsapp.png b/import_lots/static/description/assets/misc/whatsapp.png new file mode 100644 index 000000000..d513a5356 Binary files /dev/null and b/import_lots/static/description/assets/misc/whatsapp.png differ diff --git a/import_lots/static/description/assets/misc/whatsapp.svg b/import_lots/static/description/assets/misc/whatsapp.svg new file mode 100644 index 000000000..b618aea1d --- /dev/null +++ b/import_lots/static/description/assets/misc/whatsapp.svg @@ -0,0 +1,33 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/import_lots/static/description/assets/modules/1.gif b/import_lots/static/description/assets/modules/1.gif new file mode 100644 index 000000000..8ac32db03 Binary files /dev/null and b/import_lots/static/description/assets/modules/1.gif differ diff --git a/import_lots/static/description/assets/modules/1.png b/import_lots/static/description/assets/modules/1.png new file mode 100644 index 000000000..3bedf7981 Binary files /dev/null and b/import_lots/static/description/assets/modules/1.png differ diff --git a/import_lots/static/description/assets/modules/2.jpg b/import_lots/static/description/assets/modules/2.jpg new file mode 100644 index 000000000..a1dc39c89 Binary files /dev/null and b/import_lots/static/description/assets/modules/2.jpg differ diff --git a/import_lots/static/description/assets/modules/2.png b/import_lots/static/description/assets/modules/2.png new file mode 100644 index 000000000..2c8fbb83f Binary files /dev/null and b/import_lots/static/description/assets/modules/2.png differ diff --git a/import_lots/static/description/assets/modules/3.png b/import_lots/static/description/assets/modules/3.png new file mode 100644 index 000000000..25ed3e0b6 Binary files /dev/null and b/import_lots/static/description/assets/modules/3.png differ diff --git a/import_lots/static/description/assets/modules/4.png b/import_lots/static/description/assets/modules/4.png new file mode 100644 index 000000000..bc5648b1a Binary files /dev/null and b/import_lots/static/description/assets/modules/4.png differ diff --git a/import_lots/static/description/assets/modules/5.png b/import_lots/static/description/assets/modules/5.png new file mode 100644 index 000000000..7cc3625c7 Binary files /dev/null and b/import_lots/static/description/assets/modules/5.png differ diff --git a/import_lots/static/description/assets/modules/6.png b/import_lots/static/description/assets/modules/6.png new file mode 100644 index 000000000..745d6db78 Binary files /dev/null and b/import_lots/static/description/assets/modules/6.png differ diff --git a/import_lots/static/description/assets/modules/banner.jpg b/import_lots/static/description/assets/modules/banner.jpg new file mode 100644 index 000000000..67c7f7062 Binary files /dev/null and b/import_lots/static/description/assets/modules/banner.jpg differ diff --git a/import_lots/static/description/assets/screenshots/hero.gif b/import_lots/static/description/assets/screenshots/hero.gif new file mode 100644 index 000000000..d684f33de Binary files /dev/null and b/import_lots/static/description/assets/screenshots/hero.gif differ diff --git a/import_lots/static/description/assets/screenshots/scrn_001.png b/import_lots/static/description/assets/screenshots/scrn_001.png new file mode 100644 index 000000000..1946ddf6a Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_001.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_002.png b/import_lots/static/description/assets/screenshots/scrn_002.png new file mode 100644 index 000000000..2bab44a37 Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_002.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_003.png b/import_lots/static/description/assets/screenshots/scrn_003.png new file mode 100644 index 000000000..6ec834c9a Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_003.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_004.png b/import_lots/static/description/assets/screenshots/scrn_004.png new file mode 100644 index 000000000..6c83ec932 Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_004.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_005.png b/import_lots/static/description/assets/screenshots/scrn_005.png new file mode 100644 index 000000000..420dd1878 Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_005.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_006.png b/import_lots/static/description/assets/screenshots/scrn_006.png new file mode 100644 index 000000000..688e2465c Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_006.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_007.png b/import_lots/static/description/assets/screenshots/scrn_007.png new file mode 100644 index 000000000..2f0df82b9 Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_007.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_008.png b/import_lots/static/description/assets/screenshots/scrn_008.png new file mode 100644 index 000000000..b83e5719c Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_008.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_009.png b/import_lots/static/description/assets/screenshots/scrn_009.png new file mode 100644 index 000000000..ecaba6062 Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_009.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_010.png b/import_lots/static/description/assets/screenshots/scrn_010.png new file mode 100644 index 000000000..0f0081a62 Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_010.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_011.png b/import_lots/static/description/assets/screenshots/scrn_011.png new file mode 100644 index 000000000..2d3279109 Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_011.png differ diff --git a/import_lots/static/description/assets/screenshots/scrn_012.png b/import_lots/static/description/assets/screenshots/scrn_012.png new file mode 100644 index 000000000..feff908e3 Binary files /dev/null and b/import_lots/static/description/assets/screenshots/scrn_012.png differ diff --git a/import_lots/static/description/banner.jpg b/import_lots/static/description/banner.jpg new file mode 100644 index 000000000..90cf0e1b6 Binary files /dev/null and b/import_lots/static/description/banner.jpg differ diff --git a/import_lots/static/description/icon.png b/import_lots/static/description/icon.png new file mode 100644 index 000000000..8c4259eab Binary files /dev/null and b/import_lots/static/description/icon.png differ diff --git a/import_lots/static/description/index.html b/import_lots/static/description/index.html new file mode 100644 index 000000000..7c36c682b --- /dev/null +++ b/import_lots/static/description/index.html @@ -0,0 +1,816 @@ + + + + + + + Odoo App 3 Index + + + + + + + + +
+
+
+
+
+ +
+
+
+ Community +
+
+ Enterprise +
+
+
+
+
+
+

+ Import Lot from Excel

+

+ Module Helps to Import Lots From Excel Sheet to Stock Move Line. +

+
+ +
+
+
+
+
+

+ Key Highlights +

+
+
+
+
+
+ +
+
+

+ Import Lots From Excel Sheet.

+
+
+
+
+
+
+ +
+
+

+ Total Quantity Validation.

+
+
+
+
+
+
+ +
+
+

+ Same Lot Name Validation

+
+
+
+
+
+
+ +
+
+

+ Supports Community and Enterprise.

+
+
+
+
+
+
+ +
+
+
+
+
+ +
+
+

+ Enable 'Lots & Serial Numbers'

+

+ Enable lots option under inventory from res_config_settings .

+
+
+
+
+
+
+ +
+
+

+ Change Product Tracking

+

+ Choose/Create a product with tracking by lots.

+
+
+
+
+
+
+ +
+
+

+ Create a Picking

+

+ Create a new picking for the corresponding product with the operation type set to 'Receipt'.

+
+
+
+
+
+
+ +
+
+

+ Click on The Button to Add Lots.

+
+
+
+
+
+
+ +
+
+

+ Click on The Button 'Import Lots from Sheet'.

+
+
+
+
+
+
+ +
+
+

+ Click on 'Download Sample File' to Download a Sample Excel Sheet.

+
+
+
+
+
+
+ +
+
+

+ Downloaded Sample File.

+

+ User can edit/refer the sample sheet to import the lot(Use the same headers)

+
+
+
+
+
+
+ + +
+
+

+ Upload an Excel Sheet.

+
+
+
+
+
+
+ + + +
+
+

+ Click on 'Import' to Import Lots.

+
+
+
+
+
+
+
    +
  • + Import Lots From Excel Sheet. +
  • +
  • + Total Quantity and Lot Name Validation + +
  • +
  • + + Supports Community and Enterprise. +
  • +
+
+
+
+
+
+
Version + 17.0.1.0.0|Released on:20th May 2024 +
+

+ + Initial Commit for Cancel Manufacturing Order.

+
+
+
+
+
+
+
+

+ Related Products

+
+
+ +
+
+

+ Our Services

+ +
+
+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Customization

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Implementation

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Support

+
+
+
+
+
+
+ service-icon +
+
+

Hire + Odoo Developer

+
+
+
+
+ +
+
+ service-icon +
+
+

Odoo + Integration

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Migration

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Consultancy

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Implementation

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Licensing Consultancy

+
+
+
+
+
+
+

+ Our Industries

+ +
+
+
+
+
+
+ +

Trading

+

Easily procure and sell your products

+
+
+
+
+ +

POS

+

Easy configuration and convivial experience

+
+
+
+
+ +

+ Education

+

A platform for educational management

+
+
+
+
+ +

+ Manufacturing

+

Plan, track and schedule your operations

+
+
+
+
+ +

E-commerce & + Website

+

Mobile friendly, awe-inspiring product pages

+
+
+
+
+ +

Service + Management

+

Keep track of services and invoice

+
+
+
+
+ +

+ Restaurant

+

Run your bar or restaurant methodically

+
+
+
+
+ +

Hotel + Management

+

An all-inclusive hotel management application

+
+
+
+
+
+
+

+ Support

+
+
+
+
+
+
+
+ +
+ Need + Help? +

Got + questions or need help? Get in touch.

+
odoo@cybrosys.com +
+
+
+
+
+
+
+
+ +
+ WhatsApp +

Say hi to + us on WhatsApp!

+
+91 + 99456767686 +
+
+
+
+
+
+
+
+
+ + + + + + diff --git a/import_lots/static/src/import_lots.js b/import_lots/static/src/import_lots.js new file mode 100644 index 000000000..fac539951 --- /dev/null +++ b/import_lots/static/src/import_lots.js @@ -0,0 +1,38 @@ +/** @odoo-module **/ +import { Dialog } from '@web/core/dialog/dialog'; +import { useService } from "@web/core/utils/hooks"; +import { registry } from "@web/core/registry"; +import { Component, xml } from "@odoo/owl"; + +/** + * Extended and added new widget to the registry + */ +class ImportLots extends Component { + static template = xml``; + setup(){ + this.action = useService("action"); + this.orm = useService("orm"); + } + get isVisible() { + return this.props.record.data.state !== 'done'; + } + openDialog(ev){ + this.action.doAction({ + type: 'ir.actions.act_window', + name: 'Import Lots', + res_model: 'lot.attachment', + view_mode: 'form', + views: [ + [false, 'form'] + ], + target: 'new', + context:{ + default_product_id: this.props.record.data.product_id[0], + default_demanded_quantity: this.props.record.data.product_uom_qty, + default_picking_id: this.props.record.data.picking_id[0], + default_move_id: this.props.record.data.move_line_ids._config.context.default_move_id + } + }) + } +} +registry.category("view_widgets").add("import_lot", {component: ImportLots}); diff --git a/import_lots/views/stock_move_views.xml b/import_lots/views/stock_move_views.xml new file mode 100644 index 000000000..52a9e45bc --- /dev/null +++ b/import_lots/views/stock_move_views.xml @@ -0,0 +1,14 @@ + + + + + stock.move.view.form.inherit.import.lot + stock.move + + + + + + + + diff --git a/import_lots/wizard/__init__.py b/import_lots/wizard/__init__.py new file mode 100644 index 000000000..a7f2d1ac1 --- /dev/null +++ b/import_lots/wizard/__init__.py @@ -0,0 +1,22 @@ +# -*- coding: utf-8 -*- +############################################################################### +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2024-TODAY Cybrosys Technologies() +# 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 . +# +############################################################################### +from . import lots_attachment diff --git a/import_lots/wizard/lots_attachment.py b/import_lots/wizard/lots_attachment.py new file mode 100644 index 000000000..f8f991507 --- /dev/null +++ b/import_lots/wizard/lots_attachment.py @@ -0,0 +1,116 @@ +# -*- coding: utf-8 -*- +############################################################################### +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2024-TODAY Cybrosys Technologies() +# 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 . +# +############################################################################### +from odoo import fields, models +from odoo import _ +from odoo.exceptions import UserError +import openpyxl +import base64 +from io import BytesIO + + +class LotsAttachment(models.TransientModel): + """Class for lots wizard""" + + _name = 'lot.attachment' + _description = "Lots Attachment" + + picking_id = fields.Many2one('stock.picking', + string="Stock Picking", + help="Parent picking") + product_id = fields.Many2one('product.product', + string="Product", + help="Current product") + demanded_quantity = fields.Float(string="Quantity", + help="Product quantity demanded") + type = fields.Selection(string="Lots Type", + selection=[('lot', 'Lot'), ('serial', 'Serial')], + help="Choose a lot/serial") + move_id = fields.Many2one('stock.move') + attachment = fields.Binary(string="Upload", attachment=True) + attachment_name = fields.Char(string="Attachment Name", + help="Attachment" + "file name") + + def action_import_lot(self): + """Importing lots""" + current_move_id = self.env['stock.move'].browse(self.move_id.id) + if self.attachment: + wb = openpyxl.load_workbook( + filename=BytesIO(base64.b64decode(self.attachment)), + read_only=True) if self.attachment else "" + ws = wb.active + # Check if product exists in the sheet + product_found = any( + record[1] == current_move_id.product_id.display_name for + record in ws.iter_rows(min_row=2, values_only=True)) + if not product_found: + raise UserError( + _('The product "%s" does not exist in the sheet.') % + current_move_id.product_id.display_name) + # Check if lot name already exists in move line ids + if current_move_id.move_line_ids and any(record[0] in set( + current_move_id.move_line_ids.mapped('lot_name')) for + record in + ws.iter_rows(min_row=2, + values_only= + True) + ): + raise UserError( + _('This Lot name already exists in the move line.')) + # Calculate total sheet quantity for the product + total_sheet_quantity = sum( + record[2] for record in ws.iter_rows + (min_row=2, values_only=True) if + record[1] == current_move_id.product_id.display_name) + # Check if total sheet quantity exceeds demand quantity of the + # product + if total_sheet_quantity > current_move_id.product_uom_qty: + raise UserError( + _('Total quantity in the sheet exceeds the demand ' + 'quantity of the product. Please adjust the quantities ' + 'in the sheet.')) + # Prepare move line values to be written + vals_list = [] + for record in ws.iter_rows(min_row=2, values_only=True): + lot_name, product_name, quantity = record + if product_name == current_move_id.product_id.display_name: + vals_list.append((0, 0, { + 'lot_name': lot_name, + 'quantity': min(quantity, current_move_id.product_qty), + 'move_id': current_move_id.id, + })) + # Write move line values + current_move_id.move_line_ids.unlink() + current_move_id.write({'move_line_ids': vals_list}) + return { + 'type': 'ir.actions.client', + 'tag': 'reload', + } + + def action_download_sample(self): + """For downloading a sample excel file""" + return { + 'type': 'ir.actions.act_url', + 'url': '/download/excel', + 'target': 'self', + 'file_name': 'my_excel_file.xlsx' + } diff --git a/import_lots/wizard/lots_attachment_view_form.xml b/import_lots/wizard/lots_attachment_view_form.xml new file mode 100644 index 000000000..f0dce5731 --- /dev/null +++ b/import_lots/wizard/lots_attachment_view_form.xml @@ -0,0 +1,28 @@ + + + + + lot.attachment.view.form + lot.attachment + +
+ + + + + + + + + +
+
+
+