kono_utils_bootstrap_view4 0.1.0.pre.rc.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/MIT-LICENSE +20 -0
- data/README.md +21 -0
- data/Rakefile +32 -0
- data/app/assets/config/kono_utils_bootstrap_view4_manifest.js +0 -0
- data/app/assets/javascripts/kono_utils_bootstrap_view4/application.js.erb +12 -0
- data/app/assets/javascripts/kono_utils_bootstrap_view4/kono_utils_bootstrap_view4.js +36 -0
- data/app/assets/stylesheets/kono_utils_bootstrap_view4/application.css.scss.erb +12 -0
- data/app/concepts/kono_utils/object/cell/base.rb +123 -0
- data/app/concepts/kono_utils/object/cell/buttons/base.rb +57 -0
- data/app/concepts/kono_utils/object/cell/buttons/collapse_search.rb +31 -0
- data/app/concepts/kono_utils/object/cell/buttons/create.rb +22 -0
- data/app/concepts/kono_utils/object/cell/buttons/delete.rb +32 -0
- data/app/concepts/kono_utils/object/cell/buttons/download.rb +23 -0
- data/app/concepts/kono_utils/object/cell/buttons/edit.rb +18 -0
- data/app/concepts/kono_utils/object/cell/buttons/list.rb +17 -0
- data/app/concepts/kono_utils/object/cell/buttons/reset_search.rb +21 -0
- data/app/concepts/kono_utils/object/cell/create/base.rb +8 -0
- data/app/concepts/kono_utils/object/cell/create/page_title.rb +10 -0
- data/app/concepts/kono_utils/object/cell/create/side_title.rb +5 -0
- data/app/concepts/kono_utils/object/cell/edits/base.rb +8 -0
- data/app/concepts/kono_utils/object/cell/edits/page_title.rb +10 -0
- data/app/concepts/kono_utils/object/cell/edits/side_title.rb +5 -0
- data/app/concepts/kono_utils/object/cell/form.rb +51 -0
- data/app/concepts/kono_utils/object/cell/forms/base.rb +13 -0
- data/app/concepts/kono_utils/object/cell/forms/container.rb +25 -0
- data/app/concepts/kono_utils/object/cell/forms/containers/layout.rb +16 -0
- data/app/concepts/kono_utils/object/cell/forms/containers/modal_layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/containers/search_layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/containers/table_layout.rb +8 -0
- data/app/concepts/kono_utils/object/cell/forms/field_selector.rb +77 -0
- data/app/concepts/kono_utils/object/cell/forms/field_selectors/layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/field_selectors/modal_layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/field_selectors/table_layout.rb +8 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/association.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/base.rb +25 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/bases/layout.rb +24 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/bases/modal_layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/bases/table_layout.rb +11 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/check_box.rb +10 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/collection.rb +17 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/date_field.rb +15 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/date_time_field.rb +51 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/enum.rb +20 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/file_field.rb +31 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_modal_wrapper.rb +6 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_modal_wrappers/forms_container.rb +9 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_modal_wrappers/show.rb +14 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrapper.rb +63 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/form.rb +38 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/forms/layout.rb +13 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/forms/modal_layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/forms/table_layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/forms_container.rb +45 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/forms_containers/layout.rb +15 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/forms_containers/modal_layout.rb +9 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/forms_containers/table_layout.rb +16 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/header.rb +31 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/remove_button.rb +44 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/remove_buttons/layout.rb +10 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/remove_buttons/modal_layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/nested_wrappers/remove_buttons/table_layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/read_only.rb +15 -0
- data/app/concepts/kono_utils/object/cell/forms/fields/time_field.rb +11 -0
- data/app/concepts/kono_utils/object/cell/forms/layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/forms/submit.rb +22 -0
- data/app/concepts/kono_utils/object/cell/index/base.rb +12 -0
- data/app/concepts/kono_utils/object/cell/index/page_title.rb +10 -0
- data/app/concepts/kono_utils/object/cell/index/row.rb +40 -0
- data/app/concepts/kono_utils/object/cell/index/row_buttons.rb +7 -0
- data/app/concepts/kono_utils/object/cell/index/row_footer.rb +6 -0
- data/app/concepts/kono_utils/object/cell/index/row_header.rb +11 -0
- data/app/concepts/kono_utils/object/cell/index/side_title.rb +5 -0
- data/app/concepts/kono_utils/object/cell/index/table.rb +15 -0
- data/app/concepts/kono_utils/object/cell/inject.rb +122 -0
- data/app/concepts/kono_utils/object/cell/modals/base.rb +6 -0
- data/app/concepts/kono_utils/object/cell/modals/bodies/layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/modals/body.rb +6 -0
- data/app/concepts/kono_utils/object/cell/modals/container.rb +24 -0
- data/app/concepts/kono_utils/object/cell/modals/containers/layout.rb +10 -0
- data/app/concepts/kono_utils/object/cell/modals/footer.rb +6 -0
- data/app/concepts/kono_utils/object/cell/modals/footers/layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/modals/header.rb +6 -0
- data/app/concepts/kono_utils/object/cell/modals/headers/layout.rb +7 -0
- data/app/concepts/kono_utils/object/cell/search.rb +27 -0
- data/app/concepts/kono_utils/object/cell/searches/form.rb +14 -0
- data/app/concepts/kono_utils/object/cell/show.rb +26 -0
- data/app/concepts/kono_utils/object/cell/shows/base.rb +8 -0
- data/app/concepts/kono_utils/object/cell/shows/page_title.rb +10 -0
- data/app/concepts/kono_utils/object/cell/shows/side_title.rb +5 -0
- data/app/concepts/kono_utils/object/view/create/side_title.erb +1 -0
- data/app/concepts/kono_utils/object/view/edits/side_title.erb +1 -0
- data/app/concepts/kono_utils/object/view/form.erb +9 -0
- data/app/concepts/kono_utils/object/view/forms/container.erb +5 -0
- data/app/concepts/kono_utils/object/view/forms/containers/layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/forms/containers/modal_layout.erb +5 -0
- data/app/concepts/kono_utils/object/view/forms/containers/search_layout.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/containers/table_layout.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/field_selector.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/field_selectors/layout.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/field_selectors/modal_layout.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/field_selectors/table_layout.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/fields/association.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/fields/base.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/fields/bases/layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/forms/fields/bases/layout.scss +25 -0
- data/app/concepts/kono_utils/object/view/forms/fields/bases/modal_layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/forms/fields/bases/table_layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/forms/fields/check_box.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/fields/collection.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_modal_wrapper.erb +23 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_modal_wrappers/forms_container.erb +12 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_modal_wrappers/show.erb +28 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrapper.erb +18 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/form.erb +17 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/forms/layout.erb +18 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/forms/modal_layout.erb +4 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/forms/table_layout.erb +4 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/forms_container.erb +11 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/forms_containers/layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/forms_containers/modal_layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/forms_containers/table_layout.erb +14 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/header.erb +27 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/remove_button.erb +28 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/remove_buttons/layout.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/remove_buttons/modal_layout.erb +1 -0
- data/app/concepts/kono_utils/object/view/forms/fields/nested_wrappers/remove_buttons/table_layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/forms/layout.erb +1 -0
- data/app/concepts/kono_utils/object/view/index/row.erb +10 -0
- data/app/concepts/kono_utils/object/view/index/row_buttons.erb +2 -0
- data/app/concepts/kono_utils/object/view/index/row_footer.erb +0 -0
- data/app/concepts/kono_utils/object/view/index/row_header.erb +8 -0
- data/app/concepts/kono_utils/object/view/index/side_title.erb +1 -0
- data/app/concepts/kono_utils/object/view/index/table.erb +9 -0
- data/app/concepts/kono_utils/object/view/inject.erb +8 -0
- data/app/concepts/kono_utils/object/view/modals/bodies/layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/modals/body.erb +1 -0
- data/app/concepts/kono_utils/object/view/modals/container.erb +13 -0
- data/app/concepts/kono_utils/object/view/modals/containers/layout.erb +7 -0
- data/app/concepts/kono_utils/object/view/modals/footer.erb +1 -0
- data/app/concepts/kono_utils/object/view/modals/footers/layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/modals/header.erb +1 -0
- data/app/concepts/kono_utils/object/view/modals/headers/layout.erb +3 -0
- data/app/concepts/kono_utils/object/view/search.erb +40 -0
- data/app/concepts/kono_utils/object/view/searches/form.erb +16 -0
- data/app/concepts/kono_utils/object/view/show.erb +6 -0
- data/app/concepts/kono_utils/object/view/shows/side_title.erb +1 -0
- data/app/inputs/file_input_download_input.rb +22 -0
- data/app/inputs/tempus_dominus_input.rb +38 -0
- data/app/views/kaminari/_first_page.html.erb +3 -0
- data/app/views/kaminari/_gap.html.erb +3 -0
- data/app/views/kaminari/_last_page.html.erb +3 -0
- data/app/views/kaminari/_next_page.html.erb +3 -0
- data/app/views/kaminari/_page.html.erb +9 -0
- data/app/views/kaminari/_paginator.html.erb +17 -0
- data/app/views/kaminari/_prev_page.html.erb +3 -0
- data/app/views/kono_utils/base_editing/edit.html.erb +8 -0
- data/app/views/kono_utils/base_editing/edit.inject.erb +2 -0
- data/app/views/kono_utils/base_editing/index.html.erb +10 -0
- data/app/views/kono_utils/base_editing/new.html.erb +9 -0
- data/app/views/kono_utils/base_editing/new.inject.erb +2 -0
- data/app/views/kono_utils/base_editing/show.html.erb +8 -0
- data/app/views/kono_utils/base_editing/success_create_show.inject.erb +6 -0
- data/app/views/kono_utils/base_editing/success_update_show.inject.erb +6 -0
- data/config/initializers/kaminari_config.rb +30 -0
- data/config/initializers/simple_form.rb +179 -0
- data/config/initializers/simple_form_bootstrap.rb +439 -0
- data/config/locales/kono_utils_bootstrap4.en.yml +15 -0
- data/config/locales/kono_utils_bootstrap4.it.yml +15 -0
- data/config/locales/simple_form.en.yml +31 -0
- data/config/routes.rb +2 -0
- data/lib/generators/kono_utils_bootstrap_view4/concept/concept_generator.rb +79 -0
- data/lib/generators/kono_utils_bootstrap_view4/concept/templates/form.template +8 -0
- data/lib/generators/kono_utils_bootstrap_view4/concept/templates/forms/field_selector.template +13 -0
- data/lib/generators/kono_utils_bootstrap_view4/install/install_generator.rb +76 -0
- data/lib/generators/kono_utils_bootstrap_view4/install/templates/kono_utils_bootstrap_view4.js.erb.template +20 -0
- data/lib/generators/kono_utils_bootstrap_view4/install/templates/kono_utils_bootstrap_view4.template +5 -0
- data/lib/kono_utils_bootstrap_view4.rb +26 -0
- data/lib/kono_utils_bootstrap_view4/application_icon_helper.rb +31 -0
- data/lib/kono_utils_bootstrap_view4/base_class_concept_ns.rb +47 -0
- data/lib/kono_utils_bootstrap_view4/base_search.rb +5 -0
- data/lib/kono_utils_bootstrap_view4/configuration.rb +20 -0
- data/lib/kono_utils_bootstrap_view4/editable_field.rb +63 -0
- data/lib/kono_utils_bootstrap_view4/engine.rb +59 -0
- data/lib/kono_utils_bootstrap_view4/paginate_proxer.rb +11 -0
- data/lib/kono_utils_bootstrap_view4/search_form_builder.rb +14 -0
- data/lib/kono_utils_bootstrap_view4/version.rb +3 -0
- data/lib/tasks/kono_utils_bootstrap_view4_tasks.rake +4 -0
- data/lib/templates/erb/scaffold/_form.html.erb +15 -0
- metadata +391 -0
@@ -0,0 +1,439 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Please do not make direct changes to this file!
|
4
|
+
# This generator is maintained by the community around simple_form-bootstrap:
|
5
|
+
# https://github.com/rafaelfranca/simple_form-bootstrap
|
6
|
+
# All future development, tests, and organization should happen there.
|
7
|
+
# Background history: https://github.com/plataformatec/simple_form/issues/1561
|
8
|
+
|
9
|
+
# Uncomment this and change the path if necessary to include your own
|
10
|
+
# components.
|
11
|
+
# See https://github.com/plataformatec/simple_form#custom-components
|
12
|
+
# to know more about custom components.
|
13
|
+
# Dir[Rails.root.join('lib/components/**/*.rb')].each { |f| require f }
|
14
|
+
|
15
|
+
# Use this setup block to configure all options available in SimpleForm.
|
16
|
+
SimpleForm.setup do |config|
|
17
|
+
# Default class for buttons
|
18
|
+
config.button_class = 'btn'
|
19
|
+
|
20
|
+
# Define the default class of the input wrapper of the boolean input.
|
21
|
+
config.boolean_label_class = 'form-check-label'
|
22
|
+
|
23
|
+
# How the label text should be generated altogether with the required text.
|
24
|
+
config.label_text = lambda { |label, required, explicit_label| "#{label} #{required}" }
|
25
|
+
|
26
|
+
# Define the way to render check boxes / radio buttons with labels.
|
27
|
+
config.boolean_style = :inline
|
28
|
+
|
29
|
+
# You can wrap each item in a collection of radio/check boxes with a tag
|
30
|
+
config.item_wrapper_tag = :div
|
31
|
+
|
32
|
+
# Defines if the default input wrapper class should be included in radio
|
33
|
+
# collection wrappers.
|
34
|
+
config.include_default_input_wrapper_class = false
|
35
|
+
|
36
|
+
# CSS class to add for error notification helper.
|
37
|
+
config.error_notification_class = 'alert alert-danger'
|
38
|
+
|
39
|
+
# Method used to tidy up errors. Specify any Rails Array method.
|
40
|
+
# :first lists the first message for each field.
|
41
|
+
# :to_sentence to list all errors for each field.
|
42
|
+
config.error_method = :to_sentence
|
43
|
+
|
44
|
+
# add validation classes to `input_field`
|
45
|
+
config.input_field_error_class = 'is-invalid'
|
46
|
+
config.input_field_valid_class = 'is-valid'
|
47
|
+
|
48
|
+
|
49
|
+
# vertical forms
|
50
|
+
#
|
51
|
+
# vertical default_wrapper
|
52
|
+
config.wrappers :vertical_form, tag: 'div', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
53
|
+
b.use :html5
|
54
|
+
b.use :placeholder
|
55
|
+
b.optional :maxlength
|
56
|
+
b.optional :minlength
|
57
|
+
b.optional :pattern
|
58
|
+
b.optional :min_max
|
59
|
+
b.optional :readonly
|
60
|
+
b.use :label, class: 'form-control-label'
|
61
|
+
b.use :input, class: 'form-control', error_class: 'is-invalid', valid_class: 'is-valid'
|
62
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
63
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
64
|
+
end
|
65
|
+
|
66
|
+
# vertical input for boolean
|
67
|
+
config.wrappers :vertical_boolean, tag: 'fieldset', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
68
|
+
b.use :html5
|
69
|
+
b.optional :readonly
|
70
|
+
b.wrapper :form_check_wrapper, tag: 'div', class: 'form-check' do |bb|
|
71
|
+
bb.use :input, class: 'form-check-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
72
|
+
bb.use :label, class: 'form-check-label'
|
73
|
+
bb.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
74
|
+
bb.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
# vertical input for radio buttons and check boxes
|
79
|
+
config.wrappers :vertical_collection, item_wrapper_class: 'form-check', tag: 'fieldset', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
80
|
+
b.use :html5
|
81
|
+
b.optional :readonly
|
82
|
+
b.wrapper :legend_tag, tag: 'legend', class: 'col-form-label pt-0' do |ba|
|
83
|
+
ba.use :label_text
|
84
|
+
end
|
85
|
+
b.use :input, class: 'form-check-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
86
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
87
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
88
|
+
end
|
89
|
+
|
90
|
+
# vertical input for inline radio buttons and check boxes
|
91
|
+
config.wrappers :vertical_collection_inline, item_wrapper_class: 'form-check form-check-inline', tag: 'fieldset', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
92
|
+
b.use :html5
|
93
|
+
b.optional :readonly
|
94
|
+
b.wrapper :legend_tag, tag: 'legend', class: 'col-form-label pt-0' do |ba|
|
95
|
+
ba.use :label_text
|
96
|
+
end
|
97
|
+
b.use :input, class: 'form-check-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
98
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
99
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
100
|
+
end
|
101
|
+
|
102
|
+
# vertical file input
|
103
|
+
config.wrappers :vertical_file, tag: 'div', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
104
|
+
b.use :html5
|
105
|
+
b.use :placeholder
|
106
|
+
b.optional :maxlength
|
107
|
+
b.optional :minlength
|
108
|
+
b.optional :readonly
|
109
|
+
b.use :label
|
110
|
+
b.use :input, class: 'form-control-file', error_class: 'is-invalid', valid_class: 'is-valid'
|
111
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
112
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
113
|
+
end
|
114
|
+
|
115
|
+
# vertical multi select
|
116
|
+
config.wrappers :vertical_multi_select, tag: 'div', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
117
|
+
b.use :html5
|
118
|
+
b.optional :readonly
|
119
|
+
b.use :label, class: 'form-control-label'
|
120
|
+
b.wrapper tag: 'div', class: 'd-flex flex-row justify-content-between align-items-center' do |ba|
|
121
|
+
ba.use :input, class: 'form-control mx-1', error_class: 'is-invalid', valid_class: 'is-valid'
|
122
|
+
end
|
123
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
124
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
125
|
+
end
|
126
|
+
|
127
|
+
# vertical range input
|
128
|
+
config.wrappers :vertical_range, tag: 'div', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
129
|
+
b.use :html5
|
130
|
+
b.use :placeholder
|
131
|
+
b.optional :readonly
|
132
|
+
b.optional :step
|
133
|
+
b.use :label
|
134
|
+
b.use :input, class: 'form-control-range', error_class: 'is-invalid', valid_class: 'is-valid'
|
135
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
136
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
137
|
+
end
|
138
|
+
|
139
|
+
|
140
|
+
# horizontal forms
|
141
|
+
#
|
142
|
+
# horizontal default_wrapper
|
143
|
+
config.wrappers :horizontal_form, tag: 'div', class: 'form-group row', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
144
|
+
b.use :html5
|
145
|
+
b.use :placeholder
|
146
|
+
b.optional :maxlength
|
147
|
+
b.optional :minlength
|
148
|
+
b.optional :pattern
|
149
|
+
b.optional :min_max
|
150
|
+
b.optional :readonly
|
151
|
+
b.use :label, class: 'col-sm-3 col-form-label'
|
152
|
+
b.wrapper :grid_wrapper, tag: 'div', class: 'col-sm-9' do |ba|
|
153
|
+
ba.use :input, class: 'form-control', error_class: 'is-invalid', valid_class: 'is-valid'
|
154
|
+
ba.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
155
|
+
ba.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
156
|
+
end
|
157
|
+
end
|
158
|
+
|
159
|
+
# horizontal input for boolean
|
160
|
+
config.wrappers :horizontal_boolean, tag: 'div', class: 'form-group row', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
161
|
+
b.use :html5
|
162
|
+
b.optional :readonly
|
163
|
+
b.wrapper tag: 'label', class: 'col-sm-3' do |ba|
|
164
|
+
ba.use :label_text
|
165
|
+
end
|
166
|
+
b.wrapper :grid_wrapper, tag: 'div', class: 'col-sm-9' do |wr|
|
167
|
+
wr.wrapper :form_check_wrapper, tag: 'div', class: 'form-check' do |bb|
|
168
|
+
bb.use :input, class: 'form-check-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
169
|
+
bb.use :label, class: 'form-check-label'
|
170
|
+
bb.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
171
|
+
bb.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
172
|
+
end
|
173
|
+
end
|
174
|
+
end
|
175
|
+
|
176
|
+
# horizontal input for radio buttons and check boxes
|
177
|
+
config.wrappers :horizontal_collection, item_wrapper_class: 'form-check', tag: 'div', class: 'form-group row', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
178
|
+
b.use :html5
|
179
|
+
b.optional :readonly
|
180
|
+
b.use :label, class: 'col-sm-3 form-control-label'
|
181
|
+
b.wrapper :grid_wrapper, tag: 'div', class: 'col-sm-9' do |ba|
|
182
|
+
ba.use :input, class: 'form-check-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
183
|
+
ba.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
184
|
+
ba.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
185
|
+
end
|
186
|
+
end
|
187
|
+
|
188
|
+
# horizontal input for inline radio buttons and check boxes
|
189
|
+
config.wrappers :horizontal_collection_inline, item_wrapper_class: 'form-check form-check-inline', tag: 'div', class: 'form-group row', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
190
|
+
b.use :html5
|
191
|
+
b.optional :readonly
|
192
|
+
b.use :label, class: 'col-sm-3 form-control-label'
|
193
|
+
b.wrapper :grid_wrapper, tag: 'div', class: 'col-sm-9' do |ba|
|
194
|
+
ba.use :input, class: 'form-check-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
195
|
+
ba.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
196
|
+
ba.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
197
|
+
end
|
198
|
+
end
|
199
|
+
|
200
|
+
# horizontal file input
|
201
|
+
config.wrappers :horizontal_file, tag: 'div', class: 'form-group row', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
202
|
+
b.use :html5
|
203
|
+
b.use :placeholder
|
204
|
+
b.optional :maxlength
|
205
|
+
b.optional :minlength
|
206
|
+
b.optional :readonly
|
207
|
+
b.use :label, class: 'col-sm-3 form-control-label'
|
208
|
+
b.wrapper :grid_wrapper, tag: 'div', class: 'col-sm-9' do |ba|
|
209
|
+
ba.use :input, error_class: 'is-invalid', valid_class: 'is-valid'
|
210
|
+
ba.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
211
|
+
ba.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
212
|
+
end
|
213
|
+
end
|
214
|
+
|
215
|
+
# horizontal multi select
|
216
|
+
config.wrappers :horizontal_multi_select, tag: 'div', class: 'form-group row', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
217
|
+
b.use :html5
|
218
|
+
b.optional :readonly
|
219
|
+
b.use :label, class: 'col-sm-3 control-label'
|
220
|
+
b.wrapper :grid_wrapper, tag: 'div', class: 'col-sm-9' do |ba|
|
221
|
+
ba.wrapper tag: 'div', class: 'd-flex flex-row justify-content-between align-items-center' do |bb|
|
222
|
+
bb.use :input, class: 'form-control mx-1', error_class: 'is-invalid', valid_class: 'is-valid'
|
223
|
+
end
|
224
|
+
ba.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
225
|
+
ba.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
226
|
+
end
|
227
|
+
end
|
228
|
+
|
229
|
+
# horizontal range input
|
230
|
+
config.wrappers :horizontal_range, tag: 'div', class: 'form-group row', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
231
|
+
b.use :html5
|
232
|
+
b.use :placeholder
|
233
|
+
b.optional :readonly
|
234
|
+
b.optional :step
|
235
|
+
b.use :label, class: 'col-sm-3 form-control-label'
|
236
|
+
b.wrapper :grid_wrapper, tag: 'div', class: 'col-sm-9' do |ba|
|
237
|
+
ba.use :input, class: 'form-control-range', error_class: 'is-invalid', valid_class: 'is-valid'
|
238
|
+
ba.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
239
|
+
ba.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
240
|
+
end
|
241
|
+
end
|
242
|
+
|
243
|
+
|
244
|
+
# inline forms
|
245
|
+
#
|
246
|
+
# inline default_wrapper
|
247
|
+
config.wrappers :inline_form, tag: 'span', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
248
|
+
b.use :html5
|
249
|
+
b.use :placeholder
|
250
|
+
b.optional :maxlength
|
251
|
+
b.optional :minlength
|
252
|
+
b.optional :pattern
|
253
|
+
b.optional :min_max
|
254
|
+
b.optional :readonly
|
255
|
+
b.use :label, class: 'sr-only'
|
256
|
+
|
257
|
+
b.use :input, class: 'form-control', error_class: 'is-invalid', valid_class: 'is-valid'
|
258
|
+
b.use :error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
259
|
+
b.optional :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
260
|
+
end
|
261
|
+
|
262
|
+
# inline input for boolean
|
263
|
+
config.wrappers :inline_boolean, tag: 'span', class: 'form-check flex-wrap justify-content-start mr-sm-2', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
264
|
+
b.use :html5
|
265
|
+
b.optional :readonly
|
266
|
+
b.use :input, class: 'form-check-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
267
|
+
b.use :label, class: 'form-check-label'
|
268
|
+
b.use :error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
269
|
+
b.optional :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
270
|
+
end
|
271
|
+
|
272
|
+
|
273
|
+
# bootstrap custom forms
|
274
|
+
#
|
275
|
+
# custom input for boolean
|
276
|
+
config.wrappers :custom_boolean, tag: 'fieldset', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
277
|
+
b.use :html5
|
278
|
+
b.optional :readonly
|
279
|
+
b.wrapper :form_check_wrapper, tag: 'div', class: 'custom-control custom-checkbox' do |bb|
|
280
|
+
bb.use :input, class: 'custom-control-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
281
|
+
bb.use :label, class: 'custom-control-label'
|
282
|
+
bb.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
283
|
+
bb.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
284
|
+
end
|
285
|
+
end
|
286
|
+
|
287
|
+
config.wrappers :custom_boolean_switch, tag: 'fieldset', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
288
|
+
b.use :html5
|
289
|
+
b.optional :readonly
|
290
|
+
b.wrapper :form_check_wrapper, tag: 'div', class: 'custom-control custom-checkbox-switch' do |bb|
|
291
|
+
bb.use :input, class: 'custom-control-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
292
|
+
bb.use :label, class: 'custom-control-label'
|
293
|
+
bb.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
294
|
+
bb.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
295
|
+
end
|
296
|
+
end
|
297
|
+
|
298
|
+
# custom input for radio buttons and check boxes
|
299
|
+
config.wrappers :custom_collection, item_wrapper_class: 'custom-control', tag: 'fieldset', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
300
|
+
b.use :html5
|
301
|
+
b.optional :readonly
|
302
|
+
b.wrapper :legend_tag, tag: 'legend', class: 'col-form-label pt-0' do |ba|
|
303
|
+
ba.use :label_text
|
304
|
+
end
|
305
|
+
b.use :input, class: 'custom-control-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
306
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
307
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
308
|
+
end
|
309
|
+
|
310
|
+
# custom input for inline radio buttons and check boxes
|
311
|
+
config.wrappers :custom_collection_inline, item_wrapper_class: 'custom-control custom-control-inline', tag: 'fieldset', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
312
|
+
b.use :html5
|
313
|
+
b.optional :readonly
|
314
|
+
b.wrapper :legend_tag, tag: 'legend', class: 'col-form-label pt-0' do |ba|
|
315
|
+
ba.use :label_text
|
316
|
+
end
|
317
|
+
b.use :input, class: 'custom-control-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
318
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
319
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
320
|
+
end
|
321
|
+
|
322
|
+
# custom file input
|
323
|
+
config.wrappers :custom_file, tag: 'div', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
324
|
+
b.use :html5
|
325
|
+
b.use :placeholder
|
326
|
+
b.optional :maxlength
|
327
|
+
b.optional :minlength
|
328
|
+
b.optional :readonly
|
329
|
+
b.use :label, class: 'form-control-label'
|
330
|
+
b.wrapper :custom_file_wrapper, tag: 'div', class: 'custom-file' do |ba|
|
331
|
+
ba.use :input, class: 'custom-file-input', error_class: 'is-invalid', valid_class: 'is-valid'
|
332
|
+
ba.use :label, class: 'custom-file-label'
|
333
|
+
ba.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
334
|
+
end
|
335
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
336
|
+
end
|
337
|
+
|
338
|
+
# custom multi select
|
339
|
+
config.wrappers :custom_multi_select, tag: 'div', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
340
|
+
b.use :html5
|
341
|
+
b.optional :readonly
|
342
|
+
b.use :label, class: 'form-control-label'
|
343
|
+
b.wrapper tag: 'div', class: 'd-flex flex-row justify-content-between align-items-center' do |ba|
|
344
|
+
ba.use :input, class: 'custom-select mx-1', error_class: 'is-invalid', valid_class: 'is-valid'
|
345
|
+
end
|
346
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
347
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
348
|
+
end
|
349
|
+
|
350
|
+
# custom range input
|
351
|
+
config.wrappers :custom_range, tag: 'div', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
352
|
+
b.use :html5
|
353
|
+
b.use :placeholder
|
354
|
+
b.optional :readonly
|
355
|
+
b.optional :step
|
356
|
+
b.use :label, class: 'form-control-label'
|
357
|
+
b.use :input, class: 'custom-range', error_class: 'is-invalid', valid_class: 'is-valid'
|
358
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
359
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
360
|
+
end
|
361
|
+
|
362
|
+
|
363
|
+
# Input Group - custom component
|
364
|
+
# see example app and config at https://github.com/rafaelfranca/simple_form-bootstrap
|
365
|
+
# config.wrappers :input_group, tag: 'div', class: 'form-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
366
|
+
# b.use :html5
|
367
|
+
# b.use :placeholder
|
368
|
+
# b.optional :maxlength
|
369
|
+
# b.optional :minlength
|
370
|
+
# b.optional :pattern
|
371
|
+
# b.optional :min_max
|
372
|
+
# b.optional :readonly
|
373
|
+
# b.use :label, class: 'form-control-label'
|
374
|
+
# b.wrapper :input_group_tag, tag: 'div', class: 'input-group' do |ba|
|
375
|
+
# ba.optional :prepend
|
376
|
+
# ba.use :input, class: 'form-control', error_class: 'is-invalid', valid_class: 'is-valid'
|
377
|
+
# ba.optional :append
|
378
|
+
# end
|
379
|
+
# b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback d-block' }
|
380
|
+
# b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
381
|
+
# end
|
382
|
+
|
383
|
+
|
384
|
+
# Floating Labels form
|
385
|
+
#
|
386
|
+
# floating labels default_wrapper
|
387
|
+
config.wrappers :floating_labels_form, tag: 'div', class: 'form-label-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
388
|
+
b.use :html5
|
389
|
+
b.use :placeholder
|
390
|
+
b.optional :maxlength
|
391
|
+
b.optional :minlength
|
392
|
+
b.optional :pattern
|
393
|
+
b.optional :min_max
|
394
|
+
b.optional :readonly
|
395
|
+
b.use :input, class: 'form-control', error_class: 'is-invalid', valid_class: 'is-valid'
|
396
|
+
b.use :label, class: 'form-control-label'
|
397
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
398
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
399
|
+
end
|
400
|
+
|
401
|
+
# custom multi select
|
402
|
+
config.wrappers :floating_labels_select, tag: 'div', class: 'form-label-group', error_class: 'form-group-invalid', valid_class: 'form-group-valid' do |b|
|
403
|
+
b.use :html5
|
404
|
+
b.optional :readonly
|
405
|
+
b.use :input, class: 'custom-select custom-select-lg', error_class: 'is-invalid', valid_class: 'is-valid'
|
406
|
+
b.use :label, class: 'form-control-label'
|
407
|
+
b.use :full_error, wrap_with: { tag: 'div', class: 'invalid-feedback' }
|
408
|
+
b.use :hint, wrap_with: { tag: 'small', class: 'form-text text-muted' }
|
409
|
+
end
|
410
|
+
|
411
|
+
|
412
|
+
# The default wrapper to be used by the FormBuilder.
|
413
|
+
config.default_wrapper = :vertical_form
|
414
|
+
|
415
|
+
# Custom wrappers for input types. This should be a hash containing an input
|
416
|
+
# type as key and the wrapper that will be used for all inputs with specified type.
|
417
|
+
config.wrapper_mappings = {
|
418
|
+
boolean: :vertical_boolean,
|
419
|
+
check_boxes: :vertical_collection,
|
420
|
+
date: :vertical_multi_select,
|
421
|
+
datetime: :vertical_multi_select,
|
422
|
+
file: :vertical_file,
|
423
|
+
radio_buttons: :vertical_collection,
|
424
|
+
range: :vertical_range,
|
425
|
+
time: :vertical_multi_select
|
426
|
+
}
|
427
|
+
|
428
|
+
# enable custom form wrappers
|
429
|
+
# config.wrapper_mappings = {
|
430
|
+
# boolean: :custom_boolean,
|
431
|
+
# check_boxes: :custom_collection,
|
432
|
+
# date: :custom_multi_select,
|
433
|
+
# datetime: :custom_multi_select,
|
434
|
+
# file: :custom_file,
|
435
|
+
# radio_buttons: :custom_collection,
|
436
|
+
# range: :custom_range,
|
437
|
+
# time: :custom_multi_select
|
438
|
+
# }
|
439
|
+
end
|