simple_form 3.0.4 → 3.1.0.rc1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of simple_form might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +32 -43
- data/MIT-LICENSE +1 -1
- data/README.md +146 -71
- data/lib/generators/simple_form/install_generator.rb +2 -2
- data/lib/generators/simple_form/templates/README +3 -4
- data/lib/generators/simple_form/templates/config/initializers/simple_form.rb +19 -3
- data/lib/generators/simple_form/templates/config/initializers/simple_form_bootstrap.rb +83 -22
- data/lib/generators/simple_form/templates/config/initializers/simple_form_foundation.rb +1 -1
- data/lib/generators/simple_form/templates/config/locales/simple_form.en.yml +7 -2
- data/lib/simple_form.rb +38 -6
- data/lib/simple_form/action_view_extensions/form_helper.rb +1 -1
- data/lib/simple_form/components/errors.rb +27 -5
- data/lib/simple_form/components/hints.rb +2 -2
- data/lib/simple_form/components/html5.rb +1 -1
- data/lib/simple_form/components/label_input.rb +20 -2
- data/lib/simple_form/components/labels.rb +9 -5
- data/lib/simple_form/components/maxlength.rb +1 -1
- data/lib/simple_form/components/min_max.rb +1 -1
- data/lib/simple_form/components/pattern.rb +1 -1
- data/lib/simple_form/components/placeholders.rb +2 -2
- data/lib/simple_form/components/readonly.rb +1 -1
- data/lib/simple_form/form_builder.rb +92 -59
- data/lib/simple_form/helpers.rb +5 -5
- data/lib/simple_form/inputs/base.rb +34 -12
- data/lib/simple_form/inputs/block_input.rb +1 -1
- data/lib/simple_form/inputs/boolean_input.rb +23 -13
- data/lib/simple_form/inputs/collection_input.rb +32 -9
- data/lib/simple_form/inputs/collection_radio_buttons_input.rb +6 -11
- data/lib/simple_form/inputs/collection_select_input.rb +4 -2
- data/lib/simple_form/inputs/date_time_input.rb +12 -2
- data/lib/simple_form/inputs/file_input.rb +4 -2
- data/lib/simple_form/inputs/grouped_collection_select_input.rb +15 -3
- data/lib/simple_form/inputs/hidden_input.rb +4 -2
- data/lib/simple_form/inputs/numeric_input.rb +5 -4
- data/lib/simple_form/inputs/password_input.rb +4 -2
- data/lib/simple_form/inputs/priority_input.rb +4 -2
- data/lib/simple_form/inputs/range_input.rb +1 -1
- data/lib/simple_form/inputs/string_input.rb +4 -2
- data/lib/simple_form/inputs/text_input.rb +4 -2
- data/lib/simple_form/railtie.rb +7 -0
- data/lib/simple_form/tags.rb +7 -0
- data/lib/simple_form/version.rb +1 -1
- data/lib/simple_form/wrappers.rb +1 -0
- data/lib/simple_form/wrappers/builder.rb +5 -5
- data/lib/simple_form/wrappers/leaf.rb +28 -0
- data/lib/simple_form/wrappers/many.rb +5 -6
- data/lib/simple_form/wrappers/root.rb +1 -1
- data/lib/simple_form/wrappers/single.rb +5 -3
- data/test/action_view_extensions/builder_test.rb +2 -2
- data/test/components/label_test.rb +1 -1
- data/test/form_builder/association_test.rb +17 -0
- data/test/form_builder/error_notification_test.rb +1 -1
- data/test/form_builder/error_test.rb +51 -32
- data/test/form_builder/general_test.rb +2 -2
- data/test/form_builder/input_field_test.rb +21 -37
- data/test/form_builder/label_test.rb +24 -1
- data/test/form_builder/wrapper_test.rb +67 -0
- data/test/generators/simple_form_generator_test.rb +2 -2
- data/test/inputs/boolean_input_test.rb +50 -2
- data/test/inputs/collection_check_boxes_input_test.rb +40 -11
- data/test/inputs/collection_radio_buttons_input_test.rb +76 -17
- data/test/inputs/collection_select_input_test.rb +108 -3
- data/test/inputs/datetime_input_test.rb +105 -38
- data/test/inputs/discovery_test.rb +12 -1
- data/test/inputs/grouped_collection_select_input_test.rb +36 -0
- data/test/inputs/string_input_test.rb +20 -0
- data/test/simple_form_test.rb +8 -0
- data/test/support/discovery_inputs.rb +12 -2
- data/test/support/misc_helpers.rb +46 -8
- data/test/support/models.rb +49 -24
- metadata +7 -7
@@ -4,12 +4,12 @@ module SimpleForm
|
|
4
4
|
desc "Copy SimpleForm default files"
|
5
5
|
source_root File.expand_path('../templates', __FILE__)
|
6
6
|
class_option :template_engine, desc: 'Template engine to be invoked (erb, haml or slim).'
|
7
|
-
class_option :bootstrap, type: :boolean, desc: 'Add the
|
7
|
+
class_option :bootstrap, type: :boolean, desc: 'Add the Bootstrap wrappers to the SimpleForm initializer.'
|
8
8
|
class_option :foundation, type: :boolean, desc: 'Add the Zurb Foundation 3 wrappers to the SimpleForm initializer.'
|
9
9
|
|
10
10
|
def info_bootstrap
|
11
11
|
return if options.bootstrap? || options.foundation?
|
12
|
-
puts "SimpleForm 2 supports
|
12
|
+
puts "SimpleForm 2 supports Bootstrap and Zurb Foundation 3. If you want "\
|
13
13
|
"a configuration that is compatible with one of these frameworks, then please " \
|
14
14
|
"re-run this generator with --bootstrap or --foundation as an option."
|
15
15
|
end
|
@@ -1,12 +1,11 @@
|
|
1
1
|
===============================================================================
|
2
2
|
|
3
3
|
Be sure to have a copy of the Bootstrap stylesheet available on your
|
4
|
-
application, you can get it on http://
|
4
|
+
application, you can get it on http://getbootstrap.com/.
|
5
5
|
|
6
6
|
Inside your views, use the 'simple_form_for' with one of the Bootstrap form
|
7
|
-
classes, '.form-horizontal'
|
8
|
-
'.form-vertical', as the following:
|
7
|
+
classes, '.form-horizontal' or '.form-inline', as the following:
|
9
8
|
|
10
|
-
= simple_form_for(@user, html: {class: 'form-horizontal' }) do |form|
|
9
|
+
= simple_form_for(@user, html: { class: 'form-horizontal' }) do |form|
|
11
10
|
|
12
11
|
===============================================================================
|
@@ -43,6 +43,12 @@ SimpleForm.setup do |config|
|
|
43
43
|
b.use :label_input
|
44
44
|
b.use :hint, wrap_with: { tag: :span, class: :hint }
|
45
45
|
b.use :error, wrap_with: { tag: :span, class: :error }
|
46
|
+
|
47
|
+
## full_messages_for
|
48
|
+
# If you want to display the full error message for the attribute, you can
|
49
|
+
# use the component :full_error, like:
|
50
|
+
#
|
51
|
+
# b.use :full_error, wrap_with: { tag: :span, class: :error }
|
46
52
|
end
|
47
53
|
|
48
54
|
# The default wrapper to be used by the FormBuilder.
|
@@ -66,7 +72,7 @@ SimpleForm.setup do |config|
|
|
66
72
|
config.error_notification_tag = :div
|
67
73
|
|
68
74
|
# CSS class to add for error notification helper.
|
69
|
-
config.error_notification_class = '
|
75
|
+
config.error_notification_class = 'error_notification'
|
70
76
|
|
71
77
|
# ID to add for error notification helper.
|
72
78
|
# config.error_notification_id = nil
|
@@ -92,10 +98,10 @@ SimpleForm.setup do |config|
|
|
92
98
|
# config.item_wrapper_class = nil
|
93
99
|
|
94
100
|
# How the label text should be generated altogether with the required text.
|
95
|
-
# config.label_text = lambda { |label, required| "#{required} #{label}" }
|
101
|
+
# config.label_text = lambda { |label, required, explicit_label| "#{required} #{label}" }
|
96
102
|
|
97
103
|
# You can define the class to use on all labels. Default is nil.
|
98
|
-
config.label_class =
|
104
|
+
# config.label_class = nil
|
99
105
|
|
100
106
|
# You can define the class to use on all forms. Default is simple_form.
|
101
107
|
# config.form_class = :simple_form
|
@@ -142,4 +148,14 @@ SimpleForm.setup do |config|
|
|
142
148
|
|
143
149
|
# Default class for inputs
|
144
150
|
# config.input_class = nil
|
151
|
+
|
152
|
+
# Define the default class of the input wrapper of the boolean input.
|
153
|
+
config.boolean_label_class = 'checkbox'
|
154
|
+
|
155
|
+
# Defines if the default input wrapper class should be included in radio
|
156
|
+
# collection wrappers.
|
157
|
+
# config.include_default_input_wrapper_class = true
|
158
|
+
|
159
|
+
# Defines which i18n scope will be used in Simple Form.
|
160
|
+
# config.i18n_scope = 'simple_form'
|
145
161
|
end
|
@@ -1,45 +1,106 @@
|
|
1
1
|
# Use this setup block to configure all options available in SimpleForm.
|
2
2
|
SimpleForm.setup do |config|
|
3
|
-
config.
|
3
|
+
config.button_class = 'btn btn-default'
|
4
|
+
config.boolean_label_class = nil
|
5
|
+
|
6
|
+
config.wrappers :vertical_form, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
|
4
7
|
b.use :html5
|
5
8
|
b.use :placeholder
|
6
|
-
b.use :label
|
7
|
-
|
9
|
+
b.use :label, class: 'control-label'
|
10
|
+
|
11
|
+
b.wrapper tag: 'div' do |ba|
|
12
|
+
ba.use :input, class: 'form-control'
|
13
|
+
ba.use :error, wrap_with: { tag: 'span', class: 'help-block' }
|
14
|
+
ba.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
config.wrappers :vertical_file_input, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
|
19
|
+
b.use :html5
|
20
|
+
b.use :placeholder
|
21
|
+
b.use :label, class: 'control-label'
|
22
|
+
|
23
|
+
b.wrapper tag: 'div' do |ba|
|
8
24
|
ba.use :input
|
9
|
-
ba.use :error, wrap_with: { tag: 'span', class: 'help-
|
25
|
+
ba.use :error, wrap_with: { tag: 'span', class: 'help-block' }
|
10
26
|
ba.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
|
11
27
|
end
|
12
28
|
end
|
13
29
|
|
14
|
-
config.wrappers :
|
30
|
+
config.wrappers :vertical_boolean, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
|
15
31
|
b.use :html5
|
16
32
|
b.use :placeholder
|
17
|
-
|
18
|
-
b.wrapper tag: 'div', class: '
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
33
|
+
|
34
|
+
b.wrapper tag: 'div', class: 'checkbox' do |ba|
|
35
|
+
ba.use :label_input
|
36
|
+
end
|
37
|
+
|
38
|
+
b.use :error, wrap_with: { tag: 'span', class: 'help-block' }
|
39
|
+
b.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
|
40
|
+
end
|
41
|
+
|
42
|
+
config.wrappers :vertical_radio_and_checkboxes, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
|
43
|
+
b.use :html5
|
44
|
+
b.use :placeholder
|
45
|
+
b.use :label_input
|
46
|
+
b.use :error, wrap_with: { tag: 'span', class: 'help-block' }
|
47
|
+
b.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
|
48
|
+
end
|
49
|
+
|
50
|
+
config.wrappers :horizontal_form, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
|
51
|
+
b.use :html5
|
52
|
+
b.use :placeholder
|
53
|
+
b.use :label, class: 'col-sm-3 control-label'
|
54
|
+
|
55
|
+
b.wrapper tag: 'div', class: 'col-sm-9' do |ba|
|
56
|
+
ba.use :input, class: 'form-control'
|
57
|
+
ba.use :error, wrap_with: { tag: 'span', class: 'help-block' }
|
58
|
+
ba.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
|
24
59
|
end
|
25
60
|
end
|
26
61
|
|
27
|
-
config.wrappers :
|
62
|
+
config.wrappers :horizontal_file_input, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
|
28
63
|
b.use :html5
|
29
64
|
b.use :placeholder
|
30
|
-
b.use :label
|
31
|
-
|
32
|
-
|
33
|
-
|
65
|
+
b.use :label, class: 'col-sm-3 control-label'
|
66
|
+
|
67
|
+
b.wrapper tag: 'div', class: 'col-sm-9' do |ba|
|
68
|
+
ba.use :input
|
69
|
+
ba.use :error, wrap_with: { tag: 'span', class: 'help-block' }
|
70
|
+
ba.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
config.wrappers :horizontal_boolean, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
|
75
|
+
b.use :html5
|
76
|
+
b.use :placeholder
|
77
|
+
|
78
|
+
b.wrapper tag: 'div', class: 'col-sm-offset-3 col-sm-9' do |wr|
|
79
|
+
wr.wrapper tag: 'div', class: 'checkbox' do |ba|
|
80
|
+
ba.use :label_input, class: 'col-sm-9'
|
34
81
|
end
|
35
|
-
|
36
|
-
|
82
|
+
|
83
|
+
wr.use :error, wrap_with: { tag: 'span', class: 'help-block' }
|
84
|
+
wr.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
|
85
|
+
end
|
86
|
+
end
|
87
|
+
|
88
|
+
config.wrappers :horizontal_radio_and_checkboxes, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
|
89
|
+
b.use :html5
|
90
|
+
b.use :placeholder
|
91
|
+
|
92
|
+
b.use :label, class: 'col-sm-3 control-label'
|
93
|
+
|
94
|
+
b.wrapper tag: 'div', class: 'col-sm-9' do |ba|
|
95
|
+
ba.use :input
|
96
|
+
ba.use :error, wrap_with: { tag: 'span', class: 'help-block' }
|
97
|
+
ba.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
|
37
98
|
end
|
38
99
|
end
|
39
100
|
|
40
|
-
# Wrappers for forms and inputs using the
|
41
|
-
# Check the Bootstrap docs (http://
|
101
|
+
# Wrappers for forms and inputs using the Bootstrap toolkit.
|
102
|
+
# Check the Bootstrap docs (http://getbootstrap.com)
|
42
103
|
# to learn about the different styles for forms and inputs,
|
43
104
|
# buttons and other elements.
|
44
|
-
config.default_wrapper = :
|
105
|
+
config.default_wrapper = :vertical_form
|
45
106
|
end
|
@@ -8,7 +8,7 @@ SimpleForm.setup do |config|
|
|
8
8
|
b.optional :min_max
|
9
9
|
b.optional :readonly
|
10
10
|
b.use :label_input
|
11
|
-
b.use :error, wrap_with: { tag: :small }
|
11
|
+
b.use :error, wrap_with: { tag: :small, class: :error }
|
12
12
|
|
13
13
|
# Uncomment the following line to enable hints. The line is commented out by default since Foundation
|
14
14
|
# does't provide styles for hints. You will need to provide your own CSS styles for hints.
|
@@ -10,7 +10,7 @@ en:
|
|
10
10
|
# html: '<abbr title="required">*</abbr>'
|
11
11
|
error_notification:
|
12
12
|
default_message: "Please review the problems below:"
|
13
|
-
#
|
13
|
+
# Examples
|
14
14
|
# labels:
|
15
15
|
# defaults:
|
16
16
|
# password: 'Password'
|
@@ -23,4 +23,9 @@ en:
|
|
23
23
|
# defaults:
|
24
24
|
# username: 'User name to sign in.'
|
25
25
|
# password: 'No special characters, please.'
|
26
|
-
|
26
|
+
# include_blanks:
|
27
|
+
# defaults:
|
28
|
+
# age: 'Rather not say'
|
29
|
+
# prompts:
|
30
|
+
# defaults:
|
31
|
+
# age: 'Select your age'
|
data/lib/simple_form.rb
CHANGED
@@ -24,6 +24,24 @@ module SimpleForm
|
|
24
24
|
SimpleForm::Components.eager_load!
|
25
25
|
end
|
26
26
|
|
27
|
+
CUSTOM_INPUT_DEPRECATION_WARN = <<-WARN
|
28
|
+
%{name} method now accepts a `wrapper_options` argument. The method definition without the argument is deprecated and will be removed in the next Simple Form version. Change your code from:
|
29
|
+
|
30
|
+
def %{name}
|
31
|
+
|
32
|
+
to
|
33
|
+
|
34
|
+
def %{name}(wrapper_options)
|
35
|
+
|
36
|
+
See https://github.com/plataformatec/simple_form/pull/997 for more information.
|
37
|
+
WARN
|
38
|
+
|
39
|
+
@@configured = false
|
40
|
+
|
41
|
+
def self.configured? #:nodoc:
|
42
|
+
@@configured
|
43
|
+
end
|
44
|
+
|
27
45
|
## CONFIGURATION OPTIONS
|
28
46
|
|
29
47
|
# Method used to tidy up errors.
|
@@ -66,7 +84,7 @@ module SimpleForm
|
|
66
84
|
|
67
85
|
# How the label text should be generated altogether with the required text.
|
68
86
|
mattr_accessor :label_text
|
69
|
-
@@label_text = lambda { |label, required| "#{required} #{label}" }
|
87
|
+
@@label_text = lambda { |label, required, explicit_label| "#{required} #{label}" }
|
70
88
|
|
71
89
|
# You can define the class to be used on all labels. Defaults to none.
|
72
90
|
mattr_accessor :label_class
|
@@ -107,6 +125,8 @@ module SimpleForm
|
|
107
125
|
# Custom wrappers for input types. This should be a hash containing an input
|
108
126
|
# type as key and the wrapper that will be used for all inputs with specified type.
|
109
127
|
# e.g { string: :string_wrapper, boolean: :boolean_wrapper }
|
128
|
+
# You can also set a wrapper mapping per form basis.
|
129
|
+
# e.g simple_form_for(@foo, wrapper_mappings: { check_boxes: :bootstrap_checkbox })
|
110
130
|
mattr_accessor :wrapper_mappings
|
111
131
|
@@wrapper_mappings = nil
|
112
132
|
|
@@ -151,15 +171,26 @@ module SimpleForm
|
|
151
171
|
mattr_accessor :input_class
|
152
172
|
@@input_class = nil
|
153
173
|
|
174
|
+
# Defines if an input wrapper class should be included or not
|
175
|
+
mattr_accessor :include_default_input_wrapper_class
|
176
|
+
@@include_default_input_wrapper_class = true
|
177
|
+
|
178
|
+
# Define the default class of the input wrapper of the boolean input.
|
179
|
+
mattr_accessor :boolean_label_class
|
180
|
+
@@boolean_label_class = 'checkbox'
|
181
|
+
|
154
182
|
## WRAPPER CONFIGURATION
|
155
183
|
# The default wrapper to be used by the FormBuilder.
|
156
184
|
mattr_accessor :default_wrapper
|
157
185
|
@@default_wrapper = :default
|
158
|
-
@@wrappers = {}
|
186
|
+
@@wrappers = {} #:nodoc:
|
187
|
+
|
188
|
+
mattr_accessor :i18n_scope
|
189
|
+
@@i18n_scope = 'simple_form'
|
159
190
|
|
160
191
|
# Retrieves a given wrapper
|
161
192
|
def self.wrapper(name)
|
162
|
-
@@wrappers[name.
|
193
|
+
@@wrappers[name.to_s] or raise WrapperNotFound, "Couldn't find wrapper with name #{name}"
|
163
194
|
end
|
164
195
|
|
165
196
|
# Raised when fails to find a given wrapper name
|
@@ -172,14 +203,14 @@ module SimpleForm
|
|
172
203
|
if block_given?
|
173
204
|
options = args.extract_options!
|
174
205
|
name = args.first || :default
|
175
|
-
@@wrappers[name.
|
206
|
+
@@wrappers[name.to_s] = build(options, &block)
|
176
207
|
else
|
177
208
|
@@wrappers
|
178
209
|
end
|
179
210
|
end
|
180
211
|
|
181
212
|
# Builds a new wrapper using SimpleForm::Wrappers::Builder.
|
182
|
-
def self.build(options={})
|
213
|
+
def self.build(options = {})
|
183
214
|
options[:tag] = :div if options[:tag].nil?
|
184
215
|
builder = SimpleForm::Wrappers::Builder.new(options)
|
185
216
|
yield builder
|
@@ -210,9 +241,10 @@ module SimpleForm
|
|
210
241
|
ActiveSupport::Deprecation.warn "[SIMPLE_FORM] SimpleForm.default_input_size= is deprecated and has no effect", caller
|
211
242
|
end
|
212
243
|
|
213
|
-
# Default way to setup
|
244
|
+
# Default way to setup Simple Form. Run rails generate simple_form:install
|
214
245
|
# to create a fresh initializer with all configuration values.
|
215
246
|
def self.setup
|
247
|
+
@@configured = true
|
216
248
|
yield self
|
217
249
|
end
|
218
250
|
end
|
@@ -10,7 +10,7 @@ module SimpleForm
|
|
10
10
|
#
|
11
11
|
module FormHelper
|
12
12
|
|
13
|
-
def simple_form_for(record, options={}, &block)
|
13
|
+
def simple_form_for(record, options = {}, &block)
|
14
14
|
options[:builder] ||= SimpleForm::FormBuilder
|
15
15
|
options[:html] ||= {}
|
16
16
|
unless options[:html].key?(:novalidate)
|
@@ -1,10 +1,14 @@
|
|
1
1
|
module SimpleForm
|
2
2
|
module Components
|
3
3
|
module Errors
|
4
|
-
def error
|
4
|
+
def error(wrapper_options = nil)
|
5
5
|
error_text if has_errors?
|
6
6
|
end
|
7
7
|
|
8
|
+
def full_error(wrapper_options = nil)
|
9
|
+
full_error_text if options[:error] != false && has_errors?
|
10
|
+
end
|
11
|
+
|
8
12
|
def has_errors?
|
9
13
|
object && object.respond_to?(:errors) && errors.present?
|
10
14
|
end
|
@@ -12,9 +16,15 @@ module SimpleForm
|
|
12
16
|
protected
|
13
17
|
|
14
18
|
def error_text
|
15
|
-
text =
|
19
|
+
text = has_custom_error? ? options[:error] : errors.send(error_method)
|
20
|
+
|
21
|
+
"#{html_escape(options[:error_prefix])} #{text}".lstrip.html_safe
|
22
|
+
end
|
23
|
+
|
24
|
+
def full_error_text
|
25
|
+
text = has_custom_error? ? options[:error] : full_errors.send(error_method)
|
16
26
|
|
17
|
-
|
27
|
+
text.html_safe
|
18
28
|
end
|
19
29
|
|
20
30
|
def error_method
|
@@ -25,16 +35,28 @@ module SimpleForm
|
|
25
35
|
@errors ||= (errors_on_attribute + errors_on_association).compact
|
26
36
|
end
|
27
37
|
|
38
|
+
def full_errors
|
39
|
+
@full_errors ||= (full_errors_on_attribute + full_errors_on_association).compact
|
40
|
+
end
|
41
|
+
|
28
42
|
def errors_on_attribute
|
29
43
|
object.errors[attribute_name]
|
30
44
|
end
|
31
45
|
|
46
|
+
def full_errors_on_attribute
|
47
|
+
object.errors.full_messages_for(attribute_name)
|
48
|
+
end
|
49
|
+
|
32
50
|
def errors_on_association
|
33
51
|
reflection ? object.errors[reflection.name] : []
|
34
52
|
end
|
35
53
|
|
36
|
-
def
|
37
|
-
|
54
|
+
def full_errors_on_association
|
55
|
+
reflection ? object.full_messages_for(reflection.name) : []
|
56
|
+
end
|
57
|
+
|
58
|
+
def has_custom_error?
|
59
|
+
options[:error].is_a?(String)
|
38
60
|
end
|
39
61
|
end
|
40
62
|
end
|
@@ -2,14 +2,14 @@ module SimpleForm
|
|
2
2
|
module Components
|
3
3
|
# Needs to be enabled in order to do automatic lookups.
|
4
4
|
module Hints
|
5
|
-
def hint
|
5
|
+
def hint(wrapper_options = nil)
|
6
6
|
@hint ||= begin
|
7
7
|
hint = options[:hint]
|
8
8
|
|
9
9
|
if hint.is_a?(String)
|
10
10
|
html_escape(hint)
|
11
11
|
else
|
12
|
-
content =
|
12
|
+
content = translate_from_namespace(:hints)
|
13
13
|
content.html_safe if content
|
14
14
|
end
|
15
15
|
end
|
@@ -7,8 +7,26 @@ module SimpleForm
|
|
7
7
|
include SimpleForm::Components::Labels
|
8
8
|
end
|
9
9
|
|
10
|
-
def label_input
|
11
|
-
options[:label] == false
|
10
|
+
def label_input(wrapper_options = nil)
|
11
|
+
if options[:label] == false
|
12
|
+
deprecated_component(:input, wrapper_options)
|
13
|
+
else
|
14
|
+
deprecated_component(:label, wrapper_options) + deprecated_component(:input, wrapper_options)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
private
|
19
|
+
|
20
|
+
def deprecated_component(namespace, wrapper_options)
|
21
|
+
method = method(namespace)
|
22
|
+
|
23
|
+
if method.arity == 0
|
24
|
+
ActiveSupport::Deprecation.warn(SimpleForm::CUSTOM_INPUT_DEPRECATION_WARN % { name: namespace })
|
25
|
+
|
26
|
+
method.call
|
27
|
+
else
|
28
|
+
method.call(wrapper_options)
|
29
|
+
end
|
12
30
|
end
|
13
31
|
end
|
14
32
|
end
|