From bffd4d3d17d9396efefa75c5618319503a2f9dcd Mon Sep 17 00:00:00 2001 From: Tulir Asokan Date: Thu, 15 Mar 2018 20:33:01 +0200 Subject: ADKFJSLKDFJSDKLFJ --- room-view.go | 42 +++++++++++++++++++++++++++++++++++------- view-main.go | 2 +- 2 files changed, 36 insertions(+), 8 deletions(-) diff --git a/room-view.go b/room-view.go index 8e8d9db..597ed0c 100644 --- a/room-view.go +++ b/room-view.go @@ -18,6 +18,8 @@ package main import ( "fmt" + "hash/fnv" + "regexp" "sort" "strings" @@ -31,22 +33,34 @@ type RoomView struct { topic *tview.TextView content *tview.TextView status *tview.TextView - userlist *tview.TextView + userList *tview.TextView users sort.StringSlice } +var colorNames []string + +func init() { + colorNames = make([]string, len(tcell.ColorNames)) + i := 0 + for name, _ := range tcell.ColorNames { + colorNames[i] = name + i++ + } +} + func NewRoomView(topic string) *RoomView { view := &RoomView{ Box: tview.NewBox(), topic: tview.NewTextView(), content: tview.NewTextView(), status: tview.NewTextView(), - userlist: tview.NewTextView(), + userList: tview.NewTextView(), } view.topic. SetText(strings.Replace(topic, "\n", " ", -1)). SetBackgroundColor(tcell.ColorDarkGreen) view.status.SetBackgroundColor(tcell.ColorDimGray) + view.content.SetDynamicColors(true) return view } @@ -55,7 +69,7 @@ func (view *RoomView) Draw(screen tcell.Screen) { view.topic.SetRect(x, y, width, 1) view.content.SetRect(x, y+1, width-30, height-2) view.status.SetRect(x, y+height-1, width, 1) - view.userlist.SetRect(x+width-29, y+1, 29, height-2) + view.userList.SetRect(x+width-29, y+1, 29, height-2) view.topic.Draw(screen) view.content.Draw(screen) @@ -66,7 +80,7 @@ func (view *RoomView) Draw(screen tcell.Screen) { for borderY := y + 1; borderY < y+height-1; borderY++ { screen.SetContent(borderX, borderY, tview.GraphicsVertBar, nil, background) } - view.userlist.Draw(screen) + view.userList.Draw(screen) } func (view *RoomView) SetTyping(users []string) { @@ -81,21 +95,35 @@ func (view *RoomView) SetTyping(users []string) { } } +var colorPattern = regexp.MustCompile(`\[([a-zA-Z]+|#[0-9a-zA-Z]{6})\]`) + +func color(s string) string { + h := fnv.New32a() + h.Write([]byte(s)) + color := colorNames[int(h.Sum32()) % len(colorNames)] + return fmt.Sprintf("[%s]%s[white]", color, s) +} + +func escapeColor(s string) string { + return colorPattern.ReplaceAllString(s, "[$1[]") +} + func (view *RoomView) AddMessage(sender, message string) { - fmt.Fprintf(view.content, "<%s> %s\n", sender, message) + fmt.Fprintf(view.content, "%s: %s\n", + color(sender), escapeColor(message)) } func (view *RoomView) SetUsers(users []string) { view.users = sort.StringSlice(users) view.users.Sort() - view.userlist.SetText(strings.Join(view.users, "\n")) + view.userList.SetText(strings.Join(view.users, "\n")) } func (view *RoomView) RemoveUser(user string) { i := view.users.Search(user) if i >= 0 { view.users = append(view.users[:i], view.users[i+1:]...) - view.userlist.SetText(strings.Join(view.users, "\n")) + view.userList.SetText(strings.Join(view.users, "\n")) } } diff --git a/view-main.go b/view-main.go index 79dd023..148212b 100644 --- a/view-main.go +++ b/view-main.go @@ -29,7 +29,7 @@ func (ui *GomuksUI) MakeMainUI() tview.Primitive { ui.mainView.SetColumns(30, 1, 0).SetRows(0, 1) ui.mainViewRoomList = tview.NewList().ShowSecondaryText(false) - ui.mainViewRoomList.SetBorderPadding(0, 0, 0, 1) + ui.mainViewRoomList.SetBorderPadding(0, 0, 1, 0) ui.mainView.AddItem(ui.mainViewRoomList, 0, 0, 2, 1, 0, 0, false) ui.mainView.AddItem(NewBorder(), 0, 1, 2, 1, 0, 0, false) -- cgit v1.2.3