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.Endereco;

public class EnderecoDAO extends AbstractGenericDAO<Endereco>{

	// construtor
	public EnderecoDAO(Conexao conexao) {
		super(conexao);
	}
	

	@Override
	public void criarTabela() {
		String sql = "CREATE TABLE IF NOT EXISTS Endereco (" +
					  "id INT PRIMARY KEY AUTO_INCREMENT, " +
					  "rua VARCHAR(45) NOT NULL, " +
					  "cidade VARCHAR(20) NOT NULL, " +
					  "estado VARCHAR(20) NOT NULL)";
		
		try {
			Statement cmd = dbConnection.createStatement();
			cmd.executeUpdate(sql);
			cmd.close();
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	
	
	@Override
	public boolean inserir(Endereco endereco) {
		String sql = "INSERT INTO Endereco (rua, cidade, estado) VALUES (?, ?, ?)";
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setString(1, endereco.getRua());
			cmd.setString(2, endereco.getCidade());
			cmd.setString(3, endereco.getEstado());
			int retorno = cmd.executeUpdate();
			cmd.close();
			
			if (retorno > 0){
				// salva o id gerado pelo banco no próprio objeto
				endereco.setId(ultimoID("Endereco"));	
			}
			
			return retorno > 0;

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

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

	public boolean atualizar(Endereco endereco){
		String sql = "UPDATE Endereco SET rua=?, cidade=?, estado=? WHERE id=?";
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setString(1, endereco.getRua());
			cmd.setString(2, endereco.getCidade());
			cmd.setString(3, endereco.getEstado());
			cmd.setInt(4, endereco.getId());
			int retorno = cmd.executeUpdate();
			cmd.close();
			return retorno > 0;
			
		} catch (SQLException e) {
			e.printStackTrace();
			return false;
		}				
	}
	
	@Override
	public Endereco buscar(Integer id) {
		String sql = "SELECT * FROM Endereco WHERE id=?";
		Endereco endereco = null;
		
		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setInt(1, id);
			ResultSet rs = cmd.executeQuery();
			
			if (rs.next()){
				String rua = rs.getString("rua");
				String cidade = rs.getString("cidade");
				String estado = rs.getString("estado");
				endereco = new Endereco(id, rua, cidade, estado);
			}
			
			cmd.close();
			
		} catch (SQLException e) {
			e.printStackTrace();
			return null;
		}
		
		return endereco;
	}
	
	@Override
	public Endereco buscar(Endereco pojo) {
		// TODO Auto-generated method stub
		return null;
	}
	
	@Override
	public Endereco buscar(String rua) {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public List<Endereco> listar() {
		String sql = "SELECT * FROM Endereco ORDER BY id";
		List<Endereco> lista = new ArrayList<>();

		try {
			Statement cmd = dbConnection.createStatement();
			ResultSet rs = cmd.executeQuery(sql);
			
			while (rs.next()){
				Integer id = rs.getInt("id");
				String rua = rs.getString("rua");
				String cidade = rs.getString("cidade");
				String estado = rs.getString("estado");
				Endereco endereco = new Endereco(id, rua, cidade, estado);
				lista.add(endereco);
			}
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
		
		return lista;
	}

}
