commands (/nick, /me)
This commit is contained in:
parent
68525224d5
commit
221cbab51a
2 changed files with 106 additions and 45 deletions
66
display.go
66
display.go
|
|
@ -3,6 +3,7 @@ package main
|
|||
import (
|
||||
"fmt"
|
||||
"math"
|
||||
"strings"
|
||||
|
||||
"codeberg.org/lobo/nanite/widgets/pager"
|
||||
"git.sr.ht/~rockorager/vaxis"
|
||||
|
|
@ -31,9 +32,8 @@ func (app *App) resize() {
|
|||
app.dirty = true
|
||||
|
||||
win := app.vx.Window()
|
||||
app.w.log = win.New(0, 1, win.Width, win.Height-3)
|
||||
app.w.log = win.New(0, 1, win.Width, win.Height-2)
|
||||
app.w.title = win.New(0, 0, win.Width, 1)
|
||||
app.w.status = win.New(0, win.Height-2, win.Width, 1)
|
||||
app.w.input = win.New(0, win.Height-1, win.Width, 1)
|
||||
app.pager.Offset = math.MaxInt
|
||||
}
|
||||
|
|
@ -49,7 +49,7 @@ func (app *App) Redraw() {
|
|||
titlebarStyle := vaxis.Style{Attribute: vaxis.AttrBold}
|
||||
|
||||
if app.conn != nil {
|
||||
app.vx.SetTitle(fmt.Sprintf("nanite (%s:%s)", app.host, app.port))
|
||||
app.vx.SetTitle(fmt.Sprintf("%s:%s", app.host, app.port))
|
||||
app.w.title.PrintTruncate(0,
|
||||
vaxis.Segment{
|
||||
Text: "• ",
|
||||
|
|
@ -78,19 +78,59 @@ func (app *App) Redraw() {
|
|||
)
|
||||
}
|
||||
|
||||
// draw statusbar
|
||||
statusStyle := vaxis.Style{Attribute: vaxis.AttrReverse}
|
||||
app.w.status.Fill(vaxis.Cell{Style: statusStyle})
|
||||
app.w.status.PrintTruncate(0,
|
||||
vaxis.Segment{
|
||||
Text: app.nick,
|
||||
Style: statusStyle,
|
||||
},
|
||||
)
|
||||
|
||||
// let the widgets draw themselves
|
||||
app.pager.Layout()
|
||||
app.pager.Draw(app.w.log)
|
||||
app.input.Draw(app.w.input)
|
||||
app.vx.Render()
|
||||
}
|
||||
|
||||
func (app *App) HandleTerminalEvent(ev vaxis.Event) {
|
||||
app.dirty = true
|
||||
|
||||
switch ev := ev.(type) {
|
||||
case vaxis.Mouse:
|
||||
switch ev.Button {
|
||||
case vaxis.MouseWheelUp:
|
||||
app.pager.ScrollUpN(2)
|
||||
case vaxis.MouseWheelDown:
|
||||
app.pager.ScrollDownN(2)
|
||||
}
|
||||
case vaxis.Resize:
|
||||
app.resize()
|
||||
case vaxis.Key:
|
||||
if ev.MatchString("ctrl+c") {
|
||||
app.stop()
|
||||
}
|
||||
switch {
|
||||
case ev.MatchString("up"):
|
||||
app.pager.ScrollUp()
|
||||
case ev.MatchString("down"):
|
||||
app.pager.ScrollDown()
|
||||
case ev.MatchString("ctrl+l"):
|
||||
app.Redraw()
|
||||
app.vx.Refresh()
|
||||
app.dirty = false
|
||||
case ev.MatchString("enter"):
|
||||
if len(app.input.Characters()) == 0 {
|
||||
break
|
||||
}
|
||||
if app.input.Characters()[0].Grapheme == "/" {
|
||||
name, rest, _ := strings.Cut(app.input.String()[1:], " ")
|
||||
if cmd, ok := CommandMap[name]; ok {
|
||||
cmd(app, rest)
|
||||
} else {
|
||||
app.AppendSystemMessage("unknown command \"%s\"", name)
|
||||
}
|
||||
} else {
|
||||
message := fmt.Sprintf("%s: %s", app.nick, app.input.String())
|
||||
app.AppendMessage(message)
|
||||
app.outgoing <- Message(message)
|
||||
}
|
||||
|
||||
app.input.SetContent("")
|
||||
}
|
||||
}
|
||||
|
||||
app.input.Update(ev)
|
||||
}
|
||||
|
|
|
|||
85
main.go
85
main.go
|
|
@ -8,7 +8,7 @@ import (
|
|||
"math"
|
||||
"net"
|
||||
"os"
|
||||
"sync"
|
||||
"strings"
|
||||
"time"
|
||||
|
||||
"codeberg.org/lobo/nanite/widgets/pager"
|
||||
|
|
@ -20,14 +20,38 @@ var (
|
|||
ErrAlreadyConnected = errors.New("already connected")
|
||||
)
|
||||
|
||||
var CommandMap = map[string]func(*App, string){
|
||||
"nick": func(app *App, rest string) {
|
||||
args := strings.Fields(rest)
|
||||
switch len(args) {
|
||||
case 0:
|
||||
app.AppendSystemMessage("your nickname is %s", app.nick)
|
||||
default:
|
||||
app.SetNick(args[0])
|
||||
app.AppendSystemMessage("your nickname is now %s", app.nick)
|
||||
}
|
||||
},
|
||||
"me": func(app *App, rest string) {
|
||||
msg := fmt.Sprintf("%s %s", app.nick, rest)
|
||||
app.AppendMessage(msg)
|
||||
app.outgoing <- Message(msg)
|
||||
},
|
||||
"quit": func(app *App, rest string) {
|
||||
app.stop()
|
||||
},
|
||||
"q": func(app *App, rest string) {
|
||||
app.stop()
|
||||
},
|
||||
}
|
||||
|
||||
type App struct {
|
||||
ctx context.Context
|
||||
stop context.CancelFunc
|
||||
mu sync.RWMutex
|
||||
|
||||
conn net.Conn
|
||||
scanner *bufio.Scanner
|
||||
host, port string
|
||||
stats string
|
||||
|
||||
nick string
|
||||
last int
|
||||
|
|
@ -61,6 +85,7 @@ func (app *App) Connect(host, port string) (err error) {
|
|||
app.ticker = time.NewTicker(2 * time.Second)
|
||||
|
||||
go func() {
|
||||
app.Last(50)
|
||||
for {
|
||||
select {
|
||||
case ev := <-app.outgoing:
|
||||
|
|
@ -80,6 +105,18 @@ func (app *App) Disconnect() {
|
|||
app.conn.Close()
|
||||
app.conn = nil
|
||||
}
|
||||
if app.ticker != nil {
|
||||
app.ticker.Stop()
|
||||
app.ticker = nil
|
||||
}
|
||||
if app.incoming != nil {
|
||||
close(app.incoming)
|
||||
app.incoming = nil
|
||||
}
|
||||
if app.outgoing != nil {
|
||||
close(app.outgoing)
|
||||
app.outgoing = nil
|
||||
}
|
||||
}
|
||||
|
||||
func (app *App) AppendMessage(data string) {
|
||||
|
|
@ -92,36 +129,20 @@ func (app *App) AppendMessage(data string) {
|
|||
app.dirty = true
|
||||
}
|
||||
|
||||
func (app *App) HandleTerminalEvent(ev vaxis.Event) {
|
||||
func (app *App) AppendSystemMessage(format string, args ...any) {
|
||||
st := vaxis.Style{Attribute: vaxis.AttrDim | vaxis.AttrItalic}
|
||||
app.pager.Segments = append(app.pager.Segments,
|
||||
vaxis.Segment{Text: "* ", Style: st},
|
||||
vaxis.Segment{Text: fmt.Sprintf(format, args...), Style: st},
|
||||
vaxis.Segment{Text: "\n"},
|
||||
)
|
||||
app.pager.Offset = math.MaxInt
|
||||
app.dirty = true
|
||||
}
|
||||
|
||||
switch ev := ev.(type) {
|
||||
case vaxis.Resize:
|
||||
app.resize()
|
||||
case vaxis.Key:
|
||||
if ev.MatchString("ctrl+c") {
|
||||
app.stop()
|
||||
}
|
||||
switch {
|
||||
case ev.MatchString("up"):
|
||||
app.pager.ScrollUp()
|
||||
case ev.MatchString("down"):
|
||||
app.pager.ScrollDown()
|
||||
case ev.MatchString("ctrl+l"):
|
||||
app.Redraw()
|
||||
app.vx.Refresh()
|
||||
app.dirty = false
|
||||
case ev.MatchString("enter"):
|
||||
if len(app.input.Characters()) != 0 {
|
||||
message := fmt.Sprintf("%s: %s", app.nick, app.input.String())
|
||||
app.AppendMessage(message)
|
||||
app.outgoing <- Message(message)
|
||||
app.input.SetContent("")
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
app.input.Update(ev)
|
||||
func (app *App) SetNick(nick string) {
|
||||
app.input.SetPrompt(fmt.Sprintf("%s: ", nick))
|
||||
app.nick = nick
|
||||
}
|
||||
|
||||
func main() {
|
||||
|
|
@ -148,8 +169,7 @@ func main() {
|
|||
app.InitUI()
|
||||
defer app.FinishUI()
|
||||
|
||||
app.nick = "wolfdog"
|
||||
go app.Last(20)
|
||||
app.SetNick("wolfdog")
|
||||
|
||||
for {
|
||||
select {
|
||||
|
|
@ -162,6 +182,7 @@ func main() {
|
|||
case <-app.ctx.Done():
|
||||
return
|
||||
}
|
||||
|
||||
app.Redraw()
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue