require 'active_support/configurable' [%w(traits *.rb), %w(*.rb), %w(elements ** *.rb), %w(containers ** *.rb)] .flat_map { |matcher| Dir.glob(File.join(__dir__, 'govuk_design_system_formbuilder', *matcher)) } .each { |file| require file } module GOVUKDesignSystemFormBuilder include ActiveSupport::Configurable # @!group Defaults # Default form builder configuration # # * +:default_legend_size+ controls the default size of legend text. # Can be either +xl+, +l+, +m+ or +s+. # # * +:default_legend_tag+ controls the default tag that legends are # wrapped in. Defaults to +h1+. # # * +:default_submit_button_text+ sets the value assigned to +govuk_submit+, # defaults to 'Continue'. # # * +:default_submit_button_text+ sets the text used to divide the last radio # button in radio button fieldsets. As per the GOV.UK Design System spec, # it defaults to 'or'. # # * +:default_error_summary_title+ sets the text used in error summary # blocks. As per the GOV.UK Design System spec, it defaults to # 'There is a problem'. # # * +:localisation_schema_fallback+ sets the prefix elements for the array # used to build the localisation string. The final two elements are always # are the object name and attribute name. The _special_ value +__context__+, # is used as a placeholder for the context (label, fieldset or hint). # # * +:localisation_schema_legend+, +:localisation_schema_hint+ and # +:localisation_schema_label+ each override the schema root for their # particular context, allowing them to be independently customised. # === DEFAULTS = { default_legend_size: 'm', default_legend_tag: 'h1', default_submit_button_text: 'Continue', default_radio_divider_text: 'or', default_error_summary_title: 'There is a problem', localisation_schema_fallback: %i(helpers __context__), localisation_schema_label: nil, localisation_schema_hint: nil, localisation_schema_legend: nil }.freeze DEFAULTS.keys.each { |k| config_accessor(k) { DEFAULTS[k] } } class << self # Configure the form builder in the usual manner. All of the # keys in {DEFAULTS} can be configured as per the example below # # @example # GOVUKDesignSystemFormBuilder.configure do |conf| # conf.default_legend_size = 'xl' # conf.default_error_summary_title = 'OMG' # end def configure yield(config) end # Resets each of the configurable values to its default # # @note This method is only really intended for use to clean up # during testing def reset! configure do |c| DEFAULTS.each { |k, v| c.send("#{k}=", v) } end end end class FormBuilder < ActionView::Helpers::FormBuilder delegate :content_tag, :tag, :safe_join, :safe_concat, :capture, :link_to, :raw, to: :@template include GOVUKDesignSystemFormBuilder::Builder end # Disable Rails' div.field_with_error wrapper ActionView::Base.field_error_proc = ->(html_tag, _instance) { html_tag } end