Botão Editar - Vaadin

03/02/2021

0

Bom dia a todos.

Estou começando agora a trabalhar com Vaadin/Java, então me perdoem se estiver falando algo que para muito de vcs é bem simples.

Tenho um sistema de cadastro de produtos, feito todo com Vaadin.

Este sistema é bem simples, ele tem 5 atributos:

* ID (que é fornecido pelo sistema) - neste momento ainda não estou trabalhando com Banco de Dados

* Nome do Produto
* Marca / Fabricante do Produto
* Modelo do Produto
* Valor do Produto

Este últimos 4 atributos são fornecidos pelo usuário

Após o usuário salvar o produto, este produto é lançado em uma lista e gerado um uma grade.

Até aqui tudo está funcionando perfeitamente.

Agora o que quero fazer é criar um botão para atualizar, quando necessário este produto, alterar nome, ou valor, alterar marca...qualquer alteração

O comportamento deste botão deve ser da seguinte forma:

* O botão editar deve ficar desabilitado enquanto o usuário não seleciona o produto na grade.
* O botão editar só será habilitado após o clique sobre o produto que será alterado.
* A edição pode ser feita diretamente na grade ou abrindo uma janela com todas as informações atuais do produto, ou mesmo com duplo clique

Classe Produto

public class Produto {

	private Long id;
	private String nome;
	private String marca;
	private String modelo;
	private Double valor;

	public Produto() {

	}

	public Produto(Long id, String nome, String marca, String modelo, Double valor) {

		this.id = id;
		this.nome = nome;
		this.marca = marca;
		this.modelo = modelo;
		this.valor = valor;
	}

	public Long getId() {
		return id;
	}

	public void setId(Long id) {
		this.id = id;
	}

	public String getNome() {
		return nome;
	}

	public void setNome(String nome) {
		this.nome = nome;
	}

	public String getMarca() {
		return marca;
	}

	public void setMarca(String marca) {
		this.marca = marca;
	}

	public String getModelo() {
		return modelo;
	}

	public void setModelo(String modelo) {
		this.modelo = modelo;
	}

	public Double getValor() {
		return valor;
	}

	public void setValor(Double valor) {
		this.valor = valor;
	}

}



Classe GridProduto

public class GridProduto extends Div {

	private static final long serialVersionUID = 1L;

	private List<Produto> lista;
	private Grid<Produto> grid;

	public GridProduto() {

		lista = new ArrayList<>();
		grid = new Grid<>();

		grid.setItems(lista);
		
		grid.setHeight("835px");

		grid.addColumn(Produto::getId).setHeader("ID:").setAutoWidth(true);
		grid.addColumn(Produto::getNome).setHeader("Produto:").setAutoWidth(true);
		grid.addColumn(Produto::getMarca).setHeader("Marca:").setAutoWidth(true);
		grid.addColumn(Produto::getModelo).setHeader("Modelo:").setAutoWidth(true);
		grid.addColumn(new NumberRenderer<>(Produto::getValor, "R$ %(,.2f",
		        Locale.getDefault(), "R$ 0.00")).setHeader("Valor Unitário:");
		
		grid.addThemeVariants(GridVariant.LUMO_COMPACT, GridVariant.LUMO_COLUMN_BORDERS);

		add(grid);

	}

	public Grid<Produto> getGrid() {
		return grid;
	}

	public List<Produto> getLista() {
		return lista;
	}

}


Classe CadastroProduto

package br.com.fjsistemas.views;

import com.vaadin.flow.component.Text;
import com.vaadin.flow.component.button.Button;
import com.vaadin.flow.component.button.ButtonVariant;
import com.vaadin.flow.component.dialog.Dialog;
import com.vaadin.flow.component.html.Div;
import com.vaadin.flow.component.icon.Icon;
import com.vaadin.flow.component.icon.VaadinIcon;
import com.vaadin.flow.component.orderedlayout.HorizontalLayout;
import com.vaadin.flow.component.textfield.TextField;
import com.vaadin.flow.data.binder.Binder;
import com.vaadin.flow.data.binder.ValidationException;
import com.vaadin.flow.data.converter.StringToDoubleConverter;
import com.vaadin.flow.router.PageTitle;
import com.vaadin.flow.router.Route;
import com.vaadin.flow.router.RouteAlias;

import br.com.fjsistemas.backend.Produto;
import br.com.fjsistemas.grid.GridProduto;
import br.com.fjsistemas.main.MainView;

@Route(value = "cadastroprodutos", layout = MainView.class)
@PageTitle("Cadastro de Produtos")
@RouteAlias(value = "Cadastro Produtos", layout = MainView.class)

public class CadastroProduto extends Div {

	private static final long serialVersionUID = 1L;

	@SuppressWarnings("deprecation")
	private Long identity = new Long(0);

	public CadastroProduto() throws ValidationException {

		HorizontalLayout layoutInterno1 = new HorizontalLayout();

		GridProduto grid = new GridProduto();

		add(grid);

		HorizontalLayout layoutInterno2 = new HorizontalLayout();

		Dialog janela = new Dialog();

		janela.setCloseOnEsc(false);
		janela.setCloseOnOutsideClick(false);
		janela.setWidth("700px");
		janela.setHeight("360px");

		Button adicionar = new Button(new Icon(VaadinIcon.PLUS_CIRCLE_O));
		adicionar.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		adicionar.addClickListener(event -> janela.open());

		Button remover = new Button(new Icon(VaadinIcon.MINUS_CIRCLE_O));
		remover.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		remover.addClickListener(event -> {
			grid.getLista().remove(grid.getLista().size() - 1);
			grid.getGrid().getDataProvider().refreshAll();
		});

		Button atualizar = new Button(new Icon(VaadinIcon.REFRESH));
		atualizar.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		atualizar.setEnabled(false);		

		Binder<Produto> binder = new Binder<>(Produto.class);

		HorizontalLayout layoutJanelaInterno1 = new HorizontalLayout();

		Text titulo = new Text("Novo Produto");

		HorizontalLayout layoutJanelaInterno2 = new HorizontalLayout();

		TextField produto = new TextField("Produto:");
		produto.setMinWidth("50%");

		TextField marca = new TextField("Marca:");
		marca.setWidth("50%");

		HorizontalLayout layoutJanelaInterno3 = new HorizontalLayout();

		TextField modelo = new TextField("Modelo:");
		modelo.setWidth("50%");

		TextField valorUnitario = new TextField("Valor Unitário R$:");
		valorUnitario.setWidth("50%");

		layoutJanelaInterno1.add(titulo);
		layoutJanelaInterno1.setMargin(isVisible());
		layoutJanelaInterno2.add(produto, marca);
		layoutJanelaInterno2.setMargin(isVisible());
		layoutJanelaInterno3.add(modelo, valorUnitario);
		layoutJanelaInterno3.setMargin(isVisible());

		binder.forField(produto).withConverter(String::toUpperCase, String::valueOf).bind(Produto::getNome,
				Produto::setNome);
		binder.forField(marca).withConverter(String::toUpperCase, String::valueOf).bind(Produto::getMarca,
				Produto::setMarca);
		binder.forField(modelo).withConverter(String::toUpperCase, String::valueOf).bind(Produto::getModelo,
				Produto::setModelo);
		binder.forField(valorUnitario).withConverter(new StringToDoubleConverter(0.0, "Valor Inválido"))
				.withNullRepresentation(0.0).bind(Produto::getValor, Produto::setValor);

		HorizontalLayout layoutBotoes = new HorizontalLayout();

		Button salvar = new Button("Salvar");
		salvar.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		salvar.getStyle().set("margin-top", "25px");
		salvar.addClickListener(event -> {
			Produto produtoNovo = new Produto();
			produtoNovo.setId(++identity);

			grid.getLista().add(produtoNovo);
			grid.getGrid().getDataProvider().refreshAll();
			binder.writeBeanIfValid(produtoNovo);
			binder.readBean(new Produto(null, " ", " ", " ", null));
			binder.getFields().forEach(f -> f.clear());

		});

		Button fechar = new Button("Fechar");
		fechar.addThemeVariants(ButtonVariant.LUMO_PRIMARY);
		fechar.getStyle().set("margin-top", "25px");
		fechar.addClickListener(event -> {
			janela.close();
		});

		janela.add(layoutJanelaInterno1);
		janela.add(layoutJanelaInterno2);
		janela.add(layoutJanelaInterno3);
		janela.add(layoutBotoes);

		layoutBotoes.add(salvar, fechar);

		layoutInterno2.add(adicionar, remover, atualizar);

		add(layoutInterno1, layoutInterno2);

	}

}

Rafael

Rafael

Responder

Posts

03/02/2021

Rafael

https://vaadin.com/forum/thread/18524098/button
Responder

Utilizamos cookies para fornecer uma melhor experiência para nossos usuários, consulte nossa política de privacidade.

Aceitar