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.
- checksums.yaml +7 -0
- data/CHANGELOG.md +106 -0
- data/LICENSE.md +21 -0
- data/README.md +114 -0
- data/app/assets/images/jet_ui/icons/academic-cap.svg +3 -0
- data/app/assets/images/jet_ui/icons/adjustments-horizontal.svg +3 -0
- data/app/assets/images/jet_ui/icons/adjustments-vertical.svg +3 -0
- data/app/assets/images/jet_ui/icons/archive-box-arrow-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/archive-box-x-mark.svg +3 -0
- data/app/assets/images/jet_ui/icons/archive-box.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-down-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-down-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-down-on-square-stack.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-down-on-square.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-down-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-down-tray.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-left-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-left-end-on-rectangle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-left-on-rectangle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-left-start-on-rectangle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-long-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-long-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-long-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-long-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-path-rounded-square.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-path.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-right-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-right-end-on-rectangle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-right-on-rectangle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-right-start-on-rectangle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-small-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-small-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-small-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-small-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-top-right-on-square.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-trending-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-trending-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-turn-down-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-turn-down-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-turn-left-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-turn-left-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-turn-right-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-turn-right-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-turn-up-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-turn-up-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-up-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-up-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-up-on-square-stack.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-up-on-square.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-up-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-up-tray.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-uturn-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-uturn-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-uturn-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrow-uturn-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrows-pointing-in.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrows-pointing-out.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrows-right-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/arrows-up-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/at-symbol.svg +3 -0
- data/app/assets/images/jet_ui/icons/backspace.svg +3 -0
- data/app/assets/images/jet_ui/icons/backward.svg +4 -0
- data/app/assets/images/jet_ui/icons/banknotes.svg +3 -0
- data/app/assets/images/jet_ui/icons/bars-2.svg +3 -0
- data/app/assets/images/jet_ui/icons/bars-3-bottom-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/bars-3-bottom-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/bars-3-center-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/bars-3.svg +3 -0
- data/app/assets/images/jet_ui/icons/bars-4.svg +3 -0
- data/app/assets/images/jet_ui/icons/bars-arrow-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/bars-arrow-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/battery-0.svg +3 -0
- data/app/assets/images/jet_ui/icons/battery-100.svg +3 -0
- data/app/assets/images/jet_ui/icons/battery-50.svg +3 -0
- data/app/assets/images/jet_ui/icons/beaker.svg +3 -0
- data/app/assets/images/jet_ui/icons/bell-alert.svg +3 -0
- data/app/assets/images/jet_ui/icons/bell-slash.svg +3 -0
- data/app/assets/images/jet_ui/icons/bell-snooze.svg +3 -0
- data/app/assets/images/jet_ui/icons/bell.svg +3 -0
- data/app/assets/images/jet_ui/icons/bold.svg +3 -0
- data/app/assets/images/jet_ui/icons/bolt-slash.svg +3 -0
- data/app/assets/images/jet_ui/icons/bolt.svg +3 -0
- data/app/assets/images/jet_ui/icons/book-open.svg +3 -0
- data/app/assets/images/jet_ui/icons/bookmark-slash.svg +3 -0
- data/app/assets/images/jet_ui/icons/bookmark-square.svg +3 -0
- data/app/assets/images/jet_ui/icons/bookmark.svg +3 -0
- data/app/assets/images/jet_ui/icons/briefcase.svg +3 -0
- data/app/assets/images/jet_ui/icons/bug-ant.svg +3 -0
- data/app/assets/images/jet_ui/icons/building-library.svg +3 -0
- data/app/assets/images/jet_ui/icons/building-office-2.svg +3 -0
- data/app/assets/images/jet_ui/icons/building-office.svg +3 -0
- data/app/assets/images/jet_ui/icons/building-storefront.svg +3 -0
- data/app/assets/images/jet_ui/icons/cake.svg +3 -0
- data/app/assets/images/jet_ui/icons/calculator.svg +3 -0
- data/app/assets/images/jet_ui/icons/calendar-date-range.svg +3 -0
- data/app/assets/images/jet_ui/icons/calendar-days.svg +3 -0
- data/app/assets/images/jet_ui/icons/calendar.svg +3 -0
- data/app/assets/images/jet_ui/icons/camera.svg +5 -0
- data/app/assets/images/jet_ui/icons/chart-bar-square.svg +3 -0
- data/app/assets/images/jet_ui/icons/chart-bar.svg +5 -0
- data/app/assets/images/jet_ui/icons/chart-pie.svg +4 -0
- data/app/assets/images/jet_ui/icons/chat-bubble-bottom-center-text.svg +3 -0
- data/app/assets/images/jet_ui/icons/chat-bubble-bottom-center.svg +3 -0
- data/app/assets/images/jet_ui/icons/chat-bubble-left-ellipsis.svg +3 -0
- data/app/assets/images/jet_ui/icons/chat-bubble-left-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/chat-bubble-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/chat-bubble-oval-left-ellipsis.svg +3 -0
- data/app/assets/images/jet_ui/icons/chat-bubble-oval-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/check-badge.svg +3 -0
- data/app/assets/images/jet_ui/icons/check-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/check.svg +3 -0
- data/app/assets/images/jet_ui/icons/chevron-double-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/chevron-double-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/chevron-double-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/chevron-double-up.svg +4 -0
- data/app/assets/images/jet_ui/icons/chevron-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/chevron-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/chevron-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/chevron-up-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/chevron-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/circle-stack.svg +3 -0
- data/app/assets/images/jet_ui/icons/clipboard-document-check.svg +3 -0
- data/app/assets/images/jet_ui/icons/clipboard-document-list.svg +3 -0
- data/app/assets/images/jet_ui/icons/clipboard-document.svg +3 -0
- data/app/assets/images/jet_ui/icons/clipboard.svg +3 -0
- data/app/assets/images/jet_ui/icons/clock.svg +3 -0
- data/app/assets/images/jet_ui/icons/cloud-arrow-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/cloud-arrow-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/cloud.svg +3 -0
- data/app/assets/images/jet_ui/icons/code-bracket-square.svg +3 -0
- data/app/assets/images/jet_ui/icons/code-bracket.svg +3 -0
- data/app/assets/images/jet_ui/icons/cog-6-tooth.svg +4 -0
- data/app/assets/images/jet_ui/icons/cog-8-tooth.svg +4 -0
- data/app/assets/images/jet_ui/icons/cog.svg +3 -0
- data/app/assets/images/jet_ui/icons/command-line.svg +3 -0
- data/app/assets/images/jet_ui/icons/computer-desktop.svg +3 -0
- data/app/assets/images/jet_ui/icons/cpu-chip.svg +3 -0
- data/app/assets/images/jet_ui/icons/credit-card.svg +3 -0
- data/app/assets/images/jet_ui/icons/cube-transparent.svg +3 -0
- data/app/assets/images/jet_ui/icons/cube.svg +3 -0
- data/app/assets/images/jet_ui/icons/currency-bangladeshi.svg +3 -0
- data/app/assets/images/jet_ui/icons/currency-dollar.svg +3 -0
- data/app/assets/images/jet_ui/icons/currency-euro.svg +3 -0
- data/app/assets/images/jet_ui/icons/currency-pound.svg +3 -0
- data/app/assets/images/jet_ui/icons/currency-rupee.svg +3 -0
- data/app/assets/images/jet_ui/icons/currency-yen.svg +3 -0
- data/app/assets/images/jet_ui/icons/cursor-arrow-rays.svg +3 -0
- data/app/assets/images/jet_ui/icons/cursor-arrow-ripple.svg +3 -0
- data/app/assets/images/jet_ui/icons/device-phone-mobile.svg +3 -0
- data/app/assets/images/jet_ui/icons/device-tablet.svg +3 -0
- data/app/assets/images/jet_ui/icons/divide.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-arrow-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-arrow-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-chart-bar.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-check.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-currency-bangladeshi.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-currency-dollar.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-currency-euro.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-currency-pound.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-currency-rupee.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-currency-yen.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-duplicate.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-magnifying-glass.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-minus.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-plus.svg +3 -0
- data/app/assets/images/jet_ui/icons/document-text.svg +3 -0
- data/app/assets/images/jet_ui/icons/document.svg +3 -0
- data/app/assets/images/jet_ui/icons/ellipsis-horizontal-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/ellipsis-horizontal.svg +5 -0
- data/app/assets/images/jet_ui/icons/ellipsis-vertical.svg +5 -0
- data/app/assets/images/jet_ui/icons/envelope-open.svg +3 -0
- data/app/assets/images/jet_ui/icons/envelope.svg +3 -0
- data/app/assets/images/jet_ui/icons/equals.svg +3 -0
- data/app/assets/images/jet_ui/icons/exclamation-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/exclamation-triangle.svg +3 -0
- data/app/assets/images/jet_ui/icons/eye-dropper.svg +3 -0
- data/app/assets/images/jet_ui/icons/eye-slash.svg +3 -0
- data/app/assets/images/jet_ui/icons/eye.svg +4 -0
- data/app/assets/images/jet_ui/icons/face-frown.svg +3 -0
- data/app/assets/images/jet_ui/icons/face-smile.svg +3 -0
- data/app/assets/images/jet_ui/icons/film.svg +3 -0
- data/app/assets/images/jet_ui/icons/finger-print.svg +3 -0
- data/app/assets/images/jet_ui/icons/fire.svg +4 -0
- data/app/assets/images/jet_ui/icons/flag.svg +3 -0
- data/app/assets/images/jet_ui/icons/folder-arrow-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/folder-minus.svg +3 -0
- data/app/assets/images/jet_ui/icons/folder-open.svg +3 -0
- data/app/assets/images/jet_ui/icons/folder-plus.svg +3 -0
- data/app/assets/images/jet_ui/icons/folder.svg +3 -0
- data/app/assets/images/jet_ui/icons/forward.svg +4 -0
- data/app/assets/images/jet_ui/icons/funnel.svg +3 -0
- data/app/assets/images/jet_ui/icons/gif.svg +3 -0
- data/app/assets/images/jet_ui/icons/gift-top.svg +3 -0
- data/app/assets/images/jet_ui/icons/gift.svg +3 -0
- data/app/assets/images/jet_ui/icons/github.svg +10 -0
- data/app/assets/images/jet_ui/icons/globe-alt.svg +3 -0
- data/app/assets/images/jet_ui/icons/globe-americas.svg +3 -0
- data/app/assets/images/jet_ui/icons/globe-asia-australia.svg +3 -0
- data/app/assets/images/jet_ui/icons/globe-europe-africa.svg +3 -0
- data/app/assets/images/jet_ui/icons/h1.svg +3 -0
- data/app/assets/images/jet_ui/icons/h2.svg +3 -0
- data/app/assets/images/jet_ui/icons/h3.svg +3 -0
- data/app/assets/images/jet_ui/icons/hand-raised.svg +3 -0
- data/app/assets/images/jet_ui/icons/hand-thumb-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/hand-thumb-up.svg +3 -0
- data/app/assets/images/jet_ui/icons/hashtag.svg +3 -0
- data/app/assets/images/jet_ui/icons/heart.svg +3 -0
- data/app/assets/images/jet_ui/icons/home-modern.svg +3 -0
- data/app/assets/images/jet_ui/icons/home.svg +3 -0
- data/app/assets/images/jet_ui/icons/identification.svg +3 -0
- data/app/assets/images/jet_ui/icons/inbox-arrow-down.svg +3 -0
- data/app/assets/images/jet_ui/icons/inbox-stack.svg +3 -0
- data/app/assets/images/jet_ui/icons/inbox.svg +3 -0
- data/app/assets/images/jet_ui/icons/information-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/italic.svg +3 -0
- data/app/assets/images/jet_ui/icons/key.svg +3 -0
- data/app/assets/images/jet_ui/icons/language.svg +3 -0
- data/app/assets/images/jet_ui/icons/lifebuoy.svg +3 -0
- data/app/assets/images/jet_ui/icons/light-bulb.svg +3 -0
- data/app/assets/images/jet_ui/icons/link-slash.svg +3 -0
- data/app/assets/images/jet_ui/icons/link.svg +3 -0
- data/app/assets/images/jet_ui/icons/list-bullet.svg +3 -0
- data/app/assets/images/jet_ui/icons/lock-closed.svg +3 -0
- data/app/assets/images/jet_ui/icons/lock-open.svg +3 -0
- data/app/assets/images/jet_ui/icons/magnifying-glass-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/magnifying-glass-minus.svg +3 -0
- data/app/assets/images/jet_ui/icons/magnifying-glass-plus.svg +3 -0
- data/app/assets/images/jet_ui/icons/magnifying-glass.svg +3 -0
- data/app/assets/images/jet_ui/icons/map-pin.svg +4 -0
- data/app/assets/images/jet_ui/icons/map.svg +3 -0
- data/app/assets/images/jet_ui/icons/megaphone.svg +3 -0
- data/app/assets/images/jet_ui/icons/microphone.svg +3 -0
- data/app/assets/images/jet_ui/icons/minus-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/minus-small.svg +3 -0
- data/app/assets/images/jet_ui/icons/minus.svg +3 -0
- data/app/assets/images/jet_ui/icons/moon.svg +3 -0
- data/app/assets/images/jet_ui/icons/musical-note.svg +3 -0
- data/app/assets/images/jet_ui/icons/newspaper.svg +3 -0
- data/app/assets/images/jet_ui/icons/no-symbol.svg +3 -0
- data/app/assets/images/jet_ui/icons/numbered-list.svg +3 -0
- data/app/assets/images/jet_ui/icons/paint-brush.svg +3 -0
- data/app/assets/images/jet_ui/icons/paper-airplane.svg +3 -0
- data/app/assets/images/jet_ui/icons/paper-clip.svg +3 -0
- data/app/assets/images/jet_ui/icons/pause-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/pause.svg +3 -0
- data/app/assets/images/jet_ui/icons/pencil-square.svg +3 -0
- data/app/assets/images/jet_ui/icons/pencil.svg +3 -0
- data/app/assets/images/jet_ui/icons/percent-badge.svg +3 -0
- data/app/assets/images/jet_ui/icons/phone-arrow-down-left.svg +3 -0
- data/app/assets/images/jet_ui/icons/phone-arrow-up-right.svg +3 -0
- data/app/assets/images/jet_ui/icons/phone-x-mark.svg +3 -0
- data/app/assets/images/jet_ui/icons/phone.svg +3 -0
- data/app/assets/images/jet_ui/icons/photo.svg +3 -0
- data/app/assets/images/jet_ui/icons/play-circle.svg +4 -0
- data/app/assets/images/jet_ui/icons/play-pause.svg +3 -0
- data/app/assets/images/jet_ui/icons/play.svg +3 -0
- data/app/assets/images/jet_ui/icons/plus-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/plus-small.svg +3 -0
- data/app/assets/images/jet_ui/icons/plus.svg +3 -0
- data/app/assets/images/jet_ui/icons/power.svg +3 -0
- data/app/assets/images/jet_ui/icons/presentation-chart-bar.svg +3 -0
- data/app/assets/images/jet_ui/icons/presentation-chart-line.svg +3 -0
- data/app/assets/images/jet_ui/icons/printer.svg +3 -0
- data/app/assets/images/jet_ui/icons/puzzle-piece.svg +3 -0
- data/app/assets/images/jet_ui/icons/qr-code.svg +13 -0
- data/app/assets/images/jet_ui/icons/question-mark-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/queue-list.svg +3 -0
- data/app/assets/images/jet_ui/icons/radio.svg +3 -0
- data/app/assets/images/jet_ui/icons/receipt-percent.svg +3 -0
- data/app/assets/images/jet_ui/icons/receipt-refund.svg +3 -0
- data/app/assets/images/jet_ui/icons/rectangle-group.svg +5 -0
- data/app/assets/images/jet_ui/icons/rectangle-stack.svg +3 -0
- data/app/assets/images/jet_ui/icons/rocket-launch.svg +3 -0
- data/app/assets/images/jet_ui/icons/rss.svg +3 -0
- data/app/assets/images/jet_ui/icons/scale.svg +3 -0
- data/app/assets/images/jet_ui/icons/scissors.svg +3 -0
- data/app/assets/images/jet_ui/icons/server-stack.svg +3 -0
- data/app/assets/images/jet_ui/icons/server.svg +3 -0
- data/app/assets/images/jet_ui/icons/share.svg +3 -0
- data/app/assets/images/jet_ui/icons/shield-check.svg +3 -0
- data/app/assets/images/jet_ui/icons/shield-exclamation.svg +3 -0
- data/app/assets/images/jet_ui/icons/shopping-bag.svg +3 -0
- data/app/assets/images/jet_ui/icons/shopping-cart.svg +3 -0
- data/app/assets/images/jet_ui/icons/signal-slash.svg +3 -0
- data/app/assets/images/jet_ui/icons/signal.svg +3 -0
- data/app/assets/images/jet_ui/icons/slash.svg +3 -0
- data/app/assets/images/jet_ui/icons/sparkles.svg +5 -0
- data/app/assets/images/jet_ui/icons/speaker-wave.svg +3 -0
- data/app/assets/images/jet_ui/icons/speaker-x-mark.svg +3 -0
- data/app/assets/images/jet_ui/icons/spinner.svg +1 -0
- data/app/assets/images/jet_ui/icons/square-2-stack.svg +3 -0
- data/app/assets/images/jet_ui/icons/square-3-stack-3d.svg +3 -0
- data/app/assets/images/jet_ui/icons/squares-2x2.svg +6 -0
- data/app/assets/images/jet_ui/icons/squares-plus.svg +3 -0
- data/app/assets/images/jet_ui/icons/star.svg +3 -0
- data/app/assets/images/jet_ui/icons/stop-circle.svg +4 -0
- data/app/assets/images/jet_ui/icons/stop.svg +3 -0
- data/app/assets/images/jet_ui/icons/strikethrough.svg +3 -0
- data/app/assets/images/jet_ui/icons/sun.svg +3 -0
- data/app/assets/images/jet_ui/icons/swatch.svg +3 -0
- data/app/assets/images/jet_ui/icons/table-cells.svg +3 -0
- data/app/assets/images/jet_ui/icons/tag.svg +4 -0
- data/app/assets/images/jet_ui/icons/ticket.svg +3 -0
- data/app/assets/images/jet_ui/icons/trash.svg +3 -0
- data/app/assets/images/jet_ui/icons/trophy.svg +3 -0
- data/app/assets/images/jet_ui/icons/truck.svg +3 -0
- data/app/assets/images/jet_ui/icons/tv.svg +3 -0
- data/app/assets/images/jet_ui/icons/underline.svg +3 -0
- data/app/assets/images/jet_ui/icons/user-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/user-group.svg +3 -0
- data/app/assets/images/jet_ui/icons/user-minus.svg +3 -0
- data/app/assets/images/jet_ui/icons/user-plus.svg +3 -0
- data/app/assets/images/jet_ui/icons/user.svg +4 -0
- data/app/assets/images/jet_ui/icons/users.svg +3 -0
- data/app/assets/images/jet_ui/icons/variable.svg +3 -0
- data/app/assets/images/jet_ui/icons/video-camera-slash.svg +3 -0
- data/app/assets/images/jet_ui/icons/video-camera.svg +3 -0
- data/app/assets/images/jet_ui/icons/view-columns.svg +3 -0
- data/app/assets/images/jet_ui/icons/viewfinder-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/wallet.svg +3 -0
- data/app/assets/images/jet_ui/icons/wifi.svg +3 -0
- data/app/assets/images/jet_ui/icons/window.svg +3 -0
- data/app/assets/images/jet_ui/icons/wrench-screwdriver.svg +3 -0
- data/app/assets/images/jet_ui/icons/wrench.svg +4 -0
- data/app/assets/images/jet_ui/icons/x-circle.svg +3 -0
- data/app/assets/images/jet_ui/icons/x-mark.svg +3 -0
- data/app/assets/javascripts/jet_ui/clipboard_controller.js +46 -0
- data/app/assets/javascripts/jet_ui/drawer_controller.js +70 -0
- data/app/assets/javascripts/jet_ui/drawers_controller.js +83 -0
- data/app/assets/javascripts/jet_ui/dropdown_controller.js +95 -0
- data/app/assets/javascripts/jet_ui/flash_controller.js +34 -0
- data/app/assets/javascripts/jet_ui/modal_controller.js +35 -0
- data/app/assets/javascripts/jet_ui/modals_controller.js +30 -0
- data/app/assets/javascripts/jet_ui/popover_controller.js +95 -0
- data/app/assets/javascripts/jet_ui/tooltip_controller.js +107 -0
- data/app/assets/javascripts/jet_ui/turbo_confirm_controller.js +25 -0
- data/app/assets/stylesheets/jet_ui/accordion.css +24 -0
- data/app/assets/stylesheets/jet_ui/alert.css +27 -0
- data/app/assets/stylesheets/jet_ui/avatar.css +15 -0
- data/app/assets/stylesheets/jet_ui/badge.css +22 -0
- data/app/assets/stylesheets/jet_ui/breadcrumbs.css +28 -0
- data/app/assets/stylesheets/jet_ui/btn.css +88 -0
- data/app/assets/stylesheets/jet_ui/card.css +61 -0
- data/app/assets/stylesheets/jet_ui/divider.css +21 -0
- data/app/assets/stylesheets/jet_ui/drawer.css +46 -0
- data/app/assets/stylesheets/jet_ui/dropdown.css +33 -0
- data/app/assets/stylesheets/jet_ui/empty.css +25 -0
- data/app/assets/stylesheets/jet_ui/flash.css +50 -0
- data/app/assets/stylesheets/jet_ui/group.css +40 -0
- data/app/assets/stylesheets/jet_ui/header.css +65 -0
- data/app/assets/stylesheets/jet_ui/icon.css +11 -0
- data/app/assets/stylesheets/jet_ui/list.css +31 -0
- data/app/assets/stylesheets/jet_ui/modal.css +47 -0
- data/app/assets/stylesheets/jet_ui/navbar.css +36 -0
- data/app/assets/stylesheets/jet_ui/pagy.css +54 -0
- data/app/assets/stylesheets/jet_ui/popover.css +51 -0
- data/app/assets/stylesheets/jet_ui/sidebar.css +35 -0
- data/app/assets/stylesheets/jet_ui/stat.css +23 -0
- data/app/assets/stylesheets/jet_ui/stepper.css +82 -0
- data/app/assets/stylesheets/jet_ui/table.css +68 -0
- data/app/assets/stylesheets/jet_ui/tabs.css +32 -0
- data/app/assets/stylesheets/jet_ui/theme.css +174 -0
- data/app/assets/stylesheets/jet_ui/timeline.css +45 -0
- data/app/assets/stylesheets/jet_ui/tooltip.css +33 -0
- data/app/assets/stylesheets/jet_ui.css +28 -0
- data/app/components/jet_ui/accordion/body_component.rb +21 -0
- data/app/components/jet_ui/accordion/component.rb +24 -0
- data/app/components/jet_ui/accordion/summary_component.rb +29 -0
- data/app/components/jet_ui/alert/component.rb +29 -0
- data/app/components/jet_ui/alert/description_component.rb +21 -0
- data/app/components/jet_ui/alert/icon_component.rb +21 -0
- data/app/components/jet_ui/alert/title_component.rb +21 -0
- data/app/components/jet_ui/avatar/component.rb +54 -0
- data/app/components/jet_ui/badge/component.rb +35 -0
- data/app/components/jet_ui/base_component.rb +6 -0
- data/app/components/jet_ui/breadcrumbs/component.rb +18 -0
- data/app/components/jet_ui/breadcrumbs/item_component.rb +25 -0
- data/app/components/jet_ui/btn/component.rb +51 -0
- data/app/components/jet_ui/card/body_component.rb +24 -0
- data/app/components/jet_ui/card/component.rb +24 -0
- data/app/components/jet_ui/card/footer_component.rb +48 -0
- data/app/components/jet_ui/card/header_component.rb +48 -0
- data/app/components/jet_ui/card/subtitle_component.rb +24 -0
- data/app/components/jet_ui/card/title_component.rb +24 -0
- data/app/components/jet_ui/clipboard/component.rb +58 -0
- data/app/components/jet_ui/divider/component.rb +30 -0
- data/app/components/jet_ui/drawer/body_component.rb +21 -0
- data/app/components/jet_ui/drawer/component.rb +54 -0
- data/app/components/jet_ui/drawer/footer_component.rb +45 -0
- data/app/components/jet_ui/drawer/header_component.rb +46 -0
- data/app/components/jet_ui/dropdown/button_component.rb +24 -0
- data/app/components/jet_ui/dropdown/component.rb +28 -0
- data/app/components/jet_ui/dropdown/divider_component.rb +21 -0
- data/app/components/jet_ui/dropdown/link_component.rb +29 -0
- data/app/components/jet_ui/dropdown/menu_component.rb +25 -0
- data/app/components/jet_ui/dropdown/title_component.rb +21 -0
- data/app/components/jet_ui/dropdown/trigger_component.rb +28 -0
- data/app/components/jet_ui/empty/actions_component.rb +19 -0
- data/app/components/jet_ui/empty/component.rb +15 -0
- data/app/components/jet_ui/empty/description_component.rb +15 -0
- data/app/components/jet_ui/empty/icon_component.rb +18 -0
- data/app/components/jet_ui/empty/title_component.rb +15 -0
- data/app/components/jet_ui/flash/component.html.erb +14 -0
- data/app/components/jet_ui/flash/component.rb +44 -0
- data/app/components/jet_ui/group/component.rb +26 -0
- data/app/components/jet_ui/header/actions_component.rb +21 -0
- data/app/components/jet_ui/header/component.rb +35 -0
- data/app/components/jet_ui/header/heading_component.rb +21 -0
- data/app/components/jet_ui/header/subtitle_component.rb +21 -0
- data/app/components/jet_ui/header/title_component.rb +21 -0
- data/app/components/jet_ui/icon/component.rb +46 -0
- data/app/components/jet_ui/list/action_component.rb +21 -0
- data/app/components/jet_ui/list/component.rb +29 -0
- data/app/components/jet_ui/list/content_component.rb +21 -0
- data/app/components/jet_ui/list/icon_component.rb +25 -0
- data/app/components/jet_ui/list/item_component.rb +21 -0
- data/app/components/jet_ui/modal/body_component.rb +21 -0
- data/app/components/jet_ui/modal/component.rb +54 -0
- data/app/components/jet_ui/modal/footer_component.rb +45 -0
- data/app/components/jet_ui/modal/header_component.rb +46 -0
- data/app/components/jet_ui/navbar/actions_component.rb +21 -0
- data/app/components/jet_ui/navbar/brand_component.rb +21 -0
- data/app/components/jet_ui/navbar/component.rb +22 -0
- data/app/components/jet_ui/navbar/content_component.rb +21 -0
- data/app/components/jet_ui/navbar/main_component.rb +21 -0
- data/app/components/jet_ui/pagy/component.rb +38 -0
- data/app/components/jet_ui/popover/component.rb +29 -0
- data/app/components/jet_ui/popover/content_component.rb +23 -0
- data/app/components/jet_ui/popover/trigger_component.rb +20 -0
- data/app/components/jet_ui/sidebar/component.rb +27 -0
- data/app/components/jet_ui/sidebar/link_component.rb +44 -0
- data/app/components/jet_ui/sidebar/menu_component.rb +21 -0
- data/app/components/jet_ui/sidebar/section_component.rb +21 -0
- data/app/components/jet_ui/sidebar/title_component.rb +21 -0
- data/app/components/jet_ui/spinner/component.rb +16 -0
- data/app/components/jet_ui/stat/component.rb +21 -0
- data/app/components/jet_ui/stat/description_component.rb +57 -0
- data/app/components/jet_ui/stat/label_component.rb +21 -0
- data/app/components/jet_ui/stat/value_component.rb +21 -0
- data/app/components/jet_ui/stepper/component.rb +18 -0
- data/app/components/jet_ui/stepper/step_component.rb +69 -0
- data/app/components/jet_ui/table/component.rb +37 -0
- data/app/components/jet_ui/table/tbody_component.rb +15 -0
- data/app/components/jet_ui/table/td_component.rb +29 -0
- data/app/components/jet_ui/table/tfoot_component.rb +15 -0
- data/app/components/jet_ui/table/th_component.rb +27 -0
- data/app/components/jet_ui/table/thead_component.rb +15 -0
- data/app/components/jet_ui/table/tr_component.rb +15 -0
- data/app/components/jet_ui/tabs/component.rb +30 -0
- data/app/components/jet_ui/tabs/item_component.rb +34 -0
- data/app/components/jet_ui/timeline/component.rb +15 -0
- data/app/components/jet_ui/timeline/content_component.rb +15 -0
- data/app/components/jet_ui/timeline/dot_component.rb +37 -0
- data/app/components/jet_ui/timeline/item_component.rb +15 -0
- data/app/components/jet_ui/timeline/time_component.rb +15 -0
- data/app/components/jet_ui/tooltip/component.rb +34 -0
- data/app/components/jet_ui/turbo_confirm/component.html.erb +20 -0
- data/app/components/jet_ui/turbo_confirm/component.rb +8 -0
- data/app/helpers/jet_ui_helper.rb +37 -0
- data/lib/generators/jet_ui/eject/USAGE +20 -0
- data/lib/generators/jet_ui/eject/eject_generator.rb +376 -0
- data/lib/generators/jet_ui/install/USAGE +11 -0
- data/lib/generators/jet_ui/install/install_generator.rb +121 -0
- data/lib/jet_ui/engine.rb +32 -0
- data/lib/jet_ui/version.rb +5 -0
- data/lib/jet_ui.rb +5 -0
- 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
|