X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=bacula%2Fsrc%2Fqt-console%2Fmainwin.cpp;h=a73b3e9636d3008cd345174a83d96c155ab697ba;hb=7ce6c85a93932f96762d898c321fd795438a4f3f;hp=3472cbbf467ef163836129dd00b1a02f9b2eead0;hpb=a1354524bf1aa951a08664a3a669b874f1ae279a;p=bacula%2Fbacula
diff --git a/bacula/src/qt-console/mainwin.cpp b/bacula/src/qt-console/mainwin.cpp
index 3472cbbf46..a73b3e9636 100644
--- a/bacula/src/qt-console/mainwin.cpp
+++ b/bacula/src/qt-console/mainwin.cpp
@@ -39,12 +39,30 @@
#include "joblist/joblist.h"
#include "storage/storage.h"
#include "fileset/fileset.h"
+#include "label/label.h"
+#include "run/run.h"
+#include "pages.h"
+#include "restore/restore.h"
+#include "medialist/medialist.h"
+#include "joblist/joblist.h"
+#include "clients/clients.h"
+#include "help/help.h"
-MainWin::MainWin(QWidget *parent) : QMainWindow(parent)
+/*
+ * Daemon message callback
+ */
+void message_callback(int /* type */, char *msg)
{
+ QMessageBox::warning(mainWin, "Bat", msg, QMessageBox::Ok);
+}
+MainWin::MainWin(QWidget *parent) : QMainWindow(parent)
+{
+ m_dtformat = "yyyy-MM-dd HH:mm:ss";
mainWin = this;
setupUi(this); /* Setup UI defined by main.ui (designer) */
+ register_message_callback(message_callback);
+ readPreferences();
treeWidget->clear();
treeWidget->setColumnCount(1);
treeWidget->setHeaderLabel("Select Page");
@@ -60,16 +78,16 @@ MainWin::MainWin(QWidget *parent) : QMainWindow(parent)
readSettings();
- foreach(Console *console, m_consoleHash){
+ foreach(Console *console, m_consoleHash) {
console->connect();
}
m_currentConsole = (Console*)getFromHash(m_firstItem);
- treeWidget->setCurrentItem(getFromHash(m_currentConsole));
- /* FIXME
- * I'd like to turn this into a debug item
- * DIRRES* dirres = m_currentConsole->getDirRes();
- * printf("Setting initial window to %s\n", dirres->name());
- */
+ m_currentConsole->setCurrent();
+ if (m_miscDebug) {
+ QString directoryResourceName;
+ m_currentConsole->getDirResName(directoryResourceName);
+ Pmsg1(000, "Setting initial window to %s\n", directoryResourceName.toUtf8().data());
+ }
}
void MainWin::createPages()
@@ -88,8 +106,8 @@ void MainWin::createPages()
/* The top tree item representing the director */
topItem = createTopPage(dir->name());
- topItem->setIcon(0, QIcon(QString::fromUtf8("images/server.png")));
- /* Set background to grey for ease of identification of inactive dirfector */
+ topItem->setIcon(0, QIcon(":images/server.png"));
+ /* Set background to grey for ease of identification of inactive Director */
QBrush greyBrush(Qt::lightGray);
topItem->setBackground(0, greyBrush);
m_currentConsole->setDirectorTreeItem(topItem);
@@ -109,15 +127,17 @@ void MainWin::createPages()
item->setForeground(0, redBrush);
m_currentConsole->dockPage();
- /* create instances of the rest of the classes that will by default exist
- * under each director */
+ /*
+ * Create instances in alphabetic order of the rest
+ * of the classes that will by default exist under each Director.
+ */
// createPagebRestore();
- createPageMediaList();
+ createPageClients();
+ createPageFileSet();
QString emptymedia(""), emptyclient("");
createPageJobList(emptymedia, emptyclient, NULL);
- createPageClients();
+ createPageMediaList();
createPageStorage();
- createPageFileSet();
treeWidget->expandItem(topItem);
stackedWidget->setCurrentWidget(m_currentConsole);
@@ -149,7 +169,7 @@ void MainWin::createPageMediaList()
void MainWin::createPageJobList(QString &media, QString &client,
QTreeWidgetItem *parentTreeWidgetItem)
{
- QTreeWidgetItem *item, *holdItem;
+ QTreeWidgetItem *holdItem;
/* save current tree widget item in case query produces no results */
holdItem = treeWidget->currentItem();
@@ -157,8 +177,7 @@ void MainWin::createPageJobList(QString &media, QString &client,
joblist->dockPage();
/* If this is a query of jobs on a specific media */
if ((media != "") || (client != "")) {
- item = getFromHash(joblist);
- treeWidget->setCurrentItem(item);
+ joblist->setCurrent();
/* did query produce results, if not close window and set back to hold */
if (joblist->m_resultCount == 0) {
joblist->closeStackPage();
@@ -251,6 +270,7 @@ void MainWin::createConnections()
/* Connect signals to slots */
connect(lineEdit, SIGNAL(returnPressed()), this, SLOT(input_line()));
connect(actionAbout_bat, SIGNAL(triggered()), this, SLOT(about()));
+ connect(actionBat_Help, SIGNAL(triggered()), this, SLOT(help()));
connect(treeWidget, SIGNAL(itemClicked(QTreeWidgetItem *, int)), this,
SLOT(treeItemClicked(QTreeWidgetItem *, int)));
connect(treeWidget, SIGNAL(
@@ -259,12 +279,13 @@ void MainWin::createConnections()
connect(stackedWidget, SIGNAL(currentChanged(int)),
this, SLOT(stackItemChanged(int)));
connect(actionQuit, SIGNAL(triggered()), app, SLOT(closeAllWindows()));
- connect(actionLabel, SIGNAL(triggered()), this, SLOT(labelDialogClicked()));
- connect(actionRun, SIGNAL(triggered()), this, SLOT(runDialogClicked()));
- connect(actionRestore, SIGNAL(triggered()), this, SLOT(restoreDialogClicked()));
+ connect(actionLabel, SIGNAL(triggered()), this, SLOT(labelButtonClicked()));
+ connect(actionRun, SIGNAL(triggered()), this, SLOT(runButtonClicked()));
+ connect(actionRestore, SIGNAL(triggered()), this, SLOT(restoreButtonClicked()));
connect(actionUndock, SIGNAL(triggered()), this, SLOT(undockWindowButton()));
connect(actionToggleDock, SIGNAL(triggered()), this, SLOT(toggleDockContextWindow()));
connect(actionClosePage, SIGNAL(triggered()), this, SLOT(closePage()));
+ connect(actionPreferences, SIGNAL(triggered()), this, SLOT(setPreferences()));
}
/*
@@ -291,6 +312,7 @@ void MainWin::writeSettings()
settings.beginGroup("MainWin");
settings.setValue("winSize", size());
settings.setValue("winPos", pos());
+ settings.setValue("state", saveState());
settings.endGroup();
}
@@ -301,6 +323,7 @@ void MainWin::readSettings()
settings.beginGroup("MainWin");
resize(settings.value("winSize", QSize(1041, 801)).toSize());
move(settings.value("winPos", QPoint(200, 150)).toPoint());
+ restoreState(settings.value("state").toByteArray());
settings.endGroup();
}
@@ -366,6 +389,7 @@ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *pre
/* remove connections to the current console */
disconnect(actionConnect, SIGNAL(triggered()), previousConsole, SLOT(connect()));
disconnect(actionStatusDir, SIGNAL(triggered()), previousConsole, SLOT(status_dir()));
+ disconnect(actionMessages, SIGNAL(triggered()), previousConsole, SLOT(messages()));
disconnect(actionSelectFont, SIGNAL(triggered()), previousConsole, SLOT(set_font()));
QTreeWidgetItem *dirItem = previousConsole->directorTreeItem();
QBrush greyBrush(Qt::lightGray);
@@ -392,6 +416,7 @@ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *pre
connect(actionConnect, SIGNAL(triggered()), m_currentConsole, SLOT(connect()));
connect(actionSelectFont, SIGNAL(triggered()), m_currentConsole, SLOT(set_font()));
connect(actionStatusDir, SIGNAL(triggered()), m_currentConsole, SLOT(status_dir()));
+ connect(actionMessages, SIGNAL(triggered()), m_currentConsole, SLOT(messages()));
/* Set director's tree widget background to magenta for ease of identification */
QTreeWidgetItem *dirItem = m_currentConsole->directorTreeItem();
QBrush magentaBrush(Qt::magenta);
@@ -409,7 +434,7 @@ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *pre
nextPage->raise();
}
/* for the page selectors menu action to dock or undock, set the text */
- setContextMenuDockText(nextPage, currentitem);
+ nextPage->setContextMenuDockText();
treeWidget->addAction(actionToggleDock);
/* if this page is closeable, then add that action */
@@ -423,19 +448,19 @@ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *pre
}
}
-void MainWin::labelDialogClicked()
+void MainWin::labelButtonClicked()
{
- new labelDialog(m_currentConsole);
+ new labelPage();
}
-void MainWin::runDialogClicked()
+void MainWin::runButtonClicked()
{
- new runDialog(m_currentConsole);
+ new runPage();
}
-void MainWin::restoreDialogClicked()
+void MainWin::restoreButtonClicked()
{
- new prerestoreDialog(m_currentConsole);
+ new prerestorePage();
}
/*
@@ -453,19 +478,23 @@ void MainWin::input_line()
}
m_cmd_history.append(cmdStr);
m_cmd_last = -1;
- if (treeWidget->currentItem() != getFromHash(m_currentConsole)){
- treeWidget->setCurrentItem(getFromHash(m_currentConsole));
- }
+ if (treeWidget->currentItem() != getFromHash(m_currentConsole))
+ m_currentConsole->setCurrent();
}
void MainWin::about()
{
QMessageBox::about(this, tr("About bat"),
- tr("
Copyright © " BYEAR " Free Software Foundation Europe e.V." - "
The bat is an administrative console"
- " interface to the Director."));
+ tr("
Copyright © " BYEAR " Free Software Foundation Europe e.V." + "
The bat is an administrative console" + " interface to the Director.")); +} + +void MainWin::help() +{ + Help::displayFile("index.html"); } void MainWin::set_statusf(const char *fmt, ...) @@ -496,8 +525,6 @@ void MainWin::undockWindowButton() { Pages* page = (Pages*)stackedWidget->currentWidget(); page->togglePageDocking(); - /* The window has been undocked, lets change the context menu */ - setContextMenuDockText(); } /* @@ -513,78 +540,6 @@ void MainWin::toggleDockContextWindow() if (getFromHash(currentitem)) { Pages* page = getFromHash(currentitem); page->togglePageDocking(); - if (page->isDocked()) { - stackedWidget->setCurrentWidget(page); - } - /* Toggle the menu item. The window's dock status has been toggled */ - setContextMenuDockText(page, currentitem); - } -} - -/* - * Function to set the text of the toggle dock context menu when page and - * widget item are NOT known. This is an overoaded funciton. - * It is called from MainWin::undockWindowButton, it is not intended to change - * for the top pages tree widget, it is for the currently active tree widget - * item. Which is why the page is not passed. - */ -void MainWin::setContextMenuDockText() -{ - QTreeWidgetItem *currentitem = treeWidget->currentItem(); - - /* Is this a page that has been inserted into the hash */ - if (getFromHash(currentitem)) { - Pages* page = getFromHash(currentitem); - setContextMenuDockText(page, currentitem); - } -} - -/* - * Function to set the text of the toggle dock context menu when page and - * widget item are known. This is the more commonly used. - */ -void MainWin::setContextMenuDockText(Pages* page, QTreeWidgetItem* item) -{ - QString docktext(""); - if (page->isDocked()) { - docktext += "UnDock "; - } else { - docktext += "ReDock "; - } - docktext += item->text(0) += " Window"; - - actionToggleDock->setText(docktext); - setTreeWidgetItemDockColor(page, item); -} - -/* - * Function to set the color of the tree widget item based on whether it is - * docked or not. - */ -void MainWin::setTreeWidgetItemDockColor(Pages* page, QTreeWidgetItem* item) -{ - if (item->text(0) != "Console") { - if (page->isDocked()) { - /* Set the brush to blue if undocked */ - QBrush blackBrush(Qt::black); - item->setForeground(0, blackBrush); - } else { - /* Set the brush back to black if docked */ - QBrush blueBrush(Qt::blue); - item->setForeground(0, blueBrush); - } - } -} - -/* - * Overload of previous function, use treeindex to get item from page - * This is called when an undocked window is closed. - */ -void MainWin::setTreeWidgetItemDockColor(Pages* page) -{ - QTreeWidgetItem* item = getFromHash(page); - if (item) { - setTreeWidgetItemDockColor(page, item); } } @@ -658,3 +613,104 @@ void MainWin::closePage() } } } + +/* Quick function to return the current console */ +Console *MainWin::currentConsole() +{ + return m_currentConsole; +} +/* Quick function to return the tree item for the director */ +QTreeWidgetItem *MainWin::currentTopItem() +{ + return m_currentConsole->directorTreeItem(); +} + +/* Preferences menu item clicked */ +void MainWin::setPreferences() +{ + prefsDialog prefs; + prefs.commDebug->setCheckState(m_commDebug ? Qt::Checked : Qt::Unchecked); + prefs.displayAll->setCheckState(m_displayAll ? Qt::Checked : Qt::Unchecked); + prefs.sqlDebug->setCheckState(m_sqlDebug ? Qt::Checked : Qt::Unchecked); + prefs.commandDebug->setCheckState(m_commandDebug ? Qt::Checked : Qt::Unchecked); + prefs.miscDebug->setCheckState(m_miscDebug ? Qt::Checked : Qt::Unchecked); + prefs.recordLimit->setCheckState(m_recordLimitCheck ? Qt::Checked : Qt::Unchecked); + prefs.recordSpinBox->setValue(m_recordLimitVal); + prefs.daysLimit->setCheckState(m_daysLimitCheck ? Qt::Checked : Qt::Unchecked); + prefs.daysSpinBox->setValue(m_daysLimitVal); + prefs.checkMessages->setCheckState(m_checkMessages ? Qt::Checked : Qt::Unchecked); + prefs.checkMessagesSpin->setValue(m_checkMessagesInterval); + prefs.exec(); +} + +/* Preferences dialog */ +prefsDialog::prefsDialog() +{ + setupUi(this); +} + +void prefsDialog::accept() +{ + this->hide(); + mainWin->m_commDebug = this->commDebug->checkState() == Qt::Checked; + mainWin->m_displayAll = this->displayAll->checkState() == Qt::Checked; + mainWin->m_sqlDebug = this->sqlDebug->checkState() == Qt::Checked; + mainWin->m_commandDebug = this->commandDebug->checkState() == Qt::Checked; + mainWin->m_miscDebug = this->miscDebug->checkState() == Qt::Checked; + mainWin->m_recordLimitCheck = this->recordLimit->checkState() == Qt::Checked; + mainWin->m_recordLimitVal = this->recordSpinBox->value(); + mainWin->m_daysLimitCheck = this->daysLimit->checkState() == Qt::Checked; + mainWin->m_daysLimitVal = this->daysSpinBox->value(); + mainWin->m_checkMessages = this->checkMessages->checkState() == Qt::Checked; + mainWin->m_checkMessagesInterval = this->checkMessagesSpin->value(); + QSettings settings("www.bacula.org", "bat"); + settings.beginGroup("Debug"); + settings.setValue("commDebug", mainWin->m_commDebug); + settings.setValue("displayAll", mainWin->m_displayAll); + settings.setValue("sqlDebug", mainWin->m_sqlDebug); + settings.setValue("commandDebug", mainWin->m_commandDebug); + settings.setValue("miscDebug", mainWin->m_miscDebug); + settings.endGroup(); + settings.beginGroup("JobList"); + settings.setValue("recordLimitCheck", mainWin->m_recordLimitCheck); + settings.setValue("recordLimitVal", mainWin->m_recordLimitVal); + settings.setValue("daysLimitCheck", mainWin->m_daysLimitCheck); + settings.setValue("daysLimitVal", mainWin->m_daysLimitVal); + settings.endGroup(); + settings.beginGroup("Messages"); + settings.setValue("checkMessages", mainWin->m_checkMessages); + settings.setValue("checkMessagesInterval", mainWin->m_checkMessagesInterval); + settings.endGroup(); + foreach(Console *console, mainWin->m_consoleHash) { + console->startTimer(); + } +} + +void prefsDialog::reject() +{ + this->hide(); + mainWin->set_status("Canceled"); +} + +/* read preferences for the prefences dialog box */ +void MainWin::readPreferences() +{ + QSettings settings("www.bacula.org", "bat"); + settings.beginGroup("Debug"); + m_commDebug = settings.value("commDebug", false).toBool(); + m_displayAll = settings.value("displayAll", false).toBool(); + m_sqlDebug = settings.value("sqlDebug", false).toBool(); + m_commandDebug = settings.value("commandDebug", false).toBool(); + m_miscDebug = settings.value("miscDebug", false).toBool(); + settings.endGroup(); + settings.beginGroup("JobList"); + m_recordLimitCheck = settings.value("recordLimitCheck", true).toBool(); + m_recordLimitVal = settings.value("recordLimitVal", 150).toInt(); + m_daysLimitCheck = settings.value("daysLimitCheck", false).toBool(); + m_daysLimitVal = settings.value("daysLimitVal", 28).toInt(); + settings.endGroup(); + settings.beginGroup("Messages"); + m_checkMessages = settings.value("checkMessages", false).toBool(); + m_checkMessagesInterval = settings.value("checkMessagesInterval", 28).toInt(); + settings.endGroup(); +}