public Campaign(Category category, decimal discountvalue, decimal minItem, EDiscountType discountType) { Category = category; DiscountValue = discountvalue; MinItem = minItem; DiscountType = discountType; }
public Basket(EDiscountType discountType) { _products = new List <Product>(); // Here the discount strategy is defined, according to a desired kind of discount type. _discountStrategy = DiscountStrategyFactory.DiscountStrategyFor(discountType); }
/// <summary> /// Returns a discount strategy acourding to a discount type. /// </summary> /// <param name="discountType">Discount type to be applied.</param> /// <returns>Discount strategy.</returns> public static IBasketDiscountStrategy DiscountStrategyFor(EDiscountType discountType) { switch (discountType) { case EDiscountType.NoDiscount: return(new NoDiscountStrategy()); case EDiscountType.PercentageDiscount: return(new PercentageDiscountStrategy()); case EDiscountType.PerItemPercentageDiscount: return(new PerItemPercentualDiscountStrategy()); default: throw new ArgumentException("There is no discount strategy defined to the specified discount type."); } }
/// <summary> /// Defines a discount type to be applied over all products of basket. /// </summary> /// <param name="discountType">Discount type which will be applied over the products list.</param> public void SetDiscountType(EDiscountType discountType) { _discountStrategy = DiscountStrategyFactory.DiscountStrategyFor(discountType); }
protected static FR_Guid Execute(DbConnection Connection, DbTransaction Transaction, P_L5AR_SPS_1535 Parameter, CSV2Core.SessionSecurity.SessionSecurityTicket securityTicket = null) { #region UserCode var returnValue = new FR_Guid(); #region ProductSupplier var productSupplier = new ORM_CMN_PRO_Product_Supplier(); if (Parameter.Product_SupplierID != Guid.Empty) { var fetched = productSupplier.Load(Connection, Transaction, Parameter.Product_SupplierID); } if (Parameter.IsDeleted == true) { #region Delete ProductSupplier including Discount Values var deletePrices = CL1_CMN.ORM_CMN_Price.Query.Search(Connection, Transaction, new CL1_CMN.ORM_CMN_Price.Query { CMN_PriceID = productSupplier.ProcurementPrice_RefID, Tenant_RefID = securityTicket.TenantID, IsDeleted = false }).SingleOrDefault(); var deletePriceValues = CL1_CMN.ORM_CMN_Price_Value.Query.Search(Connection, Transaction, new CL1_CMN.ORM_CMN_Price_Value.Query { Price_RefID = productSupplier.ProcurementPrice_RefID, Tenant_RefID = securityTicket.TenantID, IsDeleted = false }).SingleOrDefault(); if (deletePriceValues != null) { deletePriceValues.IsDeleted = true; deletePriceValues.Save(Connection, Transaction); } if (deletePrices != null) { deletePrices.IsDeleted = true; deletePrices.Save(Connection, Transaction); } productSupplier.IsDeleted = true; productSupplier.Save(Connection, Transaction); ORM_CMN_PRO_Product_Supplier_DiscountValue.Query.SoftDelete(Connection, Transaction, new ORM_CMN_PRO_Product_Supplier_DiscountValue.Query { Product_Supplier_RefID = productSupplier.CMN_PRO_Product_SupplierID, IsDeleted = false, Tenant_RefID = securityTicket.TenantID }); returnValue.Result = Parameter.Product_SupplierID; // fixing priority var suppliersParam = new P_L5AA_GPSfPI_1248() { ProductID = Parameter.ProductID }; var SupplierProducts = cls_Get_ProductSuppliers_for_ProductID.Invoke( Connection, Transaction, suppliersParam, securityTicket).Result; for (int i = 0; i < SupplierProducts.Count(); i++) { if (SupplierProducts[i].SupplierPriority != (i + 1)) { var findSupplierProduct = ORM_CMN_PRO_Product_Supplier.Query.Search(Connection, Transaction, new ORM_CMN_PRO_Product_Supplier.Query { CMN_PRO_Product_SupplierID = SupplierProducts[i].CMN_PRO_Product_SupplierID, Tenant_RefID = securityTicket.TenantID, IsDeleted = false }).SingleOrDefault(); if (findSupplierProduct != null && findSupplierProduct.SupplierPriority != (i + 1)) { findSupplierProduct.SupplierPriority = (i + 1); findSupplierProduct.Save(Connection, Transaction); } } } return(returnValue); #endregion } if (Parameter.Product_SupplierID == Guid.Empty) { // new product supplier productSupplier.CMN_PRO_Product_SupplierID = Guid.NewGuid(); productSupplier.Tenant_RefID = securityTicket.TenantID; productSupplier.Creation_Timestamp = DateTime.Now; productSupplier.CMN_PRO_Product_RefID = Parameter.ProductID; // new cmn_prices var prices = new CL1_CMN.ORM_CMN_Price(); prices.CMN_PriceID = Guid.NewGuid(); prices.Tenant_RefID = securityTicket.TenantID; prices.Save(Connection, Transaction); // new cmn_price_values var priceValue = new CL1_CMN.ORM_CMN_Price_Value(); priceValue.CMN_Price_ValueID = Guid.NewGuid(); priceValue.Price_RefID = prices.CMN_PriceID; priceValue.PriceValue_Amount = Parameter.ProcurementPrice; priceValue.Tenant_RefID = securityTicket.TenantID; priceValue.Save(Connection, Transaction); productSupplier.ProcurementPrice_RefID = prices.CMN_PriceID; } var findPriceValues = CL1_CMN.ORM_CMN_Price_Value.Query.Search(Connection, Transaction, new CL1_CMN.ORM_CMN_Price_Value.Query { Price_RefID = productSupplier.ProcurementPrice_RefID, Tenant_RefID = securityTicket.TenantID, IsDeleted = false }).SingleOrDefault(); if (findPriceValues != null) { findPriceValues.PriceValue_Amount = Parameter.ProcurementPrice; findPriceValues.Save(Connection, Transaction); } productSupplier.CMN_BPT_Supplier_RefID = Parameter.SupplierID; productSupplier.MinimalPackageOrderingAmount = (float)Parameter.MinimalPackageOrderingAmount; productSupplier.BatchOrderSize = Parameter.BatchOrderSize; productSupplier.SupplierPriority = Parameter.SupplierPriority; productSupplier.Save(Connection, Transaction); returnValue.Result = productSupplier.CMN_PRO_Product_SupplierID; #endregion #region Product Supplier Discount Values #region Preload default discount types var discountTypes = CL1_ORD_PRC.ORM_ORD_PRC_DiscountType.Query.Search(Connection, Transaction, new CL1_ORD_PRC.ORM_ORD_PRC_DiscountType.Query { IsDeleted = false, Tenant_RefID = securityTicket.TenantID }).Where(x => !String.IsNullOrEmpty(x.GlobalPropertyMatchingID)); #endregion if (Parameter.Product_SupplierID != Guid.Empty) { #region Load and update Discounts var discountValues = ORM_CMN_PRO_Product_Supplier_DiscountValue.Query.Search(Connection, Transaction, new ORM_CMN_PRO_Product_Supplier_DiscountValue.Query { Product_Supplier_RefID = productSupplier.CMN_PRO_Product_SupplierID, IsDeleted = false, Tenant_RefID = securityTicket.TenantID }); foreach (var item in discountValues) { string matchingID = discountTypes.Single(x => x.ORD_PRC_DiscountTypeID == item.ORD_PRC_DiscountType_RefID).GlobalPropertyMatchingID; EDiscountType currentDiscountType = EnumUtils.GetEnumValueByDescription <EDiscountType>(matchingID); switch (currentDiscountType) { case EDiscountType.CashDiscount: item.DiscountValue = Parameter.CashDiscount; break; case EDiscountType.MainDiscount: item.DiscountValue = Parameter.Discount1; break; case EDiscountType.Discount2: item.DiscountValue = Parameter.Discount2; break; case EDiscountType.Discount3: item.DiscountValue = Parameter.Discount3; break; } item.Save(Connection, Transaction); } #endregion } else { #region Create discount values ORM_CMN_PRO_Product_Supplier_DiscountValue productSupplierDiscountValue = null; foreach (var item in discountTypes) { productSupplierDiscountValue = new ORM_CMN_PRO_Product_Supplier_DiscountValue { CMN_PRO_Product_Supplier_DiscountValueID = Guid.NewGuid(), Product_Supplier_RefID = productSupplier.CMN_PRO_Product_SupplierID, ORD_PRC_DiscountType_RefID = item.ORD_PRC_DiscountTypeID, IsRelativeDiscountValue = true, IsAbsoluteDiscountValue = false, Tenant_RefID = securityTicket.TenantID }; EDiscountType currentDiscountType = EnumUtils.GetEnumValueByDescription <EDiscountType>(item.GlobalPropertyMatchingID); switch (currentDiscountType) { case EDiscountType.CashDiscount: productSupplierDiscountValue.DiscountValue = Parameter.CashDiscount; break; case EDiscountType.MainDiscount: productSupplierDiscountValue.DiscountValue = Parameter.Discount1; break; case EDiscountType.Discount2: productSupplierDiscountValue.DiscountValue = Parameter.Discount2; break; case EDiscountType.Discount3: productSupplierDiscountValue.DiscountValue = Parameter.Discount3; break; } productSupplierDiscountValue.Save(Connection, Transaction); } #endregion } #endregion return(returnValue); #endregion UserCode }