# frozen_string_literal: true # # @author Kivanio Barbosa module Brcobranca # Métodos auxiliares de formatação module Formatacao # Formata como CPF # # @return [String] # @example # "12345678901".to_br_cpf #=> 123.456.789-01 def to_br_cpf somente_numeros.gsub(/^(.{3})(.{3})(.{3})(.{2})$/, '\1.\2.\3-\4') end # Formata como CEP # # @return [String] # @example # "85253100".to_br_cep #=> "85253-100" # 85253100.to_br_cep #=> "85253-100" def to_br_cep somente_numeros.gsub(/^(.{5})(.{3})$/, '\1-\2') end # Formata como CNPJ # # @return [String] # @example # "12345678000901".to_br_cnpj #=> 12.345.678/0009-01 def to_br_cnpj somente_numeros.gsub(/^(.{2})(.{3})(.{3})(.{4})(.{2})$/, '\1.\2.\3/\4-\5') end # Gera formatação automática do documento baseado no tamanho do campo. # # @return [String] Retorna a mesma caso não encontre o formato adequado. # @example # "12345678000901".formata_documento #=> 12.345.678/0009-01 # "85253100".formata_documento #=> "85253-100" # "12345678901".formata_documento #=> 123.456.789-01 # "12345".formata_documento #=> 12345 def formata_documento case somente_numeros.size when 8 then to_br_cep when 11 then to_br_cpf when 14 then to_br_cnpj else self end end # Remove caracteres que não sejam numéricos. # # @return [String] # @example # 1a23e45+".somente_numeros #=> 12345 def somente_numeros to_s.gsub(/\D/, '') end # Monta a linha digitável padrão para todos os bancos segundo a BACEN. # # A linha digitável será composta por cinco campos:
# 1º campo:
# Composto pelo código de Banco, código da moeda, as cinco primeiras posições do campo livre # e o dígito verificador deste campo.
# 2º campo:
# Composto pelas posições 6ª a 15ª do campo livre e o dígito verificador deste campo.
# 3º campo:
# Composto pelas posições 16ª a 25ª do campo livre e o dígito verificador deste campo.
# 4º campo:
# Composto pelo dígito verificador do código de barras, ou seja, a 5ª posição do código de barras.
# 5º campo:
# Composto pelo fator de vencimento com 4(quatro) caracteres e o valor do documento com # 10(dez) caracteres, sem separadores e sem edição.
# # @return [String] # @raise [ArgumentError] Caso não seja um número de 44 dígitos. # @example # "00192376900000135000000001238798777770016818".linha_digitavel #=> "00190.00009 01238.798779 77700.168188 2 37690000013500" def linha_digitavel unless self =~ /^(\d{4})(\d{1})(\d{14})(\d{5})(\d{10})(\d{10})$/ raise ArgumentError, "#{self} Precisa conter 44 caracteres numéricos." end linha = Regexp.last_match[1] linha << Regexp.last_match[4] linha << linha.modulo10.to_s linha << Regexp.last_match[5] linha << Regexp.last_match[5].modulo10.to_s linha << Regexp.last_match[6] linha << Regexp.last_match[6].modulo10.to_s linha << Regexp.last_match[2] linha << Regexp.last_match[3] linha.gsub(/^(.{5})(.{5})(.{5})(.{6})(.{5})(.{6})(.{1})(.{14})$/, '\1.\2 \3.\4 \5.\6 \7 \8') end end end [String, Numeric].each do |klass| klass.class_eval { include Brcobranca::Formatacao } end