diff options
author | Dave Camp <dave@ximian.com> | 2002-09-21 19:52:36 +0000 |
---|---|---|
committer | Dave Camp <campd@src.gnome.org> | 2002-09-21 19:52:36 +0000 |
commit | f5c2f1f263d64935953aef16a1661343f701eff2 (patch) | |
tree | f459719b6bcd3d3e48f1bad0b92c9480d3a6b1fe | |
parent | 6f2fe2a953097eb98e064f5726070696b96e42e6 (diff) | |
download | nautilus-f5c2f1f263d64935953aef16a1661343f701eff2.tar.gz |
Removed sidebar_tab_pieces from the Makefiles and theme definitions.
2002-09-21 Dave Camp <dave@ximian.com>
* configure.in:
* icons/Makefile.am:
* icons/crux_eggplant/Makefile.am:
* icons/crux_eggplant/crux_eggplant.xml:
* icons/crux_teal/Makefile.am:
* icons/crux_teal/crux_teal.xml:
* icons/default/default.xml:
* icons/gnome/Makefile.am:
* icons/gnome/gnome.xml:
* icons/sierra/sierra.xml: Removed sidebar_tab_pieces from the
Makefiles and theme definitions.
* src/nautilus-sidebar.c:
* src/nautilus-sidebar.h: Removed.
-rw-r--r-- | ChangeLog | 16 | ||||
-rw-r--r-- | configure.in | 4 | ||||
-rw-r--r-- | icons/Makefile.am | 1 | ||||
-rw-r--r-- | icons/crux_eggplant/Makefile.am | 2 | ||||
-rw-r--r-- | icons/crux_eggplant/crux_eggplant.xml | 2 | ||||
-rw-r--r-- | icons/crux_teal/Makefile.am | 2 | ||||
-rw-r--r-- | icons/crux_teal/crux_teal.xml | 2 | ||||
-rw-r--r-- | icons/default/default.xml | 2 | ||||
-rw-r--r-- | icons/gnome/Makefile.am | 2 | ||||
-rw-r--r-- | icons/gnome/gnome.xml | 2 | ||||
-rw-r--r-- | icons/sierra/sierra.xml | 2 | ||||
-rw-r--r-- | po/ChangeLog | 41 | ||||
-rw-r--r-- | src/nautilus-sidebar.c | 1747 | ||||
-rw-r--r-- | src/nautilus-sidebar.h | 78 |
14 files changed, 65 insertions, 1838 deletions
@@ -1,5 +1,21 @@ 2002-09-21 Dave Camp <dave@ximian.com> + * configure.in: + * icons/Makefile.am: + * icons/crux_eggplant/Makefile.am: + * icons/crux_eggplant/crux_eggplant.xml: + * icons/crux_teal/Makefile.am: + * icons/crux_teal/crux_teal.xml: + * icons/default/default.xml: + * icons/gnome/Makefile.am: + * icons/gnome/gnome.xml: + * icons/sierra/sierra.xml: Removed sidebar_tab_pieces from the + Makefiles and theme definitions. + * src/nautilus-sidebar.c: + * src/nautilus-sidebar.h: Removed. + +2002-09-21 Dave Camp <dave@ximian.com> + * src/nautilus-sidebar-title.c: Removed #include "nautilus-sidebar.h". diff --git a/configure.in b/configure.in index 60b59f05e..0460007d3 100644 --- a/configure.in +++ b/configure.in @@ -354,17 +354,13 @@ docs/Makefile icons/Makefile icons/crux_eggplant/Makefile icons/crux_eggplant/backgrounds/Makefile -icons/crux_eggplant/sidebar_tab_pieces/Makefile icons/crux_eggplant/throbber/Makefile icons/crux_teal/Makefile icons/crux_teal/backgrounds/Makefile -icons/crux_teal/sidebar_tab_pieces/Makefile icons/crux_teal/throbber/Makefile icons/default/Makefile icons/gnome/Makefile -icons/gnome/sidebar_tab_pieces/Makefile icons/gnome/throbber/Makefile -icons/sidebar_tab_pieces/Makefile icons/sierra/Makefile icons/tahoe/Makefile icons/throbber/Makefile diff --git a/icons/Makefile.am b/icons/Makefile.am index 24099492e..c2da889ae 100644 --- a/icons/Makefile.am +++ b/icons/Makefile.am @@ -5,7 +5,6 @@ SUBDIRS =\ crux_teal \ default \ gnome \ - sidebar_tab_pieces \ sierra \ tahoe \ throbber \ diff --git a/icons/crux_eggplant/Makefile.am b/icons/crux_eggplant/Makefile.am index 51436daf5..9a807e6ab 100644 --- a/icons/crux_eggplant/Makefile.am +++ b/icons/crux_eggplant/Makefile.am @@ -1,6 +1,6 @@ crux_eggplantdir = $(datadir)/pixmaps/nautilus/crux_eggplant -SUBDIRS = sidebar_tab_pieces backgrounds throbber +SUBDIRS = backgrounds throbber crux_eggplant_DATA = \ crux_eggplant.xml \ diff --git a/icons/crux_eggplant/crux_eggplant.xml b/icons/crux_eggplant/crux_eggplant.xml index 9e93da562..3d4913263 100644 --- a/icons/crux_eggplant/crux_eggplant.xml +++ b/icons/crux_eggplant/crux_eggplant.xml @@ -9,7 +9,7 @@ <sidebar sidebar_background_color="#886F8D-#250C2A%90-#000000:h" sidebar_background_tile_image="patterns/.striated.png" - tab_piece_images="sidebar_tab_pieces" combine="true" + combine="true" left_offset="0" shadow_offset="1" text_h_offset="-4" label_color="#FFFFFF" tab_font="Helvetica Bold" /> diff --git a/icons/crux_teal/Makefile.am b/icons/crux_teal/Makefile.am index 8c225c081..c4ff3cde2 100644 --- a/icons/crux_teal/Makefile.am +++ b/icons/crux_teal/Makefile.am @@ -1,6 +1,6 @@ crux_tealdir = $(datadir)/pixmaps/nautilus/crux_teal -SUBDIRS = sidebar_tab_pieces backgrounds throbber +SUBDIRS = backgrounds throbber crux_teal_DATA = \ crux_teal.xml \ diff --git a/icons/crux_teal/crux_teal.xml b/icons/crux_teal/crux_teal.xml index eefa852a1..35e36b2dd 100644 --- a/icons/crux_teal/crux_teal.xml +++ b/icons/crux_teal/crux_teal.xml @@ -9,7 +9,7 @@ <sidebar sidebar_background_color="#669999-#003333%90-#000000:h" sidebar_background_tile_image="patterns/.striated.png" - tab_piece_images="sidebar_tab_pieces" combine="true" + combine="true" left_offset="0" shadow_offset="1" text_h_offset="-4" label_color="#FFFFFF" tab_font="Helvetica Bold" /> diff --git a/icons/default/default.xml b/icons/default/default.xml index ef58f064f..481f98d15 100644 --- a/icons/default/default.xml +++ b/icons/default/default.xml @@ -4,7 +4,7 @@ <sidebar sidebar_background_tile_image="./side_bar_image.png" sidebar_background_color="#474A7C-#22233A:h" - tab_piece_images="sidebar_tab_pieces" combine="true" + combine="true" left_offset="0" shadow_offset="1" text_h_offset="-4" label_color="#FFFFFF" tab_font="Helvetica Bold" /> diff --git a/icons/gnome/Makefile.am b/icons/gnome/Makefile.am index 1630294aa..a7a7b2750 100644 --- a/icons/gnome/Makefile.am +++ b/icons/gnome/Makefile.am @@ -1,6 +1,6 @@ NULL= -SUBDIRS = throbber sidebar_tab_pieces +SUBDIRS = throbber gnomedir = $(datadir)/pixmaps/nautilus/gnome diff --git a/icons/gnome/gnome.xml b/icons/gnome/gnome.xml index 428e78487..3cc70fed1 100644 --- a/icons/gnome/gnome.xml +++ b/icons/gnome/gnome.xml @@ -2,7 +2,7 @@ <theme _name="GNOME" _description="A theme designed to fit well with the classic GNOME environment."> - <sidebar tab_piece_images="sidebar_tab_pieces" combine="true" + <sidebar combine="true" left_offset="0" shadow_offset="1" text_h_offset="-4"/> <desktop background_tile_image="patterns/dark-gnome.jpg" diff --git a/icons/sierra/sierra.xml b/icons/sierra/sierra.xml index ae6993561..a53739945 100644 --- a/icons/sierra/sierra.xml +++ b/icons/sierra/sierra.xml @@ -1,6 +1,6 @@ <?xml version="1.0"?> <theme _name="Sierra" _description="Uses manila folders and gray-green backgrounds."> - <sidebar sidebar_background_tile_image="./green_weave.png" sidebar_background_color="#FFFFFF" tab_piece_images="none"/> + <sidebar sidebar_background_tile_image="./green_weave.png" sidebar_background_color="#FFFFFF"/> <directory background_color="#BAC5C0" selection_box_color_rgba="0x70818359" selection_box_color="#708183"/> <desktop background_tile_image="./Sierra_desktop.png" background_color="#FFFFFF"/> <zoom_control number_v_offset="-6" number_v_2_offset="-1" number_h_offset="-2"/> diff --git a/po/ChangeLog b/po/ChangeLog index 1d5364db7..bcc7be8c5 100644 --- a/po/ChangeLog +++ b/po/ChangeLog @@ -1,5 +1,46 @@ 2002-09-21 Dave Camp <dave@ximian.com> + * az.po: + * bg.po: + * ca.po: + * cs.po: + * da.po: + * de.po: + * el.po: + * en_GB.po: + * es.po: + * eu.po: + * fi.po: + * fr.po: + * ga.po: + * gl.po: + * hu.po: + * it.po: + * ja.po: + * ko.po: + * lt.po: + * lv.po: + * ms.po: + * nl.po: + * nn.po: + * no.po: + * pl.po: + * pt.po: + * pt_BR.po: + * ro.po: + * ru.po: + * sk.po: + * sl.po: + * sv.po: + * ta.po: + * tr.po: + * uk.po: + * vi.po: + * zh_CN.po: + * zh_TW.po: + +2002-09-21 Dave Camp <dave@ximian.com> + * POTFILES.in: Added new side pane files. 2002-09-16 Hasbullah Bin Pit <sebol@ikhlas.com> diff --git a/src/nautilus-sidebar.c b/src/nautilus-sidebar.c deleted file mode 100644 index fd13707a4..000000000 --- a/src/nautilus-sidebar.c +++ /dev/null @@ -1,1747 +0,0 @@ - /* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */ - -/* - * Nautilus - * - * Copyright (C) 1999, 2000, 2001 Eazel, Inc. - * - * Nautilus 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 of the License, or - * (at your option) any later version. - * - * Nautilus 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - * - * Author: Andy Hertzfeld <andy@eazel.com> - * - */ - -/* This is the sidebar widget, which displays overview information - * hosts individual panels for various views. - */ - -#include <config.h> -#include "nautilus-sidebar.h" - -#include "nautilus-sidebar-tabs.h" -#include "nautilus-sidebar-title.h" - -#include <bonobo/bonobo-property-bag-client.h> -#include <bonobo/bonobo-ui-util.h> -#include <bonobo/bonobo-exception.h> - -#include <eel/eel-background.h> -#include <eel/eel-glib-extensions.h> -#include <eel/eel-gtk-extensions.h> -#include <eel/eel-gtk-macros.h> -#include <eel/eel-stock-dialogs.h> -#include <eel/eel-string.h> -#include <eel/eel-vfs-extensions.h> -#include <gdk-pixbuf/gdk-pixbuf.h> -#include <libxml/parser.h> -#include <gtk/gtkcheckmenuitem.h> -#include <gtk/gtkdnd.h> -#include <gtk/gtkhbox.h> -#include <gtk/gtkpaned.h> -#include <gtk/gtknotebook.h> -#include <gtk/gtksignal.h> -#include <libgnome/gnome-i18n.h> -#include <libgnomeui/gnome-uidefs.h> -#include <libgnomevfs/gnome-vfs-application-registry.h> -#include <libgnomevfs/gnome-vfs-mime-handlers.h> -#include <libgnomevfs/gnome-vfs-types.h> -#include <libgnomevfs/gnome-vfs-uri.h> -#include <libgnomevfs/gnome-vfs-utils.h> -#include <libnautilus-private/nautilus-directory.h> -#include <libnautilus-private/nautilus-file-dnd.h> -#include <libnautilus-private/nautilus-file-operations.h> -#include <libnautilus-private/nautilus-file.h> -#include <libnautilus-private/nautilus-global-preferences.h> -#include <libnautilus-private/nautilus-keep-last-vertical-box.h> -#include <libnautilus-private/nautilus-metadata.h> -#include <libnautilus-private/nautilus-mime-actions.h> -#include <libnautilus-private/nautilus-program-choosing.h> -#include <libnautilus-private/nautilus-sidebar-functions.h> -#include <libnautilus-private/nautilus-theme.h> -#include <libnautilus-private/nautilus-trash-monitor.h> -#include <math.h> - -struct NautilusSidebarDetails { - GtkVBox *container; - NautilusSidebarTitle *title; - GtkNotebook *notebook; - NautilusSidebarTabs *sidebar_tabs; - NautilusSidebarTabs *title_tab; - GtkHBox *button_box_centerer; - GtkVBox *button_box; - gboolean has_buttons; - char *uri; - NautilusFile *file; - guint file_changed_connection; - int selected_index; - gboolean background_connected; - int old_width; - - char *default_background_color; - char *default_background_image; - char *current_background_color; - char *current_background_image; - gboolean is_default_background; -}; - -/* button assignments */ -#define CONTEXTUAL_MENU_BUTTON 3 - -static void nautilus_sidebar_class_init (GtkObjectClass *object_klass); -static void nautilus_sidebar_init (GtkObject *object); -static void nautilus_sidebar_deactivate_panel (NautilusSidebar *sidebar); -static gboolean nautilus_sidebar_press_event (GtkWidget *widget, - GdkEventButton *event); -static gboolean nautilus_sidebar_release_event (GtkWidget *widget, - GdkEventButton *event); -static gboolean nautilus_sidebar_leave_event (GtkWidget *widget, - GdkEventCrossing *event); -static gboolean nautilus_sidebar_motion_event (GtkWidget *widget, - GdkEventMotion *event); -static void nautilus_sidebar_destroy (GtkObject *object); -static void nautilus_sidebar_finalize (GObject *object); -static void nautilus_sidebar_drag_data_received (GtkWidget *widget, - GdkDragContext *context, - int x, - int y, - GtkSelectionData *selection_data, - guint info, - guint time); -static void nautilus_sidebar_read_theme (NautilusSidebar *sidebar); -static void nautilus_sidebar_size_allocate (GtkWidget *widget, - GtkAllocation *allocation); -static void nautilus_sidebar_style_set (GtkWidget *widget, - GtkStyle *previous_style); -static void nautilus_sidebar_theme_changed (gpointer user_data); -static void nautilus_sidebar_confirm_trash_changed (gpointer user_data); -static void nautilus_sidebar_update_appearance (NautilusSidebar *sidebar); -static void nautilus_sidebar_update_buttons (NautilusSidebar *sidebar); -static void add_command_buttons (NautilusSidebar *sidebar, - GList *application_list); -static void background_metadata_changed_callback (NautilusSidebar *sidebar); - -#define DEFAULT_TAB_COLOR "#999999" - -/* FIXME bugzilla.gnome.org 41245: hardwired sizes */ -#define SIDEBAR_MINIMUM_WIDTH 1 -#define SIDEBAR_MINIMUM_HEIGHT 400 - -/* Some auto-updated values */ -static int sidebar_width_auto_value = SIDEBAR_MINIMUM_WIDTH; -static gboolean confirm_trash_auto_value = TRUE; - -enum { - LOCATION_CHANGED, - LAST_SIGNAL -}; - -static guint signals[LAST_SIGNAL]; - -/* drag and drop definitions */ - -enum { - TARGET_URI_LIST, - TARGET_COLOR, - TARGET_BGIMAGE, - TARGET_KEYWORD, - TARGET_BACKGROUND_RESET, - TARGET_GNOME_URI_LIST -}; - -static GtkTargetEntry target_table[] = { - { "text/uri-list", 0, TARGET_URI_LIST }, - { "application/x-color", 0, TARGET_COLOR }, - { "property/bgimage", 0, TARGET_BGIMAGE }, - { "property/keyword", 0, TARGET_KEYWORD }, - { "x-special/gnome-reset-background", 0, TARGET_BACKGROUND_RESET }, - { "x-special/gnome-icon-list", 0, TARGET_GNOME_URI_LIST } -}; - -typedef enum { - NO_PART, - BACKGROUND_PART, - ICON_PART, - TITLE_TAB_PART, - TABS_PART -} SidebarPart; - -EEL_CLASS_BOILERPLATE (NautilusSidebar, nautilus_sidebar, EEL_TYPE_BACKGROUND_BOX) - -/* initializing the class object by installing the operations we override */ -static void -nautilus_sidebar_class_init (GtkObjectClass *object_klass) -{ - GtkWidgetClass *widget_class; - GObjectClass *gobject_class; - - NautilusSidebarClass *klass; - - widget_class = GTK_WIDGET_CLASS (object_klass); - klass = NAUTILUS_SIDEBAR_CLASS (object_klass); - gobject_class = G_OBJECT_CLASS (object_klass); - - gobject_class->finalize = nautilus_sidebar_finalize; - - object_klass->destroy = nautilus_sidebar_destroy; - - widget_class->drag_data_received = nautilus_sidebar_drag_data_received; - widget_class->motion_notify_event = nautilus_sidebar_motion_event; - widget_class->leave_notify_event = nautilus_sidebar_leave_event; - widget_class->button_press_event = nautilus_sidebar_press_event; - widget_class->button_release_event = nautilus_sidebar_release_event; - widget_class->size_allocate = nautilus_sidebar_size_allocate; - widget_class->style_set = nautilus_sidebar_style_set; - - /* add the "location changed" signal */ - signals[LOCATION_CHANGED] = g_signal_new - ("location_changed", - G_TYPE_FROM_CLASS (object_klass), - G_SIGNAL_RUN_LAST, - G_STRUCT_OFFSET (NautilusSidebarClass, - location_changed), - NULL, NULL, - g_cclosure_marshal_VOID__STRING, - G_TYPE_NONE, 1, G_TYPE_STRING); -} - -/* utility routine to allocate the box the holds the command buttons */ -static void -make_button_box (NautilusSidebar *sidebar) -{ - sidebar->details->button_box_centerer = GTK_HBOX (gtk_hbox_new (FALSE, 0)); - gtk_box_pack_start_defaults (GTK_BOX (sidebar->details->container), - GTK_WIDGET (sidebar->details->button_box_centerer)); - - sidebar->details->button_box = GTK_VBOX (nautilus_keep_last_vertical_box_new (GNOME_PAD_SMALL)); - gtk_container_set_border_width (GTK_CONTAINER (sidebar->details->button_box), GNOME_PAD); - gtk_widget_show (GTK_WIDGET (sidebar->details->button_box)); - gtk_box_pack_start (GTK_BOX (sidebar->details->button_box_centerer), - GTK_WIDGET (sidebar->details->button_box), - TRUE, FALSE, 0); - sidebar->details->has_buttons = FALSE; -} - -/* initialize the instance's fields, create the necessary subviews, etc. */ - -static void -nautilus_sidebar_init (GtkObject *object) -{ - GtkWidget *widget; - static gboolean setup_autos = FALSE; - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (object); - widget = GTK_WIDGET (object); - - sidebar->details = g_new0 (NautilusSidebarDetails, 1); - - if (!setup_autos) { - setup_autos = TRUE; - eel_preferences_add_auto_integer ( - NAUTILUS_PREFERENCES_SIDEBAR_WIDTH, - &sidebar_width_auto_value); - - eel_preferences_add_auto_boolean ( - NAUTILUS_PREFERENCES_CONFIRM_TRASH, - &confirm_trash_auto_value); - } - - /* set the requested size of the sidebar */ - gtk_widget_set_size_request (widget, sidebar_width_auto_value, - SIDEBAR_MINIMUM_HEIGHT); - sidebar->details->old_width = sidebar_width_auto_value; - - /* load the default background from the current theme */ - nautilus_sidebar_read_theme (sidebar); - - /* enable mouse tracking */ - gtk_widget_add_events (GTK_WIDGET (sidebar), GDK_POINTER_MOTION_MASK); - - /* create the container box */ - sidebar->details->container = GTK_VBOX (gtk_vbox_new (FALSE, 0)); - gtk_container_set_border_width (GTK_CONTAINER (sidebar->details->container), 0); - gtk_widget_show (GTK_WIDGET (sidebar->details->container)); - gtk_container_add (GTK_CONTAINER (sidebar), - GTK_WIDGET (sidebar->details->container)); - - /* allocate and install the index title widget */ - sidebar->details->title = NAUTILUS_SIDEBAR_TITLE (nautilus_sidebar_title_new ()); - gtk_widget_show (GTK_WIDGET (sidebar->details->title)); - gtk_box_pack_start (GTK_BOX (sidebar->details->container), - GTK_WIDGET (sidebar->details->title), - FALSE, FALSE, GNOME_PAD); - - /* allocate the index tabs */ - sidebar->details->sidebar_tabs = NAUTILUS_SIDEBAR_TABS (nautilus_sidebar_tabs_new ()); - sidebar->details->selected_index = -1; - - /* also, allocate the title tab */ - sidebar->details->title_tab = NAUTILUS_SIDEBAR_TABS (nautilus_sidebar_tabs_new ()); - g_object_ref (sidebar->details->title_tab); - gtk_object_sink (GTK_OBJECT (sidebar->details->title_tab)); - - nautilus_sidebar_tabs_set_title_mode (sidebar->details->title_tab, TRUE); - - gtk_widget_show (GTK_WIDGET (sidebar->details->sidebar_tabs)); - gtk_box_pack_end (GTK_BOX (sidebar->details->container), - GTK_WIDGET (sidebar->details->sidebar_tabs), - FALSE, FALSE, 0); - - /* allocate and install the panel tabs */ - sidebar->details->notebook = GTK_NOTEBOOK (gtk_notebook_new ()); - g_object_ref (sidebar->details->notebook); - gtk_object_sink (GTK_OBJECT (sidebar->details->notebook)); - - gtk_notebook_set_show_tabs (sidebar->details->notebook, FALSE); - - /* allocate and install the command button container */ - make_button_box (sidebar); - - /* add a callback for when the theme changes */ - eel_preferences_add_callback (NAUTILUS_PREFERENCES_THEME, nautilus_sidebar_theme_changed, sidebar); - - /* add a callback for when the preference whether to confirm trashing/deleting file changes */ - eel_preferences_add_callback (NAUTILUS_PREFERENCES_CONFIRM_TRASH, nautilus_sidebar_confirm_trash_changed, sidebar); - - /* prepare ourselves to receive dropped objects */ - gtk_drag_dest_set (GTK_WIDGET (sidebar), - GTK_DEST_DEFAULT_MOTION | GTK_DEST_DEFAULT_HIGHLIGHT | GTK_DEST_DEFAULT_DROP, - target_table, G_N_ELEMENTS (target_table), - GDK_ACTION_COPY | GDK_ACTION_MOVE); -} - -static void -nautilus_sidebar_destroy (GtkObject *object) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (object); - - if (sidebar->details->notebook != NULL) { - g_object_unref (sidebar->details->notebook); - sidebar->details->notebook = NULL; - } - if (sidebar->details->title_tab != NULL) { - g_object_unref (sidebar->details->title_tab); - sidebar->details->title_tab = NULL; - } - - EEL_CALL_PARENT (GTK_OBJECT_CLASS, destroy, (object)); -} - -static void -nautilus_sidebar_finalize (GObject *object) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (object); - - if (sidebar->details->file != NULL) { - nautilus_file_monitor_remove (sidebar->details->file, sidebar); - nautilus_file_unref (sidebar->details->file); - } - - g_free (sidebar->details->uri); - g_free (sidebar->details->default_background_color); - g_free (sidebar->details->default_background_image); - g_free (sidebar->details->current_background_color); - g_free (sidebar->details->current_background_image); - g_free (sidebar->details); - - eel_preferences_remove_callback (NAUTILUS_PREFERENCES_THEME, - nautilus_sidebar_theme_changed, - sidebar); - - eel_preferences_remove_callback (NAUTILUS_PREFERENCES_CONFIRM_TRASH, - nautilus_sidebar_confirm_trash_changed, - sidebar); - - - EEL_CALL_PARENT (G_OBJECT_CLASS, finalize, (object)); -} - -/* callback to handle resetting the background */ -static void -reset_background_callback (GtkWidget *menu_item, GtkWidget *sidebar) -{ - EelBackground *background; - - background = eel_get_widget_background (sidebar); - if (background != NULL) { - eel_background_reset (background); - } -} - -static const char * -get_page_iid (NautilusSidebar *sidebar, - int page_number) -{ - GtkWidget *page; - - page = gtk_notebook_get_nth_page (GTK_NOTEBOOK (sidebar->details->notebook), - page_number); - if (page == NULL) { - return NULL; - } - return nautilus_view_frame_get_view_iid (NAUTILUS_VIEW_FRAME (page)); -} - -/* utility routine that checks if the active panel matches the passed-in object id */ -static gboolean -nautilus_sidebar_active_panel_matches_id_or_is_damaged (NautilusSidebar *sidebar, const char *id) -{ - const char *current_iid; - - if (sidebar->details->selected_index < 0) { - return FALSE; - } - - /* if we can't get the active one, say yes to removing it, to make sure to - * remove the tab - */ - current_iid = get_page_iid (sidebar, sidebar->details->selected_index); - if (current_iid == NULL) { - return TRUE; - } - return eel_strcmp (current_iid, id) == 0; -} - -/* if the active panel matches the passed in id, hide it. */ -void -nautilus_sidebar_hide_active_panel_if_matches (NautilusSidebar *sidebar, const char *sidebar_id) -{ - if (nautilus_sidebar_active_panel_matches_id_or_is_damaged (sidebar, sidebar_id)) { - nautilus_sidebar_deactivate_panel (sidebar); - } -} - -static gboolean -any_panel_matches_iid (NautilusSidebar *sidebar, const char *id) -{ - int i, count; - const char *page_iid; - - count = g_list_length (GTK_NOTEBOOK (sidebar->details->notebook)->children); - for (i = 0; i < count; i++) { - page_iid = get_page_iid (sidebar, i); - if (page_iid != NULL && strcmp (page_iid, id) == 0) { - return TRUE; - } - } - return FALSE; -} - -/* callback for sidebar panel menu items to toggle their visibility */ -static void -toggle_sidebar_panel (GtkWidget *widget, - const char *sidebar_iid) -{ - NautilusSidebar *sidebar; - const char *preference_key; - gboolean already_on; - - g_return_if_fail (GTK_IS_CHECK_MENU_ITEM (widget)); - g_return_if_fail (NAUTILUS_IS_SIDEBAR (g_object_get_data (G_OBJECT (widget), "user_data"))); - g_return_if_fail (g_object_get_data (G_OBJECT (widget), "nautilus-sidebar/preference-key") != NULL); - - preference_key = g_object_get_data (G_OBJECT (widget), "nautilus-sidebar/preference-key"); - - sidebar = NAUTILUS_SIDEBAR (g_object_get_data (G_OBJECT (widget), "user_data")); - - nautilus_sidebar_hide_active_panel_if_matches (sidebar, sidebar_iid); - - already_on = any_panel_matches_iid (sidebar, sidebar_iid); - - /* This little dance gets the preferences code to send a - * notification even though it thinks there's "no change". - * - * This is needed to deal with situations when the display - * become out of whack with the number of running sidebar - * panels, for example when a panel crashes. - */ - eel_preferences_set_boolean (preference_key, already_on); - eel_preferences_set_boolean (preference_key, !already_on); -} - -typedef struct -{ - NautilusSidebar *sidebar; - GtkMenu *menu; -} ForEachPanelData; - -static void -sidebar_for_each_sidebar_panel (const char *name, - const char *iid, - const char *preference_key, - gpointer callback_data) -{ - ForEachPanelData *data; - GtkWidget *menu_item; - gboolean panel_visible; - - g_return_if_fail (name != NULL); - g_return_if_fail (iid != NULL); - g_return_if_fail (preference_key != NULL); - g_return_if_fail (callback_data != NULL); - - data = callback_data; - - g_return_if_fail (NAUTILUS_IS_SIDEBAR (data->sidebar)); - g_return_if_fail (GTK_IS_MENU (data->menu)); - - /* If the panel is not visible in the current user level, then - * we dont need to create a menu item for it. - */ - panel_visible = any_panel_matches_iid (data->sidebar, iid); - if (!panel_visible && !eel_preferences_is_visible (preference_key)) { - return; - } - - /* add a check menu item */ - menu_item = gtk_check_menu_item_new_with_label (name); - - gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (menu_item), panel_visible); - gtk_widget_show (menu_item); - g_object_set_data (G_OBJECT (menu_item), "user_data", data->sidebar); - gtk_menu_shell_append (GTK_MENU_SHELL (data->menu), menu_item); - g_signal_connect_data (menu_item, "activate", - G_CALLBACK (toggle_sidebar_panel), - g_strdup (iid), (GClosureNotify) g_free, 0); - - g_object_set_data_full (G_OBJECT (menu_item), - "nautilus-sidebar/preference-key", - g_strdup (preference_key), g_free); -} - -/* utility routine to add a menu item for each potential sidebar panel */ -static void -sidebar_add_panel_context_menu_items (NautilusSidebar *sidebar, - GtkWidget *menu) -{ - ForEachPanelData data; - - data.sidebar = sidebar; - data.menu = GTK_MENU (menu); - - nautilus_sidebar_for_each_panel (sidebar_for_each_sidebar_panel, &data); -} - -/* create the context menu */ -GtkWidget * -nautilus_sidebar_create_context_menu (NautilusSidebar *sidebar) -{ - GtkWidget *menu, *menu_item; - EelBackground *background; - gboolean has_background; - - background = eel_get_widget_background (GTK_WIDGET(sidebar)); - has_background = background && !sidebar->details->is_default_background; - - menu = gtk_menu_new (); - - /* add the sidebar panels */ - sidebar_add_panel_context_menu_items (sidebar, menu); - - /* add a separator */ - menu_item = gtk_menu_item_new (); - gtk_widget_show (menu_item); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menu_item); - - /* add the reset background item, possibly disabled */ - menu_item = gtk_menu_item_new_with_mnemonic (_("Use _Default Background")); - gtk_widget_show (menu_item); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menu_item); - gtk_widget_set_sensitive (menu_item, has_background); - g_signal_connect_object (menu_item, "activate", - G_CALLBACK (reset_background_callback), sidebar, 0); - - return menu; -} - -/* create a new instance */ -NautilusSidebar * -nautilus_sidebar_new (void) -{ - return NAUTILUS_SIDEBAR (gtk_widget_new (nautilus_sidebar_get_type (), NULL)); -} - -/* utility routine to handle mapping local file names to a uri */ -static char* -map_local_data_file (char *file_name) -{ - char *temp_str; - if (file_name && !eel_istr_has_prefix (file_name, "file://")) { - - if (eel_str_has_prefix (file_name, "./")) { - temp_str = nautilus_theme_get_image_path (file_name + 2); - } else { - temp_str = g_strdup_printf ("%s/%s", NAUTILUS_DATADIR, file_name); - } - - g_free (file_name); - file_name = gnome_vfs_get_uri_from_local_path (temp_str); - g_free (temp_str); - } - return file_name; -} - -/* read the theme file and set up the default backgrounds and images accordingly */ -static void -nautilus_sidebar_read_theme (NautilusSidebar *sidebar) -{ - char *background_color, *background_image; - - background_color = nautilus_theme_get_theme_data ("sidebar", NAUTILUS_METADATA_KEY_SIDEBAR_BACKGROUND_COLOR); - background_image = nautilus_theme_get_theme_data ("sidebar", NAUTILUS_METADATA_KEY_SIDEBAR_BACKGROUND_IMAGE); - - g_free (sidebar->details->default_background_color); - sidebar->details->default_background_color = NULL; - g_free (sidebar->details->default_background_image); - sidebar->details->default_background_image = NULL; - - if (background_color && strlen (background_color)) { - sidebar->details->default_background_color = g_strdup (background_color); - } - - /* set up the default background image */ - - background_image = map_local_data_file (background_image); - if (background_image && strlen (background_image)) { - sidebar->details->default_background_image = g_strdup (background_image); - } - - g_free (background_color); - g_free (background_image); -} - -/* handler for handling theme changes */ - -static void -nautilus_sidebar_theme_changed (gpointer user_data) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (user_data); - nautilus_sidebar_read_theme (sidebar); - nautilus_sidebar_update_appearance (sidebar); - gtk_widget_queue_draw (GTK_WIDGET (sidebar)) ; -} - -/* handler for handling confirming trash preferences changes */ - -static void -nautilus_sidebar_confirm_trash_changed (gpointer user_data) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (user_data); - nautilus_sidebar_update_buttons (sidebar); -} - -/* hit testing */ - -static SidebarPart -hit_test (NautilusSidebar *sidebar, - int x, int y) -{ - if (eel_point_in_widget (GTK_WIDGET (sidebar->details->sidebar_tabs), x, y)) { - return TABS_PART; - } - - if (eel_point_in_widget (GTK_WIDGET (sidebar->details->title_tab), x, y)) { - return TITLE_TAB_PART; - } - - if (nautilus_sidebar_title_hit_test_icon (sidebar->details->title, x, y)) { - return ICON_PART; - } - - if (eel_point_in_widget (GTK_WIDGET (sidebar), x, y)) { - return BACKGROUND_PART; - } - - return NO_PART; -} - -/* utility to test if a uri refers to a local image */ -static gboolean -uri_is_local_image (const char *uri) -{ - GdkPixbuf *pixbuf; - char *image_path; - - image_path = gnome_vfs_get_local_path_from_uri (uri); - if (image_path == NULL) { - return FALSE; - } - - pixbuf = gdk_pixbuf_new_from_file (image_path, NULL); - g_free (image_path); - - if (pixbuf == NULL) { - return FALSE; - } - g_object_unref (pixbuf); - return TRUE; -} - -static void -receive_dropped_uri_list (NautilusSidebar *sidebar, - int x, int y, - GtkSelectionData *selection_data) -{ - char **uris; - gboolean exactly_one; - GtkWindow *window; - - uris = g_strsplit (selection_data->data, "\r\n", 0); - exactly_one = uris[0] != NULL && (uris[1] == NULL || uris[1][0] == '\0'); - window = GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (sidebar))); - - switch (hit_test (sidebar, x, y)) { - case NO_PART: - case BACKGROUND_PART: - /* FIXME bugzilla.gnome.org 42507: Does this work for all images, or only background images? - * Other views handle background images differently from other URIs. - */ - if (exactly_one && uri_is_local_image (uris[0])) { - eel_background_receive_dropped_background_image - (eel_get_widget_background (GTK_WIDGET (sidebar)), - uris[0]); - } else if (exactly_one) { - g_signal_emit (sidebar, - signals[LOCATION_CHANGED], 0, - uris[0]); - } - break; - case TABS_PART: - case TITLE_TAB_PART: - break; - case ICON_PART: - /* handle images dropped on the logo specially */ - - if (!exactly_one) { - eel_show_error_dialog ( - _("You can't assign more than one custom icon at a time! " - "Please drag just one image to set a custom icon."), - _("More Than One Image"), - window); - break; - } - - if (uri_is_local_image (uris[0])) { - if (sidebar->details->file != NULL) { - nautilus_file_set_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_CUSTOM_ICON, - NULL, - uris[0]); - nautilus_file_set_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_ICON_SCALE, - NULL, - NULL); - } - } else { - if (eel_is_remote_uri (uris[0])) { - eel_show_error_dialog ( - _("The file that you dropped is not local. " - "You can only use local images as custom icons."), - _("Local Images Only"), - window); - - } else { - eel_show_error_dialog ( - _("The file that you dropped is not an image. " - "You can only use local images as custom icons."), - _("Images Only"), - window); - } - } - break; - } - - g_strfreev (uris); -} - -static void -receive_dropped_color (NautilusSidebar *sidebar, - int x, int y, - GtkSelectionData *selection_data) -{ - guint16 *channels; - char *color_spec; - - if (selection_data->length != 8 || selection_data->format != 16) { - g_warning ("received invalid color data"); - return; - } - - channels = (guint16 *) selection_data->data; - color_spec = g_strdup_printf ("#%02X%02X%02X", channels[0] >> 8, channels[1] >> 8, channels[2] >> 8); - - switch (hit_test (sidebar, x, y)) { - case NO_PART: - g_warning ("dropped color, but not on any part of sidebar"); - break; - case TABS_PART: - /* color dropped on main tabs */ - nautilus_sidebar_tabs_receive_dropped_color - (sidebar->details->sidebar_tabs, - x, y, selection_data); - - /* Block so we don't respond to our own metadata changes. - */ - g_signal_handlers_block_by_func (sidebar->details->file, - G_CALLBACK (background_metadata_changed_callback), - sidebar); - - nautilus_file_set_metadata - (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_TAB_COLOR, - DEFAULT_TAB_COLOR, - color_spec); - - g_signal_handlers_unblock_by_func (sidebar->details->file, - G_CALLBACK (background_metadata_changed_callback), - sidebar); - break; - case TITLE_TAB_PART: - /* color dropped on title tab */ - nautilus_sidebar_tabs_receive_dropped_color - (sidebar->details->title_tab, - x, y, selection_data); - - /* Block so we don't respond to our own metadata changes. - */ - g_signal_handlers_block_by_func (sidebar->details->file, - G_CALLBACK (background_metadata_changed_callback), - sidebar); - - nautilus_file_set_metadata - (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_TITLE_TAB_COLOR, - DEFAULT_TAB_COLOR, - color_spec); - - g_signal_handlers_unblock_by_func (sidebar->details->file, - G_CALLBACK (background_metadata_changed_callback), - sidebar); - break; - case ICON_PART: - case BACKGROUND_PART: - /* Let the background change based on the dropped color. */ - eel_background_receive_dropped_color - (eel_get_widget_background (GTK_WIDGET (sidebar)), - GTK_WIDGET (sidebar), x, y, selection_data); - break; - } - g_free(color_spec); -} - -/* handle receiving a dropped keyword */ - -static void -receive_dropped_keyword (NautilusSidebar *sidebar, - int x, int y, - GtkSelectionData *selection_data) -{ - nautilus_drag_file_receive_dropped_keyword (sidebar->details->file, selection_data->data); - - /* regenerate the display */ - nautilus_sidebar_update_appearance (sidebar); -} - -static void -nautilus_sidebar_drag_data_received (GtkWidget *widget, GdkDragContext *context, - int x, int y, - GtkSelectionData *selection_data, - guint info, guint time) -{ - NautilusSidebar *sidebar; - EelBackground *background; - - g_return_if_fail (NAUTILUS_IS_SIDEBAR (widget)); - - sidebar = NAUTILUS_SIDEBAR (widget); - - switch (info) { - case TARGET_GNOME_URI_LIST: - case TARGET_URI_LIST: - receive_dropped_uri_list (sidebar, x, y, selection_data); - break; - case TARGET_COLOR: - receive_dropped_color (sidebar, x, y, selection_data); - break; - case TARGET_BGIMAGE: - if (hit_test (sidebar, x, y) == BACKGROUND_PART) - receive_dropped_uri_list (sidebar, x, y, selection_data); - break; - case TARGET_BACKGROUND_RESET: - background = eel_get_widget_background ( GTK_WIDGET (sidebar)); - if (background != NULL) { - eel_background_reset (background); - } - break; - case TARGET_KEYWORD: - receive_dropped_keyword (sidebar, x, y, selection_data); - break; - default: - g_warning ("unknown drop type"); - } -} - -static void -view_loaded_callback (NautilusViewFrame *view_frame, gpointer user_data) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (user_data); - nautilus_sidebar_tabs_connect_view (sidebar->details->sidebar_tabs, GTK_WIDGET (view_frame)); -} - -/* add a new panel to the sidebar */ -void -nautilus_sidebar_add_panel (NautilusSidebar *sidebar, NautilusViewFrame *panel) -{ - GtkWidget *label; - char *description; - int page_num; - - g_return_if_fail (NAUTILUS_IS_SIDEBAR (sidebar)); - g_return_if_fail (NAUTILUS_IS_VIEW_FRAME (panel)); - - description = nautilus_view_frame_get_label (panel); - - label = gtk_label_new (description); - - gtk_widget_show (label); - - g_signal_connect_object (panel, "view_loaded", - G_CALLBACK (view_loaded_callback), sidebar, 0); - - gtk_notebook_append_page (GTK_NOTEBOOK (sidebar->details->notebook), - GTK_WIDGET (panel), label); - page_num = gtk_notebook_page_num (GTK_NOTEBOOK (sidebar->details->notebook), - GTK_WIDGET (panel)); - - /* tell the index tabs about it */ - nautilus_sidebar_tabs_add_view (sidebar->details->sidebar_tabs, - description, GTK_WIDGET (panel), page_num); - - g_free (description); - - gtk_widget_show (GTK_WIDGET (panel)); -} - -/* remove the passed-in panel from the sidebar */ -void -nautilus_sidebar_remove_panel (NautilusSidebar *sidebar, - NautilusViewFrame *panel) -{ - int page_num; - char *description; - - g_return_if_fail (NAUTILUS_IS_VIEW_FRAME (panel)); - - page_num = gtk_notebook_page_num (GTK_NOTEBOOK (sidebar->details->notebook), - GTK_WIDGET (panel)); - description = nautilus_view_frame_get_label (panel); - - if (page_num >= 0) { - gtk_notebook_remove_page (GTK_NOTEBOOK (sidebar->details->notebook), - page_num); - } - - /* Remove the tab associated with this panel */ - nautilus_sidebar_tabs_remove_view (sidebar->details->sidebar_tabs, description); - if (page_num <= sidebar->details->selected_index) { - sidebar->details->selected_index -= 1; - } - g_free (description); -} - -static void -notify_current_sidebar_view (NautilusSidebar *sidebar, const char *property, gboolean value) -{ - CORBA_Environment ev; - Bonobo_PropertyBag property_bag; - Bonobo_Control control; - GtkWidget *notebook_page; - - notebook_page = gtk_notebook_get_nth_page (GTK_NOTEBOOK (sidebar->details->notebook), - sidebar->details->selected_index); - control = nautilus_view_frame_get_control (NAUTILUS_VIEW_FRAME (notebook_page)); - if (control != CORBA_OBJECT_NIL) { - CORBA_exception_init (&ev); - property_bag = Bonobo_Control_getProperties (control, &ev); - if (!BONOBO_EX (&ev) && property_bag != CORBA_OBJECT_NIL) { - bonobo_property_bag_client_set_value_gboolean (property_bag, property, value, &ev); - bonobo_object_release_unref (property_bag, NULL); - } - CORBA_exception_free (&ev); - } -} - -/* utility to activate the panel corresponding to the passed in index */ -static void -nautilus_sidebar_activate_panel (NautilusSidebar *sidebar, int which_view) -{ - char *title; - GtkNotebook *notebook; - - /* nothing to do if it's already active */ - if (sidebar->details->selected_index == which_view) { - return; - } - - notebook = sidebar->details->notebook; - if (sidebar->details->selected_index < 0) { - gtk_widget_show (GTK_WIDGET (notebook)); - if (GTK_WIDGET (notebook)->parent == NULL) { - gtk_box_pack_end (GTK_BOX (sidebar->details->container), - GTK_WIDGET (notebook), - TRUE, TRUE, 0); - } - - gtk_widget_show (GTK_WIDGET (sidebar->details->title_tab)); - if (GTK_WIDGET (sidebar->details->title_tab)->parent == NULL) { - gtk_box_pack_end (GTK_BOX (sidebar->details->container), - GTK_WIDGET (sidebar->details->title_tab), - FALSE, FALSE, 0); - } - } else { - notify_current_sidebar_view (sidebar, "close", TRUE); - } - - sidebar->details->selected_index = which_view; - title = nautilus_sidebar_tabs_get_title_from_index (sidebar->details->sidebar_tabs, - which_view); - nautilus_sidebar_tabs_set_title (sidebar->details->title_tab, title); - nautilus_sidebar_tabs_prelight_tab (sidebar->details->title_tab, -1); - - g_free (title); - - /* hide the buttons, since they look confusing when partially overlapped */ - gtk_widget_hide (GTK_WIDGET (sidebar->details->button_box_centerer)); - gtk_widget_hide (GTK_WIDGET (sidebar->details->title)); - - gtk_notebook_set_current_page (notebook, which_view); - notify_current_sidebar_view (sidebar, "close", FALSE); -} - -/* utility to deactivate the active panel */ -static void -nautilus_sidebar_deactivate_panel (NautilusSidebar *sidebar) -{ - if (sidebar->details->selected_index >= 0) { - gtk_widget_hide (GTK_WIDGET (sidebar->details->notebook)); - gtk_widget_hide (GTK_WIDGET (sidebar->details->title_tab)); - notify_current_sidebar_view (sidebar, "close", TRUE); - } - - gtk_widget_show (GTK_WIDGET (sidebar->details->button_box_centerer)); - gtk_widget_show (GTK_WIDGET (sidebar->details->title)); - sidebar->details->selected_index = -1; - nautilus_sidebar_tabs_select_tab (sidebar->details->sidebar_tabs, -1); -} - -/* handle mouse motion events by passing it to the tabs if necessary for pre-lighting */ -static gboolean -nautilus_sidebar_motion_event (GtkWidget *widget, GdkEventMotion *event) -{ - int x, y; - int which_tab; - int title_top, title_bottom; - NautilusSidebar *sidebar; - NautilusSidebarTabs *sidebar_tabs, *title_tab; - - sidebar = NAUTILUS_SIDEBAR (widget); - - gtk_widget_get_pointer(widget, &x, &y); - - /* if the motion is in the main tabs, tell them about it */ - sidebar_tabs = sidebar->details->sidebar_tabs; - if (y >= GTK_WIDGET (sidebar_tabs)->allocation.y) { - which_tab = nautilus_sidebar_tabs_hit_test (sidebar_tabs, x, y); - nautilus_sidebar_tabs_prelight_tab (sidebar_tabs, which_tab); - } else - nautilus_sidebar_tabs_prelight_tab (sidebar_tabs, -1); - - - /* also handle prelighting in the title tab if necessary */ - if (sidebar->details->selected_index >= 0) { - title_tab = sidebar->details->title_tab; - title_top = GTK_WIDGET (title_tab)->allocation.y; - title_bottom = title_top + GTK_WIDGET (title_tab)->allocation.height; - if (y >= title_top && y < title_bottom) { - which_tab = nautilus_sidebar_tabs_hit_test (title_tab, x, y); - } else { - which_tab = -1; - } - nautilus_sidebar_tabs_prelight_tab (title_tab, which_tab); - } - - return TRUE; -} - -/* handle the leave event by turning off the preliting */ - -static gboolean -nautilus_sidebar_leave_event (GtkWidget *widget, GdkEventCrossing *event) -{ - NautilusSidebar *sidebar; - NautilusSidebarTabs *sidebar_tabs; - - sidebar = NAUTILUS_SIDEBAR (widget); - sidebar_tabs = sidebar->details->sidebar_tabs; - nautilus_sidebar_tabs_prelight_tab (sidebar_tabs, -1); - - return TRUE; -} - -/* handle the context menu if necessary */ -static gboolean -nautilus_sidebar_press_event (GtkWidget *widget, GdkEventButton *event) -{ - NautilusSidebar *sidebar; - GtkWidget *menu; - - if (widget->window != event->window) { - return FALSE; - } - - sidebar = NAUTILUS_SIDEBAR (widget); - - /* handle the context menu */ - if (event->button == CONTEXTUAL_MENU_BUTTON) { - menu = nautilus_sidebar_create_context_menu (sidebar); - eel_pop_up_context_menu (GTK_MENU(menu), - EEL_DEFAULT_POPUP_MENU_DISPLACEMENT, - EEL_DEFAULT_POPUP_MENU_DISPLACEMENT, - event); - } - return TRUE; -} - -/* handle the sidebar tabs on the upstroke */ -static gboolean -nautilus_sidebar_release_event (GtkWidget *widget, GdkEventButton *event) -{ - int title_top, title_bottom; - NautilusSidebar *sidebar; - NautilusSidebarTabs *sidebar_tabs; - NautilusSidebarTabs *title_tab; - int rounded_y; - int which_tab; - - if (widget->window != event->window) { - return FALSE; - } - - sidebar = NAUTILUS_SIDEBAR (widget); - - sidebar_tabs = sidebar->details->sidebar_tabs; - title_tab = sidebar->details->title_tab; - rounded_y = floor (event->y + .5); - - /* if the click is in the main tabs, tell them about it */ - if (rounded_y >= GTK_WIDGET (sidebar->details->sidebar_tabs)->allocation.y) { - which_tab = nautilus_sidebar_tabs_hit_test (sidebar_tabs, event->x, event->y); - if (which_tab >= 0) { - if (which_tab == sidebar->details->selected_index) { - nautilus_sidebar_deactivate_panel (sidebar); - } else { - nautilus_sidebar_tabs_select_tab (sidebar_tabs, which_tab); - nautilus_sidebar_activate_panel (sidebar, which_tab); - gtk_widget_queue_draw (widget); - } - } - } - - /* also handle clicks in the title tab if necessary */ - if (sidebar->details->selected_index >= 0) { - title_top = GTK_WIDGET (sidebar->details->title_tab)->allocation.y; - title_bottom = title_top + GTK_WIDGET (sidebar->details->title_tab)->allocation.height; - if (rounded_y >= title_top && rounded_y <= title_bottom) { - which_tab = nautilus_sidebar_tabs_hit_test (title_tab, event->x, event->y); - if (which_tab >= 0) { - /* the user clicked in the title tab, so deactivate the panel */ - nautilus_sidebar_deactivate_panel (sidebar); - } - } - } - return TRUE; -} - -static gboolean -value_different (const char *a, const char *b) -{ - if (!a && !b) - return FALSE; - - if (!a || !b) - return TRUE; - - return strcmp (a, b); -} - -/* Handle the background changed signal by writing out the settings to metadata. - */ -static void -background_settings_changed_callback (EelBackground *background, NautilusSidebar *sidebar) -{ - char *image; - char *color; - - g_assert (EEL_IS_BACKGROUND (background)); - g_assert (NAUTILUS_IS_SIDEBAR (sidebar)); - - if (sidebar->details->file == NULL) { - return; - } - - /* Block so we don't respond to our own metadata changes. - */ - g_signal_handlers_block_by_func (sidebar->details->file, - G_CALLBACK (background_metadata_changed_callback), - sidebar); - - color = eel_background_get_color (background); - image = eel_background_get_image_uri (background); - - nautilus_file_set_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_BACKGROUND_COLOR, - NULL, - color); - - nautilus_file_set_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_BACKGROUND_IMAGE, - NULL, - image); - - if (value_different (sidebar->details->current_background_color, color)) { - g_free (sidebar->details->current_background_color); - sidebar->details->current_background_color = g_strdup (color); - } - - if (value_different (sidebar->details->current_background_image, image)) { - g_free (sidebar->details->current_background_image); - sidebar->details->current_background_image = g_strdup (image); - } - - sidebar->details->is_default_background = FALSE; - - g_free (color); - g_free (image); - - g_signal_handlers_unblock_by_func (sidebar->details->file, - G_CALLBACK (background_metadata_changed_callback), - sidebar); -} - -/* handle the background reset signal by writing out NULL to metadata and setting the backgrounds - fields to their default values */ -static void -background_reset_callback (EelBackground *background, NautilusSidebar *sidebar) -{ - g_assert (EEL_IS_BACKGROUND (background)); - g_assert (NAUTILUS_IS_SIDEBAR (sidebar)); - - if (sidebar->details->file == NULL) { - return; - } - - /* Block so we don't respond to our own metadata changes. - */ - g_signal_handlers_block_by_func (sidebar->details->file, - G_CALLBACK (background_metadata_changed_callback), - sidebar); - - nautilus_file_set_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_BACKGROUND_COLOR, - NULL, - NULL); - - nautilus_file_set_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_BACKGROUND_IMAGE, - NULL, - NULL); - - g_signal_handlers_unblock_by_func (sidebar->details->file, - G_CALLBACK (background_metadata_changed_callback), - sidebar); - - /* Force a read from the metadata to set the defaults - */ - background_metadata_changed_callback (sidebar); -} - -static GtkWindow * -nautilus_sidebar_get_window (NautilusSidebar *sidebar) -{ - GtkWidget *result; - - result = gtk_widget_get_ancestor (GTK_WIDGET (sidebar), GTK_TYPE_WINDOW); - - return result == NULL ? NULL : GTK_WINDOW (result); -} - -static void -command_button_callback (GtkWidget *button, char *id_str) -{ - NautilusSidebar *sidebar; - GnomeVFSMimeApplication *application; - - sidebar = NAUTILUS_SIDEBAR (g_object_get_data (G_OBJECT (button), "user_data")); - - application = gnome_vfs_application_registry_get_mime_application (id_str); - - if (application != NULL) { - nautilus_launch_application (application, sidebar->details->file, - nautilus_sidebar_get_window (sidebar)); - - gnome_vfs_mime_application_free (application); - } -} - -/* interpret commands for buttons specified by metadata. Handle some built-in ones explicitly, or fork - a shell to handle general ones */ -/* for now, we don't have any of these */ -static void -metadata_button_callback (GtkWidget *button, const char *command_str) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (g_object_get_data (G_OBJECT (button), "user_data")); -} - -static void -nautilus_sidebar_chose_application_callback (GnomeVFSMimeApplication *application, - gpointer callback_data) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (callback_data); - - if (application != NULL) { - nautilus_launch_application - (application, - sidebar->details->file, - nautilus_sidebar_get_window (sidebar)); - } -} - -static void -open_with_callback (GtkWidget *button, gpointer ignored) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (g_object_get_data (G_OBJECT (button), "user_data")); - - g_return_if_fail (sidebar->details->file != NULL); - - nautilus_choose_application_for_file - (sidebar->details->file, - GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (sidebar))), - nautilus_sidebar_chose_application_callback, - sidebar); -} - -/* utility routine that allocates the command buttons from the command list */ - -static void -add_command_buttons (NautilusSidebar *sidebar, GList *application_list) -{ - char *id_string, *temp_str, *file_path; - GList *p; - GtkWidget *temp_button; - GnomeVFSMimeApplication *application; - - /* There's always at least the "Open with..." button */ - sidebar->details->has_buttons = TRUE; - - for (p = application_list; p != NULL; p = p->next) { - application = p->data; - - temp_str = g_strdup_printf (_("Open with %s"), application->name); - temp_button = gtk_button_new_with_label (temp_str); - g_free (temp_str); - gtk_box_pack_start (GTK_BOX (sidebar->details->button_box), - temp_button, - FALSE, FALSE, - 0); - - /* Get the local path, if there is one */ - file_path = gnome_vfs_get_local_path_from_uri (sidebar->details->uri); - if (file_path == NULL) { - file_path = g_strdup (sidebar->details->uri); - } - - temp_str = g_shell_quote (file_path); - id_string = eel_str_replace_substring (application->id, "%s", temp_str); - g_free (file_path); - g_free (temp_str); - - eel_gtk_signal_connect_free_data - (GTK_OBJECT (temp_button), "clicked", - G_CALLBACK (command_button_callback), id_string); - - g_object_set_data (G_OBJECT (temp_button), "user_data", sidebar); - - gtk_widget_show (temp_button); - } - - /* Catch-all button after all the others. */ - temp_button = gtk_button_new_with_label (_("Open with...")); - g_signal_connect (temp_button, "clicked", - G_CALLBACK (open_with_callback), NULL); - g_object_set_data (G_OBJECT (temp_button), "user_data", sidebar); - gtk_widget_show (temp_button); - gtk_box_pack_start (GTK_BOX (sidebar->details->button_box), - temp_button, FALSE, FALSE, 0); -} - -/* utility to construct command buttons for the sidebar from the passed in metadata string */ - -static void -add_buttons_from_metadata (NautilusSidebar *sidebar, const char *button_data) -{ - char **terms; - char *current_term, *temp_str; - char *button_name, *command_string; - const char *term; - int index; - GtkWidget *temp_button; - - /* split the button specification into a set of terms */ - button_name = NULL; - terms = g_strsplit (button_data, ";", 0); - - /* for each term, either create a button or attach a property to one */ - for (index = 0; (term = terms[index]) != NULL; index++) { - current_term = g_strdup (term); - temp_str = strchr (current_term, '='); - if (temp_str) { - *temp_str = '\0'; - if (!g_ascii_strcasecmp (current_term, "button")) { - button_name = g_strdup (temp_str + 1); - } else if (!g_ascii_strcasecmp (current_term, "script")) { - if (button_name != NULL) { - temp_button = gtk_button_new_with_label (button_name); - gtk_box_pack_start (GTK_BOX (sidebar->details->button_box), - temp_button, - FALSE, FALSE, - 0); - sidebar->details->has_buttons = TRUE; - command_string = g_strdup (temp_str + 1); - g_free (button_name); - - eel_gtk_signal_connect_free_data - (GTK_OBJECT (temp_button), "clicked", - G_CALLBACK (metadata_button_callback), command_string); - g_object_set_data (G_OBJECT (temp_button), "user_data", sidebar); - - gtk_widget_show (temp_button); - } - } - } - g_free(current_term); - } - g_strfreev (terms); -} - -/* handle the hacked-in empty trash command */ -static void -empty_trash_callback (GtkWidget *button, gpointer data) -{ - GtkWidget *window; - - window = gtk_widget_get_toplevel (button); - nautilus_file_operations_empty_trash (window); -} - -static void -nautilus_sidebar_trash_state_changed_callback (NautilusTrashMonitor *trash_monitor, - gboolean state, gpointer callback_data) -{ - gtk_widget_set_sensitive (GTK_WIDGET (callback_data), !nautilus_trash_monitor_is_empty ()); -} - -/* - * nautilus_sidebar_update_buttons: - * - * Update the list of program-launching buttons based on the current uri. - */ -static void -nautilus_sidebar_update_buttons (NautilusSidebar *sidebar) -{ - char *button_data; - GtkWidget *temp_button; - GList *short_application_list; - - /* dispose of any existing buttons */ - if (sidebar->details->has_buttons) { - gtk_container_remove (GTK_CONTAINER (sidebar->details->container), - GTK_WIDGET (sidebar->details->button_box_centerer)); - make_button_box (sidebar); - } - - /* create buttons from file metadata if necessary */ - button_data = nautilus_file_get_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_BUTTONS, - NULL); - if (button_data) { - add_buttons_from_metadata (sidebar, button_data); - g_free(button_data); - } - - /* here is a hack to provide an "empty trash" button when displaying the trash. Eventually, we - * need a framework to allow protocols to add commands buttons */ - if (eel_istr_has_prefix (sidebar->details->uri, "trash:")) { - /* FIXME: We don't use spaces to pad labels! */ - temp_button = gtk_button_new_with_mnemonic (_("_Empty Trash")); - - gtk_box_pack_start (GTK_BOX (sidebar->details->button_box), - temp_button, FALSE, FALSE, 0); - gtk_widget_set_sensitive (temp_button, !nautilus_trash_monitor_is_empty ()); - gtk_widget_show (temp_button); - sidebar->details->has_buttons = TRUE; - - g_signal_connect (temp_button, "clicked", - G_CALLBACK (empty_trash_callback), NULL); - - g_signal_connect_object (nautilus_trash_monitor_get (), "trash_state_changed", - G_CALLBACK (nautilus_sidebar_trash_state_changed_callback), temp_button, 0); - } - - /* Make buttons for each item in short list + "Open with..." catchall, - * unless there aren't any applications at all in complete list. - */ - - if (nautilus_mime_has_any_applications_for_file (sidebar->details->file)) { - short_application_list = - nautilus_mime_get_short_list_applications_for_file (sidebar->details->file); - add_command_buttons (sidebar, short_application_list); - gnome_vfs_mime_application_list_free (short_application_list); - } - - /* Hide button box if a sidebar panel is showing. Otherwise, show it! */ - if (sidebar->details->selected_index != -1) { - gtk_widget_hide (GTK_WIDGET (sidebar->details->button_box_centerer)); - gtk_widget_hide (GTK_WIDGET (sidebar->details->title)); - } else { - gtk_widget_show (GTK_WIDGET (sidebar->details->button_box_centerer)); - } -} - -static void -nautilus_sidebar_update_appearance (NautilusSidebar *sidebar) -{ - EelBackground *background; - char *color_spec; - char *background_color; - char *background_image; - - g_return_if_fail (NAUTILUS_IS_SIDEBAR (sidebar)); - - /* Connect the background changed signal to code that writes the color. */ - background = eel_get_widget_background (GTK_WIDGET (sidebar)); - if (!sidebar->details->background_connected) { - sidebar->details->background_connected = TRUE; - g_signal_connect_object (background,"settings_changed", - G_CALLBACK (background_settings_changed_callback), sidebar, 0); - g_signal_connect_object (background, "reset", - G_CALLBACK (background_reset_callback), sidebar, 0); - } - - /* Set up the background color and image from the metadata. */ - background_color = nautilus_file_get_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_BACKGROUND_COLOR, - NULL); - background_image = nautilus_file_get_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_BACKGROUND_IMAGE, - NULL); - - if (background_color == NULL && background_image == NULL) { - background_color = g_strdup (sidebar->details->default_background_color); - background_image = g_strdup (sidebar->details->default_background_image); - sidebar->details->is_default_background = TRUE; - } else { - sidebar->details->is_default_background = FALSE; - } - - /* Block so we don't write these settings out in response to our set calls below */ - g_signal_handlers_block_by_func (background, - G_CALLBACK (background_settings_changed_callback), - sidebar); - - if (value_different (sidebar->details->current_background_color, background_color) || - value_different (sidebar->details->current_background_image, background_image)) { - - g_free (sidebar->details->current_background_color); - sidebar->details->current_background_color = g_strdup (background_color); - g_free (sidebar->details->current_background_image); - sidebar->details->current_background_image = g_strdup (background_image); - - eel_background_set_image_uri (background, background_image); - eel_background_set_color (background, background_color); - - nautilus_sidebar_title_select_text_color - (sidebar->details->title, background, - sidebar->details->is_default_background); - } - - g_free (background_color); - g_free (background_image); - - color_spec = nautilus_file_get_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_TAB_COLOR, - DEFAULT_TAB_COLOR); - nautilus_sidebar_tabs_set_color(sidebar->details->sidebar_tabs, color_spec); - g_free (color_spec); - - color_spec = nautilus_file_get_metadata (sidebar->details->file, - NAUTILUS_METADATA_KEY_SIDEBAR_TITLE_TAB_COLOR, - DEFAULT_TAB_COLOR); - nautilus_sidebar_tabs_set_color(sidebar->details->title_tab, color_spec); - g_free (color_spec); - - g_signal_handlers_unblock_by_func (background, - G_CALLBACK (background_settings_changed_callback), - sidebar); -} - - -static void -background_metadata_changed_callback (NautilusSidebar *sidebar) -{ - GList *attributes; - gboolean ready; - - attributes = nautilus_mime_actions_get_minimum_file_attributes (); - ready = nautilus_file_check_if_ready (sidebar->details->file, attributes); - g_list_free (attributes); - - if (ready) { - nautilus_sidebar_update_appearance (sidebar); - - /* set up the command buttons */ - nautilus_sidebar_update_buttons (sidebar); - } -} - -/* here is the key routine that populates the sidebar with the appropriate information when the uri changes */ - -void -nautilus_sidebar_set_uri (NautilusSidebar *sidebar, - const char* new_uri, - const char* initial_title) -{ - NautilusFile *file; - GList *attributes; - - g_return_if_fail (NAUTILUS_IS_SIDEBAR (sidebar)); - g_return_if_fail (new_uri != NULL); - g_return_if_fail (initial_title != NULL); - - /* there's nothing to do if the uri is the same as the current one */ - if (eel_strcmp (sidebar->details->uri, new_uri) == 0) { - return; - } - - g_free (sidebar->details->uri); - sidebar->details->uri = g_strdup (new_uri); - - if (sidebar->details->file != NULL) { - g_signal_handler_disconnect (sidebar->details->file, - sidebar->details->file_changed_connection); - nautilus_file_monitor_remove (sidebar->details->file, sidebar); - } - - - file = nautilus_file_get (sidebar->details->uri); - - nautilus_file_unref (sidebar->details->file); - - sidebar->details->file = file; - - sidebar->details->file_changed_connection = - g_signal_connect_object (sidebar->details->file, "changed", - G_CALLBACK (background_metadata_changed_callback), - sidebar, G_CONNECT_SWAPPED); - - attributes = nautilus_mime_actions_get_minimum_file_attributes (); - nautilus_file_monitor_add (sidebar->details->file, sidebar, attributes); - g_list_free (attributes); - - background_metadata_changed_callback (sidebar); - - /* tell the title widget about it */ - nautilus_sidebar_title_set_file (sidebar->details->title, - sidebar->details->file, - initial_title); -} - -void -nautilus_sidebar_set_title (NautilusSidebar *sidebar, const char* new_title) -{ - nautilus_sidebar_title_set_text (sidebar->details->title, - new_title); -} - -/* we override size allocate so we can remember our size when it changes, since the paned widget - doesn't generate a signal */ - -static void -nautilus_sidebar_size_allocate (GtkWidget *widget, - GtkAllocation *allocation) -{ - NautilusSidebar *sidebar = NAUTILUS_SIDEBAR(widget); - - EEL_CALL_PARENT (GTK_WIDGET_CLASS, size_allocate, (widget, allocation)); - - /* remember the size if it changed */ - if (widget->allocation.width != sidebar->details->old_width) { - sidebar->details->old_width = widget->allocation.width; - eel_preferences_set_integer (NAUTILUS_PREFERENCES_SIDEBAR_WIDTH, - widget->allocation.width); - } -} - -/* ::style_set handler for the sidebar */ -static void -nautilus_sidebar_style_set (GtkWidget *widget, GtkStyle *previous_style) -{ - NautilusSidebar *sidebar; - - sidebar = NAUTILUS_SIDEBAR (widget); - - nautilus_sidebar_theme_changed (sidebar); -} - -void -nautilus_sidebar_setup_width (NautilusSidebar *sidebar) -{ - GtkPaned *paned; - - g_return_if_fail (NAUTILUS_IS_SIDEBAR (sidebar)); - g_return_if_fail (GTK_WIDGET (sidebar)->parent != NULL); - - paned = GTK_PANED (GTK_WIDGET (sidebar)->parent); - - /* FIXME bugzilla.gnome.org 41245: Saved in pixels instead of in %? */ - /* FIXME bugzilla.gnome.org 41245: No reality check on the value? */ - gtk_paned_set_position (paned, sidebar_width_auto_value); - sidebar->details->old_width = sidebar_width_auto_value; -} diff --git a/src/nautilus-sidebar.h b/src/nautilus-sidebar.h deleted file mode 100644 index d3c48b4b9..000000000 --- a/src/nautilus-sidebar.h +++ /dev/null @@ -1,78 +0,0 @@ -/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */ - -/* - * Nautilus - * - * Copyright (C) 1999, 2000 Eazel, Inc. - * - * Nautilus 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 of the License, or - * (at your option) any later version. - * - * Nautilus 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - * - * Author: Andy Hertzfeld <andy@eazel.com> - * - * This is the header file for the index panel widget, which displays overview information - * in a vertical panel and hosts the meta-views. - */ - -#ifndef NAUTILUS_SIDEBAR_H -#define NAUTILUS_SIDEBAR_H - -#include <eel/eel-background-box.h> - -#include "nautilus-view-frame.h" - -#define NAUTILUS_TYPE_SIDEBAR \ - (nautilus_sidebar_get_type ()) -#define NAUTILUS_SIDEBAR(obj) \ - (GTK_CHECK_CAST ((obj), NAUTILUS_TYPE_SIDEBAR, NautilusSidebar)) -#define NAUTILUS_SIDEBAR_CLASS(klass) \ - (GTK_CHECK_CLASS_CAST ((klass), NAUTILUS_TYPE_SIDEBAR, NautilusSidebarClass)) -#define NAUTILUS_IS_SIDEBAR(obj) \ - (GTK_CHECK_TYPE ((obj), NAUTILUS_TYPE_SIDEBAR)) -#define NAUTILUS_IS_SIDEBAR_CLASS(klass) \ - (GTK_CHECK_CLASS_TYPE ((klass), NAUTILUS_TYPE_SIDEBAR)) - -typedef struct NautilusSidebarDetails NautilusSidebarDetails; - -typedef struct { - EelBackgroundBox parent_slot; - NautilusSidebarDetails *details; -} NautilusSidebar; - -typedef struct { - EelBackgroundBoxClass parent_slot; - - void (*location_changed) (NautilusSidebar *sidebar, - const char *location); -} NautilusSidebarClass; - -GtkType nautilus_sidebar_get_type (void); -NautilusSidebar *nautilus_sidebar_new (void); -void nautilus_sidebar_add_panel (NautilusSidebar *sidebar, - NautilusViewFrame *panel); -GtkWidget *nautilus_sidebar_create_context_menu (NautilusSidebar *sidebar); - -void nautilus_sidebar_hide_active_panel_if_matches (NautilusSidebar *sidebar, - const char *sidebar_id); - -void nautilus_sidebar_remove_panel (NautilusSidebar *sidebar, - NautilusViewFrame *panel); -void nautilus_sidebar_set_uri (NautilusSidebar *sidebar, - const char *new_uri, - const char *initial_title); -void nautilus_sidebar_set_title (NautilusSidebar *sidebar, - const char *new_title); -void nautilus_sidebar_setup_width (NautilusSidebar *sidebar); - -#endif /* NAUTILUS_SIDEBAR_H */ |