Class: ActiveRecord::Errors
- Inherits:
-
Object
- Object
- ActiveRecord::Errors
- Defined in:
- lib/custom_error_message.rb
Instance Method Summary collapse
-
#full_messages ⇒ Object
Redefine the ActiveRecord::Errors::full_messages method: Returns all the full error messages in an array.
Instance Method Details
#full_messages ⇒ Object
Redefine the ActiveRecord::Errors::full_messages method:
Returns all the full error messages in an array. 'Base' messages are handled as usual.
Non-base messages are prefixed with the attribute name as usual UNLESS
(1) they begin with ‘^’ in which case the attribute name is omitted.
E.g. validates_acceptance_of :accepted_terms, :message => '^Please accept the terms of service'
(2) the message is a proc, in which case the proc is invoked on the model object.
E.g. validates_presence_of :assessment_answer_option_id,
:message => Proc.new { |aa| "#{aa.label} (#{aa.group_label}) is required" }
which gives an error message like:
Rate (Accuracy) is required
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/custom_error_message.rb', line 14 def = [] @errors.each_key do |attr| @errors[attr].each do |msg| next if msg.nil? msg = msg.respond_to?(:message) ? msg. : msg if attr == "base" << msg elsif msg =~ /^\^/ << msg[1..-1] elsif msg.is_a? Proc << msg.call(@base) else << @base.class.human_attribute_name(attr) + " " + msg end end end return end |