Re-add colors to date change messages

This commit is contained in:
Tulir Asokan 2018-03-20 13:01:59 +02:00
parent 3897f23bc4
commit bfb5151cb6
3 changed files with 98 additions and 17 deletions

View File

@ -83,3 +83,27 @@ func (message *Message) CalculateBuffer(width int) {
} }
} }
} }
func (message *Message) GetSender() string {
return message.Sender
}
func (message *Message) GetSenderColor() tcell.Color {
return message.SenderColor
}
func (message *Message) GetTimestamp() string {
return message.Timestamp
}
func (message *Message) GetDate() string {
return message.Date
}
func (message *Message) GetTextColor() tcell.Color {
return tcell.ColorDefault
}
func (message *Message) GetTimestampColor() tcell.Color {
return tcell.ColorDefault
}

59
ui/types/meta.go Normal file
View File

@ -0,0 +1,59 @@
// gomuks - A terminal Matrix client written in Go.
// Copyright (C) 2018 Tulir Asokan
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
package types
import (
"github.com/gdamore/tcell"
)
type MessageMeta interface {
GetSender() string
GetSenderColor() tcell.Color
GetTextColor() tcell.Color
GetTimestampColor() tcell.Color
GetTimestamp() string
GetDate() string
}
type BasicMeta struct {
Sender, Timestamp, Date string
SenderColor, TextColor, TimestampColor tcell.Color
}
func (meta *BasicMeta) GetSender() string {
return meta.Sender
}
func (meta *BasicMeta) GetSenderColor() tcell.Color {
return meta.SenderColor
}
func (meta *BasicMeta) GetTimestamp() string {
return meta.Timestamp
}
func (meta *BasicMeta) GetDate() string {
return meta.Date
}
func (meta *BasicMeta) GetTextColor() tcell.Color {
return meta.TextColor
}
func (meta *BasicMeta) GetTimestampColor() tcell.Color {
return meta.TimestampColor
}

View File

@ -44,8 +44,8 @@ type MessageView struct {
messageIDs map[string]bool messageIDs map[string]bool
messages []*types.Message messages []*types.Message
metaBuffer []*types.Message
textBuffer []string textBuffer []string
metaBuffer []types.MessageMeta
} }
func NewMessageView() *MessageView { func NewMessageView() *MessageView {
@ -61,7 +61,7 @@ func NewMessageView() *MessageView {
messages: make([]*types.Message, 0), messages: make([]*types.Message, 0),
messageIDs: make(map[string]bool), messageIDs: make(map[string]bool),
textBuffer: make([]string, 0), textBuffer: make([]string, 0),
metaBuffer: make([]*types.Message, 0), metaBuffer: make([]types.MessageMeta, 0),
widestSender: 5, widestSender: 5,
prevWidth: -1, prevWidth: -1,
@ -129,9 +129,9 @@ func (view *MessageView) recalculateMessageBuffers() {
func (view *MessageView) appendBuffer(message *types.Message) { func (view *MessageView) appendBuffer(message *types.Message) {
if len(view.metaBuffer) > 0 { if len(view.metaBuffer) > 0 {
prevMeta := view.metaBuffer[len(view.metaBuffer)-1] prevMeta := view.metaBuffer[len(view.metaBuffer)-1]
if prevMeta != nil && prevMeta.Date != message.Date { if prevMeta != nil && prevMeta.GetDate() != message.Date {
view.textBuffer = append(view.textBuffer, fmt.Sprintf("Date changed to %s", message.Date)) view.textBuffer = append(view.textBuffer, fmt.Sprintf("Date changed to %s", message.Date))
view.metaBuffer = append(view.metaBuffer, nil) view.metaBuffer = append(view.metaBuffer, &types.BasicMeta{TextColor: tcell.ColorGreen})
} }
} }
@ -144,7 +144,7 @@ func (view *MessageView) appendBuffer(message *types.Message) {
func (view *MessageView) recalculateBuffer() { func (view *MessageView) recalculateBuffer() {
_, _, width, height := view.GetInnerRect() _, _, width, height := view.GetInnerRect()
view.textBuffer = make([]string, 0) view.textBuffer = make([]string, 0)
view.metaBuffer = make([]*types.Message, 0) view.metaBuffer = make([]types.MessageMeta, 0)
if height != view.prevHeight || width != view.prevWidth { if height != view.prevHeight || width != view.prevWidth {
for _, message := range view.messages { for _, message := range view.messages {
@ -259,8 +259,7 @@ func (view *MessageView) Draw(screen tcell.Screen) {
screen.SetContent(separatorX, separatorY, view.Separator, nil, tcell.StyleDefault) screen.SetContent(separatorX, separatorY, view.Separator, nil, tcell.StyleDefault)
} }
var prevMeta *types.Message var prevMeta types.MessageMeta
var prevSender string
indexOffset := len(view.textBuffer) - view.ScrollOffset - height indexOffset := len(view.textBuffer) - view.ScrollOffset - height
if indexOffset <= -PaddingAtTop { if indexOffset <= -PaddingAtTop {
message := "Scroll up to load more messages." message := "Scroll up to load more messages."
@ -278,18 +277,17 @@ func (view *MessageView) Draw(screen tcell.Screen) {
} }
text, meta := view.textBuffer[index], view.metaBuffer[index] text, meta := view.textBuffer[index], view.metaBuffer[index]
if meta != prevMeta { if meta != prevMeta {
if meta != nil { if len(meta.GetTimestamp()) > 0 {
view.writeLine(screen, meta.Timestamp, x, y+line, tcell.ColorDefault) view.writeLine(screen, meta.GetTimestamp(), x, y+line, meta.GetTimestampColor())
if meta.Sender != prevSender {
view.writeLineRight(
screen, meta.Sender,
x+usernameOffsetX, y+line,
view.widestSender, meta.SenderColor)
prevSender = meta.Sender
} }
if len(meta.GetSender()) > 0 && (prevMeta == nil || meta.GetSender() != prevMeta.GetSender()) {
view.writeLineRight(
screen, meta.GetSender(),
x+usernameOffsetX, y+line,
view.widestSender, meta.GetSenderColor())
} }
prevMeta = meta prevMeta = meta
} }
view.writeLine(screen, text, x+messageOffsetX, y+line, tcell.ColorDefault) view.writeLine(screen, text, x+messageOffsetX, y+line, meta.GetTextColor())
} }
} }