summaryrefslogtreecommitdiffstats
path: root/lib/redmine/field_format.rb
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2015-12-05 10:01:30 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2015-12-05 10:01:30 +0000
commit3f44fad9bac023bee0ae023e4a0cce0aa578f0e3 (patch)
tree18f4a824cfa65024d564b4abd5faf12e1f8f8921 /lib/redmine/field_format.rb
parent55c34785c0372ee430bea835410c54e11d72bbb7 (diff)
downloadredmine-3f44fad9bac023bee0ae023e4a0cce0aa578f0e3.tar.gz
redmine-3f44fad9bac023bee0ae023e4a0cce0aa578f0e3.zip
Moved custom fields totals logic to FieldFormat (#21413).
git-svn-id: http://svn.redmine.org/redmine/trunk@14944 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'lib/redmine/field_format.rb')
-rw-r--r--lib/redmine/field_format.rb21
1 files changed, 21 insertions, 0 deletions
diff --git a/lib/redmine/field_format.rb b/lib/redmine/field_format.rb
index 841d6a08d..10e5b48a0 100644
--- a/lib/redmine/field_format.rb
+++ b/lib/redmine/field_format.rb
@@ -61,6 +61,10 @@ module Redmine
class_attribute :searchable_supported
self.searchable_supported = false
+ # Set this to true if field values can be summed up
+ class_attribute :totalable_supported
+ self.totalable_supported = false
+
# Restricts the classes that the custom field can be added to
# Set to nil for no restrictions
class_attribute :customized_class_names
@@ -370,6 +374,7 @@ module Redmine
class Numeric < Unbounded
self.form_partial = 'custom_fields/formats/numeric'
+ self.totalable_supported = true
def order_statement(custom_field)
# Make the database cast values into numeric
@@ -377,6 +382,18 @@ module Redmine
# CustomValue validations should ensure that it doesn't occur
"CAST(CASE #{join_alias custom_field}.value WHEN '' THEN '0' ELSE #{join_alias custom_field}.value END AS decimal(30,3))"
end
+
+ # Returns totals for the given scope
+ def total_for_scope(custom_field, scope)
+ scope.joins(:custom_values).
+ where(:custom_values => {:custom_field_id => custom_field.id}).
+ where.not(:custom_values => {:value => ''}).
+ sum("CAST(#{CustomValue.table_name}.value AS decimal(30,3))")
+ end
+
+ def cast_total_value(custom_field, value)
+ cast_single_value(custom_field, value)
+ end
end
class IntFormat < Numeric
@@ -412,6 +429,10 @@ module Redmine
value.to_f
end
+ def cast_total_value(custom_field, value)
+ value.to_f.round(2)
+ end
+
def validate_single_value(custom_field, value, customized=nil)
errs = super
errs << ::I18n.t('activerecord.errors.messages.invalid') unless (Kernel.Float(value) rescue nil)