smelt.overlay.layout¶
Tier: UiHost — Requires a terminal UI; calling these from headless mode raises.
Composable layout-tree primitives (leaf/vbox/hbox) for overlays. The resulting userdata is passed to smelt.overlay.new via opts.layout.
smelt.overlay.layout.hbox¶
Horizontal container. items is an array of { child_layout, width = <constraint>, collapse_when_empty = bool? }. opts accepts border, title, gap, padding (uniform inner inset on all sides, inside any border).
smelt.overlay.layout.leaf¶
Wrap a Win handle or paint id into a leaf node. opts accepts border, title, collapse_when_empty (force the slot to zero size when the wrapped window's buffer is empty), measure (a {w, h} table for a static natural size or a smelt.overlay.layout.measure(...) handle for one the plugin can live-update).
smelt.overlay.layout.measure¶
Construct a shareable natural-size handle for use with layout.leaf(opts.measure = ...). Initial size is (w, h) (default (0, 0)); update at any time via handle:set(w, h) to drive a live overlay resize on the next frame. Read current size via handle:get().
smelt.overlay.layout.vbox¶
Vertical container. items is an array of { child_layout, height = <constraint>, collapse_when_empty = bool? }. opts accepts border, title, gap (cells between children), padding (uniform inner inset on all sides, inside any border).