diff options
author | Lars Uebernickel <lars.uebernickel@canonical.com> | 2013-09-25 15:29:06 +0200 |
---|---|---|
committer | Lars Uebernickel <lars.uebernickel@canonical.com> | 2013-09-25 15:29:06 +0200 |
commit | 75cefbdeafc61cfd55d0247f10f6a9d4aa5dde71 (patch) | |
tree | 1755771fbb5d532331fdf4b49e7166fa0426b4ef /src | |
parent | b0de0c4939d42950bb61b356116f06a88080c0b6 (diff) | |
download | ayatana-indicator-messages-75cefbdeafc61cfd55d0247f10f6a9d4aa5dde71.tar.gz ayatana-indicator-messages-75cefbdeafc61cfd55d0247f10f6a9d4aa5dde71.tar.bz2 ayatana-indicator-messages-75cefbdeafc61cfd55d0247f10f6a9d4aa5dde71.zip |
phone menu: don't show "Clear All" when there are no messages
Diffstat (limited to 'src')
-rw-r--r-- | src/im-phone-menu.c | 54 |
1 files changed, 38 insertions, 16 deletions
diff --git a/src/im-phone-menu.c b/src/im-phone-menu.c index 0f0a6da..02c60d0 100644 --- a/src/im-phone-menu.c +++ b/src/im-phone-menu.c @@ -30,6 +30,7 @@ struct _ImPhoneMenu GMenu *message_section; GMenu *source_section; + GMenu *clear_section; }; G_DEFINE_TYPE (ImPhoneMenu, im_phone_menu, IM_TYPE_MENU); @@ -59,29 +60,40 @@ im_phone_menu_foreach_item_with_action (GMenuModel *menu, } static void -im_phone_menu_constructed (GObject *object) +im_phone_menu_update_clear_section (ImPhoneMenu *menu) { - ImPhoneMenu *menu = IM_PHONE_MENU (object); - ImApplicationList *applist; + gboolean is_shown; + gboolean should_be_shown; - im_menu_append_section (IM_MENU (menu), G_MENU_MODEL (menu->message_section)); - im_menu_append_section (IM_MENU (menu), G_MENU_MODEL (menu->source_section)); + is_shown = g_menu_model_get_n_items (G_MENU_MODEL (menu->clear_section)) > 0; + should_be_shown = (g_menu_model_get_n_items (G_MENU_MODEL (menu->message_section)) + + g_menu_model_get_n_items (G_MENU_MODEL (menu->source_section))) > 0; - { - GMenu *clear_section; - GMenuItem *item; + if (!is_shown && should_be_shown) + { + GMenuItem *item; - clear_section = g_menu_new (); + item = g_menu_item_new (_("Clear All"), "indicator.remove-all"); + g_menu_item_set_attribute (item, "x-canonical-type", "s", "com.canonical.indicator.button"); + g_menu_append_item (menu->clear_section, item); - item = g_menu_item_new (_("Clear All"), "remove-all"); - g_menu_item_set_attribute (item, "x-canonical-type", "s", "com.canonical.indicator.button"); - g_menu_append_item (clear_section, item); + g_object_unref (item); + } + else if (is_shown && !should_be_shown) + { + g_menu_remove (menu->clear_section, 0); + } +} - im_menu_append_section (IM_MENU (menu), G_MENU_MODEL (clear_section)); +static void +im_phone_menu_constructed (GObject *object) +{ + ImPhoneMenu *menu = IM_PHONE_MENU (object); + ImApplicationList *applist; - g_object_unref (item); - g_object_unref (clear_section); - } + im_menu_append_section (IM_MENU (menu), G_MENU_MODEL (menu->message_section)); + im_menu_append_section (IM_MENU (menu), G_MENU_MODEL (menu->source_section)); + im_menu_append_section (IM_MENU (menu), G_MENU_MODEL (menu->clear_section)); applist = im_menu_get_application_list (IM_MENU (menu)); @@ -100,6 +112,7 @@ im_phone_menu_dispose (GObject *object) g_clear_object (&menu->message_section); g_clear_object (&menu->source_section); + g_clear_object (&menu->clear_section); G_OBJECT_CLASS (im_phone_menu_parent_class)->dispose (object); } @@ -125,6 +138,7 @@ im_phone_menu_init (ImPhoneMenu *menu) { menu->message_section = g_menu_new (); menu->source_section = g_menu_new (); + menu->clear_section = g_menu_new (); } ImPhoneMenu * @@ -200,6 +214,8 @@ im_phone_menu_add_message (ImPhoneMenu *menu, g_menu_insert_item (menu->message_section, pos, item); + im_phone_menu_update_clear_section (menu); + g_free (action_name); g_object_unref (item); } @@ -219,6 +235,8 @@ im_phone_menu_remove_message (ImPhoneMenu *menu, action_name, (ImMenuForeachFunc) g_menu_remove); + im_phone_menu_update_clear_section (menu); + g_free (action_name); } @@ -309,6 +327,8 @@ im_phone_menu_remove_application (ImPhoneMenu *menu, im_phone_menu_remove_all_for_app (menu->source_section, app_id); im_phone_menu_remove_all_for_app (menu->message_section, app_id); + + im_phone_menu_update_clear_section (menu); } void @@ -321,4 +341,6 @@ im_phone_menu_remove_all (ImPhoneMenu *menu) while (g_menu_model_get_n_items (G_MENU_MODEL (menu->source_section))) g_menu_remove (menu->source_section, 0); + + im_phone_menu_update_clear_section (menu); } |