In step 26 I have tried several different approaches, as you can see from what is commented out. I am stuck, and need a nudge in the right direction.
from abc import ABC, abstractmethod
class Product:
def __init__(self, name: str, price: float) -> None:
self.name = name
self.price = price
def __str__(self) -> str:
return f'{self.name} - ${self.price}'
class DiscountStrategy(ABC):
@abstractmethod
def is_applicable(self, product: Product, user_tier: str) -> bool:
pass
@abstractmethod
def apply_discount(self, product: Product) -> float:
pass
class PercentageDiscount(DiscountStrategy):
def __init__(self, percent: int) -> None:
self.percent = percent
def is_applicable(self, product: Product, user_tier: str) -> bool:
return self.percent <= 70
def apply_discount(self, product: Product) -> float:
return product.price * (1 - self.percent / 100)
class FixedAmountDiscount(DiscountStrategy):
def __init__(self, amount: int) -> None:
self.amount = amount
def is_applicable(self, product: Product, user_tier: str) -> bool:
return product.price * 0.9 > self.amount
def apply_discount(self, product: Product) -> float:
return product.price - self.amount
class PremiumUserDiscount(DiscountStrategy):
def is_applicable(self, product: Product, user_tier: str) -> bool:
return user_tier.lower() == 'premium'
def apply_discount(self, product: Product) -> float:
return product.price * 0.8
class DiscountEngine:
def __init__(self, strategies: list[DiscountStrategy]) -> None:
self.strategies = strategies
def calculate_best_price(self, product: Product, user_tier: str) -> float:
prices = [product.price]
print(prices)
for strategy in self.strategies:
if strategy.is_applicable(product, user_tier):
discounted = apply_discount(product)
prices.append(discounted)
# discounted = apply_discount(self.product)
# prices.append(discounted)
# prices.append(apply_discount(self.product))
product = Product('Wireless Mouse', 50.0)
print(product)
discount = PercentageDiscount(10)
print(discount.apply_discount(product))
fixed_discount = FixedAmountDiscount(5)
print(fixed_discount.apply_discount(product))
#premium_discount = PremiumUserDiscount()
#user_tier = 'premium'
#best_price = DiscountEngine.calculate_best_price(product, user_tier)