Hello guy!
I am in Odoo 8. I'm searching the best way to cancel a stock move directly in my Odoo backend.
I don't want to use « update stock_move set state = 'draft' where id = ?; » in a sql query.
Idea?
Thanks
Odoo is the world's easiest all-in-one management software.
 It includes hundreds of business apps:
Hello guy!
I am in Odoo 8. I'm searching the best way to cancel a stock move directly in my Odoo backend.
I don't want to use « update stock_move set state = 'draft' where id = ?; » in a sql query.
Idea?
Thanks
You're right to not want to do this via direct SQL, as you're ignoring a lot of other data validation steps that will cause errors in your data.
You could do this out of the box in OpenERP v7. In Odoo v8 this isn't possible without custom code due to how quants work. You'd need to override the existing action_cancel() function in the Python code to bypass the error for the done status, then undo changes to the quant the item came from.
What might be smarter and easier is to add a function to quickly create a new stock move that reverses the transaction.  Basically, it needs to duplicate the original stock move, then swap the source and destination locations, and immediately finalize the move.  This will also resolve the quant accuracy issue, and ensure that any accounting valuation entries are reversed as well.
Thank you so much for this complete answer.
It is really easy ton delete a stock move now. I have commented 3 lines in stock.py, in the action_cancel() function. But to undo the quants, I think I will have some difficulties.
Create an account today to enjoy exclusive features and engage with our awesome community!
Sign up| Related Posts | Replies | Views | Activity | |
|---|---|---|---|---|
|  | 2 Jul 17  | 6613 | ||
|  | 2 Jun 19  | 6133 | ||
|  | 2 Jul 17  | 9731 | ||
|  | 1 Mar 17  | 6902 | ||
|  | 3 Apr 15  | 6370 | 
I'm going crazy with this!!!!! Do you have an other solution?