Fill whole rows with row style
This commit is contained in:
parent
ddd058e89d
commit
83319fb800
@ -54,6 +54,7 @@ func main() {
|
||||
table3.RowSeparator = true
|
||||
table3.BorderStyle = ui.NewStyle(ui.ColorGreen)
|
||||
table3.SetRect(0, 30, 70, 20)
|
||||
table3.FillRow = true
|
||||
table3.RowStyles[0] = ui.NewStyle(ui.ColorWhite, ui.ColorBlack, ui.ModifierBold)
|
||||
table3.RowStyles[2] = ui.NewStyle(ui.ColorRed)
|
||||
table3.RowStyles[3] = ui.NewStyle(ui.ColorYellow)
|
||||
|
@ -27,6 +27,7 @@ type Table struct {
|
||||
RowSeparator bool
|
||||
TextAlign Alignment
|
||||
RowStyles map[int]Style
|
||||
FillRow bool
|
||||
}
|
||||
|
||||
func NewTable() *Table {
|
||||
@ -56,13 +57,20 @@ func (self *Table) Draw(buf *Buffer) {
|
||||
for i := 0; i < len(self.Rows) && yCoordinate < self.Inner.Max.Y; i++ {
|
||||
row := self.Rows[i]
|
||||
colXCoordinate := self.Inner.Min.X
|
||||
|
||||
rowStyle := self.TextStyle
|
||||
// get the row style if one exists
|
||||
if style, ok := self.RowStyles[i]; ok {
|
||||
rowStyle = style
|
||||
}
|
||||
|
||||
if self.FillRow {
|
||||
blankCell := NewCell(' ', rowStyle)
|
||||
buf.Fill(blankCell, image.Rect(self.Inner.Min.X, yCoordinate, self.Inner.Max.X, yCoordinate+1))
|
||||
}
|
||||
|
||||
// draw row cells
|
||||
for j := 0; j < len(row); j++ {
|
||||
rowStyle := self.TextStyle
|
||||
// get the row style if one exists
|
||||
if style, ok := self.RowStyles[i]; ok {
|
||||
rowStyle = style
|
||||
}
|
||||
col := ParseText(row[j], rowStyle)
|
||||
// draw row cell
|
||||
if len(col) > columnWidths[j] || self.TextAlign == AlignLeft {
|
||||
@ -91,8 +99,13 @@ func (self *Table) Draw(buf *Buffer) {
|
||||
}
|
||||
|
||||
// draw vertical separators
|
||||
separatorStyle := self.Block.BorderStyle
|
||||
if self.FillRow {
|
||||
separatorStyle.Bg = rowStyle.Bg
|
||||
}
|
||||
|
||||
separatorXCoordinate := self.Inner.Min.X
|
||||
verticalCell := NewCell(VERTICAL_LINE, self.Block.BorderStyle)
|
||||
verticalCell := NewCell(VERTICAL_LINE, separatorStyle)
|
||||
for _, width := range columnWidths {
|
||||
separatorXCoordinate += width
|
||||
buf.SetCell(verticalCell, image.Pt(separatorXCoordinate, yCoordinate))
|
||||
@ -102,7 +115,7 @@ func (self *Table) Draw(buf *Buffer) {
|
||||
yCoordinate++
|
||||
|
||||
// draw horizontal separator
|
||||
horizontalCell := NewCell(HORIZONTAL_LINE, self.Block.BorderStyle)
|
||||
horizontalCell := NewCell(HORIZONTAL_LINE, separatorStyle)
|
||||
if self.RowSeparator && yCoordinate < self.Inner.Max.Y && i != len(self.Rows)-1 {
|
||||
buf.Fill(horizontalCell, image.Rect(self.Inner.Min.X, yCoordinate, self.Inner.Max.X, yCoordinate+1))
|
||||
yCoordinate++
|
||||
|
Loading…
Reference in New Issue
Block a user