aboutsummaryrefslogtreecommitdiff
path: root/src/service.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/service.c')
-rw-r--r--src/service.c45
1 files changed, 36 insertions, 9 deletions
diff --git a/src/service.c b/src/service.c
index 2bccaae..b65079f 100644
--- a/src/service.c
+++ b/src/service.c
@@ -58,7 +58,8 @@ enum
SECTION_ADMIN = (1<<1),
SECTION_SETTINGS = (1<<2),
SECTION_SWITCH = (1<<3),
- SECTION_SESSION = (1<<4)
+ SECTION_LOGOUT = (1<<4),
+ SECTION_SESSION = (1<<5)
};
enum
@@ -133,6 +134,11 @@ rebuild_switch_section_soon (IndicatorSessionService * self)
rebuild_soon (self, SECTION_SWITCH);
}
static inline void
+rebuild_logout_section_soon (IndicatorSessionService * self)
+{
+ rebuild_soon (self, SECTION_LOGOUT);
+}
+static inline void
rebuild_session_section_soon (IndicatorSessionService * self)
{
rebuild_soon (self, SECTION_SESSION);
@@ -569,22 +575,33 @@ create_switch_section (IndicatorSessionService * self)
}
static GMenuModel *
-create_session_section (IndicatorSessionService * self, int profile)
+create_logout_section (IndicatorSessionService * self)
{
GMenu * menu;
const priv_t * const p = self->priv;
- GSettings * const s = p->indicator_settings;
const gboolean ellipsis = use_ellipsis (self);
menu = g_menu_new ();
- if ((profile == PROFILE_DESKTOP) &&
- (indicator_session_actions_can_logout (p->backend_actions)))
+ if (indicator_session_actions_can_logout (p->backend_actions))
{
const char * label = ellipsis ? _("Log Out…") : _("Log Out");
g_menu_append (menu, label, "indicator.logout");
}
+ return G_MENU_MODEL (menu);
+}
+
+static GMenuModel *
+create_session_section (IndicatorSessionService * self)
+{
+ GMenu * menu;
+ const priv_t * const p = self->priv;
+ GSettings * const s = p->indicator_settings;
+ const gboolean ellipsis = use_ellipsis (self);
+
+ menu = g_menu_new ();
+
if (indicator_session_actions_can_suspend (p->backend_actions))
g_menu_append (menu, _("Suspend"), "indicator.suspend");
@@ -624,11 +641,12 @@ create_menu (IndicatorSessionService * self, int profile)
sections[n++] = create_admin_section ();
sections[n++] = create_settings_section (self);
sections[n++] = create_switch_section (self);
- sections[n++] = create_session_section (self, profile);
+ sections[n++] = create_logout_section (self);
+ sections[n++] = create_session_section (self);
}
else if (profile == PROFILE_GREETER)
{
- sections[n++] = create_session_section (self, profile);
+ sections[n++] = create_session_section (self);
}
/* add sections to the submenu */
@@ -866,10 +884,15 @@ rebuild_now (IndicatorSessionService * self, int sections)
update_switch_actions (self);
}
+ if (sections & SECTION_LOGOUT)
+ {
+ rebuild_section (desktop->submenu, 3, create_logout_section(self));
+ }
+
if (sections & SECTION_SESSION)
{
- rebuild_section (desktop->submenu, 3, create_session_section(self, PROFILE_DESKTOP));
- rebuild_section (greeter->submenu, 0, create_session_section(self, PROFILE_GREETER));
+ rebuild_section (desktop->submenu, 4, create_session_section(self));
+ rebuild_section (greeter->submenu, 0, create_session_section(self));
}
}
@@ -1076,6 +1099,8 @@ indicator_session_service_init (IndicatorSessionService * self)
g_signal_connect_swapped (gp, "notify",
G_CALLBACK(rebuild_switch_section_soon), self);
g_signal_connect_swapped (gp, "notify",
+ G_CALLBACK(rebuild_logout_section_soon), self);
+ g_signal_connect_swapped (gp, "notify",
G_CALLBACK(rebuild_session_section_soon), self);
g_signal_connect_swapped (gp, "notify::has-online-account-error",
G_CALLBACK(rebuild_header_soon), self);
@@ -1087,6 +1112,8 @@ indicator_session_service_init (IndicatorSessionService * self)
g_signal_connect_swapped (gp, "changed::suppress-logout-restart-shutdown",
G_CALLBACK(rebuild_switch_section_soon), self);
g_signal_connect_swapped (gp, "changed::suppress-logout-restart-shutdown",
+ G_CALLBACK(rebuild_logout_section_soon), self);
+ g_signal_connect_swapped (gp, "changed::suppress-logout-restart-shutdown",
G_CALLBACK(rebuild_session_section_soon), self);
g_signal_connect_swapped (gp, "changed::suppress-shutdown-menuitem",
G_CALLBACK(rebuild_session_section_soon), self);