15Sep, 2016

8Comments

Categories / Tutorials By Benoît Raymond

*Automate your calculations with the Calculation element.*

Insert a calculation field and access its features: Go to the element options by clicking on the **pencil**.

Several options are available to you under the **Properties** tab:

- Define how many
**digits after the decimal point**will be included in your results.

- Define the
**type**of results in your calculation: number or time.

- By checking the
**Editable entry**box, you can change the results of your calculation. For example, if you want to round the results.

Under the **Calculation** tab, you will define the fields to calculate.

The **Calculation** tool has several functions.

Consider the following example: You want the price for an order to be automatically calculated.

In the back-office.

Example: Start by inserting an** Input field **and go to its properties:

Rename it according to the needs of your form and choose the type that you need. In our example, the **Entry field** will be called “Price” and will be a “decimal number” type.

- Insert as many
**Input fields**as necessary to make your calculation and set the properties of these fields. - Then insert your
**Calculation** **Add the “Price” field**in the ‘formula of calculation’.

Note : To define what multiplication is, you must enter ” * ” on the keyboard. Calculation signs are performed manually on the keyboard.

- Multiply with another field, like “Quantity” as shown here.

Once completed, confirm and save your form.

Consider the example of an employee time sheet.

- Create your time sheet form: A
**table**with a list of participants and a**numeric entry field**where you specify the number of hours worked.

/!\ ATTENTION /!\ **Specify clearly the “numeric” type.**

- Add an
**external****Calculation**field to the table.

- Define the field: According to the example, the field will make the sum of the “Hours worked” column.

- Confirm and save your form.

This feature enables it to work from the outset with a Referential list, but we would prefer to use the **Reference** element, which was developed expressly for this feature.

For those who already work with **Referential lists** and **Calculation** fields, this feature still works..

Idea: With the **Referential** and **Calculation** elements, you have the option to create a proper purchase order form. In order to obtain an identical document to your current purchase orders, you can create a Word template. Refer to the “purchase order” example, which is located in our forms library.

The **Uniq Number **allows you to create a random line. As an example, we will use the **Uniq number** to create the P.O number of your Purchase Order.

- Add a
**Calculation**field and go in its option, ‘calculation’ tab. - In the drop-down menu, select ‘Uniq number’.

**/!\ **Don’t forget to** confirm**** **your settings and** ****save **your form**.**

The **ItemRefNum** makes data reading easier. It is similar to the Reference field. It reads information contained in a given column. It is usually linked to an NFC Tag or an Input Field.

To discover how to configure your NCF tag, do not hesitate to check our tutorial!

You can condition your calculations through different operators:

List of operators

- + : addition and concatenation of text
- – : substraction
- / : division
- * : multiplication
- % : modulo or remainder of Euclidean division

- < : lesser than
- <= : Less than or equal to
- > : greater than
- >= : greater than or equal to
- == : equality
- ! = : inequality
- === : strict equality
- !== : strict inequality

- && : logical operator AND
- || : logical operator OR
- ! : negation
- ? : ternary operator. It is written in the form: ((condition)? Value_if_true: value_if_false)

- & : AND “bitwise”
- | : OR “bitwise”

Perform a calculation according to a checkbox

In order to perform a different calculation according to a checkbox, you can use the following formula:

**Check box? my calculation or my text if my box is checked: my calculation or my text if my box is not checked.**

In the example below, we want to apply a 5% discount if our box is checked.

For this, we test whether our apply 5% discount? box is checked or not. The deduction will be applied if the box is checked.

Give a value in a calculation if an element is selected in a list

In order to give a value in our calculation when an element is selected in a list, we use the following formula:

**List == value code A? Value if true: Value if false**

In the example below, we applied it to our calculation to offer VAT if New Customer is selected.

At first, we assign a code to our list, of the form code: list. This code will of course not be visible on the mobile device.

We then test if our new client has been selected.

**Warning:** if you add text, remember to remove the + which is generated automatically.

Perform operations with conditions - example: average

In the example below, we want to achieve a grade average of 0 to 10 and not to consider an item that is not applicable.

In our Slider elements, we select the type Text and we add our different notes, for the Not applicable, we give it a code, -1:

0

1

2

3

4

5

6

7

8

9

10

-1:Not applicable

In our Calculation element, we test whether the non-applicable element is entered or not. For this we use the following formulas:

- my_slider == -1?0:my_slider <- so, if Not applicable is selected, its value in the calculation will be equal to 0, otherwise the chosen value will be taken into account. This operation will allow us to know the selected note.
- my_slider == -1?0:1<- thus, if Not applicable is selected, the value taken into account during the computation will be equal to 0; otherwise, it will be equal to 1. This formula will be used for the division to know how many items have been entered.

By repeating the first calculation for each slider element and then dividing by the second, we get the calculation below:

Display a result if a field is equal to another field

In order to display a result when a field is equal to another field, we use the following formula:

**Element A == element B? Value if identical: Value if different**

In the example below, we applied it to two input fields to check if the email addresses are identical.

**Warning:** if you add text, remember to remove the + which is generated automatically.

Using two conditions - example: display a result if a field is greater than, less than, or equal to another field

If you want to combine several conditions, you can use the following formula:

**Our first condition? Value if true: Our second condition? Value if true: Value if false**

If the first condition is false, we test the second, etc., until we reach the “Value if false”

In the example below, we test our A value and B value to find out if A is greater than, less than or equal to B. We use the following formulas:

**Element A <element B? Value if true: Value if false****Element A> element B? Value if true: Value if false**

Combined, we get the operation below:

**Warning:** if you add text, remember to remove the + which is generated automatically.

OR Function (||)

To perform a calculation if a box is checked or if an item is entered, you can use this formula:

**Our first condition || Our second condition? Value if true: Value if false**

At first, we will test the first condition, if it turns out wrong, we will test the second, so on.

In the example below, we test our input field. If it contains 0, 2, 4, 6, 8 or 10, then Even will appear, otherwise it will be Odd.

**Warning:** if you add text, remember to remove the + which is generated automatically.

**Note:** we could also have used the percentage (%) to perform this operation. The Percentage allows to display the rest during a division. Thus, if the number is even, the division will not have any remainder and the calculation will be equal to 0.

AND Function (&&)

To perform a calculation if a box is checked and an item is entered, you can use this formula:

**Our first condition && Our second condition? Value if true: Value if false**

In the example below, we wish:

- Make a
**reduction of 10 €**if the box New customer is checked **Add a 10% or 20% VAT**if the respective boxes are checked.

Thus, we test respectively:

- If the box New customer is checked
- If the box New customer and VAT 10% are ticked
- If the box New customer and VAT 20% are ticked
- If the 10% VAT box is checked
- If the VAT 20% box is checked,

**Warning:** if you add text, remember to remove the + which is generated automatically.

Do not hesitate to comment on this article!

All your questions, comments and suggestions are most welcome!

Agriculture API application Checklist comparison construction COVID19 Customize your report Daily reports data collection Digital Forms Digitization external list Field Service Forms Automation FTP Health Healthcare Hospitality hours worked Human Resource Inspection Intervention Inventory Kizeo forms Kizeo team Maintenance Manufacturing mobile apps Mobile Forms New Release Paperless push Quality Risk Management Safety Sales Department table tags Testimonial Tips & Tricks Transport Updates Vehicles Windows

Our website uses cookies to offer the best browsing experience possible. Cookies perform functions like recognizing the user, measuring internet audience and allowing you to share content on social media. Find more on our cookies policy.

## There Are 8 Comments

## Riccardo

03 Apr, 2019

Dear Adeline Lucarelli,

Thanks for you kind answer. I understand that the software uses the trailing zero the same way spreadsheets use apostrophe.

The zeroes are in some cells by default. The users are more than informed that they have to delete the zero before writing the next value: it is them who reported that the action of “deleting nothing” (deleting the zeroes) is redundant and annoying.

Alternatively, is there an option so that, when I click on a cell, all the contents get selected, and whatever I write overwrites the older content? This way, the trailing zeroes would get automatically overwritten by the new numbers.

Thank you in advance.

## Adeline Lucarelli

04 Apr, 2019

Good morning Mr Felletti,

I understand that the removal of 0 can be annoying for your users, but unfortunately we do not have a field that automatically crush the 0 before a number.

I remain at your disposal if you need.

Sincerely

## Riccardo

01 Apr, 2019

We have a problem with trailing zeroes. For some reason, the software is unable to understand that (for example) “042” and “42” are the same number; “042” is treated as a text string.

EXAMPLE: if in three cells we have “25”, “025” and “05”, the result we get is “2 502 505” instead of the correct 55.

Deleting the zero before typing the data in dozens of cells in a row is an annoying waste of time: we would really need to find the other solution.

## Adeline Lucarelli

01 Apr, 2019

Hi,

This operation is voluntary.

We have customers using the calculation field to make phone numbers for example, so we need the 0 to be kept and numbers to be cumulated.

We understand your need but it would be necessary that your users do not use the 0 before a number. To inform them, you can open your field and go in the “advanced” tab to use the following Regular expressions input mask: ^[1-9][0-9]*$

I remain at your disposal if you need.

Sincerely

## Mark Strickland

05 Jan, 2019

Hi,

I am trying to export a calculation field in an excel report (i.e ##calculation##) by nothing appears. Is there a way to export calculations?

TIA

## Sarah Marivaux

07 Jan, 2019

Dear Mark.

With the correct tag, your calculation field should appears.

Could you send the name of your form to support[@]kizeo.com in order to have a look on your template?

Best regards,

## Bram Jansen

31 Jul, 2018

Hi,

I’m trying to calculate the next date my items need to re-inspected. The format i’d like to use is (Date field)+ 365 (days) or 12 (months.)

Is there a way to make this happen?

## Sarah Marivaux

31 Jul, 2018

Hi,

Unfortunately, it is not currently possible to calculate a date.

The only possibility is to use your Date & Time field and the Default date option (In a year time).

Best regards,

## Post a comment