Index: simulator/plugins/treatmentstates/loader.py =================================================================== diff -u -rf921975179b1c1ad61d841b9db5976c00432fdcc -rf4523ffcaff0d27f7392c943f0a487fcb01a7d34 --- simulator/plugins/treatmentstates/loader.py (.../loader.py) (revision f921975179b1c1ad61d841b9db5976c00432fdcc) +++ simulator/plugins/treatmentstates/loader.py (.../loader.py) (revision f4523ffcaff0d27f7392c943f0a487fcb01a7d34) @@ -1,66 +1,114 @@ """ The Ultrafiltration ui loader """ +# Python import os -from simulator.dynamicloader import DynamicLoader +# Qt from PySide2 import QtWidgets from PySide2.QtCore import Slot -from dialin.squish import denaliMessages -from dialin.squish.denaliMessages import txStates +# parent +from simulator.dynamicloader import DynamicLoader +# hd Simulator +from dialin.ui.hd_simulator import HDSimulator, TXStates +# plugin specific +# -- none -- class Loader(DynamicLoader): """ The Ultrafiltration ui loader """ + tbReset: QtWidgets.QToolButton + tblSubMode: QtWidgets.QTableWidget tblUFStates: QtWidgets.QTableWidget tblSalineStates: QtWidgets.QTableWidget tblHeparinStates: QtWidgets.QTableWidget + tblRinsebackStates: QtWidgets.QTableWidget + tblRecirculateStates: QtWidgets.QTableWidget + tblBloodPrimeStates: QtWidgets.QTableWidget + tblTreatmentEndStates: QtWidgets.QTableWidget + tblTreatmentStopStates: QtWidgets.QTableWidget - def __init__(self): - super().__init__(os.path.dirname(__file__)) + def __init__(self, hd_simulator: HDSimulator): + super().__init__(os.path.dirname(__file__), hd_simulator) + print(" ---------- ", self.hd_simulator) def _init_loader(self): """ finds and creates widgets :return: none """ + self.tbReset = self.find_tool_button('tbReset') + self.tblSubMode = self.find_table_widget('tblSubMode') self.tblUFStates = self.find_table_widget('tblUFStates') self.tblSalineStates = self.find_table_widget('tblSalineStates') self.tblHeparinStates = self.find_table_widget('tblHeparinStates') + self.tblRinsebackStates = self.find_table_widget('tblRinsebackStates') + self.tblRecirculateStates = self.find_table_widget('tblRecirculateStates') + self.tblBloodPrimeStates = self.find_table_widget('tblBloodPrimeStates') + self.tblTreatmentEndStates = self.find_table_widget('tblTreatmentEndStates') + self.tblTreatmentStopStates = self.find_table_widget('tblTreatmentStopStates') def _init_connections(self): """ initializes the widgets connections :return: none """ + self.tbReset.clicked.connect(self._init_widgets) + self.tblSubMode.cellClicked.connect(self.do_treatment_states) self.tblUFStates.cellClicked.connect(self.do_treatment_states) self.tblSalineStates.cellClicked.connect(self.do_treatment_states) self.tblHeparinStates.cellClicked.connect(self.do_treatment_states) + self.tblRinsebackStates.cellClicked.connect(self.do_treatment_states) + self.tblRecirculateStates.cellClicked.connect(self.do_treatment_states) + self.tblBloodPrimeStates.cellClicked.connect(self.do_treatment_states) + self.tblTreatmentEndStates.cellClicked.connect(self.do_treatment_states) + self.tblTreatmentStopStates.cellClicked.connect(self.do_treatment_states) # apply/send the initial states - self.do_treatment_states() + # self.do_treatment_states() + @Slot() def _init_widgets(self): """ initializes the widgets' properties :return: none """ - self.tblSubMode.setCurrentCell(txStates.TREATMENT_DIALYSIS_STATE, 0) - self.tblUFStates.setCurrentCell(txStates.UF_OFF_STATE, 0) - self.tblSalineStates.setCurrentCell(txStates.SALINE_BOLUS_STATE_IDLE, 0) - self.tblHeparinStates.setCurrentCell(txStates.HEPARIN_STATE_OFF, 0) + self.tblSubMode.setCurrentCell(TXStates.TREATMENT_START_STATE, 0) + self.tblUFStates.setCurrentCell(TXStates.UF_OFF_STATE, 0) + self.tblSalineStates.setCurrentCell(TXStates.SALINE_BOLUS_STATE_IDLE, 0) + self.tblHeparinStates.setCurrentCell(TXStates.HEPARIN_STATE_OFF, 0) + self.tblRinsebackStates.setCurrentCell(TXStates.RINSEBACK_STOP_INIT_STATE, 0) + self.tblRecirculateStates.setCurrentCell(TXStates.TREATMENT_RECIRC_RECIRC_STATE, 0) + self.tblBloodPrimeStates.setCurrentCell(TXStates.BLOOD_PRIME_RAMP_STATE, 0) + self.tblTreatmentEndStates.setCurrentCell(TXStates.TREATMENT_END_WAIT_FOR_RINSEBACK_STATE, 0) + self.tblTreatmentStopStates.setCurrentCell(TXStates.TREATMENT_STOP_RECIRC_STATE, 0) @Slot() def do_treatment_states(self): """ the slot for saline bolus state change :return: none """ - sub_mode = self.tblSubMode.verticalHeaderItem(self.tblSubMode.currentRow()).text() - uf_state = self.tblUFStates.verticalHeaderItem(self.tblUFStates.currentRow()).text() - saline = self.tblSalineStates.verticalHeaderItem(self.tblSalineStates.currentRow()).text() - heparin = self.tblHeparinStates.verticalHeaderItem(self.tblHeparinStates.currentRow()).text() - denaliMessages.setTreatmentStatesData(sub_mode, uf_state, saline, heparin) + sub_mode = int(self.tblSubMode.verticalHeaderItem(self.tblSubMode.currentRow()).text()) + uf_state = int(self.tblUFStates.verticalHeaderItem(self.tblUFStates.currentRow()).text()) + saline = int(self.tblSalineStates.verticalHeaderItem(self.tblSalineStates.currentRow()).text()) + heparin = int(self.tblHeparinStates.verticalHeaderItem(self.tblHeparinStates.currentRow()).text()) + rinseback = int(self.tblRinsebackStates.verticalHeaderItem(self.tblRinsebackStates.currentRow()).text()) + recirculate = int(self.tblRecirculateStates.verticalHeaderItem(self.tblRecirculateStates.currentRow()).text()) + blood_prime = int(self.tblBloodPrimeStates.verticalHeaderItem(self.tblBloodPrimeStates.currentRow()).text()) + treatment_end = int(self.tblTreatmentEndStates.verticalHeaderItem(self.tblTreatmentEndStates.currentRow()).text()) + treatment_stop = int(self.tblTreatmentStopStates.verticalHeaderItem(self.tblTreatmentStopStates.currentRow()).text()) + self.hd_simulator.cmd_set_treatment_states_data( + sub_mode, + uf_state, + saline, + heparin, + rinseback, + recirculate, + blood_prime, + treatment_end, + treatment_stop + )