diff --git a/setup/stock_request_picking_type/odoo/addons/stock_request_picking_type b/setup/stock_request_picking_type/odoo/addons/stock_request_picking_type new file mode 120000 index 000000000..8155692d1 --- /dev/null +++ b/setup/stock_request_picking_type/odoo/addons/stock_request_picking_type @@ -0,0 +1 @@ +../../../../stock_request_picking_type \ No newline at end of file diff --git a/setup/stock_request_picking_type/setup.py b/setup/stock_request_picking_type/setup.py new file mode 100644 index 000000000..28c57bb64 --- /dev/null +++ b/setup/stock_request_picking_type/setup.py @@ -0,0 +1,6 @@ +import setuptools + +setuptools.setup( + setup_requires=['setuptools-odoo'], + odoo_addon=True, +) diff --git a/stock_request_picking_type/README.rst b/stock_request_picking_type/README.rst new file mode 100644 index 000000000..2fee16100 --- /dev/null +++ b/stock_request_picking_type/README.rst @@ -0,0 +1,91 @@ +========================== +Stock Request Picking Type +========================== + +.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png + :target: https://odoo-community.org/page/development-status + :alt: Beta +.. |badge2| image:: https://img.shields.io/badge/licence-LGPL--3-blue.png + :target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html + :alt: License: LGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fstock--logistics--warehouse-lightgray.png?logo=github + :target: https://github.com/OCA/stock-logistics-warehouse/tree/13.0/stock_request_picking_type + :alt: OCA/stock-logistics-warehouse +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/stock-logistics-warehouse-13-0/stock-logistics-warehouse-13-0-stock_request_picking_type + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png + :target: https://runbot.odoo-community.org/runbot/153/13.0 + :alt: Try me on Runbot + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module adds stock request orders within the Inventory app with a new operation type. + +**Table of contents** + +.. contents:: + :local: + +Usage +===== + +* Go to Inventory +* Click on the Stock Request Orders tile to process stock requests +* You can also go to Inventory > Operations > Stock Request Orders + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues `_. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us smashing it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +~~~~~~~ + +* Open Source Integrators + +Contributors +~~~~~~~~~~~~ + +* Maxime Chambreuil +* Pimolnat Suntian +* Raphael Lee +* Reed Hayashikawa + +Maintainers +~~~~~~~~~~~ + +This module is maintained by the OCA. + +.. image:: https://odoo-community.org/logo.png + :alt: Odoo Community Association + :target: https://odoo-community.org + +OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use. + +.. |maintainer-max3903| image:: https://github.com/max3903.png?size=40px + :target: https://github.com/max3903 + :alt: max3903 + +Current `maintainer `__: + +|maintainer-max3903| + +This module is part of the `OCA/stock-logistics-warehouse `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/stock_request_picking_type/__init__.py b/stock_request_picking_type/__init__.py new file mode 100644 index 000000000..dbf87a2fe --- /dev/null +++ b/stock_request_picking_type/__init__.py @@ -0,0 +1,4 @@ +# Copyright 2019 Open Source Integrators +# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html). + +from . import models diff --git a/stock_request_picking_type/__manifest__.py b/stock_request_picking_type/__manifest__.py new file mode 100644 index 000000000..e85d602fb --- /dev/null +++ b/stock_request_picking_type/__manifest__.py @@ -0,0 +1,20 @@ +# Copyright 2019 Open Source Integrators +# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html). + +{ + "name": "Stock Request Picking Type", + "summary": "Add Stock Requests to the Inventory App", + "version": "14.0.1.0.0", + "license": "LGPL-3", + "website": "https://github.com/OCA/stock-logistics-warehouse", + "author": "Open Source Integrators, Odoo Community Association (OCA)", + "category": "Warehouse", + "depends": ["stock_request"], + "data": [ + "data/stock_picking_type.xml", + "views/stock_request_order_views.xml", + "views/stock_picking_views.xml", + ], + "development_status": "Beta", + "maintainers": ["max3903"], +} diff --git a/stock_request_picking_type/data/stock_picking_type.xml b/stock_request_picking_type/data/stock_picking_type.xml new file mode 100644 index 000000000..136e087d2 --- /dev/null +++ b/stock_request_picking_type/data/stock_picking_type.xml @@ -0,0 +1,8 @@ + + + Stock Requests + + stock_request_order + SRO + + diff --git a/stock_request_picking_type/i18n/es.po b/stock_request_picking_type/i18n/es.po new file mode 100644 index 000000000..1512248f6 --- /dev/null +++ b/stock_request_picking_type/i18n/es.po @@ -0,0 +1,145 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * stock_request_picking_type +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2020-01-17 05:13+0000\n" +"Last-Translator: Nelson Ramírez Sánchez \n" +"Language-Team: none\n" +"Language: es\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 3.10\n" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "" +"" +msgstr "" +"" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "New" +msgstr "Nuevo" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "View" +msgstr "Ver" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "All" +msgstr "Todo" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Done" +msgstr "Hecho" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_open +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "In Progress" +msgstr "En Progreso" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_late +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Late" +msgstr "Tarde" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_request_order__picking_type_id +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_order_search +msgid "Operation Type" +msgstr "Tipo de Operación" + +#. module: stock_request_picking_type +#: model:ir.model,name:stock_request_picking_type.model_stock_picking_type +msgid "Picking Type" +msgstr "Tipo de Picking" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Settings" +msgstr "Configuración" + +#. module: stock_request_picking_type +#: model:ir.model,name:stock_request_picking_type.model_stock_request_order +#: model:ir.model.fields.selection,name:stock_request_picking_type.selection__stock_picking_type__code__stock_request_order +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Stock Request Order" +msgstr "Pedido de Solicitud de Stock" + +#. module: stock_request_picking_type +#: model:ir.actions.act_window,name:stock_request_picking_type.action_picking_dashboard +#: model:ir.actions.act_window,name:stock_request_picking_type.action_stock_request_order_form +#: model:ir.ui.menu,name:stock_request_picking_type.menu_stock_request_order +msgid "Stock Request Orders" +msgstr "Pedidos de Solicitud de Stock" + +#. module: stock_request_picking_type +#: model:stock.picking.type,name:stock_request_picking_type.stock_request_order +msgid "Stock Requests" +msgstr "Solicitudes de Stock" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_todo +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "To Do" +msgstr "Por Hacer" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "To Process" +msgstr "A Procesar" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__code +msgid "Type of Operation" +msgstr "Tipo de Operación" + +#~ msgid "Customers" +#~ msgstr "Clientes" + +#~ msgid "Expected Date" +#~ msgstr "Fecha Esperada" + +#~ msgid "Expected Date by Month" +#~ msgstr "Fecha Esperada por Mes" + +#~ msgid "Group By..." +#~ msgstr "Agrupar por..." + +#~ msgid "Internal" +#~ msgstr "Interno" + +#~ msgid "Late Stock Requests" +#~ msgstr "Solicitudes de Stock Tardías" + +#~ msgid "Manufacturing Operation" +#~ msgstr "Operación de Fabricación" + +#~ msgid "Search Stock Request Orders" +#~ msgstr "Buscar Pedidos de Solicitud de Stock" + +#~ msgid "State" +#~ msgstr "Estado" + +#~ msgid "Stock Requests To Do." +#~ msgstr "Solicitudes de acciones para hacer." + +#~ msgid "Stock Requests in Progress." +#~ msgstr "Solicitudes de stock en curso." + +#~ msgid "Vendors" +#~ msgstr "Proveedores" diff --git a/stock_request_picking_type/i18n/pt_BR.po b/stock_request_picking_type/i18n/pt_BR.po new file mode 100644 index 000000000..941a27a78 --- /dev/null +++ b/stock_request_picking_type/i18n/pt_BR.po @@ -0,0 +1,145 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * stock_request_picking_type +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2020-03-24 18:22+0000\n" +"Last-Translator: Marcel Savegnago \n" +"Language-Team: none\n" +"Language: pt_BR\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n > 1;\n" +"X-Generator: Weblate 3.10\n" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "" +"" +msgstr "" +"" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "New" +msgstr "Novo" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "View" +msgstr "Visualizar" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "All" +msgstr "Tudo" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Done" +msgstr "Concluído" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_open +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "In Progress" +msgstr "Em Andamento" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_late +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Late" +msgstr "Atrasado" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_request_order__picking_type_id +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_order_search +msgid "Operation Type" +msgstr "Tipo da Operação" + +#. module: stock_request_picking_type +#: model:ir.model,name:stock_request_picking_type.model_stock_picking_type +msgid "Picking Type" +msgstr "Tipo de Separação" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Settings" +msgstr "Configurações" + +#. module: stock_request_picking_type +#: model:ir.model,name:stock_request_picking_type.model_stock_request_order +#: model:ir.model.fields.selection,name:stock_request_picking_type.selection__stock_picking_type__code__stock_request_order +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Stock Request Order" +msgstr "Ordens de Requisição de Estoque" + +#. module: stock_request_picking_type +#: model:ir.actions.act_window,name:stock_request_picking_type.action_picking_dashboard +#: model:ir.actions.act_window,name:stock_request_picking_type.action_stock_request_order_form +#: model:ir.ui.menu,name:stock_request_picking_type.menu_stock_request_order +msgid "Stock Request Orders" +msgstr "Ordens de Requisição de Estoque" + +#. module: stock_request_picking_type +#: model:stock.picking.type,name:stock_request_picking_type.stock_request_order +msgid "Stock Requests" +msgstr "Requisições de Estoque" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_todo +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "To Do" +msgstr "A Fazer" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "To Process" +msgstr "Para Processar" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__code +msgid "Type of Operation" +msgstr "Tipo de Operação" + +#~ msgid "Customers" +#~ msgstr "Clientes" + +#~ msgid "Expected Date" +#~ msgstr "Data Prevista" + +#~ msgid "Expected Date by Month" +#~ msgstr "Data Prevista por Mês" + +#~ msgid "Group By..." +#~ msgstr "Agrupar por..." + +#~ msgid "Internal" +#~ msgstr "Interno" + +#~ msgid "Late Stock Requests" +#~ msgstr "Requisições de Estoque em Atrasado" + +#~ msgid "Manufacturing Operation" +#~ msgstr "Operação de Fabricação" + +#~ msgid "Search Stock Request Orders" +#~ msgstr "Pesquisar Ordens de Requisição de Estoque" + +#~ msgid "State" +#~ msgstr "Estado" + +#~ msgid "Stock Requests To Do." +#~ msgstr "Requisições de Estoque A Fazer." + +#~ msgid "Stock Requests in Progress." +#~ msgstr "Requisições de Estoque em Andamento." + +#~ msgid "Vendors" +#~ msgstr "Fornecedores" diff --git a/stock_request_picking_type/i18n/stock_request_picking_type.pot b/stock_request_picking_type/i18n/stock_request_picking_type.pot new file mode 100644 index 000000000..76f24941a --- /dev/null +++ b/stock_request_picking_type/i18n/stock_request_picking_type.pot @@ -0,0 +1,102 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * stock_request_picking_type +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 13.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: \n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "" +msgstr "" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "New" +msgstr "" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "View" +msgstr "" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "All" +msgstr "" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Done" +msgstr "" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_open +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "In Progress" +msgstr "" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_late +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Late" +msgstr "" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_request_order__picking_type_id +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_order_search +msgid "Operation Type" +msgstr "" + +#. module: stock_request_picking_type +#: model:ir.model,name:stock_request_picking_type.model_stock_picking_type +msgid "Picking Type" +msgstr "" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Settings" +msgstr "" + +#. module: stock_request_picking_type +#: model:ir.model,name:stock_request_picking_type.model_stock_request_order +#: model:ir.model.fields.selection,name:stock_request_picking_type.selection__stock_picking_type__code__stock_request_order +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Stock Request Order" +msgstr "" + +#. module: stock_request_picking_type +#: model:ir.actions.act_window,name:stock_request_picking_type.action_picking_dashboard +#: model:ir.actions.act_window,name:stock_request_picking_type.action_stock_request_order_form +#: model:ir.ui.menu,name:stock_request_picking_type.menu_stock_request_order +msgid "Stock Request Orders" +msgstr "" + +#. module: stock_request_picking_type +#: model:stock.picking.type,name:stock_request_picking_type.stock_request_order +msgid "Stock Requests" +msgstr "" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_todo +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "To Do" +msgstr "" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "To Process" +msgstr "" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__code +msgid "Type of Operation" +msgstr "" diff --git a/stock_request_picking_type/i18n/zh_CN.po b/stock_request_picking_type/i18n/zh_CN.po new file mode 100644 index 000000000..9251dd865 --- /dev/null +++ b/stock_request_picking_type/i18n/zh_CN.po @@ -0,0 +1,145 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * stock_request_picking_type +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2019-10-16 15:58+0000\n" +"Last-Translator: 黎伟杰 <674416404@qq.com>\n" +"Language-Team: none\n" +"Language: zh_CN\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" +"X-Generator: Weblate 3.8\n" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "" +"" +msgstr "" +"" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "New" +msgstr "新建" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "View" +msgstr "视图" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "All" +msgstr "所有" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Done" +msgstr "完成" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_open +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "In Progress" +msgstr "进行中" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_late +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Late" +msgstr "迟到" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_request_order__picking_type_id +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_order_search +msgid "Operation Type" +msgstr "作业类型" + +#. module: stock_request_picking_type +#: model:ir.model,name:stock_request_picking_type.model_stock_picking_type +msgid "Picking Type" +msgstr "拣货类型" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Settings" +msgstr "设置" + +#. module: stock_request_picking_type +#: model:ir.model,name:stock_request_picking_type.model_stock_request_order +#: model:ir.model.fields.selection,name:stock_request_picking_type.selection__stock_picking_type__code__stock_request_order +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "Stock Request Order" +msgstr "库存请求单" + +#. module: stock_request_picking_type +#: model:ir.actions.act_window,name:stock_request_picking_type.action_picking_dashboard +#: model:ir.actions.act_window,name:stock_request_picking_type.action_stock_request_order_form +#: model:ir.ui.menu,name:stock_request_picking_type.menu_stock_request_order +msgid "Stock Request Orders" +msgstr "库存请求单" + +#. module: stock_request_picking_type +#: model:stock.picking.type,name:stock_request_picking_type.stock_request_order +msgid "Stock Requests" +msgstr "库存请求" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__count_sr_todo +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "To Do" +msgstr "去做" + +#. module: stock_request_picking_type +#: model_terms:ir.ui.view,arch_db:stock_request_picking_type.stock_request_type_kanban +msgid "To Process" +msgstr "处理" + +#. module: stock_request_picking_type +#: model:ir.model.fields,field_description:stock_request_picking_type.field_stock_picking_type__code +msgid "Type of Operation" +msgstr "作业的类型" + +#~ msgid "Customers" +#~ msgstr "客户" + +#~ msgid "Expected Date" +#~ msgstr "预计日期" + +#~ msgid "Expected Date by Month" +#~ msgstr "每月预期日期" + +#~ msgid "Group By..." +#~ msgstr "分组..." + +#~ msgid "Internal" +#~ msgstr "内部" + +#~ msgid "Late Stock Requests" +#~ msgstr "迟到的库存请求" + +#~ msgid "Manufacturing Operation" +#~ msgstr "制造作业" + +#~ msgid "Search Stock Request Orders" +#~ msgstr "搜索库存请求单" + +#~ msgid "State" +#~ msgstr "状态" + +#~ msgid "Stock Requests To Do." +#~ msgstr "库存请求去做。" + +#~ msgid "Stock Requests in Progress." +#~ msgstr "库存请求正在进行中。" + +#~ msgid "Vendors" +#~ msgstr "供应商" diff --git a/stock_request_picking_type/migrations/12.0.2.0.0/post-migration.py b/stock_request_picking_type/migrations/12.0.2.0.0/post-migration.py new file mode 100644 index 000000000..1e5b9e6e5 --- /dev/null +++ b/stock_request_picking_type/migrations/12.0.2.0.0/post-migration.py @@ -0,0 +1,16 @@ +# Copyright (C) 2019 Open Source Integrators +# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). + + +def migrate(env, version): + if not version: + return + + env.execute( + "UPDATE stock_request_order " + "SET picking_type_id = (" + "SELECT id " + "FROM stock_picking_type " + "WHERE code = 'stock_request_order') " + "WHERE picking_type_id IS NULL;" + ) diff --git a/stock_request_picking_type/models/__init__.py b/stock_request_picking_type/models/__init__.py new file mode 100644 index 000000000..bed61e447 --- /dev/null +++ b/stock_request_picking_type/models/__init__.py @@ -0,0 +1,5 @@ +# Copyright 2019 Open Source Integrators +# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html). + +from . import stock_request_order +from . import stock_picking_type diff --git a/stock_request_picking_type/models/stock_picking_type.py b/stock_request_picking_type/models/stock_picking_type.py new file mode 100644 index 000000000..8c2f40c61 --- /dev/null +++ b/stock_request_picking_type/models/stock_picking_type.py @@ -0,0 +1,46 @@ +# Copyright 2019 Open Source Integrators +# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html). + +from odoo import fields, models + + +class StockPickingType(models.Model): + _inherit = "stock.picking.type" + + code = fields.Selection( + selection_add=[("stock_request_order", "Stock Request Order")], + ondelete={"stock_request_order": "cascade"}, + ) + count_sr_todo = fields.Integer(string="To Do", compute="_compute_sr_count") + count_sr_open = fields.Integer(string="In Progress", compute="_compute_sr_count") + count_sr_late = fields.Integer(string="Late", compute="_compute_sr_count") + + def _compute_sr_count(self): + domains = { + "count_sr_todo": [("state", "=", "submitted")], + "count_sr_open": [("state", "=", "open")], + "count_sr_late": [ + ("expected_date", "<", fields.Date.today()), + ("state", "in", ("submitted", "open")), + ], + } + for field in domains: + data = self.env["stock.request.order"].read_group( + domains[field] + + [ + ("state", "not in", ("done", "cancel")), + ("picking_type_id", "in", self.ids), + ], + ["picking_type_id"], + ["picking_type_id"], + ) + count = { + x["picking_type_id"] + and x["picking_type_id"][0]: x["picking_type_id_count"] + for x in data + } + for record in self: + record[field] = count.get(record.id, 0) + + def get_stock_request_order_picking_type_action(self): + return self._get_action("stock_request_picking_type.action_picking_dashboard") diff --git a/stock_request_picking_type/models/stock_request_order.py b/stock_request_picking_type/models/stock_request_order.py new file mode 100644 index 000000000..366ec32ff --- /dev/null +++ b/stock_request_picking_type/models/stock_request_order.py @@ -0,0 +1,60 @@ +# Copyright 2019 Open Source Integrators +# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html). + +from odoo import api, fields, models + + +class StockRequestOrder(models.Model): + _inherit = "stock.request.order" + + @api.model + def _get_default_picking_type(self): + companies = self._context.get("allowed_company_ids", []).copy() + companies.append(False) + return ( + self.env["stock.picking.type"] + .search( + [ + ("code", "=", "stock_request_order"), + "|", + ("warehouse_id.company_id", "in", companies), + ("warehouse_id", "=", False), + ], + limit=1, + ) + .id + ) + + picking_type_id = fields.Many2one( + comodel_name="stock.picking.type", + string="Operation Type", + default=_get_default_picking_type, + required=True, + ) + + @api.onchange("warehouse_id") + def onchange_warehouse_picking_id(self): + if self.warehouse_id: + picking_type_id = self.env["stock.picking.type"].search( + [ + ("code", "=", "stock_request_order"), + ("warehouse_id", "=", self.warehouse_id.id), + ], + limit=1, + ) + if picking_type_id: + self._origin.write({"picking_type_id": picking_type_id.id}) + + @api.model + def create(self, vals): + if vals.get("warehouse_id", False): + picking_type_id = self.env["stock.picking.type"].search( + [ + ("code", "=", "stock_request_order"), + ("warehouse_id", "=", vals["warehouse_id"]), + ], + limit=1, + ) + if picking_type_id: + vals.update({"picking_type_id": picking_type_id.id}) + return super().create(vals) diff --git a/stock_request_picking_type/readme/CONTRIBUTORS.rst b/stock_request_picking_type/readme/CONTRIBUTORS.rst new file mode 100644 index 000000000..e2a84a062 --- /dev/null +++ b/stock_request_picking_type/readme/CONTRIBUTORS.rst @@ -0,0 +1,3 @@ +* Maxime Chambreuil +* Pimolnat Suntian +* Raphael Lee diff --git a/stock_request_picking_type/readme/DESCRIPTION.rst b/stock_request_picking_type/readme/DESCRIPTION.rst new file mode 100644 index 000000000..0173f58f4 --- /dev/null +++ b/stock_request_picking_type/readme/DESCRIPTION.rst @@ -0,0 +1 @@ +This module adds stock request orders within the Inventory app with a new operation type. diff --git a/stock_request_picking_type/readme/USAGE.rst b/stock_request_picking_type/readme/USAGE.rst new file mode 100644 index 000000000..a2807118d --- /dev/null +++ b/stock_request_picking_type/readme/USAGE.rst @@ -0,0 +1,3 @@ +* Go to Inventory +* Click on the Stock Request Orders tile to process stock requests +* You can also go to Inventory > Operations > Stock Request Orders diff --git a/stock_request_picking_type/static/description/icon.png b/stock_request_picking_type/static/description/icon.png new file mode 100644 index 000000000..d4f6a65ac Binary files /dev/null and b/stock_request_picking_type/static/description/icon.png differ diff --git a/stock_request_picking_type/static/description/index.html b/stock_request_picking_type/static/description/index.html new file mode 100644 index 000000000..13822a105 --- /dev/null +++ b/stock_request_picking_type/static/description/index.html @@ -0,0 +1,432 @@ + + + + + + +Stock Request Picking Type + + + +
+

Stock Request Picking Type

+ + +

Beta License: LGPL-3 OCA/stock-logistics-warehouse Translate me on Weblate Try me on Runbot

+

This module adds stock request orders within the Inventory app with a new operation type.

+

Table of contents

+ +
+

Usage

+
    +
  • Go to Inventory
  • +
  • Click on the Stock Request Orders tile to process stock requests
  • +
  • You can also go to Inventory > Operations > Stock Request Orders
  • +
+
+
+

Bug Tracker

+

Bugs are tracked on GitHub Issues. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us smashing it by providing a detailed and welcomed +feedback.

+

Do not contact contributors directly about support or help with technical issues.

+
+
+

Credits

+
+

Authors

+
    +
  • Open Source Integrators
  • +
+
+ +
+

Maintainers

+

This module is maintained by the OCA.

+Odoo Community Association +

OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use.

+

Current maintainer:

+

max3903

+

This module is part of the OCA/stock-logistics-warehouse project on GitHub.

+

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

+
+
+
+ + diff --git a/stock_request_picking_type/tests/__init__.py b/stock_request_picking_type/tests/__init__.py new file mode 100644 index 000000000..c6e97bd05 --- /dev/null +++ b/stock_request_picking_type/tests/__init__.py @@ -0,0 +1,2 @@ +from . import test_stock_request +from . import test_stock_picking_type diff --git a/stock_request_picking_type/tests/test_stock_picking_type.py b/stock_request_picking_type/tests/test_stock_picking_type.py new file mode 100644 index 000000000..89813dc9f --- /dev/null +++ b/stock_request_picking_type/tests/test_stock_picking_type.py @@ -0,0 +1,154 @@ +# Copyright 2019 Open Source Integrators +# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html). + +from dateutil.relativedelta import relativedelta + +from odoo import fields +from odoo.tests import common + + +class TestStockRequest(common.TransactionCase): + def setUp(self): + super(TestStockRequest, self).setUp() + + # common models + self.stock_request = self.env["stock.request"] + self.request_order = self.env["stock.request.order"] + + # refs + self.stock_request_user_group = self.env.ref( + "stock_request.group_stock_request_user" + ) + self.stock_request_manager_group = self.env.ref( + "stock_request.group_stock_request_manager" + ) + self.main_company = self.env.ref("base.main_company") + self.warehouse = self.env.ref("stock.warehouse0") + self.categ_unit = self.env.ref("uom.product_uom_categ_unit") + self.default_picking_type = self.env.ref( + "stock_request_picking_type.stock_request_order" + ) + + self.product = self._create_product("SH", "Shoes", False) + self.stock_request_manager = self._create_user( + "stock_request_manager", + [self.stock_request_manager_group.id], + [self.main_company.id], + ) + + self.ressuply_loc = self.env["stock.location"].create( + { + "name": "Ressuply", + "location_id": self.warehouse.view_location_id.id, + "usage": "internal", + "company_id": self.main_company.id, + } + ) + + self.route = self.env["stock.location.route"].create( + { + "name": "Transfer", + "product_categ_selectable": False, + "product_selectable": True, + "company_id": self.main_company.id, + "sequence": 10, + } + ) + + self.rule = self.env["stock.rule"].create( + { + "name": "Transfer", + "route_id": self.route.id, + "location_src_id": self.ressuply_loc.id, + "location_id": self.warehouse.lot_stock_id.id, + "action": "pull", + "picking_type_id": self.warehouse.int_type_id.id, + "procure_method": "make_to_stock", + "warehouse_id": self.warehouse.id, + "company_id": self.main_company.id, + } + ) + + self.env["ir.config_parameter"].sudo().set_param( + "stock.no_auto_scheduler", "True" + ) + + def _create_user(self, name, group_ids, company_ids): + return ( + self.env["res.users"] + .with_context({"no_reset_password": True}) + .create( + { + "name": name, + "password": "demo", + "login": name, + "email": "@".join([name, "test.com"]), + "groups_id": [(6, 0, group_ids)], + "company_ids": [(6, 0, company_ids)], + } + ) + ) + + def _create_product(self, default_code, name, company_id, **vals): + return self.env["product.product"].create( + dict( + name=name, + default_code=default_code, + uom_id=self.env.ref("uom.product_uom_unit").id, + company_id=company_id, + type="product", + **vals + ) + ) + + +class TestStockPickingType(TestStockRequest): + def setUp(self): + super(TestStockPickingType, self).setUp() + + def test_compute_sr_count(self): + expected_date = fields.Datetime.now() + late_expected_date = fields.Datetime.now() - relativedelta(days=1) + order_vals = { + "company_id": self.main_company.id, + "warehouse_id": self.warehouse.id, + "location_id": self.warehouse.lot_stock_id.id, + "expected_date": expected_date, + "stock_request_ids": [ + ( + 0, + 0, + { + "product_id": self.product.id, + "product_uom_id": self.product.uom_id.id, + "product_uom_qty": 5.0, + "company_id": self.main_company.id, + "warehouse_id": self.warehouse.id, + "location_id": self.warehouse.lot_stock_id.id, + "expected_date": expected_date, + }, + ) + ], + } + + order = self.request_order.with_user(self.stock_request_manager).create( + order_vals + ) + self.product.route_ids = [(6, 0, self.route.ids)] + self.assertEqual(order.picking_type_id.count_sr_todo, 0) + self.assertEqual(order.picking_type_id.count_sr_open, 0) + self.assertEqual(order.picking_type_id.count_sr_late, 0) + + order.with_user(self.stock_request_manager).action_confirm() + order.picking_type_id.sudo()._compute_sr_count() + + # check count_sr_open + self.assertEqual(order.picking_type_id.count_sr_todo, 0) + self.assertEqual(order.picking_type_id.count_sr_open, 1) + self.assertEqual(order.picking_type_id.count_sr_late, 0) + + order.expected_date = late_expected_date + order.picking_type_id.sudo()._compute_sr_count() + self.assertEqual(order.picking_type_id.count_sr_todo, 0) + self.assertEqual(order.picking_type_id.count_sr_open, 1) + self.assertEqual(order.picking_type_id.count_sr_late, 1) diff --git a/stock_request_picking_type/tests/test_stock_request.py b/stock_request_picking_type/tests/test_stock_request.py new file mode 100644 index 000000000..88ec98347 --- /dev/null +++ b/stock_request_picking_type/tests/test_stock_request.py @@ -0,0 +1,177 @@ +# Copyright 2019 Open Source Integrators +# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html). + + +from odoo import fields +from odoo.tests import Form, common + + +class TestStockRequest(common.TransactionCase): + def setUp(self): + super(TestStockRequest, self).setUp() + + # common models + self.stock_request = self.env["stock.request"] + self.request_order = self.env["stock.request.order"] + + # refs + self.stock_request_user_group = self.env.ref( + "stock_request.group_stock_request_user" + ) + self.main_company = self.env.ref("base.main_company") + self.warehouse = self.env.ref("stock.warehouse0") + self.default_picking_type = self.env.ref( + "stock_request_picking_type.stock_request_order" + ) + + # common data + self.company_2 = self.env["res.company"].create( + {"name": "Comp2", "parent_id": self.main_company.id} + ) + self.company_2_address = ( + self.env["res.partner"] + .with_context(company_id=self.company_2.id) + .create({"name": "Peñiscola"}) + ) + self.product = self._create_product("SH", "Shoes", False) + self.product_company_2 = self._create_product( + "SH_2", "Shoes", self.company_2.id + ) + self.stock_request_user = self._create_user( + "stock_request_user", + [self.stock_request_user_group.id], + [self.main_company.id, self.company_2.id], + ) + + def _create_user(self, name, group_ids, company_ids): + return ( + self.env["res.users"] + .with_context({"no_reset_password": True}) + .create( + { + "name": name, + "password": "demo", + "login": name, + "email": "@".join([name, "test.com"]), + "groups_id": [(6, 0, group_ids)], + "company_ids": [(6, 0, company_ids)], + } + ) + ) + + def _create_product(self, default_code, name, company_id, **vals): + return self.env["product.product"].create( + dict( + name=name, + default_code=default_code, + uom_id=self.env.ref("uom.product_uom_unit").id, + company_id=company_id, + type="product", + **vals + ) + ) + + +class TestStockRequestOrder(TestStockRequest): + def setUp(self): + super(TestStockRequestOrder, self).setUp() + + def test_onchanges_order(self): + expected_date = fields.Datetime.now() + + wh = ( + self.env["stock.warehouse"] + .with_context(company_id=self.main_company.id) + .create( + { + "name": "Warehouse", + "code": "Warehouse", + "company_id": self.main_company.id, + "partner_id": self.main_company.id, + } + ) + ) + + new_pick_type = ( + self.env["stock.picking.type"] + .with_context(company_id=self.main_company.id) + .create( + { + "name": "Stock Request wh", + "sequence_id": self.env.ref( + "stock_request.seq_stock_request_order" + ).id, + "code": "stock_request_order", + "sequence_code": "SRO", + "warehouse_id": wh.id, + } + ) + ) + + form = Form(self.env["stock.request.order"]) + form.company_id = self.main_company + form.expected_date = expected_date + form.warehouse_id = self.warehouse + form.location_id = self.warehouse.lot_stock_id + form.save() + + # Test onchange_warehouse_picking_id + form.warehouse_id = wh + form.save() + + self.assertEqual(form.picking_type_id, new_pick_type) + + def test_create(self): + expected_date = fields.Datetime.now() + order_vals = { + "company_id": self.main_company.id, + "warehouse_id": self.warehouse.id, + "location_id": self.warehouse.lot_stock_id.id, + "expected_date": expected_date, + "stock_request_ids": [ + ( + 0, + 0, + { + "product_id": self.product.id, + "product_uom_id": self.product.uom_id.id, + "product_uom_qty": 5.0, + "company_id": self.main_company.id, + "warehouse_id": self.warehouse.id, + "location_id": self.warehouse.lot_stock_id.id, + "expected_date": expected_date, + }, + ) + ], + } + + form = Form(self.env["stock.request.order"]) + form.company_id = self.main_company + form.expected_date = expected_date + + # test _getdefault_picking_type() + self.assertEqual(form.picking_type_id, self.default_picking_type) + + form.warehouse_id = self.warehouse + form.location_id = self.warehouse.lot_stock_id + + new_pick_type = ( + self.env["stock.picking.type"] + .with_context(company_id=self.main_company.id) + .create( + { + "name": "Stock Request wh", + "sequence_id": self.env.ref( + "stock_request.seq_stock_request_order" + ).id, + "code": "stock_request_order", + "sequence_code": "SRO", + "warehouse_id": self.warehouse.id, + } + ) + ) + + order = self.request_order.with_user(self.stock_request_user).create(order_vals) + + # test create() + self.assertEqual(order.picking_type_id, new_pick_type) diff --git a/stock_request_picking_type/views/stock_picking_views.xml b/stock_request_picking_type/views/stock_picking_views.xml new file mode 100644 index 000000000..fa16ff188 --- /dev/null +++ b/stock_request_picking_type/views/stock_picking_views.xml @@ -0,0 +1,196 @@ + + + + stock.picking.type.kanban + stock.picking.type + + + + + + + + +
+
+
+
+ + + +
+ +
+
+
+ + + +
+
+
+
+
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+
+
+ +
+
+
+
+
+ + Operation Types + stock.picking.type + + + + {"invisible": [("code", "=", "stock_request_order")]} + + + {"invisible": [("code", "=", "stock_request_order")]} + + + +
diff --git a/stock_request_picking_type/views/stock_request_order_views.xml b/stock_request_picking_type/views/stock_request_order_views.xml new file mode 100644 index 000000000..93105b7b9 --- /dev/null +++ b/stock_request_picking_type/views/stock_request_order_views.xml @@ -0,0 +1,55 @@ + + + stock.request.order.search + stock.request.order + + + + + + + + + stock.request.order.form.picking.type + stock.request.order + + + + + + + + + Stock Request Orders + ir.actions.act_window + stock.request.order + tree,form + + + [('picking_type_id', '=', active_id)] + {'default_picking_type_id': active_id} + + + Stock Request Orders + ir.actions.act_window + stock.request.order + form + + +