private void GerarRelatorioAlbum()
        {
            Text = "Relatório de álbuns";

            LabelGridView.Text     = "Álbuns a serem lançados ainda este ano";
            LabelGridView.Location = new Point(13, 12);

            dataGridView1.Size     = new Size(775, 408);
            dataGridView1.Location = new Point(13, 30);

            LabelMes.Visible     = false;
            MesDesejado.Visible  = false;
            PesquisarMes.Visible = false;

            dataGridView1.Columns.Clear();
            dataGridView1.Columns.Add("Codigo", "Código");
            dataGridView1.Columns.Add("Titulo", "Título");
            dataGridView1.Columns.Add("DataLancamento", "Data de Lançamento");
            RemoverSort();

            List <General.Album> albums = new List <General.Album>();

            for (int i = 0; i < General.AlbumsSize; i++)
            {
                if (General.Albums[i].DataLancamento > DateTime.Today && General.Albums[i].DataLancamento.Year == DateTime.Today.Year)
                {
                    albums.Add(General.Albums[i]);
                }
            }

            General.Album[] albumsArr = albums.ToArray();
            MergeSort.Sort(albumsArr, Array.ConvertAll(albumsArr, a => a.DataLancamento));

            if (albums.Count != 0)
            {
                for (int i = 0; i < albumsArr.Length; i++)
                {
                    dataGridView1.Rows.Add(albumsArr[i].Codigo, albumsArr[i].Titulo, albumsArr[i].DataLancamento.ToString("d"));
                }
            }
            else
            {
                MessageBox.Show("Não existem álbuns a serem lançados ainda este ano.", "Erro", MessageBoxButtons.OK, MessageBoxIcon.Warning);
                Close();
            }
        }
Пример #2
0
        private void Salvar_Click(object sender, EventArgs e)
        {
            string erro = "";

            int codigo = 0;

            if (Codigo.Text != "" && (!int.TryParse(Codigo.Text, out codigo) || codigo <= 0))
            {
                erro += "- O código precisa ser um número maior que zero\n";
            }

            if (Titulo.Text == "" || DataLancamento.Text == "" || NCopiasVendidas.Text == "" || ListaMusicas.CheckedItems.Count == 0 || ArtistasParticipantes.CheckedItems.Count == 0)
            {
                erro += "- Todos os campos precisam ser prenchidos com excessão do código\n";
            }

            if (Index == -1 && BinarySearch.BinarySearchDisplay(Array.ConvertAll(General.Albums, a => a.Codigo).Where(a => a > 0).ToArray(), codigo) != -1)
            {
                erro += "- Este código já está sendo utilizado\n";
            }

            if (!DateTime.TryParse(DataLancamento.Text, out DateTime dataLancamento))
            {
                erro += "- Data de Lançamento inválida\n";
            }

            if (!long.TryParse(NCopiasVendidas.Text, out long nCopiasVendidas))
            {
                erro += "- Número de cópias inválido\n";
            }

            if (erro != "")
            {
                MessageBox.Show(erro, "Erro", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return;
            }

            if (Codigo.Text == "")
            {
                codigo = General.AlbumsSize != 0 ? General.Albums[General.AlbumsSize - 1].Codigo + 1 : 1;
            }

            int[]      indicesMusicas = ListaMusicas.CheckedIndices.Cast <int>().ToArray();
            List <int> codigosMusicas = new List <int>();

            for (int i = 0; i < indicesMusicas.Length; i++)
            {
                codigosMusicas.Add(RefCodesMusicas[indicesMusicas[i]]);
            }

            int[]      indicesArtistas = ArtistasParticipantes.CheckedIndices.Cast <int>().ToArray();
            List <int> codigosArtistas = new List <int>();

            for (int i = 0; i < indicesArtistas.Length; i++)
            {
                codigosArtistas.Add(RefCodesArtistas[indicesArtistas[i]]);
            }

            if (Index == -1)
            {
                General.Albums[General.AlbumsSize++] = new General.Album()
                {
                    Codigo                = codigo,
                    Titulo                = Titulo.Text,
                    DataLancamento        = dataLancamento,
                    NumeroCopiasVendidas  = nCopiasVendidas,
                    CodigosMusicas        = codigosMusicas.ToArray(),
                    ArtistasParticipantes = codigosArtistas.ToArray()
                };

                // A função Array.ConvertAll pega o vetor da struct Album e retorna um vetor de inteiros com os códigos de cada uma
                // A função Where remove todos os índices de código 0 pois nestes casos o vetor não está preenchido e não deve ser ordenado
                MergeSort.Sort(General.Albums, Array.ConvertAll(General.Albums, a => a.Codigo).Where(a => a > 0).ToArray());
            }
            else
            {
                General.Albums[Index] = new General.Album()
                {
                    Codigo                = General.Albums[Index].Codigo,
                    Titulo                = Titulo.Text,
                    DataLancamento        = dataLancamento,
                    NumeroCopiasVendidas  = nCopiasVendidas,
                    CodigosMusicas        = codigosMusicas.ToArray(),
                    ArtistasParticipantes = codigosArtistas.ToArray()
                };
            }

            Program.globalForm.UpdateRows(Main.DataGrid.Albuns);
            Close();
        }
Пример #3
0
        private void Salvar_Click(object sender, EventArgs e)
        {
            string erro = "";

            int codigo = 0;

            if (Codigo.Text != "" && (!int.TryParse(Codigo.Text, out codigo) || codigo <= 0))
            {
                erro += "- O código precisa ser um número maior que zero\n";
            }

            if (NomeVerdadeiro.Text == "" || NomeArtistico.Text == "" || DataAniversario.Text == "" || (BandaSN.Checked && Banda.Text == "") || Email.Text == "" || Telefone.Text == "" || NomeEmpresario.Text == "" || EmailEmpresario.Text == "" || TipoTrabalho.SelectedIndex == -1 || NAlbunsLancados.Text == "" || NComposicoes.Text == "")
            {
                erro += "- Todos os campos precisam ser prenchidos com excessão do código\n";
            }

            if (!DateTime.TryParse(DataAniversario.Text, out DateTime aniversario))
            {
                erro += "- O campo Data de Aniversário não está em um formato válido, utilize o formato dia/mês/ano\n";
            }

            if (!int.TryParse(NAlbunsLancados.Text, out int nAlbunsLancados))
            {
                erro += "- O número de álbuns lançados precisa ser um número\n";
            }

            if (!int.TryParse(NComposicoes.Text, out int nComposicoes))
            {
                erro += "- O número de composições precisa ser um número\n";
            }

            if (!decimal.TryParse(CacheMinimo.Text, out decimal cacheMinimo))
            {
                erro += "- O campo cache mínimo precisa ser um número\n";
            }

            if (Index == -1 && BinarySearch.BinarySearchDisplay(Array.ConvertAll(General.Artistas, a => a.Codigo).Where(a => a > 0).ToArray(), codigo) != -1)
            {
                erro += "- Este código já está sendo utilizado\n";
            }

            if (!ValidateMail(Email.Text))
            {
                erro += "- Formato de e-mail do artista inválido, tente o formato [email protected]\n";
            }

            if (!ValidateMail(EmailEmpresario.Text))
            {
                erro += "- Formato de e-mail do empresário inválido, tente o formato [email protected]\n";
            }

            if (erro != "")
            {
                MessageBox.Show(erro, "Erro", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return;
            }

            General.Artista.TipoTrabalho tipoTrabalho = TipoTrabalho.SelectedIndex switch
            {
                0 => General.Artista.TipoTrabalho.Cantor,
                1 => General.Artista.TipoTrabalho.Compositor,
                2 => General.Artista.TipoTrabalho.Ambos,
                _ => throw new ArgumentOutOfRangeException(),
            };

            if (Codigo.Text == "")
            {
                codigo = General.ArtistasSize != 0 ? General.Artistas[General.ArtistasSize - 1].Codigo + 1 : 1;
            }

            if (Index == -1)
            {
                General.Artistas[General.ArtistasSize++] = new General.Artista()
                {
                    Codigo                    = codigo,
                    NomeVerdadeiro            = NomeVerdadeiro.Text,
                    NomeArtistico             = NomeArtistico.Text,
                    Aniversario               = aniversario,
                    BandaBool                 = BandaSN.Checked,
                    NomeBanda                 = Banda.Text,
                    Email                     = Email.Text,
                    Telefone                  = Telefone.Text,
                    NomeEmpresario            = NomeEmpresario.Text,
                    EmailEmpresario           = EmailEmpresario.Text,
                    EmailEmpresarioTabelaHash = HashTable.QuadraticHashInsert(EmailEmpresario.Text),
                    TipoDeTrabalho            = tipoTrabalho,
                    NumeroAlbunsLancados      = nAlbunsLancados,
                    NumeroComposicoes         = nComposicoes,
                    CacheMinimo               = cacheMinimo
                };

                // A função Array.ConvertAll pega o vetor da struct Album e retorna um vetor de inteiros com os códigos de cada uma
                // A função Where remove todos os índices de código 0 pois nestes casos o vetor não está preenchido e não deve ser ordenado
                MergeSort.Sort(General.Artistas, Array.ConvertAll(General.Artistas, a => a.Codigo).Where(a => a > 0).ToArray());
            }
            else
            {
                if (EmailEmpresario.Text != General.Artistas[Index].EmailEmpresario)
                {
                    HashTable.Edit(General.Artistas[Index].EmailEmpresarioTabelaHash, EmailEmpresario.Text);
                }

                General.Artistas[Index] = new General.Artista()
                {
                    Codigo                    = General.Artistas[Index].Codigo,
                    NomeVerdadeiro            = NomeVerdadeiro.Text,
                    NomeArtistico             = NomeArtistico.Text,
                    Aniversario               = aniversario,
                    BandaBool                 = BandaSN.Checked,
                    NomeBanda                 = Banda.Text,
                    Email                     = Email.Text,
                    Telefone                  = Telefone.Text,
                    NomeEmpresario            = NomeEmpresario.Text,
                    EmailEmpresario           = EmailEmpresario.Text,
                    EmailEmpresarioTabelaHash = General.Artistas[Index].EmailEmpresarioTabelaHash,
                    TipoDeTrabalho            = tipoTrabalho,
                    NumeroAlbunsLancados      = nAlbunsLancados,
                    NumeroComposicoes         = nComposicoes,
                    CacheMinimo               = cacheMinimo
                };
            }

            Program.globalForm.UpdateRows(Main.DataGrid.Artistas);
            Close();
        }
        private void Salvar_Click(object sender, EventArgs e)
        {
            string erro = "";

            int codigo = 0;

            if (Codigo.Text != "" && (!int.TryParse(Codigo.Text, out codigo) || codigo <= 0))
            {
                erro += "- O código precisa ser um número maior que zero\n";
            }

            if (Titulo.Text == "" || Letra.Text == "" || Melodia.Text == "" || Compositor.SelectedIndex == -1 || Artista.SelectedIndex == -1)
            {
                erro += "- Todos os campos precisam ser prenchidos com excessão do código\n";
            }

            if (Index == -1 && BinarySearch.BinarySearchDisplay(Array.ConvertAll(General.Cancoes, a => a.Codigo).Where(a => a > 0).ToArray(), codigo) != -1)
            {
                erro += "- Este código já está sendo utilizado\n";
            }

            if (erro != "")
            {
                MessageBox.Show(erro, "Erro", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return;
            }

            if (Codigo.Text == "")
            {
                codigo = General.CancoesSize != 0 ? General.Cancoes[General.CancoesSize - 1].Codigo + 1 : 1;
            }

            if (Index == -1)
            {
                General.Cancoes[General.CancoesSize++] = new General.Cancao()
                {
                    Codigo           = codigo,
                    Titulo           = Titulo.Text,
                    Letra            = Letra.Text,
                    Melodia          = Melodia.Text,
                    CodigoCompositor = RefCodes[Compositor.SelectedIndex],
                    CodigoArtistaPrimeiraGravacao = RefCodes[Artista.SelectedIndex]
                };

                // A função Array.ConvertAll pega o vetor da struct Album e retorna um vetor de inteiros com os códigos de cada uma
                // A função Where remove todos os índices de código 0 pois nestes casos o vetor não está preenchido e não deve ser ordenado
                MergeSort.Sort(General.Cancoes, Array.ConvertAll(General.Cancoes, a => a.Codigo).Where(a => a > 0).ToArray());
            }
            else
            {
                General.Cancoes[Index] = new General.Cancao()
                {
                    Codigo           = General.Cancoes[Index].Codigo, // Codigo nao pode ser alterado
                    Titulo           = Titulo.Text,
                    Letra            = Letra.Text,
                    Melodia          = Melodia.Text,
                    CodigoCompositor = RefCodes[Compositor.SelectedIndex],
                    CodigoArtistaPrimeiraGravacao = RefCodes[Artista.SelectedIndex]
                };
            }

            Program.globalForm.UpdateRows(Main.DataGrid.Musicas);
            Close();
        }