Skip to main content

Dynamic routing of stock moves

Project description

Beta License: AGPL-3 OCA/wms Translate me on Weblate Try me on Runboat

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

Authors

  • Camptocamp

Contributors

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.

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

File details

Details for the file odoo13_addon_stock_dynamic_routing-13.0.1.1.2.dev6-py3-none-any.whl.

File metadata

File hashes

Hashes for odoo13_addon_stock_dynamic_routing-13.0.1.1.2.dev6-py3-none-any.whl
Algorithm Hash digest
SHA256 7022e0b7df317eb8748beac9f5fe19ffb9b708aedaa52af2e8dc34dac11b6ffe
MD5 6c763c7f63e15b1b572b964be8e779de
BLAKE2b-256 f86d550fc6f9749771044ab2d66ece7eab3426d85946f61435a56a00d972d95f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page