summaryrefslogtreecommitdiff
path: root/src/dialogs/joinguild.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/dialogs/joinguild.hpp
parentfd53a76bf6f53a095a639765923a30f2206b2cd6 (diff)
parente02107feea8214a045e6faa969f00dcbc0d2b072 (diff)
downloadabaddon-portaudio-e1703aea3fd597b23bde90e6c505278c517be611.tar.gz
abaddon-portaudio-e1703aea3fd597b23bde90e6c505278c517be611.zip
merge master
Diffstat (limited to 'src/dialogs/joinguild.hpp')
-rw-r--r--src/dialogs/joinguild.hpp31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/dialogs/joinguild.hpp b/src/dialogs/joinguild.hpp
new file mode 100644
index 0000000..109d010
--- /dev/null
+++ b/src/dialogs/joinguild.hpp
@@ -0,0 +1,31 @@
+#pragma once
+#include <gtkmm.h>
+#include <string>
+#include <chrono>
+
+class JoinGuildDialog : public Gtk::Dialog {
+public:
+ JoinGuildDialog(Gtk::Window &parent);
+ std::string GetCode();
+
+protected:
+ void on_entry_changed();
+ bool IsCode(std::string str);
+
+ Gtk::Box m_layout;
+ Gtk::Button m_ok;
+ Gtk::Button m_cancel;
+ Gtk::Box m_lower;
+ Gtk::Label m_info;
+ Gtk::Entry m_entry;
+
+ void CheckCode();
+
+ // needs a rate limit cuz if u hit it u get ip banned from /invites for a long time :(
+ bool m_needs_request = false;
+ std::chrono::time_point<std::chrono::steady_clock> m_last_req_time;
+ bool on_idle_slot();
+
+private:
+ std::string m_code;
+};