Form item dependencies in grids
Form items interact with each other in terms of width, depending on the front-end widget size.
GRID
{
[a ]
[b ]
}
END
This .per implies that form items a
and b
start at the same position and have the same size, whatever a
and
b
are.
This rule leads to very different results, especially when a large widget is assigned into a small number of cells.
LAYOUT
GRID
{
[a|b ][f ]
[c|d] [e ]
}
END
END
ATTRIBUTES
CHECKBOX a = FORMONLY.a, TEXT="A Checkbox";
EDIT b = FORMONLY.b;
EDIT c = FORMONLY.c;
CHECKBOX d = FORMONLY.d, TEXT="Another Checkbox";
EDIT e = FORMONLY.e;
EDIT f = FORMONLY.f;
END
The grid is computed with regard to the character cells in the form definition:
data:image/s3,"s3://crabby-images/c0f49/c0f49a7490158ff97ba696173f315fe59d3adf07" alt="Grid layout diagram"
data:image/s3,"s3://crabby-images/de765/de765439d87951873ac96b808cafd51c8f7bd4a8" alt="Grid layout with checkboxes diagram"
Then the minimum size of each widget and the layout is computed.
Cells (0,1) and (1,3) contain a checkbox; these checkboxes will enlarge columns 1 and 3.
data:image/s3,"s3://crabby-images/b9555/b95556b327a480b2baf51b2e41141dc5eb1c5e2f" alt="Enlarged columns diagram"
Because the EDIT
field "c
" is defined to have the same width as
checkbox "a
", it will be much larger as expected.
data:image/s3,"s3://crabby-images/e64ca/e64ca5ee63747d2e2e19352293e4681c942819e1" alt="Resulting form screenshot 1"
GRID
{
[a |b ][f ]
[c|d ][e ]
}
END
Even if the grid area is wider in the source form file, the real graphical result will be smaller.
data:image/s3,"s3://crabby-images/4143b/4143b7a1fbb4b83d31ad3d8a0d173f1c051537fc" alt="Resulting form screenshot 2"
STRETCH=X
attribute to the field "f
", and make the last
grid column stretch to the size of the parent container. Note that the underlying field
"e
" will stretch as well, because it belongs to the same grid column as
"f
":EDIT f = formonly.f, STRETCH=X;
data:image/s3,"s3://crabby-images/24a6d/24a6d9c9f5b5d8457b78c8bd9fac7c1cf536ec28" alt="Resulting form screenshot 2"
STRETCH=X
attribute, add the STRETCHMIN=nn
attribute, to force the minimum width:GRID
{
Customer ID: [cid ] <-- width is 8 cells
...
}
END
...
EDIT cid: customer.cust_id, STRETCH=X, STRETCHMIN=3;
...