mirror of
https://github.com/fralx/LimeReport.git
synced 2025-01-12 09:31:04 +03:00
Saving the designer state has been refactored
This commit is contained in:
parent
fd4e8057a9
commit
2b708b38f5
@ -71,7 +71,8 @@ public:
|
|||||||
Page,
|
Page,
|
||||||
Dialog,
|
Dialog,
|
||||||
Script,
|
Script,
|
||||||
Translations
|
Translations,
|
||||||
|
TabTypeCount
|
||||||
};
|
};
|
||||||
ReportDesignWidget(ReportEngine* report, QMainWindow *mainWindow, QWidget *parent = 0);
|
ReportDesignWidget(ReportEngine* report, QMainWindow *mainWindow, QWidget *parent = 0);
|
||||||
~ReportDesignWidget();
|
~ReportDesignWidget();
|
||||||
|
@ -63,7 +63,8 @@ namespace LimeReport{
|
|||||||
ReportDesignWindow* ReportDesignWindow::m_instance=0;
|
ReportDesignWindow* ReportDesignWindow::m_instance=0;
|
||||||
|
|
||||||
ReportDesignWindow::ReportDesignWindow(ReportEngine *report, QWidget *parent, QSettings* settings) :
|
ReportDesignWindow::ReportDesignWindow(ReportEngine *report, QWidget *parent, QSettings* settings) :
|
||||||
QMainWindow(parent), m_textAttibutesIsChanging(false), m_settings(settings), m_ownedSettings(false), m_progressDialog(0), m_showProgressDialog(true)
|
QMainWindow(parent), m_textAttibutesIsChanging(false), m_settings(settings), m_ownedSettings(false),
|
||||||
|
m_progressDialog(0), m_showProgressDialog(true), m_editorTabType(ReportDesignWidget::Page)
|
||||||
{
|
{
|
||||||
initReportEditor(report);
|
initReportEditor(report);
|
||||||
createActions();
|
createActions();
|
||||||
@ -93,7 +94,6 @@ ReportDesignWindow::ReportDesignWindow(ReportEngine *report, QWidget *parent, QS
|
|||||||
restoreSetting();
|
restoreSetting();
|
||||||
m_hideLeftPanel->setChecked(isDockAreaVisible(Qt::LeftDockWidgetArea));
|
m_hideLeftPanel->setChecked(isDockAreaVisible(Qt::LeftDockWidgetArea));
|
||||||
m_hideRightPanel->setChecked(isDockAreaVisible(Qt::RightDockWidgetArea));
|
m_hideRightPanel->setChecked(isDockAreaVisible(Qt::RightDockWidgetArea));
|
||||||
m_editorTabType = ReportDesignWidget::Page;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ReportDesignWindow::~ReportDesignWindow()
|
ReportDesignWindow::~ReportDesignWindow()
|
||||||
@ -663,23 +663,12 @@ void ReportDesignWindow::writePosition()
|
|||||||
void ReportDesignWindow::writeState()
|
void ReportDesignWindow::writeState()
|
||||||
{
|
{
|
||||||
settings()->beginGroup("DesignerWindow");
|
settings()->beginGroup("DesignerWindow");
|
||||||
switch (m_editorTabType) {
|
|
||||||
case ReportDesignWidget::Page:
|
m_editorsStates[m_editorTabType] = saveState();
|
||||||
settings()->setValue("PageEditorsState", saveState());
|
settings()->setValue("PageEditorsState", m_editorsStates[ReportDesignWidget::Page]);
|
||||||
settings()->setValue("DialogEditorsState", m_dialogEditorsState);
|
settings()->setValue("DialogEditorsState", m_editorsStates[ReportDesignWidget::Dialog]);
|
||||||
settings()->setValue("ScriptEditorsState", m_scriptEditorState);
|
settings()->setValue("ScriptEditorsState", m_editorsStates[ReportDesignWidget::Script]);
|
||||||
break;
|
settings()->setValue("TranslationEditorsState", m_editorsStates[ReportDesignWidget::Translations]);
|
||||||
case ReportDesignWidget::Script:
|
|
||||||
settings()->setValue("ScriptEditorsState", saveState());
|
|
||||||
settings()->setValue("DialogEditorsState", m_dialogEditorsState);
|
|
||||||
settings()->setValue("PageEditorsState", m_pageEditorsState);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
settings()->setValue("DialogEditorsState", saveState());
|
|
||||||
settings()->setValue("PageEditorsState", m_pageEditorsState);
|
|
||||||
settings()->setValue("ScriptEditorsState", m_scriptEditorState);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
settings()->setValue("InspectorFirsColumnWidth",m_objectInspector->columnWidth(0));
|
settings()->setValue("InspectorFirsColumnWidth",m_objectInspector->columnWidth(0));
|
||||||
settings()->endGroup();
|
settings()->endGroup();
|
||||||
settings()->beginGroup("RecentFiles");
|
settings()->beginGroup("RecentFiles");
|
||||||
@ -774,18 +763,23 @@ void ReportDesignWindow::restoreSetting()
|
|||||||
}
|
}
|
||||||
v = settings()->value("PageEditorsState");
|
v = settings()->value("PageEditorsState");
|
||||||
if (v.isValid()){
|
if (v.isValid()){
|
||||||
m_pageEditorsState = v.toByteArray();
|
m_editorsStates[ReportDesignWidget::Page] = v.toByteArray();
|
||||||
restoreState(v.toByteArray());
|
|
||||||
m_editorTabType = ReportDesignWidget::Page;
|
m_editorTabType = ReportDesignWidget::Page;
|
||||||
}
|
}
|
||||||
v = settings()->value("DialogEditorsState");
|
v = settings()->value("DialogEditorsState");
|
||||||
if (v.isValid()){
|
if (v.isValid()){
|
||||||
m_dialogEditorsState = v.toByteArray();
|
m_editorsStates[ReportDesignWidget::Dialog] = v.toByteArray();
|
||||||
}
|
}
|
||||||
v = settings()->value("ScriptEditorsState");
|
v = settings()->value("ScriptEditorsState");
|
||||||
if (v.isValid()){
|
if (v.isValid()){
|
||||||
m_scriptEditorState = v.toByteArray();
|
m_editorsStates[ReportDesignWidget::Script] = v.toByteArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
v = settings()->value("TranslationEditorsState");
|
||||||
|
if (v.isValid()){
|
||||||
|
m_editorsStates[ReportDesignWidget::Translations] = v.toByteArray();
|
||||||
|
}
|
||||||
|
|
||||||
v = settings()->value("InspectorFirsColumnWidth");
|
v = settings()->value("InspectorFirsColumnWidth");
|
||||||
if (v.isValid()){
|
if (v.isValid()){
|
||||||
m_objectInspector->setColumnWidth(0,v.toInt());
|
m_objectInspector->setColumnWidth(0,v.toInt());
|
||||||
@ -1087,7 +1081,7 @@ void ReportDesignWindow::slotLoadReport()
|
|||||||
setWindowTitle(m_reportDesignWidget->report()->reportName() + " - Lime Report Designer");
|
setWindowTitle(m_reportDesignWidget->report()->reportName() + " - Lime Report Designer");
|
||||||
addRecentFile(fileName);
|
addRecentFile(fileName);
|
||||||
m_editorTabType = ReportDesignWidget::Page;
|
m_editorTabType = ReportDesignWidget::Page;
|
||||||
showDefaultToolBars();
|
//showDefaultToolBars();
|
||||||
showDefaultEditors();
|
showDefaultEditors();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1287,48 +1281,20 @@ void ReportDesignWindow::slotActivePageChanged()
|
|||||||
updateRedoUndo();
|
updateRedoUndo();
|
||||||
updateAvaibleBands();
|
updateAvaibleBands();
|
||||||
|
|
||||||
switch (m_editorTabType) {
|
if (m_editorTabType == ReportDesignWidget::Dialog){
|
||||||
case ReportDesignWidget::Dialog:
|
|
||||||
m_dialogEditorsState = saveState();
|
|
||||||
#ifdef HAVE_UI_LOADER
|
#ifdef HAVE_UI_LOADER
|
||||||
m_scriptBrowser->updateDialogsTree();
|
m_scriptBrowser->updateDialogsTree();
|
||||||
#endif
|
#endif
|
||||||
break;
|
|
||||||
case ReportDesignWidget::Script:
|
|
||||||
m_scriptEditorState = saveState();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
m_pageEditorsState = saveState();
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_editorsStates[m_editorTabType] = saveState();
|
||||||
m_editorTabType = m_reportDesignWidget->activeTabType();
|
m_editorTabType = m_reportDesignWidget->activeTabType();
|
||||||
|
|
||||||
switch (m_editorTabType) {
|
if (!m_editorsStates[m_editorTabType].isEmpty()){
|
||||||
case ReportDesignWidget::Dialog:
|
restoreState(m_editorsStates[m_editorTabType]);
|
||||||
if (!m_dialogEditorsState.isEmpty()){
|
} else {
|
||||||
restoreState(m_dialogEditorsState);
|
showDefaultEditors();
|
||||||
} else {
|
showDefaultToolBars();
|
||||||
showDefaultEditors();
|
|
||||||
showDefaultToolBars();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case ReportDesignWidget::Script:
|
|
||||||
if (!m_scriptEditorState.isEmpty()){
|
|
||||||
restoreState(m_scriptEditorState);
|
|
||||||
} else {
|
|
||||||
showDefaultEditors();
|
|
||||||
showDefaultToolBars();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
if (!m_pageEditors.isEmpty()){
|
|
||||||
restoreState(m_pageEditorsState);
|
|
||||||
} else {
|
|
||||||
showDefaultEditors();
|
|
||||||
showDefaultToolBars();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -1474,6 +1440,19 @@ void ReportDesignWindow::resizeEvent(QResizeEvent*)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ReportDesignWindow::showEvent(QShowEvent* event)
|
||||||
|
{
|
||||||
|
QMainWindow::showEvent(event);
|
||||||
|
|
||||||
|
if (!m_editorsStates[m_editorTabType].isEmpty()){
|
||||||
|
restoreState(m_editorsStates[m_editorTabType]);
|
||||||
|
} else {
|
||||||
|
showDefaultEditors();
|
||||||
|
showDefaultToolBars();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void ReportDesignWindow::moveEvent(QMoveEvent*)
|
void ReportDesignWindow::moveEvent(QMoveEvent*)
|
||||||
{
|
{
|
||||||
#ifdef Q_OS_UNIX
|
#ifdef Q_OS_UNIX
|
||||||
|
@ -126,6 +126,7 @@ private slots:
|
|||||||
protected:
|
protected:
|
||||||
void closeEvent(QCloseEvent *event);
|
void closeEvent(QCloseEvent *event);
|
||||||
void resizeEvent(QResizeEvent *);
|
void resizeEvent(QResizeEvent *);
|
||||||
|
void showEvent(QShowEvent* event);
|
||||||
void moveEvent(QMoveEvent *);
|
void moveEvent(QMoveEvent *);
|
||||||
void hideDockWidgets(Qt::DockWidgetArea area, bool value);
|
void hideDockWidgets(Qt::DockWidgetArea area, bool value);
|
||||||
bool isDockAreaVisible(Qt::DockWidgetArea area);
|
bool isDockAreaVisible(Qt::DockWidgetArea area);
|
||||||
@ -262,9 +263,7 @@ private:
|
|||||||
QVector<QDockWidget*> m_dialogEditors;
|
QVector<QDockWidget*> m_dialogEditors;
|
||||||
QVector<QDockWidget*> m_docksToTabify;
|
QVector<QDockWidget*> m_docksToTabify;
|
||||||
ReportDesignWidget::EditorTabType m_editorTabType;
|
ReportDesignWidget::EditorTabType m_editorTabType;
|
||||||
QByteArray m_pageEditorsState;
|
QByteArray m_editorsStates[ReportDesignWidget::TabTypeCount];
|
||||||
QByteArray m_dialogEditorsState;
|
|
||||||
QByteArray m_scriptEditorState;
|
|
||||||
QVector<QToolBar*> m_pageTools;
|
QVector<QToolBar*> m_pageTools;
|
||||||
QVector<QToolBar*> m_dialogTools;
|
QVector<QToolBar*> m_dialogTools;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user