Class: Redmine::FieldFormat::UserFormat
Overview
Instance Method Summary
collapse
Methods inherited from RecordList
#cast_single_value, #group_statement, #join_for_order_statement, #order_statement, #possible_custom_value_options, #reset_target_class, #target_class, #validate_custom_value
Methods inherited from List
#bulk_edit_tag, #edit_tag, #query_filter_options
Methods inherited from Base
#after_save_custom_value, #bulk_edit_tag, #cast_custom_value, #cast_single_value, #cast_value, #edit_tag, field_attributes, #formatted_custom_value, #formatted_value, #group_statement, #join_for_order_statement, #label, #name, #order_statement, #possible_custom_value_options, #query_filter_options, #set_custom_field_value, #target_class, #validate_custom_field, #validate_custom_value, #validate_single_value
#uri_with_safe_scheme?
Methods included from I18n
#current_language, #day_letter, #day_name, #find_language, #format_date, #format_hours, #format_time, #l, #l_hours, #l_hours_short, #l_or_humanize, #languages_options, #ll, #lu, #month_name, #set_language_if_valid, #valid_languages
Instance Method Details
#before_custom_field_save(custom_field) ⇒ Object
843
844
845
846
847
848
|
# File 'lib/redmine/field_format.rb', line 843
def before_custom_field_save(custom_field)
super
if custom_field.user_role.is_a?(Array)
custom_field.user_role.map!(&:to_s).reject!(&:blank?)
end
end
|
#possible_values_options(custom_field, object = nil) ⇒ Object
814
815
816
|
# File 'lib/redmine/field_format.rb', line 814
def possible_values_options(custom_field, object=nil)
possible_values_records(custom_field, object).map {|u| [u.name, u.id.to_s]}
end
|
#possible_values_records(custom_field, object = nil) ⇒ Object
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
|
# File 'lib/redmine/field_format.rb', line 818
def possible_values_records(custom_field, object=nil)
if object.is_a?(Array)
projects = object.map {|o| o.respond_to?(:project) ? o.project : nil}.compact.uniq
projects.map {|project| possible_values_records(custom_field, project)}.reduce(:&) || []
elsif object.respond_to?(:project) && object.project
scope = object.project.users
if custom_field.user_role.is_a?(Array)
role_ids = custom_field.user_role.map(&:to_s).reject(&:blank?).map(&:to_i)
if role_ids.any?
scope = scope.where("#{Member.table_name}.id IN (SELECT DISTINCT member_id FROM #{MemberRole.table_name} WHERE role_id IN (?))", role_ids)
end
end
scope.sorted
else
[]
end
end
|
#query_filter_values(custom_field, query) ⇒ Object
850
851
852
|
# File 'lib/redmine/field_format.rb', line 850
def query_filter_values(custom_field, query)
query.author_values
end
|
#value_from_keyword(custom_field, keyword, object) ⇒ Object
836
837
838
839
840
841
|
# File 'lib/redmine/field_format.rb', line 836
def value_from_keyword(custom_field, keyword, object)
users = possible_values_records(custom_field, object).to_a
parse_keyword(custom_field, keyword) do |k|
Principal.detect_by_keyword(users, k).try(:id)
end
end
|