Plugin to automate and simplify "on-the-fly" calculations. The simplest use is to set the jsAutoCalc="" attribute on an input text tag and call $("*").jAutoCalc();
npm i -P jautocalc
Includes:
- Development version with sourcemaps:
dist/jautocalc.js
- 24KBdist/jautocalc.js.map
- Minimized production version:
dist/jautocalc.min.js
- 8KB
- The calculation is run when one of the value fields gains or loses focus or when the result field is changed. Each calculation is also run once when the page is first loaded in case all the value fields come from the database.
- Field names are defined with braces, i.e. "{tax_amount}". If the field name is prefaced with "!" e.g. "{!tax_amount}" then the value will be used in the equation but it will ignore changes to that field for that equation only.
- Field names can be jquery selectors.
- Whitespace in the calculation is ignored.
- When multiple fields have the same name aggregate functions may be used. The plugin supports:
- SUM
- AVG
- MIN
- MAX
- COUNT - counts all fields
- COUNTNOTEMPTY - counts all non-empty fields
- It can handle add, subtract, multiply, divide, and power (as **) in the proper order of operations. It will respect parentheses.
- It can handle negative numbers and decimal numbers.
- If a calculation value field has no value yet, the result field is set to blank.
- when the result is calculated, the result field's change event is fired. This is so calculations can be chained together. In a shopping cart example, the grand total calculation relies on the subtotal calculation which relies on the sum of the line totals which rely on the quantity and amount fields.
- It will try to figure out what the currency symbol, thousands separator, and decimal separator are and, if found, reuse them in the result field. By default, if it can't figure out the symbols it will use comma for thousands, period for decimal, and no currency symbol.
- attribute (string; default is
'jAutoCalc'
): The name of the attribute to look for to set up the auto calculation. - thousandOpts (string array; default is
[',', '.', ' ']
): Possible options to use as the thousand separator. Will use the first one it finds in the value fields to format the result field. If you know this will always be the same, set the option to a single element array. - decimalOpts (string array: default is
['.', ',']
): Possible options to use as the decimal separator. Will use the first one it finds in the value fields to format the result field. If you know this will always be the same, set the option to a single element array. - decimalPlaces (number; default is
-1
): By default the plugin follows the rules for significant digits (the result is as significant as the least significant value). There are cases when you might want to override this behavior, i.e. shopping cart where the item quantity will be whole numbers, but the item total should contain decimals. - initFire (boolean; default is
true
): After configuring the value and results fields involved in a calculation, should the calculation be fired right away? Useful if the value fields are pre-filled from some other source, e.g. database. - chainFire (boolean: default is
true
): After calculating the result field value should the field be flagged as changed to potentially fire other calculations? - keyEventsFire (boolean: default is
false
): Should the plugin do "instant-calculations" everytime keys are pressed in a value field? By default, calculations are fired when focus is entered or lost on a value field. - readOnlyResults (boolean: default is
true
): Should the plugin mark the result field(s) as read-only and be un-editable by the user? - showParseError (boolean: default is
true
): Should the plugin show the parser errors as an alert box? Useful for debugging/testing. - emptyAsZero (boolean: default is
false
): empty values are treated as zero. - smartIntegers (boolean: default is
false
): numbers like 123.000 treated as 123. - onShowResult (function(el, value): default is
null
): called just before updating element with result. - funcs (dictionary<string, IFunction>: default is
null
): user-defined functions. - vars (dictionary<string, number>: default is
null
): user-defined constants.
<html>
<head>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js"></script>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/[email protected]/dist/jautocalc.js"></script>
<script type="text/javascript">
<!--
$(function() {
function autoCalcSetup() {
$('form#cart').jAutoCalc('destroy');
$('form#cart tr.line_items').jAutoCalc({keyEventsFire: true, decimalPlaces: 2, emptyAsZero: true});
$('form#cart').jAutoCalc({decimalPlaces: 2});
}
autoCalcSetup();
$('button.row-remove').on("click", function(e) {
e.preventDefault();
var form = $(this).parents('form')
$(this).parents('tr').remove();
autoCalcSetup();
});
$('button.row-add').on("click", function(e) {
e.preventDefault();
var $table = $(this).parents('table');
var $top = $table.find('tr.line_items').first();
var $new = $top.clone(true);
$new.jAutoCalc('destroy');
$new.insertBefore($top);
$new.find('input[type=text]').val('');
autoCalcSetup();
});
});
//-->
</script>
</head>
<body>
<form id="cart">
<table name="cart">
<tr>
<th></th>
<th>Item</th>
<th>Qty</th>
<th>Price</th>
<th> </th>
<th>Item Total</th>
</tr>
<tr class="line_items">
<td><button class="row-remove">Remove</button></td>
<td>Stuff</td>
<td><input type="text" name="qty" value="1"></td>
<td><input type="text" name="price" value="9.99"></td>
<td> </td>
<td><input type="text" name="item_total" value="" jAutoCalc="{qty} * {price}"></td>
</tr>
<tr class="line_items">
<td><button class="remove">Remove</button></td>
<td>More Stuff</td>
<td><input type="text" name="qty" value="2"></td>
<td><input type="text" name="price" value="12.50"></td>
<td> </td>
<td><input type="text" name="item_total" value="" jAutoCalc="{qty} * {price}"></td>
</tr>
<tr class="line_items">
<td><button class="remove">Remove</button></td>
<td>And More Stuff</td>
<td><input type="text" name="qty" value="3"></td>
<td><input type="text" name="price" value="99.99"></td>
<td> </td>
<td><input type="text" name="item_total" value="" jAutoCalc="{qty} * {price}"></td>
</tr>
<tr>
<td colspan="3"> </td>
<td>Subtotal</td>
<td> </td>
<td><input type="text" name="sub_total" value="" jAutoCalc="SUM({item_total})"></td>
</tr>
<tr>
<td colspan="3"> </td>
<td>
Tax:
<select name="tax">
<option value=".06">CT Tax</option>
<option selected value=".00">Tax Free</option>
</select>
</td>
<td> </td>
<td><input type="text" name="tax_total" value="" jAutoCalc="{sub_total} * {tax}"></td>
</tr>
<tr>
<td colspan="3"> </td>
<td>Total</td>
<td> </td>
<td><input type="text" name="grand_total" value="" jAutoCalc="{sub_total} + {tax_total}"></td>
</tr>
<tr>
<td colspan="99"><button class="row-add">Add Row</button></td>
</tr>
</table>
</form>
</body>
</html>
See the working example at http://c17r.github.io/jAutoCalc/sample.html