Subversion Repositories Integrator Subversion

Rev

Rev 670 | Rev 678 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
667 blopes 1
package br.com.ec.domain.dto;
2
 
3
import java.util.ArrayList;
671 blopes 4
import java.util.Date;
667 blopes 5
import java.util.List;
6
 
668 blopes 7
import org.apache.commons.httpclient.util.DateUtil;
667 blopes 8
import org.primefaces.model.file.UploadedFile;
9
 
668 blopes 10
import br.com.ec.core.util.StringUtil;
667 blopes 11
import br.com.ec.core.util.VerificadorUtil;
12
import br.com.ec.web.util.DataUtil;
13
 
14
public class ExtratoAntecipacaoArquivoDTO {
15
 
671 blopes 16
        private Date dataRecebimento;
667 blopes 17
        private ContaBancariaDTO contaBancariaDTO;
18
        private UploadedFile arquivoAntecipacao;
19
        private List<String> linhasArquivo;
669 blopes 20
        private String sqlConsultaParcelas;
671 blopes 21
        private String sqlAtualizacaoParcelas;
667 blopes 22
 
23
        private List<ExtratoAntecipacaoDTO> dadosExtratoAntecipacaoDTO;
24
        private List<ExtratoAntecipacaoDTO> dadosExtratoAntecipacaoDTOSemConciliacao;
25
 
26
        public ExtratoAntecipacaoArquivoDTO() {
27
                this.dadosExtratoAntecipacaoDTO = new ArrayList<ExtratoAntecipacaoDTO>();
28
        }
29
 
30
        public ExtratoAntecipacaoArquivoDTO(UploadedFile arquivoAntecipacao) {
31
                super();
32
                this.arquivoAntecipacao = arquivoAntecipacao;
33
        }
34
 
671 blopes 35
        public Date getDataRecebimento() {
36
                return dataRecebimento;
37
        }
38
        public void setDataRecebimento(Date dataRecebimento) {
39
                this.dataRecebimento = dataRecebimento;
40
        }
41
 
667 blopes 42
        public ContaBancariaDTO getContaBancariaDTO() {
43
                return contaBancariaDTO;
44
        }
45
        public void setContaBancariaDTO(ContaBancariaDTO contaBancariaDTO) {
46
                this.contaBancariaDTO = contaBancariaDTO;
47
        }
48
 
49
        public UploadedFile getArquivoAntecipacao() {
50
                return arquivoAntecipacao;
51
        }
52
        public void setArquivoAntecipacao(UploadedFile arquivoAntecipacao) {
53
                this.arquivoAntecipacao = arquivoAntecipacao;
54
        }
55
 
56
        public List<String> getLinhasArquivo() {
57
                return linhasArquivo;
58
        }
59
        public void setLinhasArquivo(List<String> linhasArquivo) {
60
                this.linhasArquivo = linhasArquivo;
61
        }
62
 
669 blopes 63
        public String getSqlConsultaParcelas() {
64
                return sqlConsultaParcelas;
65
        }
66
        public void setSqlConsultaParcelas(String sqlConsultaParcelas) {
67
                this.sqlConsultaParcelas = sqlConsultaParcelas;
68
        }
69
 
671 blopes 70
        public String getSqlAtualizacaoParcelas() {
71
                return sqlAtualizacaoParcelas;
72
        }
73
        public void setSqlAtualizacaoParcelas(String sqlAtualizacaoParcelas) {
74
                this.sqlAtualizacaoParcelas = sqlAtualizacaoParcelas;
75
        }
76
 
667 blopes 77
        public List<ExtratoAntecipacaoDTO> getDadosExtratoAntecipacaoDTO() {
78
                return dadosExtratoAntecipacaoDTO;
79
        }
80
        public void setDadosExtratoAntecipacaoDTO(List<ExtratoAntecipacaoDTO> dadosExtratoAntecipacaoDTO) {
81
                this.dadosExtratoAntecipacaoDTO = dadosExtratoAntecipacaoDTO;
82
        }
83
 
84
        public List<ExtratoAntecipacaoDTO> getDadosExtratoAntecipacaoDTOSemConciliacao() {
85
                return dadosExtratoAntecipacaoDTOSemConciliacao;
86
        }
87
        public void setDadosExtratoAntecipacaoDTOSemConciliacao(List<ExtratoAntecipacaoDTO> dadosExtratoAntecipacaoDTOSemConciliacao) {
88
                this.dadosExtratoAntecipacaoDTOSemConciliacao = dadosExtratoAntecipacaoDTOSemConciliacao;
89
        }
90
 
91
        /**************************************/
92
 
93
        /*
94
        public Boolean todoExtratoConciliado() {
95
                if (!VerificadorUtil.isListaNulaOuVazia(getDadosExtratoBancoDTO())) {
96
                        for (ExtratoBancoDTO extratoBancoDTO : getDadosExtratoBancoDTO()) {
97
                                if (!extratoBancoDTO.getIndicadorConciliado()) {
98
                                        return false;
99
                                }
100
                        }
101
                }
102
                return true;
103
        }
104
        */
105
 
671 blopes 106
        public void extrairDadosArquivo() {
667 blopes 107
                List<ExtratoAntecipacaoDTO> extratoAntecipacaoDTOs = new ArrayList<ExtratoAntecipacaoDTO>();
108
//                      setDadosExtratoBancoDTO(new ArrayList<ExtratoBancoDTO>());
109
//                      getDadosExtratoBancoDTO().addAll(extrairDadosItau(extratosAnexadosAnteriormente));
110
                Long sequencial = new Long(1);
111
                for (String linha : this.getLinhasArquivo()) {
112
//                      10/10/2024;29/08/2024;29/05/2025;R$ 60,00;R$ 60,00;2,30%;R$ 1,38;R$ 58,62;Livre;100,0000%;21769086;-;-;0548980;93849763;ESPACO CASE;81704828;546479******1520;não;-;Crédito;Mastercard;10;9;ITAÚ UNIBANCO S.A.;7951;998611;-;-;antecipada
113
//                      10/10/2024;05/08/2024;05/06/2025;R$ 41,50;R$ 41,50;2,30%;R$ 0,95;R$ 40,55;Livre;100,0000%;32994398;-;-;0086277;62449554;ESPACO CASE;81704828;485464******4098;não;-;Crédito;Visa;10;10;ITAÚ UNIBANCO S.A.;7951;998611;-;-;antecipada
114
//                      System.out.println(linha);
115
                        String[] dadosSeparados = linha.split(";");
116
                        if (dadosSeparados.length >= 29) {
117
                                if (VerificadorUtil.naoEstaNuloOuVazio(dadosSeparados[2])) {
118
                                        if (dadosSeparados[29].contains("antecipada")) {
119
                                                ExtratoAntecipacaoDTO extratoAntecipacaoDTO = new ExtratoAntecipacaoDTO();
120
                                                extratoAntecipacaoDTO.setSequencial(sequencial);
121
                                                sequencial++;
671 blopes 122
                                                extratoAntecipacaoDTO.setDataRecebimento(DataUtil.retornarDataApartirString("dd/MM/yyyy", dadosSeparados[0]));
667 blopes 123
                                                extratoAntecipacaoDTO.setDataVencimento(DataUtil.retornarDataApartirString("dd/MM/yyyy", dadosSeparados[2]));
124
                                                Double valor = 0.0;
125
                                                if (VerificadorUtil.naoEstaNuloOuVazio(dadosSeparados[7])) {
126
                                                        String valorLinha = dadosSeparados[7].replace("R$", "").trim();
127
                                                        valor = new Double(valorLinha.replace(".", "").replace(",", ".")        );
128
                                                }
670 blopes 129
                                                String bandeira = StringUtil.setarUpperCaseComTrim(dadosSeparados[21]);
130
                                                if (bandeira.equals("AMEX")) {
131
                                                        bandeira = "AMERICAN EXPRESS";
132
                                                }
133
                                                extratoAntecipacaoDTO.setBandeira(bandeira);
667 blopes 134
                                                extratoAntecipacaoDTO.setValorLiquido(valor);
668 blopes 135
                                                extratoAntecipacaoDTO.setQuantidadeParcelas(new Integer(dadosSeparados[22]));
136
                                                extratoAntecipacaoDTO.setNumeroDaParcela(new Integer(dadosSeparados[23]));
667 blopes 137
                                                extratoAntecipacaoDTOs.add(extratoAntecipacaoDTO);
138
//                                              [20] Débito ou Crédito
139
//                                              [21] Elo, Hipercard, Mastercard, Visa...
140
//                                              [22] Qnt de parcelas
141
//                                              [23] Número da parcela
142
//                                              [29] antecipada 758
143
                                        }
144
                                }
145
                        }
146
                }
147
 
669 blopes 148
                /*
668 blopes 149
                StringBuilder sqlConsulta = new StringBuilder();
150
                sqlConsulta.append("SELECT * FROM sc_sec.sec_parcela ");
151
                sqlConsulta.append("WHERE dat_pagamento IS NULL AND (");
667 blopes 152
                for (ExtratoAntecipacaoDTO extratoAntecipacaoDTO : extratoAntecipacaoDTOs) {
668 blopes 153
//                      System.out.println(extratoAntecipacaoDTO.getSequencial() + " : " + extratoAntecipacaoDTO.getDataVencimento() + " : " + extratoAntecipacaoDTO.getValorLiquido() + " : " + extratoAntecipacaoDTO.getBandeira() + " : " + extratoAntecipacaoDTO.getNumeroDaParcela() + "/" + extratoAntecipacaoDTO.getQuantidadeParcelas());
154
                        Double valorInicial = extratoAntecipacaoDTO.getValorLiquido() - 0.10;
155
                        Double valorFinal = extratoAntecipacaoDTO.getValorLiquido() + 0.10;
156
                        sqlConsulta.append("(dat_vencimento = '" + DateUtil.formatDate(extratoAntecipacaoDTO.getDataVencimento(), "yyyy-MM-dd") + "' AND ");
157
                        sqlConsulta.append("val_valor >= " + valorInicial + " AND val_valor <= " + valorFinal + " AND ");
158
                        sqlConsulta.append("dsc_observacao LIKE 'CRÉDITO " + extratoAntecipacaoDTO.getNumeroDaParcela() + "/" + extratoAntecipacaoDTO.getQuantidadeParcelas() + "%" + extratoAntecipacaoDTO.getBandeira() + "%') ");
159
                        sqlConsulta.append("OR ");
667 blopes 160
                }
668 blopes 161
                sqlConsulta.append(")");
669 blopes 162
//              System.out.println(sqlConsulta.toString().replace("OR )", ")"));
163
                setSqlConsultaParcelas(sqlConsulta.toString().replace("OR )", ")"));
164
                */
668 blopes 165
 
166
                /*
167
                StringBuilder sqlConsulta = new StringBuilder();
168
                sqlConsulta.append("SELECT * FROM Parcela p");
169
                sqlConsulta.append("WHERE p.dataPagamento IS NULL AND (");
170
                for (ExtratoAntecipacaoDTO extratoAntecipacaoDTO : extratoAntecipacaoDTOs) {
171
//                      System.out.println(extratoAntecipacaoDTO.getSequencial() + " : " + extratoAntecipacaoDTO.getDataVencimento() + " : " + extratoAntecipacaoDTO.getValorLiquido() + " : " + extratoAntecipacaoDTO.getBandeira() + " : " + extratoAntecipacaoDTO.getNumeroDaParcela() + "/" + extratoAntecipacaoDTO.getQuantidadeParcelas());
172
                        Double valorInicial = extratoAntecipacaoDTO.getValorLiquido() - 0.10;
173
                        Double valorFinal = extratoAntecipacaoDTO.getValorLiquido() + 0.10;
174
                        sqlConsulta.append("(p.dataVencimento = '" + DateUtil.formatDate(extratoAntecipacaoDTO.getDataVencimento(), "yyyy-MM-dd") + "' AND ");
175
                        sqlConsulta.append("p.valor >= " + valorInicial + " AND p.valor <= " + valorFinal + " AND ");
176
                        sqlConsulta.append("p.observacao LIKE 'CRÉDITO " + extratoAntecipacaoDTO.getNumeroDaParcela() + "/" + extratoAntecipacaoDTO.getQuantidadeParcelas() + "%" + extratoAntecipacaoDTO.getBandeira() + "%') ");
177
                        sqlConsulta.append("OR ");
178
                }
179
                sqlConsulta.append(")");
180
                System.out.println(sqlConsulta.toString().replace("OR )", ")"));
181
                */
182
 
669 blopes 183
                StringBuilder sqlConsulta = new StringBuilder();
184
                sqlConsulta.append("SELECT new br.com.ec.domain.dto.ParcelaDTO(");
185
                sqlConsulta.append(ParcelaDTO.CONSULTA_SEM_CATEGORIA_DTO);
186
                sqlConsulta.append(") FROM Parcela e ");
187
                sqlConsulta.append("WHERE e.indicadorAtivo IS TRUE AND e.dataPagamento IS NULL AND (");
188
                for (ExtratoAntecipacaoDTO extratoAntecipacaoDTO : extratoAntecipacaoDTOs) {
189
                        Double valorInicial = extratoAntecipacaoDTO.getValorLiquido() - 0.10;
190
                        Double valorFinal = extratoAntecipacaoDTO.getValorLiquido() + 0.10;
191
                        sqlConsulta.append("(e.dataVencimento = '" + DateUtil.formatDate(extratoAntecipacaoDTO.getDataVencimento(), "yyyy-MM-dd") + "' AND ");
192
                        sqlConsulta.append("e.valor >= " + valorInicial + " AND e.valor <= " + valorFinal + " AND ");
193
                        sqlConsulta.append("e.observacao LIKE 'CRÉDITO " + extratoAntecipacaoDTO.getNumeroDaParcela() + "/" + extratoAntecipacaoDTO.getQuantidadeParcelas() + "%" + extratoAntecipacaoDTO.getBandeira() + "%') ");
194
                        sqlConsulta.append("OR ");
195
                }
196
                sqlConsulta.append(")");
197
//              System.out.println(sqlConsulta.toString().replace("OR )", ")"));
668 blopes 198
 
669 blopes 199
                setDadosExtratoAntecipacaoDTOSemConciliacao(extratoAntecipacaoDTOs);
200
                setSqlConsultaParcelas(sqlConsulta.toString().replace("OR )", ")"));
667 blopes 201
        }
202
 
203
        public void extrairDados(List<ExtratoAntecipacaoArquivoDTO> extratosAnexadosAnteriormente) {
204
//              if (getTipoExtratoBancarioCsv().equals(TipoExtratoBancarioCsv.EXTRATO_BANCARIO_CSV_ITAU.getValor())) {
205
//                      setDadosExtratoBancoDTO(new ArrayList<ExtratoBancoDTO>());
206
//                      getDadosExtratoBancoDTO().addAll(extrairDadosItau(extratosAnexadosAnteriormente));
207
//              }
208
        }
209
 
210
        public static void main(String[] args) {
211
                String valor = "SISPAG PAG TIT BANCO 00";
212
                System.out.println(!valor.contains("SISPAG PAG"));
213
        }
214
 
215
        /*
216
        private Boolean dadoExtratoBancarioEhNovo(List<AntecipacaoArquivoDTO> extratosAnexadosAnteriormente, ExtratoBancoDTO extratoBancoNovoDTO) {
217
                List<ExtratoBancoDTO> extratosAnexados = new ArrayList<ExtratoBancoDTO>();
218
                for (AntecipacaoArquivoDTO extratoBancarioArquivoDTO : extratosAnexadosAnteriormente) {
219
                        if (extratoBancarioArquivoDTO.getContaBancariaDTO().getSequencial().equals(extratoBancoNovoDTO.getContaBancariaDTO().getSequencial())) {
220
                                extratosAnexados.addAll(extratoBancarioArquivoDTO.getDadosExtratoBancoDTO());
221
                                break;
222
                        }
223
                }
224
                for (ExtratoBancoDTO extratoBancoDTO : extratosAnexados) {
225
                        if (DataUtils.datasIguais(extratoBancoDTO.getDataLancamento(), extratoBancoNovoDTO.getDataLancamento()) &&
226
                                extratoBancoDTO.getDescricao().equals(extratoBancoNovoDTO.getDescricao()) &&
227
                                extratoBancoDTO.getValorTotal().equals(extratoBancoNovoDTO.getValorTotal())) {
228
                                return false;
229
                        }
230
                }
231
                return true;
232
        }
233
 
234
        public void marcarTodosDadosExtrato() {
235
                if (VerificadorUtil.naoEstaNuloOuVazio(getDadosExtratoBancoDTO())) {
236
                        for (ExtratoBancoDTO extratoBancoDTO : getDadosExtratoBancoDTO()) {
237
                                extratoBancoDTO.setIndicadorCadastrar(true);
238
                        }
239
                }
240
        }
241
 
242
        public void desmarcarTodosDadosExtrato() {
243
                if (VerificadorUtil.naoEstaNuloOuVazio(getDadosExtratoBancoDTO())) {
244
                        for (ExtratoBancoDTO extratoBancoDTO : getDadosExtratoBancoDTO()) {
245
                                extratoBancoDTO.setIndicadorCadastrar(false);
246
                        }
247
                }
248
        }
249
        */
250
}