Subversion Repositories Integrator Subversion

Rev

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