Header text changed.
[situare] / src / ui / meetpeoplepanel.cpp
index b30e767..3f53b53 100644 (file)
@@ -3,16 +3,17 @@
 
 #include "headerlistitemdelegate.h"
 #include "personlistitem.h"
-#include "extendedlistitemdelegate.h"
+#include "friendlistitemdelegate.h"
 #include "personlistview.h"
 #include "imagebutton.h"
 #include "panelcommon.h"
-#include "user/user.h"
+#include "../user/user.h"
 
 #include "meetpeoplepanel.h"
 
 MeetPeoplePanel::MeetPeoplePanel(QWidget *parent)
-    : PanelBase(parent)
+    : PanelBase(parent),
+      m_headerListItemDelegate(0)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
@@ -22,9 +23,10 @@ MeetPeoplePanel::MeetPeoplePanel(QWidget *parent)
     setLayout(meetPeopleLayout);
 
     m_personListView = new PersonListView(this);
-    m_personListView->setItemDelegate(new ExtendedListItemDelegate(this));
+    m_personListItemDelegate = new FriendListItemDelegate(this);
+    initItemDelegates();
     connect(m_personListView, SIGNAL(listItemSelectionChanged()),
-            this, SLOT(onListItemSelectionChanged()));
+            this, SLOT(listItemSelectionHandler()));
     connect(m_personListView, SIGNAL(personItemClicked(GeoCoordinate)),
             this, SIGNAL(findPerson(GeoCoordinate)));
 
@@ -45,10 +47,10 @@ MeetPeoplePanel::MeetPeoplePanel(QWidget *parent)
     connect(searchPeopleButton, SIGNAL(clicked()),
             this, SIGNAL(requestInterestingPeopleSearch()));
 
-    ImageButton *friendListButton = new ImageButton(":/res/images/friend_list_btn.png",
+    m_friendListButton = new ImageButton(":/res/images/friend_list_btn.png",
                                                  ":/res/images/friend_list_btn_s.png",
                                                  ":/res/images/friend_list_btn_d.png", this);
-    connect(friendListButton, SIGNAL(clicked()),
+    connect(m_friendListButton, SIGNAL(clicked()),
             this, SLOT(showFriend()));
 
     ImageButton *messageButton = new ImageButton(":/res/images/chat_btn.png",
@@ -59,10 +61,18 @@ MeetPeoplePanel::MeetPeoplePanel(QWidget *parent)
 
     m_genericButtonsLayout->addWidget(refreshInterestingPeopleButton);
     m_genericButtonsLayout->addWidget(searchPeopleButton);
-    m_itemButtonsLayout->addWidget(friendListButton);
+    m_itemButtonsLayout->addWidget(m_friendListButton);
     m_itemButtonsLayout->addWidget(messageButton);
 }
 
+void MeetPeoplePanel::addHeaderItem(const QString &key, const QString &title)
+{
+    m_personListView->setItemDelegateForRow(m_personListView->count(), m_headerListItemDelegate);
+    ExtendedListItem *friendsHeaderItem = new ExtendedListItem(0, QListWidgetItem::UserType);
+    friendsHeaderItem->setTitle(title);
+    m_personListView->addListItem(key, friendsHeaderItem);
+}
+
 void MeetPeoplePanel::anyPanelClosed()
 {
     qDebug() << __PRETTY_FUNCTION__;
@@ -70,6 +80,66 @@ void MeetPeoplePanel::anyPanelClosed()
     m_personListView->clearItemSelection();
 }
 
+bool MeetPeoplePanel::friendDistanceLessThan(const User &user1, const User &user2)
+{
+    double user1Value;
+    QString user1Unit;
+    double user2Value;
+    QString user2Unit;
+
+    user1.distance(user1Value, user1Unit);
+    user2.distance(user2Value, user2Unit);
+
+    static int KM_FACTOR = 1000;
+
+    if (user1Unit == "km")
+        user1Value *= KM_FACTOR;
+    if (user2Unit == "km")
+        user2Value *= KM_FACTOR;
+
+    return user1Value < user2Value;
+}
+
+QList<QList<User> > MeetPeoplePanel::groupFriendsByDistance(const QList<User> &friends)
+{
+    const int AEROPLANE_DISTANCE = 5000;///< Aeroplane distance limit
+    const int CAR_DISTANCE = 500;       ///< Car distance limit
+    const int WALK_DISTANCE = 5;        ///< Walk distance limit
+
+    QList<QList<User> > groupedFriends;
+    QList<User> walkingDistanceUsers;
+    QList<User> drivingDistanceUsers;
+    QList<User> flyingDistanceUsers;
+    QList<User> rocketDistanceUsers;
+
+    foreach (const User user, friends) {
+        double value;
+        QString unit;
+        user.distance(value, unit);
+
+        if ((unit == "m") || (value < WALK_DISTANCE))
+            walkingDistanceUsers.append(user);
+        else if (value < CAR_DISTANCE)
+            drivingDistanceUsers.append(user);
+        else if (value < AEROPLANE_DISTANCE)
+            flyingDistanceUsers.append(user);
+        else
+            rocketDistanceUsers.append(user);
+    }
+
+    qSort(walkingDistanceUsers.begin(), walkingDistanceUsers.end(), friendDistanceLessThan);
+    qSort(drivingDistanceUsers.begin(), drivingDistanceUsers.end(), friendDistanceLessThan);
+    qSort(flyingDistanceUsers.begin(), flyingDistanceUsers.end(), friendDistanceLessThan);
+    qSort(rocketDistanceUsers.begin(), rocketDistanceUsers.end(), friendDistanceLessThan);
+
+    groupedFriends.append(walkingDistanceUsers);
+    groupedFriends.append(drivingDistanceUsers);
+    groupedFriends.append(flyingDistanceUsers);
+    groupedFriends.append(rocketDistanceUsers);
+
+    return groupedFriends;
+}
+
 void MeetPeoplePanel::hideEvent(QHideEvent *event)
 {
     qDebug() << __PRETTY_FUNCTION__;
@@ -79,14 +149,46 @@ void MeetPeoplePanel::hideEvent(QHideEvent *event)
     m_personListView->clearItemSelection();
 }
 
+void MeetPeoplePanel::initItemDelegates()
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    m_personListView->setItemDelegate(m_personListItemDelegate);
+
+    if (m_headerListItemDelegate)
+        delete m_headerListItemDelegate;
+    m_headerListItemDelegate = new HeaderListItemDelegate(this);
+}
+
+void MeetPeoplePanel::listItemSelectionHandler()
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    PersonListItem *personItem = dynamic_cast<PersonListItem*>(m_personListView->selectedItem());
+
+    if (personItem) {
+        if (personItem->isFriend())
+            m_friendListButton->setEnabled(true);
+        else
+            m_friendListButton->setDisabled(true);
+    } else {
+        m_friendListButton->setDisabled(true);
+    }
+
+    onListItemSelectionChanged();
+}
+
 void MeetPeoplePanel::messageButtonPressed()
 {
     qDebug() << __PRETTY_FUNCTION__;
 
     PersonListItem *personItem = dynamic_cast<PersonListItem*>(m_personListView->selectedItem());
-    if (personItem)
+
+    if (personItem) {
+        m_personListView->clearItemSelection();
         emit requestMessageDialog(QPair<QString, QString>(personItem->facebookId(),
                                                           personItem->title()));
+    }
 }
 
 void MeetPeoplePanel::setImage(const QString &id, const QPixmap &image)
@@ -104,34 +206,51 @@ void MeetPeoplePanel::showFriend()
 
     PersonListItem *personItem = dynamic_cast<PersonListItem*>(m_personListView->selectedItem());
     if (personItem) {
+        m_personListView->clearItemSelection();
         QList<QString> userIds;
         userIds.append(personItem->facebookId());
         emit requestShowFriend(userIds);
     }
 }
 
-void MeetPeoplePanel::populateInterestingPeopleListView(QList<User> &interestingPeople)
+void MeetPeoplePanel::populateInterestingPeopleListView(QList<User> &friends, QList<User> &others)
 {
-    qDebug() << __PRETTY_FUNCTION__ ;
+    qDebug() << __PRETTY_FUNCTION__;
 
     m_personListView->clearList();
+    initItemDelegates();
+
+    if (friends.count() > 0) {
+        QStringList headers;
+        headers.append(tr("Walking distance:"));
+        headers.append(tr("Driving distance:"));
+        headers.append(tr("Flying distance:"));
+        headers.append(tr("Rocket distance:"));
 
-    for (int i = 0; i < interestingPeople.count(); ++i) {
-        if (i == 0) {
-            m_personListView->setItemDelegateForRow(i, new HeaderListItemDelegate(this));
-            ExtendedListItem *item = new ExtendedListItem(0, QListWidgetItem::UserType);
-            item->setTitle(tr("Friends:"));
-            m_personListView->addListItem(QString("header") + QString::number(i), item);
+        QList<QList<User> > groupedFriends = groupFriendsByDistance(friends);
+
+        foreach (QList<User> group, groupedFriends) {
+            QString header = headers.takeFirst();
+            if (group.count() > 0) {
+                addHeaderItem(header, header);
+
+                foreach (User user, group) {
+                    PersonListItem *item = new PersonListItem();
+                    item->setPersonData(user, true);
+                    m_personListView->addListItem(user.userId(), item);
+                }
+            }
         }
-        else if (i == 2) {
-            m_personListView->setItemDelegateForRow(i+1, new HeaderListItemDelegate(this));
-            ExtendedListItem *item = new ExtendedListItem(0, QListWidgetItem::UserType);
-            item->setTitle(tr("Others:"));
-            m_personListView->addListItem(QString("header") + QString::number(i), item);
+    }
+
+    if (others.count() > 0) {
+        addHeaderItem("othersHeader", tr("Unknown distance:"));
+
+        foreach (User user, others) {
+            PersonListItem *item = new PersonListItem();
+            item->setPersonData(user, false);
+            m_personListView->addListItem(user.userId(), item);
         }
-        PersonListItem *item = new PersonListItem();
-        item->setPersonData(interestingPeople.at(i));
-        m_personListView->addListItem(interestingPeople.at(i).userId(), item);
     }
 
     m_personListView->scrollToTop();