#2379 import summary cases. Fixed dialog issues

This commit is contained in:
Bjørn Erik Jensen
2018-01-16 13:37:57 +01:00
parent d283f2c733
commit 735165bb2b
4 changed files with 172 additions and 56 deletions

View File

@@ -33,6 +33,7 @@
#include <QVBoxLayout> #include <QVBoxLayout>
#include <QLabel> #include <QLabel>
#include <QLineEdit> #include <QLineEdit>
#include <QTextEdit>
#include <QDialogButtonBox> #include <QDialogButtonBox>
#include <QPushButton> #include <QPushButton>
#include <QToolBar> #include <QToolBar>
@@ -61,10 +62,18 @@ RicFileHierarchyDialog::RicFileHierarchyDialog(QWidget* parent)
m_fileFilterLabel = new QLabel(); m_fileFilterLabel = new QLabel();
m_fileFilter = new QLineEdit(); m_fileFilter = new QLineEdit();
m_fileExtension = new QLabel(); m_fileExtension = new QLabel();
m_effectiveFilterLabel = new QLabel();
m_effectiveFilter = new QLabel();
m_fileListLabel = new QLabel();
m_fileList = new QTextEdit();
m_buttons = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel); m_buttons = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel);
// Connect to close button signal // Connect to close button signal
connect(m_rootDir, SIGNAL(textChanged(const QString&)), this, SLOT(slotFilterChanged(const QString&)));
connect(m_pathFilter, SIGNAL(textChanged(const QString&)), this, SLOT(slotFilterChanged(const QString&)));
connect(m_fileFilter, SIGNAL(textChanged(const QString&)), this, SLOT(slotFilterChanged(const QString&)));
connect(m_buttons, SIGNAL(accepted()), this, SLOT(slotDialogOkClicked())); connect(m_buttons, SIGNAL(accepted()), this, SLOT(slotDialogOkClicked()));
connect(m_buttons, SIGNAL(rejected()), this, SLOT(slotDialogCancelClicked())); connect(m_buttons, SIGNAL(rejected()), this, SLOT(slotDialogCancelClicked()));
connect(m_browseButton, SIGNAL(clicked()), this, SLOT(slotBrowseButtonClicked())); connect(m_browseButton, SIGNAL(clicked()), this, SLOT(slotBrowseButtonClicked()));
@@ -72,23 +81,15 @@ RicFileHierarchyDialog::RicFileHierarchyDialog(QWidget* parent)
// Set widget properties // Set widget properties
m_rootDirLabel->setText("Root folder"); m_rootDirLabel->setText("Root folder");
m_pathFilterLabel->setText("Path pattern"); m_pathFilterLabel->setText("Path pattern");
m_pathFilter->setText("*");
m_fileFilterLabel->setText("File pattern"); m_fileFilterLabel->setText("File pattern");
m_effectiveFilterLabel->setText("Effective filter");
m_fileListLabel->setText("Files found");
m_fileList->setLineWrapMode(QTextEdit::NoWrap);
m_browseButton->setText("..."); m_browseButton->setText("...");
m_browseButton->setFixedWidth(25); m_browseButton->setFixedWidth(25);
// Define layout // Define layout
QVBoxLayout* dialogLayout = new QVBoxLayout(); QVBoxLayout* dialogLayout = new QVBoxLayout();
//dialogLayout->addWidget(m_rootDirLabel);
//dialogLayout->addWidget(m_rootDir);
//dialogLayout->addWidget(m_browseButton);
//dialogLayout->addWidget(m_pathFilterLabel);
//dialogLayout->addWidget(m_pathFilter);
//dialogLayout->addWidget(m_fileFilterLabel);
//dialogLayout->addWidget(m_fileFilter);
//dialogLayout->addWidget(m_fileExtension);
//dialogLayout->addWidget(m_buttons);
QGridLayout* gridLayout = new QGridLayout(); QGridLayout* gridLayout = new QGridLayout();
gridLayout->addWidget(m_rootDirLabel, 0, 0); gridLayout->addWidget(m_rootDirLabel, 0, 0);
@@ -99,6 +100,10 @@ RicFileHierarchyDialog::RicFileHierarchyDialog(QWidget* parent)
gridLayout->addWidget(m_fileFilterLabel, 2, 0); gridLayout->addWidget(m_fileFilterLabel, 2, 0);
gridLayout->addWidget(m_fileFilter, 2, 1); gridLayout->addWidget(m_fileFilter, 2, 1);
gridLayout->addWidget(m_fileExtension, 2, 2); gridLayout->addWidget(m_fileExtension, 2, 2);
gridLayout->addWidget(m_effectiveFilterLabel, 3, 0);
gridLayout->addWidget(m_effectiveFilter, 3, 1);
gridLayout->addWidget(m_fileListLabel, 4, 0);
gridLayout->addWidget(m_fileList, 4, 1);
dialogLayout->addLayout(gridLayout); dialogLayout->addLayout(gridLayout);
dialogLayout->addWidget(m_buttons); dialogLayout->addWidget(m_buttons);
@@ -129,12 +134,54 @@ QString RicFileHierarchyDialog::rootDir() const
return m_rootDir->text(); return m_rootDir->text();
} }
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
QString RicFileHierarchyDialog::pathFilter() const
{
return m_pathFilter->text();
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
QString RicFileHierarchyDialog::fileNameFilter() const
{
return m_fileFilter->text();
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
QStringList RicFileHierarchyDialog::fileExtensions() const
{
return m_fileExtension->text().split("|");
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
bool RicFileHierarchyDialog::cancelPressed() const
{
return m_cancelPressed;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RicFileHierarchyDialog::appendToFileList(const QString& fileName)
{
m_fileList->append(fileName);
QApplication::processEvents();
}
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
/// ///
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
RicFileHierarchyDialogResult RicFileHierarchyDialog::getOpenFileNames(QWidget *parent /*= 0*/, RicFileHierarchyDialogResult RicFileHierarchyDialog::getOpenFileNames(QWidget *parent /*= 0*/,
const QString &caption /*= QString()*/, const QString &caption /*= QString()*/,
const QString &dir /*= QString()*/, const QString &dir /*= QString()*/,
const QString &pathFilter /*= QString()*/,
const QString &fileNameFilter /*= QString()*/, const QString &fileNameFilter /*= QString()*/,
const QStringList &fileExtensions /*= QStringList()*/) const QStringList &fileExtensions /*= QStringList()*/)
{ {
@@ -143,46 +190,57 @@ RicFileHierarchyDialogResult RicFileHierarchyDialog::getOpenFileNames(QWidget *p
dialog.setWindowTitle(caption); dialog.setWindowTitle(caption);
dialog.m_rootDir->setText(dir); dialog.m_rootDir->setText(QDir::toNativeSeparators(dir));
dialog.m_pathFilter->setText(pathFilter);
dialog.m_fileFilter->setText(fileNameFilter); dialog.m_fileFilter->setText(fileNameFilter);
dialog.m_fileExtension->setText(prefixStrings(fileExtensions, ".").join(" | ")); dialog.m_fileExtension->setText(prefixStrings(fileExtensions, ".").join(" | "));
dialog.updateEffectiveFilter();
dialog.m_fileList->setText("");
dialog.resize(600, 150); dialog.resize(600, 250);
dialog.exec(); dialog.exec();
return RicFileHierarchyDialogResult(dialog.result() == QDialog::Accepted, dialog.files(), dialog.rootDir()); return RicFileHierarchyDialogResult(dialog.result() == QDialog::Accepted, dialog.files(), dialog.rootDir(), dialog.pathFilter(), dialog.fileNameFilter());
} }
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
/// ///
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
QStringList RicFileHierarchyDialog::findMatchingFiles(const QString& rootDir, const QString& pathFilter, const QString& fileNameFilter, const QStringList& fileExtensions) QStringList RicFileHierarchyDialog::findMatchingFiles(RicFileHierarchyDialog& dialog)
{ {
QStringList files = findFilesRecursive(rootDir, fileNameFilter, fileExtensions); return findFilesRecursive(dialog.rootDir(), dialog);
return filterByPathFilter(files, pathFilter);
} }
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
/// ///
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
QStringList RicFileHierarchyDialog::findFilesRecursive(const QString &dir, const QString &fileNameFilter, const QStringList &fileExtensions) QStringList RicFileHierarchyDialog::findFilesRecursive(const QString &currentDir, RicFileHierarchyDialog& dialog)
{ {
QStringList allFiles; QStringList allFiles;
QDir qdir(dir); if (dialog.cancelPressed()) return allFiles;
QDir qdir(currentDir);
QStringList subDirs = qdir.entryList(QDir::Dirs | QDir::NoDotAndDotDot); QStringList subDirs = qdir.entryList(QDir::Dirs | QDir::NoDotAndDotDot);
QStringList files = qdir.entryList(createNameFilterList(fileNameFilter, fileExtensions), QDir::Files); QStringList files = qdir.entryList(createNameFilterList(dialog.fileNameFilter(), dialog.fileExtensions()), QDir::Files);
for (QString file : files) for (QString file : files)
{ {
allFiles.append(qdir.absoluteFilePath(file)); QString absFilePath = qdir.absoluteFilePath(file);
if (pathFilterMatch(absFilePath, dialog.pathFilter()))
{
allFiles.append(absFilePath);
dialog.appendToFileList(absFilePath);
}
} }
for (QString subDir : subDirs) for (QString subDir : subDirs)
{ {
allFiles += findFilesRecursive(qdir.absoluteFilePath(subDir), fileNameFilter, fileExtensions); QApplication::processEvents();
allFiles += findFilesRecursive(qdir.absoluteFilePath(subDir), dialog);
} }
return allFiles; return dialog.cancelPressed() ? QStringList() : allFiles;
} }
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
@@ -210,23 +268,48 @@ QStringList RicFileHierarchyDialog::createNameFilterList(const QString &fileName
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
/// ///
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
QStringList RicFileHierarchyDialog::filterByPathFilter(const QStringList& files, const QString& pathFilter) bool RicFileHierarchyDialog::pathFilterMatch(const QString& file, const QString& pathFilter)
{ {
QStringList filteredFiles;
QRegExp regexp(pathFilter, Qt::CaseInsensitive, QRegExp::Wildcard); QRegExp regexp(pathFilter, Qt::CaseInsensitive, QRegExp::Wildcard);
for (QString file : files) QFileInfo fileInfo(file);
{ QString path = fileInfo.absolutePath();
QFileInfo fileInfo(file);
QString path = fileInfo.absolutePath();
if (regexp.exactMatch(path))
{
filteredFiles.append(file);
}
}
return filteredFiles; return regexp.exactMatch(path);
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RicFileHierarchyDialog::updateEffectiveFilter()
{
QString sep(QDir::separator());
QString effFilter = QString("%1/%2/%3%4")
.arg(m_rootDir->text())
.arg(m_pathFilter->text())
.arg(m_fileFilter->text())
.arg(m_fileExtension->text());
QString native(QDir::toNativeSeparators(effFilter));
// Remove duplicate separators
int len;
do
{
len = native.size();
native.replace(sep + sep, sep);
} while (native.size() != len);
m_effectiveFilter->setText(native);
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RicFileHierarchyDialog::slotFilterChanged(const QString& text)
{
updateEffectiveFilter();
} }
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
@@ -234,7 +317,8 @@ QStringList RicFileHierarchyDialog::filterByPathFilter(const QStringList& files,
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
void RicFileHierarchyDialog::slotDialogOkClicked() void RicFileHierarchyDialog::slotDialogOkClicked()
{ {
m_files = findMatchingFiles(m_rootDir->text(), m_pathFilter->text(), m_fileFilter->text(), m_fileExtension->text().split("|")); m_cancelPressed = false;
m_files = findMatchingFiles(*this);
accept(); accept();
} }
@@ -244,6 +328,7 @@ void RicFileHierarchyDialog::slotDialogOkClicked()
void RicFileHierarchyDialog::slotDialogCancelClicked() void RicFileHierarchyDialog::slotDialogCancelClicked()
{ {
m_files = QStringList(); m_files = QStringList();
m_cancelPressed = true;
reject(); reject();
} }

View File

@@ -26,6 +26,7 @@
class QLabel; class QLabel;
class QLineEdit; class QLineEdit;
class QTextEdit;
class QDialogButtonBox; class QDialogButtonBox;
class QPushButton; class QPushButton;
class QMainWindow; class QMainWindow;
@@ -44,29 +45,35 @@ public:
QStringList files() const; QStringList files() const;
QString rootDir() const; QString rootDir() const;
QString pathFilter() const;
QString fileNameFilter() const;
QStringList fileExtensions() const;
bool cancelPressed() const;
void appendToFileList(const QString& fileName);
static RicFileHierarchyDialogResult getOpenFileNames(QWidget *parent = 0, static RicFileHierarchyDialogResult getOpenFileNames(QWidget *parent = 0,
const QString &caption = QString(), const QString& caption = QString(),
const QString &dir = QString(), const QString& dir = QString(),
const QString &fileNameFilter = QString(), const QString& pathFilter = QString(),
const QStringList &fileExtensions = QStringList()); const QString& fileNameFilter = QString(),
const QStringList& fileExtensions = QStringList());
private: private:
static QStringList findMatchingFiles(const QString &rootDir, static QStringList findMatchingFiles(RicFileHierarchyDialog& dialog);
const QString& pathFilter,
const QString &fileNameFilter,
const QStringList &fileExtensions);
static QStringList findFilesRecursive(const QString &dir, static QStringList findFilesRecursive(const QString& currentDir,
const QString &fileNameFilter, RicFileHierarchyDialog& dialog);
const QStringList &fileExtensions);
static QStringList createNameFilterList(const QString &fileNameFilter, static QStringList createNameFilterList(const QString& fileNameFilter,
const QStringList &fileExtensions); const QStringList& fileExtensions);
static QStringList filterByPathFilter(const QStringList& files, const QString& pathFilter); static bool pathFilterMatch(const QString& file, const QString& pathFilter);
void updateEffectiveFilter();
private slots: private slots:
void slotFilterChanged(const QString& text);
void slotDialogOkClicked(); void slotDialogOkClicked();
void slotDialogCancelClicked(); void slotDialogCancelClicked();
void slotBrowseButtonClicked(); void slotBrowseButtonClicked();
@@ -81,12 +88,19 @@ private:
QLabel* m_fileFilterLabel; QLabel* m_fileFilterLabel;
QLineEdit* m_fileFilter; QLineEdit* m_fileFilter;
QLabel* m_fileExtension; QLabel* m_fileExtension;
QLabel* m_effectiveFilterLabel;
QLabel* m_effectiveFilter;
QLabel* m_fileListLabel;
QTextEdit* m_fileList;
QDialogButtonBox* m_buttons; QDialogButtonBox* m_buttons;
QStringList m_files; QStringList m_files;
bool m_cancelPressed;
}; };
@@ -96,9 +110,16 @@ private:
class RicFileHierarchyDialogResult class RicFileHierarchyDialogResult
{ {
public: public:
RicFileHierarchyDialogResult(bool ok, const QStringList& files, const QString& rootDir) : RicFileHierarchyDialogResult(bool ok,
ok(ok), files(files), rootDir(rootDir) {} const QStringList& files,
const QString& rootDir,
const QString& pathFilter,
const QString& fileNameFilter) :
ok(ok), files(files), rootDir(rootDir), pathFilter(pathFilter), fileNameFilter(fileNameFilter) {}
bool ok; bool ok;
QStringList files; QStringList files;
QString rootDir; QString rootDir;
QString pathFilter;
QString fileNameFilter;
}; };

View File

@@ -57,7 +57,11 @@ void RicImportSummaryCasesFeature::onActionTriggered(bool isChecked)
RiaApplication* app = RiaApplication::instance(); RiaApplication* app = RiaApplication::instance();
QString defaultDir = app->lastUsedDialogDirectory("INPUT_FILES"); QString defaultDir = app->lastUsedDialogDirectory("INPUT_FILES");
RicFileHierarchyDialogResult result = RicFileHierarchyDialog::getOpenFileNames(NULL, "Import Summary Cases", defaultDir, "*", QStringList(".SMSPEC")); RicFileHierarchyDialogResult result = RicFileHierarchyDialog::getOpenFileNames(NULL, "Import Summary Cases", defaultDir, m_pathFilter, m_fileNameFilter, QStringList(".SMSPEC"));
// Remember filters
m_pathFilter = result.pathFilter;
m_fileNameFilter = result.fileNameFilter;
if (!result.ok) return; if (!result.ok) return;

View File

@@ -30,6 +30,8 @@ class RicImportSummaryCasesFeature : public caf::CmdFeature
CAF_CMD_HEADER_INIT; CAF_CMD_HEADER_INIT;
public: public:
RicImportSummaryCasesFeature() : m_pathFilter("*"), m_fileNameFilter("*") { }
static bool createAndAddSummaryCaseFromFile(const QString& fileName); static bool createAndAddSummaryCaseFromFile(const QString& fileName);
protected: protected:
@@ -37,6 +39,10 @@ protected:
virtual bool isCommandEnabled() override; virtual bool isCommandEnabled() override;
virtual void onActionTriggered( bool isChecked ) override; virtual void onActionTriggered( bool isChecked ) override;
virtual void setupActionLook( QAction* actionToSetup ) override; virtual void setupActionLook( QAction* actionToSetup ) override;
private:
QString m_pathFilter;
QString m_fileNameFilter;
}; };