Reorder all menu items under <Image>/Filters which were created by

1999-12-04  Michael Natterer  <mitch@gimp.org>

	* app/menus.c: Reorder all menu items under <Image>/Filters which
	were created by plugins, so they appear after <Image>/Filters/Web.
	(this way <Image>/Filters/Toys is always the last submenu)

	* app/palette.c: My last change caused both the normal _and_ the
	small menu to pop up on right mouse click on an already existing
	color. Thanks to Nick for pointing this out.

	Now there is only one menu with "Edit" and "Delete" greyed out if
	the click was outside a valid color square.
	I also moved "New" to the top of the menu because that's how other
	gimp menus look like.
This commit is contained in:
Michael Natterer 1999-12-04 13:08:45 +00:00 committed by Michael Natterer
parent 7c96774bd4
commit 6e637d6eb4
8 changed files with 289 additions and 223 deletions

View File

@ -1,3 +1,18 @@
1999-12-04 Michael Natterer <mitch@gimp.org>
* app/menus.c: Reorder all menu items under <Image>/Filters which
were created by plugins, so they appear after <Image>/Filters/Web.
(this way <Image>/Filters/Toys is always the last submenu)
* app/palette.c: My last change caused both the normal _and_ the
small menu to pop up on right mouse click on an already existing
color. Thanks to Nick for pointing this out.
Now there is only one menu with "Edit" and "Delete" greyed out if
the click was outside a valid color square.
I also moved "New" to the top of the menu because that's how other
gimp menus look like.
Sat Dec 4 05:30:38 GMT 1999 Nick Lamb <njl195@zepler.org.uk> Sat Dec 4 05:30:38 GMT 1999 Nick Lamb <njl195@zepler.org.uk>
* libgimp/gimpunitmenu.c: Move mitch's change so now it * libgimp/gimpunitmenu.c: Move mitch's change so now it

View File

@ -1039,10 +1039,6 @@ menus_reorder_plugins (void)
static gint n_reorder_subsubmenus = (sizeof (reorder_subsubmenus) / static gint n_reorder_subsubmenus = (sizeof (reorder_subsubmenus) /
sizeof (reorder_subsubmenus[0])); sizeof (reorder_subsubmenus[0]));
static gchar *reorder_if_exists[] = { "/Filters/Misc" };
static gint n_reorder_if_exists = (sizeof (reorder_if_exists) /
sizeof (reorder_if_exists[0]));
GtkItemFactory *item_factory; GtkItemFactory *item_factory;
GtkWidget *menu_item; GtkWidget *menu_item;
GtkWidget *menu; GtkWidget *menu;
@ -1050,7 +1046,7 @@ menus_reorder_plugins (void)
gchar *path; gchar *path;
gint i, pos; gint i, pos;
/* Beautify <Toolbox>/Xtns */ /* Beautify "<Toolbox>/Xtns" */
pos = 2; pos = 2;
for (i = 0; i < n_xtns_plugins; i++) for (i = 0; i < n_xtns_plugins; i++)
{ {
@ -1065,7 +1061,7 @@ menus_reorder_plugins (void)
} }
} }
/* Move "Filter all Layers..." before the separator */ /* Move "<Image>/Filters/Filter all Layers..." before the separator */
menu_item = gtk_item_factory_get_widget (image_factory, menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/Filter all Layers..."); "/Filters/Filter all Layers...");
if (menu_item && menu_item->parent) if (menu_item && menu_item->parent)
@ -1100,7 +1096,7 @@ menus_reorder_plugins (void)
} }
} }
/* Reorder <Image>/File */ /* Reorder "<Image>/File" */
for (i = 0; i < n_image_file_entries; i++) for (i = 0; i < n_image_file_entries; i++)
{ {
path = g_strconcat ("/File/", image_file_entries[i], NULL); path = g_strconcat ("/File/", image_file_entries[i], NULL);
@ -1145,7 +1141,9 @@ menus_reorder_plugins (void)
} }
} }
/* Reorder submenus of <Image>/Filters which only exist sometimes */ /* Move all submenus which registered after "<Image>/Filters/Toys"
* before the separator after "<Image>/Filters/Web"
*/
menu_item = gtk_item_factory_get_widget (image_factory, menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/---INSERT"); "/Filters/---INSERT");
@ -1154,28 +1152,30 @@ menus_reorder_plugins (void)
menu = menu_item->parent; menu = menu_item->parent;
pos = g_list_index (GTK_MENU_SHELL (menu)->children, menu_item); pos = g_list_index (GTK_MENU_SHELL (menu)->children, menu_item);
for (i = 0; i < n_reorder_if_exists; i++) menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/Toys");
if (menu_item && GTK_IS_MENU (menu_item))
{ {
GList *list; GList *list;
gint index = 1;
menu_item = gtk_item_factory_get_widget (image_factory, for (list = GTK_MENU_SHELL (menu)->children; list;
reorder_if_exists[i]); list = g_list_next (list))
if (menu_item && GTK_IS_MENU (menu_item))
{ {
for (list = GTK_MENU_SHELL (menu)->children; list; if (GTK_MENU_ITEM (list->data)->submenu == menu_item)
list = g_list_next (list)) break;
{
if (GTK_MENU_ITEM (list->data)->submenu == menu_item)
break;
}
if (list) index++;
{ }
gtk_menu_reorder_child (GTK_MENU (menu),
GTK_WIDGET (list->data), pos); while ((menu_item = g_list_nth_data (GTK_MENU_SHELL (menu)->children,
pos++; index)))
} {
gtk_menu_reorder_child (GTK_MENU (menu), menu_item, pos);
pos++;
index++;
} }
} }
} }

View File

@ -105,17 +105,23 @@ typedef struct _PaletteDialog PaletteDialog;
struct _PaletteDialog struct _PaletteDialog
{ {
GtkWidget *shell; GtkWidget *shell;
GtkWidget *color_area; GtkWidget *color_area;
GtkWidget *scrolled_window; GtkWidget *scrolled_window;
GtkWidget *color_name; GtkWidget *color_name;
GtkWidget *clist; GtkWidget *clist;
GtkWidget *popup_menu; GtkWidget *popup_menu;
GtkWidget *popup_small_menu; GtkWidget *delete_menu_item;
GtkWidget *edit_menu_item;
ColorNotebookP color_notebook; ColorNotebookP color_notebook;
gboolean color_notebook_active; gboolean color_notebook_active;
PaletteEntries *entries; PaletteEntries *entries;
PaletteEntry *color; PaletteEntry *color;
PaletteEntry *dnd_color; PaletteEntry *dnd_color;
GdkGC *gc; GdkGC *gc;
guint entry_sig_id; guint entry_sig_id;
gfloat zoom_factor; /* range from 0.1 to 4.0 */ gfloat zoom_factor; /* range from 0.1 to 4.0 */
@ -1175,40 +1181,35 @@ static void
palette_dialog_create_popup_menu (PaletteDialog *palette) palette_dialog_create_popup_menu (PaletteDialog *palette)
{ {
GtkWidget *menu; GtkWidget *menu;
GtkWidget *menu_items; GtkWidget *menu_item;
menu = gtk_menu_new (); palette->popup_menu = menu = gtk_menu_new ();
menu_items = gtk_menu_item_new_with_label (_("Edit"));
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate", menu_item = gtk_menu_item_new_with_label (_("New"));
gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_item);
menu_item = gtk_menu_item_new_with_label (_("Edit"));
gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_edit_entry_callback), GTK_SIGNAL_FUNC (palette_dialog_edit_entry_callback),
(gpointer) palette); (gpointer) palette);
gtk_widget_show (menu_items); gtk_widget_show (menu_item);
menu_items = gtk_menu_item_new_with_label (_("New")); palette->edit_menu_item = menu_item;
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_items);
menu_items = gtk_menu_item_new_with_label (_("Delete")); menu_item = gtk_menu_item_new_with_label (_("Delete"));
gtk_signal_connect (GTK_OBJECT(menu_items), "activate", gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_delete_entry_callback), GTK_SIGNAL_FUNC (palette_dialog_delete_entry_callback),
(gpointer) palette); (gpointer) palette);
gtk_menu_append (GTK_MENU (menu), menu_items); gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_widget_show (menu_items); gtk_widget_show (menu_item);
palette->popup_menu = menu; palette->delete_menu_item = menu_item;
palette->popup_small_menu = menu = gtk_menu_new ();
menu_items = gtk_menu_item_new_with_label (_("New"));
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_items);
} }
/* the color area event callbacks ******************************************/ /* the color area event callbacks ******************************************/
@ -1218,16 +1219,23 @@ palette_dialog_eventbox_button_press (GtkWidget *widget,
GdkEventButton *bevent, GdkEventButton *bevent,
PaletteDialog *palette) PaletteDialog *palette)
{ {
if (gtk_get_event_widget ((GdkEvent *) bevent) == palette->color_area)
return FALSE;
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the small new menu */ if (GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
gtk_menu_popup (GTK_MENU (palette->popup_small_menu), {
NULL, NULL, gtk_widget_set_sensitive (palette->edit_menu_item, FALSE);
gtk_widget_set_sensitive (palette->delete_menu_item, FALSE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
bevent->time); bevent->time);
} }
return FALSE; return TRUE;
} }
static gint static gint
@ -1237,11 +1245,11 @@ palette_dialog_color_area_events (GtkWidget *widget,
{ {
GdkEventButton *bevent; GdkEventButton *bevent;
GSList *tmp_link; GSList *tmp_link;
int r, g, b; gint r, g, b;
int entry_width; gint entry_width;
int entry_height; gint entry_height;
int row, col; gint row, col;
int pos; gint pos;
switch (event->type) switch (event->type)
{ {
@ -1308,21 +1316,30 @@ palette_dialog_color_area_events (GtkWidget *widget,
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the edit menu */ if (! GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
{
gtk_widget_set_sensitive (palette->edit_menu_item, TRUE);
gtk_widget_set_sensitive (palette->delete_menu_item, TRUE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL, gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
((GdkEventButton *)event)->time); bevent->time);
} }
} }
else else
{ {
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the small new menu */ if (GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
gtk_menu_popup (GTK_MENU (palette->popup_small_menu), {
NULL, NULL, gtk_widget_set_sensitive (palette->edit_menu_item, FALSE);
gtk_widget_set_sensitive (palette->delete_menu_item, FALSE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
((GdkEventButton *)event)->time); bevent->time);
} }
} }
} }

View File

@ -1039,10 +1039,6 @@ menus_reorder_plugins (void)
static gint n_reorder_subsubmenus = (sizeof (reorder_subsubmenus) / static gint n_reorder_subsubmenus = (sizeof (reorder_subsubmenus) /
sizeof (reorder_subsubmenus[0])); sizeof (reorder_subsubmenus[0]));
static gchar *reorder_if_exists[] = { "/Filters/Misc" };
static gint n_reorder_if_exists = (sizeof (reorder_if_exists) /
sizeof (reorder_if_exists[0]));
GtkItemFactory *item_factory; GtkItemFactory *item_factory;
GtkWidget *menu_item; GtkWidget *menu_item;
GtkWidget *menu; GtkWidget *menu;
@ -1050,7 +1046,7 @@ menus_reorder_plugins (void)
gchar *path; gchar *path;
gint i, pos; gint i, pos;
/* Beautify <Toolbox>/Xtns */ /* Beautify "<Toolbox>/Xtns" */
pos = 2; pos = 2;
for (i = 0; i < n_xtns_plugins; i++) for (i = 0; i < n_xtns_plugins; i++)
{ {
@ -1065,7 +1061,7 @@ menus_reorder_plugins (void)
} }
} }
/* Move "Filter all Layers..." before the separator */ /* Move "<Image>/Filters/Filter all Layers..." before the separator */
menu_item = gtk_item_factory_get_widget (image_factory, menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/Filter all Layers..."); "/Filters/Filter all Layers...");
if (menu_item && menu_item->parent) if (menu_item && menu_item->parent)
@ -1100,7 +1096,7 @@ menus_reorder_plugins (void)
} }
} }
/* Reorder <Image>/File */ /* Reorder "<Image>/File" */
for (i = 0; i < n_image_file_entries; i++) for (i = 0; i < n_image_file_entries; i++)
{ {
path = g_strconcat ("/File/", image_file_entries[i], NULL); path = g_strconcat ("/File/", image_file_entries[i], NULL);
@ -1145,7 +1141,9 @@ menus_reorder_plugins (void)
} }
} }
/* Reorder submenus of <Image>/Filters which only exist sometimes */ /* Move all submenus which registered after "<Image>/Filters/Toys"
* before the separator after "<Image>/Filters/Web"
*/
menu_item = gtk_item_factory_get_widget (image_factory, menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/---INSERT"); "/Filters/---INSERT");
@ -1154,28 +1152,30 @@ menus_reorder_plugins (void)
menu = menu_item->parent; menu = menu_item->parent;
pos = g_list_index (GTK_MENU_SHELL (menu)->children, menu_item); pos = g_list_index (GTK_MENU_SHELL (menu)->children, menu_item);
for (i = 0; i < n_reorder_if_exists; i++) menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/Toys");
if (menu_item && GTK_IS_MENU (menu_item))
{ {
GList *list; GList *list;
gint index = 1;
menu_item = gtk_item_factory_get_widget (image_factory, for (list = GTK_MENU_SHELL (menu)->children; list;
reorder_if_exists[i]); list = g_list_next (list))
if (menu_item && GTK_IS_MENU (menu_item))
{ {
for (list = GTK_MENU_SHELL (menu)->children; list; if (GTK_MENU_ITEM (list->data)->submenu == menu_item)
list = g_list_next (list)) break;
{
if (GTK_MENU_ITEM (list->data)->submenu == menu_item)
break;
}
if (list) index++;
{ }
gtk_menu_reorder_child (GTK_MENU (menu),
GTK_WIDGET (list->data), pos); while ((menu_item = g_list_nth_data (GTK_MENU_SHELL (menu)->children,
pos++; index)))
} {
gtk_menu_reorder_child (GTK_MENU (menu), menu_item, pos);
pos++;
index++;
} }
} }
} }

View File

@ -1039,10 +1039,6 @@ menus_reorder_plugins (void)
static gint n_reorder_subsubmenus = (sizeof (reorder_subsubmenus) / static gint n_reorder_subsubmenus = (sizeof (reorder_subsubmenus) /
sizeof (reorder_subsubmenus[0])); sizeof (reorder_subsubmenus[0]));
static gchar *reorder_if_exists[] = { "/Filters/Misc" };
static gint n_reorder_if_exists = (sizeof (reorder_if_exists) /
sizeof (reorder_if_exists[0]));
GtkItemFactory *item_factory; GtkItemFactory *item_factory;
GtkWidget *menu_item; GtkWidget *menu_item;
GtkWidget *menu; GtkWidget *menu;
@ -1050,7 +1046,7 @@ menus_reorder_plugins (void)
gchar *path; gchar *path;
gint i, pos; gint i, pos;
/* Beautify <Toolbox>/Xtns */ /* Beautify "<Toolbox>/Xtns" */
pos = 2; pos = 2;
for (i = 0; i < n_xtns_plugins; i++) for (i = 0; i < n_xtns_plugins; i++)
{ {
@ -1065,7 +1061,7 @@ menus_reorder_plugins (void)
} }
} }
/* Move "Filter all Layers..." before the separator */ /* Move "<Image>/Filters/Filter all Layers..." before the separator */
menu_item = gtk_item_factory_get_widget (image_factory, menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/Filter all Layers..."); "/Filters/Filter all Layers...");
if (menu_item && menu_item->parent) if (menu_item && menu_item->parent)
@ -1100,7 +1096,7 @@ menus_reorder_plugins (void)
} }
} }
/* Reorder <Image>/File */ /* Reorder "<Image>/File" */
for (i = 0; i < n_image_file_entries; i++) for (i = 0; i < n_image_file_entries; i++)
{ {
path = g_strconcat ("/File/", image_file_entries[i], NULL); path = g_strconcat ("/File/", image_file_entries[i], NULL);
@ -1145,7 +1141,9 @@ menus_reorder_plugins (void)
} }
} }
/* Reorder submenus of <Image>/Filters which only exist sometimes */ /* Move all submenus which registered after "<Image>/Filters/Toys"
* before the separator after "<Image>/Filters/Web"
*/
menu_item = gtk_item_factory_get_widget (image_factory, menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/---INSERT"); "/Filters/---INSERT");
@ -1154,28 +1152,30 @@ menus_reorder_plugins (void)
menu = menu_item->parent; menu = menu_item->parent;
pos = g_list_index (GTK_MENU_SHELL (menu)->children, menu_item); pos = g_list_index (GTK_MENU_SHELL (menu)->children, menu_item);
for (i = 0; i < n_reorder_if_exists; i++) menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/Toys");
if (menu_item && GTK_IS_MENU (menu_item))
{ {
GList *list; GList *list;
gint index = 1;
menu_item = gtk_item_factory_get_widget (image_factory, for (list = GTK_MENU_SHELL (menu)->children; list;
reorder_if_exists[i]); list = g_list_next (list))
if (menu_item && GTK_IS_MENU (menu_item))
{ {
for (list = GTK_MENU_SHELL (menu)->children; list; if (GTK_MENU_ITEM (list->data)->submenu == menu_item)
list = g_list_next (list)) break;
{
if (GTK_MENU_ITEM (list->data)->submenu == menu_item)
break;
}
if (list) index++;
{ }
gtk_menu_reorder_child (GTK_MENU (menu),
GTK_WIDGET (list->data), pos); while ((menu_item = g_list_nth_data (GTK_MENU_SHELL (menu)->children,
pos++; index)))
} {
gtk_menu_reorder_child (GTK_MENU (menu), menu_item, pos);
pos++;
index++;
} }
} }
} }

View File

@ -105,17 +105,23 @@ typedef struct _PaletteDialog PaletteDialog;
struct _PaletteDialog struct _PaletteDialog
{ {
GtkWidget *shell; GtkWidget *shell;
GtkWidget *color_area; GtkWidget *color_area;
GtkWidget *scrolled_window; GtkWidget *scrolled_window;
GtkWidget *color_name; GtkWidget *color_name;
GtkWidget *clist; GtkWidget *clist;
GtkWidget *popup_menu; GtkWidget *popup_menu;
GtkWidget *popup_small_menu; GtkWidget *delete_menu_item;
GtkWidget *edit_menu_item;
ColorNotebookP color_notebook; ColorNotebookP color_notebook;
gboolean color_notebook_active; gboolean color_notebook_active;
PaletteEntries *entries; PaletteEntries *entries;
PaletteEntry *color; PaletteEntry *color;
PaletteEntry *dnd_color; PaletteEntry *dnd_color;
GdkGC *gc; GdkGC *gc;
guint entry_sig_id; guint entry_sig_id;
gfloat zoom_factor; /* range from 0.1 to 4.0 */ gfloat zoom_factor; /* range from 0.1 to 4.0 */
@ -1175,40 +1181,35 @@ static void
palette_dialog_create_popup_menu (PaletteDialog *palette) palette_dialog_create_popup_menu (PaletteDialog *palette)
{ {
GtkWidget *menu; GtkWidget *menu;
GtkWidget *menu_items; GtkWidget *menu_item;
menu = gtk_menu_new (); palette->popup_menu = menu = gtk_menu_new ();
menu_items = gtk_menu_item_new_with_label (_("Edit"));
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate", menu_item = gtk_menu_item_new_with_label (_("New"));
gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_item);
menu_item = gtk_menu_item_new_with_label (_("Edit"));
gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_edit_entry_callback), GTK_SIGNAL_FUNC (palette_dialog_edit_entry_callback),
(gpointer) palette); (gpointer) palette);
gtk_widget_show (menu_items); gtk_widget_show (menu_item);
menu_items = gtk_menu_item_new_with_label (_("New")); palette->edit_menu_item = menu_item;
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_items);
menu_items = gtk_menu_item_new_with_label (_("Delete")); menu_item = gtk_menu_item_new_with_label (_("Delete"));
gtk_signal_connect (GTK_OBJECT(menu_items), "activate", gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_delete_entry_callback), GTK_SIGNAL_FUNC (palette_dialog_delete_entry_callback),
(gpointer) palette); (gpointer) palette);
gtk_menu_append (GTK_MENU (menu), menu_items); gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_widget_show (menu_items); gtk_widget_show (menu_item);
palette->popup_menu = menu; palette->delete_menu_item = menu_item;
palette->popup_small_menu = menu = gtk_menu_new ();
menu_items = gtk_menu_item_new_with_label (_("New"));
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_items);
} }
/* the color area event callbacks ******************************************/ /* the color area event callbacks ******************************************/
@ -1218,16 +1219,23 @@ palette_dialog_eventbox_button_press (GtkWidget *widget,
GdkEventButton *bevent, GdkEventButton *bevent,
PaletteDialog *palette) PaletteDialog *palette)
{ {
if (gtk_get_event_widget ((GdkEvent *) bevent) == palette->color_area)
return FALSE;
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the small new menu */ if (GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
gtk_menu_popup (GTK_MENU (palette->popup_small_menu), {
NULL, NULL, gtk_widget_set_sensitive (palette->edit_menu_item, FALSE);
gtk_widget_set_sensitive (palette->delete_menu_item, FALSE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
bevent->time); bevent->time);
} }
return FALSE; return TRUE;
} }
static gint static gint
@ -1237,11 +1245,11 @@ palette_dialog_color_area_events (GtkWidget *widget,
{ {
GdkEventButton *bevent; GdkEventButton *bevent;
GSList *tmp_link; GSList *tmp_link;
int r, g, b; gint r, g, b;
int entry_width; gint entry_width;
int entry_height; gint entry_height;
int row, col; gint row, col;
int pos; gint pos;
switch (event->type) switch (event->type)
{ {
@ -1308,21 +1316,30 @@ palette_dialog_color_area_events (GtkWidget *widget,
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the edit menu */ if (! GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
{
gtk_widget_set_sensitive (palette->edit_menu_item, TRUE);
gtk_widget_set_sensitive (palette->delete_menu_item, TRUE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL, gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
((GdkEventButton *)event)->time); bevent->time);
} }
} }
else else
{ {
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the small new menu */ if (GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
gtk_menu_popup (GTK_MENU (palette->popup_small_menu), {
NULL, NULL, gtk_widget_set_sensitive (palette->edit_menu_item, FALSE);
gtk_widget_set_sensitive (palette->delete_menu_item, FALSE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
((GdkEventButton *)event)->time); bevent->time);
} }
} }
} }

View File

@ -1039,10 +1039,6 @@ menus_reorder_plugins (void)
static gint n_reorder_subsubmenus = (sizeof (reorder_subsubmenus) / static gint n_reorder_subsubmenus = (sizeof (reorder_subsubmenus) /
sizeof (reorder_subsubmenus[0])); sizeof (reorder_subsubmenus[0]));
static gchar *reorder_if_exists[] = { "/Filters/Misc" };
static gint n_reorder_if_exists = (sizeof (reorder_if_exists) /
sizeof (reorder_if_exists[0]));
GtkItemFactory *item_factory; GtkItemFactory *item_factory;
GtkWidget *menu_item; GtkWidget *menu_item;
GtkWidget *menu; GtkWidget *menu;
@ -1050,7 +1046,7 @@ menus_reorder_plugins (void)
gchar *path; gchar *path;
gint i, pos; gint i, pos;
/* Beautify <Toolbox>/Xtns */ /* Beautify "<Toolbox>/Xtns" */
pos = 2; pos = 2;
for (i = 0; i < n_xtns_plugins; i++) for (i = 0; i < n_xtns_plugins; i++)
{ {
@ -1065,7 +1061,7 @@ menus_reorder_plugins (void)
} }
} }
/* Move "Filter all Layers..." before the separator */ /* Move "<Image>/Filters/Filter all Layers..." before the separator */
menu_item = gtk_item_factory_get_widget (image_factory, menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/Filter all Layers..."); "/Filters/Filter all Layers...");
if (menu_item && menu_item->parent) if (menu_item && menu_item->parent)
@ -1100,7 +1096,7 @@ menus_reorder_plugins (void)
} }
} }
/* Reorder <Image>/File */ /* Reorder "<Image>/File" */
for (i = 0; i < n_image_file_entries; i++) for (i = 0; i < n_image_file_entries; i++)
{ {
path = g_strconcat ("/File/", image_file_entries[i], NULL); path = g_strconcat ("/File/", image_file_entries[i], NULL);
@ -1145,7 +1141,9 @@ menus_reorder_plugins (void)
} }
} }
/* Reorder submenus of <Image>/Filters which only exist sometimes */ /* Move all submenus which registered after "<Image>/Filters/Toys"
* before the separator after "<Image>/Filters/Web"
*/
menu_item = gtk_item_factory_get_widget (image_factory, menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/---INSERT"); "/Filters/---INSERT");
@ -1154,28 +1152,30 @@ menus_reorder_plugins (void)
menu = menu_item->parent; menu = menu_item->parent;
pos = g_list_index (GTK_MENU_SHELL (menu)->children, menu_item); pos = g_list_index (GTK_MENU_SHELL (menu)->children, menu_item);
for (i = 0; i < n_reorder_if_exists; i++) menu_item = gtk_item_factory_get_widget (image_factory,
"/Filters/Toys");
if (menu_item && GTK_IS_MENU (menu_item))
{ {
GList *list; GList *list;
gint index = 1;
menu_item = gtk_item_factory_get_widget (image_factory, for (list = GTK_MENU_SHELL (menu)->children; list;
reorder_if_exists[i]); list = g_list_next (list))
if (menu_item && GTK_IS_MENU (menu_item))
{ {
for (list = GTK_MENU_SHELL (menu)->children; list; if (GTK_MENU_ITEM (list->data)->submenu == menu_item)
list = g_list_next (list)) break;
{
if (GTK_MENU_ITEM (list->data)->submenu == menu_item)
break;
}
if (list) index++;
{ }
gtk_menu_reorder_child (GTK_MENU (menu),
GTK_WIDGET (list->data), pos); while ((menu_item = g_list_nth_data (GTK_MENU_SHELL (menu)->children,
pos++; index)))
} {
gtk_menu_reorder_child (GTK_MENU (menu), menu_item, pos);
pos++;
index++;
} }
} }
} }

View File

@ -105,17 +105,23 @@ typedef struct _PaletteDialog PaletteDialog;
struct _PaletteDialog struct _PaletteDialog
{ {
GtkWidget *shell; GtkWidget *shell;
GtkWidget *color_area; GtkWidget *color_area;
GtkWidget *scrolled_window; GtkWidget *scrolled_window;
GtkWidget *color_name; GtkWidget *color_name;
GtkWidget *clist; GtkWidget *clist;
GtkWidget *popup_menu; GtkWidget *popup_menu;
GtkWidget *popup_small_menu; GtkWidget *delete_menu_item;
GtkWidget *edit_menu_item;
ColorNotebookP color_notebook; ColorNotebookP color_notebook;
gboolean color_notebook_active; gboolean color_notebook_active;
PaletteEntries *entries; PaletteEntries *entries;
PaletteEntry *color; PaletteEntry *color;
PaletteEntry *dnd_color; PaletteEntry *dnd_color;
GdkGC *gc; GdkGC *gc;
guint entry_sig_id; guint entry_sig_id;
gfloat zoom_factor; /* range from 0.1 to 4.0 */ gfloat zoom_factor; /* range from 0.1 to 4.0 */
@ -1175,40 +1181,35 @@ static void
palette_dialog_create_popup_menu (PaletteDialog *palette) palette_dialog_create_popup_menu (PaletteDialog *palette)
{ {
GtkWidget *menu; GtkWidget *menu;
GtkWidget *menu_items; GtkWidget *menu_item;
menu = gtk_menu_new (); palette->popup_menu = menu = gtk_menu_new ();
menu_items = gtk_menu_item_new_with_label (_("Edit"));
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate", menu_item = gtk_menu_item_new_with_label (_("New"));
gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_item);
menu_item = gtk_menu_item_new_with_label (_("Edit"));
gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_edit_entry_callback), GTK_SIGNAL_FUNC (palette_dialog_edit_entry_callback),
(gpointer) palette); (gpointer) palette);
gtk_widget_show (menu_items); gtk_widget_show (menu_item);
menu_items = gtk_menu_item_new_with_label (_("New")); palette->edit_menu_item = menu_item;
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_items);
menu_items = gtk_menu_item_new_with_label (_("Delete")); menu_item = gtk_menu_item_new_with_label (_("Delete"));
gtk_signal_connect (GTK_OBJECT(menu_items), "activate", gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
GTK_SIGNAL_FUNC (palette_dialog_delete_entry_callback), GTK_SIGNAL_FUNC (palette_dialog_delete_entry_callback),
(gpointer) palette); (gpointer) palette);
gtk_menu_append (GTK_MENU (menu), menu_items); gtk_menu_append (GTK_MENU (menu), menu_item);
gtk_widget_show (menu_items); gtk_widget_show (menu_item);
palette->popup_menu = menu; palette->delete_menu_item = menu_item;
palette->popup_small_menu = menu = gtk_menu_new ();
menu_items = gtk_menu_item_new_with_label (_("New"));
gtk_menu_append (GTK_MENU (menu), menu_items);
gtk_signal_connect (GTK_OBJECT (menu_items), "activate",
GTK_SIGNAL_FUNC (palette_dialog_new_entry_callback),
(gpointer) palette);
gtk_widget_show (menu_items);
} }
/* the color area event callbacks ******************************************/ /* the color area event callbacks ******************************************/
@ -1218,16 +1219,23 @@ palette_dialog_eventbox_button_press (GtkWidget *widget,
GdkEventButton *bevent, GdkEventButton *bevent,
PaletteDialog *palette) PaletteDialog *palette)
{ {
if (gtk_get_event_widget ((GdkEvent *) bevent) == palette->color_area)
return FALSE;
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the small new menu */ if (GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
gtk_menu_popup (GTK_MENU (palette->popup_small_menu), {
NULL, NULL, gtk_widget_set_sensitive (palette->edit_menu_item, FALSE);
gtk_widget_set_sensitive (palette->delete_menu_item, FALSE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
bevent->time); bevent->time);
} }
return FALSE; return TRUE;
} }
static gint static gint
@ -1237,11 +1245,11 @@ palette_dialog_color_area_events (GtkWidget *widget,
{ {
GdkEventButton *bevent; GdkEventButton *bevent;
GSList *tmp_link; GSList *tmp_link;
int r, g, b; gint r, g, b;
int entry_width; gint entry_width;
int entry_height; gint entry_height;
int row, col; gint row, col;
int pos; gint pos;
switch (event->type) switch (event->type)
{ {
@ -1308,21 +1316,30 @@ palette_dialog_color_area_events (GtkWidget *widget,
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the edit menu */ if (! GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
{
gtk_widget_set_sensitive (palette->edit_menu_item, TRUE);
gtk_widget_set_sensitive (palette->delete_menu_item, TRUE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL, gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
((GdkEventButton *)event)->time); bevent->time);
} }
} }
else else
{ {
if (bevent->button == 3) if (bevent->button == 3)
{ {
/* Popup the small new menu */ if (GTK_WIDGET_SENSITIVE (palette->edit_menu_item))
gtk_menu_popup (GTK_MENU (palette->popup_small_menu), {
NULL, NULL, gtk_widget_set_sensitive (palette->edit_menu_item, FALSE);
gtk_widget_set_sensitive (palette->delete_menu_item, FALSE);
}
gtk_menu_popup (GTK_MENU (palette->popup_menu), NULL, NULL,
NULL, NULL, 3, NULL, NULL, 3,
((GdkEventButton *)event)->time); bevent->time);
} }
} }
} }