def VisualizarDepartamentos(): if 'username' in session: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre as Nombre, apellido as Apellido,sueldo as Sueldo, cargo.descripcion as Cargo, departamento.descripcion as Departamento, sector.descripcion as Sector, codigoSupervisor FROM empresa.empleado, empresa.cargo, empresa.departamento, empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and sector.Departamento_idDepartamento = departamento.idDepartamento and idEmpleado >5;''') data = db.fetchall() db.close() if data: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre, apellido FROM empresa.empleado where idEmpleado<6;''') data1 = db.fetchall() db.close() user = session['username'] return render_template('departamentos.html', user=user, empleados=data, sup=data1)
def add_contact(): if 'username' in session: if request.method == 'POST': name = request.form['name'] lastname = request.form['lastname'] email = request.form['email'] phone = request.form['phone'] sueldo = request.form['sueldo'] cargo = request.form['cargo'] sector = request.form['sector'] supervisor = request.form['supervisor'] con.connect() db = con.cursor() db.execute( '''SELECT idEmpleado FROM empresa.empleado where nombre = %s''', (supervisor)) data = db.fetchall() db.close() print(data) if data: con.connect() db = con.cursor() db.execute( "INSERT INTO empresa.empleado (nombre, apellido, email, telefono, sueldo, codigoSupervisor, Cargo_idCargo, Sector_idSector) VALUES (%s,%s,%s,%s,%s,%s, %s,%s)", (name, lastname, email, phone, sueldo, data, cargo, sector)) con.commit() flash('Empleado Added successfully') return redirect(url_for('Index'))
def Buscar(): if 'username' in session: con.connect() db = con.cursor() if request.method == 'POST': busqueda = request.form['busqueda'] sql = f"select idEmpleado as Id, nombre as Nombre, apellido as Apellido,sueldo as Sueldo, cargo.descripcion as Cargo, departamento.descripcion as Departamento, sector.descripcion as Sector, codigoSupervisor from empresa.empleado, empresa.cargo, empresa.departamento, empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and sector.Departamento_idDepartamento = departamento.idDepartamento and idEmpleado >5 and (nombre LIKE '%{busqueda}%' or cargo.descripcion LIKE '%{busqueda}%' or sector.descripcion LIKE '%{busqueda}%' or apellido LIKE '%{busqueda}%' or departamento.descripcion LIKE '%{busqueda}%');" db.execute(sql) user = db.fetchall() db.close() con.close() data = [] if user: for usu in user: datos = { 'id': usu[0], 'nombre': usu[1], 'apellido': usu[2], 'sueldo': usu[3], 'cargo': usu[4], 'departamento': usu[5], 'sector': usu[6], 'supervisor': usu[7] } data.append(datos) users = json.dumps(data) return users
def update_contact(id): if 'username' in session: if request.method == 'POST': name = request.form['name'] lastname = request.form['lastname'] email = request.form['email'] phone = request.form['phone'] sueldo = request.form['sueldo'] cargo = request.form['cargo'] sector = request.form['sector'] supervisor = request.form['supervisor'] con.connect() db = con.cursor() db.execute( """ UPDATE empresa.empleado SET nombre = %s, apellido = %s, email = %s, telefono = %s, sueldo = %s, Cargo_idCargo = %s, Sector_idSector = %s, codigoSupervisor = %s WHERE idEmpleado = %s """, (name, lastname, email, phone, sueldo, cargo, sector, supervisor, id)) flash('Empleado actualizado satisfactoriamente') con.commit() return redirect(url_for('Index'))
def Index(): if 'username' in session: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre, apellido FROM empresa.empleado where idEmpleado<6;''') data = db.fetchall() db.close() if data: con.connect() db = con.cursor() db.execute('SELECT * FROM empresa.cargo') data1 = db.fetchall() db.close() if data1: con.connect() db = con.cursor() db.execute('SELECT * FROM empresa.empleado') data2 = db.fetchall() db.close() if data2: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre as Nombre, apellido as Apellido, email as Email, telefono as Telefono,sueldo as Sueldo, cargo.descripcion as Cargo, sector.descripcion as Sector FROM empresa.empleado, empresa.cargo,empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector''' ) data3 = db.fetchall() db.close() if data3: con.connect() db = con.cursor() db.execute('SELECT * FROM empresa.sector') data4 = db.fetchall() db.close() user = session['username'] return render_template('index.html', user=user, supervisor=data, cargos=data1, empleado=data2[0], empleados=data3, sector=data4)
def delete_contact(id): if 'username' in session: con.connect() db = con.cursor() db.execute( 'DELETE FROM empresa.empleado WHERE idEmpleado = {0}'.format(id)) con.commit() flash('Empleado eliminado satisfactoriamente') return redirect(url_for('Index'))
def GenerarReporte(): if 'username' in session: con.connect() db = con.cursor() db.execute( '''select departamento.idDepartamento, departamento.descripcion from empresa.departamento''' ) depto = db.fetchall() con.commit() user = session['username'] return render_template('generar-reporte.html', user=user, depto=depto)
def getSector(id): if 'username' in session: print(id) con.connect() db = con.cursor() db.execute( '''select idEmpleado, nombre from empresa.empleado, empresa.sector where idEmpleado<6 and sector.idSector = %s''', (id)) sector = db.fetchall() con.commit() print(sector) sec = json.dumps(sector) return sec
def get_contact(id): if 'username' in session: con.connect() db = con.cursor() db.execute( '''SELECT idEmpleado, nombre, apellido, email, telefono,sueldo, cargo.idCargo, cargo.descripcion, sector.idSector, sector.descripcion,codigoSupervisor FROM empresa.empleado, empresa.cargo, empresa.sector WHERE cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and idEmpleado = %s''', (id)) data = db.fetchall() db.close() if data: con.connect() db = con.cursor() db.execute('SELECT * FROM empresa.cargo') data1 = db.fetchall() db.close() if data1: con.connect() db = con.cursor() db.execute('SELECT * FROM empresa.sector') data2 = db.fetchall() db.close() if data2: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre, apellido FROM empresa.empleado where idEmpleado<6;''') data3 = db.fetchall() db.close() user = session['username'] return render_template('edit-contact.html', user=user, empleados=data[0], cargos=data1, sector=data2, sup=data3)
def acceso(): if request.method == 'POST': name = request.form['name'] password = request.form['password'] #clave = generate_password_hash(password) db = con.connect() db = con.cursor() sql = "Select * from empresa.empleado where nombre='{}' and clave='{}'".format( name, password) db.execute(sql) user = db.fetchone() if user: session['username'] = name session['id'] = user[0] # al acceder exitosamente traemos la informacion de los contactos db.execute('SELECT * FROM empresa.empleado') db.close() con.close() #return redirect(url_for('Index')) user = session['username'] return render_template('home.html', user=user) else: flash('Error. Usuario y/o contraseña incorrectos.') return redirect(url_for('login'))
def reporte(): if request.method == 'POST': depa = request.form['departamento'] tipo = request.form['tipo'] # Selecciona todos y que muestre los departamentos y sectores if depa == 'todos' and tipo == '0': con.connect() db = con.cursor() db.execute( '''select idEmpleado, nombre as Nombre, apellido as Apellido, cargo.descripcion as Cargo, departamento.descripcion as Departamento, sector.descripcion as Sector, codigoSupervisor FROM empresa.empleado, empresa.cargo, empresa.departamento, empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and sector.Departamento_idDepartamento = departamento.idDepartamento and idEmpleado >5;''' ) data = db.fetchall() print(data) db.close() if data: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre, apellido FROM empresa.empleado where idEmpleado<6;''') sup = db.fetchall() db.close() rendered = render_template('reportes/report-depa-todos.html', empleados=data, sup=sup) pdf = pdfkit.from_string(rendered, False) response = make_response(pdf) response.headers['content-Type'] = 'application/pdf' response.headers[ 'content-Disposition'] = 'inline: filename=reporte_departamentos.pdf' return response # Selecciona todos y que muestre los sueldos elif depa == 'todos' and tipo == '1': con.connect() db = con.cursor() db.execute( '''select idEmpleado, nombre, apellido, cargo.descripcion, sueldo, departamento.descripcion, sector.descripcion, codigoSupervisor FROM empresa.empleado, empresa.cargo, empresa.departamento, empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and sector.Departamento_idDepartamento = departamento.idDepartamento and idEmpleado >5;''') data1 = db.fetchall() db.close() if data1: con.connect() db = con.cursor() db.execute( '''select sueldo as Sueldo FROM empresa.empleado where idEmpleado>5;''') dat = db.fetchall() db.close() sueldo = 0 for suel in dat: sueldo = sueldo + suel[0] if dat: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre, apellido FROM empresa.empleado where idEmpleado<6;''') sup = db.fetchall() db.close() rendered = render_template('reportes/report-sueldo-todos.html', empleados=data1, sueldo=sueldo, sup=sup) pdf = pdfkit.from_string(rendered, False) response = make_response(pdf) response.headers['content-Type'] = 'application/pdf' response.headers[ 'content-Disposition'] = 'inline: filename=reporte_sueldos.pdf' return response # Selecciona todos y que muestre por fecha elif depa == 'todos' and tipo == '2': con.connect() db = con.cursor() db.execute( '''select idEmpleado, nombre, apellido, departamento.descripcion, fecha_ingreso FROM empresa.empleado, empresa.cargo, empresa.departamento, empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and sector.Departamento_idDepartamento = departamento.idDepartamento and idEmpleado >5 ORDER BY fecha_ingreso DESC;''' ) data2 = db.fetchall() db.close() rendered = render_template('reportes/report-fecha-todos.html', empleados=data2) pdf = pdfkit.from_string(rendered, False) response = make_response(pdf) response.headers['content-Type'] = 'application/pdf' response.headers[ 'content-Disposition'] = 'inline: filename=reporte_fecha.pdf' return response # Selecciona un departamento y quiere ver los empleados por departamento elif depa and tipo == '0': con.connect() db = con.cursor() db.execute( '''select idEmpleado, nombre, apellido,cargo.descripcion, departamento.descripcion, sector.descripcion, codigoSupervisor FROM empresa.empleado, empresa.cargo, empresa.departamento, empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and sector.Departamento_idDepartamento = departamento.idDepartamento and idEmpleado >5 and departamento.descripcion = %s;''', (depa)) data3 = db.fetchall() db.close() if data3: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre, apellido FROM empresa.empleado where idEmpleado<6;''') sup = db.fetchall() db.close() rendered = render_template('reportes/report-depa.html', empleados=data3, sup=sup, depa=depa) pdf = pdfkit.from_string(rendered, False) response = make_response(pdf) response.headers['content-Type'] = 'application/pdf' response.headers[ 'content-Disposition'] = 'inline: filename=reporte_depa.pdf' return response elif depa and tipo == '1': con.connect() db = con.cursor() db.execute( '''select idEmpleado, nombre, apellido,sueldo, cargo.descripcion, departamento.descripcion, sector.descripcion, codigoSupervisor FROM empresa.empleado, empresa.cargo, empresa.departamento, empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and sector.Departamento_idDepartamento = departamento.idDepartamento and idEmpleado >5 and departamento.descripcion = %s;''', (depa)) data4 = db.fetchall() db.close() if data4: sueldo = 0 for suel in data4: sueldo = sueldo + suel[3] if data4: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre, apellido FROM empresa.empleado where idEmpleado<6;''') sup = db.fetchall() db.close() rendered = render_template('reportes/report-sueldo.html', empleados=data4, sup=sup, depa=depa, sueldo=sueldo) pdf = pdfkit.from_string(rendered, False) response = make_response(pdf) response.headers['content-Type'] = 'application/pdf' response.headers[ 'content-Disposition'] = 'inline: filename=reporte_sueldo.pdf' return response # Se selecciona un departamento y el reporte por fecha elif depa and tipo == '2': con.connect() db = con.cursor() db.execute( '''select idEmpleado, nombre, apellido, departamento.descripcion, fecha_ingreso FROM empresa.empleado, empresa.cargo, empresa.departamento, empresa.sector where cargo.idCargo = empleado.Cargo_idCargo and sector.idSector = empleado.Sector_idSector and sector.Departamento_idDepartamento = departamento.idDepartamento and idEmpleado >5 and departamento.descripcion = %s ORDER BY empleado.fecha_ingreso DESC;''', (depa)) data5 = db.fetchall() db.close() if data5: con.connect() db = con.cursor() db.execute( '''select idEmpleado as Id, nombre, apellido FROM empresa.empleado where idEmpleado<6;''') sup = db.fetchall() db.close() rendered = render_template('reportes/report-fecha.html', empleados=data5, sup=sup, depa=depa) pdf = pdfkit.from_string(rendered, False) response = make_response(pdf) response.headers['content-Type'] = 'application/pdf' response.headers[ 'content-Disposition'] = 'inline: filename=reporte_fecha.pdf' return response return redirect(url_for('GenerarReporte'))