class ListaClientes: def __init__(self): self.rc = RepositorioClientes() self.lista = self.rc.get_all() def nuevo_cliente_corporativo(self, nombre_empresa, nombre_contacto, telefono_contacto, telefono, mail): c = ClienteCorporativo(nombre_empresa, nombre_contacto, telefono_contacto, telefono, mail) c.id_cliente = self.rc.store(c) if c.id_cliente == 0: return None else: self.lista.append(c) return c def nuevo_cliente_particular(self, nombre, apellido, telefono, mail): c = ClienteParticular(nombre, apellido, telefono, mail) c.id_cliente = self.rc.store(c) if c.id_cliente == 0: return None else: self.lista.append(c) return c def buscar_cliente(self, id_cliente): '''Recibe un id del cliente y lo busca en la lista, devuelve el cliente''' for c in self.lista: if c.id_cliente == id_cliente: break return c def eliminar_cliente(self, id_cliente): c = self.buscar_cliente(id_cliente) eliminado = self.rc.delete(c) if eliminado: self.lista.remove(c) return True else: return False def modificar_cliente(self, cliente): modificado = self.rc.update(cliente) if modificado: self.lista = self.rc.get_all() return True else: return False
class Product: nombre_bd = 'base_datos.sqlite' def __init__(self, window): self.wind = window self.wind.title('Sistema de gestion de trabajos') self.rc = RepositorioClientes() self.lista_clientes = self.rc.get_all_particulares() self.rt = RepositorioTrabajos() #Frame frame = LabelFrame(self.wind, text='Menu principal') frame.grid(row=0, column=0, columnspan=8, pady=20) # Botonera ttk.Button(frame, text="Agregar cliente particular", command=self.add_clientspart_window).grid(row=1, column=4, columnspan=2, sticky=W + E) ttk.Button(frame, text="Agregar cliente corporativo", command=self.add_clientscorp_window).grid(row=2, column=4, columnspan=2, sticky=W + E) ttk.Button(frame, text="Agregar un trabajo", command=self.add_works_window).grid(row=3, column=4, columnspan=2, sticky=W + E) # Mensajes de salida self.message = Label(text='', fg='red') self.message.grid(row=8, column=0, columnspan=2, sticky=W + E) # Tabla self.tree = ttk.Treeview(height=5, columns=("#1", "#2", "#3", '#4')) self.tree.grid(row=9, column=0, columnspan=6) self.tree.heading('#0', text='Nombre', anchor=CENTER) self.tree.heading('#1', text='Apellido', anchor=CENTER) self.tree.heading('#2', text='Teléfono', anchor=CENTER) self.tree.heading('#3', text='Mail', anchor=CENTER) self.tree.heading('#4', text='ID', anchor=CENTER) # Tabla clientes corporativos self.tree2 = ttk.Treeview(height=5, columns=("#1", "#2", "#3", "#4", '#5')) self.tree2.grid(row=11, column=0, columnspan=6) self.tree2.heading('#0', text='Nombre de la Empresa', anchor=CENTER) self.tree2.heading('#1', text='Nombre de Contacto', anchor=CENTER) self.tree2.heading('#2', text='Teléfono', anchor=CENTER) self.tree2.heading('#3', text='Teléfono de contacto', anchor=CENTER) self.tree2.heading('#4', text='Mail', anchor=CENTER) self.tree2.heading('#5', text='ID', anchor=CENTER) # Tabla trabajos self.tree3 = ttk.Treeview(height=5, columns=("#1", "#2", "#3", "#4", '#5', '#6')) self.tree3.grid(row=13, column=0, columnspan=6) self.tree3.heading('#0', text='ID de trabajo', anchor=CENTER) self.tree3.heading('#1', text='Nombre de cliente', anchor=CENTER) self.tree3.heading('#2', text='Fecha de Ingreso', anchor=CENTER) self.tree3.heading('#3', text='Fecha de Entrega Propuesta', anchor=CENTER) self.tree3.heading('#4', text='Fecha de Entrega Real', anchor=CENTER) self.tree3.heading('#5', text='Descripción', anchor=CENTER) self.tree3.heading('#6', text='Entregado', anchor=CENTER) # Botonera 2 ttk.Button(text="Editar cliente particular", command=self.edit_clients_part_window).grid(row=10, column=1, columnspan=2) ttk.Button(text="Eliminar cliente particular", command=self.delete_clients_part).grid(row=10, column=3, columnspan=2) ttk.Button(text="Editar cliente corporativo", command=self.edit_clients_corp_window).grid(row=12, column=0, columnspan=3) ttk.Button(text="Eliminar cliente corporativo", command=self.delete_clients_corp).grid(row=12, column=3, columnspan=3) ttk.Button(text="Finalizar trabajo", command=self.trabajo_finalizado).grid(row=14, column=0, columnspan=2) ttk.Button(text="Entregar el trabajo", command=self.trabajo_entregado).grid(row=14, column=1, columnspan=2) ttk.Button(text="Modificar datos del trabajo", command=self.edit_trabajos_window).grid(row=14, column=2, columnspan=2) ttk.Button(text="Cancelar trabajo", command=self.eliminar_trabajo_confirmacion).grid( row=14, column=3, columnspan=2) ttk.Button(text="Informe de trabajos pendientes", command=self.informe).grid(row=14, column=4, columnspan=2) self.get_clients() self.get_works() def run_query(self, query, parameters=()): with sqlite3.connect(self.nombre_bd) as Conectar: cursor = Conectar.cursor() resultado = cursor.execute(query, parameters) Conectar.commit() return resultado def get_clients(self, lista=None): # Limpio la tabla antes de arrancar la query records = self.tree.get_children() records2 = self.tree2.get_children() for element in records: self.tree.delete(element) for element2 in records2: self.tree2.delete(element2) # Muestro clientes query = 'SELECT * FROM cliente JOIN cliente_particular ON cliente.id=cliente_particular.id_cliente ORDER BY id ASC' query1 = 'SELECT * FROM cliente JOIN cliente_corporativo ON cliente.id=cliente_corporativo.id_cliente ORDER BY id ASC' db_rows = self.run_query(query) db_rows1 = self.run_query(query1) #Particulares for row in db_rows: self.tree.insert('', 0, text=(row[4]), values=(row[5], row[1], row[2], row[3])) #Corporativos for fila in db_rows1: self.tree2.insert('', 0, text=(fila[4]), values=(fila[5], fila[1], fila[6], fila[2], fila[3])) def get_works(self, lista=None): # Limpio la tabla antes de arrancar la query registros = self.tree3.get_children() for element3 in registros: self.tree3.delete(element3) # Muestro los trabajos query = 'SELECT trabajos.id_cliente, trabajos.fecha_ingreso, trabajos.fecha_entrega_propuesta, cliente.id,\ trabajos.fecha_entrega_real, trabajos.descripcion, trabajos.retirado, trabajos.id, \ cliente_corporativo.nombre_contacto \ FROM trabajos \ JOIN cliente ON trabajos.id_cliente = cliente.id \ JOIN cliente_corporativo ON cliente.id = cliente_corporativo.id_cliente' query2 = 'SELECT trabajos.id_cliente, trabajos.fecha_ingreso, trabajos.fecha_entrega_propuesta, cliente.id,\ trabajos.fecha_entrega_real, trabajos.descripcion, trabajos.retirado, trabajos.id, \ cliente_particular.nombre,cliente_particular.apellido \ FROM trabajos \ JOIN cliente ON trabajos.id_cliente = cliente.id \ JOIN cliente_particular ON cliente.id = cliente_particular.id_cliente' filas_db = self.run_query(query) filas2_db = self.run_query(query2) for filas in filas_db: self.tree3.insert('', 0, text=(filas[7]), values=(filas[8], filas[1], filas[2], filas[4], filas[5], filas[6])) for filas2 in filas2_db: self.tree3.insert('', 0, text=(filas2[7]), values=(filas2[8] + ' ' + filas2[9], filas2[1], filas2[2], filas2[4], filas2[5], filas2[6])) def validations_particular(self): '''Valida que no haya espacios en blanco''' return len(self.name.get()) != 0 and len( self.surname.get()) != 0 and len(self.phone.get()) != 0 and len( self.mail.get()) != 0 def validations_corporativo(self): '''Valida que no haya espacios en blanco''' return len(self.company_name.get()) != 0 and len( self.contact_name.get()) != 0 and len( self.contact_phone.get()) != 0 and len( self.phone.get()) != 0 and len(self.mail.get()) != 0 def add_clientspart_window(self): self.add_window_part = Toplevel() self.add_window_part.title = 'Agregar cliente' # Input Nombre Label(self.add_window_part, text='Nombre: ').grid(row=1, column=0) Entry(self.add_window_part, textvariable=StringVar(self.add_window_part), state='readonly') self.name = Entry(self.add_window_part) self.name.focus() self.name.grid(row=1, column=1) # Input Apellido Label(self.add_window_part, text='Apellido: ').grid(row=2, column=0) Entry(self.add_window_part) self.surname = Entry(self.add_window_part) self.surname.grid(row=2, column=1) # Input Telefono Label(self.add_window_part, text='Telefono: ').grid(row=3, column=0) Entry(self.add_window_part) self.phone = Entry(self.add_window_part) self.phone.grid(row=3, column=1) # Input Mail Label(self.add_window_part, text='Mail: ').grid(row=4, column=0) Entry(self.add_window_part) self.mail = Entry(self.add_window_part) self.mail.grid(row=4, column=1) # Botonera ttk.Button(self.add_window_part, text="Guardar", command=self.add_client_particular).grid(row=5, columnspan=2, sticky=W + E) def add_clientscorp_window(self): self.add_window_corp = Toplevel() self.add_window_corp.title = 'Agregar cliente corporativo' # Input Nombre Empresa Label(self.add_window_corp, text='Nombre Empresa: ').grid(row=1, column=0) Entry(self.add_window_corp, textvariable=StringVar(self.add_window_corp), state='readonly') self.company_name = Entry(self.add_window_corp) self.company_name.focus() self.company_name.grid(row=1, column=1) # Input Nombre Contacto Label(self.add_window_corp, text='Nombre Contacto: ').grid(row=2, column=0) Entry(self.add_window_corp) self.contact_name = Entry(self.add_window_corp) self.contact_name.grid(row=2, column=1) # Input Telefono Label(self.add_window_corp, text='Telefono: ').grid(row=3, column=0) Entry(self.add_window_corp) self.phone = Entry(self.add_window_corp) self.phone.grid(row=3, column=1) # Input Telefono de Contacto Label(self.add_window_corp, text='Telefono de contacto: ').grid(row=4, column=0) Entry(self.add_window_corp) self.contact_phone = Entry(self.add_window_corp) self.contact_phone.grid(row=4, column=1) # Input Mail Label(self.add_window_corp, text='Mail: ').grid(row=5, column=0) Entry(self.add_window_corp) self.mail = Entry(self.add_window_corp) self.mail.grid(row=5, column=1) # Botonera ttk.Button(self.add_window_corp, text="Guardar", command=self.add_client_corporativo).grid(row=6, columnspan=2, sticky=W + E) def add_client_particular(self): #si las validaciones son correctas if self.validations_particular(): parameters = ClienteParticular(self.name.get(), self.surname.get(), self.phone.get(), self.mail.get()) parameters.id_cliente = self.rc.store(parameters) self.lista_clientes.append(parameters) self.message[ 'text'] = 'El cliente personal {0} {1} ha sido añadido correctamente'.format( self.name.get(), self.surname.get()) self.name.delete(0, END) self.surname.delete(0, END) self.phone.delete(0, END) self.mail.delete(0, END) self.get_clients() return parameters else: self.message[ 'text'] = 'Nombre, Apellido, Teléfono y Mail son requeridos' def add_client_corporativo(self): #si las validaciones son correctas if self.validations_corporativo(): parameters = ClienteCorporativo(self.company_name.get(), self.contact_name.get(), self.contact_phone.get(), self.phone.get(), self.mail.get()) parameters.id_cliente = self.rc.store(parameters) self.lista_clientes.append(parameters) self.message[ 'text'] = 'El cliente corporativo {0} de la empresa {1} ha sido añadido correctamente'.format( self.contact_name.get(), self.company_name.get()) self.company_name.delete(0, END) self.contact_name.delete(0, END) self.contact_phone.delete(0, END) self.phone.delete(0, END) self.mail.delete(0, END) self.get_clients() return parameters else: self.message[ 'text'] = 'Nombre, Apellido, Teléfono y Mail son requeridos' def edit_clients_part_window(self): '''Ventana para editar un cliente particular''' self.message['text'] = '' try: self.tree.item(self.tree.selection())['text'][0] except IndexError: self.message['text'] = 'Por favor, seleccione un registro' return old_name = self.tree.item(self.tree.selection())['text'] old_surname = self.tree.item(self.tree.selection())['values'][0] old_phone = self.tree.item(self.tree.selection())['values'][1] old_mail = self.tree.item(self.tree.selection())['values'][2] id_cliente1 = self.tree.item(self.tree.selection())['values'][3] self.edit_window = Toplevel() self.edit_window.title = 'Editar cliente' # ID Label(self.edit_window, text='ID: ').grid(row=1, column=1) Entry(self.edit_window, textvariable=StringVar(self.edit_window, value=id_cliente1), state='readonly').grid(row=1, column=2) # Nombre Anterior Label(self.edit_window, text='Nombre anterior: ').grid(row=2, column=1) Entry(self.edit_window, textvariable=StringVar(self.edit_window, value=old_name), state='readonly').grid(row=2, column=2) # Nombre Actual Label(self.edit_window, text='Nombre actual: ').grid(row=3, column=1) new_name = Entry(self.edit_window) new_name.grid(row=3, column=2) # Apellido Anterior Label(self.edit_window, text='Apellido Anterior: ').grid(row=4, column=1) Entry(self.edit_window, textvariable=StringVar(self.edit_window, value=old_surname), state='readonly').grid(row=4, column=2) # Nuevo Apellido Label(self.edit_window, text='Apellido Actual: ').grid(row=5, column=1) new_surname = Entry(self.edit_window) new_surname.grid(row=5, column=2) # Telefono Anterior Label(self.edit_window, text='Telefono Anterior: ').grid(row=6, column=1) Entry(self.edit_window, textvariable=StringVar(self.edit_window, value=old_phone), state='readonly').grid(row=6, column=2) # Nuevo Telefono Label(self.edit_window, text='Telefono Actual: ').grid(row=7, column=1) new_phone = Entry(self.edit_window) new_phone.grid(row=7, column=2) # Mail anterior Label(self.edit_window, text='Mail Anterior: ').grid(row=8, column=1) Entry(self.edit_window, textvariable=StringVar(self.edit_window, value=old_mail), state='readonly').grid(row=8, column=2) # Nuevo mail Label(self.edit_window, text='Mail Actual: ').grid(row=9, column=1) new_mail = Entry(self.edit_window) new_mail.grid(row=9, column=2) # Botón de guardar cambios ttk.Button(self.edit_window, text='Actualizar', command=lambda: self.edit_clients_part( new_name.get(), new_surname.get(), new_phone.get(), new_mail.get(), id_cliente1)).grid(row=10, columnspan=3, sticky=W + E) def edit_clients_part(self, new_name, new_surname, new_phone, new_mail, id_cliente): '''Editar un cliente particular''' parameters = ClienteParticular(new_name, new_surname, new_phone, new_mail, id_cliente) self.rc.update(parameters) self.edit_window.destroy() self.message[ 'text'] = 'El cliente {0} {1} sido editado correctamente'.format( new_name, new_surname) self.get_clients() def edit_clients_corp_window(self): '''Ventana para editar un cliente corporativo''' self.message['text'] = '' try: self.tree2.item(self.tree2.selection())['text'][0] except IndexError: self.message['text'] = 'Por favor, seleccione un registro' return old_company_name = self.tree2.item(self.tree2.selection())['text'] old_contact_name = self.tree2.item(self.tree2.selection())['values'][0] old_contact_phone = self.tree2.item( self.tree2.selection())['values'][1] old_phone = self.tree2.item(self.tree2.selection())['values'][2] old_mail = self.tree2.item(self.tree2.selection())['values'][3] id_cliente = self.tree2.item(self.tree2.selection())['values'][4] self.edit_window2 = Toplevel() self.edit_window2.title = 'Editar cliente' # ID Label(self.edit_window2, text='ID: ').grid(row=0, column=1) Entry(self.edit_window2, textvariable=StringVar(self.edit_window2, value=id_cliente), state='readonly').grid(row=0, column=2) # Nombre de la empresa Anterior Label(self.edit_window2, text='Nombre de la empresa anterior: ').grid(row=1, column=1) Entry(self.edit_window2, textvariable=StringVar(self.edit_window2, value=old_company_name), state='readonly').grid(row=1, column=2) # Nombre de la empresa Actual Label(self.edit_window2, text='Nombre de la empresa actual: ').grid(row=2, column=1) new_company_name = Entry(self.edit_window2) new_company_name.grid(row=2, column=2) # Nombre de contacto Anterior Label(self.edit_window2, text='Nombre de contacto anterior: ').grid(row=3, column=1) Entry(self.edit_window2, textvariable=StringVar(self.edit_window2, value=old_contact_name), state='readonly').grid(row=3, column=2) # Nombre de contacto Actual Label(self.edit_window2, text='Nombre de contacto actual: ').grid(row=4, column=1) new_contact_name = Entry(self.edit_window2) new_contact_name.grid(row=4, column=2) # Telefono Anterior Label(self.edit_window2, text='Telefono Anterior: ').grid(row=5, column=1) Entry(self.edit_window2, textvariable=StringVar(self.edit_window2, value=old_phone), state='readonly').grid(row=5, column=2) # Nuevo Telefono Label(self.edit_window2, text='Telefono Actual: ').grid(row=6, column=1) new_phone = Entry(self.edit_window2) new_phone.grid(row=6, column=2) # Telefono de contacto Anterior Label(self.edit_window2, text='Telefono de contacto anterior: ').grid(row=7, column=1) Entry(self.edit_window2, textvariable=StringVar(self.edit_window2, value=old_contact_phone), state='readonly').grid(row=7, column=2) # Telefono de contacto actual Label(self.edit_window2, text='Telefono de contacto actual: ').grid(row=8, column=1) new_contact_phone = Entry(self.edit_window2) new_contact_phone.grid(row=8, column=2) # Mail Anterior Label(self.edit_window2, text='Mail anterior: ').grid(row=9, column=1) Entry(self.edit_window2, textvariable=StringVar(self.edit_window2, value=old_mail), state='readonly').grid(row=9, column=2) # Mail actual Label(self.edit_window2, text='Mail actual: ').grid(row=10, column=1) new_mail = Entry(self.edit_window2) new_mail.grid(row=10, column=2) # Botón de guardar cambios ttk.Button( self.edit_window2, text='Actualizar', command=lambda: self.edit_clients_corp(new_company_name.get( ), new_contact_name.get(), new_contact_phone.get(), new_phone.get( ), new_mail.get(), id_cliente)).grid(row=11, columnspan=3, sticky=W + E) def edit_clients_corp(self, new_company_name, new_contact_name, new_contact_phone, new_phone, new_mail, id_cliente): '''Editar un cliente corporativo''' parameters = ClienteCorporativo(new_company_name, new_contact_name, new_contact_phone, new_phone, new_mail, id_cliente) self.rc.update(parameters) self.edit_window2.destroy() self.message[ 'text'] = 'El cliente {0} de la empresa {1} ha sido editado correctamente'.format( new_contact_name, new_company_name) self.get_clients() def delete_clients_part(self): '''Eliminar a un cliente particular''' name = self.tree.item(self.tree.selection())['text'] surname = self.tree.item(self.tree.selection())['values'][0] phone = self.tree.item(self.tree.selection())['values'][1] mail = self.tree.item(self.tree.selection())['values'][2] id_cliente1 = self.tree.item(self.tree.selection())['values'][3] try: self.tree.item(self.tree.selection())['text'] except IndexError: self.message['text'] = 'Seleccione a un cliente' name = self.tree.item(self.tree.selection())['text'] parameters = ClienteParticular(name, surname, phone, mail, id_cliente1) self.rc.delete(parameters) self.message[ 'text'] = 'El cliente {0} {1} sido editado correctamente'.format( name, surname) self.get_clients() def delete_clients_corp(self): '''Eliminar a un cliente corporativo''' company_name = self.tree2.item(self.tree2.selection())['text'] contact_name = self.tree2.item(self.tree2.selection())['values'][0] contact_phone = self.tree2.item(self.tree2.selection())['values'][1] phone = self.tree2.item(self.tree2.selection())['values'][2] mail = self.tree2.item(self.tree2.selection())['values'][3] id_cliente1 = self.tree2.item(self.tree2.selection())['values'][4] try: self.tree.item(self.tree2.selection())['text'] except IndexError: self.message['text'] = 'Seleccione a un cliente' parameters = ClienteCorporativo(company_name, contact_name, contact_phone, phone, mail, id_cliente1) self.rc.delete(parameters) self.message[ 'text'] = 'El cliente {0} de la empresa {1} sido eliminado correctamente'.format( contact_name, company_name) self.get_clients() def add_works_window(self): self.add_window_work = Toplevel() self.add_window_work.title = 'Agregar trabajo' # Input ID Label(self.add_window_work, text='ID del cliente: ').grid(row=1, column=0) self.id_cliente_entry = Entry(self.add_window_work) self.id_cliente_entry.focus() self.id_cliente_entry.grid(row=1, column=1) # Input Fecha de Ingreso Label(self.add_window_work, text='Fecha de Ingreso: ').grid(row=2, column=0) self.entry_date = Entry(self.add_window_work) self.entry_date.grid(row=2, column=1) # Input Fecha de Entrega Propuesta Label(self.add_window_work, text='Fecha de Entrega Propuesta: ').grid(row=3, column=0) self.proposal_delivery_date = Entry(self.add_window_work) self.proposal_delivery_date.grid(row=3, column=1) # Input Descripcion Label(self.add_window_work, text='Descripcion: ').grid(row=5, column=0) self.description = Entry(self.add_window_work) self.description.grid(row=5, column=1) # Botonera ttk.Button(self.add_window_work, text="Guardar", command=self.add_work).grid(row=7, columnspan=2, sticky=W + E) def validations_work(self): #'''Valida que no haya espacios en blanco''' return len(self.id_cliente_entry.get()) def add_work(self): #si las validaciones son correctass if self.validations_work(): self.message['text'] = '' obj_cliente = None obj_cliente = self.rc.get_one(self.id_cliente_entry.get()) fe_entrada = datetime.strptime(self.entry_date.get(), '%d-%m-%Y') fe_entrada.strftime('%Y-%m-%d') fecha_ent_pro = '' # En caso de que la fecha propuesta esté en blanco, asignar None if fecha_ent_pro != '': fecha_ent_pro = datetime.strptime( self.proposal_delivery_date.get(), '%d-%m-%Y') fecha_ent_pro.strftime('%Y-%m-%d') else: fecha_ent_pro = None parameters = Trabajo(obj_cliente, fe_entrada, fecha_ent_pro, None, self.description.get(), False, None) a = self.rt.store(parameters) print(parameters, a) if a: self.message[ 'text'] = 'El trabajo del cliente {0} ha sido añadido correctamente'.format( self.id_cliente_entry.get()) self.get_works() self.id_cliente_entry.delete(0, END) self.entry_date.delete(0, END) self.proposal_delivery_date.delete(0, END) self.description.delete(0, END) else: self.message[ 'text'] = 'El trabajo del cliente no se ha sido añadido. Código de error: 0' print(fecha_ent_pro) else: self.message['text'] = 'Todos los campos son requeridos' def retirado(self): '''Se cambia su estado de retirado a True''' try: self.tree3.item(self.tree3.selection())['text'] except IndexError: self.message['text'] = 'Seleccione un trabajo' self.message['text'] = 'El trabajo ha sido entregado correctamente' self.get_works() def edit_trabajos_window(self): '''Ventana para editar un trabajo''' self.message['text'] = '' try: self.tree3.item(self.tree3.selection())['values'][0] except IndexError: self.message['text'] = 'Por favor, seleccione un registro' return old_description = self.tree3.item(self.tree3.selection())['values'][4] old_entry_date = self.tree3.item(self.tree3.selection())['values'][1] id_cliente = self.tree3.item(self.tree3.selection())['values'][0] proposal_delivery_date = self.tree3.item( self.tree3.selection())['values'][2] real_delivery_date = self.tree3.item( self.tree3.selection())['values'][3] if real_delivery_date == None: real_delivery_date = '01-01-1981' else: real_delivery_date = real_delivery_date withdrawn = self.tree3.item(self.tree3.selection())['values'][5] id_trabajo = self.tree3.item(self.tree3.selection())['text'] self.edit_work_window = Toplevel() self.edit_work_window.title = 'Editar trabajo' # ID Label(self.edit_work_window, text='ID: ').grid(row=1, column=1) Entry(self.edit_work_window, textvariable=StringVar(self.edit_work_window, value=id_trabajo), state='readonly').grid(row=1, column=2) # Descripcion Anterior Label(self.edit_work_window, text='Descripcion anterior: ').grid(row=2, column=1) Entry(self.edit_work_window, textvariable=StringVar(self.edit_work_window, value=old_description), state='readonly').grid(row=2, column=2) # Descripcion Actual Label(self.edit_work_window, text='Descripcion actual: ').grid(row=3, column=1) new_description = Entry(self.edit_work_window) new_description.grid(row=3, column=2) # Fecha propuesta anterior Label(self.edit_work_window, text='Fecha propuesta anterior: ').grid(row=4, column=1) Entry(self.edit_work_window, textvariable=StringVar(self.edit_work_window, value=proposal_delivery_date), state='readonly').grid(row=4, column=2) # Fecha propuesta actual Label(self.edit_work_window, text='Fecha propuesta actual: ').grid(row=5, column=1) new_proposal_date = Entry(self.edit_work_window) new_proposal_date.grid(row=5, column=2) # Fecha de Ingreso Anterior Label(self.edit_work_window, text='Fecha de ingreso anterior: ').grid(row=6, column=1) Entry(self.edit_work_window, textvariable=StringVar(self.edit_work_window, value=old_entry_date), state='readonly').grid(row=6, column=2) # Fecha de Ingreso Actual Label(self.edit_work_window, text='Fecha de ingreso actual: ').grid(row=7, column=1) new_entry_date = Entry(self.edit_work_window) new_entry_date.grid(row=7, column=2) # Botón de guardar cambios ttk.Button(self.edit_work_window, text='Actualizar', command=lambda: self.edit_works_desc( id_cliente, new_entry_date.get(), new_proposal_date.get( ), real_delivery_date, new_description.get(), withdrawn, id_trabajo)).grid(row=8, columnspan=3, sticky=W + E) def edit_works_desc(self, id_cliente, new_entry_date, new_proposal_date, real_delivery_date, new_description, withdrawn, id_trabajo): '''Editar descripcion y fecha de ingreso''' nueva_fecha = datetime.strptime(new_entry_date, '%d-%m-%Y') nueva_fecha.strftime('%Y-%m-%d') fecha_ent_pro = datetime.strptime(new_proposal_date, '%d-%m-%Y') fecha_ent_pro.strftime('%Y-%m-%d') if real_delivery_date == 'None': real_delivery_date = '01-01-1981' fecha_ent_re = datetime.strptime(real_delivery_date, '%Y-%m-%d') fecha_ent_re.strftime('%Y-%m-%d') else: fecha_ent_re = datetime.strptime(real_delivery_date, '%Y-%m-%d') fecha_ent_re.strftime('%Y-%m-%d') parameters = Trabajo(id_cliente, nueva_fecha, fecha_ent_pro, fecha_ent_re, new_description, withdrawn, id_trabajo) a = self.rt.update(parameters) if a: self.edit_work_window.destroy() self.message['text'] = 'El trabajo sido editado correctamente' else: self.message['text'] = 'El trabajo no ha sido editado' self.get_works() def trabajo_finalizado(self): '''Cambiar el estado a finalizado, modificando su fecha de entrega real a hoy''' try: self.tree3.item(self.tree3.selection())['values'][0] except IndexError: self.message['text'] = 'Por favor, seleccione un registro' return # Obtengo la fecha de hoy hoy = date.today() hoy.strftime('%d, %m, %Y') # Obtengo los datos actuales del objeto en cuestión description = self.tree3.item(self.tree3.selection())['values'][4] entry_date = self.tree3.item(self.tree3.selection())['values'][1] id_cliente = self.tree3.item(self.tree3.selection())['values'][0] proposal_delivery_date = self.tree3.item( self.tree3.selection())['values'][2] #old_real_delivery_date = self.tree3.item(self.tree3.selection())['values'][3] withdrawn = self.tree3.item(self.tree3.selection())['values'][5] id_trabajo = self.tree3.item(self.tree3.selection())['text'] # Formateo las fechas nueva_fecha = datetime.strptime(entry_date, '%Y-%m-%d') nueva_fecha.strftime('%Y-%m-%d') if proposal_delivery_date == 'None': proposal_delivery_date = '2000-01-01' else: proposal_delivery_date = proposal_delivery_date fecha_ent_pro = datetime.strptime(proposal_delivery_date, '%Y-%m-%d') fecha_ent_pro.strftime('%Y-%m-%d') fecha_ent_pro = datetime.strptime(proposal_delivery_date, '%Y-%m-%d') fecha_ent_pro.strftime('%Y-%m-%d') # Paso parametros al obj Trabajo parameters = Trabajo(id_cliente, nueva_fecha, fecha_ent_pro, hoy, description, withdrawn, id_trabajo) a = self.rt.update(parameters) if a: self.message['text'] = 'El trabajo sido editado correctamente' else: self.message['text'] = 'El trabajo no ha sido editado' self.get_works() def trabajo_entregado(self): '''Cambiar el estado a entregado''' try: self.tree3.item(self.tree3.selection())['values'][0] except IndexError: self.message['text'] = 'Por favor, seleccione un registro' return # Obtengo los datos actuales del objeto en cuestión description = self.tree3.item(self.tree3.selection())['values'][4] entry_date = self.tree3.item(self.tree3.selection())['values'][1] id_cliente = self.tree3.item(self.tree3.selection())['values'][0] proposal_delivery_date = self.tree3.item( self.tree3.selection())['values'][2] real_delivery_date = self.tree3.item( self.tree3.selection())['values'][3] #withdrawn = self.tree3.item(self.tree3.selection())['values'][5] id_trabajo = self.tree3.item(self.tree3.selection())['text'] # Formateo las fechas nueva_fecha = datetime.strptime(entry_date, '%Y-%m-%d') nueva_fecha.strftime('%Y-%m-%d') fecha_ent_pro = datetime.strptime(proposal_delivery_date, '%Y-%m-%d') fecha_ent_pro.strftime('%Y-%m-%d') fecha_ent_real = datetime.strptime(real_delivery_date, '%Y-%m-%d') fecha_ent_real.strftime('%Y-%m-%d') withdrawn = True # Paso parametros al obj Trabajo parameters = Trabajo(id_cliente, nueva_fecha, fecha_ent_pro, fecha_ent_real, description, withdrawn, id_trabajo) a = self.rt.update(parameters) if a: self.message[ 'text'] = 'El trabajo {0} sido entregado correctamente'.format( id_trabajo) else: self.message['text'] = 'El trabajo no ha sido editado' self.get_works() def eliminar_trabajo_confirmacion(self): '''ventana para confirmar la eliminación de los trabajos''' # Creo ventana self.delete_work_window = Toplevel() self.delete_work_window.title = 'Eliminar trabajo' # Label label = Label(self.delete_work_window, text='¿Está seguro que desea eliminar el trabajo?') label.grid(row=1, column=0) # Botón de Confirmar ttk.Button(self.delete_work_window, text='Sí, eliminar', command=lambda: self.eliminar_trabajo()).grid(row=2, column=0) # Botón Cancelar ttk.Button(self.delete_work_window, text='NO, cancelar', command=lambda: self.delete_work_window.destroy()).grid( row=3, column=0) def eliminar_trabajo(self): '''Eliminar un trabajo de la BD''' # Obtengo los datos actuales del objeto en cuestión description = self.tree3.item(self.tree3.selection())['values'][4] entry_date = self.tree3.item(self.tree3.selection())['values'][1] id_cliente = self.tree3.item(self.tree3.selection())['values'][0] proposal_delivery_date = self.tree3.item( self.tree3.selection())['values'][2] real_delivery_date = self.tree3.item( self.tree3.selection())['values'][3] withdrawn = self.tree3.item(self.tree3.selection())['values'][5] id_trabajo = self.tree3.item(self.tree3.selection())['text'] # Paso parametros al obj Trabajo parameters = Trabajo(id_cliente, entry_date, proposal_delivery_date, real_delivery_date, description, withdrawn, id_trabajo) a = self.rt.delete(parameters) # Códigos de éxito o error y retorno la lista de trabajos actualizados if a: self.message[ 'text'] = 'El trabajo {0} sido eliminado correctamente'.format( id_trabajo) else: self.message['text'] = 'El trabajo no ha sido eliminado' self.get_works() def informe(self): # Creo ventana self.informe_trabajos_window = Toplevel() self.informe_trabajos_window.title = 'Informe' # Obtengo la fecha de hoy hoy = date.today() hoyhoy = hoy.strftime('%Y-%m-%d') # Traigo todos los parámetros para comparar la fecha y la entrega trabajos_deben = [] clientes_deben = [] trabajos_no_deben = [] clientes_no_deben = [] fecha_propuesta = [] trabajos_realmente_deben = [] for Parent in self.tree3.get_children(): entregado = self.tree3.item(Parent)["values"][5] id_cliente = self.tree3.item(Parent)['text'] fecha_entrega_propuesta = self.tree3.item(Parent)['values'][3] if entregado == 0: trabajos_deben.append(entregado) clientes_deben.append(id_cliente) fecha_propuesta.append(fecha_entrega_propuesta) else: trabajos_no_deben.append(entregado) clientes_no_deben.append(id_cliente) #print (fecha_propuesta) cant_trabajos = len(trabajos_deben) for i in fecha_propuesta: if i <= hoyhoy: trabajos_realmente_deben.append(i) print("Al dia de hoy", hoyhoy, "faltan entregar", cant_trabajos, "trabajos") # Label label = Label(self.informe_trabajos_window, text='Informes') label.grid(row=1, column=0) label2 = Label(self.informe_trabajos_window, text="El informe sale por consola") label2.grid(row=1, column=0) # Botón Cierre ttk.Button( self.informe_trabajos_window, text='Cerrar', command=lambda: self.informe_trabajos_window.destroy()).grid( row=2, column=0)
class ListaClientes: def __init__(self): self.rc = RepositorioClientes() self.rt = RepositorioTrabajos() self.list_clientes = self.rc.get_all() self.listaTrabajo = self.rt.get_all() def nuevo_cliente_corporativo(self, nombre, nombre_contacto, telefono_contacto, telefono, mail): """Recibe los datos de un cliente corporativo, crea un nuevo cliente corporativo y lo agrega a lista de clientes""" c = ClienteCorporativo(nombre, nombre_contacto, telefono_contacto, telefono, mail) c.id_cliente = self.rc.store(c) if c.id_cliente == 0: return None else: self.list_clientes.append(c) return c def nuevo_cliente_particular(self, nombre, apellido, telefono, mail): """Recibe los datos de un cliente particular, crea un nuevo cliente particular y lo agrega a la lista de clietes""" c = ClienteParticular(nombre, apellido, telefono, mail) c.id_cliente = self.rc.store(c) if c.id_cliente == 0: return None else: self.list_clientes.append(c) return c def _buscar_por_id(self, id_cliente): """Recibe un id de contacto y retorna el contacto que coincide con esa id, o None si ninguno de ellos coincide""" for C in self.list_clientes: if C.id_cliente == int(id_cliente): return (C) return None def modificar_datos_CP(self, nombre, apellido, telefono, mail, id_cliente): """Recibe los datos modificados y actualiza los datos del cliente particular""" Cp = self._buscar_por_id(id_cliente) if Cp: if nombre == '': nombre = Cp.nombre else: Cp.nombre = nombre if apellido == '': apellido = Cp.apellido else: Cp.apellido = apellido if telefono == '': telefono = Cp.telefono else: Cp.telefono = telefono if mail == '': mail = Cp.mail else: Cp.mail = mail return self.rc.update(Cp) return None def modificar_datos_CC(self, nombre_empresa, nombre_contacto, telefono_contacto, telefono, mail, id_cliente): """Recibe los datos modificados y actualiza los datos del cliente corporativo""" Cc = self._buscar_por_id(id_cliente) if Cc: if nombre_empresa == '': nombre_empresa = Cc.nombre_empresa else: Cc.nombre_empresa = nombre_empresa if nombre_contacto == '': nombre_contacto = Cc.nombre_contacto else: Cc.nombre_contacto = nombre_contacto if telefono_contacto == '': telefono_contacto = Cc.telefono_contacto else: Cc.telefono_contacto = telefono_contacto if telefono == '': telefono = Cc.telefono else: Cc.telefono = telefono if mail == '': mail = Cc.mail else: Cc.mail = mail return self.rc.update(Cc) return None def eliminar_cliente(self, id_cliente): """"Recibe el ID de un cliente y lo elimina, en caso de contener trabajos, tambien los elimina""" C = self._buscar_por_id(id_cliente) for i in self.rt.get_all(): if i.cliente.id_cliente == id_cliente: self.rt.delete(i) self.listaTrabajo = self.rt.get_all() self.rc.delete(C) self.list_clientes = self.rc.get_all() return True
class Menu: '''Mostrar un menú y responder a las opciones''' def __init__(self): self.repotrabajo = RepositorioTrabajos() self.lista_clientes = ListaClientes() self.recl = RepositorioClientes() self.repo = Repositorio() self.listaT = ListaTrabajos() self.opciones= { "1": self.mostrar_clientes, "2": self.nuevo_cliente, "3": self.actualizar_datos, "4": self.eliminar_cliente, "5": self.nuevo_trabajo, "6": self.mostrar_trabajo, "7": self.modificar_trabajo, "8": self.eliminar_trabajo, "9": self.generar_informe, "0": self.salir } def mostrar_menu(self): print(""" Menú del anotador: 1. Mostrar todos los clientes 2. Ingresar los datos del nuevo cliente 3. Actualizar datos de un cliente 4. Eliminar cliente 5. Ingresar los datos del nuevo trabajo 6. Mostrar trabajos 7. Modificar datos de trabajo (registro de trabajo retirado/finalizado) 8. Eliminar trabajo 9. Mostrar trabajos de un cliente (Informe) 0. Salir """) def ejecutar(self): '''Mostrar el menu y responder a las opciones.''' while True: self.mostrar_menu() opcion = input("Ingresar una opción: ") accion = self.opciones.get(opcion) if accion: accion() else: print("{0} no es una opción válida".format(opcion)) def mostrar_clientes(self, lista = None): if lista == None: lista = self.lista_clientes.lista for cliente in lista: print(cliente) def nuevo_cliente(self): tipo = "A" while tipo not in ("C", "c", "P", "p"): tipo = input("Ingrese el tipo de cliente: C: Corporativo / P: Particular: ") nombre = input("Ingrese el nombre del contacto: ") if tipo in ("C", "c"): contacto = input("Ingrese el nombre de la empresa: ") tc = int(input("Ingrese el telefono de la empresa: ")) else: apellido = input("Ingrese el apellido: ") tel = int(input("Ingrese el telefono particular: ")) mail = input("Ingrese el correo electronico: ") if tipo in ("C", "c"): c = self.lista_clientes.nuevo_cliente_corporativo(nombre, contacto, tc, tel, mail) else: c = self.lista_clientes.nuevo_cliente_particular(nombre, apellido, tel, mail) if c is None: print("Error al cargar el trabajo") else: print("Trabajo cargado correctamente") def actualizar_datos(self): tipo = "A" id = int(input("Ingrese ID del cliente para actualizar sus datos: ")) while tipo not in ("C", "c", "P", "p"): tipo = input("Ingrese el tipo de cliente: C: Corporativo / P: Particular: ") nombre = input("Ingrese el nombre actualizado del contacto: ") if tipo in ("C", "c"): contacto = input("Ingrese el nombre actualizado de la empresa: ") tc = int(input("Ingrese el telefono actualizado de la empresa: ")) else: apellido = input("Ingrese el apellido actualizado : ") tel = int(input("Ingrese el telefono particular actualizado : ")) mail = input("Ingrese el correo electronico actualizado : ") if tipo in ("C", "c"): cliente = ClienteCorporativo(nombre, contacto, tc, tel, mail, id) c = self.recl.update(cliente) else: cliente = ClienteParticular(nombre, apellido, tel, mail, id) c = self.recl.update(cliente) if c is None: print("Error al actualizar el cliente") else: print("Cliente actualizado correctamente") def eliminar_cliente(self): id_cliente = int(input("Ingrese ID del cliente para eliminar sus datos: ")) borrar = input("Para eliminar los datos del cliente ingrese E, de caso contrario se cancelará la eliminación: ") cliente = self.recl.get_one(id_cliente) if borrar == "E" or "e": c = self.recl.delete(cliente) print("El cliente se elimino correctamente! ") else: print("Se cancela la eliminación.") def nuevo_trabajo(self): id_cliente = int(input("Ingrese ID del cliente al que le desea asignar un trabajo: ")) ingreso_trabajo = input("Ingrese N para ingresar un trabajo al cliente: ") cliente = self.recl.get_one(id_cliente) if ingreso_trabajo in ("N", "n"): hoy = datetime.today() ingreso = hoy dia = int(input("Ingrese el dia propuesto para la entrega: ")) mes = int(input("Ingrese el mes propuesto para la entrega (en número, 1 a 12): ")) anio = int(input("Ingrese el año propuesto para la entrega (4 dígitos): ")) fecha_entrega_propuesta = datetime(anio, mes, dia) fecha_entrega_real = None descripcion = input("Ingrese una breve descripcion del trabajo: ") retirado = False t = self.listaT.nuevo_trabajo(cliente, ingreso, fecha_entrega_propuesta, fecha_entrega_real, descripcion, retirado) if t == 0: print("Error al cargar el cliente. ") else: print("Cliente cargado correctamente!") else: if ingreso_trabajo != ("N", "n"): print("Ingreso de trabajo CANCELADO. ") def mostrar_trabajo(self, listaT = None): if listaT == None: listaT = self.listaT.listatrabajo for Trabajo in listaT: print(Trabajo) def modificar_trabajo(self): id_trabajo = int(input("Ingrese ID de trabajo al que le desea modificar un trabajo: ")) mod_trabajo= input("Ingrese M para modificar un trabajo al cliente: ") trabajo = self.repotrabajo.get_one(id_trabajo) if mod_trabajo in ("M", "m"): mod_descripcion = input("Si desea modificar la descripcion presione X, si no presione otra letra: ") if mod_descripcion in ("X","x"): descripcion = input("Ingrese una breve descripcion del trabajo: ") trabajo.descripcion = descripcion mod_ingreso = input("Si desea modificar la fecha de ingreso presione X, si no presione otra letra: ") if mod_ingreso in ("X","x"): hoy = datetime.today() ingreso = hoy trabajo.ingreso = ingreso print("Se modifico la descripcion y la fecha de ingreso ! ") else: print("Se modifico solamente la descripcion") else: mod_ingreso = input("Si desea modificar la fecha de ingreso presione X, si no presione otra letra: ") if mod_ingreso in ("X","x"): hoy = datetime.today() ingreso = hoy trabajo.ingreso = ingreso print("Se modifico la fecha de ingreso !") else: print("No se modificó la fecha de entrega. ") mod_fechapropuesta = input("Si desea modificar la fecha propuesta presione X, si no presione otra letra: ") if mod_fechapropuesta in ("X", "x"): dia = int(input("Ingrese el dia propuesto para la entrega: ")) mes = int(input("Ingrese el mes propuesto para la entrega (en número, 1 a 12): ")) anio = int(input("Ingrese el año propuesto para la entrega (4 dígitos): ")) fecha_entrega_propuesta = datetime(anio, mes, dia) trabajo.fecha_entrega_propuesta = fecha_entrega_propuesta print("Se modificó la fecha propuesta de entrega !") else: print("No se modifico la fecha propuesta de entrega") mod_fechareal = input("Ingrese X para modificar la fecha de entrega real, si no presione otra letra: ") if mod_fechareal in ("X", "x"): hoy = datetime.today() fecha_entrega_real = hoy trabajo.fecha_entrega_real = fecha_entrega_real print("Se modificó la fecha de entrega real. ") else: print("No se modificó la fecha de entrega real") mod_retirado = input("Ingrese X para modificar si el trabajo fue retirado, si no fue retirado presione N, si no presione otra letra: ") if mod_retirado in ("X", "x"): retirado = True trabajo.retirado = retirado print("El trabajó fue retirado.") t = self.repotrabajo.update(trabajo) else: if mod_retirado in ("N", "n"): print("El trabajo no fue retirado") retirado = False trabajo.retirado = retirado t = self.repotrabajo.update(trabajo) print("Datos actualizados correctamente !") t = self.repotrabajo.update(trabajo) def eliminar_trabajo(self): id_trabajo = int(input("Ingrese ID de trabajo del cliente para eliminar sus trabajos: ")) borrar = input("Para eliminar los datos del cliente ingrese E, de caso contrario se cancelará la eliminación: ") trabajo = self.repotrabajo.get_one(id_trabajo) if borrar == "E" or "e": t = self.repotrabajo.delete(trabajo) if t == 0: print("El trabajo ha sido eliminado") else: print("No se eliminó correctamente") print("Eliminación del trabajo de manera exitosa.") else: print("Se cancela la eliminación.") ########### No se como hacer para que con el id del cliente imprima sus trabajos ########## def generar_informe(self): id_cliente = int(input("Ingrese el ID del cliente: ")) cliente = self.recl.get_one(id_cliente) t = self.listaT.un_trabajo for cliente in t: print(cliente) def salir(self): print("Gracias por utilizar el sistema.") sys.exit(0)
class Menu: "Muestra un menu para que se responda a las opciones" def __init__(self): self.lista_clientes = ListaClientes() self.repositoriocl = RepositorioClientes() self.lista = self.repositoriocl.get_all() self.repositoriotr = RepositorioTrabajos() self.LT = ListaTrabajos() self.opciones = { "1": self.mostrar_clientes, "2": self.nuevo_cliente, "3": self.modificar_cliente, "4": self.eliminar_cliente, "5": self.carga_trabajo, "6": self.modificar_trabajo, "7": self.mostrar_trabajos, "8": self.HistorialTrabajosCl, "0": self.salir } def mostrar_menu(self): print(""" Menu del sistema: 1. Mostrar todos los clientes 2. Ingreso de nuevo cliente 3. Modificacion de cliente 4. Eliminacion de cliente 5. Carga de nuevo trabajo 6. Modificar datos de un trabajo 7. Mostrar todos los trabajos 8. Informe 0. Salir """) def ejecutar(self): "Muestra el menu y responde a las opciones." while True: self.mostrar_menu() opcion = input("Ingresar una opcion: ") accion = self.opciones.get(opcion) if accion: accion() else: print("{0} no es una opcion valida".format(opcion)) #CLIENTE // Mostrar todos los clientes. def mostrar_clientes(self, lista=None): if lista == None: lista = self.repositoriocl.get_all() for cliente in lista: print(cliente) print("==========================") #CLIENTE // Ingreso de cliente. def nuevo_cliente(self): tipo = "A" while tipo not in ("C", "c", "P", "p"): tipo = input( "Ingrese el tipo de cliente: C: Corporativo/ P:Particular") nombre = input("Ingrese el nombre:") if tipo in ("C", "c"): contacto = input("Ingrese el nombre del contacto: ") tc = input("Ingrese el telefono del contacto: ") else: apellido = input("Ingrese el apellido: ") tel = input("Ingrese el telefono: ") mail = input("Ingresa la direccion de email: ") if tipo in ("C", "c"): c = self.lista_clientes.nuevo_cliente_corporativo( nombre, contacto, tc, tel, mail) else: c = self.lista_clientes.nuevo_cliente_particular( nombre, apellido, tel, mail) if c is None: print("Error al cargar el cliente") else: print("Cliente cargado correctamente") #CLIENTE // Modificacion de cliente. def modificar_cliente(self): tipo = "A" id_cliente = int(input("Ingrese el ID del cliente registrado: ")) while tipo not in ("C", "c", "P", "p"): tipo = input( "Ingrese el tipo de cliente: C: Corporativo/ P: Particular ") nombre = input("Ingrese el nombre: ") if tipo in ("C", "c"): contacto = input("Ingrese el nombre del contacto: ") tc = input("Ingrese el telefono del contacto: ") else: apellido = input("Ingrese el apellido: ") tel = input("Ingrese el telefono: ") mail = input("Ingresa la direccion de email: ") if tipo in ("C", "c"): cliente = ClienteCorporativo(nombre, contacto, tc, tel, mail, id_cliente) c = self.repositoriocl.update(cliente) else: cliente = ClienteParticular(nombre, apellido, tel, mail, id_cliente) c = self.repositoriocl.update(cliente) if c is None: print("Error al modificar el cliente") else: print("Cliente modificado correctamente") #CLIENTE // Suprimir un cliente. def eliminar_cliente(self): id_cliente = int(input("Ingrese el id del cliente")) c = self.repositoriocl.get_one(id_cliente) if c == None: print("El id del cliente no esta cargado en nuestra base de datos") else: self.repositoriocl.delete(c) print("El cliente fue eliminado correctamente!") #TRABAJO // Carga de un nuevo trabajo. def carga_trabajo(self): id_cliente = int(input("Ingrese el id del cliente: ")) rc = RepositorioClientes() cl = rc.get_one(id_cliente) fecha_ingreso = datetime.date.today() dia = int(input("Ingrese el dia: ")) mes = int(input("Ingrese el mes: ")) anio = int(input("Ingrese el anio: ")) fecha_entrega_propuesta = datetime.date(anio, mes, dia) descripcion_trabajo = input( "Ingrese una descripcion del trabajo a realizar: ") c = self.LT.nuevo_trabajo(cl, fecha_ingreso, fecha_entrega_propuesta, descripcion_trabajo) if c == None: print("Error, no puede cargarse el nuevo trabajo ") else: print("Trabajo cargado correctamente en la base de datos! ") #TRABAJO // Modificar datos de los trabajos cargados. // FechaING-PROP-REAL-DESC-ESTADO DEL TRABAJO. def modificar_trabajo(self): print( "Al ingresar un ID de trabajo se tendran que modificar todos los datos, en caso de que quede un campo vacio se modificara de esa forma" ) id_trabajo = int(input("Ingrese el ID del trabajo: ")) C = self.repositoriotr.get_one(id_trabajo) if C == None: print("No se encontro el trabajo") else: t = input( "Si desea modificar la fecha de ingreso presione f, de lo contrario presione 0 para continuar: " ) if t in ("f", "F"): dia = int(input("Ingrese nuevamente el dia: ")) mes = int(input("Ingrese nuevamente el mes: ")) anio = int(input("Ingrese nuevamente el anio: ")) print("Fecha modificada exitosamente! ") fechaingreso = datetime.date(anio, mes, dia) else: fechaingreso = C.fecha_ingreso t = input( "Si desea modificar la fecha de entrega propuesta de un trabajo presione la tecla e, de lo contrario presione 0 para continuar: " ) if t in ("e", "E"): dia = int(input("Ingrese nuevamente el dia: ")) mes = int(input("Ingrese nuevamente el mes: ")) anio = int(input("Ingrese nuevamente el anio: ")) print("Fecha modificada exitosamente! ") fentregapropuesta = datetime.date(anio, mes, dia) else: fentregapropuesta = C.fecha_entrega_propuesta print("Ningun dato se ha modificado") t = input( "Si desea modificar la fecha real de un trabajo presione la tecla r, de lo contrario presione 0 para continuar: " ) if t in ("r", "R"): dia = int(input("Ingrese nuevamente el dia: ")) mes = int(input("Ingrese nuevamente el mes: ")) anio = int(input("Ingrese nuevamente el anio: ")) print("Fecha modificada exitosamente! ") fentregareal = datetime.date(anio, mes, dia) else: fentregareal = C.fecha_entrega_real print("No se ha modificado la fecha! ") t = input( "Si desea modificar la descripcion de un trabajo presione la tecla t, de lo contrario presione 0 para continuar: " ) if t in ("t", "T"): t = input("Ingrese la nueva descripcion del trabajo: ") print("Se ha modificado el nombre del trabajo! ") descripcion = t else: C.descripcion = descripcion print("La descripcion del trabajo no ha podido modificarse") trabajo = self.LT.modificar_trabajo(fechaingreso, fentregapropuesta, fentregareal, descripcion, id_trabajo) self.repositoriocl.update(trabajo) self.LT.TrabajoL = self.repositoriotr.get_all() #TRABAJO // Mostrar todos los trabajos. def mostrar_trabajos(self, listat=None): if listat == None: listat = self.repositoriotr.get_all() for cliente in listat: print(cliente) print("============================") #INFORME // Despliega una lista con los trabajos cargados en cada cliente. def HistorialTrabajosCl(self): "Pide un ID y muestra una lista con los trabajos cargados en cada cliente" for i in self.repositoriocl.get_all_particulares(): print("=====================================") print("ID cliente: ", i.id_cliente, "- Nombre: ", i.nombre) print("=====================================") for i in self.repositoriocl.get_all_corporativos(): print("=====================================") print("ID cliente: ", i.id_cliente, "- Nombre: ", i.nombre_empresa) id = int(input("Ingrese el ID del cliente: ")) C = self.repositoriotr.get_one(id) if C == None: print() else: print("=====================================") print(C) print("=====================================") for I in self.LT.TrabajoL: if I.cliente.id_cliente == id: print("========================================") print("ID trabajo: ", I.id_trabajo) print("Fecha de ingreso: ", I.fecha_ingreso) print("Fecha entrega propuesta: ", I.fecha_entrega_propuesta) print("Fecha entrega real: ", I.fecha_entrega_real) print("Descripcion: ", I.descripcion) print("Retirado: ", I.retirado) print("========================================") else: print("========================================") print("No se encontraron trabajos") print("========================================") def salir(self): print("Gracias por utilizar el sistema.") sys.exit(0)
class ListaClientes: def __init__(self): self.RC = RepositorioClientes() self.RT = RepositorioTrabajos() self.ClienteL = self.RC.get_all() self.ListaT = self.RT.get_all() def NuevoClienteCorp(self, nombre_empresa, nombre_contacto, telefono_contacto, telefono, mail): """Recibe los datos de un cliente corporativo, crea un nuevo cliente corporativo y lo agrega a lista de clientes""" C = ClienteCorporativo(nombre_empresa, nombre_contacto, telefono_contacto, telefono, mail) C.id_cliente = self.RC.store(C) if C.id_cliente == 0: return None else: self.ClienteL.append(C) return C def NuevoClientePart(self, nombre, apellido, telefono, mail): """Recibe los datos de un cliente particular, crea un nuevo cliente particular y lo agrega a la lista de clientes""" C = ClienteParticular(nombre, apellido, telefono, mail) C.id_cliente = self.RC.store(C) if C.id_cliente == 0: return None else: self.ClienteL.append(C) return C def BuscarPorID(self, id_cliente): """Recibe un ID y retorna un cliente""" for T in self.ClienteL: if T.id_cliente == int(id_cliente): return (T) return None def ModificarDatosCP(self, nombre, apellido, telefono ,mail, id_cliente): """Recibe los datos modificados y actualiza los datos del cliente particular""" C = self.BuscarPorID(id_cliente) if C: if nombre == '': nombre = C.nombre else: C.nombre = nombre if apellido == '': apellido = C.apellido else: C.apellido = apellido if telefono == '': telefono = C.telefono else: C.telefono = telefono if mail == '': mail = C.mail else: C.mail = mail return self.RC.update(C) return None def ModificarDatosCC(self, nombre_empresa, nombre_contacto, telefono_contacto, telefono, mail, id_cliente): """Recibe los datos modificados y actualiza los datos del cliente corporativo""" C = self.BuscarPorID(id_cliente) if C: if nombre_empresa == '': nombre_empresa = C.nombre_empresa else: C.nombre_empresa = nombre_empresa if nombre_contacto == '': nombre_contacto = C.nombre_contacto else: C.nombre_contacto = nombre_contacto if telefono_contacto == '': telefono_contacto = C.telefono_contacto else: C.telefono_contacto = telefono_contacto if telefono == '': telefono = C.telefono else: C.telefono = telefono if mail == '': mail = C.mail else: C.mail = mail return self.RC.update(C) return None def EliminarCliente(self, id_cliente): """"Recibe el ID de un cliente y lo elimina, en caso de contener trabajos, tambien los elimina""" C = self.BuscarPorID(id_cliente) for I in self.RT.get_all(): if I.cliente.id_cliente == id_cliente: self.RT.delete(I) self.ListaT = self.RT.get_all() self.RC.delete(C) self.ClienteL = self.RC.get_all() return True
class Menu: """Mostrar un menú y responder a las opciones""" def __init__(self): self.rc = RepositorioClientes() self.rt = RepositorioTrabajos() self.opciones = { "0": self.salir, "1": self.mostrar_clientes, "2": self.nuevo_cliente, "3": self.eliminar_cliente, "4": self.modificar_cliente, "5": self.nuevo_trabajo, "6": self.mostrar_trabajos, "7": self.modificar_trabajo, "8": self.marcar_finalizado, "9": self.marcar_entregado, "10": self.eliminar_trabajo, "11": self.imprimir_informe } def mostrar_menu(self): print(""" Menú del sistema: 0. Salir 1. Mostrar todos los clientes 2. Ingresar los datos de un nuevo cliente 3. Eliminar cliente 4. Modificar cliente 5. Cargar trabajo nuevo 6. Mostrar todos los trabajos 7. Modificar trabajo 8. Marcar trabajo como finalizado 9. Marcar trabajo como entregado 10. Eliminar trabajo 11. Imprimir informe de trabajos por cliente """) def ejecutar(self): """Mostrar el menu y responder a las opciones.""" while True: self.mostrar_menu() opcion = input("Ingresar una opción: ") accion = self.opciones.get(opcion) if accion: accion() else: print("{0} no es una opción válida".format(opcion)) def mostrar_clientes(self, lista=None): if lista == None: lista = ListaClientes().lista for Cliente in lista: print(Cliente) print("==============================") def nuevo_cliente(self): tipo = "A" while tipo not in ("C", "c", "P", "p"): tipo = input( "Ingrese el tipo de cliente: C:Corporativo / P:Particular") nombre = input("Ingrese el nombre: ") if tipo in ("C", "c"): contacto = input("Ingrese el nombre del contacto: ") tc = input("Ingrese el telefono del contacto: ") else: apellido = input("Ingrese el apellido: ") tel = input("Ingrese el telefono: ") mail = input("Ingrese el correo electronico: ") if tipo in ("C", "c"): c = ListaClientes().nuevo_cliente_corporativo( nombre, contacto, tc, tel, mail) else: c = ListaClientes().nuevo_cliente_particular( nombre, apellido, tel, mail) if c is None: print("Error al cargar el cliente") else: print("Cliente cargado correctamente") def eliminar_cliente(self): id_cliente = input("Ingrese el ID del cliente: ") cliente = self.rc.get_one(id_cliente) if cliente is None: print("No existe el cliente") else: cliente_eliminado = self.rc.delete(cliente) if cliente_eliminado is True: print("El cliente se elimino correctamente") else: print("No se pudo eliminar") def modificar_cliente(self): id_cliente = input("Ingrese el ID del cliente: ") cliente = self.rc.get_one(id_cliente) if cliente is None: print("No existe el cliente") else: print(cliente) nuevo_nombre = input("Ingrese el nombre: ") cliente.nombre = nuevo_nombre if type(cliente).__name__ == "ClienteCorporativo": nuevo_contacto = input("Ingrese el nombre del contacto: ") cliente.nombre_contacto = nuevo_contacto nuevo_tc = input("Ingrese el telefono del contacto: ") cliente.telefono_contacto = nuevo_tc else: nuevo_apellido = input("Ingrese el apellido: ") cliente.apellido = nuevo_apellido nuevo_tel = input("Ingrese el telefono: ") cliente.telefono = nuevo_tel nuevo_mail = input("Ingrese el correo electronico: ") cliente.mail = nuevo_mail cliente_modificado = self.rc.update(cliente) if cliente_modificado is True: print("El cliente se modifico correctamente") else: print("No se pudo modificar") def nuevo_trabajo(self): id_cliente = input("Ingrese el ID del cliente: ") cliente = self.rc.get_one(id_cliente) if cliente is None: print("No existe el cliente") else: date_entry = input( "Ingrese una fecha de ingreso con formato YYYY-MM-DD: ") year, month, day = map(int, date_entry.split("-")) fecha_ingreso = datetime.date(year, month, day) date_entry = input( "Ingrese una fecha de entrega propuesta con formato YYYY-MM-DD: " ) year, month, day = map(int, date_entry.split("-")) fecha_entrega_propuesta = datetime.date(year, month, day) descripcion = input("Ingrese una descripcion para el trabajo: ") t = ListaTrabajos().nuevo_trabajo(cliente, fecha_entrega_propuesta, descripcion, fecha_ingreso) if t is None: print("Error al cargar el trabajo") else: print("Trabajo cargado correctamente") def mostrar_trabajos(self, lista=None): if lista == None: lista = ListaTrabajos().lista for Trabajos in lista: print(Trabajos) print("==============================") def modificar_trabajo(self): id_trabajo = input("Ingrese el ID del trabajo: ") trabajo = self.rt.get_one(id_trabajo) if trabajo is None: print("No existe el trabajo") else: print(trabajo) date_entry = input( "Ingrese una nueva fecha de ingreso con formato YYYY-MM-DD: ") year, month, day = map(int, date_entry.split("-")) fecha_ingreso = datetime.date(year, month, day) date_entry = input( "Ingrese una nueva fecha de entrega propuesta con formato YYYY-MM-DD: " ) year, month, day = map(int, date_entry.split("-")) fecha_entrega_propuesta = datetime.date(year, month, day) descripcion = input( "Ingrese una nueva descripcion para el trabajo: ") trabajo.fecha_ingreso = fecha_ingreso trabajo.fecha_entrega_propuesta = fecha_entrega_propuesta trabajo.descripcion = descripcion finalizado = "A" while finalizado not in ("S", "s", "N", "n"): finalizado = input("¿Fue finalizado? (S)í / (N)o: ") if finalizado in ("S", "s"): date_entry = input( "Ingrese la fecha de finalización con formato YYYY-MM-DD: " ) year, month, day = map(int, date_entry.split("-")) fecha_entrega = datetime.date(year, month, day) trabajo.fecha_entrega_real = fecha_entrega else: trabajo.fecha_entrega_real = None entregado = "A" while entregado not in ("S", "s", "N", "n"): entregado = input("¿Fue entregado? (S)í / (N)o: ") if entregado in ("S", "s"): trabajo.retirado = True else: trabajo.retirado = False trabajo_modificado = self.rt.update(trabajo) if trabajo_modificado is True: print("El trabajo se modifico correctamente") else: print("No se pudo modificar") def marcar_finalizado(self): id_trabajo = input("Ingrese el ID del trabajo: ") trabajo = self.rt.get_one(id_trabajo) if trabajo is None: print("No existe el trabajo") else: trabajo.fecha_entrega_real = datetime.date.today() trabajo_modificado = self.rt.update(trabajo) if trabajo_modificado is True: print("El trabajo se modifico correctamente") print("==============================") print(trabajo) else: print("No se pudo modificar") def marcar_entregado(self): id_trabajo = input("Ingrese el ID del trabajo: ") trabajo = self.rt.get_one(id_trabajo) if trabajo is None: print("No existe el trabajo") else: trabajo.retirado = True trabajo_modificado = self.rt.update(trabajo) if trabajo_modificado is True: print("El trabajo se modifico correctamente") print("==============================") print(trabajo) else: print("No se pudo modificar") def eliminar_trabajo(self): id_trabajo = input("Ingrese el ID del trabajo: ") trabajo = self.rt.get_one(id_trabajo) if trabajo is None: print("No existe el trabajo") else: trabajo_eliminado = self.rt.delete(trabajo) if trabajo_eliminado is True: print("El trabajo se elimino correctamente") else: print("No se pudo eliminar") def imprimir_informe(self): id_cliente = input("Ingrese el ID del cliente: ") cliente = self.rc.get_one(id_cliente) if cliente is None: print("No existe el cliente") else: Informe().imprimir_informe(id_cliente) def salir(self): print("Gracias por utilizar el sistema.") sys.exit(0)
class Menu: '''Mostrar un menu y responder a las opciones''' def __init__(self): self.lista_clientes = ListaClientes() self.reposclientes = RepositorioClientes() self.listatrabajos = ListaTrabajos() self.repostrabajos = RepositorioTrabajos() self.opciones = { "1": self.mostrar_clientes, "2": self.mostrar_un_cliente, "3": self.nuevo_cliente, "4": self.actualizar_datos_clientes, "5": self.eliminar_clientes, "6": self.nuevo_trabajo, "7": self.mostrar_trabajo, "8": self.trabajo_finalizado, "9": self.trabajo_entregado, "10": self.actualizar_datos_trabajo, "11": self.eliminar_trabajo, "12": self.historial_trabajos, "13": self.mostrar_trabajos, "0": self.salir } def mostrar_menu(self): print(""" Menu del sistema: 1. Mostrar todos los clientes 2. Mostrar un cliente por ID 3. Ingresar los datos de un nuevo cliente 4. Actualizar datos de un cliente 5. Eliminar cliente 6. Ingresar los datos de un nuevo trabajo 7. Mostrar trabajo por ID 8. Marcar un trabajo como finalizado 9. Marcar un trabajo como entregado 10. Actualizar datos de un trabajo 11. Eliminar trabajo 12. Historial de trabajos de un cliente 13. Mostrar todos los trabajos 0. Salir """) def ejecutar(self): '''Mostrar el menu y responder a las opciones''' while True: self.mostrar_menu() opcion = input("Ingresar una opcion: ") accion = self.opciones.get(opcion) if accion: accion() else: print("{0} no es una opcion valida".format(opcion)) #READ - Metodo para mostrar todos los clientes cargados en la base de datos def mostrar_clientes(self, lista=None): if lista == None: lista = self.lista_clientes.lista for cliente in lista: print(cliente) print("***********************************") #READ - Metodo para mostrar un solo cliente de la base de datos, buscando por ID def mostrar_un_cliente(self, lista=None): id_cliente = int(input("Ingrese el id del cliente: ")) cliente = self.reposclientes.get_one(id_cliente) if cliente == None: print("Error, no existe un cliente con el ID ingresado") else: print(cliente) #CREATE - Metodo para crear un nuevo objeto cliente en la base de datos, dentro de la clase hija que corresponde (C o P) def nuevo_cliente(self): tipo = "A" while tipo not in ("C", "c", "P", "p"): tipo = input( "Ingrese el tipo de cliente: C = Corporativo - P = Particular: " ) nombre = input("Ingrese el nombre: ") if tipo in ("C", "c"): contacto = input("Ingrese el nombre del contacto: ") tc = input("Ingrese el telefono del contacto: ") else: apellido = input("Ingrese el apellido: ") tel = input("Ingrese el telefono: ") mail = input("Ingrese el correo electronico: ") if tipo in ("C", "c"): c = self.lista_clientes.nuevo_cliente_corporativo( nombre, contacto, tc, tel, mail) else: c = self.lista_clientes.nuevo_cliente_particular( nombre, apellido, tel, mail) if c is None: print("Error al cargar el cliente") else: print("Cliente cargado correctamente") #UPDATE - Metodo para modificar y actualizar los datos de un cliente particular o corporativo, en la base de datos. def actualizar_datos_clientes(self): id = int(input("Ingrese el id del cliente: ")) tipo = "A" while tipo not in ("C", "c", "P", "p"): tipo = input( "Ingrese el tipo de cliente: C = Corporativo - P = Particular: " ) nombre = input("Ingrese el nuevo nombre: ") if tipo in ("C", "c"): contacto = input("Ingrese el nuevo nombre del contacto: ") tc = input("Ingrese el telefono del contacto: ") else: apellido = input("Ingrese el nuevo apellido: ") tel = input("Ingrese el nuevo telefono: ") mail = input("Ingrese el nuevo correo electronico: ") if tipo in ("C", "c"): cliente = ClienteCorporativo(nombre, contacto, tc, tel, mail, id) c = self.reposclientes.update(cliente) else: cliente = ClienteParticular(nombre, apellido, tel, mail, id) c = self.reposclientes.update(cliente) if c is False: print( "Error al intentar modificar al cliente, no existe en la lista que corresponde al tipo seleccionado (C o P)" ) else: print("Cliente modificado correctamente") #DELETE - Metodo para eliminar definitivamente un cliente particular o corporativo, de la base de datos. def eliminar_clientes(self, lista=None): tipo = "A" while tipo not in ("C", "c", "P", "p"): tipo = input( "Ingrese el tipo de cliente que desea eliminar: C = Corporativo - P = Particular: " ) nombre = None if tipo in ("C", "c"): id = int(input("Ingrese el id del cliente que desea eliminar: ")) contacto = None tc = None else: id = int(input("Ingrese el id del cliente que desea eliminar: ")) apellido = None tel = None mail = None if tipo in ("C", "c"): cliente = ClienteCorporativo(nombre, contacto, tc, tel, mail, id) c = self.reposclientes.delete(cliente) else: cliente = ClienteParticular(nombre, apellido, tel, mail, id) c = self.reposclientes.delete(cliente) if c is False: print("Error al intentar eliminar al cliente de la base de datos") else: print("Cliente eliminado correctamente de la base de datos") #NUEVO TRABAJO: Para cargar un nuevo trabajo en base de datos trabajo def nuevo_trabajo(self): tipo = "A" while tipo not in ("C", "c", "P", "p"): tipo = input( "Ingrese el tipo de cliente al que desa asignarle el trabajo: C = Corporativo - P = Particular: " ) nombre = None if tipo in ("C", "c"): id = int(input("Ingrese el id del cliente: ")) contacto = None tc = None else: id = int(input("Ingrese el id del cliente: ")) apellido = None tel = None mail = None if tipo in ("C", "c"): cliente = ClienteCorporativo(nombre, contacto, tc, tel, mail, id) fecha_ingreso = datetime.date.today() print("Fecha de entrega propuesta: ") dia = (int(input("Ingrese el dia de entrega propuesta: "))) mes = (int(input("Ingrese el mes de entrega propuesta: "))) anio = (int(input("Ingrese el año de entrega propuesta: "))) fecha_entrega_propuesta = datetime.date(anio, mes, dia) fecha_entrega_real = None retirado = False descripcion = input( "Ingrese una breve descripcion del trabajo a realizar: ") nt = self.listatrabajos.nuevo_trabajo(cliente, fecha_ingreso, fecha_entrega_propuesta, fecha_entrega_real, descripcion, retirado) else: cliente = ClienteParticular(nombre, apellido, tel, mail, id) fecha_ingreso = datetime.date.today() print("Fecha de entrega propuesta: ") dia = (int(input("Ingrese el dia de entrega propuesta: "))) mes = (int(input("Ingrese el mes de entrega propuesta: "))) anio = (int(input("Ingrese el año de entrega propuesta: "))) fecha_entrega_propuesta = datetime.date(anio, mes, dia) fecha_entrega_real = None retirado = False descripcion = input( "Ingrese una breve descripcion del trabajo a realizar: ") nt = self.listatrabajos.nuevo_trabajo(cliente, fecha_ingreso, fecha_entrega_propuesta, fecha_entrega_real, descripcion, retirado) if nt == 0: print("Error al intentar cargar el trabajo nuevo") else: print("Trabajo cargado exitosamente") #Mostrar un trabajo en particular def mostrar_trabajo(self): id_trabajo = int(input("Ingrese el id del trabajo: ")) trabajo = self.repostrabajos.get_one(id_trabajo) if trabajo == None: print("Error, no existe un trabajo con el ID ingresado") else: print(trabajo) #TRABAJO FINALIZADO: Para marcar un trabajo como finalizado con la fecha actual (hoy) def trabajo_finalizado(self): id_trabajo = int( input( "Ingrese el id del trabajo que desea marcar como concluido: ")) trabajo = self.repostrabajos.get_one(id_trabajo) if trabajo == None: print("Error, no existe un trabajo con el ID ingresado") else: trabajo.fecha_entrega_real = datetime.date.today() return self.repostrabajos.update(trabajo) print("El trabajo fue marcado como finalizado, de manera exitosa") #TRABAJO ENTREGADO: Para marcar un trabajo como entregado def trabajo_entregado(self): id_trabajo = int( input( "Ingrese el id del trabajo que desea marcar como entregado: ")) trabajo = self.repostrabajos.get_one(id_trabajo) if trabajo == None: print("Error, no existe un trabajo con el ID ingresado") else: trabajo.retirado = True return self.repostrabajos.update(trabajo) print("El trabajo fue marcado como entregado, de manera exitosa") #ACTUALIZAR TRABAJO: Para actualizar cualquiera de los datos del trabajo #(excepto id, y cliente asociado al mismo), buscando por ID def actualizar_datos_trabajo(self): id_trabajo = int( input("Ingrese el id del trabajo que desea actualizar: ")) trabajo = self.repostrabajos.get_one(id_trabajo) if trabajo == None: print("Error, no existe un trabajo con el ID ingresado") else: preg_uno = int( input( "Si desea actualizar la fecha de ingreso marque 1, de lo contrario otro numero: " )) if preg_uno == 1: print("Actualizar la fecha de ingreso: ") dia = (int(input("Ingrese el dia de ingreso: "))) mes = (int(input("Ingrese el mes de ingreso: "))) anio = (int(input("Ingrese el año de ingreso: "))) fecha_ingreso = datetime.date(anio, mes, dia) trabajo.fecha_ingreso = fecha_ingreso preg_dos = int( input( "Si desea actualizar la fecha de entrega propuesta marque 1, \n de lo contrario otro numero: " )) if preg_dos == 1: print("Actualizar la fecha de entrega propuesta: ") dia = (int(input("Ingrese el dia de entrega propuesta: "))) mes = (int(input("Ingrese el mes de entrega propuesta: "))) anio = (int(input("Ingrese el año de entrega propuesta: "))) fecha_entrega_propuesta = datetime.date(anio, mes, dia) trabajo.fecha_entrega_propuesta = fecha_entrega_propuesta preg_tres = int( input( "Si el trabajo ya fue entregado, y desea modificar esa fecha, marque 1,\n de lo contrario marque otro numero: " )) if preg_tres == 1: print("Actualizar la fecha de entrega real: ") dia = (int(input("Ingrese el dia de entrega real: "))) mes = (int(input("Ingrese el mes de entrega real: "))) anio = (int(input("Ingrese el año de entrega real: "))) fecha_entrega_real = datetime.date(anio, mes, dia) trabajo.fecha_entrega_real = fecha_entrega_real preg_cuatro = int( input( "Si desea modificar la descripcion del trabajo, marque 1,\n de lo contrario otro numero: " )) if preg_cuatro == 1: print("Actualizar descripcion del trabajo: ") descripcion = input( "Ingrese una breve descripcion del trabajo a realizar: ") trabajo.descripcion = descripcion preg_cinco = int( input( "Si desea modificar el estado a retirado/no retirado,\n marque 1, de lo contrario otro numero: " )) if preg_cinco == 1: preg_retirado = int( input( "Ingrese 1 para indicar que el trabajo esta retirado,\n otro numero para marcar como no retirado: " )) if preg_retirado == 1: retirado = True else: retirado = False return self.repostrabajos.update(trabajo) print("Datos del trabajo actualizados con exito !!!") #ELIMINAR TRABAJO: busca por ID, en repositorio trabajos y si lo encuentra lo elimina de la base de datos def eliminar_trabajo(self): id_trabajo = int( input("Ingrese el id del trabajo que desea eliminar: ")) trabajo = self.repostrabajos.get_one(id_trabajo) if trabajo == None: print("Error, no existe un trabajo con el ID ingresado") else: return self.repostrabajos.delete(trabajo) print("Trabajo eliminado con exito !!!") #INFORME: Historial de trabajos de un cliente, buscado por su id def historial_trabajos(self): id_cliente = int(input("Ingrese el ID del cliente: ")) cliente = self.reposclientes.get_one(id_cliente) lista = self.listatrabajos.lista for consulta in lista: if consulta.cliente.id_cliente == id_cliente: print("Trabajo del cliente: ") print(consulta) #Mostrar todos los trabajos de la base de datos def mostrar_trabajos(self, lista=None): if lista == None: lista = self.listatrabajos.lista for cliente in lista: print(cliente) print("***********************************") def salir(self): print("Gracias por utilizar el sistema.") sys.exit(0)