// Listar
  @RequestMapping(value = "/centrocusto_lista")
  public String lista(@PageableDefault(size = 10) Pageable pageable, Model model) {
    Usuario usuario = rotinas.usuarioLogado();
    List<Empresa> listaEmpresa = empresaDao.selectEmpresasUsuario(usuario.getId_usuario());
    CentroCusto filtros = new CentroCusto();

    if (!listaEmpresa.isEmpty()) {
      filtros.setId_Empresa(listaEmpresa.get(0).getId_Empresa());
    }

    Boolean lista = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "1501");
    if (lista != true) {
      model.addAttribute("mensagem", "AVISO: Transação não permitida.");
      return "mensagemerro";
    }
    Boolean novo = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "150101");
    Boolean editar = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "150102");
    Boolean deletar = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "150103");
    Boolean detalhes = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "150104");

    model.addAttribute("novo", novo);
    model.addAttribute("editar", editar);
    model.addAttribute("deletar", deletar);
    model.addAttribute("detalhes", detalhes);

    model.addAttribute("filtros", filtros);
    model.addAttribute("listaempresa", listaEmpresa);
    model.addAttribute(
        "lista", centroCustoDao.selectAll_paginado(filtros.getId_Empresa(), pageable));
    model.addAttribute(
        "pagina", new Pagina(pageable, centroCustoDao.count(filtros.getId_Empresa())));
    return "centrocusto_lista";
  }
  // Filtros
  @RequestMapping(value = "/centrocusto_lista", method = RequestMethod.POST)
  public ModelAndView filtros(
      @ModelAttribute CentroCusto filtros, @PageableDefault(size = 10) Pageable pageable) {
    ModelAndView mav = new ModelAndView();
    Usuario usuario = rotinas.usuarioLogado();
    List<Empresa> listaEmpresa = empresaDao.selectEmpresasUsuario(usuario.getId_usuario());

    if (!listaEmpresa.isEmpty()) {
      filtros.setId_Empresa(listaEmpresa.get(0).getId_Empresa());
    }
    ;

    Boolean lista = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "1501");
    if (lista != true) {
      mav.addObject("mensagem", "AVISO: Transação não permitida.");
      mav.setViewName("mensagemerro");
      return mav;
    }
    Boolean novo = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "150101");
    Boolean editar = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "150102");
    Boolean deletar = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "150103");
    Boolean detalhes = rotinas.validaTransacaoUsuario(usuario.getId_usuario(), "150104");

    mav.addObject("novo", novo);
    mav.addObject("editar", editar);
    mav.addObject("deletar", deletar);
    mav.addObject("detalhes", detalhes);

    mav.addObject("filtros", filtros);
    mav.addObject("listaempresa", listaEmpresa);
    mav.addObject("lista", centroCustoDao.selectAll_paginado(filtros.getId_Empresa(), pageable));
    mav.addObject("pagina", new Pagina(pageable, centroCustoDao.count(filtros.getId_Empresa())));
    mav.setViewName("centrocusto_lista");
    return mav;
  }