ui_bibz 2.5.6 → 3.0.0.alpha2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (256) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +3 -2
  3. data/.rubocop.yml +78 -0
  4. data/.ruby-gemset +1 -0
  5. data/.ruby-version +1 -0
  6. data/Gemfile +1 -0
  7. data/Gemfile.lock +90 -102
  8. data/README.md +9 -52
  9. data/Rakefile +3 -2
  10. data/bin/test +7 -0
  11. data/config/initializers/will_paginate.rb +2 -1
  12. data/lib/ui_bibz.rb +17 -2
  13. data/lib/ui_bibz/concerns/models/searchable.rb +3 -3
  14. data/lib/ui_bibz/helpers/ui/core/boxes_helper.rb +9 -1
  15. data/lib/ui_bibz/helpers/ui/core/forms_helper.rb +18 -0
  16. data/lib/ui_bibz/helpers/ui/core/layouts_helper.rb +10 -2
  17. data/lib/ui_bibz/helpers/ui/core/lists_helper.rb +1 -1
  18. data/lib/ui_bibz/helpers/ui/core/notifications_helper.rb +9 -5
  19. data/lib/ui_bibz/helpers/ui/ux_helper.rb +2 -6
  20. data/lib/ui_bibz/infos.rb +11 -5
  21. data/lib/ui_bibz/inputs/ui_bibz_form/ui_bibz_form_builder.rb +15 -2
  22. data/lib/ui_bibz/inputs/ui_bibz_inputs/base_input.rb +0 -4
  23. data/lib/ui_bibz/inputs/ui_bibz_inputs/collection_input.rb +6 -9
  24. data/lib/ui_bibz/inputs/ui_bibz_inputs/ui_choice_field_input.rb +23 -0
  25. data/lib/ui_bibz/inputs/ui_bibz_inputs/ui_slider_field_input.rb +11 -0
  26. data/lib/ui_bibz/rails/engine.rb +2 -13
  27. data/lib/ui_bibz/railtie.rb +6 -0
  28. data/lib/ui_bibz/ui/concerns/card_itemable_concern.rb +65 -0
  29. data/lib/ui_bibz/ui/concerns/html_concern.rb +16 -0
  30. data/lib/ui_bibz/ui/core/boxes/card.rb +5 -50
  31. data/lib/ui_bibz/ui/core/boxes/card_accordion.rb +2 -0
  32. data/lib/ui_bibz/ui/core/boxes/card_column.rb +3 -1
  33. data/lib/ui_bibz/ui/core/boxes/card_deck.rb +3 -1
  34. data/lib/ui_bibz/ui/core/boxes/card_grid.rb +60 -0
  35. data/lib/ui_bibz/ui/core/boxes/card_group.rb +3 -1
  36. data/lib/ui_bibz/ui/core/boxes/components/body/card_body_link.rb +0 -3
  37. data/lib/ui_bibz/ui/core/boxes/components/body/card_body_subtitle.rb +47 -0
  38. data/lib/ui_bibz/ui/core/boxes/components/body/card_body_text.rb +0 -3
  39. data/lib/ui_bibz/ui/core/boxes/components/body/card_body_title.rb +1 -4
  40. data/lib/ui_bibz/ui/core/boxes/components/card_body.rb +7 -0
  41. data/lib/ui_bibz/ui/core/boxes/components/card_col.rb +65 -0
  42. data/lib/ui_bibz/ui/core/boxes/components/card_footer.rb +0 -3
  43. data/lib/ui_bibz/ui/core/boxes/components/card_header.rb +2 -4
  44. data/lib/ui_bibz/ui/core/boxes/components/card_image.rb +0 -3
  45. data/lib/ui_bibz/ui/core/boxes/components/card_row.rb +65 -0
  46. data/lib/ui_bibz/ui/core/boxes/components/card_tab_group.rb +0 -4
  47. data/lib/ui_bibz/ui/core/boxes/jumbotron.rb +1 -4
  48. data/lib/ui_bibz/ui/core/component.rb +16 -9
  49. data/lib/ui_bibz/ui/core/forms/buttons/button.rb +1 -1
  50. data/lib/ui_bibz/ui/core/forms/buttons/button_group.rb +9 -11
  51. data/lib/ui_bibz/ui/core/forms/buttons/button_refresh.rb +0 -3
  52. data/lib/ui_bibz/ui/core/forms/buttons/components/button_group_dropdown.rb +0 -3
  53. data/lib/ui_bibz/ui/core/forms/buttons/components/button_group_split_dropdown.rb +0 -3
  54. data/lib/ui_bibz/ui/core/forms/choices/box_switch_field.rb +7 -10
  55. data/lib/ui_bibz/ui/core/forms/choices/checkbox_field.rb +8 -7
  56. data/lib/ui_bibz/ui/core/forms/choices/choice_group.rb +22 -2
  57. data/lib/ui_bibz/ui/core/forms/choices/components/choice.rb +24 -12
  58. data/lib/ui_bibz/ui/core/forms/choices/radio_field.rb +11 -6
  59. data/lib/ui_bibz/ui/core/forms/choices/switch_field.rb +1 -5
  60. data/lib/ui_bibz/ui/core/forms/dates/date_picker_field.rb +12 -15
  61. data/lib/ui_bibz/ui/core/forms/dropdowns/components/dropdown_divider.rb +0 -1
  62. data/lib/ui_bibz/ui/core/forms/dropdowns/components/dropdown_header.rb +0 -3
  63. data/lib/ui_bibz/ui/core/forms/dropdowns/dropdown.rb +8 -13
  64. data/lib/ui_bibz/ui/core/forms/dropdowns/split_dropdown.rb +0 -3
  65. data/lib/ui_bibz/ui/core/forms/files/file_field.rb +20 -10
  66. data/lib/ui_bibz/ui/core/forms/numbers/formula_field.rb +16 -8
  67. data/lib/ui_bibz/ui/core/forms/numbers/number_field.rb +20 -3
  68. data/lib/ui_bibz/ui/core/forms/numbers/range_field.rb +33 -5
  69. data/lib/ui_bibz/ui/core/forms/numbers/slider_field.rb +132 -0
  70. data/lib/ui_bibz/ui/core/forms/numbers/slider_header.rb +71 -0
  71. data/lib/ui_bibz/ui/core/forms/selects/abstract_select.rb +0 -3
  72. data/lib/ui_bibz/ui/core/forms/selects/dropdown_select_field.rb +6 -9
  73. data/lib/ui_bibz/ui/core/forms/selects/multi_column_field.rb +0 -3
  74. data/lib/ui_bibz/ui/core/forms/selects/multi_select_field.rb +0 -3
  75. data/lib/ui_bibz/ui/core/forms/selects/select_field.rb +2 -5
  76. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_addon.rb +1 -4
  77. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_button.rb +0 -3
  78. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_button_group.rb +0 -3
  79. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_button_link.rb +0 -3
  80. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_button_refresh.rb +1 -12
  81. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_checkbox_field.rb +9 -4
  82. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_dropdown.rb +0 -3
  83. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_radio_field.rb +9 -4
  84. data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_switch_field.rb +0 -3
  85. data/lib/ui_bibz/ui/core/forms/surrounds/surround_field.rb +1 -4
  86. data/lib/ui_bibz/ui/core/forms/textareas/markdown_editor_field.rb +4 -7
  87. data/lib/ui_bibz/ui/core/forms/texts/auto_complete_field.rb +2 -5
  88. data/lib/ui_bibz/ui/core/forms/texts/text_field.rb +0 -3
  89. data/lib/ui_bibz/ui/core/icons/components/glyph_counter.rb +0 -3
  90. data/lib/ui_bibz/ui/core/icons/components/glyph_text.rb +1 -4
  91. data/lib/ui_bibz/ui/core/icons/glyph.rb +1 -4
  92. data/lib/ui_bibz/ui/core/icons/star.rb +0 -3
  93. data/lib/ui_bibz/ui/core/layouts/col.rb +5 -42
  94. data/lib/ui_bibz/ui/core/layouts/container.rb +9 -6
  95. data/lib/ui_bibz/ui/core/layouts/row.rb +32 -2
  96. data/lib/ui_bibz/ui/core/lists/components/list.rb +6 -8
  97. data/lib/ui_bibz/ui/core/lists/components/list/list_body.rb +0 -3
  98. data/lib/ui_bibz/ui/core/lists/components/list/list_header.rb +0 -3
  99. data/lib/ui_bibz/ui/core/lists/list_group.rb +9 -6
  100. data/lib/ui_bibz/ui/core/navigations/breadcrumb.rb +3 -2
  101. data/lib/ui_bibz/ui/core/navigations/components/breadcrumb_link.rb +0 -3
  102. data/lib/ui_bibz/ui/core/navigations/components/nav_dropdown.rb +1 -4
  103. data/lib/ui_bibz/ui/core/navigations/components/nav_link.rb +3 -1
  104. data/lib/ui_bibz/ui/core/navigations/components/nav_link_link.rb +14 -5
  105. data/lib/ui_bibz/ui/core/navigations/components/nav_link_list.rb +0 -4
  106. data/lib/ui_bibz/ui/core/navigations/components/nav_link_span.rb +1 -4
  107. data/lib/ui_bibz/ui/core/navigations/components/nav_text.rb +0 -3
  108. data/lib/ui_bibz/ui/core/navigations/components/navbar_brand.rb +0 -3
  109. data/lib/ui_bibz/ui/core/navigations/components/navbar_form.rb +4 -4
  110. data/lib/ui_bibz/ui/core/navigations/components/navbar_nav.rb +1 -4
  111. data/lib/ui_bibz/ui/core/navigations/components/navbar_text.rb +0 -3
  112. data/lib/ui_bibz/ui/core/navigations/components/pagination_link.rb +0 -3
  113. data/lib/ui_bibz/ui/core/navigations/components/toolbar_form.rb +3 -3
  114. data/lib/ui_bibz/ui/core/navigations/link.rb +0 -3
  115. data/lib/ui_bibz/ui/core/navigations/nav.rb +37 -10
  116. data/lib/ui_bibz/ui/core/navigations/navbar.rb +28 -7
  117. data/lib/ui_bibz/ui/core/navigations/pagination.rb +3 -1
  118. data/lib/ui_bibz/ui/core/navigations/tab_group.rb +10 -5
  119. data/lib/ui_bibz/ui/core/navigations/toolbar.rb +2 -0
  120. data/lib/ui_bibz/ui/core/notifications/alert.rb +2 -2
  121. data/lib/ui_bibz/ui/core/notifications/badge.rb +2 -5
  122. data/lib/ui_bibz/ui/core/notifications/components/alert_body.rb +0 -3
  123. data/lib/ui_bibz/ui/core/notifications/components/alert_header.rb +4 -10
  124. data/lib/ui_bibz/ui/core/notifications/components/bar.rb +0 -3
  125. data/lib/ui_bibz/ui/core/notifications/components/toast_body.rb +0 -3
  126. data/lib/ui_bibz/ui/core/notifications/components/toast_header.rb +1 -6
  127. data/lib/ui_bibz/ui/core/notifications/progress_bar.rb +7 -5
  128. data/lib/ui_bibz/ui/core/notifications/spinner.rb +0 -3
  129. data/lib/ui_bibz/ui/core/notifications/toast.rb +14 -3
  130. data/lib/ui_bibz/ui/core/windows/components/modal_body.rb +0 -3
  131. data/lib/ui_bibz/ui/core/windows/components/modal_footer.rb +0 -3
  132. data/lib/ui_bibz/ui/core/windows/components/modal_header.rb +1 -7
  133. data/lib/ui_bibz/ui/core/windows/modal.rb +61 -14
  134. data/lib/ui_bibz/ui/extensions/core/component/glyph_extension.rb +4 -2
  135. data/lib/ui_bibz/ui/extensions/core/component/popover_extension.rb +9 -9
  136. data/lib/ui_bibz/ui/extensions/core/forms/connect_extension.rb +2 -2
  137. data/lib/ui_bibz/ui/ux/containers/components/panel_body.rb +0 -3
  138. data/lib/ui_bibz/ui/ux/containers/components/panel_column.rb +2 -0
  139. data/lib/ui_bibz/ui/ux/containers/components/panel_deck.rb +2 -0
  140. data/lib/ui_bibz/ui/ux/containers/components/panel_footer.rb +0 -3
  141. data/lib/ui_bibz/ui/ux/containers/components/panel_group.rb +2 -0
  142. data/lib/ui_bibz/ui/ux/containers/components/panel_header.rb +1 -4
  143. data/lib/ui_bibz/ui/ux/containers/components/panel_tab_group.rb +0 -4
  144. data/lib/ui_bibz/ui/ux/containers/components/panel_toolbar.rb +0 -3
  145. data/lib/ui_bibz/ui/ux/containers/panel.rb +4 -2
  146. data/lib/ui_bibz/ui/ux/tables/components/thead.rb +0 -3
  147. data/lib/ui_bibz/ui/ux/tables/table.rb +2 -4
  148. data/lib/ui_bibz/ui/ux/tables/table_card.rb +4 -3
  149. data/lib/ui_bibz/ui/ux/tables/table_search_field.rb +5 -5
  150. data/lib/ui_bibz/utils/breakdown_class_name_generator.rb +69 -0
  151. data/lib/ui_bibz/utils/internationalization.rb +1 -1
  152. data/lib/ui_bibz/utils/screwdriver.rb +16 -10
  153. data/package.json +5 -0
  154. data/test/dummy/Rakefile +1 -1
  155. data/test/dummy/app/javascripts/packs/index.js +3 -0
  156. data/test/dummy/app/views/layouts/application.html.erb +4 -1
  157. data/{app/ui/.keep → test/dummy/app/views/users/index.html.erb} +0 -0
  158. data/test/dummy/bin/setup +17 -13
  159. data/test/dummy/config.ru +2 -1
  160. data/test/dummy/config/application.rb +1 -0
  161. data/test/dummy/config/cable.yml +10 -0
  162. data/test/dummy/config/database.yml +1 -1
  163. data/test/dummy/config/environment.rb +1 -1
  164. data/test/dummy/config/environments/development.rb +33 -12
  165. data/test/dummy/config/environments/production.rb +52 -19
  166. data/test/dummy/config/environments/test.rb +18 -12
  167. data/test/dummy/config/initializers/application_controller_renderer.rb +9 -0
  168. data/test/dummy/config/initializers/assets.rb +4 -3
  169. data/test/dummy/config/initializers/backtrace_silencers.rb +0 -1
  170. data/test/dummy/config/initializers/content_security_policy.rb +29 -0
  171. data/test/dummy/config/initializers/cookies_serializer.rb +2 -0
  172. data/test/dummy/config/initializers/inflections.rb +0 -1
  173. data/test/dummy/config/initializers/mime_types.rb +0 -1
  174. data/test/dummy/config/initializers/wrap_parameters.rb +2 -2
  175. data/test/dummy/config/puma.rb +40 -0
  176. data/test/dummy/config/routes.rb +3 -0
  177. data/test/dummy/config/spring.rb +8 -0
  178. data/test/dummy/config/storage.yml +34 -0
  179. data/test/dummy/db/migrate/20150123191805_create_users.rb +1 -1
  180. data/test/dummy/db/schema.rb +24 -24
  181. data/test/dummy/public/404.html +6 -6
  182. data/test/dummy/public/422.html +6 -6
  183. data/test/dummy/public/500.html +6 -6
  184. data/test/dummy/public/apple-touch-icon-precomposed.png +0 -0
  185. data/test/dummy/public/apple-touch-icon.png +0 -0
  186. data/test/dummy/storage/.keep +0 -0
  187. data/test/simple_form_test.rb +45 -22
  188. data/test/store_test.rb +5 -5
  189. data/test/test_helper.rb +18 -9
  190. data/test/ui/core/boxes/card_grid_test.rb +17 -0
  191. data/test/ui/core/boxes/card_test.rb +45 -11
  192. data/test/ui/core/boxes/jumbotron_test.rb +2 -2
  193. data/test/ui/core/component_test.rb +1 -1
  194. data/test/ui/core/forms/buttons/button_link_test.rb +1 -1
  195. data/test/ui/core/forms/buttons/button_test.rb +2 -2
  196. data/test/ui/core/forms/choices/checkbox_field_test.rb +1 -1
  197. data/test/ui/core/forms/choices/choice_group_test.rb +11 -9
  198. data/test/ui/core/forms/choices/radio_field_test.rb +1 -1
  199. data/test/ui/core/forms/dates/date_picker_field_test.rb +1 -1
  200. data/test/ui/core/forms/files/file_field_test.rb +12 -0
  201. data/test/ui/core/forms/numbers/formula_field_test.rb +1 -1
  202. data/test/ui/core/forms/numbers/range_field_test.rb +23 -2
  203. data/test/ui/core/forms/numbers/slider_field_test.rb +26 -0
  204. data/test/ui/core/forms/selects/dropdown_select_field_test.rb +10 -10
  205. data/test/ui/core/forms/selects/multi_column_field_test.rb +1 -1
  206. data/test/ui/core/forms/selects/multi_select_field_test.rb +2 -2
  207. data/test/ui/core/forms/selects/select_field_test.rb +3 -3
  208. data/test/ui/core/forms/surrounds/surround_field_test.rb +15 -3
  209. data/test/ui/core/forms/textareas/markdown_editor_field_test.rb +1 -1
  210. data/test/ui/core/forms/texts/auto_complete_field_test.rb +8 -8
  211. data/test/ui/core/forms/texts/text_field_test.rb +2 -2
  212. data/test/ui/core/layouts/col_test.rb +11 -2
  213. data/test/ui/core/layouts/container_test.rb +15 -1
  214. data/test/ui/core/layouts/row_test.rb +68 -3
  215. data/test/ui/core/lists/list_group_test.rb +1 -1
  216. data/test/ui/core/navigations/breadcrumb_test.rb +1 -1
  217. data/test/ui/core/navigations/link_test.rb +1 -1
  218. data/test/ui/core/navigations/nav_test.rb +11 -0
  219. data/test/ui/core/navigations/navbar_test.rb +4 -4
  220. data/test/ui/core/notifications/alert_test.rb +2 -2
  221. data/test/ui/core/notifications/badge_test.rb +3 -3
  222. data/test/ui/core/notifications/progress_bar_test.rb +1 -1
  223. data/test/ui/core/notifications/toast_test.rb +10 -1
  224. data/test/ui/core/windows/modal_test.rb +15 -1
  225. data/test/ui/utils/breakdown_class_name_generator_test.rb +60 -0
  226. data/test/ui/ux/containers/panel_test.rb +5 -5
  227. data/test/ui/ux/tables/table_test.rb +6 -6
  228. data/test/ui_bibz_test.rb +1 -1
  229. data/ui_bibz.gemspec +16 -16
  230. metadata +100 -105
  231. data/app/assets/javascripts/fix_bootstrap.coffee +0 -7
  232. data/app/assets/javascripts/form.coffee +0 -83
  233. data/app/assets/javascripts/formula.coffee +0 -69
  234. data/app/assets/javascripts/input-connected.coffee +0 -101
  235. data/app/assets/javascripts/interface.coffee +0 -55
  236. data/app/assets/javascripts/jquery.multi-select-extend.coffee +0 -38
  237. data/app/assets/javascripts/table.coffee +0 -36
  238. data/app/assets/javascripts/ui_bibz.coffee.erb +0 -75
  239. data/app/assets/stylesheets/_custom_variables.sass +0 -20
  240. data/app/assets/stylesheets/_panel.scss +0 -315
  241. data/app/assets/stylesheets/bootstrap-switch.sass +0 -159
  242. data/app/assets/stylesheets/boxes.sass +0 -5
  243. data/app/assets/stylesheets/containers.sass +0 -2
  244. data/app/assets/stylesheets/fix-bootstrap-4.sass +0 -19
  245. data/app/assets/stylesheets/fix_addon.sass +0 -216
  246. data/app/assets/stylesheets/forms.sass +0 -91
  247. data/app/assets/stylesheets/navigations.sass +0 -17
  248. data/app/assets/stylesheets/notifications.sass +0 -42
  249. data/app/assets/stylesheets/tables.sass +0 -66
  250. data/app/assets/stylesheets/ui_bibz.sass.erb +0 -55
  251. data/lib/generators/ui_bibz/install_generator.rb +0 -17
  252. data/lib/generators/ui_bibz/templates/ui_bibz_initializer.rb +0 -5
  253. data/lib/ui_bibz/ui/core/icons/glyph_group.rb +0 -101
  254. data/test/dummy/bin/bundle +0 -5
  255. data/test/ui/core/forms/files/text_field_test.rb +0 -12
  256. data/test/ui/core/icons/glyph_group_test.rb +0 -37
@@ -48,9 +48,6 @@ module UiBibz::Ui::Core::Forms::Numbers
48
48
  #
49
49
  class NumberField < UiBibz::Ui::Core::Forms::Texts::TextField
50
50
  # See UiBibz::Ui::Core::Component.initialize
51
- def initialize(content = nil, options = nil, html_options = nil, &block)
52
- super
53
- end
54
51
 
55
52
  # Render html tag
56
53
  def pre_render
@@ -73,5 +70,25 @@ module UiBibz::Ui::Core::Forms::Numbers
73
70
  within: options[:within]
74
71
  }
75
72
  end
73
+
74
+ def html_max
75
+ options[:max] || 100
76
+ end
77
+
78
+ def html_min
79
+ options[:min] || 0
80
+ end
81
+
82
+ def html_step
83
+ options[:step] || 1
84
+ end
85
+
86
+ def html_in
87
+ options[:in]
88
+ end
89
+
90
+ def html_within
91
+ options[:within]
92
+ end
76
93
  end
77
94
  end
@@ -47,19 +47,47 @@ module UiBibz::Ui::Core::Forms::Numbers
47
47
  #
48
48
  class RangeField < UiBibz::Ui::Core::Forms::Numbers::NumberField
49
49
  # See UiBibz::Ui::Core::Component.initialize
50
- def initialize(content = nil, options = nil, html_options = nil, &block)
51
- super
52
- end
53
50
 
54
51
  # Render html tag
55
52
  def pre_render
56
- range_field_tag content, options[:value] || html_options[:value], html_options
53
+ capture do
54
+ concat range_field_tag(content, options[:value] || html_options[:value], html_options)
55
+ concat datalist_tag if options[:tick]
56
+ end
57
+ end
58
+
59
+ def html_id
60
+ @html_id ||= html_options[:id] || generate_id('range')
57
61
  end
58
62
 
59
63
  private
60
64
 
65
+ def datalist_tag
66
+ content_tag :datalist, id: datalist_id do
67
+ (html_min..html_max).step(html_step).map do |i|
68
+ content_tag :option, option_label(i), value: i, label: option_label(i)
69
+ end.join.html_safe
70
+ end
71
+ end
72
+
73
+ def component_html_options
74
+ options[:tick] ? super.merge(list: datalist_id) : super
75
+ end
76
+
61
77
  def component_html_classes
62
- 'custom-range'
78
+ 'form-range'
79
+ end
80
+
81
+ def option_label(value)
82
+ value if [html_min, middle_range_value, html_max].include?(value)
83
+ end
84
+
85
+ def middle_range_value
86
+ (html_min..html_max).to_a[(html_min..html_max).size / 2]
87
+ end
88
+
89
+ def datalist_id
90
+ "#{html_id}-list"
63
91
  end
64
92
  end
65
93
  end
@@ -0,0 +1,132 @@
1
+ # frozen_string_literal: true
2
+
3
+ module UiBibz::Ui::Core::Forms::Numbers
4
+ # Create a SliderField
5
+ #
6
+ # This element is an extend of UiBibz::Ui::Core::Component.
7
+ #
8
+ # ==== Attributes
9
+ #
10
+ # * +content+ - Content of element
11
+ # * +options+ - Options of element
12
+ # * +html_options+ - Html Options of element
13
+ #
14
+ # ==== Options
15
+ #
16
+ # You can add HTML attributes using the +html_options+.
17
+ # You can pass arguments in options attribute:
18
+ # * +max+ - [Float, Integer]
19
+ # * +min+ - [Float, Integer]
20
+ # * +step+ - [Float, Integer]
21
+ # * +in+ - Array
22
+ # * +within+ - Array
23
+ #
24
+ # ==== Signatures
25
+ #
26
+ # UiBibz::Ui::Core::Forms::Numbers::SliderField.new(content, options = {}, html_options = {}).render
27
+ #
28
+ # UiBibz::Ui::Core::Forms::Numbers::SliderField.new(options = {}, html_options = {}) do
29
+ # content
30
+ # end.render
31
+ #
32
+ # ==== Examples
33
+ #
34
+ # UiBibz::Ui::Core::Forms::Numbers::SliderField.new(4, max: 20, min: 0, step: 2)
35
+ #
36
+ # UiBibz::Ui::Core::Forms::Numbers::SliderField.new(max: 2, min: -3, step: 0.5) do
37
+ # 5
38
+ # end
39
+ #
40
+ # ==== Helper
41
+ #
42
+ # ui_slider_field(content, options = {}, html_options = {})
43
+ #
44
+ # ui_slider_field(options = {}, html_options = {}) do
45
+ # # content
46
+ # end
47
+ #
48
+ class SliderField < UiBibz::Ui::Core::Forms::Numbers::NumberField
49
+ # See UiBibz::Ui::Core::Component.initialize
50
+
51
+ private
52
+
53
+ # Render html tag
54
+ def pre_render
55
+ content_tag :div, html_options do
56
+ concat slider_html
57
+ concat range_field_tag(options[:input_name_min] || range_name('_min'), options[:thumb_min] || 0, range_html_options)
58
+ concat range_field_tag(options[:input_name_max] || range_name('_max'), options[:thumb_max] || 100, range_html_options)
59
+ end
60
+ end
61
+
62
+ def slider_html
63
+ content_tag :div do
64
+ concat content_tag :div, '', class: 'slider-inverse-left', style: 'width: 100%'
65
+ concat content_tag :div, '', class: 'slider-inverse-right', style: 'width: 100%'
66
+ concat content_tag :div, '', class: 'slider-range', style: "left: #{left_percentage}%; right: #{100 - right_percentage}%"
67
+ concat content_tag :div, '', class: 'slider-thumb slider-thumb-left', style: "left: #{left_percentage}%"
68
+ concat content_tag :div, '', class: 'slider-thumb slider-thumb-right', style: "left: #{right_percentage}%"
69
+ end
70
+ end
71
+
72
+ def range_html_options
73
+ { max: options[:max] || 100, min: options[:min] || 0, step: options[:step] || 1, disabled: disabled }
74
+ end
75
+
76
+ def not_on_hundred_percent?
77
+ options[:max].present? && options[:max] != 100 || options[:min].present? && options[:min] != 0
78
+ end
79
+
80
+ def absolute_total
81
+ @absolute_total ||= min.abs + max.abs
82
+ end
83
+
84
+ def absolute_min
85
+ (min - thumb_min).abs
86
+ end
87
+
88
+ def absolute_max
89
+ (max - thumb_max).abs
90
+ end
91
+
92
+ def min
93
+ options[:min] || 0
94
+ end
95
+
96
+ def max
97
+ options[:max] || 100
98
+ end
99
+
100
+ def thumb_min
101
+ options[:thumb_min] || 0
102
+ end
103
+
104
+ def thumb_max
105
+ options[:thumb_max] || 100
106
+ end
107
+
108
+ def left_percentage
109
+ @left_percentage ||= not_on_hundred_percent? ? 100 * absolute_min / absolute_total : thumb_min
110
+ end
111
+
112
+ def right_percentage
113
+ @right_percentage ||= not_on_hundred_percent? ? 100 - (100 * absolute_max / absolute_total) : thumb_max
114
+ end
115
+
116
+ def component_html_classes
117
+ ['slider', ('disabled' if disabled)]
118
+ end
119
+
120
+ def disabled
121
+ 'disabled' if options[:state] == :disabled || html_options[:disabled]
122
+ end
123
+
124
+ def range_name(suffix)
125
+ if content.end_with?(']')
126
+ content.clone.insert(-2, suffix)
127
+ else
128
+ "#{content}#{suffix}"
129
+ end
130
+ end
131
+ end
132
+ end
@@ -0,0 +1,71 @@
1
+ # frozen_string_literal: true
2
+
3
+ module UiBibz::Ui::Core::Forms::Numbers
4
+ # Create a SliderHeader
5
+ #
6
+ # This element is an extend of UiBibz::Ui::Core::Component.
7
+ #
8
+ # ==== Attributes
9
+ #
10
+ # * +content+ - Content of element
11
+ # * +options+ - Options of element
12
+ # * +html_options+ - Html Options of element
13
+ #
14
+ # ==== Options
15
+ #
16
+ # You can add HTML attributes using the +html_options+.
17
+ # You can pass arguments in options attribute:
18
+ # * +max+ - [Float, Integer]
19
+ # * +min+ - [Float, Integer]
20
+ # * +step+ - [Float, Integer]
21
+ # * +in+ - Array
22
+ # * +within+ - Array
23
+ #
24
+ # ==== Signatures
25
+ #
26
+ # UiBibz::Ui::Core::Forms::Numbers::SliderHeader.new(content, options = {}, html_options = {}).render
27
+ #
28
+ # UiBibz::Ui::Core::Forms::Numbers::SliderHeader.new(options = {}, html_options = {}) do
29
+ # content
30
+ # end.render
31
+ #
32
+ # ==== Examples
33
+ #
34
+ # UiBibz::Ui::Core::Forms::Numbers::SliderHeader.new(nil, max: 20, min: 0)
35
+ #
36
+ # ==== Helper
37
+ #
38
+ # ui_slider_header(content, options = {}, html_options = {})
39
+ #
40
+ class SliderHeader < UiBibz::Ui::Core::Component
41
+ # See UiBibz::Ui::Core::Component.initialize
42
+
43
+ # Render html tag
44
+ def pre_render
45
+ content_tag :div, html_options do
46
+ concat header_min
47
+ concat header_max
48
+ end
49
+ end
50
+
51
+ private
52
+
53
+ def header_min
54
+ content_tag :div, class: 'slider-header-min' do
55
+ concat content_tag :label, options[:label_min] || 'Min: '
56
+ concat content_tag :span, options[:thumb_min]
57
+ end
58
+ end
59
+
60
+ def header_max
61
+ content_tag :div, class: 'slider-header-max' do
62
+ concat content_tag :label, options[:label_max] || 'max: '
63
+ concat content_tag :span, options[:thumb_max]
64
+ end
65
+ end
66
+
67
+ def component_html_classes
68
+ 'slider-header'
69
+ end
70
+ end
71
+ end
@@ -71,9 +71,6 @@ module UiBibz::Ui::Core::Forms::Selects
71
71
  include SurroundExtension
72
72
 
73
73
  # See UiBibz::Ui::Core::Component.initialize
74
- def initialize(content = nil, options = nil, html_options = nil, &block)
75
- super
76
- end
77
74
 
78
75
  # Render html tag
79
76
  def pre_render
@@ -68,9 +68,6 @@ module UiBibz::Ui::Core::Forms::Selects
68
68
  #
69
69
  class DropdownSelectField < UiBibz::Ui::Core::Forms::Selects::AbstractSelect
70
70
  # See UiBibz::Ui::Core::Component.initialize
71
- def initialize(content = nil, options = nil, html_options = nil, &block)
72
- super
73
- end
74
71
 
75
72
  private
76
73
 
@@ -102,11 +99,11 @@ module UiBibz::Ui::Core::Forms::Selects
102
99
  ############################ Data html options
103
100
 
104
101
  def max_options
105
- add_html_data('max_options', options[:max_options]) if options[:max_options]
102
+ add_html_data('max_options', value: options[:max_options]) if options[:max_options]
106
103
  end
107
104
 
108
105
  def selected_text_format
109
- add_html_data('selected_text_format', options[:selected_text_format]) if options[:selected_text_format]
106
+ add_html_data('selected_text_format', value: options[:selected_text_format]) if options[:selected_text_format]
110
107
  end
111
108
 
112
109
  def searchable
@@ -114,11 +111,11 @@ module UiBibz::Ui::Core::Forms::Selects
114
111
  end
115
112
 
116
113
  def style
117
- add_html_data('style', "btn-#{options[:status] || :secondary}")
114
+ add_html_data('style', value: "btn-#{options[:status] || :secondary}")
118
115
  end
119
116
 
120
117
  def menu_size
121
- add_html_data('size', options[:menu_size]) if options[:menu_size]
118
+ add_html_data('size', value: options[:menu_size]) if options[:menu_size]
122
119
  end
123
120
 
124
121
  def actions_box
@@ -126,11 +123,11 @@ module UiBibz::Ui::Core::Forms::Selects
126
123
  end
127
124
 
128
125
  def header
129
- add_html_data('header', options[:header]) if options[:header]
126
+ add_html_data('header', value: options[:header]) if options[:header]
130
127
  end
131
128
 
132
129
  def add_status
133
- add_html_data('style', "btn-#{options[:status]}") if options[:status]
130
+ add_html_data('style', value: "btn-#{options[:status]}") if options[:status]
134
131
  end
135
132
 
136
133
  ############################# Css classes
@@ -48,9 +48,6 @@ module UiBibz::Ui::Core::Forms::Selects
48
48
  #
49
49
  class MultiColumnField < UiBibz::Ui::Core::Forms::Selects::AbstractSelect
50
50
  # See UiBibz::Ui::Core::Component.initialize
51
- def initialize(content = nil, options = nil, html_options = nil, &block)
52
- super
53
- end
54
51
 
55
52
  private
56
53
 
@@ -53,9 +53,6 @@ module UiBibz::Ui::Core::Forms::Selects
53
53
  #
54
54
  class MultiSelectField < UiBibz::Ui::Core::Forms::Selects::AbstractSelect
55
55
  # See UiBibz::Ui::Core::Forms::Buttons::Button.initialize
56
- def initialize(content = nil, options = nil, html_options = nil, &block)
57
- super
58
- end
59
56
 
60
57
  private
61
58
 
@@ -61,14 +61,11 @@ module UiBibz::Ui::Core::Forms::Selects
61
61
  #
62
62
  class SelectField < UiBibz::Ui::Core::Forms::Selects::AbstractSelect
63
63
  # See UiBibz::Ui::Core::Component.initialize
64
- def initialize(content = nil, options = nil, html_options = nil, &block)
65
- super
66
- end
67
64
 
68
65
  private
69
66
 
70
67
  def component_html_classes
71
- super << ['select-field', 'form-control', 'custom-select', size]
68
+ super << ['select-field', 'form-control', 'form-select', size]
72
69
  end
73
70
 
74
71
  def component_options
@@ -76,7 +73,7 @@ module UiBibz::Ui::Core::Forms::Selects
76
73
  end
77
74
 
78
75
  def size
79
- "custom-select-#{options[:size]}" unless options[:size].nil?
76
+ "form-select-#{options[:size]}" unless options[:size].nil?
80
77
  end
81
78
  end
82
79
  end
@@ -3,9 +3,6 @@
3
3
  module UiBibz::Ui::Core::Forms::Surrounds
4
4
  class SurroundAddon < UiBibz::Ui::Core::Component
5
5
  # See UiBibz::Ui::Core::Dropdown.initialize
6
- def initialize(content, options = nil, html_options = nil, &block)
7
- super
8
- end
9
6
 
10
7
  # Render html tag
11
8
  def pre_render
@@ -19,7 +16,7 @@ module UiBibz::Ui::Core::Forms::Surrounds
19
16
  end
20
17
 
21
18
  def component_html_classes
22
- 'input-group-addon'
19
+ 'input-group-text'
23
20
  end
24
21
  end
25
22
  end
@@ -3,9 +3,6 @@
3
3
  module UiBibz::Ui::Core::Forms::Surrounds
4
4
  class SurroundButton < UiBibz::Ui::Core::Forms::Buttons::Button
5
5
  # See UiBibz::Ui::Core::Dropdown.initialize
6
- def initialize(content, options = nil, html_options = nil, &block)
7
- super
8
- end
9
6
 
10
7
  def pre_render
11
8
  content_tag :div, class: 'input-group-btn' do
@@ -3,9 +3,6 @@
3
3
  module UiBibz::Ui::Core::Forms::Surrounds
4
4
  class SurroundButtonGroup < UiBibz::Ui::Core::Forms::Buttons::ButtonGroup
5
5
  # See UiBibz::Ui::Core::Dropdown.initialize
6
- def initialize(content, options = nil, html_options = nil, &block)
7
- super
8
- end
9
6
 
10
7
  private
11
8
 
@@ -3,9 +3,6 @@
3
3
  module UiBibz::Ui::Core::Forms::Surrounds
4
4
  class SurroundButtonLink < UiBibz::Ui::Core::Forms::Buttons::ButtonLink
5
5
  # See UiBibz::Ui::Core::Dropdown.initialize
6
- def initialize(content, options = nil, html_options = nil, &block)
7
- super
8
- end
9
6
 
10
7
  def pre_render
11
8
  content_tag :div, class: 'input-group-btn' do