Formulas

When your customers Add or [AddLineItem] products to their shopping cart, WebCatalog gets the price of the product in one of two ways: the price can come from a field in the database called "price", or it can be calculated based on a formula. To prevent "hacking", WebCatalog never allows remote users to set product prices -- but you can still customize pricing by creating a formula that calculates a different price based on any WebDNA tags, such as [username], [zip], or even a [math] calculation.

**Note**: The GeneralStore example uses a formula to calculate price, taxRate, unitShipCost and overall shipping costs based on the customer's shipping address.

Every time a product is added to the shopping cart, WebCatalog calculates the item's price, taxable, and unitShipCost as follows:

- Look for a file called Formulas.db in the same folder as the shopping cart template itself, and look for a formula called "price"
- If Formulas.db contains a "price" formula, then evaluate the WebDNA expression (in the context of the current lineitem, so tags such as [price], [quantity], [zip] and [sku] are available)
- Set the price of the product based on the calculated formula, or if no formula is found then simply use the "price" field from the product database that corresponds to the the item's SKU
- Repeat the 3 steps above for "unitShipCost"
- Repeat the 3 steps above for "taxable"
- Repeat the 3 steps above for "taxRate", which is applied to the entire order, not just the one item that was added. If no formula is found, then look for a form variable called "taxRate" and use that instead.
- Repeat the 3 steps above for "shipCost", which is applied to the entire order, not just the one item that was added. If no formula is found, then look for a form variable called "shipCost" and use that instead.

Variable (case-sensitive) |
Description |
---|---|

price |
lookup SKU in database, or calculate from formula (applied only to this lineItem being added) |

unitShipCost |
lookup SKU in database, or calculate from formula (applied only to this lineItem being added) |

taxRate |
optional parameter to Add command, or calculate from formula (applied to entire order file) |

shipCost |
optional parameter to Add command, or calculate from formula (applied to entire order file). This number is added to the sum total of all the unitShipCost values to arrive at the shippingTotal for the whole order. |

taxable |
lookup SKU in database, or calculate from formula (applied only to this lineItem being added). The result of the formula must be either T or F. |

The GeneralStore example uses the following formula for price:

[lookup db=catalog.txt&lookInField=sku&value=[sku]&returnField=price]

This formula looks up the price of the product in the database and returns it unchanged. This is for demonstration purposes only, because in this particular case, the formula calculates exactly the same price as though you had not specified a formula at all. To do something more complex, you might perform some calculation based on the visitor's [username] information, like so:

[math][showif [username]=GRANT]0.0*[/showif][lookup db=catalog.txt&lookInField=sku&value=[sku]&returnField=price][/math]

This example would set the price to $0 if the user was logged in as "GRANT",
otherwise the price would be unchanged.

Example Shipping Cost Strategies | |
---|---|

If your charges for shipping are... | ...then the formulas would be as follows: |

$6.95 + $2.00 per additional item | shipCost 4.95 (in Formulas.db) unitShipCost 2.00 (in Formulas.db) When there is 1 item in the cart, the shipTotal will be 4.95+2.00 = 6.95 |

$15.00 flat | shipCost 15.00 (in Formulas.db) unitShipCost 0.00 (in Formulas.db) |

$9.95 base charge + each item has its own handling charge (often based on weight) | shipCost 9.95 (in Formulas.db) "unitShipCost" field in your product database contains numeric cost for each item Erase unitShipCost formula from Formulas.db, so that product database field is used instead of formula. When there is 1 item in the cart, the shipTotal will be 9.95 + [unitShipCost] taken from that SKU's record in the product database. |

$15.00 flat in the state of NJ, $35.00 everywhere else | shipCost [ShowIf [ShipToState]=NJ]15.00[/ShowIf][HideIf [ShipToState]=NJ]35.00[/HideIf] unitShipCost 0.00 (in Formulas.db) |

15% of the subtotal | shipCost [math][subTotal]*.15[/math] (in Formulas.db) unitShipCost 0.00 (in Formulas.db) |