Fixed search history settings read and write and added search history
[situare] / src / ui / listview.cpp
index 55292f1..40ec9c2 100644 (file)
@@ -58,6 +58,8 @@ void ListView::addListItemToView(ListItem *item)
 
 void ListView::clearItemSelection()
 {
+    qDebug() << __PRETTY_FUNCTION__;
+
     clearSelection();
 
     if (m_currentItem)
@@ -116,10 +118,12 @@ void ListView::filter(const QList<QString> &itemIDs)
     m_filteredItemIDs = itemIDs;
 
     foreach (ListItem *item, m_listItems) {
-        if (itemIDs.contains(m_listItems.key(item)))
+        if (itemIDs.contains(m_listItems.key(item))) {
             item->setHidden(false);
-        else
+        } else {
+            item->setSelected(false);
             item->setHidden(true);
+        }
     }
 
     emit listItemSelectionChanged();
@@ -131,9 +135,9 @@ void ListView::filter(const QString &pattern)
 
     if (m_filteredItemIDs.isEmpty()) {
         foreach (ListItem *item, m_listItems) {
-            if (item->title().contains(pattern, Qt::CaseInsensitive))
+            if (item->title().contains(pattern, Qt::CaseInsensitive)) {
                 item->setHidden(false);
-            else {
+            } else {
                 item->setSelected(false);
                 item->setHidden(true);
             }
@@ -142,9 +146,9 @@ void ListView::filter(const QString &pattern)
         foreach (QString key, m_filteredItemIDs) {
             ListItem *item = m_listItems.value(key);
             if (item) {
-                if (item->title().contains(pattern, Qt::CaseInsensitive))
+                if (item->title().contains(pattern, Qt::CaseInsensitive)) {
                     item->setHidden(false);
-                else {
+                } else {
                     item->setSelected(false);
                     item->setHidden(true);
                 }
@@ -204,20 +208,39 @@ ListItem *ListView::listItemAt(int index)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
-    QHashIterator<QString, ListItem*> itemIterator(m_listItems);
-    ListItem *item = 0;
-    int counter = 0;
+    ListItem *listItem = 0;
 
-    while (itemIterator.hasNext()) {
-        itemIterator.next();
-        if (index == counter) {
-            item = itemIterator.value();
-            break;
-        }
-        counter++;
+    if (index < count())
+        listItem = dynamic_cast<ListItem*>(item(index));
+
+    return listItem;
+}
+
+void ListView::prependListItem(const QString &key, ListItem *item)
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    if (!m_listItems.contains(key)) {
+        insertItem(0, item);
+        m_listItems.insert(key, item);
     }
+}
 
-    return item;
+void ListView::removeLastItem()
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    ListItem *item = listItemAt(count() - 1);
+
+    if (item) {
+        if (item) {
+            m_listItems.remove(item->title());
+            takeItem(row(item));
+            if (m_currentItem == item)
+                m_currentItem = 0;
+            delete item;
+        }
+    }
 }
 
 ListItem *ListView::selectedItem()