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:
Figure: Grid layout
data:image/s3,"s3://crabby-images/fed8b/fed8bc6bbd826c7e394c33c744c4467ec1c2b4e2" alt="Grid layout diagram"
Figure: Grid layout with checkboxes
data:image/s3,"s3://crabby-images/c2c0e/c2c0e1b0036ddf3eb622eda0aa0943059a974e8d" 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.
Figure: Enlarged columns
data:image/s3,"s3://crabby-images/db6e3/db6e355c2c4e45f37d6781471398e4ec04cbf7e0" 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.
Figure: Resulting form
data:image/s3,"s3://crabby-images/4e5bb/4e5bb43c498ea68ba556f47bc6556dfc1f1da290" alt="Resulting form screenshot"
GRID
{
[a |b ][f ]
[c|d ][e ]
}
Even if the grid area is wider in the source form file, the real graphical result will be smaller.
Figure: Resulting form
data:image/s3,"s3://crabby-images/408b8/408b8ef03d46e489a397a6a689a0bd46dfb16348" alt="Resulting form screenshot"