[libadwaita/wip/exalm/tab-overview: 2/2] Demo
- From: Alexander Mikhaylenko <alexm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libadwaita/wip/exalm/tab-overview: 2/2] Demo
- Date: Tue, 6 Sep 2022 01:59:57 +0000 (UTC)
commit 3b8b32680f0ad90b45bf3f0528e8586bf332ee87
Author: Alexander Mikhaylenko <alexm gnome org>
Date: Fri Aug 12 03:15:10 2022 +0400
Demo
demo/pages/tab-view/adw-tab-view-demo-window.c | 120 +++++++++++++++++++++---
demo/pages/tab-view/adw-tab-view-demo-window.ui | 84 +++++++++++------
demo/style.css | 5 +
3 files changed, 167 insertions(+), 42 deletions(-)
---
diff --git a/demo/pages/tab-view/adw-tab-view-demo-window.c b/demo/pages/tab-view/adw-tab-view-demo-window.c
index 4462e535..1ce734da 100644
--- a/demo/pages/tab-view/adw-tab-view-demo-window.c
+++ b/demo/pages/tab-view/adw-tab-view-demo-window.c
@@ -7,14 +7,25 @@ struct _AdwTabViewDemoWindow
AdwWindow parent_instance;
AdwTabView *view;
AdwTabBar *tab_bar;
+ AdwTabOverview *tab_overview;
GActionMap *tab_action_group;
AdwTabPage *menu_page;
+ gboolean narrow;
+ gboolean in_dispose;
};
G_DEFINE_TYPE (AdwTabViewDemoWindow, adw_tab_view_demo_window, ADW_TYPE_WINDOW)
+enum {
+ PROP_0,
+ PROP_NARROW,
+ LAST_PROP,
+};
+
+static GParamSpec *props[LAST_PROP];
+
char **icon_names = NULL;
gsize n_icon_names = 0;
@@ -96,35 +107,44 @@ add_page (AdwTabViewDemoWindow *self,
adw_tab_page_set_icon (page, icon);
adw_tab_page_set_indicator_activatable (page, TRUE);
+ adw_tab_page_set_thumbnail_xalign (page, 0.5);
+ adw_tab_page_set_thumbnail_yalign (page, 0.5);
return page;
}
-static void
-tab_new (GSimpleAction *action,
- GVariant *parameter,
- gpointer user_data)
+static AdwTabPage *
+create_tab_cb (AdwTabViewDemoWindow *self)
{
- AdwTabViewDemoWindow *self = ADW_TAB_VIEW_DEMO_WINDOW (user_data);
char *title;
- AdwTabPage *page;
- GtkWidget *content;
GIcon *icon;
+ AdwTabPage *page;
static int next_page = 1;
title = g_strdup_printf (_("Tab %d"), next_page);
icon = get_random_icon (self);
page = add_page (self, NULL, title, icon);
- content = adw_tab_page_get_child (page);
-
- adw_tab_view_set_selected_page (self->view, page);
-
- gtk_widget_grab_focus (content);
next_page++;
g_free (title);
+
+ return page;
+}
+
+static void
+tab_new (GSimpleAction *action,
+ GVariant *parameter,
+ gpointer user_data)
+{
+ AdwTabViewDemoWindow *self = ADW_TAB_VIEW_DEMO_WINDOW (user_data);
+ AdwTabPage *page = create_tab_cb (self);
+ GtkWidget *content = adw_tab_page_get_child (page);
+
+ adw_tab_view_set_selected_page (self->view, page);
+
+ gtk_widget_grab_focus (content);
}
static AdwTabPage *
@@ -401,7 +421,11 @@ static void
page_detached_cb (AdwTabViewDemoWindow *self,
AdwTabPage *page)
{
- if (!adw_tab_view_get_n_pages (self->view))
+ if (self->in_dispose)
+ return;
+
+ if (!adw_tab_view_get_n_pages (self->view) &&
+ !adw_tab_overview_get_open (self->tab_overview))
gtk_window_close (GTK_WINDOW (self));
}
@@ -497,11 +521,50 @@ extra_drag_drop_cb (AdwTabViewDemoWindow *self,
return GDK_EVENT_STOP;
}
+static void
+adw_tab_view_demo_window_size_allocate (GtkWidget *widget,
+ int width,
+ int height,
+ int baseline)
+{
+ AdwTabViewDemoWindow *self = ADW_TAB_VIEW_DEMO_WINDOW (widget);
+ gboolean narrow = width < 600;
+
+ if (self->narrow != narrow) {
+ self->narrow = narrow;
+ g_object_notify_by_pspec (G_OBJECT (self), props[PROP_NARROW]);
+ }
+
+ GTK_WIDGET_CLASS (adw_tab_view_demo_window_parent_class)->size_allocate (widget,
+ width,
+ height,
+ baseline);
+}
+
+static void
+adw_tab_view_demo_window_get_property (GObject *object,
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ AdwTabViewDemoWindow *self = ADW_TAB_VIEW_DEMO_WINDOW (object);
+
+ switch (prop_id) {
+ case PROP_NARROW:
+ g_value_set_boolean (value, self->narrow);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ }
+}
+
static void
adw_tab_view_demo_window_dispose (GObject *object)
{
AdwTabViewDemoWindow *self = ADW_TAB_VIEW_DEMO_WINDOW (object);
+ self->in_dispose = TRUE;
+
g_clear_object (&self->tab_action_group);
G_OBJECT_CLASS (adw_tab_view_demo_window_parent_class)->dispose (object);
@@ -514,12 +577,24 @@ adw_tab_view_demo_window_class_init (AdwTabViewDemoWindowClass *klass)
GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
object_class->dispose = adw_tab_view_demo_window_dispose;
+ object_class->get_property = adw_tab_view_demo_window_get_property;
+
+ widget_class->size_allocate = adw_tab_view_demo_window_size_allocate;
+
+ props[PROP_NARROW] =
+ g_param_spec_boolean ("narrow", NULL, NULL,
+ FALSE,
+ G_PARAM_READABLE | G_PARAM_STATIC_STRINGS);
+
+ g_object_class_install_properties (object_class, LAST_PROP, props);
gtk_widget_class_set_template_from_resource (widget_class,
"/org/gnome/Adwaita1/Demo/ui/pages/tab-view/adw-tab-view-demo-window.ui");
gtk_widget_class_bind_template_child (widget_class, AdwTabViewDemoWindow, view);
gtk_widget_class_bind_template_child (widget_class, AdwTabViewDemoWindow, tab_bar);
+ gtk_widget_class_bind_template_child (widget_class, AdwTabViewDemoWindow, tab_overview);
gtk_widget_class_bind_template_callback (widget_class, page_detached_cb);
gtk_widget_class_bind_template_callback (widget_class, setup_menu_cb);
+ gtk_widget_class_bind_template_callback (widget_class, create_tab_cb);
gtk_widget_class_bind_template_callback (widget_class, create_window_cb);
gtk_widget_class_bind_template_callback (widget_class, indicator_activated_cb);
gtk_widget_class_bind_template_callback (widget_class, extra_drag_drop_cb);
@@ -533,6 +608,8 @@ static void
adw_tab_view_demo_window_init (AdwTabViewDemoWindow *self)
{
GActionMap *action_map;
+ GdkDisplay *display;
+ AdwStyleManager *style_manager;
gtk_widget_init_template (GTK_WIDGET (self));
@@ -558,6 +635,21 @@ adw_tab_view_demo_window_init (AdwTabViewDemoWindow *self)
adw_tab_bar_setup_extra_drop_target (self->tab_bar,
GDK_ACTION_COPY,
(GType[1]) { G_TYPE_STRING }, 1);
+ adw_tab_overview_setup_extra_drop_target (self->tab_overview,
+ GDK_ACTION_COPY,
+ (GType[1]) { G_TYPE_STRING }, 1);
+
+ display = gtk_widget_get_display (GTK_WIDGET (self));
+ style_manager = adw_style_manager_get_for_display (display);
+
+ g_signal_connect_object (style_manager, "notify::dark",
+ G_CALLBACK (adw_tab_view_invalidate_thumbnails),
+ self->view,
+ G_CONNECT_SWAPPED);
+ g_signal_connect_object (style_manager, "notify::high-contrast",
+ G_CALLBACK (adw_tab_view_invalidate_thumbnails),
+ self->view,
+ G_CONNECT_SWAPPED);
}
AdwTabViewDemoWindow *
@@ -572,4 +664,6 @@ adw_tab_view_demo_window_prepopulate (AdwTabViewDemoWindow *self)
tab_new (NULL, NULL, self);
tab_new (NULL, NULL, self);
tab_new (NULL, NULL, self);
+
+ adw_tab_view_invalidate_thumbnails (self->view);
}
diff --git a/demo/pages/tab-view/adw-tab-view-demo-window.ui b/demo/pages/tab-view/adw-tab-view-demo-window.ui
index a53ad72e..11784b0f 100644
--- a/demo/pages/tab-view/adw-tab-view-demo-window.ui
+++ b/demo/pages/tab-view/adw-tab-view-demo-window.ui
@@ -6,41 +6,67 @@
<property name="title" translatable="yes">Tab View Demo</property>
<property name="default-width">800</property>
<property name="default-height">600</property>
+ <property name="width-request">360</property>
<property name="content">
- <object class="GtkBox">
- <property name="orientation">vertical</property>
- <child>
- <object class="GtkHeaderBar">
- <child type="start">
- <object class="GtkButton">
- <property name="action-name">win.tab-new</property>
- <property name="icon-name">tab-new-symbolic</property>
+ <object class="AdwTabOverview" id="tab_overview">
+ <property name="view">view</property>
+ <property name="enable-new-tab">True</property>
+ <signal name="extra-drag-drop" handler="extra_drag_drop_cb" swapped="true"/>
+ <signal name="create-tab" handler="create_tab_cb" swapped="true"/>
+ <property name="child">
+ <object class="GtkBox">
+ <property name="orientation">vertical</property>
+ <child>
+ <object class="GtkHeaderBar">
+ <child type="start">
+ <object class="GtkButton">
+ <property name="action-name">win.window-new</property>
+ <property name="icon-name">window-new-symbolic</property>
+ </object>
+ </child>
+ <child type="end">
+ <object class="AdwTabButton">
+ <property name="visible" bind-source="AdwTabViewDemoWindow" bind-property="narrow"
bind-flags="sync-create"/>
+ <property name="view">view</property>
+ <property name="action-name">overview.open</property>
+ </object>
+ </child>
+ <child type="end">
+ <object class="GtkButton">
+ <property name="visible" bind-source="AdwTabViewDemoWindow" bind-property="narrow"
bind-flags="invert-boolean"/>
+ <property name="icon-name">view-grid-symbolic</property>
+ <property name="tooltip-text" translatable="yes">View Open Tabs</property>
+ <property name="action-name">overview.open</property>
+ </object>
+ </child>
+ <child type="end">
+ <object class="GtkButton">
+ <property name="visible" bind-source="AdwTabViewDemoWindow" bind-property="narrow"
bind-flags="invert-boolean"/>
+ <property name="action-name">win.tab-new</property>
+ <property name="icon-name">tab-new-symbolic</property>
+ </object>
+ </child>
</object>
</child>
- <child type="end">
- <object class="GtkButton">
- <property name="action-name">win.window-new</property>
- <property name="icon-name">window-new-symbolic</property>
+ <child>
+ <object class="AdwTabBar" id="tab_bar">
+ <property name="visible" bind-source="AdwTabViewDemoWindow" bind-property="narrow"
bind-flags="invert-boolean"/>
+ <property name="view">view</property>
+ <signal name="extra-drag-drop" handler="extra_drag_drop_cb" swapped="true"/>
+ </object>
+ </child>
+ <child>
+ <object class="AdwTabView" id="view">
+ <property name="vexpand">True</property>
+ <property name="menu-model">tab_menu</property>
+ <signal name="page-detached" handler="page_detached_cb" swapped="true"/>
+ <signal name="setup-menu" handler="setup_menu_cb" swapped="true"/>
+ <signal name="create-window" handler="create_window_cb" swapped="true"/>
+ <signal name="indicator-activated" handler="indicator_activated_cb" swapped="true"/>
</object>
</child>
</object>
- </child>
- <child>
- <object class="AdwTabBar" id="tab_bar">
- <property name="view">view</property>
- <signal name="extra-drag-drop" handler="extra_drag_drop_cb" swapped="true"/>
- </object>
- </child>
- <child>
- <object class="AdwTabView" id="view">
- <property name="vexpand">True</property>
- <property name="menu-model">tab_menu</property>
- <signal name="page-detached" handler="page_detached_cb" swapped="true"/>
- <signal name="setup-menu" handler="setup_menu_cb" swapped="true"/>
- <signal name="create-window" handler="create_window_cb" swapped="true"/>
- <signal name="indicator-activated" handler="indicator_activated_cb" swapped="true"/>
- </object>
- </child>
+ </property>
</object>
</property>
</template>
diff --git a/demo/style.css b/demo/style.css
index 53aa8b52..10dfe79a 100644
--- a/demo/style.css
+++ b/demo/style.css
@@ -48,3 +48,8 @@ flowbox.inline flowboxchild {
border-radius: 24px;
background: linear-gradient(to bottom, @green_2, @green_5);
}
+
+tabview > * {
+ background-color: @view_bg_color;
+ color: @view_fg_color;
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]