aboutsummaryrefslogtreecommitdiffstats
path: root/lib/widgets
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <marco@it.gnome.org>2003-04-01 03:22:58 +0800
committerMarco Pesenti Gritti <mpeseng@src.gnome.org>2003-04-01 03:22:58 +0800
commit7f0ed6fc4aa39684c079b391b28840cfdfacc7af (patch)
tree9f00ef9f7190dc1a541205df5cf320198a7fbf45 /lib/widgets
parent8c10e78e46c4427326cc9cb7162aa65346048102 (diff)
downloadgsoc2013-epiphany-7f0ed6fc4aa39684c079b391b28840cfdfacc7af.tar
gsoc2013-epiphany-7f0ed6fc4aa39684c079b391b28840cfdfacc7af.tar.gz
gsoc2013-epiphany-7f0ed6fc4aa39684c079b391b28840cfdfacc7af.tar.bz2
gsoc2013-epiphany-7f0ed6fc4aa39684c079b391b28840cfdfacc7af.tar.lz
gsoc2013-epiphany-7f0ed6fc4aa39684c079b391b28840cfdfacc7af.tar.xz
gsoc2013-epiphany-7f0ed6fc4aa39684c079b391b28840cfdfacc7af.tar.zst
gsoc2013-epiphany-7f0ed6fc4aa39684c079b391b28840cfdfacc7af.zip
Use the new EggToolbar apis. Better drop feedback, separators drag and
2003-03-31 Marco Pesenti Gritti <marco@it.gnome.org> * lib/egg/eggtoolbar.c: (egg_toolbar_class_init), (egg_toolbar_init), (egg_toolbar_unrealize), (egg_toolbar_expose), (egg_toolbar_size_allocate), (find_drop_pos), (egg_toolbar_drag_leave), (egg_toolbar_drag_motion), (egg_toolbar_get_item_index), (egg_toolbar_get_show_arrow), (egg_toolbar_get_drop_index): * lib/egg/eggtoolbar.h: * lib/egg/eggtoolitem.c: (egg_tool_item_get_type), (egg_tool_item_class_init), (create_drag_window), (egg_tool_item_realize), (egg_tool_item_unrealize), (egg_tool_item_map), (egg_tool_item_unmap), (egg_tool_item_size_allocate), (egg_tool_item_set_tooltip), (egg_tool_item_set_use_drag_window): * lib/egg/eggtoolitem.h: * lib/widgets/ephy-editable-toolbar.c: (drag_data_received_cb), (drag_data_get_cb), (connect_item_drag_source), (disconnect_item_drag_source), (popup_toolbar_context_menu), (setup_toolbar), (do_merge), (ephy_editable_toolbar_init), (hide_editor), (update_editor_sheet), (show_editor): * lib/widgets/ephy-toolbars-group.c: (add_action), (ephy_toolbars_group_add_item), (parse_item_list): * lib/widgets/ephy-toolbars-group.h: Use the new EggToolbar apis. Better drop feedback, separators drag and code cleanups.
Diffstat (limited to 'lib/widgets')
-rwxr-xr-xlib/widgets/ephy-editable-toolbar.c164
-rwxr-xr-xlib/widgets/ephy-toolbars-group.c20
-rwxr-xr-xlib/widgets/ephy-toolbars-group.h2
3 files changed, 56 insertions, 130 deletions
diff --git a/lib/widgets/ephy-editable-toolbar.c b/lib/widgets/ephy-editable-toolbar.c
index 2af974a87..e65015d3a 100755
--- a/lib/widgets/ephy-editable-toolbar.c
+++ b/lib/widgets/ephy-editable-toolbar.c
@@ -29,19 +29,27 @@
#include <libgnome/gnome-i18n.h>
#include <string.h>
+enum
+{
+ X_TOOLBAR_ITEM
+};
+
static GtkTargetEntry dest_drag_types [] =
{
- { "EPHY_TOOLBAR_BUTTON", 0, 0 },
+ { "application/x-toolbar-item", 0, X_TOOLBAR_ITEM },
/* FIXME generic way to add types */
- { EPHY_DND_URL_TYPE, 0, 1 },
+ { EPHY_DND_URL_TYPE, 0, 2 },
{ EPHY_DND_TOPIC_TYPE, 0, 2 }
};
+static int n_dest_drag_types = G_N_ELEMENTS (dest_drag_types);
static GtkTargetEntry source_drag_types [] =
{
- { "EPHY_TOOLBAR_BUTTON", 0, 0 }
+ { "application/x-toolbar-item", 0, X_TOOLBAR_ITEM },
};
+static int n_source_drag_types = G_N_ELEMENTS (source_drag_types);
+
enum
{
RESPONSE_ADD_TOOLBAR
@@ -238,31 +246,20 @@ drag_data_received_cb (GtkWidget *widget,
EphyEditableToolbar *etoolbar)
{
EphyToolbarsToolbar *toolbar;
- EphyToolbarsToolbar *parent;
- EphyToolbarsItem *sibling;
const char *type = NULL;
GdkAtom target;
EggAction *action = NULL;
+ int pos;
g_return_if_fail (IS_EPHY_EDITABLE_TOOLBAR (etoolbar));
- LOG ("Drag data received")
+ LOG ("Drag data received %s", selection_data->data)
toolbar = (EphyToolbarsToolbar *)g_object_get_data (G_OBJECT (widget), "toolbar_data");
+ pos = egg_toolbar_get_drop_index (EGG_TOOLBAR (widget), x, y);
- if (!toolbar)
- {
- sibling = (EphyToolbarsItem *)g_object_get_data (G_OBJECT (widget), "item_data");
- g_return_if_fail (sibling != NULL);
- parent = sibling->parent;
- }
- else
- {
- sibling = NULL;
- parent = toolbar;
- }
-
- g_return_if_fail (parent != NULL);
+ /* HACK placeholder are implemented as separators */
+ pos = pos/3 + 1;
target = gtk_drag_dest_find_target (widget, context, NULL);
if (target == gdk_atom_intern (EPHY_DND_URL_TYPE, FALSE))
@@ -293,11 +290,18 @@ drag_data_received_cb (GtkWidget *widget,
if (action)
{
- ephy_toolbars_group_add_item (etoolbar->priv->group, parent, sibling,
+ ephy_toolbars_group_add_item (etoolbar->priv->group, toolbar, pos,
action->name);
etoolbar->priv->toolbars_dirty = TRUE;
- queue_ui_update (etoolbar);
}
+ else if (strcmp (selection_data->data, "separator") == 0)
+ {
+ ephy_toolbars_group_add_item (etoolbar->priv->group, toolbar, pos,
+ "separator");
+ etoolbar->priv->toolbars_dirty = TRUE;
+ }
+
+ queue_ui_update (etoolbar);
}
static void
@@ -331,9 +335,17 @@ drag_data_get_cb (GtkWidget *widget,
g_return_if_fail (IS_EPHY_EDITABLE_TOOLBAR (etoolbar));
action = EGG_ACTION (g_object_get_data (G_OBJECT (widget), "egg-action"));
- target = action->name;
- LOG ("Drag data get %s", action->name);
+ if (action)
+ {
+ LOG ("Drag data get %s", action->name);
+ target = action->name;
+ }
+ else
+ {
+ LOG ("Drag data get %s", separator);
+ target = "separator";
+ }
gtk_selection_data_set (selection_data,
selection_data->target,
@@ -431,6 +443,13 @@ connect_item_drag_source (EphyToolbarsItem *item, EphyEditableToolbar *etoolbar)
g_object_set_data (G_OBJECT (toolitem), "drag_source_set",
GINT_TO_POINTER (TRUE));
+ egg_tool_item_set_use_drag_window (EGG_TOOL_ITEM (toolitem), TRUE);
+
+ g_object_set_data (G_OBJECT (toolitem), "item_data", item);
+
+ gtk_drag_source_set (toolitem, GDK_BUTTON1_MASK,
+ source_drag_types, n_source_drag_types,
+ GDK_ACTION_MOVE);
g_signal_connect (toolitem, "drag_data_get",
G_CALLBACK (drag_data_get_cb),
etoolbar);
@@ -455,6 +474,8 @@ disconnect_item_drag_source (EphyToolbarsItem *item, EphyEditableToolbar *etoolb
g_object_set_data (G_OBJECT (toolitem), "drag_source_set",
GINT_TO_POINTER (FALSE));
+ egg_tool_item_set_use_drag_window (EGG_TOOL_ITEM (toolitem), FALSE);
+
g_signal_handlers_disconnect_by_func (toolitem,
G_CALLBACK (drag_data_get_cb),
etoolbar);
@@ -524,7 +545,7 @@ static void
popup_toolbar_context_menu (EggToolbar *toolbar, ContextMenuData *data)
{
GtkWidget *widget;
-
+
widget = egg_menu_merge_get_widget (data->etoolbar->priv->popup_merge,
"/popups/EphyToolbarPopup");
@@ -556,7 +577,7 @@ setup_toolbar (EphyToolbarsToolbar *toolbar, EphyEditableToolbar *etoolbar)
g_object_set_data (G_OBJECT (widget), "drag_dest_set",
GINT_TO_POINTER (TRUE));
gtk_drag_dest_set (widget, GTK_DEST_DEFAULT_ALL,
- dest_drag_types, 3,
+ dest_drag_types, n_dest_drag_types,
GDK_ACTION_MOVE | GDK_ACTION_COPY);
g_signal_connect (widget, "drag_data_received",
G_CALLBACK (drag_data_received_cb),
@@ -582,38 +603,6 @@ setup_toolbar (EphyToolbarsToolbar *toolbar, EphyEditableToolbar *etoolbar)
}
static void
-setup_item (EphyToolbarsItem *item, EphyEditableToolbar *etoolbar)
-{
- GtkWidget *toolitem;
- char *path;
-
- g_return_if_fail (IS_EPHY_EDITABLE_TOOLBAR (etoolbar));
- g_return_if_fail (item != NULL);
-
- path = ephy_toolbars_group_get_path (etoolbar->priv->group, item);
- g_return_if_fail (path != NULL);
-
- toolitem = get_item_widget (etoolbar, item);
- g_object_set_data (G_OBJECT (toolitem), "item_data", item);
-
- LOG ("Setup drag dest for toolbar item %s %p", path, toolitem);
-
- if (!g_object_get_data (G_OBJECT (toolitem), "drag_dest_set"))
- {
- g_object_set_data (G_OBJECT (toolitem), "drag_dest_set",
- GINT_TO_POINTER (TRUE));
- gtk_drag_dest_set (toolitem, GTK_DEST_DEFAULT_ALL,
- dest_drag_types, 3,
- GDK_ACTION_COPY | GDK_ACTION_MOVE);
- g_signal_connect (toolitem, "drag_data_received",
- G_CALLBACK (drag_data_received_cb),
- etoolbar);
- }
-
- g_free (path);
-}
-
-static void
ensure_toolbar_min_size (EphyToolbarsToolbar *toolbar, EphyEditableToolbar *t)
{
GtkWidget *widget;
@@ -664,9 +653,6 @@ do_merge (EphyEditableToolbar *t)
ephy_toolbars_group_foreach_toolbar (t->priv->group,
(EphyToolbarsGroupForeachToolbarFunc)
setup_toolbar, t);
- ephy_toolbars_group_foreach_item (t->priv->group,
- (EphyToolbarsGroupForeachItemFunc)
- setup_item, t);
if (t->priv->edit_mode)
{
@@ -827,9 +813,9 @@ ephy_editable_toolbar_init (EphyEditableToolbar *t)
{
ephy_toolbar_popups[i].user_data = t;
}
-
+
t->priv->popup_merge = egg_menu_merge_new ();
-
+
t->priv->popup_action_group = egg_action_group_new ("ToolbarPopupActions");
egg_action_group_add_actions (t->priv->popup_action_group,
ephy_toolbar_popups,
@@ -887,7 +873,6 @@ hide_editor (EphyEditableToolbar *etoolbar)
{
g_return_if_fail (IS_EPHY_EDITABLE_TOOLBAR (etoolbar));
- gtk_grab_remove (GTK_WIDGET (etoolbar->priv->editor));
gtk_widget_hide (GTK_WIDGET (etoolbar->priv->editor));
}
@@ -1050,7 +1035,7 @@ update_editor_sheet (EphyEditableToolbar *etoolbar)
gtk_scrolled_window_add_with_viewport
(GTK_SCROLLED_WINDOW (etoolbar->priv->scrolled_window), table);
gtk_drag_dest_set (table, GTK_DEST_DEFAULT_ALL,
- dest_drag_types, 3, GDK_ACTION_MOVE);
+ dest_drag_types, n_dest_drag_types, GDK_ACTION_MOVE);
g_signal_connect (table, "drag_data_received",
G_CALLBACK (editor_drag_data_received_cb),
etoolbar);
@@ -1120,52 +1105,6 @@ update_editor_sheet (EphyEditableToolbar *etoolbar)
g_list_free (to_drag);
}
-static gboolean
-button_press_cb (GtkWidget *w,
- GdkEvent *event,
- EphyEditableToolbar *etoolbar)
-{
- GtkWidget *widget;
- GtkWidget *toolitem;
-
- g_return_val_if_fail (IS_EPHY_EDITABLE_TOOLBAR (etoolbar), FALSE);
-
- widget = gtk_get_event_widget (event);
- toolitem = gtk_widget_get_ancestor (widget, EGG_TYPE_TOOL_ITEM);
-
- if (toolitem == NULL &&
- event->type == GDK_BUTTON_PRESS &&
- EGG_IS_TOOLBAR (widget))
- {
- if (event->button.button == 3)
- {
- gtk_widget_event (widget, event);
- return FALSE;
- }
- else
- {
- gtk_drag_begin (widget,
- gtk_target_list_new (source_drag_types, 1),
- GDK_ACTION_MOVE, 1, event);
- return TRUE;
- }
- }
- else if (toolitem == NULL) return FALSE;
-
- switch (event->type)
- {
- case GDK_BUTTON_PRESS:
- gtk_drag_begin (toolitem,
- gtk_target_list_new (source_drag_types, 1),
- GDK_ACTION_MOVE, 1, event);
- return TRUE;
- default:
- break;
- }
-
- return FALSE;
-}
-
static void
show_editor (EphyEditableToolbar *etoolbar)
{
@@ -1175,11 +1114,6 @@ show_editor (EphyEditableToolbar *etoolbar)
g_return_if_fail (editor != NULL);
gtk_widget_show (GTK_WIDGET (editor));
- gtk_grab_add (editor);
-
- g_signal_connect (editor, "button_press_event",
- G_CALLBACK (button_press_cb),
- etoolbar);
}
static void
diff --git a/lib/widgets/ephy-toolbars-group.c b/lib/widgets/ephy-toolbars-group.c
index 0a11b6285..9a1d47528 100755
--- a/lib/widgets/ephy-toolbars-group.c
+++ b/lib/widgets/ephy-toolbars-group.c
@@ -179,7 +179,7 @@ free_item_node (EphyToolbarsItem *item)
static void
add_action (EphyToolbarsGroup *t,
GNode *parent,
- GNode *sibling,
+ int pos,
const char *name)
{
EphyToolbarsItem *item;
@@ -193,17 +193,16 @@ add_action (EphyToolbarsGroup *t,
item->parent = parent->data;
node = g_node_new (item);
- g_node_insert_before (parent, sibling, node);
+ g_node_insert (parent, pos, node);
}
void
ephy_toolbars_group_add_item (EphyToolbarsGroup *t,
EphyToolbarsToolbar *parent,
- EphyToolbarsItem *sibling,
+ int pos,
const char *name)
{
GNode *parent_node;
- GNode *sibling_node = NULL;
g_return_if_fail (IS_EPHY_TOOLBARS_GROUP (t));
g_return_if_fail (parent != NULL);
@@ -211,14 +210,7 @@ ephy_toolbars_group_add_item (EphyToolbarsGroup *t,
parent_node = g_node_find (t->priv->toolbars, G_IN_ORDER, G_TRAVERSE_ALL, parent);
- if (sibling)
- {
- sibling_node = g_node_find (t->priv->toolbars, G_IN_ORDER,
- G_TRAVERSE_ALL, sibling);
- g_return_if_fail (sibling_node != NULL);
- }
-
- add_action (t, parent_node, sibling_node, name);
+ add_action (t, parent_node, pos, name);
toolbars_group_save (t);
@@ -237,13 +229,13 @@ parse_item_list (EphyToolbarsGroup *t,
xmlChar *verb;
verb = xmlGetProp (child, "verb");
- add_action (t, parent, NULL, verb);
+ add_action (t, parent, -1, verb);
xmlFree (verb);
}
else if (xmlStrEqual (child->name, "separator"))
{
- add_action (t, parent, NULL, "separator");
+ add_action (t, parent, -1, "separator");
}
child = child->next;
diff --git a/lib/widgets/ephy-toolbars-group.h b/lib/widgets/ephy-toolbars-group.h
index 8be71cb23..1d1c12a7d 100755
--- a/lib/widgets/ephy-toolbars-group.h
+++ b/lib/widgets/ephy-toolbars-group.h
@@ -80,7 +80,7 @@ EphyToolbarsToolbar *ephy_toolbars_group_add_toolbar (EphyToolbarsGroup *t);
void ephy_toolbars_group_add_item (EphyToolbarsGroup *t,
EphyToolbarsToolbar *parent,
- EphyToolbarsItem *sibling,
+ int pos,
const char *name);
void ephy_toolbars_group_remove_toolbar (EphyToolbarsGroup *t,