-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlist_indemnizaciones_calc.py
92 lines (73 loc) · 4.19 KB
/
list_indemnizaciones_calc.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
from list_indemnizaciones import *
import leew
class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):
def __init__(self, obj, obj2, *args, **kwargs):
QtWidgets.QMainWindow.__init__(self, *args, **kwargs)
self.setupUi(self)
self.obj = obj # para poder habilitar de nuevo el menu de listado de inasistencias
self.obj2 = obj2 # para poder habilitar de nuevo el menu de registro de ina
# print(self.obj)
# Carga de data
self.numero_ficha = ""
self.refresh_tabla()
self.borrar.setDisabled(1)
# conexiones
self.cancelar.clicked.connect(self.cerrar_cmd)
self.tableWidget.clicked.connect(self.cambia_nombre)
self.borrar.clicked.connect(self.borrar_cmd)
def borrar_cmd(self):
reply = QtWidgets.QMessageBox.question(self, "Para continuar", "Desea usted eliminar el registro Número: " + \
self.numero_ficha + "?"
, QtWidgets.QMessageBox.Yes, QtWidgets.QMessageBox.No)
if reply == QtWidgets.QMessageBox.Yes:
try:
leew.del_gen('worker.db', 'indemnizaciones', 'id_indem', f'{self.numero_ficha} AND computado = 0')
# self.close()
QtWidgets.QMessageBox.information(self, "Atención", "Registro borrado satisfactoriamente",
QtWidgets.QMessageBox.Ok)
except:
QtWidgets.QMessageBox.warning(self, "Error fatal", "Error en operación",
QtWidgets.QMessageBox.Ok)
self.refresh_tabla()
self.borrar.setText('Borrar') # esto para que el boton se vuelva a desbilitar
self.borrar.setDisabled(1)
def refresh_tabla(self):
lista_id_indemnizaciones = leew.consulta_lista('worker.db', 'id_indem', 'indemnizaciones', 'computado', '"0"')
n = len(lista_id_indemnizaciones)
self.tableWidget.setRowCount(n)
# estas lineas de abajo son para estirar las columnas
header = self.tableWidget.horizontalHeader()
header.setSectionResizeMode(0, QtWidgets.QHeaderView.ResizeToContents)
header.setSectionResizeMode(1, QtWidgets.QHeaderView.ResizeToContents)
header.setSectionResizeMode(2, QtWidgets.QHeaderView.ResizeToContents)
header.setSectionResizeMode(3, QtWidgets.QHeaderView.ResizeToContents)
cont = 0
for id_indem in lista_id_indemnizaciones:
id_indem = str(id_indem)
item = id_indem
self.tableWidget.setItem(cont, 0, QtWidgets.QTableWidgetItem(item))
id_trab = leew.consulta_gen('worker.db', 'id', 'indemnizaciones', 'id_indem', id_indem)
nombre = leew.consulta_gen('worker.db', 'Nombre', 'info', 'id', f'"{id_trab}"')
apellido = leew.consulta_gen('worker.db', 'Apellido', 'info', 'id', f'"{id_trab}"')
cedula = leew.consulta_gen('worker.db', 'Identificacion', 'info', 'id', f'"{id_trab}"')
trabajador = f"{id_trab} {nombre} {apellido} {cedula}"
self.tableWidget.setItem(cont, 1, QtWidgets.QTableWidgetItem(trabajador))
item = leew.consulta_gen('worker.db', 'fecha_doc', 'indemnizaciones', 'id_indem', id_indem)
self.tableWidget.setItem(cont, 2, QtWidgets.QTableWidgetItem(item))
item = leew.consulta_gen('worker.db', 'monto', 'indemnizaciones', 'id_indem', id_indem)
self.tableWidget.setItem(cont, 3, QtWidgets.QTableWidgetItem(str(item)))
cont = cont + 1
def cambia_nombre(self):
self.borrar.setDisabled(0)
for currentQTableWidgetItem in self.tableWidget.selectedItems():
self.numero_ficha = self.tableWidget.item(currentQTableWidgetItem.row(), 0).text()
self.borrar.setText("Borrar: " + self.numero_ficha)
def cerrar_cmd(self):
self.close()
self.parentWidget().close()
def closeEvent(self, QCloseEvent):
# esta funcion es para que el boton cerrar y la X de la ventana reactiven el menu de listado de trabajadores
self.close()
self.parentWidget().close()
self.obj.setDisabled(False)
self.obj2.setDisabled(False)