diff options
author | Claudio Saavedra <csaavedra@igalia.com> | 2011-08-29 17:55:41 +0800 |
---|---|---|
committer | Xan Lopez <xan@igalia.com> | 2012-03-07 04:49:46 +0800 |
commit | f73a9d9a5ba6a3f7613fc566af24c75d022a27ec (patch) | |
tree | 5d9dc35acaf9bbacb39d2578961b038728ee46bb | |
parent | e9578ad2e1af09bc0a3920ccc83783bcd3d9eb53 (diff) | |
download | gsoc2013-epiphany-f73a9d9a5ba6a3f7613fc566af24c75d022a27ec.tar gsoc2013-epiphany-f73a9d9a5ba6a3f7613fc566af24c75d022a27ec.tar.gz gsoc2013-epiphany-f73a9d9a5ba6a3f7613fc566af24c75d022a27ec.tar.bz2 gsoc2013-epiphany-f73a9d9a5ba6a3f7613fc566af24c75d022a27ec.tar.lz gsoc2013-epiphany-f73a9d9a5ba6a3f7613fc566af24c75d022a27ec.tar.xz gsoc2013-epiphany-f73a9d9a5ba6a3f7613fc566af24c75d022a27ec.tar.zst gsoc2013-epiphany-f73a9d9a5ba6a3f7613fc566af24c75d022a27ec.zip |
Add a new view for the pages history
The current view is based in EphyNode, so it's not useful. GtkTreeView
and GtkListStore subclasses are added for this purpose.
-rw-r--r-- | embed/Makefile.am | 4 | ||||
-rw-r--r-- | embed/ephy-history-store.c | 99 | ||||
-rw-r--r-- | embed/ephy-history-store.h | 66 | ||||
-rw-r--r-- | embed/ephy-history-view.c | 178 | ||||
-rw-r--r-- | embed/ephy-history-view.h | 56 |
5 files changed, 403 insertions, 0 deletions
diff --git a/embed/Makefile.am b/embed/Makefile.am index 8476bfc39..dec4afbe9 100644 --- a/embed/Makefile.am +++ b/embed/Makefile.am @@ -26,6 +26,8 @@ INST_H_FILES = \ ephy-embed-shell.h \ ephy-embed-utils.h \ ephy-history.h \ + ephy-history-store.h \ + ephy-history-view.h \ ephy-permission-manager.h \ ephy-web-view.h @@ -48,6 +50,8 @@ libephyembed_la_SOURCES = \ ephy-encodings.c \ ephy-favicon-cache.c \ ephy-history.c \ + ephy-history-store.c \ + ephy-history-view.c \ ephy-permission-manager.c \ ephy-request-about.c \ ephy-embed-prefs.c \ diff --git a/embed/ephy-history-store.c b/embed/ephy-history-store.c new file mode 100644 index 000000000..37ccaaf9c --- /dev/null +++ b/embed/ephy-history-store.c @@ -0,0 +1,99 @@ +/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ +/* vim: set sw=2 ts=2 sts=2 et: */ +/* + * Copyright © 2011, 2012 Igalia S.L. + * + * 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 2, 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, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + */ + +#include "config.h" + +#include "ephy-history-store.h" + +#include "ephy-history-types.h" + +#include <gtk/gtk.h> + +G_DEFINE_TYPE (EphyHistoryStore, ephy_history_store, GTK_TYPE_LIST_STORE) + +static void +ephy_history_store_class_init (EphyHistoryStoreClass *klass) +{ +} + +static void +ephy_history_store_init (EphyHistoryStore *self) +{ + GType types[EPHY_HISTORY_STORE_N_COLUMNS]; + + types[EPHY_HISTORY_STORE_COLUMN_TITLE] = G_TYPE_STRING; + types[EPHY_HISTORY_STORE_COLUMN_ADDRESS] = G_TYPE_STRING; + types[EPHY_HISTORY_STORE_COLUMN_DATE] = G_TYPE_INT; + + gtk_list_store_set_column_types (GTK_LIST_STORE (self), + EPHY_HISTORY_STORE_N_COLUMNS, + types); +} + +EphyHistoryStore * +ephy_history_store_new (void) +{ + return g_object_new (EPHY_TYPE_HISTORY_STORE, + NULL); +} + +void +ephy_history_store_add_urls (EphyHistoryStore *store, + GList *urls) +{ + EphyHistoryURL *url; + GList *iter; + + for (iter = urls; iter != NULL; iter = iter->next) { + url = (EphyHistoryURL *)iter->data; + gtk_list_store_insert_with_values (GTK_LIST_STORE (store), + NULL, G_MAXINT, + EPHY_HISTORY_STORE_COLUMN_TITLE, url->title, + EPHY_HISTORY_STORE_COLUMN_ADDRESS, url->url, + EPHY_HISTORY_STORE_COLUMN_DATE, url->last_visit_time, + -1); + } +} + +void +ephy_history_store_add_url (EphyHistoryStore *store, EphyHistoryURL *url) +{ + GList *urls = NULL; + urls = g_list_append (urls, url); + ephy_history_store_add_urls (store, urls); + g_list_free (urls); +} + +EphyHistoryURL * +ephy_history_store_get_url_from_path (EphyHistoryStore *store, + GtkTreePath *path) +{ + GtkTreeIter iter; + + EphyHistoryURL *url = ephy_history_url_new ("", "", 0, 0, 0); + + gtk_tree_model_get_iter (GTK_TREE_MODEL (store), &iter, path); + gtk_tree_model_get (GTK_TREE_MODEL (store), &iter, + EPHY_HISTORY_STORE_COLUMN_TITLE, &url->title, + EPHY_HISTORY_STORE_COLUMN_ADDRESS, &url->url, + -1); + return url; +} diff --git a/embed/ephy-history-store.h b/embed/ephy-history-store.h new file mode 100644 index 000000000..f5b5e702d --- /dev/null +++ b/embed/ephy-history-store.h @@ -0,0 +1,66 @@ +/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ +/* vim: set sw=2 ts=2 sts=2 et: */ +/* + * Copyright © 2011, 2012 Igalia S.L. + * + * 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 2, 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, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + */ + +#ifndef _EPHY_HISTORY_STORE_H +#define _EPHY_HISTORY_STORE_H + +#include "ephy-history-types.h" + +#include <gtk/gtk.h> + +G_BEGIN_DECLS + +#define EPHY_TYPE_HISTORY_STORE (ephy_history_store_get_type()) +#define EPHY_HISTORY_STORE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_HISTORY_STORE, EphyHistoryStore)) +#define EPHY_HISTORY_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_HISTORY_STORE, EphyHistoryStoreClass)) +#define EPHY_IS_HISTORY_STORE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_HISTORY_STORE)) +#define EPHY_IS_HISTORY_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), EPHY_TYPE_HISTORY_STORE)) +#define EPHY_HISTORY_STORE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), EPHY_TYPE_HISTORY_STORE, EphyHistoryStoreClass)) + +typedef struct _EphyHistoryStore EphyHistoryStore; +typedef struct _EphyHistoryStoreClass EphyHistoryStoreClass; +typedef struct _EphyHistoryStorePrivate EphyHistoryStorePrivate; + +typedef enum { + EPHY_HISTORY_STORE_COLUMN_TITLE = 0, + EPHY_HISTORY_STORE_COLUMN_ADDRESS, + EPHY_HISTORY_STORE_COLUMN_DATE, + EPHY_HISTORY_STORE_N_COLUMNS +} EphyHistoryStoreColumn; + +struct _EphyHistoryStore { + GtkListStore parent; +}; + +struct _EphyHistoryStoreClass { + GtkListStoreClass parent_class; +}; + +GType ephy_history_store_get_type (void) G_GNUC_CONST; +EphyHistoryStore* ephy_history_store_new (void); +void ephy_history_store_add_urls (EphyHistoryStore *store, GList *urls); +void ephy_history_store_add_url (EphyHistoryStore *store, EphyHistoryURL *url); +void ephy_history_store_add_visits (EphyHistoryStore *store, GList *visits); +EphyHistoryURL* ephy_history_store_get_url_from_path (EphyHistoryStore *store, GtkTreePath *path); + +G_END_DECLS + +#endif /* _EPHY_HISTORY_STORE_H */ diff --git a/embed/ephy-history-view.c b/embed/ephy-history-view.c new file mode 100644 index 000000000..0df4e972d --- /dev/null +++ b/embed/ephy-history-view.c @@ -0,0 +1,178 @@ +/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ +/* vim: set sw=2 ts=2 sts=2 et: */ +/* + * Copyright © 2011, 2012 Igalia S.L. + * + * 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 2, 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, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + */ + +#include "config.h" + +#include "ephy-history-view.h" + +#include "ephy-gui.h" +#include "ephy-history-store.h" + +#include <glib/gi18n.h> +#include <gtk/gtk.h> + +G_DEFINE_TYPE (EphyHistoryView, ephy_history_view, GTK_TYPE_TREE_VIEW) + +static void +ephy_history_view_class_init (EphyHistoryViewClass *klass) +{ +} + +static gboolean +button_event_modifies_selection (GdkEventButton *event) +{ + return (event->state & (GDK_CONTROL_MASK | GDK_SHIFT_MASK)) != 0; +} + +static gboolean +ephy_history_view_button_press_cb (GtkWidget *treeview, + GdkEventButton *event, + EphyHistoryView *view) +{ + GtkTreeSelection *selection; + GtkTreePath *path = NULL; + gboolean path_is_selected, call_parent = TRUE; + + if (event->window != gtk_tree_view_get_bin_window (GTK_TREE_VIEW (treeview))) { + return GTK_WIDGET_CLASS (ephy_history_view_parent_class)->button_press_event (treeview, event); + } + + selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (treeview)); + if (gtk_tree_view_get_path_at_pos (GTK_TREE_VIEW (treeview), + event->x, + event->y, + &path, + NULL, NULL, NULL)) { + path_is_selected = gtk_tree_selection_path_is_selected (selection, path); + + if (!gtk_widget_is_focus (GTK_WIDGET (treeview))) + gtk_widget_grab_focus (GTK_WIDGET (treeview)); + + if (event->button == 3 && path_is_selected) + call_parent = FALSE; + + if (!button_event_modifies_selection (event) && + event->button == 1 && path_is_selected && + gtk_tree_selection_count_selected_rows (selection) > 1) + call_parent = FALSE; + + if (call_parent) + GTK_WIDGET_CLASS (ephy_history_view_parent_class)->button_press_event (treeview, event); + + if (event->button == 3) { + gboolean retval; + + g_signal_emit_by_name (view, "popup_menu", &retval); + } + gtk_tree_path_free (path); + } else + gtk_tree_selection_unselect_all (selection); + + return TRUE; +} + +static void +ephy_history_view_init (EphyHistoryView *self) +{ + GtkTreeViewColumn *column; + GtkTreeSelection *selection; + + column = gtk_tree_view_column_new_with_attributes (_("Title"), + gtk_cell_renderer_text_new (), + "text", EPHY_HISTORY_STORE_COLUMN_TITLE, + NULL); + gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); + + column = gtk_tree_view_column_new_with_attributes (_("Address"), + gtk_cell_renderer_text_new (), + "text", EPHY_HISTORY_STORE_COLUMN_ADDRESS, + NULL); + gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); + + column = gtk_tree_view_column_new_with_attributes (_("Date"), + gtk_cell_renderer_text_new (), + "text", EPHY_HISTORY_STORE_COLUMN_DATE, + NULL); + gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); + + selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (self)); + gtk_tree_selection_set_mode (selection, GTK_SELECTION_MULTIPLE); + + g_signal_connect_object (self, "button_press_event", + G_CALLBACK (ephy_history_view_button_press_cb), + self, 0); +} + +GtkWidget * +ephy_history_view_new (void) +{ + return g_object_new (EPHY_TYPE_HISTORY_VIEW, NULL); +} + +void +ephy_history_view_popup (EphyHistoryView *view, GtkWidget *menu) +{ + GdkEvent *event; + + event = gtk_get_current_event (); + if (event) { + if (event->type == GDK_KEY_PRESS) { + GdkEventKey *key = (GdkEventKey *) event; + + gtk_menu_popup (GTK_MENU (menu), NULL, NULL, + ephy_gui_menu_position_tree_selection, + view, 0, key->time); + gtk_menu_shell_select_first (GTK_MENU_SHELL (menu), FALSE); + } else if (event->type == GDK_BUTTON_PRESS) { + GdkEventButton *button = (GdkEventButton *) event; + + gtk_menu_popup (GTK_MENU (menu), NULL, NULL, NULL, + NULL, button->button, button->time); + } + gdk_event_free (event); + } +} + +static void +get_selection (GtkTreeModel *model, + GtkTreePath *path, + GtkTreeIter *iter, + gpointer *data) +{ + EphyHistoryURL *url; + + url = ephy_history_store_get_url_from_path (EPHY_HISTORY_STORE (model), path); + *data = g_list_prepend (*data, url); +} + +GList * +ephy_history_view_get_selection (EphyHistoryView *view) +{ + GtkTreeSelection *selection; + GList *list = NULL; + + selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (view)); + gtk_tree_selection_selected_foreach (selection, + (GtkTreeSelectionForeachFunc) get_selection, + &list); + + return g_list_reverse (list); +} diff --git a/embed/ephy-history-view.h b/embed/ephy-history-view.h new file mode 100644 index 000000000..d6c2d0656 --- /dev/null +++ b/embed/ephy-history-view.h @@ -0,0 +1,56 @@ +/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ +/* vim: set sw=2 ts=2 sts=2 et: */ +/* + * Copyright © 2011, 2012 Igalia S.L. + * + * 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 2, 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, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + */ + +#ifndef _EPHY_HISTORY_VIEW_H +#define _EPHY_HISTORY_VIEW_H + +#include <gtk/gtk.h> + +G_BEGIN_DECLS + +#define EPHY_TYPE_HISTORY_VIEW ephy_history_view_get_type() + +#define EPHY_HISTORY_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_HISTORY_VIEW, EphyHistoryView)) +#define EPHY_HISTORY_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_HISTORY_VIEW, EphyHistoryViewClass)) +#define EPHY_IS_HISTORY_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_HISTORY_VIEW)) +#define EPHY_IS_HISTORY_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), EPHY_TYPE_HISTORY_VIEW)) +#define EPHY_HISTORY_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), EPHY_TYPE_HISTORY_VIEW, EphyHistoryViewClass)) + +typedef struct _EphyHistoryView EphyHistoryView; +typedef struct _EphyHistoryViewClass EphyHistoryViewClass; +typedef struct _EphyHistoryViewPrivate EphyHistoryViewPrivate; + +struct _EphyHistoryView { + GtkTreeView parent; +}; + +struct _EphyHistoryViewClass { + GtkTreeViewClass parent_class; +}; + +GType ephy_history_view_get_type (void) G_GNUC_CONST; +GtkWidget * ephy_history_view_new (void); +void ephy_history_view_popup (EphyHistoryView *view, GtkWidget *menu); +GList * ephy_history_view_get_selection (EphyHistoryView *view); + +G_END_DECLS + +#endif /* _EPHY_HISTORY_VIEW_H */ |