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,24 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .accordion {
5
+ @apply w-full;
6
+ }
7
+
8
+ .accordion__summary {
9
+ @apply flex items-center justify-between gap-3 py-3.5 font-medium cursor-pointer;
10
+ }
11
+
12
+ .accordion__icon {
13
+ @apply size-4;
14
+ transition: transform 0.15s ease;
15
+ }
16
+
17
+ details[open] .accordion__icon {
18
+ transform: rotate(-180deg);
19
+ }
20
+
21
+ .accordion__body {
22
+ @apply pb-3.5;
23
+ }
24
+ }
@@ -0,0 +1,27 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .alert {
5
+ @apply grid items-center gap-x-2 px-3.5 py-3 rounded-card border text-sm;
6
+ }
7
+
8
+ .alert:has(.alert__icon) {
9
+ grid-template-columns: auto 1fr;
10
+ }
11
+
12
+ /* Variants */
13
+ .alert-default { @apply bg-muted border-border text-foreground; }
14
+ .alert-info { @apply bg-info-soft border-info-border text-info-soft-foreground; }
15
+ .alert-error { @apply bg-destructive-soft border-destructive-border text-destructive-soft-foreground; }
16
+ .alert-success { @apply bg-success-soft border-success-border text-success-soft-foreground; }
17
+ .alert-warning { @apply bg-warning-soft border-warning-border text-warning-soft-foreground; }
18
+
19
+ /* Subcomponents */
20
+ .alert__title { @apply font-semibold; }
21
+ .alert__icon { @apply flex items-center; }
22
+ .alert__description { }
23
+
24
+ .alert__icon ~ .alert__description {
25
+ grid-column-start: 2;
26
+ }
27
+ }
@@ -0,0 +1,15 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .avatar {
5
+ @apply relative flex items-center justify-center overflow-hidden font-medium text-muted-foreground bg-muted;
6
+ }
7
+
8
+ .avatar--circle {
9
+ @apply rounded-full;
10
+ }
11
+
12
+ .avatar--rounded {
13
+ @apply rounded-lg;
14
+ }
15
+ }
@@ -0,0 +1,22 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .badge {
5
+ @apply inline-flex items-center font-semibold w-fit whitespace-nowrap border;
6
+ }
7
+
8
+ /* Variants */
9
+ .badge-default { @apply bg-muted border-border text-foreground; }
10
+ .badge-info { @apply bg-info-soft border-info-border text-info-soft-foreground; }
11
+ .badge-error { @apply bg-destructive-soft border-destructive-border text-destructive-soft-foreground; }
12
+ .badge-success { @apply bg-success-soft border-success-border text-success-soft-foreground; }
13
+ .badge-warning { @apply bg-warning-soft border-warning-border text-warning-soft-foreground; }
14
+
15
+ /* Sizes */
16
+ .badge-xs { @apply px-1.5 py-0.5 text-[10px] rounded-btn-xs; }
17
+ .badge-sm { @apply px-2 py-1 text-[11px] rounded-btn-sm; }
18
+ .badge-md { @apply px-3 py-1.5 text-xs rounded-btn-md; }
19
+ .badge-lg { @apply px-4 py-2 text-[13px] rounded-btn-lg; }
20
+
21
+ .badge-rounded { @apply rounded-full; }
22
+ }
@@ -0,0 +1,28 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .breadcrumbs {
5
+ @apply text-sm text-muted-foreground;
6
+ }
7
+
8
+ .breadcrumbs__list {
9
+ @apply flex items-center flex-wrap list-none;
10
+ }
11
+
12
+ .breadcrumbs__item {
13
+ @apply flex items-center;
14
+ }
15
+
16
+ .breadcrumbs__item:not(:last-child)::after {
17
+ content: "/";
18
+ @apply mx-2 text-muted-foreground;
19
+ }
20
+
21
+ .breadcrumbs__link {
22
+ @apply text-muted-foreground hover:text-foreground transition-colors;
23
+ }
24
+
25
+ .breadcrumbs__current {
26
+ @apply text-foreground font-medium;
27
+ }
28
+ }
@@ -0,0 +1,88 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .btn {
5
+ @apply inline-flex items-center justify-center gap-2 w-fit;
6
+ @apply outline-none cursor-pointer shrink-0;
7
+ @apply font-medium text-center no-underline;
8
+ @apply transition-transform active:translate-y-px;
9
+ @apply focus-visible:ring-2 focus-visible:ring-(--color-ring) focus-visible:ring-offset-2 focus-visible:ring-offset-(--color-background);
10
+ }
11
+
12
+ .btn-default {
13
+ @apply bg-(--color-accent) text-(--color-accent-foreground);
14
+ @apply hover:bg-(--color-accent-hover);
15
+ }
16
+
17
+ .btn-outline {
18
+ @apply text-(--color-foreground) border border-(--color-input);
19
+ @apply hover:bg-(--color-muted);
20
+ }
21
+
22
+ .btn-secondary {
23
+ @apply bg-(--color-muted) text-(--color-foreground);
24
+ @apply hover:bg-(--color-muted-hover);
25
+ }
26
+
27
+ .btn-danger {
28
+ @apply bg-(--color-destructive) text-(--color-destructive-foreground);
29
+ @apply hover:bg-(--color-destructive-hover);
30
+ }
31
+
32
+ .btn-ghost {
33
+ @apply text-(--color-foreground);
34
+ @apply hover:bg-(--color-muted);
35
+ }
36
+
37
+ .btn-link {
38
+ @apply text-(--color-link) no-underline;
39
+ @apply hover:text-(--color-link-hover);
40
+ }
41
+
42
+ /* Sizes */
43
+ .btn-xs {
44
+ @apply px-2 text-xs min-h-6.5 gap-1 rounded-(--radius-btn-xs);
45
+ }
46
+
47
+ .btn-sm {
48
+ @apply px-3 text-sm min-h-8 gap-1.5 rounded-(--radius-btn-sm);
49
+ }
50
+
51
+ .btn-md {
52
+ @apply px-4 text-sm min-h-10 rounded-(--radius-btn-md);
53
+ }
54
+
55
+ .btn-lg {
56
+ @apply px-6 text-base min-h-12 rounded-(--radius-btn-lg);
57
+ }
58
+
59
+ /* Icon sizes */
60
+ .btn-icon-xs {
61
+ @apply size-6.5 rounded-(--radius-btn-xs);
62
+ }
63
+
64
+ .btn-icon-sm {
65
+ @apply size-8 rounded-(--radius-btn-sm);
66
+ }
67
+
68
+ .btn-icon-md {
69
+ @apply size-10 rounded-(--radius-btn-md);
70
+ }
71
+
72
+ .btn-icon-lg {
73
+ @apply size-12 rounded-(--radius-btn-lg);
74
+ }
75
+
76
+ /* Modifiers */
77
+ .btn-block {
78
+ @apply w-full;
79
+ }
80
+
81
+ .btn-rounded {
82
+ @apply rounded-full;
83
+ }
84
+
85
+ .btn-circle {
86
+ @apply p-0 rounded-full;
87
+ }
88
+ }
@@ -0,0 +1,61 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .card {
5
+ @apply block w-full bg-surface border border-border rounded-card;
6
+ }
7
+
8
+ /* ------------------------------------------------------------------ */
9
+ /* Header */
10
+ /* ------------------------------------------------------------------ */
11
+ .card__header {
12
+ @apply flex flex-col gap-1 items-start justify-start px-6 pt-4;
13
+ }
14
+
15
+ .card__header--row { @apply flex-row gap-6; }
16
+
17
+ .card__header--align-center { @apply items-center; }
18
+ .card__header--align-end { @apply items-end; }
19
+
20
+ .card__header--justify-center { @apply justify-center; }
21
+ .card__header--justify-end { @apply justify-end; }
22
+ .card__header--justify-between { @apply justify-between; }
23
+
24
+ .card__header-bordered { @apply pb-4 border-b border-border; }
25
+
26
+ /* ------------------------------------------------------------------ */
27
+ /* Body */
28
+ /* ------------------------------------------------------------------ */
29
+ .card__body {
30
+ @apply px-6 py-4;
31
+ }
32
+
33
+ /* ------------------------------------------------------------------ */
34
+ /* Footer */
35
+ /* ------------------------------------------------------------------ */
36
+ .card__footer {
37
+ @apply flex flex-row gap-4 items-start justify-start px-6 pb-4;
38
+ }
39
+
40
+ .card__footer--col { @apply flex-col gap-1; }
41
+
42
+ .card__footer--align-center { @apply items-center; }
43
+ .card__footer--align-end { @apply items-end; }
44
+
45
+ .card__footer--justify-center { @apply justify-center; }
46
+ .card__footer--justify-end { @apply justify-end; }
47
+ .card__footer--justify-between { @apply justify-between; }
48
+
49
+ .card__footer-bordered { @apply pt-4 border-t border-border; }
50
+
51
+ /* ------------------------------------------------------------------ */
52
+ /* Title & Subtitle */
53
+ /* ------------------------------------------------------------------ */
54
+ .card__title {
55
+ @apply text-lg font-semibold;
56
+ }
57
+
58
+ .card__subtitle {
59
+ @apply text-sm text-muted-foreground;
60
+ }
61
+ }
@@ -0,0 +1,21 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .divider {
5
+ @apply flex items-center gap-3 text-sm text-muted-foreground;
6
+ }
7
+
8
+ .divider::before,
9
+ .divider::after {
10
+ content: "";
11
+ @apply flex-1 border-t border-(--color-border);
12
+ }
13
+
14
+ .divider-start::before {
15
+ @apply flex-none w-4;
16
+ }
17
+
18
+ .divider-end::after {
19
+ @apply flex-none w-4;
20
+ }
21
+ }
@@ -0,0 +1,46 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .drawer {
5
+ @apply fixed inset-0 left-auto flex-col hidden m-0 min-h-full shadow-sm w-2xl;
6
+ @apply bg-card backdrop:bg-overlay rounded-tl-modal rounded-bl-modal;
7
+ }
8
+
9
+ .drawer[open] {
10
+ @apply flex;
11
+ }
12
+
13
+ .drawer__header {
14
+ @apply sticky top-0 flex items-center justify-between p-4 px-6 backdrop-blur-sm bg-card/70;
15
+ }
16
+
17
+ .drawer__header-bordered {
18
+ @apply border-b border-border;
19
+ }
20
+
21
+ .drawer__title {
22
+ @apply text-xl font-semibold leading-tight text-foreground;
23
+ }
24
+
25
+ .drawer__subtitle {
26
+ @apply mt-1 text-sm text-muted-foreground;
27
+ }
28
+
29
+ .drawer__close {
30
+ @apply inline-flex items-center p-1 ml-auto text-sm transition-all duration-300 bg-transparent rounded-full cursor-pointer outline-0;
31
+ @apply text-muted-foreground hover:bg-accent hover:text-accent-foreground;
32
+ }
33
+
34
+ .drawer__body {
35
+ @apply flex-1 p-6 text-muted-foreground;
36
+ }
37
+
38
+ .drawer__footer {
39
+ @apply sticky bottom-0 w-full p-4 backdrop-blur-sm bg-card/70;
40
+ border-bottom-left-radius: var(--radius-modal);
41
+ }
42
+
43
+ .drawer__footer-bordered {
44
+ @apply border-t border-border;
45
+ }
46
+ }
@@ -0,0 +1,33 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .dropdown {
5
+ @apply relative w-fit;
6
+ }
7
+
8
+ .dropdown__menu {
9
+ @apply absolute z-40 hidden overflow-auto py-1.5 shadow min-w-44 animate-fade-in max-w-96 max-h-96;
10
+ @apply bg-popover border border-border text-foreground rounded-dropdown;
11
+ }
12
+
13
+ .dropdown__title {
14
+ @apply px-4 py-1 font-semibold text-sm text-foreground;
15
+ }
16
+
17
+ .dropdown__item {
18
+ @apply block mx-2;
19
+ }
20
+
21
+ .dropdown__link {
22
+ @apply block w-full px-2 py-1.5 text-sm text-left cursor-pointer rounded-btn-md;
23
+ @apply hover:bg-accent hover:text-accent-foreground;
24
+ }
25
+
26
+ .dropdown__link-active {
27
+ @apply bg-accent text-accent-foreground;
28
+ }
29
+
30
+ .dropdown__divider {
31
+ @apply pb-2 mb-2 border-b border-border;
32
+ }
33
+ }
@@ -0,0 +1,25 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .empty {
5
+ @apply flex flex-col items-center text-center py-12 px-4;
6
+ }
7
+
8
+ .empty__icon {
9
+ @apply flex items-center justify-center mb-4 bg-muted text-muted-foreground rounded-xl;
10
+ width: calc(var(--spacing) * 14);
11
+ height: calc(var(--spacing) * 14);
12
+ }
13
+
14
+ .empty__title {
15
+ @apply text-xl font-semibold text-foreground;
16
+ }
17
+
18
+ .empty__description {
19
+ @apply text-muted-foreground mt-1;
20
+ }
21
+
22
+ .empty__actions {
23
+ @apply mt-6;
24
+ }
25
+ }
@@ -0,0 +1,50 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .flash-container {
5
+ @apply fixed flex flex-col items-end gap-2 top-3 left-3 right-3 z-[100];
6
+ @apply md:left-auto md:w-fit;
7
+ }
8
+
9
+ .flash-item {
10
+ @apply relative w-full py-3 pl-4 pr-12 text-sm rounded-xl text-white;
11
+ @apply md:max-w-lg md:w-fit;
12
+ min-width: 20rem;
13
+ opacity: 0;
14
+ transform: translateX(25%);
15
+ transition: opacity 300ms, transform 300ms;
16
+ }
17
+
18
+ .flash-item--hidden {
19
+ display: none;
20
+ }
21
+
22
+ .flash-item--visible {
23
+ opacity: 1;
24
+ transform: translateX(0);
25
+ }
26
+
27
+ .flash-item-info {
28
+ background-color: var(--color-info);
29
+ }
30
+
31
+ .flash-item-success {
32
+ background-color: var(--color-success);
33
+ }
34
+
35
+ .flash-item-warning {
36
+ background-color: var(--color-warning);
37
+ }
38
+
39
+ .flash-item-error {
40
+ background-color: var(--color-destructive);
41
+ }
42
+
43
+ .flash-item__message {
44
+ @apply flex-1;
45
+ }
46
+
47
+ .flash-item__close {
48
+ @apply absolute top-2.5 right-3 text-white transition duration-300 focus:outline-none opacity-80 hover:opacity-100;
49
+ }
50
+ }
@@ -0,0 +1,40 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .ui_group {
5
+ @apply inline-flex items-center gap-2;
6
+ }
7
+
8
+ .ui_group-sticky {
9
+ @apply gap-0;
10
+
11
+ > .btn:first-child,
12
+ > *:first-child .btn {
13
+ @apply rounded-r-none;
14
+ }
15
+
16
+ > .btn:last-child,
17
+ > *:last-child .btn {
18
+ @apply rounded-l-none;
19
+ }
20
+
21
+ > *:not(:last-child) .btn-outline,
22
+ > .btn-outline:not(:last-child) {
23
+ @apply border-r-0;
24
+ }
25
+
26
+ > *:not(:last-child) .btn-default,
27
+ > .btn-default:not(:last-child),
28
+ > *:not(:last-child) .btn-secondary,
29
+ > .btn-secondary:not(:last-child),
30
+ > *:not(:last-child) .btn-danger,
31
+ > .btn-danger:not(:last-child) {
32
+ @apply border-r border-r-surface/25;
33
+ }
34
+
35
+ > *:not(:first-child):not(:last-child) .btn,
36
+ > .btn:not(:first-child):not(:last-child) {
37
+ @apply rounded-none;
38
+ }
39
+ }
40
+ }
@@ -0,0 +1,65 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .header {
5
+ @apply flex gap-y-2 py-3;
6
+ column-gap: calc(var(--spacing) * 8);
7
+ }
8
+
9
+ .header--row { flex-direction: column; }
10
+ .header--col { flex-direction: column; }
11
+
12
+ .header--align-start { @apply items-start; }
13
+ .header--align-center { @apply items-center; }
14
+ .header--align-end { @apply items-end; }
15
+
16
+ .header--justify-start { @apply justify-start; }
17
+ .header--justify-center { @apply justify-center; }
18
+ .header--justify-end { @apply justify-end; }
19
+ .header--justify-between { @apply justify-between; }
20
+
21
+ .header--bordered {
22
+ @apply pb-4 border-b border-border;
23
+ }
24
+
25
+ .header__heading {
26
+ @apply flex-1 flex flex-col gap-2;
27
+ }
28
+
29
+ .header__title {
30
+ @apply flex items-center gap-2 flex-1 font-semibold tracking-tight text-3xl;
31
+ }
32
+
33
+ .header__subtitle {
34
+ @apply text-base text-muted-foreground;
35
+ }
36
+
37
+ .header__actions {
38
+ @apply flex items-center shrink-0 gap-2 whitespace-nowrap;
39
+ }
40
+ }
41
+
42
+ @media (min-width: 768px) {
43
+ .header {
44
+ padding-block: calc(var(--spacing) * 6);
45
+ }
46
+
47
+ .header--row {
48
+ flex-direction: row;
49
+ }
50
+ }
51
+
52
+ @media (min-width: 1024px) {
53
+ .header {
54
+ column-gap: calc(var(--spacing) * 16);
55
+ }
56
+
57
+ .header--sticky {
58
+ position: sticky;
59
+ z-index: 30;
60
+ top: var(--height-navbar);
61
+ background-color: color-mix(in oklab, var(--color-muted) 90%, transparent);
62
+ -webkit-backdrop-filter: blur(var(--blur-xs));
63
+ backdrop-filter: blur(var(--blur-xs));
64
+ }
65
+ }
@@ -0,0 +1,11 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .icon {
5
+ display: inline-block;
6
+ flex-shrink: 0;
7
+ vertical-align: middle;
8
+ width: calc(var(--spacing) * 5);
9
+ height: calc(var(--spacing) * 5);
10
+ }
11
+ }
@@ -0,0 +1,31 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .list {
5
+ @apply w-full;
6
+ }
7
+
8
+ .list__item {
9
+ @apply flex items-center gap-3 px-4 py-3;
10
+ }
11
+
12
+ .list--divided .list__item {
13
+ @apply border-b border-(--color-border);
14
+ }
15
+
16
+ .list--divided .list__item:last-child {
17
+ @apply border-b-0;
18
+ }
19
+
20
+ .list__icon {
21
+ @apply flex-shrink-0 text-muted-foreground;
22
+ }
23
+
24
+ .list__content {
25
+ @apply flex-1 min-w-0;
26
+ }
27
+
28
+ .list__action {
29
+ @apply flex-shrink-0 ml-auto;
30
+ }
31
+ }
@@ -0,0 +1,47 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .modal {
5
+ @apply p-0 m-auto shadow-sm max-w-11/12 h-fit w-2xl;
6
+ @apply bg-card rounded-modal backdrop:bg-overlay;
7
+ }
8
+
9
+ .modal-page {
10
+ @apply mt-4;
11
+ }
12
+
13
+ .modal__header {
14
+ @apply sticky top-0 flex items-start justify-between p-4 px-6 backdrop-blur-sm bg-card/70;
15
+ }
16
+
17
+ .modal__header-bordered {
18
+ @apply border-b border-border;
19
+ }
20
+
21
+ .modal__title {
22
+ @apply text-xl font-semibold leading-tight text-foreground;
23
+ }
24
+
25
+ .modal__subtitle {
26
+ @apply mt-1 text-sm text-muted-foreground;
27
+ }
28
+
29
+ .modal__close {
30
+ @apply inline-flex items-center p-1 ml-auto text-sm transition-all duration-300 bg-transparent rounded-full cursor-pointer outline-0;
31
+ @apply text-muted-foreground hover:bg-accent hover:text-accent-foreground;
32
+ }
33
+
34
+ .modal__body {
35
+ @apply px-6 py-6 overflow-auto rounded-modal;
36
+ }
37
+
38
+ .modal__footer {
39
+ @apply sticky bottom-0 w-full p-4 backdrop-blur-sm bg-card/70;
40
+ border-bottom-left-radius: var(--radius-modal);
41
+ border-bottom-right-radius: var(--radius-modal);
42
+ }
43
+
44
+ .modal__footer-bordered {
45
+ @apply border-t border-border;
46
+ }
47
+ }
@@ -0,0 +1,36 @@
1
+ @layer theme, base, components, utilities;
2
+
3
+ @layer components {
4
+ .navbar {
5
+ @apply z-20 w-full backdrop-blur-xs bg-background/90;
6
+ @apply flex items-center justify-between gap-6;
7
+ height: var(--height-navbar);
8
+ }
9
+
10
+ .navbar-sticky {
11
+ @apply sticky top-0;
12
+ }
13
+
14
+ .navbar__brand {
15
+ @apply flex items-center gap-3;
16
+ }
17
+
18
+ .navbar__main {
19
+ @apply flex flex-1 items-center justify-between;
20
+ }
21
+
22
+ .navbar__content {
23
+ @apply flex items-center gap-4;
24
+ }
25
+
26
+ .navbar__actions {
27
+ @apply flex items-center gap-2;
28
+ }
29
+ }
30
+
31
+ @media (min-width: 768px) {
32
+ .navbar {
33
+ display: grid;
34
+ grid-template-columns: var(--width-sidebar) 1fr;
35
+ }
36
+ }