# -*- 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