/* -*- Mode: Vala; indent-tabs-mode: nil; tab-width: 4 -*- * * Copyright (C) 2012 Canonical Ltd * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License version 3 as * published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * * Authors: Michael Terry */ public class SessionPrompt : PromptBox { public string session { get; construct; } public string default_session { get; construct; } public SessionPrompt (string id, string? session, string? default_session) { Object (id: id, session: session, default_session: default_session); } private ToggleBox box; construct { label = _("Select desktop environment"); name_label.vexpand = false; box = new ToggleBox (default_session, session); if (UnityGreeter.singleton.test_mode) { box.add_item ("gnome", "GNOME", SessionList.get_badge ("gnome")); box.add_item ("kde", "KDE", SessionList.get_badge ("kde")); box.add_item ("ubuntu", "Ubuntu", SessionList.get_badge ("ubuntu")); } else { foreach (var session in LightDM.get_sessions ()) { debug ("Adding session %s (%s)", session.key, session.name); box.add_item (session.key, session.name, SessionList.get_badge (session.key)); } } box.notify["selected-key"].connect (selected_cb); box.show (); attach_item (box); } private void selected_cb () { respond ({ box.selected_key }); } } public class SessionList : GreeterList { public signal void session_clicked (string session); public string session { get; construct; } public string default_session { get; construct; } private SessionPrompt prompt; public SessionList (Background bg, MenuBar mb, string? session, string? default_session) { Object (background: bg, menubar: mb, session: session, default_session: default_session); } construct { prompt = add_session_prompt ("session"); } private SessionPrompt add_session_prompt (string id) { var e = new SessionPrompt (id, session, default_session); e.respond.connect ((responses) => { session_clicked (responses[0]); }); add_entry (e); return e; } protected override void add_manual_entry () {} public override void show_authenticated (bool successful = true) {} private static string? get_badge_name (string session) { switch (session) { case "ubuntu": case "ubuntu-2d": return "ubuntu_badge.png"; case "gnome-classic": case "gnome-flashback-compiz": case "gnome-flashback-metacity": case "gnome-shell": case "gnome-wayland": case "gnome": return "gnome_badge.png"; case "kde": case "kde-plasma": case "plasma": return "kde_badge.png"; case "xterm": return "recovery_console_badge.png"; case "remote-login": return "remote_login_help.png"; default: return null; } } private static HashTable badges; /* cache of badges */ public static Gdk.Pixbuf? get_badge (string session) { var name = get_badge_name (session); if (name == null) { /* Not a known name, but let's see if we have a custom badge before giving up entirely and using the unknown badget. */ var maybe_name = "custom_%s_badge.png".printf (session); var maybe_path = Path.build_filename (Config.PKGDATADIR, maybe_name, null); if (FileUtils.test (maybe_path, FileTest.EXISTS)) name = maybe_name; else name = "unknown_badge.png"; } if (badges == null) badges = new HashTable (str_hash, str_equal); var pixbuf = badges.lookup (name); if (pixbuf == null) { try { pixbuf = new Gdk.Pixbuf.from_file (Path.build_filename (Config.PKGDATADIR, name, null)); badges.insert (name, pixbuf); } catch (Error e) { debug ("Error loading badge %s: %s", name, e.message); } } return pixbuf; } }