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(); } }
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(); }
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(); }