protected void Page_Load(object sender, EventArgs e) { TrabajoDeFecha fecha = new TrabajoDeFecha(); DataTable turnosEmpresa = fecha.TurnosEmpresa(Login.Cod_Empresa); droTurnos.DataSource = turnosEmpresa; droTurnos.DataValueField = "COD_TURNO"; droTurnos.DataBind(); txtTurnoEmple.Text = Request.QueryString["val"]; txtFecha.Text = Request.QueryString["dia"]; }
protected void Page_Load(object sender, EventArgs e) { TrabajoDeFecha fecha = new TrabajoDeFecha(); DataTable turnosEmpresa = fecha.TurnosEmpresa(Login.Cod_Empresa); droTurnos.DataSource = turnosEmpresa; droTurnos.DataTextField = "COD_TURNO"; droTurnos.DataValueField = "COD_TURNO"; droTurnos.DataBind(); if (IsPostBack) { droTurnos.SelectedIndex = valor; } /* RUTINA LA CUAL PERMITE DEJAR CONFIGURADA LA INSERCION O ACTUALIZACION DEL TURNO */ txtTurnoEmple.Text = Request.QueryString["val"]; string diaT = Request.QueryString["dia"]; string fechaT = Request.QueryString["fecha"]; txtCodigo.Text = Request.QueryString["codTur"]; lblNombre2.Text = Request.QueryString["nombre"]; Session["codi"] = Request.QueryString["Empre"]; fechaT = fechaT.Remove(0, 2); string resul = diaT + fechaT; //if (txtTurnoEmple.Text == "Sin Turno") //{ // btnActualizarTurno.Text = "Ingresar"; //} if (resul.Length < 10) { resul = resul.PadLeft(10, '0'); txtFecha.Text = resul; } else { txtFecha.Text = resul; } }
/* FUNCION QUE SE ENCARGA DEL LLENADO DE LA TABLA, COLOCANDO TANTO LOS TURNOS COMO LOS DIAS CORRESPONDIENTES * AL MES EN CURSO */ public void AsignarPrimerDia(string primerDia, int cantiDias, string fecha_ini, string fecha_fin, string cod_empleado) { /* ESTADO CONTROLA SI YA SE HA ESTABLECIDO EL PRIMER DIA, 0 SIGNIFICA QUE TODAVIA NO SE HA ESTABLECIDO */ /* contadorTurnos PERMITE IR EXTRAYENDO LOS TURNOS DEL ARRAYLIST turnoEmpleado */ int contador = 1; int estadoInicial = 0; int contadorTurnos = 0; int contaIDCeldas = 0; TrabajoDeFecha fecha = new TrabajoDeFecha(Session["fecha"].ToString()); ArrayList turnosEmpleado = fecha.TurnoEmpleadoPorFecha(cod_empleado, fecha_ini, fecha_fin); //Table ListaUsuario = new Table(); for (int i = 0; i < 7; i++) { TableRow fila = new TableRow(); TableRow fila2 = new TableRow(); for (int j = 0; j < 7; j++) { /* ESTABLECE EL PRIMER DIA DEL MES */ if ((primerDia == ListaUsuario.Rows[0].Cells[j].Text) && (estadoInicial == 0)) { TableCell celda = new TableCell(); celda.Text = "1"; fila.Cells.Add(celda); estadoInicial = 1; } /* DEJA CON EL TEXTO VACIO LA CELDA SI TODAVIA NO SE HA ESTABLECIDO EL PRIMER DIA */ else if (estadoInicial == 0) { TableCell celda = new TableCell(); celda.Text = "Vacio"; fila.Cells.Add(celda); } /* DEJA EN VACIO TODOS LOS DIAS CORRESPONDIENTES AL MES SGT */ else if (contador >= cantiDias) { TableCell celda = new TableCell(); celda.Text = "Vacio"; fila.Cells.Add(celda); } /* DEJA COMO TEXTO EL CONTADOR EL CUAL MANTIENE EL NUMERO DE DIAS MAXIMOS DEL MES */ else { contador = contador + 1; TableCell celda = new TableCell(); celda.Text = Convert.ToString(contador); fila.Cells.Add(celda); } } ListaUsuario.Rows.Add(fila); /* RECORRE CELDAS DE LA TABLA COMPARANDO SI EL DIA Y EL DIATURNO SON IGUALES SI ES ASI CREA UNA CELDA LA CUAL TIENE EL * TURNO DEL EMPLEADO, SINO COLOCA SIN TURNO */ for (int x = 0; x < 7; x++) { int rows = ListaUsuario.Rows.Count - 1; /* VERIFICA QUE SE NO SE PRODUSCA UN DESBORDE EN EL ARRAYLIST turnosEmpleado */ if (contadorTurnos >= turnosEmpleado.Count) { TableCell celda = new TableCell(); LinkButton tur = new LinkButton(); tur.Text = "Sin Turno"; tur.Attributes.Add("OnClick","Open('" + tur.Text + "')"); celda.ID = contaIDCeldas.ToString(); celda.Controls.Add(tur); celda.Font.Bold = true; fila2.Cells.Add(celda); } /* EN CASO DE QUE LA CELDA CORRESPONDIENTE AL DIA DEL MES DIGA Vacio ESTE LO DEJA COMO SIN TURNO */ else if (ListaUsuario.Rows[rows].Cells[x].Text == "Vacio") { TableCell celda = new TableCell(); LinkButton tur = new LinkButton(); tur.Text = "Sin Turno"; tur.Attributes.Add("OnClick", "Open('" + tur.Text + "')"); celda.ID = contaIDCeldas.ToString(); celda.Controls.Add(tur); celda.Font.Bold = true; fila2.Cells.Add(celda); } /* ASIGNA TURNO CUANDO EL DIA DE LA TABLA SE CORRESPONDA CON EL DEL TURNO * SE APLICAN CONVERSIONES A INT PARA PODER REALIZAR COMPARACION */ else if (Convert.ToInt32(ListaUsuario.Rows[rows].Cells[x].Text) == Convert.ToInt32(turnosEmpleado[contadorTurnos].ToString())) { TableCell celda = new TableCell(); LinkButton tur = new LinkButton(); tur.Text = turnosEmpleado[contadorTurnos + 1].ToString(); tur.Attributes.Add("OnClick", "Open('" + tur.Text + "','" + ListaUsuario.Rows[rows].Cells[x].Text + "')"); celda.ID = contaIDCeldas.ToString(); celda.Controls.Add(tur); fila2.Cells.Add(celda); contadorTurnos += 2; } else { TableCell celda = new TableCell(); LinkButton tur = new LinkButton(); tur.Text = "Sin Turno"; tur.Attributes.Add("OnClick", "Open('" + tur.Text + "')"); celda.ID = contaIDCeldas.ToString(); celda.Controls.Add(tur); celda.Font.Bold = true; fila2.Cells.Add(celda); } contaIDCeldas += 1; } /* SE AGREGA FILA2 LA CUAL CONTIENE LAS CELDAS CORRESPONDIENTES A LOS TURNOS */ ListaUsuario.Rows.Add(fila2); } }
/* FUNCION QUE SE ENCARGA DE CREAR Y LLENAR LA TABLA */ public void LlenaTabla(string codEmple) { TrabajoDeFecha myfecha = new TrabajoDeFecha(Session["fecha"].ToString()); ArrayList datos = myfecha.CantidadDiaMes(); AsignarPrimerDia(datos[1].ToString(), Convert.ToInt32(datos[0].ToString()), datos[3].ToString(), datos[4].ToString(),codEmple); }