aboutsummaryrefslogtreecommitdiff
path: root/main/src/ui
diff options
context:
space:
mode:
authorTeemu Ikonen <tpikonen@mailbox.org>2022-09-12 17:43:30 +0300
committerMarvin W <git@larma.de>2023-01-24 19:20:43 +0100
commit0d7c8bb6e117f8cdd631730302413aad21632c2d (patch)
treed404cc81ba6c6605f43db2535857956659e77196 /main/src/ui
parente934a76a1139938ae668836b812102cd5d9c9d9f (diff)
downloaddino-0d7c8bb6e117f8cdd631730302413aad21632c2d.tar.gz
dino-0d7c8bb6e117f8cdd631730302413aad21632c2d.zip
Change Gtk.Paned to Adw.Leaflet in MainWindow
Diffstat (limited to 'main/src/ui')
-rw-r--r--main/src/ui/main_window.vala13
1 files changed, 8 insertions, 5 deletions
diff --git a/main/src/ui/main_window.vala b/main/src/ui/main_window.vala
index 4d660f82..9aeb4217 100644
--- a/main/src/ui/main_window.vala
+++ b/main/src/ui/main_window.vala
@@ -20,7 +20,7 @@ public class MainWindow : Adw.Window {
public ConversationTitlebar conversation_titlebar;
public Widget conversation_list_titlebar;
public Box box = new Box(Orientation.VERTICAL, 0) { orientation=Orientation.VERTICAL };
- public Paned paned;
+ public Adw.Leaflet leaflet;
public Box left_box;
public Box right_box;
public Revealer search_revealer;
@@ -60,8 +60,8 @@ public class MainWindow : Adw.Window {
private void setup_unified() {
Builder builder = new Builder.from_resource("/im/dino/Dino/unified_main_content.ui");
- paned = (Paned) builder.get_object("paned");
- box.append(paned);
+ leaflet = (Adw.Leaflet) builder.get_object("leaflet");
+ box.append(leaflet);
left_box = (Box) builder.get_object("left_box");
right_box = (Box) builder.get_object("right_box");
left_stack = (Stack) builder.get_object("left_stack");
@@ -69,6 +69,7 @@ public class MainWindow : Adw.Window {
conversation_view = (ConversationView) builder.get_object("conversation_view");
search_revealer = (Revealer) builder.get_object("search_revealer");
conversation_selector = ((ConversationSelector) builder.get_object("conversation_list")).init(stream_interactor);
+ conversation_selector.conversation_selected.connect_after(() => leaflet.navigate(Adw.NavigationDirection.FORWARD));
Frame search_frame = (Frame) builder.get_object("search_frame");
global_search = new GlobalSearch(stream_interactor);
@@ -82,8 +83,8 @@ public class MainWindow : Adw.Window {
if (Util.use_csd()) {
conversation_list_titlebar = get_conversation_list_titlebar_csd();
conversation_titlebar = new ConversationTitlebarCsd();
- paned.bind_property("folded", conversation_list_titlebar, "show-end-title-buttons", BindingFlags.SYNC_CREATE);
- paned.bind_property("folded", conversation_titlebar.get_widget(), "show-start-title-buttons", BindingFlags.SYNC_CREATE);
+ leaflet.bind_property("folded", conversation_list_titlebar, "show-end-title-buttons", BindingFlags.SYNC_CREATE);
+ leaflet.bind_property("folded", conversation_titlebar.get_widget(), "show-start-title-buttons", BindingFlags.SYNC_CREATE);
} else {
Label title_label = new Label("Dino");
HeaderBar titlebar = new HeaderBar() { title_widget=title_label, show_title_buttons=true };
@@ -94,6 +95,8 @@ public class MainWindow : Adw.Window {
}
left_box.prepend(conversation_list_titlebar);
right_box.prepend(conversation_titlebar.get_widget());
+ leaflet.notify["folded"].connect_after(() => conversation_titlebar.back_button_visible = leaflet.folded);
+ conversation_titlebar.back_pressed.connect(() => leaflet.navigate(Adw.NavigationDirection.BACK));
}
private void setup_stack() {