-
-
Notifications
You must be signed in to change notification settings - Fork 161
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[IMP] account_invoice_margin_sale: Update purchase cost in invoice li…
…nes from sale order when installing module
- Loading branch information
1 parent
012c35e
commit 396845e
Showing
6 changed files
with
56 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,3 @@ | ||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). | ||
|
||
from .hooks import post_init_hook | ||
from . import models |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
def post_init_hook(cr, registry): | ||
# update purchase_price for invoices from sale_order | ||
cr.execute( | ||
""" | ||
UPDATE account_move_line AS aml | ||
SET purchase_price = ( | ||
SELECT COALESCE(SUM(order_line.purchase_price), 0.0) | ||
FROM sale_order_line AS order_line | ||
INNER JOIN sale_order AS so ON order_line.order_id = so.id | ||
INNER JOIN sale_order_line_invoice_rel AS soi | ||
ON soi.order_line_id = order_line.id | ||
WHERE soi.invoice_line_id = aml.id | ||
) | ||
WHERE EXISTS ( | ||
SELECT 1 | ||
FROM sale_order_line AS order_line | ||
INNER JOIN sale_order_line_invoice_rel AS soi | ||
ON soi.order_line_id = order_line.id | ||
WHERE soi.invoice_line_id = aml.id | ||
); | ||
""" | ||
) | ||
# recalculate margin for invoices from sale_order | ||
cr.execute( | ||
""" | ||
WITH aml AS ( | ||
SELECT | ||
account_move_line.move_id, | ||
SUM(account_move_line.margin) AS sum_margin, | ||
SUM(account_move_line.margin_signed) AS sum_margin_signed | ||
FROM account_move_line | ||
INNER JOIN account_move ON account_move.id = account_move_line.move_id | ||
WHERE EXISTS ( | ||
SELECT 1 | ||
FROM sale_order_line AS order_line | ||
INNER JOIN sale_order AS so ON order_line.order_id = so.id | ||
INNER JOIN sale_order_line_invoice_rel AS soi | ||
ON soi.order_line_id = order_line.id | ||
WHERE soi.invoice_line_id = account_move_line.id | ||
) | ||
GROUP BY account_move_line.move_id | ||
) | ||
UPDATE account_move | ||
SET margin = aml.sum_margin, | ||
margin_signed = aml.sum_margin_signed, | ||
margin_percent = aml.sum_margin_signed / amount_untaxed * 100 | ||
FROM aml | ||
WHERE account_move.id = aml.move_id | ||
AND account_move.amount_untaxed > 0.0; | ||
""" | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters