summaryrefslogtreecommitdiffstats
path: root/documentation/articles/RightAlignComparableNumericalFields.asciidoc
blob: 4f835ead59e204fbd3bb9b80733923b38ad2c3bd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
[[right-align-comparable-numeric-fields]]
Right-align comparable numeric fields
-------------------------------------

In the table below, the various numerical fields are kind of hard to
compare and easy misinterpret, because of the alignment of the values:

image:img/table1.png[Table with left alignment]

By right-aligning numerical fields, the values become easier to compare
and less prone to misinterpretation, since the least significant digits
are vertically aligned:

[source,java]
....
Table tblExpenses = new Table();
tblExpenses.setContainerDataSource(expensesData);
tblExpenses.setColumnAlignment("cost", Table.Align.RIGHT);
tblExpenses.setColumnAlignment("vat", Table.Align.RIGHT);
....

image:img/table2.png[Table with right alignment]

This effect is of course ruined if the formats of these fields are
different, such as different number of decimals. Make sure that you’re
using the same format for fields that should be easy to compare.

Even though this example was of a table, the same principles also apply
to input fields. Right-aligning a text field indicates to the user that
a numerical value is expected, and makes multiple numerical fields in
the same form easier to compare. To do this, you’ll need to set up a
custom theme for your application (which you’ll probably end up doing at
some point anyway), set a custom stylename to the field, such as
_“numerical”_ or _“right-aligned”_...

[source,java]
....
TextField tfExpensesLodging = new TextField(“Lodging”);
tfExpensesLodging.addStyleName(“numerical”);
....

...and get your hands dirty with a bit of CSS:

[source,css]
....
.v-textfield.numerical {
  text-align: right;
}
....

Note that right-aligning non-comparable numerical fields, such as
product IDs or ISBNs is kind of pointless, and probably best to avoid.