class MySearchWidget(object): def __init__(self): # 搜索关键列的列表 一般大小为3 self.select_conditions = [] # 在setupUi中进行重写 self.queryModel = MySearchTableModel("T_Knowladge_Base_Mangement", ["Num"]) self.totalPageLabel = QtWidgets.QLabel() self.totalPageLabel.setObjectName("totalPageLabel") self.jumpEdit = QtWidgets.QLineEdit() self.jumpEdit.setMaximumSize(QtCore.QSize(50, 50)) def setupUi(self, Form): pass def retranslateUi(self, Form): pass def updateUI(self): """ hsj 跳转的后更新 :return: """ self.totalPageLabel.setText("/ " + str(self.queryModel.totalPage) + " 页") self.jumpEdit.setText(str(self.queryModel.currentPage + 1)) def bindButton(self): """ hsj 绑定按钮 :return: """ pass def deleteButtonEvent(self): """ hsj 删除批次按钮绑定事件 :return: """ # print(self.queryModel.checkList.count("Checked")) # 如果没有选中数据,则提示无数据 if self.queryModel.checkList.count("Checked") == 0: QMessageBox.warning(QDialog(), "警告", "没有数据被选中,请选中后重试!", QMessageBox.Yes, QMessageBox.Yes) return a = QMessageBox.information(QDialog(), "提示", "是否确认删除?", QMessageBox.Yes, QMessageBox.No) if a == QMessageBox.No: return self.queryModel.delete() self.queryModel.update() def addButtonEvent(self, Widget): """ hsj 新建 :param Widget: 要显示的窗体 :return: """ form = QDialog() w = Widget w.setupUi(form) form.show() a = form.exec_() # 如果对话框关闭,则对查询数据进行更行 if a == 0: self.queryModel.refreshPage() self.queryModel.update() self.updateUI() def selectButtonEvent(self, Widget): """ hsj 根据批次中的产品Id查询产品详细信息 :param Widget: 要显示的窗体 :return: """ # 判断复选框是否只选中一个 a = self.isCorrect() if a == 0: return result = self.queryModel.selectSingleTableForeign() #print('re:',result) productDiglog = Widget form = QDialog() productDiglog.setupUi(form) productDiglog.setData(result) form.show() form.exec() def updateButtonEvent(self, Widget): """ hsj 修改产品批次信息 :param Widget: 要显示的窗体 :return: """ # 判断复选框是否只选中一个 a = self.isCorrect() if a == 0: return result = self.queryModel.selectSingleTable() batchDialog = Widget form = QDialog() batchDialog.setupUi(form) batchDialog.updateData(result, self.queryModel) form.show() a = form.exec() # 如果对话框关闭,则对查询数据进行更行 if a == 0: self.queryModel.refreshPage() self.queryModel.update() def preButtonEvent(self): """ hsj 上一页按钮事件 :return: """ if self.queryModel.currentPage == 0: QMessageBox.information(QDialog(), "提示", "已经是第一页!", QMessageBox.Yes, QMessageBox.Yes) return else: self.queryModel.prePage() self.queryModel.update() self.updateUI() def nextButtonEvent(self): """ hsj 下一页按钮事件 :return: """ if (self.queryModel.currentPage + 1) == self.queryModel.totalPage: QMessageBox.information(QDialog(), "提示", "已经是最后一页!", QMessageBox.Yes, QMessageBox.Yes) return else: self.queryModel.nextPage() self.queryModel.update() self.updateUI() def jumpButtonEvent(self): """ hsj 跳转按钮事件 :return: """ objectPage = self.jumpEdit.text() if not objectPage.isdigit(): QMessageBox.information(QDialog(), "提示", "跳转输入的不是数字,请正确填写后重试!", QMessageBox.Yes, QMessageBox.Yes) return else: objectPage = int(objectPage) if objectPage <= 0 or objectPage > self.queryModel.totalPage: QMessageBox.information(QDialog(), "提示", "跳转输入超出范围,请正确填写后重试!", QMessageBox.Yes, QMessageBox.Yes) return else: self.queryModel.currentPage = objectPage - 1 self.queryModel.setCurrentData() self.queryModel.update() self.updateUI() def searchButtonEvent(self): """ hsj 输入查询条件查询按钮事件 :return: """ content = self.searchEdit.text() if content == "": print(111) self.queryModel.refreshPage() self.queryModel.update() else: n = self.comboBox.currentIndex() self.queryModel.searchTable(self.select_conditions[n], content) self.updateUI() def isCorrect(self): """ hsj 判断复选框是否选中一个数据 :return: """ if self.queryModel.checkList.count("Checked") == 0: QMessageBox.warning(QDialog(), "警告", "没有数据被选中,请选中后重试!", QMessageBox.Yes, QMessageBox.Yes) return 0 elif self.queryModel.checkList.count("Checked") > 1: QMessageBox.warning(QDialog(), "警告", "数据过多,请选中一条后重试!", QMessageBox.Yes, QMessageBox.Yes) return 0 else: return 1
class MySearchWidget(object): def __init__(self): # 搜索关键列的列表 一般大小为3 self.select_conditions = [] # 在setupUi中进行重写 self.queryModel = MySearchTableModel("T_Product_New", ["ProductID"]) self.totalPageLabel = QtWidgets.QLabel() self.totalPageLabel.setObjectName("totalPageLabel") self.jumpEdit = QtWidgets.QLineEdit() self.jumpEdit.setMaximumSize(QtCore.QSize(50, 50)) def setupUi(self, Form): pass def retranslateUi(self, Form): pass def updateUI(self): """ hsj 跳转的后更新 :return: """ self.totalPageLabel.setText("/ " + str(self.queryModel.totalPage) + " 页") self.jumpEdit.setText(str(self.queryModel.currentPage + 1)) def bindButton(self): """ hsj 绑定按钮 :return: """ pass def deleteButtonEvent(self): """ hsj 删除批次按钮绑定事件 :return: """ # print(self.queryModel.checkList.count("Checked")) # 如果没有选中数据,则提示无数据 logger = logToFile() UserId = getCurrentUserId() data = self.queryModel.getAllCheckedData() tableName = self.queryModel.table logger.info("用户:" + str(UserId) + " 点击了删除按钮,试图删除 " + str(tableName) + " 表中的数据:" + str(data)) if self.queryModel.checkList.count("Checked") == 0: QMessageBox.warning(QDialog(), "警告", "没有数据被选中,请选中后重试!", QMessageBox.Yes, QMessageBox.Yes) logger.info("用户:" + str(UserId) + " 删除失败(没有选择要删除的数据)") return a = QMessageBox.information(QDialog(), "提示", "是否确认删除?", QMessageBox.Yes, QMessageBox.No) if a == QMessageBox.No: logger.info("用户:" + str(UserId) + " 取消了删除") return logger.info("用户:" + str(UserId) + " 删除了" + str(tableName) + "中选中的数据:" + str(data)) self.queryModel.delete() self.queryModel.update() self.updateBottomWidget() def addButtonEvent(self, Widget): """ hsj 新建 :param Widget: 要显示的窗体 :return: """ # logger = logToFile() # UserId = getCurrentUserId() # tableName = self.queryModel.table # logger.info("用户:" + str(UserId) + " 点击了添加按钮,试图在 " + str(tableName) + " 表中添加数据项") form = QDialog() w = Widget w.setupUi(form) form.show() a = form.exec_() # 如果对话框关闭,则对查询数据进行更行 if a == 0: self.queryModel.refreshPage() self.queryModel.update() self.updateUI() # def selectButtonEvent(self, Widget): # """ # hsj 根据批次中的产品Id查询产品详细信息 # :param Widget: 要显示的窗体 # :return: # """ # # 判断复选框是否只选中一个 # a = self.isCorrect() # if a == 0: # return # result = self.queryModel.selectSingleTableForeign() # productDiglog = Widget # form = QDialog() # productDiglog.setupUi(form) # productDiglog.setData(result) # form.show() # form.exec() def updateButtonEvent(self, Widget): """ hsj 修改信息 :param Widget: 要显示的窗体 :return: """ # 判断复选框是否只选中一个 a = self.isCorrect() if a == 0: return result = self.queryModel.selectSingleTable() logger = logToFile() UserId = getCurrentUserId() tableName = self.queryModel.table logger.info("用户:" + str(UserId) + " 点击了更新按钮,试图更新 " + str(tableName) + " 表中的原数据:" + str(result)) batchDialog = Widget form = QDialog() batchDialog.setupUi(form) batchDialog.updateData(result, self.queryModel) form.show() a = form.exec() # 如果对话框关闭,则对查询数据进行更行 if a == 0: self.queryModel.refreshPage() self.queryModel.update() def selectDetailButtonEvent(self, Widget): """ hsj 修改产品批次信息 :param Widget: 要显示的窗体 :return: """ # 判断复选框是否只选中一个 a = self.isCorrect() if a == 0: return result = self.queryModel.selectSingleTable() batchDialog = Widget form = QDialog() batchDialog.setupUi(form) batchDialog.showData(result, self.queryModel) form.show() a = form.exec() # 如果对话框关闭,则对查询数据进行更行 if a == 0: self.queryModel.refreshPage() self.queryModel.update() def preButtonEvent(self): """ hsj 上一页按钮事件 :return: """ if self.queryModel.currentPage == 0: QMessageBox.information(QDialog(), "提示", "已经是第一页!", QMessageBox.Yes, QMessageBox.Yes) return else: self.queryModel.prePage() self.queryModel.update() self.updateUI() def nextButtonEvent(self): """ hsj 下一页按钮事件 :return: """ if (self.queryModel.currentPage + 1) >= self.queryModel.totalPage: QMessageBox.information(QDialog(), "提示", "已经是最后一页!", QMessageBox.Yes, QMessageBox.Yes) return else: self.queryModel.nextPage() self.queryModel.update() self.updateUI() def jumpButtonEvent(self): """ hsj 跳转按钮事件 :return: """ objectPage = self.jumpEdit.text() if not objectPage.isdigit(): QMessageBox.information(QDialog(), "提示", "跳转输入的不是数字,请正确填写后重试!", QMessageBox.Yes, QMessageBox.Yes) return else: objectPage = int(objectPage) if objectPage <= 0 or objectPage > self.queryModel.totalPage: QMessageBox.information(QDialog(), "提示", "跳转输入超出范围,请正确填写后重试!", QMessageBox.Yes, QMessageBox.Yes) return else: self.queryModel.currentPage = objectPage - 1 self.queryModel.setCurrentData() self.queryModel.update() self.updateUI() def searchButtonEvent(self): """ hsj 输入查询条件查询按钮事件 :return: """ content = self.searchEdit.text() if content == "": self.queryModel.refreshPage() self.queryModel.update() else: n = self.comboBox.currentIndex() self.queryModel.searchTable(self.select_conditions[n], content) self.updateUI() def isCorrect(self): """ hsj 判断复选框是否选中一个数据 :return: """ if self.queryModel.checkList.count("Checked") == 0: QMessageBox.warning(QDialog(), "警告", "没有数据被选中,请选中后重试!", QMessageBox.Yes, QMessageBox.Yes) return 0 elif self.queryModel.checkList.count("Checked") > 1: QMessageBox.warning(QDialog(), "警告", "数据过多,请选中一条后重试!", QMessageBox.Yes, QMessageBox.Yes) return 0 else: return 1 def updateBottomWidget(self): # 更新查询界面底下控件 self.totalPageLabel.setText("/ " + str(self.queryModel.totalPage) + " 页") self.jumpEdit.setText(str(self.queryModel.currentPage + 1))