public class PriceRangeShippingCalculator extends DoubleRangeShippingCalculator
ranges property.
With the given array of price range configurations (format: low:high:price)
the service parses the values into their double format for use in calculating shipping costs.
For example:
ranges=00.00:15.99:4.50,\
16.00:30.99:6.00,\
31.00:40.99:7.25,\
41.00:MAX_VALUE:10.00
Note: the keyword MAX_VALUE indicates a top end
If the property addAmount is true then instead of setting the price quote amount to the value
of the amount property, the calculator adds the amount to the current amount in the
price quote. This can be used to configure a "surcharge" calculator, which increases the shipping
price.
The shippingMethod property should be set to the name of a particular delivery process.
For example: UPS Ground, UPS 2-day or UPS Next Day.
If the ignoreShippingMethod property is true, then this calculator does not
expose a shipping method name (through getAvailableMethods). In addition this calculator will
always attempt to perform pricing. This option is available if the user is not given a choice
of different shipping methods.
| Modifier and Type | Field and Description |
|---|---|
static java.lang.String |
CLASS_VERSION
Class version string
|
mAmounts, MAX_VALUE_KEY, mHighRanges, mLowRanges, TOKENSERVICE_INFO_KEYDEFAULT_LOG_TRACE_STATUSDEFAULT_LOG_DEBUG_STATUS, DEFAULT_LOG_ERROR_STATUS, DEFAULT_LOG_INFO_STATUS, DEFAULT_LOG_WARNING_STATUS| Constructor and Description |
|---|
PriceRangeShippingCalculator()
Constructs an instanceof PriceRangeShippingCalculator
|
| Modifier and Type | Method and Description |
|---|---|
protected double |
getRangeComparisonValue(Order pOrder,
ShippingGroup pShippingGroup)
Return the value which should be used as a comparison between the range values
|
protected double |
getRangeComparisonValue(ShippingGroup pShippingGroup)
Deprecated.
|
protected double |
getSubTotal(Order pOrder,
ShippingGroup pShippingGroup)
Return the sub total of all the items in the shipping group.
|
doStartService, getAmount, getRanges, initializeRanges, setRangesgetAmount, getAvailableMethods, getPricingTools, getShippingMethod, haveItemsToShip, isAddAmount, isIgnoreShippingMethod, performPricing, priceShippingGroup, priceShippingPriceInfo, resetShippingPriceInfo, setAddAmount, setIgnoreShippingMethod, setPricingTools, setShippingMethodaddLogListener, createAdminServlet, doStopService, getAbsoluteName, getAdminServlet, getAdminServletOutputStreamEncoding, getLoggingForVlogging, getLogListenerCount, getLogListeners, getName, getNameContext, getNucleus, getRoot, getServiceConfiguration, getServiceInfo, isAdminServletUseServletOutputStream, isLoggingDebug, isLoggingError, isLoggingInfo, isLoggingTrace, isLoggingWarning, isRunning, logDebug, logDebug, logDebug, logError, logError, logError, logInfo, logInfo, logInfo, logTrace, logTrace, logTrace, logWarning, logWarning, logWarning, nameContextElementBound, nameContextElementUnbound, removeLogListener, reResolveThis, resolveName, resolveName, resolveName, resolveName, sendLogEvent, setAdminServletOutputStreamEncoding, setAdminServletUseServletOutputStream, setLoggingDebug, setLoggingError, setLoggingInfo, setLoggingTrace, setLoggingWarning, setNucleus, setServiceInfo, startService, stopServicevlogDebug, vlogDebug, vlogDebug, vlogDebug, vlogDebugTrace, vlogError, vlogError, vlogError, vlogError, vlogInfo, vlogInfo, vlogInfo, vlogInfo, vlogTrace, vlogTrace, vlogTrace, vlogTrace, vlogWarning, vlogWarning, vlogWarning, vlogWarningpublic PriceRangeShippingCalculator()
protected double getRangeComparisonValue(ShippingGroup pShippingGroup) throws PricingException
getRangeComparisonValue in class DoubleRangeShippingCalculatorpShippingGroup - the group that should be inspected for a value which falls
between configured range values.PricingException - if there was a problem discovering the range comparison valueprotected double getRangeComparisonValue(Order pOrder, ShippingGroup pShippingGroup) throws PricingException
getRangeComparisonValue in class DoubleRangeShippingCalculatorpShippingGroup - the group that should be inspected for a value which falls
between configured range values.PricingException - if there was a problem discovering the range comparison valueprotected double getSubTotal(Order pOrder, ShippingGroup pShippingGroup)
order is null, then the subtotal is calculated
by summing the ItemPriceInfo values for the items in the shipping group.
(Warning: This will not take order level discounts into consideration)
If order is not null, then it is used to get the
given shipping group's subtotal from the order's OrderPriceInfo and
used as the sub total. (This DOES take order level discounts into
consideration.)