# 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