/// -----------------------------------------------------------------------------
 /// <summary>
 /// AnnomesAFecha: zfsf  fasdfa sdfasdf asdf asdf
 /// </summary>
 /// -----------------------------------------------------------------------------
 public static DateTime AnnomesAFecha(int nAnnoMes)
 {
     if (Fechas.ValidarAnnomes(nAnnoMes))
     {
         return(DateTime.Parse("01/" + nAnnoMes.ToString().Substring(4, 2) + "/" + nAnnoMes.ToString().Substring(0, 4)));
     }
     else
     {
         return(DateTime.Parse("01/01/1900"));
     }
 }
        public static string AnnomesAFechaDescLarga(int nAnnoMes)
        {
            string[] aMeses = new string[12] {
                "Enero", "Febrero", "Marzo", "Abril", "Mayo", "Junio", "Julio", "Agosto", "Septiembre", "Octubre", "Noviembre", "Diciembre"
            };

            if (Fechas.ValidarAnnomes(nAnnoMes))
            {
                return(aMeses[AnnomesAFecha(nAnnoMes).Month - 1] + " " + AnnomesAFecha(nAnnoMes).Year.ToString());
            }
            else
            {
                return("");
            }
        }
        public static string AnnomesAFechaDescCorta(int nAnnoMes)
        {
            string[] aMeses = new string[12] {
                "Ene", "Feb", "Mar", "Abr", "May", "Jun", "Jul", "Ago", "Sep", "Oct", "Nov", "Dic"
            };

            if (Fechas.ValidarAnnomes(nAnnoMes))
            {
                return(aMeses[AnnomesAFecha(nAnnoMes).Month - 1] + " " + AnnomesAFecha(nAnnoMes).Year.ToString());
            }
            else
            {
                return("");
            }
        }
        public static string Obtener()
        {
            StringBuilder sb = new StringBuilder();
            SqlDataReader dr = SUPER.Capa_Datos.LIMITEALERTAS.Obtener(null);

            sb.Append(@"<table id='tblDatos' style='width:265px;text-align:left' mantenimiento='1' cellpadding='0' cellspacing='0'>
                        <colgroup>
                            <col style='width:190px' />
                            <col style='width:75px' />
                        </colgroup>");
            string sFecha = "";

            while (dr.Read())
            {
                sb.Append("<tr id='" + dr["t828_anomes"] + "' bd='' " + " onclick='ms(this);'>");
                sb.Append("<td align='center'>" + Fechas.AnnomesAFechaDescLarga(int.Parse(dr["t828_anomes"].ToString())) + "</td>");
                if (dr["t828_limitealertas"] != DBNull.Value)
                {
                    sFecha = DateTime.Parse(dr["t828_limitealertas"].ToString()).ToShortDateString();
                }
                else
                {
                    sFecha = "";
                }

                sb.Append("<td style='text-align:center' class='MA'>");

                if (HttpContext.Current.Session["BTN_FECHA"].ToString() == "I")
                {
                    sb.Append("<input id='txtFF-" + dr["t828_anomes"] + "' type='text' class='txtFecL' style='width:63px;' value='" + sFecha + "' oValueOriginal='" + sFecha + "' Calendar='oCal' ondblclick='mc(event);' onchange='aG(this);' readonly />");
                }
                else
                {
                    sb.Append("<input id='txtFF-" + dr["t828_anomes"] + "' type='text' class='txtFecL' style='width:63px;' value='" + sFecha + "' oValueOriginal='" + sFecha + "' Calendar='oCal' onchange='aG(this);' onfocus='focoFecha(event);' onmousedown='mc1(event)'/>");
                }

                sb.Append("</td>");
                sb.Append("</tr>" + (char)10);
            }
            dr.Close();
            dr.Dispose();
            sb.Append("</table>");

            return("OK@#@" + sb.ToString());;
        }
Beispiel #5
0
        public static int EliminarLineaBase(int t685_idlineabase, int t001_idficepi, string t422_idmoneda)
        {
            string sObservaciones = "";

            //1º Obtener los datos de la línea base para obtener los datos necesarios para la creación de la observación.
            LINEABASE oLB = LINEABASE.Obtener(t685_idlineabase);

            sObservaciones = "Eliminada l&iacute;nea base \"" + oLB.t685_denominacion + "\" que hab&iacute;a sido creada el " + oLB.t685_fecha.ToShortDateString() + ", con Coste Total Planificado (BAC) = ";

            DataSet ds = LINEABASE.ObtenerDatosValorGanado(t685_idlineabase, Fechas.FechaAAnnomes(DateTime.Now), t422_idmoneda);

            sObservaciones += decimal.Parse(ds.Tables[0].Rows[0]["BAC"].ToString()).ToString("N") + " " + t422_idmoneda;

            //2º Creación de la observación automática.
            SUPER.BLL.OBSERVACIONES_LB.Insertar(oLB.t305_idproyectosubnodo, t001_idficepi, true, sObservaciones);

            //3º Eliminar la línea base
            return(Capa_Datos.LINEABASE.Eliminar(null, t685_idlineabase));
        }
Beispiel #6
0
        public static int CrearLineaBase(int t305_idproyectosubnodo, int t314_idusuario, string t685_denominacion, int t001_idficepi, string t422_idmoneda)
        {
            string sDatosLBAnterior = "";
            string sDatosLBNueva    = "";
            string sObservaciones   = "";
            bool   bExisteAnterior  = false;

            //1º Obtener la última línea base (si existe) para obtener los datos necesarios para la creación de la observación.
            int nLineaBase = LINEABASE.ObtenerUltimaLineaBase(t305_idproyectosubnodo);

            if (nLineaBase > 0)
            {
                bExisteAnterior = true;
                DataSet ds = LINEABASE.ObtenerDatosValorGanado(nLineaBase, Fechas.FechaAAnnomes(DateTime.Now), t422_idmoneda);
                sDatosLBAnterior  = "Coste Total Planificado (BAC) de línea base anterior = " + decimal.Parse(ds.Tables[0].Rows[0]["BAC"].ToString()).ToString("N") + " " + t422_idmoneda + (char)10 + (char)13; // "<br>";//  <NNN.NNN€>";
                sDatosLBAnterior += "Duración de proyecto en línea base anterior: " + ds.Tables[0].Rows.Count.ToString() + " meses, finalizando en " + Fechas.AnnomesAFechaDescLarga((int)ds.Tables[0].Rows[ds.Tables[0].Rows.Count - 1]["anomes"]) + ".";
            }

            //2º Crear la nueva línea base.
            int     nIDLB = Capa_Datos.LINEABASE.Insertar(null, Utilidades.unescape(t685_denominacion), t314_idusuario, t305_idproyectosubnodo);
            DataSet ds1   = LINEABASE.ObtenerDatosValorGanado(nIDLB, Fechas.FechaAAnnomes(DateTime.Now), t422_idmoneda);

            sDatosLBNueva  = "Creada línea base " + (char)34 + "{{nombre}}" + (char)34 + @"." + (char)10 + (char)13;                                                                // <br>";
            sDatosLBNueva += "Coste Total Planificado (BAC) = " + decimal.Parse(ds1.Tables[0].Rows[0]["BAC"].ToString()).ToString("N") + " " + t422_idmoneda + (char)10 + (char)13; //"<br>";//  <NNN.NNN€>";
            sDatosLBNueva += "Duración de proyecto en línea base: " + ds1.Tables[0].Rows.Count.ToString() + " meses, finalizando en " + Fechas.AnnomesAFechaDescLarga((int)ds1.Tables[0].Rows[ds1.Tables[0].Rows.Count - 1]["anomes"]) + ".";

            sObservaciones = sDatosLBNueva;
            if (bExisteAnterior)
            {
                //Nota: poniendo: sObservaciones += (char)10 + (char)13... añade dos caracteres "23" antes del salto de línea.
                sObservaciones = sObservaciones + (char)10 + (char)13 + " " + (char)10 + (char)13 + " " + (char)10 + (char)13 + sDatosLBAnterior;
            }

            byte[] data = Encoding.Default.GetBytes(sObservaciones);
            sObservaciones = Encoding.UTF8.GetString(data).Replace("{{nombre}}", Utilidades.unescape(t685_denominacion));
            //3º Creación de la observación automática.
            SUPER.BLL.OBSERVACIONES_LB.Insertar(t305_idproyectosubnodo, t001_idficepi, true, sObservaciones);

            return(nIDLB);
        }
Beispiel #7
0
        public static int ObtenerMesDefecto_old(int t685_idlineabase)
        {
            int nMesActual = Fechas.FechaAAnnomes(DateTime.Today);
            int nMesMinimo = Fechas.FechaAAnnomes(DateTime.Today);
            int nMesMaximo = 0;// Fechas.FechaAAnnomes(DateTime.Today);

            SqlDataReader dr = Capa_Datos.LINEABASE.ObtenerMeses(null, t685_idlineabase);

            while (dr.Read())
            {
                if ((int)dr["anomes"] < nMesMinimo)
                {
                    nMesMinimo = (int)dr["anomes"];
                }
                if ((int)dr["anomes"] > nMesMaximo)
                {
                    nMesMaximo = (int)dr["anomes"];
                }
            }
            dr.Close();
            dr.Dispose();

            if (nMesMaximo == 0)
            {
                nMesMaximo = nMesMinimo;
            }

            if (nMesMaximo < nMesActual)
            {
                return(nMesMaximo);
            }
            else if (nMesMinimo > nMesActual)
            {
                return(nMesMinimo);
            }
            else
            {
                return(nMesActual);
            }
        }
Beispiel #8
0
        public static string ObtenerDesgloseLB(int t685_idlineabase, string t422_idmoneda)
        {
            StringBuilder sbTM       = new StringBuilder();
            StringBuilder sbTMF1     = new StringBuilder();
            StringBuilder sbTMF2     = new StringBuilder();
            StringBuilder sbBF       = new StringBuilder();
            StringBuilder sbBM       = new StringBuilder();
            Hashtable     htDatosMes = new Hashtable();

            bool bColgroupCreado = false;
            int  nWidthBM        = 0;
            //string sGrupo = "";
            DataSet ds = SUPER.Capa_Datos.LINEABASE.ObtenerDesgloseLB(null, t685_idlineabase, t422_idmoneda);

            foreach (DataRow oFila in ds.Tables[2].Rows)     //tabla de datos
            {
                htDatosMes.Add(oFila["anomes"].ToString()
                               + "/" + oFila["idclase"].ToString(), new DATODESGLOSELB((int)oFila["anomes"],
                                                                                       (int)oFila["idclase"],
                                                                                       decimal.Parse(oFila["importe_lb"].ToString()),
                                                                                       decimal.Parse(oFila["importe_real"].ToString()))
                               );
            }

            int nConcepto = -1, nSubgrupo = -1, nGrupo = -1;    //nClase = -1,

            //string sHTML = "";
            foreach (DataRow oFila in ds.Tables[0].Rows)
            {
                //sHTML = "";
                if (!bColgroupCreado)
                {
                    bColgroupCreado = true;

                    #region tblTituloMovil
                    nWidthBM = ds.Tables[1].Rows.Count * 150;
                    sbTM.Append("<table id='tblTituloMovil' style='width:" + nWidthBM.ToString() + "px;' cellpadding='0' cellspacing='0' border='0'>");
                    sbTM.Append("    <colgroup>");
                    #endregion

                    #region tblBodyFijo
                    sbBF.Append("<table id='tblBodyFijo' style='width:480px;' cellpadding='0' cellspacing='0' border='0'>");
                    sbBF.Append("<colgroup>");
                    sbBF.Append("   <col style='width:300px;' />");
                    sbBF.Append("   <col style='width:90px;' />");
                    sbBF.Append("   <col style='width:90px;' />");
                    sbBF.Append("</colgroup>");

                    #endregion

                    #region tblBodyMovil
                    sbBM.Append("<table id='tblBodyMovil' style='width:" + nWidthBM.ToString() + "px;' cellpadding='0' cellspacing='0' border='0'>");
                    sbBM.Append("    <colgroup>");
                    #endregion

                    #region Creacion Colgroups Móviles
                    sbTMF1.Append("<tr style='height:17px;'>");
                    sbTMF2.Append("<tr style='height:17px;'>");

                    foreach (DataRow oFilaMes in ds.Tables[1].Rows)    //Tabla de meses
                    {
                        sbTM.Append("   <col style='width:75px;' />");
                        sbTM.Append("   <col style='width:75px;' />");

                        sbTMF1.Append("   <td colspan='2' style='width:150px;'>" + Fechas.AnnomesAFechaDescLarga((int)oFilaMes["anomes"]) + "</td>");

                        sbTMF2.Append("   <td style='width:75px;'>L&iacute;nea base</td>");
                        sbTMF2.Append("   <td style='width:75px;'>Real</td>");

                        sbBM.Append("   <col style='width:75px;' />");
                        sbBM.Append("   <col style='width:75px;' />");
                    }

                    sbTM.Append("</colgroup>");

                    sbTMF1.Append("</tr>");
                    sbTMF2.Append("</tr>");
                    sbTM.Append(sbTMF1.ToString());
                    sbTM.Append(sbTMF2.ToString());
                    sbTM.Append("</table>");

                    sbBM.Append("</colgroup>");

                    #endregion
                }

                #region tblBodyFijo
                if (nGrupo != int.Parse(oFila["t326_idgrupoeco"].ToString()))
                {
                    nGrupo    = int.Parse(oFila["t326_idgrupoeco"].ToString());
                    nSubgrupo = int.Parse(oFila["t327_idsubgrupoeco"].ToString());
                    nConcepto = int.Parse(oFila["t328_idconceptoeco"].ToString());
                    string[] aTablas = LINEABASE.CrearFilaGrupo(oFila, ds.Tables[1]);
                    sbBF.Append(aTablas[0]);
                    sbBM.Append(aTablas[1]);
                }
                else if (nSubgrupo != int.Parse(oFila["t327_idsubgrupoeco"].ToString()))
                {
                    nSubgrupo = int.Parse(oFila["t327_idsubgrupoeco"].ToString());
                    nConcepto = int.Parse(oFila["t328_idconceptoeco"].ToString());
                    string[] aTablas = LINEABASE.CrearFilaSubgrupo(oFila, ds.Tables[1]);
                    sbBF.Append(aTablas[0]);
                    sbBM.Append(aTablas[1]);
                }
                else if (nConcepto != int.Parse(oFila["t328_idconceptoeco"].ToString()))
                {
                    nConcepto = int.Parse(oFila["t328_idconceptoeco"].ToString());
                    string[] aTablas = LINEABASE.CrearFilaConcepto(oFila, ds.Tables[1]);
                    sbBF.Append(aTablas[0]);
                    sbBM.Append(aTablas[1]);
                }

                sbBF.Append("<tr style='height:20px;' ");
                sbBF.Append("sTipo='CL' ");
                sbBF.Append("idGrupo='" + oFila["t326_idgrupoeco"].ToString() + "' ");
                sbBF.Append("idSubgrupo='" + oFila["t327_idsubgrupoeco"].ToString() + "' ");
                sbBF.Append("idConcepto='" + oFila["t328_idconceptoeco"].ToString() + "' ");
                sbBF.Append("idClase='" + oFila["idclase"].ToString() + "' ");
                sbBF.Append(">");
                sbBF.Append("<td style='text-align:left;'><nobr class='NBR W215' style='margin-left:75px;' onmouseover='TTip(event)'>" + oFila["t329_denominacion"].ToString() + "<nobr></td>");    //
                sbBF.Append("<td>" + (((decimal)oFila["importe_lb"] == 0)?"": decimal.Parse(oFila["importe_lb"].ToString()).ToString("N")) + "</td>");
                sbBF.Append("<td style='border-right: 2px solid #A6C3D2;'>" + (((decimal)oFila["importe_real"] == 0) ? "" : decimal.Parse(oFila["importe_real"].ToString()).ToString("N")) + "</td>");
                sbBF.Append("</tr>");

                #endregion

                #region tblBodyMovil
                //sbBM.Append("<tr style='height:20px;'>");
                sbBM.Append("<tr style='height:20px;' ");
                sbBM.Append("sTipo='CL' ");
                sbBM.Append("idGrupo='" + oFila["t326_idgrupoeco"].ToString() + "' ");
                sbBM.Append("idSubgrupo='" + oFila["t327_idsubgrupoeco"].ToString() + "' ");
                sbBM.Append("idConcepto='" + oFila["t328_idconceptoeco"].ToString() + "' ");
                sbBM.Append("idClase='" + oFila["idclase"].ToString() + "' ");
                sbBM.Append(">");

                foreach (DataRow oFilaMes in ds.Tables[1].Rows)
                {
                    DATODESGLOSELB oDE = (DATODESGLOSELB)htDatosMes[oFilaMes["anomes"].ToString()
                                                                    + "/" + oFila["idclase"].ToString()];
                    if (oDE != null)
                    {
                        sbBM.Append("<td style='width:75px;'>" + ((oDE.importe_lb == 0) ? "" : oDE.importe_lb.ToString("N")) + "</td>");
                        sbBM.Append("<td style='width:75px;'>" + ((oDE.importe_real == 0) ? "" : oDE.importe_real.ToString("N")) + "</td>");
                    }
                    else
                    {
                        sbBM.Append("<td style='width:75px;'></td>");
                        sbBM.Append("<td style='width:75px;'></td>");
                    }
                }

                sbBM.Append("</tr>");
                #endregion
            }

            sbBF.Append("</table>");
            sbBM.Append("</table>");

            return(sbTM.ToString() + "{{septabla}}"
                   + "<div style=\"background-image: url('../../../Images/imgFT20.gif'); background-repeat:repeat; width:480px; height:auto;\">" + sbBF.ToString() + "</div>" + "{{septabla}}"
                   + "<div style=\"background-image: url('../../../Images/imgFT20.gif'); background-repeat:repeat; width:" + nWidthBM.ToString() + "px; height:auto;\">" + sbBM.ToString() + "</div>" + "{{septabla}}");
        }
 public static DateTime getSigDiaUltMesCerrado(int iAnoMesCerrado)
 {
     return(Fechas.AnnomesAFecha(iAnoMesCerrado).AddMonths(1));
 }
        public static string ObtenerIncentivos()
        {
            StringBuilder sb = new StringBuilder();

            #region Cabecera tabla HTML
            sb.Append("<table id='tblDatos' style='width:970px;'>");
            sb.Append("    <colgroup>");
            sb.Append("    <col style='width:40px;' />");
            sb.Append("    <col style='width:70px;' />");
            sb.Append("    <col style='width:280px;' />");
            sb.Append("    <col style='width:50px;' />");
            sb.Append("    <col style='width:50px;' />");
            sb.Append("    <col style='width:220px;' />");
            sb.Append("    <col style='width:80px;' />");
            sb.Append("    <col style='width:80px;' />");
            sb.Append("    <col style='width:100px;' />");
            sb.Append("</colgroup>");
            #endregion

            SqlDataReader dr = SUPER.Capa_Datos.INCENTIVOSPRODUCTIVIDAD.ObtenerIncentivos();
            while (dr.Read())
            {
                sb.Append("<tr id='" + dr["t726_idincentivo"].ToString() + "' ");
                sb.Append("idiberper='" + dr["t726_idiberper"].ToString() + "' ");
                sb.Append("idficepi='" + dr["t001_idficepi"].ToString() + "' ");
                sb.Append("idusuario='" + dr["t314_idusuario"].ToString() + "' ");
                sb.Append("idnodo_usuario='" + dr["t303_idnodo_usuario"].ToString() + "' ");
                sb.Append("importe='" + dr["t726_importe"].ToString() + "' ");
                sb.Append("importeSS='" + dr["t726_importeSS"].ToString() + "' ");
                sb.Append("idproyecto='" + dr["t301_idproyecto"].ToString() + "' ");
                sb.Append("anomes='" + dr["anomesimputacion"].ToString() + "' ");
                sb.Append("style='height:20px;' ");
                if (dr["t314_idusuario"].ToString() == "" && dr["t001_idficepi"].ToString() != "")
                {
                    sb.Append("onclick='ms(this);'");
                }
                sb.Append(">");

                if (dr["t314_idusuario"].ToString() != "")
                {
                    sb.Append("<td style='text-align:center;'><input type='checkbox' class='check' checked></td>");
                }
                else
                {
                    sb.Append("<td><input style='text-align:center;' type='checkbox' class='check' disabled></td>");
                }

                if (dr["t001_idficepi"].ToString() != "")
                {
                    sb.Append("<td style='text-align:right; padding-right:5px;'>" + ((int)dr["t726_idiberper"]).ToString("#,###") + "</td>");
                }
                else
                {
                    sb.Append("<td style='color:red;text-align:right; padding-right:5px;'>" + ((int)dr["t726_idiberper"]).ToString("#,###") + "</td>");
                }

                sb.Append("<td><nobr class='NBR W270'>" + dr["Profesional"].ToString() + "</nobr></td>");

                if (dr["t314_idusuario"].ToString() == "")// && dr["t001_idficepi"].ToString() != "")
                {
                    sb.Append("<td style='text-align:right; padding-right:5px;' class='MA' ondblclick='getProfesional(this, event)'>" + ((dr["t314_idusuario"] == DBNull.Value) ? "" : ((int)dr["t314_idusuario"]).ToString("#,###")) + "</td>");
                }
                else
                {
                    sb.Append("<td style='text-align:right; padding-right:5px;'>" + ((dr["t314_idusuario"] == DBNull.Value) ? "" : ((int)dr["t314_idusuario"]).ToString("#,###")) + "</td>");
                }
                sb.Append("<td style='text-align:right; padding-right:5px;'>" + ((int)dr["t301_idproyecto"]).ToString("#,###") + "</td>");
                sb.Append("<td><div class='NBR W220' onmouseover='TTip(event)'>" + dr["t301_denominacion"].ToString() + "</div></td>");
                sb.Append("<td style='text-align:right; padding-right:3px;'>" + decimal.Parse(dr["t726_importe"].ToString()).ToString("N") + "</td>");
                sb.Append("<td style='text-align:right; padding-right:3px;'>" + decimal.Parse(dr["t726_importeSS"].ToString()).ToString("N") + "</td>");
                sb.Append("<td style='padding-left:5px;'>" + Fechas.AnnomesAFechaDescLarga((int)dr["anomesimputacion"]) + "</td>");
                sb.Append("</tr>");
            }
            dr.Close();
            dr.Dispose();

            sb.Append("</table>");

            return(sb.ToString());
        }