Added routing feature to friend and location list.
[situare] / src / ui / listview.cpp
index 2df8fad..e2dfbee 100644 (file)
 
 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*)));
 }
@@ -58,14 +62,16 @@ void ListView::clearList()
 
     m_listItems.clear();
     clear();
+
+    m_previousItem = 0;
 }
 
-void ListView::clearUnused(const QStringList &userIDs)
+void ListView::clearUnused(const QStringList &itemIDs)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
     foreach (QString key, m_listItems.keys()) {
-        if (!userIDs.contains(key)) {
+        if (!itemIDs.contains(key)) {
             ListItem *item = m_listItems.take(key);
             if (item) {
                 takeItem(row(item));
@@ -79,70 +85,123 @@ void ListView::clearFilter()
 {
     qDebug() << __PRETTY_FUNCTION__;
 
-    if (previousItem)
-        previousItem->setSelected(false);
+    if (m_previousItem)
+        m_previousItem->setSelected(false);
 
     foreach (ListItem *item, m_listItems)
         setItemHidden(item, false);
 }
 
-bool ListView::contains(const QString &userID)
+bool ListView::contains(const QString &itemID)
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    return m_listItems.contains(itemID);
+}
+
+void ListView::filter(const QList<QString> &itemIDs)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
-    return m_listItems.contains(userID);
+    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 (userIDs.contains(item->id()))
+        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)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
-    ListItem *item = listItem(userID);
+    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)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
-    ListItem *currentItem = static_cast<ListItem*>(item);
+    ListItem *currentItem = dynamic_cast<ListItem*>(item);
 
-    if (currentItem) {
+    if (currentItem)
+        listItemClicked(currentItem);
+}
 
-        if (previousItem == currentItem) {
-            bool selected = currentItem->toggleSelection();
+ListItem *ListView::listItem(const QString &itemID)
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    return dynamic_cast<ListItem*>(m_listItems.value(itemID));
+}
 
-            if (selected)
-                emit listItemClicked(currentItem->coordinates());
+ListItem *ListView::listItemAt(int index)
+{
+    qDebug() << __PRETTY_FUNCTION__;
 
-        } else {
-            if (previousItem)
-                previousItem->setSelected(false);
+    QHashIterator<QString, ListItem*> itemIterator(m_listItems);
+    ListItem *item = 0;
+    int counter = 0;
 
-            currentItem->setSelected(true);
-            emit listItemClicked(currentItem->coordinates());
+    while (itemIterator.hasNext()) {
+        itemIterator.next();
+        if (index == counter) {
+            item = itemIterator.value();
+            break;
         }
-
-        previousItem = currentItem;
+        counter++;
     }
+
+    return item;
+}
+
+ListItem *ListView::selectedItem()
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    return m_previousItem;
+}
+
+void ListView::setSelectedItem(ListItem *item)
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    listItemClicked(item);
 }
 
-ListItem *ListView::listItem(const QString &userID)
+ListView::~ListView()
 {
     qDebug() << __PRETTY_FUNCTION__;
 
-    return static_cast<ListItem*>(m_listItems.value(userID));
+    clearList();
 }