show crown next to owner

This commit is contained in:
ouwou 2021-03-04 00:02:37 -05:00
parent d6a8b8c333
commit 9186a4f3f5
8 changed files with 48 additions and 12 deletions

View File

@ -126,6 +126,7 @@ For example, memory_db would be set by adding `memory_db = true` under the line
* emojis (true or false, default true) - resolve unicode and custom emojis to images. this needs to be false to allow GTK to render emojis by itself
* css (string) - path to the main CSS file
* animations (true or false, default true) - use animated images where available (e.g. server icons, emojis, avatars). false means static images will be used
* owner_crown (true or false, default true) - show a crown next to the owner
#### misc
* linkcolor (string) - color to use for links in messages

View File

@ -6,7 +6,7 @@
constexpr static const int MaxMemberListRows = 200;
MemberListUserRow::MemberListUserRow(Snowflake guild_id, const UserData *data) {
MemberListUserRow::MemberListUserRow(const GuildData &guild, const UserData *data) {
ID = data->ID;
m_ev = Gtk::manage(new Gtk::EventBox);
m_box = Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_HORIZONTAL));
@ -14,6 +14,16 @@ MemberListUserRow::MemberListUserRow(Snowflake guild_id, const UserData *data) {
m_avatar = Gtk::manage(new LazyImage(16, 16));
m_status_indicator = Gtk::manage(new StatusIndicator(ID));
static bool crown = Abaddon::Get().GetSettings().GetShowOwnerCrown();
if (crown && guild.OwnerID == data->ID) {
try {
auto pixbuf = Gdk::Pixbuf::create_from_file("./res/crown.png", 12, 12);
m_crown = Gtk::manage(new Gtk::Image(pixbuf));
m_crown->set_valign(Gtk::ALIGN_CENTER);
m_crown->set_margin_end(8);
} catch (...) {}
}
m_status_indicator->set_margin_start(3);
if (data->HasAvatar())
@ -31,7 +41,7 @@ MemberListUserRow::MemberListUserRow(Snowflake guild_id, const UserData *data) {
std::string display = data->Username;
if (show_discriminator)
display += "#" + data->Discriminator;
auto col_id = data->GetHoistedRole(guild_id, true);
auto col_id = data->GetHoistedRole(guild.ID, true);
if (col_id.IsValid()) {
auto color = Abaddon::Get().GetDiscordClient().GetRole(col_id)->Color;
m_label->set_use_markup(true);
@ -49,6 +59,8 @@ MemberListUserRow::MemberListUserRow(Snowflake guild_id, const UserData *data) {
m_box->add(*m_avatar);
m_box->add(*m_status_indicator);
m_box->add(*m_label);
if (m_crown != nullptr)
m_box->add(*m_crown);
m_ev->add(*m_box);
add(*m_ev);
show_all();
@ -118,10 +130,8 @@ void MemberList::UpdateMemberList() {
for (const auto &id : ids) {
auto user = discord.GetUser(id);
if (!user.has_value()) {
roleless_users.push_back(id);
if (!user.has_value() || user->IsDeleted())
continue;
}
auto pos_role_id = discord.GetMemberHoistedRole(m_guild_id, id); // role for positioning
auto col_role_id = discord.GetMemberHoistedRole(m_guild_id, id, true); // role for color
@ -140,9 +150,10 @@ void MemberList::UpdateMemberList() {
}
int num_rows = 0;
auto add_user = [this, &user_to_color, &num_rows](const UserData *data) -> bool {
const auto guild = *discord.GetGuild(m_guild_id);
auto add_user = [this, &user_to_color, &num_rows, guild](const UserData *data) -> bool {
if (num_rows++ > MaxMemberListRows) return false;
auto *row = Gtk::manage(new MemberListUserRow(m_guild_id, data));
auto *row = Gtk::manage(new MemberListUserRow(guild, data));
m_id_to_row[data->ID] = row;
AttachUserMenuHandler(row, data->ID);
m_listbox->add(*row);

View File

@ -8,7 +8,7 @@ class LazyImage;
class StatusIndicator;
class MemberListUserRow : public Gtk::ListBoxRow {
public:
MemberListUserRow(Snowflake guild_id, const UserData *data);
MemberListUserRow(const GuildData& guild, const UserData *data);
Snowflake ID;
@ -18,6 +18,7 @@ private:
LazyImage *m_avatar;
StatusIndicator *m_status_indicator;
Gtk::Label *m_label;
Gtk::Image *m_crown = nullptr;
};
class MemberList {

BIN
res/crown.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.5 KiB

View File

@ -77,3 +77,7 @@ std::string SettingsManager::GetMainCSS() const {
bool SettingsManager::GetShowAnimations() const {
return GetSettingBool("gui", "animations", true);
}
bool SettingsManager::GetShowOwnerCrown() const {
return GetSettingBool("gui", "owner_crown", true);
}

View File

@ -19,6 +19,7 @@ public:
bool GetPrefetch() const;
std::string GetMainCSS() const;
bool GetShowAnimations() const;
bool GetShowOwnerCrown() const;
bool IsValid() const;

View File

@ -40,11 +40,12 @@ GuildSettingsMembersPaneMembers::GuildSettingsMembersPaneMembers(Snowflake id)
auto &discord = Abaddon::Get().GetDiscordClient();
auto members = discord.GetUsersInGuild(id);
const auto guild = *discord.GetGuild(GuildID);
for (const auto member_id : members) {
auto member = *discord.GetMember(member_id, GuildID);
member.User = discord.GetUser(member_id);
if (member.User->IsDeleted()) continue;
auto *row = Gtk::manage(new GuildSettingsMembersListItem(GuildID, member));
auto *row = Gtk::manage(new GuildSettingsMembersListItem(guild, member));
row->show();
m_list.add(*row);
}
@ -81,9 +82,9 @@ GuildSettingsMembersPaneMembers::type_signal_member_select GuildSettingsMembersP
return m_signal_member_select;
}
GuildSettingsMembersListItem::GuildSettingsMembersListItem(Snowflake guild_id, const GuildMember &member)
GuildSettingsMembersListItem::GuildSettingsMembersListItem(const GuildData &guild, const GuildMember &member)
: UserID(member.User->ID)
, GuildID(guild_id)
, GuildID(guild.ID)
, m_avatar(32, 32) {
m_avatar.SetAnimated(true);
@ -113,14 +114,29 @@ GuildSettingsMembersListItem::GuildSettingsMembersListItem(Snowflake guild_id, c
discord.signal_guild_member_update().connect(sigc::track_obj(member_update_cb, *this));
UpdateColor();
static bool crown = Abaddon::Get().GetSettings().GetShowOwnerCrown();
if (crown && guild.OwnerID == member.User->ID) {
try {
auto pixbuf = Gdk::Pixbuf::create_from_file("./res/crown.png", 12, 12);
m_crown = Gtk::manage(new Gtk::Image(pixbuf));
m_crown->set_valign(Gtk::ALIGN_CENTER);
m_crown->set_margin_start(10);
m_crown->show();
} catch (...) {}
}
m_avatar.set_margin_end(5);
m_avatar.set_halign(Gtk::ALIGN_START);
m_avatar.set_valign(Gtk::ALIGN_CENTER);
m_name.set_halign(Gtk::ALIGN_START);
m_name.set_valign(Gtk::ALIGN_CENTER);
m_main.set_hexpand(true);
m_main.add(m_avatar);
m_main.add(m_name);
if (m_crown != nullptr)
m_main.add(*m_crown);
m_ev.add(m_main);
add(m_ev);

View File

@ -2,6 +2,7 @@
#include <unordered_set>
#include <gtkmm.h>
#include "../../discord/member.hpp"
#include "../../discord/guild.hpp"
#include "../../components/lazyimage.hpp"
class GuildSettingsMembersPaneRolesItem : public Gtk::ListBoxRow {
@ -103,7 +104,7 @@ public:
class GuildSettingsMembersListItem : public Gtk::ListBoxRow {
public:
GuildSettingsMembersListItem(Snowflake guild_id, const GuildMember &member);
GuildSettingsMembersListItem(const GuildData &guild, const GuildMember &member);
Glib::ustring DisplayTerm;
@ -117,6 +118,7 @@ private:
LazyImage m_avatar;
Gtk::Label m_name;
Gtk::Box m_main;
Gtk::Image *m_crown = nullptr;
};
class GuildSettingsMembersPane : public Gtk::Box {