diff options
author | Toshi MARUYAMA <marutosijp2@yahoo.co.jp> | 2020-12-12 15:49:21 +0000 |
---|---|---|
committer | Toshi MARUYAMA <marutosijp2@yahoo.co.jp> | 2020-12-12 15:49:21 +0000 |
commit | 655057f08ba6bc4873ea91d99d515f29dc2fb6a3 (patch) | |
tree | 2d9e103a1eb5d7db4473ea1f3aedda14aabb4b1c /app/models/custom_field.rb | |
parent | 7afb0995c2ecfb0022a0b385b7afbca39e6893ec (diff) | |
download | redmine-655057f08ba6bc4873ea91d99d515f29dc2fb6a3.tar.gz redmine-655057f08ba6bc4873ea91d99d515f29dc2fb6a3.zip |
shorten long line of app/models/custom_field.rb
git-svn-id: http://svn.redmine.org/redmine/trunk@20637 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models/custom_field.rb')
-rw-r--r-- | app/models/custom_field.rb | 38 |
1 files changed, 24 insertions, 14 deletions
diff --git a/app/models/custom_field.rb b/app/models/custom_field.rb index 06005031e..e0ea10cc8 100644 --- a/app/models/custom_field.rb +++ b/app/models/custom_field.rb @@ -26,7 +26,9 @@ class CustomField < ActiveRecord::Base :class_name => 'CustomFieldEnumeration', :dependent => :delete_all has_many :custom_values, :dependent => :delete_all - has_and_belongs_to_many :roles, :join_table => "#{table_name_prefix}custom_fields_roles#{table_name_suffix}", :foreign_key => "custom_field_id" + has_and_belongs_to_many :roles, + :join_table => "#{table_name_prefix}custom_fields_roles#{table_name_suffix}", + :foreign_key => "custom_field_id" acts_as_positioned serialize :possible_values store :format_store @@ -35,7 +37,8 @@ class CustomField < ActiveRecord::Base validates_uniqueness_of :name, :scope => :type validates_length_of :name, :maximum => 30 validates_length_of :regexp, maximum: 255 - validates_inclusion_of :field_format, :in => Proc.new {Redmine::FieldFormat.available_formats} + validates_inclusion_of :field_format, + :in => proc {Redmine::FieldFormat.available_formats} validate :validate_custom_field before_validation :set_searchable @@ -56,11 +59,15 @@ class CustomField < ActiveRecord::Base # nop elsif user.memberships.any? where( - "#{table_name}.visible = ? OR #{table_name}.id IN (SELECT DISTINCT cfr.custom_field_id FROM #{Member.table_name} m" + - " INNER JOIN #{MemberRole.table_name} mr ON mr.member_id = m.id" + - " INNER JOIN #{table_name_prefix}custom_fields_roles#{table_name_suffix} cfr ON cfr.role_id = mr.role_id" + + "#{table_name}.visible = ? OR #{table_name}.id" \ + " IN (SELECT DISTINCT cfr.custom_field_id FROM #{Member.table_name} m" \ + " INNER JOIN #{MemberRole.table_name} mr ON mr.member_id = m.id" \ + " INNER JOIN #{table_name_prefix}custom_fields_roles#{table_name_suffix} cfr" \ + " ON cfr.role_id = mr.role_id" \ " WHERE m.user_id = ?)", - true, user.id) + true, + user.id + ) else where(:visible => true) end @@ -227,9 +234,10 @@ class CustomField < ActiveRecord::Base else project_key ||= "#{self.class.customized_class.table_name}.project_id" id_column ||= id - "#{project_key} IN (SELECT DISTINCT m.project_id FROM #{Member.table_name} m" + - " INNER JOIN #{MemberRole.table_name} mr ON mr.member_id = m.id" + - " INNER JOIN #{table_name_prefix}custom_fields_roles#{table_name_suffix} cfr ON cfr.role_id = mr.role_id" + + "#{project_key} IN (SELECT DISTINCT m.project_id FROM #{Member.table_name} m" \ + " INNER JOIN #{MemberRole.table_name} mr ON mr.member_id = m.id" \ + " INNER JOIN #{table_name_prefix}custom_fields_roles#{table_name_suffix} cfr" \ + " ON cfr.role_id = mr.role_id" \ " WHERE m.user_id = #{user.id} AND cfr.custom_field_id = #{id_column})" end end @@ -318,11 +326,13 @@ class CustomField < ActiveRecord::Base def handle_multiplicity_change if !new_record? && multiple_before_last_save && !multiple ids = custom_values. - where("EXISTS(SELECT 1 FROM #{CustomValue.table_name} cve WHERE cve.custom_field_id = #{CustomValue.table_name}.custom_field_id" + - " AND cve.customized_type = #{CustomValue.table_name}.customized_type AND cve.customized_id = #{CustomValue.table_name}.customized_id" + - " AND cve.id > #{CustomValue.table_name}.id)"). - pluck(:id) - + where( + "EXISTS(SELECT 1 FROM #{CustomValue.table_name} cve" \ + " WHERE cve.custom_field_id = #{CustomValue.table_name}.custom_field_id" \ + " AND cve.customized_type = #{CustomValue.table_name}.customized_type" \ + " AND cve.customized_id = #{CustomValue.table_name}.customized_id" \ + " AND cve.id > #{CustomValue.table_name}.id)" + ).pluck(:id) if ids.any? custom_values.where(:id => ids).delete_all end |