# frozen_string_literal: true module Brcobranca module Boleto # Banco Itaú class Itau < Base # Usado somente em carteiras especiais com registro para complementar o número do cocumento attr_reader :seu_numero validates_length_of :agencia, maximum: 4, message: 'deve ser menor ou igual a 4 dígitos.' validates_length_of :convenio, maximum: 5, message: 'deve ser menor ou igual a 5 dígitos.' validates_length_of :nosso_numero, maximum: 8, message: 'deve ser menor ou igual a 8 dígitos.' validates_length_of :conta_corrente, maximum: 5, message: 'deve ser menor ou igual a 5 dígitos.' with_options if: :usa_seu_numero? do |v| v.validates_length_of :seu_numero, maximum: 7, message: 'deve ser menor ou igual a 7 dígitos.' end # Nova instancia do Itau # @param (see Brcobranca::Boleto::Base#initialize) def initialize(campos = {}) campos = { carteira: '175' }.merge!(campos) super(campos) end # Codigo do banco emissor (3 dígitos sempre) # # @return [String] 3 caracteres numéricos. def banco '341' end # Número do convênio/contrato do cliente junto ao banco. # @return [String] 5 caracteres numéricos. def convenio=(valor) @convenio = valor.to_s.rjust(5, '0') if valor end # Conta corrente # @return [String] 5 caracteres numéricos. def conta_corrente=(valor) @conta_corrente = valor.to_s.rjust(5, '0') if valor end # Número seqüencial utilizado para identificar o boleto. # @return [String] 8 caracteres numéricos. def nosso_numero=(valor) @nosso_numero = valor.to_s.rjust(8, '0') if valor end # Número seqüencial utilizado para identificar o boleto. # @return [String] 7 caracteres numéricos. def seu_numero=(valor) @seu_numero = valor.to_s.rjust(7, '0') if valor end def usa_seu_numero? %w[198 106 107 122 142 143 195 196].include?(carteira.to_s) end # Dígito verificador do nosso número. # # Para a grande maioria das carteiras, são considerados para a obtenção do DAC/DV, os dados # "AGENCIA(sem DAC/DV)/CONTA(sem DAC/DV)/CARTEIRA/NOSSO NUMERO", calculado pelo criterio do Modulo 10.
# A excecao, estão as carteiras 112, 126, 131, 146, 150 e 168 cuja obtenção esta baseada apenas nos # dados "CARTEIRA/NOSSO NUMERO". # # @return [String] 1 caracteres numéricos. def nosso_numero_dv if %w[112 126 131 146 150 168].include?(carteira) "#{carteira}#{nosso_numero}".modulo10 else "#{agencia}#{conta_corrente}#{carteira}#{nosso_numero}".modulo10 end end # Calcula o dígito verificador para conta corrente do Itau. # Retorna apenas o dígito verificador da conta ou nil caso seja impossível calcular. def agencia_conta_corrente_dv "#{agencia}#{conta_corrente}".modulo10 end # Nosso número para exibir no boleto. # @return [String] # @example # boleto.nosso_numero_boleto #=> "175/12345678-4" def nosso_numero_boleto "#{carteira}/#{nosso_numero}-#{nosso_numero_dv}" end # Agência + conta corrente do cliente para exibir no boleto. # @return [String] # @example # boleto.agencia_conta_boleto #=> "0811 / 53678-8" def agencia_conta_boleto "#{agencia} / #{conta_corrente}-#{agencia_conta_corrente_dv}" end # Segunda parte do código de barras. # # CARTEIRAS 198, 106, 107,122, 142, 143, 195 e 196
# 01 a 03 | 03 | 9(3) | Código do Banco na Câmara de Compensação = ‘341’
# 04 a 04 | 01 | 9(1) | Código da Moeda = '9'
# 05 a 05 | 01 | 9(1) | DAC do Código de Barras MOD 11-2a9
# 06 a 09 | 04 | 9(04) | Fator de Vencimento
# 10 a 19 | 10 | 9(08) | V(2) Valor
# 20 a 22 | 03 | 9(3) | Carteira
# 23 a 30 | 08 | 9(8) | Nosso Número
# 31 a 37 | 07 | 9(7) | Seu Número (Número do Documento)
# 38 a 42 | 05 | 9(5) | Código do Cliente (fornecido pelo Banco)
# 43 a 43 | 01 | 9(1) | DAC dos campos acima (posições 20 a 42) MOD 10
# 44 a 44 | 01 | 9(1) | Zero
# # DEMAIS CARTEIRAS
# 01 a 03 | 03 | 9(03) | Código do Banco na Câmara de Compensação = '341'
# 04 a 04 | 01 | 9(01) | Código da Moeda = '9'
# 05 a 05 | 01 | 9(01) | DAC código de Barras MOD 11-2a9
# 06 a 09 | 04 | 9(04) | Fator de Vencimento
# 10 a 19 | 10 | 9(08)V(2) | Valor
# 20 a 22 | 03 | 9(03) | Carteira
# 23 a 30 | 08 | 9(08) | Nosso Número
# 31 a 31 | 01 | 9(01) | DAC [Agência /Conta/Carteira/Nosso Número] MOD 10
# 32 a 35 | 04 | 9(04) | N.º da Agência cedente
# 36 a 40 | 05 | 9(05) | N.º da Conta Corrente
# 41 a 41 | 01 | 9(01) | DAC [Agência/Conta Corrente] MOD 10
# 42 a 44 | 03 | 9(03) | Zeros
# # @return [String] 25 caracteres numéricos. def codigo_barras_segunda_parte case carteira.to_i when 198, 106, 107, 122, 142, 143, 195, 196 dv = "#{carteira}#{nosso_numero}#{seu_numero}#{convenio}".modulo10 "#{carteira}#{nosso_numero}#{seu_numero}#{convenio}#{dv}0" else "#{carteira}#{nosso_numero}#{nosso_numero_dv}#{agencia}#{conta_corrente}#{agencia_conta_corrente_dv}000" end end end end end