# frozen_string_literal: true
module Brcobranca
module Remessa
class Pagamento
include Brcobranca::Validations
# REQUERIDO: nosso numero
attr_accessor :nosso_numero
# REQUERIDO: data do vencimento do boleto
attr_accessor :data_vencimento
# REQUERIDO: data de emissao do boleto
attr_accessor :data_emissao
# REQUERIDO: valor do boleto
attr_accessor :valor
# REQUERIDO: documento do sacado (cliente)
attr_accessor :documento_sacado
# REQUERIDO: nome do sacado (cliente)
attr_accessor :nome_sacado
# REQUERIDO: endereco do sacado (cliente)
attr_accessor :endereco_sacado
# REQUERIDO: bairro do sacado (cliente)
attr_accessor :bairro_sacado
# REQUERIDO: CEP do sacado (cliente)
attr_accessor :cep_sacado
# REQUERIDO: cidade do sacado (cliente)
attr_accessor :cidade_sacado
# REQUERIDO: UF do sacado (cliente)
attr_accessor :uf_sacado
# REQUERIDO: Código da ocorrência
attr_accessor :identificacao_ocorrencia
# OPCIONAL: nome do avalista
attr_accessor :nome_avalista
# OPCIONAL: documento do avalista
attr_accessor :documento_avalista
# OPCIONAL: codigo da 1a instrucao
attr_accessor :cod_primeira_instrucao
# OPCIONAL: codigo da 2a instrucao
attr_accessor :cod_segunda_instrucao
# OPCIONAL: valor da mora ao dia
attr_accessor :valor_mora
# OPCIONAL: data limite para o desconto
attr_accessor :data_desconto
# OPCIONAL: valor a ser concedido de desconto
attr_accessor :valor_desconto
# OPCIONAL: codigo do desconto (para CNAB240)
attr_accessor :cod_desconto
# OPCIONAL: valor do IOF
attr_accessor :valor_iof
# OPCIONAL: valor do abatimento
attr_accessor :valor_abatimento
# OPCIONAL: Número do Documento de Cobrança - Número adotado e controlado pelo Cliente,
# para identificar o título de cobrança.
# Informação utilizada para referenciar a identificação do documento objeto de cobrança.
# Poderá conter número de duplicata, no caso de cobrança de duplicatas; número da apólice,
# no caso de cobrança de seguros, etc
attr_accessor :numero
# OPCIONAL: Número utilizado para controle do beneficiário/cedente
attr_accessor :documento
# OPCIONAL: data limite para o desconto
attr_accessor :data_segundo_desconto
# OPCIONAL: valor a ser concedido de desconto
attr_accessor :valor_segundo_desconto
# OPCIONAL: data limite para o terceiro desconto
attr_accessor :data_terceiro_desconto
# OPCIONAL: valor a ser concedido de desconto
attr_accessor :valor_terceiro_desconto
# OPCIONAL: espécie do título
attr_accessor :especie_titulo
# OPCIONAL: código da multa
attr_accessor :codigo_multa
# OPCIONAL: Percentual multa por atraso %
attr_accessor :percentual_multa
# OPCIONAL: Data para cobrança de multa
attr_accessor :data_multa
# OPCIONAL: tipo de mora (diário, mensal)
attr_accessor :tipo_mora
# OPCIONAL: Data para cobrança de mora
attr_accessor :data_mora
# OPCIONAL: codigo dos juros
attr_accessor :codigo_juros
# OPCIONAL: codigo do protesto
attr_accessor :codigo_protesto
# OPCIONAL: dias para protesto
attr_accessor :dias_protesto
# OPCIONAL: codigo baixa
attr_accessor :codigo_baixa
# OPCIONAL: dias para baixa
attr_accessor :dias_baixa
# OPCIONAL: Número da Parcela
attr_accessor :parcela
validates_presence_of :nosso_numero, :data_vencimento, :valor,
:documento_sacado, :nome_sacado, :endereco_sacado,
:cep_sacado, :cidade_sacado, :uf_sacado, message: 'não pode estar em branco.'
validates_length_of :uf_sacado, is: 2, message: 'deve ter 2 dígitos.'
validates_length_of :cep_sacado, is: 8, message: 'deve ter 8 dígitos.'
validates_length_of :cod_desconto, is: 1, message: 'deve ter 1 dígito.'
validates_length_of :especie_titulo, is: 2, message: 'deve ter 2 dígitos.', allow_blank: true
validates_length_of :identificacao_ocorrencia, is: 2, message: 'deve ter 2 dígitos.'
# Nova instancia da classe Pagamento
#
# @param campos [Hash]
#
def initialize(campos = {})
padrao = {
data_emissao: Date.current,
data_segundo_desconto: '00-00-00',
data_terceiro_desconto: '00-00-00',
tipo_mora: '3',
valor_mora: 0.0,
valor_desconto: 0.0,
valor_segundo_desconto: 0.0,
valor_terceiro_desconto: 0.0,
valor_iof: 0.0,
valor_abatimento: 0.0,
nome_avalista: '',
cod_desconto: '0',
especie_titulo: '01',
identificacao_ocorrencia: '01',
codigo_multa: '0',
percentual_multa: 0.0,
parcela: '01',
codigo_protesto: '3',
dias_protesto: '00',
codigo_baixa: '0',
dias_baixa: '000',
cod_primeira_instrucao: '00',
cod_segunda_instrucao: '00'
}
campos = padrao.merge!(campos)
campos.each do |campo, valor|
send :"#{campo}=", valor
end
yield self if block_given?
end
# Formata a data de desconto de acordo com o formato passado
#
# @return [String]
#
def formata_data_desconto(formato = '%d%m%y')
data_desconto.strftime(formato)
rescue StandardError
if formato == '%d%m%y'
'000000'
else
'00000000'
end
end
# Formata a data de segundo desconto de acordo com o formato passado
#
# @return [String]
#
def formata_data_segundo_desconto(formato = '%d%m%y')
data_segundo_desconto.strftime(formato)
rescue StandardError
if formato == '%d%m%y'
'000000'
else
'00000000'
end
end
# Formata a data de terceiro desconto de acordo com o formato passado
#
# @return [String]
#
def formata_data_terceiro_desconto(formato = '%d%m%y')
data_terceiro_desconto.strftime(formato)
rescue StandardError
if formato == '%d%m%y'
'000000'
else
'00000000'
end
end
# Formata a valor do percentual da multa
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
# @return [String]
#
def formata_percentual_multa(tamanho = 4)
format_value(:percentual_multa, tamanho)
end
# Formata a data de cobrança da multa
#
# @return [String]
#
def formata_data_multa(formato = '%d%m%y')
data_multa.strftime(formato)
rescue StandardError
if formato == '%d%m%y'
'000000'
else
'00000000'
end
end
# Formata o campo valor
# referentes as casas decimais
# exe. R$199,90 => 0000000019990
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
def formata_valor(tamanho = 13)
format_value(:valor, tamanho)
end
def documento_ou_numero
documento || numero
end
def formata_documento_ou_numero(tamanho = 25, caracter = ' ')
doc = documento_ou_numero.to_s.gsub(/[^0-9A-Za-z ]/, '')
doc.rjust(tamanho, caracter)[0...tamanho]
end
# Formata o campo valor da mora
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
def formata_valor_mora(tamanho = 13)
format_value(:valor_mora, tamanho)
end
# Formata o campo valor da multa
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
def formata_valor_multa(tamanho = 6)
format_value(:percentual_multa, tamanho)
end
# Formata o campo valor do desconto
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
def formata_valor_desconto(tamanho = 13)
format_value(:valor_desconto, tamanho)
end
# Formata o campo valor do segundo desconto
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
def formata_valor_segundo_desconto(tamanho = 13)
format_value(:valor_segundo_desconto, tamanho)
end
# Formata o campo valor do terceiro desconto
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
def formata_valor_terceiro_desconto(tamanho = 13)
format_value(:valor_terceiro_desconto, tamanho)
end
# Formata o campo valor do IOF
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
def formata_valor_iof(tamanho = 13)
format_value(:valor_iof, tamanho)
end
# Formata o campo valor do IOF
#
# @param tamanho [Integer]
# quantidade de caracteres a ser retornado
#
def formata_valor_abatimento(tamanho = 13)
format_value(:valor_abatimento, tamanho)
end
# Retorna a identificacao do pagador
# Se for pessoa fisica (CPF com 11 digitos) é 1
# Se for juridica (CNPJ com 14 digitos) é 2
#
def identificacao_sacado(zero = true)
Brcobranca::Util::Empresa.new(documento_sacado, zero).tipo
end
# Retorna a identificacao do avalista
# Se for pessoa fisica (CPF com 11 digitos) é 1
# Se for juridica (CNPJ com 14 digitos) é 2
#
def identificacao_avalista(zero = true)
return '0' if documento_avalista.nil?
Brcobranca::Util::Empresa.new(documento_avalista, zero).tipo
end
private
def format_value(attribute, tamanho)
value = send(attribute)
raise ValorInvalido, "Pagamento##{attribute}: Deve ser um Float" unless value.to_s.include?('.')
format('%.2f', value).delete('.').rjust(tamanho, '0')
end
end
end
end