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

public class ProdutoDAO extends AbstractGenericDAO<Produto> {

	public ProdutoDAO(Conexao conexao) {
		super(conexao);
	}


	@Override
	public void criarTabela() {
		String sql = "CREATE TABLE IF NOT EXISTS Produto (" +
					  "id INT PRIMARY KEY AUTO_INCREMENT, " +
					  "nome VARCHAR(45) NOT NULL UNIQUE, " +
					  "preco FLOAT NOT NULL)";
		
		try {
			Statement cmd = dbConnection.createStatement();
			cmd.executeUpdate(sql);
			cmd.close();
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	
	
	@Override
	public boolean inserir(Produto produto) {
		String sql = "INSERT INTO Produto (nome, preco) VALUES (?, ?)";

		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setString(1, produto.getNome());
			cmd.setFloat(2, produto.getPreco());
			int retorno = cmd.executeUpdate();
			cmd.close();

			if (retorno > 0) {
				// salva o id gerado pelo banco no próprio objeto
				produto.setId(ultimoID("Produto"));
			}

			return retorno > 0;

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

	@Override
	public boolean apagar(Produto produto) {
		String sql = "DELETE FROM Produto WHERE id=?";

		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setInt(1, produto.getId());
			int retorno = cmd.executeUpdate();
			cmd.close();
			return retorno > 0;

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

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

	@Override
	public Produto buscar(Integer id) {
		String sql = "SELECT * from Produto WHERE id=?";
		Produto produto = null;

		try {
			PreparedStatement cmd = dbConnection.prepareStatement(sql);
			cmd.setInt(1, id);
			ResultSet rs = cmd.executeQuery();

			if (rs.next()) {
				String nome = rs.getString("nome");
				Float preco = rs.getFloat("preco");
				produto = new Produto(id, nome, preco);
			}

			cmd.close();

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

		return produto;
	}
	
	@Override
	public Produto buscar(Produto pojo) {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public Produto buscar(String campo) {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public List<Produto> listar() {
		String sql = "SELECT * FROM Produto";
		List<Produto> 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");
				Float preco = rs.getFloat("preco");
				Produto produto = new Produto(id, nome, preco);
				lista.add(produto);
			}

			cmd.close();

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

		return lista;
	}

}
