fixes according to fixed types

This commit is contained in:
nflnkr 2023-02-25 16:54:52 +03:00
parent e905e12ca3
commit 56d0e535ec

@ -7,7 +7,6 @@ export function calcCartData(
user: User,
cartItems: Cart.CartItem[],
discounts: Cart.AnyDiscount[],
privileges: Tariffs.Privilege[],
promocode?: Cart.Promocode,
): Cart.CartTotal {
const cartTotal: Cart.CartTotal = {
@ -38,7 +37,7 @@ export function calcCartData(
return cartTotal;
}
// TODO layer 1
// TODO layer 1-user
if (promocode) {
for (const discount of discounts) {
if (discount.conditionType !== "user" || discount.condition.user !== user.ID || discount.condition.coupon !== promocode.name) continue;
@ -54,6 +53,7 @@ export function calcCartData(
}
}
// layer 1-promo
for (const cartItem of cartItems) {
const cartItemTotal: Cart.CartItemTotal = {
item: cartItem.item,
@ -72,7 +72,7 @@ export function calcCartData(
const maxPrivilegeDiscount = findMaxApplicablePrivilegeDiscount(discounts, tariff);
if (maxPrivilegeDiscount) {
maxPrivilegeDiscount.target.products.forEach(product => {
if (product.productId === tariff.id) { // TODO productId - ид продукта(тариф или пакет тарифов) или привилегии? Если второе, то откуда берется привилегия?
if (product.productId === tariff.privilege.privilegeId) {
cartItemTotal.totalPrice *= product.factor;
cartItemTotal.envolvedDiscounts.push(maxPrivilegeDiscount._id);
}
@ -80,7 +80,7 @@ export function calcCartData(
}
cartTotal.items.push(cartItemTotal);
cartTotal.priceByService[tariff.service] += cartItemTotal.totalPrice;
cartTotal.priceByService[tariff.privilege.serviceKey] += cartItemTotal.totalPrice;
}
// layer 2
@ -96,7 +96,7 @@ export function calcCartData(
if (cartPurchasesAmountDiscount) cartTotal.totalPrice *= cartPurchasesAmountDiscount.factor;
// layer 4
const totalPurchasesAmountDiscount = findMaxPurchasesAmountDiscount(discounts, user);
const totalPurchasesAmountDiscount = findMaxTotalPurchasesAmountDiscount(discounts, user);
if (totalPurchasesAmountDiscount) cartTotal.totalPrice *= totalPurchasesAmountDiscount.factor;
return cartTotal;
@ -130,7 +130,7 @@ function findMaxCartPurchasesAmountDiscount(discounts: Cart.AnyDiscount[], cartT
return maxValueDiscount;
}
function findMaxPurchasesAmountDiscount(discounts: Cart.AnyDiscount[], user: User): Cart.PurchasesAmountDiscount | null {
function findMaxTotalPurchasesAmountDiscount(discounts: Cart.AnyDiscount[], user: User): Cart.PurchasesAmountDiscount | null {
const applicableDiscounts = discounts.filter((discount): discount is Cart.PurchasesAmountDiscount => {
return discount.conditionType === "purchasesAmount" && discount.condition.purchasesAmount >= user.PurchasesAmount;
});
@ -186,13 +186,13 @@ function calcCartItemWithPromocode(
const tariff = cartItem.item;
discount.target.products.forEach(product => {
if (product.productId === tariff.id) { // TODO productId - ид продукта(тариф или пакет тарифов) или привилегии? Если второе, то откуда берется привилегия?
if (product.productId === tariff.privilege.privilegeId) {
cartItemTotal.totalPrice *= product.factor;
cartItemTotal.envolvedDiscounts.push(discount._id);
}
});
priceByService[tariff.service] = cartItemTotal.totalPrice;
priceByService[tariff.privilege.serviceKey] = cartItemTotal.totalPrice;
return cartItemTotal;
}
@ -200,7 +200,7 @@ function calcCartItemWithPromocode(
export function packTariffs(tariffs: Tariffs.Tariff[], id: string, name: string): Tariffs.Package {
const services: Tariffs.ServiceType[] = [];
tariffs.forEach(tariff => {
if (!services.includes(tariff.service)) services.push(tariff.service);
if (!services.includes(tariff.privilege.serviceKey)) services.push(tariff.privilege.serviceKey);
});
return {