2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
# File 'app/helpers/effective_form_builder_helper.rb', line 2
def effective_form_with(**options, &block)
options[:class] = [options[:class], 'needs-validation', ('form-inline' if options[:layout] == :inline)].compact.join(' ')
options[:html] = (options[:html] || {}).merge(novalidate: true, onsubmit: 'return EffectiveForm.validate(this);')
subject = Array(options[:scope] || options[:model]).last
class_name = subject.class.name.underscore
html_id = if subject.kind_of?(Symbol)
subject.to_s
elsif subject.respond_to?(:persisted?) && subject.persisted?
"edit_#{class_name}_#{subject.to_param}"
else
"new_#{class_name}"
end
remote_index = options.except(:model).hash.abs
if options.delete(:remote) == true
@_effective_remote_index ||= 0
if options[:html][:data].kind_of?(Hash)
options[:html][:data][:remote] = true
options[:html][:data]['data-remote-index'] = remote_index
else
options[:html]['data-remote'] = true
options[:html]['data-remote-index'] = remote_index
end
html_id = "#{html_id}_#{remote_index}"
end
options[:id] ||= options[:html].delete(:id) || html_id
without_error_proc do
form_with(**options.merge(builder: Effective::FormBuilder), &block)
end
end
|