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.
- checksums.yaml +4 -4
- data/LICENSE.txt +21 -0
- data/README.md +85 -0
- data/lib/generators/ruby_ui/component_generator.rb +94 -0
- data/lib/generators/ruby_ui/dependencies.yml +74 -0
- data/lib/generators/ruby_ui/install/install_generator.rb +89 -0
- data/lib/generators/ruby_ui/install/templates/ruby_ui.rb.erb +18 -0
- data/lib/generators/ruby_ui/install/templates/tailwind.css.erb +156 -0
- data/lib/generators/ruby_ui/javascript_utils.rb +57 -0
- data/lib/{rbui → ruby_ui}/accordion/accordion.rb +1 -1
- data/lib/{rbui → ruby_ui}/accordion/accordion_content.rb +2 -2
- data/lib/ruby_ui/accordion/accordion_controller.js +97 -0
- data/lib/{rbui → ruby_ui}/accordion/accordion_default_content.rb +1 -1
- data/lib/{rbui → ruby_ui}/accordion/accordion_default_trigger.rb +3 -3
- data/lib/{rbui → ruby_ui}/accordion/accordion_icon.rb +2 -2
- data/lib/{rbui → ruby_ui}/accordion/accordion_item.rb +4 -4
- data/lib/{rbui → ruby_ui}/accordion/accordion_trigger.rb +3 -2
- data/lib/{rbui → ruby_ui}/alert/alert.rb +3 -3
- data/lib/{rbui → ruby_ui}/alert/alert_description.rb +1 -1
- data/lib/{rbui → ruby_ui}/alert/alert_title.rb +1 -1
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog.rb +3 -3
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_action.rb +2 -2
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_cancel.rb +3 -3
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_content.rb +5 -5
- data/lib/ruby_ui/alert_dialog/alert_dialog_controller.js +31 -0
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_description.rb +1 -1
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_footer.rb +2 -2
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_header.rb +2 -2
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_title.rb +1 -1
- data/lib/{rbui → ruby_ui}/alert_dialog/alert_dialog_trigger.rb +2 -2
- data/lib/{rbui → ruby_ui}/aspect_ratio/aspect_ratio.rb +1 -1
- data/lib/{rbui → ruby_ui}/avatar/avatar.rb +2 -2
- data/lib/{rbui → ruby_ui}/avatar/avatar_fallback.rb +1 -1
- data/lib/{rbui → ruby_ui}/avatar/avatar_image.rb +1 -1
- data/lib/{rbui → ruby_ui}/badge/badge.rb +2 -2
- data/lib/{rbui → ruby_ui}/base.rb +1 -8
- data/lib/ruby_ui/breadcrumb/breadcrumb.rb +17 -0
- data/lib/ruby_ui/breadcrumb/breadcrumb_ellipsis.rb +39 -0
- data/lib/{rbui/typography/typography_list_item.rb → ruby_ui/breadcrumb/breadcrumb_item.rb} +3 -3
- data/lib/ruby_ui/breadcrumb/breadcrumb_link.rb +22 -0
- data/lib/ruby_ui/breadcrumb/breadcrumb_list.rb +17 -0
- data/lib/ruby_ui/breadcrumb/breadcrumb_page.rb +19 -0
- data/lib/ruby_ui/breadcrumb/breadcrumb_separator.rb +38 -0
- data/lib/{rbui → ruby_ui}/button/button.rb +13 -13
- data/lib/ruby_ui/calendar/calendar.rb +39 -0
- data/lib/{rbui → ruby_ui}/calendar/calendar_body.rb +2 -2
- data/lib/ruby_ui/calendar/calendar_controller.js +249 -0
- data/lib/{rbui → ruby_ui}/calendar/calendar_days.rb +14 -14
- data/lib/{rbui → ruby_ui}/calendar/calendar_header.rb +1 -1
- data/lib/ruby_ui/calendar/calendar_input_controller.js +8 -0
- data/lib/{rbui → ruby_ui}/calendar/calendar_next.rb +2 -2
- data/lib/{rbui → ruby_ui}/calendar/calendar_prev.rb +2 -2
- data/lib/{rbui → ruby_ui}/calendar/calendar_title.rb +2 -2
- data/lib/{rbui → ruby_ui}/calendar/calendar_weekdays.rb +2 -2
- data/lib/{rbui → ruby_ui}/card/card.rb +1 -1
- data/lib/{rbui → ruby_ui}/card/card_content.rb +1 -1
- data/lib/{rbui → ruby_ui}/card/card_description.rb +1 -1
- data/lib/{rbui → ruby_ui}/card/card_footer.rb +1 -1
- data/lib/{rbui → ruby_ui}/card/card_header.rb +1 -1
- data/lib/{rbui → ruby_ui}/card/card_title.rb +1 -1
- data/lib/ruby_ui/carousel/carousel.rb +44 -0
- data/lib/ruby_ui/carousel/carousel_content.rb +23 -0
- data/lib/ruby_ui/carousel/carousel_controller.js +60 -0
- data/lib/ruby_ui/carousel/carousel_item.rb +23 -0
- data/lib/ruby_ui/carousel/carousel_next.rb +48 -0
- data/lib/ruby_ui/carousel/carousel_previous.rb +49 -0
- data/lib/{rbui → ruby_ui}/chart/chart.rb +3 -3
- data/lib/ruby_ui/chart/chart_controller.js +103 -0
- data/lib/{rbui → ruby_ui}/checkbox/checkbox.rb +4 -4
- data/lib/{rbui → ruby_ui}/checkbox/checkbox_group.rb +2 -2
- data/lib/ruby_ui/checkbox/checkbox_group_controller.js +21 -0
- data/lib/{rbui → ruby_ui}/clipboard/clipboard.rb +6 -6
- data/lib/ruby_ui/clipboard/clipboard_controller.js +54 -0
- data/lib/{rbui → ruby_ui}/clipboard/clipboard_popover.rb +2 -2
- data/lib/{rbui → ruby_ui}/clipboard/clipboard_source.rb +2 -2
- data/lib/{rbui → ruby_ui}/clipboard/clipboard_trigger.rb +3 -3
- data/lib/{rbui → ruby_ui}/codeblock/codeblock.rb +7 -10
- data/lib/{rbui → ruby_ui}/collapsible/collapsible.rb +3 -3
- data/lib/{rbui → ruby_ui}/collapsible/collapsible_content.rb +2 -2
- data/lib/ruby_ui/collapsible/collapsible_controller.js +47 -0
- data/lib/{rbui → ruby_ui}/collapsible/collapsible_trigger.rb +2 -2
- data/lib/ruby_ui/combobox/combobox.rb +26 -0
- data/lib/ruby_ui/combobox/combobox_checkbox.rb +25 -0
- data/lib/ruby_ui/combobox/combobox_controller.js +176 -0
- data/lib/{rbui/combobox/combobox_empty.rb → ruby_ui/combobox/combobox_empty_state.rb} +3 -3
- data/lib/ruby_ui/combobox/combobox_item.rb +25 -0
- data/lib/ruby_ui/combobox/combobox_list.rb +18 -0
- data/lib/ruby_ui/combobox/combobox_list_group.rb +20 -0
- data/lib/ruby_ui/combobox/combobox_popover.rb +30 -0
- data/lib/ruby_ui/combobox/combobox_radio.rb +26 -0
- data/lib/{rbui → ruby_ui}/combobox/combobox_search_input.rb +22 -25
- data/lib/ruby_ui/combobox/combobox_toggle_all_checkbox.rb +25 -0
- data/lib/{rbui → ruby_ui}/combobox/combobox_trigger.rb +26 -21
- data/lib/{rbui → ruby_ui}/command/command.rb +1 -1
- data/lib/ruby_ui/command/command_controller.js +136 -0
- data/lib/{rbui → ruby_ui}/command/command_dialog.rb +2 -2
- data/lib/{rbui → ruby_ui}/command/command_dialog_content.rb +6 -6
- data/lib/{rbui → ruby_ui}/command/command_dialog_trigger.rb +3 -3
- data/lib/{rbui → ruby_ui}/command/command_empty.rb +2 -2
- data/lib/{rbui → ruby_ui}/command/command_group.rb +2 -2
- data/lib/{rbui → ruby_ui}/command/command_input.rb +3 -3
- data/lib/{rbui → ruby_ui}/command/command_item.rb +2 -2
- data/lib/{rbui → ruby_ui}/command/command_list.rb +1 -1
- data/lib/{rbui → ruby_ui}/context_menu/context_menu.rb +2 -2
- data/lib/{rbui → ruby_ui}/context_menu/context_menu_content.rb +2 -2
- data/lib/ruby_ui/context_menu/context_menu_controller.js +144 -0
- data/lib/{rbui → ruby_ui}/context_menu/context_menu_item.rb +3 -3
- data/lib/{rbui → ruby_ui}/context_menu/context_menu_label.rb +2 -2
- data/lib/{rbui → ruby_ui}/context_menu/context_menu_separator.rb +1 -1
- data/lib/{rbui → ruby_ui}/context_menu/context_menu_trigger.rb +3 -3
- data/lib/{rbui → ruby_ui}/dialog/dialog.rb +3 -3
- data/lib/{rbui → ruby_ui}/dialog/dialog_content.rb +9 -9
- data/lib/ruby_ui/dialog/dialog_controller.js +32 -0
- data/lib/{rbui → ruby_ui}/dialog/dialog_description.rb +1 -1
- data/lib/{rbui → ruby_ui}/dialog/dialog_footer.rb +2 -2
- data/lib/{rbui → ruby_ui}/dialog/dialog_header.rb +2 -2
- data/lib/{rbui → ruby_ui}/dialog/dialog_middle.rb +1 -1
- data/lib/{rbui → ruby_ui}/dialog/dialog_title.rb +1 -1
- data/lib/{rbui → ruby_ui}/dialog/dialog_trigger.rb +2 -2
- data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu.rb +4 -4
- data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_content.rb +2 -2
- data/lib/ruby_ui/dropdown_menu/dropdown_menu_controller.js +120 -0
- data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_item.rb +3 -3
- data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_label.rb +1 -1
- data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_separator.rb +1 -1
- data/lib/{rbui → ruby_ui}/dropdown_menu/dropdown_menu_trigger.rb +2 -2
- data/lib/{rbui → ruby_ui}/form/form.rb +1 -1
- data/lib/{rbui → ruby_ui}/form/form_field.rb +2 -2
- data/lib/ruby_ui/form/form_field_controller.js +61 -0
- data/lib/{rbui → ruby_ui}/form/form_field_error.rb +2 -2
- data/lib/{rbui → ruby_ui}/form/form_field_hint.rb +1 -1
- data/lib/{rbui → ruby_ui}/form/form_field_label.rb +1 -1
- data/lib/{rbui → ruby_ui}/hover_card/hover_card.rb +3 -3
- data/lib/{rbui → ruby_ui}/hover_card/hover_card_content.rb +2 -2
- data/lib/ruby_ui/hover_card/hover_card_controller.js +144 -0
- data/lib/{rbui → ruby_ui}/hover_card/hover_card_trigger.rb +2 -2
- data/lib/{rbui → ruby_ui}/input/input.rb +3 -3
- data/lib/{rbui → ruby_ui}/link/link.rb +13 -13
- data/lib/ruby_ui/masked_input/masked_input.rb +15 -0
- data/lib/ruby_ui/masked_input/masked_input_controller.js +9 -0
- data/lib/{rbui → ruby_ui}/pagination/pagination.rb +1 -1
- data/lib/{rbui → ruby_ui}/pagination/pagination_content.rb +1 -1
- data/lib/{rbui → ruby_ui}/pagination/pagination_ellipsis.rb +1 -1
- data/lib/{rbui → ruby_ui}/pagination/pagination_item.rb +4 -4
- data/lib/{rbui → ruby_ui}/popover/popover.rb +4 -4
- data/lib/{rbui → ruby_ui}/popover/popover_content.rb +2 -2
- data/lib/ruby_ui/popover/popover_controller.js +107 -0
- data/lib/{rbui → ruby_ui}/popover/popover_trigger.rb +2 -2
- data/lib/ruby_ui/progress/progress.rb +37 -0
- data/lib/ruby_ui/radio_button/radio_button.rb +25 -0
- data/lib/{rbui → ruby_ui}/select/select.rb +5 -5
- data/lib/{rbui → ruby_ui}/select/select_content.rb +3 -3
- data/lib/ruby_ui/select/select_controller.js +171 -0
- data/lib/{rbui → ruby_ui}/select/select_group.rb +1 -1
- data/lib/{rbui → ruby_ui}/select/select_input.rb +4 -4
- data/lib/{rbui → ruby_ui}/select/select_item.rb +4 -4
- data/lib/ruby_ui/select/select_item_controller.js +11 -0
- data/lib/{rbui → ruby_ui}/select/select_label.rb +1 -1
- data/lib/{rbui → ruby_ui}/select/select_trigger.rb +3 -3
- data/lib/{rbui → ruby_ui}/select/select_value.rb +3 -3
- data/lib/ruby_ui/separator/separator.rb +38 -0
- data/lib/{rbui → ruby_ui}/sheet/sheet.rb +2 -2
- data/lib/{rbui → ruby_ui}/sheet/sheet_content.rb +8 -8
- data/lib/ruby_ui/sheet/sheet_content_controller.js +7 -0
- data/lib/ruby_ui/sheet/sheet_controller.js +9 -0
- data/lib/{rbui → ruby_ui}/sheet/sheet_description.rb +1 -1
- data/lib/{rbui → ruby_ui}/sheet/sheet_footer.rb +1 -1
- data/lib/{rbui → ruby_ui}/sheet/sheet_header.rb +1 -1
- data/lib/{rbui → ruby_ui}/sheet/sheet_middle.rb +1 -1
- data/lib/{rbui → ruby_ui}/sheet/sheet_title.rb +1 -1
- data/lib/{rbui → ruby_ui}/sheet/sheet_trigger.rb +2 -2
- data/lib/{rbui → ruby_ui}/shortcut_key/shortcut_key.rb +1 -1
- data/lib/ruby_ui/skeleton/skeleton.rb +17 -0
- data/lib/ruby_ui/switch/switch.rb +24 -0
- data/lib/{rbui → ruby_ui}/table/table.rb +1 -1
- data/lib/{rbui → ruby_ui}/table/table_body.rb +1 -1
- data/lib/{rbui → ruby_ui}/table/table_caption.rb +1 -1
- data/lib/{rbui → ruby_ui}/table/table_cell.rb +1 -1
- data/lib/{rbui → ruby_ui}/table/table_footer.rb +1 -1
- data/lib/{rbui → ruby_ui}/table/table_head.rb +1 -1
- data/lib/{rbui → ruby_ui}/table/table_header.rb +1 -1
- data/lib/{rbui → ruby_ui}/table/table_row.rb +1 -1
- data/lib/{rbui → ruby_ui}/tabs/tabs.rb +3 -3
- data/lib/{rbui → ruby_ui}/tabs/tabs_content.rb +2 -2
- data/lib/ruby_ui/tabs/tabs_controller.js +45 -0
- data/lib/{rbui → ruby_ui}/tabs/tabs_list.rb +1 -1
- data/lib/{rbui → ruby_ui}/tabs/tabs_trigger.rb +3 -3
- data/lib/{rbui → ruby_ui}/textarea/textarea.rb +3 -3
- data/lib/{rbui → ruby_ui}/theme_toggle/theme_toggle.rb +4 -4
- data/lib/ruby_ui/theme_toggle/theme_toggle_controller.js +30 -0
- data/lib/{rbui → ruby_ui}/tooltip/tooltip.rb +3 -3
- data/lib/{rbui → ruby_ui}/tooltip/tooltip_content.rb +3 -3
- data/lib/ruby_ui/tooltip/tooltip_controller.js +37 -0
- data/lib/{rbui → ruby_ui}/tooltip/tooltip_trigger.rb +2 -2
- data/lib/ruby_ui/typography/heading.rb +60 -0
- data/lib/{rbui/typography/typography_inline_code.rb → ruby_ui/typography/inline_code.rb} +2 -2
- data/lib/{rbui/typography/typography_inline_link.rb → ruby_ui/typography/inline_link.rb} +2 -2
- data/lib/ruby_ui/typography/text.rb +53 -0
- data/lib/{rbui → ruby_ui}/typography/typography_blockquote.rb +1 -1
- data/lib/ruby_ui.rb +5 -1
- metadata +208 -173
- data/lib/generators/rbui/base_generator.rb +0 -17
- data/lib/generators/rbui/component_generator.rb +0 -137
- data/lib/generators/rbui/install/install_generator.rb +0 -194
- data/lib/rbui/calendar/calendar.rb +0 -39
- data/lib/rbui/combobox/combobox.rb +0 -24
- data/lib/rbui/combobox/combobox_content.rb +0 -31
- data/lib/rbui/combobox/combobox_group.rb +0 -38
- data/lib/rbui/combobox/combobox_input.rb +0 -22
- data/lib/rbui/combobox/combobox_item.rb +0 -53
- data/lib/rbui/combobox/combobox_list.rb +0 -29
- data/lib/rbui/combobox/combobox_separator.rb +0 -15
- data/lib/rbui/combobox/combobox_value.rb +0 -27
- data/lib/rbui/radio_button/radio_button.rb +0 -22
- data/lib/rbui/railtie.rb +0 -52
- data/lib/rbui/typography/typography_h1.rb +0 -17
- data/lib/rbui/typography/typography_h2.rb +0 -17
- data/lib/rbui/typography/typography_h3.rb +0 -17
- data/lib/rbui/typography/typography_h4.rb +0 -17
- data/lib/rbui/typography/typography_large.rb +0 -17
- data/lib/rbui/typography/typography_lead.rb +0 -17
- data/lib/rbui/typography/typography_list.rb +0 -47
- data/lib/rbui/typography/typography_muted.rb +0 -17
- data/lib/rbui/typography/typography_p.rb +0 -17
- data/lib/rbui/typography/typography_small.rb +0 -17
- data/lib/rbui/version.rb +0 -5
- data/lib/rbui.rb +0 -57
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: bef04b912f756edd217e2294608bc08eef650d0e944145ef052b5a1760860682
|
4
|
+
data.tar.gz: '0792ce039b5817ce7fd9b6965c20672497ba6615ab555b2965110ce6a6817ed2'
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
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
|
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
|
-
|
14
|
+
ruby_ui__accordion_target: "content"
|
15
15
|
},
|
16
16
|
class: "overflow-y-hidden",
|
17
17
|
style: "height: 0px;"
|