Module: Aerogel::I18n::NumberHelper
- Included in:
- Aerogel::I18n
- Defined in:
- lib/aerogel/core/i18n/number_helper.rb
Constant Summary collapse
- DECIMAL_UNITS =
{0 => :unit, 1 => :ten, 2 => :hundred, 3 => :thousand, 6 => :million, 9 => :billion, 12 => :trillion, 15 => :quadrillion, -1 => :deci, -2 => :centi, -3 => :mili, -6 => :micro, -9 => :nano, -12 => :pico, -15 => :femto}
- STORAGE_UNITS =
[:byte, :kb, :mb, :gb, :tb]
Instance Method Summary collapse
-
#number_to_human_size(number, options = {}) ⇒ Object
TODO: use NumberHelper from ‘activesupport ~> 4.0’, at the moment it is incompatible with mongoid,.
- #number_with_delimiter(number, options = {}) ⇒ Object
- #number_with_precision(number, options = {}) ⇒ Object
Instance Method Details
#number_to_human_size(number, options = {}) ⇒ Object
TODO: use NumberHelper from ‘activesupport ~> 4.0’, at the moment it is incompatible with mongoid,
83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 |
# File 'lib/aerogel/core/i18n/number_helper.rb', line 83 def number_to_human_size(number, = {}) .symbolize_keys! number = begin Float(number) rescue ArgumentError, TypeError if [:raise] raise # InvalidNumberError, number else return number end end defaults = ::I18n.translate(:'number.format', :locale => [:locale], :default => {}) human = ::I18n.translate(:'number.human.format', :locale => [:locale], :default => {}) defaults = defaults.merge(human) = .reverse_merge(defaults) #for backwards compatibility with those that didn't add strip_insignificant_zeros to their locale files [:strip_insignificant_zeros] = true if not .key?(:strip_insignificant_zeros) storage_units_format = ::I18n.translate(:'number.human.storage_units.format', :locale => [:locale], :raise => true) base = [:prefix] == :si ? 1000 : 1024 if number.to_i < base unit = ::I18n.translate(:'number.human.storage_units.units.byte', :locale => [:locale], :count => number.to_i, :raise => true) storage_units_format.gsub(/%n/, number.to_i.to_s).gsub(/%u/, unit).html_safe else max_exp = STORAGE_UNITS.size - 1 exponent = (Math.log(number) / Math.log(base)).to_i # Convert to base exponent = max_exp if exponent > max_exp # we need this to avoid overflow for the highest unit number /= base ** exponent unit_key = STORAGE_UNITS[exponent] unit = ::I18n.translate(:"number.human.storage_units.units.#{unit_key}", :locale => [:locale], :count => number, :raise => true) formatted_number = number_with_precision(number, ) storage_units_format.gsub(/%n/, formatted_number).gsub(/%u/, unit).html_safe end end |
#number_with_delimiter(number, options = {}) ⇒ Object
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
# File 'lib/aerogel/core/i18n/number_helper.rb', line 4 def number_with_delimiter(number, = {}) .symbolize_keys! [:delimiter] = ERB::Util.html_escape([:delimiter]) if [:delimiter] [:separator] = ERB::Util.html_escape([:separator]) if [:separator] begin Float(number) rescue ArgumentError, TypeError if [:raise] raise # InvalidNumberError, number else return number end end defaults = ::I18n.translate(:'number.format', :locale => [:locale], :default => {}) = .reverse_merge(defaults) parts = number.to_s.to_str.split('.') parts[0].gsub!(/(\d)(?=(\d\d\d)+(?!\d))/, "\\1#{options[:delimiter]}") parts.join([:separator]).html_safe end |
#number_with_precision(number, options = {}) ⇒ Object
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/aerogel/core/i18n/number_helper.rb', line 32 def number_with_precision(number, = {}) .symbolize_keys! number = begin Float(number) rescue ArgumentError, TypeError if [:raise] raise # InvalidNumberError, number else return number end end defaults = ::I18n.translate(:'number.format', :locale => [:locale], :default => {}) precision_defaults = ::I18n.translate(:'number.precision.format', :locale => [:locale], :default => {}) defaults = defaults.merge(precision_defaults) = .reverse_merge(defaults) # Allow the user to unset default values: Eg.: :significant => false precision = .delete :precision significant = .delete :significant strip_insignificant_zeros = .delete :strip_insignificant_zeros if significant and precision > 0 if number == 0 digits, rounded_number = 1, 0 else digits = (Math.log10(number.abs) + 1).floor rounded_number = (BigDecimal.new(number.to_s) / BigDecimal.new((10 ** (digits - precision)).to_f.to_s)).round.to_f * 10 ** (digits - precision) digits = (Math.log10(rounded_number.abs) + 1).floor # After rounding, the number of digits may have changed end precision -= digits precision = precision > 0 ? precision : 0 #don't let it be negative else rounded_number = BigDecimal.new(number.to_s).round(precision).to_f end formatted_number = number_with_delimiter("%01.#{precision}f" % rounded_number, ) if strip_insignificant_zeros escaped_separator = Regexp.escape([:separator]) formatted_number.sub(/(#{escaped_separator})(\d*[1-9])?0+\z/, '\1\2').sub(/#{escaped_separator}\z/, '').html_safe else formatted_number end end |