""" The Ultrafiltration ui loader """ # Python import os # Qt from PySide2 import QtWidgets from PySide2.QtCore import Slot # 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 tblWaterSampleStates: QtWidgets.QTableWidget tblNoCartridgeSelfTestStates: QtWidgets.QTableWidget tblInstallationStates: QtWidgets.QTableWidget tblDrySelfTestStates: QtWidgets.QTableWidget tblPrimeStates: QtWidgets.QTableWidget tblPatientConnectionStates: QtWidgets.QTableWidget 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.tblWaterSampleStates = self.find_table_widget('tblWaterSampleStates') self.tblNoCartridgeSelfTestStates = self.find_table_widget('tblNoCartridgeSelfTestStates') self.tblInstallationStates = self.find_table_widget('tblInstallationStates') self.tblDrySelfTestStates = self.find_table_widget('tblDrySelfTestStates') self.tblPrimeStates = self.find_table_widget('tblPrimeStates') self.tblPatientConnectionStates = self.find_table_widget('tblPatientConnectionStates') 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.tblWaterSampleStates.cellClicked.connect(self.do_treatment_states) self.tblNoCartridgeSelfTestStates.cellClicked.connect(self.do_treatment_states) self.tblInstallationStates.cellClicked.connect(self.do_treatment_states) self.tblDrySelfTestStates.cellClicked.connect(self.do_treatment_states) self.tblPrimeStates.cellClicked.connect(self.do_treatment_states) self.tblPatientConnectionStates.cellClicked.connect(self.do_treatment_states) # apply/send the initial states # self.do_treatment_states() @Slot() def _init_widgets(self): """ initializes the widgets' properties :return: none """ self.tblSubMode.setCurrentCell(TXStates.TREATMENT_START_STATE, 0) self.tblWaterSampleStates.setCurrentCell(TXStates.UF_OFF_STATE, 0) self.tblNoCartridgeSelfTestStates.setCurrentCell(TXStates.SALINE_BOLUS_STATE_IDLE, 0) self.tblInstallationStates.setCurrentCell(TXStates.HEPARIN_STATE_OFF, 0) self.tblDrySelfTestStates.setCurrentCell(TXStates.RINSEBACK_STOP_INIT_STATE, 0) self.tblPrimeStates.setCurrentCell(TXStates.TREATMENT_RECIRC_RECIRC_STATE, 0) self.tblPatientConnectionStates.setCurrentCell(TXStates.BLOOD_PRIME_RAMP_STATE, 0) @Slot() def do_treatment_states(self): """ the slot for saline bolus state change :return: none """ 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 )