Page tree

Playground and DEMO space

This is a playground and demo space for ConfiForms and ConfiDoc addons developed and supported by Vertuna LLC

Most pages provide a storage format for the demo, so you can use the free add-on from Atlassian Confluence Source Editor to import this configuration into your Confluence and see it in action

To import examples from the storage format on Confluence Cloud please see this page

Please note, all the examples here are provided without any obligation and may or may not be incomplete or may have bugs, and we provide NO SUPPORT for these examples and demos.

Here is a simple demo to show how the formula fields can be used 

We have 2 types of fields for calculations:

  • Calculated - which is calculated ONLY when the record is created
  • Formula - which is calculated and re-calculated each time the record is saved (created or updated)

You can use any of the functions or operations documented here: Supported math operators, formulas and functions

There is also a way to do calculations with ConfiForms Field Definition Rules


Here we have a simple form with 4 fields:

2 of number types and 3 of formula types

We have the following formulas in this form:

  • ([entry.f1] + [entry.f2])
  • (ROUND([entry.f1] / [entry.f2],2))
  • CONCAT("Some random: ", ((RANDOM() + [entry.f1] - [entry.f2] + NOW())))

Example configuration of a formula field:


Stored data

f1

f2

My formula 0

My formula 1

My formula 2

2 2 1 4 Some random: 1711689792327.949
1 2 0.5 3 Some random: 1711689792334.870
1 1 1 2 Some random: 1711689792336.030
1 2 0.5 3 Some random: 1711689792336.584
4 4 1 8 Some random: 1711689792337.064
4 4 1 8 Some random: 1711689792338.241
7 8 0.88 15 Some random: 1711689792338.923
1 2 0.5 3 Some random: 1711689792339.479
8 9 0.89 17 Some random: 1711689792340.119
4 5 0.8 9 Some random: 1711689792341.602
100 1 100 101 Some random: 1711689792441.809
100 1 100 101 Some random: 1711689792442.849
2 3 0.67 5 Some random: 1711689792343.396
1 1 1 2 Some random: 1711689792344.009
1 2 0.5 3 Some random: 1711689792344.454
10 10 1 20 Some random: 1711689792346.289
1 2 0.5 3 Some random: 1711689792346.151
1 1 1 2 Some random: 1711689792348.898
100 50 2 150 Some random: 1711689792399.063
1 2 0.5 3 Some random: 1711689792349.075
11 13 0.85 24 Some random: 1711689792348.267
23 44 0.52 67 Some random: 1711689792330.706
1 2 0.5 3 Some random: 1711689792350.267
1 3 0.33 4 Some random: 1711689792350.387
5 5 1 10 Some random: 1711689792352.831
20 20 1 40 Some random: 1711689792353.831
1 1 1 2 Some random: 1711689792354.245
1 2 0.5 3 Some random: 1711689792353.802
1 3 0.33 4 Some random: 1711689792353.118
1 2 0.5 3 Some random: 1711689792354.767
5 5 1 10 Some random: 1711689792357.519
10 2 5 12 Some random: 1711689792368.054
2 2 1 4 Some random: 1711689792361.207
5 4 1.25 9 Some random: 1711689792363.290
3 2 1.5 5 Some random: 1711689792365.594
1 2 0.5 3 Some random: 1711689792364.135
2 2 1 4 Some random: 1711689792366.300
5 5 1 10 Some random: 1711689792366.946
3 3 1 6 Some random: 1711689792367.950
22 100 0.22 122 Some random: 1711689792289.816
3 3 1 6 Some random: 1711689792368.811
1 2 0.5 3 Some random: 1711689792368.990
1 1 1 2 Some random: 1711689792370.832
1 0 0 1 Some random: 1711689792372.606
1 2 0.5 3 Some random: 1711689792371.494
1 1 1 2 Some random: 1711689792380.107
33 33 1 66 Some random: 1711689792382.923
545 556 0.98 1101 Some random: 1711689792372.942
545 556 0.98 1101 Some random: 1711689792373.166
3 6 0.5 9 Some random: 1711689792382.932
1 2 0.5 3 Some random: 1711689792384.259
20 10 2 30 Some random: 1711689792396.158
12 12 1 24 Some random: 1711689792387.093
7 5 1.4 12 Some random: 1711689792389.407
11 14 0.79 25 Some random: 1711689792385.680
1 2 0.5 3 Some random: 1711689792388.410
2 2 1 4 Some random: 1711689792392.730
1 2 0.5 3 Some random: 1711689792392.501
24 1 24 25 Some random: 1711689792417.696
13 13 1 26 Some random: 1711689792394.245
100 10 10 110 Some random: 1711689792485.300
2 2 1 4 Some random: 1711689792396.657
5 0 0 5 Some random: 1711689792402.900
0 1 0 1 Some random: 1711689792397.966
5 5 1 10 Some random: 1711689792399.656
2 2 1 4 Some random: 1711689792400.612
-2 2 -1 0 Some random: 1711689792398.977
8 9 0.89 17 Some random: 1711689792402.300
15 1 15 16 Some random: 1711689792417.963
1 1 1 2 Some random: 1711689792404.925
1 1 1 2 Some random: 1711689792405.872
1 1 1 2 Some random: 1711689792405.105
1 2 0.5 3 Some random: 1711689792405.020
45 5 9 50 Some random: 1711689792447.591
2 2 1 4 Some random: 1711689792408.964
2 2 1 4 Some random: 1711689792409.036
5 10 0.5 15 Some random: 1711689792405.426
3 2 1.5 5 Some random: 1711689792411.673
11 13 0.85 24 Some random: 1711689792409.892
22 22 1 44 Some random: 1711689792411.137
2 2 1 4 Some random: 1711689792412.421
1 2 0.5 3 Some random: 1711689792411.707
5 5 1 10 Some random: 1711689792413.274
6 125 0.05 131 Some random: 1711689792295.338
23 32312 0 32335 Some random: 1711689760126.904
1 1 1 2 Some random: 1711689792416.988
1 2 0.5 3 Some random: 1711689792416.690
2 2 1 4 Some random: 1711689792418.651
100 200 0.5 300 Some random: 1711689792319.077
2 2 1 4 Some random: 1711689792420.545
3 5 0.6 8 Some random: 1711689792419.182
3 4 0.75 7 Some random: 1711689792421.723
1 2 0.5 3 Some random: 1711689792421.158
1 2 0.5 3 Some random: 1711689792422.692
5 8 0.62 13 Some random: 1711689792420.990
3 8 0.38 11 Some random: 1711689792419.026
1 1 1 2 Some random: 1711689792425.835
5 3 1.67 8 Some random: 1711689792427.627
10 5 2 15 Some random: 1711689792431.417
1 2 0.5 3 Some random: 1711689792425.612
2 2 1 4 Some random: 1711689792427.491
2 123 0.02 125 Some random: 1711689792307.401
480 60 8 540 Some random: 1711689792849.519
300 20 15 320 Some random: 1711689792709.838
123 321 0.38 444 Some random: 1711689792232.716
6 509 0.01 515 Some random: 1711689791928.979
10 5 2 15 Some random: 1711689792436.782
([entry.f1] + [entry.f2]) ([entry.f1] + [entry.f2]) Expression: [(ROUND(([entry.f1] + [entry.f2]) / ([entry.f1] + [entry.f2]),2))] could not be calculated, Unknown operator '[' at position 9 Expression: [(([entry.f1] + [entry.f2]) + ([entry.f1] + [entry.f2]))] could not be calculated, Unknown operator '[' at position 3 Expression: [CONCAT("Some random: ", ((RANDOM() + ([entry.f1] + [entry.f2]) - ([entry.f1] + [entry.f2]) + NOW())))] could not be calculated, Unknown operator '[' at position 39
100 200 0.5 300 Some random: 1711689792340.897
3 4 0.75 7 Some random: 1711689792440.327
1 2 0.5 3 Some random: 1711689792441.820
3 3 1 6 Some random: 1711689792443.058
2 5 0.4 7 Some random: 1711689792441.277



Storage format for this demo:

<ac:structured-macro ac:macro-id="e44fca82-119b-4e79-b70a-1d521f0f13e3" ac:name="confiform" ac:schema-version="1">
  <ac:parameter ac:name="formName">myform1</ac:parameter>
  <ac:rich-text-body>
    <ac:structured-macro ac:macro-id="9930843c-b7ee-493d-b93d-6c91cf13da7a" ac:name="confiform-entry-register" ac:schema-version="1">
      <ac:parameter ac:name="embedded">true</ac:parameter>
      <ac:rich-text-body>
        <p>
          <br/>
        </p>
      </ac:rich-text-body>
    </ac:structured-macro>
    <p>
      <ac:structured-macro ac:macro-id="c1d112a1-145d-4822-9263-57e7f1d95202" ac:name="confiform-field-definition" ac:schema-version="1">
        <ac:parameter ac:name="fieldName">f1</ac:parameter>
        <ac:parameter ac:name="fieldLabel">f1</ac:parameter>
        <ac:parameter ac:name="type">number</ac:parameter>
        <ac:parameter ac:name="required">true</ac:parameter>
      </ac:structured-macro>
    </p>
    <p>
      <ac:structured-macro ac:macro-id="5b285aed-c238-42cb-8fb0-74b504f51edd" ac:name="confiform-field-definition" ac:schema-version="1">
        <ac:parameter ac:name="fieldName">f2</ac:parameter>
        <ac:parameter ac:name="fieldLabel">f2</ac:parameter>
        <ac:parameter ac:name="type">number</ac:parameter>
        <ac:parameter ac:name="required">true</ac:parameter>
      </ac:structured-macro>
    </p>
    <p>
      <ac:structured-macro ac:macro-id="9981f97b-d090-401d-95d2-b19d45a4df9f" ac:name="confiform-field-definition" ac:schema-version="1">
        <ac:parameter ac:name="fieldName">myformula1</ac:parameter>
        <ac:parameter ac:name="fieldLabel">My formula 1</ac:parameter>
        <ac:parameter ac:name="extras">([entry.f1] + [entry.f2])</ac:parameter>
        <ac:parameter ac:name="type">formula</ac:parameter>
      </ac:structured-macro>
    </p>
    <p>
      <ac:structured-macro ac:macro-id="f6b5b3d7-3462-4068-b23c-2ccee3789f66" ac:name="confiform-field-definition" ac:schema-version="1">
        <ac:parameter ac:name="fieldName">myformula2</ac:parameter>
        <ac:parameter ac:name="fieldLabel">My formula 2</ac:parameter>
        <ac:parameter ac:name="extras">CONCAT("Some random: ", ((RANDOM() + [entry.f1] - [entry.f2] + NOW())))</ac:parameter>
        <ac:parameter ac:name="type">formula</ac:parameter>
      </ac:structured-macro>
    </p>
  </ac:rich-text-body>
</ac:structured-macro>
<p>Stored data</p>
<ac:structured-macro ac:macro-id="1d573801-7d23-412f-aa1e-c3c04d1fcc63" ac:name="confiform-table" ac:schema-version="1">
  <ac:parameter ac:name="formName">myform1</ac:parameter>
  <ac:rich-text-body>
    <p>
      <ac:structured-macro ac:macro-id="dc71204e-5341-4543-af04-45ab036c827d" ac:name="confiform-field" ac:schema-version="1">
        <ac:parameter ac:name="fieldName">f1</ac:parameter>
      </ac:structured-macro>
    </p>
    <p>
      <ac:structured-macro ac:macro-id="12af5c9f-b5bb-475e-b9c1-470d60b3bd6c" ac:name="confiform-field" ac:schema-version="1">
        <ac:parameter ac:name="fieldName">f2</ac:parameter>
      </ac:structured-macro>
    </p>
    <p>
      <ac:structured-macro ac:macro-id="0c76996a-654f-4b77-848b-9d8b2212a85f" ac:name="confiform-field" ac:schema-version="1">
        <ac:parameter ac:name="fieldName">myformula1</ac:parameter>
      </ac:structured-macro>
    </p>
    <p>
      <ac:structured-macro ac:macro-id="9a8cf996-366b-4a8b-be43-da01d32dc449" ac:name="confiform-field" ac:schema-version="1">
        <ac:parameter ac:name="fieldName">myformula2</ac:parameter>
      </ac:structured-macro>
    </p>
  </ac:rich-text-body>
</ac:structured-macro>
  • No labels