[gnome-calendar] window: Turn search button into a DzlSuggestionButton
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-calendar] window: Turn search button into a DzlSuggestionButton
- Date: Mon, 29 Apr 2019 20:11:41 +0000 (UTC)
commit 36f4809c1cfc4559820a4f316b7c611ff0333945
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date: Fri Apr 26 18:45:36 2019 -0300
window: Turn search button into a DzlSuggestionButton
Gives us a nice, smooth and sweet animation.
data/ui/window.ui | 31 +---------
src/gcal-window.c | 132 +++++-----------------------------------
src/meson.build | 2 +
src/search/gcal-search-button.c | 110 +++++++++++++++++++++++++++++++++
src/search/gcal-search-button.h | 30 +++++++++
5 files changed, 159 insertions(+), 146 deletions(-)
---
diff --git a/data/ui/window.ui b/data/ui/window.ui
index 7c82b259..f68cd288 100644
--- a/data/ui/window.ui
+++ b/data/ui/window.ui
@@ -22,28 +22,6 @@
<property name="hexpand">True</property>
<property name="vexpand">True</property>
<property name="orientation">vertical</property>
- <child>
- <object class="GtkSearchBar" id="search_bar">
- <property name="visible">True</property>
- <property name="hexpand">True</property>
- <property name="show_close_button">True</property>
- <property name="search-mode-enabled" bind-source="search_button" bind-property="active"
bind-flags="bidirectional"/>
- <signal name="notify::search-mode-enabled" handler="search_toggled" object="GcalWindow"
swapped="no"/>
- <child>
- <object class="GtkSearchEntry" id="search_entry">
- <property name="width_request">500</property>
- <property name="visible">True</property>
- <property name="can_focus">True</property>
- <property name="halign">center</property>
- <property name="hexpand">True</property>
- <property name="primary_icon_name">edit-find-symbolic</property>
- <property name="primary_icon_activatable">False</property>
- <property name="primary_icon_sensitive">False</property>
- <signal name="search-changed" handler="search_changed" object="GcalWindow" swapped="no"/>
- </object>
- </child>
- </object>
- </child>
<child>
<object class="GtkStack" id="views_stack">
<property name="visible">True</property>
@@ -281,17 +259,11 @@
</packing>
</child>
<child>
- <object class="GtkToggleButton" id="search_button">
+ <object class="GcalSearchButton" id="search_button">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="tooltip_text" translatable="yes" context="tooltip">Search for events</property>
- <child>
- <object class="GtkImage" id="search_button_image">
- <property name="visible">True</property>
- <property name="icon_name">edit-find-symbolic</property>
- </object>
- </child>
</object>
<packing>
<property name="pack_type">end</property>
@@ -301,7 +273,6 @@
</child>
</template>
<object class="GcalSearchPopover" id="search_popover">
- <property name="relative_to">search_entry</property>
<property name="position">bottom</property>
<signal name="event-activated" handler="search_event_selected" object="GcalWindow" swapped="no"/>
</object>
diff --git a/src/gcal-window.c b/src/gcal-window.c
index cfa479c0..f3560eb5 100644
--- a/src/gcal-window.c
+++ b/src/gcal-window.c
@@ -26,6 +26,7 @@
#include "gcal-manager.h"
#include "gcal-month-view.h"
#include "gcal-quick-add-popover.h"
+#include "gcal-search-button.h"
#include "gcal-search-popover.h"
#include "gcal-source-dialog.h"
#include "gcal-view.h"
@@ -105,7 +106,6 @@ struct _GcalWindow
GtkWidget *main_box;
GtkWidget *header_bar;
- GtkWidget *search_bar;
GtkWidget *views_overlay;
GtkWidget *views_stack;
GtkWidget *week_view;
@@ -118,14 +118,14 @@ struct _GcalWindow
/* header_bar widets */
GtkWidget *menu_button;
- GtkWidget *search_button;
GtkWidget *calendars_button;
- GtkWidget *search_entry;
GtkWidget *back_button;
GtkWidget *today_button;
GtkWidget *forward_button;
GtkWidget *views_switcher;
+ DzlSuggestionButton *search_button;
+
/* new event popover widgets */
GtkWidget *quick_add_popover;
@@ -173,6 +173,7 @@ struct _GcalWindow
gint pos_x;
gint pos_y;
gboolean is_maximized;
+ gboolean in_key_press;
};
enum
@@ -199,16 +200,11 @@ static void on_view_action_activated (GSimpleAction
GVariant *param,
gpointer user_data);
-static void on_toggle_search_bar_activated (GSimpleAction *action,
- GVariant *param,
- gpointer user_data);
-
G_DEFINE_TYPE (GcalWindow, gcal_window, GTK_TYPE_APPLICATION_WINDOW)
static const GActionEntry actions[] = {
{"change-view", on_view_action_activated, "i" },
{"show-calendars", on_show_calendars_action_activated },
- {"toggle-search-bar", on_toggle_search_bar_activated }
};
static GParamSpec* properties[N_PROPS] = { NULL, };
@@ -218,25 +214,6 @@ static GParamSpec* properties[N_PROPS] = { NULL, };
* Auxiliary methods
*/
-static gboolean
-hide_search_view_on_click_outside (GcalWindow *window,
- GdkEventButton *event,
- GtkPopover *popover)
-{
- GdkWindow *search_view_window;
-
- search_view_window = gtk_widget_get_window (GTK_WIDGET (popover));
-
- /* If the event is not produced in the search view widget, we hide the search_bar */
- if (event->window != search_view_window)
- {
- gtk_popover_popdown (popover);
- gtk_search_bar_set_search_mode (GTK_SEARCH_BAR (window->search_bar), FALSE);
- }
-
- return GDK_EVENT_PROPAGATE;
-}
-
static void
update_today_button_sensitive (GcalWindow *window)
{
@@ -469,34 +446,6 @@ on_view_action_activated (GSimpleAction *action,
g_object_notify_by_pspec (G_OBJECT (user_data), properties[PROP_ACTIVE_VIEW]);
}
-static void
-on_toggle_search_bar_activated (GSimpleAction *action,
- GVariant *param,
- gpointer user_data)
-{
- GcalWindow *window = GCAL_WINDOW (user_data);
- gint search_mode;
-
- search_mode = gtk_search_bar_get_search_mode (GTK_SEARCH_BAR (window->search_bar));
- gtk_search_bar_set_search_mode (GTK_SEARCH_BAR (window->search_bar), !search_mode);
-}
-
-
-static gboolean
-key_pressed (GtkWidget *widget,
- GdkEvent *event,
- gpointer user_data)
-{
- GcalWindow *window = GCAL_WINDOW (user_data);
-
- /* special case: creating an event */
- if (window->new_event_mode)
- return GDK_EVENT_PROPAGATE;
-
- return gtk_search_bar_handle_event (GTK_SEARCH_BAR (window->search_bar),
- event);
-}
-
static void
search_event_selected (GcalSearchPopover *search_view,
icaltimetype *date,
@@ -1076,59 +1025,6 @@ edit_dialog_closed (GtkDialog *dialog,
GCAL_EXIT;
}
-static void
-search_toggled (GObject *object,
- GParamSpec *pspec,
- gpointer user_data)
-{
- GcalWindow *window = GCAL_WINDOW (user_data);
-
- /* update header_bar widget */
- if (gtk_search_bar_get_search_mode (GTK_SEARCH_BAR (window->search_bar)))
- {
- gcal_search_popover_search (GCAL_SEARCH_POPOVER (window->search_popover), NULL, NULL);
-
- /* When the search button is toogled we connect the signal */
- window->click_outside_handler_id = g_signal_connect (window,
- "button-press-event",
- G_CALLBACK (hide_search_view_on_click_outside),
- window->search_popover);
- }
- else
- {
- /* When the search mode is false we disconnect the handler */
- g_signal_handler_disconnect (window, window->click_outside_handler_id);
- }
-
-}
-
-static void
-search_changed (GtkEditable *editable,
- gpointer user_data)
-{
- GcalWindow *window = GCAL_WINDOW (user_data);
- gint search_length;
-
- if (gtk_search_bar_get_search_mode (GTK_SEARCH_BAR (window->search_bar)))
- {
- /* perform the search or hide when the field is empty */
-
- search_length = gtk_entry_get_text_length (GTK_ENTRY (window->search_entry));
-
- if (search_length)
- {
- gtk_popover_popup (GTK_POPOVER (window->search_popover));
- gcal_search_popover_search (GCAL_SEARCH_POPOVER (window->search_popover),
- "summary",
- gtk_entry_get_text (GTK_ENTRY (window->search_entry)));
- }
- else
- {
- gtk_popover_popdown (GTK_POPOVER (window->search_popover));
- }
- }
-}
-
static void
remove_event (GtkWidget *notification,
GParamSpec *spec,
@@ -1399,6 +1295,7 @@ gcal_window_class_init (GcalWindowClass *klass)
g_type_ensure (GCAL_TYPE_MANAGER);
g_type_ensure (GCAL_TYPE_MONTH_VIEW);
g_type_ensure (GCAL_TYPE_QUICK_ADD_POPOVER);
+ g_type_ensure (GCAL_TYPE_SEARCH_BUTTON);
g_type_ensure (GCAL_TYPE_SEARCH_POPOVER);
g_type_ensure (GCAL_TYPE_SOURCE_DIALOG);
g_type_ensure (GCAL_TYPE_WEATHER_SETTINGS);
@@ -1456,10 +1353,8 @@ gcal_window_class_init (GcalWindowClass *klass)
gtk_widget_class_bind_template_child (widget_class, GcalWindow, menu_button);
gtk_widget_class_bind_template_child (widget_class, GcalWindow, month_view);
gtk_widget_class_bind_template_child (widget_class, GcalWindow, quick_add_popover);
- gtk_widget_class_bind_template_child (widget_class, GcalWindow, search_bar);
gtk_widget_class_bind_template_child (widget_class, GcalWindow, search_button);
gtk_widget_class_bind_template_child (widget_class, GcalWindow, source_dialog);
- gtk_widget_class_bind_template_child (widget_class, GcalWindow, search_entry);
gtk_widget_class_bind_template_child (widget_class, GcalWindow, search_popover);
gtk_widget_class_bind_template_child (widget_class, GcalWindow, today_button);
gtk_widget_class_bind_template_child (widget_class, GcalWindow, views_overlay);
@@ -1476,9 +1371,6 @@ gcal_window_class_init (GcalWindowClass *klass)
gtk_widget_class_bind_template_callback (widget_class, source_row_activated);
- gtk_widget_class_bind_template_callback (widget_class, key_pressed);
- gtk_widget_class_bind_template_callback (widget_class, search_toggled);
- gtk_widget_class_bind_template_callback (widget_class, search_changed);
gtk_widget_class_bind_template_callback (widget_class, view_changed);
gtk_widget_class_bind_template_callback (widget_class, date_updated);
@@ -1530,6 +1422,13 @@ gcal_window_init (GcalWindow *self)
self->active_date = g_date_time_new_from_unix_local (0);
self->rtl = gtk_widget_get_direction (GTK_WIDGET (self)) == GTK_TEXT_DIR_RTL;
+ /* Dzl shortcut support */
+ g_signal_connect_object (self,
+ "key-press-event",
+ G_CALLBACK (dzl_shortcut_manager_handle_event),
+ NULL,
+ G_CONNECT_SWAPPED);
+
/* setup accels */
app = g_application_get_default ();
gcal_window_add_accelerator (app, "win.change-view(-1)", "<Ctrl>Page_Down");
@@ -1537,7 +1436,6 @@ gcal_window_init (GcalWindow *self)
gcal_window_add_accelerator (app, "win.change-view(1)", "<Ctrl>1")
gcal_window_add_accelerator (app, "win.change-view(2)", "<Ctrl>2");
gcal_window_add_accelerator (app, "win.change-view(3)", "<Ctrl>3");
- gcal_window_add_accelerator (app, "win.toggle-search-bar", "<Ctrl>f");
gcal_window_add_accelerator (app, "app.quit", "<Ctrl>q");
}
@@ -1577,7 +1475,6 @@ gcal_window_set_search_mode (GcalWindow *self,
g_return_if_fail (GCAL_IS_WINDOW (self));
self->search_mode = enabled;
- gtk_search_bar_set_search_mode (GTK_SEARCH_BAR (self->search_bar), enabled);
}
/**
@@ -1593,9 +1490,12 @@ void
gcal_window_set_search_query (GcalWindow *self,
const gchar *query)
{
+ DzlSuggestionEntry *entry;
+
g_return_if_fail (GCAL_IS_WINDOW (self));
- gtk_entry_set_text (GTK_ENTRY (self->search_entry), query);
+ entry = dzl_suggestion_button_get_entry (self->search_button);
+ gtk_entry_set_text (GTK_ENTRY (entry), query);
}
/**
diff --git a/src/meson.build b/src/meson.build
index dd081ade..d7ddc6de 100644
--- a/src/meson.build
+++ b/src/meson.build
@@ -20,6 +20,7 @@ gcal_deps = [
]
sources = files(
+ 'search/gcal-search-button.c',
'utils/gcal-date-time-utils.c',
'utils/gcal-utils.c',
'views/gcal-month-cell.c',
@@ -107,6 +108,7 @@ sources += configure_file(
incs = [
top_inc,
+ include_directories('search'),
include_directories('utils'),
include_directories('views'),
include_directories('weather'),
diff --git a/src/search/gcal-search-button.c b/src/search/gcal-search-button.c
new file mode 100644
index 00000000..bf0d2ad3
--- /dev/null
+++ b/src/search/gcal-search-button.c
@@ -0,0 +1,110 @@
+/* gcal-search-button.c
+ *
+ * Copyright 2019 Georges Basile Stavracas Neto <georges stavracas gmail com>
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ */
+
+#define G_LOG_DOMAIN "GcalSearchButton"
+
+#include "gcal-search-button.h"
+
+struct _GcalSearchButton
+{
+ DzlSuggestionButton parent;
+};
+
+G_DEFINE_TYPE (GcalSearchButton, gcal_search_button, DZL_TYPE_SUGGESTION_BUTTON)
+
+
+/*
+ * Callbacks
+ */
+
+static void
+on_unfocus_action_activated_cb (GSimpleAction *action,
+ GVariant *param,
+ gpointer user_data)
+{
+ DzlSuggestionEntry *entry;
+ GcalSearchButton *self;
+ GtkWidget *toplevel;
+
+ g_assert (GCAL_IS_SEARCH_BUTTON (user_data));
+ g_assert (G_IS_SIMPLE_ACTION (action));
+
+ g_debug ("Unfocusing search button");
+
+ self = GCAL_SEARCH_BUTTON (user_data);
+ entry = dzl_suggestion_button_get_entry (DZL_SUGGESTION_BUTTON (self));
+ g_signal_emit_by_name (entry, "hide-suggestions");
+
+ toplevel = gtk_widget_get_toplevel (GTK_WIDGET (self));
+ gtk_widget_grab_focus (toplevel);
+ gtk_entry_set_text (GTK_ENTRY (entry), "");
+}
+
+static void
+on_shortcut_grab_focus_cb (GtkWidget *widget,
+ gpointer user_data)
+{
+ g_debug ("Focusing search button");
+
+ gtk_widget_grab_focus (GTK_WIDGET (user_data));
+}
+
+
+static void
+gcal_search_button_class_init (GcalSearchButtonClass *klass)
+{
+}
+
+static void
+gcal_search_button_init (GcalSearchButton *self)
+{
+ g_autoptr (GSimpleActionGroup) group = NULL;
+ DzlShortcutController *controller;
+ DzlSuggestionEntry *entry;
+
+ static GActionEntry actions[] = {
+ { "unfocus", on_unfocus_action_activated_cb },
+ };
+
+ group = g_simple_action_group_new ();
+ g_action_map_add_action_entries (G_ACTION_MAP (group),
+ actions,
+ G_N_ELEMENTS (actions),
+ self);
+
+ gtk_widget_insert_action_group (GTK_WIDGET (self), "search", G_ACTION_GROUP (group));
+
+ entry = dzl_suggestion_button_get_entry (DZL_SUGGESTION_BUTTON (self));
+ controller = dzl_shortcut_controller_find (GTK_WIDGET (entry));
+
+ dzl_shortcut_controller_add_command_callback (controller,
+ "org.gnome.calendar.search",
+ "<Primary>f",
+ DZL_SHORTCUT_PHASE_CAPTURE | DZL_SHORTCUT_PHASE_GLOBAL,
+ on_shortcut_grab_focus_cb,
+ self,
+ NULL);
+
+ dzl_shortcut_controller_add_command_action (controller,
+ "org.gnome.calendar.search-button.unfocus",
+ "Escape",
+ DZL_SHORTCUT_PHASE_CAPTURE,
+ "search.unfocus");
+}
diff --git a/src/search/gcal-search-button.h b/src/search/gcal-search-button.h
new file mode 100644
index 00000000..c9f3fd97
--- /dev/null
+++ b/src/search/gcal-search-button.h
@@ -0,0 +1,30 @@
+/* gcal-search-button.h
+ *
+ * Copyright 2019 Georges Basile Stavracas Neto <georges stavracas gmail com>
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ */
+
+#pragma once
+
+#include <dazzle.h>
+
+G_BEGIN_DECLS
+
+#define GCAL_TYPE_SEARCH_BUTTON (gcal_search_button_get_type())
+G_DECLARE_FINAL_TYPE (GcalSearchButton, gcal_search_button, GCAL, SEARCH_BUTTON, DzlSuggestionButton)
+
+G_END_DECLS
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]