Dev GuideAPI Reference
Dev GuideAPI ReferenceUser GuideGitHubNuGetDev CommunityOptimizely AcademySubmit a ticketLog In
Dev Guide

Return order form calculator

Describes ReturnOrderFormCalculator, which calculates the total, subtotal, handling total, shipping subtotal, order discount total, discount total, and tax total for a return order form in Optimizely Commerce Connect.

total

Calculates the total for a return order form.

public void GetTotal(IReturnOrderForm returnOrderForm, IMarket market, Currency currency, IReturnOrderFormCalculator returnOrderFormCalculator) {
  var total = returnOrderFormCalculator.GetTotal(returnOrderForm, market, currency);
  Debug.WriteLine("Total for return order form '{0}': {1}", returnOrderForm.OrderFormId, total);
}

subTotal

Calculates the total of all shipments in a return order form.

public void GetSubTotal(IReturnOrderForm returnOrderForm, Currency currency, IReturnOrderFormCalculator returnOrderFormCalculator) {
  var subTotal = returnOrderFormCalculator.GetSubTotal(returnOrderForm, currency);
  Debug.WriteLine("Subtotal for return order form '{0}': {1}", returnOrderForm.OrderFormId, subTotal);
}

handlingTotal

Calculates the handling total for a return order form.

public void GetHandlingTotal(IReturnOrderForm returnOrderForm, Currency currency, IReturnOrderFormCalculator returnOrderFormCalculator) {
  var handlingTotal = returnOrderFormCalculator.GetHandlingTotal(returnOrderForm, currency);
  Debug.WriteLine("Handling total for return order form '{0}': {1}", returnOrderForm.OrderFormId, handlingTotal);
}

shippingSubTotal

Calculates the shipping subtotal for a return order form.

public void GetShippingSubTotal(IReturnOrderForm returnOrderForm, IMarket market, Currency currency, IReturnOrderFormCalculator returnOrderFormCalculator) {
  var shippingSubTotal = returnOrderFormCalculator.GetShippingSubTotal(returnOrderForm, market, currency);
  Debug.WriteLine("Shipping subtotal for return order form '{0}': {1}", returnOrderForm.OrderFormId, shippingSubTotal);
}

orderDiscountTotal

Calculates a return order form's discount amount, which is the sum of all order-level discounts applied to line items across every shipment in the return order form.

public void GetOrderDiscountTotal(IReturnOrderForm returnOrderForm, Currency currency, IReturnOrderFormCalculator returnOrderFormCalculator) {
  var orderDiscountTotal = returnOrderFormCalculator.GetOrderDiscountTotal(returnOrderForm, currency);
  Debug.WriteLine("Order discount total for return order form '{0}': {1}", returnOrderForm.OrderFormId, orderDiscountTotal);
}

discountTotal

Calculates a return order form's discount total, which is the sum of:

  • The order-level discount amount.
  • Line item discount amounts for all line items in all shipments.
  • Shipment discount amounts for all shipments in the return order form.
public void GetDiscountTotal(IReturnOrderForm returnOrderForm, Currency currency, IReturnOrderFormCalculator returnOrderFormCalculator) {
  var discountTotal = returnOrderFormCalculator.GetDiscountTotal(returnOrderForm, currency);
  Debug.WriteLine("Discount total for return order form '{0}': {1}", returnOrderForm.OrderFormId, discountTotal);
}

returnTaxTotal

Calculates the tax total for a return order form.

public void GetReturnTaxTotal(IReturnOrderForm returnOrderForm, IMarket market, Currency currency, IReturnOrderFormCalculator returnOrderFormCalculator) {
  var returnTaxTotal = returnOrderFormCalculator.GetReturnTaxTotal(returnOrderForm, market, currency);
  Debug.WriteLine("Tax total for return order form '{0}': {1}", returnOrderForm.OrderFormId, returnTaxTotal);
}

Change the default calculation

Inherit from DefaultReturnOrderFormCalculator, the default implementation of IReturnOrderFormCalculator, and override one or more of its methods to change the calculation behavior.

public class ReturnOrderFormCalculatorOverridingDefault: DefaultReturnOrderFormCalculator {
  public ReturnOrderFormCalculatorOverridingDefault(IShippingCalculator shippingCalculator, ITaxCalculator taxCalculator): base(shippingCalculator, taxCalculator) {}
  protected override Money CalculateTotal(IReturnOrderForm returnOrderForm, IMarket market, Currency currency) {
    return new Money(0, currency);
  }
  protected override Money CalculateSubtotal(IReturnOrderForm returnOrderForm, Currency currency) {
    return new Money(0, currency);
  }
  protected override Money CalculateHandlingTotal(IReturnOrderForm returnOrderForm, Currency currency) {
    return new Money(0, currency);
  }
  protected override Money CalculateShippingSubTotal(IReturnOrderForm returnOrderForm, IMarket market, Currency currency) {
    return new Money(0, currency);
  }
  protected override Money CalculateReturnTaxTotal(IReturnOrderForm returnOrderForm, IMarket market, Currency currency) {
    return new Money(0, currency);
  }
}

Change the default validation

The default implementation validates that each total is non-negative after calculation. To change the behavior, override the appropriate method: ValidateTotal, ValidateSubtotal, ValidateHandlingTotal, ValidateShippingSubTotal, or ValidateReturnTaxTotal.

public class ReturnOrderFormCalculatorOverridingDefault: DefaultReturnOrderFormCalculator {
  public ReturnOrderFormCalculatorOverridingDefault(IShippingCalculator shippingCalculator, ITaxCalculator taxCalculator): base(shippingCalculator, taxCalculator) {}
  protected override void ValidateTotal(Money money) {
    if (money.Amount < 0) {
      throw new ValidationException("Total must not be negative.");
    }
  }
  protected override void ValidateSubtotal(Money money) {
    if (money.Amount < 0) {
      throw new ValidationException("Subtotal must not be negative.");
    }
  }
  protected override void ValidateHandlingTotal(Money money) {
    if (money.Amount < 0) {
      throw new ValidationException("Handling total must not be negative.");
    }
  }
  protected override void ValidateShippingSubTotal(Money money) {
    if (money.Amount < 0) {
      throw new ValidationException("Shipping subtotal must not be negative.");
    }
  }
  protected override void ValidateReturnTaxTotal(Money money) {
    if (money.Amount < 0) {
      throw new ValidationException("Return tax total must not be negative.");
    }
  }
}