Use base class name as customized type to fix @UserCustomField#order_statement@.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@9880 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
7ed2c481d8
commit
0cc817fba3
|
@ -139,8 +139,9 @@ class CustomField < ActiveRecord::Base
|
||||||
case field_format
|
case field_format
|
||||||
when 'string', 'text', 'list', 'date', 'bool'
|
when 'string', 'text', 'list', 'date', 'bool'
|
||||||
# COALESCE is here to make sure that blank and NULL values are sorted equally
|
# COALESCE is here to make sure that blank and NULL values are sorted equally
|
||||||
|
self.custom_values.first.to_sql
|
||||||
"COALESCE((SELECT cv_sort.value FROM #{CustomValue.table_name} cv_sort" +
|
"COALESCE((SELECT cv_sort.value FROM #{CustomValue.table_name} cv_sort" +
|
||||||
" WHERE cv_sort.customized_type='#{self.class.customized_class.name}'" +
|
" WHERE cv_sort.customized_type='#{self.class.customized_class.base_class.name}'" +
|
||||||
" AND cv_sort.customized_id=#{self.class.customized_class.table_name}.id" +
|
" AND cv_sort.customized_id=#{self.class.customized_class.table_name}.id" +
|
||||||
" AND cv_sort.custom_field_id=#{id} LIMIT 1), '')"
|
" AND cv_sort.custom_field_id=#{id} LIMIT 1), '')"
|
||||||
when 'int', 'float'
|
when 'int', 'float'
|
||||||
|
@ -148,7 +149,7 @@ class CustomField < ActiveRecord::Base
|
||||||
# Postgresql will raise an error if a value can not be casted!
|
# Postgresql will raise an error if a value can not be casted!
|
||||||
# CustomValue validations should ensure that it doesn't occur
|
# CustomValue validations should ensure that it doesn't occur
|
||||||
"(SELECT CAST(cv_sort.value AS decimal(60,3)) FROM #{CustomValue.table_name} cv_sort" +
|
"(SELECT CAST(cv_sort.value AS decimal(60,3)) FROM #{CustomValue.table_name} cv_sort" +
|
||||||
" WHERE cv_sort.customized_type='#{self.class.customized_class.name}'" +
|
" WHERE cv_sort.customized_type='#{self.class.customized_class.base_class.name}'" +
|
||||||
" AND cv_sort.customized_id=#{self.class.customized_class.table_name}.id" +
|
" AND cv_sort.customized_id=#{self.class.customized_class.table_name}.id" +
|
||||||
" AND cv_sort.custom_field_id=#{id} AND cv_sort.value <> '' AND cv_sort.value IS NOT NULL LIMIT 1)"
|
" AND cv_sort.custom_field_id=#{id} AND cv_sort.value <> '' AND cv_sort.value IS NOT NULL LIMIT 1)"
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in New Issue