]> git.sur5r.net Git - bacula/bacula/blobdiff - bacula/src/qt-console/mainwin.cpp
Make name more discriptive
[bacula/bacula] / bacula / src / qt-console / mainwin.cpp
index 561bd75f199b6d048bec53f61a88d9f9ce390d5d..a73b3e9636d3008cd345174a83d96c155ab697ba 100644 (file)
 #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");
@@ -72,11 +83,11 @@ MainWin::MainWin(QWidget *parent) : QMainWindow(parent)
    }
    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();
+}