termui/_widget/par.go

72 lines
1.5 KiB
Go
Raw Normal View History

// +build ignore
2015-03-20 14:21:50 -06:00
// Copyright 2015 Zack Guo <gizak@icloud.com>. All rights reserved.
// Use of this source code is governed by a MIT license that can
// be found in the LICENSE file.
2015-02-03 12:13:51 -07:00
package termui
2015-03-24 15:16:43 -06:00
// Par displays a paragraph.
/*
par := termui.NewPar("Simple Text")
par.Height = 3
par.Width = 17
par.Border.Label = "Label"
*/
type Par struct {
2015-02-03 18:56:49 -07:00
Block
Text string
TextFgColor Attribute
TextBgColor Attribute
RendererFactory TextRendererFactory
2015-02-03 12:13:51 -07:00
}
2015-03-24 15:16:43 -06:00
// NewPar returns a new *Par with given text as its content.
func NewPar(s string) *Par {
return &Par{
Block: *NewBlock(),
Text: s,
TextFgColor: theme.ParTextFg,
TextBgColor: theme.ParTextBg,
RendererFactory: PlainRendererFactory{},
}
2015-02-03 12:13:51 -07:00
}
2015-03-24 15:16:43 -06:00
// Buffer implements Bufferer interface.
func (p *Par) Buffer() []Point {
2015-02-03 18:56:49 -07:00
ps := p.Block.Buffer()
2015-02-03 12:13:51 -07:00
fg, bg := p.TextFgColor, p.TextBgColor
sequence := p.RendererFactory.TextRenderer(p.Text).Render(fg, bg)
runes := []rune(sequence.NormalizedText)
y, x, n := 0, 0, 0
for y < p.innerHeight && n < len(runes) {
point, width := sequence.PointAt(n, x+p.innerX, y+p.innerY)
if runes[n] == '\n' || x+width > p.innerWidth {
y++
x = 0 // set x = 0
if runes[n] == '\n' {
n++
2015-02-03 12:13:51 -07:00
}
if y >= p.innerHeight {
ps = append(ps, newPointWithAttrs('…',
p.innerX+p.innerWidth-1,
p.innerY+p.innerHeight-1,
p.TextFgColor, p.TextBgColor))
break
}
2015-02-03 12:13:51 -07:00
continue
}
ps = append(ps, point)
n++
x += width
2015-02-03 12:13:51 -07:00
}
return p.Block.chopOverflow(ps)
2015-02-03 12:13:51 -07:00
}