Skip to content

Commit

Permalink
Navigate to image/graph tabs when all alerts cleared
Browse files Browse the repository at this point in the history
  • Loading branch information
reilleya committed Dec 17, 2024
1 parent 545a8e1 commit f1c5198
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 3 deletions.
20 changes: 20 additions & 0 deletions uilib/widgets/grainPreviewWidget.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,11 @@ def __init__(self):
self.ui.tabRegression.setupImagePlot()
self.ui.tabAreaGraph.setupGraphPlot()

# Used to navigate back to the tab the user was on after they clear alerts
self.lastNonAlertTab = 1

self.ui.tabWidget.currentChanged.connect(self.onTabChanged)

self.previewReady.connect(self.updateView)

def loadGrain(self, grain):
Expand All @@ -31,8 +36,18 @@ def loadGrain(self, grain):

for alert in geomAlerts:
if alert.level == motorlib.simResult.SimAlertLevel.ERROR:
# Go to alerts tab and clear up graph/images
self.ui.tabWidget.setCurrentIndex(0)
self.ui.tabFace.cleanup()
self.ui.tabRegression.cleanup()
self.ui.tabAreaGraph.cleanup()
return

# If they were on the alert tab, go to their last image/graph tab. Otherwise, let them stay
if self.ui.tabWidget.currentIndex() == 0:
self.ui.tabWidget.setCurrentIndex(self.lastNonAlertTab)

# Generate the contents to show on the image/graph tabs
dataThread = Thread(target=self._genData, args=[grain])
dataThread.start()

Expand Down Expand Up @@ -60,7 +75,12 @@ def updateView(self, data):
self.ui.tabAreaGraph.cleanup()
self.ui.tabAreaGraph.showGraph(points)

def onTabChanged(self, tabIndex):
if tabIndex != 0:
self.lastNonAlertTab = tabIndex

def cleanup(self):
self.lastNonAlertTab = 1
self.ui.tabAlerts.clear()
self.ui.tabRegression.cleanup()
self.ui.tabFace.cleanup()
Expand Down
10 changes: 7 additions & 3 deletions uilib/widgets/nozzlePreviewWidget.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

from PyQt6.QtWidgets import QWidget, QApplication, QGraphicsScene, QGraphicsPolygonItem
from PyQt6.QtGui import QPolygonF, QBrush
from PyQt6.QtCore import QPointF, Qt
from PyQt6.QtCore import QPointF, Qt, QTimer

import motorlib
from ..views.NozzlePreview_ui import Ui_NozzlePreview
Expand Down Expand Up @@ -42,6 +42,7 @@ def loadNozzle(self, nozzle):

for alert in geomAlerts:
if alert.level == motorlib.simResult.SimAlertLevel.ERROR:
self.ui.tabWidget.setCurrentIndex(0)
return

convAngle = radians(nozzle.props['convAngle'].getValue())
Expand All @@ -67,7 +68,7 @@ def loadNozzle(self, nozzle):
else:
convLen = 0

nozzleBottomRad = max(exitRad*1.1, outerRad)
nozzleBottomRad = max(exitRad * 1.1, outerRad)

upperPoints = [
[throatLen, throatRad],
Expand All @@ -82,7 +83,10 @@ def loadNozzle(self, nozzle):

self.upper.setPolygon(upper)
self.lower.setPolygon(lower)
self.rescale()

self.ui.tabWidget.setCurrentIndex(1)

QTimer.singleShot(0, self.rescale) # I really don't know why this "delay" is needed

def rescale(self):
self.scene.setSceneRect(self.scene.itemsBoundingRect())
Expand Down

0 comments on commit f1c5198

Please sign in to comment.