Rev 328 | Details | Compare with Previous | Last modification | View Log | RSS feed
| Rev | Author | Line No. | Line |
|---|---|---|---|
| 106 | espaco | 1 | package br.com.ec.domain.service.avaliacao.impl; |
| 2 | |||
| 3 | import java.io.ByteArrayOutputStream; |
||
| 4 | import java.io.FileNotFoundException; |
||
| 5 | import java.io.IOException; |
||
| 6 | import java.io.InputStream; |
||
| 7 | import java.util.Iterator; |
||
| 8 | import java.util.List; |
||
| 9 | |||
| 10 | import javax.faces.context.FacesContext; |
||
| 11 | import javax.servlet.ServletContext; |
||
| 12 | |||
| 13 | import org.apache.poi.hssf.usermodel.HSSFSheet; |
||
| 14 | import org.apache.poi.hssf.usermodel.HSSFWorkbook; |
||
| 15 | import org.apache.poi.ss.usermodel.Cell; |
||
| 16 | import org.apache.poi.ss.usermodel.Row; |
||
| 17 | import org.springframework.beans.factory.annotation.Autowired; |
||
| 18 | import org.springframework.stereotype.Service; |
||
| 19 | |||
| 291 | espaco | 20 | import br.com.ec.core.exception.NegocioException; |
| 195 | espaco | 21 | import br.com.ec.core.generic.AbstractService; |
| 22 | import br.com.ec.core.generic.GenericRepository; |
||
| 23 | import br.com.ec.core.util.DataUtils; |
||
| 24 | import br.com.ec.core.util.StringUtil; |
||
| 25 | import br.com.ec.core.util.VerificadorUtil; |
||
| 26 | import br.com.ec.core.validador.Validador; |
||
| 106 | espaco | 27 | import br.com.ec.domain.dto.RankingVendedorDTO; |
| 28 | import br.com.ec.domain.model.Avaliacao; |
||
| 29 | import br.com.ec.domain.model.AvaliacaoFuncionario; |
||
| 356 | espaco | 30 | import br.com.ec.domain.model.AvaliacaoProduto; |
| 106 | espaco | 31 | import br.com.ec.domain.model.Loja; |
| 32 | import br.com.ec.domain.model.Pendencia; |
||
| 33 | import br.com.ec.domain.model.Perfil; |
||
| 34 | import br.com.ec.domain.model.Vigencia; |
||
| 328 | espaco | 35 | import br.com.ec.domain.model.tipos.TipoComissionamento; |
| 106 | espaco | 36 | import br.com.ec.domain.service.avaliacao.AvaliacaoService; |
| 37 | import br.com.ec.domain.service.email.impl.GerenciadorEmailImpl; |
||
| 38 | import br.com.ec.domain.service.pendencia.PendenciaService; |
||
| 39 | import br.com.ec.domain.service.usuario.UsuarioService; |
||
| 40 | import br.com.ec.domain.shared.ConstantesSEC; |
||
| 41 | import br.com.ec.infrastructure.repository.AvaliacaoRepository; |
||
| 195 | espaco | 42 | import br.com.ec.web.util.DataUtil; |
| 106 | espaco | 43 | |
| 44 | @Service |
||
| 45 | public class AvaliacaoServiceImpl extends AbstractService<Avaliacao> implements AvaliacaoService { |
||
| 46 | |||
| 47 | private AvaliacaoRepository avaliacaoRepository; |
||
| 48 | |||
| 49 | private PendenciaService pendenciaService; |
||
| 50 | private UsuarioService usuarioService; |
||
| 51 | |||
| 52 | @Autowired |
||
| 53 | public AvaliacaoServiceImpl(Validador validador, AvaliacaoRepository avaliacaoRepository, PendenciaService pendenciaService, |
||
| 54 | UsuarioService usuarioService) { |
||
| 55 | super(validador); |
||
| 56 | this.avaliacaoRepository = avaliacaoRepository; |
||
| 57 | this.pendenciaService = pendenciaService; |
||
| 58 | this.usuarioService = usuarioService; |
||
| 59 | } |
||
| 60 | |||
| 61 | @Override |
||
| 62 | protected GenericRepository<Avaliacao> getRepository() { |
||
| 63 | return avaliacaoRepository; |
||
| 64 | } |
||
| 65 | |||
| 66 | @Override |
||
| 67 | public Avaliacao detalhar(Avaliacao avaliacao) { |
||
| 68 | return avaliacaoRepository.detalhar(avaliacao); |
||
| 69 | } |
||
| 70 | |||
| 71 | @Override |
||
| 72 | public Avaliacao consultarAvaliacaoDaVigencia(Vigencia vigencia) { |
||
| 73 | return avaliacaoRepository.consultarAvaliacaoDaVigencia(vigencia); |
||
| 74 | } |
||
| 75 | |||
| 76 | @Override |
||
| 77 | public List<Avaliacao> consultarAvaliacoesDivulgadas() { |
||
| 78 | return avaliacaoRepository.consultarAvaliacoesDivulgadas(); |
||
| 79 | } |
||
| 80 | |||
| 81 | @Override |
||
| 82 | public void solicitarReavaliacao(RankingVendedorDTO rankingVendedor, String solicitacao) { |
||
| 83 | StringBuilder conteudo = new StringBuilder(); |
||
| 84 | conteudo.append("SOLICITANTE: " + rankingVendedor.getVendedor().getNomeDaPessoa() + "\n"); |
||
| 85 | conteudo.append("DATA DA SOLICITAÇÃO: " + DataUtil.retornarDataFormatadaEmFormatoTexto("dd/MM/yyyy 'às' HH:mm", DataUtils.getDataAtual()) + "\n"); |
||
| 86 | conteudo.append("OBSERVAÇÕES: \n"); |
||
| 87 | conteudo.append(solicitacao); |
||
| 88 | |||
| 89 | Pendencia pendencia = new Pendencia(); |
||
| 90 | pendencia.setDescricao("SOLICITAÇÃO DE REAVALIAÇÃO: " + rankingVendedor.getVendedor().getNomeDaPessoa()); |
||
| 91 | pendencia.setUsuario(usuarioService.consultarUsuarioPorPessoa(rankingVendedor.getVendedor().getPessoa())); |
||
| 92 | pendencia.setData(DataUtils.getDataAtual()); |
||
| 93 | if (VerificadorUtil.estaNulo(rankingVendedor.getVendedor().getLoja())) { |
||
| 94 | pendencia.setLoja(new Loja(ConstantesSEC.SEQUENCIAL_MATRIZ_ESTOQUE_9.longValue())); |
||
| 95 | } else { |
||
| 96 | pendencia.setLoja(rankingVendedor.getVendedor().getLoja()); |
||
| 97 | } |
||
| 98 | Perfil perfilRh = new Perfil(); |
||
| 99 | perfilRh.setCodigo(ConstantesSEC.PERFIL_RECURSOS_HUMANOS_11); |
||
| 100 | pendencia.setPerfil(perfilRh); |
||
| 101 | pendenciaService.cadastrar(pendencia); |
||
| 102 | |||
| 103 | new GerenciadorEmailImpl() |
||
| 104 | .comEmailsDestino(ConstantesSEC.DESTINATARIOS_EMAIL_SUPERVISAO) |
||
| 105 | .comAssunto("SOLICITAÇÃO DE REAVALIAÇÃO") |
||
| 106 | .comConteudo(conteudo.toString()) |
||
| 107 | .enviar(); |
||
| 108 | } |
||
| 109 | |||
| 110 | @Override |
||
| 328 | espaco | 111 | public byte[] emitirRelatorioImportacaoFolhaPagamento(ServletContext contexto, Avaliacao avaliacao, Long empresa) { |
| 106 | espaco | 112 | ByteArrayOutputStream baos = new ByteArrayOutputStream(); |
| 113 | |||
| 114 | try { |
||
| 115 | String caminhoArquivo = "/arquivos/modelos/Relatório de Importação - Folha de Pagamento Espaço Case.xls"; |
||
| 116 | InputStream arquivo = FacesContext.getCurrentInstance().getExternalContext().getResourceAsStream(caminhoArquivo); |
||
| 117 | HSSFWorkbook workbook = new HSSFWorkbook(arquivo); |
||
| 118 | HSSFSheet sheet = workbook.getSheetAt(0); |
||
| 119 | |||
| 120 | Iterator rowIterator = sheet.rowIterator(); |
||
| 121 | while (rowIterator.hasNext()) { |
||
| 122 | Row row = (Row) rowIterator.next(); |
||
| 123 | if (row.getRowNum() < 11) { |
||
| 124 | continue; |
||
| 291 | espaco | 125 | } else { |
| 106 | espaco | 126 | Iterator cellIterator = row.cellIterator(); |
| 127 | Integer codigoFolha = null; |
||
| 128 | while (cellIterator.hasNext()) { |
||
| 129 | Boolean atualizar = true; |
||
| 130 | Cell cell = (Cell) cellIterator.next(); |
||
| 131 | switch (cell.getColumnIndex()) { |
||
| 132 | case 1: |
||
| 133 | Integer tipoCelula = cell.getCellType(); |
||
| 134 | if (tipoCelula.equals(Cell.CELL_TYPE_NUMERIC)) { |
||
| 135 | Double codigo = cell.getNumericCellValue(); |
||
| 136 | codigoFolha = codigo.intValue(); |
||
| 137 | } else { |
||
| 138 | atualizar = false; |
||
| 139 | } |
||
| 140 | break; |
||
| 141 | case 3: |
||
| 142 | if (atualizar) { |
||
| 143 | for (AvaliacaoFuncionario avaliacaoFunc : avaliacao.getParticipantes()) { |
||
| 291 | espaco | 144 | if (VerificadorUtil.estaNulo(avaliacaoFunc.getFuncionario().getCodigoContabilidade())) { |
| 145 | throw new NegocioException("Participante " + avaliacaoFunc.getFuncionario().getNomeDaPessoa() + " sem código contábil cadastrado"); |
||
| 146 | } |
||
| 328 | espaco | 147 | if (avaliacaoFunc.getFuncionario().getTipoComissionamento().equals(TipoComissionamento.parse(empresa).getValor()) && |
| 148 | avaliacaoFunc.getFuncionario().getCodigoContabilidade().equals(codigoFolha)) { |
||
| 291 | espaco | 149 | Double valorComissao = avaliacaoFunc.getValorComissao(); |
| 150 | if (VerificadorUtil.estaNulo(valorComissao)) { |
||
| 151 | throw new NegocioException("Obrigatório informar todas as comissões"); |
||
| 152 | } |
||
| 153 | String valor = StringUtil.formatarValorComDoisDigitos(valorComissao.toString()); |
||
| 106 | espaco | 154 | cell.setCellValue(valor.replace(".", ",")); |
| 155 | break; |
||
| 156 | } |
||
| 157 | } |
||
| 158 | } |
||
| 159 | break; |
||
| 160 | } |
||
| 161 | } |
||
| 162 | } |
||
| 163 | } |
||
| 164 | |||
| 165 | try { |
||
| 166 | workbook.write(baos); |
||
| 167 | return baos.toByteArray(); |
||
| 168 | } catch (FileNotFoundException e) { |
||
| 169 | e.printStackTrace(); |
||
| 170 | } catch (IOException e) { |
||
| 171 | e.printStackTrace(); |
||
| 172 | } finally { |
||
| 173 | baos.close(); |
||
| 174 | arquivo.close(); |
||
| 175 | workbook.close(); |
||
| 176 | } |
||
| 177 | } catch (FileNotFoundException e) { |
||
| 178 | e.printStackTrace(); |
||
| 291 | espaco | 179 | } catch (NegocioException ne) { |
| 180 | throw new NegocioException(ne.getMessage()); |
||
| 106 | espaco | 181 | } catch (Exception e) { |
| 182 | e.printStackTrace(); |
||
| 183 | } |
||
| 184 | |||
| 185 | return null; |
||
| 186 | } |
||
| 187 | |||
| 356 | espaco | 188 | @Override |
| 189 | public List<AvaliacaoProduto> consultarProdutosPromocaoInterna(Long sequencialAvaliacao) { |
||
| 190 | return avaliacaoRepository.consultarProdutosPromocaoInterna(sequencialAvaliacao); |
||
| 191 | } |
||
| 192 | |||
| 106 | espaco | 193 | } |