2019-03-15 13:07:04 +01:00
|
|
|
#include "IRCLogBufferModel.h"
|
|
|
|
#include "IRCLogBuffer.h"
|
|
|
|
#include <stdio.h>
|
2019-03-15 13:16:29 +01:00
|
|
|
#include <time.h>
|
2019-03-15 17:37:13 +01:00
|
|
|
#include <SharedGraphics/Font.h>
|
2019-03-15 13:07:04 +01:00
|
|
|
|
|
|
|
IRCLogBufferModel::IRCLogBufferModel(Retained<IRCLogBuffer>&& log_buffer)
|
|
|
|
: m_log_buffer(move(log_buffer))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
IRCLogBufferModel::~IRCLogBufferModel()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2019-03-29 03:27:03 +01:00
|
|
|
int IRCLogBufferModel::row_count(const GModelIndex&) const
|
2019-03-15 13:07:04 +01:00
|
|
|
{
|
|
|
|
return m_log_buffer->count();
|
|
|
|
}
|
|
|
|
|
2019-03-29 03:27:03 +01:00
|
|
|
int IRCLogBufferModel::column_count(const GModelIndex&) const
|
2019-03-15 13:07:04 +01:00
|
|
|
{
|
2019-03-15 17:37:13 +01:00
|
|
|
return Column::__Count;
|
2019-03-15 13:07:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
String IRCLogBufferModel::column_name(int column) const
|
|
|
|
{
|
|
|
|
switch (column) {
|
|
|
|
case Column::Timestamp: return "Time";
|
|
|
|
case Column::Name: return "Name";
|
|
|
|
case Column::Text: return "Text";
|
|
|
|
}
|
|
|
|
ASSERT_NOT_REACHED();
|
|
|
|
}
|
|
|
|
|
2019-03-23 01:42:49 +01:00
|
|
|
GModel::ColumnMetadata IRCLogBufferModel::column_metadata(int column) const
|
2019-03-15 13:07:04 +01:00
|
|
|
{
|
|
|
|
switch (column) {
|
2019-03-15 13:16:29 +01:00
|
|
|
case Column::Timestamp: return { 60, TextAlignment::CenterLeft };
|
2019-03-15 17:37:13 +01:00
|
|
|
case Column::Name: return { 70, TextAlignment::CenterRight, &Font::default_bold_font() };
|
2019-03-15 13:16:29 +01:00
|
|
|
case Column::Text: return { 800, TextAlignment::CenterLeft };
|
2019-03-15 13:07:04 +01:00
|
|
|
}
|
|
|
|
ASSERT_NOT_REACHED();
|
|
|
|
}
|
|
|
|
|
2019-03-18 04:54:07 +01:00
|
|
|
GVariant IRCLogBufferModel::data(const GModelIndex& index, Role role) const
|
2019-03-15 13:07:04 +01:00
|
|
|
{
|
2019-03-18 04:54:07 +01:00
|
|
|
if (role == Role::Display) {
|
|
|
|
auto& entry = m_log_buffer->at(index.row());
|
|
|
|
switch (index.column()) {
|
|
|
|
case Column::Timestamp: {
|
|
|
|
auto* tm = localtime(&entry.timestamp);
|
|
|
|
return String::format("%02u:%02u:%02u", tm->tm_hour, tm->tm_min, tm->tm_sec);
|
|
|
|
}
|
|
|
|
case Column::Name:
|
|
|
|
if (entry.sender.is_empty())
|
|
|
|
return String::empty();
|
|
|
|
return String::format("<%c%s>", entry.prefix ? entry.prefix : ' ', entry.sender.characters());
|
|
|
|
case Column::Text: return entry.text;
|
|
|
|
}
|
2019-03-15 13:16:29 +01:00
|
|
|
}
|
2019-03-18 20:56:45 +01:00
|
|
|
if (role == Role::ForegroundColor) {
|
2019-03-20 13:35:11 +01:00
|
|
|
if (index.column() == Column::Timestamp)
|
|
|
|
return Color(Color::MidGray);
|
2019-03-18 20:56:45 +01:00
|
|
|
if (index.column() == Column::Text)
|
|
|
|
return m_log_buffer->at(index.row()).color;
|
|
|
|
}
|
2019-03-18 04:54:07 +01:00
|
|
|
return { };
|
2019-03-15 13:07:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void IRCLogBufferModel::update()
|
|
|
|
{
|
|
|
|
did_update();
|
|
|
|
}
|