aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2005-04-02 15:14:57 +0000
committerDavid Heinemeier Hansson <david@loudthinking.com>2005-04-02 15:14:57 +0000
commitaa09c770e9b5400683be11952673017295246de7 (patch)
tree50f11d959542b207fa429169f3866ba8b6bc38bf
parent91834e0c3f00786ce8e03008f485d18d6ff1d906 (diff)
downloadrails-aa09c770e9b5400683be11952673017295246de7.tar.gz
rails-aa09c770e9b5400683be11952673017295246de7.tar.bz2
rails-aa09c770e9b5400683be11952673017295246de7.zip
Added NumberHelper for common string representations like phone number, currency, and percentage #1015 [DeLynn]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1071 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r--actionpack/CHANGELOG2
-rw-r--r--actionpack/lib/action_view/helpers/number_helper.rb82
2 files changed, 84 insertions, 0 deletions
diff --git a/actionpack/CHANGELOG b/actionpack/CHANGELOG
index 4fd2ceddba..36eed04161 100644
--- a/actionpack/CHANGELOG
+++ b/actionpack/CHANGELOG
@@ -1,5 +1,7 @@
*SVN*
+* Added NumberHelper for common string representations like phone number, currency, and percentage #1015 [DeLynn]
+
* Added pagination for scaffolding (10 items per page) #964 [mortonda@dgrmm.net]
* Added assert_no_cookie and fixed assert_cookie_equal to deal with non-existing cookies #979 [bitsweat]
diff --git a/actionpack/lib/action_view/helpers/number_helper.rb b/actionpack/lib/action_view/helpers/number_helper.rb
new file mode 100644
index 0000000000..e93be4e1a2
--- /dev/null
+++ b/actionpack/lib/action_view/helpers/number_helper.rb
@@ -0,0 +1,82 @@
+module ActionView
+ module Helpers
+ # Provides methods for converting a number into a formatted string that currently represents
+ # one of the following forms: phone number, percentage, money, or precision level.
+ module NumberHelper
+
+ # Formats a +number+ into a US phone number string. The +options+ can be hash used to customize the format of the output.
+ # The area code can be surrounded by parenthesis by setting +:area_code+ to true; default is false
+ # The delimeter can be set using +:delimter+; default is "-"
+ # Examples:
+ # number_to_phone(1235551234) => 123-555-1234
+ # number_to_phone(1235551234, {:area_code => true}) => (123) 555-1234
+ # number_to_phone(1235551234, {:delimter => " "}) => 123 555 1234
+ def number_to_phone(number, options = {})
+ options = options.stringify_keys
+ area_code = options.delete("area_code") { false }
+ delimeter = options.delete("delimeter") { "-" }
+ begin
+ str = number.to_s
+ if area_code == true
+ str.gsub!(/([0-9]{3})([0-9]{3})([0-9]{4})/,"(\\1) \\2#{delimeter}\\3")
+ else
+ str.gsub!(/([0-9]{3})([0-9]{3})([0-9]{4})/,"\\1#{delimeter}\\2#{delimeter}\\3")
+ end
+ rescue
+ number
+ end
+ end
+
+ # Formates a +number+ into a currency string. The +options+ hash can be used to customize the format of the output.
+ # The +number+ can contain a level of precision using the +precision+ key; default is 2
+ # The currency type can be set using the +unit+ key; default is "$"
+ # The unit separator can be set using the +separator+ key; default is "."
+ # The delimter can be set using the +delimeter+ key; default is ","
+ # Examples:
+ # number_to_currency(1234567890.50) => $1,234,567,890.50
+ # number_to_currency(1234567890.506) => $1,234,567,890.51
+ # number_to_currency(1234567890.50, {:unit => "&pound;", :separator => ",", :delim => ""}) => &pound;123456789,50
+ def number_to_currency(number, options = {})
+ options = options.stringify_keys
+ precision, unit, separator, delim = options.delete("precision") { 2 }, options.delete("unit") { "$" }, options.delete("separator") { "." }, options.delete("delim") { "," }
+ begin
+ parts = number_with_precision(number, precision).split('.')
+ parts[0].gsub!(/(\d)(?=(\d\d\d)+(?!\d))/, "\\1#{delim}")
+ unit + parts[0] + separator + parts[1].to_s
+ rescue
+ number
+ end
+ end
+
+ # Formats a +number+ as into a percentage string. The +options+ hash can be used to customize the format of the output.
+ # The +number+ can contain a level of precision using the +precision+ key; default is 3
+ # The unit separator can be set using the +separator+ key; default is "."
+ # Examples:
+ # number_to_precision(100) => 100.000%
+ # number_to_precision(100, {:precision => 0}) => 100%
+ # number_to_precision(302.0574, {:precision => 2}) => 302.06%
+ def number_to_percentage(number, options = {})
+ options = options.stringify_keys
+ precision, separator = options.delete("precision") { 3 }, options.delete("separator") { "." }
+ begin
+ number = number_with_precision(number, precision)
+ parts = number.split('.')
+ if parts.at(1).nil?
+ parts[0] + "%"
+ else
+ parts[0] + separator + parts[1].to_s + "%"
+ end
+ rescue
+ number
+ end
+ end
+
+ # Formats a +number+ with a level of +precision+.
+ # Example:
+ # number_with_precision(111.2345) => 111.235
+ def number_with_precision(number, precision=3)
+ sprintf("%01.#{precision}f", number)
+ end
+ end
+ end
+end \ No newline at end of file