]> vaikene.ee Git - evaf/commitdiff
* Added auto-completor to the directory field
authorEnar Väikene <enar@vaikene.net>
Mon, 28 Nov 2011 11:36:28 +0000 (13:36 +0200)
committerEnar Väikene <enar@vaikene.net>
Mon, 28 Nov 2011 11:36:28 +0000 (13:36 +0200)
* Limited the number of history items that are stored
* Search fields are disabled while the search is ongoing.

src/apps/FileFinder/GUI/gui.cpp
src/apps/FileFinder/GUI/gui.h
src/apps/FileFinder/GUI/version.h

index a849da970d2e2cf4da6da630ee2d39dfbc0848b6..29dcd712b3280e4aa22d3d37ee4dbce38f32f592 100644 (file)
@@ -75,6 +75,8 @@ void FileFinder::GUI::Internal::MainWidget::keyPressEvent(QKeyEvent * e)
 
 //-------------------------------------------------------------------
 
+int const FileFinder::GUI::Module::MaxHistoryItems = 20;
+
 FileFinder::GUI::Module::Module()
     : Plugins::iPlugin()
     , mReady(false)
@@ -138,6 +140,8 @@ void FileFinder::GUI::Module::done()
 {
     mReady = false;
 
+    mFinder = 0;
+
     /*
      * Widgets are deleted by the SdiWindow module. We use wMain to track calls to done() without
      * proper init().
@@ -155,27 +159,27 @@ void FileFinder::GUI::Module::saveHistory()
     QSettings settings(VER_COMPANY_NAME_STR, Common::iApp::instance()->name());
 
     QStringList t;
-    for (int i = 0; i < wDirectory->count(); ++i)
+    for (int i = 0; i < wDirectory->count() && i < MaxHistoryItems; ++i)
         t.append(wDirectory->itemText(i));
     settings.setValue("FileFinder/Directories", t);
 
     t.clear();
-    for (int i = 0; i < wIncludeNames->count(); ++i)
+    for (int i = 0; i < wIncludeNames->count() && i < MaxHistoryItems; ++i)
         t.append(wIncludeNames->itemText(i));
     settings.setValue("FileFinder/IncludeNames", t);
 
     t.clear();
-    for (int i = 0; i < wExcludeNames->count(); ++i)
+    for (int i = 0; i < wExcludeNames->count() && i < MaxHistoryItems; ++i)
         t.append(wExcludeNames->itemText(i));
     settings.setValue("FileFinder/ExcludeNames", t);
 
     t.clear();
-    for (int i = 0; i < wIncludeContent->count(); ++i)
+    for (int i = 0; i < wIncludeContent->count() && i < MaxHistoryItems; ++i)
         t.append(wIncludeContent->itemText(i));
     settings.setValue("FileFinder/IncludeContent", t);
 
     t.clear();
-    for (int i = 0; i < wExcludeContent->count(); ++i)
+    for (int i = 0; i < wExcludeContent->count() && i < MaxHistoryItems; ++i)
         t.append(wExcludeContent->itemText(i));
     settings.setValue("FileFinder/ExcludeContent", t);
 
@@ -187,6 +191,7 @@ void FileFinder::GUI::Module::loadHistory()
 
     wDirectory->addItems(settings.value("FileFinder/Directories").toStringList());
     wDirectory->setEditText(QDir::currentPath());
+    mDirModel->setRootPath(QDir::currentPath());
 
     wIncludeNames->addItems(settings.value("FileFinder/IncludeNames").toStringList());
     wIncludeNames->setEditText("");
@@ -216,12 +221,17 @@ void FileFinder::GUI::Module::createWidgets()
     wDirectory->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
     wDirectory->setEditable(true);
     wDirectory->setInsertPolicy(QComboBox::InsertAtTop);
+    QCompleter * completer = new QCompleter(wMain);
+    mDirModel = new QFileSystemModel(wMain);
+    mDirModel->setFilter(QDir::AllDirs | QDir::Dirs | QDir::NoDotAndDotDot);
+    completer->setModel(mDirModel);
+    wDirectory->setCompleter(completer);
     l->setBuddy(wDirectory);
     hbox->addWidget(wDirectory);
 
-    QPushButton * btn = new QPushButton(tr("&Browse"));
-    connect(btn, SIGNAL(clicked()), this, SLOT(browseDirectory()));
-    hbox->addWidget(btn);
+    wBrowse = new QPushButton(tr("&Browse"));
+    connect(wBrowse, SIGNAL(clicked()), this, SLOT(browseDirectory()));
+    hbox->addWidget(wBrowse);
 
     wRecursive = new QCheckBox(tr("&Recursive"));
     wRecursive->setChecked(true);
@@ -286,7 +296,7 @@ void FileFinder::GUI::Module::createWidgets()
     connect(wFind, SIGNAL(clicked()), this, SLOT(find()));
     hbox->addWidget(wFind);
 
-    btn = new QPushButton(tr("&Close"));
+    QPushButton * btn = new QPushButton(tr("&Close"));
     connect(btn, SIGNAL(clicked()), qApp, SLOT(quit()));
     hbox->addWidget(btn);
 }
@@ -323,7 +333,27 @@ void FileFinder::GUI::Module::find()
     }
     else {
         wResults->clear();
-        
+
+        if (wDirectory->findText(wDirectory->currentText()) == -1)
+            wDirectory->insertItem(0, wDirectory->currentText());
+        if (wIncludeNames->findText(wIncludeNames->currentText()) == -1)
+            wIncludeNames->insertItem(0, wIncludeNames->currentText());
+        if (wExcludeNames->findText(wExcludeNames->currentText()) == -1)
+            wExcludeNames->insertItem(0, wExcludeNames->currentText());
+        if (wIncludeContent->findText(wIncludeContent->currentText()) == -1)
+            wIncludeContent->insertItem(0, wIncludeContent->currentText());
+        if (wExcludeContent->findText(wExcludeContent->currentText()) == -1)
+            wExcludeContent->insertItem(0, wExcludeContent->currentText());
+
+        // Disable input fields
+        wDirectory->setEnabled(false);
+        wBrowse->setEnabled(false);
+        wRecursive->setEnabled(false);
+        wIncludeNames->setEnabled(false);
+        wExcludeNames->setEnabled(false);
+        wIncludeContent->setEnabled(false);
+        wExcludeContent->setEnabled(false);
+
         mFinder->search(wDirectory->currentText(),
                         wRecursive->isChecked(),
                         FileFinder::Filter(
@@ -351,6 +381,15 @@ void FileFinder::GUI::Module::finished(bool canceled)
 {
     Q_UNUSED(canceled)
 
+    // Enable input fields
+    wDirectory->setEnabled(true);
+    wBrowse->setEnabled(true);
+    wRecursive->setEnabled(true);
+    wIncludeNames->setEnabled(true);
+    wExcludeNames->setEnabled(true);
+    wIncludeContent->setEnabled(true);
+    wExcludeContent->setEnabled(true);
+
     wFind->setText(tr("&Search"));
 }
 
index 809dab1f39449499fa7d1f727add7f9c5a0fad53..e4c0c8e885c2a7cda45c9058ce69f47ab66a7309 100644 (file)
@@ -33,6 +33,7 @@ class QComboBox;
 class QPushButton;
 class QListWidget;
 class QAction;
+class QFileSystemModel;
 
 namespace eVaf {
 namespace SdiWindow {
@@ -113,6 +114,9 @@ private slots:
 
 private: // Members
 
+    /// Max number of items in each field that we save
+    static int const MaxHistoryItems;
+
     /// Flag indicating that the module is ready
     bool mReady;
 
@@ -126,6 +130,7 @@ private: // Members
     /// Widgets on the screen
     Internal::MainWidget * wMain;
     QComboBox * wDirectory;
+    QPushButton * wBrowse;
     QCheckBox * wRecursive;
     QComboBox * wIncludeNames;
     QComboBox * wExcludeNames;
@@ -134,6 +139,9 @@ private: // Members
     QListWidget * wResults;
     QPushButton * wFind;
 
+    /// File system auto-completion model for the directory field
+    QFileSystemModel * mDirModel;
+
 
 private: // Methods
 
index 745d9c79aa1236f3b0b615cb27abb5e3a6d282bb..dd5c198056476bdbeeee7cbae9e95fb1a75eb41a 100644 (file)
 /**
  * Module/library version number in the form major,minor,release,build
  */
-#define VER_FILE_VERSION                0,1,1,1
+#define VER_FILE_VERSION                0,1,2,2
 
 /**
  * Module/library version number in the string format (shall end with \0)
  */
-#define VER_FILE_VERSION_STR            "0.1.1.1\0"
+#define VER_FILE_VERSION_STR            "0.1.2.2\0"
 
 /**
  * Module/library name (shall end with \0)