diff options
Diffstat (limited to 'widgets/menus')
-rw-r--r-- | widgets/menus/gal-view-menus.c | 238 |
1 files changed, 127 insertions, 111 deletions
diff --git a/widgets/menus/gal-view-menus.c b/widgets/menus/gal-view-menus.c index b3d8120f28..33ae89cbba 100644 --- a/widgets/menus/gal-view-menus.c +++ b/widgets/menus/gal-view-menus.c @@ -1,11 +1,11 @@ /* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ /* - * gal-view-menus.c: Savable state of a table. + * gal-view-menus.c: Deploy a GalViewCollection in the menus. * * Author: * Chris Lahey <clahey@helixcode.com> * - * (C) 2000 Helix Code, Inc. + * (C) 2000, 2001 Ximian, Inc. */ #include <config.h> #include <stdlib.h> @@ -19,12 +19,37 @@ struct _GalViewMenusPrivate { GalViewCollection *collection; + BonoboUIVerb *verbs; }; #define PARENT_TYPE (gtk_object_get_type()) static GtkObjectClass *gvm_parent_class; +typedef struct { + GalViewCollection *collection; + GalView *view; +} CollectionAndView; + +static void +free_verbs (GalViewMenus *gvm) +{ + BonoboUIVerb *verbs; + if (gvm->priv->verbs) { + for (verbs = gvm->priv->verbs + 1; verbs->cname; verbs++) { + CollectionAndView *cnv = verbs->user_data; + + g_free(verbs->cname); + + gtk_object_unref(GTK_OBJECT(cnv->collection)); + gtk_object_unref(GTK_OBJECT(cnv->view)); + g_free(cnv); + } + g_free(gvm->priv->verbs); + } + gvm->priv->verbs = NULL; +} + static void gvm_destroy (GtkObject *object) { @@ -32,6 +57,7 @@ gvm_destroy (GtkObject *object) if (gvm->priv->collection) gtk_object_unref(GTK_OBJECT(gvm->priv->collection)); + free_verbs(gvm); g_free(gvm->priv); gvm->priv = NULL; @@ -51,6 +77,7 @@ gvm_init (GalViewMenus *gvm) { gvm->priv = g_new(GalViewMenusPrivate, 1); gvm->priv->collection = NULL; + gvm->priv->verbs = NULL; } E_MAKE_TYPE(gal_view_menus, "GalViewMenus", GalViewMenus, gvm_class_init, gvm_init, PARENT_TYPE); @@ -70,7 +97,7 @@ gal_view_menus_construct (GalViewMenus *gvm, GalViewCollection *collection) { if (collection) - gtk_object_ref(GTK_OBJECT(gvm)); + gtk_object_ref(GTK_OBJECT(collection)); gvm->priv->collection = collection; return gvm; } @@ -78,6 +105,9 @@ gal_view_menus_construct (GalViewMenus *gvm, static void dialog_clicked(GtkWidget *dialog, int button, GalViewMenus *menus) { + if (button == 0) { + gal_view_collection_save(menus->priv->collection); + } gnome_dialog_close(GNOME_DIALOG(dialog)); } @@ -92,133 +122,119 @@ define_views(BonoboUIComponent *component, gtk_widget_show(dialog); } -static BonoboUIVerb verbs[] = { - {"DefineViews", (BonoboUIVerbFn) define_views, NULL, NULL}, - {NULL, NULL, NULL, NULL} -}; - -void gal_view_menus_apply (GalViewMenus *menus, - BonoboUIComponent *component, - CORBA_Environment *ev) +static char * +build_menus(GalViewMenus *menus) { - bonobo_ui_component_set_translate(component, "/", "<Root> <menu> <submenu name=\"View\"> <menuitem name=\"DefineViews\" _label=\"Define Views\" verb=\"DefineViews\"/> </submenu></menu></Root>", ev); - bonobo_ui_component_add_verb_list_with_data(component, verbs, menus); -} + BonoboUINode *root; + BonoboUINode *menu; + BonoboUINode *submenu; + BonoboUINode *menuitem; + char *xml; + xmlChar *string; + int length; + int i; + GalViewCollection *collection = menus->priv->collection; -#if 0 -gboolean -gal_view_menus_load_from_file (GalViewMenus *state, - const char *filename) -{ - xmlDoc *doc; - doc = xmlParseFile (filename); - if (doc) { - xmlNode *node = xmlDocGetRootElement(doc); - gal_view_menus_load_from_node(state, node); - xmlFreeDoc(doc); - return TRUE; - } - return FALSE; -} -void -gal_view_menus_load_from_string (GalViewMenus *state, - const char *xml) -{ - xmlDoc *doc; - doc = xmlParseMemory ((char *) xml, strlen(xml)); - if (doc) { - xmlNode *node = xmlDocGetRootElement(doc); - gal_view_menus_load_from_node(state, node); - xmlFreeDoc(doc); - } -} -void -gal_view_menus_load_from_node (GalViewMenus *state, - const xmlNode *node) -{ - xmlNode *children; - GList *list = NULL, *iterator; - int i; + root = bonobo_ui_node_new("Root"); + menu = bonobo_ui_node_new_child(root, "menu"); - if (state->sort_info) - gtk_object_unref(GTK_OBJECT(state->sort_info)); - state->sort_info = NULL; - for (children = node->xmlChildrenNode; children; children = children->next) { - if (!strcmp(children->name, "column")) { - int *column = g_new(int, 1); + submenu = bonobo_ui_node_new_child(menu, "submenu"); + bonobo_ui_node_set_attr(submenu, "name", "View"); - *column = e_xml_get_integer_prop_by_name(children, "source"); + submenu = bonobo_ui_node_new_child(submenu, "submenu"); + bonobo_ui_node_set_attr(submenu, "name", "CurrentView"); + bonobo_ui_node_set_attr(submenu, "_label", "Current View"); - list = g_list_append(list, column); - } else if (state->sort_info == NULL && !strcmp(children->name, "grouping")) { - state->sort_info = e_table_sort_info_new(); - e_table_sort_info_load_from_node(state->sort_info, children); - } - } - g_free(state->columns); - state->col_count = g_list_length(list); - state->columns = g_new(int, state->col_count); - for (iterator = list, i = 0; iterator; iterator = g_list_next(iterator), i++) { - state->columns[i] = *(int *)iterator->data; - g_free(iterator->data); + length = gal_view_collection_get_count(collection); + for (i = 0; i < length; i++) { + GalViewCollectionItem *item = gal_view_collection_get_view_item(collection, i); + menuitem = bonobo_ui_node_new_child(submenu, "menuitem"); + bonobo_ui_node_set_attr(menuitem, "name", item->id); + bonobo_ui_node_set_attr(menuitem, "_label", item->title); + bonobo_ui_node_set_attr(menuitem, "verb", item->id); } - g_list_free(list); -} -void -gal_view_menus_save_to_file (GalViewMenus *state, - const char *filename) -{ - xmlDoc *doc; - doc = xmlNewDoc("1.0"); - xmlDocSetRootElement(doc, gal_view_menus_save_to_node(state, NULL)); - xmlSaveFile(filename, doc); -} + menuitem = bonobo_ui_node_new_child(submenu, "separator"); -char * -gal_view_menus_save_to_string (GalViewMenus *state) -{ - char *ret_val; - xmlChar *string; - int length; - xmlDoc *doc; + menuitem = bonobo_ui_node_new_child(submenu, "menuitem"); + bonobo_ui_node_set_attr(menuitem, "name", "DefineViews"); + bonobo_ui_node_set_attr(menuitem, "_label", "Define Views"); + bonobo_ui_node_set_attr(menuitem, "verb", "DefineViews"); + + string = bonobo_ui_node_to_string(root, TRUE); + xml = g_strdup(string); + bonobo_ui_node_free_string(string); + + bonobo_ui_node_free(root); + + g_print (xml); - doc = xmlNewDoc(NULL); - xmlDocSetRootElement(doc, gal_view_menus_save_to_node(state, NULL)); - xmlDocDumpMemory(doc, &string, &length); + return xml; +} - ret_val = g_strdup(string); - xmlFree(string); - return ret_val; +static void +show_view(BonoboUIComponent *component, + gpointer user_data, + const char *cname) +{ + CollectionAndView *cnv = user_data; + gal_view_collection_display_view(cnv->collection, cnv->view); } -xmlNode * -gal_view_menus_save_to_node (GalViewMenus *state, - xmlNode *parent) +static BonoboUIVerb * +build_verbs (GalViewMenus *menus) { + GalViewCollection *collection = menus->priv->collection; + int count = gal_view_collection_get_count(collection); + BonoboUIVerb *verbs = g_new(BonoboUIVerb, count + 2); + BonoboUIVerb *verb; int i; - xmlNode *node; - - if (parent) - node = xmlNewChild (parent, NULL, "GalViewMenus", NULL); - else - node = xmlNewNode (NULL, "GalViewMenus"); - - e_xml_set_double_prop_by_name(node, "state-version", 0.0); + + verb = verbs; + verb->cname = "DefineViews"; + verb->cb = (BonoboUIVerbFn) define_views; + verb->user_data = menus; + verb->dummy = NULL; + verb ++; + for (i = 0; i < count; i++) { + CollectionAndView *cnv; + GalViewCollectionItem *item = gal_view_collection_get_view_item(collection, i); + + cnv = g_new(CollectionAndView, 1); + cnv->view = item->view; + cnv->collection = collection; + + gtk_object_ref(GTK_OBJECT(cnv->view)); + gtk_object_ref(GTK_OBJECT(cnv->collection)); + + verb->cname = item->id; + verb->cb = show_view; + verb->user_data = cnv; + verb->dummy = NULL; + verb++; + } - for (i = 0; i < state->col_count; i++) { - int column = state->columns[i]; - xmlNode *new_node; + verb->cname = NULL; + verb->cb = NULL; + verb->user_data = NULL; + verb->dummy = NULL; + verb++; - new_node = xmlNewChild(node, NULL, "column", NULL); - e_xml_set_integer_prop_by_name (new_node, "source", column); - } + return verbs; +} - e_table_sort_info_save_to_node(state->sort_info, node); +void gal_view_menus_apply (GalViewMenus *menus, + BonoboUIComponent *component, + CORBA_Environment *ev) +{ + char *xml = build_menus(menus); + bonobo_ui_component_set_translate(component, "/", xml, ev); + g_free(xml); - return node; + free_verbs(menus); + menus->priv->verbs = build_verbs(menus); + bonobo_ui_component_add_verb_list(component, menus->priv->verbs); } -#endif |