From 6ff24f2b511208aa8ac1ea4750004a615f7f02d5 Mon Sep 17 00:00:00 2001 From: qndel Date: Tue, 17 Oct 2023 23:59:31 +0200 Subject: [PATCH] chatlog refactor --- Source/qol/chatlog.cpp | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/Source/qol/chatlog.cpp b/Source/qol/chatlog.cpp index 064c801c3dc9..8312bdbb9adf 100644 --- a/Source/qol/chatlog.cpp +++ b/Source/qol/chatlog.cpp @@ -37,7 +37,6 @@ struct ColoredText { struct MultiColoredText { std::string text; std::vector colors; - int offset = 0; }; bool UnreadFlag = false; @@ -123,14 +122,24 @@ void AddMessageToChatLog(std::string_view message, Player *player, UiFlags flags std::string timestamp = localtimeResult != nullptr ? fmt::format("[#{:d}] {:02}:{:02}:{:02}", MessageCounter, localtimeResult->tm_hour, localtimeResult->tm_min, localtimeResult->tm_sec) : fmt::format("[#{:d}] ", MessageCounter); int oldSize = ChatLogLines.size(); - ChatLogLines.emplace_back(MultiColoredText { "", { {} } }); if (player == nullptr) { ChatLogLines.emplace_back(MultiColoredText { "{0} {1}", { { timestamp, UiFlags::ColorRed }, { std::string(message), flags } } }); } else { std::string playerInfo = fmt::format(fmt::runtime(_("{:s} (lvl {:d}): ")), player->_pName, player->getCharacterLevel()); - ChatLogLines.emplace_back(MultiColoredText { std::string(message), { {} }, 20 }); UiFlags nameColor = player == MyPlayer ? UiFlags::ColorWhitegold : UiFlags::ColorBlue; - ChatLogLines.emplace_back(MultiColoredText { "{0} - {1}", { { timestamp, UiFlags::ColorRed }, { playerInfo, nameColor } } }); + std::string prefix = timestamp + " - " + playerInfo; + std::string text = WordWrapString(prefix + std::string(message), ContentTextWidth); + std::vector lines; + std::stringstream ss(text); + + for (std::string s; getline(ss, s, '\n');) { + lines.push_back(s); + } + for (int i = lines.size() - 1; i >= 1; i--) { + ChatLogLines.emplace_back(MultiColoredText { lines[i], {} }); + } + lines[0].erase(0, prefix.length()); + ChatLogLines.emplace_back(MultiColoredText { "{0} - {1}{2}", { { timestamp, UiFlags::ColorRed }, { playerInfo, nameColor }, { lines[0], UiFlags::ColorWhite } } }); } unsigned int diff = ChatLogLines.size() - oldSize; @@ -182,7 +191,7 @@ void DrawChatLog(const Surface &out) for (auto &x : text.colors) { args.emplace_back(DrawStringFormatArg { x.text, x.color }); } - DrawStringWithColors(out, line, args, { { (sx + text.offset), contentY + i * lineHeight }, { ContentTextWidth - text.offset * 2, lineHeight } }, UiFlags::ColorWhite, /*spacing=*/1, lineHeight); + DrawStringWithColors(out, line, args, { { sx, contentY + i * lineHeight }, { ContentTextWidth, lineHeight } }, UiFlags::ColorWhite, /*spacing=*/1, lineHeight); } DrawString(out, _("Press ESC to end or the arrow keys to scroll."),