X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;ds=sidebyside;f=bacula%2Fsrc%2Fqt-console%2Fmainwin.cpp;h=a73b3e9636d3008cd345174a83d96c155ab697ba;hb=7ce6c85a93932f96762d898c321fd795438a4f3f;hp=56b62a112689d05e047a8d15d5de601d29b3e8dd;hpb=1f5aaf8b766dbe3a9b92e282da500ad41df4d4c0;p=bacula%2Fbacula diff --git a/bacula/src/qt-console/mainwin.cpp b/bacula/src/qt-console/mainwin.cpp index 56b62a1126..a73b3e9636 100644 --- a/bacula/src/qt-console/mainwin.cpp +++ b/bacula/src/qt-console/mainwin.cpp @@ -37,12 +37,32 @@ #include "bat.h" #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"); @@ -58,22 +78,23 @@ MainWin::MainWin(QWidget *parent) : QMainWindow(parent) readSettings(); - bool first = true; - foreach(Console *console, m_consoleHash){ + foreach(Console *console, m_consoleHash) { console->connect(); - if (first) { - m_currentConsole = console; - treeWidget->setCurrentItem(getFromHash(console)); - first = false; - } + } + m_currentConsole = (Console*)getFromHash(m_firstItem); + 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() { DIRRES *dir; - QTreeWidgetItem *item, *topItem, *firstItem; - firstItem = NULL; + QTreeWidgetItem *item, *topItem; + m_firstItem = NULL; LockRes(); foreach_res(dir, R_DIRECTOR) { @@ -85,15 +106,16 @@ void MainWin::createPages() /* The top tree item representing the director */ topItem = createTopPage(dir->name()); - topItem->setIcon(0, QIcon(QString::fromUtf8("images/server.png"))); + 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); m_consoleHash.insert(topItem, m_currentConsole); /* Create Tree Widget Item */ item = createPage("Console", topItem); - if (!firstItem){ - firstItem = item; - } + if (!m_firstItem){ m_firstItem = item; } /* insert the cosole and tree widget item into the hashes */ hashInsert(item, m_currentConsole); @@ -105,13 +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 */ - createPagebRestore(); - createPageMediaList(); - QString emptymedia(""), emptyclient(""); - createPageJobList(emptymedia, emptyclient); + /* + * Create instances in alphabetic order of the rest + * of the classes that will by default exist under each Director. + */ +// createPagebRestore(); createPageClients(); + createPageFileSet(); + QString emptymedia(""), emptyclient(""); + createPageJobList(emptymedia, emptyclient, NULL); + createPageMediaList(); + createPageStorage(); treeWidget->expandItem(topItem); stackedWidget->setCurrentWidget(m_currentConsole); @@ -140,18 +166,18 @@ void MainWin::createPageMediaList() /* * create an instance of the the joblist class on the stack */ -void MainWin::createPageJobList(QString &media, QString &client) +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(); - JobList* joblist = new JobList(media, client); + JobList* joblist = new JobList(media, client, parentTreeWidgetItem); 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(); @@ -169,6 +195,23 @@ void MainWin::createPageClients() clients->dockPage(); } +/* + * create an instance of the the storage class on the stack + */ +void MainWin::createPageStorage() +{ + Storage* storage = new Storage(); + storage->dockPage(); +} + +/* + * create an instance of the the fileset class on the stack + */ +void MainWin::createPageFileSet() +{ + FileSet* fileset = new FileSet(); + fileset->dockPage(); +} /* Create a root Tree Widget */ QTreeWidgetItem *MainWin::createTopPage(char *name) @@ -227,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( @@ -235,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())); } /* @@ -267,6 +312,7 @@ void MainWin::writeSettings() settings.beginGroup("MainWin"); settings.setValue("winSize", size()); settings.setValue("winPos", pos()); + settings.setValue("state", saveState()); settings.endGroup(); } @@ -277,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(); } @@ -304,87 +351,116 @@ void MainWin::treeItemClicked(QTreeWidgetItem *item, int /*column*/) */ void MainWin::treeItemChanged(QTreeWidgetItem *currentitem, QTreeWidgetItem *previousitem) { - Pages* page; - Console* console; + Pages *previousPage, *nextPage; + Console *previousConsole, *nextConsole; + + /* first determine the next item */ + + /* knowing the treeWidgetItem, get the page from the hash */ + nextPage = getFromHash(currentitem); + nextConsole = m_consoleHash.value(currentitem); + /* Is this a page that has been inserted into the hash */ + if (nextPage) { + nextConsole = nextPage->console(); + /* then is it a treeWidgetItem representing a director */ + } else if (nextConsole) { + /* let the next page BE the console */ + nextPage = nextConsole; + } else { + /* Should never get here */ + nextPage = NULL; + nextConsole = NULL; + } + /* The Previous item */ + /* this condition prevents a segfault. The first time there is no previousitem*/ if (previousitem) { /* knowing the treeWidgetItem, get the page from the hash */ - page = getFromHash(previousitem); - console = m_consoleHash.value(previousitem); - if (page) { - console = page->console(); - } else if (console) { - page = console; + previousPage = getFromHash(previousitem); + previousConsole = m_consoleHash.value(previousitem); + if (previousPage) { + previousConsole = previousPage->console(); + } else if (previousConsole) { + previousPage = previousConsole; } - /* make connections to the current console */ - disconnect(actionConnect, SIGNAL(triggered()), console, SLOT(connect())); - disconnect(actionStatusDir, SIGNAL(triggered()), console, SLOT(status_dir())); - disconnect(actionSelectFont, SIGNAL(triggered()), console, SLOT(set_font())); - /* make sure the close window and toggle dock options are removed */ - treeWidget->removeAction(actionClosePage); - treeWidget->removeAction(actionToggleDock); - /* Is this a page that has been inserted into the hash */ - if (page) { - foreach(QAction* pageaction, page->m_contextActions) { - treeWidget->removeAction(pageaction); + if ((previousPage) || (previousConsole)) { + if (nextConsole != previousConsole) { + /* 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); + dirItem->setBackground(0, greyBrush); + } + /* make sure the close window and toggle dock options are removed */ + treeWidget->removeAction(actionClosePage); + treeWidget->removeAction(actionToggleDock); + /* Is this a page that has been inserted into the hash */ + if (previousPage) { + foreach(QAction* pageaction, previousPage->m_contextActions) { + treeWidget->removeAction(pageaction); + } } } } - /* knowing the treeWidgetItem, get the page from the hash */ - page = getFromHash(currentitem); - console = m_consoleHash.value(currentitem); - /* Is this a page that has been inserted into the hash */ - if (page) { - m_currentConsole = page->console(); - } else if (console) { - m_currentConsole = console; - page = console; - } - if ((page) || (console)) { - /* make connections to the current console */ - 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())); + /* process the current (next) item */ + + if ((nextPage) || (nextConsole)) { + if (nextConsole != previousConsole) { + /* make connections to the current console */ + m_currentConsole = nextConsole; + 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); + dirItem->setBackground(0, magentaBrush); + } /* set the value for the currently active console */ - int stackindex = stackedWidget->indexOf(page); + int stackindex = stackedWidget->indexOf(nextPage); - /* Is this page currently on the stack */ + /* Is this page currently on the stack or is it undocked */ if (stackindex >= 0) { /* put this page on the top of the stack */ stackedWidget->setCurrentIndex(stackindex); } else { /* it is undocked, raise it to the front */ - page->raise(); + nextPage->raise(); } - setContextMenuDockText(page, currentitem); + /* for the page selectors menu action to dock or undock, set the text */ + nextPage->setContextMenuDockText(); treeWidget->addAction(actionToggleDock); /* if this page is closeable, then add that action */ - if (page->isCloseable()) { + if (nextPage->isCloseable()) { treeWidget->addAction(actionClosePage); } /* Add the actions to the Page Selectors tree widget that are part of the * current items list of desired actions regardless of whether on top of stack*/ - treeWidget->addActions(page->m_contextActions); + treeWidget->addActions(nextPage->m_contextActions); } } -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(); } /* @@ -402,16 +478,23 @@ void MainWin::input_line() } m_cmd_history.append(cmdStr); m_cmd_last = -1; + if (treeWidget->currentItem() != getFromHash(m_currentConsole)) + m_currentConsole->setCurrent(); } void MainWin::about() { QMessageBox::about(this, tr("About bat"), - tr("

bat 0.2, by Kern Sibbald

" - "

Copyright © " BYEAR " Free Software Foundation Europe e.V." - "

The bat is an administrative console" - " interface to the Director.")); + tr("

bat 1.0, by Dirk H Bartley and Kern Sibbald

" + "

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, ...) @@ -442,8 +525,6 @@ void MainWin::undockWindowButton() { Pages* page = (Pages*)stackedWidget->currentWidget(); page->togglePageDocking(); - /* The window has been undocked, lets change the context menu */ - setContextMenuDockText(); } /* @@ -459,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); } } @@ -604,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(); +}