gnome: adapt to LRC api to update frequent contacts

Requires change: https://gerrit-ring.savoirfairelinux.com/#/c/2002/

Refs #73492

Change-Id: Iab798dffabf65370b210c24a51b3b1554ff2700e
diff --git a/src/frequentcontactsview.cpp b/src/frequentcontactsview.cpp
index 59f9d1b..8e595fa 100644
--- a/src/frequentcontactsview.cpp
+++ b/src/frequentcontactsview.cpp
@@ -38,7 +38,7 @@
 #include <contactmethod.h>
 #include "defines.h"
 #include "utils/models.h"
-#include <categorizedbookmarkmodel.h>
+#include <phonedirectorymodel.h>
 #include <call.h>
 
 #define COPY_DATA_KEY "copy_data"
@@ -77,27 +77,21 @@
 static void
 render_contact_photo(G_GNUC_UNUSED GtkTreeViewColumn *tree_column,
                      GtkCellRenderer *cell,
-                     GtkTreeModel *filter_model,
-                     GtkTreeIter *filter_iter,
+                     GtkTreeModel *model,
+                     GtkTreeIter *iter,
                      G_GNUC_UNUSED gpointer data)
 {
-    /* convert to original model */
-    GtkTreeIter iter;
-    GtkTreeModel *model = gtk_tree_model_filter_get_model(GTK_TREE_MODEL_FILTER(filter_model));
-    gtk_tree_model_filter_convert_iter_to_child_iter(
-        GTK_TREE_MODEL_FILTER(filter_model),
-        &iter,
-        filter_iter);
-
     /* get contact method */
-    QModelIndex idx = gtk_q_tree_model_get_source_idx(GTK_Q_TREE_MODEL(model), &iter);
+    QModelIndex idx = gtk_q_tree_model_get_source_idx(GTK_Q_TREE_MODEL(model), iter);
     if (idx.isValid()) {
-        auto n = CategorizedBookmarkModel::instance()->getNumber(idx);
-        /* get photo */
-        QVariant var_p = PixbufDelegate::instance()->callPhoto(n, QSize(50, 50), false);
-        std::shared_ptr<GdkPixbuf> photo = var_p.value<std::shared_ptr<GdkPixbuf>>();
-        g_object_set(G_OBJECT(cell), "pixbuf", photo.get(), NULL);
-        return;
+        auto n = idx.data(static_cast<int>(Call::Role::ContactMethod)).value<ContactMethod *>();
+        if (n) {
+            /* get photo */
+            QVariant var_p = PixbufDelegate::instance()->callPhoto(n, QSize(50, 50), false);
+            std::shared_ptr<GdkPixbuf> photo = var_p.value<std::shared_ptr<GdkPixbuf>>();
+            g_object_set(G_OBJECT(cell), "pixbuf", photo.get(), NULL);
+            return;
+        }
     }
 
     /* otherwise, make sure its an empty pixbuf */
@@ -107,22 +101,14 @@
 static void
 render_name_and_contact_method(G_GNUC_UNUSED GtkTreeViewColumn *tree_column,
                                GtkCellRenderer *cell,
-                               GtkTreeModel *filter_model,
-                               GtkTreeIter *filter_iter,
+                               GtkTreeModel *model,
+                               GtkTreeIter *iter,
                                G_GNUC_UNUSED gpointer data)
 {
     gchar *text = NULL;
 
-    /* convert to original model */
-    GtkTreeIter iter;
-    GtkTreeModel *model = gtk_tree_model_filter_get_model(GTK_TREE_MODEL_FILTER(filter_model));
-    gtk_tree_model_filter_convert_iter_to_child_iter(
-        GTK_TREE_MODEL_FILTER(filter_model),
-        &iter,
-        filter_iter);
-
     /* get contact method */
-    QModelIndex idx = gtk_q_tree_model_get_source_idx(GTK_Q_TREE_MODEL(model), &iter);
+    QModelIndex idx = gtk_q_tree_model_get_source_idx(GTK_Q_TREE_MODEL(model), iter);
     if (idx.isValid()) {
         /* get name and number */
         QVariant c = idx.data(static_cast<int>(Call::Role::Name));
@@ -144,16 +130,9 @@
               G_GNUC_UNUSED GtkTreeViewColumn *column,
               G_GNUC_UNUSED gpointer user_data)
 {
-    GtkTreeModel *filter_model = gtk_tree_view_get_model(tree_view);
-    GtkTreeIter filter_iter;
-    if (gtk_tree_model_get_iter(filter_model, &filter_iter, path)) {
-        /* convert to original model */
-        GtkTreeIter iter;
-        GtkTreeModel *model = gtk_tree_model_filter_get_model(GTK_TREE_MODEL_FILTER(filter_model));
-        gtk_tree_model_filter_convert_iter_to_child_iter(
-            GTK_TREE_MODEL_FILTER(filter_model),
-            &iter,
-            &filter_iter);
+    GtkTreeModel *model = gtk_tree_view_get_model(tree_view);
+    GtkTreeIter iter;
+    if (gtk_tree_model_get_iter(model, &iter, path)) {
         QModelIndex idx = gtk_q_tree_model_get_source_idx(GTK_Q_TREE_MODEL(model), &iter);
         if (idx.isValid()) {
             QVariant var_n = idx.data(static_cast<int>(Call::Role::ContactMethod));
@@ -175,23 +154,12 @@
     if (event->button != BUTTON_RIGHT_CLICK || event->type != GDK_BUTTON_PRESS)
         return FALSE;
 
-    /* we don't want a popup menu for categories for now, so everything deeper
-     * than one */
-    GtkTreeIter filter_iter;
-    GtkTreeModel *filter_model;
+    GtkTreeIter iter;
+    GtkTreeModel *model;
     GtkTreeSelection *selection = gtk_tree_view_get_selection(treeview);
-    if (!gtk_tree_selection_get_selected(selection, &filter_model, &filter_iter))
+    if (!gtk_tree_selection_get_selected(selection, &model, &iter))
         return FALSE;
 
-    /* convert to original model */
-    GtkTreeIter iter;
-    GtkTreeModel *model = gtk_tree_model_filter_get_model(GTK_TREE_MODEL_FILTER(filter_model));
-    gtk_tree_model_filter_convert_iter_to_child_iter(
-        GTK_TREE_MODEL_FILTER(filter_model),
-        &iter,
-        &filter_iter);
-
-    /* deeper than a category, so create a menu */
     GtkWidget *menu = gtk_menu_new();
     QModelIndex idx = gtk_q_tree_model_get_source_idx(GTK_Q_TREE_MODEL(model), &iter);
 
@@ -247,18 +215,12 @@
     gtk_tree_view_set_enable_search(GTK_TREE_VIEW(treeview_frequent), FALSE);
 
     GtkQTreeModel *bookmark_model = gtk_q_tree_model_new(
-        (QAbstractItemModel *)CategorizedBookmarkModel::instance(),
+        PhoneDirectoryModel::instance()->mostPopularNumberModel(),
         1,
         Qt::DisplayRole, G_TYPE_STRING);
 
-    /* create filter to only show the children of the popular contacts item */
-    GtkTreePath *popular_contact_parent_path = gtk_tree_path_new_from_indices(0, -1);
-    GtkTreeModel *frequent_model = gtk_tree_model_filter_new(
-                                    GTK_TREE_MODEL(bookmark_model),
-                                    popular_contact_parent_path);
-    gtk_tree_path_free(popular_contact_parent_path);
     gtk_tree_view_set_model(GTK_TREE_VIEW(treeview_frequent),
-                            GTK_TREE_MODEL(frequent_model));
+                            GTK_TREE_MODEL(bookmark_model));
 
     /* photo and name/contact method column */
     GtkCellArea *area = gtk_cell_area_box_new();
@@ -273,7 +235,7 @@
     gtk_tree_view_column_set_cell_data_func(
         column,
         renderer,
-        (GtkTreeCellDataFunc) render_contact_photo,
+        (GtkTreeCellDataFunc)render_contact_photo,
         NULL,
         NULL);
 
@@ -325,4 +287,4 @@
     gpointer self = g_object_new(FREQUENT_CONTACTS_VIEW_TYPE, NULL);
 
     return (GtkWidget *)self;
-}
\ No newline at end of file
+}