public static Dictionary <int, PlantillaItem> GetAllItemsByPlantillaFromDB(int IdPlantilla) { PlantillaItem item = new PlantillaItem(); Dictionary <int, PlantillaItem> items = new Dictionary <int, PlantillaItem>(); SqlConnection conexion = null; SqlCommand comando = null; SqlDataReader resultado = null; conexion = new SqlConnection(); conexion.ConnectionString = ConfiguracionDataAccess.GetInstance().CadenaConexion; comando = new SqlCommand(); comando.Connection = conexion; comando.CommandText = ProcGet.GET_ITEM_ALL_BYPLANTILLA; comando.CommandType = CommandType.StoredProcedure; comando.Parameters.AddWithValue("@idPlantilla", IdPlantilla); comando.Connection.Open(); resultado = comando.ExecuteReader(); while (resultado.Read()) { item.IdData = Convert.ToInt32(resultado["id"]); item.TipoDato = (TipoDato)Convert.ToInt32(resultado["tipoDato"]); items.Add(item.IdData, item); } resultado.Close(); comando.Connection.Close(); comando.Dispose(); return(items); }
public static Dictionary <int, PlantillaItem> GetItemByGrupo(int idData) { Dictionary <int, PlantillaItem> items = new Dictionary <int, PlantillaItem>(); PlantillaItem item = null; SqlConnection conexion = new SqlConnection(); conexion.ConnectionString = ConfiguracionDataAccess.GetInstance().CadenaConexion; SqlCommand comando = new SqlCommand(); comando.Connection = conexion; comando.CommandText = ProcGet.GET_ITEM_BYGRUPO; comando.CommandType = CommandType.StoredProcedure; comando.Parameters.AddWithValue("@idGrupo", idData); int indiceItem = 0, idGrupo = idData; comando.Connection.Open(); SqlDataReader resultado = comando.ExecuteReader(); while (resultado.Read()) { item = new PlantillaItem(); item.IdData = Convert.ToInt32(resultado["id"]); item.Nombre = resultado["nombre"].ToString(); item.PorDefault = resultado["porDefault"].ToString(); item.TipoDato = (TipoDato)Convert.ToInt32(resultado["idTipoItem"]); item.TipoCampo = (TipoCampo)Convert.ToInt32(resultado["idTipoCampo"]); item.TieneUnidad = Convert.ToBoolean(resultado["tieneUnidad"]); item.Unidad = resultado["unidad"].ToString(); int indice = Convert.ToInt32(resultado["indice"]); indiceItem = indice; switch (item.TipoCampo) { case TipoCampo.Lista: item.Opciones = GetListItemByItem(item.IdData); break; } items.Add(indice, item); } resultado.Close(); conexion.Close(); comando.Dispose(); return(items); }
public FormatoImpresion CrearAllDocumento(Dictionary <int, Examen> examenes, Orden orden, float tamañoFuente, Size tamañoPag) { LogicaPaciente oLPaciente = new LogicaPaciente(); Clasificador clasificador = new Clasificador(); FormatoImpresion formato; tamañoPag.Height = tamañoPag.Height / 2; tamañoPag.Width = tamañoPag.Width / 2; Paciente paciente = oLPaciente.ObtenerPerfilPorId(orden.IdPaciente); int idLastResponsable = 0; DateTime tempTime = DateTime.MinValue; foreach (Examen ex in examenes.Values) { Area area = (Area)Plantillas.GetInstance().GetPlantilla(ex.IdPlantilla).Area; repositorio[area].Add(ex.IdData); if (ex.UltimaModificacion >= tempTime) { tempTime = ex.UltimaModificacion; idLastResponsable = ex.IdCuenta; } } //CONSTRUCCION DE CABECERA formato = new FormatoImpresion(); FormatoImpresionCabecera cab = new FormatoImpresionCabecera(); Dictionary <int, FormatoImpresionPagina> paginas = new Dictionary <int, FormatoImpresionPagina>(); LogicaCuenta oLCuenta = new LogicaCuenta(); BLMedico oLMedico = new BLMedico(); Medico med = oLMedico.ObtenerMedico(orden.IdMedico); Cuenta cu = oLCuenta.ObtenerCuenta(idLastResponsable); Tiempo tiempo = DiccionarioGeneral.GetInstance().CalcularEdad(paciente.FechaNacimiento); cab.Edad = DiccionarioGeneral.GetInstance().FormatoEdad(tiempo); cab.Orden = "No " + orden.IdData; cab.Nombre = CultureInfo.CurrentCulture.TextInfo.ToTitleCase((paciente.Nombre + " " + paciente.PrimerApellido + " " + paciente.SegundoApellido)); cab.Historia = paciente.Historia; cab.Responsable = CultureInfo.CurrentCulture.TextInfo.ToTitleCase((cu.Nombre + " " + cu.PrimerApellido + " " + cu.SegundoApellido + " - " + cu.Especialidad)); cab.Doctor = CultureInfo.CurrentCulture.TextInfo.ToTitleCase((med.Nombre + " " + med.PrimerApellido + " " + med.SegundoApellido)); cab.UltimaRev = (tempTime.ToShortDateString()); formato.Cabecera = cab; Dictionary <int, FormatoImpresionPaginaLinea> lineas = null; FormatoImpresionPagina pagina = null; FormatoImpresionPaginaLinea linea = null; int indexLinea = 0; foreach (Area key in repositorio.Keys) { if (repositorio[key].Count > 0) { pagina = new FormatoImpresionPagina(); lineas = new Dictionary <int, FormatoImpresionPaginaLinea>(); pagina.Detalles = lineas; indexLinea = 0; //CONSTRUCCION DE PAGINAS linea = new FormatoImpresionPaginaLinea(); linea.Nombre = "LABORATORIO DE " + DiccionarioGeneral.GetInstance().Area[(int)key]; linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.TituloArea; lineas.Add(indexLinea, linea); indexLinea++; foreach (int idEx in repositorio[key]) { Examen ex = examenes[idEx]; linea = new FormatoImpresionPaginaLinea(); linea.Nombre = Plantillas.GetInstance().GetPlantilla(ex.IdPlantilla).Nombre; linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.TituloExamen; lineas.Add(indexLinea, linea); indexLinea++; Dictionary <int, PlantillaFila> plantillaFila = Plantillas.GetInstance().GetPlantilla(ex.IdPlantilla).Filas; for (int i = 0; i < plantillaFila.Count; i++) { switch (plantillaFila[i].Tipo) { case PlantillaFila.PlantillaFilaTipo.Agrupada: PlantillaFilaGrupo filaGrupo = (PlantillaFilaGrupo)plantillaFila[i]; linea = new FormatoImpresionPaginaLinea(); linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.TituloGrupo; linea.Nombre = filaGrupo.Nombre; lineas.Add(indexLinea, linea); indexLinea++; if (filaGrupo.IdData == 4) //Para el grupo especial Medicina // Luego se puede mejorar Agregando un elemento deseado incorporandolo { foreach (PlantillaItem itemG in filaGrupo.Items.Values) { linea = new FormatoImpresionPaginaLinea(); linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.ItemSimple; linea.Nombre = " * " + itemG.Nombre; int indice = Convert.ToInt32(ex.DetallesByItem[itemG.IdData].Campo); if (indice != 0) { linea.Resultado = itemG.OpcionesByIndice[indice]; lineas.Add(indexLinea, linea); indexLinea++; } } } else { foreach (PlantillaItem itemG in filaGrupo.Items.Values) { switch (itemG.TipoCampo) { case TipoCampo.Input: linea = new FormatoImpresionPaginaLinea(); linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.ItemSimple; linea.Nombre = " * " + itemG.Nombre; linea.Resultado = ex.DetallesByItem[itemG.IdData].Campo.ToString(); if (itemG.TieneUnidad) { linea.Resultado += itemG.Unidad; } linea.Resultado += clasificador.Clasificar(paciente, ex.IdData, ex.DetallesByItem[itemG.IdData]); lineas.Add(indexLinea, linea); indexLinea++; break; case TipoCampo.Lista: linea = new FormatoImpresionPaginaLinea(); linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.ItemSimple; linea.Nombre = " * " + itemG.Nombre; linea.Resultado = itemG.OpcionesByIndice[Convert.ToInt32(ex.DetallesByItem[itemG.IdData].Campo)]; lineas.Add(indexLinea, linea); indexLinea++; break; case TipoCampo.Texto: if (!ex.DetallesByItem[itemG.IdData].Campo.Equals("")) { linea = new FormatoImpresionPaginaLinea(); linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.ItemSimple; linea.Nombre = " * " + itemG.Nombre; string temp = ""; List <string> lista = ConstructorFicha.AcoplarTexto(linea.Nombre + ": " + ex.DetallesByItem[itemG.IdData].Campo.ToString(), "Futura Bk BT", 7.5f, (double)tamañoPag.Width); for (int ind = 0; ind < lista.Count; ind++) { linea = new FormatoImpresionPaginaLinea(); linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.ItemTexto; if (itemG.TieneUnidad && indexLinea + 1 == lista.Count) { temp += itemG.Unidad; } linea.Resultado = lista[ind]; lineas.Add(indexLinea, linea); indexLinea++; } } break; } } } break; case PlantillaFila.PlantillaFilaTipo.Simple: PlantillaItem item = ((PlantillaFilaSimple)plantillaFila[i]).Item; switch (item.TipoCampo) { case TipoCampo.Input: linea = new FormatoImpresionPaginaLinea(); linea.Nombre = item.Nombre; linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.ItemSimple; linea.Resultado = ex.DetallesByItem[item.IdData].Campo.ToString(); if (item.TieneUnidad) { linea.Resultado += " " + item.Unidad; } switch (item.TipoDato) { case TipoDato.Entero: linea.Resultado += clasificador.Clasificar(paciente, ex.IdData, ex.DetallesByItem[item.IdData]); break; case TipoDato.Decimal: linea.Resultado += clasificador.Clasificar(paciente, ex.IdData, ex.DetallesByItem[item.IdData]); break; } lineas.Add(indexLinea, linea); indexLinea++; break; case TipoCampo.Lista: linea = new FormatoImpresionPaginaLinea(); linea.Nombre = item.Nombre; linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.ItemSimple; linea.Resultado = item.OpcionesByIndice[Convert.ToInt32(ex.DetallesByItem[item.IdData].Campo)]; lineas.Add(indexLinea, linea); indexLinea++; break; case TipoCampo.Texto: if (!ex.DetallesByItem[item.IdData].Campo.Equals("")) { linea = new FormatoImpresionPaginaLinea(); linea.Nombre = item.Nombre; string temp = ""; List <string> lista = ConstructorFicha.AcoplarTexto(linea.Nombre + ": " + ex.DetallesByItem[item.IdData].Campo, "Futura Bk BT", 7.5f, (double)tamañoPag.Width); for (int ind = 0; ind < lista.Count; ind++) { linea = new FormatoImpresionPaginaLinea(); linea.TipoLinea = FormatoImpresionPaginaLinea.TipoPaginaLinea.ItemTexto; if (item.TieneUnidad && ind + 1 == lista.Count) { temp += item.Unidad; } linea.Resultado = lista[ind]; lineas.Add(indexLinea, linea); indexLinea++; } } break; } break; } } } formato.Paginas.Add(pagina); } } return(formato); }