Rev 106 | Rev 291 | Go to most recent revision | 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 | |||
| 195 | espaco | 20 | import br.com.ec.core.generic.AbstractService; |
| 21 | import br.com.ec.core.generic.GenericRepository; |
||
| 22 | import br.com.ec.core.util.DataUtils; |
||
| 23 | import br.com.ec.core.util.StringUtil; |
||
| 24 | import br.com.ec.core.util.VerificadorUtil; |
||
| 25 | import br.com.ec.core.validador.Validador; |
||
| 106 | espaco | 26 | import br.com.ec.domain.dto.RankingVendedorDTO; |
| 27 | import br.com.ec.domain.model.Avaliacao; |
||
| 28 | import br.com.ec.domain.model.AvaliacaoFuncionario; |
||
| 29 | import br.com.ec.domain.model.Loja; |
||
| 30 | import br.com.ec.domain.model.Pendencia; |
||
| 31 | import br.com.ec.domain.model.Perfil; |
||
| 32 | import br.com.ec.domain.model.Vigencia; |
||
| 33 | import br.com.ec.domain.service.avaliacao.AvaliacaoService; |
||
| 34 | import br.com.ec.domain.service.email.impl.GerenciadorEmailImpl; |
||
| 35 | import br.com.ec.domain.service.pendencia.PendenciaService; |
||
| 36 | import br.com.ec.domain.service.usuario.UsuarioService; |
||
| 37 | import br.com.ec.domain.shared.ConstantesSEC; |
||
| 38 | import br.com.ec.infrastructure.repository.AvaliacaoRepository; |
||
| 195 | espaco | 39 | import br.com.ec.web.util.DataUtil; |
| 106 | espaco | 40 | |
| 41 | @Service |
||
| 42 | public class AvaliacaoServiceImpl extends AbstractService<Avaliacao> implements AvaliacaoService { |
||
| 43 | |||
| 44 | private AvaliacaoRepository avaliacaoRepository; |
||
| 45 | |||
| 46 | private PendenciaService pendenciaService; |
||
| 47 | private UsuarioService usuarioService; |
||
| 48 | |||
| 49 | @Autowired |
||
| 50 | public AvaliacaoServiceImpl(Validador validador, AvaliacaoRepository avaliacaoRepository, PendenciaService pendenciaService, |
||
| 51 | UsuarioService usuarioService) { |
||
| 52 | super(validador); |
||
| 53 | this.avaliacaoRepository = avaliacaoRepository; |
||
| 54 | this.pendenciaService = pendenciaService; |
||
| 55 | this.usuarioService = usuarioService; |
||
| 56 | } |
||
| 57 | |||
| 58 | @Override |
||
| 59 | protected GenericRepository<Avaliacao> getRepository() { |
||
| 60 | return avaliacaoRepository; |
||
| 61 | } |
||
| 62 | |||
| 63 | @Override |
||
| 64 | public Avaliacao detalhar(Avaliacao avaliacao) { |
||
| 65 | return avaliacaoRepository.detalhar(avaliacao); |
||
| 66 | } |
||
| 67 | |||
| 68 | @Override |
||
| 69 | public Avaliacao consultarAvaliacaoDaVigencia(Vigencia vigencia) { |
||
| 70 | return avaliacaoRepository.consultarAvaliacaoDaVigencia(vigencia); |
||
| 71 | } |
||
| 72 | |||
| 73 | @Override |
||
| 74 | public List<Avaliacao> consultarAvaliacoesDivulgadas() { |
||
| 75 | return avaliacaoRepository.consultarAvaliacoesDivulgadas(); |
||
| 76 | } |
||
| 77 | |||
| 78 | @Override |
||
| 79 | public void solicitarReavaliacao(RankingVendedorDTO rankingVendedor, String solicitacao) { |
||
| 80 | StringBuilder conteudo = new StringBuilder(); |
||
| 81 | conteudo.append("SOLICITANTE: " + rankingVendedor.getVendedor().getNomeDaPessoa() + "\n"); |
||
| 82 | conteudo.append("DATA DA SOLICITAÇÃO: " + DataUtil.retornarDataFormatadaEmFormatoTexto("dd/MM/yyyy 'às' HH:mm", DataUtils.getDataAtual()) + "\n"); |
||
| 83 | conteudo.append("OBSERVAÇÕES: \n"); |
||
| 84 | conteudo.append(solicitacao); |
||
| 85 | |||
| 86 | Pendencia pendencia = new Pendencia(); |
||
| 87 | pendencia.setDescricao("SOLICITAÇÃO DE REAVALIAÇÃO: " + rankingVendedor.getVendedor().getNomeDaPessoa()); |
||
| 88 | pendencia.setUsuario(usuarioService.consultarUsuarioPorPessoa(rankingVendedor.getVendedor().getPessoa())); |
||
| 89 | pendencia.setData(DataUtils.getDataAtual()); |
||
| 90 | if (VerificadorUtil.estaNulo(rankingVendedor.getVendedor().getLoja())) { |
||
| 91 | pendencia.setLoja(new Loja(ConstantesSEC.SEQUENCIAL_MATRIZ_ESTOQUE_9.longValue())); |
||
| 92 | } else { |
||
| 93 | pendencia.setLoja(rankingVendedor.getVendedor().getLoja()); |
||
| 94 | } |
||
| 95 | Perfil perfilRh = new Perfil(); |
||
| 96 | perfilRh.setCodigo(ConstantesSEC.PERFIL_RECURSOS_HUMANOS_11); |
||
| 97 | pendencia.setPerfil(perfilRh); |
||
| 98 | pendenciaService.cadastrar(pendencia); |
||
| 99 | |||
| 100 | new GerenciadorEmailImpl() |
||
| 101 | .comEmailsDestino(ConstantesSEC.DESTINATARIOS_EMAIL_SUPERVISAO) |
||
| 102 | .comAssunto("SOLICITAÇÃO DE REAVALIAÇÃO") |
||
| 103 | .comConteudo(conteudo.toString()) |
||
| 104 | .enviar(); |
||
| 105 | } |
||
| 106 | |||
| 107 | @Override |
||
| 108 | public byte[] emitirRelatorioImportacaoFolhaPagamento(ServletContext contexto, Avaliacao avaliacao) { |
||
| 109 | ByteArrayOutputStream baos = new ByteArrayOutputStream(); |
||
| 110 | |||
| 111 | try { |
||
| 112 | String caminhoArquivo = "/arquivos/modelos/Relatório de Importação - Folha de Pagamento Espaço Case.xls"; |
||
| 113 | InputStream arquivo = FacesContext.getCurrentInstance().getExternalContext().getResourceAsStream(caminhoArquivo); |
||
| 114 | HSSFWorkbook workbook = new HSSFWorkbook(arquivo); |
||
| 115 | HSSFSheet sheet = workbook.getSheetAt(0); |
||
| 116 | |||
| 117 | Iterator rowIterator = sheet.rowIterator(); |
||
| 118 | while (rowIterator.hasNext()) { |
||
| 119 | Row row = (Row) rowIterator.next(); |
||
| 120 | if (row.getRowNum() < 11) { |
||
| 121 | continue; |
||
| 122 | } else if (row.getRowNum() < 52) { |
||
| 123 | Iterator cellIterator = row.cellIterator(); |
||
| 124 | Integer codigoFolha = null; |
||
| 125 | while (cellIterator.hasNext()) { |
||
| 126 | Boolean atualizar = true; |
||
| 127 | Cell cell = (Cell) cellIterator.next(); |
||
| 128 | switch (cell.getColumnIndex()) { |
||
| 129 | case 1: |
||
| 130 | Integer tipoCelula = cell.getCellType(); |
||
| 131 | if (tipoCelula.equals(Cell.CELL_TYPE_NUMERIC)) { |
||
| 132 | Double codigo = cell.getNumericCellValue(); |
||
| 133 | codigoFolha = codigo.intValue(); |
||
| 134 | } else { |
||
| 135 | atualizar = false; |
||
| 136 | } |
||
| 137 | break; |
||
| 138 | case 3: |
||
| 139 | if (atualizar) { |
||
| 140 | for (AvaliacaoFuncionario avaliacaoFunc : avaliacao.getParticipantes()) { |
||
| 141 | if (avaliacaoFunc.getFuncionario().getCodigoContabilidade().equals(codigoFolha)) { |
||
| 142 | String valor = StringUtil.formatarValorComDoisDigitos(avaliacaoFunc.getValorComissao().toString()); |
||
| 143 | cell.setCellValue(valor.replace(".", ",")); |
||
| 144 | break; |
||
| 145 | } |
||
| 146 | } |
||
| 147 | } |
||
| 148 | break; |
||
| 149 | } |
||
| 150 | } |
||
| 151 | } |
||
| 152 | } |
||
| 153 | |||
| 154 | try { |
||
| 155 | workbook.write(baos); |
||
| 156 | return baos.toByteArray(); |
||
| 157 | } catch (FileNotFoundException e) { |
||
| 158 | e.printStackTrace(); |
||
| 159 | } catch (IOException e) { |
||
| 160 | e.printStackTrace(); |
||
| 161 | } finally { |
||
| 162 | baos.close(); |
||
| 163 | arquivo.close(); |
||
| 164 | workbook.close(); |
||
| 165 | } |
||
| 166 | } catch (FileNotFoundException e) { |
||
| 167 | e.printStackTrace(); |
||
| 168 | } catch (Exception e) { |
||
| 169 | e.printStackTrace(); |
||
| 170 | } |
||
| 171 | |||
| 172 | return null; |
||
| 173 | } |
||
| 174 | |||
| 175 | } |