jet_ui 0.2.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 (471) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.md +106 -0
  3. data/LICENSE.md +21 -0
  4. data/README.md +114 -0
  5. data/app/assets/images/jet_ui/icons/academic-cap.svg +3 -0
  6. data/app/assets/images/jet_ui/icons/adjustments-horizontal.svg +3 -0
  7. data/app/assets/images/jet_ui/icons/adjustments-vertical.svg +3 -0
  8. data/app/assets/images/jet_ui/icons/archive-box-arrow-down.svg +3 -0
  9. data/app/assets/images/jet_ui/icons/archive-box-x-mark.svg +3 -0
  10. data/app/assets/images/jet_ui/icons/archive-box.svg +3 -0
  11. data/app/assets/images/jet_ui/icons/arrow-down-circle.svg +3 -0
  12. data/app/assets/images/jet_ui/icons/arrow-down-left.svg +3 -0
  13. data/app/assets/images/jet_ui/icons/arrow-down-on-square-stack.svg +3 -0
  14. data/app/assets/images/jet_ui/icons/arrow-down-on-square.svg +3 -0
  15. data/app/assets/images/jet_ui/icons/arrow-down-right.svg +3 -0
  16. data/app/assets/images/jet_ui/icons/arrow-down-tray.svg +3 -0
  17. data/app/assets/images/jet_ui/icons/arrow-down.svg +3 -0
  18. data/app/assets/images/jet_ui/icons/arrow-left-circle.svg +3 -0
  19. data/app/assets/images/jet_ui/icons/arrow-left-end-on-rectangle.svg +3 -0
  20. data/app/assets/images/jet_ui/icons/arrow-left-on-rectangle.svg +3 -0
  21. data/app/assets/images/jet_ui/icons/arrow-left-start-on-rectangle.svg +3 -0
  22. data/app/assets/images/jet_ui/icons/arrow-left.svg +3 -0
  23. data/app/assets/images/jet_ui/icons/arrow-long-down.svg +3 -0
  24. data/app/assets/images/jet_ui/icons/arrow-long-left.svg +3 -0
  25. data/app/assets/images/jet_ui/icons/arrow-long-right.svg +3 -0
  26. data/app/assets/images/jet_ui/icons/arrow-long-up.svg +3 -0
  27. data/app/assets/images/jet_ui/icons/arrow-path-rounded-square.svg +3 -0
  28. data/app/assets/images/jet_ui/icons/arrow-path.svg +3 -0
  29. data/app/assets/images/jet_ui/icons/arrow-right-circle.svg +3 -0
  30. data/app/assets/images/jet_ui/icons/arrow-right-end-on-rectangle.svg +3 -0
  31. data/app/assets/images/jet_ui/icons/arrow-right-on-rectangle.svg +3 -0
  32. data/app/assets/images/jet_ui/icons/arrow-right-start-on-rectangle.svg +3 -0
  33. data/app/assets/images/jet_ui/icons/arrow-right.svg +3 -0
  34. data/app/assets/images/jet_ui/icons/arrow-small-down.svg +3 -0
  35. data/app/assets/images/jet_ui/icons/arrow-small-left.svg +3 -0
  36. data/app/assets/images/jet_ui/icons/arrow-small-right.svg +3 -0
  37. data/app/assets/images/jet_ui/icons/arrow-small-up.svg +3 -0
  38. data/app/assets/images/jet_ui/icons/arrow-top-right-on-square.svg +3 -0
  39. data/app/assets/images/jet_ui/icons/arrow-trending-down.svg +3 -0
  40. data/app/assets/images/jet_ui/icons/arrow-trending-up.svg +3 -0
  41. data/app/assets/images/jet_ui/icons/arrow-turn-down-left.svg +3 -0
  42. data/app/assets/images/jet_ui/icons/arrow-turn-down-right.svg +3 -0
  43. data/app/assets/images/jet_ui/icons/arrow-turn-left-down.svg +3 -0
  44. data/app/assets/images/jet_ui/icons/arrow-turn-left-up.svg +3 -0
  45. data/app/assets/images/jet_ui/icons/arrow-turn-right-down.svg +3 -0
  46. data/app/assets/images/jet_ui/icons/arrow-turn-right-up.svg +3 -0
  47. data/app/assets/images/jet_ui/icons/arrow-turn-up-left.svg +3 -0
  48. data/app/assets/images/jet_ui/icons/arrow-turn-up-right.svg +3 -0
  49. data/app/assets/images/jet_ui/icons/arrow-up-circle.svg +3 -0
  50. data/app/assets/images/jet_ui/icons/arrow-up-left.svg +3 -0
  51. data/app/assets/images/jet_ui/icons/arrow-up-on-square-stack.svg +3 -0
  52. data/app/assets/images/jet_ui/icons/arrow-up-on-square.svg +3 -0
  53. data/app/assets/images/jet_ui/icons/arrow-up-right.svg +3 -0
  54. data/app/assets/images/jet_ui/icons/arrow-up-tray.svg +3 -0
  55. data/app/assets/images/jet_ui/icons/arrow-up.svg +3 -0
  56. data/app/assets/images/jet_ui/icons/arrow-uturn-down.svg +3 -0
  57. data/app/assets/images/jet_ui/icons/arrow-uturn-left.svg +3 -0
  58. data/app/assets/images/jet_ui/icons/arrow-uturn-right.svg +3 -0
  59. data/app/assets/images/jet_ui/icons/arrow-uturn-up.svg +3 -0
  60. data/app/assets/images/jet_ui/icons/arrows-pointing-in.svg +3 -0
  61. data/app/assets/images/jet_ui/icons/arrows-pointing-out.svg +3 -0
  62. data/app/assets/images/jet_ui/icons/arrows-right-left.svg +3 -0
  63. data/app/assets/images/jet_ui/icons/arrows-up-down.svg +3 -0
  64. data/app/assets/images/jet_ui/icons/at-symbol.svg +3 -0
  65. data/app/assets/images/jet_ui/icons/backspace.svg +3 -0
  66. data/app/assets/images/jet_ui/icons/backward.svg +4 -0
  67. data/app/assets/images/jet_ui/icons/banknotes.svg +3 -0
  68. data/app/assets/images/jet_ui/icons/bars-2.svg +3 -0
  69. data/app/assets/images/jet_ui/icons/bars-3-bottom-left.svg +3 -0
  70. data/app/assets/images/jet_ui/icons/bars-3-bottom-right.svg +3 -0
  71. data/app/assets/images/jet_ui/icons/bars-3-center-left.svg +3 -0
  72. data/app/assets/images/jet_ui/icons/bars-3.svg +3 -0
  73. data/app/assets/images/jet_ui/icons/bars-4.svg +3 -0
  74. data/app/assets/images/jet_ui/icons/bars-arrow-down.svg +3 -0
  75. data/app/assets/images/jet_ui/icons/bars-arrow-up.svg +3 -0
  76. data/app/assets/images/jet_ui/icons/battery-0.svg +3 -0
  77. data/app/assets/images/jet_ui/icons/battery-100.svg +3 -0
  78. data/app/assets/images/jet_ui/icons/battery-50.svg +3 -0
  79. data/app/assets/images/jet_ui/icons/beaker.svg +3 -0
  80. data/app/assets/images/jet_ui/icons/bell-alert.svg +3 -0
  81. data/app/assets/images/jet_ui/icons/bell-slash.svg +3 -0
  82. data/app/assets/images/jet_ui/icons/bell-snooze.svg +3 -0
  83. data/app/assets/images/jet_ui/icons/bell.svg +3 -0
  84. data/app/assets/images/jet_ui/icons/bold.svg +3 -0
  85. data/app/assets/images/jet_ui/icons/bolt-slash.svg +3 -0
  86. data/app/assets/images/jet_ui/icons/bolt.svg +3 -0
  87. data/app/assets/images/jet_ui/icons/book-open.svg +3 -0
  88. data/app/assets/images/jet_ui/icons/bookmark-slash.svg +3 -0
  89. data/app/assets/images/jet_ui/icons/bookmark-square.svg +3 -0
  90. data/app/assets/images/jet_ui/icons/bookmark.svg +3 -0
  91. data/app/assets/images/jet_ui/icons/briefcase.svg +3 -0
  92. data/app/assets/images/jet_ui/icons/bug-ant.svg +3 -0
  93. data/app/assets/images/jet_ui/icons/building-library.svg +3 -0
  94. data/app/assets/images/jet_ui/icons/building-office-2.svg +3 -0
  95. data/app/assets/images/jet_ui/icons/building-office.svg +3 -0
  96. data/app/assets/images/jet_ui/icons/building-storefront.svg +3 -0
  97. data/app/assets/images/jet_ui/icons/cake.svg +3 -0
  98. data/app/assets/images/jet_ui/icons/calculator.svg +3 -0
  99. data/app/assets/images/jet_ui/icons/calendar-date-range.svg +3 -0
  100. data/app/assets/images/jet_ui/icons/calendar-days.svg +3 -0
  101. data/app/assets/images/jet_ui/icons/calendar.svg +3 -0
  102. data/app/assets/images/jet_ui/icons/camera.svg +5 -0
  103. data/app/assets/images/jet_ui/icons/chart-bar-square.svg +3 -0
  104. data/app/assets/images/jet_ui/icons/chart-bar.svg +5 -0
  105. data/app/assets/images/jet_ui/icons/chart-pie.svg +4 -0
  106. data/app/assets/images/jet_ui/icons/chat-bubble-bottom-center-text.svg +3 -0
  107. data/app/assets/images/jet_ui/icons/chat-bubble-bottom-center.svg +3 -0
  108. data/app/assets/images/jet_ui/icons/chat-bubble-left-ellipsis.svg +3 -0
  109. data/app/assets/images/jet_ui/icons/chat-bubble-left-right.svg +3 -0
  110. data/app/assets/images/jet_ui/icons/chat-bubble-left.svg +3 -0
  111. data/app/assets/images/jet_ui/icons/chat-bubble-oval-left-ellipsis.svg +3 -0
  112. data/app/assets/images/jet_ui/icons/chat-bubble-oval-left.svg +3 -0
  113. data/app/assets/images/jet_ui/icons/check-badge.svg +3 -0
  114. data/app/assets/images/jet_ui/icons/check-circle.svg +3 -0
  115. data/app/assets/images/jet_ui/icons/check.svg +3 -0
  116. data/app/assets/images/jet_ui/icons/chevron-double-down.svg +3 -0
  117. data/app/assets/images/jet_ui/icons/chevron-double-left.svg +3 -0
  118. data/app/assets/images/jet_ui/icons/chevron-double-right.svg +3 -0
  119. data/app/assets/images/jet_ui/icons/chevron-double-up.svg +4 -0
  120. data/app/assets/images/jet_ui/icons/chevron-down.svg +3 -0
  121. data/app/assets/images/jet_ui/icons/chevron-left.svg +3 -0
  122. data/app/assets/images/jet_ui/icons/chevron-right.svg +3 -0
  123. data/app/assets/images/jet_ui/icons/chevron-up-down.svg +3 -0
  124. data/app/assets/images/jet_ui/icons/chevron-up.svg +3 -0
  125. data/app/assets/images/jet_ui/icons/circle-stack.svg +3 -0
  126. data/app/assets/images/jet_ui/icons/clipboard-document-check.svg +3 -0
  127. data/app/assets/images/jet_ui/icons/clipboard-document-list.svg +3 -0
  128. data/app/assets/images/jet_ui/icons/clipboard-document.svg +3 -0
  129. data/app/assets/images/jet_ui/icons/clipboard.svg +3 -0
  130. data/app/assets/images/jet_ui/icons/clock.svg +3 -0
  131. data/app/assets/images/jet_ui/icons/cloud-arrow-down.svg +3 -0
  132. data/app/assets/images/jet_ui/icons/cloud-arrow-up.svg +3 -0
  133. data/app/assets/images/jet_ui/icons/cloud.svg +3 -0
  134. data/app/assets/images/jet_ui/icons/code-bracket-square.svg +3 -0
  135. data/app/assets/images/jet_ui/icons/code-bracket.svg +3 -0
  136. data/app/assets/images/jet_ui/icons/cog-6-tooth.svg +4 -0
  137. data/app/assets/images/jet_ui/icons/cog-8-tooth.svg +4 -0
  138. data/app/assets/images/jet_ui/icons/cog.svg +3 -0
  139. data/app/assets/images/jet_ui/icons/command-line.svg +3 -0
  140. data/app/assets/images/jet_ui/icons/computer-desktop.svg +3 -0
  141. data/app/assets/images/jet_ui/icons/cpu-chip.svg +3 -0
  142. data/app/assets/images/jet_ui/icons/credit-card.svg +3 -0
  143. data/app/assets/images/jet_ui/icons/cube-transparent.svg +3 -0
  144. data/app/assets/images/jet_ui/icons/cube.svg +3 -0
  145. data/app/assets/images/jet_ui/icons/currency-bangladeshi.svg +3 -0
  146. data/app/assets/images/jet_ui/icons/currency-dollar.svg +3 -0
  147. data/app/assets/images/jet_ui/icons/currency-euro.svg +3 -0
  148. data/app/assets/images/jet_ui/icons/currency-pound.svg +3 -0
  149. data/app/assets/images/jet_ui/icons/currency-rupee.svg +3 -0
  150. data/app/assets/images/jet_ui/icons/currency-yen.svg +3 -0
  151. data/app/assets/images/jet_ui/icons/cursor-arrow-rays.svg +3 -0
  152. data/app/assets/images/jet_ui/icons/cursor-arrow-ripple.svg +3 -0
  153. data/app/assets/images/jet_ui/icons/device-phone-mobile.svg +3 -0
  154. data/app/assets/images/jet_ui/icons/device-tablet.svg +3 -0
  155. data/app/assets/images/jet_ui/icons/divide.svg +3 -0
  156. data/app/assets/images/jet_ui/icons/document-arrow-down.svg +3 -0
  157. data/app/assets/images/jet_ui/icons/document-arrow-up.svg +3 -0
  158. data/app/assets/images/jet_ui/icons/document-chart-bar.svg +3 -0
  159. data/app/assets/images/jet_ui/icons/document-check.svg +3 -0
  160. data/app/assets/images/jet_ui/icons/document-currency-bangladeshi.svg +3 -0
  161. data/app/assets/images/jet_ui/icons/document-currency-dollar.svg +3 -0
  162. data/app/assets/images/jet_ui/icons/document-currency-euro.svg +3 -0
  163. data/app/assets/images/jet_ui/icons/document-currency-pound.svg +3 -0
  164. data/app/assets/images/jet_ui/icons/document-currency-rupee.svg +3 -0
  165. data/app/assets/images/jet_ui/icons/document-currency-yen.svg +3 -0
  166. data/app/assets/images/jet_ui/icons/document-duplicate.svg +3 -0
  167. data/app/assets/images/jet_ui/icons/document-magnifying-glass.svg +3 -0
  168. data/app/assets/images/jet_ui/icons/document-minus.svg +3 -0
  169. data/app/assets/images/jet_ui/icons/document-plus.svg +3 -0
  170. data/app/assets/images/jet_ui/icons/document-text.svg +3 -0
  171. data/app/assets/images/jet_ui/icons/document.svg +3 -0
  172. data/app/assets/images/jet_ui/icons/ellipsis-horizontal-circle.svg +3 -0
  173. data/app/assets/images/jet_ui/icons/ellipsis-horizontal.svg +5 -0
  174. data/app/assets/images/jet_ui/icons/ellipsis-vertical.svg +5 -0
  175. data/app/assets/images/jet_ui/icons/envelope-open.svg +3 -0
  176. data/app/assets/images/jet_ui/icons/envelope.svg +3 -0
  177. data/app/assets/images/jet_ui/icons/equals.svg +3 -0
  178. data/app/assets/images/jet_ui/icons/exclamation-circle.svg +3 -0
  179. data/app/assets/images/jet_ui/icons/exclamation-triangle.svg +3 -0
  180. data/app/assets/images/jet_ui/icons/eye-dropper.svg +3 -0
  181. data/app/assets/images/jet_ui/icons/eye-slash.svg +3 -0
  182. data/app/assets/images/jet_ui/icons/eye.svg +4 -0
  183. data/app/assets/images/jet_ui/icons/face-frown.svg +3 -0
  184. data/app/assets/images/jet_ui/icons/face-smile.svg +3 -0
  185. data/app/assets/images/jet_ui/icons/film.svg +3 -0
  186. data/app/assets/images/jet_ui/icons/finger-print.svg +3 -0
  187. data/app/assets/images/jet_ui/icons/fire.svg +4 -0
  188. data/app/assets/images/jet_ui/icons/flag.svg +3 -0
  189. data/app/assets/images/jet_ui/icons/folder-arrow-down.svg +3 -0
  190. data/app/assets/images/jet_ui/icons/folder-minus.svg +3 -0
  191. data/app/assets/images/jet_ui/icons/folder-open.svg +3 -0
  192. data/app/assets/images/jet_ui/icons/folder-plus.svg +3 -0
  193. data/app/assets/images/jet_ui/icons/folder.svg +3 -0
  194. data/app/assets/images/jet_ui/icons/forward.svg +4 -0
  195. data/app/assets/images/jet_ui/icons/funnel.svg +3 -0
  196. data/app/assets/images/jet_ui/icons/gif.svg +3 -0
  197. data/app/assets/images/jet_ui/icons/gift-top.svg +3 -0
  198. data/app/assets/images/jet_ui/icons/gift.svg +3 -0
  199. data/app/assets/images/jet_ui/icons/github.svg +10 -0
  200. data/app/assets/images/jet_ui/icons/globe-alt.svg +3 -0
  201. data/app/assets/images/jet_ui/icons/globe-americas.svg +3 -0
  202. data/app/assets/images/jet_ui/icons/globe-asia-australia.svg +3 -0
  203. data/app/assets/images/jet_ui/icons/globe-europe-africa.svg +3 -0
  204. data/app/assets/images/jet_ui/icons/h1.svg +3 -0
  205. data/app/assets/images/jet_ui/icons/h2.svg +3 -0
  206. data/app/assets/images/jet_ui/icons/h3.svg +3 -0
  207. data/app/assets/images/jet_ui/icons/hand-raised.svg +3 -0
  208. data/app/assets/images/jet_ui/icons/hand-thumb-down.svg +3 -0
  209. data/app/assets/images/jet_ui/icons/hand-thumb-up.svg +3 -0
  210. data/app/assets/images/jet_ui/icons/hashtag.svg +3 -0
  211. data/app/assets/images/jet_ui/icons/heart.svg +3 -0
  212. data/app/assets/images/jet_ui/icons/home-modern.svg +3 -0
  213. data/app/assets/images/jet_ui/icons/home.svg +3 -0
  214. data/app/assets/images/jet_ui/icons/identification.svg +3 -0
  215. data/app/assets/images/jet_ui/icons/inbox-arrow-down.svg +3 -0
  216. data/app/assets/images/jet_ui/icons/inbox-stack.svg +3 -0
  217. data/app/assets/images/jet_ui/icons/inbox.svg +3 -0
  218. data/app/assets/images/jet_ui/icons/information-circle.svg +3 -0
  219. data/app/assets/images/jet_ui/icons/italic.svg +3 -0
  220. data/app/assets/images/jet_ui/icons/key.svg +3 -0
  221. data/app/assets/images/jet_ui/icons/language.svg +3 -0
  222. data/app/assets/images/jet_ui/icons/lifebuoy.svg +3 -0
  223. data/app/assets/images/jet_ui/icons/light-bulb.svg +3 -0
  224. data/app/assets/images/jet_ui/icons/link-slash.svg +3 -0
  225. data/app/assets/images/jet_ui/icons/link.svg +3 -0
  226. data/app/assets/images/jet_ui/icons/list-bullet.svg +3 -0
  227. data/app/assets/images/jet_ui/icons/lock-closed.svg +3 -0
  228. data/app/assets/images/jet_ui/icons/lock-open.svg +3 -0
  229. data/app/assets/images/jet_ui/icons/magnifying-glass-circle.svg +3 -0
  230. data/app/assets/images/jet_ui/icons/magnifying-glass-minus.svg +3 -0
  231. data/app/assets/images/jet_ui/icons/magnifying-glass-plus.svg +3 -0
  232. data/app/assets/images/jet_ui/icons/magnifying-glass.svg +3 -0
  233. data/app/assets/images/jet_ui/icons/map-pin.svg +4 -0
  234. data/app/assets/images/jet_ui/icons/map.svg +3 -0
  235. data/app/assets/images/jet_ui/icons/megaphone.svg +3 -0
  236. data/app/assets/images/jet_ui/icons/microphone.svg +3 -0
  237. data/app/assets/images/jet_ui/icons/minus-circle.svg +3 -0
  238. data/app/assets/images/jet_ui/icons/minus-small.svg +3 -0
  239. data/app/assets/images/jet_ui/icons/minus.svg +3 -0
  240. data/app/assets/images/jet_ui/icons/moon.svg +3 -0
  241. data/app/assets/images/jet_ui/icons/musical-note.svg +3 -0
  242. data/app/assets/images/jet_ui/icons/newspaper.svg +3 -0
  243. data/app/assets/images/jet_ui/icons/no-symbol.svg +3 -0
  244. data/app/assets/images/jet_ui/icons/numbered-list.svg +3 -0
  245. data/app/assets/images/jet_ui/icons/paint-brush.svg +3 -0
  246. data/app/assets/images/jet_ui/icons/paper-airplane.svg +3 -0
  247. data/app/assets/images/jet_ui/icons/paper-clip.svg +3 -0
  248. data/app/assets/images/jet_ui/icons/pause-circle.svg +3 -0
  249. data/app/assets/images/jet_ui/icons/pause.svg +3 -0
  250. data/app/assets/images/jet_ui/icons/pencil-square.svg +3 -0
  251. data/app/assets/images/jet_ui/icons/pencil.svg +3 -0
  252. data/app/assets/images/jet_ui/icons/percent-badge.svg +3 -0
  253. data/app/assets/images/jet_ui/icons/phone-arrow-down-left.svg +3 -0
  254. data/app/assets/images/jet_ui/icons/phone-arrow-up-right.svg +3 -0
  255. data/app/assets/images/jet_ui/icons/phone-x-mark.svg +3 -0
  256. data/app/assets/images/jet_ui/icons/phone.svg +3 -0
  257. data/app/assets/images/jet_ui/icons/photo.svg +3 -0
  258. data/app/assets/images/jet_ui/icons/play-circle.svg +4 -0
  259. data/app/assets/images/jet_ui/icons/play-pause.svg +3 -0
  260. data/app/assets/images/jet_ui/icons/play.svg +3 -0
  261. data/app/assets/images/jet_ui/icons/plus-circle.svg +3 -0
  262. data/app/assets/images/jet_ui/icons/plus-small.svg +3 -0
  263. data/app/assets/images/jet_ui/icons/plus.svg +3 -0
  264. data/app/assets/images/jet_ui/icons/power.svg +3 -0
  265. data/app/assets/images/jet_ui/icons/presentation-chart-bar.svg +3 -0
  266. data/app/assets/images/jet_ui/icons/presentation-chart-line.svg +3 -0
  267. data/app/assets/images/jet_ui/icons/printer.svg +3 -0
  268. data/app/assets/images/jet_ui/icons/puzzle-piece.svg +3 -0
  269. data/app/assets/images/jet_ui/icons/qr-code.svg +13 -0
  270. data/app/assets/images/jet_ui/icons/question-mark-circle.svg +3 -0
  271. data/app/assets/images/jet_ui/icons/queue-list.svg +3 -0
  272. data/app/assets/images/jet_ui/icons/radio.svg +3 -0
  273. data/app/assets/images/jet_ui/icons/receipt-percent.svg +3 -0
  274. data/app/assets/images/jet_ui/icons/receipt-refund.svg +3 -0
  275. data/app/assets/images/jet_ui/icons/rectangle-group.svg +5 -0
  276. data/app/assets/images/jet_ui/icons/rectangle-stack.svg +3 -0
  277. data/app/assets/images/jet_ui/icons/rocket-launch.svg +3 -0
  278. data/app/assets/images/jet_ui/icons/rss.svg +3 -0
  279. data/app/assets/images/jet_ui/icons/scale.svg +3 -0
  280. data/app/assets/images/jet_ui/icons/scissors.svg +3 -0
  281. data/app/assets/images/jet_ui/icons/server-stack.svg +3 -0
  282. data/app/assets/images/jet_ui/icons/server.svg +3 -0
  283. data/app/assets/images/jet_ui/icons/share.svg +3 -0
  284. data/app/assets/images/jet_ui/icons/shield-check.svg +3 -0
  285. data/app/assets/images/jet_ui/icons/shield-exclamation.svg +3 -0
  286. data/app/assets/images/jet_ui/icons/shopping-bag.svg +3 -0
  287. data/app/assets/images/jet_ui/icons/shopping-cart.svg +3 -0
  288. data/app/assets/images/jet_ui/icons/signal-slash.svg +3 -0
  289. data/app/assets/images/jet_ui/icons/signal.svg +3 -0
  290. data/app/assets/images/jet_ui/icons/slash.svg +3 -0
  291. data/app/assets/images/jet_ui/icons/sparkles.svg +5 -0
  292. data/app/assets/images/jet_ui/icons/speaker-wave.svg +3 -0
  293. data/app/assets/images/jet_ui/icons/speaker-x-mark.svg +3 -0
  294. data/app/assets/images/jet_ui/icons/spinner.svg +1 -0
  295. data/app/assets/images/jet_ui/icons/square-2-stack.svg +3 -0
  296. data/app/assets/images/jet_ui/icons/square-3-stack-3d.svg +3 -0
  297. data/app/assets/images/jet_ui/icons/squares-2x2.svg +6 -0
  298. data/app/assets/images/jet_ui/icons/squares-plus.svg +3 -0
  299. data/app/assets/images/jet_ui/icons/star.svg +3 -0
  300. data/app/assets/images/jet_ui/icons/stop-circle.svg +4 -0
  301. data/app/assets/images/jet_ui/icons/stop.svg +3 -0
  302. data/app/assets/images/jet_ui/icons/strikethrough.svg +3 -0
  303. data/app/assets/images/jet_ui/icons/sun.svg +3 -0
  304. data/app/assets/images/jet_ui/icons/swatch.svg +3 -0
  305. data/app/assets/images/jet_ui/icons/table-cells.svg +3 -0
  306. data/app/assets/images/jet_ui/icons/tag.svg +4 -0
  307. data/app/assets/images/jet_ui/icons/ticket.svg +3 -0
  308. data/app/assets/images/jet_ui/icons/trash.svg +3 -0
  309. data/app/assets/images/jet_ui/icons/trophy.svg +3 -0
  310. data/app/assets/images/jet_ui/icons/truck.svg +3 -0
  311. data/app/assets/images/jet_ui/icons/tv.svg +3 -0
  312. data/app/assets/images/jet_ui/icons/underline.svg +3 -0
  313. data/app/assets/images/jet_ui/icons/user-circle.svg +3 -0
  314. data/app/assets/images/jet_ui/icons/user-group.svg +3 -0
  315. data/app/assets/images/jet_ui/icons/user-minus.svg +3 -0
  316. data/app/assets/images/jet_ui/icons/user-plus.svg +3 -0
  317. data/app/assets/images/jet_ui/icons/user.svg +4 -0
  318. data/app/assets/images/jet_ui/icons/users.svg +3 -0
  319. data/app/assets/images/jet_ui/icons/variable.svg +3 -0
  320. data/app/assets/images/jet_ui/icons/video-camera-slash.svg +3 -0
  321. data/app/assets/images/jet_ui/icons/video-camera.svg +3 -0
  322. data/app/assets/images/jet_ui/icons/view-columns.svg +3 -0
  323. data/app/assets/images/jet_ui/icons/viewfinder-circle.svg +3 -0
  324. data/app/assets/images/jet_ui/icons/wallet.svg +3 -0
  325. data/app/assets/images/jet_ui/icons/wifi.svg +3 -0
  326. data/app/assets/images/jet_ui/icons/window.svg +3 -0
  327. data/app/assets/images/jet_ui/icons/wrench-screwdriver.svg +3 -0
  328. data/app/assets/images/jet_ui/icons/wrench.svg +4 -0
  329. data/app/assets/images/jet_ui/icons/x-circle.svg +3 -0
  330. data/app/assets/images/jet_ui/icons/x-mark.svg +3 -0
  331. data/app/assets/javascripts/jet_ui/clipboard_controller.js +46 -0
  332. data/app/assets/javascripts/jet_ui/drawer_controller.js +70 -0
  333. data/app/assets/javascripts/jet_ui/drawers_controller.js +83 -0
  334. data/app/assets/javascripts/jet_ui/dropdown_controller.js +95 -0
  335. data/app/assets/javascripts/jet_ui/flash_controller.js +34 -0
  336. data/app/assets/javascripts/jet_ui/modal_controller.js +35 -0
  337. data/app/assets/javascripts/jet_ui/modals_controller.js +30 -0
  338. data/app/assets/javascripts/jet_ui/popover_controller.js +95 -0
  339. data/app/assets/javascripts/jet_ui/tooltip_controller.js +107 -0
  340. data/app/assets/javascripts/jet_ui/turbo_confirm_controller.js +25 -0
  341. data/app/assets/stylesheets/jet_ui/accordion.css +24 -0
  342. data/app/assets/stylesheets/jet_ui/alert.css +27 -0
  343. data/app/assets/stylesheets/jet_ui/avatar.css +15 -0
  344. data/app/assets/stylesheets/jet_ui/badge.css +22 -0
  345. data/app/assets/stylesheets/jet_ui/breadcrumbs.css +28 -0
  346. data/app/assets/stylesheets/jet_ui/btn.css +88 -0
  347. data/app/assets/stylesheets/jet_ui/card.css +61 -0
  348. data/app/assets/stylesheets/jet_ui/divider.css +21 -0
  349. data/app/assets/stylesheets/jet_ui/drawer.css +46 -0
  350. data/app/assets/stylesheets/jet_ui/dropdown.css +33 -0
  351. data/app/assets/stylesheets/jet_ui/empty.css +25 -0
  352. data/app/assets/stylesheets/jet_ui/flash.css +50 -0
  353. data/app/assets/stylesheets/jet_ui/group.css +40 -0
  354. data/app/assets/stylesheets/jet_ui/header.css +65 -0
  355. data/app/assets/stylesheets/jet_ui/icon.css +11 -0
  356. data/app/assets/stylesheets/jet_ui/list.css +31 -0
  357. data/app/assets/stylesheets/jet_ui/modal.css +47 -0
  358. data/app/assets/stylesheets/jet_ui/navbar.css +36 -0
  359. data/app/assets/stylesheets/jet_ui/pagy.css +54 -0
  360. data/app/assets/stylesheets/jet_ui/popover.css +51 -0
  361. data/app/assets/stylesheets/jet_ui/sidebar.css +35 -0
  362. data/app/assets/stylesheets/jet_ui/stat.css +23 -0
  363. data/app/assets/stylesheets/jet_ui/stepper.css +82 -0
  364. data/app/assets/stylesheets/jet_ui/table.css +68 -0
  365. data/app/assets/stylesheets/jet_ui/tabs.css +32 -0
  366. data/app/assets/stylesheets/jet_ui/theme.css +174 -0
  367. data/app/assets/stylesheets/jet_ui/timeline.css +45 -0
  368. data/app/assets/stylesheets/jet_ui/tooltip.css +33 -0
  369. data/app/assets/stylesheets/jet_ui.css +28 -0
  370. data/app/components/jet_ui/accordion/body_component.rb +21 -0
  371. data/app/components/jet_ui/accordion/component.rb +24 -0
  372. data/app/components/jet_ui/accordion/summary_component.rb +29 -0
  373. data/app/components/jet_ui/alert/component.rb +29 -0
  374. data/app/components/jet_ui/alert/description_component.rb +21 -0
  375. data/app/components/jet_ui/alert/icon_component.rb +21 -0
  376. data/app/components/jet_ui/alert/title_component.rb +21 -0
  377. data/app/components/jet_ui/avatar/component.rb +54 -0
  378. data/app/components/jet_ui/badge/component.rb +35 -0
  379. data/app/components/jet_ui/base_component.rb +6 -0
  380. data/app/components/jet_ui/breadcrumbs/component.rb +18 -0
  381. data/app/components/jet_ui/breadcrumbs/item_component.rb +25 -0
  382. data/app/components/jet_ui/btn/component.rb +51 -0
  383. data/app/components/jet_ui/card/body_component.rb +24 -0
  384. data/app/components/jet_ui/card/component.rb +24 -0
  385. data/app/components/jet_ui/card/footer_component.rb +48 -0
  386. data/app/components/jet_ui/card/header_component.rb +48 -0
  387. data/app/components/jet_ui/card/subtitle_component.rb +24 -0
  388. data/app/components/jet_ui/card/title_component.rb +24 -0
  389. data/app/components/jet_ui/clipboard/component.rb +58 -0
  390. data/app/components/jet_ui/divider/component.rb +30 -0
  391. data/app/components/jet_ui/drawer/body_component.rb +21 -0
  392. data/app/components/jet_ui/drawer/component.rb +54 -0
  393. data/app/components/jet_ui/drawer/footer_component.rb +45 -0
  394. data/app/components/jet_ui/drawer/header_component.rb +46 -0
  395. data/app/components/jet_ui/dropdown/button_component.rb +24 -0
  396. data/app/components/jet_ui/dropdown/component.rb +28 -0
  397. data/app/components/jet_ui/dropdown/divider_component.rb +21 -0
  398. data/app/components/jet_ui/dropdown/link_component.rb +29 -0
  399. data/app/components/jet_ui/dropdown/menu_component.rb +25 -0
  400. data/app/components/jet_ui/dropdown/title_component.rb +21 -0
  401. data/app/components/jet_ui/dropdown/trigger_component.rb +28 -0
  402. data/app/components/jet_ui/empty/actions_component.rb +19 -0
  403. data/app/components/jet_ui/empty/component.rb +15 -0
  404. data/app/components/jet_ui/empty/description_component.rb +15 -0
  405. data/app/components/jet_ui/empty/icon_component.rb +18 -0
  406. data/app/components/jet_ui/empty/title_component.rb +15 -0
  407. data/app/components/jet_ui/flash/component.html.erb +14 -0
  408. data/app/components/jet_ui/flash/component.rb +44 -0
  409. data/app/components/jet_ui/group/component.rb +26 -0
  410. data/app/components/jet_ui/header/actions_component.rb +21 -0
  411. data/app/components/jet_ui/header/component.rb +35 -0
  412. data/app/components/jet_ui/header/heading_component.rb +21 -0
  413. data/app/components/jet_ui/header/subtitle_component.rb +21 -0
  414. data/app/components/jet_ui/header/title_component.rb +21 -0
  415. data/app/components/jet_ui/icon/component.rb +46 -0
  416. data/app/components/jet_ui/list/action_component.rb +21 -0
  417. data/app/components/jet_ui/list/component.rb +29 -0
  418. data/app/components/jet_ui/list/content_component.rb +21 -0
  419. data/app/components/jet_ui/list/icon_component.rb +25 -0
  420. data/app/components/jet_ui/list/item_component.rb +21 -0
  421. data/app/components/jet_ui/modal/body_component.rb +21 -0
  422. data/app/components/jet_ui/modal/component.rb +54 -0
  423. data/app/components/jet_ui/modal/footer_component.rb +45 -0
  424. data/app/components/jet_ui/modal/header_component.rb +46 -0
  425. data/app/components/jet_ui/navbar/actions_component.rb +21 -0
  426. data/app/components/jet_ui/navbar/brand_component.rb +21 -0
  427. data/app/components/jet_ui/navbar/component.rb +22 -0
  428. data/app/components/jet_ui/navbar/content_component.rb +21 -0
  429. data/app/components/jet_ui/navbar/main_component.rb +21 -0
  430. data/app/components/jet_ui/pagy/component.rb +38 -0
  431. data/app/components/jet_ui/popover/component.rb +29 -0
  432. data/app/components/jet_ui/popover/content_component.rb +23 -0
  433. data/app/components/jet_ui/popover/trigger_component.rb +20 -0
  434. data/app/components/jet_ui/sidebar/component.rb +27 -0
  435. data/app/components/jet_ui/sidebar/link_component.rb +44 -0
  436. data/app/components/jet_ui/sidebar/menu_component.rb +21 -0
  437. data/app/components/jet_ui/sidebar/section_component.rb +21 -0
  438. data/app/components/jet_ui/sidebar/title_component.rb +21 -0
  439. data/app/components/jet_ui/spinner/component.rb +16 -0
  440. data/app/components/jet_ui/stat/component.rb +21 -0
  441. data/app/components/jet_ui/stat/description_component.rb +57 -0
  442. data/app/components/jet_ui/stat/label_component.rb +21 -0
  443. data/app/components/jet_ui/stat/value_component.rb +21 -0
  444. data/app/components/jet_ui/stepper/component.rb +18 -0
  445. data/app/components/jet_ui/stepper/step_component.rb +69 -0
  446. data/app/components/jet_ui/table/component.rb +37 -0
  447. data/app/components/jet_ui/table/tbody_component.rb +15 -0
  448. data/app/components/jet_ui/table/td_component.rb +29 -0
  449. data/app/components/jet_ui/table/tfoot_component.rb +15 -0
  450. data/app/components/jet_ui/table/th_component.rb +27 -0
  451. data/app/components/jet_ui/table/thead_component.rb +15 -0
  452. data/app/components/jet_ui/table/tr_component.rb +15 -0
  453. data/app/components/jet_ui/tabs/component.rb +30 -0
  454. data/app/components/jet_ui/tabs/item_component.rb +34 -0
  455. data/app/components/jet_ui/timeline/component.rb +15 -0
  456. data/app/components/jet_ui/timeline/content_component.rb +15 -0
  457. data/app/components/jet_ui/timeline/dot_component.rb +37 -0
  458. data/app/components/jet_ui/timeline/item_component.rb +15 -0
  459. data/app/components/jet_ui/timeline/time_component.rb +15 -0
  460. data/app/components/jet_ui/tooltip/component.rb +34 -0
  461. data/app/components/jet_ui/turbo_confirm/component.html.erb +20 -0
  462. data/app/components/jet_ui/turbo_confirm/component.rb +8 -0
  463. data/app/helpers/jet_ui_helper.rb +37 -0
  464. data/lib/generators/jet_ui/eject/USAGE +20 -0
  465. data/lib/generators/jet_ui/eject/eject_generator.rb +376 -0
  466. data/lib/generators/jet_ui/install/USAGE +11 -0
  467. data/lib/generators/jet_ui/install/install_generator.rb +121 -0
  468. data/lib/jet_ui/engine.rb +32 -0
  469. data/lib/jet_ui/version.rb +5 -0
  470. data/lib/jet_ui.rb +5 -0
  471. metadata +667 -0
@@ -0,0 +1,54 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .pagy {
5
+ @apply inline-flex;
6
+
7
+ a:not(.gap) {
8
+ @apply relative flex items-center justify-center size-8 text-muted-foreground border border-border;
9
+
10
+ &:first-child {
11
+ @apply text-transparent;
12
+ border-top-left-radius: var(--radius-btn-md);
13
+ border-bottom-left-radius: var(--radius-btn-md);
14
+ }
15
+
16
+ &:last-child {
17
+ @apply text-transparent;
18
+ border-top-right-radius: var(--radius-btn-md);
19
+ border-bottom-right-radius: var(--radius-btn-md);
20
+ }
21
+
22
+ &:hover {
23
+ @apply bg-muted;
24
+ }
25
+
26
+ &:not(:last-child) {
27
+ @apply border-r-0;
28
+ }
29
+
30
+ &:first-child::before,
31
+ &:last-child::before {
32
+ @apply absolute size-4 content-[''] text-muted-foreground;
33
+ background-color: currentColor;
34
+ mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='2' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M15.75 19.5 8.25 12l7.5-7.5'/%3E%3C/svg%3E");
35
+ mask-position: center;
36
+ mask-repeat: no-repeat;
37
+ mask-size: 100%;
38
+ }
39
+
40
+ &:last-child::before {
41
+ transform: rotate(180deg);
42
+ }
43
+
44
+ &:not([href]) {
45
+ @apply relative inline-flex items-center h-8 px-2 cursor-not-allowed bg-transparent;
46
+ }
47
+
48
+ &.current {
49
+ @apply relative z-10 flex items-center justify-center cursor-default size-8;
50
+ @apply bg-(--color-accent) border-(--color-accent) text-(--color-accent-foreground);
51
+ }
52
+ }
53
+ }
54
+ }
@@ -0,0 +1,51 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ [data-controller~="popover"] {
5
+ position: relative;
6
+ width: fit-content;
7
+ }
8
+
9
+ .popover {
10
+ @apply absolute z-10 w-64 text-sm shadow-sm;
11
+ @apply text-muted-foreground bg-popover border border-border rounded-dropdown;
12
+ opacity: 0;
13
+ pointer-events: none;
14
+ transition: opacity 0.3s;
15
+ }
16
+
17
+ .popover--visible {
18
+ opacity: 1;
19
+ pointer-events: auto;
20
+ }
21
+
22
+ .popover::after {
23
+ @apply absolute rotate-45 size-2.5 bg-popover border border-border;
24
+ content: "";
25
+ }
26
+
27
+ .popover[data-placement^="top"]::after {
28
+ @apply bottom-0 -translate-x-1/2 translate-y-1/2 border-t-0 border-l-0 left-1/2;
29
+ }
30
+
31
+ .popover[data-placement^="bottom"]::after {
32
+ @apply top-0 -translate-x-1/2 -translate-y-1/2 border-b-0 border-r-0 left-1/2 bg-muted;
33
+ }
34
+
35
+ .popover[data-placement^="left"]::after {
36
+ @apply right-0 translate-x-1/2 -translate-y-1/2 border-b-0 border-l-0 top-1/2;
37
+ }
38
+
39
+ .popover[data-placement^="right"]::after {
40
+ @apply left-0 -translate-x-1/2 -translate-y-1/2 border-t-0 border-r-0 top-1/2;
41
+ }
42
+
43
+ .popover__title {
44
+ @apply px-3 py-3 font-semibold text-foreground bg-muted border-b border-border;
45
+ @apply rounded-tl-dropdown rounded-tr-dropdown;
46
+ }
47
+
48
+ .popover__body {
49
+ @apply p-3;
50
+ }
51
+ }
@@ -0,0 +1,35 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .sidebar {
5
+ @apply flex flex-col gap-y-8 overflow-y-auto text-sm;
6
+ scrollbar-width: thin;
7
+ scrollbar-color: transparent transparent;
8
+ }
9
+
10
+ .sidebar__section {
11
+ @apply flex flex-col gap-3;
12
+ }
13
+
14
+ .sidebar__title {
15
+ @apply flex items-center justify-between gap-2 font-semibold text-foreground;
16
+ }
17
+
18
+ .sidebar__menu {
19
+ @apply flex flex-col gap-1;
20
+ }
21
+
22
+ .sidebar__link {
23
+ @apply block px-3 py-1.5 font-medium text-muted-foreground rounded-btn-md;
24
+ @apply hover:text-foreground;
25
+ }
26
+
27
+ .sidebar__link-active {
28
+ @apply font-semibold bg-muted text-foreground;
29
+ }
30
+
31
+ .sidebar__link-disabled {
32
+ @apply cursor-not-allowed font-normal text-muted-foreground;
33
+ @apply hover:text-muted-foreground;
34
+ }
35
+ }
@@ -0,0 +1,23 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .stat {
5
+ @apply border border-border rounded-card p-6;
6
+ }
7
+
8
+ .stat__label {
9
+ @apply text-sm font-medium text-muted-foreground;
10
+ }
11
+
12
+ .stat__value {
13
+ @apply text-2xl font-bold text-foreground mt-1;
14
+ }
15
+
16
+ .stat__description {
17
+ @apply text-sm mt-2 flex items-center gap-1 text-muted-foreground;
18
+ }
19
+
20
+ .stat__description--success { @apply text-success; }
21
+ .stat__description--warning { @apply text-warning; }
22
+ .stat__description--error { @apply text-destructive; }
23
+ }
@@ -0,0 +1,82 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .stepper {
5
+ @apply w-full;
6
+ }
7
+
8
+ .stepper__list {
9
+ @apply flex items-start list-none p-0 m-0;
10
+ }
11
+
12
+ .stepper__item {
13
+ @apply relative flex-1 flex flex-col items-center text-center;
14
+ }
15
+
16
+ .stepper__item:not(:last-child)::after {
17
+ content: "";
18
+ @apply absolute top-5 left-[calc(50%+1rem)] right-[calc(-50%+1rem)] h-0.5 z-0 bg-border;
19
+ }
20
+
21
+ .stepper__item-completed:not(:last-child)::after {
22
+ @apply bg-(--color-accent);
23
+ }
24
+
25
+ .stepper__indicator {
26
+ @apply relative z-10 flex items-center justify-center w-10 h-10 rounded-full border-2;
27
+ @apply bg-(--color-surface) border-border text-muted-foreground;
28
+ }
29
+
30
+ .stepper__item-current .stepper__indicator {
31
+ @apply bg-(--color-accent) border-(--color-accent) text-(--color-accent-foreground);
32
+ }
33
+
34
+ .stepper__item-completed .stepper__indicator {
35
+ @apply bg-(--color-accent) border-(--color-accent) text-(--color-accent-foreground);
36
+ }
37
+
38
+ .stepper__icon {
39
+ @apply size-5;
40
+ }
41
+
42
+ .stepper__number {
43
+ @apply text-sm font-semibold;
44
+ }
45
+
46
+ .stepper__dot {
47
+ @apply size-2.5 rounded-full bg-current;
48
+ }
49
+
50
+ .stepper__content {
51
+ @apply mt-3 flex flex-col gap-0.5;
52
+ }
53
+
54
+ .stepper__title {
55
+ @apply text-sm font-medium;
56
+ }
57
+
58
+ .stepper__item-pending .stepper__title {
59
+ @apply text-muted-foreground;
60
+ }
61
+
62
+ .stepper__item-current .stepper__title,
63
+ .stepper__item-completed .stepper__title {
64
+ @apply text-foreground;
65
+ }
66
+
67
+ .stepper__description {
68
+ @apply text-xs text-muted-foreground;
69
+ }
70
+
71
+ .stepper__link {
72
+ @apply relative z-10 flex flex-col items-center no-underline transition-opacity hover:opacity-80;
73
+ }
74
+
75
+ .stepper__item-has-url:not(.stepper__item-pending) {
76
+ @apply cursor-pointer;
77
+ }
78
+
79
+ .stepper__item-has-url.stepper__item-pending {
80
+ @apply cursor-not-allowed;
81
+ }
82
+ }
@@ -0,0 +1,68 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .scroller {
5
+ @apply w-full overflow-auto;
6
+ }
7
+
8
+ .scroller-x {
9
+ @apply overflow-x-auto;
10
+ }
11
+
12
+ .table {
13
+ @apply w-auto;
14
+
15
+ thead {
16
+ @apply bg-(--color-surface);
17
+ }
18
+
19
+ th, td {
20
+ @apply px-3 py-2 text-sm border-b border-border;
21
+ }
22
+
23
+ th {
24
+ @apply font-semibold text-left text-foreground;
25
+ }
26
+
27
+ tfoot {
28
+ @apply font-semibold bg-muted;
29
+ }
30
+ }
31
+
32
+ .table-full {
33
+ @apply min-w-full;
34
+ }
35
+
36
+ .table-hovered {
37
+ tbody tr:hover td,
38
+ thead tr:hover th {
39
+ @apply bg-muted;
40
+ }
41
+ }
42
+
43
+ .table-bordered {
44
+ th, td {
45
+ @apply border border-border;
46
+ }
47
+ }
48
+
49
+ .table__th_sticky {
50
+ @apply sticky z-10 bg-(--color-surface) hover:bg-muted;
51
+ }
52
+
53
+ .table__th_sticky-left { @apply left-0 text-left; }
54
+ .table__th_sticky-right { @apply right-0 text-right; }
55
+
56
+ .table__td_sticky { @apply sticky bg-(--color-surface); }
57
+ .table__td_sticky-left { @apply left-0 text-left; }
58
+ .table__td_sticky-right { @apply right-0 text-right; }
59
+
60
+ .table-xs { th, td { @apply px-2 py-2 text-xs; } }
61
+ .table-sm { th, td { @apply px-3 py-2 text-sm; } }
62
+ .table-md { th, td { @apply px-3 py-2.5 text-sm; } }
63
+ .table-lg { th, td { @apply px-4 py-4 text-base; } }
64
+
65
+ .table__actions {
66
+ @apply w-0 text-right;
67
+ }
68
+ }
@@ -0,0 +1,32 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .tabs__list {
5
+ @apply inline-flex gap-1 p-1 text-sm list-none bg-muted rounded-(--radius-btn-md);
6
+ }
7
+
8
+ .tabs__link {
9
+ @apply inline-flex items-center gap-2 px-3 py-1.5 font-medium transition-colors;
10
+ @apply text-muted-foreground rounded-(--radius-btn-md);
11
+ @apply hover:text-foreground;
12
+ @apply focus:outline-none focus-visible:ring-2 focus-visible:ring-(--color-ring);
13
+ }
14
+
15
+ .tabs__link--active {
16
+ @apply shadow-sm text-foreground bg-(--color-surface);
17
+ }
18
+
19
+ /* Underline variant */
20
+ .tabs--underline .tabs__list {
21
+ @apply w-full gap-6 p-0 bg-transparent rounded-none border-b border-(--color-border);
22
+ }
23
+
24
+ .tabs--underline .tabs__link {
25
+ @apply px-0 py-4 rounded-none -mb-px border-b-2 border-transparent;
26
+ @apply hover:text-foreground hover:border-(--color-border);
27
+ }
28
+
29
+ .tabs--underline .tabs__link--active {
30
+ @apply bg-transparent shadow-none text-(--color-accent) border-(--color-accent);
31
+ }
32
+ }
@@ -0,0 +1,174 @@
1
+ @layer base {
2
+ @keyframes fadeIn {
3
+ from { opacity: 0; }
4
+ to { opacity: 1; }
5
+ }
6
+
7
+ @keyframes slideUp {
8
+ from { opacity: 0.7; transform: translateY(2rem); }
9
+ to { opacity: 1; transform: translateY(0); }
10
+ }
11
+
12
+ @keyframes slideLeft {
13
+ from { opacity: 0.8; transform: translateX(3rem); }
14
+ to { opacity: 1; transform: translateX(0); }
15
+ }
16
+ }
17
+
18
+ :root {
19
+ --accent-hue: 262;
20
+ --accent-chroma: 0.245;
21
+ --accent-lightness: 0.55;
22
+ --gray-chroma: 0.006;
23
+ }
24
+
25
+ @theme {
26
+ /* Layout */
27
+ --height-navbar: 54px;
28
+ --width-sidebar: 220px;
29
+ --spacing-navbar: var(--height-navbar);
30
+ --spacing-sidebar: var(--width-sidebar);
31
+
32
+ /* Animations */
33
+ --animate-fade-in: fadeIn 0.15s ease-in-out;
34
+ --animate-slide-up: slideUp 0.3s ease-in-out;
35
+ --animate-slide-left: slideLeft 0.3s ease-in-out;
36
+
37
+ /* Radius */
38
+ --radius-btn-xs: calc(var(--radius-md) * 0.75);
39
+ --radius-btn-sm: calc(var(--radius-md) * 1);
40
+ --radius-btn-md: calc(var(--radius-md) * 1.125);
41
+ --radius-btn-lg: calc(var(--radius-md) * 1.25);
42
+ --radius-card: calc(var(--radius-md) * 1.5);
43
+ --radius-modal: calc(var(--radius-md) * 1.5);
44
+ --radius-dropdown: calc(var(--radius-md) * 1.5);
45
+ --radius-field: var(--radius-md);
46
+ --radius-tooltip: var(--radius-sm);
47
+
48
+ /* Dynamic Gray */
49
+ --color-gray-50: oklch(0.985 var(--gray-chroma) var(--accent-hue));
50
+ --color-gray-100: oklch(0.967 var(--gray-chroma) var(--accent-hue));
51
+ --color-gray-200: oklch(0.928 var(--gray-chroma) var(--accent-hue));
52
+ --color-gray-300: oklch(0.872 var(--gray-chroma) var(--accent-hue));
53
+ --color-gray-400: oklch(0.707 var(--gray-chroma) var(--accent-hue));
54
+ --color-gray-500: oklch(0.551 var(--gray-chroma) var(--accent-hue));
55
+ --color-gray-600: oklch(0.446 var(--gray-chroma) var(--accent-hue));
56
+ --color-gray-700: oklch(0.373 var(--gray-chroma) var(--accent-hue));
57
+ --color-gray-800: oklch(0.278 var(--gray-chroma) var(--accent-hue));
58
+ --color-gray-900: oklch(0.21 var(--gray-chroma) var(--accent-hue));
59
+ --color-gray-950: oklch(0.13 var(--gray-chroma) var(--accent-hue));
60
+
61
+ /* Card / Popover (semantic surface tokens) */
62
+ --color-card: var(--color-surface);
63
+ --color-card-foreground: var(--color-surface-foreground);
64
+ --color-popover: var(--color-surface);
65
+ --color-popover-foreground: var(--color-surface-foreground);
66
+
67
+ /* Layout */
68
+ --color-background: var(--color-gray-50);
69
+ --color-foreground: var(--color-gray-900);
70
+ --color-surface: oklch(1 0 0);
71
+ --color-surface-foreground: var(--color-gray-900);
72
+ --color-overlay: oklch(0.21 var(--gray-chroma) var(--accent-hue) / 0.5);
73
+
74
+ /* Accent */
75
+ --color-accent: oklch(var(--accent-lightness) var(--accent-chroma) var(--accent-hue));
76
+ --color-accent-hover: oklch(calc(var(--accent-lightness) - 0.06) var(--accent-chroma) var(--accent-hue));
77
+ --color-accent-active: oklch(calc(var(--accent-lightness) - 0.12) var(--accent-chroma) var(--accent-hue));
78
+ --color-accent-foreground: oklch(1 0 0);
79
+
80
+ /* Muted */
81
+ --color-muted: oklch(0.97 var(--gray-chroma) var(--accent-hue));
82
+ --color-muted-hover: oklch(0.94 var(--gray-chroma) var(--accent-hue));
83
+ --color-muted-foreground: var(--color-gray-500);
84
+
85
+ /* Border & Input */
86
+ --color-border: var(--color-gray-200);
87
+ --color-input: var(--color-gray-300);
88
+ --color-input-focus: oklch(0.809 0.105 var(--accent-hue));
89
+ --color-ring: oklch(0.882 0.059 var(--accent-hue) / 0.5);
90
+
91
+ /* Destructive */
92
+ --color-destructive: var(--color-red-600);
93
+ --color-destructive-hover: var(--color-red-700);
94
+ --color-destructive-foreground: oklch(1 0 0);
95
+ --color-destructive-soft: var(--color-red-50);
96
+ --color-destructive-soft-foreground: var(--color-red-800);
97
+ --color-destructive-border: var(--color-red-200);
98
+
99
+ /* Success */
100
+ --color-success: var(--color-green-600);
101
+ --color-success-hover: var(--color-green-700);
102
+ --color-success-foreground: oklch(1 0 0);
103
+ --color-success-soft: var(--color-green-50);
104
+ --color-success-soft-foreground: var(--color-green-800);
105
+ --color-success-border: var(--color-green-200);
106
+
107
+ /* Warning */
108
+ --color-warning: var(--color-yellow-500);
109
+ --color-warning-hover: var(--color-yellow-600);
110
+ --color-warning-foreground: oklch(1 0 0);
111
+ --color-warning-soft: var(--color-yellow-50);
112
+ --color-warning-soft-foreground: var(--color-yellow-800);
113
+ --color-warning-border: var(--color-yellow-200);
114
+
115
+ /* Info */
116
+ --color-info: var(--color-blue-600);
117
+ --color-info-hover: var(--color-blue-700);
118
+ --color-info-foreground: oklch(1 0 0);
119
+ --color-info-soft: var(--color-blue-50);
120
+ --color-info-soft-foreground: var(--color-blue-800);
121
+ --color-info-border: var(--color-blue-200);
122
+
123
+ /* Link */
124
+ --color-link: var(--color-accent);
125
+ --color-link-hover: var(--color-accent-hover);
126
+ }
127
+
128
+ .dark {
129
+ --dark-chroma: calc(var(--gray-chroma) * 6);
130
+
131
+ --color-background: oklch(0.13 var(--dark-chroma) var(--accent-hue));
132
+ --color-foreground: oklch(0.85 var(--dark-chroma) var(--accent-hue));
133
+ --color-surface: oklch(0.17 var(--dark-chroma) var(--accent-hue));
134
+ --color-surface-foreground: oklch(0.95 var(--dark-chroma) var(--accent-hue));
135
+ --color-overlay: oklch(0 0 0 / 0.7);
136
+
137
+ --color-accent: oklch(calc(var(--accent-lightness) - 0.15) calc(var(--accent-chroma) * 0.55) var(--accent-hue));
138
+ --color-accent-hover: oklch(calc(var(--accent-lightness) - 0.1) calc(var(--accent-chroma) * 0.6) var(--accent-hue));
139
+ --color-accent-active: oklch(calc(var(--accent-lightness) - 0.2) calc(var(--accent-chroma) * 0.5) var(--accent-hue));
140
+ --color-accent-foreground: oklch(1 0 0);
141
+
142
+ --color-muted: oklch(0.2 var(--dark-chroma) var(--accent-hue));
143
+ --color-muted-hover: oklch(0.24 var(--dark-chroma) var(--accent-hue));
144
+ --color-muted-foreground: oklch(0.6 var(--dark-chroma) var(--accent-hue));
145
+
146
+ --color-border: oklch(0.28 var(--dark-chroma) var(--accent-hue));
147
+ --color-input: oklch(0.32 var(--dark-chroma) var(--accent-hue));
148
+ --color-input-focus: oklch(0.55 0.15 var(--accent-hue));
149
+ --color-ring: oklch(0.5 0.12 var(--accent-hue) / 0.35);
150
+
151
+ --color-destructive: oklch(0.5 0.12 25);
152
+ --color-destructive-hover: oklch(0.55 0.14 25);
153
+ --color-destructive-foreground: oklch(1 0 0);
154
+ --color-destructive-soft: oklch(0.2 0.04 25);
155
+ --color-destructive-border: oklch(0.35 0.08 25);
156
+
157
+ --color-success: oklch(0.7 0.19 145);
158
+ --color-success-hover: oklch(0.75 0.2 145);
159
+ --color-success-foreground: oklch(0.15 0.04 145);
160
+ --color-success-soft: oklch(0.2 0.035 145);
161
+ --color-success-border: oklch(0.35 0.07 145);
162
+
163
+ --color-warning: oklch(0.8 0.16 85);
164
+ --color-warning-hover: oklch(0.85 0.17 85);
165
+ --color-warning-foreground: oklch(0.2 0.04 85);
166
+ --color-warning-soft: oklch(0.22 0.035 85);
167
+ --color-warning-border: oklch(0.38 0.07 85);
168
+
169
+ --color-info: oklch(0.7 0.16 240);
170
+ --color-info-hover: oklch(0.75 0.18 240);
171
+ --color-info-foreground: oklch(1 0 0);
172
+ --color-info-soft: oklch(0.2 0.04 240);
173
+ --color-info-border: oklch(0.35 0.08 240);
174
+ }
@@ -0,0 +1,45 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .timeline {
5
+ @apply relative flex flex-col;
6
+ }
7
+
8
+ .timeline-item {
9
+ @apply relative flex gap-4 pb-8;
10
+ }
11
+
12
+ .timeline-item:last-child {
13
+ @apply pb-0;
14
+ }
15
+
16
+ .timeline-item:not(:last-child)::before {
17
+ content: "";
18
+ @apply absolute left-[11px] top-6 bottom-0 w-0.5 bg-border;
19
+ }
20
+
21
+ .timeline-dot {
22
+ @apply relative z-10 flex-shrink-0 size-6 rounded-full border-2 flex items-center justify-center;
23
+ }
24
+
25
+ .timeline-dot-default { @apply bg-muted border-border; }
26
+ .timeline-dot-info { @apply bg-info-soft border-info; }
27
+ .timeline-dot-success { @apply bg-success-soft border-success; }
28
+ .timeline-dot-warning { @apply bg-warning-soft border-warning; }
29
+ .timeline-dot-error { @apply bg-destructive-soft border-destructive; }
30
+
31
+ .timeline-dot-icon { @apply size-6; }
32
+ .timeline-dot-icon.timeline-dot-default { @apply text-muted-foreground; }
33
+ .timeline-dot-icon.timeline-dot-info { @apply text-info; }
34
+ .timeline-dot-icon.timeline-dot-success { @apply text-success; }
35
+ .timeline-dot-icon.timeline-dot-warning { @apply text-warning; }
36
+ .timeline-dot-icon.timeline-dot-error { @apply text-destructive; }
37
+
38
+ .timeline-content {
39
+ @apply flex-1 pt-0.5;
40
+ }
41
+
42
+ .timeline-time {
43
+ @apply block text-sm mb-1 text-muted-foreground;
44
+ }
45
+ }
@@ -0,0 +1,33 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .tooltip {
5
+ --tooltip-bg: var(--color-gray-900);
6
+
7
+ @apply absolute z-20 px-3 py-2 text-xs text-center shadow-sm pointer-events-none;
8
+ @apply text-white rounded-tooltip;
9
+ background-color: var(--tooltip-bg);
10
+ }
11
+
12
+ .tooltip::after {
13
+ @apply absolute rotate-45 size-2;
14
+ background-color: var(--tooltip-bg);
15
+ content: "";
16
+ }
17
+
18
+ .tooltip[data-placement^="top"]::after {
19
+ @apply bottom-0 -translate-x-1/2 translate-y-1/2 left-1/2;
20
+ }
21
+
22
+ .tooltip[data-placement^="bottom"]::after {
23
+ @apply top-0 -translate-x-1/2 -translate-y-1/2 left-1/2;
24
+ }
25
+
26
+ .tooltip[data-placement^="left"]::after {
27
+ @apply right-0 translate-x-1/2 -translate-y-1/2 top-1/2;
28
+ }
29
+
30
+ .tooltip[data-placement^="right"]::after {
31
+ @apply left-0 -translate-x-1/2 -translate-y-1/2 top-1/2;
32
+ }
33
+ }
@@ -0,0 +1,28 @@
1
+ @import "./jet_ui/theme.css";
2
+ @import "./jet_ui/icon.css";
3
+ @import "./jet_ui/avatar.css";
4
+ @import "./jet_ui/breadcrumbs.css";
5
+ @import "./jet_ui/btn.css";
6
+ @import "./jet_ui/card.css";
7
+ @import "./jet_ui/badge.css";
8
+ @import "./jet_ui/alert.css";
9
+ @import "./jet_ui/group.css";
10
+ @import "./jet_ui/stat.css";
11
+ @import "./jet_ui/tabs.css";
12
+ @import "./jet_ui/empty.css";
13
+ @import "./jet_ui/list.css";
14
+ @import "./jet_ui/divider.css";
15
+ @import "./jet_ui/timeline.css";
16
+ @import "./jet_ui/stepper.css";
17
+ @import "./jet_ui/table.css";
18
+ @import "./jet_ui/pagy.css";
19
+ @import "./jet_ui/flash.css";
20
+ @import "./jet_ui/accordion.css";
21
+ @import "./jet_ui/sidebar.css";
22
+ @import "./jet_ui/header.css";
23
+ @import "./jet_ui/navbar.css";
24
+ @import "./jet_ui/modal.css";
25
+ @import "./jet_ui/drawer.css";
26
+ @import "./jet_ui/dropdown.css";
27
+ @import "./jet_ui/tooltip.css";
28
+ @import "./jet_ui/popover.css";
@@ -0,0 +1,21 @@
1
+ # frozen_string_literal: true
2
+
3
+ module JetUi
4
+ module Accordion
5
+ class BodyComponent < JetUi::BaseComponent
6
+ def initialize(**options)
7
+ @options = options
8
+ end
9
+
10
+ def call
11
+ content_tag :div, content, class: classes, **@options.except(:class)
12
+ end
13
+
14
+ private
15
+
16
+ def classes
17
+ class_names('accordion__body', @options[:class])
18
+ end
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,24 @@
1
+ # frozen_string_literal: true
2
+
3
+ module JetUi
4
+ module Accordion
5
+ class Component < JetUi::BaseComponent
6
+ def initialize(name: nil, open: false, **options)
7
+ @name = name
8
+ @open = open
9
+ @options = options
10
+ end
11
+
12
+ def call
13
+ content_tag :details, content, class: classes, name: @name, open: @open,
14
+ **@options.except(:class)
15
+ end
16
+
17
+ private
18
+
19
+ def classes
20
+ class_names('accordion', @options[:class])
21
+ end
22
+ end
23
+ end
24
+ end