summaryrefslogtreecommitdiff
path: root/tools/glade/glade/gnome/gnomeapp.c
diff options
context:
space:
mode:
Diffstat (limited to 'tools/glade/glade/gnome/gnomeapp.c')
-rw-r--r--tools/glade/glade/gnome/gnomeapp.c461
1 files changed, 461 insertions, 0 deletions
diff --git a/tools/glade/glade/gnome/gnomeapp.c b/tools/glade/glade/gnome/gnomeapp.c
new file mode 100644
index 00000000..3835f6d8
--- /dev/null
+++ b/tools/glade/glade/gnome/gnomeapp.c
@@ -0,0 +1,461 @@
+/* Gtk+ User Interface Builder
+ * Copyright (C) 1999 Damon Chaplin
+ *
+ * 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 of the License, 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#include <config.h>
+
+#include <gnome.h>
+#include "../gb.h"
+#include "../tree.h"
+#include "../glade_gnome.h"
+
+/* Include the 21x21 icon pixmap for this widget, to be used in the palette */
+#include "../graphics/gnome-app.xpm"
+
+/*
+ * This is the GbWidget struct for this widget (see ../gbwidget.h).
+ * It is initialized in the init() function at the end of this file
+ */
+static GbWidget gbwidget;
+
+
+static gchar *Title = "GnomeApp|GtkWindow::title";
+static gchar *Type = "GnomeApp|GtkWindow::type";
+static gchar *Position = "GnomeApp|GtkWindow::window_position";
+static gchar *Modal = "GnomeApp|GtkWindow::modal";
+static gchar *DefaultWidth = "GnomeApp|GtkWindow::default_width";
+static gchar *DefaultHeight = "GnomeApp|GtkWindow::default_height";
+static gchar *Shrink = "GnomeAppl|GtkWindow::allow_shrink";
+static gchar *Grow = "GnomeApp|GtkWindow::allow_grow";
+static gchar *AutoShrink = "GnomeApp|GtkWindow::auto_shrink";
+static gchar *IconName = "GnomeApp|GtkWindow::icon_name";
+static gchar *FocusOnMap = "GnomeApp|GtkWindow::focus_on_map";
+
+static gchar *Resizable = "GnomeApp|GtkWindow::resizable";
+static gchar *DestroyWithParent = "GnomeApp|GtkWindow::destroy_with_parent";
+static gchar *Icon = "GnomeApp|GtkWindow::icon";
+
+static gchar *Role = "GnomeApp|GtkWindow::role";
+static gchar *TypeHint = "GnomeApp|GtkWindow::type_hint";
+static gchar *SkipTaskbar = "GnomeApp|GtkWindow::skip_taskbar_hint";
+static gchar *SkipPager = "GnomeApp|GtkWindow::skip_pager_hint";
+static gchar *Decorated = "GnomeApp|GtkWindow::decorated";
+static gchar *Gravity = "GnomeApp|GtkWindow::gravity";
+static gchar *Urgency = "GnomeApp|GtkWindow::urgency_hint";
+
+/* This is kept as object data as we don't want config info written when it is
+ used in Glade. */
+static gchar *EnableLayoutConfig = "GnomeApp::enable_layout_config";
+
+/* This is only used within Glade. We don't save or load it, since the
+ appbar will be saved on its own if it has been added. */
+static gchar *StatusBar = "GnomeApp::status_bar";
+
+
+static void gb_gnome_app_setup_initial_app (GtkWidget *widget);
+
+/******
+ * NOTE: To use these functions you need to uncomment them AND add a pointer
+ * to the function in the GbWidget struct at the end of this file.
+ ******/
+
+/*
+ * Creates a new GtkWidget of class GnomeApp, performing any specialized
+ * initialization needed for the widget to work correctly in this environment.
+ * If a dialog box is used to initialize the widget, return NULL from this
+ * function, and call data->callback with your new widget when it is done.
+ * If the widget needs a special destroy handler, add a signal here.
+ */
+static GtkWidget*
+gb_gnome_app_new (GbWidgetNewData *data)
+{
+ GtkWidget *new_widget;
+ gchar *project_name;
+
+ project_name = glade_project_get_name (data->project);
+ new_widget = gnome_app_new (project_name ? project_name : "", project_name);
+ gtk_object_set_data (GTK_OBJECT (new_widget), EnableLayoutConfig,
+ GINT_TO_POINTER (TRUE));
+
+ /* Turn off the automatic loading/saving of the configuration, and
+ destroy the BonoboDockLayout, so that when items are added they are
+ added straight away. If we don't do this, items don't get added to
+ the widget tree. */
+ gnome_app_enable_layout_config (GNOME_APP (new_widget), FALSE);
+ g_object_unref (G_OBJECT (GNOME_APP (new_widget)->layout));
+ GNOME_APP (new_widget)->layout = NULL;
+
+ gtk_signal_connect (GTK_OBJECT (new_widget), "delete_event",
+ GTK_SIGNAL_FUNC (editor_close_window), NULL);
+
+ gb_widget_create_from (GNOME_APP (new_widget)->dock,
+ data->action == GB_CREATING ? "BonoboDock" : NULL);
+ gb_widget_set_child_name (GNOME_APP (new_widget)->dock, GladeChildGnomeAppDock);
+
+ if (data->action == GB_CREATING)
+ gb_gnome_app_setup_initial_app (new_widget);
+
+ return new_widget;
+}
+
+
+static void
+gb_gnome_app_add_toolbar_button (GtkToolbar *toolbar,
+ const gchar *stock_id,
+ const gchar *tooltip)
+{
+ GtkWidget *button;
+ GladeWidgetData *wdata;
+
+ button = gb_widget_new ("GtkToolButton", NULL);
+
+ gtk_tool_button_set_stock_id (GTK_TOOL_BUTTON (button), stock_id);
+ gtk_tool_button_set_icon_widget (GTK_TOOL_BUTTON (button), NULL);
+ gtk_tool_button_set_label (GTK_TOOL_BUTTON (button), NULL);
+
+ gtk_object_set_data_full (GTK_OBJECT (button),
+ GladeToolButtonStockIDKey,
+ g_strdup (stock_id), g_free);
+
+ wdata = gtk_object_get_data (GTK_OBJECT (button), GB_WIDGET_DATA_KEY);
+ wdata->tooltip = g_strdup (tooltip);
+
+ gtk_toolbar_insert (GTK_TOOLBAR (toolbar), GTK_TOOL_ITEM (button), -1);
+}
+
+
+static void
+gb_gnome_app_setup_initial_app (GtkWidget *widget)
+{
+ GtkWidget *placeholder, *toolbar;
+
+ /* We create a standard menubar and toolbar which the user can edit or
+ simply delete anything they don't want. */
+ glade_gnome_setup_initial_menus (widget);
+
+ /* We need to get rid of the accelerators, since they aren't used, and
+ they would override our default accelerators. */
+ gtk_window_remove_accel_group (GTK_WINDOW (widget),
+ GNOME_APP (widget)->accel_group);
+
+ /* FIXME: GnomeLibs bug workaround. It sets the initial border width
+ to -2, which causes us lots of problems. */
+#if 0
+ gtk_container_set_border_width (GTK_CONTAINER (GNOME_APP (widget)->menubar),
+ 0);
+#endif
+ gb_widget_create_from (GNOME_APP (widget)->menubar, "GtkMenubar");
+ gb_widget_create_from (GNOME_APP (widget)->menubar->parent, "BonoboDockItem");
+
+ /* Toolbar */
+ toolbar = gtk_toolbar_new ();
+ gnome_app_set_toolbar (GNOME_APP (widget), GTK_TOOLBAR (toolbar));
+ gb_widget_create_from (toolbar, "GtkToolbar");
+ gb_widget_create_from (toolbar->parent, "BonoboDockItem");
+
+ gb_gnome_app_add_toolbar_button (GTK_TOOLBAR (toolbar), GTK_STOCK_NEW,
+ _("New File"));
+ gb_gnome_app_add_toolbar_button (GTK_TOOLBAR (toolbar), GTK_STOCK_OPEN,
+ _("Open File"));
+ gb_gnome_app_add_toolbar_button (GTK_TOOLBAR (toolbar), GTK_STOCK_SAVE,
+ _("Save File"));
+
+
+ /* Statusbar */
+ gnome_app_set_statusbar (GNOME_APP (widget),
+ gb_widget_new ("GnomeAppBar", widget));
+ gb_widget_set_child_name (GNOME_APP (widget)->statusbar, GladeChildGnomeAppBar);
+
+ /* We need to size the placeholders or the dialog is very small. */
+ placeholder = editor_new_placeholder ();
+ gtk_widget_set_usize (placeholder, 300, 200);
+ gnome_app_set_contents (GNOME_APP (widget), placeholder);
+}
+
+
+/*
+ * Creates the components needed to edit the extra properties of this widget.
+ */
+static void
+gb_gnome_app_create_properties (GtkWidget * widget, GbWidgetCreateArgData * data)
+{
+ gb_window_create_standard_properties (widget, data,
+ Title, Type, Position, Modal,
+ DefaultWidth, DefaultHeight,
+ Shrink, Grow, AutoShrink,
+ IconName, FocusOnMap,
+ Resizable, DestroyWithParent, Icon,
+ Role, TypeHint, SkipTaskbar,
+ SkipPager, Decorated, Gravity, Urgency);
+ property_add_bool (StatusBar, _("Status Bar:"),
+ _("If the window has a status bar"));
+ property_add_bool (EnableLayoutConfig, _("Store Config:"),
+ _("If the layout is saved and restored automatically"));
+}
+
+
+
+/*
+ * Gets the properties of the widget. This is used for both displaying the
+ * properties in the property editor, and also for saving the properties.
+ */
+static void
+gb_gnome_app_get_properties (GtkWidget *widget, GbWidgetGetArgData * data)
+{
+ gb_window_get_standard_properties (widget, data,
+ Title, Type, Position, Modal,
+ DefaultWidth, DefaultHeight,
+ Shrink, Grow, AutoShrink,
+ IconName, FocusOnMap,
+ Resizable, DestroyWithParent, Icon,
+ Role, TypeHint, SkipTaskbar,
+ SkipPager, Decorated, Gravity, Urgency);
+
+ if (data->action == GB_SHOWING)
+ {
+ gb_widget_output_bool (data, StatusBar,
+ GNOME_APP (widget)->statusbar != NULL
+ ? TRUE : FALSE);
+ }
+
+ gb_widget_output_bool (data, EnableLayoutConfig, GPOINTER_TO_INT (gtk_object_get_data (GTK_OBJECT (widget), EnableLayoutConfig)));
+}
+
+
+
+/*
+ * Sets the properties of the widget. This is used for both applying the
+ * properties changed in the property editor, and also for loading.
+ */
+static void
+gb_gnome_app_set_properties (GtkWidget * widget, GbWidgetSetArgData * data)
+{
+ gboolean statusbar, enable_layout_config;
+
+ gb_window_set_standard_properties (widget, data,
+ Title, Type, Position, Modal,
+ DefaultWidth, DefaultHeight,
+ Shrink, Grow, AutoShrink,
+ IconName, FocusOnMap,
+ Resizable, DestroyWithParent, Icon,
+ Role, TypeHint, SkipTaskbar,
+ SkipPager, Decorated, Gravity, Urgency);
+
+ if (data->action == GB_APPLYING)
+ {
+ statusbar = gb_widget_input_bool (data, StatusBar);
+ if (data->apply)
+ {
+ if (statusbar)
+ {
+ if (!GNOME_APP (widget)->statusbar)
+ {
+ gnome_app_set_statusbar (GNOME_APP (widget),
+ gb_widget_new ("GnomeAppBar",
+ widget));
+ gb_widget_set_child_name (GNOME_APP (widget)->statusbar,
+ GladeChildGnomeAppBar);
+ tree_add_widget (GNOME_APP (widget)->statusbar);
+ }
+ }
+ else
+ {
+ if (GNOME_APP (widget)->statusbar)
+ {
+ /* This is not very clean, but there's no proper way to
+ remove the statusbar. The statusbar has an hbox inserted
+ above it which is added to the GnomeApp's vbox, so we
+ remove the hbox. */
+ GtkWidget *hbox = GNOME_APP (widget)->statusbar->parent;
+ gtk_container_remove (GTK_CONTAINER (hbox->parent), hbox);
+ GNOME_APP (widget)->statusbar = NULL;
+ }
+ }
+ }
+ }
+
+ enable_layout_config = gb_widget_input_bool (data, EnableLayoutConfig);
+ if (data->apply)
+ {
+ gtk_object_set_data (GTK_OBJECT (widget), EnableLayoutConfig,
+ GINT_TO_POINTER (enable_layout_config));
+ }
+}
+
+
+
+/*
+ * Adds menu items to a context menu which is just about to appear!
+ * Add commands to aid in editing a GnomeApp, with signals pointing to
+ * other functions in this file.
+ */
+/*
+static void
+gb_gnome_app_create_popup_menu (GtkWidget * widget, GbWidgetCreateMenuData * data)
+{
+
+}
+*/
+
+
+
+/*
+ * Writes the source code needed to create this widget.
+ * You have to output everything necessary to create the widget here, though
+ * there are some convenience functions to help.
+ */
+static void
+gb_gnome_app_write_source (GtkWidget * widget, GbWidgetWriteSourceData * data)
+{
+ gchar *appname;
+ gboolean translatable, context;
+ gchar *comments;
+
+ if (data->create_widget)
+ {
+ appname = glade_project_get_name (data->project);
+ appname = appname ? source_make_string (appname, FALSE) : "\"\"";
+ appname = g_strdup (appname);
+
+ glade_util_get_translation_properties (widget, Title, &translatable,
+ &comments, &context);
+ source_add_translator_comments (data, translatable, comments);
+
+ /* Note that this assumes that we use the same appname for each GnomeApp.
+ FIXME: I think this is correct, but I'm not sure.
+ Note also that we don't translate the project name. Maybe we should.*/
+ source_add (data, " %s = gnome_app_new (%s, %s);\n", data->wname,
+ appname,
+ GTK_WINDOW (widget)->title
+ ? source_make_string_full (GTK_WINDOW (widget)->title,
+ data->use_gettext && translatable,
+ context)
+ : "NULL");
+ g_free (appname);
+ }
+
+ gb_widget_write_standard_source (widget, data);
+
+ /* The title is already set above, so we pass NULL to skip it. */
+ gb_window_write_standard_source (widget, data,
+ NULL, Type, Position, Modal,
+ DefaultWidth, DefaultHeight,
+ Shrink, Grow, AutoShrink,
+ IconName, FocusOnMap,
+ Resizable, DestroyWithParent, Icon,
+ Role, TypeHint, SkipTaskbar,
+ SkipPager, Decorated, Gravity, Urgency);
+
+ if (!GPOINTER_TO_INT (gtk_object_get_data (GTK_OBJECT (widget),
+ EnableLayoutConfig)))
+ {
+ source_add (data,
+ " gnome_app_enable_layout_config (GNOME_APP (%s), FALSE);\n",
+ data->wname);
+ }
+}
+
+
+/* Outputs source to add a child menu to a GnomeApp. */
+static void
+gb_gnome_app_write_add_child_source (GtkWidget * parent,
+ const gchar *parent_name,
+ GtkWidget *child,
+ GbWidgetWriteSourceData * data)
+{
+ gchar *child_name;
+
+ child_name = gb_widget_get_child_name (child);
+
+ if (child_name && (!strcmp (child_name, GladeChildGnomeAppBar)))
+ {
+ source_add (data,
+ " gnome_app_set_statusbar (GNOME_APP (%s), %s);\n",
+ parent_name, data->wname);
+ }
+ else
+ {
+ g_warning ("Adding unknown child to a GnomeApp: %s", data->wname);
+ source_add (data, " gtk_container_add (GTK_CONTAINER (%s), %s);\n",
+ parent_name, data->wname);
+ }
+}
+
+
+static void
+gb_gnome_app_add_child (GtkWidget *widget, GtkWidget * child,
+ GbWidgetSetArgData *data)
+{
+ gchar *child_name = NULL;
+
+ if (data->child_info)
+ child_name = data->child_info->internal_child;
+
+ if (child_name && (!strcmp (child_name, GladeChildGnomeAppBar)))
+ {
+ gnome_app_set_statusbar (GNOME_APP (widget), child);
+ }
+}
+
+
+static GtkWidget *
+gb_gnome_app_get_child (GtkWidget * widget,
+ const gchar * child_name)
+{
+ if (!strcmp (child_name, GladeChildGnomeAppDock))
+ return GNOME_APP (widget)->dock;
+ else
+ return NULL;
+}
+
+
+/*
+ * Initializes the GbWidget structure.
+ * I've placed this at the end of the file so we don't have to include
+ * declarations of all the functions.
+ */
+GbWidget*
+gb_gnome_app_init ()
+{
+ /* Initialise the GTK type */
+ volatile GtkType type;
+ type = gnome_app_get_type();
+
+ /* Initialize the GbWidget structure */
+ gb_widget_init_struct(&gbwidget);
+
+ /* Fill in the pixmap struct & tooltip */
+ gbwidget.pixmap_struct = gnome_app_xpm;
+ gbwidget.tooltip = _("Gnome Application Window");
+
+ /* Fill in any functions that this GbWidget has */
+ gbwidget.gb_widget_new = gb_gnome_app_new;
+ gbwidget.gb_widget_add_child = gb_gnome_app_add_child;
+ gbwidget.gb_widget_get_child = gb_gnome_app_get_child;
+ gbwidget.gb_widget_create_properties = gb_gnome_app_create_properties;
+ gbwidget.gb_widget_get_properties = gb_gnome_app_get_properties;
+ gbwidget.gb_widget_set_properties = gb_gnome_app_set_properties;
+ gbwidget.gb_widget_write_source = gb_gnome_app_write_source;
+ gbwidget.gb_widget_write_add_child_source = gb_gnome_app_write_add_child_source;
+ gbwidget.gb_widget_destroy = gb_window_destroy;
+/*
+ gbwidget.gb_widget_create_popup_menu = gb_gnome_app_create_popup_menu;
+*/
+
+ return &gbwidget;
+}
+