From 6af0f0710011c532c6eff1815a39794db91297aa Mon Sep 17 00:00:00 2001 From: Rodrigo Moya Date: Mon, 17 Nov 2003 15:39:39 +0000 Subject: try first to create the icon from the stock, and then from a file. 2003-11-17 Rodrigo Moya * gui/calendar-component.c (add_popup_menu_item): try first to create the icon from the stock, and then from a file. (fill_popup_menu_cb): set callback for 'Rename' menu item. (rename_calendar_cb): callback for 'Rename' menu item. (new_calendar_cb): fixed arguments. * gui/tasks-component.c (impl_createControls): connect to "fill_popup_menu" signal on the source selector. (fill_popup_menu_cb): callback to create our menu items. svn path=/trunk/; revision=23388 --- calendar/gui/tasks-component.c | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) (limited to 'calendar/gui/tasks-component.c') diff --git a/calendar/gui/tasks-component.c b/calendar/gui/tasks-component.c index 58448dc646..f79ddfd3a8 100644 --- a/calendar/gui/tasks-component.c +++ b/calendar/gui/tasks-component.c @@ -198,6 +198,44 @@ get_default_task (ECal *ecal) } /* Callbacks. */ +static void +add_popup_menu_item (GtkMenu *menu, const char *label, const char *pixmap, + GCallback callback, gpointer user_data) +{ + GtkWidget *item, *image; + + if (pixmap) { + item = gtk_image_menu_item_new_with_label (label); + + /* load the image */ + image = gtk_image_new_from_stock (pixmap, GTK_ICON_SIZE_MENU); + if (!image) + image = gtk_image_new_from_file (pixmap); + + if (image) + gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (item), image); + } else { + item = gtk_menu_item_new_with_label (label); + } + + if (callback) + g_signal_connect (G_OBJECT (item), "activate", callback, user_data); + + gtk_menu_shell_append (GTK_MENU_SHELL (menu), item); + gtk_widget_show (item); +} + +static void +new_task_list_cb (GtkWidget *widget, TasksComponent *component) +{ +} + +static void +fill_popup_menu_cb (ESourceSelector *selector, GtkMenu *menu, TasksComponent *component) +{ + add_popup_menu (menu, _("New Task List"), GTK_STOCK_NEW, G_CALLBACK (new_task_list_cb), component); +} + static void source_selection_changed_cb (ESourceSelector *selector, TasksComponent *component) { @@ -337,6 +375,9 @@ impl_createControls (PortableServer_Servant servant, g_signal_connect_object (priv->source_selector, "primary_selection_changed", G_CALLBACK (primary_source_selection_changed_cb), G_OBJECT (component), 0); + g_signal_connect_object (priv->source_selector, "fill_popup_menu", + G_CALLBACK (fill_popup_menu_cb), + G_OBJECT (component), 0); /* Load the selection from the last run */ update_selection (component); -- cgit v1.2.3