shadcn-ui 0.0.2 → 0.0.4

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 (154) hide show
  1. checksums.yaml +4 -4
  2. data/.env +1 -0
  3. data/Rakefile +6 -3
  4. data/app/assets/stylesheets/{application.scss → application.css} +0 -27
  5. data/app/assets/stylesheets/application.tailwind.css +32 -160
  6. data/app/assets/stylesheets/shadcn.css +216 -0
  7. data/app/helpers/components/accordion_helper.rb +14 -1
  8. data/app/helpers/components/alert_helper.rb +4 -2
  9. data/app/helpers/components/button_helper.rb +2 -1
  10. data/app/helpers/components/card_helper.rb +1 -1
  11. data/app/helpers/components/checkbox_helper.rb +2 -2
  12. data/app/helpers/components/collapsible_helper.rb +8 -0
  13. data/app/helpers/components/input_helper.rb +1 -1
  14. data/app/helpers/components/sheet_helper.rb +9 -0
  15. data/app/helpers/components/slider_helper.rb +1 -1
  16. data/app/helpers/components_helper.rb +11 -0
  17. data/app/helpers/examples_helper.rb +7 -3
  18. data/app/javascript/controllers/highlight_controller.js +0 -1
  19. data/app/javascript/controllers/ui/popover_controller.js +6 -2
  20. data/app/views/application/index.html.erb +625 -17
  21. data/app/views/components/ui/_accordion.html.erb +2 -2
  22. data/app/views/components/ui/_alert.html.erb +15 -3
  23. data/app/views/components/ui/_card.html.erb +7 -1
  24. data/app/views/components/ui/_checkbox.html.erb +2 -1
  25. data/app/views/components/ui/_collapsible.html.erb +2 -6
  26. data/app/views/components/ui/_filter.html.erb +2 -1
  27. data/app/views/components/ui/_sheet.html.erb +1 -1
  28. data/app/views/documentation/generators.html.md +21 -0
  29. data/app/views/documentation/helpers.html.md +54 -0
  30. data/app/views/documentation/index.html.md +22 -0
  31. data/app/views/documentation/installation.html.md +130 -2
  32. data/app/views/documentation/javascript.html.md +8 -0
  33. data/app/views/examples/components/accordion/_usage.html.erb +15 -0
  34. data/app/views/examples/components/accordion/code/_block.html.erb +8 -0
  35. data/app/views/examples/components/accordion/code/_description.html.erb +7 -0
  36. data/app/views/examples/components/accordion/code/_preview.erb +3 -0
  37. data/app/views/examples/components/accordion/code/_usage.erb +16 -0
  38. data/app/views/examples/components/accordion.html.erb +37 -3
  39. data/app/views/examples/components/alert/_usage.html.erb +10 -0
  40. data/app/views/examples/components/alert/code/_attention.erb +3 -0
  41. data/app/views/examples/components/alert/code/_destructive.erb +2 -0
  42. data/app/views/examples/components/alert/code/_info.erb +3 -0
  43. data/app/views/examples/components/alert/code/_no_icon.erb +3 -0
  44. data/app/views/examples/components/alert/code/_preview.erb +2 -0
  45. data/app/views/examples/components/alert/code/_success.erb +3 -0
  46. data/app/views/examples/components/alert/code/_usage.erb +1 -0
  47. data/app/views/examples/components/alert-dialog/code/_preview.erb +6 -0
  48. data/app/views/examples/components/alert-dialog/code/_usage.erb +0 -0
  49. data/app/views/examples/components/alert-dialog.html.erb +8 -11
  50. data/app/views/examples/components/alert.html.erb +90 -8
  51. data/app/views/examples/components/badge/_usage.html.erb +10 -0
  52. data/app/views/examples/components/badge/code/_preview.erb +5 -0
  53. data/app/views/examples/components/badge/code/_usage.erb +1 -0
  54. data/app/views/examples/components/badge.html.erb +12 -17
  55. data/app/views/examples/components/button/_usage.html.erb +19 -0
  56. data/app/views/examples/components/button/code/_preview.erb +13 -0
  57. data/app/views/examples/components/button/code/_usage.erb +6 -0
  58. data/app/views/examples/components/button.html.erb +12 -20
  59. data/app/views/examples/components/card/_usage.html.erb +21 -0
  60. data/app/views/examples/components/card/code/_form.erb +72 -0
  61. data/app/views/examples/components/card/code/_notifications.erb +61 -0
  62. data/app/views/examples/components/card/code/_preview.erb +6 -0
  63. data/app/views/examples/components/card/code/_usage.erb +3 -0
  64. data/app/views/examples/components/card.html.erb +31 -143
  65. data/app/views/examples/components/checkbox/_usage.html.erb +9 -0
  66. data/app/views/examples/components/checkbox/code/_preview.erb +2 -0
  67. data/app/views/examples/components/checkbox/code/_usage.erb +1 -0
  68. data/app/views/examples/components/checkbox.html.erb +15 -1
  69. data/app/views/examples/components/collapsible/_usage.html.erb +16 -0
  70. data/app/views/examples/components/collapsible/code/_preview.erb +9 -0
  71. data/app/views/examples/components/collapsible/code/_usage.erb +7 -0
  72. data/app/views/examples/components/collapsible.html.erb +12 -10
  73. data/app/views/examples/components/dialog.html.erb +6 -15
  74. data/app/views/examples/components/dropdown-menu/_usage.html.erb +19 -0
  75. data/app/views/examples/components/dropdown-menu/code/_preview.erb +19 -0
  76. data/app/views/examples/components/dropdown-menu/code/_usage.erb +13 -0
  77. data/app/views/examples/components/dropdown-menu.html.erb +29 -15
  78. data/app/views/examples/components/filter/_usage.html.erb +14 -0
  79. data/app/views/examples/components/filter/code/_icon.html.erb +7 -0
  80. data/app/views/examples/components/filter/code/_preview.erb +3 -0
  81. data/app/views/examples/components/filter/code/_usage.erb +5 -0
  82. data/app/views/examples/components/filter.html.erb +27 -7
  83. data/app/views/examples/components/hover-card/_usage.html.erb +15 -0
  84. data/app/views/examples/components/hover-card/code/_preview.erb +13 -0
  85. data/app/views/examples/components/hover-card/code/_usage.erb +6 -0
  86. data/app/views/examples/components/hover-card.html.erb +12 -14
  87. data/app/views/examples/components/input/_usage.html.erb +10 -0
  88. data/app/views/examples/components/input/code/_borderless.erb +3 -0
  89. data/app/views/examples/components/input/code/_preview.erb +1 -0
  90. data/app/views/examples/components/input/code/_usage.erb +1 -0
  91. data/app/views/examples/components/input.html.erb +17 -3
  92. data/app/views/examples/components/label/_usage.html.erb +9 -0
  93. data/app/views/examples/components/label/code/_preview.erb +5 -0
  94. data/app/views/examples/components/label/code/_usage.erb +1 -0
  95. data/app/views/examples/components/label.html.erb +14 -5
  96. data/app/views/examples/components/popover/_usage.html.erb +12 -0
  97. data/app/views/examples/components/popover/code/_form.erb +23 -0
  98. data/app/views/examples/components/popover/code/_preview.erb +13 -0
  99. data/app/views/examples/components/popover/code/_usage.erb +7 -0
  100. data/app/views/examples/components/popover.html.erb +28 -24
  101. data/app/views/examples/components/progress/_usage.erb +9 -0
  102. data/app/views/examples/components/progress/code/_preview.erb +1 -0
  103. data/app/views/examples/components/progress/code/_usage.erb +1 -0
  104. data/app/views/examples/components/progress.html.erb +12 -2
  105. data/app/views/examples/components/separator/_usage.html.erb +10 -0
  106. data/app/views/examples/components/separator/code/_fancy.erb +21 -0
  107. data/app/views/examples/components/separator/code/_preview.erb +1 -0
  108. data/app/views/examples/components/separator/code/_usage.erb +1 -0
  109. data/app/views/examples/components/separator.html.erb +26 -19
  110. data/app/views/examples/components/sheet/_usage.html.erb +38 -0
  111. data/app/views/examples/components/sheet/code/_mobile_menu.erb +17 -0
  112. data/app/views/examples/components/sheet/code/_preview.erb +22 -0
  113. data/app/views/examples/components/sheet/code/_usage.erb +7 -0
  114. data/app/views/examples/components/sheet.html.erb +17 -10
  115. data/app/views/examples/components/skeleton/_usage.html.erb +9 -0
  116. data/app/views/examples/components/skeleton/code/_preview.erb +1 -0
  117. data/app/views/examples/components/skeleton/code/_usage.erb +1 -0
  118. data/app/views/examples/components/skeleton.html.erb +16 -2
  119. data/app/views/examples/components/slider/_usage.html.erb +11 -0
  120. data/app/views/examples/components/slider/code/_preview.erb +3 -0
  121. data/app/views/examples/components/slider/code/_usage.erb +1 -0
  122. data/app/views/examples/components/slider.html.erb +16 -2
  123. data/app/views/examples/components/textarea/_usage.html.erb +9 -0
  124. data/app/views/examples/components/textarea/code/_preview.erb +1 -0
  125. data/app/views/examples/components/textarea/code/_usage.erb +1 -0
  126. data/app/views/examples/components/textarea.html.erb +16 -2
  127. data/app/views/examples/components/toast/_usage.html.erb +11 -0
  128. data/app/views/examples/components/toast/code/_preview.erb +3 -0
  129. data/app/views/examples/components/toast/code/_usage.erb +2 -0
  130. data/app/views/examples/components/toast.html.erb +12 -4
  131. data/app/views/examples/components/toggle/_usage.html.erb +10 -0
  132. data/app/views/examples/components/toggle/code/_preview.erb +1 -0
  133. data/app/views/examples/components/toggle/code/_usage.erb +1 -0
  134. data/app/views/examples/components/toggle.html.erb +16 -2
  135. data/app/views/examples/components/tooltip/_usage.html.erb +11 -0
  136. data/app/views/examples/components/tooltip/code/_preview.erb +12 -0
  137. data/app/views/examples/components/tooltip/code/_usage.erb +7 -0
  138. data/app/views/examples/components/tooltip.html.erb +16 -13
  139. data/app/views/layouts/shared/_components.html.erb +44 -41
  140. data/config/environments/production.rb +4 -4
  141. data/config/shadcn.tailwind.js +98 -0
  142. data/config/tailwind.config.js +13 -74
  143. data/lib/components.json +7 -3
  144. data/lib/generators/shadcn-ui_generator.rb +201 -0
  145. data/lib/shadcn-ui/version.rb +1 -1
  146. data/package-lock.json +90 -3
  147. data/package.json +4 -0
  148. metadata +97 -9
  149. data/lib/generators/shadcn_ui_generator.rb +0 -81
  150. /data/app/assets/stylesheets/{lambda.light.scss → lambda.light.css} +0 -0
  151. /data/app/views/examples/components/dialog/code/{form.erb → _form.erb} +0 -0
  152. /data/app/views/examples/components/dialog/code/{notifications.erb → _notifications.erb} +0 -0
  153. /data/app/views/examples/components/dialog/code/{preview.erb → _preview.erb} +0 -0
  154. /data/app/views/examples/components/dialog/code/{usage.erb → _usage.erb} +0 -0
@@ -2,6 +2,7 @@
2
2
 
3
3
  import { Controller } from "@hotwired/stimulus";
4
4
  import { createPopper } from "@popperjs/core";
5
+ import { useClickOutside } from "stimulus-use";
5
6
 
6
7
  export default class UIPopover extends Controller {
7
8
  static values = {
@@ -9,9 +10,8 @@ export default class UIPopover extends Controller {
9
10
  };
10
11
  static targets = ["content", "wrapper", "trigger"];
11
12
 
12
- // Sets the popover offset using Stimulus data map objects.
13
-
14
13
  connect() {
14
+ useClickOutside(this);
15
15
  this.popperInstance = createPopper(this.triggerTarget, this.contentTarget, {
16
16
  placement: this.contentTarget.dataset.side || "bottom",
17
17
  modifiers: [
@@ -37,6 +37,10 @@ export default class UIPopover extends Controller {
37
37
  this.contentTarget.dataset.state = "closed";
38
38
  }
39
39
 
40
+ clickOutside(event) {
41
+ this.hide();
42
+ }
43
+
40
44
  // Toggle the popover on demand
41
45
  toggle(event) {
42
46
  this.popperInstance.update();