summaryrefslogtreecommitdiff
path: root/components/draglistbox.hpp
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2021-03-12 01:55:46 -0500
committerouwou <26526779+ouwou@users.noreply.github.com>2021-03-12 01:55:46 -0500
commitae38add9310cf95756e3f0ea3c1ecfa3eaaffbec (patch)
treed351e277f3e2d089104e2a11b030ccb6b202a95f /components/draglistbox.hpp
parentf35dea89f9dd88e6570b9c713ded2017bf2f5889 (diff)
downloadabaddon-portaudio-ae38add9310cf95756e3f0ea3c1ecfa3eaaffbec.tar.gz
abaddon-portaudio-ae38add9310cf95756e3f0ea3c1ecfa3eaaffbec.zip
add ability to reorder roles
- some other small tweaks
Diffstat (limited to 'components/draglistbox.hpp')
-rw-r--r--components/draglistbox.hpp45
1 files changed, 45 insertions, 0 deletions
diff --git a/components/draglistbox.hpp b/components/draglistbox.hpp
new file mode 100644
index 0000000..9f204be
--- /dev/null
+++ b/components/draglistbox.hpp
@@ -0,0 +1,45 @@
+#pragma once
+#include <gtkmm.h>
+
+class DragListBox : public Gtk::ListBox {
+public:
+ DragListBox();
+
+ void row_drag_begin(Gtk::Widget *widget, const Glib::RefPtr<Gdk::DragContext> &context);
+
+ bool on_drag_motion(const Glib::RefPtr<Gdk::DragContext> &context, gint x, gint y, guint time) override;
+
+ void on_drag_leave(const Glib::RefPtr<Gdk::DragContext> &context, guint time) override;
+
+ void check_scroll(gint y);
+
+ bool scroll();
+
+ void on_drag_data_received(const Glib::RefPtr<Gdk::DragContext> &context, int x, int y, const Gtk::SelectionData &selection_data, guint info, guint time) override;
+
+ void add_draggable(Gtk::ListBoxRow *widget);
+
+private:
+ Gtk::ListBoxRow *m_hover_row = nullptr;
+ Gtk::ListBoxRow *m_drag_row = nullptr;
+ bool m_top = false;
+ int m_hover_top = 0;
+ int m_hover_bottom = 0;
+ bool m_should_scroll = false;
+ bool m_scrolling = false;
+ bool m_scroll_up = false;
+
+ constexpr static int SCROLL_STEP_SIZE = 8;
+ constexpr static int SCROLL_DISTANCE = 30;
+ constexpr static int SCROLL_DELAY = 50;
+
+ const std::vector<Gtk::TargetEntry> m_entries = {
+ Gtk::TargetEntry("GTK_LIST_BOX_ROW", Gtk::TARGET_SAME_APP, 0),
+ };
+
+ using type_signal_on_drop = sigc::signal<bool, Gtk::ListBoxRow *, int /* new index */>;
+ type_signal_on_drop m_signal_on_drop;
+
+public:
+ type_signal_on_drop signal_on_drop(); // return true to prevent drop
+};