package com.softgraf.vendas.model.dao;

import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import com.softgraf.vendas.model.dao.abstrato.AbstractGenericDAO;
import com.softgraf.vendas.model.pojo.Cliente;
import com.softgraf.vendas.model.pojo.Endereco;


public class ClienteDAO extends AbstractGenericDAO<Cliente> {

	final private EnderecoDAO enderecoDAO;

	// construtor
	public ClienteDAO(Conexao conexao, EnderecoDAO enderecoDAO) {
		super(conexao);
		this.enderecoDAO = enderecoDAO;
	}

	@Override
	public void criarTabela() {
		String sql = "CREATE TABLE IF NOT EXISTS Cliente (" +
					  "id INT PRIMARY KEY AUTO_INCREMENT, " +
					  "nome VARCHAR(45) NOT NULL, " +
					  "Endereco_id INT NOT NULL," +
					  "FOREIGN KEY(Endereco_id) REFERENCES Endereco(id))";
		
		try {
			Statement cmd = dbConnection.createStatement();
			cmd.executeUpdate(sql);
			cmd.close();
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	
	@Override
	public boolean inserir(Cliente cliente) {
		String sql = "INSERT INTO Cliente (nome, Endereco_id) VALUES (?, ?)";
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setString(1, cliente.getNome());
			cmd.setInt(2, cliente.getEndereco().getId());
			int retorno = cmd.executeUpdate();
			cmd.close();			
			
			if (retorno > 0){
				// salva o id gerado pelo banco no próprio objeto
				cliente.setId(ultimoID("Cliente"));	
			}
			
			return retorno > 0;

		} catch (SQLException e) {
			e.printStackTrace();
			return false;
		}
	}

	@Override
	public boolean apagar(Cliente cliente) {
		String sql = "DELETE FROM Cliente WHERE id=?";
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setInt(1, cliente.getId());
			int retorno = cmd.executeUpdate();
			cmd.close();
			return retorno > 0;
			
		} catch (SQLException e) {
			e.printStackTrace();
			return false;
		}
	}

	@Override
	public boolean atualizar(Cliente cliente) {
		String sql = "UPDATE Cliente SET nome=?, Endereco_id=? WHERE id=?";
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setString(1, cliente.getNome());
			cmd.setInt(2, cliente.getEndereco().getId());
			cmd.setInt(3, cliente.getId());
			int retorno = cmd.executeUpdate();
			cmd.close();
			return retorno > 0;
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
				
		return false;
	}

	@Override
	public Cliente buscar(Integer id) {
		String sql = "SELECT * from Cliente WHERE id=?";
		Cliente cliente = null;
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setInt(1, id);
			ResultSet rs = cmd.executeQuery();
			
			if (rs.next()){
				String nome = rs.getString("nome");
				Integer endereco_id = rs.getInt("Endereco_id");
				Endereco endereco = enderecoDAO.buscar(endereco_id);
				cliente = new Cliente(id, nome, endereco);
			}
			
			cmd.close();
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
		
		return cliente;
	}
	

	@Override
	public Cliente buscar(String nome) {
		nome = "%" + nome + "%";
		String sql = "SELECT * from Cliente WHERE nome LIKE ? LIMIT 1";
		Cliente cliente = null;
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setString(1, nome);
			ResultSet rs = cmd.executeQuery();
			
			if (rs.next()){
				Integer id = rs.getInt("id");
				String tbNome = rs.getString("nome");
				Integer endereco_id = rs.getInt("Endereco_id");
				Endereco endereco = enderecoDAO.buscar(endereco_id);
				cliente = new Cliente(id, tbNome, endereco);
			}
			cmd.close();
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
		
		return cliente;
	}
	
	@Override
	public Cliente buscar(Cliente pojo) {
		// TODO Auto-generated method stub
		return null;
	}
	
	@Override
	public List<Cliente> listar() {
		String sql = "SELECT * FROM Cliente";
		List<Cliente> lista = new ArrayList<>();
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			ResultSet rs = cmd.executeQuery();
			
			while (rs.next()){
				Integer id = rs.getInt("id");
				String nome = rs.getString("nome");
				Integer endereco_id = rs.getInt("Endereco_id");
				Endereco endereco = enderecoDAO.buscar(endereco_id);
				Cliente cliente = new Cliente(id, nome, endereco);
				lista.add(cliente);
			}
			
			cmd.close();
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
		
		return lista;
	}
	
	public EnderecoDAO getEnderecoDAO(){
		return enderecoDAO;
	}
}
