trytond-product_special_price/product.py

93 lines
3.3 KiB
Python
Raw Permalink Normal View History

2013-04-29 16:07:21 +02:00
# This file is part of product_special_price module for Tryton.
# The COPYRIGHT file at the top level of this repository contains the full
# copyright notices and license terms.
from trytond.pool import Pool, PoolMeta
2018-03-19 14:16:12 +01:00
from trytond.model import ModelSQL, fields
2013-04-29 16:07:21 +02:00
from trytond.pyson import Eval
from trytond.transaction import Transaction
2018-03-19 14:16:12 +01:00
from trytond.modules.product.product import price_digits
from trytond.modules.company.model import CompanyValueMixin
2013-04-29 16:07:21 +02:00
2018-06-14 17:56:47 +02:00
__all__ = ['Template', 'ProductSpecialPrice', 'Product']
2013-04-29 16:07:21 +02:00
STATES = {
'readonly': ~Eval('active', True),
}
DEPENDS = ['active']
2018-09-15 18:11:46 +02:00
class Template(metaclass=PoolMeta):
2013-04-29 16:07:21 +02:00
__name__ = 'product.template'
2018-03-19 14:16:12 +01:00
special_price = fields.MultiValue(fields.Numeric(
"Special Price", digits=price_digits,
states=STATES, depends=DEPENDS))
2018-06-14 17:56:47 +02:00
special_prices = fields.One2Many(
'product.special_price', 'template', "Special Prices")
2014-05-06 18:52:46 +02:00
special_price_from = fields.Date('Special Price From')
special_price_to = fields.Date('Special Price To')
2013-04-29 16:07:21 +02:00
2018-03-19 14:16:12 +01:00
@classmethod
def multivalue_model(cls, field):
pool = Pool()
if field == 'special_price':
return pool.get('product.special_price')
return super(Template, cls).multivalue_model(field)
class ProductSpecialPrice(ModelSQL, CompanyValueMixin):
"Product Special Price"
__name__ = 'product.special_price'
template = fields.Many2One(
'product.template', "Template", ondelete='CASCADE',
2022-05-04 11:45:37 +02:00
context={
'company': Eval('company', -1),
2022-05-04 11:45:37 +02:00
}, depends=['company'])
2018-03-19 14:16:12 +01:00
special_price = fields.Numeric("Special Price", digits=price_digits)
2013-04-29 16:07:21 +02:00
2018-09-15 18:11:46 +02:00
class Product(metaclass=PoolMeta):
2013-04-29 16:07:21 +02:00
__name__ = 'product.product'
@classmethod
def get_sale_price(cls, products, quantity=0):
2014-06-08 16:37:25 +02:00
pool = Pool()
Date = pool.get('ir.date')
User = pool.get('res.user')
Uom = pool.get('product.uom')
2014-05-06 18:52:46 +02:00
2013-04-29 16:07:21 +02:00
prices = super(Product, cls).get_sale_price(products, quantity)
if Transaction().context.get('without_special_price'):
return prices
2013-08-28 17:37:33 +02:00
today = Date.today()
user = User(Transaction().user)
if user.shop and user.shop.special_price:
for product in products:
if (product.special_price_from and
today < product.special_price_from):
continue
if (product.special_price_to and
today > product.special_price_to):
continue
special_price = 0.0
if user.shop.type_special_price == 'pricelist':
price_list = user.shop.special_pricelist
customer = Transaction().context.get('customer', None)
uom_id = Transaction().context.get('uom', None)
if uom_id:
uom = Uom(uom_id)
else:
uom = product.default_uom
special_price = price_list.compute(customer, product,
prices[product.id], quantity, uom)
else:
special_price = product.special_price
2013-08-28 17:37:33 +02:00
2018-03-19 14:16:12 +01:00
if (special_price != 0.0
and special_price is not None
and special_price < prices[product.id]):
prices[product.id] = special_price
2013-04-29 16:07:21 +02:00
return prices