Skip to content

Instantly share code, notes, and snippets.

@codemilan
Forked from telwell/customize_error.rb
Created November 9, 2021 09:46
Show Gist options
  • Save codemilan/71ee9d7eb0aa77de9c022eb6552d080b to your computer and use it in GitHub Desktop.
Save codemilan/71ee9d7eb0aa77de9c022eb6552d080b to your computer and use it in GitHub Desktop.
Customize Field Errors with Rails 5 and Bootstrap
# Adapted from https://rubyplus.com/articles/3401-Customize-Field-Error-in-Rails-5
ActionView::Base.field_error_proc = Proc.new do |html_tag, instance|
html = ''
form_fields = [
'textarea',
'input',
'select'
]
elements = Nokogiri::HTML::DocumentFragment.parse(html_tag).css "label, " + form_fields.join(', ')
elements.each do |e|
if e.node_name.eql? 'label'
html = %(#{e}).html_safe
elsif form_fields.include? e.node_name
e['class'] += ' is-invalid'
if instance.error_message.kind_of?(Array)
html = %(#{e}<div class="invalid-feedback">#{instance.error_message.uniq.join(', ')}</div>).html_safe
else
html = %(#{e}<div class="invalid-feedback">#{instance.error_message}</div>).html_safe
end
end
end
html
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment