minor tweaks
[sface.git] / sface / mainwindow.py
index 0bcd766..fdd52a5 100644 (file)
@@ -8,7 +8,7 @@ from PyQt4.QtGui import *
 
 from sface.config import config
 from sface.logwindow import LogWindow
-from sface.xmlwindow import XmlWindow
+from sface.rspecwindow import RSpecWindow
 from sface.screens.configscreen import ConfigScreen
 from sface.screens.mainscreen import MainScreen
 
@@ -17,20 +17,26 @@ class Nav(QWidget):
         QWidget.__init__(self, parent)
         
         self.title = QLabel("", self)
-        self.link = QLabel("", self)
-        self.link.setAlignment(Qt.AlignRight)
+        self.main = QLabel("", self)
+        self.main.setAlignment(Qt.AlignRight)
+
+        self.config = QLabel("", self)
+        self.config.setAlignment(Qt.AlignRight)
         
         hlayout = QHBoxLayout()
         hlayout.addWidget(self.title)
         hlayout.addStretch()
-        hlayout.addWidget(self.link)
+        hlayout.addWidget(QLabel("Go to: ", self))
+        hlayout.addWidget(self.main)
+        hlayout.addWidget(self.config)
         self.setLayout(hlayout)
 
     def setTitle(self, title):
         self.title.setText(title)
 
-    def setLink(self, link):
-        self.link.setText(link)
+    def setLinks(self, main, config):
+        self.main.setText(main)
+        self.config.setText(config)
 
 
 class Status(QLabel):
@@ -56,12 +62,13 @@ class Status(QLabel):
         self.setText("")
         QTimer.singleShot(1500, self.sliceUpdateDate)
 
+
 class MainWindow(QWidget):
     def __init__(self, parent=None):
         QWidget.__init__(self, parent)
 
         self.logWindow = LogWindow(self)
-        self.xmlWindow = XmlWindow(self)
+        self.rspecWindow = RSpecWindow(self)
 
         self.pix = QLabel(self)
         self.config_screen = ConfigScreen(self)
@@ -75,47 +82,50 @@ class MainWindow(QWidget):
 
         self.nav = Nav(self)
         self.nav.setTitle(self.main_screen.getTitleText())
-        self.nav.setLink(self.config_screen.getLinkText())
+        self.nav.setLinks(self.main_screen.getLinkText(),
+                          self.config_screen.getLinkText())
 
         self.status = Status(self)
         self.log = QLabel("<a href='showlog'>Show Log</a>", self)
-        self.xml = QLabel("<a href='showrspec'>Show RSpec</a>", self)
+        self.rspec = QLabel("<a href='showlog'>Show RSpec</a>", self)
 
         hlayout = QHBoxLayout()
         hlayout.addWidget(self.status)
         hlayout.addStretch()
+        hlayout.addWidget(self.rspec)
         hlayout.addWidget(self.log)
-        hlayout.addWidget(self.xml)
 
         layout = QVBoxLayout()
         layout.addWidget(self.nav)
         layout.addWidget(self.screens)
         layout.addLayout(hlayout)
         self.setLayout(layout)
-        self.resize(800, 600)
+        self.resize(800, 500)
+
+        for link in (self.nav.main, self.nav.config):
+            self.connect(link, SIGNAL('linkActivated(QString)'),
+                         self.animateToScreen)
 
-        self.connect(self.nav.link, SIGNAL('linkActivated(QString)'),
-                     self.animateToScreen)
         self.connect(self.log, SIGNAL('linkActivated(QString)'),
                      self.showLogWindow)
-        self.connect(self.xml, SIGNAL('linkActivated(QString)'),
-                     self.showXmlWindow)
+        self.connect(self.rspec, SIGNAL('linkActivated(QString)'),
+                     self.showRSpecWindow)
 
     def redirectOutputToLog(self):
         self.logWindow.redirectOutput()
 
     def showLogWindow(self, link):
         self.logWindow.show()
-        self.logWindow.resize(500, 500)
+        self.logWindow.resize(800, 200)
         self.logWindow.raise_()
         self.logWindow.activateWindow()
 
-    def showXmlWindow(self, link):
-        self.xmlWindow.init_view()
-        self.xmlWindow.show()
-        self.xmlWindow.resize(500, 500)
-        self.xmlWindow.raise_()
-        self.xmlWindow.activateWindow()
+    def showRSpecWindow(self, link):
+        self.rspecWindow.show()
+        self.rspecWindow.resize(500, 640)
+        self.rspecWindow.raise_()
+        self.rspecWindow.activateWindow()
+
 
     def animatePixmap(self, y):
         self.pix.move(0, y)
@@ -125,9 +135,18 @@ class MainWindow(QWidget):
             self.next_screen = self.config_screen
         elif link == self.main_screen.name:
             self.next_screen = self.main_screen
-        
+
+        curr_screen = self.screens.currentWidget()
+
+        if self.next_screen == curr_screen:
+            self.setStatus("Already showing %s" % curr_screen.getTitleText(), timeout=1000)
+            return
+
+        # This is an optimization to have a smoother animation. We
+        # render the widget into a pixmap and animate that instead of
+        # moving the whole widget around.
         pixmap = QPixmap(self.screens.size())
-        self.screens.currentWidget().render(pixmap)
+        curr_screen.render(pixmap)
         self.screens.setCurrentWidget(self.pix)
         self.pix.setPixmap(pixmap)
 
@@ -146,13 +165,15 @@ class MainWindow(QWidget):
 
     def toConfigScreen(self):
         self.screens.setCurrentWidget(self.config_screen)
-        self.nav.setLink(self.main_screen.getLinkText())
         self.nav.setTitle(self.config_screen.getTitleText())
 
     def toMainScreen(self):
         self.screens.setCurrentWidget(self.main_screen)
-        self.nav.setLink(self.config_screen.getLinkText())
         self.nav.setTitle(self.main_screen.getTitleText())
 
     def setStatus(self, msg, timeout):
         self.status.set(msg, timeout)
+
+    def nodeSelectionChanged(self, hostname):
+        if self.rspecWindow.isVisible():
+            self.rspecWindow.showNode(hostname)