UI.AutoGrid 
Name 
Mandatory 
Description 
Default 
Type 
 
 
⬅️ InputThe input of the shard, if any 
[Any] 
Output ➡️The resulting output of the shard 
[Any] 
ContentsThe UI contents to be generated and inserted in each column for each element in the given sequence. 
noneNoneShard[Shard] 
StripedWhether to alternate a subtle background color to every other row. 
falseBoolVar(Bool)None 
MaxGridWidthMaximum grid width. 
noneFloatVar(Float) 
ItemWidthThe width of each item. 
noneFloatVar(Float) 
ColumnSpacingSpacing between columns. 
noneFloatVar(Float) 
RowSpacingSpacing between rows. 
noneFloatVar(Float) 
MaxTileHeightMaximum height of each tile for viewport culling. 
noneFloatVar(Float) 
 
 
Works like UI.Grid, but given a Sequence, it will, it each object in the Sequence, execute the Shard provided in its Contents and automatically wrap the generated contents when it exceeds the grid's width.
Examples 
 1 
 2 
 3 
 4 
 5 
 6 
 7 
 8 
 9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 @wire(ui-wire {
  UI.Window(
    Title: "Greetings"
    Contents: {
      [
        "Hello" "World" "Please" "Sort" "Me"
        "Hello" "World" "Please" "Sort" "Me"
      ]
      UI.AutoGrid(
        ItemWidth: 300.0
        MaxGridWidth: 700.0 ; Since item size is 300, max grid width is 700, only two items allowed per row
        Contents: {
          UI.Button(Label: "Test" Action: {
            Log ; Logs the given sequence element
          })
        }
      )
      ; | Log ; Passthrough
    }
  )
} Looped: true)
{ui-behavior: ui-wire}
 
 1 
 2 
 3 
 4 
 5 
 6 
 7 
 8 
 9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 @wire(ui-wire {
  UI.Window(
    Title: "Greetings"
    Contents: {
      [
        "Hello" "World" "Please" "Sort" "Me"
        "Hello" "World" "Please" "Sort" "Me"
      ]
      UI.AutoGrid(
        ItemWidth: 300.0
        MaxGridWidth: 700.0
        ColumnSpacing: 50.0 ; Spacing between columns, not included in MaxGridWidth
        RowSpacing: 30.0 ; Spacing between rows
        Contents: {
          UI.Button(Label: "Test" Action: {
            Log
          })
        }
      )
    }
  )
} Looped: true)
{ui-behavior: ui-wire}
 
 1 
 2 
 3 
 4 
 5 
 6 
 7 
 8 
 9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 @wire(ui-wire {
  UI.Window(
    Title: "Greetings"
    Width: 200 ; Makes window resizable but with a minimum width of 200, allowing resizing window to manipulate number of rows in autogrid
    Contents: {
      [
        "Hello" "World" "Please" "Sort" "Me"
        "Hello" 2 "Please" 4 5.5
      ]
      UI.AutoGrid(
        ItemWidth: 300.0
        Contents: {
          UI.Button(Label: "Test" Action: {
            Log ; Logs the given sequence element
          })
        }
      )
      ; | Log ; Passthrough
    }
  )
} Looped: true)
{ui-behavior: ui-wire}