Class: SimpleForm::Wrappers::Builder

Inherits:
Object
  • Object
show all
Defined in:
lib/simple_form/wrappers/builder.rb

Overview

Provides the builder syntax for components. The builder provides three methods ‘use`, `optional` and `wrapper` and they allow the following invocations:

config.wrappers do |b|
  # Use a single component
  b.use :html5

  # Use the component, but do not automatically lookup. It will only be triggered when
  # :placeholder is explicitly set.
  b.optional :placeholder

  # Use a component with specific wrapper options
  b.use :error, :wrap_with => { :tag => "span", :class => "error" }

  # Use a set of components by wrapping them in a tag+class.
  b.wrapper :tag => "div", :class => "another" do |ba|
    ba.use :label
    ba.use :input
  end

  # Use a set of components by wrapping them in a tag+class.
  # This wrapper is identified by :label_input, which means it can
  # be turned off on demand with `f.input :name, :label_input => false`
  b.wrapper :label_input, :tag => "div", :class => "another" do |ba|
    ba.use :label
    ba.use :input
  end
end

The builder also accepts default options at the root level. This is usually used if you want a component to be disabled by default:

config.wrappers :hint => false do |b|
  b.use :hint
  b.use :label_input
end

In the example above, hint defaults to false, which means it won’t automatically do the lookup anymore. It will only be triggered when :hint is explicitly set.

Instance Method Summary collapse

Constructor Details

#initialize(options) ⇒ Builder

Returns a new instance of Builder.



43
44
45
46
# File 'lib/simple_form/wrappers/builder.rb', line 43

def initialize(options)
  @options    = options
  @components = []
end

Instance Method Details

#optional(name, options = nil, &block) ⇒ Object



68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# File 'lib/simple_form/wrappers/builder.rb', line 68

def optional(name, options=nil, &block)
  if block_given?
    ActiveSupport::Deprecation.warn "Passing a block to optional is deprecated. " \
      "Please use wrapper instead of optional."
    return wrapper(name, options, &block)
  end

  if options && options.keys != [:wrap_with]
    ActiveSupport::Deprecation.warn "Passing :tag, :class and others to optional is deprecated. " \
      "Please invoke b.optional #{name.inspect}, :wrap_with => #{options.inspect} instead."
    options = { :wrap_with => options }
  end

  @options[name] = false
  use(name, options, &block)
end

#to_aObject



98
99
100
# File 'lib/simple_form/wrappers/builder.rb', line 98

def to_a
  @components
end

#use(name, options = nil, &block) ⇒ Object



48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# File 'lib/simple_form/wrappers/builder.rb', line 48

def use(name, options=nil, &block)
  if block_given?
    ActiveSupport::Deprecation.warn "Passing a block to use is deprecated. " \
      "Please use wrapper instead of use."
    return wrapper(name, options, &block)
  end

  if options && options.keys != [:wrap_with]
    ActiveSupport::Deprecation.warn "Passing :tag, :class and others to use is deprecated. " \
      "Please invoke b.use #{name.inspect}, :wrap_with => #{options.inspect} instead."
    options = { :wrap_with => options }
  end

  if options && wrapper = options[:wrap_with]
    @components << Single.new(name, wrapper)
  else
    @components << name
  end
end

#wrapper(name, options = nil) ⇒ Object



85
86
87
88
89
90
91
92
93
94
95
96
# File 'lib/simple_form/wrappers/builder.rb', line 85

def wrapper(name, options=nil)
  if block_given?
    name, options = nil, name if name.is_a?(Hash)
    builder = self.class.new(@options)
    options ||= {}
    options[:tag] = :div if options[:tag].nil?
    yield builder
    @components << Many.new(name, builder.to_a, options)
  else
    raise ArgumentError, "A block is required as argument to wrapper"
  end
end