trytonpsk-purchase_co/product.py

26 lines
994 B
Python
Raw Permalink Normal View History

2022-05-06 17:46:53 +02:00
# This file is part of Tryton. The COPYRIGHT file at the top level of
# this repository contains the full copyright notices and license terms.
from trytond.model import fields
from trytond.pool import PoolMeta, Pool
from trytond.modules.product import price_digits
2022-10-14 22:13:41 +02:00
2022-05-06 17:46:53 +02:00
class Product(metaclass=PoolMeta):
__name__ = 'product.product'
last_cost = fields.Function(fields.Numeric('Last Cost', digits=price_digits,
help='Last purchase price'), 'get_last_cost')
def get_last_cost(self, name=None):
res = self.cost_price
InvoiceLine = Pool().get('account.invoice.line')
products = InvoiceLine.search_read([
('product', '=', self.id),
2022-08-16 18:01:25 +02:00
('invoice.state', 'in', ['posted', 'paid', 'validated']),
2022-05-06 17:46:53 +02:00
('invoice.type', '=', 'in'),
2022-08-16 18:01:25 +02:00
], fields_names=['unit_price'], order=[
('invoice.invoice_date', 'DESC')],
limit=1)
2022-05-06 17:46:53 +02:00
if products:
res = products[0]['unit_price']
return res