From efb37aedc72b4ec4bcedd77d35996e3c089cd81c Mon Sep 17 00:00:00 2001 From: Arin Alexander Date: Fri, 19 Feb 2016 04:03:48 +0300 Subject: [PATCH] Recent files menu item has been added --- src/lrreportdesignwindow.cpp | 77 +++++++++++++++++++++++++++++++++++- src/lrreportdesignwindow.h | 5 +++ 2 files changed, 81 insertions(+), 1 deletion(-) diff --git a/src/lrreportdesignwindow.cpp b/src/lrreportdesignwindow.cpp index 0c5663a..b201245 100644 --- a/src/lrreportdesignwindow.cpp +++ b/src/lrreportdesignwindow.cpp @@ -401,7 +401,10 @@ void ReportDesignWindow::createMainMenu() m_editMenu->addAction(m_settingsAction); m_infoMenu = menuBar()->addMenu(tr("Info")); m_infoMenu->addAction(m_aboutAction); - + m_recentFilesMenu = m_fileMenu->addMenu(tr("Recent Files")); + m_recentFilesSignalMap = new QSignalMapper(this); + connect(m_recentFilesSignalMap,SIGNAL(mapped(QString)),this,SLOT(slotLoadRecentFile(QString))); + m_recentFilesMenu->setDisabled(m_recentFiles.isEmpty()); } void ReportDesignWindow::initReportEditor(ReportEnginePrivate* report) @@ -510,9 +513,34 @@ void ReportDesignWindow::writeState() settings()->setValue("State",saveState()); settings()->setValue("InspectorFirsColumnWidth",m_objectInspector->columnWidth(0)); settings()->endGroup(); + settings()->beginGroup("RecentFiles"); + settings()->setValue("filesCount",m_recentFiles.count()); + QMap::const_iterator it = m_recentFiles.constBegin(); + int count = 0; + while (it != m_recentFiles.constEnd()) { + settings()->setValue("fileName"+QString::number(count),it.key()); + settings()->setValue("fileDate"+QString::number(count),it.value()); + ++count; + ++it; + } + settings()->endGroup(); m_reportDesignWidget->saveState(settings()); } +void ReportDesignWindow::createRecentFilesMenu() +{ + if (m_recentFilesMenu){ + m_recentFilesMenu->clear(); + foreach(QString fileName, m_recentFiles.keys()){ + QAction* tmpAction = new QAction(QIcon(":/report/images/newReport"),fileName,this); + connect(tmpAction,SIGNAL(triggered()), m_recentFilesSignalMap, SLOT(map())); + m_recentFilesSignalMap->setMapping(tmpAction,fileName); + m_recentFilesMenu->addAction(tmpAction); + } + } + m_recentFilesMenu->setDisabled(m_recentFiles.isEmpty()); +} + void ReportDesignWindow::restoreSetting() { settings()->beginGroup("DesignerWindow"); @@ -539,9 +567,25 @@ void ReportDesignWindow::restoreSetting() if (v.isValid()){ m_objectInspector->setColumnWidth(0,v.toInt()); } + settings()->endGroup(); + + settings()->beginGroup("RecentFiles"); + int filesCount = settings()->value("filesCount").toInt(); + QStringList keys = settings()->childKeys(); + for(int i=0;ivalue("fileName"+QString::number(i)).toString()] = + settings()->value("fileData"+QString::number(i)).toDateTime(); + + } else break; + + } + settings()->endGroup(); + m_reportDesignWidget->loadState(settings()); m_useGridAction->setChecked(m_reportDesignWidget->useGrid()); + createRecentFilesMenu(); } bool ReportDesignWindow::checkNeedToSave() @@ -778,6 +822,21 @@ void ReportDesignWindow::slotLoadReport() updateRedoUndo(); unsetCursor(); setWindowTitle(m_reportDesignWidget->report()->reportName() + " - Lime Report Designer"); + if (!m_recentFiles.contains(fileName)){ + if (m_recentFiles.count()==10){ + QMap::const_iterator it = m_recentFiles.constBegin(); + QDateTime minDate = QDateTime::currentDateTime(); + while (it != m_recentFiles.constEnd()) { + if (minDate>it.value()) minDate = it.value(); + ++it; + } + m_recentFiles.remove(m_recentFiles.key(minDate)); + } + m_recentFiles.insert(fileName,QDateTime::currentDateTime()); + } else { + m_recentFiles[fileName] = QDateTime::currentDateTime(); + } + createRecentFilesMenu(); } } @@ -976,6 +1035,22 @@ void ReportDesignWindow::slotUseGrid(bool value) m_reportDesignWidget->setUseGrid(value); } +void ReportDesignWindow::slotLoadRecentFile(const QString fileName) +{ + if (checkNeedToSave()){ + QApplication::processEvents(); + setCursor(Qt::WaitCursor); + m_reportDesignWidget->clear(); + m_reportDesignWidget->loadFromFile(fileName); + m_lblReportName->setText(fileName); + m_propertyModel->setObject(0); + updateRedoUndo(); + unsetCursor(); + setWindowTitle(m_reportDesignWidget->report()->reportName() + " - Lime Report Designer"); + m_recentFiles[fileName] = QDateTime::currentDateTime(); + } +} + void ReportDesignWindow::closeEvent(QCloseEvent * event) { if (checkNeedToSave()){ diff --git a/src/lrreportdesignwindow.h b/src/lrreportdesignwindow.h index 5e46bc1..0fcd8d3 100644 --- a/src/lrreportdesignwindow.h +++ b/src/lrreportdesignwindow.h @@ -111,6 +111,7 @@ private slots: void slotHideRightPanel(bool value); void slotEditSettings(); void slotUseGrid(bool value); + void slotLoadRecentFile(const QString fileName); protected: void closeEvent(QCloseEvent *event); void resizeEvent(QResizeEvent *); @@ -132,6 +133,7 @@ private: void startNewReport(); void writePosition(); void writeState(); + void createRecentFilesMenu(); private: static ReportDesignWindow* m_instance; @@ -186,8 +188,10 @@ private: QAction* m_addHLayout; QAction* m_hideLeftPanel; QAction* m_hideRightPanel; + QMenu* m_recentFilesMenu; QSignalMapper* m_bandsAddSignalsMap; + QSignalMapper* m_recentFilesSignalMap; ObjectInspectorWidget* m_objectInspector; QObjectPropertyModel* m_propertyModel; @@ -214,6 +218,7 @@ private: ValidatorIntf* m_validator; QProgressDialog* m_progressDialog; bool m_showProgressDialog; + QMap m_recentFiles; }; class ObjectNameValidator : public ValidatorIntf{