X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;ds=sidebyside;f=bacula%2Fsrc%2Fqt-console%2Fmainwin.cpp;h=a73b3e9636d3008cd345174a83d96c155ab697ba;hb=7ce6c85a93932f96762d898c321fd795438a4f3f;hp=ec64b6042bf2cb632e570a0a99947441342bad81;hpb=0dcb9d6ef267a77a4647fecde514bc39ac043788;p=bacula%2Fbacula diff --git a/bacula/src/qt-console/mainwin.cpp b/bacula/src/qt-console/mainwin.cpp index ec64b6042b..a73b3e9636 100644 --- a/bacula/src/qt-console/mainwin.cpp +++ b/bacula/src/qt-console/mainwin.cpp @@ -46,12 +46,23 @@ #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"); @@ -67,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); m_currentConsole->setCurrent(); - /* 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()); - */ + if (m_miscDebug) { + QString directoryResourceName; + m_currentConsole->getDirResName(directoryResourceName); + Pmsg1(000, "Setting initial window to %s\n", directoryResourceName.toUtf8().data()); + } } void MainWin::createPages() @@ -96,7 +107,7 @@ void MainWin::createPages() /* The top tree item representing the director */ topItem = createTopPage(dir->name()); topItem->setIcon(0, QIcon(":images/server.png")); - /* Set background to grey for ease of identification of inactive dirfector */ + /* Set background to grey for ease of identification of inactive Director */ QBrush greyBrush(Qt::lightGray); topItem->setBackground(0, greyBrush); m_currentConsole->setDirectorTreeItem(topItem); @@ -116,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); @@ -257,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( @@ -298,6 +312,7 @@ void MainWin::writeSettings() settings.beginGroup("MainWin"); settings.setValue("winSize", size()); settings.setValue("winPos", pos()); + settings.setValue("state", saveState()); settings.endGroup(); } @@ -308,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(); } @@ -476,6 +492,11 @@ void MainWin::about() " interface to the Director.")); } +void MainWin::help() +{ + Help::displayFile("index.html"); +} + void MainWin::set_statusf(const char *fmt, ...) { va_list arg_ptr; @@ -608,8 +629,17 @@ QTreeWidgetItem *MainWin::currentTopItem() void MainWin::setPreferences() { prefsDialog prefs; - prefs.commDebug->setCheckState(g_commDebug ? Qt::Checked : Qt::Unchecked); - prefs.displayAll->setCheckState(g_displayAll ? Qt::Checked : Qt::Unchecked); + 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(); } @@ -622,8 +652,38 @@ prefsDialog::prefsDialog() void prefsDialog::accept() { this->hide(); - g_commDebug = this->commDebug->checkState() == Qt::Checked; - g_displayAll = this->displayAll->checkState() == Qt::Checked; + 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() @@ -631,3 +691,26 @@ 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(); +}