Beispiel #1
0
    protected void Page_Load(object sender, EventArgs e)
    {
        if ((bool)Session["Complete"] != true)
        {
            Response.Write("<META HTTP-EQUIV='refresh' content='2;URL=''>");
        }
        else
        {
            //            pnlAguarde.Visible = false;
            lblStatus.Text     = "Recursos distribuidos com sucesso (N/S = recursos não solicitados)";
            lblStatus.Visible  = true;
            lbtnVoltar.Visible = true;

            BusinessData.Entities.Calendario cal = (BusinessData.Entities.Calendario)Session["Calendario"];
            ControleCalendario calendarios       = new ControleCalendario();
            Calendario         calAtual          = calendarios.GetCalendario(cal.Ano, cal.Semestre);

            Dictionary <Guid, SatisfacaoTurma> satTurmas = new Dictionary <Guid, SatisfacaoTurma>();
            //Preenche a colecao para todas as turmas do semestre
            foreach (TurmaDistribuicao t in calAtual.Turmas)
            {
                satTurmas.Add(t.EntidadeTurma.Id, new SatisfacaoTurma(t));
            }

            ColecaoRequisicoes listaReq = (ColecaoRequisicoes)Session["ReqResult"];
            string             ant      = "";
            foreach (Requisicao req in listaReq)
            {
                Guid   id    = req.Turma.EntidadeTurma.Id;
                string atual = req.Turma.EntidadeTurma.Id + req.Dia.Data.ToShortDateString() + req.Horario;
                // Se a turma estiver no dicionário (todas devem estar) e a turma+dia+horário
                // do último recurso atendido não for o mesmo, conta essa requisição
                // como válida
                if (satTurmas.ContainsKey(id))// && !atual.Equals(ant))
                {
                    /*
                     * if (req.Turma.EntidadeTurma.Disciplina.Nome.Contains("Nome da Disciplina") &&
                     * req.Turma.EntidadeTurma.Professor.Nome.Contains("Nome do Professor"))
                     * {
                     *  Debug.WriteLine(req.Prioridade + ": " + req.Dia.Data.ToShortDateString() + " " +
                     *      " - " + req.Horario + " - " +
                     *      req.CategoriaRecurso.Descricao + " - " + req.EstaAtendido);
                     *  Debug.WriteLine("   atual: " + atual);
                     *  Debug.WriteLine("   ant:   " + ant);
                     * }
                     */

                    if (!atual.Equals(ant))
                    {
                        satTurmas[id].Pedidos++;
                    }
                    if (req.EstaAtendido)
                    {
                        satTurmas[id].Atendimentos++;
//                        if (atual.Equals(ant))
//                            satTurmas[id].Pedidos--;
                    }
                    ant = req.Turma.EntidadeTurma.Id + req.Dia.Data.ToShortDateString() + req.Horario;
                }
            }

            List <TurmaRelat> listaTurmas = new List <TurmaRelat>();
            foreach (TurmaDistribuicao t in calAtual.Turmas)
            {
                Guid id = t.EntidadeTurma.Id;

                int    atend        = satTurmas[id].Atendimentos;
                int    pedidos      = satTurmas[id].Pedidos;
                double satisfDouble = 1;
                string satisf       = "100%";
                if (pedidos > 0)
                {
                    satisfDouble = atend / (double)pedidos;
                    satisf       = String.Format("{0:P}", satisfDouble);
                }
                bool dadosOK = t.EntidadeTurma.Disciplina.Categoria.Descricao.Contains("Teórica") ||
                               t.EntidadeTurma.Disciplina.Categoria.Descricao.Contains("PPG") ||
                               t.EntidadeTurma.Curso.Nome.Contains("PPG") ||
                               t.EntidadeTurma.Curso.Nome.StartsWith("Física");

                // Recursos não foram solicitados para essa turma, mas deveriam ter sido
                if (!dadosOK && pedidos == 0)
                {
                    satisfDouble = 0;
                    satisf       = "N/S";
                }

                listaTurmas.Add(new TurmaRelat
                {
                    Id         = id,
                    Numero     = t.EntidadeTurma.Numero,
                    Disciplina = t.EntidadeTurma.Disciplina,
                    Curso      = t.EntidadeTurma.Curso,
                    DataHora   = t.EntidadeTurma.DataHora,
                    Professor  = t.EntidadeTurma.Professor,
                    Pedidos    = pedidos,
                    Atendidos  = atend,
                    Satisfacao = satisf,
                    Satisf     = satisfDouble
                });
                //                Response.Write(t.EntidadeTurma.Disciplina+ " - " +
                //                    t.EntidadeTurma.Numero + " ("+ t.EntidadeTurma.Professor+") " +
                //                    atend + " de " + pedidos + "<br/>");
            }
            listaTurmas.Sort();
            grvListaTurmas.DataSource    = listaTurmas;
            grvListaTurmas.RowDataBound += grvListaTurmas_RowDataBound;
            grvListaTurmas.DataBind();
        }
    }
Beispiel #2
0
 public static Evento newEvento(PessoaBase autorId, string descricao, Calendario calendarioId, string responsavel, string titulo, string unidade)
 {
     return(new Evento(Guid.NewGuid(), autorId, descricao, calendarioId, responsavel, titulo, unidade));
 }
Beispiel #3
0
    protected void Page_Load(object sender, EventArgs e)
    {
        cal = null;
        Guid idturma    = new Guid();
        bool mostraAval = true;

        if (Request.QueryString["id"] != null)
        {
            listCData = cdataBo.GetCategoriaDatas();
            try
            {
                idturma = new Guid(Request.QueryString["id"]);
                int           ano      = int.Parse(Request.QueryString["ano"]);
                int           semestre = int.Parse(Request.QueryString["sem"]);
                CalendariosBO calBO    = new CalendariosBO();
                cal = calBO.GetCalendarioByAnoSemestre(ano, semestre);
                string strProx = Request.QueryString["aval"];
                if (string.IsNullOrEmpty(strProx))
                {
                    mostraAval = false;
                }
            }
            catch (FormatException)
            {
                Response.Redirect("~/Default/Erro.aspx?Erro=Codigo de turma inválido!");
            }

            Session["TurmaId"] = idturma;
            CategoriaAtividadeBO      cateBO          = new CategoriaAtividadeBO();
            List <CategoriaAtividade> listaAtividades = cateBO.GetCategoriaAtividade();
            AulaBO      AulaBO     = new AulaBO();
            List <Aula> listaAulas = null;
            try
            {
                listaAulas = AulaBO.GetAulas(idturma);
            }
            catch (Exception)
            {
                Response.Redirect("~/Default/Erro.aspx?Erro=Codigo de turma inválido!");
            }
            Disciplina          d   = listaAulas[0].TurmaId.Disciplina;
            CategoriaDisciplina cat = d.Categoria;

            string sala   = Regex.Replace(listaAulas[0].TurmaId.Sala, "32/A", "32");
            string titulo = d.Cod + "-" + d.Cred + " " + d.Nome + " (" + listaAulas[0].TurmaId.Numero + ") - " + sala;//" "+facin;
            lblTitulo.Text = titulo;

            string shortTitle = "";
            foreach (string part in d.Nome.Split())
            {
                if (part.Length == 1 && part[0] != 'I')
                {
                    continue;
                }
                if (part == "de" || part == "do" || part == "da" || part == "em")
                {
                    continue;
                }
                if (part == "I" || part == "II" || part == "III" || part == "IV" || part == "V" ||
                    part == "A" || part == "B" || part == "C")
                {
                    shortTitle += part;
                }
                else
                {
                    shortTitle += char.ToUpper(part[0]);
                }
            }
            string st = shortTitle;

            string output = "BEGIN:VCALENDAR\n";
            output += "PRODID:-//SARC//" + d.Cod + "-" + d.Cred + " " + d.Nome + "//PT\n";
            output += "VERSION:2.0\n";
            output += "CALSCALE:GREGORIAN\n";
            output += "METHOD:PUBLISH\n";
            output += "X-WR-CALNAME:" + st + "\n";
            output += "X-WR-TIMEZONE:America/Sao_Paulo\n";
            output += "X-WR-CALDESC:" + st + "\n";

            DateTime hoje = DateTime.Now;

            DataTable tabela = new DataTable();

            AlocacaoBO alocBO = new AlocacaoBO();

            foreach (DataGridColumn coluna in dgAulas.Columns)
            {
                tabela.Columns.Add(coluna.HeaderText);
            }

            int     totalAulas = 1;
            DataRow dr;
            bool    notset = true;
            foreach (Aula aula in listaAulas)
            {
                string hi = Horarios.ParseToDateTime(aula.Hora).TimeOfDay.ToString().Substring(0, 5);
                string hf = Horarios.ParseToDateTime(aula.Hora).TimeOfDay.Add(TimeSpan.FromMinutes(90)).ToString().Substring(0, 5);
                dr              = tabela.NewRow();
                dr["#"]         = totalAulas++;
                dr["Dia"]       = DataHelper.GetDia(aula.Data.DayOfWeek);
                dr["Data"]      = aula.Data.Date.ToShortDateString();
                dr["Hora"]      = aula.Hora + "<br>" + hi + " - " + hf;
                dr["Descrição"] = aula.DescricaoAtividade;
                dr["Atividade"] = aula.CategoriaAtividade.Descricao;
                dr["Prox"]      = "";

                DateTime startDt = aula.Data.Add(Horarios.ParseToDateTime(aula.Hora).TimeOfDay).AddHours(3);
                DateTime endDt   = startDt.AddMinutes(90);

                List <BusinessData.Entities.Recurso> recAlocados = alocBO.GetRecursoAlocadoByAula(aula.Data, aula.Hora, (Guid)aula.Id);
                string aux     = "";
                string recHoje = "";
                shortTitle = st;
                foreach (var rec in recAlocados)
                {
                    if (aux != String.Empty)
                    {
                        aux += "<br/>" + rec.Descricao;
                    }
                    else
                    {
                        aux = rec.Descricao;
                        //Debug.WriteLine("Tipo recurso:" + rec.Tipo);
                        if (rec.Tipo == 'L' || rec.Tipo == 'A' || rec.Tipo == 'D')
                        {
                            recHoje     = rec.Descricao;
                            shortTitle += " " + recHoje.Split().Last();
                            break;
                        }
                    }
                }
                dr["Recursos"]  = aux;
                dr["CorDaData"] = aula.CategoriaAtividade.Cor.ToArgb();

                if (aula.Data.Date >= cal.InicioG2)
                {
                    dr["#"] = "";
                    totalAulas--;
                }

                Data data      = VerificaData(aula.Data.Date);
                bool diaLetivo = true;
                if (data != null)
                {
                    foreach (CategoriaData c in listCData)
                    {
                        if (c.Id == data.Categoria.Id)
                        {
                            if (!c.DiaLetivo)
                            {
                                dr["Descrição"] = c.Descricao + (aula.DescricaoAtividade != "Feriado" ? " (era " + aula.DescricaoAtividade + ")" : "");
                                dr["#"]         = "";
                                totalAulas--;
                                diaLetivo = false;
                                break;
                            }
                        }
                    }
                }
                //Debug.WriteLine("Cor aula: " + aula.CategoriaAtividade.Cor.ToString());
                tabela.Rows.Add(dr);

                if (recHoje == string.Empty)
                {
                    recHoje     = sala;
                    shortTitle += " " + recHoje;
                }

                if (diaLetivo)
                {
                    if (mostraAval && aula.CategoriaAtividade.Descricao != "Prova" && aula.CategoriaAtividade.Descricao != "Prova de Substituição" &&
                        aula.CategoriaAtividade.Descricao != "Prova de G2" && aula.CategoriaAtividade.Descricao != "Trabalho")
                    {
                        continue;
                    }
                    output += "BEGIN:VEVENT\n";
                    output += "DESCRIPTION: " + aula.DescricaoAtividade + "\n";
                    output += "SUMMARY: " + shortTitle + "\n";
                    output += string.Format("DTSTAMP:{0:yyyyMMddTHHmmssZ}\n", DateTime.Now);
//                    output += "DTSTART:"+startDt.Year+startDt.Month+startDt.Day+startDt.Hour+startDt.Minute+startDt.Second+"\n";
                    //output += "DTSTART:" + startDt.ToString() + "\n";
                    output += string.Format("DTSTART:{0:yyyyMMddTHHmmssZ}\n", startDt);
                    output += string.Format("DTEND:{0:yyyyMMddTHHmmssZ}\n", endDt);
                    output += "LOCATION:" + recHoje + "\n";
                    output += "SEQUENCE:0\n";
                    output += "TRANSP:OPAQUE\n";
                    SHA256 sha      = SHA256.Create();
                    byte[] uidarray = sha.ComputeHash(Encoding.Unicode.GetBytes(aula.DescricaoAtividade + startDt.ToString() + shortTitle + endDt.ToString()));
                    string uid      = Convert.ToBase64String(uidarray);
                    output += "UID:" + uid + "\n";
                    output += "END:VEVENT\n";
                }
            }
            dgAulas.DataSource     = tabela;
            dgAulas.ItemDataBound += new DataGridItemEventHandler(dgAux_ItemDataBound);
            dgAulas.DataBind();

            output += "END:VCALENDAR\n";
            Response.AppendHeader("Content-Disposition", "attachment; filename=" + st + ".ics");
            Response.ContentType = "text/calendar";
            Response.Write(output);

            Response.End();
        }
    }
Beispiel #4
0
    private void VisualizarAlocacoesRecurso()
    {
        List <Alocacao> listaAlocacoes;

        try
        {
            //if (ddlCategorias.SelectedIndex != 0)
            //{
            // Selecionou um recurso especifico?
            if (ddlRecursos.SelectedIndex != 0)
            {
                Guid recursoId = new Guid(ddlRecursos.SelectedValue);
                if (txtData.Text.Length != 0)
                {
                    DateTime data = DateTime.Parse(txtData.Text);
                    listaAlocacoes = controladorAlocacoes.GetAlocacoes((BusinessData.Entities.Calendario)Session["Calendario"], data, recursoId);
                    if (listaAlocacoes.Count != 0)
                    {
                        dgAlocacoes.DataSource = listaAlocacoes;
                        dgAlocacoes.Visible    = true;
                        dgAlocacoes.DataBind();
                        lblStatus.Visible = false;
                    }
                    else
                    {
                        lblStatus.Text      = "Não existem alocações para este recurso na data selecionada.";
                        lblStatus.Visible   = true;
                        dgAlocacoes.Visible = false;
                    }
                }
                else
                {
                    listaAlocacoes = controladorAlocacoes.GetAlocacoesSemData((BusinessData.Entities.Calendario)Session["Calendario"], recursoId);
                    if (listaAlocacoes.Count != 0)
                    {
                        ((List <Alocacao>)listaAlocacoes).Sort();
                        dgAlocacoes.DataSource = listaAlocacoes;
                        dgAlocacoes.Visible    = true;
                        dgAlocacoes.DataBind();
                        lblStatus.Visible = false;
                    }
                    else
                    {
                        lblStatus.Text      = "Não existem alocações para este recurso.";
                        lblStatus.Visible   = true;
                        dgAlocacoes.Visible = false;
                    }
                }
            }
            else
            {
                dgAlocacoes.Visible = false;
                lblStatus.Text      = "Selecione um Recurso Válido.";
                BusinessData.Entities.Calendario cal = (BusinessData.Entities.Calendario)Session["Calendario"];

//                    AulaBO aulaBo = new AulaBO();
//                    List<Aula> aulas = aulaBo.
//                    foreach (Aula aula in aulas)
//                    {
//                        lblStatus.Text += aula.Data.ToShortDateString() + "<br>";
//                    }
            }
            //}
            //else
            //{
            //    dgAlocacoes.Visible = false;
            //    lblStatus.Text = "Selecione uma Categoria de Recurso Válido.";
            //}
        }
        catch (FormatException)
        {
            dgAlocacoes.Visible = false;
            lblStatus.Text      = "Digite uma data válida!";
        }
        catch (System.Data.SqlTypes.SqlTypeException)
        {
            dgAlocacoes.Visible = false;
            lblStatus.Text      = "Digite uma data válida!";
        }
    }
Beispiel #5
0
 /// <summary>
 /// Cria uma nova turma contendo um Guid
 /// </summary>
 /// <param name="numero">Numero</param>
 /// <param name="calendario">Calendario</param>
 /// <param name="disciplina">Disciplina</param>
 /// <param name="dh">DataHora</param>
 /// <param name="prof">Professor</param>
 /// <returns></returns>
 public static TurmaSemProfessor NewTurma(int numero, Calendario calendario, Disciplina disciplina, string dh, Curso curso)
 {
     return(new TurmaSemProfessor(Guid.NewGuid(), numero, calendario, disciplina, dh, curso));
 }
Beispiel #6
0
 public static TurmaSemProfessor GetTurma(Guid id, int num, Calendario calend, Disciplina disc, string dh, Curso curso)
 {
     return(new TurmaSemProfessor(id, num, calend, disc, dh, curso));
 }
Beispiel #7
0
 public object Clone()
 {
     return(Calendario.GetCalendario(id, semestre, ano, datas, inicioG1, inicioG2, fimG2));
 }
Beispiel #8
0
    protected void Page_Load(object sender, EventArgs e)
    {
        cal = null;
        Guid idturma    = new Guid();
        bool mostraProx = true;

        if (Request.QueryString["id"] != null)
        {
            listCData = cdataBo.GetCategoriaDatas();
            try
            {
                idturma = new Guid(Request.QueryString["id"]);
                int           ano      = int.Parse(Request.QueryString["ano"]);
                int           semestre = int.Parse(Request.QueryString["sem"]);
                CalendariosBO calBO    = new CalendariosBO();
                cal = calBO.GetCalendarioByAnoSemestre(ano, semestre);
                string strProx = Request.QueryString["prox"];
                if (string.IsNullOrEmpty(strProx))
                {
                    mostraProx = false;
                }
            }
            catch (FormatException)
            {
                Response.Redirect("~/Default/Erro.aspx?Erro=Codigo de turma inválido!");
            }

            Session["TurmaId"] = idturma;
            CategoriaAtividadeBO      cateBO          = new CategoriaAtividadeBO();
            List <CategoriaAtividade> listaAtividades = cateBO.GetCategoriaAtividade();
            AulaBO      AulaBO     = new AulaBO();
            List <Aula> listaAulas = null;
            try
            {
                listaAulas = AulaBO.GetAulas(idturma);
            }
            catch (Exception)
            {
                Response.Redirect("~/Default/Erro.aspx?Erro=Codigo de turma inválido!");
            }
            Disciplina          d   = listaAulas[0].TurmaId.Disciplina;
            CategoriaDisciplina cat = d.Categoria;

            string sala   = Regex.Replace(listaAulas[0].TurmaId.Sala, "32/A", "32");
            string titulo = d.Cod + "-" + d.Cred + " " + d.Nome + " (" + listaAulas[0].TurmaId.Numero + ") - " + sala;//" "+facin;
            lblTitulo.Text = titulo;

            DateTime hoje = DateTime.Now;
            //           if (mostraProx)
            //               lblProx.Text = "26/08/2019 [QUA LM] - Apresentação (Sala de aula)";

            DataTable tabela = new DataTable();

            AlocacaoBO alocBO = new AlocacaoBO();

            foreach (DataGridColumn coluna in dgAulas.Columns)
            {
                tabela.Columns.Add(coluna.HeaderText);
            }
            //            tabela.Columns.Add("Recursos");

            int     totalAulas = 1;
            DataRow dr;
            bool    notset = true;
            foreach (Aula aula in listaAulas)
            {
                string hi = Horarios.ParseToDateTime(aula.Hora).TimeOfDay.ToString().Substring(0, 5);
                string hf = Horarios.ParseToDateTime(aula.Hora).TimeOfDay.Add(TimeSpan.FromMinutes(90)).ToString().Substring(0, 5);
                dr              = tabela.NewRow();
                dr["#"]         = totalAulas++;
                dr["Dia"]       = DataHelper.GetDia(aula.Data.DayOfWeek);
                dr["Data"]      = aula.Data.Date.ToShortDateString();
                dr["Hora"]      = aula.Hora + "<br>" + hi + " - " + hf;
                dr["Descrição"] = aula.DescricaoAtividade;
                dr["Atividade"] = aula.CategoriaAtividade.Descricao;
                dr["Prox"]      = "";

                List <BusinessData.Entities.Recurso> recAlocados = alocBO.GetRecursoAlocadoByAula(aula.Data, aula.Hora, (Guid)aula.Id);
                //                dr["Recursos"] = "";
                string aux     = "";
                string recHoje = "";
                foreach (var rec in recAlocados)
                {
                    if (aux != String.Empty)
                    {
                        aux += "<br/>" + rec.Descricao;
                    }
                    else
                    {
                        aux = rec.Descricao;
                        //Debug.WriteLine("Tipo recurso:" + rec.Tipo);
                        if (rec.Tipo == 'L' || rec.Tipo == 'A' || rec.Tipo == 'D' || rec.Tipo == 'X')
                        {
                            recHoje = rec.Descricao;
                        }
                    }
                }
                dr["Recursos"]  = aux;
                dr["CorDaData"] = aula.CategoriaAtividade.Cor.ToArgb();

                if (aula.Data.Date >= cal.InicioG2)
                {
                    dr["#"] = "";
                    totalAulas--;
                }

                Data data = VerificaData(aula.Data.Date);
                if (data != null)
                {
                    foreach (CategoriaData c in listCData)
                    {
                        if (c.Id == data.Categoria.Id)
                        {
                            if (!c.DiaLetivo)
                            {
                                dr["Descrição"] = c.Descricao + (aula.DescricaoAtividade != "Feriado" ? " (era " + aula.DescricaoAtividade + ")" : "");
                                dr["#"]         = "";
                                totalAulas--;
                                break;
                            }
                        }
                    }
                }
                //Debug.WriteLine("Cor aula: " + aula.CategoriaAtividade.Cor.ToString());
                tabela.Rows.Add(dr);

                if (recHoje == string.Empty)
                {
                    recHoje = sala;
                }

                if (notset)
                {// && hoje.Date == aula.Data.Date)
                    //Debug.WriteLine("Aula: " + aula.Data.ToString() + " - hoje: "+hoje.ToString());
                    switch (aula.Hora)
                    {
                    case "AB":
                        aula.Data = aula.Data.AddHours(8);
                        break;

                    case "CD":
                        aula.Data = aula.Data.AddHours(9).AddMinutes(45);
                        break;

                    case "EX":
                        aula.Data = aula.Data.AddHours(11).AddMinutes(30);
                        break;

                    case "FG":
                        aula.Data = aula.Data.AddHours(14);
                        break;

                    case "HI":
                        aula.Data = aula.Data.AddHours(15).AddMinutes(45);
                        break;

                    case "JK":
                        aula.Data = aula.Data.AddHours(17).AddMinutes(30);
                        break;

                    case "LM":
                        aula.Data = aula.Data.AddHours(19).AddMinutes(15);
                        break;

                    case "NP":
                        aula.Data = aula.Data.AddHours(21).AddMinutes(0);
                        break;
                    }
                    long tickDiff = aula.Data.Ticks - hoje.Ticks;
                    //Debug.WriteLine("Tickdiff: "+tickDiff);
//                    hoje.
                    TimeSpan ts = TimeSpan.FromTicks(tickDiff);
                    //Debug.WriteLine("Timespan diff: " + ts.Duration().TotalHours);
                    if (tickDiff >= 0 || ts.Duration().TotalHours < 1)
                    {
                        lblProx.Text = aula.Data.Date.ToShortDateString() + " [" + dr["Dia"] + " " + aula.Hora + "] - " + aula.DescricaoAtividade
                                       + " (" + recHoje + ")";
                        TimeSpan diff        = aula.Data.Subtract(hoje);
                        int      roundedDays = (int)Math.Round(diff.TotalDays);
//                        lblProx.Text += diff.TotalDays + " - " + diff.TotalHours + " - " + diff.TotalMinutes + " -> "+Math.Round(diff.TotalDays);
                        //lblProx.Text += " -> " + aula.Data.ToString() + " - " + hoje.ToString();
                        /**/
                        if (roundedDays > 0)
                        {
                            if (roundedDays == 1)
                            {
                                lblProx.Text += " - amanhã";
                            }
                            else
                            {
                                lblProx.Text += " - daqui a " + roundedDays + " dias";
                            }
                        }
                        else if (diff.Hours > 0)
                        {
                            lblProx.Text += " - começa em " + diff.Hours + " hora" + (diff.Hours > 1 ? "s" : "");
                        }
                        else if (diff.Minutes > 0)
                        {
                            lblProx.Text += " - começa em " + diff.Minutes + " minuto" + (diff.Minutes > 1 ? "s" : "");
                        }
                        else if (diff.Minutes < 0)
                        {
                            lblProx.Text += " - começou há " + (-diff.Minutes) + " minuto" + (diff.Minutes < 1 ? "s" : "");
                        }
                        /**/

                        //lblProx.Text += " - " + diff.Days + " dias, " + diff.Hours + " horas, " + diff.Minutes + " minutos";
                        dr["Prox"] = "X"; // marca como a próxima aula na tabela
                        if (!mostraProx)
                        {
                            lblProx.Text = "";
                        }
                        else
                        {
                            // Se prox estiver ativo, oculta a grade e o título
                            dgAulas.Visible   = false;
                            lblTitulo.Visible = false;
                            break;
                        }
                        notset = false;
                    }
                }
            }
            if (lblProx.Text == String.Empty && mostraProx)
            {
                dgAulas.Visible   = false;
                lblTitulo.Visible = false;
                lblProx.Text      = "Não há mais atividades";
            }
            dgAulas.DataSource     = tabela;
            dgAulas.ItemDataBound += new DataGridItemEventHandler(dgAux_ItemDataBound);
            dgAulas.DataBind();
        }
    }