/// <summary> /// Loads customer. /// </summary> /// <param name="context">The service request context.</param> /// <param name="accountNumber">The account number.</param> /// <returns>The customer, or null if not found.</returns> private static Customer GetCustomer(RequestContext context, string accountNumber) { var getCustomerDataRequest = new GetCustomerDataRequest(accountNumber); SingleEntityDataServiceResponse <Customer> getCustomerDataResponse = context.Execute <SingleEntityDataServiceResponse <Customer> >(getCustomerDataRequest); Customer customer = getCustomerDataResponse.Entity; return(customer); }
/// <summary> /// Calculates the auto charges for the transaction / sales lines. /// </summary> /// <param name="request">The request.</param> /// <param name="transaction">Current sales transaction.</param> private static void CalculateAutoCharges(GetChargesServiceRequest request, SalesTransaction transaction) { // get customer to see their markup group string customerAccount = transaction.CustomerId ?? string.Empty; string customerChargeGroup = string.Empty; if (!string.IsNullOrWhiteSpace(customerAccount)) { var getCustomerDataRequest = new GetCustomerDataRequest(customerAccount); SingleEntityDataServiceResponse <Customer> getCustomerDataResponse = request.RequestContext.Execute <SingleEntityDataServiceResponse <Customer> >(getCustomerDataRequest); var customer = getCustomerDataResponse.Entity; customerChargeGroup = (customer != null) ? customer.ChargeGroup : string.Empty; } // get delivery mode information off the transaction string deliveryMode = transaction.DeliveryMode ?? string.Empty; string deliveryModeGroup = GetDeliveryModeGroupFromCode(request.RequestContext, deliveryMode); var channelConfiguration = request.RequestContext.GetChannelConfiguration(); string currencyCode = (channelConfiguration != null) ? channelConfiguration.Currency : string.Empty; // put charges on the transaction var transactionCharges = CalculateTransactionCharges(request.RequestContext, customerAccount, customerChargeGroup, deliveryMode, deliveryModeGroup, transaction); foreach (var charge in transactionCharges) { transaction.ChargeLines.Add(charge); } // put charges on the transaction lines // Consider calculable lines only. Ignore voided or return-by-receipt lines. foreach (var salesLine in transaction.ChargeCalculableSalesLines) { // get delivery mode information off the sales line deliveryMode = string.IsNullOrEmpty(salesLine.DeliveryMode) ? (transaction.DeliveryMode ?? string.Empty) : salesLine.DeliveryMode; deliveryModeGroup = GetDeliveryModeGroupFromCode(request.RequestContext, deliveryMode); var lineCharges = CalculateLineCharges(request.RequestContext, customerAccount, customerChargeGroup, deliveryMode, deliveryModeGroup, salesLine, transaction); foreach (var charge in lineCharges) { salesLine.ChargeLines.Add(charge); } } // now that all auto charges are on the transaction, calculate their amounts CalculateAutoChargeAmounts(request.RequestContext, transaction); // convert any charge amounts not in the channel currency var transactionAutoChargeLines = transaction.ChargeLines.Where(cl => cl.ChargeType == ChargeType.AutoCharge); // Consider calculable lines only. Ignore voided or return-by-receipt lines. var lineAutoChargeLines = transaction.ChargeCalculableSalesLines.SelectMany(sl => sl.ChargeLines).Where(cl => cl.ChargeType == ChargeType.AutoCharge); var allAutoChargeLines = transactionAutoChargeLines.Concat(lineAutoChargeLines); ChargeAmountsToStoreCurrency(request.RequestContext, allAutoChargeLines, currencyCode); }
internal static Customer GetCustomer(RequestContext context, string customerAccount) { Customer customer = null; if (!string.IsNullOrWhiteSpace(customerAccount)) { var getCustomerDataRequest = new GetCustomerDataRequest(customerAccount); SingleEntityDataServiceResponse <Customer> getCustomerDataResponse = context.Execute <SingleEntityDataServiceResponse <Customer> >(getCustomerDataRequest); customer = getCustomerDataResponse.Entity; } return(customer ?? (new Customer())); }
/// <summary> /// Gets the maximum retail price of the item. /// </summary> /// <returns>The maximum retail price of the item.</returns> private decimal GetItemMaxRetailPrice() { decimal maxRetailPrice = decimal.Zero; SalesLine salesLine = this.TaxableEntity as SalesLine; if (salesLine != null) { // get maximum retail price from trade agreement try { Customer customer = null; if (!string.IsNullOrWhiteSpace(this.Transaction.CustomerId)) { var getCustomerDataRequest = new GetCustomerDataRequest(this.Transaction.CustomerId); var getCustomerDataResponse = this.RequestContext.Execute <SingleEntityDataServiceResponse <Customer> >(getCustomerDataRequest); customer = getCustomerDataResponse.Entity; } string priceGroup = customer != null ? customer.PriceGroup : string.Empty; this.indiaPriceHelper = new IndiaPriceHelper(this.RequestContext.GetChannelConfiguration(), new PricingDataServiceManager(this.RequestContext), this.Transaction, priceGroup); } catch (ArgumentException) { maxRetailPrice = decimal.Zero; } if (this.indiaPriceHelper != null) { maxRetailPrice = this.indiaPriceHelper.GetMaximumRetailPriceFromTradeAgreement(salesLine, this.RequestContext); } } if (maxRetailPrice == decimal.Zero) { // No maximum retail price was defined in trade agreement, then use maximum retail price defined in item master. GetItemMaxRetailPriceDataRequest dataRequest = new GetItemMaxRetailPriceDataRequest(this.TaxableEntity.ItemId); dataRequest.QueryResultSettings = new QueryResultSettings(new ColumnSet("MAXIMUMRETAILPRICE_IN"), PagingInfo.AllRecords); maxRetailPrice = this.RequestContext.Runtime.Execute <SingleEntityDataServiceResponse <ItemMaxRetailPriceIndia> >(dataRequest, this.RequestContext).Entity.MaximumRetailPrice; } return(maxRetailPrice); }
private static string GetCustomerPriceGroup(RequestContext context, string customerAccount) { string customerPriceGroup = string.Empty; if (!string.IsNullOrWhiteSpace(customerAccount)) { var getCustomerDataRequest = new GetCustomerDataRequest(customerAccount); SingleEntityDataServiceResponse <Customer> getCustomerDataResponse = context.Execute <SingleEntityDataServiceResponse <Customer> >(getCustomerDataRequest); Customer customer = getCustomerDataResponse.Entity; if (customer != null) { if (!string.IsNullOrWhiteSpace(customer.PriceGroup)) { customerPriceGroup = customer.PriceGroup; } } } return(customerPriceGroup); }
/// <summary> /// Factory method to construct the SalesTaxGroupPicker. /// </summary> /// <param name="channel">The current channel.</param> /// <param name="context">The request context.</param> /// <param name="address">The destination address object.</param> /// <param name="deliveryMode">The delivery mode used.</param> /// <param name="fulfillmentStoreId">The store that fulfills the purchase (pick up from).</param> /// <param name="shippingFromInventLocation">The invent location that item shipped from.</param> /// <param name="customerId">Customer account number.</param> /// <returns> /// The SalesTaxGroupPicker object. /// </returns> public static SalesTaxGroupPicker Create(Channel channel, RequestContext context, Address address, string deliveryMode, string fulfillmentStoreId, string shippingFromInventLocation, string customerId) { ThrowIf.Null(channel, "channel"); ThrowIf.Null(context, "context"); if (channel.OrgUnitType != RetailChannelType.RetailStore) { return(CreatePickerForOnlineChannel(context, address, deliveryMode, fulfillmentStoreId, shippingFromInventLocation)); } Customer customer = null; if (!string.IsNullOrWhiteSpace(customerId)) { var getCustomerDataRequest = new GetCustomerDataRequest(customerId); SingleEntityDataServiceResponse <Customer> getCustomerDataResponse = context.Runtime.Execute <SingleEntityDataServiceResponse <Customer> >(getCustomerDataRequest, context); customer = getCustomerDataResponse.Entity; } OrgUnit store = channel as OrgUnit; return(CreatePickerForStore(store, customer, context, address, deliveryMode, fulfillmentStoreId, shippingFromInventLocation)); }
/// <summary> /// Gets the customer by account number. /// </summary> /// <param name="request">The data service request.</param> /// <returns>The data service response.</returns> private SingleEntityDataServiceResponse <Customer> GetCustomerByAccountNumber(GetCustomerDataRequest request) { CustomerSqlServerDatabaseAccessor databaseAccessor = this.GetSqlDatabaseAccessorInstance(request.RequestContext); Customer customer = databaseAccessor.GetCustomerByAccountNumber(request.AccountNumber); return(new SingleEntityDataServiceResponse <Customer>(customer)); }
/// <summary> /// Make the transaction service call to email the receipt. /// </summary> /// <param name="salesOrder">The sales order.</param> private void SendReceiptMail(SalesOrder salesOrder) { List <ReceiptType> receiptTypes = new List <ReceiptType>(); receiptTypes.Add(ReceiptType.SalesReceipt); var emailReceipt = new GetEmailReceiptServiceRequest( salesOrder, receiptTypes, salesOrder.TenderLines, false); var emailResponse = this.Context.Execute <GetEmailReceiptServiceResponse>(emailReceipt); if (emailResponse.Receipts == null || emailResponse.Receipts.Results.Count == 0) { return; } string emailMessage = emailResponse.Receipts.Results[0].Header + emailResponse.Receipts.Results[0].Body + emailResponse.Receipts.Results[0].Footer; emailMessage = this.ConvertToHTML(emailMessage); string language = string.Empty; if (!string.IsNullOrEmpty(salesOrder.CustomerId)) { var getCustomerDataRequest = new GetCustomerDataRequest(salesOrder.CustomerId); SingleEntityDataServiceResponse <Customer> getCustomerDataResponse = this.Context.Runtime.Execute <SingleEntityDataServiceResponse <Customer> >(getCustomerDataRequest, this.Context); Customer customer = getCustomerDataResponse.Entity; if (customer == null) { language = this.Context.GetChannelConfiguration().DefaultLanguageId; } else { language = customer.Language; } } if (string.IsNullOrEmpty(language)) { language = CultureInfo.CurrentUICulture.ToString(); } NameValuePair mapping = new NameValuePair { Name = this.receiptEmailTemplateParameter, Value = emailMessage }; Collection <NameValuePair> mappings = new Collection <NameValuePair>(); mappings.Add(mapping); var emailServiceRequest = new SendEmailRealtimeRequest( salesOrder.ReceiptEmail, mappings, language, string.Empty, this.receiptEmailTemplate); this.Context.Execute <NullResponse>(emailServiceRequest); }
/// <summary> /// Gets the customer by account number. /// </summary> /// <param name="request">The data service request.</param> /// <returns>The data service response.</returns> private static SingleEntityDataServiceResponse <Customer> GetCustomerByAccountNumber(GetCustomerDataRequest request) { var procedure = new GetCustomersProcedure(request.RequestContext); Customer customer = procedure.GetCustomerByAccountNumber(request.AccountNumber); return(new SingleEntityDataServiceResponse <Customer>(customer)); }
/// <summary> /// Executes the workflow to retrieve active product prices for given product ids. /// </summary> /// <param name="request">The request.</param> /// <returns>The response.</returns> protected override GetActiveProductPriceResponse Process(GetActiveProductPriceRequest request) { ThrowIf.Null(request, "request"); var validateCustomerAccountRequest = new GetValidatedCustomerAccountNumberServiceRequest(request.CustomerAccountNumber, throwOnValidationFailure: true); var validateCustomerAccountResponse = this.Context.Execute <GetValidatedCustomerAccountNumberServiceResponse>(validateCustomerAccountRequest); if (validateCustomerAccountResponse.IsCustomerAccountNumberInContextDifferent) { request.CustomerAccountNumber = validateCustomerAccountResponse.ValidatedAccountNumber; } bool downloadedProductsFilter = false; if (request.Context.ChannelId != this.Context.GetPrincipal().ChannelId) { downloadedProductsFilter = true; } var settings = new QueryResultSettings(PagingInfo.CreateWithExactCount(request.ProductIds.Count(), 0)); var productsRequest = new GetProductsDataRequest(request.ProductIds, settings, downloadedProductsFilter); var products = this.Context.Execute <EntityDataServiceResponse <SimpleProduct> >(productsRequest).PagedEntityCollection.Results; var activePrices = new List <ProductPrice>(products.Count); // package sales lines to calculate var salesLines = new List <SalesLine>(products.Count); foreach (var product in products) { salesLines.Add(new SalesLine { ItemId = product.ItemId, InventoryDimensionId = product.InventoryDimensionId, SalesOrderUnitOfMeasure = product.DefaultUnitOfMeasure, LineId = System.Guid.NewGuid().ToString("N"), Quantity = 1, ProductId = product.RecordId, CatalogId = request.Context.CatalogId.GetValueOrDefault() }); } // set the catalogIds on the sales lines if (request.Context.CatalogId != null) { if (request.Context.CatalogId.Value > 0) { // If a specific catalogId is set on the context, add it to the catalogIds on the sales lines. foreach (var sl in salesLines) { sl.CatalogIds.Add(request.Context.CatalogId.Value); } } else { // If catalogId is 0, add all active catalogs to the catalogIds on the sales lines. foreach (var sl in salesLines) { var productCatalogAssociationRequest = new GetProductCatalogAssociationsDataRequest(salesLines.Select(p => p.ProductId)) { QueryResultSettings = QueryResultSettings.AllRecords }; var productCatalogs = request.RequestContext.Runtime.Execute <GetProductCatalogAssociationsDataResponse>( productCatalogAssociationRequest, request.RequestContext).CatalogAssociations; sl.CatalogIds.UnionWith(productCatalogs.Where(pc => pc.ProductRecordId == sl.ProductId).Select(pc => pc.CatalogRecordId)); } } } Customer customer = null; if (!string.IsNullOrWhiteSpace(request.CustomerAccountNumber)) { var getCustomerDataRequest = new GetCustomerDataRequest(request.CustomerAccountNumber); SingleEntityDataServiceResponse <Customer> getCustomerDataResponse = this.Context.Runtime.Execute <SingleEntityDataServiceResponse <Customer> >(getCustomerDataRequest, this.Context); customer = getCustomerDataResponse.Entity; } string priceGroup = customer != null ? customer.PriceGroup : string.Empty; // calculate prices for sales lines var itemPriceServiceRequest = new GetPricesServiceRequest(salesLines, request.DateWhenActive, request.CustomerAccountNumber, priceGroup, PricingCalculationMode.Independent, request.AffiliationLoyaltyTiers); var itemPriceServiceResponse = this.Context.Execute <GetPricesServiceResponse>(itemPriceServiceRequest); var salesLineDictionary = itemPriceServiceResponse.SalesLines.Results.ToDictionary(sl => sl.ProductId); foreach (var product in products) { SalesLine salesLine; if (!salesLineDictionary.TryGetValue(product.RecordId, out salesLine)) { salesLine = new SalesLine(); } ProductPrice activePrice = GetActiveProductPriceRequestHandler.ActivePriceFromSalesLine(product.RecordId, salesLine); activePrice.ProductId = product.RecordId; activePrice.ValidFrom = request.DateWhenActive; activePrice.CurrencyCode = itemPriceServiceResponse.CurrencyCode; activePrice.ChannelId = request.Context.ChannelId.GetValueOrDefault(); activePrice.CatalogId = request.Context.CatalogId.GetValueOrDefault(); activePrices.Add(activePrice); } return(new GetActiveProductPriceResponse(activePrices.AsPagedResult())); }