# -*- encoding: utf-8 -*-
#
# @author Kivanio Barbosa
module Brcobranca
# Métodos auxiliares de cálculos envolvendo Datas.
module CalculoData
# Calcula o número de dias corridos entre a data base ("Fixada" em 07.10.1997) e a data de vencimento desejada.
# A partir de 22.02.2025, o fator retorna para '1000' adicionando- se '1' a cada dia subsequente a este fator
# até que chegue a 9999 novamente onde deve ser usada nova data base começando de 1000.
#
# Somente serão considerados válidos para pagamento os boletos com 3.000 fatores de vencimento anteriores
# e 5.500 fatores futuros, ambos em relação a data atual.
# Boletos fora deste controle não serão considerados validos para pagamento na rede bancária.
# Ex. Hoje é 13/03/2014 (fator 6.001)
# Limite para emissão ou pagamento de boletos vencido: 24/12/2005 (fator 3.000)
# Limite para emissão ou pagamento de boletos à vencer: 03/04/2029 (fator 2.501)
#
# @return [String] Contendo 4 dígitos
# @example
# Date.parse(2000-07-04).fator_vencimento #=> 1001
def fator_vencimento
data_base = Date.parse '1997-10-07'
fator_vencimento = Integer(self - data_base)
while fator_vencimento > 9999
data_base = data_base + 10000
fator_vencimento = Integer(self - data_base) + 1000
end
fator_vencimento.to_s
end
# Mostra a data em formato dia/mês/ano
# @return [String]
# @example
# Date.current.to_s_br #=> 20/01/2010
def to_s_br
strftime('%d/%m/%Y')
end
# Calcula número de dias julianos.
#
# O cálculo é feito subtraindo-se a data atual, pelo último dia válido do ano anterior,
# acrescentando-se o último algarismo do ano atual na quarta posição.
#
# @return [String] contendo 4 dígitos
#
# @example
# Date.parse(2009-02-11).to_juliano #=> "0429"
def to_juliano
ultima_data = Date.parse("#{year - 1}-12-31")
ultimo_digito_ano = to_s[3..3]
dias = Integer(self - ultima_data)
(dias.to_s + ultimo_digito_ano).rjust(4, '0')
end
end
end
[Date].each do |klass|
klass.class_eval { include Brcobranca::CalculoData }
end