package com.softgraf.vendas.model.repositorio;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;

import com.softgraf.vendas.model.entity.Cliente;
import com.softgraf.vendas.model.repositorio.abstrato.AbstractRepositorio;

public class RepositorioCliente implements AbstractRepositorio<Cliente> {

	private static final long serialVersionUID = -1987554231465102578L;

	private EntityManager em;

	public RepositorioCliente(EntityManager em) {
		this.em = em;
	}

	@Override
	public boolean adicionar(Cliente cliente) {
		EntityTransaction tx = em.getTransaction();
		try {
			
			tx.begin();
			em.persist(cliente);
			tx.commit();
			
		} catch (Exception e) {
			e.printStackTrace();
			return false;
		}
		
		return true;
	}

	@Override
	public Cliente buscarPorId(Integer id) {
		return em.find(Cliente.class, id);
	}
	
	public Cliente buscarPorId(String id) {
		return buscarPorId(Integer.parseInt(id));
	}

	@Override
	public boolean atualizar(Cliente cliente) {
		EntityTransaction tx = em.getTransaction();
		try {
			
			tx.begin();
			em.merge(cliente);
			tx.commit();
			
		} catch (Exception e) {
			e.printStackTrace();
			return false;
		}
		
		return true;
	}
	
	@Override
	public boolean remover(Cliente cliente) {
		EntityTransaction tx = em.getTransaction();
		
		try {
			
			tx.begin();
			em.remove(cliente);
			tx.commit();
			
		} catch (Exception e) {
			e.printStackTrace();
			return false;
		}
		
		return true;
	}

	@Override
	public List<Cliente> listarTodos() {
		return em.createQuery("from Cliente", Cliente.class).getResultList();
	}
	
	@Override
	public List<Cliente> listarTodos(int maximo) {
		return em.createQuery("from Cliente", Cliente.class).setMaxResults(maximo).getResultList();
	}
	
	public List<Cliente> listarPorNome(String nome) {
		return em.createQuery("Select c from Cliente c where c.nome like :nomeCliente", Cliente.class)
									  .setParameter("nomeCliente", nome)
									  .getResultList();
	}
}
