chatpb/chat.gui.pb.go

251 lines
5.9 KiB
Go

// Code generated by go.wit.com/apps/autogenpb DO NOT EDIT.
// This file was autogenerated with autogenpb v0.5.3-12-g0ccf2c0 2025-09-18_03:38:50_UTC
// go install go.wit.com/apps/autogenpb@latest
//
// define which structs (messages) you want to use in the .proto file
// Then sort.pb.go and marshal.pb.go files are autogenerated
//
// autogenpb uses it and has an example .proto file with instructions
//
package chatpb
import (
"time"
"github.com/google/uuid"
"go.wit.com/gui"
"go.wit.com/lib/protobuf/guipb"
"go.wit.com/log"
"google.golang.org/protobuf/proto"
anypb "google.golang.org/protobuf/types/known/anypb"
timestamppb "google.golang.org/protobuf/types/known/timestamppb"
"google.golang.org/protobuf/types/known/wrapperspb"
)
// START GUI
func (x *Chats) NewTable(title string) *ChatsTable {
t := new(ChatsTable)
t.x = x
pb := new(guipb.Table)
pb.Title = title
t.pb = pb
return t
}
// force the application to choose the type of data. this allows the GUI plugin to be smarter
func (t *ChatsTable) AddStringFunc(title string, f func(*Chat) string) *ChatAnyFunc {
t.pb.Order = append(t.pb.Order, title)
sf := new(ChatAnyFunc)
sf.title = title
sf.f = func(x *Chat) any {
return f(x)
}
sf.attr = new(guipb.ColAttr)
sf.attr.Width = int32(sf.Width)
sf.attr.Type = guipb.ColAttr_STRING
t.anyFuncs = append(t.anyFuncs, sf)
return sf
}
// force the application to choose the type of data. this allows the GUI plugin to be smarter
func (t *ChatsTable) AddButtonFunc(title string, f func(*Chat) string) *ChatAnyFunc {
t.pb.Order = append(t.pb.Order, title)
sf := new(ChatAnyFunc)
sf.title = title
sf.f = func(x *Chat) any {
return f(x)
}
sf.attr = new(guipb.ColAttr)
sf.attr.Width = int32(sf.Width)
sf.attr.Type = guipb.ColAttr_STRING
sf.attr.Click = true
t.anyFuncs = append(t.anyFuncs, sf)
return sf
}
// force the application to choose the type of data. this allows the GUI plugin to be smarter
func (t *ChatsTable) AddIntFunc(title string, f func(*Chat) int) *ChatAnyFunc {
t.pb.Order = append(t.pb.Order, title)
sf := new(ChatAnyFunc)
sf.title = title
sf.f = func(x *Chat) any {
return f(x)
}
sf.attr = new(guipb.ColAttr)
sf.attr.Width = int32(sf.Width)
sf.attr.Type = guipb.ColAttr_INT
t.anyFuncs = append(t.anyFuncs, sf)
return sf
}
// force the application to choose the type of data. this allows the GUI plugin to be smarter
func (t *ChatsTable) AddTimeFunc(title string, f func(*Chat) time.Time) *ChatAnyFunc {
t.pb.Order = append(t.pb.Order, title)
sf := new(ChatAnyFunc)
sf.title = title
sf.f = func(x *Chat) any {
return f(x)
}
sf.attr = new(guipb.ColAttr)
sf.attr.Width = int32(sf.Width)
sf.attr.Type = guipb.ColAttr_TIME
// t.timeFuncs = append(t.timeFuncs, sf)
t.anyFuncs = append(t.anyFuncs, sf)
return sf
}
func (sf *ChatAnyFunc) SetTitle(title string) {
sf.title = title
}
func (mt *ChatsTable) SetParent(p *gui.Node) {
mt.parent = p
}
func (mt *ChatsTable) ShowTable() {
// log.Info("ShowTable() SENDING TO GUI")
mt.MakeTable()
mt.parent.ShowTable(mt.pb)
}
type ChatAnyFunc struct {
title string
f func(*Chat) any
Custom func(*Chat)
Width int
attr *guipb.ColAttr
}
type ChatsTable struct {
pb *guipb.Table
parent *gui.Node
x *Chats
hostnames []string
anyFuncs []*ChatAnyFunc
CustomFunc func(*Chat)
}
func (mt *ChatsTable) doAnyFuncNew(sf *ChatAnyFunc) bool {
r := new(guipb.AnyCol)
r.Header = new(guipb.Widget)
r.Header.Name = sf.title
r.Attr = proto.Clone(sf.attr).(*guipb.ColAttr)
for m := range mt.x.IterAll() {
t := sf.f(m)
switch r.Attr.Type {
case guipb.ColAttr_STRING:
// anyProto, err := anypb.New(tsProto)
stringValue := wrapperspb.String(t.(string))
anyProto, err := anypb.New(stringValue)
_ = err // do something with err someday (?)
r.Vals = append(r.Vals, anyProto)
// return col.Vals[row] true
case guipb.ColAttr_INT:
var finalInt int
finalInt = t.(int)
intVal := wrapperspb.Int32(int32(finalInt))
anyProto, _ := anypb.New(intVal)
r.Vals = append(r.Vals, anyProto)
case guipb.ColAttr_DURATION:
case guipb.ColAttr_TIME:
var goTime time.Time
goTime = t.(time.Time)
tsProto := timestamppb.New(goTime)
anyProto, err := anypb.New(tsProto)
_ = err // do something with err someday (?)
r.Vals = append(r.Vals, anyProto)
default:
log.Info("cell unhandled type", r.Attr.Type)
}
// cellTime := r.Vals[row]
// s := shell.FormatDuration(time.Since(cellTime.AsTime()))
}
mt.pb.AnyCols = append(mt.pb.AnyCols, r)
return true
}
func (mt *ChatsTable) MakeTable() {
for _, sf := range mt.anyFuncs {
mt.doAnyFuncNew(sf)
}
}
func (t *ChatsTable) AddUuid() *ChatAnyFunc {
sf := t.AddStringFunc("Uuid", func(m *Chat) string {
return m.Uuid
})
return sf
}
func (t *ChatsTable) AddChatName() *ChatAnyFunc {
sf := t.AddStringFunc("ChatName", func(m *Chat) string {
return m.ChatName
})
return sf
}
func (mt *ChatsTable) NewUuid() {
mt.pb.Uuid = uuid.New().String()
}
// START TABLE UPDATE (doesn't work yet)
func (mt *ChatsTable) dumpStringFunc(name string) {
for i, r := range mt.pb.StringCols {
// log.Info("could use", i, r.Header.Name, "for name =", name)
if r.Header.Name == name {
log.Info("dump Strings row", i, r.Header.Name, r.Vals)
break
}
}
}
func (mt *ChatsTable) Delete() {
if mt == nil {
log.Info("mt == nil table already deleted")
return
}
// log.Info("table Delete here")
mt.parent.DeleteTable(mt.pb)
}
func (mt *ChatsTable) chatsCustom(w *guipb.Widget) {
row := mt.x.Chats[w.Location.Y-1]
// log.Info("got to chatsCustom() with", w.Location.X, w.Location.Y-1)
for i, sf := range mt.anyFuncs {
if i == int(w.Location.X) {
if sf.Custom != nil {
log.Info("doing Custom() func for button")
sf.Custom(row)
return
}
}
}
mt.CustomFunc(row)
}
func (mt *ChatsTable) Custom(f func(*Chat)) {
mt.pb.RegisterCustom(mt.chatsCustom)
mt.CustomFunc = f
}
func (mt *ChatsTable) GetUuid() string {
return mt.pb.Uuid
}
// END TABLE UPDATE
// END GUI