Added routing feature to friend and location list.
[situare] / src / ui / listview.cpp
index f1e18f6..e2dfbee 100644 (file)
@@ -1,40 +1,81 @@
+/*
+   Situare - A location system for Facebook
+   Copyright (C) 2010  Ixonos Plc. Authors:
+
+       Jussi Laitinen - jussi.laitinen@ixonos.com
+
+   Situare is free software; you can redistribute it and/or
+   modify it under the terms of the GNU General Public License
+   version 2 as published by the Free Software Foundation.
+
+   Situare 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 Situare; if not, write to the Free Software
+   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301,
+   USA.
+*/
+
 #include <QDebug>
 
 #include "listitem.h"
 #include "listview.h"
+#include "friendlistitem.h"
 
 ListView::ListView(QWidget *parent)
     : QListWidget(parent),
-      previousItem(0)
+      m_previousItem(0)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
+    setSelectionMode(QAbstractItemView::SingleSelection);
+    setAutoFillBackground(false);
+    viewport()->setAutoFillBackground(false);
+
     connect(this, SIGNAL(itemClicked(QListWidgetItem*)),
             this, SLOT(listItemClicked(QListWidgetItem*)));
 }
 
 void ListView::addListItem(const QString &key, ListItem *item)
 {
+    qDebug() << __PRETTY_FUNCTION__;
+
     if (!m_listItems.contains(key)) {
         addItem(item);
         m_listItems.insert(key, item);
     }
 }
 
-void ListView::addItemToView(ListItem *item)
+void ListView::addListItemToView(ListItem *item)
 {
+    qDebug() << __PRETTY_FUNCTION__;
+
     addItem(item);
 }
 
-void ListView::clearUnused(const QStringList &userIDs)
+void ListView::clearList()
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    m_listItems.clear();
+    clear();
+
+    m_previousItem = 0;
+}
+
+void ListView::clearUnused(const QStringList &itemIDs)
 {
+    qDebug() << __PRETTY_FUNCTION__;
+
     foreach (QString key, m_listItems.keys()) {
-        if (!userIDs.contains(key)) {
-            ListItem *item = m_listItems.value(key);
+        if (!itemIDs.contains(key)) {
+            ListItem *item = m_listItems.take(key);
             if (item) {
                 takeItem(row(item));
                 delete item;
-                m_listItems.remove(key);
             }
         }
     }
@@ -42,50 +83,125 @@ void ListView::clearUnused(const QStringList &userIDs)
 
 void ListView::clearFilter()
 {
+    qDebug() << __PRETTY_FUNCTION__;
+
+    if (m_previousItem)
+        m_previousItem->setSelected(false);
+
+    foreach (ListItem *item, m_listItems)
+        setItemHidden(item, false);
+}
+
+bool ListView::contains(const QString &itemID)
+{
+    qDebug() << __PRETTY_FUNCTION__;
 
+    return m_listItems.contains(itemID);
 }
 
-bool ListView::contains(const QString &userID)
+void ListView::filter(const QList<QString> &itemIDs)
 {
-    return m_listItems.contains(userID);
+    qDebug() << __PRETTY_FUNCTION__;
+
+    foreach (ListItem *item, m_listItems) {
+        if (itemIDs.contains(m_listItems.key(item)))
+            setItemHidden(item, false);
+        else
+            setItemHidden(item, true);
+    }
 }
 
-void ListView::filter(const QList<QString> &userIDs)
+void ListView::filter(const QString &pattern)
 {
+    qDebug() << __PRETTY_FUNCTION__;
 
+    foreach (ListItem *item, m_listItems) {
+        if (item->title().contains(pattern, Qt::CaseInsensitive))
+            setItemHidden(item, false);
+        else
+            setItemHidden(item, true);
+    }
 }
 
-ListItem *ListView::takeListItemFromView(const QString &userID)
+ListItem *ListView::takeListItemFromView(const QString &itemID)
 {
-    ListItem *listItem = item(userID);
-    takeItem(row(listItem));
-    return listItem;
+    qDebug() << __PRETTY_FUNCTION__;
+
+    ListItem *item = listItem(itemID);
+    takeItem(row(item));
+    return item;
+}
+
+void ListView::listItemClicked(ListItem *item)
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    if (m_previousItem == item) {
+        item->toggleSelection();
+
+    } else {
+        if (m_previousItem)
+            m_previousItem->setSelected(false);
+
+        item->setSelected(true);
+    }
+    m_previousItem = item;
 }
 
 void ListView::listItemClicked(QListWidgetItem *item)
 {
-    qWarning() << __PRETTY_FUNCTION__;
+    qDebug() << __PRETTY_FUNCTION__;
 
-    ListItem *currentItem = static_cast<ListItem*>(item);
+    ListItem *currentItem = dynamic_cast<ListItem*>(item);
 
-    if (currentItem) {
+    if (currentItem)
+        listItemClicked(currentItem);
+}
 
-        if (previousItem == currentItem) {
-            currentItem->toggleHeight();
-        }
-        else {
-            if (previousItem)
-                previousItem->setExpanded(false);
+ListItem *ListView::listItem(const QString &itemID)
+{
+    qDebug() << __PRETTY_FUNCTION__;
 
-            currentItem->setExpanded(true);
-        }
+    return dynamic_cast<ListItem*>(m_listItems.value(itemID));
+}
+
+ListItem *ListView::listItemAt(int index)
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    QHashIterator<QString, ListItem*> itemIterator(m_listItems);
+    ListItem *item = 0;
+    int counter = 0;
 
-        previousItem = currentItem;
-        emit listItemClicked(currentItem->id());
+    while (itemIterator.hasNext()) {
+        itemIterator.next();
+        if (index == counter) {
+            item = itemIterator.value();
+            break;
+        }
+        counter++;
     }
+
+    return item;
+}
+
+ListItem *ListView::selectedItem()
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    return m_previousItem;
+}
+
+void ListView::setSelectedItem(ListItem *item)
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    listItemClicked(item);
 }
 
-ListItem *ListView::item(const QString &userID)
+ListView::~ListView()
 {
-    return static_cast<ListItem*>(m_listItems.value(userID));
+    qDebug() << __PRETTY_FUNCTION__;
+
+    clearList();
 }