summaryrefslogtreecommitdiff
path: root/src/components/ratelimitindicator.hpp
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2021-11-28 22:48:30 -0500
committerouwou <26526779+ouwou@users.noreply.github.com>2021-11-28 22:48:30 -0500
commite1703aea3fd597b23bde90e6c505278c517be611 (patch)
tree37d98fc90c9cd0844388bfb79beda2204f44af92 /src/components/ratelimitindicator.hpp
parentfd53a76bf6f53a095a639765923a30f2206b2cd6 (diff)
parente02107feea8214a045e6faa969f00dcbc0d2b072 (diff)
downloadabaddon-portaudio-e1703aea3fd597b23bde90e6c505278c517be611.tar.gz
abaddon-portaudio-e1703aea3fd597b23bde90e6c505278c517be611.zip
merge master
Diffstat (limited to 'src/components/ratelimitindicator.hpp')
-rw-r--r--src/components/ratelimitindicator.hpp31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/components/ratelimitindicator.hpp b/src/components/ratelimitindicator.hpp
new file mode 100644
index 0000000..b4dbb69
--- /dev/null
+++ b/src/components/ratelimitindicator.hpp
@@ -0,0 +1,31 @@
+#pragma once
+#include <gtkmm.h>
+#include <unordered_map>
+#include <chrono>
+#include "discord/message.hpp"
+
+class RateLimitIndicator : public Gtk::Box {
+public:
+ RateLimitIndicator();
+ void SetActiveChannel(Snowflake id);
+
+ // even tho this probably isnt the right place for this im gonna do it anyway to reduce coad
+ bool CanSpeak() const;
+
+private:
+ int GetTimeLeft() const;
+ int GetRateLimit() const;
+ bool UpdateIndicator();
+ void OnMessageCreate(const Message &message);
+ void OnMessageSendFail(const std::string &nonce, float rate_limit);
+ void OnChannelUpdate(Snowflake channel_id);
+
+ Gtk::Image m_img;
+ Gtk::Label m_label;
+
+ sigc::connection m_connection;
+
+ int m_rate_limit;
+ Snowflake m_active_channel;
+ std::unordered_map<Snowflake, std::chrono::time_point<std::chrono::steady_clock>> m_times; // time point of when next message can be sent
+};