Layout
This document aims to explain how the layout behavior works for components in Zero-True. Defining a layout is optional but provides a way to explicitly define the position of components defined in a cell. By default, each component is rendered in its own row, taking up the full width available.
Specifying Rows, Cols and Nested Layouts
Zero-True allows you to create complicated nested layouts. These are the docs for columns, rows, and the layout:
pydantic model zero_true.Layout
Layout is an object that contains the list of rows to be rendered.
pydantic model zero_true.Row
Rows can contain both individual components and columns. They are the top level components of a layout and can be subcomponents of columns.
A Column must be a subcomponent of a Row. It can contain both individual components and rows.
Mixed Layouts
If some components are placed in a layout and others are not, the layout will accommodate both:
Rendering Order
Rows defined in the layout will be rendered in the order they are in the list and their subcomponents and columns will be rendered in the order they are defined in the list.
Multiple Rendering
If a row or column is a subcomponent of another row/column or the layout itself, its components will be rendered multiple times wherever it is included.
Component Definition
Any components included in a row, column, or layout must be defined in the cell where that row, column, or layout is defined or they will not be rendered.
Full Width Rendering
All other components not in a row or column will be rendered in the order they are defined in code and take up the full width available, each in their own row.
Example
Here is an example with actual code that shows how the layout works:
And this is the resulting layout: