ruby_ui 1.0.0.pre.alpha.4 → 1.0.0.rc1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (227) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.txt +21 -0
  3. data/README.md +85 -0
  4. data/lib/generators/ruby_ui/component_generator.rb +94 -0
  5. data/lib/generators/ruby_ui/dependencies.yml +74 -0
  6. data/lib/generators/ruby_ui/install/install_generator.rb +89 -0
  7. data/lib/generators/ruby_ui/install/templates/ruby_ui.rb.erb +18 -0
  8. data/lib/generators/ruby_ui/install/templates/tailwind.css.erb +156 -0
  9. data/lib/generators/ruby_ui/javascript_utils.rb +57 -0
  10. data/lib/{rbui → ruby_ui}/accordion/accordion.rb +1 -1
  11. data/lib/{rbui → ruby_ui}/accordion/accordion_content.rb +2 -2
  12. data/lib/ruby_ui/accordion/accordion_controller.js +97 -0
  13. data/lib/{rbui → ruby_ui}/accordion/accordion_default_content.rb +1 -1
  14. data/lib/{rbui → ruby_ui}/accordion/accordion_default_trigger.rb +3 -3
  15. data/lib/{rbui → ruby_ui}/accordion/accordion_icon.rb +2 -2
  16. data/lib/{rbui → ruby_ui}/accordion/accordion_item.rb +4 -4
  17. data/lib/{rbui → ruby_ui}/accordion/accordion_trigger.rb +3 -2
  18. data/lib/{rbui → ruby_ui}/alert/alert.rb +3 -3
  19. data/lib/{rbui → ruby_ui}/alert/alert_description.rb +1 -1
  20. data/lib/{rbui → ruby_ui}/alert/alert_title.rb +1 -1
  21. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog.rb +3 -3
  22. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_action.rb +2 -2
  23. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_cancel.rb +3 -3
  24. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_content.rb +5 -5
  25. data/lib/ruby_ui/alert_dialog/alert_dialog_controller.js +31 -0
  26. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_description.rb +1 -1
  27. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_footer.rb +2 -2
  28. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_header.rb +2 -2
  29. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_title.rb +1 -1
  30. data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_trigger.rb +2 -2
  31. data/lib/{rbui → ruby_ui}/aspect_ratio/aspect_ratio.rb +1 -1
  32. data/lib/{rbui → ruby_ui}/avatar/avatar.rb +2 -2
  33. data/lib/{rbui → ruby_ui}/avatar/avatar_fallback.rb +1 -1
  34. data/lib/{rbui → ruby_ui}/avatar/avatar_image.rb +1 -1
  35. data/lib/{rbui → ruby_ui}/badge/badge.rb +2 -2
  36. data/lib/{rbui → ruby_ui}/base.rb +1 -8
  37. data/lib/ruby_ui/breadcrumb/breadcrumb.rb +17 -0
  38. data/lib/ruby_ui/breadcrumb/breadcrumb_ellipsis.rb +39 -0
  39. data/lib/{rbui/typography/typography_list_item.rb → ruby_ui/breadcrumb/breadcrumb_item.rb} +3 -3
  40. data/lib/ruby_ui/breadcrumb/breadcrumb_link.rb +22 -0
  41. data/lib/ruby_ui/breadcrumb/breadcrumb_list.rb +17 -0
  42. data/lib/ruby_ui/breadcrumb/breadcrumb_page.rb +19 -0
  43. data/lib/ruby_ui/breadcrumb/breadcrumb_separator.rb +38 -0
  44. data/lib/{rbui → ruby_ui}/button/button.rb +13 -13
  45. data/lib/ruby_ui/calendar/calendar.rb +39 -0
  46. data/lib/{rbui → ruby_ui}/calendar/calendar_body.rb +2 -2
  47. data/lib/ruby_ui/calendar/calendar_controller.js +249 -0
  48. data/lib/{rbui → ruby_ui}/calendar/calendar_days.rb +14 -14
  49. data/lib/{rbui → ruby_ui}/calendar/calendar_header.rb +1 -1
  50. data/lib/ruby_ui/calendar/calendar_input_controller.js +8 -0
  51. data/lib/{rbui → ruby_ui}/calendar/calendar_next.rb +2 -2
  52. data/lib/{rbui → ruby_ui}/calendar/calendar_prev.rb +2 -2
  53. data/lib/{rbui → ruby_ui}/calendar/calendar_title.rb +2 -2
  54. data/lib/{rbui → ruby_ui}/calendar/calendar_weekdays.rb +2 -2
  55. data/lib/{rbui → ruby_ui}/card/card.rb +1 -1
  56. data/lib/{rbui → ruby_ui}/card/card_content.rb +1 -1
  57. data/lib/{rbui → ruby_ui}/card/card_description.rb +1 -1
  58. data/lib/{rbui → ruby_ui}/card/card_footer.rb +1 -1
  59. data/lib/{rbui → ruby_ui}/card/card_header.rb +1 -1
  60. data/lib/{rbui → ruby_ui}/card/card_title.rb +1 -1
  61. data/lib/ruby_ui/carousel/carousel.rb +44 -0
  62. data/lib/ruby_ui/carousel/carousel_content.rb +23 -0
  63. data/lib/ruby_ui/carousel/carousel_controller.js +60 -0
  64. data/lib/ruby_ui/carousel/carousel_item.rb +23 -0
  65. data/lib/ruby_ui/carousel/carousel_next.rb +48 -0
  66. data/lib/ruby_ui/carousel/carousel_previous.rb +49 -0
  67. data/lib/{rbui → ruby_ui}/chart/chart.rb +3 -3
  68. data/lib/ruby_ui/chart/chart_controller.js +103 -0
  69. data/lib/{rbui → ruby_ui}/checkbox/checkbox.rb +4 -4
  70. data/lib/{rbui → ruby_ui}/checkbox/checkbox_group.rb +2 -2
  71. data/lib/ruby_ui/checkbox/checkbox_group_controller.js +21 -0
  72. data/lib/{rbui → ruby_ui}/clipboard/clipboard.rb +6 -6
  73. data/lib/ruby_ui/clipboard/clipboard_controller.js +54 -0
  74. data/lib/{rbui → ruby_ui}/clipboard/clipboard_popover.rb +2 -2
  75. data/lib/{rbui → ruby_ui}/clipboard/clipboard_source.rb +2 -2
  76. data/lib/{rbui → ruby_ui}/clipboard/clipboard_trigger.rb +3 -3
  77. data/lib/{rbui → ruby_ui}/codeblock/codeblock.rb +7 -10
  78. data/lib/{rbui → ruby_ui}/collapsible/collapsible.rb +3 -3
  79. data/lib/{rbui → ruby_ui}/collapsible/collapsible_content.rb +2 -2
  80. data/lib/ruby_ui/collapsible/collapsible_controller.js +47 -0
  81. data/lib/{rbui → ruby_ui}/collapsible/collapsible_trigger.rb +2 -2
  82. data/lib/ruby_ui/combobox/combobox.rb +26 -0
  83. data/lib/ruby_ui/combobox/combobox_checkbox.rb +25 -0
  84. data/lib/ruby_ui/combobox/combobox_controller.js +176 -0
  85. data/lib/{rbui/combobox/combobox_empty.rb → ruby_ui/combobox/combobox_empty_state.rb} +3 -3
  86. data/lib/ruby_ui/combobox/combobox_item.rb +25 -0
  87. data/lib/ruby_ui/combobox/combobox_list.rb +18 -0
  88. data/lib/ruby_ui/combobox/combobox_list_group.rb +20 -0
  89. data/lib/ruby_ui/combobox/combobox_popover.rb +30 -0
  90. data/lib/ruby_ui/combobox/combobox_radio.rb +26 -0
  91. data/lib/{rbui → ruby_ui}/combobox/combobox_search_input.rb +22 -25
  92. data/lib/ruby_ui/combobox/combobox_toggle_all_checkbox.rb +25 -0
  93. data/lib/{rbui → ruby_ui}/combobox/combobox_trigger.rb +26 -21
  94. data/lib/{rbui → ruby_ui}/command/command.rb +1 -1
  95. data/lib/ruby_ui/command/command_controller.js +136 -0
  96. data/lib/{rbui → ruby_ui}/command/command_dialog.rb +2 -2
  97. data/lib/{rbui → ruby_ui}/command/command_dialog_content.rb +6 -6
  98. data/lib/{rbui → ruby_ui}/command/command_dialog_trigger.rb +3 -3
  99. data/lib/{rbui → ruby_ui}/command/command_empty.rb +2 -2
  100. data/lib/{rbui → ruby_ui}/command/command_group.rb +2 -2
  101. data/lib/{rbui → ruby_ui}/command/command_input.rb +3 -3
  102. data/lib/{rbui → ruby_ui}/command/command_item.rb +2 -2
  103. data/lib/{rbui → ruby_ui}/command/command_list.rb +1 -1
  104. data/lib/{rbui → ruby_ui}/context_menu/context_menu.rb +2 -2
  105. data/lib/{rbui → ruby_ui}/context_menu/context_menu_content.rb +2 -2
  106. data/lib/ruby_ui/context_menu/context_menu_controller.js +144 -0
  107. data/lib/{rbui → ruby_ui}/context_menu/context_menu_item.rb +3 -3
  108. data/lib/{rbui → ruby_ui}/context_menu/context_menu_label.rb +2 -2
  109. data/lib/{rbui → ruby_ui}/context_menu/context_menu_separator.rb +1 -1
  110. data/lib/{rbui → ruby_ui}/context_menu/context_menu_trigger.rb +3 -3
  111. data/lib/{rbui → ruby_ui}/dialog/dialog.rb +3 -3
  112. data/lib/{rbui → ruby_ui}/dialog/dialog_content.rb +9 -9
  113. data/lib/ruby_ui/dialog/dialog_controller.js +32 -0
  114. data/lib/{rbui → ruby_ui}/dialog/dialog_description.rb +1 -1
  115. data/lib/{rbui → ruby_ui}/dialog/dialog_footer.rb +2 -2
  116. data/lib/{rbui → ruby_ui}/dialog/dialog_header.rb +2 -2
  117. data/lib/{rbui → ruby_ui}/dialog/dialog_middle.rb +1 -1
  118. data/lib/{rbui → ruby_ui}/dialog/dialog_title.rb +1 -1
  119. data/lib/{rbui → ruby_ui}/dialog/dialog_trigger.rb +2 -2
  120. data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu.rb +4 -4
  121. data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_content.rb +2 -2
  122. data/lib/ruby_ui/dropdown_menu/dropdown_menu_controller.js +120 -0
  123. data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_item.rb +3 -3
  124. data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_label.rb +1 -1
  125. data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_separator.rb +1 -1
  126. data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_trigger.rb +2 -2
  127. data/lib/{rbui → ruby_ui}/form/form.rb +1 -1
  128. data/lib/{rbui → ruby_ui}/form/form_field.rb +2 -2
  129. data/lib/ruby_ui/form/form_field_controller.js +61 -0
  130. data/lib/{rbui → ruby_ui}/form/form_field_error.rb +2 -2
  131. data/lib/{rbui → ruby_ui}/form/form_field_hint.rb +1 -1
  132. data/lib/{rbui → ruby_ui}/form/form_field_label.rb +1 -1
  133. data/lib/{rbui → ruby_ui}/hover_card/hover_card.rb +3 -3
  134. data/lib/{rbui → ruby_ui}/hover_card/hover_card_content.rb +2 -2
  135. data/lib/ruby_ui/hover_card/hover_card_controller.js +144 -0
  136. data/lib/{rbui → ruby_ui}/hover_card/hover_card_trigger.rb +2 -2
  137. data/lib/{rbui → ruby_ui}/input/input.rb +3 -3
  138. data/lib/{rbui → ruby_ui}/link/link.rb +13 -13
  139. data/lib/ruby_ui/masked_input/masked_input.rb +15 -0
  140. data/lib/ruby_ui/masked_input/masked_input_controller.js +9 -0
  141. data/lib/{rbui → ruby_ui}/pagination/pagination.rb +1 -1
  142. data/lib/{rbui → ruby_ui}/pagination/pagination_content.rb +1 -1
  143. data/lib/{rbui → ruby_ui}/pagination/pagination_ellipsis.rb +1 -1
  144. data/lib/{rbui → ruby_ui}/pagination/pagination_item.rb +4 -4
  145. data/lib/{rbui → ruby_ui}/popover/popover.rb +4 -4
  146. data/lib/{rbui → ruby_ui}/popover/popover_content.rb +2 -2
  147. data/lib/ruby_ui/popover/popover_controller.js +107 -0
  148. data/lib/{rbui → ruby_ui}/popover/popover_trigger.rb +2 -2
  149. data/lib/ruby_ui/progress/progress.rb +37 -0
  150. data/lib/ruby_ui/radio_button/radio_button.rb +25 -0
  151. data/lib/{rbui → ruby_ui}/select/select.rb +5 -5
  152. data/lib/{rbui → ruby_ui}/select/select_content.rb +3 -3
  153. data/lib/ruby_ui/select/select_controller.js +171 -0
  154. data/lib/{rbui → ruby_ui}/select/select_group.rb +1 -1
  155. data/lib/{rbui → ruby_ui}/select/select_input.rb +4 -4
  156. data/lib/{rbui → ruby_ui}/select/select_item.rb +4 -4
  157. data/lib/ruby_ui/select/select_item_controller.js +11 -0
  158. data/lib/{rbui → ruby_ui}/select/select_label.rb +1 -1
  159. data/lib/{rbui → ruby_ui}/select/select_trigger.rb +3 -3
  160. data/lib/{rbui → ruby_ui}/select/select_value.rb +3 -3
  161. data/lib/ruby_ui/separator/separator.rb +38 -0
  162. data/lib/{rbui → ruby_ui}/sheet/sheet.rb +2 -2
  163. data/lib/{rbui → ruby_ui}/sheet/sheet_content.rb +8 -8
  164. data/lib/ruby_ui/sheet/sheet_content_controller.js +7 -0
  165. data/lib/ruby_ui/sheet/sheet_controller.js +9 -0
  166. data/lib/{rbui → ruby_ui}/sheet/sheet_description.rb +1 -1
  167. data/lib/{rbui → ruby_ui}/sheet/sheet_footer.rb +1 -1
  168. data/lib/{rbui → ruby_ui}/sheet/sheet_header.rb +1 -1
  169. data/lib/{rbui → ruby_ui}/sheet/sheet_middle.rb +1 -1
  170. data/lib/{rbui → ruby_ui}/sheet/sheet_title.rb +1 -1
  171. data/lib/{rbui → ruby_ui}/sheet/sheet_trigger.rb +2 -2
  172. data/lib/{rbui → ruby_ui}/shortcut_key/shortcut_key.rb +1 -1
  173. data/lib/ruby_ui/skeleton/skeleton.rb +17 -0
  174. data/lib/ruby_ui/switch/switch.rb +24 -0
  175. data/lib/{rbui → ruby_ui}/table/table.rb +1 -1
  176. data/lib/{rbui → ruby_ui}/table/table_body.rb +1 -1
  177. data/lib/{rbui → ruby_ui}/table/table_caption.rb +1 -1
  178. data/lib/{rbui → ruby_ui}/table/table_cell.rb +1 -1
  179. data/lib/{rbui → ruby_ui}/table/table_footer.rb +1 -1
  180. data/lib/{rbui → ruby_ui}/table/table_head.rb +1 -1
  181. data/lib/{rbui → ruby_ui}/table/table_header.rb +1 -1
  182. data/lib/{rbui → ruby_ui}/table/table_row.rb +1 -1
  183. data/lib/{rbui → ruby_ui}/tabs/tabs.rb +3 -3
  184. data/lib/{rbui → ruby_ui}/tabs/tabs_content.rb +2 -2
  185. data/lib/ruby_ui/tabs/tabs_controller.js +45 -0
  186. data/lib/{rbui → ruby_ui}/tabs/tabs_list.rb +1 -1
  187. data/lib/{rbui → ruby_ui}/tabs/tabs_trigger.rb +3 -3
  188. data/lib/{rbui → ruby_ui}/textarea/textarea.rb +3 -3
  189. data/lib/{rbui → ruby_ui}/theme_toggle/theme_toggle.rb +4 -4
  190. data/lib/ruby_ui/theme_toggle/theme_toggle_controller.js +30 -0
  191. data/lib/{rbui → ruby_ui}/tooltip/tooltip.rb +3 -3
  192. data/lib/{rbui → ruby_ui}/tooltip/tooltip_content.rb +3 -3
  193. data/lib/ruby_ui/tooltip/tooltip_controller.js +37 -0
  194. data/lib/{rbui → ruby_ui}/tooltip/tooltip_trigger.rb +2 -2
  195. data/lib/ruby_ui/typography/heading.rb +60 -0
  196. data/lib/{rbui/typography/typography_inline_code.rb → ruby_ui/typography/inline_code.rb} +2 -2
  197. data/lib/{rbui/typography/typography_inline_link.rb → ruby_ui/typography/inline_link.rb} +2 -2
  198. data/lib/ruby_ui/typography/text.rb +53 -0
  199. data/lib/{rbui → ruby_ui}/typography/typography_blockquote.rb +1 -1
  200. data/lib/ruby_ui.rb +5 -1
  201. metadata +208 -173
  202. data/lib/generators/rbui/base_generator.rb +0 -17
  203. data/lib/generators/rbui/component_generator.rb +0 -137
  204. data/lib/generators/rbui/install/install_generator.rb +0 -194
  205. data/lib/rbui/calendar/calendar.rb +0 -39
  206. data/lib/rbui/combobox/combobox.rb +0 -24
  207. data/lib/rbui/combobox/combobox_content.rb +0 -31
  208. data/lib/rbui/combobox/combobox_group.rb +0 -38
  209. data/lib/rbui/combobox/combobox_input.rb +0 -22
  210. data/lib/rbui/combobox/combobox_item.rb +0 -53
  211. data/lib/rbui/combobox/combobox_list.rb +0 -29
  212. data/lib/rbui/combobox/combobox_separator.rb +0 -15
  213. data/lib/rbui/combobox/combobox_value.rb +0 -27
  214. data/lib/rbui/radio_button/radio_button.rb +0 -22
  215. data/lib/rbui/railtie.rb +0 -52
  216. data/lib/rbui/typography/typography_h1.rb +0 -17
  217. data/lib/rbui/typography/typography_h2.rb +0 -17
  218. data/lib/rbui/typography/typography_h3.rb +0 -17
  219. data/lib/rbui/typography/typography_h4.rb +0 -17
  220. data/lib/rbui/typography/typography_large.rb +0 -17
  221. data/lib/rbui/typography/typography_lead.rb +0 -17
  222. data/lib/rbui/typography/typography_list.rb +0 -47
  223. data/lib/rbui/typography/typography_muted.rb +0 -17
  224. data/lib/rbui/typography/typography_p.rb +0 -17
  225. data/lib/rbui/typography/typography_small.rb +0 -17
  226. data/lib/rbui/version.rb +0 -5
  227. data/lib/rbui.rb +0 -57
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: e8fe198601269bb419936470eb4544e7a18d649b11dca407cfccf6abab19c6d1
4
- data.tar.gz: 78c7c0804dad0d83f8e6fd4d71846946b9d11f81b474e888b70aef5c8023eaea
3
+ metadata.gz: bef04b912f756edd217e2294608bc08eef650d0e944145ef052b5a1760860682
4
+ data.tar.gz: '0792ce039b5817ce7fd9b6965c20672497ba6615ab555b2965110ce6a6817ed2'
5
5
  SHA512:
6
- metadata.gz: 5e129efa1ca42b66ed176a70d4b0548c512aaf2a617802aa5559f1215a33c820822b2ed4784c04670b67220f02bbd7c56962c770293a156ee7e7606b59cc30ef
7
- data.tar.gz: 01a600e4229632bc54cabd1abd4caf3acceb9fb689d973f74b18973b31e23247852a28d3db11b4b66532c094049d004b8987469c6240cfaccbbdeb36cb6b6e94
6
+ metadata.gz: 7c515453889a668ab223f6099407cd32c70046bd91e8e1e814ee3759e865857b83d0de87fda35b67a157da6a045794f067b1871574eff82b3d313180a62c5aff
7
+ data.tar.gz: 2cb5b4988c27072c593bf6fa88b3f40785cb8ba19c6c9627082b56260e4793978757ddac1683216e74e1a91c0052ac2474cead61ecef67c8b4249f67988b7f9b
data/LICENSE.txt ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2024 RubyUI
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,85 @@
1
+ # RubyUI (former PhlexUI) 🚀
2
+
3
+ Beautifully designed components that you can copy and paste into your apps. Accessible. Customizable. Open Source.
4
+
5
+ This is NOT a component library. It's a collection of re-usable components that you can generate or copy and paste into your apps.
6
+
7
+ Pick the components you need. Copy and paste the code into your project and customize to your needs. The code is yours.
8
+
9
+ Use this as a reference to build your own component libraries.
10
+
11
+ ### Key Features:
12
+
13
+ - **Built for Speed** ⚡: RubyUI leverages Phlex, which is up to 12x faster than traditional Rails ERB templates.
14
+ - **Stunning UI** 🎨: Design beautiful, streamlined, and customizable UIs that sell your app effortlessly.
15
+ - **Stay Organized** 📁: Keep your UI components well-organized and easy to manage.
16
+ - **Customer-Centric UX** 🧑‍💼: Create memorable app experiences for your users.
17
+ - **Completely Customizable** 🔧: Full control over the design of all components.
18
+ - **Minimal Dependencies** 🍃: Uses custom-built Stimulus.js controllers to keep your app lean.
19
+ - **Reuse with Ease** ♻️: Build components once and use them seamlessly across your project.
20
+
21
+ ### How to Use:
22
+
23
+ 1. **Find the perfect component** 🔍: Browse live-embedded components on our documentation page.
24
+ 2. **Copy the snippet** 📋: Easily copy code snippets for quick implementation.
25
+ 3. **Make it yours** 🎨: Customize components using Tailwind utility classes to fit your specific needs.
26
+
27
+ ## Installation 🚀
28
+
29
+ ### 1. Install the gem
30
+
31
+ ```bash
32
+ bundle add ruby_ui --group development --require false
33
+ ```
34
+
35
+ or add it to your Gemfile:
36
+
37
+ ```ruby
38
+ gem "ruby_ui", group: :development, require: false
39
+ ```
40
+
41
+ ### 2. Run the installer:
42
+
43
+ ```bash
44
+ bin/rails g ruby_ui:install
45
+ ```
46
+
47
+ ### 3. Done! 🎉
48
+
49
+ You can generate your components using `ruby_ui:component` generator.
50
+
51
+ ```bash
52
+ bin/rails g ruby_ui:component Accordion
53
+ ```
54
+
55
+ ## Documentation 📖
56
+
57
+ Visit https://rubyui.com/docs/introduction to view the full documentation, including:
58
+
59
+ - Detailed component guides
60
+ - Themes
61
+ - Lookbook
62
+ - Getting started guide
63
+
64
+ ## Speed Comparison 🏎️
65
+
66
+ RubyUI, powered by Phlex, outperforms alternative methods:
67
+
68
+ - Phlex: Baseline 🏁
69
+ - ViewComponent: ~1.5x slower 🚙
70
+ - ERB Templates: ~5x slower 🐢
71
+
72
+ See the original [view layers benchmark](https://github.com/KonnorRogers/view-layer-benchmarks) by @KonnorRogers and its [variations](https://github.com/KonnorRogers/view-layer-benchmarks/forks).
73
+
74
+ ## Importmap notes:
75
+
76
+ If you run into importmap issues this stackoverflow question might help:
77
+ https://stackoverflow.com/questions/70548841/how-to-add-custom-js-file-to-new-rails-7-project/72855705
78
+
79
+ ## License 📜
80
+
81
+ Licensed under the [MIT license](https://github.com/shadcn/ui/blob/main/LICENSE.md).
82
+
83
+ ---
84
+
85
+ © 2024 RubyUI. All rights reserved. 🔒
@@ -0,0 +1,94 @@
1
+ require_relative "javascript_utils"
2
+ module RubyUI
3
+ module Generators
4
+ class ComponentGenerator < Rails::Generators::Base
5
+ include RubyUI::Generators::JavascriptUtils
6
+
7
+ namespace "ruby_ui:component"
8
+
9
+ source_root File.expand_path("../../ruby_ui", __dir__)
10
+ argument :component_name, type: :string, required: true
11
+
12
+ def generate_component
13
+ if component_not_found?
14
+ say "Component not found: #{component_name}", :red
15
+ exit
16
+ end
17
+
18
+ say "Generating #{component_name} files..."
19
+ end
20
+
21
+ def copy_related_component_files
22
+ say "Generating components"
23
+
24
+ components_file_paths.each do |file_path|
25
+ component_file_name = file_path.split("/").last
26
+ copy_file file_path, Rails.root.join("app/components/ruby_ui", component_folder_name, component_file_name)
27
+ end
28
+ end
29
+
30
+ def copy_js_files
31
+ return if js_controller_file_paths.empty?
32
+
33
+ say "Generating Stimulus controllers"
34
+
35
+ js_controller_file_paths.each do |file_path|
36
+ controller_file_name = file_path.split("/").last
37
+ copy_file file_path, Rails.root.join("app/javascript/controllers/ruby_ui", controller_file_name)
38
+ end
39
+
40
+ # Importmap doesn't have controller manifest, instead it uses `eagerLoadControllersFrom("controllers", application)`
41
+ if !using_importmap?
42
+ say "Updating Stimulus controllers manifest"
43
+ run "rake stimulus:manifest:update"
44
+ end
45
+ end
46
+
47
+ def install_dependencies
48
+ return if dependencies.blank?
49
+
50
+ say "Installing dependencies"
51
+
52
+ install_components_dependencies(dependencies["components"])
53
+ install_gems_dependencies(dependencies["gems"])
54
+ install_js_packages(dependencies["js_packages"])
55
+ end
56
+
57
+ private
58
+
59
+ def component_not_found? = !Dir.exist?(component_folder_path)
60
+
61
+ def component_folder_name = component_name.underscore
62
+
63
+ def component_folder_path = File.join(self.class.source_root, component_folder_name)
64
+
65
+ def components_file_paths = Dir.glob(File.join(component_folder_path, "*.rb"))
66
+
67
+ def js_controller_file_paths = Dir.glob(File.join(component_folder_path, "*.js"))
68
+
69
+ def install_components_dependencies(components)
70
+ components&.each do |component|
71
+ run "bin/rails generate ruby_ui:component #{component}"
72
+ end
73
+ end
74
+
75
+ def install_gems_dependencies(gems)
76
+ gems&.each do |ruby_gem|
77
+ run "bundle show #{ruby_gem} > /dev/null 2>&1 || bundle add #{ruby_gem}"
78
+ end
79
+ end
80
+
81
+ def install_js_packages(js_packages)
82
+ js_packages&.each do |js_package|
83
+ install_js_package(js_package)
84
+ end
85
+ end
86
+
87
+ def dependencies
88
+ @dependencies ||= YAML.load_file(File.join(__dir__, "dependencies.yml")).freeze
89
+
90
+ @dependencies[component_folder_name]
91
+ end
92
+ end
93
+ end
94
+ end
@@ -0,0 +1,74 @@
1
+ accordion:
2
+ js_packages:
3
+ - "motion"
4
+
5
+ alert_dialog:
6
+ components:
7
+ - "Button"
8
+
9
+ calendar:
10
+ js_packages:
11
+ - "mustache"
12
+
13
+ carousel:
14
+ js_packages:
15
+ - "embla-carousel"
16
+
17
+ chart:
18
+ js_packages:
19
+ - "chart.js"
20
+
21
+ clipboard:
22
+ js_packages:
23
+ - "@floating-ui/dom"
24
+
25
+ codeblock:
26
+ components:
27
+ - "Button"
28
+ - "Clipboard"
29
+
30
+ gems:
31
+ - "rouge"
32
+
33
+ combobox:
34
+ js_packages:
35
+ - "@floating-ui/dom"
36
+
37
+ command:
38
+ js_packages:
39
+ - "fuse.js"
40
+
41
+ context_menu:
42
+ js_packages:
43
+ - "tippy.js"
44
+
45
+ dropdown_menu:
46
+ js_packages:
47
+ - "@floating-ui/dom"
48
+
49
+ hover_card:
50
+ js_packages:
51
+ - "tippy.js"
52
+
53
+ masked_input:
54
+ components:
55
+ - "Input"
56
+
57
+ js_packages:
58
+ - "maska"
59
+
60
+ pagination:
61
+ components:
62
+ - "Button"
63
+
64
+ popover:
65
+ js_packages:
66
+ - "@floating-ui/dom"
67
+
68
+ select:
69
+ js_packages:
70
+ - "@floating-ui/dom"
71
+
72
+ tooltip:
73
+ js_packages:
74
+ - "@floating-ui/dom"
@@ -0,0 +1,89 @@
1
+ require "rails/generators"
2
+ require_relative "../javascript_utils"
3
+
4
+ module RubyUI
5
+ module Generators
6
+ class InstallGenerator < Rails::Generators::Base
7
+ include RubyUI::Generators::JavascriptUtils
8
+
9
+ namespace "ruby_ui:install"
10
+
11
+ source_root File.expand_path("templates", __dir__)
12
+
13
+ def install_phlex_rails
14
+ say "Checking for phlex-rails"
15
+
16
+ if gem_installed?("phlex-rails")
17
+ say "phlex-rails is already installed", :green
18
+ else
19
+ say "Adding phlex-rails to Gemfile"
20
+ run %(bundle add phlex-rails)
21
+
22
+ say "Generating phlex-rails structure"
23
+ run "bin/rails generate phlex:install"
24
+ end
25
+ end
26
+
27
+ def install_tailwind_merge
28
+ say "Checking for tailwind_merge"
29
+
30
+ if gem_installed?("tailwind_merge")
31
+ say "tailwind_merge is already installed", :green
32
+ else
33
+ say "Adding phlex-rails to Gemfile"
34
+ run %(bundle add tailwind_merge)
35
+ end
36
+ end
37
+
38
+ def install_ruby_ui_initializer
39
+ say "Creating RubyUI initializer"
40
+ template "ruby_ui.rb.erb", Rails.root.join("config/initializers/ruby_ui.rb")
41
+ end
42
+
43
+ def add_ruby_ui_module_to_components_base
44
+ say "Adding RubyUI Kit to Components::Base"
45
+ insert_into_file Rails.root.join("app/components/base.rb"), after: "include Components" do
46
+ "\n include RubyUI"
47
+ end
48
+ end
49
+
50
+ def add_tailwind_css
51
+ say "Adding Tailwind css"
52
+
53
+ css_path = if using_importmap?
54
+ Rails.root.join("app/assets/tailwind/application.css")
55
+ else
56
+ Rails.root.join("app/assets/stylesheets/application.tailwind.css")
57
+ end
58
+
59
+ template "tailwind.css.erb", css_path
60
+ end
61
+
62
+ def install_tailwind_plugins
63
+ say "Installing tw-animate-css plugin"
64
+ install_js_package("tw-animate-css")
65
+
66
+ say "Installing @tailwindcss/forms plugin"
67
+ install_js_package("@tailwindcss/forms")
68
+
69
+ say "Installing @tailwindcss/typography plugin"
70
+ install_js_package("@tailwindcss/typography")
71
+ end
72
+
73
+ def add_ruby_ui_base
74
+ say "Adding RubyUI::Base component"
75
+ template "../../../../ruby_ui/base.rb", Rails.root.join("app/components/ruby_ui/base.rb")
76
+ end
77
+
78
+ private
79
+
80
+ def gem_installed?(name)
81
+ Gem::Specification.find_all_by_name(name).any?
82
+ end
83
+
84
+ def using_tailwindcss_rails_gem?
85
+ File.exist?(Rails.root.join("app/assets/tailwind/application.css"))
86
+ end
87
+ end
88
+ end
89
+ end
@@ -0,0 +1,18 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RubyUI
4
+ extend Phlex::Kit
5
+ end
6
+
7
+ # Allow using RubyUI instead RubyUi
8
+ Rails.autoloaders.main.inflector.inflect(
9
+ "ruby_ui" => "RubyUI"
10
+ )
11
+
12
+ # Allow using RubyUI::ComponentName instead Components::RubyUI::ComponentName
13
+ Rails.autoloaders.main.push_dir(
14
+ "#{Rails.root}/app/components/ruby_ui", namespace: RubyUI
15
+ )
16
+
17
+ # Allow using RubyUI::ComponentName instead RubyUI::ComponentName::ComponentName
18
+ Rails.autoloaders.main.collapse(Rails.root.join("app/components/ruby_ui/*"))
@@ -0,0 +1,156 @@
1
+ @import "tailwindcss";
2
+
3
+ @plugin "@tailwindcss/forms";
4
+ @plugin "@tailwindcss/typography";
5
+
6
+ <% if using_importmap? %>
7
+ @import "../../../vendor/javascript/tw-animate-css.js";
8
+ <% else %>
9
+ @import "tw-animate-css";
10
+ <% end %>
11
+
12
+ @custom-variant dark (&:is(.dark *));
13
+
14
+ :root {
15
+ --background: oklch(1 0 0);
16
+ --foreground: oklch(0.145 0 0);
17
+ --card: oklch(1 0 0);
18
+ --card-foreground: oklch(0.145 0 0);
19
+ --popover: oklch(1 0 0);
20
+ --popover-foreground: oklch(0.145 0 0);
21
+ --primary: oklch(0.205 0 0);
22
+ --primary-foreground: oklch(0.985 0 0);
23
+ --secondary: oklch(0.97 0 0);
24
+ --secondary-foreground: oklch(0.205 0 0);
25
+ --muted: oklch(0.97 0 0);
26
+ --muted-foreground: oklch(0.556 0 0);
27
+ --accent: oklch(0.97 0 0);
28
+ --accent-foreground: oklch(0.205 0 0);
29
+ --destructive: oklch(0.577 0.245 27.325);
30
+ --destructive-foreground: oklch(0.577 0.245 27.325);
31
+ --border: oklch(0.922 0 0);
32
+ --input: oklch(0.922 0 0);
33
+ --ring: oklch(0.708 0 0);
34
+ --chart-1: oklch(0.646 0.222 41.116);
35
+ --chart-2: oklch(0.6 0.118 184.704);
36
+ --chart-3: oklch(0.398 0.07 227.392);
37
+ --chart-4: oklch(0.828 0.189 84.429);
38
+ --chart-5: oklch(0.769 0.188 70.08);
39
+ --radius: 0.625rem;
40
+ --sidebar: oklch(0.985 0 0);
41
+ --sidebar-foreground: oklch(0.145 0 0);
42
+ --sidebar-primary: oklch(0.205 0 0);
43
+ --sidebar-primary-foreground: oklch(0.985 0 0);
44
+ --sidebar-accent: oklch(0.97 0 0);
45
+ --sidebar-accent-foreground: oklch(0.205 0 0);
46
+ --sidebar-border: oklch(0.922 0 0);
47
+ --sidebar-ring: oklch(0.708 0 0);
48
+
49
+ /* ruby_ui specific */
50
+ --warning: hsl(38 92% 50%);
51
+ --warning-foreground: hsl(0 0% 100%);
52
+ --success: hsl(87 100% 37%);
53
+ --success-foreground: hsl(0 0% 100%);
54
+ }
55
+
56
+ .dark {
57
+ --background: oklch(0.145 0 0);
58
+ --foreground: oklch(0.985 0 0);
59
+ --card: oklch(0.145 0 0);
60
+ --card-foreground: oklch(0.985 0 0);
61
+ --popover: oklch(0.145 0 0);
62
+ --popover-foreground: oklch(0.985 0 0);
63
+ --primary: oklch(0.985 0 0);
64
+ --primary-foreground: oklch(0.205 0 0);
65
+ --secondary: oklch(0.269 0 0);
66
+ --secondary-foreground: oklch(0.985 0 0);
67
+ --muted: oklch(0.269 0 0);
68
+ --muted-foreground: oklch(0.708 0 0);
69
+ --accent: oklch(0.269 0 0);
70
+ --accent-foreground: oklch(0.985 0 0);
71
+ --destructive: oklch(0.396 0.141 25.723);
72
+ --destructive-foreground: oklch(0.637 0.237 25.331);
73
+ --border: oklch(0.269 0 0);
74
+ --input: oklch(0.269 0 0);
75
+ --ring: oklch(0.439 0 0);
76
+ --chart-1: oklch(0.488 0.243 264.376);
77
+ --chart-2: oklch(0.696 0.17 162.48);
78
+ --chart-3: oklch(0.769 0.188 70.08);
79
+ --chart-4: oklch(0.627 0.265 303.9);
80
+ --chart-5: oklch(0.645 0.246 16.439);
81
+ --sidebar: oklch(0.205 0 0);
82
+ --sidebar-foreground: oklch(0.985 0 0);
83
+ --sidebar-primary: oklch(0.488 0.243 264.376);
84
+ --sidebar-primary-foreground: oklch(0.985 0 0);
85
+ --sidebar-accent: oklch(0.269 0 0);
86
+ --sidebar-accent-foreground: oklch(0.985 0 0);
87
+ --sidebar-border: oklch(0.269 0 0);
88
+ --sidebar-ring: oklch(0.439 0 0);
89
+
90
+ /* ruby_ui specific */
91
+ --warning: hsl(38 92% 50%);
92
+ --warning-foreground: hsl(0 0% 100%);
93
+ --success: hsl(84 81% 44%);
94
+ --success-foreground: hsl(0 0% 100%);
95
+ }
96
+
97
+ @theme inline {
98
+ --color-background: var(--background);
99
+ --color-foreground: var(--foreground);
100
+ --color-card: var(--card);
101
+ --color-card-foreground: var(--card-foreground);
102
+ --color-popover: var(--popover);
103
+ --color-popover-foreground: var(--popover-foreground);
104
+ --color-primary: var(--primary);
105
+ --color-primary-foreground: var(--primary-foreground);
106
+ --color-secondary: var(--secondary);
107
+ --color-secondary-foreground: var(--secondary-foreground);
108
+ --color-muted: var(--muted);
109
+ --color-muted-foreground: var(--muted-foreground);
110
+ --color-accent: var(--accent);
111
+ --color-accent-foreground: var(--accent-foreground);
112
+ --color-destructive: var(--destructive);
113
+ --color-destructive-foreground: var(--destructive-foreground);
114
+ --color-border: var(--border);
115
+ --color-input: var(--input);
116
+ --color-ring: var(--ring);
117
+ --color-chart-1: var(--chart-1);
118
+ --color-chart-2: var(--chart-2);
119
+ --color-chart-3: var(--chart-3);
120
+ --color-chart-4: var(--chart-4);
121
+ --color-chart-5: var(--chart-5);
122
+ --radius-sm: calc(var(--radius) - 4px);
123
+ --radius-md: calc(var(--radius) - 2px);
124
+ --radius-lg: var(--radius);
125
+ --radius-xl: calc(var(--radius) + 4px);
126
+ --color-sidebar: var(--sidebar);
127
+ --color-sidebar-foreground: var(--sidebar-foreground);
128
+ --color-sidebar-primary: var(--sidebar-primary);
129
+ --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
130
+ --color-sidebar-accent: var(--sidebar-accent);
131
+ --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
132
+ --color-sidebar-border: var(--sidebar-border);
133
+ --color-sidebar-ring: var(--sidebar-ring);
134
+
135
+ /* ruby_ui specific */
136
+ --color-warning: var(--warning);
137
+ --color-warning-foreground: var(--warning-foreground);
138
+ --color-success: var(--success);
139
+ --color-success-foreground: var(--success-foreground);
140
+ }
141
+
142
+ /* Container settings */
143
+ @utility container {
144
+ margin-inline: auto;
145
+ padding-inline: 2rem;
146
+ max-width: 1400px;
147
+ }
148
+
149
+ @layer base {
150
+ * {
151
+ @apply border-border outline-ring/50;
152
+ }
153
+ body {
154
+ @apply bg-background text-foreground;
155
+ }
156
+ }
@@ -0,0 +1,57 @@
1
+ module RubyUI
2
+ module Generators
3
+ module JavascriptUtils
4
+ def install_js_package(package)
5
+ if using_importmap?
6
+ pin_with_importmap(package)
7
+ elsif using_yarn?
8
+ run "yarn add #{package}"
9
+ elsif using_npm?
10
+ run "npm install #{package}"
11
+ else
12
+ say "Could not detect the package manager, you need to install '#{package}' manually", :red
13
+ end
14
+ end
15
+
16
+ def pin_with_importmap(package)
17
+ case package
18
+ when "motion"
19
+ pin_motion
20
+ when "tippy.js"
21
+ pin_tippy_js
22
+ else
23
+ run "bin/importmap pin #{package}"
24
+ end
25
+ end
26
+
27
+ def using_importmap?
28
+ File.exist?(Rails.root.join("config/importmap.rb")) && File.exist?(Rails.root.join("bin/importmap"))
29
+ end
30
+
31
+ def using_npm? = File.exist?(Rails.root.join("package-lock.json"))
32
+
33
+ def using_yarn? = File.exist?(Rails.root.join("yarn.lock"))
34
+
35
+ def pin_motion
36
+ say <<~TEXT
37
+ WARNING: Installing motion from CDN because `bin/importmap pin motion` doesn't download the correct file.
38
+ TEXT
39
+
40
+ inject_into_file Rails.root.join("config/importmap.rb"), <<~RUBY
41
+ pin "motion", to: "https://cdn.jsdelivr.net/npm/motion@11.11.17/+esm"\n
42
+ RUBY
43
+ end
44
+
45
+ def pin_tippy_js
46
+ say <<~TEXT
47
+ WARNING: Installing tippy.js from CDN because `bin/importmap pin tippy.js` doesn't download the correct file.
48
+ TEXT
49
+
50
+ inject_into_file Rails.root.join("config/importmap.rb"), <<~RUBY
51
+ pin "tippy.js", to: "https://cdn.jsdelivr.net/npm/tippy.js@6.3.7/+esm"
52
+ pin "@popperjs/core", to: "https://cdn.jsdelivr.net/npm/@popperjs/core@2.11.8/+esm"\n
53
+ RUBY
54
+ end
55
+ end
56
+ end
57
+ end
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- module RBUI
3
+ module RubyUI
4
4
  class Accordion < Base
5
5
  def view_template(&)
6
6
  div(**attrs, &)
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- module RBUI
3
+ module RubyUI
4
4
  class AccordionContent < Base
5
5
  def view_template(&)
6
6
  div(**attrs, &)
@@ -11,7 +11,7 @@ module RBUI
11
11
  def default_attrs
12
12
  {
13
13
  data: {
14
- rbui__accordion_target: "content"
14
+ ruby_ui__accordion_target: "content"
15
15
  },
16
16
  class: "overflow-y-hidden",
17
17
  style: "height: 0px;"