rails_admin 3.0.0.beta2 → 3.0.0.rc

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of rails_admin might be problematic. Click here for more details.

Files changed (250) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -2
  3. data/Rakefile +11 -0
  4. data/app/assets/javascripts/rails_admin.js +4 -4
  5. data/app/assets/stylesheets/rails_admin.scss +31 -0
  6. data/app/controllers/rails_admin/application_controller.rb +1 -1
  7. data/app/controllers/rails_admin/main_controller.rb +10 -18
  8. data/app/helpers/rails_admin/application_helper.rb +12 -13
  9. data/app/helpers/rails_admin/form_builder.rb +3 -3
  10. data/app/helpers/rails_admin/main_helper.rb +1 -1
  11. data/app/views/kaminari/ra-twitter-bootstrap/_gap.html.erb +2 -2
  12. data/app/views/kaminari/ra-twitter-bootstrap/_next_page.html.erb +4 -4
  13. data/app/views/kaminari/ra-twitter-bootstrap/_page.html.erb +4 -4
  14. data/app/views/kaminari/ra-twitter-bootstrap/_paginator.html.erb +12 -10
  15. data/app/views/kaminari/ra-twitter-bootstrap/_prev_page.html.erb +4 -4
  16. data/app/views/kaminari/ra-twitter-bootstrap/without_count/_next_page.html.erb +4 -4
  17. data/app/views/kaminari/ra-twitter-bootstrap/without_count/_paginator.html.erb +6 -4
  18. data/app/views/kaminari/ra-twitter-bootstrap/without_count/_prev_page.html.erb +4 -4
  19. data/app/views/layouts/rails_admin/_navigation.html.erb +12 -16
  20. data/app/views/layouts/rails_admin/_secondary_navigation.html.erb +8 -8
  21. data/app/views/layouts/rails_admin/_sidebar_navigation.html.erb +1 -5
  22. data/app/views/layouts/rails_admin/application.html.erb +4 -7
  23. data/app/views/layouts/rails_admin/{pjax.html.erb → content.html.erb} +7 -5
  24. data/app/views/layouts/rails_admin/modal.js.erb +1 -1
  25. data/app/views/rails_admin/main/_dashboard_history.html.erb +1 -1
  26. data/app/views/rails_admin/main/_delete_notice.html.erb +2 -2
  27. data/app/views/rails_admin/main/_form_boolean.html.erb +6 -8
  28. data/app/views/rails_admin/main/_form_colorpicker.html.erb +5 -1
  29. data/app/views/rails_admin/main/_form_datetime.html.erb +8 -7
  30. data/app/views/rails_admin/main/_form_enumeration.html.erb +5 -1
  31. data/app/views/rails_admin/main/_form_file_upload.html.erb +1 -1
  32. data/app/views/rails_admin/main/_form_filtering_multiselect.html.erb +14 -14
  33. data/app/views/rails_admin/main/_form_filtering_select.html.erb +16 -21
  34. data/app/views/rails_admin/main/_form_multiple_file_upload.html.erb +1 -1
  35. data/app/views/rails_admin/main/_form_nested_many.html.erb +4 -4
  36. data/app/views/rails_admin/main/_form_nested_one.html.erb +4 -4
  37. data/app/views/rails_admin/main/_form_polymorphic_association.html.erb +11 -6
  38. data/app/views/rails_admin/main/_submit_buttons.html.erb +8 -8
  39. data/app/views/rails_admin/main/bulk_delete.html.erb +1 -1
  40. data/app/views/rails_admin/main/dashboard.html.erb +4 -4
  41. data/app/views/rails_admin/main/delete.html.erb +1 -1
  42. data/app/views/rails_admin/main/edit.html.erb +1 -1
  43. data/app/views/rails_admin/main/export.html.erb +35 -32
  44. data/app/views/rails_admin/main/history.html.erb +16 -14
  45. data/app/views/rails_admin/main/index.html.erb +38 -35
  46. data/app/views/rails_admin/main/new.html.erb +1 -1
  47. data/config/locales/rails_admin.en.yml +0 -1
  48. data/lib/generators/rails_admin/install_generator.rb +0 -1
  49. data/lib/generators/rails_admin/templates/webpack.config.js +0 -3
  50. data/lib/rails_admin/adapters/active_record/object_extension.rb +1 -1
  51. data/lib/rails_admin/adapters/active_record/property.rb +1 -1
  52. data/lib/rails_admin/adapters/active_record.rb +7 -3
  53. data/lib/rails_admin/adapters/mongoid/property.rb +3 -3
  54. data/lib/rails_admin/adapters/mongoid.rb +2 -2
  55. data/lib/rails_admin/config/actions/base.rb +1 -6
  56. data/lib/rails_admin/config/actions/dashboard.rb +13 -9
  57. data/lib/rails_admin/config/actions/delete.rb +4 -0
  58. data/lib/rails_admin/config/actions/edit.rb +4 -0
  59. data/lib/rails_admin/config/actions/new.rb +5 -0
  60. data/lib/rails_admin/config/actions/show_in_app.rb +0 -4
  61. data/lib/rails_admin/config/fields/association.rb +6 -1
  62. data/lib/rails_admin/config/fields/base.rb +1 -1
  63. data/lib/rails_admin/config/fields/types/action_text.rb +1 -1
  64. data/lib/rails_admin/config/fields/types/date.rb +7 -0
  65. data/lib/rails_admin/config/fields/types/datetime.rb +9 -4
  66. data/lib/rails_admin/config/fields/types/has_many_association.rb +4 -0
  67. data/lib/rails_admin/config/fields/types/has_one_association.rb +4 -0
  68. data/lib/rails_admin/config/fields/types/time.rb +9 -0
  69. data/lib/rails_admin/config/has_fields.rb +4 -0
  70. data/lib/rails_admin/config/model.rb +8 -0
  71. data/lib/rails_admin/config/sections/list.rb +4 -4
  72. data/lib/rails_admin/config.rb +4 -1
  73. data/lib/rails_admin/engine.rb +2 -5
  74. data/lib/rails_admin/support/datetime.rb +50 -53
  75. data/lib/rails_admin/support/esmodule_preprocessor.rb +2 -1
  76. data/lib/rails_admin/version.rb +1 -1
  77. data/package.json +7 -5
  78. data/src/rails_admin/base.js +3 -6
  79. data/src/rails_admin/filter-box.js +36 -37
  80. data/src/rails_admin/filtering-select.js +3 -6
  81. data/src/rails_admin/i18n.js +0 -3
  82. data/src/rails_admin/nested-form-hooks.js +16 -8
  83. data/src/rails_admin/remote-form.js +18 -15
  84. data/src/rails_admin/styles/base/theming.scss +80 -155
  85. data/src/rails_admin/styles/base/variables.scss +2 -0
  86. data/src/rails_admin/styles/base.scss +8 -45
  87. data/src/rails_admin/styles/filtering-multiselect.scss +2 -2
  88. data/src/rails_admin/styles/filtering-select.scss +1 -1
  89. data/src/rails_admin/styles/widgets.scss +1 -10
  90. data/src/rails_admin/ui.js +4 -54
  91. data/src/rails_admin/widgets.js +38 -48
  92. data/vendor/assets/javascripts/rails_admin/bootstrap.js +5046 -0
  93. data/vendor/assets/javascripts/rails_admin/flatpickr-with-locales.js +10683 -0
  94. data/vendor/assets/javascripts/rails_admin/popper.js +1974 -0
  95. data/vendor/assets/stylesheets/rails_admin/bootstrap/_accordion.scss +118 -0
  96. data/vendor/assets/stylesheets/rails_admin/bootstrap/_alert.scss +57 -0
  97. data/vendor/assets/stylesheets/rails_admin/bootstrap/_badge.scss +29 -0
  98. data/vendor/assets/stylesheets/rails_admin/bootstrap/_breadcrumb.scss +28 -0
  99. data/vendor/assets/stylesheets/rails_admin/bootstrap/_button-group.scss +139 -0
  100. data/vendor/assets/stylesheets/rails_admin/bootstrap/_buttons.scss +64 -110
  101. data/vendor/assets/stylesheets/rails_admin/bootstrap/_card.scss +216 -0
  102. data/vendor/assets/stylesheets/rails_admin/bootstrap/_carousel.scss +162 -176
  103. data/vendor/assets/stylesheets/rails_admin/bootstrap/_close.scss +31 -26
  104. data/vendor/assets/stylesheets/rails_admin/bootstrap/_containers.scss +41 -0
  105. data/vendor/assets/stylesheets/rails_admin/bootstrap/_dropdown.scss +240 -0
  106. data/vendor/assets/stylesheets/rails_admin/bootstrap/_forms.scss +9 -538
  107. data/vendor/assets/stylesheets/rails_admin/bootstrap/_functions.scss +302 -0
  108. data/vendor/assets/stylesheets/rails_admin/bootstrap/_grid.scss +18 -69
  109. data/vendor/assets/stylesheets/rails_admin/bootstrap/_helpers.scss +9 -0
  110. data/vendor/assets/stylesheets/rails_admin/bootstrap/_images.scss +42 -0
  111. data/vendor/assets/stylesheets/rails_admin/bootstrap/_list-group.scss +127 -84
  112. data/vendor/assets/stylesheets/rails_admin/bootstrap/_mixins.scss +26 -22
  113. data/vendor/assets/stylesheets/rails_admin/bootstrap/_modal.scss +209 -0
  114. data/vendor/assets/stylesheets/rails_admin/bootstrap/_nav.scss +139 -0
  115. data/vendor/assets/stylesheets/rails_admin/bootstrap/_navbar.scss +218 -542
  116. data/vendor/assets/stylesheets/rails_admin/bootstrap/_offcanvas.scss +83 -0
  117. data/vendor/assets/stylesheets/rails_admin/bootstrap/_pagination.scss +46 -70
  118. data/vendor/assets/stylesheets/rails_admin/bootstrap/_placeholders.scss +51 -0
  119. data/vendor/assets/stylesheets/rails_admin/bootstrap/_popover.scss +158 -0
  120. data/vendor/assets/stylesheets/rails_admin/bootstrap/_progress.scss +48 -0
  121. data/vendor/assets/stylesheets/rails_admin/bootstrap/_reboot.scss +625 -0
  122. data/vendor/assets/stylesheets/rails_admin/bootstrap/_root.scss +54 -0
  123. data/vendor/assets/stylesheets/rails_admin/bootstrap/_spinners.scss +69 -0
  124. data/vendor/assets/stylesheets/rails_admin/bootstrap/_tables.scss +100 -178
  125. data/vendor/assets/stylesheets/rails_admin/bootstrap/_toasts.scss +51 -0
  126. data/vendor/assets/stylesheets/rails_admin/bootstrap/_tooltip.scss +97 -77
  127. data/vendor/assets/stylesheets/rails_admin/bootstrap/_transitions.scss +27 -0
  128. data/vendor/assets/stylesheets/rails_admin/bootstrap/_type.scss +54 -254
  129. data/vendor/assets/stylesheets/rails_admin/bootstrap/_utilities.scss +628 -55
  130. data/vendor/assets/stylesheets/rails_admin/bootstrap/_variables.scss +1572 -781
  131. data/vendor/assets/stylesheets/rails_admin/bootstrap/bootstrap.scss +38 -35
  132. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_floating-labels.scss +63 -0
  133. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_form-check.scss +152 -0
  134. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_form-control.scss +219 -0
  135. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_form-range.scss +91 -0
  136. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_form-select.scss +72 -0
  137. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_form-text.scss +11 -0
  138. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_input-group.scss +121 -0
  139. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_labels.scss +36 -0
  140. data/vendor/assets/stylesheets/rails_admin/bootstrap/forms/_validation.scss +12 -0
  141. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_clearfix.scss +3 -0
  142. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_colored-links.scss +12 -0
  143. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_position.scss +30 -0
  144. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_ratio.scss +26 -0
  145. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_stacks.scss +15 -0
  146. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_stretched-link.scss +15 -0
  147. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_text-truncation.scss +7 -0
  148. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_visually-hidden.scss +8 -0
  149. data/vendor/assets/stylesheets/rails_admin/bootstrap/helpers/_vr.scss +8 -0
  150. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_alert.scss +11 -0
  151. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_backdrop.scss +14 -0
  152. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_border-radius.scss +72 -12
  153. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_box-shadow.scss +18 -0
  154. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_breakpoints.scss +127 -0
  155. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_buttons.scss +113 -30
  156. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_caret.scss +64 -0
  157. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_clearfix.scss +5 -18
  158. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_color-scheme.scss +7 -0
  159. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_container.scss +9 -0
  160. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_deprecate.scss +10 -0
  161. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_forms.scss +130 -70
  162. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_gradients.scss +27 -38
  163. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_grid.scss +127 -98
  164. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_image.scss +6 -24
  165. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_list-group.scss +13 -20
  166. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_lists.scss +7 -0
  167. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_pagination.scss +24 -16
  168. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_reset-text.scss +17 -0
  169. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_resize.scss +1 -1
  170. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_table-variants.scss +21 -0
  171. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/{_text-overflow.scss → _text-truncate.scss} +2 -2
  172. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_transition.scss +26 -0
  173. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_utilities.scss +89 -0
  174. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_visually-hidden.scss +29 -0
  175. data/vendor/assets/stylesheets/rails_admin/bootstrap/utilities/_api.scss +47 -0
  176. data/vendor/assets/stylesheets/rails_admin/bootstrap/vendor/_rfs.scss +354 -0
  177. data/vendor/assets/stylesheets/rails_admin/flatpickr.css +791 -0
  178. metadata +80 -91
  179. data/app/assets/stylesheets/rails_admin.scss.erb +0 -76
  180. data/lib/generators/rails_admin/templates/environment.js +0 -6
  181. data/src/rails_admin/styles/themes/cerulean/mixins.scss +0 -0
  182. data/src/rails_admin/styles/themes/cerulean/theming.scss +0 -135
  183. data/src/rails_admin/styles/themes/cerulean/variables.scss +0 -830
  184. data/src/rails_admin/styles/themes/default/mixins.scss +0 -8
  185. data/src/rails_admin/styles/themes/default/theming.scss +0 -11
  186. data/src/rails_admin/styles/themes/default/variables.scss +0 -12
  187. data/src/rails_admin/vendor/jquery.pjax.js +0 -899
  188. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-affix.js +0 -164
  189. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-alert.js +0 -95
  190. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-button.js +0 -125
  191. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-carousel.js +0 -246
  192. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-collapse.js +0 -212
  193. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-dropdown.js +0 -165
  194. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-modal.js +0 -358
  195. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-popover.js +0 -123
  196. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-scrollspy.js +0 -172
  197. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-tab.js +0 -155
  198. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-tooltip.js +0 -677
  199. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-transition.js +0 -59
  200. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap-typeahead.js +0 -1782
  201. data/vendor/assets/javascripts/rails_admin/bootstrap/bootstrap.js +0 -13
  202. data/vendor/assets/javascripts/rails_admin/bootstrap-datetimepicker.js +0 -2611
  203. data/vendor/assets/javascripts/rails_admin/jquery.pjax.js +0 -898
  204. data/vendor/assets/javascripts/rails_admin/moment-with-locales.js +0 -18085
  205. data/vendor/assets/stylesheets/rails_admin/_bootstrap-datetimepicker.scss +0 -343
  206. data/vendor/assets/stylesheets/rails_admin/bootstrap/_alerts.scss +0 -68
  207. data/vendor/assets/stylesheets/rails_admin/bootstrap/_badges.scss +0 -57
  208. data/vendor/assets/stylesheets/rails_admin/bootstrap/_breadcrumbs.scss +0 -26
  209. data/vendor/assets/stylesheets/rails_admin/bootstrap/_button-groups.scss +0 -240
  210. data/vendor/assets/stylesheets/rails_admin/bootstrap/_code.scss +0 -68
  211. data/vendor/assets/stylesheets/rails_admin/bootstrap/_component-animations.scss +0 -35
  212. data/vendor/assets/stylesheets/rails_admin/bootstrap/_dropdowns.scss +0 -215
  213. data/vendor/assets/stylesheets/rails_admin/bootstrap/_glyphicons.scss +0 -237
  214. data/vendor/assets/stylesheets/rails_admin/bootstrap/_input-groups.scss +0 -166
  215. data/vendor/assets/stylesheets/rails_admin/bootstrap/_jumbotron.scss +0 -48
  216. data/vendor/assets/stylesheets/rails_admin/bootstrap/_labels.scss +0 -66
  217. data/vendor/assets/stylesheets/rails_admin/bootstrap/_media.scss +0 -56
  218. data/vendor/assets/stylesheets/rails_admin/bootstrap/_modals.scss +0 -150
  219. data/vendor/assets/stylesheets/rails_admin/bootstrap/_navs.scss +0 -242
  220. data/vendor/assets/stylesheets/rails_admin/bootstrap/_normalize.scss +0 -425
  221. data/vendor/assets/stylesheets/rails_admin/bootstrap/_pager.scss +0 -55
  222. data/vendor/assets/stylesheets/rails_admin/bootstrap/_panels.scss +0 -243
  223. data/vendor/assets/stylesheets/rails_admin/bootstrap/_popovers.scss +0 -133
  224. data/vendor/assets/stylesheets/rails_admin/bootstrap/_print.scss +0 -101
  225. data/vendor/assets/stylesheets/rails_admin/bootstrap/_progress-bars.scss +0 -105
  226. data/vendor/assets/stylesheets/rails_admin/bootstrap/_responsive-embed.scss +0 -34
  227. data/vendor/assets/stylesheets/rails_admin/bootstrap/_responsive-utilities.scss +0 -174
  228. data/vendor/assets/stylesheets/rails_admin/bootstrap/_scaffolding.scss +0 -150
  229. data/vendor/assets/stylesheets/rails_admin/bootstrap/_theme.scss +0 -258
  230. data/vendor/assets/stylesheets/rails_admin/bootstrap/_thumbnails.scss +0 -38
  231. data/vendor/assets/stylesheets/rails_admin/bootstrap/_wells.scss +0 -29
  232. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_alerts.scss +0 -14
  233. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_background-variant.scss +0 -11
  234. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_center-block.scss +0 -7
  235. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_grid-framework.scss +0 -81
  236. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_hide-text.scss +0 -21
  237. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_labels.scss +0 -12
  238. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_nav-divider.scss +0 -10
  239. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_nav-vertical-align.scss +0 -9
  240. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_opacity.scss +0 -8
  241. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_panels.scss +0 -24
  242. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_progress-bar.scss +0 -10
  243. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_reset-filter.scss +0 -8
  244. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_responsive-visibility.scss +0 -21
  245. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_size.scss +0 -10
  246. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_tab-focus.scss +0 -9
  247. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_table-row.scss +0 -28
  248. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_text-emphasis.scss +0 -11
  249. data/vendor/assets/stylesheets/rails_admin/bootstrap/mixins/_vendor-prefixes.scss +0 -219
  250. data/vendor/assets/stylesheets/rails_admin/bootstrap-datetimepicker-build.scss +0 -16
@@ -1 +1,5 @@
1
- <%= form.send field.view_helper, field.method_name, field.html_attributes.reverse_merge({class: 'form-control', value: field.form_value}) %>
1
+ <div class="row">
2
+ <div class="col-sm-2">
3
+ <%= form.send field.view_helper, field.method_name, field.html_attributes.reverse_merge({class: 'form-control', value: field.form_value}) %>
4
+ </div>
5
+ </div>
@@ -1,9 +1,10 @@
1
- <div class="form-inline">
2
- <div class="input-group">
3
- <%= form.hidden_field(field.method_name, id: nil, value: field.form_value) %>
4
- <%= form.text_field field.method_name, field.html_attributes.reverse_merge({class: 'form-control', data: {datetimepicker: true, options: field.datepicker_options.to_json}, name: nil, value: nil}) %>
5
- <%= form.label(field.method_name, class: 'input-group-addon') do %>
6
- <i class="fa fa-fw fa-calendar"></i>
7
- <% end %>
1
+ <div class="row">
2
+ <div class="col-sm-4">
3
+ <div class="input-group">
4
+ <%= form.text_field field.method_name, field.html_attributes.reverse_merge({autocomplete: 'off', class: 'form-control', data: {datetimepicker: true, options: field.datepicker_options.to_json}, value: field.form_value}) %>
5
+ <%= form.label(field.method_name, class: 'input-group-text') do %>
6
+ <i class="fa fa-fw fa-calendar"></i>
7
+ <% end %>
8
+ </div>
8
9
  </div>
9
10
  </div>
@@ -1,5 +1,9 @@
1
1
  <% unless field.multiple? %>
2
- <%= form.select field.method_name, field.enum, { include_blank: true }.reverse_merge({ selected: field.form_value }), field.html_attributes.reverse_merge({ data: { enumeration: true }, placeholder: t('admin.misc.search') }) %>
2
+ <div class="row">
3
+ <div class="col-sm-4">
4
+ <%= form.select field.method_name, field.enum, { include_blank: true }.reverse_merge({ selected: field.form_value }), field.html_attributes.reverse_merge({ data: { enumeration: true }, placeholder: t('admin.misc.search') }) %>
5
+ </div>
6
+ </div>
3
7
  <% else %>
4
8
  <%
5
9
  js_data = {
@@ -2,7 +2,7 @@
2
2
  <% if field.cache_method %>
3
3
  <%= form.hidden_field(field.cache_method, value: field.cache_value) %>
4
4
  <% end %>
5
- <div class="toggle" style="<%= ('display:none;' if file && field.delete_method && form.object.send(field.delete_method) == '1') %>">
5
+ <div class="toggle mb-2" style="<%= ('display:none;' if file && field.delete_method && form.object.send(field.delete_method) == '1') %>">
6
6
  <% if value = field.pretty_value %>
7
7
  <%= value %>
8
8
  <% end %>
@@ -1,13 +1,8 @@
1
1
  <%
2
- related_id = params[:associations] && params[:associations][field.name.to_s]
3
2
  config = field.associated_model_config
4
3
  source_abstract_model = RailsAdmin.config(form.object.class).abstract_model
5
4
 
6
- if form.object.new_record? && related_id.present? && related_id != 'new'
7
- selected = [config.abstract_model.get(related_id)]
8
- else
9
- selected = form.object.send(field.name)
10
- end
5
+ selected = form.object.send(field.name)
11
6
  selected_ids = selected.map{|s| s.send(field.associated_primary_key)}
12
7
 
13
8
  current_action = params[:action].in?(['create', 'new']) ? 'create' : 'update'
@@ -39,11 +34,16 @@
39
34
  }
40
35
  }
41
36
  %>
42
- <input name="<%= form.dom_name(field) %>" type="hidden"></input>
43
- <% selected_ids = (hdv = field.form_default_value).nil? ? selected_ids : hdv %>
44
- <%= form.select field.method_name, collection, { selected: selected_ids, object: form.object }, field.html_attributes.reverse_merge({data: { filteringmultiselect: true, options: js_data.to_json }, multiple: true}) %>
45
- <% if authorized?(:new, config.abstract_model) && field.inline_add %>
46
- <% path_hash = { model_name: config.abstract_model.to_param, modal: true } %>
47
- <% path_hash.merge!({ associations: { field.inverse_of => (form.object.persisted? ? form.object.id : 'new') } }) if field.inverse_of %>
48
- <%= link_to "<i class=\"fas fa-plus\"></i> ".html_safe + wording_for(:link, :new, config.abstract_model), '#', data: { link: new_path(path_hash) }, class: "create btn btn-info", style: 'margin-left:10px' %>
49
- <% end %>
37
+ <div class="row">
38
+ <div class="col-auto">
39
+ <input name="<%= form.dom_name(field) %>" type="hidden" />
40
+ <% selected_ids = (hdv = field.form_default_value).nil? ? selected_ids : hdv %>
41
+ <%= form.select field.method_name, collection, { selected: selected_ids, object: form.object }, field.html_attributes.reverse_merge({data: { filteringmultiselect: true, options: js_data.to_json }, multiple: true}) %>
42
+ </div>
43
+ <% if authorized?(:new, config.abstract_model) && field.inline_add %>
44
+ <div class="col-sm-4 modal-actions">
45
+ <% path_hash = { model_name: config.abstract_model.to_param, modal: true }.merge!(field.associated_prepopulate_params) %>
46
+ <%= link_to "<i class=\"fas fa-plus\"></i> ".html_safe + wording_for(:link, :new, config.abstract_model), '#', data: { link: new_path(path_hash) }, class: "create btn btn-info", style: 'margin-left:10px' %>
47
+ </div>
48
+ <% end %>
49
+ </div>
@@ -1,24 +1,14 @@
1
1
  <%
2
2
  config = field.associated_model_config
3
- related_id = params[:associations] && params[:associations][field.name.to_s]
4
3
  source_abstract_model = RailsAdmin.config(form.object.class).abstract_model
5
4
 
6
- if form.object.new_record? && related_id.present? && related_id != 'new'
7
- selected = config.abstract_model.get(related_id)
8
- selected_id = selected.send(field.associated_primary_key)
9
- selected_name = selected.send(field.associated_object_label_method)
10
- else
11
- selected_id = field.selected_id
12
- selected_name = field.formatted_value
13
- end
14
-
15
5
  current_action = params[:action].in?(['create', 'new']) ? 'create' : 'update'
16
6
 
17
7
  edit_url = authorized?(:edit, config.abstract_model) ? edit_path(model_name: config.abstract_model.to_param, modal: true, id: '__ID__') : ''
18
8
 
19
9
  xhr = !field.associated_collection_cache_all
20
10
 
21
- collection = xhr ? [[selected_name, selected_id]] : controller.list_entries(config, :index, field.associated_collection_scope, false).map { |o| [o.send(field.associated_object_label_method), o.send(field.associated_primary_key)] }
11
+ collection = xhr ? [[field.formatted_value, field.selected_id]] : controller.list_entries(config, :index, field.associated_collection_scope, false).map { |o| [o.send(field.associated_object_label_method), o.send(field.associated_primary_key)] }
22
12
 
23
13
  js_data = {
24
14
  xhr: xhr,
@@ -26,13 +16,18 @@
26
16
  }
27
17
  %>
28
18
 
29
- <% selected_id = (hdv = field.form_default_value).nil? ? selected_id : hdv %>
30
- <%= form.select field.method_name, collection, { selected: selected_id, include_blank: true }, field.html_attributes.reverse_merge({ data: { filteringselect: true, options: js_data.to_json }, placeholder: t('admin.misc.search'), style: "float: left" }) %>
31
- <% if authorized?(:new, config.abstract_model) && field.inline_add %>
32
- <% path_hash = { model_name: config.abstract_model.to_param, modal: true } %>
33
- <% path_hash.merge!({ associations: { field.inverse_of => (form.object.persisted? ? form.object.id : 'new') } }) if field.inverse_of %>
34
- <%= link_to "<i class=\"fas fa-plus\"></i> ".html_safe + wording_for(:link, :new, config.abstract_model), '#', data: { link: new_path(path_hash) }, class: "btn btn-info create", style: 'margin-left:10px' %>
35
- <% end %>
36
- <% if edit_url.present? && field.inline_edit %>
37
- <%= link_to "<i class=\"fas fa-pencil-alt\"></i> ".html_safe + wording_for(:link, :edit, config.abstract_model), '#', data: { link: edit_url }, class: "btn btn-info update #{field.value.nil? && 'disabled'}", style: 'margin-left:10px' %>
38
- <% end %>
19
+ <div class="row">
20
+ <div class="col-sm-4">
21
+ <% selected_id = (hdv = field.form_default_value).nil? ? field.selected_id : hdv %>
22
+ <%= form.select field.method_name, collection, { selected: selected_id, include_blank: true }, field.html_attributes.reverse_merge({ data: { filteringselect: true, options: js_data.to_json }, placeholder: t('admin.misc.search') }) %>
23
+ </div>
24
+ <div class="col-sm-8 mt-2 mt-md-0 modal-actions">
25
+ <% if authorized?(:new, config.abstract_model) && field.inline_add %>
26
+ <% path_hash = { model_name: config.abstract_model.to_param, modal: true }.merge!(field.associated_prepopulate_params) %>
27
+ <%= link_to "<i class=\"fas fa-plus\"></i> ".html_safe + wording_for(:link, :new, config.abstract_model), '#', data: { link: new_path(path_hash) }, class: "btn btn-info create" %>
28
+ <% end %>
29
+ <% if edit_url.present? && field.inline_edit %>
30
+ <%= link_to "<i class=\"fas fa-pencil-alt\"></i> ".html_safe + wording_for(:link, :edit, config.abstract_model), '#', data: { link: edit_url }, class: "btn btn-info update ms-2#{' disabled' if field.value.nil?}" %>
31
+ <% end %>
32
+ </div>
33
+ </div>
@@ -1,5 +1,5 @@
1
1
  <% field.attachments.each_with_index do |attachment, i| %>
2
- <div class="<%= field.reorderable? ? 'sortables' : '' %> toggle">
2
+ <div class="<%= field.reorderable? ? 'sortables' : '' %> toggle mb-2">
3
3
  <%= attachment.pretty_value %>
4
4
  <% if field.delete_method || field.keep_method %>
5
5
  <a class="btn btn-info btn-remove-image" data-toggle="button" href="#" role="button">
@@ -1,6 +1,6 @@
1
1
  <div class="controls col-sm-10" data-nestedmany="true">
2
2
  <div class="btn-group">
3
- <a class="<%= (field.active? ? 'active' : '') %> btn btn-info toggler" data-target="<%= form.jquery_namespace(field) %> > .tab-content, <%= form.jquery_namespace(field) %> > .controls > .nav" data-toggle="button">
3
+ <a class="<%= (field.active? ? 'active' : '') %> btn btn-info toggler" data-bs-target="<%= form.jquery_namespace(field) %> .collapse" data-bs-toggle="collapse" role="button">
4
4
  <i class="fas"></i>
5
5
  </a>
6
6
  <% unless field.nested_form[:update_only] || !field.inline_add %>
@@ -9,12 +9,12 @@
9
9
  </div>
10
10
  <%= form.errors_for(field) %>
11
11
  <%= form.help_for(field) %>
12
- <ul class="nav nav-tabs"></ul>
12
+ <ul class="nav nav-tabs collapse"></ul>
13
13
  </div>
14
- <div class="tab-content">
14
+ <div class="tab-content collapse">
15
15
  <%= form.fields_for field.name do |nested_form| %>
16
16
  <% if field.nested_form[:allow_destroy] || nested_form.options[:child_index] == "new_#{field.name}" %>
17
- <%= nested_form.link_to_remove '<span class="btn btn-small btn-danger"><i class="fas fa-trash"></i></span>'.html_safe %>
17
+ <%= nested_form.link_to_remove '<span class="btn btn-danger"><i class="fas fa-trash"></i></span>'.html_safe %>
18
18
  <% end %>
19
19
  <%= nested_form.generate({action: :nested, model_config: field.associated_model_config, nested_in: field }) %>
20
20
  <% end %>
@@ -1,7 +1,7 @@
1
1
  <div class="controls col-sm-10" data-nestedone="true">
2
- <ul class="nav" style="margin-bottom:0px; display:none"></ul>
2
+ <ul class="nav collapse"></ul>
3
3
  <div class="btn-group">
4
- <a class="<%= (field.active? ? 'active' : '') %> btn btn-info toggler" data-target="<%= form.jquery_namespace(field) %> > .tab-content">
4
+ <a class="<%= (field.active? ? 'active' : '') %> btn btn-info toggler" data-bs-target="<%= form.jquery_namespace(field) %> .collapse" data-bs-toggle="collapse" role="button">
5
5
  <i class="fas"></i>
6
6
  </a>
7
7
  <% unless field.nested_form[:update_only] || !field.inline_add %>
@@ -11,10 +11,10 @@
11
11
  <%= form.errors_for(field) %>
12
12
  <%= form.help_for(field) %>
13
13
  </div>
14
- <div class="tab-content">
14
+ <div class="tab-content collapse">
15
15
  <%= form.fields_for field.name do |nested_form| %>
16
16
  <% if field.nested_form[:allow_destroy] %>
17
- <%= nested_form.link_to_remove '<span class="btn btn-small btn-danger"><i class="fas fa-trash"></i></span>'.html_safe %>
17
+ <%= nested_form.link_to_remove '<span class="btn btn-danger"><i class="fas fa-trash"></i></span>'.html_safe %>
18
18
  <% end %>
19
19
  <%= nested_form.generate({action: :nested, model_config: field.associated_model_config, nested_in: field }) %>
20
20
  <% end %>
@@ -18,10 +18,15 @@
18
18
  })
19
19
  end
20
20
  %>
21
- <div class="form-inline">
22
- <% js_data.each do |model, value| %>
23
- <div data-options="<%= value.to_json %>" id="<%= model %>-js-options"></div>
24
- <% end %>
25
- <%= form.select type_column, type_collection, {include_blank: true, selected: selected_type}, class: "form-control", id: column_type_dom_id, data: { polymorphic: true, urls: field.polymorphic_type_urls.to_json }, style: "float: left; margin-right: 10px;" %>
26
- <%= form.select field.method_name, collection, {include_blank: true, selected: selected.try(:id)}, class: "form-control", data: { filteringselect: true, options: js_data[selected_type.try(:downcase)] || default_options }, placeholder: 'Search' %>
21
+
22
+ <div class="row">
23
+ <div class="col-sm-3">
24
+ <% js_data.each do |model, value| %>
25
+ <div data-options="<%= value.to_json %>" id="<%= model %>-js-options"></div>
26
+ <% end %>
27
+ <%= form.select type_column, type_collection, {include_blank: true, selected: selected_type}, class: "form-select", id: column_type_dom_id, data: { polymorphic: true, urls: field.polymorphic_type_urls.to_json }, style: "float: left; margin-right: 10px;" %>
28
+ </div>
29
+ <div class="col-sm-4">
30
+ <%= form.select field.method_name, collection, {include_blank: true, selected: selected.try(:id)}, class: "form-control", data: { filteringselect: true, options: js_data[selected_type.try(:downcase)] || default_options }, placeholder: 'Search' %>
31
+ </div>
27
32
  </div>
@@ -1,22 +1,22 @@
1
- <div class="form-group form-actions">
2
- <div class="col-sm-offset-2 col-sm-10">
3
- <input name="return_to" type="<%= :hidden %>" value="<%= (params[:return_to].presence || request.referer) %>"></input>
4
- <button class="btn btn-primary" data-disable-with="<%= t("admin.form.save") %>" name="_save" type="submit">
1
+ <div class="form-actions row justify-content-end my-3">
2
+ <div class="col-sm-10">
3
+ <input name="return_to" type="<%= :hidden %>" value="<%= (params[:return_to].presence || request.referer) %>" />
4
+ <button class="btn btn-primary" data-disable-with="<%= t("admin.form.save") %>" name="_save" type="submit"<%= ' disabled' unless @action.enabled? %>>
5
5
  <i class="fas fa-check"></i>
6
6
  <%= t("admin.form.save") %>
7
7
  </button>
8
8
  <span class="extra_buttons">
9
- <% if authorized? :new, @abstract_model %>
9
+ <% if @action.enabled? && authorized?(:new, @abstract_model) %>
10
10
  <button class="btn btn-info" data-disable-with="<%= t("admin.form.save_and_add_another") %>" name="_add_another" type="submit">
11
11
  <%= t("admin.form.save_and_add_another") %>
12
12
  </button>
13
13
  <% end %>
14
- <% if authorized? :edit, @abstract_model %>
15
- <button class="btn btn-info" data-disable-with="<%= t("admin.form.save_and_edit") %>" name="_add_edit" type="submit">
14
+ <% if @action.enabled? && authorized?(:edit, @abstract_model) %>
15
+ <button class="btn btn-info" data-disable-with="<%= t("admin.form.save_and_edit") %>" name="_add_edit" type="submit"<%= ' disabled' unless @action.enabled? %>>
16
16
  <%= t("admin.form.save_and_edit") %>
17
17
  </button>
18
18
  <% end %>
19
- <button class="btn btn-default" data-disable-with="<%= t("admin.form.cancel") %>" formnovalidate="<%= true %>" name="_continue" type="submit">
19
+ <button class="btn btn-light" data-disable-with="<%= t("admin.form.cancel") %>" formnovalidate="<%= true %>" name="_continue" type="submit">
20
20
  <i class="fas fa-times"></i>
21
21
  <%= t("admin.form.cancel") %>
22
22
  </button>
@@ -6,7 +6,7 @@
6
6
  </ul>
7
7
  <%= form_tag bulk_delete_path(model_name: @abstract_model.to_param, bulk_ids: @objects.map(&:id)), method: :delete do %>
8
8
  <div class="form-actions">
9
- <input name="return_to" type="<%= :hidden %>" value="<%= (params[:return_to].presence || request.referer) %>"></input>
9
+ <input name="return_to" type="<%= :hidden %>" value="<%= (params[:return_to].presence || request.referer) %>" />
10
10
  <button class="btn btn-danger" data-disable-with="<%= t("admin.form.confirmation") %>" type="submit">
11
11
  <i class="fas fa-check"></i>
12
12
  <%= t("admin.form.confirmation") %>
@@ -24,7 +24,7 @@
24
24
  <% active = last_created.try(:today?) %>
25
25
  <td>
26
26
  <span class="show">
27
- <%= link_to abstract_model.config.label_plural, index_path, class: 'pjax' %>
27
+ <%= link_to abstract_model.config.label_plural, index_path %>
28
28
  </span>
29
29
  </td>
30
30
  <td>
@@ -35,8 +35,8 @@
35
35
  <td>
36
36
  <% count = @count[abstract_model.model.name] %>
37
37
  <% percent = count > 0 ? (@max <= 1 ? count : ((Math.log(count+1) * 100.0) / Math.log(@max+1)).to_i) : -1 %>
38
- <div class="progress-<%= get_indicator(percent) %> <%= active && 'active progress-striped' %> progress" style="margin-bottom:0px">
39
- <div class="progress-bar-<%= get_indicator(percent) %> progress-bar animate-width-to" data-animate-length="<%= ([1.0, percent].max.to_i * 20) %>" data-animate-width-to="<%= [2.0, percent].max.to_i %>%" style="width:2%">
38
+ <div class="<%= active ? 'active progress-bar-striped ' : '' %>progress" style="margin-bottom:0px">
39
+ <div class="bg-<%= get_indicator(percent) %> progress-bar animate-width-to" data-animate-length="<%= ([1.0, percent].max.to_i * 20) %>" data-animate-width-to="<%= [2.0, percent].max.to_i %>%" style="width:2%">
40
40
  <%= @count[abstract_model.model.name] %>
41
41
  </div>
42
42
  </div>
@@ -52,7 +52,7 @@
52
52
  </tbody>
53
53
  </table>
54
54
  <% end %>
55
- <% if @auditing_adapter && authorized?(:history_index) %>
55
+ <% if @history && authorized?(:history_index) %>
56
56
  <div class="block" id="block-tables">
57
57
  <div class="content">
58
58
  <h2>
@@ -7,7 +7,7 @@
7
7
  <%= render partial: "delete_notice", object: @object %>
8
8
  </ul>
9
9
  <%= form_for(@object, url: delete_path(model_name: @abstract_model.to_param, id: @object.id), html: {method: "delete"}) do %>
10
- <input name="return_to" type="<%= :hidden %>" value="<%= (params[:return_to].presence || request.referer) %>"></input>
10
+ <input name="return_to" type="<%= :hidden %>" value="<%= (params[:return_to].presence || request.referer) %>" />
11
11
  <div class="form-actions">
12
12
  <button class="btn btn-danger" data-disable-with="<%= t("admin.form.confirmation") %>" type="submit">
13
13
  <i class="fas fa-check"></i>
@@ -1,3 +1,3 @@
1
- <%= rails_admin_form_for @object, url: edit_path(@abstract_model, @object.id), as: @abstract_model.param_key, html: { method: "put", multipart: true, class: "form-horizontal denser", data: { title: @page_name } } do |form| %>
1
+ <%= rails_admin_form_for @object, url: edit_path(@abstract_model, @object.id), as: @abstract_model.param_key, html: { method: "put", multipart: true, class: "main", data: { title: @page_name } } do |form| %>
2
2
  <%= form.generate action: :update %>
3
3
  <% end %>
@@ -1,8 +1,8 @@
1
1
  <% params = request.params.except(:action, :controller, :utf8, :page, :per_page, :format, :authenticity_token) %>
2
2
  <% visible_fields = @model_config.export.with(view: self, object: @abstract_model.model.new, controller: self.controller).visible_fields %>
3
- <%= form_tag export_path(params.merge(all: true)), method: 'post', class: 'form-horizontal' do %>
4
- <input name="send_data" type="hidden" value="true">/</input>
5
- <fieldset id="fields_to_export">
3
+ <%= form_tag export_path(params.merge(all: true)), method: 'post', class: "main" do %>
4
+ <input name="send_data" type="hidden" value="true" />
5
+ <fieldset id="fields_to_export" class="mb-3">
6
6
  <legend>
7
7
  <i class="fas fa-chevron-down"></i>
8
8
  <%= t('admin.export.select') %>
@@ -19,18 +19,18 @@
19
19
  </div>
20
20
  </div>
21
21
  </div>
22
- <div class="form-group control-group">
22
+ <div class="control-group row">
23
23
  <div class="col-sm-12">
24
- <div class="well well-sm reverse-selection" rel="tooltip" style="margin: 0; cursor: pointer;" title="<%= t('admin.export.click_to_reverse_selection') %>">
25
- <b>
26
- <%= t('admin.export.fields_from', name: @model_config.label_plural.downcase) %>
27
- </b>
24
+ <div class="card bg-light my-2 reverse-selection" rel="tooltip" role="button" title="<%= t('admin.export.click_to_reverse_selection') %>">
25
+ <div class="card-body p-2">
26
+ <b><%= t('admin.export.fields_from', name: @model_config.label_plural.downcase) %></b>
27
+ </div>
28
28
  </div>
29
29
  <div class="controls">
30
30
  <div class="row">
31
31
  <% visible_fields.select{ |f| !f.association? || f.association.polymorphic? }.each do |field| %>
32
32
  <% list = field.virtual? ? 'methods' : 'only' %>
33
- <div class="checkbox col-sm-3">
33
+ <div class="checkbox col-sm-3 my-1">
34
34
  <% if field.association? && field.association.polymorphic? %>
35
35
  <label for="schema_<%= list %>_<%= field.method_name %>">
36
36
  <%= check_box_tag "schema[#{list}][]", field.method_name, true, { id: "schema_#{list}_#{field.method_name}" } %>
@@ -55,18 +55,18 @@
55
55
  </div>
56
56
  <% visible_fields.select{ |f| f.association? && !f.association.polymorphic? }.each do |field| %>
57
57
  <% fields = field.associated_model_config.export.with(controller: self.controller, view: self, object: (associated_model = field.associated_model_config.abstract_model.model).new).visible_fields.select{ |f| !f.association? } %>
58
- <div class="form-group control-group">
58
+ <div class="control-group row">
59
59
  <div class="col-sm-12">
60
- <div class="well well-sm reverse-selection" rel="tooltip" style="margin: 0; cursor: pointer;" title="<%= t('admin.export.click_to_reverse_selection') %>">
61
- <b>
62
- <%= t('admin.export.fields_from_associated', name: field.label.downcase) %>
63
- </b>
60
+ <div class="card bg-light my-2 reverse-selection" rel="tooltip" role="button" title="<%= t('admin.export.click_to_reverse_selection') %>">
61
+ <div class="card-body p-2">
62
+ <b><%= t('admin.export.fields_from_associated', name: field.label.downcase) %></b>
63
+ </div>
64
64
  </div>
65
65
  <div class="controls">
66
66
  <div class="row">
67
67
  <% fields.each do |associated_model_field| %>
68
68
  <% list = associated_model_field.virtual? ? 'methods' : 'only' %>
69
- <div class="checkbox col-sm-3">
69
+ <div class="checkbox col-sm-3 my-1">
70
70
  <label for="schema_include_<%= field.name %>_<%= list %>_<%= associated_model_field.name %>">
71
71
  <%= check_box_tag "schema[include][#{field.name}][#{list}][]", associated_model_field.name, true, { id: "schema_include_#{field.name}_#{list}_#{associated_model_field.name}" } %>
72
72
  <%= associated_model_field.label %>
@@ -84,49 +84,52 @@
84
84
  <i class="fas fa-chevron-down"></i>
85
85
  <%= t('admin.export.options_for', name: 'csv') %>
86
86
  </legend>
87
- <div class="form-group control-group">
87
+ <div class="control-group row">
88
88
  <% guessed_encoding = @abstract_model.encoding %>
89
- <label class="col-sm-2 control-label" for="csv_options_encoding_to">
89
+ <label class="col-sm-2 col-form-label text-md-end" for="csv_options_encoding_to">
90
90
  <%= t('admin.export.csv.encoding_to') %>
91
91
  </label>
92
92
  <div class="col-sm-10 controls">
93
- <% # from http://books.google.com/support/partner/bin/answer.py?answer=30990 : %>
94
- <%= select_tag 'csv_options[encoding_to]', options_for_select(Encoding.name_list.sort), include_blank: true, placeholder: t('admin.misc.search'), :'data-enumeration' => true %>
95
- <p class="help-block">
93
+ <div class="w-50">
94
+ <%= select_tag 'csv_options[encoding_to]', options_for_select(Encoding.name_list.sort), include_blank: true, placeholder: t('admin.misc.search'), :'data-enumeration' => true %>
95
+ </div>
96
+ <p class="form-text">
96
97
  <%= t('admin.export.csv.encoding_to_help', name: guessed_encoding) %>
97
98
  </p>
98
99
  </div>
99
100
  </div>
100
- <div class="form-group control-group">
101
- <label class="col-sm-2 control-label" for="csv_options_skip_header">
101
+ <div class="control-group row">
102
+ <label class="col-sm-2 col-form-label text-md-end" for="csv_options_skip_header">
102
103
  <%= t('admin.export.csv.skip_header') %>
103
104
  </label>
104
105
  <div class="col-sm-10 controls">
105
- <div class="checkbox">
106
- <label style="display: block;">
106
+ <div class="col-form-label">
107
+ <label>
107
108
  <%= check_box_tag 'csv_options[skip_header]', 'true' %>
108
109
  </label>
109
110
  </div>
110
- <p class="help-block">
111
+ <p class="form-text">
111
112
  <%= t('admin.export.csv.skip_header_help') %>
112
113
  </p>
113
114
  </div>
114
115
  </div>
115
- <div class="form-group control-group">
116
- <label class="col-sm-2 control-label" for="csv_options_generator_col_sep">
116
+ <div class="control-group row">
117
+ <label class="col-sm-2 col-form-label text-md-end" for="csv_options_generator_col_sep">
117
118
  <%= t('admin.export.csv.col_sep') %>
118
119
  </label>
119
120
  <div class="col-sm-10 controls">
120
- <%= select_tag 'csv_options[generator][col_sep]', options_for_select({ '' => t('admin.export.csv.default_col_sep'), "<comma> ','" => ',', "<semicolon> ';'" => ';', '<tabs>' => "'\t'" }), placeholder: t('admin.misc.search'), :'data-enumeration' => true %>
121
- <p class="help-block">
121
+ <div class="w-50">
122
+ <%= select_tag 'csv_options[generator][col_sep]', options_for_select({ '' => t('admin.export.csv.default_col_sep'), "<comma> ','" => ',', "<semicolon> ';'" => ';', '<tabs>' => "'\t'" }), placeholder: t('admin.misc.search'), :'data-enumeration' => true %>
123
+ </div>
124
+ <p class="form-text">
122
125
  <%= t('admin.export.csv.col_sep_help', value: t('admin.export.csv.default_col_sep')) %>
123
126
  </p>
124
127
  </div>
125
128
  </div>
126
129
  </fieldset>
127
- <div class="form-group form-actions">
130
+ <div class="form-actions row justify-content-end mb-3">
128
131
  <div class="col-sm-offset-2 col-sm-10">
129
- <input name="return_to" type="<%= :hidden %>" value="<%= (params[:return_to].presence || request.referer) %>"></input>
132
+ <input name="return_to" type="<%= :hidden %>" value="<%= (params[:return_to].presence || request.referer) %>" />
130
133
  <button class="btn btn-primary" name="csv" type="submit">
131
134
  <i class="fas fa-check"></i>
132
135
  <%= t("admin.export.confirmation", name: 'csv') %>
@@ -137,7 +140,7 @@
137
140
  <button class="btn btn-info" name="xml" type="submit">
138
141
  <%= t("admin.export.confirmation", name: 'xml') %>
139
142
  </button>
140
- <button class="btn" name="_continue" type="submit">
143
+ <button class="btn btn-light" name="_continue" type="submit">
141
144
  <i class="fas fa-times"></i>
142
145
  <%= t("admin.form.cancel") %>
143
146
  </button>
@@ -4,16 +4,18 @@
4
4
  <% sort = params[:sort] %>
5
5
  <% sort_reverse = params[:sort_reverse] %>
6
6
  <% path_method = params[:id] ? "history_show_path" : "history_index_path" %>
7
- <%= form_tag("", method: "get", class: "search pjax-form form-inline") do %>
8
- <div class="well">
9
- <div class="input-group">
10
- <input class="input-small form-control input-small" name="query" placeholder="<%= t("admin.misc.filter") %>" type="search" value="<%= query %>"></input>
11
- <span class="input-group-btn">
12
- <button class="btn btn-primary" data-disable-with="<%= '<i class="fas fa-sync"></i> '.html_safe + t('admin.misc.refresh') %>" type="submit">
13
- <i class="fas fa-sync"></i>
14
- <%= t("admin.misc.refresh") %>
15
- </button>
16
- </span>
7
+ <%= form_tag("", method: "get", class: "search form-inline") do %>
8
+ <div class="card mb-3 p-3 bg-light">
9
+ <div class="row">
10
+ <div class="col-sm-6">
11
+ <div class="input-group">
12
+ <input class="form-control" name="query" placeholder="<%= t("admin.misc.filter") %>" type="search" value="<%= query %>" />
13
+ <button class="btn btn-primary" data-disable-with="<%= '<i class="fas fa-sync"></i> ' + t('admin.misc.refresh') %>" type="submit">
14
+ <i class="fas fa-sync"></i>
15
+ <%= t("admin.misc.refresh") %>
16
+ </button>
17
+ </div>
18
+ </div>
17
19
  </div>
18
20
  </div>
19
21
  <% end %>
@@ -30,7 +32,7 @@
30
32
  <% selected = (sort == property_name) %>
31
33
  <% sort_direction = (sort_reverse ? "headerSortUp" : "headerSortDown" if selected) %>
32
34
  <% sort_location = send(path_method, params.except("sort_reverse").merge(model_name: @abstract_model.to_param, sort: property_name).merge(selected && sort_reverse != "true" ? {sort_reverse: "true"} : {})) %>
33
- <th class="header pjax <%= column[:css_class] %> <%= sort_direction if selected %>" data-href="<%= sort_location %>">
35
+ <th class="header <%= column[:css_class] %> <%= sort_direction if selected %>">
34
36
  <%= column[:link_text] %>
35
37
  </th>
36
38
  <% end %>
@@ -52,7 +54,7 @@
52
54
  <% label = o.send(@abstract_model.config.object_label_method) %>
53
55
  <% if show_action = action(:show, @abstract_model, o) %>
54
56
  <td>
55
- <%= link_to(label, url_for(action: show_action.action_name, model_name: @abstract_model.to_param, id: o.id), class: 'pjax') %>
57
+ <%= link_to(label, url_for(action: show_action.action_name, model_name: @abstract_model.to_param, id: o.id)) %>
56
58
  </td>
57
59
  <% else %>
58
60
  <td>
@@ -73,6 +75,6 @@
73
75
  </tbody>
74
76
  </table>
75
77
  <% unless params[:all] || !@history.respond_to?(:current_page) %>
76
- <%= paginate(@history, theme: 'ra-twitter-bootstrap', remote: true) %>
77
- <%= link_to(t("admin.misc.show_all"), send(path_method, params.merge(all: true)), class: "show-all btn pjax") unless (tc = @history.total_count) <= @history.size || tc > 100 %>
78
+ <%= paginate(@history, theme: 'ra-twitter-bootstrap') %>
79
+ <%= link_to(t("admin.misc.show_all"), send(path_method, params.merge(all: true)), class: "show-all btn btn-light") unless (tc = @history.total_count) <= @history.size || tc > 100 %>
78
80
  <% end %>