Commit Graph

75 Commits

Author SHA1 Message Date
Matt Taylor
e5d81dc0ee [IMP] mrp_multi_level: mrp cleanup performance
- Index the planned_order_id column on mrp.production model
- Delete from mrp.planned.order before deleting from mrp.inventory
2024-12-04 09:42:26 +05:30
Lois Rilo
e6a953ebd9 [IMP] mrp_multi_level: better logs during calculation
* Explicitly log which area and LLC is being computed.
* Correct LLC being logged.
2024-12-04 09:42:26 +05:30
Jordi Ballester Alomar
020ec886dd [IMP] mrp_multi_level: add hooks to improve extensibility 2024-12-04 09:42:26 +05:30
JordiMForgeFlow
6105928a35 [IMP] mrp_multi_level: fix typo 2024-12-04 09:42:26 +05:30
JordiMForgeFlow
79d99a6114 [IMP] mrp_multi_level: use area from component in the explosion vals 2024-12-04 09:42:26 +05:30
JasminSForgeFlow
995e752a6e [MIG] mrp_multi_level: Migration to 17.0 2024-12-04 09:42:26 +05:30
JasminSForgeFlow
677bde6b00 [IMP] mrp_multi_level: black, isort, prettier 2024-12-04 09:42:26 +05:30
BernatPForgeFlow
57cba495f0 [FIX] mrp_multi_level: Prioritize safety stock with mrp moves today
If I have 0 units, my safety stock is 5 units and today I have a supply for 10 units, the procurement recommendation should be 0 units
2024-12-04 09:42:26 +05:30
Lois Rilo
7d740b502f [FIX] mrp_multi_level: wrong safety stock intial order in grouped demand mode
Three tests cases modelize the issues being solved.
2024-12-04 09:42:26 +05:30
Lois Rilo
6b5aca3abe [FIX] mrp_multi_level: ariable 'move' referenced before assignment 2024-12-04 09:42:26 +05:30
Lois Rilo
4c5968f545 [FIX] mrp_multi_level: starting qty on hand wrong when using lots
Unify the way to get the starting on hand whenever needed in MRP
calculations.
2024-12-04 09:42:26 +05:30
Alexandre Fayolle
33329e0d5f [IMP] mrp_multi_level: safety stock
When a product has a safety stock in an area, and the current stock is
below safety, but there are moves in the future, mrp_multi_level does
not compute an immediate action to get back to the safety stock.

This PR changes this behavior: when the mrp_moves are considered, before
processing the first move in the future, we insert a resupply action to
rebuild the safety stock.

We also add some refactoring in the process:

* add extension point on the wizard to compute the quantity to reorder
(so we can choose in a separate module whether to rebuild safety stock
or not)
* add extension point on the wizard to get the date at which the safety
stock must be rebuilt (defaults to today)
* make the code of the wizard symetric between the groupes and non
grouped configuration
2024-12-04 09:42:26 +05:30
Alexandre Fayolle
0d9e98f53f [IMP] mrp_multi_level: reduce some logging
When running the multi level planner, the wizard will delete the records
from the previous run (mrp.inventory, mrp.move, mrp.planned.order).
There can be hundreds of such records, and the call to unlink() will
create a log entry which is not really informative. We disable this log
during the call to the wizard (but keep if for manual unlinking of the
records which we want to trace).
2024-12-04 09:42:26 +05:30
Alexandre Fayolle
9d288ee154 [REF] mrp_multi_level: location management
Small refactoring adding a _get_locations method on product.mrp.area
which by defaults delegates the computation to the related mrp.area.

This enables extending a few things related to locations at the
product.mrp.area level.

Change the way `_get_locations()` work: don't return the list of child
locations, only the top-most locations, and then use the `child_of`
operator in the code that looks for locations.
2024-12-04 09:42:26 +05:30
BernatPForgeFlow
784e40e8fc [IMP] mrp_multi_level: Get BoM to explode
When exploding requirements or calculating supply method, we will consider the first active BoM taking into account the routes.
2024-12-04 09:42:25 +05:30
Lois Rilo
554c0126d7 [IMP] mrp_multi_level: do not create moves if not data
This improves extensibility, allowing to not create moves on
certain situations by extending the prepare vals hook method.
2024-12-04 09:42:25 +05:30
joan
caf43f4cc4 [MIG] mrp_multi_level: Migration to 16.0 2024-12-04 09:42:25 +05:30
Lois Rilo
6e51607b0b [IMP] mrp_multi_level: avoid recursion on LLC calculation.
Introduce a safe and configurable LLC depth limit to avoid infinite
recursion.

Also, improve extensibility of BoM finding and fix it to not
consider archived BoMs.
2024-12-04 09:42:25 +05:30
Bernat Puig Font
1c19dc0ebb [FIX] mrp_multi_level: Descriptive order number in MRP Moves 2024-12-04 09:42:25 +05:30
Bernat Puig Font
df8c1f961c [FIX] mrp_multi_level: Manage Kits in MRP Multi Level 2024-12-04 09:42:25 +05:30
Lois Rilo
81b8dc2d8c [FIX] mrp_multi_level: do not include supplies on origin.
Planned orders' origin when groupping was including supplies
which could lead to confusion.
2024-12-04 09:42:25 +05:30
LaiaTForgeFlow
fcee5d8fd6 [FIX]mrp_multi_level: avoid mixing str with boolean 2024-12-04 09:42:25 +05:30
Miquel Raïch
8d88214796 [IMP] mrp_multi_level: add utf8 encoding to xml files 2024-12-04 09:42:25 +05:30
Lois Rilo
2d7b0e9450 [IMP] mrp_multi_level: enchance traceability with origin.
* keept description of planned orders verbose.
* make it translatable in most cases.
* while grouping demand include the product in the description.
* add `origin` field not mrp moves and planned orders. Fill it
  with top level demand origin.
2024-12-04 09:42:25 +05:30
Jordi Ballester
03744c275c improve usage of planned orders. - The description of the planned order includes the topmost requirement that caused the planned order. This makes it easier to trace, for example, what planned orders has a given sales order generated. The description of the planned order is passed on to the Manufacturing Orders / Purchase Orders / Transfers as the origin, so it can be possible to search for PO's / MO's that were originated as a result of a given sales order, for example.
- The MRP Inventory tree view is improved so as to add a button to allow you to
  jump to the planned orders.
2024-12-04 09:42:25 +05:30
Lois Rilo
28f35f78a9 [FIX] mrp_multi_level: date_planned required as date object after change upstream.
Due to aec7fcdb69.
2024-12-04 09:42:25 +05:30
NuriaXForgeFlow
4bf6c455b4 [FIX] mrp_multi_level: Fix case when Purchase Uom is different from Uom and PO in draft 2024-12-04 09:42:25 +05:30
Jordi Ballester
13441f52d5 [FIX] mrp_multi_level: Use running on hand quantity in mrp.inventory
We need to show the projected on hand as it evolves over time.
2024-12-04 09:42:25 +05:30
Christopher Ormaza
b335a85d2d [15.0][MIG] mrp_multi_level 2024-12-04 09:42:25 +05:30
Christopher Ormaza
3a2e84b8f7 [IMP] mrp_multi_level: black, isort, prettier 2024-12-04 09:42:25 +05:30
Jordi Ballester
bbc5f5ead8 [14.0][mrp_multi_level][imp] improve speed by creating mrp.move records using the create_multi capabilities 2024-12-04 09:42:25 +05:30
Jordi Ballester
a90e971e30 [mrp_multi_level][fix] allow to procure from planned orders 2024-12-04 09:42:25 +05:30
Lois Rilo
3519eaa966 [FIX] mrp_multi_level: Consider timezone of the warehouse to generate mrp inventory records. 2024-12-04 09:42:25 +05:30
Lois Rilo
2c324338e2 [14.0][FIX] mrp_multi_level: error with 3 step delivery.
If the destination moves do not include a MO, the mrp move end
up without a name that raises an error later. This can happen
with 3 setep delivery but also with in more cases in wich there is
a chain of stock moves.

We ensure that the variable `order_number` always have a value.
2024-12-04 09:42:25 +05:30
Lois Rilo
4ec44db0ea [MIG] mrp_multi_level: finish migration of test 2024-12-04 09:42:25 +05:30
davidborromeo
b133065846 [MIG] mrp_multi_level: Migration to 14.0 2024-12-04 09:42:25 +05:30
davidborromeo
957b50af16 [IMP] mrp_multi_level: black, isort, prettier 2024-12-04 09:42:25 +05:30
Jordi Ballester Alomar
62f54da323 [FIX] mrp_multi_level: when a bom has quantity multiplier, consider it 2024-12-04 09:42:25 +05:30
AaronHForgeFlow
64ff10eae0 [IMP]mrp_multi_level
* let third modules to choose wether to continue exploding or not

This is useful for subcontracting and potentially for other flows.
2024-12-04 09:42:25 +05:30
Matt Taylor
601a08265d [FIX] mrp_multi_level: Check BoM Line Attrs
add a call to mrp.bom.line._skip_bom_line() method
fixes #505
2024-12-04 09:42:25 +05:30
Núria Martín Xifré
0dffeaf492 [13.0][IMP] mrp_multi_level: index llc 2024-12-04 09:42:25 +05:30
hveficent
2a1c277c96 [IMP] mrp_multi_level:
* Stock Moves Domain moved to product mrp area
2024-12-04 09:42:25 +05:30
OCA-git-bot
da891f212a pre-commit update 2024-12-04 09:42:25 +05:30
Lois Rilo
88c28972bf [11.0][FIX] mrp_multi_level: origin for "mv" was never being set.
Also, improve mrp.move by using picking name if the move is part of a picking.

[13.0] set "mo" as origin also for material consumption moves.
2024-12-04 09:42:25 +05:30
hveficent
e8cbf54a8d [IMP] mrp_multi_level:
* Planned Order release and due date become required.
* Add button to Product MRP Area to update MOQ from Supplier Info.
* Link Manufacturing Orders with Planned Orders.
* Allow Mrp Inventory Procure Wizard to be used from other models.
* Make MRP Inventory creation more extensible.
* Main Supplier computation (v13 requires explicit False definitions).
2024-12-04 09:42:25 +05:30
hveficent
0da15fcd89 [IMP] mrp_multi_level: Minor changes
* Planned Orders become fixed on manual creation by default
* Released Quantity become readonly
* Add product reference if Planned Order name is not defined on bom explosion
2024-12-04 09:42:25 +05:30
hveficent
1bb0ef773c [IMP] mrp_multi_level: Show supply method on mrp inventory 2024-12-04 09:42:25 +05:30
Lois Rilo
8a17a4376f [13.0][MIG] mrp_multi_level 2024-12-04 09:42:25 +05:30
Lois Rilo
2c18d11916 [IMP] mrp_multi_level: black, isort 2024-12-04 09:42:25 +05:30
Lois Rilo
68701a99f4 [12.0][FIX] mrp_multi_level: when grouping demand, if supply and
demand moves have the same date it can happen that the supply is
effectively ignored if considered as staring move of the
grouping and there are more groups to be done after it.

A test case include in this fix depicts in detail the
the problem and ensures no regression.
2024-12-04 09:42:25 +05:30