Dynamic routing of stock moves
Project description
Standard Stock Routes explain the steps you want to produce whereas the “Dynamic Routing” defines how operations are grouped according to their final source and destination location.
This allows for example:
To parallelize transfers in two locations of a warehouse, splitting them in two different operation type
To define pre-picking (wave) in some sub-locations, then roundtrip picking of the sub-location waves
Context for the use cases:
In the warehouse, you have a High-Bay which requires to place goods in a handover when you move goods in or out of it. The High-Bay contains many sub-locations.
A product can be stored either in the High-Bay, either in the Shelving zone.
When picking:
When there is enough stock in the Shelving, you expect the moves to have the usual Pick(Highbay)-Pack-Ship steps. If the good is picked from the High-Bay, you will need an extra operation: Pick(Highbay)-Handover-Pack-Ship.
This is what this feature is doing: on the High-Bay location, you define a “routing rule”. A routing rule selects a different operation type for the move. The extra transfer will have the selected operation type, and be added dynamically, on reservation, before the chain of moves.
When putting away:
A put-away rule targets the High-Bay location. An operation Input-Highbay is created. You expect Input-Handover-Highbay.
You can configure a dynamic routing for the put-away on the High-Bay Location. The operation type of the new Handover move will the one of the matching routing rule, and its destination will be the destination of the operation type.
Table of contents
Configuration
In Inventory Settings, you must have:
Storage Locations
Multi-Warehouses
Multi-Step Routes
A new menu in Inventory Settings allow to create new routing rules: “Stock Routing”.
Create a new routing for a location, then pull or push routing rules. A pull rule is applied on moves with the same source location (or children). A push rule is applied on moves with the same destination location (or children).
Rules can exclude moves based on a domain. The order of the rules is important: the first to match is used.
Usage
Try on runbot
In Inventory Settings, activate:
Storage Locations
Multi-Warehouses
Multi-Step Routes
The initial setup in the demo data contains locations:
WH/Stock/Highbay
WH/Stock/Highbay/Bin 1
WH/Stock/Highbay/Bin 2
WH/Stock/Handover
The “Highbay” location (and children) is configured to:
create a pull routing transfer from Highbay to Handover when goods are taken from Highbay (using a new picking type Highbay → Handover)
create a push routing transfer from Handover to Highbay when goods are put to Highbay (using a new picking type Handover → Highbay)
Steps to try the Pull Routing Transfer:
In the main Warehouse, configure outgoing shipments to “Send goods in output and then deliver (2 steps)”
Inventory a product, for instance “[FURN_8999] Three-Seat Sofa”, add 50 items in “WH/Stock/Highbay/Bay A/Bin 1”, and nowhere else
Create a sales order with 5 “[FURN_8999] Three-Seat Sofa”, confirm
You’ll have 3 transfers; a new one has been created dynamically for Highbay -> Handover.
Steps to try the Push Routing Transfer:
In the “WH/Stock” location, create a Put-Away Strategy with:
“[DESK0004] Customizable Desk (Aluminium, Black)” to location “WH/Stock/Highbay/Bay A/Bin 1”
“[E-COM06] Corner Desk Right Sit” to location “WH/Stock/Shelf 1”
Create a new purchase order of:
5 “[DESK0004] Customizable Desk (Aluminium, Black)”
5 “[E-COM06] Corner Desk Right Sit”
Confirm the purchase
You’ll have 2 transfers:
one to move DESK0004 from Supplier → Handover and E-COM06 from Supplier → Shelf 1
one waiting on the other to move DESK0004 from Handover → WH/Stock/Highbay/Bay A/Bin 1 (the final location of the put-away)
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 to smash it by providing a detailed and welcomed feedback.
Do not contact contributors directly about support or help with technical issues.
Credits
Contributors
Joël Grand-Guillaume <joel.grandguillaume@camptocamp.com>
Guewen Baconnier <guewen.baconnier@camptocamp.com>
Jacques-Etienne Baudoux (BCIM) <je@bcim.be>
Akim Juillerat <akim.juillerat@camptocamp.com>
Maintainers
This module is maintained by the OCA.
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:
This module is part of the OCA/wms project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file odoo14_addon_stock_dynamic_routing-14.0.1.1.3.dev1-py3-none-any.whl
.
File metadata
- Download URL: odoo14_addon_stock_dynamic_routing-14.0.1.1.3.dev1-py3-none-any.whl
- Upload date:
- Size: 63.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f1c4961c99ec894ae4b3b734a7bd20dbd77a633c909dc5f53b296082822f1a87 |
|
MD5 | 5ec9ea8446fcb51d470e48732a006da0 |
|
BLAKE2b-256 | 346b8161ede46172f649c8247daefaa53aa643a3b3e580ed2e07346b71ee7396 |