(RESOLVIDO)Ajuda com Relatório - Por Favor!

Pessoal, bom dia…eu criei esta tela para gerar um relatório de vendas:

Até aqui foi fácil, mas como eu nunca fiz um relatório, gostaria de saber como faço agora para que, quando o usuario clicar no botão “Gerar Relatório”, o sistema busque todas as vendas realizadas no período selecionado pelo usuario (Inicio e Fim).

Por exemplo, tenho uma venda teste feita hoje:

agora quero que ao gerar o relatório, todas as vendas do dia 01/04/2021 a 30/04/2021 sejam exibidas no relatório(tenho apenas uma de exemplo, mas imagem 100 vendas no mês, todas devem aparecer). Elas devem aparecer aqui:

Como fazer isso?

Falai @rafaspara2017 blz? Cara vamos la, suponho que esteja construindo o sistema do zero, para o primeiro registro surgir eh bem provável que tenha utilizado SQL para executar a pesquisa no banco de dados correto? Se sim, vc provavelmente teria uma classe itemVendas ou algo do tipo para ser preenchida em seguida exibir na tela?

Pois é só tela não vai adiantar muito para te ajudarmos, precisamos que seja postado seu código para podermos dar uma ajuda mais precisa. Por exemplo posta o código que vc exibe esse item vendido e o codigo de ate onde vc chegou no relatório.

Abraço

1 curtida

@FacaNaCaveira boa tarde, muito obg por sua reposta…segue meus códigos:

Classe Venda (@Entity)

package br.com.fjsistemas.backend;

import java.time.LocalDate;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.ManyToOne;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@AllArgsConstructor
@NoArgsConstructor
@Data
@Entity
public class Venda {
	
	@Id
	@GeneratedValue(strategy = GenerationType.AUTO)
	private Long id;
	
	private LocalDate dataVenda = LocalDate.now();
	
	@ManyToOne
	private Cliente cliente;
	
	private String valorTotalVenda;
}

Classe VendaView

package br.com.fjsistemas.cadastros.view;

import java.text.NumberFormat;
import java.text.ParseException;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
import java.util.List;
import java.util.Locale;

import javax.annotation.PostConstruct;

import org.springframework.beans.factory.annotation.Autowired;
import org.vaadin.textfieldformatter.CustomStringBlockFormatter;

import com.vaadin.flow.component.button.Button;
import com.vaadin.flow.component.button.ButtonVariant;
import com.vaadin.flow.component.combobox.ComboBox;
import com.vaadin.flow.component.datepicker.DatePicker;
import com.vaadin.flow.component.dialog.Dialog;
import com.vaadin.flow.component.grid.Grid;
import com.vaadin.flow.component.grid.GridVariant;
import com.vaadin.flow.component.html.Div;
import com.vaadin.flow.component.html.Label;
import com.vaadin.flow.component.orderedlayout.HorizontalLayout;
import com.vaadin.flow.component.orderedlayout.VerticalLayout;
import com.vaadin.flow.component.textfield.NumberField;
import com.vaadin.flow.component.textfield.TextField;
import com.vaadin.flow.data.binder.Binder;
import com.vaadin.flow.data.binder.PropertyId;
import com.vaadin.flow.data.renderer.LocalDateRenderer;
import com.vaadin.flow.router.PageTitle;
import com.vaadin.flow.router.Route;

import br.com.fjsistemas.backend.Cliente;
import br.com.fjsistemas.backend.Produto;
import br.com.fjsistemas.backend.Venda;
import br.com.fjsistemas.main.MainView;
import br.com.fjsistemas.repository.ClienteRepository;
import br.com.fjsistemas.repository.ProdutoRepository;
import br.com.fjsistemas.service.VendaService;

@Route(value = "venda-view", layout = MainView.class)
@PageTitle("Lançamento de Vendas")
public class VendaView extends VerticalLayout {

	private static final long serialVersionUID = 1L;

	private HorizontalLayout hltVenda = new HorizontalLayout();
	Grid<Venda> grdVenda = new Grid<>(Venda.class, false);

	private HorizontalLayout hltBarraBotoes = new HorizontalLayout();
	Button btnNovo = new Button("Novo");
	Button btnAlterar = new Button("Alterar");
	Button btnExcluir = new Button("Excluir");

	private Dialog dlgJanela = new Dialog();

	Div superior = new Div();
	Div centro = new Div();
	Div inferior = new Div();
	
	HorizontalLayout primeiraLinhaDivSuperior = new HorizontalLayout();
	HorizontalLayout segundaLinhaDivSuperior = new HorizontalLayout();
	HorizontalLayout adicionarProdutos = new HorizontalLayout();

	double somaValores;

	@PropertyId("dataVenda")
	private DatePicker txtDataVenda = new DatePicker("Data Venda");

	@PropertyId("cliente")
	private ComboBox<Cliente> txtNomeCliente = new ComboBox<>("Cliente");

	@PropertyId("telefone")
	private TextField txtTelefone = new TextField("Telefone");

	@PropertyId("celular")
	private TextField txtCelular = new TextField("Celular");
	
	@PropertyId("endereco")
	private TextField txtEndereco = new TextField("Endereço");
	
	@PropertyId("numero")
	private TextField txtNumero = new TextField("Nº");
	
	@PropertyId("bairro")
	private TextField txtBairro = new TextField("Bairro");
	
	@PropertyId("cidade")
	TextField txtCidade = new TextField("Cidade");
	
	@PropertyId("estado")
	TextField txtEstado = new TextField("Estado");
	

	@PropertyId("valorTotalVenda")
	private TextField campoSomaValores = new TextField();

	private HorizontalLayout htlDlgBarraBotoes = new HorizontalLayout();
	private Button btnSalvar = new Button("Salvar");
	private Button btnFechar = new Button("Fechar");
	private Button btnAdicionarItem = new Button("+ Item");

	@Autowired
	VendaService vendaService;

	@Autowired
	ClienteRepository clienteRepository;

	@Autowired
	ProdutoRepository produtoRepository;

	private List<Venda> listaVendas;
	private List<TextField> valores = new ArrayList<>();
	private Venda venda;

	Binder<Venda> binderVenda = new Binder<>(Venda.class);

	public VendaView() {

	}

	@PostConstruct
	public void init() {
		configuraTela();

	}

	private void configuraTela() {

		setMargin(false);
		setPadding(false);

		configuraHltVenda();
		configuraFltBarraBotoes();
		configuraDlgJanela();
		populaGrdVenda();
		configuraBinder();

		add(hltVenda, hltBarraBotoes);
	}

	private void configuraFltBarraBotoes() {

		btnNovo.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		btnNovo.addClickListener(e -> {
			novoClick();
		});

		btnAlterar.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		btnAlterar.addClickListener(e -> {
			alterarClick();
		});

		btnExcluir.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		btnExcluir.addClickListener(e -> {
			excluirClick();
		});

		hltBarraBotoes.add(btnNovo, btnAlterar, btnExcluir);
	}

	private void excluirClick() {

		if (venda != null) {
			listaVendas.remove(venda);
			vendaService.delete(venda);
			atualizaGrdVenda();
		}
	}

	private void configuraHltVenda() {
		hltVenda.setWidthFull();
		configuraGrdVenda();
		hltVenda.add(grdVenda);
	}

	private void configuraGrdVenda() {
		grdVenda.setHeight("820px");
		grdVenda.setWidthFull();

		grdVenda.addColumn(Venda::getId).setHeader("ID:").setAutoWidth(true);

		grdVenda.addColumn(new LocalDateRenderer<>(Venda::getDataVenda, DateTimeFormatter.ofPattern("dd/MM/yyy")))
				.setHeader("Data Venda").setAutoWidth(true);

		grdVenda.addColumn(venda -> venda.getCliente().getNome()).setHeader("Nome:").setAutoWidth(true)
				.setKey("cliente.nome");

		grdVenda.addColumn(Venda::getValorTotalVenda).setHeader("Valor Total:").setAutoWidth(true)
				.setKey("valorTotalVenda");

		grdVenda.addThemeVariants(GridVariant.LUMO_COMPACT, GridVariant.LUMO_COLUMN_BORDERS);

		grdVenda.getColumns().forEach(col -> col.setAutoWidth(true).setSortable(true).setResizable(true));

		grdVenda.addItemClickListener(e -> {
			venda = e.getItem();
		});

	}

	private void configuraDlgJanela() {

		dlgJanela.setHeightFull();
		dlgJanela.setWidthFull();
		dlgJanela.setCloseOnEsc(false);
		dlgJanela.setCloseOnOutsideClick(false);

		superior.setHeight("170px");
		superior.setWidthFull();
		
		txtNomeCliente.setWidth("350px");
		txtNomeCliente.setLabel("Nome Cliente");

		txtNomeCliente.setItemLabelGenerator(cliente -> {
			if (cliente == null || cliente.getNome() == null) {
				return " ";

			} else {
				return cliente.getNome();
			}
		});

		List<Cliente> listaDeClientes = clienteRepository.findAll();

		txtNomeCliente.setItems(listaDeClientes);
		txtNomeCliente.addValueChangeListener(event -> {
			if (event.getValue() == null || event.getValue().getFone() == null) {
				txtTelefone.setValue(" ");
			} else {
				txtTelefone.setValue(event.getValue().getFone());
			}
			if (event.getValue() == null || event.getValue().getCelular() == null) {
				txtCelular.setValue(" ");
			} else {
				txtCelular.setValue(event.getValue().getCelular());
			}
			if(event.getValue() == null || event.getValue().getEndereco() == null) {
				txtEndereco.setValue(" ");
			}else {
				txtEndereco.setValue(event.getValue().getEndereco());
			}
			if(event.getValue() == null || event.getValue().getNumero() == null) {
				txtNumero.setValue(" ");
			}else {
				txtNumero.setValue(event.getValue().getNumero());
			}
			if(event.getValue() == null || event.getValue().getBairro() == null) {
				txtBairro.setValue(" ");
			}else {
				txtBairro.setValue(event.getValue().getBairro());
			}
			if(event.getValue() == null || event.getValue().getCidade() == null) {
				txtCidade.setValue(" ");
			}else {
				txtCidade.setValue(event.getValue().getCidade());
			}
			if(event.getValue() == null || event.getValue().getEstado() == null) {
				txtEstado.setValue(" ");
			}else {
				txtEstado.setValue(event.getValue().getEstado());
			}

		});

		new CustomStringBlockFormatter.Builder().blocks(0, 2, 4, 4).delimiters("(", ")", "-").numeric().build()
				.extend(txtTelefone);

		new CustomStringBlockFormatter.Builder().blocks(0, 2, 5, 4).delimiters("(", ")", "-").numeric().build()
				.extend(txtCelular);
		
		primeiraLinhaDivSuperior.add(txtDataVenda, txtNomeCliente, txtTelefone, txtCelular);
		
		txtNumero.setWidth("140px");
		
		segundaLinhaDivSuperior.add(txtEndereco, txtNumero, txtBairro, txtCidade, txtEstado);
		
		superior.add(primeiraLinhaDivSuperior, segundaLinhaDivSuperior);
		
		centro.setHeight("660px");
		centro.getStyle().set("border-style", "ridge");
		centro.getStyle().set("overflow-y", "scroll");
		centro.setWidthFull();
		
		btnSalvar.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		btnSalvar.getStyle().set("margin-top", "0em");
		btnSalvar.getStyle().set("margin-left", "1em");
		btnSalvar.addClickListener(e -> {
			salvarClick();
			limparCampos();
		});

		btnFechar.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		btnFechar.getStyle().set("margin-top", "0em");
		btnFechar.addClickListener(e -> {
			dlgJanela.close();
			limparCampos();
		});

		btnAdicionarItem.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		btnAdicionarItem.getStyle().set("margin-top", "0em");
		btnAdicionarItem.addClickListener(e -> {
			adicionaProduto();
		});
		
		Label text = new Label("Valor Total");
		text.getElement().getStyle().set("fontWeight", "bold");
		text.getStyle().set("margin-top", "0.8em");
		text.getStyle().set("margin-left", "2em");
		text.getStyle().set("text-align", "center");
		campoSomaValores.getStyle().set("margin-top", "0em");
		campoSomaValores.getStyle().set("margin-right", "0.2em");
		campoSomaValores.setWidth("30em");
		
		htlDlgBarraBotoes.add(btnSalvar, btnFechar, btnAdicionarItem, text, campoSomaValores);
		
		inferior.getStyle().set("margin-top", "0px");
		inferior.setHeight("45px");
		inferior.setWidthFull();
		inferior.add(htlDlgBarraBotoes);

		dlgJanela.add(superior, centro, inferior);

	}

	private void salvarClick() {

		venda = binderVenda.getBean();

		boolean adicionarLista = venda.getId() == null ? true : false;

		vendaService.create(venda);

		if (adicionarLista) {
			listaVendas.add(venda);
		}
		atualizaGrdVenda();
		novaVenda();
		txtNomeCliente.focus();

		binderVenda.setBean(venda);

		if (adicionarLista) {
			dlgJanela.close();
		}
	}

	private void populaGrdVenda() {

		listaVendas = vendaService.read();
		atualizaGrdVenda();
	}

	private void atualizaGrdVenda() {
		grdVenda.setItems(listaVendas);
	}

	private void configuraBinder() {

		binderVenda.bindInstanceFields(this);

	}

	private void novoClick() {

		novaVenda();
		binderVenda.setBean(venda);

		dlgJanela.open();
		txtNomeCliente.focus();
	}

	private void alterarClick() {

		if (venda != null) {
			binderVenda.setBean(venda);

			dlgJanela.open();

		}
	}

	private void adicionaProduto() {

		ComboBox<Produto> txtProdutos = new ComboBox<>();

		NumberField txtQuantidade = new NumberField("Quantidade");

		TextField txtValorUnitario = new TextField("Valor Unitário");

		TextField txtValorTotalItem = new TextField("Valor Total Item");

		txtProdutos.setWidth("370px");
		txtProdutos.setLabel("Produtos");
		List<Produto> listaDeProdutos = produtoRepository.findAll();
		txtProdutos.setItemLabelGenerator(Produto::getNome);
		txtProdutos.setItems(listaDeProdutos);
		txtProdutos.addValueChangeListener(event -> {

			NumberFormat formatter = NumberFormat.getCurrencyInstance(new Locale("pt", "BR"));
			try {

				txtValorUnitario.setValue(formatter.format(event.getValue().getValor()));

			} catch (Exception e) {
				e.printStackTrace();
			}

		});

//==========================================================================================================================

		txtQuantidade.setHasControls(true);
		txtQuantidade.setValue(null);
		txtQuantidade.setMin(1);

		txtQuantidade.addValueChangeListener(event -> {

			NumberFormat formatter = NumberFormat.getCurrencyInstance(new Locale("pt", "BR"));
			double valorTotal = 0;

			try {
				valorTotal = formatter.parse(txtValorUnitario.getValue()).doubleValue() * txtQuantidade.getValue();
			} catch (ParseException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}

			txtValorTotalItem.setValue(formatter.format(valorTotal));

			double soma = 0;
			for (TextField tf : valores) {
				try {
					soma += formatter.parse(tf.getValue()).doubleValue();

				} catch (ParseException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}

			}

			campoSomaValores.setValue(formatter.format(soma));

		});

		adicionarProdutos = new HorizontalLayout();
		adicionarProdutos.add(txtProdutos, txtQuantidade, txtValorUnitario, txtValorTotalItem);

		centro.add(adicionarProdutos);
		valores.add(txtValorTotalItem);
	}
	
	private void limparCampos() {
		centro.removeAll();
	}

	private void novaVenda() {
		venda = new Venda();
		venda.setCliente(null);
		dlgJanela.close();

	}
}
package br.com.fjsistemas.repository;

import org.springframework.data.jpa.repository.JpaRepository;

import br.com.fjsistemas.backend.Venda;

public interface VendaRepository extends JpaRepository<Venda, Long> {

}
package br.com.fjsistemas.service;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import br.com.fjsistemas.backend.Venda;
import br.com.fjsistemas.repository.VendaRepository;

@Service
public class VendaService {
	
	// CRUD

	@Autowired
	private VendaRepository vendaRepository;

	public void create(Venda venda) {
		vendaRepository.save(venda);
	}

	public List<Venda> read() {
		List<Venda> vendas = vendaRepository.findAll();
		return vendas;

	}

	public void update(Venda venda) {
		vendaRepository.save(venda);
	}

	public void delete(Venda venda) {
		vendaRepository.delete(venda);
	}

}

@FacaNaCaveira

tudo que diz respeito as vendas, estão nestas classes

RelatorioView

package br.com.fjsistemas.cadastros.view;

import com.vaadin.flow.component.button.Button;
import com.vaadin.flow.component.button.ButtonVariant;
import com.vaadin.flow.component.datepicker.DatePicker;
import com.vaadin.flow.component.grid.Grid;
import com.vaadin.flow.component.html.Div;
import com.vaadin.flow.component.html.Label;
import com.vaadin.flow.component.orderedlayout.HorizontalLayout;
import com.vaadin.flow.component.orderedlayout.VerticalLayout;
import com.vaadin.flow.component.textfield.TextField;
import com.vaadin.flow.data.binder.PropertyId;
import com.vaadin.flow.router.PageTitle;
import com.vaadin.flow.router.Route;

import br.com.fjsistemas.backend.Venda;
import br.com.fjsistemas.main.MainView;

@Route(value = "relatorio-view", layout = MainView.class)
@PageTitle("Relatório de Vendas")
public class RelatorioView extends VerticalLayout{

	private static final long serialVersionUID = 1L;
	
	Grid<Venda> grdRelatorio = new Grid<>(Venda.class, false);
	private HorizontalLayout layoutDatas = new HorizontalLayout();
	private HorizontalLayout layoutTitulosDiv = new HorizontalLayout();
	
	Div div = new Div();
	
	Div esquerda = new Div();
	Div centro = new Div();
	Div direita = new Div();
	
	Div tituloEsquerda = new Div();
	Div tituloCentro = new Div();
	Div tituloDireita = new Div();
	
	
	private Button gerarRelatorio = new Button("Gerar Relatório");
	
	Label label = new Label("Valor Total no Periodo:");
	Label labelEsquerda = new Label("Data");
	Label labelCentro = new Label("Cliente");
	Label labelDireita = new Label("Valor");
	
	@PropertyId("dataInicio")
	private DatePicker dataInicio = new DatePicker("Início");
	
	@PropertyId("dataFim")
	private DatePicker dataFim = new DatePicker("Final");
	
	@PropertyId("somaValores")
	private TextField somaValores = new TextField();

	public RelatorioView() {
		configuraRelatorio();
	}	
	
	private void configuraRelatorio() {
		
		div.setHeight("700px");
		div.setWidth("1600px");
		div.getStyle().set("display", "table");
		div.getStyle().set("border-style", "ridge");
		div.getStyle().set("overflow-y", "scroll");
		
		tituloEsquerda.getStyle().set("border-style", "ridge");
		tituloEsquerda.setHeight("20px");
		tituloEsquerda.setWidth("530px");
		
		tituloEsquerda.getStyle().set("text-align", "center");
		tituloEsquerda.getElement().getStyle().set("fontWeight", "bold");
		tituloEsquerda.add(labelEsquerda);
		
		esquerda.add(tituloEsquerda);
		esquerda.getStyle().set("border-style", "ridge");
		esquerda.getStyle().set("text-align", "center");
		esquerda.getStyle().set("vertical-align", "middle");
		esquerda.getStyle().set("display", "table-cell");
		
		tituloCentro.getStyle().set("text-align", "center");
		tituloCentro.getElement().getStyle().set("fontWeight", "bold");
		tituloCentro.add(labelCentro);

		tituloCentro.getStyle().set("border-style", "ridge");
		tituloCentro.setHeight("20px");
		tituloCentro.setWidth("530px");
		
		centro.getStyle().set("border-style", "ridge");
		centro.getStyle().set("text-align", "center");
		centro.getStyle().set("vertical-align", "middle");
		centro.getStyle().set("display", "table-cell");
		
		tituloDireita.getStyle().set("text-align", "center");
		tituloDireita.getElement().getStyle().set("fontWeight", "bold");
		tituloDireita.add(labelDireita);
		
		tituloDireita.getStyle().set("border-style", "ridge");
		tituloDireita.setHeight("20px");
		tituloDireita.setWidth("530px");
		
		direita.getStyle().set("border-style", "ridge");
		direita.getStyle().set("text-align", "center");
		direita.getStyle().set("vertical-align", "middle");
		direita.getStyle().set("display", "table-cell");
		
		div.add(esquerda, centro, direita);
		
		gerarRelatorio.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		gerarRelatorio.getStyle().set("margin-top", "37px");
		
		label.getStyle().set("margin-left", "540px");
		label.getStyle().set("margin-top", "40px");
		label.getElement().getStyle().set("fontWeight", "bold");
		
		somaValores.getStyle().set("margin-top", "33px");
		somaValores.setWidth("340px");
		
		dataInicio.setWidth("181px");
		dataFim.setWidth("181px");
				
		layoutDatas.add(dataInicio, dataFim, gerarRelatorio, label, somaValores);
		layoutTitulosDiv.add(tituloEsquerda, tituloCentro, tituloDireita);
		layoutTitulosDiv.setSpacing(false);
		
		add(layoutDatas, layoutTitulosDiv, div);
	}	
}

Para o relatorio eu não fiz nada ainda com Repository, Service, Entity

Se alguém mais além do @FacaNaCaveira puder ajudar, fico grato

Help!!!

help!!

up

Usa o operador BETWEEN:

https://www.w3schools.com/sql/sql_between.asp

1 curtida

@javaflex

Muito obg por sua resposta, mas preciso aprender a fazer isso em código Java mesmo…

1 curtida

@javaflex obg por sua reposta novamente, vou tentar seguir o que vc me passou

Não se limite só a esse exemplo. Pesquise sobre JPQL e algo mais do que for falado lá.

1 curtida

@javaflex obg por sua ajuda…mas não consegui implementar…vou continuar pesquisando

@RoinujNosde, bom dia…alguma ideia que vc possa me dar?