summaryrefslogtreecommitdiff
path: root/components/ratelimitindicator.hpp
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2021-04-15 02:35:36 -0400
committerouwou <26526779+ouwou@users.noreply.github.com>2021-04-15 02:35:36 -0400
commitcd8cd97c9b1fb297f4bf455135d0e0e690358c53 (patch)
tree1ae78c800072bb8154596566b1898ba232e9422c /components/ratelimitindicator.hpp
parent0aaebf9ea77eede8a347aa71b95e86686d04a854 (diff)
parentf5df43194e19be7995d753c5e9dd0a5a9365f24a (diff)
downloadabaddon-portaudio-cd8cd97c9b1fb297f4bf455135d0e0e690358c53.tar.gz
abaddon-portaudio-cd8cd97c9b1fb297f4bf455135d0e0e690358c53.zip
Merge branch 'slowmode'
Diffstat (limited to 'components/ratelimitindicator.hpp')
-rw-r--r--components/ratelimitindicator.hpp31
1 files changed, 31 insertions, 0 deletions
diff --git a/components/ratelimitindicator.hpp b/components/ratelimitindicator.hpp
new file mode 100644
index 0000000..d6ada43
--- /dev/null
+++ b/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
+};