diff options
-rw-r--r-- | shell/ChangeLog | 11 | ||||
-rw-r--r-- | shell/e-shortcuts-view.c | 44 | ||||
-rw-r--r-- | shell/e-shortcuts.c | 64 |
3 files changed, 88 insertions, 31 deletions
diff --git a/shell/ChangeLog b/shell/ChangeLog index 69f46445e1..bf1fa018c3 100644 --- a/shell/ChangeLog +++ b/shell/ChangeLog @@ -1,5 +1,16 @@ 2001-07-01 Ettore Perazzoli <ettore@ximian.com> + * e-shortcuts-view.c: Added a "Rename" right-click command. + (rename_shortcut_cb): New function, implementation for the "Rename + command". + (rename_shortcut_dialog_cb): Callback for the gnome_request_dialog + function to ask the new name. + + * e-shortcuts.c (e_shortcuts_update_shortcut): Call `make_dirty()' + so we get saved too. + +2001-07-01 Ettore Perazzoli <ettore@ximian.com> + * e-shell-view.c (activate_shortcut_cb): Receive an @in_new_window arg as well. diff --git a/shell/e-shortcuts-view.c b/shell/e-shortcuts-view.c index 76939f1941..4009e7e5a8 100644 --- a/shell/e-shortcuts-view.c +++ b/shell/e-shortcuts-view.c @@ -40,6 +40,8 @@ #include <libgnomeui/gnome-uidefs.h> #include <gal/util/e-util.h> +#include "e-util/e-request.h" + #include "e-shortcuts-view-model.h" #include "e-shortcuts-view.h" @@ -336,7 +338,7 @@ pop_up_right_click_menu_for_group (EShortcutsView *shortcuts_view, } -/* Shortcut right-click menu. */ +/* Data to be passed around for the shortcut right-click menu items. */ struct _ShortcutRightClickMenuData { EShortcutsView *shortcuts_view; @@ -345,6 +347,9 @@ struct _ShortcutRightClickMenuData { }; typedef struct _ShortcutRightClickMenuData ShortcutRightClickMenuData; + +/* "Open Shortcut" and "Open Shortcut in New Window" commands. */ + static void open_shortcut_helper (ShortcutRightClickMenuData *menu_data, gboolean in_new_window) @@ -375,9 +380,10 @@ static void open_shortcut_in_new_window_cb (GtkWidget *widget, void *data) { - open_shortcut_helper ((ShortcutRightClickMenuData *) data, TRUE); + } + static void remove_shortcut_cb (GtkWidget *widget, void *data) @@ -393,12 +399,46 @@ remove_shortcut_cb (GtkWidget *widget, e_shortcuts_remove_shortcut (shortcuts, menu_data->group_num, menu_data->item_num); } + +/* "Rename Shortcut" command. */ + +static void +rename_shortcut_cb (GtkWidget *widget, + void *data) +{ + ShortcutRightClickMenuData *menu_data; + EShortcutsView *shortcuts_view; + EShortcuts *shortcuts; + const EShortcutItem *shortcut_item; + char *new_name; + + menu_data = (ShortcutRightClickMenuData *) data; + shortcuts_view = menu_data->shortcuts_view; + shortcuts = shortcuts_view->priv->shortcuts; + + shortcut_item = e_shortcuts_get_shortcut (shortcuts, menu_data->group_num, menu_data->item_num); + + new_name = e_request_string (GTK_WINDOW (gtk_widget_get_toplevel (widget)), + _("Rename shortcut"), + _("Rename selected shortcut to:"), + shortcut_item->name); + + if (new_name == NULL) + return; + + e_shortcuts_update_shortcut (shortcuts, menu_data->group_num, menu_data->item_num, + shortcut_item->uri, new_name, shortcut_item->type); + g_free (new_name); +} + static GnomeUIInfo shortcut_right_click_menu_uiinfo[] = { GNOMEUIINFO_ITEM (N_("Open"), N_("Open the folder linked to this shortcut"), open_shortcut_cb, NULL), GNOMEUIINFO_ITEM (N_("Open in New Window"), N_("Open the folder linked to this shortcut in a new window"), open_shortcut_in_new_window_cb, NULL), GNOMEUIINFO_SEPARATOR, + GNOMEUIINFO_ITEM_STOCK (N_("Rename"), N_("Rename this shortcut"), + rename_shortcut_cb, NULL), GNOMEUIINFO_ITEM_STOCK (N_("Remove"), N_("Remove this shortcut from the shortcut bar"), remove_shortcut_cb, GNOME_STOCK_MENU_CLOSE), GNOMEUIINFO_END diff --git a/shell/e-shortcuts.c b/shell/e-shortcuts.c index 60453eae4b..1dff42e6f7 100644 --- a/shell/e-shortcuts.c +++ b/shell/e-shortcuts.c @@ -119,6 +119,9 @@ enum { static guint signals[LAST_SIGNAL] = { 0 }; +static void make_dirty (EShortcuts *shortcuts); + + static EShortcutItem * shortcut_item_new (const char *uri, const char *name, @@ -360,6 +363,7 @@ load_shortcuts (EShortcuts *shortcuts, /* After loading, we always have to re-save ourselves as we have merged the information we have with the information we got from the StorageSet. */ + /* FIXME: Obviously, this sucks. */ make_dirty (shortcuts); return TRUE; @@ -412,35 +416,6 @@ save_shortcuts (EShortcuts *shortcuts, return TRUE; } - -static EShortcutItem * -get_item (EShortcuts *shortcuts, - int group_num, - int num) -{ - EShortcutsPrivate *priv; - ShortcutGroup *group; - GSList *group_element; - GSList *shortcut_element; - - g_return_val_if_fail (shortcuts != NULL, NULL); - g_return_val_if_fail (E_IS_SHORTCUTS (shortcuts), NULL); - - priv = shortcuts->priv; - - group_element = g_slist_nth (priv->groups, group_num); - if (group_element == NULL) - return NULL; - - group = (ShortcutGroup *) group_element->data; - - shortcut_element = g_slist_nth (group->shortcuts, num); - if (shortcut_element == NULL) - return NULL; - - return (EShortcutItem *) shortcut_element->data; -} - /* Idle function to update the file on disk. */ @@ -533,6 +508,35 @@ update_shortcuts_by_path (EShortcuts *shortcuts, } +static EShortcutItem * +get_item (EShortcuts *shortcuts, + int group_num, + int num) +{ + EShortcutsPrivate *priv; + ShortcutGroup *group; + GSList *group_element; + GSList *shortcut_element; + + g_return_val_if_fail (shortcuts != NULL, NULL); + g_return_val_if_fail (E_IS_SHORTCUTS (shortcuts), NULL); + + priv = shortcuts->priv; + + group_element = g_slist_nth (priv->groups, group_num); + if (group_element == NULL) + return NULL; + + group = (ShortcutGroup *) group_element->data; + + shortcut_element = g_slist_nth (group->shortcuts, num); + if (shortcut_element == NULL) + return NULL; + + return (EShortcutItem *) shortcut_element->data; +} + + /* Signal handlers for the views. */ static void @@ -973,6 +977,8 @@ e_shortcuts_update_shortcut (EShortcuts *shortcuts, shortcut_item = get_item (shortcuts, group_num, num); update_shortcut_and_emit_signal (shortcuts, shortcut_item, group_num, num, uri, name, type); + + make_dirty (shortcuts); } |