summaryrefslogtreecommitdiff
path: root/windows
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2021-02-05 21:35:48 -0500
committerouwou <26526779+ouwou@users.noreply.github.com>2021-02-05 21:35:48 -0500
commit6896db53d672bc5b94eeb66e9fda85f6a4c81c8f (patch)
treea0d58ae3e06bb8314d1f4260b6c60e56b1dcb83c /windows
parent10ed518c8345ee1c1f01ce330e2698fbdf8f4e96 (diff)
downloadabaddon-portaudio-6896db53d672bc5b94eeb66e9fda85f6a4c81c8f.tar.gz
abaddon-portaudio-6896db53d672bc5b94eeb66e9fda85f6a4c81c8f.zip
show mutual guilds
Diffstat (limited to 'windows')
-rw-r--r--windows/profile/mutualguildspane.cpp67
-rw-r--r--windows/profile/mutualguildspane.hpp26
-rw-r--r--windows/profilewindow.cpp5
-rw-r--r--windows/profilewindow.hpp2
4 files changed, 99 insertions, 1 deletions
diff --git a/windows/profile/mutualguildspane.cpp b/windows/profile/mutualguildspane.cpp
new file mode 100644
index 0000000..8068992
--- /dev/null
+++ b/windows/profile/mutualguildspane.cpp
@@ -0,0 +1,67 @@
+#include "mutualguildspane.hpp"
+#include "../../abaddon.hpp"
+
+MutualGuildItem::MutualGuildItem(const MutualGuildData &guild)
+ : Gtk::Box(Gtk::ORIENTATION_HORIZONTAL)
+ , m_box(Gtk::ORIENTATION_VERTICAL) {
+ get_style_context()->add_class("mutual-guild-item");
+ m_name.get_style_context()->add_class("mutual-guild-item-name");
+ m_icon.get_style_context()->add_class("mutual-guild-item-icon");
+
+ m_icon.set_margin_end(10);
+
+ const auto data = *Abaddon::Get().GetDiscordClient().GetGuild(guild.ID);
+ const auto show_animations = Abaddon::Get().GetSettings().GetShowAnimations();
+ auto &img = Abaddon::Get().GetImageManager();
+ m_icon.property_pixbuf() = img.GetPlaceholder(24);
+ if (data.HasIcon()) {
+ if (data.HasAnimatedIcon() && show_animations) {
+ auto cb = [this](const Glib::RefPtr<Gdk::PixbufAnimation> &pb) {
+ m_icon.property_pixbuf_animation() = pb;
+ };
+ img.LoadAnimationFromURL(data.GetIconURL("gif", "32"), 24, 24, sigc::track_obj(cb, *this));
+ } else {
+ auto cb = [this](const Glib::RefPtr<Gdk::Pixbuf> &pb) {
+ m_icon.property_pixbuf() = pb->scale_simple(24, 24, Gdk::INTERP_BILINEAR);
+ };
+ img.LoadFromURL(data.GetIconURL("png", "32"), sigc::track_obj(cb, *this));
+ }
+ }
+
+ m_name.set_markup("<b>" + Glib::Markup::escape_text(data.Name) + "</b>");
+
+ if (guild.Nick.has_value()) {
+ m_nick = Gtk::manage(new Gtk::Label(*guild.Nick));
+ m_nick->get_style_context()->add_class("mutual-guild-item-nick");
+ m_nick->set_margin_start(5);
+ m_nick->set_halign(Gtk::ALIGN_START);
+ m_nick->set_single_line_mode(true);
+ m_nick->set_ellipsize(Pango::ELLIPSIZE_END);
+ }
+
+ m_box.set_valign(Gtk::ALIGN_CENTER);
+
+ m_box.add(m_name);
+ if (m_nick != nullptr)
+ m_box.add(*m_nick);
+ add(m_icon);
+ add(m_box);
+ show_all_children();
+}
+
+UserMutualGuildsPane::UserMutualGuildsPane(Snowflake id)
+ : UserID(id) {
+ add(m_list);
+ show_all_children();
+}
+
+void UserMutualGuildsPane::SetMutualGuilds(const std::vector<MutualGuildData> &guilds) {
+ for (auto child : m_list.get_children())
+ delete child;
+
+ for (const auto &guild : guilds) {
+ auto *item = Gtk::manage(new MutualGuildItem(guild));
+ item->show();
+ m_list.add(*item);
+ }
+}
diff --git a/windows/profile/mutualguildspane.hpp b/windows/profile/mutualguildspane.hpp
new file mode 100644
index 0000000..6afdb07
--- /dev/null
+++ b/windows/profile/mutualguildspane.hpp
@@ -0,0 +1,26 @@
+#pragma once
+#include <gtkmm.h>
+#include "../../discord/objects.hpp"
+
+class MutualGuildItem : public Gtk::Box {
+public:
+ MutualGuildItem(const MutualGuildData &guild);
+
+private:
+ Gtk::Image m_icon;
+ Gtk::Box m_box;
+ Gtk::Label m_name;
+ Gtk::Label *m_nick = nullptr;
+};
+
+class UserMutualGuildsPane : public Gtk::ScrolledWindow {
+public:
+ UserMutualGuildsPane(Snowflake id);
+
+ void SetMutualGuilds(const std::vector<MutualGuildData> &guilds);
+
+ Snowflake UserID;
+
+private:
+ Gtk::ListBox m_list;
+};
diff --git a/windows/profilewindow.cpp b/windows/profilewindow.cpp
index 265367b..2599065 100644
--- a/windows/profilewindow.cpp
+++ b/windows/profilewindow.cpp
@@ -6,7 +6,8 @@ ProfileWindow::ProfileWindow(Snowflake user_id)
, m_main(Gtk::ORIENTATION_VERTICAL)
, m_upper(Gtk::ORIENTATION_HORIZONTAL)
, m_badges(Gtk::ORIENTATION_HORIZONTAL)
- , m_pane_info(user_id) {
+ , m_pane_info(user_id)
+ , m_pane_guilds(user_id) {
const auto &discord = Abaddon::Get().GetDiscordClient();
auto user = *discord.GetUser(ID);
@@ -70,6 +71,7 @@ ProfileWindow::ProfileWindow(Snowflake user_id)
m_switcher.set_hexpand(true);
m_stack.add(m_pane_info, "info", "User Info");
+ m_stack.add(m_pane_guilds, "guilds", "Mutual Servers");
m_badges.set_valign(Gtk::ALIGN_CENTER);
m_badges_scroll.set_hexpand(true);
@@ -99,6 +101,7 @@ void ProfileWindow::on_hide() {
void ProfileWindow::OnFetchProfile(const UserProfileData &data) {
m_pane_info.SetConnections(data.ConnectedAccounts);
+ m_pane_guilds.SetMutualGuilds(data.MutualGuilds);
for (auto child : m_badges.get_children())
delete child;
diff --git a/windows/profilewindow.hpp b/windows/profilewindow.hpp
index 5d4f319..a5627d3 100644
--- a/windows/profilewindow.hpp
+++ b/windows/profilewindow.hpp
@@ -2,6 +2,7 @@
#include <gtkmm.h>
#include "../discord/snowflake.hpp"
#include "profile/userinfopane.hpp"
+#include "profile/mutualguildspane.hpp"
class ProfileWindow : public Gtk::Window {
public:
@@ -26,4 +27,5 @@ private:
Gtk::StackSwitcher m_switcher;
ProfileUserInfoPane m_pane_info;
+ UserMutualGuildsPane m_pane_guilds;
};