Subversion Repositories Integrator Subversion

Rev

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
}