aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLars Uebernickel <lars.uebernickel@canonical.com>2014-04-07 11:48:50 +0200
committerLars Uebernickel <lars.uebernickel@canonical.com>2014-04-07 11:48:50 +0200
commitfc6ee128cb49aaa96d433442d326db4c6141d48d (patch)
tree399ab8bfcc46254eec33ffd9b9a6ab2b1657b3ec
parent67c7bc304d79f9cd61370430de172acb6a2f7834 (diff)
downloadayatana-indicator-messages-fc6ee128cb49aaa96d433442d326db4c6141d48d.tar.gz
ayatana-indicator-messages-fc6ee128cb49aaa96d433442d326db4c6141d48d.tar.bz2
ayatana-indicator-messages-fc6ee128cb49aaa96d433442d326db4c6141d48d.zip
desktop menu: don't show status section when no apps supports it
-rw-r--r--src/im-desktop-menu.c94
-rw-r--r--src/im-menu.c14
-rw-r--r--src/im-menu.h3
3 files changed, 62 insertions, 49 deletions
diff --git a/src/im-desktop-menu.c b/src/im-desktop-menu.c
index 11e3d41..bfae137 100644
--- a/src/im-desktop-menu.c
+++ b/src/im-desktop-menu.c
@@ -27,12 +27,54 @@ struct _ImDesktopMenu
{
ImMenu parent;
+ gboolean status_section_visible;
GHashTable *source_sections;
};
G_DEFINE_TYPE (ImDesktopMenu, im_desktop_menu, IM_TYPE_MENU);
static void
+menu_append_status (GMenu *menu,
+ const gchar *label,
+ const gchar *detailed_action,
+ const gchar *icon_name)
+{
+ GMenuItem *item;
+ GIcon *icon;
+
+ icon = g_themed_icon_new (icon_name);
+
+ item = g_menu_item_new (label, detailed_action);
+ g_menu_item_set_icon (item, icon);
+ g_menu_append_item (menu, item);
+
+ g_object_unref (icon);
+ g_object_unref (item);
+}
+
+static void
+im_desktop_menu_show_chat_section (ImDesktopMenu *menu)
+{
+ GMenu *status_section;
+
+ if (menu->status_section_visible)
+ return;
+
+ status_section = g_menu_new ();
+
+ menu_append_status (status_section, _("Available"), "indicator.status::available", "user-available");
+ menu_append_status (status_section, _("Away"), "indicator.status::away", "user-away");
+ menu_append_status (status_section, _("Busy"), "indicator.status::busy", "user-busy");
+ menu_append_status (status_section, _("Invisible"), "indicator.status::invisible", "user-invisible");
+ menu_append_status (status_section, _("Offline"), "indicator.status::offline", "user-offline");
+
+ im_menu_prepend_section (IM_MENU (menu), G_MENU_MODEL (status_section));
+ menu->status_section_visible = TRUE;
+
+ g_object_unref (status_section);
+}
+
+static void
im_desktop_menu_app_added (ImApplicationList *applist,
const gchar *app_id,
GDesktopAppInfo *app_info,
@@ -94,6 +136,9 @@ im_desktop_menu_app_added (ImApplicationList *applist,
g_clear_object(&shortcuts);
}
+ if (g_desktop_app_info_get_boolean (app_info, "X-MessagingMenu-UsesChatSection"))
+ im_desktop_menu_show_chat_section (menu);
+
source_section = g_menu_new ();
section = g_menu_new ();
@@ -261,46 +306,6 @@ im_desktop_menu_app_stopped (ImApplicationList *applist,
g_menu_remove (section, 0);
}
-static GMenu *
-create_status_section (void)
-{
- GMenu *menu;
- GMenuItem *item;
- struct status_item {
- gchar *label;
- gchar *action;
- gchar *icon_name;
- } status_items[] = {
- { _("Available"), "indicator.status::available", "user-available" },
- { _("Away"), "indicator.status::away", "user-away" },
- { _("Busy"), "indicator.status::busy", "user-busy" },
- { _("Invisible"), "indicator.status::invisible", "user-invisible" },
- { _("Offline"), "indicator.status::offline", "user-offline" }
- };
- int i;
-
- menu = g_menu_new ();
-
- item = g_menu_item_new (NULL, NULL);
-
- for (i = 0; i < G_N_ELEMENTS (status_items); i++) {
- GIcon *icon;
-
- g_menu_item_set_label (item, status_items[i].label);
- g_menu_item_set_detailed_action (item, status_items[i].action);
-
- icon = g_themed_icon_new (status_items[i].icon_name);
- g_menu_item_set_icon (item, icon);
-
- g_menu_append_item (menu, item);
-
- g_object_unref (icon);
- }
-
- g_object_unref (item);
- return menu;
-}
-
static void
im_desktop_menu_constructed (GObject *object)
{
@@ -308,15 +313,6 @@ im_desktop_menu_constructed (GObject *object)
ImApplicationList *applist;
{
- GMenu *status_section;
-
- status_section = create_status_section();
- im_menu_append_section (IM_MENU (menu), G_MENU_MODEL (status_section));
-
- g_object_unref (status_section);
- }
-
- {
GMenu *clear_section;
clear_section = g_menu_new ();
diff --git a/src/im-menu.c b/src/im-menu.c
index 55ea99c..57cf957 100644
--- a/src/im-menu.c
+++ b/src/im-menu.c
@@ -149,6 +149,20 @@ im_menu_export (ImMenu *menu,
}
void
+im_menu_prepend_section (ImMenu *menu,
+ GMenuModel *section)
+{
+ ImMenuPrivate *priv;
+
+ g_return_if_fail (IM_IS_MENU (menu));
+ g_return_if_fail (G_IS_MENU_MODEL (section));
+
+ priv = im_menu_get_instance_private (menu);
+
+ g_menu_prepend_section (priv->menu, NULL, section);
+}
+
+void
im_menu_append_section (ImMenu *menu,
GMenuModel *section)
{
diff --git a/src/im-menu.h b/src/im-menu.h
index 7c15eb7..57815b5 100644
--- a/src/im-menu.h
+++ b/src/im-menu.h
@@ -53,6 +53,9 @@ gboolean im_menu_export (ImMenu
const gchar *object_path,
GError **error);
+void im_menu_prepend_section (ImMenu *menu,
+ GMenuModel *section);
+
void im_menu_append_section (ImMenu *menu,
GMenuModel *section);