]> git.0d.be Git - empathy.git/blobdiff - libempathy-gtk/empathy-status-preset-dialog.c
sort contacts by most recent event
[empathy.git] / libempathy-gtk / empathy-status-preset-dialog.c
index 562b9e4d9c37346dfc401e4d65c1f151eefc51a6..f487b8cc10ee70c6839ea9cc957b678454e439af 100644 (file)
  *
  * You should have received a copy of the GNU General Public
  * License along with this program; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
+ * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
+ * Boston, MA  02110-1301  USA
  *
- * Authors: Davyd Madeley <davyd.madeley@collabora.co.uk>
+ * Authors: Danielle Madeley <danielle.madeley@collabora.co.uk>
+ */
+/**
+ * SECTION:empathy-status-preset-dialog
+ * @title: EmpathyStatusPresetDialog
+ * @short_description: a dialog for editing the saved status messages
+ * @include: libempathy-gtk/empathy-status-preset-dialog.h
+ *
+ * #EmpathyStatusPresetDialog is a dialog allowing the user to add/remove/edit
+ * their saved status messages.
  */
 
 #include "config.h"
+#include "empathy-status-preset-dialog.h"
 
 #include <glib/gi18n-lib.h>
-#include <gtk/gtk.h>
+#include <tp-account-widgets/tpaw-builder.h>
 
-#include <libmissioncontrol/mc-enum-types.h>
-
-#include <libempathy/empathy-utils.h>
-#include <libempathy/empathy-status-presets.h>
+#include "empathy-status-presets.h"
+#include "empathy-ui-utils.h"
+#include "empathy-utils.h"
 
 #define DEBUG_FLAG EMPATHY_DEBUG_OTHER
-#include <libempathy/empathy-debug.h>
-
-#include "empathy-ui-utils.h"
-#include "empathy-status-preset-dialog.h"
+#include "empathy-debug.h"
 
 #define GET_PRIV(obj) EMPATHY_GET_PRIV (obj, EmpathyStatusPresetDialog)
 
 G_DEFINE_TYPE (EmpathyStatusPresetDialog, empathy_status_preset_dialog, GTK_TYPE_DIALOG);
 
-static McPresence states[] = {
-       MC_PRESENCE_AVAILABLE,
-       MC_PRESENCE_DO_NOT_DISTURB,
-       MC_PRESENCE_AWAY
+static TpConnectionPresenceType states[] = {
+       TP_CONNECTION_PRESENCE_TYPE_AVAILABLE,
+       TP_CONNECTION_PRESENCE_TYPE_BUSY,
+       TP_CONNECTION_PRESENCE_TYPE_AWAY,
 };
 
 typedef struct _EmpathyStatusPresetDialogPriv EmpathyStatusPresetDialogPriv;
 struct _EmpathyStatusPresetDialogPriv
 {
+       /* block status_preset_dialog_add_combo_changed () when > 0 */
        int block_add_combo_changed;
 
        GtkWidget *presets_treeview;
-       GtkWidget *add_combobox;
-       GtkWidget *add_button;
+       GtkTreeViewColumn *column;
+       GtkCellRenderer *text_cell;
 
        GtkTreeIter selected_iter;
        gboolean add_combo_changed;
+       char *saved_status;
 };
 
 enum
@@ -81,12 +89,23 @@ enum
        ADD_COMBO_N_COLS
 };
 
+static void
+empathy_status_preset_dialog_finalize (GObject *self)
+{
+       EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
+
+       g_free (priv->saved_status);
+
+       G_OBJECT_CLASS (empathy_status_preset_dialog_parent_class)->finalize (self);
+}
+
 static void
 empathy_status_preset_dialog_class_init (EmpathyStatusPresetDialogClass *class)
 {
        GObjectClass *gobject_class;
 
        gobject_class = G_OBJECT_CLASS (class);
+       gobject_class->finalize = empathy_status_preset_dialog_finalize;
 
        g_type_class_add_private (gobject_class,
                        sizeof (EmpathyStatusPresetDialogPriv));
@@ -97,7 +116,7 @@ status_preset_dialog_presets_update (EmpathyStatusPresetDialog *self)
 {
        EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
        GtkListStore *store;
-       int i;
+       guint i;
 
        store = GTK_LIST_STORE (gtk_tree_view_get_model (
                                GTK_TREE_VIEW (priv->presets_treeview)));
@@ -108,8 +127,9 @@ status_preset_dialog_presets_update (EmpathyStatusPresetDialog *self)
                GList *presets, *l;
                const char *icon_name;
 
-               presets = empathy_status_presets_get (states[i], -1);
                icon_name = empathy_icon_name_for_presence (states[i]);
+               presets = empathy_status_presets_get (states[i], -1);
+               presets = g_list_sort (presets, (GCompareFunc) g_utf8_collate);
 
                for (l = presets; l; l = l->next) {
                        char *preset = (char *) l->data;
@@ -126,65 +146,6 @@ status_preset_dialog_presets_update (EmpathyStatusPresetDialog *self)
        }
 }
 
-static void
-status_preset_add_combo_reset (EmpathyStatusPresetDialog *self)
-{
-       EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
-
-       gtk_combo_box_set_active_iter (GTK_COMBO_BOX (priv->add_combobox),
-                       &priv->selected_iter);
-}
-
-static void
-status_preset_dialog_setup_add_combobox (EmpathyStatusPresetDialog *self)
-{
-       EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
-       GtkWidget *combobox = priv->add_combobox;
-       GtkListStore *store;
-       GtkCellRenderer *renderer;
-       int i;
-
-       store = gtk_list_store_new (ADD_COMBO_N_COLS,
-                       MC_TYPE_PRESENCE,       /* ADD_COMBO_STATE */
-                       G_TYPE_STRING,          /* ADD_COMBO_ICON_NAME */
-                       G_TYPE_STRING,          /* ADD_COMBO_STATUS */
-                       G_TYPE_STRING);         /* ADD_COMBO_DEFAULT_TEXT */
-
-       gtk_combo_box_set_model (GTK_COMBO_BOX (combobox),
-                                GTK_TREE_MODEL (store));
-       g_object_unref (store);
-
-       gtk_combo_box_entry_set_text_column (GTK_COMBO_BOX_ENTRY (combobox),
-                       ADD_COMBO_DEFAULT_TEXT);
-
-       for (i = 0; i < G_N_ELEMENTS (states); i++) {
-               gtk_list_store_insert_with_values (store, NULL, -1,
-                               ADD_COMBO_STATE, states[i],
-                               ADD_COMBO_ICON_NAME, empathy_icon_name_for_presence (states[i]),
-                               ADD_COMBO_STATUS, empathy_presence_get_default_message (states[i]),
-                               ADD_COMBO_DEFAULT_TEXT, "",
-                               -1);
-       }
-
-       gtk_cell_layout_clear (GTK_CELL_LAYOUT (combobox));
-
-       renderer = gtk_cell_renderer_pixbuf_new ();
-       gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (combobox), renderer, FALSE);
-       gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (combobox), renderer,
-                       "icon-name", ADD_COMBO_ICON_NAME);
-
-       renderer = gtk_cell_renderer_text_new ();
-       gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (combobox), renderer, TRUE);
-       gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (combobox), renderer,
-                       "text", ADD_COMBO_STATUS);
-       g_object_set (renderer,
-                       "style", PANGO_STYLE_ITALIC,
-                       "foreground", "Gray", /* FIXME - theme */
-                       NULL);
-
-       gtk_combo_box_set_active (GTK_COMBO_BOX (combobox), 0);
-}
-
 static void
 status_preset_dialog_status_edited (GtkCellRendererText *renderer,
                                    char *path_str,
@@ -195,7 +156,7 @@ status_preset_dialog_status_edited (GtkCellRendererText *renderer,
        GtkTreeModel *model;
        GtkTreePath *path;
        GtkTreeIter iter;
-       McPresence state;
+       TpConnectionPresenceType state;
        char *old_status;
        gboolean valid;
 
@@ -242,7 +203,7 @@ status_preset_dialog_setup_presets_treeview (EmpathyStatusPresetDialog *self)
        GtkCellRenderer *renderer;
 
        store = gtk_list_store_new (PRESETS_STORE_N_COLS,
-                       MC_TYPE_PRESENCE,       /* PRESETS_STORE_STATE */
+                       G_TYPE_UINT,            /* PRESETS_STORE_STATE */
                        G_TYPE_STRING,          /* PRESETS_STORE_ICON_NAME */
                        G_TYPE_STRING);         /* PRESETS_STORE_STATUS */
 
@@ -253,6 +214,7 @@ status_preset_dialog_setup_presets_treeview (EmpathyStatusPresetDialog *self)
        status_preset_dialog_presets_update (self);
 
        column = gtk_tree_view_column_new ();
+       priv->column = column;
        gtk_tree_view_append_column (GTK_TREE_VIEW (treeview), column);
 
        renderer = gtk_cell_renderer_pixbuf_new ();
@@ -261,12 +223,15 @@ status_preset_dialog_setup_presets_treeview (EmpathyStatusPresetDialog *self)
                        "icon-name", PRESETS_STORE_ICON_NAME);
 
        renderer = gtk_cell_renderer_text_new ();
+       priv->text_cell = renderer;
        gtk_tree_view_column_pack_start (column, renderer, TRUE);
        gtk_tree_view_column_add_attribute (column, renderer,
                        "text", PRESETS_STORE_STATUS);
        g_object_set (renderer,
                        "editable", TRUE,
                        NULL);
+       g_object_set (renderer, "ellipsize", PANGO_ELLIPSIZE_END, NULL);
+
        g_signal_connect (renderer, "edited",
                        G_CALLBACK (status_preset_dialog_status_edited), self);
 }
@@ -277,27 +242,19 @@ status_preset_dialog_preset_selection_changed (GtkTreeSelection *selection,
 {
        /* update the sensitivity of the Remove button */
        gtk_widget_set_sensitive (remove_button,
-                       gtk_tree_selection_get_selected (selection, NULL, NULL));
+                       gtk_tree_selection_count_selected_rows (selection) != 0);
 }
 
 static void
-status_preset_dialog_preset_remove (GtkButton *button,
-                                   EmpathyStatusPresetDialog *self)
+foreach_removed_status (GtkTreeModel *model,
+                       GtkTreePath *path,
+                       GtkTreeIter *iter,
+                       gpointer data)
 {
-       EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
-       GtkTreeSelection *selection;
-       GtkTreeModel *model;
-       GtkTreeIter iter;
-       McPresence state;
+       TpConnectionPresenceType state;
        char *status;
 
-       selection = gtk_tree_view_get_selection (
-                       GTK_TREE_VIEW (priv->presets_treeview));
-
-       g_return_if_fail (gtk_tree_selection_get_selected (selection,
-                               &model, &iter));
-
-       gtk_tree_model_get (model, &iter,
+       gtk_tree_model_get (model, iter,
                        PRESETS_STORE_STATE, &state,
                        PRESETS_STORE_STATUS, &status,
                        -1);
@@ -306,137 +263,19 @@ status_preset_dialog_preset_remove (GtkButton *button,
        empathy_status_presets_remove (state, status);
 
        g_free (status);
-
-       status_preset_dialog_presets_update (self);
-}
-
-static void
-status_preset_dialog_set_add_combo_changed (EmpathyStatusPresetDialog *self,
-                                           gboolean state,
-                                           gboolean reset_text)
-{
-       EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
-       GtkWidget *entry;
-
-       entry = gtk_bin_get_child (GTK_BIN (priv->add_combobox));
-
-       priv->add_combo_changed = state;
-       gtk_widget_set_sensitive (priv->add_button, state);
-
-       if (state) {
-               gtk_widget_modify_text (entry, GTK_STATE_NORMAL, NULL);
-       } else {
-               GdkColor colour;
-
-               gdk_color_parse ("Gray", &colour); /* FIXME - theme */
-               gtk_widget_modify_text (entry, GTK_STATE_NORMAL, &colour);
-
-               if (reset_text) {
-                       priv->block_add_combo_changed++;
-                       gtk_entry_set_text (GTK_ENTRY (entry),
-                                       _("Enter Custom Message"));
-                       priv->block_add_combo_changed--;
-               }
-       }
 }
 
 static void
-status_preset_dialog_add_combo_changed (GtkComboBox *combo,
-                                       EmpathyStatusPresetDialog *self)
-{
-       EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
-       GtkWidget *entry;
-       GtkTreeModel *model;
-       GtkTreeIter iter;
-
-       if (priv->block_add_combo_changed) return;
-
-       model = gtk_combo_box_get_model (combo);
-       entry = gtk_bin_get_child (GTK_BIN (combo));
-
-       if (gtk_combo_box_get_active_iter (combo, &iter)) {
-               char *icon_name;
-
-               priv->selected_iter = iter;
-               gtk_tree_model_get (model, &iter,
-                               PRESETS_STORE_ICON_NAME, &icon_name,
-                               -1);
-
-               gtk_entry_set_icon_from_icon_name (GTK_ENTRY (entry),
-                               GTK_ENTRY_ICON_PRIMARY,
-                               icon_name);
-
-               g_free (icon_name);
-
-               status_preset_dialog_set_add_combo_changed (self, FALSE, TRUE);
-       } else {
-               const char *status;
-
-               status = gtk_entry_get_text (GTK_ENTRY (entry));
-               status_preset_dialog_set_add_combo_changed (self,
-                               strlen (status) > 0, FALSE);
-       }
-}
-
-static void
-status_preset_dialog_add_preset (GtkWidget *widget,
-                                EmpathyStatusPresetDialog *self)
+status_preset_dialog_preset_remove (GtkButton *button,
+                                   EmpathyStatusPresetDialog *self)
 {
        EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
-       GtkTreeModel *model;
-       GtkWidget *entry;
-       McPresence state;
-       const char *status;
-
-       g_return_if_fail (priv->add_combo_changed);
-
-       model = gtk_combo_box_get_model (GTK_COMBO_BOX (priv->add_combobox));
-       entry = gtk_bin_get_child (GTK_BIN (priv->add_combobox));
-
-       status = gtk_entry_get_text (GTK_ENTRY (entry));
-       gtk_tree_model_get (model, &priv->selected_iter,
-                       PRESETS_STORE_STATE, &state,
-                       -1);
-
-       DEBUG ("ADD PRESET (%i, %s)\n", state, status);
-       empathy_status_presets_set_last (state, status);
+       GtkTreeSelection *selection;
 
+       selection = gtk_tree_view_get_selection (
+                       GTK_TREE_VIEW (priv->presets_treeview));
+       gtk_tree_selection_selected_foreach (selection, foreach_removed_status, NULL);
        status_preset_dialog_presets_update (self);
-       status_preset_add_combo_reset (self);
-}
-
-static gboolean
-status_preset_dialog_add_combo_press_event (GtkWidget *widget,
-                                           GdkEventButton *event,
-                                           EmpathyStatusPresetDialog *self)
-{
-       if (!GTK_WIDGET_HAS_FOCUS (widget)) {
-               /* if the widget isn't focused, focus it and select the text */
-               gtk_widget_grab_focus (widget);
-               gtk_editable_select_region (GTK_EDITABLE (widget), 0, -1);
-
-               return TRUE;
-       }
-
-       return FALSE;
-}
-
-static gboolean
-status_preset_dialog_add_combo_focus_out (GtkWidget *widget,
-                                         GdkEventFocus *event,
-                                         EmpathyStatusPresetDialog *self)
-{
-       EmpathyStatusPresetDialogPriv *priv = GET_PRIV (self);
-       const char *status;
-
-       gtk_editable_set_position (GTK_EDITABLE (widget), 0);
-
-       status = gtk_entry_get_text (GTK_ENTRY (widget));
-       status_preset_dialog_set_add_combo_changed (self,
-                       priv->add_combo_changed && strlen (status) > 0,
-                       TRUE);
-
-       return FALSE;
 }
 
 static void
@@ -447,53 +286,50 @@ empathy_status_preset_dialog_init (EmpathyStatusPresetDialog *self)
                        EMPATHY_TYPE_STATUS_PRESET_DIALOG,
                        EmpathyStatusPresetDialogPriv);
        GtkBuilder *gui;
-       GtkWidget *toplevel_vbox, *remove_button, *entry;
+       GtkWidget *toplevel_vbox, *presets_sw, *remove_toolbar, *remove_button;
+       GtkTreeSelection *selection;
        char *filename;
+       GtkStyleContext *context;
 
        gtk_window_set_title (GTK_WINDOW (self),
                        _("Edit Custom Messages"));
-       gtk_dialog_set_has_separator (GTK_DIALOG (self), FALSE);
        gtk_dialog_add_button (GTK_DIALOG (self),
                        GTK_STOCK_CLOSE, GTK_RESPONSE_CLOSE);
+       gtk_window_set_resizable (GTK_WINDOW (self), FALSE);
 
        filename = empathy_file_lookup ("empathy-status-preset-dialog.ui",
                        "libempathy-gtk");
-       gui = empathy_builder_get_file (filename,
+       gui = tpaw_builder_get_file (filename,
                        "toplevel-vbox", &toplevel_vbox,
+                       "presets-sw", &presets_sw,
                        "presets-treeview", &priv->presets_treeview,
+                       "remove-toolbar", &remove_toolbar,
                        "remove-button", &remove_button,
-                       "add-combobox", &priv->add_combobox,
-                       "add-button", &priv->add_button,
                        NULL);
        g_free (filename);
 
-       g_signal_connect (gtk_tree_view_get_selection (
-                               GTK_TREE_VIEW (priv->presets_treeview)),
+       /* join the remove toolbar to the treeview */
+       context = gtk_widget_get_style_context (presets_sw);
+       gtk_style_context_set_junction_sides (context, GTK_JUNCTION_BOTTOM);
+       context = gtk_widget_get_style_context (remove_toolbar);
+       gtk_style_context_set_junction_sides (context, GTK_JUNCTION_TOP);
+
+       selection = gtk_tree_view_get_selection (
+               GTK_TREE_VIEW (priv->presets_treeview));
+       g_signal_connect (selection,
                        "changed",
                        G_CALLBACK (status_preset_dialog_preset_selection_changed),
                        remove_button);
+       gtk_tree_selection_set_mode (selection, GTK_SELECTION_MULTIPLE);
 
-       entry = gtk_bin_get_child (GTK_BIN (priv->add_combobox));
-       g_signal_connect (entry, "activate",
-                       G_CALLBACK (status_preset_dialog_add_preset), self);
-       g_signal_connect (entry, "button-press-event",
-                       G_CALLBACK (status_preset_dialog_add_combo_press_event),
-                       self);
-       g_signal_connect (entry, "focus-out-event",
-                       G_CALLBACK (status_preset_dialog_add_combo_focus_out),
-                       self);
-
-       empathy_builder_connect (gui, self,
+       tpaw_builder_connect (gui, self,
                        "remove-button", "clicked", status_preset_dialog_preset_remove,
-                       "add-combobox", "changed", status_preset_dialog_add_combo_changed,
-                       "add-button", "clicked", status_preset_dialog_add_preset,
                        NULL);
 
        status_preset_dialog_setup_presets_treeview (self);
-       status_preset_dialog_setup_add_combobox (self);
 
-       gtk_box_pack_start(GTK_BOX (GTK_DIALOG (self)->vbox), toplevel_vbox,
-                       TRUE, TRUE, 0);
+       gtk_box_pack_start (GTK_BOX (gtk_dialog_get_content_area (GTK_DIALOG (self))),
+           toplevel_vbox, TRUE, TRUE, 0);
 
        g_object_unref (gui);
 }